package com.by4cloud.platformx.device.controller; import cn.hutool.core.util.ArrayUtil; import cn.hutool.core.collection.CollUtil; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.baomidou.mybatisplus.core.toolkit.StringUtils; import com.baomidou.mybatisplus.core.toolkit.Wrappers; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.by4cloud.platformx.common.core.util.R; import com.by4cloud.platformx.common.log.annotation.SysLog; import com.by4cloud.platformx.device.constant.MaxSizeContant; import com.by4cloud.platformx.device.entity.*; import com.by4cloud.platformx.device.service.*; import com.by4cloud.platformx.device.util.NumUtils; import com.github.yulichang.adapter.base.ITableInfoAdapter; import org.springframework.security.access.prepost.PreAuthorize; import com.by4cloud.platformx.common.excel.annotation.ResponseExcel; import io.swagger.v3.oas.annotations.security.SecurityRequirement; import org.springdoc.api.annotations.ParameterObject; import org.springframework.http.HttpHeaders; import io.swagger.v3.oas.annotations.tags.Tag; import io.swagger.v3.oas.annotations.Operation; import lombok.RequiredArgsConstructor; import org.springframework.web.bind.annotation.*; import java.util.*; import java.util.stream.Collectors; /** * 年度投资计划主表 * * @author kdq * @date 2025-03-28 11:06:50 */ @RestController @RequiredArgsConstructor @RequestMapping("/investmentPlan" ) @Tag(description = "investmentPlan" , name = "年度投资计划主表管理" ) @SecurityRequirement(name = HttpHeaders.AUTHORIZATION) public class InvestmentPlanController { private final InvestmentPlanService investmentPlanService; private final InvestmentPlanItemService investmentPlanItemService; private final DeviceDemandPlanService deviceDemandPlanService; private final DeviceDemandSubService deviceDemandSubService; private final JcMaxSizeService maxSizeService; private final DeviceService deviceService; /** * 分页查询 * @param page 分页对象 * @param investmentPlan 年度投资计划主表 * @return */ @Operation(summary = "分页查询" , description = "分页查询" ) @GetMapping("/page" ) @PreAuthorize("@pms.hasPermission('device_investmentPlan_view')" ) public R getInvestmentPlanPage(@ParameterObject Page page, @ParameterObject InvestmentPlan investmentPlan) { LambdaQueryWrapper wrapper = Wrappers.lambdaQuery(); wrapper.eq(investmentPlan.getYear()!=null,InvestmentPlan::getYear,investmentPlan.getYear()); wrapper.like(StringUtils.isNotBlank(investmentPlan.getName()),InvestmentPlan::getName,investmentPlan.getName()); wrapper.orderByDesc(InvestmentPlan::getCreateTime); return R.ok(investmentPlanService.page(page, wrapper)); } /** * 通过id查询年度投资计划主表 * @param id id * @return R */ @Operation(summary = "通过id查询" , description = "通过id查询" ) @GetMapping("/{id}" ) @PreAuthorize("@pms.hasPermission('device_investmentPlan_view')" ) public R getById(@PathVariable("id" ) Long id) { Map map = new HashMap<>(); InvestmentPlan plan = investmentPlanService.getById(id); QueryWrapper wrapper = new QueryWrapper<>(); wrapper.lambda() .eq(InvestmentPlanItem::getPlanId,plan.getId()) .orderByAsc(InvestmentPlanItem::getMonth); List list = investmentPlanItemService.list(wrapper); List> resultList = new ArrayList<>(); for (Map.Entry> listEntry : list.stream().collect(Collectors.groupingBy(item -> item.getMonth())).entrySet()) { Integer month = listEntry.getKey(); List value = listEntry.getValue(); Map entry = new HashMap<>(); entry.put("month",month); entry.put("value",value); resultList.add(entry); } map.put("plan",plan); map.put("items",resultList); return R.ok(map); } /** * 新增年度投资计划主表 * @param investmentPlan 年度投资计划主表 * @return R */ @Operation(summary = "新增年度投资计划主表" , description = "新增年度投资计划主表" ) @SysLog("新增年度投资计划主表" ) @PostMapping @PreAuthorize("@pms.hasPermission('device_investmentPlan_add')" ) public R save(@RequestBody InvestmentPlan investmentPlan) { List subs = new ArrayList<>(); investmentPlan.setNumber(maxSizeService.nextNo(MaxSizeContant.TZPLAN_NUM)); investmentPlanService.save(investmentPlan); String planIds = investmentPlan.getPlanIds(); String[] split = planIds.split(","); for (String s : split) { DeviceDemandPlan demandPlan = deviceDemandPlanService.getById(Long.parseLong(s)); QueryWrapper wrapper = new QueryWrapper<>(); wrapper.lambda() .eq(DeviceDemandPlan::getPlanId,demandPlan.getId()); List list = deviceDemandPlanService.list(wrapper); List collect = list.stream().map(DeviceDemandPlan::getId).collect(Collectors.toList()); for (Long l : collect) { //合并子项 List byPlanId = deviceDemandSubService.getByPlanId(l); subs.addAll(byPlanId); } } List items = new ArrayList<>(); for (Map.Entry> integerListEntry : subs.stream().collect(Collectors.groupingBy(item -> item.getMonth())).entrySet()) { Integer month = integerListEntry.getKey(); List subList = integerListEntry.getValue(); for (Map.Entry> deviceEntry : subList.stream().collect(Collectors.groupingBy(item -> item.getDeviceId())).entrySet()) { Long deviceId = deviceEntry.getKey(); List value = deviceEntry.getValue(); double total = value.stream().mapToDouble(DeviceDemandSub::getPrice).sum(); Device device = deviceService.getById(deviceId); InvestmentPlanItem item = new InvestmentPlanItem(); item.setYear(value.get(0).getYear()); item.setPlanId(investmentPlan.getId()); item.setMonth(month); item.setDeviceId(deviceId); item.setNumber(device.getNumber()); item.setSpecification(device.getSpecification()); item.setNum(value.size()); item.setUnit(device.getUnit()); item.setPrice(device.getPrice()); item.setAmount(total); items.add(item); } } investmentPlanItemService.saveBatch(items); return R.ok(); } /** * 修改年度投资计划主表 * @param investmentPlan 年度投资计划主表 * @return R */ @Operation(summary = "修改年度投资计划主表" , description = "修改年度投资计划主表" ) @SysLog("修改年度投资计划主表" ) @PutMapping @PreAuthorize("@pms.hasPermission('device_investmentPlan_edit')" ) public R updateById(@RequestBody InvestmentPlan investmentPlan) { return R.ok(investmentPlanService.updateById(investmentPlan)); } /** * 通过id删除年度投资计划主表 * @param ids id列表 * @return R */ @Operation(summary = "通过id删除年度投资计划主表" , description = "通过id删除年度投资计划主表" ) @SysLog("通过id删除年度投资计划主表" ) @DeleteMapping @PreAuthorize("@pms.hasPermission('device_investmentPlan_del')" ) public R removeById(@RequestBody Long[] ids) { return R.ok(investmentPlanService.removeBatchByIds(CollUtil.toList(ids))); } /** * 导出excel 表格 * @param investmentPlan 查询条件 * @param ids 导出指定ID * @return excel 文件流 */ @ResponseExcel @GetMapping("/export") @PreAuthorize("@pms.hasPermission('device_investmentPlan_export')" ) public List export(InvestmentPlan investmentPlan,Long[] ids) { return investmentPlanService.list(Wrappers.lambdaQuery(investmentPlan).in(ArrayUtil.isNotEmpty(ids), InvestmentPlan::getId, ids)); } }