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.core.conditions.query.QueryWrapper; 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.framework.exception.CoolException; 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.common.utils.FieldsUtils; import com.vincent.rsf.server.manager.entity.WkOrder; import com.vincent.rsf.server.manager.entity.WkOrderItem; import com.vincent.rsf.server.manager.entity.Companys; import com.vincent.rsf.server.manager.entity.excel.AsnOrderTemplate; import com.vincent.rsf.server.manager.enums.CompanysType; import com.vincent.rsf.server.manager.enums.OrderType; import com.vincent.rsf.server.manager.service.AsnOrderItemService; import com.vincent.rsf.server.manager.service.AsnOrderService; import com.vincent.rsf.server.manager.service.CompanysService; import com.vincent.rsf.server.system.controller.BaseController; import io.swagger.annotations.Api; import io.swagger.annotations.ApiOperation; import org.apache.commons.lang3.StringUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.security.access.prepost.PreAuthorize; import org.springframework.web.bind.annotation.*; import org.springframework.web.multipart.MultipartFile; import javax.servlet.http.HttpServletResponse; import java.util.*; import java.util.stream.Collectors; @Api(tags = "ASN单明细") @RestController public class WkOrderItemController extends BaseController { @Autowired private AsnOrderItemService asnOrderItemService; @Autowired private AsnOrderService asnOrderService; @Autowired private CompanysService companysService; @PreAuthorize("hasAuthority('manager:asnOrder:list')") @ApiOperation("分页获取列表") @PostMapping("/asnOrderItem/page") public R page(@RequestBody Map map) { BaseParam baseParam = buildParam(map, BaseParam.class); PageParam pageParam = new PageParam<>(baseParam, WkOrderItem.class); /** 拼接扩展字段 */ PageParam page = asnOrderItemService.page(pageParam, pageParam.buildWrapper(true)); List records = page.getRecords(); for (WkOrderItem record : records) { if (!Objects.isNull(record.getFieldsIndex())) { Map fields = FieldsUtils.getFields(record.getFieldsIndex()); record.setExtendFields(fields); } } page.setRecords(records); return R.ok(page); } @PreAuthorize("hasAuthority('manager:asnOrder:list')") @ApiOperation("分页获取列表") @PostMapping("/asnOrderItem/in/page") public R pageIn(@RequestBody Map map) { BaseParam baseParam = buildParam(map, BaseParam.class); PageParam pageParam = new PageParam<>(baseParam, WkOrderItem.class); // 查询type为"in"的订单ID列表 List orderIds = asnOrderService.list(new LambdaQueryWrapper() .eq(WkOrder::getType, OrderType.ORDER_IN.type) .select(WkOrder::getId)) .stream() .map(WkOrder::getId) .collect(Collectors.toList()); // 构建查询条件,关联asnOrder表筛选type为in的数据 QueryWrapper wrapper = pageParam.buildWrapper(true); if (!orderIds.isEmpty()) { wrapper.in("order_id", orderIds); } else { // 如果没有符合条件的订单,返回空结果 wrapper.eq("1", "0"); } /** 拼接扩展字段 */ PageParam page = asnOrderItemService.page(pageParam, wrapper); List records = page.getRecords(); for (WkOrderItem record : records) { if (!Objects.isNull(record.getFieldsIndex())) { Map fields = FieldsUtils.getFields(record.getFieldsIndex()); record.setExtendFields(fields); } } page.setRecords(records); return R.ok(page); } @PreAuthorize("hasAuthority('manager:asnOrder:list')") @ApiOperation("分页获取列表") @PostMapping("/asnOrderItem/out/page") public R pageOut(@RequestBody Map map) { BaseParam baseParam = buildParam(map, BaseParam.class); PageParam pageParam = new PageParam<>(baseParam, WkOrderItem.class); // 查询type为"in"的订单ID列表 List orderIds = asnOrderService.list(new LambdaQueryWrapper() .eq(WkOrder::getType, OrderType.ORDER_OUT.type) .select(WkOrder::getId)) .stream() .map(WkOrder::getId) .collect(Collectors.toList()); // 构建查询条件,关联asnOrder表筛选type为in的数据 QueryWrapper wrapper = pageParam.buildWrapper(true); if (!orderIds.isEmpty()) { wrapper.in("order_id", orderIds); } else { // 如果没有符合条件的订单,返回空结果 wrapper.eq("1", "0"); } /** 拼接扩展字段 */ PageParam page = asnOrderItemService.page(pageParam, wrapper); List records = page.getRecords(); for (WkOrderItem record : records) { if (!Objects.isNull(record.getFieldsIndex())) { Map fields = FieldsUtils.getFields(record.getFieldsIndex()); record.setExtendFields(fields); } } page.setRecords(records); return R.ok(page); } @PreAuthorize("hasAuthority('manager:asnOrder:list')") @PostMapping("/asnOrderItem/list") public R list(@RequestBody Map map) { return R.ok().add(asnOrderItemService.list()); } @PreAuthorize("hasAuthority('manager:asnOrder:list')") @PostMapping({ "/asnOrderItem/many/{ids}", "/asnOrderItems/many/{ids}" }) public R many(@PathVariable Long[] ids) { return R.ok().add(asnOrderItemService.listByIds(Arrays.asList(ids))); } @PreAuthorize("hasAuthority('manager:asnOrder:list')") @GetMapping("/asnOrderItem/{id}") public R get(@PathVariable("id") Long id) { return R.ok().add(asnOrderItemService.getById(id)); } @PreAuthorize("hasAuthority('manager:asnOrder:save')") @OperationLog("Create ASN单据") @PostMapping("/asnOrderItem/save") public R save(@RequestBody Map params) { if (Objects.isNull(params)) { throw new CoolException("信息不能为空!!"); } params.put("createBy", getLoginUserId()); params.put("updateBy", getLoginUserId()); if (!asnOrderItemService.fieldsSave(params, getLoginUserId())) { return R.error("Save Fail"); } return R.ok("Save Success"); } @PreAuthorize("hasAuthority('manager:asnOrder:update')") @OperationLog("Update ASN单据") @PostMapping("/asnOrderItem/update") public R update(@RequestBody WkOrderItem wkOrderItem) { wkOrderItem.setUpdateBy(getLoginUserId()); wkOrderItem.setUpdateTime(new Date()); if (!Objects.isNull(wkOrderItem.getSplrName()) && StringUtils.isNotBlank(wkOrderItem.getSplrName())) { Companys companys = companysService.getOne(new LambdaQueryWrapper() .eq(Companys::getType, CompanysType.COMPANYS_TYPE_SUPPLIER.val) .eq(Companys::getId, wkOrderItem.getSplrName())); if (!Objects.isNull(companys)) { wkOrderItem.setSplrCode(companys.getCode()).setSplrName(companys.getName()); } } if (!asnOrderItemService.updateById(wkOrderItem)) { return R.error("Update Fail"); } return R.ok("Update Success").add(wkOrderItem); } @PreAuthorize("hasAuthority('manager:asnOrder:remove')") @OperationLog("Delete ASN单据") @PostMapping("/asnOrderItem/remove/{ids}") public R remove(@PathVariable Long[] ids) { if (!asnOrderItemService.removeByIds(Arrays.asList(ids))) { return R.error("Delete Fail"); } return R.ok("Delete Success").add(ids); } @PreAuthorize("hasAuthority('manager:asnOrder:list')") @PostMapping("/asnOrderItem/query") public R query(@RequestParam(required = false) String condition) { List vos = new ArrayList<>(); LambdaQueryWrapper wrapper = new LambdaQueryWrapper<>(); if (!Cools.isEmpty(condition)) { wrapper.like(WkOrderItem::getId, condition); } asnOrderItemService.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:asnOrder:list')") @PostMapping("/asnOrderItem/export") @ApiOperation("导出收货通知单明细") public void export(@RequestBody Map map, HttpServletResponse response) throws Exception { List orderItems = new ArrayList<>(); if (!Objects.isNull(map.get("ids"))) { List ids = JSONArray.parseArray(JSONObject.toJSONString(map.get("ids")), Long.class); if (!ids.isEmpty()) { orderItems = asnOrderItemService.list(new LambdaQueryWrapper() .in(WkOrderItem::getId, ids) .eq(WkOrderItem::getStatus, 1)); } else { orderItems = asnOrderItemService.list(new LambdaQueryWrapper<>()); } } else { orderItems = asnOrderItemService.list(new LambdaQueryWrapper<>()); } ExcelUtil.build(ExcelUtil.create(orderItems, WkOrderItem.class, true), response); } @PostMapping("/asnOrderItem/generate/barcode") @ApiOperation("生成ASN标签") @PreAuthorize("hasAuthority('manager:asnOrder:list')") public R generateBarcode(@RequestBody List orders) { if (orders.isEmpty()) { return R.error("单据不能为空!!"); } return asnOrderItemService.generateBarcode(orders); } /** * ASN单据明细导入 * * @param file * @return */ @PostMapping("/asnOrderItem/import") @ApiOperation("ASN导入接口") @PreAuthorize("hasAuthority('manager:asnOrder:update')") public R importExcel(@RequestParam(value = "file") MultipartFile file) throws Exception { if (Objects.isNull(file)) { return R.error("文件不能为空!!"); } HashMap hashMap = new HashMap<>(); return asnOrderItemService.excelImport(file, hashMap, getLoginUserId()); } /** * @author Ryan * @description 下载模板 * @param * @return * @time 2025/4/18 08:17 */ @PostMapping("/asnOrderItem/template/download") @ApiOperation("下载收货单模板") @PreAuthorize("hasAuthority('manager:asnOrder:update')") public void downloadTemplate(@RequestBody Map map, HttpServletResponse response) throws Exception { AsnOrderTemplate template = ExcelUtil.mockData(AsnOrderTemplate.class); List list = Arrays.asList(template); ExcelUtil.build(ExcelUtil.create(list, AsnOrderTemplate.class, true), response); } }