| package doumeemes.api.ext; | 
|   | 
| import doumeemes.api.BaseController; | 
| import doumeemes.core.annotation.excel.ExcelExporter; | 
| import doumeemes.core.annotation.pr.PreventRepeat; | 
| import doumeemes.core.model.ApiResponse; | 
| import doumeemes.core.model.PageData; | 
| import doumeemes.core.model.PageWrap; | 
| import doumeemes.core.utils.Constants; | 
| import doumeemes.dao.business.dto.QueryUnitExtDTO; | 
| import doumeemes.dao.business.model.Unit; | 
| import doumeemes.dao.business.vo.UnitExtListVO; | 
| import doumeemes.service.business.UnitExtService; | 
| import doumeemes.service.business.UnitService; | 
| import io.swagger.annotations.Api; | 
| import io.swagger.annotations.ApiImplicitParam; | 
| import io.swagger.annotations.ApiImplicitParams; | 
| import io.swagger.annotations.ApiOperation; | 
| import org.apache.shiro.authz.annotation.RequiresPermissions; | 
| import org.springframework.beans.factory.annotation.Autowired; | 
| import org.springframework.web.bind.annotation.*; | 
|   | 
| import javax.servlet.http.HttpServletResponse; | 
| import java.util.ArrayList; | 
| import java.util.Date; | 
| import java.util.List; | 
|   | 
| /** | 
|  * 计量单位信息接口 | 
|  * @author 江蹄蹄 | 
|  * @date 2022/05/12 10:18 | 
|  */ | 
| @RestController | 
| @RequestMapping("/ext/unitExt") | 
| @Api(tags = "计量单位信息接口") | 
| public class UnitExtController extends BaseController { | 
|   | 
|     @Autowired | 
|     private UnitExtService unitExtService; | 
|      | 
|     @Autowired | 
|     private UnitService unitService; | 
|   | 
|     @PreventRepeat | 
|     @ApiOperation("新建") | 
|     @PostMapping("/create") | 
|     @RequiresPermissions("ext:unitext:create") | 
|     public ApiResponse create(@RequestBody Unit unit) { | 
|         Integer result=unitService.create(unit); | 
|         if(result==0){ | 
|             return ApiResponse.failed("同一单位类型下名称不能重复"); | 
|         }else{ | 
|             return ApiResponse.success(result); | 
|         } | 
|   | 
|     } | 
|   | 
|     @ApiOperation("根据ID删除") | 
|     @GetMapping("/delete/{id}") | 
|     @RequiresPermissions("ext:unitext:delete") | 
|     public ApiResponse deleteById(@PathVariable Integer id) { | 
|         unitService.deleteById(id); | 
|         return ApiResponse.success(null); | 
|     } | 
|   | 
|     @ApiOperation("批量删除") | 
|     @GetMapping("/delete/batch") | 
|     @RequiresPermissions("ext:unitext:delete") | 
|     public ApiResponse deleteByIds(@RequestParam String ids) { | 
|         String [] idArray = ids.split(","); | 
|         List<Integer> idList = new ArrayList<>(); | 
|         for (String id : idArray) { | 
|             idList.add(Integer.valueOf(id)); | 
|         } | 
|         unitService.deleteByIdInBatch(idList); | 
|         return ApiResponse.success(null); | 
|     } | 
|   | 
|     @ApiOperation("根据ID修改") | 
|     @PostMapping("/updateById") | 
|     @RequiresPermissions("ext:unitext:update") | 
|     public ApiResponse updateById(@RequestBody Unit unit) { | 
|         unitService.updateById(unit); | 
|         return ApiResponse.success(null); | 
|     } | 
|   | 
|     @ApiOperation("分页查询") | 
|     @PostMapping("/page") | 
|     @RequiresPermissions("ext:unitext:query") | 
|     public ApiResponse<PageData<UnitExtListVO>> findPage (@RequestBody PageWrap<QueryUnitExtDTO> pageWrap) { | 
|         return ApiResponse.success(unitExtService.findPage(pageWrap)); | 
|     } | 
|   | 
|     @ApiOperation("导出Excel") | 
|     @PostMapping("/exportExcel") | 
|     @RequiresPermissions("ext:unitext:exportExcel") | 
|     public void exportExcel (@RequestBody PageWrap<QueryUnitExtDTO> pageWrap, HttpServletResponse response) { | 
|         ExcelExporter.build(UnitExtListVO.class).export(unitExtService.findPage(pageWrap).getRecords(), "计量单位信息", response); | 
|     } | 
|   | 
|     @ApiOperation("根据ID查询") | 
|     @GetMapping("/{id}") | 
|     @RequiresPermissions("ext:unitext:query") | 
|     public ApiResponse findById(@PathVariable Integer id) { | 
|         return ApiResponse.success(unitService.findById(id)); | 
|     } | 
|   | 
|   | 
|   | 
|     @ApiOperation("物料单位状态变更") | 
|     @ApiImplicitParams({ | 
|             @ApiImplicitParam(value = "ids,逗号分割", name = "ids", paramType = "query", required = true, dataType = "String"), | 
|             @ApiImplicitParam(value = "状态 0禁用 1启用", name = "status", paramType = "query", required = true, dataType = "String") | 
|     }) | 
|     @GetMapping("/updateUnitStatus") | 
|     @RequiresPermissions("ext:unitext:updateUnitStatus") | 
|     public ApiResponse updateUnitStatus(@RequestParam String ids,@RequestParam String status) { | 
|         String [] idArray = ids.split(","); | 
|         List<Unit> idList = new ArrayList<>(); | 
|         for (String id : idArray) { | 
|             Unit unit= unitService.findById(Integer.valueOf(id)); | 
|             unit.setId(Integer.valueOf(id)); | 
|             unit.setStatus(Integer.valueOf(status)); | 
|             unit.setUpdateTime(new Date()); | 
|             unit.setUpdateUser(getLoginUser().getId()); | 
|             idList.add(unit); | 
|         } | 
|         unitService.updateByIdInBatch(idList); | 
|         return ApiResponse.success(null); | 
|     } | 
|   | 
|   | 
|     @ApiOperation("根据物料单位类型查询所有的数据") | 
|     @PostMapping("/getCollectionByType") | 
|     public ApiResponse<List<UnitExtListVO>> getCollectionByType (@RequestBody QueryUnitExtDTO pageWrap) { | 
|         pageWrap.setStatus(Constants.ONE); | 
|         pageWrap.setDeleted(Constants.ZERO); | 
|         pageWrap.setRootDepartId(getLoginUser().getRootDepartment().getId()); | 
|         return ApiResponse.success(unitExtService.getUnitListByOrg(pageWrap)); | 
|     } | 
| } |