Browse Source

仓库、货区、货架删除调整;托盘信息管理

test
kilo 2 years ago
parent
commit
7ca82e0b4b
  1. 95
      blade-service-api/logpm-basicdata-api/src/main/java/com/logpm/basicdata/entity/BasicdataTrayEntity.java
  2. 2
      blade-service-api/logpm-basicdata-api/src/main/java/com/logpm/basicdata/entity/BasicdataWarehouseEntity.java
  3. 49
      blade-service-api/logpm-basicdata-api/src/main/java/com/logpm/basicdata/feign/IBasicdataTrayClient.java
  4. 35
      blade-service-api/logpm-basicdata-api/src/main/java/com/logpm/basicdata/vo/BasicdataTrayVO.java
  5. 4
      blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/controller/BasicdataGoodsAllocationController.java
  6. 2
      blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/controller/BasicdataGoodsAreaController.java
  7. 6
      blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/controller/BasicdataGoodsShelfController.java
  8. 152
      blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/controller/BasicdataTrayController.java
  9. 6
      blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/controller/BasicdataWarehouseController.java
  10. 2
      blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/dto/BasicdataGoodsAllocationDTO.java
  11. 16
      blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/dto/BasicdataTrayDTO.java
  12. 123
      blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/excel/BasicdataTrayExcel.java
  13. 53
      blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/feign/BasicdataTrayClient.java
  14. 4
      blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/mapper/BasicdataGoodsAllocationMapper.xml
  15. 2
      blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/mapper/BasicdataGoodsAreaMapper.java
  16. 13
      blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/mapper/BasicdataGoodsAreaMapper.xml
  17. 1
      blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/mapper/BasicdataGoodsShelfMapper.java
  18. 9
      blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/mapper/BasicdataGoodsShelfMapper.xml
  19. 54
      blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/mapper/BasicdataTrayMapper.java
  20. 39
      blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/mapper/BasicdataTrayMapper.xml
  21. 5
      blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/mapper/BasicdataWarehouseMapper.java
  22. 22
      blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/mapper/BasicdataWarehouseMapper.xml
  23. 1
      blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/service/IBasicdataGoodsAllocationService.java
  24. 6
      blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/service/IBasicdataGoodsShelfService.java
  25. 55
      blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/service/IBasicdataTrayService.java
  26. 58
      blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/service/impl/BasicdataGoodsAllocationServiceImpl.java
  27. 15
      blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/service/impl/BasicdataGoodsAreaServiceImpl.java
  28. 95
      blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/service/impl/BasicdataGoodsShelfServiceImpl.java
  29. 92
      blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/service/impl/BasicdataTrayServiceImpl.java
  30. 25
      blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/service/impl/BasicdataWarehouseServiceImpl.java
  31. 2
      doc/dpm/物流租户系统.pdma.json

95
blade-service-api/logpm-basicdata-api/src/main/java/com/logpm/basicdata/entity/BasicdataTrayEntity.java

@ -0,0 +1,95 @@
/*
* Copyright (c) 2018-2028, Chill Zhuang All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
* Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* Neither the name of the dreamlu.net developer nor the names of its
* contributors may be used to endorse or promote products derived from
* this software without specific prior written permission.
* Author: Chill 庄骞 (smallchill@163.com)
*/
package com.logpm.basicdata.entity;
import com.baomidou.mybatisplus.annotation.TableName;
import lombok.Data;
import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
import java.util.Date;
import lombok.EqualsAndHashCode;
import org.springblade.core.tenant.mp.TenantEntity;
/**
* 托盘 实体类
*
* @author tjj
* @since 2023-05-25
*/
@Data
@TableName("logpm_warehouse_tray")
@ApiModel(value = "BasicdataTray对象", description = "托盘")
@EqualsAndHashCode(callSuper = true)
public class BasicdataTrayEntity extends TenantEntity {
/**
* 预留1
*/
@ApiModelProperty(value = "预留1")
private String reserve1;
/**
* 预留2
*/
@ApiModelProperty(value = "预留2")
private String reserve2;
/**
* 预留3
*/
@ApiModelProperty(value = "预留3")
private String reserve3;
/**
* 预留4
*/
@ApiModelProperty(value = "预留4")
private String reserve4;
/**
* 预留5
*/
@ApiModelProperty(value = "预留5")
private String reserve5;
/**
* 托盘码
*/
@ApiModelProperty(value = "托盘码")
private String palletCode;
/**
* 仓库编号
*/
@ApiModelProperty(value = "仓库编号")
private String warehouseId;
/**
* 托盘状态;1-空闲2-货物3-损毁4-流通5
*/
@ApiModelProperty(value = "托盘状态;1-空闲;2-货物;3-损毁;4-流通;5")
private String trayStatus;
/**
* 二维码图片
*/
@ApiModelProperty(value = "二维码图片")
private String qrCodeUrl;
/**
* 二维码
*/
@ApiModelProperty(value = "二维码")
private String qrCode;
/**
* 类型;木托 铁托 台面托
*/
@ApiModelProperty(value = "类型;木托 铁托 台面托")
private Integer type;
}

2
blade-service-api/logpm-basicdata-api/src/main/java/com/logpm/basicdata/entity/BasicdataWarehouseEntity.java

@ -147,7 +147,7 @@ public class BasicdataWarehouseEntity extends TenantEntity {
* 仓库类型;1平台2高台
*/
@ApiModelProperty(value = "仓库类型;1平台,2高台")
private Integer warehouseType;
private String warehouseType;
/**
* 消防等级
*/

49
blade-service-api/logpm-basicdata-api/src/main/java/com/logpm/basicdata/feign/IBasicdataTrayClient.java

@ -0,0 +1,49 @@
/*
* Copyright (c) 2018-2028, Chill Zhuang All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
* Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* Neither the name of the dreamlu.net developer nor the names of its
* contributors may be used to endorse or promote products derived from
* this software without specific prior written permission.
* Author: Chill 庄骞 (smallchill@163.com)
*/
package com.logpm.basicdata.feign;
import com.logpm.basicdata.entity.BasicdataTrayEntity;
import org.springblade.core.mp.support.BladePage;
import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestParam;
/**
* 托盘 Feign接口类
*
* @author tjj
* @since 2023-05-25
*/
@FeignClient(
value = "blade-BasicdataTray"
)
public interface IBasicdataTrayClient {
String API_PREFIX = "tray/client";
String TOP = API_PREFIX + "/top";
/**
* 获取托盘列表
*
* @param current 页号
* @param size 页数
* @return BladePage
*/
@GetMapping(TOP)
BladePage<BasicdataTrayEntity> trayTop(@RequestParam("current") Integer current, @RequestParam("size") Integer size);
}

35
blade-service-api/logpm-basicdata-api/src/main/java/com/logpm/basicdata/vo/BasicdataTrayVO.java

@ -0,0 +1,35 @@
/*
* Copyright (c) 2018-2028, Chill Zhuang All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
* Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* Neither the name of the dreamlu.net developer nor the names of its
* contributors may be used to endorse or promote products derived from
* this software without specific prior written permission.
* Author: Chill 庄骞 (smallchill@163.com)
*/
package com.logpm.basicdata.vo;
import com.logpm.basicdata.entity.BasicdataTrayEntity;
import org.springblade.core.tool.node.INode;
import lombok.Data;
import lombok.EqualsAndHashCode;
/**
* 托盘 视图实体类
*
* @author tjj
* @since 2023-05-25
*/
@Data
@EqualsAndHashCode(callSuper = true)
public class BasicdataTrayVO extends BasicdataTrayEntity {
private static final long serialVersionUID = 1L;
}

4
blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/controller/BasicdataGoodsAllocationController.java

@ -110,8 +110,8 @@ public class BasicdataGoodsAllocationController extends BladeController {
@PostMapping("/update")
@ApiOperationSupport(order = 5)
@ApiOperation(value = "修改", notes = "传入BasicdataGoodsAllocation")
public R update(@Valid @RequestBody BasicdataGoodsAllocationEntity BasicdataGoodsAllocation) {
return R.status(basicdataGoodsAllocationService.updateById(BasicdataGoodsAllocation));
public R update(@Valid @RequestBody BasicdataGoodsAllocationDTO basicdataGoodsAllocationDto) {
return R.status(basicdataGoodsAllocationService.updateGoodsAllocation(basicdataGoodsAllocationDto));
}
/**

2
blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/controller/BasicdataGoodsAreaController.java

@ -133,7 +133,7 @@ public class BasicdataGoodsAreaController extends BladeController {
public R remove(@ApiParam(value = "主键集合", required = true) @RequestParam List<String> ids) {
boolean result = basicdataGoodsAreaService.removeGoodsArea(ids);
// return R.status(basicdataGoodsAreaService.deleteLogic(Func.toLongList(ids)));
return R.status(result);
return R.status(result);
}

6
blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/controller/BasicdataGoodsShelfController.java

@ -131,8 +131,10 @@ public class BasicdataGoodsShelfController extends BladeController {
@PostMapping("/remove")
@ApiOperationSupport(order = 7)
@ApiOperation(value = "逻辑删除", notes = "传入ids")
public R remove(@ApiParam(value = "主键集合", required = true) @RequestParam String ids) {
return R.status(basicdataGoodsShelfService.deleteLogic(Func.toLongList(ids)));
public R remove(@ApiParam(value = "主键集合", required = true) @RequestParam List<String> ids) {
// return R.status(basicdataGoodsShelfService.deleteLogic(Func.toLongList(ids)));
boolean result = basicdataGoodsShelfService.removeGoodsShelf(ids);
return R.status(result);
}

152
blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/controller/BasicdataTrayController.java

@ -0,0 +1,152 @@
/*
* Copyright (c) 2018-2028, Chill Zhuang All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
* Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* Neither the name of the dreamlu.net developer nor the names of its
* contributors may be used to endorse or promote products derived from
* this software without specific prior written permission.
* Author: Chill 庄骞 (smallchill@163.com)
*/
package com.logpm.basicdata.controller;
import com.logpm.basicdata.dto.BasicdataTrayDTO;
import com.logpm.basicdata.entity.BasicdataTrayEntity;
import com.logpm.basicdata.excel.BasicdataTrayExcel;
import com.logpm.basicdata.service.IBasicdataTrayService;
import com.logpm.basicdata.vo.BasicdataTrayVO;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import io.swagger.annotations.ApiParam;
import com.github.xiaoymin.knife4j.annotations.ApiOperationSupport;
import lombok.AllArgsConstructor;
import javax.validation.Valid;
import org.springblade.core.secure.BladeUser;
import org.springblade.core.mp.support.Condition;
import org.springblade.core.mp.support.Query;
import org.springblade.core.tool.api.R;
import org.springblade.core.tool.utils.Func;
import org.springframework.web.bind.annotation.*;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import org.springblade.core.boot.ctrl.BladeController;
import org.springblade.core.tool.utils.DateUtil;
import org.springblade.core.excel.util.ExcelUtil;
import org.springblade.core.tool.constant.BladeConstant;
import springfox.documentation.annotations.ApiIgnore;
import java.util.Map;
import java.util.List;
import javax.servlet.http.HttpServletResponse;
/**
* 托盘 控制器
*
* @author tjj
* @since 2023-05-25
*/
@RestController
@AllArgsConstructor
@RequestMapping("/tray")
@Api(value = "托盘", tags = "托盘接口")
public class BasicdataTrayController extends BladeController {
private final IBasicdataTrayService BasicdataTrayService;
/**
* 托盘 详情
*/
@GetMapping("/detail")
@ApiOperationSupport(order = 1)
@ApiOperation(value = "详情", notes = "传入BasicdataTray")
public R<BasicdataTrayEntity> detail(BasicdataTrayEntity BasicdataTray) {
BasicdataTrayEntity detail = BasicdataTrayService.getOne(Condition.getQueryWrapper(BasicdataTray));
return R.data(detail);
}
/**
* 托盘 分页
*/
@GetMapping("/list")
@ApiOperationSupport(order = 2)
@ApiOperation(value = "分页", notes = "传入BasicdataTray")
public R<IPage<BasicdataTrayEntity>> list(@ApiIgnore @RequestParam Map<String, Object> BasicdataTray, Query query) {
IPage<BasicdataTrayEntity> pages = BasicdataTrayService.page(Condition.getPage(query), Condition.getQueryWrapper(BasicdataTray, BasicdataTrayEntity.class));
return R.data(pages);
}
/**
* 托盘 自定义分页
*/
@GetMapping("/page")
@ApiOperationSupport(order = 3)
@ApiOperation(value = "分页", notes = "传入BasicdataTray")
public R<IPage<BasicdataTrayVO>> page(BasicdataTrayVO BasicdataTray, Query query) {
IPage<BasicdataTrayVO> pages = BasicdataTrayService.selectBasicdataTrayPage(Condition.getPage(query), BasicdataTray);
return R.data(pages);
}
/**
* 托盘 新增
*/
@PostMapping("/save")
@ApiOperationSupport(order = 4)
@ApiOperation(value = "新增", notes = "传入BasicdataTray")
public R save(@Valid @RequestBody BasicdataTrayDTO basicdataTrayDTO) {
return R.status(BasicdataTrayService.insertTray(basicdataTrayDTO));
}
/**
* 托盘 修改
*/
@PostMapping("/update")
@ApiOperationSupport(order = 5)
@ApiOperation(value = "修改", notes = "传入BasicdataTray")
public R update(@Valid @RequestBody BasicdataTrayEntity BasicdataTray) {
return R.status(BasicdataTrayService.updateById(BasicdataTray));
}
/**
* 托盘 新增或修改
*/
@PostMapping("/submit")
@ApiOperationSupport(order = 6)
@ApiOperation(value = "新增或修改", notes = "传入BasicdataTray")
public R submit(@Valid @RequestBody BasicdataTrayEntity BasicdataTray) {
return R.status(BasicdataTrayService.saveOrUpdate(BasicdataTray));
}
/**
* 托盘 删除
*/
@PostMapping("/remove")
@ApiOperationSupport(order = 7)
@ApiOperation(value = "逻辑删除", notes = "传入ids")
public R remove(@ApiParam(value = "主键集合", required = true) @RequestParam String ids) {
return R.status(BasicdataTrayService.deleteLogic(Func.toLongList(ids)));
}
/**
* 导出数据
*/
@GetMapping("/export-BasicdataTray")
@ApiOperationSupport(order = 9)
@ApiOperation(value = "导出数据", notes = "传入BasicdataTray")
public void exportBasicdataTray(@ApiIgnore @RequestParam Map<String, Object> BasicdataTray, BladeUser bladeUser, HttpServletResponse response) {
QueryWrapper<BasicdataTrayEntity> queryWrapper = Condition.getQueryWrapper(BasicdataTray, BasicdataTrayEntity.class);
//if (!AuthUtil.isAdministrator()) {
// queryWrapper.lambda().eq(BasicdataTray::getTenantId, bladeUser.getTenantId());
//}
queryWrapper.lambda().eq(BasicdataTrayEntity::getIsDeleted, BladeConstant.DB_NOT_DELETED);
List<BasicdataTrayExcel> list = BasicdataTrayService.exportBasicdataTray(queryWrapper);
ExcelUtil.export(response, "托盘数据" + DateUtil.time(), "托盘数据表", list, BasicdataTrayExcel.class);
}
}

6
blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/controller/BasicdataWarehouseController.java

@ -142,11 +142,7 @@ public class BasicdataWarehouseController extends BladeController {
@ApiOperation(value = "逻辑删除", notes = "传入ids")
public R remove(@ApiParam(value = "主键集合", required = true) @RequestParam List<String> ids) {
boolean result = warehouseService.removeWarehouse(ids);
if (result){
return R.status(result);
}else {
return R.fail("该仓库还存在绑定资源!!!!");
}
return R.status(result);
}

2
blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/dto/BasicdataGoodsAllocationDTO.java

@ -33,6 +33,6 @@ import java.util.List;
public class BasicdataGoodsAllocationDTO extends BasicdataGoodsAllocationEntity {
private static final long serialVersionUID = 1L;
private List<Object> nodeInfo;
private List<String> nodeInfo;
}

16
blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/dto/BasicdataDTO.java → blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/dto/BasicdataTrayDTO.java

@ -16,23 +16,19 @@
*/
package com.logpm.basicdata.dto;
import com.logpm.basicdata.entity.BasicdataBrandEntity;
import com.logpm.basicdata.entity.BasicdataTrayEntity;
import lombok.Data;
import lombok.EqualsAndHashCode;
/**
* 基础品牌表 数据传输对象实体类
* 托盘 数据传输对象实体类
*
* @author cyz
* @since 2023-05-16
* @author tjj
* @since 2023-05-25
*/
@Data
public class BasicdataDTO {
@EqualsAndHashCode(callSuper = true)
public class BasicdataTrayDTO extends BasicdataTrayEntity {
private static final long serialVersionUID = 1L;
private String isHaveGoodsArea;
private String isHaveGoodsShelf;
private String isHaveGoodsAllocation;
}

123
blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/excel/BasicdataTrayExcel.java

@ -0,0 +1,123 @@
/*
* Copyright (c) 2018-2028, Chill Zhuang All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
* Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* Neither the name of the dreamlu.net developer nor the names of its
* contributors may be used to endorse or promote products derived from
* this software without specific prior written permission.
* Author: Chill 庄骞 (smallchill@163.com)
*/
package com.logpm.basicdata.excel;
import lombok.Data;
import java.util.Date;
import com.alibaba.excel.annotation.ExcelProperty;
import com.alibaba.excel.annotation.write.style.ColumnWidth;
import com.alibaba.excel.annotation.write.style.ContentRowHeight;
import com.alibaba.excel.annotation.write.style.HeadRowHeight;
import java.io.Serializable;
/**
* 托盘 Excel实体类
*
* @author tjj
* @since 2023-05-25
*/
@Data
@ColumnWidth(25)
@HeadRowHeight(20)
@ContentRowHeight(18)
public class BasicdataTrayExcel implements Serializable {
private static final long serialVersionUID = 1L;
/**
* 租户号
*/
@ColumnWidth(20)
@ExcelProperty("租户号")
private String tenantId;
/**
* 是否已删除
*/
@ColumnWidth(20)
@ExcelProperty("是否已删除")
private Integer isDeleted;
/**
* 预留1
*/
@ColumnWidth(20)
@ExcelProperty("预留1")
private String reserve1;
/**
* 预留2
*/
@ColumnWidth(20)
@ExcelProperty("预留2")
private String reserve2;
/**
* 预留3
*/
@ColumnWidth(20)
@ExcelProperty("预留3")
private String reserve3;
/**
* 预留4
*/
@ColumnWidth(20)
@ExcelProperty("预留4")
private String reserve4;
/**
* 预留5
*/
@ColumnWidth(20)
@ExcelProperty("预留5")
private String reserve5;
/**
* 托盘码
*/
@ColumnWidth(20)
@ExcelProperty("托盘码")
private String palletCode;
/**
* 仓库编号
*/
@ColumnWidth(20)
@ExcelProperty("仓库编号")
private String warehouseId;
/**
* 托盘状态;1-空闲2-货物3-损毁4-流通5
*/
@ColumnWidth(20)
@ExcelProperty("托盘状态;1-空闲;2-货物;3-损毁;4-流通;5")
private String trayStatus;
/**
* 二维码图片
*/
@ColumnWidth(20)
@ExcelProperty("二维码图片")
private String qrCodeUrl;
/**
* 二维码
*/
@ColumnWidth(20)
@ExcelProperty("二维码")
private String qrCode;
/**
* 类型;木托 铁托 台面托
*/
@ColumnWidth(20)
@ExcelProperty("类型;木托 铁托 台面托")
private Integer type;
}

53
blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/feign/BasicdataTrayClient.java

@ -0,0 +1,53 @@
/*
* Copyright (c) 2018-2028, Chill Zhuang All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
* Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* Neither the name of the dreamlu.net developer nor the names of its
* contributors may be used to endorse or promote products derived from
* this software without specific prior written permission.
* Author: Chill 庄骞 (smallchill@163.com)
*/
package com.logpm.basicdata.feign;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.logpm.basicdata.entity.BasicdataTrayEntity;
import com.logpm.basicdata.service.IBasicdataTrayService;
import lombok.AllArgsConstructor;
import org.springblade.core.mp.support.BladePage;
import org.springblade.core.mp.support.Condition;
import org.springblade.core.mp.support.Query;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;
import springfox.documentation.annotations.ApiIgnore;
/**
* 托盘 Feign实现类
*
* @author tjj
* @since 2023-05-25
*/
@ApiIgnore()
@RestController
@AllArgsConstructor
public class BasicdataTrayClient implements IBasicdataTrayClient {
private final IBasicdataTrayService BasicdataTrayService;
@Override
@GetMapping(TOP)
public BladePage<BasicdataTrayEntity> trayTop(Integer current, Integer size) {
Query query = new Query();
query.setCurrent(current);
query.setSize(size);
IPage<BasicdataTrayEntity> page = BasicdataTrayService.page(Condition.getPage(query));
return BladePage.of(page);
}
}

4
blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/mapper/BasicdataGoodsAllocationMapper.xml

@ -44,6 +44,8 @@
FROM
logpm_warehouse_goods_area
WHERE
is_deleted = 0
AND
warehouse_id = #{warehouseId}
</select>
<select id="selectThirdNode" resultType="com.logpm.basicdata.vo.BasicdataNodeVO">
@ -54,7 +56,7 @@
FROM
logpm_warehouse_goods_shelf AS shelf
WHERE
shelf.warehouse_id = #{warehouseId} AND shelf.goods_area_id = #{areaId}
shelf.is_deleted = 0 AND shelf.warehouse_id = #{warehouseId} AND shelf.goods_area_id = #{areaId}
</select>
<select id="selectGoodsAllocationList" resultType="com.logpm.basicdata.vo.BasicdataGoodsAllocationVO">
SELECT

2
blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/mapper/BasicdataGoodsAreaMapper.java

@ -61,4 +61,6 @@ public interface BasicdataGoodsAreaMapper extends BaseMapper<BasicdataGoodsAreaE
List<BasicdataNodeVO> selectFirstNode();
List<BasicdataNodeVO> selectSecondNode(String value);
Integer removeGoodsArea(String id);
}

13
blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/mapper/BasicdataGoodsAreaMapper.xml

@ -20,9 +20,16 @@
<result column="reserve5" property="reserve5"/>
<result column="warehouse_id" property="warehouseId"/>
<result column="headline" property="headline"/>
<result column="area_status" property="areaStatus"/>
<result column="enbale_status" property="enableStatus"/>
<result column="is_strage_area" property="isStrageArea"/>
</resultMap>
<update id="removeGoodsArea">
UPDATE logpm_warehouse_goods_area
SET is_deleted = 1
WHERE
NOT EXISTS(SELECT goods_shelf.id FROM logpm_warehouse_goods_shelf AS goods_shelf WHERE goods_shelf.goods_area_id=#{id} AND goods_shelf.is_deleted=0)
AND id = #{id}
</update>
<select id="selectWarehouseGoodsAreaPage" resultMap="warehouseGoodsAreaResultMap">
@ -84,6 +91,8 @@
name AS label
FROM
logpm_warehouse_warehouse
WHERE
is_deleted=0
</select>
<select id="selectSecondNode" resultType="com.logpm.basicdata.vo.BasicdataNodeVO">
SELECT
@ -93,7 +102,7 @@
FROM
logpm_warehouse_goods_area
WHERE
warehouse_id = #{value}
warehouse_id = #{value} AND is_deleted=0
</select>
</mapper>

1
blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/mapper/BasicdataGoodsShelfMapper.java

@ -68,4 +68,5 @@ public interface BasicdataGoodsShelfMapper extends BaseMapper<BasicdataGoodsShel
*/
BasicdataGoodsShelfVO getGoodsShelfDetail(@Param("po")BasicdataGoodsShelfDTO basicdataGoodsShelfDTO);
Integer removeGoodsShelf(String id);
}

9
blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/mapper/BasicdataGoodsShelfMapper.xml

@ -26,6 +26,15 @@
<result column="goods_allcation_id" property="goodsAllcationId"/>
<result column="remarks" property="remarks"/>
</resultMap>
<update id="removeGoodsShelf">
UPDATE logpm_warehouse_goods_shelf
SET is_deleted = 1
WHERE
NOT EXISTS (
SELECT
goods_allocation.id FROM logpm_warehouse_goods_allocation AS goods_allocation WHERE goods_allocation.goods_shelf_id = #{id} AND goods_allocation.is_deleted=0)
AND id=#{id}
</update>
<select id="selectBasicdataGoodsShelfPage" resultMap="BasicdataGoodsShelfResultMap">

54
blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/mapper/BasicdataTrayMapper.java

@ -0,0 +1,54 @@
/*
* Copyright (c) 2018-2028, Chill Zhuang All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
* Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* Neither the name of the dreamlu.net developer nor the names of its
* contributors may be used to endorse or promote products derived from
* this software without specific prior written permission.
* Author: Chill 庄骞 (smallchill@163.com)
*/
package com.logpm.basicdata.mapper;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.baomidou.mybatisplus.core.conditions.Wrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.logpm.basicdata.entity.BasicdataTrayEntity;
import com.logpm.basicdata.excel.BasicdataTrayExcel;
import com.logpm.basicdata.vo.BasicdataTrayVO;
import org.apache.ibatis.annotations.Param;
import java.util.List;
/**
* 托盘 Mapper 接口
*
* @author tjj
* @since 2023-05-25
*/
public interface BasicdataTrayMapper extends BaseMapper<BasicdataTrayEntity> {
/**
* 自定义分页
*
* @param page
* @param BasicdataTray
* @return
*/
List<BasicdataTrayVO> selectBasicdataTrayPage(IPage page, BasicdataTrayVO BasicdataTray);
/**
* 获取导出数据
*
* @param queryWrapper
* @return
*/
List<BasicdataTrayExcel> exportBasicdataTray(@Param("ew") Wrapper<BasicdataTrayEntity> queryWrapper);
}

39
blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/mapper/BasicdataTrayMapper.xml

@ -0,0 +1,39 @@
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.logpm.basicdata.mapper.BasicdataTrayMapper">
<!-- 通用查询映射结果 -->
<resultMap id="BasicdataTrayResultMap" type="com.logpm.basicdata.entity.BasicdataTrayEntity">
<result column="tenant_id" property="tenantId"/>
<result column="create_user" property="createUser"/>
<result column="create_time" property="createTime"/>
<result column="update_user" property="updateUser"/>
<result column="update_time" property="updateTime"/>
<result column="status" property="status"/>
<result column="is_deleted" property="isDeleted"/>
<result column="create_dept" property="createDept"/>
<result column="id" property="id"/>
<result column="reserve1" property="reserve1"/>
<result column="reserve2" property="reserve2"/>
<result column="reserve3" property="reserve3"/>
<result column="reserve4" property="reserve4"/>
<result column="reserve5" property="reserve5"/>
<result column="pallet_code" property="palletCode"/>
<result column="warehouse_id" property="warehouseId"/>
<result column="tray_status" property="trayStatus"/>
<result column="qr_code_url" property="qrCodeUrl"/>
<result column="qr_code" property="qrCode"/>
<result column="type" property="type"/>
</resultMap>
<select id="selectBasicdataTrayPage" resultMap="BasicdataTrayResultMap">
select * from logpm_warehouse_tray where is_deleted = 0
</select>
<select id="exportBasicdataTray" resultType="com.logpm.basicdata.excel.BasicdataTrayExcel">
SELECT * FROM logpm_warehouse_tray ${ew.customSqlSegment}
</select>
</mapper>

5
blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/mapper/BasicdataWarehouseMapper.java

@ -19,10 +19,8 @@ package com.logpm.basicdata.mapper;
import com.baomidou.mybatisplus.core.conditions.Wrapper;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.logpm.basicdata.dto.BasicdataDTO;
import com.logpm.basicdata.entity.BasicdataWarehouseEntity;
import com.logpm.basicdata.excel.BasicdataWarehouseExcel;
import com.logpm.basicdata.vo.BasicdataGoodsShelfVO;
import com.logpm.basicdata.vo.BasicdataWarehouseVO;
import org.apache.ibatis.annotations.Param;
@ -60,5 +58,6 @@ public interface BasicdataWarehouseMapper extends BaseMapper<BasicdataWarehouseE
List<BasicdataWarehouseVO> getWarehouseList();
BasicdataDTO selectIsHaveResource(String id);
Integer removeWarehouse(String id);
}

22
blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/mapper/BasicdataWarehouseMapper.xml

@ -47,6 +47,14 @@
<result column="seating" property="seating"/>
<result column="grade" property="grade"/>
</resultMap>
<update id="removeWarehouse">
UPDATE logpm_warehouse_warehouse
SET is_deleted = 1
WHERE
NOT EXISTS ( SELECT b.id FROM logpm_warehouse_goods_area b WHERE b.warehouse_id = #{id} )
AND NOT EXISTS (SELECT f.id FROM logpm_basic_team_group f WHERE f.belong_to=#{id})
AND id = #{id}
</update>
<select id="selectWarehouseWarehousePage" resultMap="warehouseWarehouseResultMap">
@ -63,18 +71,8 @@
</select>
<select id="getWarehouseList" resultType="com.logpm.basicdata.vo.BasicdataWarehouseVO">
SELECT * FROM logpm_warehouse_warehouse
</select>
<select id="selectIsHaveResource" resultType="com.logpm.basicdata.dto.BasicdataDTO">
SELECT
b.id AS isHaveGoodsArea,
c.id AS isHaveGoodsShelf
FROM
logpm_warehouse_warehouse a
INNER JOIN logpm_warehouse_goods_area b ON a.id = b.warehouse_id
INNER JOIN logpm_warehouse_goods_shelf c ON a.id = c.warehouse_id
WHERE
a.id = #{id}
SELECT * FROM logpm_warehouse_warehouse WHERE is_deleted=0
</select>
</mapper>

1
blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/service/IBasicdataGoodsAllocationService.java

@ -76,4 +76,5 @@ public interface IBasicdataGoodsAllocationService extends BaseService<BasicdataG
IPage<BasicdataGoodsAllocationVO> selectGoodsAllocationList(Query query, Map<String, Object> basicdataGoodsAllocation);
boolean updateGoodsAllocation(BasicdataGoodsAllocationDTO basicdataGoodsAllocationDto);
}

6
blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/service/IBasicdataGoodsShelfService.java

@ -82,4 +82,10 @@ public interface IBasicdataGoodsShelfService extends BaseService<BasicdataGoodsS
*/
BasicdataGoodsShelfVO getGoodsShelfDetail(BasicdataGoodsShelfDTO basicdataGoodsShelfDTO);
/**
* 删除货架
* @param ids
* @return
*/
boolean removeGoodsShelf(List<String> ids);
}

55
blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/service/IBasicdataTrayService.java

@ -0,0 +1,55 @@
/*
* Copyright (c) 2018-2028, Chill Zhuang All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
* Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* Neither the name of the dreamlu.net developer nor the names of its
* contributors may be used to endorse or promote products derived from
* this software without specific prior written permission.
* Author: Chill 庄骞 (smallchill@163.com)
*/
package com.logpm.basicdata.service;
import com.baomidou.mybatisplus.core.conditions.Wrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.logpm.basicdata.dto.BasicdataTrayDTO;
import com.logpm.basicdata.entity.BasicdataTrayEntity;
import com.logpm.basicdata.excel.BasicdataTrayExcel;
import com.logpm.basicdata.vo.BasicdataTrayVO;
import org.springblade.core.mp.base.BaseService;
import java.util.List;
/**
* 托盘 服务类
*
* @author tjj
* @since 2023-05-25
*/
public interface IBasicdataTrayService extends BaseService<BasicdataTrayEntity> {
/**
* 自定义分页
*
* @param page
* @param BasicdataTray
* @return
*/
IPage<BasicdataTrayVO> selectBasicdataTrayPage(IPage<BasicdataTrayVO> page, BasicdataTrayVO BasicdataTray);
/**
* 导出数据
*
* @param queryWrapper
* @return
*/
List<BasicdataTrayExcel> exportBasicdataTray(Wrapper<BasicdataTrayEntity> queryWrapper);
boolean insertTray(BasicdataTrayDTO basicdataTrayDTO);
}

58
blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/service/impl/BasicdataGoodsAllocationServiceImpl.java

@ -84,7 +84,7 @@ public class BasicdataGoodsAllocationServiceImpl extends BaseServiceImpl<Basicda
for (BasicdataNodeVO goodeAreaNode : goodeAreaNodes) {
//遍历货区节点信息,查询货区对应货架节点
List<BasicdataNodeVO> goodsShelfNode = goodsAllocationMapper.selectThirdNode(basicdataNodeVO.getValue(),goodeAreaNode.getValue());
if (!Func.isEmpty(goodeAreaNode)){
if (!Func.isEmpty(goodsShelfNode)){
goodeAreaNode.setChildren(goodsShelfNode);
}else {
goodeAreaNode.setLeaf(true);
@ -101,18 +101,19 @@ public class BasicdataGoodsAllocationServiceImpl extends BaseServiceImpl<Basicda
@Override
public boolean insertGoodsAllocation( BasicdataGoodsAllocationDTO basicdataGoodsAllocationDto) {
BasicdataGoodsAllocationEntity basicdataGoodsAllocationEntity = new BasicdataGoodsAllocationEntity();
List<Object> nodeInfo = basicdataGoodsAllocationDto.getNodeInfo();
List<String> nodeInfo = basicdataGoodsAllocationDto.getNodeInfo();
if (Func.isEmpty(nodeInfo)){
log.error("参数不合法:{}"+nodeInfo);
return false;
}else {
basicdataGoodsAllocationEntity.setWarehouseId((String) nodeInfo.get(0));
basicdataGoodsAllocationEntity.setGoodsAreaId((String) nodeInfo.get(1));
basicdataGoodsAllocationEntity.setGoodsShelfId((String) nodeInfo.get(2));
}
BeanUtils.copyProperties(basicdataGoodsAllocationDto,basicdataGoodsAllocationEntity);
BladeUser user = AuthUtil.getUser();
Long userId = user.getUserId();
basicdataGoodsAllocationEntity.setWarehouseId( nodeInfo.get(0));
basicdataGoodsAllocationEntity.setGoodsAreaId( nodeInfo.get(1));
basicdataGoodsAllocationEntity.setGoodsShelfId( nodeInfo.get(2));
basicdataGoodsAllocationEntity.setEnableStatus("1");
basicdataGoodsAllocationEntity.setStatus(1);
basicdataGoodsAllocationEntity.setIsDeleted(0);
@ -134,23 +135,40 @@ public class BasicdataGoodsAllocationServiceImpl extends BaseServiceImpl<Basicda
@Override
public IPage<BasicdataGoodsAllocationVO> selectGoodsAllocationList(Query query, Map<String, Object> basicdataGoodsAllocation) {
IPage<Object> page = Condition.getPage(query);
String nodeInfo = (String) basicdataGoodsAllocation.get("nodeInfo[]");
if (!Func.isBlank(nodeInfo)){
String[] split = nodeInfo.split(",");
if (split.length==1){
basicdataGoodsAllocation.put("warehouseId",split[0]);
}else if (split.length==2){
basicdataGoodsAllocation.put("warehouseId",split[0]);
basicdataGoodsAllocation.put("goodsAreaId",split[1]);
}else if (split.length==3){
basicdataGoodsAllocation.put("warehouseId",split[0]);
basicdataGoodsAllocation.put("goodsAreaId",split[1]);
basicdataGoodsAllocation.put("goodsShelfId",split[2]);
}
}
//这里前端进行了封装,不需要再进行处理了
IPage<BasicdataGoodsAllocationVO> goodsAllocationVOIPage = goodsAllocationMapper.selectGoodsAllocationList(page,basicdataGoodsAllocation);
return goodsAllocationVOIPage;
}
@Override
public boolean updateGoodsAllocation(BasicdataGoodsAllocationDTO basicdataGoodsAllocationDto) {
List<String> nodeInfo = basicdataGoodsAllocationDto.getNodeInfo();
boolean result = false;
if (Func.isEmpty(nodeInfo)){
return result;
}else {
BasicdataGoodsAllocationEntity basicdataGoodsAllocationEntity = new BasicdataGoodsAllocationEntity();
BeanUtils.copyProperties(basicdataGoodsAllocationDto,basicdataGoodsAllocationEntity);
if (nodeInfo.size()==1){
basicdataGoodsAllocationEntity.setWarehouseId(nodeInfo.get(0));
basicdataGoodsAllocationEntity.setGoodsAreaId("");
basicdataGoodsAllocationEntity.setGoodsShelfId("");
}else if (nodeInfo.size()==2){
basicdataGoodsAllocationEntity.setWarehouseId(nodeInfo.get(0));
basicdataGoodsAllocationEntity.setWarehouseId(nodeInfo.get(1));
basicdataGoodsAllocationEntity.setGoodsShelfId("");
}else if (nodeInfo.size()==3){
basicdataGoodsAllocationEntity.setWarehouseId(nodeInfo.get(0));
basicdataGoodsAllocationEntity.setGoodsAreaId(nodeInfo.get(1));
basicdataGoodsAllocationEntity.setGoodsShelfId(nodeInfo.get(2));
}else {
return result;
}
result = SqlHelper.retBool(goodsAllocationMapper.updateById(basicdataGoodsAllocationEntity));
}
return result;
}
}

15
blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/service/impl/BasicdataGoodsAreaServiceImpl.java

@ -17,6 +17,7 @@
package com.logpm.basicdata.service.impl;
import com.baomidou.mybatisplus.extension.toolkit.SqlHelper;
import com.logpm.basicdata.entity.BasicdataGoodsAreaEntity;
import com.logpm.basicdata.excel.BasicdataGoodsAreaExcel;
import com.logpm.basicdata.mapper.BasicdataGoodsAreaMapper;
@ -30,6 +31,7 @@ import org.springframework.stereotype.Service;
import com.baomidou.mybatisplus.core.conditions.Wrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import org.springblade.core.mp.base.BaseServiceImpl;
import org.springframework.transaction.annotation.Transactional;
import java.util.Collections;
import java.util.List;
@ -95,10 +97,19 @@ public class BasicdataGoodsAreaServiceImpl extends BaseServiceImpl<BasicdataGood
}
@Override
@Transactional
public boolean removeGoodsArea(List<String> ids) {
//删除货区,查看货区下是否存在货架信息
if (Func.isEmpty(ids)){
log.error("参数错误:{}"+ids);
return false;
}
boolean result = false;
if (!Func.isEmpty(ids)){
result = super.removeByIds(ids);
for (String id : ids) {
result = SqlHelper.retBool(basicdataGoodsAreaMapper.removeGoodsArea(id));
if (!result){
throw new RuntimeException("选中货区还存在待删货架!!!");
}
}
return result;
}

95
blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/service/impl/BasicdataGoodsShelfServiceImpl.java

@ -80,47 +80,66 @@ public class BasicdataGoodsShelfServiceImpl extends BaseServiceImpl<BasicdataGoo
@Transactional(rollbackFor = Exception.class)
public boolean insertGoodsshelf(BasicdataGoodsShelfDTO basicdataGoodsShelfDTO) {
//维护仓库、货区数据
List<String> info = basicdataGoodsShelfDTO.getGoodsAreaInfo();
boolean result = false;
//这里新增货架必须有仓库和货区的信息
if (!Func.isEmpty(info) ){
basicdataGoodsShelfDTO.setWarehouseId(info.get(0));
basicdataGoodsShelfDTO.setGoodsAreaId(info.get(1));
if (Func.isEmpty(info) ){
return result;
}else {
BasicdataGoodsShelfEntity basicdataGoodsShelfEntity = new BasicdataGoodsShelfEntity();
BeanUtils.copyProperties(basicdataGoodsShelfDTO,basicdataGoodsShelfEntity);
if (info.size()==1){
basicdataGoodsShelfEntity.setWarehouseId(info.get(0));
basicdataGoodsShelfEntity.setGoodsAreaId(null);
}else if (info.size()==2){
basicdataGoodsShelfEntity.setWarehouseId(info.get(0));
basicdataGoodsShelfEntity.setGoodsAreaId(info.get(1));
}else {
return result;
}
BladeUser user = AuthUtil.getUser();
BeanUtils.copyProperties(basicdataGoodsShelfDTO,basicdataGoodsShelfEntity);
basicdataGoodsShelfEntity.setCreateTime(new Date());
basicdataGoodsShelfEntity.setCreateDept( Long.valueOf(user.getDeptId()));
basicdataGoodsShelfEntity.setCreateUser(user.getUserId());
basicdataGoodsShelfEntity.setUpdateTime(new Date());
basicdataGoodsShelfEntity.setUpdateUser(user.getUserId());
basicdataGoodsShelfEntity.setCreateUser(user.getUserId());
//数据状态默认正常
basicdataGoodsShelfEntity.setStatus(1);
//货架添加删除状态为正常
basicdataGoodsShelfEntity.setIsDeleted(0);
//货架添加初始未满
basicdataGoodsShelfEntity.setGoodsShelfStatus(1);
//货架添加默认启用
basicdataGoodsShelfEntity.setEnableStatus(1);
result = SqlHelper.retBool(basicdataGoodsShelfMapper.insert(basicdataGoodsShelfEntity));
}
BladeUser user = AuthUtil.getUser();
BasicdataGoodsShelfEntity basicdataGoodsShelfEntity = new BasicdataGoodsShelfEntity();
BeanUtils.copyProperties(basicdataGoodsShelfDTO,basicdataGoodsShelfEntity);
basicdataGoodsShelfEntity.setCreateTime(new Date());
basicdataGoodsShelfEntity.setCreateDept( Long.valueOf(user.getDeptId()));
basicdataGoodsShelfEntity.setCreateUser(user.getUserId());
basicdataGoodsShelfEntity.setUpdateTime(new Date());
basicdataGoodsShelfEntity.setUpdateUser(user.getUserId());
basicdataGoodsShelfEntity.setCreateUser(user.getUserId());
//数据状态默认正常
basicdataGoodsShelfEntity.setStatus(1);
//货架添加删除状态为正常
basicdataGoodsShelfEntity.setIsDeleted(0);
//货架添加初始未满
basicdataGoodsShelfEntity.setGoodsShelfStatus(1);
//货架添加默认启用
basicdataGoodsShelfEntity.setEnableStatus(1);
boolean result = SqlHelper.retBool(basicdataGoodsShelfMapper.insert(basicdataGoodsShelfEntity));
return result;
}
@Override
@Transactional
public boolean updateGoodsShelfInfo(BasicdataGoodsShelfDTO basicdataGoodsShelfDTO) {
List<String> goodsAreaInfo = basicdataGoodsShelfDTO.getGoodsAreaInfo();
if (!Func.isEmpty(goodsAreaInfo) ){
basicdataGoodsShelfDTO.setWarehouseId(goodsAreaInfo.get(0));
basicdataGoodsShelfDTO.setGoodsAreaId(goodsAreaInfo.get(1));
boolean result = false;
if (Func.isEmpty(goodsAreaInfo) ){
return result;
}else {
BasicdataGoodsShelfEntity basicdataGoodsShelfEntity = new BasicdataGoodsShelfEntity();
BeanUtils.copyProperties(basicdataGoodsShelfDTO,basicdataGoodsShelfEntity);
if (goodsAreaInfo.size()==1){
basicdataGoodsShelfEntity.setWarehouseId(goodsAreaInfo.get(0));
basicdataGoodsShelfEntity.setGoodsAreaId("");
}else if (goodsAreaInfo.size()==2){
basicdataGoodsShelfEntity.setWarehouseId(goodsAreaInfo.get(0));
basicdataGoodsShelfEntity.setGoodsAreaId(goodsAreaInfo.get(1));
}else {
return result;
}
result = SqlHelper.retBool(basicdataGoodsShelfMapper.updateById(basicdataGoodsShelfEntity));
}
BasicdataGoodsShelfEntity basicdataGoodsShelfEntity = new BasicdataGoodsShelfEntity();
BeanUtils.copyProperties(basicdataGoodsShelfDTO,basicdataGoodsShelfEntity);
boolean result = SqlHelper.retBool(basicdataGoodsShelfMapper.updateById(basicdataGoodsShelfEntity));
//获取当前登陆对象
return result;
}
@ -130,4 +149,20 @@ public class BasicdataGoodsShelfServiceImpl extends BaseServiceImpl<BasicdataGoo
return basicdataGoodsShelf;
}
@Override
public boolean removeGoodsShelf(List<String> ids) {
if (Func.isEmpty(ids)){
log.error("参数错误:{}"+ids);
return false;
}
boolean result = false;
for (String id : ids) {
result = SqlHelper.retBool(basicdataGoodsShelfMapper.removeGoodsShelf(id));
if (!result){
throw new RuntimeException("选中货架存在待删货位!!!");
}
}
return result;
}
}

92
blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/service/impl/BasicdataTrayServiceImpl.java

@ -0,0 +1,92 @@
/*
* Copyright (c) 2018-2028, Chill Zhuang All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
* Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* Neither the name of the dreamlu.net developer nor the names of its
* contributors may be used to endorse or promote products derived from
* this software without specific prior written permission.
* Author: Chill 庄骞 (smallchill@163.com)
*/
package com.logpm.basicdata.service.impl;
import com.baomidou.mybatisplus.extension.toolkit.SqlHelper;
import com.logpm.basicdata.dto.BasicdataTrayDTO;
import com.logpm.basicdata.entity.BasicdataTrayEntity;
import com.logpm.basicdata.excel.BasicdataTrayExcel;
import com.logpm.basicdata.mapper.BasicdataTrayMapper;
import com.logpm.basicdata.service.IBasicdataTrayService;
import com.logpm.basicdata.vo.BasicdataTrayVO;
import lombok.AllArgsConstructor;
import org.springblade.core.mp.base.BaseServiceImpl;
import org.springblade.core.secure.BladeUser;
import org.springblade.core.secure.utils.AuthUtil;
import org.springblade.core.tool.utils.Func;
import org.springframework.beans.BeanUtils;
import org.springframework.stereotype.Service;
import com.baomidou.mybatisplus.core.conditions.Wrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import java.util.Date;
import java.util.List;
/**
* 托盘 服务实现类
*
* @author tjj
* @since 2023-05-25
*/
@Service
@AllArgsConstructor
public class BasicdataTrayServiceImpl extends BaseServiceImpl<BasicdataTrayMapper, BasicdataTrayEntity> implements IBasicdataTrayService {
private BasicdataTrayMapper trayMapper;
@Override
public IPage<BasicdataTrayVO> selectBasicdataTrayPage(IPage<BasicdataTrayVO> page, BasicdataTrayVO BasicdataTray) {
return page.setRecords(baseMapper.selectBasicdataTrayPage(page, BasicdataTray));
}
@Override
public List<BasicdataTrayExcel> exportBasicdataTray(Wrapper<BasicdataTrayEntity> queryWrapper) {
List<BasicdataTrayExcel> BasicdataTrayList = baseMapper.exportBasicdataTray(queryWrapper);
//BasicdataTrayList.forEach(BasicdataTray -> {
// BasicdataTray.setTypeName(DictCache.getValue(DictEnum.YES_NO, BasicdataTray.getType()));
//});
return BasicdataTrayList;
}
@Override
public boolean insertTray(BasicdataTrayDTO basicdataTrayDTO) {
BasicdataTrayEntity basicdataTrayEntity =null;
if (Func.isEmpty(basicdataTrayDTO)){
return false;
}else {
basicdataTrayEntity = new BasicdataTrayEntity();
BeanUtils.copyProperties(basicdataTrayDTO,basicdataTrayEntity);
BladeUser user = AuthUtil.getUser();
Long userId = user.getUserId();
Date date = new Date();
basicdataTrayEntity.setCreateDept(Long.valueOf(user.getDeptId()));
basicdataTrayEntity.setCreateTime(date);
basicdataTrayEntity.setCreateUser(userId);
basicdataTrayEntity.setIsDeleted(0);
basicdataTrayEntity.setTenantId(user.getTenantId());
basicdataTrayEntity.setStatus(1);
basicdataTrayEntity.setUpdateTime(date);
basicdataTrayEntity.setUpdateUser(user.getUserId());
basicdataTrayEntity.setTrayStatus("1");
}
boolean result = SqlHelper.retBool(trayMapper.insert(basicdataTrayEntity));
return result;
}
}

25
blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/service/impl/BasicdataWarehouseServiceImpl.java

@ -16,17 +16,14 @@
*/
package com.logpm.basicdata.service.impl;
import cn.hutool.db.Page;
import com.alibaba.fastjson.JSONObject;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.core.toolkit.StringUtils;
import com.logpm.basicdata.dto.BasicdataDTO;
import com.baomidou.mybatisplus.extension.toolkit.SqlHelper;
import com.logpm.basicdata.entity.BasicdataWarehouseEntity;
import com.logpm.basicdata.excel.BasicdataWarehouseExcel;
import com.logpm.basicdata.mapper.BasicdataGoodsAreaMapper;
import com.logpm.basicdata.mapper.BasicdataWarehouseMapper;
import com.logpm.basicdata.service.IBasicdataWarehouseService;
import com.logpm.basicdata.vo.BasicdataGoodsShelfVO;
import com.logpm.basicdata.vo.BasicdataWarehouseVO;
import lombok.AllArgsConstructor;
import org.springblade.core.tool.utils.Func;
@ -34,10 +31,9 @@ import org.springframework.stereotype.Service;
import com.baomidou.mybatisplus.core.conditions.Wrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import org.springblade.core.mp.base.BaseServiceImpl;
import org.springframework.transaction.annotation.Transactional;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
/**
* 仓库 服务实现类
@ -53,6 +49,7 @@ public class BasicdataWarehouseServiceImpl extends BaseServiceImpl<BasicdataWare
private BasicdataGoodsAreaMapper goodsAreaMapper;
@Override
public IPage<BasicdataWarehouseVO> selectWarehouseWarehousePage(IPage<BasicdataWarehouseVO> page, BasicdataWarehouseVO warehouseWarehouse) {
return page.setRecords(baseMapper.selectWarehouseWarehousePage(page, warehouseWarehouse));
@ -82,19 +79,19 @@ public class BasicdataWarehouseServiceImpl extends BaseServiceImpl<BasicdataWare
}
@Override
@Transactional
public boolean removeWarehouse(List<String> ids) {
//删除仓库应该针对仓库锁关联的信息都进行逻辑删除
//多个id数据格式1658283633661894657,1658317411591540738,1659120672275914753
// //仓库涉及众多表,取消批量删除,这里只针对仓库下是否存在有托盘、货区、班组等下级资源
if (Func.isEmpty(ids)){
return false;
}
boolean result = false;
for (String id : ids) {
BasicdataDTO basicdataDTO = warehouseMapper.selectIsHaveResource(id);
if (!Func.isEmpty(basicdataDTO)){
return result;
}else {
result = super.removeByIds(ids);
result = SqlHelper.retBool(warehouseMapper.removeWarehouse(id));
if (!result){
throw new RuntimeException("选中仓库还存在待删除资源!!!");
}
}
return result;
}

2
doc/dpm/物流租户系统.pdma.json

@ -32685,4 +32685,4 @@
}
],
"dbConn": []
}
}

Loading…
Cancel
Save