add: 分切CRUD
This commit is contained in:
@@ -1,6 +1,7 @@
|
||||
package org.nl.b_lms.bst.ivt.cutpointivt.controller;
|
||||
|
||||
import lombok.extern.slf4j.Slf4j;
|
||||
import org.nl.b_lms.bst.ivt.cutpointivt.service.dto.BstIvtCutpointivtQuery;
|
||||
import org.nl.common.TableDataInfo;
|
||||
import org.nl.common.domain.query.PageQuery;
|
||||
import org.nl.modules.logging.annotation.Log;
|
||||
@@ -29,7 +30,7 @@ public class BstIvtCutpointivtController {
|
||||
@GetMapping
|
||||
@Log("查询分切区缓存点位库存")
|
||||
//@SaCheckPermission("@el.check('bstIvtCutpointivt:list')")
|
||||
public ResponseEntity<Object> query(@RequestParam Map whereJson, PageQuery page){
|
||||
public ResponseEntity<Object> query(BstIvtCutpointivtQuery whereJson, PageQuery page){
|
||||
return new ResponseEntity<>(TableDataInfo.build(bstIvtCutpointivtService.queryAll(whereJson,page)),HttpStatus.OK);
|
||||
}
|
||||
|
||||
|
||||
@@ -1,6 +1,7 @@
|
||||
package org.nl.b_lms.bst.ivt.cutpointivt.service;
|
||||
|
||||
import com.baomidou.mybatisplus.core.metadata.IPage;
|
||||
import org.nl.b_lms.bst.ivt.cutpointivt.service.dto.BstIvtCutpointivtQuery;
|
||||
import org.nl.common.domain.query.PageQuery;
|
||||
import com.baomidou.mybatisplus.extension.service.IService;
|
||||
import org.nl.b_lms.bst.ivt.cutpointivt.service.dao.BstIvtCutpointivt;
|
||||
@@ -22,7 +23,7 @@ public interface IBstIvtCutpointivtService extends IService<BstIvtCutpointivt> {
|
||||
* @param pageable 分页参数
|
||||
* @return IPage<BstIvtCutpointivt>
|
||||
*/
|
||||
IPage<BstIvtCutpointivt> queryAll(Map whereJson, PageQuery pageable);
|
||||
IPage<BstIvtCutpointivt> queryAll(BstIvtCutpointivtQuery whereJson, PageQuery pageable);
|
||||
|
||||
/**
|
||||
* 创建
|
||||
|
||||
@@ -1,12 +1,20 @@
|
||||
package org.nl.b_lms.bst.ivt.cutpointivt.service.dto;
|
||||
|
||||
import lombok.Data;
|
||||
import org.nl.common.domain.query.BaseQuery;
|
||||
import org.nl.b_lms.bst.ivt.cutpointivt.service.dao.BstIvtCutpointivt;
|
||||
|
||||
import java.io.Serializable;
|
||||
|
||||
/**
|
||||
* @author lyd
|
||||
* @date 2024-02-26
|
||||
**/
|
||||
public class BstIvtCutpointivtQuery extends BaseQuery<BstIvtCutpointivt> {
|
||||
|
||||
@Data
|
||||
public class BstIvtCutpointivtQuery implements Serializable {
|
||||
private String point_type;
|
||||
private String point_code;
|
||||
private String product_area;
|
||||
private String is_used;
|
||||
private String point_location;
|
||||
}
|
||||
|
||||
@@ -2,6 +2,7 @@ package org.nl.b_lms.bst.ivt.cutpointivt.service.impl;
|
||||
|
||||
import cn.hutool.core.date.DateUtil;
|
||||
import cn.hutool.core.util.IdUtil;
|
||||
import cn.hutool.core.util.ObjectUtil;
|
||||
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
||||
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
|
||||
import com.baomidou.mybatisplus.core.metadata.IPage;
|
||||
@@ -11,6 +12,7 @@ import lombok.extern.slf4j.Slf4j;
|
||||
import org.nl.b_lms.bst.ivt.cutpointivt.service.IBstIvtCutpointivtService;
|
||||
import org.nl.b_lms.bst.ivt.cutpointivt.service.dao.BstIvtCutpointivt;
|
||||
import org.nl.b_lms.bst.ivt.cutpointivt.service.dao.mapper.BstIvtCutpointivtMapper;
|
||||
import org.nl.b_lms.bst.ivt.cutpointivt.service.dto.BstIvtCutpointivtQuery;
|
||||
import org.nl.common.domain.query.PageQuery;
|
||||
import org.nl.common.utils.SecurityUtils;
|
||||
import org.nl.modules.common.exception.BadRequestException;
|
||||
@@ -35,8 +37,13 @@ public class BstIvtCutpointivtServiceImpl extends ServiceImpl<BstIvtCutpointivtM
|
||||
private BstIvtCutpointivtMapper bstIvtCutpointivtMapper;
|
||||
|
||||
@Override
|
||||
public IPage<BstIvtCutpointivt> queryAll(Map whereJson, PageQuery page){
|
||||
public IPage<BstIvtCutpointivt> queryAll(BstIvtCutpointivtQuery whereJson, PageQuery page){
|
||||
LambdaQueryWrapper<BstIvtCutpointivt> lam = new LambdaQueryWrapper<>();
|
||||
lam.eq(ObjectUtil.isNotEmpty(whereJson.getPoint_code()), BstIvtCutpointivt::getPoint_code, whereJson.getPoint_code())
|
||||
.eq(ObjectUtil.isNotEmpty(whereJson.getPoint_type()), BstIvtCutpointivt::getPoint_type, whereJson.getPoint_type())
|
||||
.eq(ObjectUtil.isNotEmpty(whereJson.getProduct_area()), BstIvtCutpointivt::getProduct_area, whereJson.getProduct_area())
|
||||
.eq(ObjectUtil.isNotEmpty(whereJson.getIs_used()), BstIvtCutpointivt::getIs_used, whereJson.getIs_used())
|
||||
.eq(ObjectUtil.isNotEmpty(whereJson.getPoint_location()), BstIvtCutpointivt::getPoint_location, whereJson.getPoint_location());
|
||||
IPage<BstIvtCutpointivt> pages = new Page<>(page.getPage() + 1, page.getSize());
|
||||
bstIvtCutpointivtMapper.selectPage(pages, lam);
|
||||
return pages;
|
||||
|
||||
@@ -1,6 +1,7 @@
|
||||
package org.nl.b_lms.bst.ivt.shafttubeivt.controller;
|
||||
|
||||
import lombok.extern.slf4j.Slf4j;
|
||||
import org.nl.b_lms.bst.ivt.shafttubeivt.service.dto.BstIvtShafttubeivtQuery;
|
||||
import org.nl.common.TableDataInfo;
|
||||
import org.nl.common.domain.query.PageQuery;
|
||||
import org.nl.modules.logging.annotation.Log;
|
||||
@@ -29,7 +30,7 @@ public class BstIvtShafttubeivtController {
|
||||
@GetMapping
|
||||
@Log("查询穿拔轴区点位库存管理")
|
||||
//@SaCheckPermission("@el.check('bstIvtShafttubeivt:list')")
|
||||
public ResponseEntity<Object> query(@RequestParam Map whereJson, PageQuery page){
|
||||
public ResponseEntity<Object> query(BstIvtShafttubeivtQuery whereJson, PageQuery page){
|
||||
return new ResponseEntity<>(TableDataInfo.build(bstIvtShafttubeivtService.queryAll(whereJson,page)),HttpStatus.OK);
|
||||
}
|
||||
|
||||
|
||||
@@ -1,6 +1,7 @@
|
||||
package org.nl.b_lms.bst.ivt.shafttubeivt.service;
|
||||
|
||||
import com.baomidou.mybatisplus.core.metadata.IPage;
|
||||
import org.nl.b_lms.bst.ivt.shafttubeivt.service.dto.BstIvtShafttubeivtQuery;
|
||||
import org.nl.common.domain.query.PageQuery;
|
||||
import com.baomidou.mybatisplus.extension.service.IService;
|
||||
import org.nl.b_lms.bst.ivt.shafttubeivt.service.dao.BstIvtShafttubeivt;
|
||||
@@ -22,7 +23,7 @@ public interface IBstIvtShafttubeivtService extends IService<BstIvtShafttubeivt>
|
||||
* @param pageable 分页参数
|
||||
* @return IPage<BstIvtShafttubeivt>
|
||||
*/
|
||||
IPage<BstIvtShafttubeivt> queryAll(Map whereJson, PageQuery pageable);
|
||||
IPage<BstIvtShafttubeivt> queryAll(BstIvtShafttubeivtQuery whereJson, PageQuery pageable);
|
||||
|
||||
/**
|
||||
* 创建
|
||||
|
||||
@@ -1,12 +1,20 @@
|
||||
package org.nl.b_lms.bst.ivt.shafttubeivt.service.dto;
|
||||
|
||||
import lombok.Data;
|
||||
import org.nl.common.domain.query.BaseQuery;
|
||||
import org.nl.b_lms.bst.ivt.shafttubeivt.service.dao.BstIvtShafttubeivt;
|
||||
|
||||
import java.io.Serializable;
|
||||
|
||||
/**
|
||||
* @author lyd
|
||||
* @date 2024-02-26
|
||||
**/
|
||||
public class BstIvtShafttubeivtQuery extends BaseQuery<BstIvtShafttubeivt> {
|
||||
@Data
|
||||
public class BstIvtShafttubeivtQuery implements Serializable {
|
||||
private String point_code;
|
||||
private String point_type;
|
||||
private String point_location;
|
||||
private String is_used;
|
||||
|
||||
}
|
||||
|
||||
@@ -10,6 +10,7 @@ import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
||||
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
||||
import lombok.RequiredArgsConstructor;
|
||||
import lombok.extern.slf4j.Slf4j;
|
||||
import org.nl.b_lms.bst.ivt.shafttubeivt.service.dto.BstIvtShafttubeivtQuery;
|
||||
import org.nl.modules.common.exception.BadRequestException;
|
||||
import org.nl.common.domain.query.PageQuery;
|
||||
import org.nl.common.utils.SecurityUtils;
|
||||
@@ -36,8 +37,12 @@ public class BstIvtShafttubeivtServiceImpl extends ServiceImpl<BstIvtShafttubeiv
|
||||
private BstIvtShafttubeivtMapper bstIvtShafttubeivtMapper;
|
||||
|
||||
@Override
|
||||
public IPage<BstIvtShafttubeivt> queryAll(Map whereJson, PageQuery page){
|
||||
public IPage<BstIvtShafttubeivt> queryAll(BstIvtShafttubeivtQuery whereJson, PageQuery page){
|
||||
LambdaQueryWrapper<BstIvtShafttubeivt> lam = new LambdaQueryWrapper<>();
|
||||
lam.eq(ObjectUtil.isNotEmpty(whereJson.getPoint_code()), BstIvtShafttubeivt::getPoint_code, whereJson.getPoint_code())
|
||||
.eq(ObjectUtil.isNotEmpty(whereJson.getPoint_type()), BstIvtShafttubeivt::getPoint_type, whereJson.getPoint_type())
|
||||
.eq(ObjectUtil.isNotEmpty(whereJson.getPoint_location()), BstIvtShafttubeivt::getPoint_location, whereJson.getPoint_location())
|
||||
.eq(ObjectUtil.isNotEmpty(whereJson.getIs_used()), BstIvtShafttubeivt::getIs_used, whereJson.getIs_used());
|
||||
IPage<BstIvtShafttubeivt> pages = new Page<>(page.getPage() + 1, page.getSize());
|
||||
bstIvtShafttubeivtMapper.selectPage(pages, lam);
|
||||
return pages;
|
||||
|
||||
@@ -15,6 +15,7 @@ import org.nl.b_lms.sch.task.dao.SchBaseTask;
|
||||
import org.nl.b_lms.sch.task.service.IschBaseTaskService;
|
||||
import org.nl.b_lms.sch.tasks.slitter.TrussCallAirShaftTask;
|
||||
import org.nl.b_lms.sch.tasks.slitter.mapper.dto.SlitterPlanDistinctDto;
|
||||
import org.nl.common.utils.SecurityUtils;
|
||||
import org.nl.common.utils.TaskUtils;
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
import org.springframework.stereotype.Component;
|
||||
@@ -52,18 +53,20 @@ public class AutoCallAirShaftTask {
|
||||
// todo: 未考虑区域
|
||||
List<SlitterPlanDistinctDto> plans = slittingproductionplanService.getAllCutPlan();
|
||||
if (plans.size() == 0) {
|
||||
// todo: 如果不需要套轴,就只做拔轴
|
||||
// 如果不需要套轴,就只做拔轴
|
||||
makePullShaft(empty);
|
||||
return;
|
||||
}
|
||||
// 获取一个分切计划的Dto。一根轴可能有两个分切计划
|
||||
SlitterPlanDistinctDto planDto = plans.get(0);
|
||||
// 查看套轴对接位是否满了
|
||||
List<BstIvtCutpointivt> emptyShaftPoint = bcutpointivtService.getAreaNotTaskPointByStatus("1", "1", "0");
|
||||
// 如果满了就只做拔轴
|
||||
if (emptyShaftPoint.size() == 0) {
|
||||
// todo: 如果不需要套轴,就只做拔轴
|
||||
// 如果不需要套轴,就只做拔轴
|
||||
makePullShaft(empty);
|
||||
return;
|
||||
}
|
||||
// 获取一个分切计划的Dto。一根轴可能有两个分切计划
|
||||
SlitterPlanDistinctDto planDto = plans.get(0);
|
||||
// 获取分切计划dto中对应的需要套轴的分切计划 最多两个计划
|
||||
List<PdmBiSlittingproductionplan> needPlans = slittingproductionplanService.list(new LambdaQueryWrapper<PdmBiSlittingproductionplan>()
|
||||
.eq(PdmBiSlittingproductionplan::getResource_name, planDto.getResource_name())
|
||||
@@ -78,7 +81,8 @@ public class AutoCallAirShaftTask {
|
||||
if (qzzPoint.size() == 0) {
|
||||
// todo 调用ACS滚条气涨轴下来
|
||||
|
||||
// todo: 保存所需要的分切计划数据到点位上(套轴对接位)更新分切计划
|
||||
// 保存所需要的分切计划数据到点位上(套轴对接位)更新分切计划
|
||||
saveCutPlanMessage(empty, needPlans, qzzSize);
|
||||
return;
|
||||
}
|
||||
// 查找一条没任务的点位 todo: 优先获取只有一根轴的点位
|
||||
@@ -87,7 +91,8 @@ public class AutoCallAirShaftTask {
|
||||
// 如果不存在,则发起信号滚气涨轴
|
||||
// todo 调用ACS滚条气涨轴下来
|
||||
|
||||
// todo: 保存所需要的分切计划数据到点位上(套轴对接位)更新分切计划
|
||||
// 保存所需要的分切计划数据到点位上(套轴对接位)更新分切计划
|
||||
saveCutPlanMessage(empty, needPlans, qzzSize);
|
||||
return;
|
||||
}
|
||||
// 创建任务
|
||||
@@ -122,6 +127,57 @@ public class AutoCallAirShaftTask {
|
||||
});
|
||||
}
|
||||
|
||||
private static void saveCutPlanMessage(BstIvtShafttubeivt empty, List<PdmBiSlittingproductionplan> needPlans, String qzzSize) {
|
||||
empty.setHave_qzz("1");
|
||||
empty.setQzz_size(qzzSize);
|
||||
empty.setUpdate_optid(SecurityUtils.getCurrentUserId());
|
||||
empty.setUpdate_optname(SecurityUtils.getCurrentUsername());
|
||||
empty.setUpdate_time(DateUtil.now());
|
||||
for (PdmBiSlittingproductionplan plan : needPlans) {
|
||||
if ("1".equals(plan.getLeft_or_right())) {
|
||||
// 左卷
|
||||
if ("1".equals(plan.getPaper_tube_or_FRP())) {
|
||||
empty.setTube_code1(plan.getPaper_tube_material());
|
||||
empty.setTube_name1(plan.getPaper_tube_model());
|
||||
} else {
|
||||
empty.setTube_code1(plan.getFRP_material());
|
||||
empty.setTube_name1(plan.getFRP_model());
|
||||
}
|
||||
empty.setContainer_name1(plan.getContainer_name());
|
||||
} else {
|
||||
// 右卷
|
||||
if ("1".equals(plan.getPaper_tube_or_FRP())) {
|
||||
empty.setTube_code1(plan.getPaper_tube_material());
|
||||
empty.setTube_name1(plan.getPaper_tube_model());
|
||||
} else {
|
||||
empty.setTube_code1(plan.getFRP_material());
|
||||
empty.setTube_name1(plan.getFRP_model());
|
||||
}
|
||||
empty.setContainer_name2(plan.getContainer_name());
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private void makePullShaft(BstIvtShafttubeivt empty) {
|
||||
List<BstIvtCutpointivt> notTaskPoints = bcutpointivtService.getAreaNotTaskPointByStatus("1", "3", "0");
|
||||
if (notTaskPoints.size() == 0) {
|
||||
return;
|
||||
}
|
||||
BstIvtCutpointivt cutpointivt = notTaskPoints.get(0);
|
||||
JSONObject param = new JSONObject();
|
||||
param.put("point_code1", ObjectUtil.isNotEmpty(cutpointivt.getQzz_no1())
|
||||
? cutpointivt.getTruss_point_code1() : cutpointivt.getTruss_point_code2());
|
||||
param.put("point_code2", empty.getPoint_code());
|
||||
param.put("vehicle_code", ObjectUtil.isNotEmpty(cutpointivt.getQzz_no1())
|
||||
? cutpointivt.getQzz_no1() : cutpointivt.getQzz_no2());
|
||||
param.put("qzz_no", ObjectUtil.isNotEmpty(cutpointivt.getQzz_no1())
|
||||
? cutpointivt.getQzz_no1() : cutpointivt.getQzz_no2());
|
||||
param.put("task_type", "6");
|
||||
param.put("product_area", "Test");
|
||||
param.put("is_bushing", "0");
|
||||
trussCallAirShaftTask.createTask(param);
|
||||
}
|
||||
|
||||
public boolean checkHaveTask(BstIvtCutpointivt p) {
|
||||
List<SchBaseTask> list = taskService.list(new LambdaQueryWrapper<SchBaseTask>()
|
||||
.eq(SchBaseTask::getTask_code, "07").and(la -> la.eq(SchBaseTask::getPoint_code1, p.getPoint_code()).or()
|
||||
|
||||
Reference in New Issue
Block a user