package org.jeecg.modules.spare.controller; import java.util.Arrays; import java.util.List; import java.util.Map; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import org.jeecg.common.api.vo.Result; import org.jeecg.common.system.query.QueryGenerator; import org.jeecg.modules.spare.entity.SparePartOutbound; import org.jeecg.modules.spare.entity.SparePartPurchaseStorage; import org.jeecg.modules.spare.entity.SparePartPurchaseStorageDetail; import org.jeecg.modules.spare.service.ISparePartPurchaseStorageDetailService; import org.jeecg.modules.spare.service.ISparePartPurchaseStorageService; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.baomidou.mybatisplus.core.metadata.IPage; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import lombok.extern.slf4j.Slf4j; import org.jeecg.common.system.base.controller.JeecgController; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.context.annotation.Lazy; import org.springframework.transaction.annotation.Transactional; import org.springframework.web.bind.annotation.*; import org.springframework.web.servlet.ModelAndView; import io.swagger.annotations.Api; import io.swagger.annotations.ApiOperation; import org.jeecg.common.aspect.annotation.AutoLog; /** * @Description: mom_eam_spare_part_purchase_storage * @Author: jeecg-boot * @Date: 2023-06-27 * @Version: V1.0 */ @Api(tags = "mom_eam_spare_part_purchase_storage") @RestController @RequestMapping("/spare/sparePartPurchaseStorage") @Slf4j public class SparePartPurchaseStorageController extends JeecgController { @Autowired private ISparePartPurchaseStorageService sparePartPurchaseStorageService; @Autowired @Lazy private ISparePartPurchaseStorageDetailService sparePartPurchaseStorageDetailService; /** * 分页列表查询 * * @param sparePartPurchaseStorage * @param pageNo * @param pageSize * @param req * @return */ //@AutoLog(value = "mom_eam_spare_part_purchase_storage-分页列表查询") @ApiOperation(value = "mom_eam_spare_part_purchase_storage-分页列表查询", notes = "mom_eam_spare_part_purchase_storage-分页列表查询") @GetMapping(value = "/list") public Result> queryPageList(SparePartPurchaseStorage sparePartPurchaseStorage, @RequestParam(name = "pageNo", defaultValue = "1") Integer pageNo, @RequestParam(name = "pageSize", defaultValue = "10") Integer pageSize, HttpServletRequest req) { QueryWrapper queryWrapper = QueryGenerator.initQueryWrapper(sparePartPurchaseStorage, req.getParameterMap()); Page page = new Page(pageNo, pageSize); IPage pageList = sparePartPurchaseStorageService.page(page, queryWrapper); for (SparePartPurchaseStorage record : pageList.getRecords()) { String id = record.getId(); List> storageDeatilList = sparePartPurchaseStorageDetailService.getSparePartPurchaseStorageDeatilList(id); record.setSparePartPurchaseStorageDeatilList(storageDeatilList); String warehouseId = record.getWarehouseId(); List warehouselocationManage = sparePartPurchaseStorageService.getWarehouselocationManage(warehouseId); if (warehouselocationManage.size() > 0) { record.setLocationManage(warehouselocationManage.get(0)); } } return Result.OK(pageList); } /** * 添加 * * @param sparePartPurchaseStorage * @return */ @AutoLog(value = "mom_eam_spare_part_purchase_storage-添加") @ApiOperation(value = "mom_eam_spare_part_purchase_storage-添加", notes = "mom_eam_spare_part_purchase_storage-添加") @PostMapping(value = "/add") @Transactional(rollbackFor = {Exception.class}) public Result add(@RequestBody SparePartPurchaseStorage sparePartPurchaseStorage) { sparePartPurchaseStorage.setType("1"); sparePartPurchaseStorage.setStatus("0"); sparePartPurchaseStorageService.save(sparePartPurchaseStorage); List sparePartPurchaseStorageDetails = sparePartPurchaseStorage.getSparePartPurchaseStorageDetails(); for (SparePartPurchaseStorageDetail sparePartPurchaseStorageDetail : sparePartPurchaseStorageDetails) { sparePartPurchaseStorageDetail.setId(""); sparePartPurchaseStorageDetail.setStatus("0"); sparePartPurchaseStorageDetail.setWarehouseId(sparePartPurchaseStorage.getWarehouseId()); sparePartPurchaseStorageDetail.setSparePartPurchaseStorageId(sparePartPurchaseStorage.getId()); sparePartPurchaseStorageDetailService.save(sparePartPurchaseStorageDetail); } return Result.OK("添加成功!"); } /** * 编辑 * * @param sparePartPurchaseStorage * @return */ @AutoLog(value = "mom_eam_spare_part_purchase_storage-编辑") @ApiOperation(value = "mom_eam_spare_part_purchase_storage-编辑", notes = "mom_eam_spare_part_purchase_storage-编辑") //@RequiresPermissions("org.jeecg.modules:mom_eam_spare_part_purchase_storage:edit") @RequestMapping(value = "/edit", method = {RequestMethod.PUT, RequestMethod.POST}) public Result edit(@RequestBody SparePartPurchaseStorage sparePartPurchaseStorage) { sparePartPurchaseStorageService.updateById(sparePartPurchaseStorage); //1.删除备件信息明细 List list = sparePartPurchaseStorageDetailService.lambdaQuery() .eq(SparePartPurchaseStorageDetail::getSparePartPurchaseStorageId, sparePartPurchaseStorage.getId()) .eq(SparePartPurchaseStorageDetail::getDelFlag, 0).list(); for (SparePartPurchaseStorageDetail sparePartPurchaseStorageDetail : list) { sparePartPurchaseStorageDetailService.removeById(sparePartPurchaseStorageDetail); } List sparePartPurchaseStorageDetails = sparePartPurchaseStorage.getSparePartPurchaseStorageDetails(); for (SparePartPurchaseStorageDetail sparePartPurchaseStorageDetail : sparePartPurchaseStorageDetails) { sparePartPurchaseStorageDetail.setId(""); sparePartPurchaseStorageDetail.setStatus("0"); sparePartPurchaseStorageDetail.setSparePartPurchaseStorageId(sparePartPurchaseStorage.getId()); sparePartPurchaseStorageDetailService.save(sparePartPurchaseStorageDetail); } return Result.OK("编辑成功!"); } /** * 通过id删除 * * @param id * @return */ @AutoLog(value = "mom_eam_spare_part_purchase_storage-通过id删除") @ApiOperation(value = "mom_eam_spare_part_purchase_storage-通过id删除", notes = "mom_eam_spare_part_purchase_storage-通过id删除") //@RequiresPermissions("org.jeecg.modules:mom_eam_spare_part_purchase_storage:delete") @DeleteMapping(value = "/delete") public Result delete(@RequestParam(name = "id", required = true) String id) { sparePartPurchaseStorageService.removeById(id); //1.删除备件信息明细 List list = sparePartPurchaseStorageDetailService.lambdaQuery() .eq(SparePartPurchaseStorageDetail::getSparePartPurchaseStorageId, id) .eq(SparePartPurchaseStorageDetail::getDelFlag, 0).list(); for (SparePartPurchaseStorageDetail sparePartPurchaseStorageDetail : list) { sparePartPurchaseStorageDetailService.removeById(sparePartPurchaseStorageDetail); } return Result.OK("删除成功!"); } /** * 批量删除 * * @param ids * @return */ @AutoLog(value = "mom_eam_spare_part_purchase_storage-批量删除") @ApiOperation(value = "mom_eam_spare_part_purchase_storage-批量删除", notes = "mom_eam_spare_part_purchase_storage-批量删除") //@RequiresPermissions("org.jeecg.modules:mom_eam_spare_part_purchase_storage:deleteBatch") @DeleteMapping(value = "/deleteBatch") public Result deleteBatch(@RequestParam(name = "ids", required = true) String ids) { this.sparePartPurchaseStorageService.removeByIds(Arrays.asList(ids.split(","))); //1.删除备件信息明细 List list = sparePartPurchaseStorageDetailService.lambdaQuery() .in(SparePartPurchaseStorageDetail::getSparePartPurchaseStorageId, Arrays.asList(ids.split(","))) .eq(SparePartPurchaseStorageDetail::getDelFlag, 0).list(); for (SparePartPurchaseStorageDetail sparePartPurchaseStorageDetail : list) { sparePartPurchaseStorageDetailService.removeById(sparePartPurchaseStorageDetail); } return Result.OK("批量删除成功!"); } /** * 通过id查询 * * @param id * @return */ //@AutoLog(value = "mom_eam_spare_part_purchase_storage-通过id查询") @ApiOperation(value = "mom_eam_spare_part_purchase_storage-通过id查询", notes = "mom_eam_spare_part_purchase_storage-通过id查询") @GetMapping(value = "/queryById") public Result queryById(@RequestParam(name = "id", required = true) String id) { SparePartPurchaseStorage sparePartPurchaseStorage = sparePartPurchaseStorageService.getById(id); if (sparePartPurchaseStorage == null) { return Result.error("未找到对应数据"); } return Result.OK(sparePartPurchaseStorage); } /** * 导出excel * * @param request * @param sparePartPurchaseStorage */ //@RequiresPermissions("org.jeecg.modules:mom_eam_spare_part_purchase_storage:exportXls") @RequestMapping(value = "/exportXls") public ModelAndView exportXls(HttpServletRequest request, SparePartPurchaseStorage sparePartPurchaseStorage) { return super.exportXls(request, sparePartPurchaseStorage, SparePartPurchaseStorage.class, "mom_eam_spare_part_purchase_storage"); } /** * 通过excel导入数据 * * @param request * @param response * @return */ //@RequiresPermissions("mom_eam_spare_part_purchase_storage:importExcel") @RequestMapping(value = "/importExcel", method = RequestMethod.POST) public Result importExcel(HttpServletRequest request, HttpServletResponse response) { return super.importExcel(request, response, SparePartPurchaseStorage.class); } /** * 入库单提交、撤回、通过等操作 */ @RequestMapping(value = "/auditOperation", method = {RequestMethod.PUT, RequestMethod.POST}) public Result auditOperation(@RequestBody SparePartPurchaseStorage sparePartPurchaseStorage) { boolean b = sparePartPurchaseStorageService.updateById(sparePartPurchaseStorage); if (b) { return Result.OK("提交成功!"); } else { return Result.error("提交失败!"); } } /** * 备件领用申请单提交 * * @param sparePartPurchaseStorage * @return */ @AutoLog(value = "备件入库-提交") @ApiOperation(value = "备件入库-提交", notes = "备件入库-提交") @PostMapping(value = "/submit") public Result submit(@RequestBody SparePartPurchaseStorage sparePartPurchaseStorage) { sparePartPurchaseStorage.setStatus("1"); sparePartPurchaseStorageService.updateById(sparePartPurchaseStorage); return Result.OK("提交成功!"); } /** * 撤回 * * @param sparePartPurchaseStorage * @return */ @AutoLog(value = "备件入库-撤回") @ApiOperation(value = "备件入库-撤回", notes = "备件入库-撤回") @PostMapping(value = "/revocation") public Result revocation(@RequestBody SparePartPurchaseStorage sparePartPurchaseStorage) { String id = sparePartPurchaseStorage.getId(); sparePartPurchaseStorageService.revocation(id); return Result.OK("撤回成功!"); } /** * 审批通过 * * @param sparePartPurchaseStorage * @return */ @AutoLog(value = "备件入库-审批通过") @ApiOperation(value = "备件入库-审批通过", notes = "备件入库-审批通过") @PostMapping(value = "/approval") public Result approval(@RequestBody SparePartPurchaseStorage sparePartPurchaseStorage) { sparePartPurchaseStorageService.approval(sparePartPurchaseStorage); return Result.OK("审批通过!"); } /** * 驳回 * * @param sparePartPurchaseStorage * @return */ @AutoLog(value = "备件入库-驳回") @ApiOperation(value = "备件入库-驳回", notes = "备件入库-驳回") @PostMapping(value = "/reject") public Result reject(@RequestBody SparePartPurchaseStorage sparePartPurchaseStorage) { sparePartPurchaseStorageService.reject(sparePartPurchaseStorage); return Result.OK("驳回成功!"); } }