package com.aps.core.controller; import java.util.List; import java.io.IOException; import com.aps.common.core.utils.uuid.IdUtils; import com.aps.common.security.utils.DictUtils; import com.aps.core.domain.ApsGasPipingPlanTemp; import com.aps.core.domain.ApsPartPlanTemp; import com.aps.core.service.IApsGasPipingPlanTempService; import com.aps.system.api.domain.SysDictData; import jakarta.servlet.http.HttpServletResponse; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.PostMapping; import org.springframework.web.bind.annotation.PutMapping; import org.springframework.web.bind.annotation.DeleteMapping; import org.springframework.web.bind.annotation.PathVariable; import org.springframework.web.bind.annotation.RequestBody; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; import com.aps.common.log.annotation.Log; import com.aps.common.log.enums.BusinessType; import com.aps.common.security.annotation.RequiresPermissions; import com.aps.core.domain.ApsGasPipingPlan; import com.aps.core.service.IApsGasPipingPlanService; import com.aps.common.core.web.controller.BaseController; import com.aps.common.core.web.domain.AjaxResult; import com.aps.common.core.utils.poi.ExcelUtil; import com.aps.common.core.web.page.TableDataInfo; import org.springframework.web.multipart.MultipartFile; /** * 气体管路计划管理Controller * * @author wwj * @date 2025-04-09 */ @RestController @RequestMapping("/gasPiping") public class ApsGasPipingPlanController extends BaseController { @Autowired private IApsGasPipingPlanService apsGasPipingPlanService; @Autowired private IApsGasPipingPlanTempService apsGasPipingPlanTempService; /** * 查询气体管路计划管理列表 */ @RequiresPermissions("gasPiping:gasPiping:list") @GetMapping("/list") public TableDataInfo list(ApsGasPipingPlan apsGasPipingPlan) { // startPage(); List list = apsGasPipingPlanService.selectApsGasPipingPlanList(apsGasPipingPlan); return getDataTable(list); } /** * 导出气体管路计划管理列表 */ @RequiresPermissions("gasPiping:gasPiping:export") @Log(title = "气体管路计划管理", businessType = BusinessType.EXPORT) @PostMapping("/export") public void export(HttpServletResponse response, ApsGasPipingPlan apsGasPipingPlan) { List apsGasPipingPlans = apsGasPipingPlanService.selectApsGasPipingPlanList(apsGasPipingPlan); List list = DictUtils.getDictCache("aps_is_suspended"); for (int i = 0; i < apsGasPipingPlans.size(); i++) { for (int j = 0; j < list.size(); j++) { if (apsGasPipingPlans.get(i).getIsSuspended().equals(Integer.parseInt(list.get(j).getDictValue()))) { apsGasPipingPlans.get(i).setIsSuspendedTxt(list.get(j).getDictLabel()); break; } } } ExcelUtil util = new ExcelUtil(ApsGasPipingPlan.class); util.exportExcel(response, apsGasPipingPlans, "气体管路计划管理数据"); } /** * 获取气体管路计划管理详细信息 */ @RequiresPermissions("gasPiping:gasPiping:query") @GetMapping(value = "/{id}") public AjaxResult getInfo(@PathVariable("id") String id) { return success(apsGasPipingPlanService.selectApsGasPipingPlanById(id)); } /** * 新增气体管路计划管理 */ @RequiresPermissions("gasPiping:gasPiping:add") @Log(title = "气体管路计划管理", businessType = BusinessType.INSERT) @PostMapping public AjaxResult add(@RequestBody ApsGasPipingPlan apsGasPipingPlan) { return toAjax(apsGasPipingPlanService.insertApsGasPipingPlan(apsGasPipingPlan)); } /** * 修改气体管路计划管理 */ @RequiresPermissions("gasPiping:gasPiping:edit") @Log(title = "气体管路计划管理", businessType = BusinessType.UPDATE) @PutMapping public AjaxResult edit(@RequestBody ApsGasPipingPlan apsGasPipingPlan) { return toAjax(apsGasPipingPlanService.updateApsGasPipingPlan(apsGasPipingPlan)); } /** * 删除气体管路计划管理 */ @RequiresPermissions("gasPiping:gasPiping:remove") @Log(title = "气体管路计划管理", businessType = BusinessType.DELETE) @DeleteMapping("/{ids}") public AjaxResult remove(@PathVariable String[] ids) { return toAjax(apsGasPipingPlanService.deleteApsGasPipingPlanByIds(ids)); } /** * 气体管路计划导入 */ @PostMapping("/importData") public AjaxResult importData(MultipartFile file) throws Exception { ExcelUtil util = new ExcelUtil(ApsGasPipingPlanTemp.class); List apsGasPipingPlanTemps = util.importExcel(file.getInputStream()); //判断导入数据是否为空 if (apsGasPipingPlanTemps.size() > 0) { String batchNum= IdUtils.fastUUID(); List list = DictUtils.getDictCache("aps_is_suspended"); for (int i = 0; i < apsGasPipingPlanTemps.size(); i++) { for (int j = 0; j < list.size(); j++) { if (apsGasPipingPlanTemps.get(i).getIsSuspendedTxt().equals(list.get(j).getDictLabel())) { apsGasPipingPlanTemps.get(i).setIsSuspended(Integer.parseInt(list.get(j).getDictValue())); break; } } //插入版本号 apsGasPipingPlanTemps.get(i).setBatchNumber(batchNum); //插入临时表 apsGasPipingPlanTempService.insertApsGasPipingPlanTemp(apsGasPipingPlanTemps.get(i)); } return AjaxResult.success("导入成功",batchNum); } else { return AjaxResult.error("模板内容为空"); } } /*** * @Description: 确认上传 * @Param: [apsPartPlan] * @return: com.aps.common.core.web.domain.AjaxResult * @Author: wwj * @Date: 2025/4/9 */ @GetMapping("/confirmGasPiping") public AjaxResult confirmGasPiping(ApsGasPipingPlanTemp apsGasPipingPlanTemp) { return toAjax(apsGasPipingPlanService.confirmGasPiping(apsGasPipingPlanTemp)); } }