package com.vincent.rsf.server.manager.controller; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.vincent.rsf.framework.common.Cools; import com.vincent.rsf.framework.common.R; import com.vincent.rsf.server.common.utils.ExcelUtil; import com.vincent.rsf.server.common.annotation.OperationLog; import com.vincent.rsf.server.common.domain.BaseParam; import com.vincent.rsf.server.common.domain.KeyValVo; import com.vincent.rsf.server.common.domain.PageParam; import com.vincent.rsf.server.manager.entity.WaitPakinItemLog; import com.vincent.rsf.server.manager.entity.WaitPakinLog; import com.vincent.rsf.server.manager.service.WaitPakinItemLogService; import com.vincent.rsf.server.manager.service.WaitPakinLogService; import com.vincent.rsf.server.system.controller.BaseController; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.security.access.prepost.PreAuthorize; import org.springframework.web.bind.annotation.*; import javax.servlet.http.HttpServletResponse; import java.util.*; import java.util.stream.Collectors; @RestController public class WaitPakinLogController extends BaseController { @Autowired private WaitPakinLogService waitPakinLogService; @Autowired private WaitPakinItemLogService waitPakinItemLogService; @PreAuthorize("hasAuthority('manager:waitPakinLog:list')") @PostMapping("/waitPakinLog/page") public R page(@RequestBody Map map) { BaseParam baseParam = buildParam(map, BaseParam.class); PageParam pageParam = new PageParam<>(baseParam, WaitPakinLog.class); Page page = waitPakinLogService.page(pageParam, pageParam.buildWrapper(true)); fillAsnCodesForLog(page.getRecords()); return R.ok().add(page); } @PreAuthorize("hasAuthority('manager:waitPakinLog:list')") @PostMapping("/waitPakinLog/list") public R list(@RequestBody Map map) { List list = waitPakinLogService.list(); fillAsnCodesForLog(list); return R.ok().add(list); } @PreAuthorize("hasAuthority('manager:waitPakinLog:list')") @PostMapping({"/waitPakinLog/many/{ids}", "/waitPakinLogs/many/{ids}"}) public R many(@PathVariable Long[] ids) { List list = waitPakinLogService.listByIds(Arrays.asList(ids)); fillAsnCodesForLog(list); return R.ok().add(list); } @PreAuthorize("hasAuthority('manager:waitPakinLog:list')") @GetMapping("/waitPakinLog/{id}") public R get(@PathVariable("id") Long id) { WaitPakinLog one = waitPakinLogService.getById(id); if (one != null) { fillAsnCodesForLog(Collections.singletonList(one)); } return R.ok().add(one); } @PreAuthorize("hasAuthority('manager:waitPakinLog:save')") @OperationLog("Create 组拖历史档") @PostMapping("/waitPakinLog/save") public R save(@RequestBody WaitPakinLog waitPakinLog) { waitPakinLog.setCreateBy(getLoginUserId()); waitPakinLog.setCreateTime(new Date()); waitPakinLog.setUpdateBy(getLoginUserId()); waitPakinLog.setUpdateTime(new Date()); if (!waitPakinLogService.save(waitPakinLog)) { return R.error("Save Fail"); } return R.ok("Save Success").add(waitPakinLog); } @PreAuthorize("hasAuthority('manager:waitPakinLog:update')") @OperationLog("Update 组拖历史档") @PostMapping("/waitPakinLog/update") public R update(@RequestBody WaitPakinLog waitPakinLog) { waitPakinLog.setUpdateBy(getLoginUserId()); waitPakinLog.setUpdateTime(new Date()); if (!waitPakinLogService.updateById(waitPakinLog)) { return R.error("Update Fail"); } return R.ok("Update Success").add(waitPakinLog); } @PreAuthorize("hasAuthority('manager:waitPakinLog:remove')") @OperationLog("Delete 组拖历史档") @PostMapping("/waitPakinLog/remove/{ids}") public R remove(@PathVariable Long[] ids) { if (!waitPakinLogService.removeByIds(Arrays.asList(ids))) { return R.error("Delete Fail"); } return R.ok("Delete Success").add(ids); } @PreAuthorize("hasAuthority('manager:waitPakinLog:list')") @PostMapping("/waitPakinLog/query") public R query(@RequestParam(required = false) String condition) { List vos = new ArrayList<>(); LambdaQueryWrapper wrapper = new LambdaQueryWrapper<>(); if (!Cools.isEmpty(condition)) { wrapper.like(WaitPakinLog::getId, condition); } waitPakinLogService.page(new Page<>(1, 30), wrapper).getRecords().forEach( item -> vos.add(new KeyValVo(item.getId(), item.getId())) ); return R.ok().add(vos); } @PreAuthorize("hasAuthority('manager:waitPakinLog:list')") @PostMapping("/waitPakinLog/export") public void export(@RequestBody Map map, HttpServletResponse response) throws Exception { List list = waitPakinLogService.list(); fillAsnCodesForLog(list); ExcelUtil.build(ExcelUtil.create(list, WaitPakinLog.class), response); } /** * 根据组托历史明细填充主档的关联入库通知单号(asnCodes),与组托通知档保持一致 */ private void fillAsnCodesForLog(List list) { if (list == null || list.isEmpty()) { return; } List logIds = list.stream().map(WaitPakinLog::getId).collect(Collectors.toList()); List items = waitPakinItemLogService.list( new LambdaQueryWrapper() .in(WaitPakinItemLog::getLogId, logIds) .select(WaitPakinItemLog::getLogId, WaitPakinItemLog::getAsnCode)); Map asnCodesByLogId = logIds.stream().collect(Collectors.toMap( logId -> logId, logId -> items.stream() .filter(i -> logId.equals(i.getLogId()) && i.getAsnCode() != null && !i.getAsnCode().trim().isEmpty()) .map(WaitPakinItemLog::getAsnCode) .distinct() .collect(Collectors.joining(",")))); for (WaitPakinLog p : list) { p.setAsnCodes(asnCodesByLogId.get(p.getId())); } } }