package com.zy.asrs.wms.asrs.controller; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.zy.asrs.framework.common.Cools; import com.zy.asrs.framework.common.R; import com.zy.asrs.framework.exception.CoolException; import com.zy.asrs.wms.asrs.entity.*; import com.zy.asrs.wms.asrs.entity.enums.OrderSettleType; import com.zy.asrs.wms.asrs.service.*; import com.zy.asrs.wms.common.annotation.OperationLog; import com.zy.asrs.wms.common.domain.BaseParam; import com.zy.asrs.wms.common.domain.KeyValVo; import com.zy.asrs.wms.common.domain.PageParam; import com.zy.asrs.wms.system.controller.BaseController; import com.zy.asrs.wms.utils.ExcelUtil; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.security.access.prepost.PreAuthorize; import org.springframework.transaction.annotation.Transactional; import org.springframework.web.bind.annotation.*; import javax.servlet.http.HttpServletResponse; import java.util.*; @RestController @RequestMapping("/api") public class WaitPakinController extends BaseController { @Autowired private WaitPakinService waitPakinService; @Autowired private OrderService orderService; @Autowired private OrderDetlService orderDetlService; @Autowired private LocService locService; @Autowired private TaskService taskService; @PreAuthorize("hasAuthority('asrs:waitPakin:list')") @PostMapping("/waitPakin/page") public R page(@RequestBody Map map) { BaseParam baseParam = buildParam(map, BaseParam.class); PageParam pageParam = new PageParam<>(baseParam, WaitPakin.class); return R.ok().add(waitPakinService.page(pageParam, pageParam.buildWrapper(true))); } @PreAuthorize("hasAuthority('asrs:waitPakin:list')") @PostMapping("/waitPakin/list") public R list(@RequestBody Map map) { return R.ok().add(waitPakinService.list()); } @PreAuthorize("hasAuthority('asrs:waitPakin:list')") @GetMapping("/waitPakin/{id}") public R get(@PathVariable("id") Long id) { return R.ok().add(waitPakinService.getById(id)); } @PreAuthorize("hasAuthority('asrs:waitPakin:list')") @GetMapping("/waitPakin/orderDetlId/{orderDetlId}") public R getByOrderDetlId(@PathVariable("orderDetlId") Long orderDetlId) { return R.ok().add(waitPakinService.getByOrderDetlId(orderDetlId)); } @PreAuthorize("hasAuthority('asrs:waitPakin:save')") @OperationLog("添加组托通知档") @PostMapping("/waitPakin/save") @Transactional public R save(@RequestBody WaitPakin waitPakin) { if (waitPakin.getAnfme() <= 0) { return R.error("组托数量错误"); } List locList = locService.list(new LambdaQueryWrapper().eq(Loc::getBarcode, waitPakin.getBarcode())); if (!locList.isEmpty()) { return R.error("托盘已在库"); } List taskList = taskService.list(new LambdaQueryWrapper().eq(Task::getBarcode, waitPakin.getBarcode())); if (!taskList.isEmpty()) { return R.error("托盘正在入库中"); } //查询是否存在相同明细和托盘码的组托通知档 WaitPakin waitPakin1 = waitPakinService.getOne(new LambdaQueryWrapper().eq(WaitPakin::getBarcode, waitPakin.getBarcode()).eq(WaitPakin::getDetlId, waitPakin.getDetlId())); if (waitPakin1 == null) { //不存在组托通知档,创建 if (!waitPakinService.save(waitPakin)) { return R.error("添加失败"); } }else { //存在组托通知档,更新 waitPakin1.setAnfme(waitPakin1.getAnfme() + waitPakin.getAnfme()); waitPakin1.setUpdateTime(new Date()); if (!waitPakinService.updateById(waitPakin1)) { return R.error("添加失败"); } } OrderDetl orderDetl = orderDetlService.getById(waitPakin.getDetlId()); if (orderDetl == null) { throw new CoolException("订单明细不存在"); } //获取订单 Order order = orderService.getById(orderDetl.getOrderId()); if(order == null){ throw new CoolException("订单不存在"); } //更新订单状态 if (order.getOrderSettle().equals(OrderSettleType.INIT.val())) { order.setOrderSettle(OrderSettleType.WAIT.val()); order.setUpdateTime(new Date()); if (!orderService.updateById(order)) { throw new CoolException("订单数据更新失败"); } } return R.ok("添加成功"); } @PreAuthorize("hasAuthority('asrs:waitPakin:update')") @OperationLog("修改组托通知档") @PostMapping("/waitPakin/update") public R update(@RequestBody WaitPakin waitPakin) { if (!waitPakinService.updateById(waitPakin)) { return R.error("修改失败"); } return R.ok("修改成功"); } @PreAuthorize("hasAuthority('asrs:waitPakin:remove')") @OperationLog("删除组托通知档") @PostMapping("/waitPakin/remove/{ids}") public R remove(@PathVariable Long[] ids) { if (!waitPakinService.removeByIds(Arrays.asList(ids))) { return R.error("删除失败"); } return R.ok("删除成功"); } @PreAuthorize("hasAuthority('asrs:waitPakin:list')") @PostMapping("/waitPakin/query") public R query(@RequestParam(required = false) String condition) { List vos = new ArrayList<>(); LambdaQueryWrapper wrapper = new LambdaQueryWrapper<>(); if (!Cools.isEmpty(condition)) { wrapper.like(WaitPakin::getId, condition); } waitPakinService.page(new Page<>(1, 30), wrapper).getRecords().forEach( item -> vos.add(new KeyValVo(item.getId(), item.getId())) ); return R.ok().add(vos); } @PreAuthorize("hasAuthority('asrs:waitPakin:list')") @PostMapping("/waitPakin/barcode/query") public R barcodeQuery(@RequestParam(required = false) String condition) { List vos = new ArrayList<>(); QueryWrapper queryWrapper = new QueryWrapper<>(); queryWrapper.select("distinct barcode"); if (!Cools.isEmpty(condition)) { queryWrapper.like("barcode", condition); } waitPakinService.page(new Page<>(1, 30), queryWrapper).getRecords().forEach( item -> vos.add(new KeyValVo(item.getBarcode(), item.getBarcode())) ); return R.ok().add(vos); } @PreAuthorize("hasAuthority('asrs:waitPakin:list')") @PostMapping("/waitPakin/export") public void export(@RequestBody Map map, HttpServletResponse response) throws Exception { ExcelUtil.build(ExcelUtil.create(waitPakinService.list(), WaitPakin.class), response); } }