package com.vincent.rsf.server.manager.controller; import com.alibaba.fastjson.JSONArray; import com.alibaba.fastjson.JSONObject; 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.api.entity.enums.OrderType; import com.vincent.rsf.server.api.entity.enums.OrderWorkType; 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.common.utils.ExcelUtil; import com.vincent.rsf.server.manager.entity.AsnOrder; import com.vincent.rsf.server.manager.entity.AsnOrderItem; import com.vincent.rsf.server.manager.entity.excel.AsnOrderTemplate; import com.vincent.rsf.server.manager.enums.AsnExceStatus; import com.vincent.rsf.server.manager.service.AsnOrderItemService; import com.vincent.rsf.server.manager.service.AsnOrderService; import com.vincent.rsf.server.manager.service.OutStockItemService; import com.vincent.rsf.server.manager.service.OutStockService; import com.vincent.rsf.server.system.constant.SerialRuleCode; import com.vincent.rsf.server.system.controller.BaseController; import com.vincent.rsf.server.system.utils.SerialRuleUtils; import io.swagger.annotations.Api; import io.swagger.annotations.ApiOperation; 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.*; @RestController @Api(tags = "出库单据") public class OutStockController extends BaseController { @Autowired private OutStockService outStockService; @Autowired private OutStockItemService outStockItemService; @PreAuthorize("hasAuthority('manager:outStock:list')") @PostMapping("/outStock/page") public R page(@RequestBody Map map) { BaseParam baseParam = buildParam(map, BaseParam.class); PageParam pageParam = new PageParam<>(baseParam, AsnOrder.class); return R.ok().add(outStockService.page(pageParam, pageParam.buildWrapper(true))); } @PreAuthorize("hasAuthority('manager:outStock:list')") @PostMapping("/outStock/list") public R list(@RequestBody Map map) { return R.ok().add(outStockService.list(new LambdaQueryWrapper().eq(AsnOrder::getType, OrderType.ORDER_OUT.type))); } @PreAuthorize("hasAuthority('manager:outStock:list')") @PostMapping({"/outStock/many/{ids}", "/asnOrders/many/{ids}"}) public R many(@PathVariable Long[] ids) { return R.ok().add(outStockService.listByIds(Arrays.asList(ids))); } @PreAuthorize("hasAuthority('manager:outStock:list')") @OperationLog("表单查询") @GetMapping("/outStock/{id}") public R get(@PathVariable("id") Long id) { return R.ok().add(outStockService.getById(id)); } @PreAuthorize("hasAuthority('manager:outStock:save')") @OperationLog("Create 出库单据") @PostMapping("/outStock/save") @ApiOperation("保存") public R save(@RequestBody AsnOrder asnOrder) { asnOrder.setCreateBy(getLoginUserId()) .setUpdateBy(getLoginUserId()); if (!Objects.isNull(asnOrder.getCode())) { String code = SerialRuleUtils.generateRuleCode(SerialRuleCode.SYS_OUT_STOCK_CODE, asnOrder); asnOrder.setCode(code); } if (!outStockService.save(asnOrder)) { return R.error("Save Fail"); } return R.ok("Save Success").add(asnOrder); } @PreAuthorize("hasAuthority('manager:outStock:update')") @OperationLog("Update ;出库单据") @PostMapping("/outStock/update") @ApiOperation("更新") public R update(@RequestBody AsnOrder asnOrder) { asnOrder.setType(OrderType.ORDER_OUT.type) .setUpdateBy(getLoginUserId()) .setUpdateTime(new Date()); if (!outStockService.updateById(asnOrder)) { return R.error("Update Fail"); } return R.ok("Update Success").add(asnOrder); } @PreAuthorize("hasAuthority('manager:outStock:remove')") @OperationLog("Delete 出库单据") @PostMapping("/outStock/remove/{ids}") public R remove(@PathVariable Long[] ids) { if (!outStockService.removeByIds(Arrays.asList(ids))) { return R.error("Delete Fail"); } return R.ok("Delete Success").add(ids); } @PreAuthorize("hasAuthority('manager:outStock:list')") @PostMapping("/outStock/query") @ApiOperation("查询") public R query(@RequestParam(required = false) String condition) { List vos = new ArrayList<>(); LambdaQueryWrapper wrapper = new LambdaQueryWrapper<>(); if (!Cools.isEmpty(condition)) { wrapper.like(AsnOrder::getCode, condition); } outStockService.page(new Page<>(1, 30), wrapper).getRecords().forEach( item -> vos.add(new KeyValVo(item.getId(), item.getCode())) ); return R.ok().add(vos); } @PreAuthorize("hasAuthority('manager:outStock:update')") @ApiOperation("取消出库单据") @GetMapping("/outStock/cancel/{id}") public R cancel(@PathVariable String id) { if (Objects.isNull(id)) { return R.error("参数不能为空!!"); } return outStockService.cancelOutOrder(id); } @PreAuthorize("hasAuthority('manager:outStock:list')") @PostMapping("/outStock/export") @ApiOperation("导出") public void export(@RequestBody Map map, HttpServletResponse response) throws Exception { List orders = new ArrayList<>(); if (!Objects.isNull(map.get("ids"))) { List ids = JSONArray.parseArray(JSONObject.toJSONString(map.get("ids")), Long.class); if (!ids.isEmpty()) { orders = outStockService.list(new LambdaQueryWrapper().in(AsnOrder::getId, ids)); } else { orders = outStockService.list(new LambdaQueryWrapper<>()); } } else { orders = outStockService.list(); } List orderTemplates = new ArrayList<>(); for (AsnOrder order : orders) { List orderItems = outStockItemService.list(new LambdaQueryWrapper().eq(AsnOrderItem::getAsnId, order.getId())); for (AsnOrderItem item : orderItems) { if (Objects.isNull(item)) { continue; } AsnOrderTemplate template = new AsnOrderTemplate(); template.setCode(order.getCode()) .setType(OrderType.getValType(order.getType())) .setWkType(OrderWorkType.getWorkDesc(order.getWkType())) .setExceStatus(AsnExceStatus.getExceStatus(order.getExceStatus())) .setAnfme(item.getAnfme() + "") .setMaktx(item.getMaktx()) .setMemo(item.getMemo()) .setMatnrCode(item.getMatnrCode()) .setPoCode(item.getPoCode()) .setSplrName(item.getSplrName()) .setPoId(order.getPoId() + "") .setTrackCode(item.getTrackCode()) .setBarcode(item.getBarcode()) .setPackName(item.getPackName()) .setPlatItemId(item.getPlatItemId()) .setSplrBatch(item.getSplrBatch()) .setSplrCode(item.getSplrCode()) .setStockUnit(item.getStockUnit()) .setPurQty(item.getPurQty() + "") .setPurUnit(item.getPurUnit()); orderTemplates.add(template); } } ExcelUtil.build(ExcelUtil.create(orderTemplates, AsnOrderTemplate.class), response); } }