feat:分拣、冷却窑业务
This commit is contained in:
@@ -197,4 +197,11 @@ public interface AcsToWmsService {
|
||||
BaseResponse applyOneCloth(JSONObject param);
|
||||
|
||||
ApplyTaskResponse recordOutCoolKilnTime(ApplyTaskRequest request);
|
||||
|
||||
/**
|
||||
* 分拣清除库存
|
||||
* @param baseRequest
|
||||
* @return
|
||||
*/
|
||||
ApplyTaskResponse sortClearInventory(ApplyTaskRequest baseRequest);
|
||||
}
|
||||
|
||||
@@ -665,6 +665,8 @@ public class AcsToWmsServiceImpl implements AcsToWmsService {
|
||||
return this.recordKilnTime(baseRequest);
|
||||
case GeneralDefinition.LQY:
|
||||
return this.recordOutCoolKilnTime(baseRequest);
|
||||
case GeneralDefinition.FJ:
|
||||
return this.sortClearInventory(baseRequest);
|
||||
default:
|
||||
taskResponse.setMessage("参数错误!");
|
||||
taskResponse.setCode(HttpStatus.HTTP_BAD_REQUEST);
|
||||
@@ -1097,9 +1099,12 @@ public class AcsToWmsServiceImpl implements AcsToWmsService {
|
||||
// 空盘只做记录
|
||||
// 记录入窑记录
|
||||
PdmBdKilnRecord record = kilnRecordService.oneByVehicleAndStatus(baseRequest.getVehicle_code(), "2");
|
||||
if (ObjectUtil.isEmpty(record)) {
|
||||
record = kilnRecordService.oneByVehicleAndStatus("-", "2");
|
||||
if (ObjectUtil.isEmpty(record)) {
|
||||
throw new BadRequestException("入窑记录不存在!");
|
||||
}
|
||||
}
|
||||
kilnRecordService.outCoolEmptyKilnInfo(record);
|
||||
} else {
|
||||
if (null == groupInfo) {
|
||||
@@ -1113,4 +1118,29 @@ public class AcsToWmsServiceImpl implements AcsToWmsService {
|
||||
}
|
||||
return ApplyTaskResponse.responseOk(baseRequest.getRequestNo(), "扫码成功申请");
|
||||
}
|
||||
|
||||
@Override
|
||||
public ApplyTaskResponse sortClearInventory(ApplyTaskRequest baseRequest) {
|
||||
log.info("扫码成功申请 - 分拣送空的参数: {}", baseRequest);
|
||||
SchBasePoint point = pointService.getById(baseRequest.getDevice_code());
|
||||
if (ObjectUtil.isEmpty(point)) {
|
||||
throw new BadRequestException("点位[" + baseRequest.getDevice_code() + "]不存在!");
|
||||
}
|
||||
if (ObjectUtil.isEmpty(point.getVehicle_code())) {
|
||||
throw new BadRequestException("点位没有的托盘号,请检查!");
|
||||
}
|
||||
baseRequest.setVehicle_code(point.getVehicle_code());
|
||||
baseRequest.setVehicle_type(GeneralDefinition.STEEL_TRAY);
|
||||
SchBaseVehiclematerialgroup groupInfo = vehiclematerialgroupService.getGroupInfo(baseRequest.getVehicle_code(), GeneralDefinition.STEEL_TRAY, GroupBindMaterialStatusEnum.BOUND.getValue());
|
||||
if (null == groupInfo) {
|
||||
throw new BadRequestException("组盘信息不存在,请确认是否为空盘!");
|
||||
}
|
||||
// 组盘信息解绑
|
||||
groupInfo.setGroup_bind_material_status(GroupBindMaterialStatusEnum.UNBOUND.getValue());
|
||||
TaskUtils.setGroupUpdateByAcs(groupInfo);
|
||||
vehiclematerialgroupService.updateById(groupInfo);
|
||||
// 点位清空
|
||||
PointUtils.clearPoint(point);
|
||||
return ApplyTaskResponse.responseOk(baseRequest.getRequestNo(), "扫码成功申请");
|
||||
}
|
||||
}
|
||||
|
||||
@@ -44,8 +44,18 @@ public interface IPdmBdKilnRecordService extends IService<PdmBdKilnRecord> {
|
||||
*/
|
||||
void deleteAll(Set<String> ids);
|
||||
|
||||
/**
|
||||
* 入干燥窑插入记录
|
||||
* @param groupInfo 组盘信息
|
||||
* @param basePoint 当前点位
|
||||
*/
|
||||
void recordKilnInfo(SchBaseVehiclematerialgroup groupInfo, SchBasePoint basePoint);
|
||||
|
||||
/**
|
||||
* 入干燥窑插入空盘记录
|
||||
* @param vehicleCode
|
||||
* @param basePoint
|
||||
*/
|
||||
void recordEmptyKilnInfo(String vehicleCode, SchBasePoint basePoint);
|
||||
|
||||
void outDryKilnInfo(String vehicleCode);
|
||||
@@ -60,4 +70,12 @@ public interface IPdmBdKilnRecordService extends IService<PdmBdKilnRecord> {
|
||||
void outCoolEmptyKilnInfo(PdmBdKilnRecord record);
|
||||
void outCoolKilnInfo(PdmBdKilnRecord record);
|
||||
void outCoolStatusKilnInfo(PdmBdKilnRecord record);
|
||||
|
||||
/**
|
||||
* 直接入冷却窑插入记录
|
||||
* @param point
|
||||
*/
|
||||
void recordCoolEmptyKilnInfo(SchBasePoint point);
|
||||
|
||||
void removeOneCoolEmptyInfo(SchBasePoint point);
|
||||
}
|
||||
|
||||
@@ -99,7 +99,6 @@ public class PdmBdKilnRecordServiceImpl extends ServiceImpl<PdmBdKilnRecordMappe
|
||||
SchBasePoint device = pointService.getById(basePoint.getParent_point_code());
|
||||
PdmBdKilnRecord record = new PdmBdKilnRecord();
|
||||
record.setRecord_id(IdUtil.getSnowflake(1,1).nextIdStr());
|
||||
record.setVehicle_code(basePoint.getVehicle_code());
|
||||
// 空托
|
||||
record.setVehicle_code(vehicleCode);
|
||||
record.setVehicle_type("2");
|
||||
@@ -148,7 +147,7 @@ public class PdmBdKilnRecordServiceImpl extends ServiceImpl<PdmBdKilnRecordMappe
|
||||
LambdaQueryWrapper<PdmBdKilnRecord> lam = new LambdaQueryWrapper<>();
|
||||
lam.eq(PdmBdKilnRecord::getVehicle_code, vehicleCode)
|
||||
.eq(PdmBdKilnRecord::getStatus, status);
|
||||
return getOne(lam);
|
||||
return getOne(lam, false);
|
||||
}
|
||||
|
||||
@Override
|
||||
@@ -194,4 +193,35 @@ public class PdmBdKilnRecordServiceImpl extends ServiceImpl<PdmBdKilnRecordMappe
|
||||
updateById(record);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void recordCoolEmptyKilnInfo(SchBasePoint point) {
|
||||
SchBasePoint device = pointService.getById(point.getParent_point_code());
|
||||
PdmBdKilnRecord record = new PdmBdKilnRecord();
|
||||
record.setRecord_id(IdUtil.getSnowflake(1,1).nextIdStr());
|
||||
// 空托
|
||||
record.setVehicle_code("-");
|
||||
record.setVehicle_type("2");
|
||||
record.setInto_cooling_kiln_time(DateUtil.now());
|
||||
record.setCooling_code(device.getPoint_code());
|
||||
record.setCooling_name(device.getPoint_name());
|
||||
record.setStatus("2");
|
||||
record.setCreate_time(DateUtil.now());
|
||||
pdmBdKilnRecordMapper.insert(record);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void removeOneCoolEmptyInfo(SchBasePoint point) {
|
||||
LambdaQueryWrapper<PdmBdKilnRecord> lam = new LambdaQueryWrapper<>();
|
||||
lam.eq(PdmBdKilnRecord::getVehicle_code, "-")
|
||||
.eq(PdmBdKilnRecord::getCooling_code, point.getParent_point_code())
|
||||
.eq(PdmBdKilnRecord::getStatus, "2");
|
||||
List<PdmBdKilnRecord> pdmBdKilnRecords = pdmBdKilnRecordMapper.selectList(lam);
|
||||
if (pdmBdKilnRecords.size() == 0) {
|
||||
throw new BadRequestException("找不到冷却窑空");
|
||||
}
|
||||
PdmBdKilnRecord pdmBdKilnRecord = pdmBdKilnRecords.get(0);
|
||||
pdmBdKilnRecord.setStatus("3");
|
||||
pdmBdKilnRecordMapper.updateById(pdmBdKilnRecord);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
@@ -129,7 +129,7 @@ public class PdmBdWorkorderServiceImpl extends ServiceImpl<PdmBdWorkorderMapper,
|
||||
throw new BadRequestException("创建工单失败,物料[" + entity.getMaterial_id() + "]包装规格为空,请维护!");
|
||||
}
|
||||
// 计算一个托盘能放多少块砖
|
||||
BigDecimal multiply = new BigDecimal(TaskUtils.convertMultiply(entity.getPack_method()));
|
||||
BigDecimal multiply = new BigDecimal(TaskUtils.convertMultiply(material.getPack_method()));
|
||||
// 1 获取所需数(以库存为主)
|
||||
BigDecimal totalNum;
|
||||
// 1.1 工单指定数
|
||||
|
||||
@@ -143,4 +143,11 @@ public interface ISchBaseTaskService extends IService<SchBaseTask> {
|
||||
* @return /
|
||||
*/
|
||||
BigDecimal getCallMaterialCarryingByDevice(String deviceCode);
|
||||
|
||||
/**
|
||||
* 检测是否有任务
|
||||
* @param pointCode 点位
|
||||
* @return true: 有任务, false:没任务
|
||||
*/
|
||||
boolean checkTask(String pointCode);
|
||||
}
|
||||
|
||||
@@ -21,4 +21,6 @@ public interface SchBaseTaskMapper extends BaseMapper<SchBaseTask> {
|
||||
int getCarryingByDevice(String deviceCode, String taskConfig);
|
||||
|
||||
IPage<SchBaseTask> selectPageLeftJoin(IPage<SchBaseTask> pages, SchBaseTaskQuery whereJson, List<String> collect);
|
||||
|
||||
Integer checkTask(String pointCode);
|
||||
}
|
||||
|
||||
@@ -5,11 +5,12 @@
|
||||
<select id="getEmptyVehicleCarryingByDevice" resultType="java.lang.Integer">
|
||||
SELECT COUNT(*)
|
||||
FROM `sch_base_task` t
|
||||
LEFT JOIN sch_base_point p1 ON p1.point_code = t.point_code4
|
||||
LEFT JOIN sch_base_point p1 ON p1.point_code = t.point_code2
|
||||
LEFT JOIN sch_base_point p2 ON p2.point_code = #{deviceCode}
|
||||
WHERE t.config_code = 'FJMLTask'
|
||||
AND t.point_code4 IS NOT NULL
|
||||
WHERE t.is_delete = FALSE
|
||||
AND t.task_status IN ('1', '2', '3', '4')
|
||||
AND ((t.config_code = 'FJQKTask')
|
||||
OR (t.config_code = 'MDOutMoveTask' AND t.request_param LIKE CONCAT('%', t.point_code2, '%')))
|
||||
AND p1.parent_point_code = p2.parent_point_code
|
||||
</select>
|
||||
<select id="getCarryingByDevice" resultType="java.lang.Integer">
|
||||
@@ -73,4 +74,9 @@
|
||||
</where>
|
||||
ORDER BY t.create_time DESC
|
||||
</select>
|
||||
<select id="checkTask" resultType="java.lang.Integer">
|
||||
select count(*) from sch_base_task t
|
||||
where '5' > t.task_status and t.is_delete = false
|
||||
and (t.point_code1 = #{pointCode} or t.point_code2 = #{pointCode} or t.point_code3 = #{pointCode} or t.point_code4 = #{pointCode})
|
||||
</select>
|
||||
</mapper>
|
||||
|
||||
@@ -251,4 +251,10 @@ public class SchBaseTaskServiceImpl extends ServiceImpl<SchBaseTaskMapper, SchBa
|
||||
return schBaseTaskMapper.getCallMaterialCarryingByDevice(deviceCode);
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean checkTask(String pointCode) {
|
||||
Integer num = schBaseTaskMapper.checkTask(pointCode);
|
||||
return num > 0;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
@@ -239,6 +239,10 @@ public abstract class AbstractTask {
|
||||
*/
|
||||
public abstract void cancel(String task_code);
|
||||
|
||||
public boolean checkTask(JSONObject param) {
|
||||
return false;
|
||||
}
|
||||
|
||||
/**
|
||||
* 申请任务
|
||||
*
|
||||
@@ -251,9 +255,13 @@ public abstract class AbstractTask {
|
||||
// 请求点
|
||||
String apply_point_code = param.getString("device_code");
|
||||
String config_code = param.getString("config_code");
|
||||
if (ObjectUtil.isEmpty(config_code)) {
|
||||
throw new BadRequestException("请配置任务编码!!!");
|
||||
}
|
||||
String requestNo = param.getString("requestNo");
|
||||
String vehicleType = param.getString("vehicle_type");
|
||||
String vehicleCode = TaskUtils.defaultVehicleCode(param.getString("vehicle_code"));
|
||||
param.put("vehicle_code", vehicleCode);
|
||||
AbstractTask bean = SpringContextHolder.getBean(this.getClass());
|
||||
// 1、校验数据
|
||||
SchBaseTaskconfig taskConfig = taskConfigService.getOne(new LambdaQueryWrapper<SchBaseTaskconfig>()
|
||||
@@ -264,7 +272,9 @@ public abstract class AbstractTask {
|
||||
// 获取执行中的任务
|
||||
List<SchBaseTask> unFinishTasksByTaskConfig = taskService.findUnFinishTasksByTaskConfig(
|
||||
taskConfig.getConfig_code(), apply_point_code, taskConfig.getTask_direction());
|
||||
|
||||
if (bean.checkTask(param)) {
|
||||
throw new BadRequestException("已经创建过任务了!");
|
||||
}
|
||||
Assert.isFalse(unFinishTasksByTaskConfig.size() >= tcmn,
|
||||
apply_point_code + "该点位申请的任务未完成数已超过上限,无法申请任务");
|
||||
// 获取对接位点位对象
|
||||
|
||||
@@ -83,6 +83,10 @@ public class GeneralDefinition {
|
||||
* 对接位
|
||||
*/
|
||||
public static final String DOCKING_POINT = "2";
|
||||
/**
|
||||
* 中转位
|
||||
*/
|
||||
public static final String TRANSIT_POSITION = "1";
|
||||
/**
|
||||
* 物料位
|
||||
*/
|
||||
@@ -136,6 +140,7 @@ public class GeneralDefinition {
|
||||
*/
|
||||
public static final String GZY = "GZY";
|
||||
public static final String LQY = "LQY";
|
||||
public static final String FJ = "FJ";
|
||||
// 特殊: 1-缓存输送线入口,2-缓存输送线出口,3-上输送线,4-下输送线
|
||||
/**
|
||||
* 上输送线
|
||||
|
||||
@@ -0,0 +1,187 @@
|
||||
package org.nl.wms.sch.task_manage.task.tasks.common;
|
||||
|
||||
import cn.hutool.core.util.ObjectUtil;
|
||||
import com.alibaba.fastjson.JSONObject;
|
||||
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
||||
import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
|
||||
import org.nl.common.exception.BadRequestException;
|
||||
import org.nl.wms.pdm.track.service.IPdmBdProductionProcessTrackingService;
|
||||
import org.nl.wms.sch.group.service.ISchBaseVehiclematerialgroupService;
|
||||
import org.nl.wms.sch.group.service.dao.SchBaseVehiclematerialgroup;
|
||||
import org.nl.wms.sch.point.service.ISchBasePointService;
|
||||
import org.nl.wms.sch.point.service.dao.SchBasePoint;
|
||||
import org.nl.wms.sch.task.service.ISchBaseTaskService;
|
||||
import org.nl.wms.sch.task.service.ISchBaseTaskconfigService;
|
||||
import org.nl.wms.sch.task.service.dao.SchBaseTask;
|
||||
import org.nl.wms.sch.task_manage.AbstractTask;
|
||||
import org.nl.wms.sch.task_manage.GeneralDefinition;
|
||||
import org.nl.wms.sch.task_manage.enums.GroupBindMaterialStatusEnum;
|
||||
import org.nl.wms.sch.task_manage.enums.PointStatusEnum;
|
||||
import org.nl.wms.sch.task_manage.enums.TaskFinishedTypeEnum;
|
||||
import org.nl.wms.sch.task_manage.task.TaskFactory;
|
||||
import org.nl.wms.sch.task_manage.task.core.TaskStatus;
|
||||
import org.nl.wms.sch.task_manage.task.tasks.fj.FJQKTask;
|
||||
import org.nl.wms.util.PointUtils;
|
||||
import org.nl.wms.util.TaskUtils;
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
import org.springframework.stereotype.Component;
|
||||
import org.springframework.transaction.annotation.Transactional;
|
||||
|
||||
import javax.annotation.Resource;
|
||||
|
||||
/**
|
||||
* 码垛移回库(中转移到半托货位)
|
||||
* @Author: lyd
|
||||
* @Date: 2025/12/22
|
||||
*/
|
||||
@Component(value = "MDInMoveTask")
|
||||
public class MDInMoveTask extends AbstractTask {
|
||||
private static final String TASK_CONFIG_CODE = "MDInMoveTask";
|
||||
@Resource
|
||||
private ISchBaseTaskService taskService;
|
||||
@Resource
|
||||
private ISchBaseTaskconfigService taskConfigService;
|
||||
@Resource
|
||||
private ISchBasePointService pointService;
|
||||
@Autowired
|
||||
private ISchBaseVehiclematerialgroupService vehiclematerialgroupService;
|
||||
@Autowired
|
||||
private IPdmBdProductionProcessTrackingService processTrackingService;
|
||||
@Resource
|
||||
private FJQKTask fjqkTask;
|
||||
@Override
|
||||
public void create() throws BadRequestException {
|
||||
|
||||
}
|
||||
|
||||
@Override
|
||||
public void createCompletion(SchBaseTask task) {
|
||||
JSONObject req = JSONObject.parseObject(task.getRequest_param());
|
||||
task.setPoint_code2(req.getString("target"));
|
||||
task.setTask_status(TaskStatus.CREATED.getCode());
|
||||
task.setRemark("");
|
||||
TaskUtils.setUpdateByAcs(task);
|
||||
taskService.save(task);
|
||||
}
|
||||
|
||||
@Override
|
||||
public String setGroupPlate(JSONObject param) {
|
||||
return param.getString("group_id");
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void updateStatus(String task_code, TaskStatus status) {
|
||||
// 校验任务
|
||||
SchBaseTask taskObj = taskService.getByCode(task_code);
|
||||
if (taskObj.getTask_status().equals(TaskStatus.FINISHED.getCode())) {
|
||||
throw new BadRequestException("该任务已完成!");
|
||||
}
|
||||
if (taskObj.getTask_status().equals(TaskStatus.CANCELED.getCode())) {
|
||||
throw new BadRequestException("该任务已取消!");
|
||||
}
|
||||
|
||||
// 根据传来的类型去对任务进行操作
|
||||
if (status.equals(TaskStatus.EXECUTING)) {
|
||||
taskObj.setTask_status(TaskStatus.EXECUTING.getCode());
|
||||
taskObj.setRemark("执行中");
|
||||
TaskUtils.setUpdateByAcs(taskObj);
|
||||
taskService.updateById(taskObj);
|
||||
}
|
||||
if (status.equals(TaskStatus.FINISHED)) {
|
||||
this.finishTask(taskObj, TaskFinishedTypeEnum.AUTO_ACS);
|
||||
}
|
||||
if (status.equals(TaskStatus.CANCELED)) {
|
||||
this.cancelTask(taskObj, TaskFinishedTypeEnum.AUTO_ACS);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void forceFinish(String task_code) {
|
||||
SchBaseTask taskObj = taskService.getByCode(task_code);
|
||||
if (ObjectUtil.isEmpty(taskObj)) {
|
||||
throw new BadRequestException("该任务不存在");
|
||||
}
|
||||
this.finishTask(taskObj, TaskFinishedTypeEnum.MANUAL_PC);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void cancel(String task_code) {
|
||||
SchBaseTask taskObj = taskService.getByCode(task_code);
|
||||
if (ObjectUtil.isEmpty(taskObj)) {
|
||||
throw new BadRequestException("该任务不存在");
|
||||
}
|
||||
this.cancelTask(taskObj, TaskFinishedTypeEnum.MANUAL_PC);
|
||||
}
|
||||
|
||||
|
||||
@Transactional(rollbackFor = Exception.class)
|
||||
public void finishTask(SchBaseTask taskObj, TaskFinishedTypeEnum taskFinishedType) {
|
||||
// 载具编码:前面需要根据任务判断,没有载具不能生成任务
|
||||
String vehicle_code = taskObj.getVehicle_code();
|
||||
String vehicleType = taskObj.getVehicle_type();
|
||||
if (vehicleType == null || vehicleType.equals(GeneralDefinition.NO)) {
|
||||
vehicleType = GeneralDefinition.STEEL_TRAY;
|
||||
}
|
||||
String startPoint = taskObj.getPoint_code1();
|
||||
String endPoint = taskObj.getPoint_code2();
|
||||
SchBasePoint startPointObj = pointService.getById(startPoint);
|
||||
SchBasePoint endPointObj = pointService.getById(endPoint);
|
||||
// 终点解锁
|
||||
if (ObjectUtil.isNotEmpty(endPointObj)) {
|
||||
// 修改组盘信息
|
||||
SchBaseVehiclematerialgroup one = vehiclematerialgroupService.getOne(new LambdaQueryWrapper<SchBaseVehiclematerialgroup>()
|
||||
.eq(SchBaseVehiclematerialgroup::getVehicle_code, vehicle_code)
|
||||
.eq(SchBaseVehiclematerialgroup::getVehicle_type, vehicleType)
|
||||
.eq(SchBaseVehiclematerialgroup::getGroup_bind_material_status,
|
||||
GroupBindMaterialStatusEnum.BOUND.getValue()));
|
||||
if (ObjectUtil.isEmpty(one)) {
|
||||
throw new BadRequestException(vehicle_code + " => " + vehicleType + "的组盘信息未找到");
|
||||
}
|
||||
one.setTask_code(taskObj.getTask_code());
|
||||
one.setPoint_code(endPointObj.getPoint_code());
|
||||
one.setPoint_name(endPointObj.getPoint_name());
|
||||
one.setMove_way(one.getMove_way() + " -> " + endPointObj.getPoint_code());
|
||||
TaskUtils.setGroupUpdateByType(one, taskFinishedType);
|
||||
vehiclematerialgroupService.updateById(one);
|
||||
// 记录库存并解锁
|
||||
endPointObj.setIng_task_code("");
|
||||
endPointObj.setVehicle_code(vehicle_code);
|
||||
endPointObj.setVehicle_type(vehicleType);
|
||||
endPointObj.setVehicle_qty(1);
|
||||
endPointObj.setPoint_status(PointStatusEnum.EMPTY_VEHICLE.getCode());
|
||||
PointUtils.setUpdateByType(endPointObj, taskFinishedType);
|
||||
pointService.updateById(endPointObj);
|
||||
PointUtils.clearPoint(startPointObj);
|
||||
// 是否需要释放
|
||||
JSONObject req = JSONObject.parseObject(taskObj.getRequest_param());
|
||||
String needReleased = req.getString("need_released");
|
||||
if (ObjectUtil.isNotEmpty(needReleased)) {
|
||||
pointService.update(new LambdaUpdateWrapper<SchBasePoint>()
|
||||
.set(SchBasePoint::getIng_task_code, "")
|
||||
.eq(SchBasePoint::getPoint_code, needReleased));
|
||||
}
|
||||
}
|
||||
// 任务完成
|
||||
taskObj.setTask_status(TaskStatus.FINISHED.getCode());
|
||||
taskObj.setRemark(GeneralDefinition.TASK_FINISH);
|
||||
taskObj.setFinished_type(taskFinishedType.getCode());
|
||||
TaskUtils.setUpdateByType(taskObj, taskFinishedType);
|
||||
taskService.updateById(taskObj);
|
||||
}
|
||||
|
||||
@Transactional(rollbackFor = Exception.class)
|
||||
public void cancelTask(SchBaseTask taskObj, TaskFinishedTypeEnum taskFinishedType) {
|
||||
String endPoint = taskObj.getPoint_code2();
|
||||
SchBasePoint endPointObj = pointService.getById(endPoint);
|
||||
// 终点解锁
|
||||
if (ObjectUtil.isNotEmpty(endPointObj)) {
|
||||
endPointObj.setIng_task_code("");
|
||||
pointService.update(endPointObj);
|
||||
}
|
||||
taskObj.setRemark(GeneralDefinition.TASK_CANCEL);
|
||||
taskObj.setTask_status(TaskStatus.CANCELED.getCode());
|
||||
taskObj.setFinished_type(taskFinishedType.getCode());
|
||||
TaskUtils.setUpdateByType(taskObj, taskFinishedType);
|
||||
taskService.updateById(taskObj);
|
||||
}
|
||||
}
|
||||
@@ -10,13 +10,17 @@ import org.nl.wms.sch.group.service.dao.SchBaseVehiclematerialgroup;
|
||||
import org.nl.wms.sch.point.service.ISchBasePointService;
|
||||
import org.nl.wms.sch.point.service.dao.SchBasePoint;
|
||||
import org.nl.wms.sch.task.service.ISchBaseTaskService;
|
||||
import org.nl.wms.sch.task.service.ISchBaseTaskconfigService;
|
||||
import org.nl.wms.sch.task.service.dao.SchBaseTask;
|
||||
import org.nl.wms.sch.task.service.dao.SchBaseTaskconfig;
|
||||
import org.nl.wms.sch.task_manage.AbstractTask;
|
||||
import org.nl.wms.sch.task_manage.GeneralDefinition;
|
||||
import org.nl.wms.sch.task_manage.enums.GroupBindMaterialStatusEnum;
|
||||
import org.nl.wms.sch.task_manage.enums.PointStatusEnum;
|
||||
import org.nl.wms.sch.task_manage.enums.TaskFinishedTypeEnum;
|
||||
import org.nl.wms.sch.task_manage.task.TaskFactory;
|
||||
import org.nl.wms.sch.task_manage.task.core.TaskStatus;
|
||||
import org.nl.wms.sch.task_manage.task.tasks.fj.FJQKTask;
|
||||
import org.nl.wms.util.PointUtils;
|
||||
import org.nl.wms.util.TaskUtils;
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
@@ -24,9 +28,12 @@ import org.springframework.stereotype.Component;
|
||||
import org.springframework.transaction.annotation.Transactional;
|
||||
|
||||
import javax.annotation.Resource;
|
||||
import java.util.Arrays;
|
||||
import java.util.List;
|
||||
import java.util.stream.Collectors;
|
||||
|
||||
/**
|
||||
* 码垛移库
|
||||
* 码垛移库(移到中转)
|
||||
* @Author: lyd
|
||||
* @Date: 2025/12/22
|
||||
*/
|
||||
@@ -36,11 +43,15 @@ public class MDOutMoveTask extends AbstractTask {
|
||||
@Resource
|
||||
private ISchBaseTaskService taskService;
|
||||
@Resource
|
||||
private ISchBaseTaskconfigService taskConfigService;
|
||||
@Resource
|
||||
private ISchBasePointService pointService;
|
||||
@Autowired
|
||||
private ISchBaseVehiclematerialgroupService vehiclematerialgroupService;
|
||||
@Autowired
|
||||
private IPdmBdProductionProcessTrackingService processTrackingService;
|
||||
@Resource
|
||||
private TaskFactory taskFactory;
|
||||
@Override
|
||||
public void create() throws BadRequestException {
|
||||
|
||||
@@ -48,14 +59,38 @@ public class MDOutMoveTask extends AbstractTask {
|
||||
|
||||
@Override
|
||||
public void createCompletion(SchBaseTask task) {
|
||||
JSONObject req = JSONObject.parseObject(task.getRequest_param());
|
||||
task.setPoint_code2(req.getString("target"));
|
||||
SchBaseTaskconfig taskConfig = taskConfigService.getOne(new LambdaQueryWrapper<SchBaseTaskconfig>()
|
||||
.eq(SchBaseTaskconfig::getConfig_code, TASK_CONFIG_CODE));
|
||||
List<String> nextRegionStr = Arrays.stream(taskConfig.getNext_region_str().split(","))
|
||||
.collect(Collectors.toList());
|
||||
// 找终点
|
||||
SchBasePoint movePoint = findNextPoint(nextRegionStr);
|
||||
if (ObjectUtil.isEmpty(movePoint)) {
|
||||
throw new BadRequestException("找不到可用的中转点位!");
|
||||
}
|
||||
task.setPoint_code2(movePoint.getPoint_code());
|
||||
task.setTask_status(TaskStatus.CREATED.getCode());
|
||||
task.setRemark("");
|
||||
TaskUtils.setUpdateByAcs(task);
|
||||
taskService.save(task);
|
||||
}
|
||||
|
||||
public SchBasePoint findNextPoint(List<String> nextRegionStr) {
|
||||
// 查找移库点
|
||||
LambdaQueryWrapper<SchBasePoint> lam = new LambdaQueryWrapper<>();
|
||||
lam.in(SchBasePoint::getRegion_code, nextRegionStr)
|
||||
// 当前执行的任务为空或者NULL,有数据表示锁住
|
||||
.and(la -> la.isNull(SchBasePoint::getIng_task_code)
|
||||
.or()
|
||||
.eq(SchBasePoint::getIng_task_code, ""))
|
||||
.eq(SchBasePoint::getIs_used, true)
|
||||
.eq(SchBasePoint::getPoint_type, "2")
|
||||
.eq(SchBasePoint::getPoint_status, "1")
|
||||
.orderByAsc(SchBasePoint::getPoint_type)
|
||||
.orderByAsc(SchBasePoint::getPoint_code);
|
||||
return pointService.getOne(lam, false);
|
||||
}
|
||||
|
||||
@Override
|
||||
public String setGroupPlate(JSONObject param) {
|
||||
return param.getString("group_id");
|
||||
@@ -114,6 +149,8 @@ public class MDOutMoveTask extends AbstractTask {
|
||||
if (vehicleType == null || vehicleType.equals(GeneralDefinition.NO)) {
|
||||
vehicleType = GeneralDefinition.STEEL_TRAY;
|
||||
}
|
||||
String startPoint = taskObj.getPoint_code1();
|
||||
SchBasePoint startPointObj = pointService.getById(startPoint);
|
||||
String endPoint = taskObj.getPoint_code2();
|
||||
SchBasePoint endPointObj = pointService.getById(endPoint);
|
||||
// 终点解锁
|
||||
@@ -138,10 +175,32 @@ public class MDOutMoveTask extends AbstractTask {
|
||||
endPointObj.setVehicle_code(vehicle_code);
|
||||
endPointObj.setVehicle_type(vehicleType);
|
||||
endPointObj.setVehicle_qty(1);
|
||||
endPointObj.setPoint_status(PointStatusEnum.FULL_POINT.getCode());
|
||||
endPointObj.setPoint_status(PointStatusEnum.EMPTY_VEHICLE.getCode());
|
||||
PointUtils.setUpdateByType(endPointObj, taskFinishedType);
|
||||
pointService.updateById(endPointObj);
|
||||
// 起点解锁,创建四点任务
|
||||
JSONObject req = JSONObject.parseObject(taskObj.getRequest_param());
|
||||
SchBasePoint point = pointService.getById(req.getString("point_code1"));
|
||||
// 创建呼叫任务
|
||||
AbstractTask task = taskFactory.getTask(req.getString("next"));
|
||||
JSONObject param = new JSONObject();
|
||||
if ("FJMLTask".equals(req.getString("next"))) {
|
||||
SchBaseVehiclematerialgroup group = vehiclematerialgroupService.getById(req.getString("group_id"));
|
||||
param.put("vehicle_code", group.getVehicle_code());
|
||||
param.put("vehicle_type", group.getVehicle_type());
|
||||
param.put("group_id", req.getString("group_id"));
|
||||
} else {
|
||||
param.put("vehicle_code", point.getVehicle_code());
|
||||
param.put("vehicle_type", point.getVehicle_type());
|
||||
param.put("need_released", startPoint);
|
||||
PointUtils.clearPointNoLock(startPointObj);
|
||||
}
|
||||
param.put("device_code", req.getString("point_code2"));
|
||||
param.put("target", req.getString("point_code1"));
|
||||
param.put("point_code1", taskObj.getPoint_code2());
|
||||
param.put("point_code2", req.getString("point_code1"));
|
||||
param.put("config_code", req.getString("next"));
|
||||
param.put("is_confirm", "1");
|
||||
task.apply(param);
|
||||
}
|
||||
// 任务完成
|
||||
taskObj.setTask_status(TaskStatus.FINISHED.getCode());
|
||||
@@ -153,12 +212,17 @@ public class MDOutMoveTask extends AbstractTask {
|
||||
|
||||
@Transactional(rollbackFor = Exception.class)
|
||||
public void cancelTask(SchBaseTask taskObj, TaskFinishedTypeEnum taskFinishedType) {
|
||||
String startPoint = taskObj.getPoint_code1();
|
||||
SchBasePoint startPointObj = pointService.getById(startPoint);
|
||||
String endPoint = taskObj.getPoint_code2();
|
||||
SchBasePoint endPointObj = pointService.getById(endPoint);
|
||||
// 终点解锁
|
||||
if (ObjectUtil.isNotEmpty(endPointObj)) {
|
||||
endPointObj.setIng_task_code("");
|
||||
pointService.update(endPointObj);
|
||||
startPointObj.setIng_task_code("");
|
||||
PointUtils.setUpdateByType(startPointObj, taskFinishedType);
|
||||
PointUtils.setUpdateByType(endPointObj, taskFinishedType);
|
||||
pointService.updateBatchById(Arrays.asList(startPointObj, endPointObj));
|
||||
}
|
||||
taskObj.setRemark(GeneralDefinition.TASK_CANCEL);
|
||||
taskObj.setTask_status(TaskStatus.CANCELED.getCode());
|
||||
|
||||
@@ -20,6 +20,7 @@ import org.nl.wms.sch.task_manage.enums.GroupBindMaterialStatusEnum;
|
||||
import org.nl.wms.sch.task_manage.enums.PointStatusEnum;
|
||||
import org.nl.wms.sch.task_manage.enums.TaskFinishedTypeEnum;
|
||||
import org.nl.wms.sch.task_manage.task.core.TaskStatus;
|
||||
import org.nl.wms.sch.task_manage.task.tasks.fj.FJQLTask;
|
||||
import org.nl.wms.util.PointUtils;
|
||||
import org.nl.wms.util.TaskUtils;
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
@@ -29,7 +30,7 @@ import org.springframework.transaction.annotation.Transactional;
|
||||
import javax.annotation.Resource;
|
||||
|
||||
/**
|
||||
* 转运任务
|
||||
* 转运任务(AGV)
|
||||
* @Author: lyd
|
||||
* @Date: 2025/12/22
|
||||
*/
|
||||
@@ -44,6 +45,8 @@ public class MoveTask extends AbstractTask {
|
||||
private ISchBaseVehiclematerialgroupService vehiclematerialgroupService;
|
||||
@Autowired
|
||||
private IPdmBdProductionProcessTrackingService processTrackingService;
|
||||
@Resource(name = "FJQLTask")
|
||||
private FJQLTask fjqlTask;
|
||||
@Override
|
||||
public void create() throws BadRequestException {
|
||||
|
||||
@@ -53,8 +56,15 @@ public class MoveTask extends AbstractTask {
|
||||
public void createCompletion(SchBaseTask task) {
|
||||
JSONObject req = JSONObject.parseObject(task.getRequest_param());
|
||||
task.setPoint_code2(req.getString("target"));
|
||||
task.setPoint_code3(req.getString("target2"));
|
||||
task.setTask_status(TaskStatus.CREATED.getCode());
|
||||
task.setRemark("");
|
||||
task.setGroup_id(setGroupPlate(req));
|
||||
// 提前分配的货位需要锁住
|
||||
SchBasePoint flagPoint = pointService.getById(req.getString("target"));
|
||||
flagPoint.setIng_task_code(task.getTask_code());
|
||||
PointUtils.setUpdateByAcs(flagPoint);
|
||||
pointService.updateById(flagPoint);
|
||||
TaskUtils.setUpdateByAcs(task);
|
||||
taskService.save(task);
|
||||
}
|
||||
@@ -117,10 +127,12 @@ public class MoveTask extends AbstractTask {
|
||||
if (vehicleType == null || vehicleType.equals(GeneralDefinition.NO)) {
|
||||
vehicleType = GeneralDefinition.STEEL_TRAY;
|
||||
}
|
||||
String startPoint = taskObj.getPoint_code1();
|
||||
String endPoint = taskObj.getPoint_code2();
|
||||
SchBasePoint startPointObj = pointService.getById(startPoint);
|
||||
SchBasePoint endPointObj = pointService.getById(endPoint);
|
||||
// 终点解锁
|
||||
if (ObjectUtil.isNotEmpty(endPointObj)) {
|
||||
if (ObjectUtil.isNotEmpty(startPointObj)) {
|
||||
// 修改组盘信息
|
||||
SchBaseVehiclematerialgroup one = vehiclematerialgroupService.getOne(new LambdaQueryWrapper<SchBaseVehiclematerialgroup>()
|
||||
.eq(SchBaseVehiclematerialgroup::getVehicle_code, vehicle_code)
|
||||
@@ -139,18 +151,21 @@ public class MoveTask extends AbstractTask {
|
||||
// 插入生产过程跟踪表
|
||||
PdmBdProductionProcessTracking processTracking = new PdmBdProductionProcessTracking();
|
||||
processTracking.setBuss_move_id(one.getBuss_move_id());
|
||||
processTracking.setProcess_action("出中转进入缓存");
|
||||
processTracking.setProcess_action("出钢托缓存到中转位");
|
||||
processTracking.setProcess_location(endPoint);
|
||||
processTracking.setRecord_time(DateUtil.now());
|
||||
processTrackingService.create(processTracking);
|
||||
// 记录库存并解锁
|
||||
endPointObj.setIng_task_code("");
|
||||
endPointObj.setVehicle_code(vehicle_code);
|
||||
endPointObj.setVehicle_type(vehicleType);
|
||||
endPointObj.setVehicle_qty(1);
|
||||
endPointObj.setPoint_status(PointStatusEnum.FULL_POINT.getCode());
|
||||
PointUtils.setUpdateByType(endPointObj, taskFinishedType);
|
||||
pointService.updateById(endPointObj);
|
||||
PointUtils.clearPoint(startPointObj);
|
||||
// 创建RGV任务
|
||||
JSONObject param = new JSONObject();
|
||||
param.put("device_code", taskObj.getPoint_code3());
|
||||
param.put("is_confirm", 1);
|
||||
param.put("target", taskObj.getPoint_code2());
|
||||
param.put("vehicle_code", taskObj.getVehicle_code());
|
||||
param.put("vehicle_type", taskObj.getVehicle_type());
|
||||
param.put("config_code", "FJQLTask");
|
||||
param.put("group_id", one.getGroup_id());
|
||||
fjqlTask.apply(param);
|
||||
}
|
||||
// 任务完成
|
||||
taskObj.setTask_status(TaskStatus.FINISHED.getCode());
|
||||
|
||||
@@ -26,6 +26,8 @@ import org.nl.wms.sch.task_manage.GeneralDefinition;
|
||||
import org.nl.wms.sch.task_manage.enums.*;
|
||||
import org.nl.wms.sch.task_manage.task.TaskType;
|
||||
import org.nl.wms.sch.task_manage.task.core.TaskStatus;
|
||||
import org.nl.wms.sch.task_manage.task.tasks.common.MDInMoveTask;
|
||||
import org.nl.wms.sch.task_manage.task.tasks.common.MDOutMoveTask;
|
||||
import org.nl.wms.sch.task_manage.task.tasks.fj.mapper.FJMapper;
|
||||
import org.nl.wms.util.PointUtils;
|
||||
import org.nl.wms.util.TaskUtils;
|
||||
@@ -33,14 +35,16 @@ import org.springframework.beans.factory.annotation.Autowired;
|
||||
import org.springframework.stereotype.Component;
|
||||
import org.springframework.transaction.annotation.Transactional;
|
||||
|
||||
import javax.annotation.Resource;
|
||||
import java.math.BigDecimal;
|
||||
import java.util.ArrayList;
|
||||
import java.util.Arrays;
|
||||
import java.util.List;
|
||||
import java.util.stream.Collectors;
|
||||
|
||||
/**
|
||||
* @Author: lyd
|
||||
* @Description: 分拣满料任务,半满才有流程,全满没有业务
|
||||
* @Description: 分拣满料任务
|
||||
* @Date: 2023/6/21
|
||||
*/
|
||||
@Slf4j
|
||||
@@ -64,6 +68,10 @@ public class FJMLTask extends AbstractTask {
|
||||
private ISchBaseVehiclematerialgroupService vehiclematerialgroupService;
|
||||
@Autowired
|
||||
private WmsToMesService wmsToMesService;
|
||||
@Resource(name = "MDOutMoveTask")
|
||||
private MDOutMoveTask mdOutMoveTask;
|
||||
@Resource(name = "MDInMoveTask")
|
||||
private MDInMoveTask mdInMoveTask;
|
||||
|
||||
@Override
|
||||
public void create() throws BadRequestException {
|
||||
@@ -120,6 +128,15 @@ public class FJMLTask extends AbstractTask {
|
||||
List<String> nextRegionStr = Arrays.stream(taskConfig.getNext_region_str().split(","))
|
||||
.collect(Collectors.toList());
|
||||
JSONObject jsonObject = JSONObject.parseObject(task.getRequest_param());
|
||||
String isConfirm = jsonObject.getString("is_confirm");
|
||||
if (ObjectUtil.isNotEmpty(isConfirm) && GeneralDefinition.YES.equals(isConfirm)) {
|
||||
task.setPoint_code2(jsonObject.getString("target"));
|
||||
task.setTask_status(TaskStatus.CREATED.getCode());
|
||||
task.setVehicle_code(jsonObject.getString("vehicle_code"));
|
||||
task.setVehicle_type(jsonObject.getString("vehicle_type"));
|
||||
task.setGroup_id(jsonObject.getString("group_id"));
|
||||
task.setRemark("中转后的半托任务");
|
||||
} else {
|
||||
task.setGroup_id(setGroupPlate(jsonObject));
|
||||
// 找终点
|
||||
/** 包装位/半托缓存 */
|
||||
@@ -130,10 +147,43 @@ public class FJMLTask extends AbstractTask {
|
||||
NoticeTypeEnum.WARN.getCode());
|
||||
throw new BadRequestException("包装线不可用!");
|
||||
}
|
||||
// 设置组盘 - 需要的话由子类自行实现
|
||||
// 半托任务
|
||||
if ("1".equals(jsonObject.getString("flag"))) {
|
||||
SchBasePoint movePoint = packagePoint.getFlagPoint();
|
||||
// 需要移库
|
||||
JSONObject param = new JSONObject();
|
||||
// 移动的货位
|
||||
param.put("device_code", movePoint.getPoint_code());
|
||||
// 所需要的半托位置
|
||||
param.put("point_code1", packagePoint.getPoint_code());
|
||||
// 分拣码垛位
|
||||
param.put("point_code2", task.getPoint_code1());
|
||||
param.put("vehicle_code", movePoint.getVehicle_code());
|
||||
param.put("vehicle_type", movePoint.getVehicle_type());
|
||||
// 满托的组盘id
|
||||
param.put("group_id", task.getGroup_id());
|
||||
param.put("config_code", "MDOutMoveTask");
|
||||
param.put("next", "FJMLTask");
|
||||
mdOutMoveTask.apply(param);
|
||||
packagePoint.setIng_task_code("半托移库任务");
|
||||
PointUtils.setUpdateByAcs(packagePoint);
|
||||
movePoint.setIng_task_code("半托移库任务");
|
||||
PointUtils.setUpdateByAcs(movePoint);
|
||||
pointService.updateBatchById(Arrays.asList(packagePoint, movePoint));
|
||||
return;
|
||||
} else {
|
||||
// 不需要移库
|
||||
// 设置起点并修改创建成功状态
|
||||
task.setPoint_code2(packagePoint.getPoint_code());
|
||||
task.setTask_status(TaskStatus.CREATED.getCode());
|
||||
task.setVehicle_code(jsonObject.getString("vehicle_code"));
|
||||
task.setVehicle_type(jsonObject.getString("vehicle_type"));
|
||||
packagePoint.setIng_task_code(task.getTask_code());
|
||||
PointUtils.setUpdateByAcs(packagePoint);
|
||||
pointService.updateById(packagePoint);
|
||||
}
|
||||
task.setRemark("");
|
||||
}
|
||||
task.setTask_status(TaskStatus.CREATED.getCode());
|
||||
taskService.save(task);
|
||||
|
||||
}
|
||||
@@ -198,14 +248,15 @@ public class FJMLTask extends AbstractTask {
|
||||
|
||||
groupEntity.setPcsn(DateUtil.format(DateUtil.date(), "yyyyMMdd"));
|
||||
groupEntity.setInstorage_time(DateUtil.now());
|
||||
groupEntity.setGroup_bind_material_status(GroupBindMaterialStatusEnum.UNBOUND.getValue());
|
||||
groupEntity.setGroup_bind_material_status(GroupBindMaterialStatusEnum.BOUND.getValue());
|
||||
|
||||
groupEntity.setGroup_status(GroupStatusEnum.IN_STORAGE.getType());
|
||||
groupEntity.setIs_delete(false);
|
||||
groupEntity.setIs_full(isFull.equals(GeneralDefinition.YES));
|
||||
vehiclematerialgroupService.saveOrUpdate(groupEntity);
|
||||
param.put("vehicle_code", vehicleCode);
|
||||
// 返回组盘id记录任务中
|
||||
return isFull.equals(GeneralDefinition.YES) ? null : groupEntity.getGroup_id();
|
||||
return groupEntity.getGroup_id();
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -216,16 +267,50 @@ public class FJMLTask extends AbstractTask {
|
||||
* @return
|
||||
*/
|
||||
private SchBasePoint findNextPoint(List<String> nextRegionStr, JSONObject requestParam) {
|
||||
String isFull = requestParam.getString("is_full");
|
||||
List<SchBasePoint> schBasePoints;
|
||||
if ("1".equals(isFull)) {
|
||||
// 满托
|
||||
LambdaQueryWrapper<SchBasePoint> lam = new LambdaQueryWrapper<>();
|
||||
lam.in(SchBasePoint::getRegion_code, nextRegionStr)
|
||||
lam.eq(SchBasePoint::getRegion_code, "BZ")
|
||||
.eq(SchBasePoint::getPoint_status, PointStatusEnum.EMPTY_POINT.getCode())
|
||||
.and(la -> la.isNull(SchBasePoint::getIng_task_code)
|
||||
.or()
|
||||
.eq(SchBasePoint::getIng_task_code, ""))
|
||||
.eq(SchBasePoint::getPoint_type, GeneralDefinition.DOCKING_POINT)
|
||||
.orderByAsc(SchBasePoint::getIn_order_seq)
|
||||
.orderByAsc(SchBasePoint::getPoint_code);
|
||||
List<SchBasePoint> schBasePoints = pointService.list(lam);
|
||||
schBasePoints = pointService.list(lam);
|
||||
} else {
|
||||
// 需要判断是否满托
|
||||
LambdaQueryWrapper<SchBasePoint> lam = new LambdaQueryWrapper<>();
|
||||
lam.eq(SchBasePoint::getRegion_code, "BTHC")
|
||||
.eq(SchBasePoint::getPoint_status, PointStatusEnum.EMPTY_POINT.getCode())
|
||||
.eq(SchBasePoint::getPoint_type, GeneralDefinition.TRANSIT_POSITION)
|
||||
.orderByAsc(SchBasePoint::getIn_order_seq)
|
||||
.orderByAsc(SchBasePoint::getPoint_code);
|
||||
schBasePoints = pointService.list(lam);
|
||||
SchBasePoint schBasePoint = schBasePoints.get(0);
|
||||
if (schBasePoint.getRow_num() == 2) {
|
||||
// 判断是否阻挡
|
||||
LambdaQueryWrapper<SchBasePoint> lam2 = new LambdaQueryWrapper<>();
|
||||
lam2.eq(SchBasePoint::getRegion_code, schBasePoint.getRegion_code())
|
||||
// 当前执行的任务为空或者NULL,有数据表示锁住
|
||||
.and(la -> la.isNull(SchBasePoint::getIng_task_code)
|
||||
.or()
|
||||
.eq(SchBasePoint::getIng_task_code, ""))
|
||||
.eq(SchBasePoint::getIs_used, true)
|
||||
.eq(SchBasePoint::getPoint_status, "2")
|
||||
.eq(SchBasePoint::getCol_num, schBasePoint.getCol_num())
|
||||
.ne(SchBasePoint::getRow_num, schBasePoint.getRow_num())
|
||||
.orderByAsc(SchBasePoint::getPoint_type)
|
||||
.orderByAsc(SchBasePoint::getPoint_code);
|
||||
SchBasePoint movePoint = pointService.getOne(lam2);
|
||||
if (ObjectUtil.isNotEmpty(movePoint)) {
|
||||
// 创建移库
|
||||
requestParam.put("flag", "1");
|
||||
schBasePoint.setFlagPoint(movePoint);
|
||||
}
|
||||
return schBasePoint;
|
||||
}
|
||||
}
|
||||
return ObjectUtil.isNotEmpty(schBasePoints) ? schBasePoints.get(0) : null;
|
||||
}
|
||||
|
||||
@@ -276,39 +361,20 @@ public class FJMLTask extends AbstractTask {
|
||||
|
||||
@Transactional(rollbackFor = Exception.class)
|
||||
public void finishTask(SchBaseTask taskObj, TaskFinishedTypeEnum taskFinishedType) {
|
||||
String requestParam = taskObj.getRequest_param();
|
||||
JSONObject jsonObject = JSONObject.parseObject(requestParam);
|
||||
String workorderCode = jsonObject.getString("workorder_code");
|
||||
PdmBdWorkorder workorder = workorderService.getByCode(workorderCode);
|
||||
// 获取参数
|
||||
String startPoint = taskObj.getPoint_code1();
|
||||
String bzxPoint = taskObj.getPoint_code2();
|
||||
String fmPoint = taskObj.getPoint_code3();
|
||||
String fjcPoint = taskObj.getPoint_code4();
|
||||
SchBasePoint startPointObj = pointService.getById(startPoint);
|
||||
SchBasePoint bzxPointObj = pointService.getById(bzxPoint);
|
||||
SchBasePoint fmPointObj = pointService.getById(fmPoint);
|
||||
SchBasePoint fjcPointObj = pointService.getById(fjcPoint);
|
||||
JSONObject parsedObject = JSONObject.parseObject(taskObj.getRequest_param());
|
||||
if (ObjectUtil.isNotEmpty(bzxPointObj)) {
|
||||
// 包装位: 解锁
|
||||
// 包装位/半托: 解锁
|
||||
bzxPointObj.setVehicle_qty(1);
|
||||
bzxPointObj.setVehicle_code(taskObj.getVehicle_code());
|
||||
bzxPointObj.setVehicle_type(taskObj.getVehicle_type());
|
||||
PointUtils.setUpdateByType(bzxPointObj, taskFinishedType);
|
||||
PointUtils.clearPoint(bzxPointObj);
|
||||
if (ObjectUtil.isNotEmpty(fmPoint)) {
|
||||
// 覆膜位: 解锁 . 清空
|
||||
PointUtils.setUpdateByType(fmPointObj, taskFinishedType);
|
||||
PointUtils.clearPoint(fmPointObj);
|
||||
// 工单的真实数+1
|
||||
workorder.setReal_qty(workorder.getReal_qty().add(BigDecimal.ONE));
|
||||
TaskUtils.setWorkOrderUpdateByType(workorder, taskFinishedType);
|
||||
workorderService.updateById(workorder);
|
||||
}
|
||||
// 分拣机械手: 清空
|
||||
if (ObjectUtil.isNotEmpty(fjcPointObj)) {
|
||||
// 机械手对接位: 赋值
|
||||
fjcPointObj.setPoint_status(PointStatusEnum.EMPTY_VEHICLE.getCode());
|
||||
fjcPointObj.setVehicle_qty(1);
|
||||
fjcPointObj.setVehicle_type(taskObj.getVehicle_type());
|
||||
PointUtils.setUpdateByType(fjcPointObj, taskFinishedType);
|
||||
pointService.updateById(fjcPointObj);
|
||||
}
|
||||
pointService.updateById(bzxPointObj);
|
||||
PointUtils.clearPoint(startPointObj);
|
||||
SchBaseVehiclematerialgroup vehicleMaterialGroupObj =
|
||||
vehiclematerialgroupService.getById(taskObj.getGroup_id());
|
||||
vehicleMaterialGroupObj.setGroup_bind_material_status(GroupBindMaterialStatusEnum.UNBOUND.getValue());
|
||||
@@ -319,6 +385,20 @@ public class FJMLTask extends AbstractTask {
|
||||
TaskUtils.setGroupUpdateByType(vehicleMaterialGroupObj, taskFinishedType);
|
||||
vehiclematerialgroupService.updateById(vehicleMaterialGroupObj);
|
||||
}
|
||||
if (ObjectUtil.isNotEmpty(parsedObject.getString("is_confirm"))
|
||||
&& "1".equals(parsedObject.getString("is_confirm"))) {
|
||||
if (!taskService.checkTask(parsedObject.getString("point_code1"))) {
|
||||
// 创建恢复任务
|
||||
SchBasePoint point = pointService.getById(parsedObject.getString("point_code1"));
|
||||
JSONObject param = new JSONObject();
|
||||
param.put("device_code", parsedObject.getString("point_code1"));
|
||||
param.put("target", parsedObject.getString("point_code2"));
|
||||
param.put("vehicle_code", point.getVehicle_code());
|
||||
param.put("vehicle_type", point.getVehicle_type());
|
||||
param.put("config_code", "MDInMoveTask");
|
||||
mdInMoveTask.apply(param);
|
||||
}
|
||||
}
|
||||
taskObj.setTask_status(TaskStatus.FINISHED.getCode());
|
||||
taskObj.setRemark(GeneralDefinition.TASK_FINISH);
|
||||
taskObj.setFinished_type(taskFinishedType.getCode());
|
||||
@@ -330,20 +410,15 @@ public class FJMLTask extends AbstractTask {
|
||||
public void cancelTask(SchBaseTask taskObj, TaskFinishedTypeEnum taskFinishedType) {
|
||||
// 获取参数
|
||||
String bzxPoint = taskObj.getPoint_code2();
|
||||
String fmPoint = taskObj.getPoint_code3();
|
||||
SchBasePoint bzxPointObj = pointService.getById(bzxPoint);
|
||||
SchBasePoint fmPointObj = pointService.getById(fmPoint);
|
||||
if (ObjectUtil.isNotEmpty(bzxPointObj)) {
|
||||
// 释放点位
|
||||
bzxPointObj.setIng_task_code("");
|
||||
PointUtils.setUpdateByType(bzxPointObj, taskFinishedType);
|
||||
pointService.updateById(bzxPointObj);
|
||||
}
|
||||
if (ObjectUtil.isNotEmpty(fmPointObj)) {
|
||||
fmPointObj.setIng_task_code("");
|
||||
PointUtils.setUpdateByType(fmPointObj, taskFinishedType);
|
||||
pointService.updateById(fmPointObj);
|
||||
}
|
||||
// 组盘删除
|
||||
vehiclematerialgroupService.removeById(taskObj.getGroup_id());
|
||||
taskObj.setTask_status(TaskStatus.CANCELED.getCode());
|
||||
taskObj.setRemark(GeneralDefinition.TASK_CANCEL);
|
||||
taskObj.setFinished_type(taskFinishedType.getCode());
|
||||
|
||||
@@ -23,6 +23,7 @@ import org.nl.wms.sch.task_manage.enums.PointStatusEnum;
|
||||
import org.nl.wms.sch.task_manage.enums.TaskFinishedTypeEnum;
|
||||
import org.nl.wms.sch.task_manage.task.TaskType;
|
||||
import org.nl.wms.sch.task_manage.task.core.TaskStatus;
|
||||
import org.nl.wms.sch.task_manage.task.tasks.common.MDInMoveTask;
|
||||
import org.nl.wms.sch.task_manage.task.tasks.common.MDOutMoveTask;
|
||||
import org.nl.wms.sch.task_manage.task.tasks.fj.mapper.FJMapper;
|
||||
import org.nl.wms.util.PointUtils;
|
||||
@@ -63,6 +64,8 @@ public class FJQKTask extends AbstractTask {
|
||||
private FJMapper fjMapper;
|
||||
@Resource(name = "MDOutMoveTask")
|
||||
private MDOutMoveTask mdOutMoveTask;
|
||||
@Resource(name = "MDInMoveTask")
|
||||
private MDInMoveTask mdInMoveTask;
|
||||
|
||||
@Override
|
||||
@Transactional(rollbackFor = Exception.class)
|
||||
@@ -128,11 +131,21 @@ public class FJQKTask extends AbstractTask {
|
||||
// 找起点
|
||||
String requestParam = task.getRequest_param();
|
||||
JSONObject extGroupData = JSONObject.parseObject(requestParam);
|
||||
String isConfirm = extGroupData.getString("is_confirm");
|
||||
if (ObjectUtil.isNotEmpty(isConfirm) && GeneralDefinition.YES.equals(isConfirm)) {
|
||||
task.setPoint_code1(extGroupData.getString("target"));
|
||||
task.setTask_status(TaskStatus.CREATED.getCode());
|
||||
task.setVehicle_code(extGroupData.getString("vehicle_code"));
|
||||
task.setVehicle_type(extGroupData.getString("vehicle_type"));
|
||||
task.setGroup_id(extGroupData.getString("group_id"));
|
||||
task.setRemark("中转后的半托任务");
|
||||
} else {
|
||||
// 判断工单是否够
|
||||
boolean enoughCallEmpty = workorderService.isEnoughCallEmpty(task.getPoint_code2());
|
||||
if (!enoughCallEmpty) {
|
||||
throw new BadRequestException("所需数量已足够,不呼叫空盘");
|
||||
}
|
||||
// 找起点
|
||||
SchBasePoint point = findStartPoint(startRegionStr, extGroupData);
|
||||
if (ObjectUtil.isEmpty(point)) {
|
||||
// 消息通知
|
||||
@@ -154,46 +167,45 @@ public class FJQKTask extends AbstractTask {
|
||||
} else {
|
||||
// 半托任务
|
||||
if ("1".equals(extGroupData.getString("flag"))) {
|
||||
// 查找移库点
|
||||
LambdaQueryWrapper<SchBasePoint> lam = new LambdaQueryWrapper<>();
|
||||
lam.eq(SchBasePoint::getRegion_code, point.getRegion_code())
|
||||
// 当前执行的任务为空或者NULL,有数据表示锁住
|
||||
.and(la -> la.isNull(SchBasePoint::getIng_task_code)
|
||||
.or()
|
||||
.eq(SchBasePoint::getIng_task_code, ""))
|
||||
.eq(SchBasePoint::getIs_used, true)
|
||||
.eq(SchBasePoint::getPoint_type, "2")
|
||||
.eq(SchBasePoint::getPoint_status, "1")
|
||||
.orderByAsc(SchBasePoint::getPoint_type)
|
||||
.orderByAsc(SchBasePoint::getPoint_code);
|
||||
SchBasePoint movePoint = pointService.getOne(lam);
|
||||
if (ObjectUtil.isEmpty(movePoint)) {
|
||||
throw new BadRequestException("找不到可用的中转点位!");
|
||||
}
|
||||
SchBasePoint movePoint = point.getFlagPoint();
|
||||
// 需要移库
|
||||
JSONObject param = new JSONObject();
|
||||
// 移动的货位
|
||||
param.put("device_code", point.getFlagPoint().getPoint_code());
|
||||
// 中转位
|
||||
param.put("target", movePoint.getPoint_code());
|
||||
param.put("device_code", movePoint.getPoint_code());
|
||||
// 所需要的半托位置
|
||||
param.put("point_code1", point.getPoint_code());
|
||||
// 分拣码垛位
|
||||
param.put("point_code2", task.getPoint_code2());
|
||||
param.put("vehicle_code", task.getVehicle_code());
|
||||
param.put("vehicle_type", task.getVehicle_type());
|
||||
param.put("vehicle_code", movePoint.getVehicle_code());
|
||||
param.put("vehicle_type", movePoint.getVehicle_type());
|
||||
param.put("group_id", point.getGroup_id());
|
||||
param.put("config_code", "MDOutMoveTask");
|
||||
param.put("next", "FJQKTask");
|
||||
mdOutMoveTask.apply(param);
|
||||
point.setIng_task_code("半托移库任务");
|
||||
PointUtils.setUpdateByAcs(point);
|
||||
movePoint.setIng_task_code("半托移库任务");
|
||||
PointUtils.setUpdateByAcs(movePoint);
|
||||
pointService.updateBatchById(Arrays.asList(point, movePoint));
|
||||
return;
|
||||
} else {
|
||||
// 不需要移库
|
||||
// 设置起点并修改创建成功状态
|
||||
task.setPoint_code1(point.getPoint_code());
|
||||
point.setIng_task_code(task.getTask_code());
|
||||
PointUtils.setUpdateByAcs(point);
|
||||
pointService.updateById(point);
|
||||
}
|
||||
}
|
||||
// 记录了上一个任务的任务号,等这个任务完成之后,才能触发下发该任务
|
||||
if (ObjectUtil.isNotEmpty(point.getTask_warn())) {
|
||||
|
||||
}
|
||||
task.setTask_status(TaskStatus.CREATED.getCode());
|
||||
task.setResponse_param(extGroupData.toJSONString());
|
||||
task.setRemark("");
|
||||
task.setGroup_id(point.getGroup_id());
|
||||
}
|
||||
task.setResponse_param(extGroupData.toJSONString());
|
||||
taskService.save(task);
|
||||
}
|
||||
|
||||
@@ -244,6 +256,20 @@ public class FJQKTask extends AbstractTask {
|
||||
}
|
||||
}
|
||||
return endPointObj;
|
||||
} else {
|
||||
// 判断是否正在移库或者被还原移库 且没其他任务
|
||||
SchBasePoint zzwPoint = fjMapper.findOnePointAndTransit();
|
||||
if (ObjectUtil.isNotEmpty(zzwPoint)) {
|
||||
return zzwPoint;
|
||||
}
|
||||
// 判断是否存在任务
|
||||
List<SchBaseTask> tasks = fjMapper.findTaskForRunningMaterial(one.getMaterial_id());
|
||||
if (!tasks.isEmpty()) {
|
||||
SchBaseTask schBaseTask = tasks.get(0);
|
||||
SchBasePoint point = pointService.getById(schBaseTask.getPoint_code2());
|
||||
point.setTask_warn(schBaseTask.getTask_code());
|
||||
return point;
|
||||
}
|
||||
}
|
||||
// 向ACS请求所需木托盘在那个栈拆盘机?已经实时更新,故只需要自己查询即可
|
||||
endPointObj = fjMapper.findPointForFJQK(startRegionStr, new JSONObject()
|
||||
@@ -326,6 +352,22 @@ public class FJQKTask extends AbstractTask {
|
||||
TaskUtils.setWorkOrderUpdateByType(workorder, taskFinishedType);
|
||||
workorderService.updateById(workorder);
|
||||
}
|
||||
// 如果是移库,需要还原
|
||||
if (ObjectUtil.isNotEmpty(jsonObject.getString("is_confirm"))
|
||||
&& "1".equals(jsonObject.getString("is_confirm"))) {
|
||||
// 需要再次判断是否有任务
|
||||
if (!taskService.checkTask(jsonObject.getString("point_code1"))) {
|
||||
SchBasePoint point = pointService.getById(jsonObject.getString("point_code1"));
|
||||
JSONObject param = new JSONObject();
|
||||
param.put("device_code", jsonObject.getString("point_code1"));
|
||||
param.put("target", jsonObject.getString("point_code2"));
|
||||
param.put("vehicle_code", point.getVehicle_code());
|
||||
param.put("vehicle_type", point.getVehicle_type());
|
||||
param.put("config_code", "MDInMoveTask");
|
||||
param.put("need_released", jsonObject.getString("need_released"));
|
||||
mdInMoveTask.apply(param);
|
||||
}
|
||||
}
|
||||
// 任务完成
|
||||
taskObj.setTask_status(TaskStatus.FINISHED.getCode());
|
||||
taskObj.setRemark(GeneralDefinition.TASK_FINISH);
|
||||
|
||||
@@ -111,6 +111,33 @@ public class FJQLTask extends AbstractTask {
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean checkTask(JSONObject param) {
|
||||
// 1. 优先检查确认标志
|
||||
if (isConfirmed(param)) {
|
||||
return false;
|
||||
}
|
||||
// 2. 验证必要参数
|
||||
String deviceCode = param.getString("device_code");
|
||||
if (ObjectUtil.isEmpty(deviceCode)) {
|
||||
return false;
|
||||
}
|
||||
// 3. 查询未完成任务数量
|
||||
long count = taskService.count(buildTaskQuery(deviceCode));
|
||||
return count > 0;
|
||||
}
|
||||
private boolean isConfirmed(JSONObject param) {
|
||||
String isConfirm = param.getString("is_confirm");
|
||||
return ObjectUtil.isNotEmpty(isConfirm)
|
||||
&& GeneralDefinition.YES.equals(isConfirm);
|
||||
}
|
||||
private LambdaQueryWrapper<SchBaseTask> buildTaskQuery(String deviceCode) {
|
||||
return new LambdaQueryWrapper<SchBaseTask>()
|
||||
.eq(SchBaseTask::getPoint_code3, deviceCode)
|
||||
.eq(SchBaseTask::getIs_delete, false)
|
||||
.lt(SchBaseTask::getTask_status, TaskStatus.FINISHED.getCode());
|
||||
}
|
||||
|
||||
@Override
|
||||
@Transactional(rollbackFor = Exception.class)
|
||||
public void createCompletion(SchBaseTask task) {
|
||||
@@ -125,12 +152,21 @@ public class FJQLTask extends AbstractTask {
|
||||
// 找起点
|
||||
String requestParam = task.getRequest_param();
|
||||
JSONObject extGroupData = JSONObject.parseObject(requestParam);
|
||||
String isConfirm = extGroupData.getString("is_confirm");
|
||||
if (ObjectUtil.isNotEmpty(isConfirm) && GeneralDefinition.YES.equals(isConfirm)) {
|
||||
task.setPoint_code1(extGroupData.getString("target"));
|
||||
task.setTask_status(TaskStatus.CREATED.getCode());
|
||||
task.setVehicle_code(extGroupData.getString("vehicle_code"));
|
||||
task.setVehicle_type(extGroupData.getString("vehicle_type"));
|
||||
task.setGroup_id(extGroupData.getString("group_id"));
|
||||
task.setRemark("");
|
||||
} else {
|
||||
// hint: 需要加上搬运过程中的数量
|
||||
boolean enoughCallMaterial = workorderService.isEnoughCallMaterial(task.getPoint_code2());
|
||||
// 对于分拣,用于分拣钢托盘砖块数
|
||||
if (!enoughCallMaterial) {
|
||||
// 消息通知
|
||||
noticeService.createNotice("钢托盘砖块数已达到所需数量!", TASK_CONFIG_CODE + task.getPoint_code2(),
|
||||
noticeService.createNotice("钢托盘砖块数已达到所需数量!", task.getPoint_code2() + "分拣呼叫物料失败",
|
||||
NoticeTypeEnum.WARN.getCode());
|
||||
throw new BadRequestException("钢托盘砖块数已达到所需数量!");
|
||||
}
|
||||
@@ -139,7 +175,7 @@ public class FJQLTask extends AbstractTask {
|
||||
SchBasePoint point = findStartPoint(startRegionStr, extGroupData);
|
||||
if (ObjectUtil.isEmpty(point)) {
|
||||
// 消息通知
|
||||
noticeService.createNotice("钢托盘缓存货架没有所需物料!", TASK_CONFIG_CODE + task.getPoint_code2(),
|
||||
noticeService.createNotice("钢托盘缓存货架没有所需物料!", task.getPoint_code2() + "分拣呼叫物料失败",
|
||||
NoticeTypeEnum.WARN.getCode());
|
||||
throw new BadRequestException("钢托盘缓存货架没有所需物料!");
|
||||
}
|
||||
@@ -152,19 +188,24 @@ public class FJQLTask extends AbstractTask {
|
||||
if ("1".equals(point.getTask_warn())) {
|
||||
// 提前分配的货位需要锁住
|
||||
SchBasePoint flagPoint = point.getFlagPoint();
|
||||
flagPoint.setIng_task_code(task.getTask_code());
|
||||
PointUtils.setUpdateByAcs(flagPoint);
|
||||
pointService.updateById(flagPoint);
|
||||
task.setPoint_code3(task.getPoint_code2());
|
||||
task.setPoint_code2(flagPoint.getPoint_code());
|
||||
task.setRequest_param(JSONObject.toJSONString(extGroupData));
|
||||
JSONObject param = new JSONObject();
|
||||
param.put("device_code", point.getPoint_code());
|
||||
param.put("target", flagPoint.getPoint_code());
|
||||
param.put("target2", task.getPoint_code2());
|
||||
param.put("vehicle_code", point.getVehicle_code());
|
||||
param.put("vehicle_type", point.getVehicle_type());
|
||||
param.put("config_code", "MoveTask");
|
||||
param.put("ext_param", extGroupData);
|
||||
param.put("group_id", point.getGroup_id());
|
||||
moveTask.apply(param);
|
||||
return;
|
||||
}
|
||||
taskService.save(task);
|
||||
|
||||
point.setIng_task_code(task.getTask_code());
|
||||
PointUtils.setUpdateByAcs(point);
|
||||
pointService.updateById(point);
|
||||
}
|
||||
taskService.save(task);
|
||||
}
|
||||
|
||||
/**
|
||||
* 找起点:到钢托盘缓存/双层输送线找一个物料与分拣工单的物料相同的物料
|
||||
@@ -184,7 +225,7 @@ public class FJQLTask extends AbstractTask {
|
||||
Assert.notNull(workOrder, "工单不能为空!");
|
||||
// 从所选区域中,选择满料位、无锁、可用的点位
|
||||
List<SchBasePoint> points = fjMapper.findPointForFJQL(startRegionStr, workOrder.getMaterial_id());
|
||||
if (points.size() == 0) {
|
||||
if (points.isEmpty()) {
|
||||
return null;
|
||||
}
|
||||
// 判断点位是否需要先AGV中转
|
||||
@@ -198,7 +239,8 @@ public class FJQLTask extends AbstractTask {
|
||||
requestParam.put("flag", "1");
|
||||
requestParam.put("target", hcssx.getPoint_code());
|
||||
basePoint.setTask_warn("1");
|
||||
basePoint.setFlagPoint(basePoint);
|
||||
// 存放缓存输送线中转点
|
||||
basePoint.setFlagPoint(hcssx);
|
||||
}
|
||||
return basePoint;
|
||||
}
|
||||
@@ -279,6 +321,7 @@ public class FJQLTask extends AbstractTask {
|
||||
endPointObj.setVehicle_code(vehicleMaterialGroupObj.getVehicle_code());
|
||||
endPointObj.setVehicle_type(vehicleMaterialGroupObj.getVehicle_type());
|
||||
endPointObj.setPoint_status(PointStatusEnum.EMPTY_VEHICLE.getCode());
|
||||
endPointObj.setVehicle_qty(1);
|
||||
PointUtils.setUpdateByType(endPointObj, taskFinishedType);
|
||||
pointService.updateById(endPointObj);
|
||||
// 修改工单实际搬运钢托盘上的码垛数量
|
||||
@@ -287,20 +330,6 @@ public class FJQLTask extends AbstractTask {
|
||||
vehicleMaterialGroupObj.getMaterial_qty())));
|
||||
TaskUtils.setWorkOrderUpdateByType(workorderCode, taskFinishedType);
|
||||
workorderService.updateById(workorderCode);
|
||||
// 创建中转任务
|
||||
// 判断是否转运
|
||||
String flag = extGroupData.getString("flag");
|
||||
if (ObjectUtil.isNotEmpty(flag) && "1".equals(flag)) {
|
||||
// 创建AGV任务
|
||||
JSONObject param = new JSONObject();
|
||||
param.put("device_code", taskObj.getPoint_code2());
|
||||
param.put("target", taskObj.getPoint_code3());
|
||||
param.put("vehicle_code", taskObj.getVehicle_code());
|
||||
param.put("vehicle_type", taskObj.getVehicle_type());
|
||||
param.put("config_code", "MoveTask");
|
||||
param.put("group_id", vehicleMaterialGroupObj.getGroup_id());
|
||||
moveTask.apply(param);
|
||||
}
|
||||
}
|
||||
// 任务完成
|
||||
taskObj.setTask_status(TaskStatus.FINISHED.getCode());
|
||||
|
||||
@@ -3,6 +3,7 @@ package org.nl.wms.sch.task_manage.task.tasks.fj.mapper;
|
||||
import com.alibaba.fastjson.JSONObject;
|
||||
import org.apache.ibatis.annotations.Param;
|
||||
import org.nl.wms.sch.point.service.dao.SchBasePoint;
|
||||
import org.nl.wms.sch.task.service.dao.SchBaseTask;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
@@ -41,4 +42,8 @@ public interface FJMapper {
|
||||
String getNeedFullNumber(String materialId);
|
||||
|
||||
SchBasePoint findPointForBt(String materialId);
|
||||
|
||||
List<SchBaseTask> findTaskForRunningMaterial(String materialId);
|
||||
|
||||
SchBasePoint findOnePointAndTransit();
|
||||
}
|
||||
|
||||
@@ -77,7 +77,8 @@
|
||||
</select>
|
||||
<select id="findPointForBt" resultType="org.nl.wms.sch.point.service.dao.SchBasePoint">
|
||||
SELECT
|
||||
p.*
|
||||
p.*,
|
||||
g.group_id
|
||||
FROM
|
||||
`sch_base_point` p
|
||||
LEFT JOIN sch_base_vehiclematerialgroup g ON g.vehicle_code = p.vehicle_code
|
||||
@@ -95,4 +96,23 @@
|
||||
p.out_order_seq
|
||||
LIMIT 1
|
||||
</select>
|
||||
<select id="findTaskForRunningMaterial" resultType="org.nl.wms.sch.task.service.dao.SchBaseTask">
|
||||
select * from sch_base_task t
|
||||
where t.is_delete = false
|
||||
and (t.config_code = 'MDOutMoveTask' or t.config_code = 'MDInMoveTask')
|
||||
and '5' > t.task_status
|
||||
and #{materialId} = (select v.material_id from sch_base_vehiclematerialgroup v
|
||||
where v.vehicle_code = t.vehicle_code and v.vehicle_type = t.vehicle_type
|
||||
and v.group_bind_material_status = '2')
|
||||
</select>
|
||||
<select id="findOnePointAndTransit" resultType="org.nl.wms.sch.point.service.dao.SchBasePoint">
|
||||
SELECT p.*
|
||||
FROM sch_base_point p
|
||||
WHERE p.region_code = 'BTHC'
|
||||
AND (p.ing_task_code IS NULL OR p.ing_task_code = '')
|
||||
AND p.is_used = true
|
||||
AND p.point_status = '2'
|
||||
AND p.point_type = '2'
|
||||
AND 0 = (select count(*) from sch_base_task t where '5' > t.task_status and (t.point_code1 = p.point_code or t.point_code2 = p.point_code))
|
||||
</select>
|
||||
</mapper>
|
||||
|
||||
@@ -39,6 +39,7 @@ import org.springframework.beans.factory.annotation.Autowired;
|
||||
import org.springframework.stereotype.Component;
|
||||
import org.springframework.transaction.annotation.Transactional;
|
||||
|
||||
import java.math.BigDecimal;
|
||||
import java.util.Arrays;
|
||||
import java.util.List;
|
||||
import java.util.stream.Collectors;
|
||||
@@ -211,7 +212,7 @@ public class CYZCTask extends AbstractTask {
|
||||
}
|
||||
PdmBdWorkorder order = workorderService.getByCode(vehilceCode.getWorkorder_code());
|
||||
if (order.getIs_urgent()) {
|
||||
// 加急,直接去3号窑
|
||||
// 加急,直接去3号窑todo: 判断3号窑满了没
|
||||
return pointService.getById("LQYRK03");
|
||||
}
|
||||
}
|
||||
@@ -273,8 +274,6 @@ public class CYZCTask extends AbstractTask {
|
||||
}
|
||||
if (status.equals(TaskStatus.FINISHED)) {
|
||||
this.finishTask(taskObj, TaskFinishedTypeEnum.AUTO_ACS);
|
||||
// todo 出窑上报出窑记录
|
||||
// wmsToMesService.reportGdyMaterialInfoOut(taskObj.getGroup_id());
|
||||
}
|
||||
if (status.equals(TaskStatus.CANCELED)) {
|
||||
this.cancelTask(taskObj, TaskFinishedTypeEnum.AUTO_ACS);
|
||||
@@ -340,6 +339,15 @@ public class CYZCTask extends AbstractTask {
|
||||
processTracking.setProcess_location(endPoint);
|
||||
processTracking.setRecord_time(DateUtil.now());
|
||||
processTrackingService.create(processTracking);
|
||||
|
||||
// 如果是去分拣拆垛位,需要给工单加上数量
|
||||
if (endPoint.startsWith("FJ")) {
|
||||
PdmBdWorkorder productionTask = workorderService.getDeviceProductionTask(endPointObj.getParent_point_code());
|
||||
productionTask.setReal_weight(productionTask.getReal_weight().add(BigDecimal.valueOf(
|
||||
one.getMaterial_qty())));
|
||||
TaskUtils.setWorkOrderUpdateByType(productionTask, taskFinishedType);
|
||||
workorderService.updateById(productionTask);
|
||||
}
|
||||
}
|
||||
|
||||
kilnRecordService.inCoolKilnInfo(vehicle_code, endPointObj);
|
||||
|
||||
@@ -222,14 +222,14 @@ public class LQYMLTask extends AbstractTask {
|
||||
// 判断双层输送线和钢托缓存库有没有相同物料
|
||||
List<SchBasePoint> list = gzyMapper.getPointTheSameMaterial(vehicleObj.getMaterial_id());
|
||||
List<SchBasePoint> useList = new ArrayList<>();
|
||||
if (list.size() == 0) {
|
||||
// 分配一个到对应分拣工单的空位置。
|
||||
if (list.isEmpty()) {
|
||||
// 分配一个到对应分拣工单的空位置。已经判断了工单计划数与实际数
|
||||
useList = gzyMapper.getSortingEmptyPoint(vehicleObj.getMaterial_id());
|
||||
}
|
||||
if (useList.size() == 0) {
|
||||
if (useList.isEmpty()) {
|
||||
// 分配一个双层输送线的一层货位
|
||||
useList = gzyMapper.getOneLayerConveyor(vehicleObj.getMaterial_id());
|
||||
if (useList.size() == 0) {
|
||||
if (useList.isEmpty()) {
|
||||
// 分配钢托盘缓存库
|
||||
useList = gzyMapper.getSteelLib();
|
||||
}
|
||||
|
||||
@@ -0,0 +1,142 @@
|
||||
package org.nl.wms.sch.task_manage.task.tasks.yao;
|
||||
|
||||
import cn.hutool.core.util.IdUtil;
|
||||
import cn.hutool.core.util.ObjectUtil;
|
||||
import org.nl.common.exception.BadRequestException;
|
||||
import org.nl.wms.pdm.record.service.IPdmBdKilnRecordService;
|
||||
import org.nl.wms.sch.point.service.ISchBasePointService;
|
||||
import org.nl.wms.sch.point.service.dao.SchBasePoint;
|
||||
import org.nl.wms.sch.task.service.ISchBaseTaskService;
|
||||
import org.nl.wms.sch.task.service.dao.SchBaseTask;
|
||||
import org.nl.wms.sch.task_manage.AbstractTask;
|
||||
import org.nl.wms.sch.task_manage.GeneralDefinition;
|
||||
import org.nl.wms.sch.task_manage.enums.TaskFinishedTypeEnum;
|
||||
import org.nl.wms.sch.task_manage.task.core.TaskStatus;
|
||||
import org.nl.wms.util.TaskUtils;
|
||||
import org.springframework.stereotype.Component;
|
||||
|
||||
import javax.annotation.Resource;
|
||||
|
||||
/**
|
||||
* 冷却窑缺空任务
|
||||
* <p>
|
||||
* 会呼叫空的窑口:
|
||||
* 冷却窑入口01-03
|
||||
* 冷却窑出口03
|
||||
* <p>
|
||||
* 呼叫的统统不知道载具号,故为“-”,空盘出窑的时候,如果有载具号,但是没找到载具号的记录,则筛选一条“-”的出窑
|
||||
* @Author: lyd
|
||||
* @Date: 2025/12/30
|
||||
*/
|
||||
@Component("LQYQKTask")
|
||||
public class LQYQKTask extends AbstractTask {
|
||||
public static final String[] AREA = {"DTW02", "CPJCK"};
|
||||
@Resource
|
||||
private ISchBasePointService pointService;
|
||||
@Resource
|
||||
private ISchBaseTaskService taskService;
|
||||
@Resource
|
||||
private IPdmBdKilnRecordService kilnRecordService;
|
||||
@Override
|
||||
public void create() throws BadRequestException {
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* 入窑口去DTW02
|
||||
* 出窑口去CPJCK
|
||||
* @param task
|
||||
*/
|
||||
@Override
|
||||
public void createCompletion(SchBaseTask task) {
|
||||
int vehicleQty = task.getVehicle_qty();
|
||||
SchBasePoint startPoint = pointService.getById(task.getPoint_code1());
|
||||
// CPJCK DTW02
|
||||
SchBasePoint point = pointService.getById(AREA[Integer.parseInt(startPoint.getPoint_type())]);
|
||||
if (!"3".equals(point.getPoint_type())) {
|
||||
SchBasePoint point1 = pointService.getById(point.getParent_point_code());
|
||||
vehicleQty = Math.min(vehicleQty, point1.getVehicle_qty());
|
||||
} else {
|
||||
vehicleQty = Math.min(vehicleQty, point.getVehicle_qty());
|
||||
}
|
||||
if (0 == vehicleQty) {
|
||||
throw new BadRequestException("暂无空托盘!");
|
||||
}
|
||||
for (int i = 0; i < vehicleQty; i++) {
|
||||
task.setTask_id(IdUtil.getSnowflake(1, 1).nextIdStr());
|
||||
task.setTask_code(IdUtil.getSnowflake(1, 1).nextIdStr());
|
||||
task.setVehicle_type(GeneralDefinition.STEEL_TRAY);
|
||||
task.setPoint_code2(point.getPoint_code());
|
||||
task.setTask_status(TaskStatus.CREATED.getCode());
|
||||
task.setRemark("");
|
||||
TaskUtils.setUpdateByAcs(task);
|
||||
taskService.updateById(task);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void updateStatus(String task_code, TaskStatus status) {
|
||||
// 校验任务
|
||||
SchBaseTask taskObj = taskService.getByCode(task_code);
|
||||
if (taskObj.getTask_status().equals(TaskStatus.FINISHED.getCode())) {
|
||||
throw new BadRequestException("该任务已完成!");
|
||||
}
|
||||
if (taskObj.getTask_status().equals(TaskStatus.CANCELED.getCode())) {
|
||||
throw new BadRequestException("该任务已取消!");
|
||||
}
|
||||
|
||||
// 根据传来的类型去对任务进行操作
|
||||
if (status.equals(TaskStatus.EXECUTING)) {
|
||||
taskObj.setTask_status(TaskStatus.EXECUTING.getCode());
|
||||
taskObj.setRemark("执行中");
|
||||
TaskUtils.setUpdateByAcs(taskObj);
|
||||
taskService.updateById(taskObj);
|
||||
}
|
||||
if (status.equals(TaskStatus.FINISHED)) {
|
||||
this.finishTask(taskObj, TaskFinishedTypeEnum.AUTO_ACS);
|
||||
}
|
||||
if (status.equals(TaskStatus.CANCELED)) {
|
||||
this.cancelTask(taskObj, TaskFinishedTypeEnum.AUTO_ACS);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void forceFinish(String task_code) {
|
||||
SchBaseTask taskObj = taskService.getByCode(task_code);
|
||||
if (ObjectUtil.isEmpty(taskObj)) {
|
||||
throw new BadRequestException("该任务不存在");
|
||||
}
|
||||
this.finishTask(taskObj, TaskFinishedTypeEnum.MANUAL_PC);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void cancel(String task_code) {
|
||||
SchBaseTask taskObj = taskService.getByCode(task_code);
|
||||
if (ObjectUtil.isEmpty(taskObj)) {
|
||||
throw new BadRequestException("该任务不存在");
|
||||
}
|
||||
this.cancelTask(taskObj, TaskFinishedTypeEnum.MANUAL_PC);
|
||||
}
|
||||
|
||||
public void finishTask(SchBaseTask taskObj, TaskFinishedTypeEnum taskFinishedType) {
|
||||
SchBasePoint point = pointService.getById(taskObj.getPoint_code2());
|
||||
// 记录入窑
|
||||
// 记录入窑记录
|
||||
kilnRecordService.recordCoolEmptyKilnInfo( point);
|
||||
// 任务完成
|
||||
taskObj.setTask_status(TaskStatus.FINISHED.getCode());
|
||||
taskObj.setRemark(GeneralDefinition.TASK_FINISH);
|
||||
taskObj.setFinished_type(taskFinishedType.getCode());
|
||||
TaskUtils.setUpdateByType(taskObj, taskFinishedType);
|
||||
taskService.updateById(taskObj);
|
||||
}
|
||||
|
||||
public void cancelTask(SchBaseTask taskObj, TaskFinishedTypeEnum taskFinishedType) {
|
||||
// 任务完成
|
||||
taskObj.setTask_status(TaskStatus.CANCELED.getCode());
|
||||
taskObj.setRemark(GeneralDefinition.TASK_CANCEL);
|
||||
taskObj.setFinished_type(taskFinishedType.getCode());
|
||||
TaskUtils.setUpdateByType(taskObj, taskFinishedType);
|
||||
taskService.updateById(taskObj);
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,165 @@
|
||||
package org.nl.wms.sch.task_manage.task.tasks.yao;
|
||||
|
||||
import cn.hutool.core.util.ObjectUtil;
|
||||
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
||||
import org.nl.common.exception.BadRequestException;
|
||||
import org.nl.system.service.param.ISysParamService;
|
||||
import org.nl.system.service.param.dao.Param;
|
||||
import org.nl.wms.pdm.record.service.IPdmBdKilnRecordService;
|
||||
import org.nl.wms.pdm.record.service.dao.PdmBdKilnRecord;
|
||||
import org.nl.wms.sch.point.service.ISchBasePointService;
|
||||
import org.nl.wms.sch.point.service.dao.SchBasePoint;
|
||||
import org.nl.wms.sch.task.service.ISchBaseTaskService;
|
||||
import org.nl.wms.sch.task.service.dao.SchBaseTask;
|
||||
import org.nl.wms.sch.task_manage.AbstractTask;
|
||||
import org.nl.wms.sch.task_manage.GeneralDefinition;
|
||||
import org.nl.wms.sch.task_manage.enums.TaskFinishedTypeEnum;
|
||||
import org.nl.wms.sch.task_manage.task.core.TaskStatus;
|
||||
import org.nl.wms.util.TaskUtils;
|
||||
import org.springframework.stereotype.Component;
|
||||
|
||||
import javax.annotation.Resource;
|
||||
import java.util.Comparator;
|
||||
import java.util.List;
|
||||
import java.util.stream.Collectors;
|
||||
|
||||
/**
|
||||
* 冷却窑送空任务
|
||||
* @Author: lyd
|
||||
* @Date: 2025/12/30
|
||||
*/
|
||||
@Component("LQYSKTask")
|
||||
public class LQYSKTask extends AbstractTask {
|
||||
private static final String COOL_KILN_MAX = "COOL_KILN_MAX";
|
||||
|
||||
@Resource
|
||||
private ISchBasePointService pointService;
|
||||
@Resource
|
||||
private ISchBaseTaskService taskService;
|
||||
@Resource
|
||||
private IPdmBdKilnRecordService kilnRecordService;
|
||||
@Resource
|
||||
private ISysParamService paramService;
|
||||
@Override
|
||||
public void create() throws BadRequestException {
|
||||
|
||||
}
|
||||
|
||||
@Override
|
||||
public void createCompletion(SchBaseTask task) {
|
||||
// 过滤窑内现有的托盘数不超过设定值
|
||||
Param param = paramService.findByCode(COOL_KILN_MAX);
|
||||
if (ObjectUtil.isEmpty(param)) {
|
||||
throw new BadRequestException("未配置冷却窑最大托盘数!");
|
||||
}
|
||||
LambdaQueryWrapper<SchBasePoint> lam = new LambdaQueryWrapper<>();
|
||||
lam.eq(SchBasePoint::getRegion_code, "LQY")
|
||||
.eq(SchBasePoint::getPoint_type, GeneralDefinition.ENTRANCE)
|
||||
.ne(SchBasePoint::getPoint_code, "LQYRK03")
|
||||
.eq(SchBasePoint::getIs_used, true);
|
||||
List<SchBasePoint> schBasePoints = pointService.list(lam);
|
||||
List<SchBasePoint> collect = schBasePoints.stream()
|
||||
.map(p -> {
|
||||
int count = kilnRecordService.count(new LambdaQueryWrapper<PdmBdKilnRecord>()
|
||||
.eq(PdmBdKilnRecord::getCooling_code, p.getPoint_code())
|
||||
.eq(PdmBdKilnRecord::getStatus, "2"));
|
||||
int taskNum = taskService.count(new LambdaQueryWrapper<SchBaseTask>()
|
||||
.eq(SchBaseTask::getPoint_code2, p.getPoint_code())
|
||||
.eq(SchBaseTask::getIs_delete, false)
|
||||
.lt(SchBaseTask::getTask_status, "5"));
|
||||
return new PointWithTotal(p, count + taskNum);
|
||||
})
|
||||
.filter(pwt -> pwt.total < Integer.parseInt(param.getValue()))
|
||||
.sorted(Comparator.comparingInt((PointWithTotal pwt) -> pwt.total).reversed())
|
||||
.map(pwt -> pwt.point)
|
||||
.collect(Collectors.toList());
|
||||
if (collect.size() == 0) {
|
||||
throw new BadRequestException("冷却窑均满了,请稍后在试!");
|
||||
}
|
||||
SchBasePoint basePoint = collect.get(0);
|
||||
task.setVehicle_type(GeneralDefinition.STEEL_TRAY);
|
||||
task.setPoint_code2(basePoint.getPoint_code());
|
||||
task.setTask_status(TaskStatus.CREATED.getCode());
|
||||
task.setRemark("");
|
||||
TaskUtils.setUpdateByAcs(task);
|
||||
taskService.updateById(task);
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void updateStatus(String task_code, TaskStatus status) {
|
||||
// 校验任务
|
||||
SchBaseTask taskObj = taskService.getByCode(task_code);
|
||||
if (taskObj.getTask_status().equals(TaskStatus.FINISHED.getCode())) {
|
||||
throw new BadRequestException("该任务已完成!");
|
||||
}
|
||||
if (taskObj.getTask_status().equals(TaskStatus.CANCELED.getCode())) {
|
||||
throw new BadRequestException("该任务已取消!");
|
||||
}
|
||||
|
||||
// 根据传来的类型去对任务进行操作
|
||||
if (status.equals(TaskStatus.EXECUTING)) {
|
||||
taskObj.setTask_status(TaskStatus.EXECUTING.getCode());
|
||||
taskObj.setRemark("执行中");
|
||||
TaskUtils.setUpdateByAcs(taskObj);
|
||||
taskService.updateById(taskObj);
|
||||
}
|
||||
if (status.equals(TaskStatus.FINISHED)) {
|
||||
this.finishTask(taskObj, TaskFinishedTypeEnum.AUTO_ACS);
|
||||
}
|
||||
if (status.equals(TaskStatus.CANCELED)) {
|
||||
this.cancelTask(taskObj, TaskFinishedTypeEnum.AUTO_ACS);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void forceFinish(String task_code) {
|
||||
SchBaseTask taskObj = taskService.getByCode(task_code);
|
||||
if (ObjectUtil.isEmpty(taskObj)) {
|
||||
throw new BadRequestException("该任务不存在");
|
||||
}
|
||||
this.finishTask(taskObj, TaskFinishedTypeEnum.MANUAL_PC);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void cancel(String task_code) {
|
||||
SchBaseTask taskObj = taskService.getByCode(task_code);
|
||||
if (ObjectUtil.isEmpty(taskObj)) {
|
||||
throw new BadRequestException("该任务不存在");
|
||||
}
|
||||
this.cancelTask(taskObj, TaskFinishedTypeEnum.MANUAL_PC);
|
||||
}
|
||||
|
||||
public void finishTask(SchBaseTask taskObj, TaskFinishedTypeEnum taskFinishedType) {
|
||||
SchBasePoint point = pointService.getById(taskObj.getPoint_code2());
|
||||
// 记录入窑
|
||||
// 记录入窑记录
|
||||
kilnRecordService.recordCoolEmptyKilnInfo(point);
|
||||
// 去处当前出窑的空托
|
||||
kilnRecordService.removeOneCoolEmptyInfo(point);
|
||||
// 任务完成
|
||||
taskObj.setTask_status(TaskStatus.FINISHED.getCode());
|
||||
taskObj.setRemark(GeneralDefinition.TASK_FINISH);
|
||||
taskObj.setFinished_type(taskFinishedType.getCode());
|
||||
TaskUtils.setUpdateByType(taskObj, taskFinishedType);
|
||||
taskService.updateById(taskObj);
|
||||
}
|
||||
|
||||
public void cancelTask(SchBaseTask taskObj, TaskFinishedTypeEnum taskFinishedType) {
|
||||
// 任务完成
|
||||
taskObj.setTask_status(TaskStatus.CANCELED.getCode());
|
||||
taskObj.setRemark(GeneralDefinition.TASK_CANCEL);
|
||||
taskObj.setFinished_type(taskFinishedType.getCode());
|
||||
TaskUtils.setUpdateByType(taskObj, taskFinishedType);
|
||||
taskService.updateById(taskObj);
|
||||
}
|
||||
|
||||
static class PointWithTotal {
|
||||
SchBasePoint point;
|
||||
int total;
|
||||
|
||||
PointWithTotal(SchBasePoint point, int total) {
|
||||
this.point = point;
|
||||
this.total = total;
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -45,21 +45,22 @@
|
||||
AND g.group_bind_material_status = '2'
|
||||
</select>
|
||||
<select id="getSortingEmptyPoint" resultType="org.nl.wms.sch.point.service.dao.SchBasePoint">
|
||||
SELECT
|
||||
p.*
|
||||
FROM
|
||||
sch_base_point p
|
||||
SELECT p.*
|
||||
FROM sch_base_point p
|
||||
INNER JOIN pdm_bd_workorder w ON w.point_code = p.parent_point_code
|
||||
AND w.region_code = 'FJ'
|
||||
AND w.real_weight <![CDATA[<>]]> w.plan_weight
|
||||
AND w.workorder_status = '3'
|
||||
WHERE
|
||||
p.point_type = '2'
|
||||
WHERE p.point_type = '2'
|
||||
AND p.region_code = 'FJ'
|
||||
AND p.is_used = TRUE
|
||||
AND p.point_status = '1'
|
||||
AND IFNULL( p.ing_task_code, '' ) = ''
|
||||
AND 0 = (SELECT COUNT(*) FROM sch_base_task t WHERE t.is_delete = FALSE AND t.point_code2 = p.point_code AND t.task_status <![CDATA[<]]> '5')
|
||||
AND IFNULL(p.ing_task_code, '') = ''
|
||||
AND 0 = (SELECT COUNT(*)
|
||||
FROM sch_base_task t
|
||||
WHERE t.is_delete = FALSE
|
||||
AND t.point_code2 = p.point_code
|
||||
AND t.task_status <![CDATA[<]]> '5')
|
||||
AND w.material_id = #{materialId}
|
||||
</select>
|
||||
<select id="getOneLayerConveyor" resultType="org.nl.wms.sch.point.service.dao.SchBasePoint">
|
||||
|
||||
@@ -54,6 +54,23 @@ public class PointUtils {
|
||||
point.setUpdate_time(DateUtil.now());
|
||||
pointService.updateById(point);
|
||||
}
|
||||
/**
|
||||
* 清空点位 - 不解锁
|
||||
*
|
||||
* @param point
|
||||
*/
|
||||
public static void clearPointNoLock(SchBasePoint point) {
|
||||
if (ObjectUtil.isEmpty(point)) {
|
||||
return; // 空直接退出
|
||||
}
|
||||
SchBasePointServiceImpl pointService = SpringContextHolder.getBean(SchBasePointServiceImpl.class);
|
||||
point.setPoint_status(PointStatusEnum.EMPTY_POINT.getCode());
|
||||
point.setVehicle_type("");
|
||||
point.setVehicle_code("");
|
||||
point.setVehicle_qty(0);
|
||||
point.setUpdate_time(DateUtil.now());
|
||||
pointService.updateById(point);
|
||||
}
|
||||
|
||||
/**
|
||||
* 清空点位
|
||||
|
||||
@@ -199,6 +199,9 @@ public class TaskUtils {
|
||||
if (ObjectUtil.isEmpty(acsVehicleCode) || acsVehicleCode.equals(GeneralDefinition.NO)) {
|
||||
return null;
|
||||
}
|
||||
if (acsVehicleCode.startsWith("M")) {
|
||||
return acsVehicleCode;
|
||||
}
|
||||
return String.format("%04d", Integer.parseInt(acsVehicleCode));
|
||||
}
|
||||
|
||||
|
||||
791
lms/nladmin-ui/src/views/wms/pdm/workerorder/pressedOrder.vue
Normal file
791
lms/nladmin-ui/src/views/wms/pdm/workerorder/pressedOrder.vue
Normal file
@@ -0,0 +1,791 @@
|
||||
<template>
|
||||
<div v-loading.fullscreen.lock="fullscreenLoading" class="app-container">
|
||||
<!--工具栏-->
|
||||
<div class="head-container">
|
||||
<div v-if="crud.props.searchToggle">
|
||||
<!-- 搜索 -->
|
||||
<el-form
|
||||
:inline="true"
|
||||
class="demo-form-inline"
|
||||
label-position="right"
|
||||
label-width="80px"
|
||||
label-suffix=":"
|
||||
>
|
||||
<el-form-item label="工单编号">
|
||||
<el-input
|
||||
v-model="query.workorder_code"
|
||||
clearable
|
||||
placeholder="工单编号"
|
||||
class="filter-item"
|
||||
@keyup.enter.native="crud.toQuery"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item label="设备编码">
|
||||
<el-input
|
||||
v-model="query.point_code"
|
||||
clearable
|
||||
placeholder="设备编码"
|
||||
class="filter-item"
|
||||
@keyup.enter.native="crud.toQuery"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item label="创建时间">
|
||||
<el-date-picker
|
||||
v-model="query.createTime"
|
||||
type="datetimerange"
|
||||
value-format="yyyy-MM-dd HH:mm:ss"
|
||||
range-separator="至"
|
||||
start-placeholder="开始日期"
|
||||
end-placeholder="结束日期"
|
||||
@change="crud.toQuery"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item label="工单状态">
|
||||
<el-select
|
||||
v-model="query.workorder_status"
|
||||
multiple
|
||||
placeholder="工单状态"
|
||||
class="filter-item"
|
||||
clearable
|
||||
@change="handOrderStatus"
|
||||
>
|
||||
<el-option
|
||||
v-for="item in dict.pdm_workorder_status"
|
||||
:label="item.label"
|
||||
:value="item.value"
|
||||
/>
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<rrOperation :crud="crud" />
|
||||
</el-form>
|
||||
</div>
|
||||
<!--如果想在工具栏加入更多按钮,可以使用插槽方式, slot = 'left' or 'right'-->
|
||||
<crudOperation :permission="permission">
|
||||
<el-button
|
||||
slot="right"
|
||||
class="filter-item"
|
||||
type="success"
|
||||
icon="el-icon-position"
|
||||
size="mini"
|
||||
:disabled="!(crud.selections[0]) || crud.selections[1]"
|
||||
@click="submits(crud.selections[0])"
|
||||
>
|
||||
开工
|
||||
</el-button>
|
||||
<el-button
|
||||
slot="right"
|
||||
class="filter-item"
|
||||
type="success"
|
||||
icon="el-icon-position"
|
||||
size="mini"
|
||||
@click="synchronize()"
|
||||
>
|
||||
同步
|
||||
</el-button>
|
||||
<el-button
|
||||
slot="right"
|
||||
class="filter-item"
|
||||
type="danger"
|
||||
icon="el-icon-position"
|
||||
size="mini"
|
||||
:disabled="!(crud.selections[0]) || crud.selections[1]"
|
||||
@click="forceFinish(crud.selections[0])"
|
||||
>
|
||||
强制完工
|
||||
</el-button>
|
||||
</crudOperation>
|
||||
<!--表单组件-->
|
||||
<el-dialog
|
||||
:close-on-click-modal="false"
|
||||
:before-close="crud.cancelCU"
|
||||
:visible.sync="crud.status.cu > 0"
|
||||
:title="crud.status.title"
|
||||
width="820px"
|
||||
>
|
||||
<el-form
|
||||
ref="form"
|
||||
style="border: 1px solid #cfe0df;margin-top: 10px;padding-top: 10px;"
|
||||
:inline="true"
|
||||
:model="form"
|
||||
:rules="rules"
|
||||
size="mini"
|
||||
label-width="135px"
|
||||
label-suffix=":"
|
||||
>
|
||||
<el-form-item label="所属工序" prop="region_code">
|
||||
<el-select
|
||||
v-model="form.region_code"
|
||||
filterable
|
||||
placeholder="请选择"
|
||||
style="width: 240px;"
|
||||
@change="setRegionName"
|
||||
disabled
|
||||
>
|
||||
<el-option
|
||||
v-for="item in regionList"
|
||||
:key="item.region_code"
|
||||
:label="item.region_code"
|
||||
:value="item.region_code"
|
||||
>
|
||||
<span style="float: left">{{ item.region_name }}</span>
|
||||
<span style="float: right; color: #8492a6; font-size: 13px">{{ item.region_code }}</span>
|
||||
</el-option>
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item label="工序名称">
|
||||
<el-input v-model="form.region_name" style="width: 240px;" disabled />
|
||||
</el-form-item>
|
||||
<el-form-item v-if="false" label="所属车间">
|
||||
<el-select
|
||||
v-model="form.workshop_code"
|
||||
placeholder="请选择"
|
||||
style="width: 240px;"
|
||||
>
|
||||
<el-option
|
||||
v-for="item in workShopList"
|
||||
:label="item.workshop_name"
|
||||
:value="item.workshop_code"
|
||||
/>
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item label="物料名称" prop="material_name">
|
||||
<el-input v-model="form.material_name" style="width: 240px;" @focus="getMaterial(1)" />
|
||||
</el-form-item>
|
||||
<el-form-item label="物料编码">
|
||||
<el-input v-model="form.material_code" style="width: 240px;" disabled />
|
||||
</el-form-item>
|
||||
<el-form-item label="物料规格">
|
||||
<el-input v-model="form.material_spec" style="width: 240px;" disabled />
|
||||
</el-form-item>
|
||||
<el-form-item label="计划数量" prop="plan_qty">
|
||||
<el-input-number
|
||||
v-model.number="form.plan_qty"
|
||||
:disabled="form.region_code === 'FJ'"
|
||||
:min="0"
|
||||
style="width: 240px;"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item label="半成品编码" prop="material_name">
|
||||
<el-input v-model="form.half_material_code" style="width: 240px;" disabled />
|
||||
</el-form-item>
|
||||
<el-form-item label="原料编码">
|
||||
<el-input v-model="form.raw_material_code" style="width: 240px;" disabled />
|
||||
</el-form-item>
|
||||
<el-form-item label="计划开始时间" prop="planproducestart_date">
|
||||
<el-date-picker
|
||||
v-model="form.planproducestart_date"
|
||||
value-format="yyyy-MM-dd HH:mm:ss"
|
||||
type="datetime"
|
||||
style="width: 240px;"
|
||||
placeholder="选择日期时间"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item label="计划结束时间" prop="planproduceend_date">
|
||||
<el-date-picker
|
||||
v-model="form.planproduceend_date"
|
||||
value-format="yyyy-MM-dd HH:mm:ss"
|
||||
type="datetime"
|
||||
style="width: 240px;"
|
||||
placeholder="选择日期时间"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item v-if="crud.status.edit" label="实际开始时间">
|
||||
<el-date-picker
|
||||
v-model="form.realproducestart_date"
|
||||
value-format="yyyy-MM-dd HH:mm:ss"
|
||||
type="datetime"
|
||||
style="width: 240px;"
|
||||
placeholder="选择日期时间"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item v-if="crud.status.edit" label="实际结束时间">
|
||||
<el-date-picker
|
||||
v-model="form.realproduceend_date"
|
||||
value-format="yyyy-MM-dd HH:mm:ss"
|
||||
type="datetime"
|
||||
style="width: 240px;"
|
||||
placeholder="选择日期时间"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item label="设备编码" prop="point_code">
|
||||
<el-select
|
||||
v-model="form.point_code"
|
||||
filterable
|
||||
placeholder="请选择"
|
||||
style="width: 240px;"
|
||||
@change="setPointName"
|
||||
>
|
||||
<el-option
|
||||
v-for="item in pointList"
|
||||
:key="item.point_code"
|
||||
:label="item.point_code"
|
||||
:value="item.point_code"
|
||||
>
|
||||
<span style="float: left">{{ item.point_name }}</span>
|
||||
<span style="float: right; color: #8492a6; font-size: 13px">{{ item.point_code }}</span>
|
||||
</el-option>
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item label="设备名称">
|
||||
<el-input v-model="form.point_name" style="width: 240px;" disabled />
|
||||
</el-form-item>
|
||||
<!-- <el-form-item v-if="form.region_code === 'FJ'" label="订单号">-->
|
||||
<!-- <el-input-->
|
||||
<!-- v-model="form.order_no"-->
|
||||
<!-- :disabled="form.material_code===null"-->
|
||||
<!-- style="width: 240px;"-->
|
||||
<!-- @focus="getProductionOrder(form.material_id)"-->
|
||||
<!-- />-->
|
||||
<!-- </el-form-item>-->
|
||||
<!-- <el-form-item v-if="form.region_code === 'FJ'" label="客户编码">-->
|
||||
<!-- <el-select v-model="form.custer_no" clearable filterable placeholder="请选择" style="width: 240px;">-->
|
||||
<!-- <el-option-->
|
||||
<!-- v-for="item in custerList"-->
|
||||
<!-- :key="item.custer_NO"-->
|
||||
<!-- :label="item.custer_NAME"-->
|
||||
<!-- :value="item.custer_NO"-->
|
||||
<!-- >-->
|
||||
<!-- <span style="float: left">{{ item.custer_NO }}</span>-->
|
||||
<!-- <span style="float: right; color: #8492a6; font-size: 13px">{{ item.custer_NAME }}</span>-->
|
||||
<!-- </el-option>-->
|
||||
<!-- </el-select>-->
|
||||
<!-- </el-form-item>-->
|
||||
<el-form-item label="静置时间(分钟)" prop="standing_time">
|
||||
<el-input-number
|
||||
v-model.number="form.standing_time"
|
||||
:min="0"
|
||||
:max="999"
|
||||
style="width: 240px;"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item v-if="crud.status.edit" label="实际数量" prop="real_qty">
|
||||
<el-input-number
|
||||
v-model.number="form.real_qty"
|
||||
:min="0"
|
||||
style="width: 240px;"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item v-if="form.region_code === 'YZ'" label="小料盅比例(%)">
|
||||
<el-input-number
|
||||
v-model.number="form.material_ratio"
|
||||
:min="0"
|
||||
style="width: 240px;"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item v-if="form.region_code === 'YZ'" label="所需泥料重量">
|
||||
<el-input-number
|
||||
v-model.number="form.plan_weight"
|
||||
:min="0"
|
||||
style="width: 240px;"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item v-if="form.region_code === 'FJ'" label="计划拆数">
|
||||
<el-input-number
|
||||
v-model.number="form.plan_weight"
|
||||
:min="0"
|
||||
style="width: 240px;"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item v-if="crud.status.edit && form.region_code === 'YZ'" label="实际重量">
|
||||
<el-input-number
|
||||
v-model.number="form.real_weight"
|
||||
:min="0"
|
||||
style="width: 240px;"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item v-if="crud.status.edit && form.region_code === 'FJ'" label="实际拆数">
|
||||
<el-input-number
|
||||
v-model.number="form.real_weight"
|
||||
:min="0"
|
||||
style="width: 240px;"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item label="载具类型">
|
||||
<el-select
|
||||
v-model="form.vehicle_type"
|
||||
clearable
|
||||
size="mini"
|
||||
placeholder="请选择"
|
||||
class="filter-item"
|
||||
style="width: 240px;"
|
||||
>
|
||||
<el-option
|
||||
v-for="item in dict.vehicle_type"
|
||||
:label="item.label"
|
||||
:value="item.value"
|
||||
:disabled="item.value !== 'GTP'"
|
||||
/>
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item v-if="form.region_code === 'YZ'" label="分拣拆码类型">
|
||||
<el-select
|
||||
v-model="form.workorder_type"
|
||||
clearable
|
||||
size="mini"
|
||||
placeholder="请选择"
|
||||
class="filter-item"
|
||||
style="width: 240px;"
|
||||
>
|
||||
<el-option
|
||||
v-for="item in dict.order_type"
|
||||
:label="item.label"
|
||||
:value="item.value"
|
||||
/>
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item v-if="form.region_code === 'YZ'" label="优先级">
|
||||
<el-input-number
|
||||
v-model.number="form.priority"
|
||||
:min="0"
|
||||
:max="99"
|
||||
style="width: 240px;"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item v-if="false" label="工单类型" prop="workorder_type">
|
||||
<el-input v-model="form.workorder_type" style="width: 240px;" />
|
||||
</el-form-item>
|
||||
<el-form-item label="是否自动搬运" prop="is_needmove">
|
||||
<el-radio-group v-model="form.is_needmove" style="width: 240px">
|
||||
<el-radio :label="true">是</el-radio>
|
||||
<el-radio :label="false">否</el-radio>
|
||||
</el-radio-group>
|
||||
</el-form-item>
|
||||
<el-form-item label="是否加急" prop="is_needmove">
|
||||
<el-radio-group v-model="form.is_urgent" style="width: 240px">
|
||||
<el-radio :label="true">是</el-radio>
|
||||
<el-radio :label="false">否</el-radio>
|
||||
</el-radio-group>
|
||||
</el-form-item>
|
||||
</el-form>
|
||||
<div slot="footer" class="dialog-footer">
|
||||
<el-button type="text" @click="crud.cancelCU">取消</el-button>
|
||||
<el-button :loading="crud.cu === 2" type="primary" @click="crud.submitCU">确认</el-button>
|
||||
</div>
|
||||
</el-dialog>
|
||||
<!--表格渲染-->
|
||||
<el-table
|
||||
ref="table"
|
||||
v-loading="crud.loading"
|
||||
:data="crud.data"
|
||||
size="mini"
|
||||
style="width: 100%;"
|
||||
@selection-change="crud.selectionChangeHandler"
|
||||
>
|
||||
<el-table-column type="selection" width="55" />
|
||||
<el-table-column
|
||||
prop="workorder_code"
|
||||
label="工单编号"
|
||||
:min-width="flexWidth('workorder_code',crud.data,'工单编号')"
|
||||
/>
|
||||
<el-table-column
|
||||
prop="workorder_status"
|
||||
label="工单状态"
|
||||
:min-width="flexWidth('workorder_status',crud.data,'工单状态')"
|
||||
>
|
||||
<template slot-scope="scope">
|
||||
{{ dict.label.pdm_workorder_status[scope.row.workorder_status] }}
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column prop="plan_qty" label="计划数量" :min-width="flexWidth('plan_qty',crud.data,'计划数量')" />
|
||||
<el-table-column prop="real_qty" label="实际数量" :min-width="flexWidth('real_qty',crud.data,'实际数量')" />
|
||||
<el-table-column prop="plan_weight" label="计划重量" :min-width="flexWidth('plan_weight',crud.data,'计划数量')">
|
||||
<template slot-scope="scope">
|
||||
<el-tooltip
|
||||
class="item"
|
||||
effect="dark"
|
||||
content="分拣工单的重量是砖块数"
|
||||
placement="right"
|
||||
>
|
||||
<div>{{ scope.row.plan_weight }}</div>
|
||||
</el-tooltip>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column prop="real_weight" label="实际重量" :min-width="flexWidth('real_weight',crud.data,'实际数量')" />
|
||||
<!-- <el-table-column prop="region_code" label="区域编码" :min-width="flexWidth('region_code',crud.data,'区域编码')" />-->
|
||||
<el-table-column
|
||||
prop="region_name"
|
||||
label="区域名称"
|
||||
:min-width="flexWidth('region_name',crud.data,'区域名称')"
|
||||
/>
|
||||
<el-table-column prop="point_code" label="设备编码" :min-width="flexWidth('point_code',crud.data,'设备编码')" />
|
||||
<el-table-column prop="point_name" label="设备名称" :min-width="flexWidth('point_name',crud.data,'设备名称')" />
|
||||
<el-table-column
|
||||
prop="material_code"
|
||||
label="成品编码"
|
||||
:min-width="flexWidth('material_name',crud.data,'物料标识')"
|
||||
/>
|
||||
<el-table-column
|
||||
prop="half_material_code"
|
||||
label="半成品编码"
|
||||
:min-width="flexWidth('half_material_code',crud.data,'半成品编码')"
|
||||
/>
|
||||
<el-table-column
|
||||
prop="raw_material_code"
|
||||
label="泥料编码"
|
||||
:min-width="flexWidth('raw_material_code',crud.data,'物料标识')"
|
||||
/>
|
||||
<el-table-column
|
||||
prop="material_name"
|
||||
label="物料名称"
|
||||
:min-width="flexWidth('material_name',crud.data,'物料标识')"
|
||||
/>
|
||||
<el-table-column
|
||||
prop="material_spec"
|
||||
label="物料规格"
|
||||
:min-width="flexWidth('material_spec',crud.data,'物料标识')"
|
||||
/>
|
||||
<el-table-column
|
||||
prop="vehicle_type"
|
||||
label="载具类型"
|
||||
:min-width="flexWidth('vehicle_type',crud.data,'载具类型', 20)"
|
||||
>
|
||||
<template slot-scope="scope">
|
||||
{{ dict.label.vehicle_type[scope.row.vehicle_type] }}
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column
|
||||
prop="produce_date"
|
||||
label="生产日期"
|
||||
:min-width="flexWidth('produce_date',crud.data,'生产日期')"
|
||||
/>
|
||||
<el-table-column
|
||||
prop="planproducestart_date"
|
||||
label="计划开始时间"
|
||||
:min-width="flexWidth('planproducestart_date',crud.data,'计划开始时间')"
|
||||
/>
|
||||
<el-table-column
|
||||
prop="planproduceend_date"
|
||||
label="计划结束时间"
|
||||
:min-width="flexWidth('planproduceend_date',crud.data,'计划结束时间')"
|
||||
/>
|
||||
<el-table-column
|
||||
prop="realproducestart_date"
|
||||
label="实际开始时间"
|
||||
:min-width="flexWidth('realproducestart_date',crud.data,'实际开始时间')"
|
||||
/>
|
||||
<el-table-column
|
||||
prop="realproduceend_date"
|
||||
label="实际结束时间"
|
||||
:min-width="flexWidth('realproduceend_date',crud.data,'实际结束时间')"
|
||||
/>
|
||||
<el-table-column
|
||||
prop="standing_time"
|
||||
label="静置时间(分钟)"
|
||||
:min-width="flexWidth('standing_time',crud.data,'静置时间(分钟)')"
|
||||
/>
|
||||
<el-table-column
|
||||
prop="is_needmove"
|
||||
label="是否自动搬运"
|
||||
:min-width="flexWidth('is_needmove',crud.data,'是否自动搬运')"
|
||||
>
|
||||
<template slot-scope="scope">
|
||||
{{ scope.row.is_needmove ? '是' : '否' }}
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column prop="is_urgent" label="是否加急" :min-width="flexWidth('is_urgent',crud.data,'是否加急')">
|
||||
<template slot-scope="scope">
|
||||
{{ scope.row.is_urgent ? '是' : '否' }}
|
||||
</template>
|
||||
</el-table-column>
|
||||
<!-- <el-table-column prop="workorder_type" label="工单类型" :min-width="flexWidth('workorder_type',crud.data,'工单类型')" />-->
|
||||
<!--<el-table-column
|
||||
prop="passback_status"
|
||||
label="回传MES状态"
|
||||
:min-width="flexWidth('passback_status',crud.data,'回传MES状态')"
|
||||
/>-->
|
||||
<!-- <el-table-column prop="workshop_code" label="车间编码" :min-width="flexWidth('workshop_code',crud.data,'车间编码')" />-->
|
||||
<el-table-column prop="create_name" label="创建人" :min-width="flexWidth('create_name',crud.data,'创建人')" />
|
||||
<el-table-column
|
||||
prop="create_time"
|
||||
label="创建时间"
|
||||
:min-width="flexWidth('create_time',crud.data,'创建时间')"
|
||||
/>
|
||||
<el-table-column prop="update_name" label="修改人" :min-width="flexWidth('update_name',crud.data,'修改人')" />
|
||||
<el-table-column
|
||||
prop="update_time"
|
||||
label="修改时间"
|
||||
:min-width="flexWidth('update_time',crud.data,'修改时间')"
|
||||
/>
|
||||
<el-table-column v-permission="[]" label="操作" width="120px" align="center" fixed="right">
|
||||
<template slot-scope="scope">
|
||||
<udOperation
|
||||
:data="scope.row"
|
||||
:permission="permission"
|
||||
/>
|
||||
</template>
|
||||
</el-table-column>
|
||||
</el-table>
|
||||
<!--分页组件-->
|
||||
<pagination />
|
||||
</div>
|
||||
<MaterialDialog :dialog-show.sync="materialDialog" :flag="flag" @tableChanged="tableChanged" />
|
||||
<!-- <ProductionOrder :dialog-show.sync="orderDialog" :material-code="materialCode" @recordMesOrder="recordMesOrder" />-->
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
import crudPdmBdWorkorder from './pdmBdWorkorder'
|
||||
import crudSchBaseRegion from '@/views/wms/sch/region/schBaseRegion'
|
||||
import crudSchBasePoint from '@/views/wms/sch/point/schBasePoint'
|
||||
import CRUD, { crud, form, header, presenter } from '@crud/crud'
|
||||
import rrOperation from '@crud/RR.operation'
|
||||
import crudOperation from '@crud/CRUD.operation'
|
||||
import udOperation from '@crud/UD.operation'
|
||||
import pagination from '@crud/Pagination'
|
||||
import crudMdBaseWorkShop from '@/views/wms/basedata/workshop/mdBaseWorkshop'
|
||||
import MaterialDialog from '@/views/wms/sch/group/MaterialDialog.vue'
|
||||
import item from '@/layout/components/Sidebar/Item.vue'
|
||||
// import ProductionOrder from '@/views/wms/pdm/workerorder/ProductionOrder.vue'
|
||||
|
||||
const defaultForm = {
|
||||
workorder_id: null,
|
||||
workorder_code: null,
|
||||
plan_qty: null,
|
||||
real_qty: null,
|
||||
material_id: null,
|
||||
half_material_code: null,
|
||||
raw_material_code: null,
|
||||
vehicle_type: 'GTP',
|
||||
planproducestart_date: null,
|
||||
planproduceend_date: null,
|
||||
realproducestart_date: null,
|
||||
realproduceend_date: null,
|
||||
material_spec: null,
|
||||
material_code: null,
|
||||
material_name: null,
|
||||
standing_time: null,
|
||||
point_code: null,
|
||||
point_name: null,
|
||||
region_code: 'YZ',
|
||||
region_name: null,
|
||||
workorder_status: null,
|
||||
is_needmove: true,
|
||||
workorder_type: '1',
|
||||
passback_status: null,
|
||||
workshop_code: null,
|
||||
ext_id: null,
|
||||
is_delete: false,
|
||||
is_urgent: false,
|
||||
order_no: null,
|
||||
custer_no: null,
|
||||
pack_method: null,
|
||||
order_subnum: 0,
|
||||
real_weight: 0,
|
||||
plan_weight: 0,
|
||||
guadansum: 0,
|
||||
ext_data: 0,
|
||||
material_ratio: 0,
|
||||
priority: 1,
|
||||
show: false
|
||||
}
|
||||
export default {
|
||||
name: 'PressedOrder',
|
||||
dicts: ['vehicle_type', 'pdm_workorder_status', 'order_type'],
|
||||
components: { MaterialDialog, pagination, crudOperation, rrOperation, udOperation },
|
||||
mixins: [presenter(), header(), form(defaultForm), crud()],
|
||||
cruds() {
|
||||
return CRUD({
|
||||
title: '压制工单',
|
||||
url: 'api/pdmBdWorkorder',
|
||||
idField: 'workorder_id',
|
||||
sort: 'workorder_id,desc',
|
||||
query: {
|
||||
region_code: 'YZ'
|
||||
},
|
||||
crudMethod: { ...crudPdmBdWorkorder },
|
||||
optShow: {
|
||||
add: true,
|
||||
edit: true,
|
||||
del: false,
|
||||
download: false,
|
||||
reset: true
|
||||
}
|
||||
})
|
||||
},
|
||||
data() {
|
||||
return {
|
||||
permission: {},
|
||||
rules: {
|
||||
material_code: [
|
||||
{ required: true, message: '物料不能为空', trigger: 'blur' }
|
||||
],
|
||||
plan_qty: [
|
||||
{ required: true, message: '计划数量不能为空', trigger: 'blur' }
|
||||
],
|
||||
planproducestart_date: [
|
||||
{ required: true, message: '计划开始不能为空', trigger: 'change' }
|
||||
],
|
||||
planproduceend_date: [
|
||||
{ required: true, message: '计划结束不能为空', trigger: 'change' }
|
||||
],
|
||||
point_code: [
|
||||
{ required: true, message: '设备编码不能为空', trigger: 'change' }
|
||||
],
|
||||
region_code: [
|
||||
{ required: true, message: '区域编码不能为空', trigger: 'change' }
|
||||
],
|
||||
workorder_type: [
|
||||
{ required: true, message: '工单类型不能为空', trigger: 'blur' }
|
||||
]
|
||||
},
|
||||
queryTypeOptions: [
|
||||
{ key: 'workorder_code', display_name: '工单编号' },
|
||||
{ key: 'point_code', display_name: '设备编码' }
|
||||
],
|
||||
workShopList: [],
|
||||
regionList: [],
|
||||
pointList: [],
|
||||
custerList: [],
|
||||
regionCodeParam: null,
|
||||
materialDialog: false,
|
||||
orderDialog: false,
|
||||
fullscreenLoading: false,
|
||||
materialCode: null,
|
||||
flag: 1
|
||||
}
|
||||
},
|
||||
created() {
|
||||
this.getWorkShopList()
|
||||
this.getRegionList()
|
||||
// this.getCuster()
|
||||
},
|
||||
methods: {
|
||||
item() {
|
||||
return item
|
||||
},
|
||||
// 钩子:在获取表格数据之前执行,false 则代表不获取数据
|
||||
[CRUD.HOOK.beforeRefresh]() {
|
||||
return true
|
||||
},
|
||||
[CRUD.HOOK.beforeToCU]() {
|
||||
this.setRegionName('YZ')
|
||||
},
|
||||
getWorkShopList() { // 获取车间列表
|
||||
crudMdBaseWorkShop.getWorkShopList().then(res => {
|
||||
this.workShopList = res
|
||||
})
|
||||
},
|
||||
getRegionList() { // 获取区域列表
|
||||
const param = {
|
||||
is_has_workder: true
|
||||
}
|
||||
crudSchBaseRegion.getRegionList(param).then(res => {
|
||||
this.regionList = res
|
||||
})
|
||||
},
|
||||
getCuster() { // 获取客户信息
|
||||
crudPdmBdWorkorder.getCuster().then(res => {
|
||||
this.custerList = res
|
||||
})
|
||||
},
|
||||
getPointList() { // 获取点位列表
|
||||
if (this.regionCodeParam) {
|
||||
const param = {
|
||||
region_code: this.regionCodeParam
|
||||
}
|
||||
crudSchBasePoint.getPointList(param).then(res => {
|
||||
this.pointList = res
|
||||
this.regionCodeParam = null
|
||||
})
|
||||
}
|
||||
},
|
||||
getMaterial(flag) {
|
||||
this.materialDialog = true
|
||||
this.flag = flag
|
||||
},
|
||||
getProductionOrder(code) {
|
||||
this.orderDialog = true
|
||||
this.materialCode = code
|
||||
},
|
||||
tableChanged(row, flag) {
|
||||
if (flag === 1) {
|
||||
this.form.material_name = row.material_name
|
||||
this.form.material_id = row.material_id
|
||||
this.form.material_spec = row.material_spec
|
||||
this.form.material_code = row.material_code
|
||||
this.form.half_material_code = row.half_material_code
|
||||
this.form.raw_material_code = row.raw_material_code
|
||||
this.form.plan_weight = row.total_material_qty == null ? 0 : row.total_material_qty
|
||||
this.form.standing_time = row.standing_time == null ? 0 : row.standing_time
|
||||
} else {
|
||||
this.form.raw_material_name = row.material_name
|
||||
this.form.raw_material_id = row.material_id
|
||||
this.form.raw_material_code = row.material_code
|
||||
}
|
||||
this.form.pack_method = row.pack_method
|
||||
this.form.standing_time = row.standing_time
|
||||
const result = Object.keys(this.dict.label.vehicle_type).find(key => this.dict.label.vehicle_type[key] === row.pack_palletspec)
|
||||
if (result) {
|
||||
this.form.vehicle_type = result
|
||||
}
|
||||
},
|
||||
clearRecordMesOrder() {
|
||||
this.form.order_no = null
|
||||
this.form.order_subnum = 0
|
||||
this.form.guadansum = 0
|
||||
},
|
||||
recordMesOrder(row) { // 操作mes工单
|
||||
this.clearRecordMesOrder()
|
||||
this.form.order_no = row.forder_NO
|
||||
this.form.order_subnum = row.forder_SUBNUM
|
||||
this.form.guadansum = row.guadansum
|
||||
},
|
||||
setRegionName(data) {
|
||||
// 清空
|
||||
this.regionCodeParam = data
|
||||
var region = this.regionList.find(item => item.region_code === data)
|
||||
this.form.region_name = region.region_name
|
||||
this.getPointList()
|
||||
},
|
||||
setPointName(data) {
|
||||
var point = this.pointList.find(item => item.point_code === data)
|
||||
this.form.point_name = point.point_name
|
||||
},
|
||||
handOrderStatus(value) {
|
||||
this.crud.query.more_order_status = null
|
||||
if (value) {
|
||||
this.crud.query.more_order_status = value.toString()
|
||||
}
|
||||
this.crud.toQuery()
|
||||
},
|
||||
// 下发
|
||||
submits(row) {
|
||||
this.fullscreenLoading = true
|
||||
crudPdmBdWorkorder.submits(row).then(res => {
|
||||
this.crud.notify('下发成功', CRUD.NOTIFICATION_TYPE.SUCCESS)
|
||||
this.crud.toQuery()
|
||||
}).catch(() => {
|
||||
this.fullscreenLoading = false
|
||||
}).finally(() => {
|
||||
this.fullscreenLoading = false
|
||||
})
|
||||
},
|
||||
synchronize() {
|
||||
this.fullscreenLoading = true
|
||||
crudPdmBdWorkorder.orderSynchronize(this.crud.query).then(res => {
|
||||
this.fullscreenLoading = false
|
||||
this.crud.notify('同步成功!', CRUD.NOTIFICATION_TYPE.SUCCESS)
|
||||
}).catch(() => {
|
||||
this.fullscreenLoading = false
|
||||
}).finally(() => {
|
||||
this.fullscreenLoading = false
|
||||
})
|
||||
},
|
||||
forceFinish(row) {
|
||||
this.fullscreenLoading = true
|
||||
crudPdmBdWorkorder.forceFinish(row).then(res => {
|
||||
this.crud.notify('报工完成', CRUD.NOTIFICATION_TYPE.SUCCESS)
|
||||
this.crud.toQuery()
|
||||
}).catch(() => {
|
||||
this.fullscreenLoading = false
|
||||
}).finally(() => {
|
||||
this.fullscreenLoading = false
|
||||
})
|
||||
}
|
||||
}
|
||||
}
|
||||
</script>
|
||||
|
||||
<style scoped>
|
||||
|
||||
</style>
|
||||
784
lms/nladmin-ui/src/views/wms/pdm/workerorder/sortedOrder.vue
Normal file
784
lms/nladmin-ui/src/views/wms/pdm/workerorder/sortedOrder.vue
Normal file
@@ -0,0 +1,784 @@
|
||||
<template>
|
||||
<div v-loading.fullscreen.lock="fullscreenLoading" class="app-container">
|
||||
<!--工具栏-->
|
||||
<div class="head-container">
|
||||
<div v-if="crud.props.searchToggle">
|
||||
<!-- 搜索 -->
|
||||
<el-form
|
||||
:inline="true"
|
||||
class="demo-form-inline"
|
||||
label-position="right"
|
||||
label-width="80px"
|
||||
label-suffix=":"
|
||||
>
|
||||
<el-form-item label="工单编号">
|
||||
<el-input
|
||||
v-model="query.workorder_code"
|
||||
clearable
|
||||
placeholder="工单编号"
|
||||
class="filter-item"
|
||||
@keyup.enter.native="crud.toQuery"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item label="设备编码">
|
||||
<el-input
|
||||
v-model="query.point_code"
|
||||
clearable
|
||||
placeholder="设备编码"
|
||||
class="filter-item"
|
||||
@keyup.enter.native="crud.toQuery"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item label="创建时间">
|
||||
<el-date-picker
|
||||
v-model="query.createTime"
|
||||
type="datetimerange"
|
||||
value-format="yyyy-MM-dd HH:mm:ss"
|
||||
range-separator="至"
|
||||
start-placeholder="开始日期"
|
||||
end-placeholder="结束日期"
|
||||
@change="crud.toQuery"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item label="工单状态">
|
||||
<el-select
|
||||
v-model="query.workorder_status"
|
||||
multiple
|
||||
placeholder="工单状态"
|
||||
class="filter-item"
|
||||
clearable
|
||||
@change="handOrderStatus"
|
||||
>
|
||||
<el-option
|
||||
v-for="item in dict.pdm_workorder_status"
|
||||
:label="item.label"
|
||||
:value="item.value"
|
||||
/>
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<rrOperation :crud="crud" />
|
||||
</el-form>
|
||||
</div>
|
||||
<!--如果想在工具栏加入更多按钮,可以使用插槽方式, slot = 'left' or 'right'-->
|
||||
<crudOperation :permission="permission">
|
||||
<el-button
|
||||
slot="right"
|
||||
class="filter-item"
|
||||
type="success"
|
||||
icon="el-icon-position"
|
||||
size="mini"
|
||||
:disabled="!(crud.selections[0]) || crud.selections[1]"
|
||||
@click="submits(crud.selections[0])"
|
||||
>
|
||||
开工
|
||||
</el-button>
|
||||
<el-button
|
||||
slot="right"
|
||||
class="filter-item"
|
||||
type="success"
|
||||
icon="el-icon-position"
|
||||
size="mini"
|
||||
@click="synchronize()"
|
||||
>
|
||||
同步
|
||||
</el-button>
|
||||
<el-button
|
||||
slot="right"
|
||||
class="filter-item"
|
||||
type="danger"
|
||||
icon="el-icon-position"
|
||||
size="mini"
|
||||
:disabled="!(crud.selections[0]) || crud.selections[1]"
|
||||
@click="forceFinish(crud.selections[0])"
|
||||
>
|
||||
强制完工
|
||||
</el-button>
|
||||
</crudOperation>
|
||||
<!--表单组件-->
|
||||
<el-dialog
|
||||
:close-on-click-modal="false"
|
||||
:before-close="crud.cancelCU"
|
||||
:visible.sync="crud.status.cu > 0"
|
||||
:title="crud.status.title"
|
||||
width="820px"
|
||||
>
|
||||
<el-form
|
||||
ref="form"
|
||||
style="border: 1px solid #cfe0df;margin-top: 10px;padding-top: 10px;"
|
||||
:inline="true"
|
||||
:model="form"
|
||||
:rules="rules"
|
||||
size="mini"
|
||||
label-width="135px"
|
||||
label-suffix=":"
|
||||
>
|
||||
<el-form-item label="所属工序" prop="region_code">
|
||||
<el-select
|
||||
v-model="form.region_code"
|
||||
filterable
|
||||
placeholder="请选择"
|
||||
style="width: 240px;"
|
||||
@change="setRegionName"
|
||||
>
|
||||
<el-option
|
||||
v-for="item in regionList"
|
||||
:key="item.region_code"
|
||||
:label="item.region_code"
|
||||
:value="item.region_code"
|
||||
>
|
||||
<span style="float: left">{{ item.region_name }}</span>
|
||||
<span style="float: right; color: #8492a6; font-size: 13px">{{ item.region_code }}</span>
|
||||
</el-option>
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item label="工序名称">
|
||||
<el-input v-model="form.region_name" style="width: 240px;" disabled />
|
||||
</el-form-item>
|
||||
<el-form-item v-if="false" label="所属车间">
|
||||
<el-select
|
||||
v-model="form.workshop_code"
|
||||
placeholder="请选择"
|
||||
style="width: 240px;"
|
||||
>
|
||||
<el-option
|
||||
v-for="item in workShopList"
|
||||
:label="item.workshop_name"
|
||||
:value="item.workshop_code"
|
||||
/>
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item label="物料名称" prop="material_name">
|
||||
<el-input v-model="form.material_name" style="width: 240px;" @focus="getMaterial(1)" />
|
||||
</el-form-item>
|
||||
<el-form-item label="物料编码">
|
||||
<el-input v-model="form.material_code" style="width: 240px;" disabled />
|
||||
</el-form-item>
|
||||
<el-form-item label="物料规格">
|
||||
<el-input v-model="form.material_spec" style="width: 240px;" disabled />
|
||||
</el-form-item>
|
||||
<el-form-item v-if="form.region_code !== 'HL'" label="计划数量" prop="plan_qty">
|
||||
<el-input-number
|
||||
v-model.number="form.plan_qty"
|
||||
:disabled="form.region_code === 'FJ'"
|
||||
:min="0"
|
||||
style="width: 240px;"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item v-else label="计划重量">
|
||||
<el-input-number
|
||||
v-model.number="form.plan_weight"
|
||||
:min="0"
|
||||
style="width: 240px;"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item label="半成品编码" prop="material_name">
|
||||
<el-input v-model="form.half_material_code" style="width: 240px;" disabled />
|
||||
</el-form-item>
|
||||
<el-form-item label="原料编码">
|
||||
<el-input v-model="form.raw_material_code" style="width: 240px;" disabled />
|
||||
</el-form-item>
|
||||
<el-form-item label="计划开始时间" prop="planproducestart_date">
|
||||
<el-date-picker
|
||||
v-model="form.planproducestart_date"
|
||||
value-format="yyyy-MM-dd HH:mm:ss"
|
||||
type="datetime"
|
||||
style="width: 240px;"
|
||||
placeholder="选择日期时间"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item label="计划结束时间" prop="planproduceend_date">
|
||||
<el-date-picker
|
||||
v-model="form.planproduceend_date"
|
||||
value-format="yyyy-MM-dd HH:mm:ss"
|
||||
type="datetime"
|
||||
style="width: 240px;"
|
||||
placeholder="选择日期时间"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item v-if="crud.status.edit" label="实际开始时间">
|
||||
<el-date-picker
|
||||
v-model="form.realproducestart_date"
|
||||
value-format="yyyy-MM-dd HH:mm:ss"
|
||||
type="datetime"
|
||||
style="width: 240px;"
|
||||
placeholder="选择日期时间"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item v-if="crud.status.edit" label="实际结束时间">
|
||||
<el-date-picker
|
||||
v-model="form.realproduceend_date"
|
||||
value-format="yyyy-MM-dd HH:mm:ss"
|
||||
type="datetime"
|
||||
style="width: 240px;"
|
||||
placeholder="选择日期时间"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item label="设备编码" prop="point_code">
|
||||
<el-select
|
||||
v-model="form.point_code"
|
||||
filterable
|
||||
placeholder="请选择"
|
||||
style="width: 240px;"
|
||||
@change="setPointName"
|
||||
>
|
||||
<el-option
|
||||
v-for="item in pointList"
|
||||
:key="item.point_code"
|
||||
:label="item.point_code"
|
||||
:value="item.point_code"
|
||||
>
|
||||
<span style="float: left">{{ item.point_name }}</span>
|
||||
<span style="float: right; color: #8492a6; font-size: 13px">{{ item.point_code }}</span>
|
||||
</el-option>
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item label="设备名称">
|
||||
<el-input v-model="form.point_name" style="width: 240px;" disabled />
|
||||
</el-form-item>
|
||||
<!-- <el-form-item v-if="form.region_code === 'FJ'" label="订单号">-->
|
||||
<!-- <el-input-->
|
||||
<!-- v-model="form.order_no"-->
|
||||
<!-- :disabled="form.material_code===null"-->
|
||||
<!-- style="width: 240px;"-->
|
||||
<!-- @focus="getProductionOrder(form.material_id)"-->
|
||||
<!-- />-->
|
||||
<!-- </el-form-item>-->
|
||||
<!-- <el-form-item v-if="form.region_code === 'FJ'" label="客户编码">-->
|
||||
<!-- <el-select v-model="form.custer_no" clearable filterable placeholder="请选择" style="width: 240px;">-->
|
||||
<!-- <el-option-->
|
||||
<!-- v-for="item in custerList"-->
|
||||
<!-- :key="item.custer_NO"-->
|
||||
<!-- :label="item.custer_NAME"-->
|
||||
<!-- :value="item.custer_NO"-->
|
||||
<!-- >-->
|
||||
<!-- <span style="float: left">{{ item.custer_NO }}</span>-->
|
||||
<!-- <span style="float: right; color: #8492a6; font-size: 13px">{{ item.custer_NAME }}</span>-->
|
||||
<!-- </el-option>-->
|
||||
<!-- </el-select>-->
|
||||
<!-- </el-form-item>-->
|
||||
<!-- <el-form-item label="静置时间(分钟)" prop="standing_time">-->
|
||||
<!-- <el-input-number-->
|
||||
<!-- v-model.number="form.standing_time"-->
|
||||
<!-- :min="0"-->
|
||||
<!-- :max="999"-->
|
||||
<!-- style="width: 240px;"-->
|
||||
<!-- />-->
|
||||
<!-- </el-form-item>-->
|
||||
<el-form-item v-if="crud.status.edit" label="实际数量" prop="real_qty">
|
||||
<el-input-number
|
||||
v-model.number="form.real_qty"
|
||||
:min="0"
|
||||
style="width: 240px;"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item v-if="form.region_code === 'YZ'" label="小料盅比例">
|
||||
<el-input-number
|
||||
v-model.number="form.material_ratio"
|
||||
:min="0"
|
||||
style="width: 240px;"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item v-if="form.region_code === 'YZ'" label="计划重量">
|
||||
<el-input-number
|
||||
v-model.number="form.plan_weight"
|
||||
:min="0"
|
||||
style="width: 240px;"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item v-if="form.region_code === 'FJ'" label="计划拆数">
|
||||
<el-input-number
|
||||
v-model.number="form.plan_weight"
|
||||
:min="0"
|
||||
style="width: 240px;"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item v-if="crud.status.edit && form.region_code === 'YZ'" label="实际重量">
|
||||
<el-input-number
|
||||
v-model.number="form.real_weight"
|
||||
:min="0"
|
||||
style="width: 240px;"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item v-if="crud.status.edit && form.region_code === 'FJ'" label="实际拆数">
|
||||
<el-input-number
|
||||
v-model.number="form.real_weight"
|
||||
:min="0"
|
||||
style="width: 240px;"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item label="载具类型">
|
||||
<el-select
|
||||
v-model="form.vehicle_type"
|
||||
clearable
|
||||
size="mini"
|
||||
placeholder="请选择"
|
||||
class="filter-item"
|
||||
style="width: 240px;"
|
||||
>
|
||||
<el-option
|
||||
v-for="item in dict.vehicle_type"
|
||||
:label="item.label"
|
||||
:value="item.value"
|
||||
/>
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item v-if="form.region_code === 'YZ'" label="工单类型">
|
||||
<el-select
|
||||
v-model="form.workorder_type"
|
||||
clearable
|
||||
size="mini"
|
||||
placeholder="请选择"
|
||||
class="filter-item"
|
||||
style="width: 240px;"
|
||||
>
|
||||
<el-option
|
||||
v-for="item in dict.order_type"
|
||||
:label="item.label"
|
||||
:value="item.value"
|
||||
/>
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item v-if="form.region_code === 'YZ'" label="优先级">
|
||||
<el-input-number
|
||||
v-model.number="form.priority"
|
||||
:min="0"
|
||||
:max="99"
|
||||
style="width: 240px;"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item v-if="false" label="工单类型" prop="workorder_type">
|
||||
<el-input v-model="form.workorder_type" style="width: 240px;" />
|
||||
</el-form-item>
|
||||
<el-form-item label="是否自动搬运" prop="is_needmove">
|
||||
<el-radio-group v-model="form.is_needmove" style="width: 240px">
|
||||
<el-radio :label="true">是</el-radio>
|
||||
<el-radio :label="false">否</el-radio>
|
||||
</el-radio-group>
|
||||
</el-form-item>
|
||||
<!-- <el-form-item label="是否加急" prop="is_needmove">-->
|
||||
<!-- <el-radio-group v-model="form.is_urgent" style="width: 240px">-->
|
||||
<!-- <el-radio :label="true">是</el-radio>-->
|
||||
<!-- <el-radio :label="false">否</el-radio>-->
|
||||
<!-- </el-radio-group>-->
|
||||
<!-- </el-form-item>-->
|
||||
</el-form>
|
||||
<div slot="footer" class="dialog-footer">
|
||||
<el-button type="text" @click="crud.cancelCU">取消</el-button>
|
||||
<el-button :loading="crud.cu === 2" type="primary" @click="crud.submitCU">确认</el-button>
|
||||
</div>
|
||||
</el-dialog>
|
||||
<!--表格渲染-->
|
||||
<el-table
|
||||
ref="table"
|
||||
v-loading="crud.loading"
|
||||
:data="crud.data"
|
||||
size="mini"
|
||||
style="width: 100%;"
|
||||
@selection-change="crud.selectionChangeHandler"
|
||||
>
|
||||
<el-table-column type="selection" width="55" />
|
||||
<el-table-column
|
||||
prop="workorder_code"
|
||||
label="工单编号"
|
||||
:min-width="flexWidth('workorder_code',crud.data,'工单编号')"
|
||||
/>
|
||||
<el-table-column
|
||||
prop="workorder_status"
|
||||
label="工单状态"
|
||||
:min-width="flexWidth('workorder_status',crud.data,'工单状态')"
|
||||
>
|
||||
<template slot-scope="scope">
|
||||
{{ dict.label.pdm_workorder_status[scope.row.workorder_status] }}
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column prop="plan_qty" label="计划空托" :min-width="flexWidth('plan_qty',crud.data,'计划数量')" />
|
||||
<el-table-column prop="real_qty" label="实际空托" :min-width="flexWidth('real_qty',crud.data,'实际数量')" />
|
||||
<el-table-column prop="plan_weight" label="计划拆数" :min-width="flexWidth('plan_weight',crud.data,'计划数量')" />
|
||||
<el-table-column prop="real_weight" label="实际拆数" :min-width="flexWidth('real_weight',crud.data,'实际数量')" />
|
||||
<!-- <el-table-column prop="region_code" label="区域编码" :min-width="flexWidth('region_code',crud.data,'区域编码')" />-->
|
||||
<el-table-column
|
||||
prop="region_name"
|
||||
label="区域名称"
|
||||
:min-width="flexWidth('region_name',crud.data,'区域名称')"
|
||||
/>
|
||||
<el-table-column prop="point_code" label="设备编码" :min-width="flexWidth('point_code',crud.data,'设备编码')" />
|
||||
<el-table-column prop="point_name" label="设备名称" :min-width="flexWidth('point_name',crud.data,'设备名称')" />
|
||||
<el-table-column
|
||||
prop="material_code"
|
||||
label="成品编码"
|
||||
:min-width="flexWidth('material_name',crud.data,'物料标识')"
|
||||
/>
|
||||
<el-table-column
|
||||
prop="half_material_code"
|
||||
label="半成品编码"
|
||||
:min-width="flexWidth('half_material_code',crud.data,'半成品编码')"
|
||||
/>
|
||||
<el-table-column
|
||||
prop="raw_material_code"
|
||||
label="泥料编码"
|
||||
:min-width="flexWidth('raw_material_code',crud.data,'物料标识')"
|
||||
/>
|
||||
<el-table-column
|
||||
prop="material_name"
|
||||
label="物料名称"
|
||||
:min-width="flexWidth('material_name',crud.data,'物料标识')"
|
||||
/>
|
||||
<el-table-column
|
||||
prop="material_spec"
|
||||
label="物料规格"
|
||||
:min-width="flexWidth('material_spec',crud.data,'物料标识')"
|
||||
/>
|
||||
<el-table-column
|
||||
prop="vehicle_type"
|
||||
label="载具类型"
|
||||
:min-width="flexWidth('vehicle_type',crud.data,'载具类型', 20)"
|
||||
>
|
||||
<template slot-scope="scope">
|
||||
{{ dict.label.vehicle_type[scope.row.vehicle_type] }}
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column
|
||||
prop="produce_date"
|
||||
label="生产日期"
|
||||
:min-width="flexWidth('produce_date',crud.data,'生产日期')"
|
||||
/>
|
||||
<el-table-column
|
||||
prop="planproducestart_date"
|
||||
label="计划开始时间"
|
||||
:min-width="flexWidth('planproducestart_date',crud.data,'计划开始时间')"
|
||||
/>
|
||||
<el-table-column
|
||||
prop="planproduceend_date"
|
||||
label="计划结束时间"
|
||||
:min-width="flexWidth('planproduceend_date',crud.data,'计划结束时间')"
|
||||
/>
|
||||
<el-table-column
|
||||
prop="realproducestart_date"
|
||||
label="实际开始时间"
|
||||
:min-width="flexWidth('realproducestart_date',crud.data,'实际开始时间')"
|
||||
/>
|
||||
<el-table-column
|
||||
prop="realproduceend_date"
|
||||
label="实际结束时间"
|
||||
:min-width="flexWidth('realproduceend_date',crud.data,'实际结束时间')"
|
||||
/>
|
||||
<el-table-column
|
||||
prop="standing_time"
|
||||
label="静置时间(分钟)"
|
||||
:min-width="flexWidth('standing_time',crud.data,'静置时间(分钟)')"
|
||||
/>
|
||||
<el-table-column
|
||||
prop="is_needmove"
|
||||
label="是否自动搬运"
|
||||
:min-width="flexWidth('is_needmove',crud.data,'是否自动搬运')"
|
||||
>
|
||||
<template slot-scope="scope">
|
||||
{{ scope.row.is_needmove ? '是' : '否' }}
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column prop="is_urgent" label="是否加急" :min-width="flexWidth('is_urgent',crud.data,'是否加急')">
|
||||
<template slot-scope="scope">
|
||||
{{ scope.row.is_urgent ? '是' : '否' }}
|
||||
</template>
|
||||
</el-table-column>
|
||||
<!-- <el-table-column prop="workorder_type" label="工单类型" :min-width="flexWidth('workorder_type',crud.data,'工单类型')" />-->
|
||||
<!--<el-table-column
|
||||
prop="passback_status"
|
||||
label="回传MES状态"
|
||||
:min-width="flexWidth('passback_status',crud.data,'回传MES状态')"
|
||||
/>-->
|
||||
<!-- <el-table-column prop="workshop_code" label="车间编码" :min-width="flexWidth('workshop_code',crud.data,'车间编码')" />-->
|
||||
<el-table-column prop="create_name" label="创建人" :min-width="flexWidth('create_name',crud.data,'创建人')" />
|
||||
<el-table-column
|
||||
prop="create_time"
|
||||
label="创建时间"
|
||||
:min-width="flexWidth('create_time',crud.data,'创建时间')"
|
||||
/>
|
||||
<el-table-column prop="update_name" label="修改人" :min-width="flexWidth('update_name',crud.data,'修改人')" />
|
||||
<el-table-column
|
||||
prop="update_time"
|
||||
label="修改时间"
|
||||
:min-width="flexWidth('update_time',crud.data,'修改时间')"
|
||||
/>
|
||||
<el-table-column v-permission="[]" label="操作" width="120px" align="center" fixed="right">
|
||||
<template slot-scope="scope">
|
||||
<udOperation
|
||||
:data="scope.row"
|
||||
:permission="permission"
|
||||
/>
|
||||
</template>
|
||||
</el-table-column>
|
||||
</el-table>
|
||||
<!--分页组件-->
|
||||
<pagination />
|
||||
</div>
|
||||
<MaterialDialog :dialog-show.sync="materialDialog" :flag="flag" @tableChanged="tableChanged" />
|
||||
<!-- <ProductionOrder :dialog-show.sync="orderDialog" :material-code="materialCode" @recordMesOrder="recordMesOrder" />-->
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
import crudPdmBdWorkorder from './pdmBdWorkorder'
|
||||
import crudSchBaseRegion from '@/views/wms/sch/region/schBaseRegion'
|
||||
import crudSchBasePoint from '@/views/wms/sch/point/schBasePoint'
|
||||
import CRUD, { crud, form, header, presenter } from '@crud/crud'
|
||||
import rrOperation from '@crud/RR.operation'
|
||||
import crudOperation from '@crud/CRUD.operation'
|
||||
import udOperation from '@crud/UD.operation'
|
||||
import pagination from '@crud/Pagination'
|
||||
import crudMdBaseWorkShop from '@/views/wms/basedata/workshop/mdBaseWorkshop'
|
||||
import MaterialDialog from '@/views/wms/sch/group/MaterialDialog.vue'
|
||||
import item from '@/layout/components/Sidebar/Item.vue'
|
||||
// import ProductionOrder from '@/views/wms/pdm/workerorder/ProductionOrder.vue'
|
||||
|
||||
const defaultForm = {
|
||||
workorder_id: null,
|
||||
workorder_code: null,
|
||||
plan_qty: null,
|
||||
real_qty: null,
|
||||
material_id: null,
|
||||
half_material_code: null,
|
||||
raw_material_code: null,
|
||||
vehicle_type: null,
|
||||
planproducestart_date: null,
|
||||
planproduceend_date: null,
|
||||
realproducestart_date: null,
|
||||
realproduceend_date: null,
|
||||
material_spec: null,
|
||||
material_code: null,
|
||||
material_name: null,
|
||||
standing_time: null,
|
||||
point_code: null,
|
||||
point_name: null,
|
||||
region_code: 'FJ',
|
||||
region_name: null,
|
||||
workorder_status: null,
|
||||
is_needmove: true,
|
||||
workorder_type: '1',
|
||||
passback_status: null,
|
||||
workshop_code: null,
|
||||
ext_id: null,
|
||||
is_delete: false,
|
||||
is_urgent: false,
|
||||
order_no: null,
|
||||
custer_no: null,
|
||||
pack_method: null,
|
||||
order_subnum: 0,
|
||||
real_weight: 0,
|
||||
plan_weight: 0,
|
||||
guadansum: 0,
|
||||
ext_data: 0,
|
||||
material_ratio: 0,
|
||||
priority: 1,
|
||||
show: false
|
||||
}
|
||||
export default {
|
||||
name: 'SortedOrder',
|
||||
dicts: ['vehicle_type', 'pdm_workorder_status', 'order_type'],
|
||||
components: { MaterialDialog, pagination, crudOperation, rrOperation, udOperation },
|
||||
mixins: [presenter(), header(), form(defaultForm), crud()],
|
||||
cruds() {
|
||||
return CRUD({
|
||||
title: '分拣工单',
|
||||
url: 'api/pdmBdWorkorder',
|
||||
idField: 'workorder_id',
|
||||
sort: 'workorder_id,desc',
|
||||
query: {
|
||||
region_code: 'FJ'
|
||||
},
|
||||
crudMethod: { ...crudPdmBdWorkorder },
|
||||
optShow: {
|
||||
add: true,
|
||||
edit: true,
|
||||
del: false,
|
||||
download: false,
|
||||
reset: true
|
||||
}
|
||||
})
|
||||
},
|
||||
data() {
|
||||
return {
|
||||
permission: {},
|
||||
rules: {
|
||||
material_code: [
|
||||
{ required: true, message: '物料不能为空', trigger: 'blur' }
|
||||
],
|
||||
plan_qty: [
|
||||
{ required: true, message: '计划数量不能为空', trigger: 'blur' }
|
||||
],
|
||||
planproducestart_date: [
|
||||
{ required: true, message: '计划开始不能为空', trigger: 'change' }
|
||||
],
|
||||
planproduceend_date: [
|
||||
{ required: true, message: '计划结束不能为空', trigger: 'change' }
|
||||
],
|
||||
point_code: [
|
||||
{ required: true, message: '设备编码不能为空', trigger: 'change' }
|
||||
],
|
||||
region_code: [
|
||||
{ required: true, message: '区域编码不能为空', trigger: 'change' }
|
||||
]
|
||||
/* workorder_type: [
|
||||
{ required: true, message: '工单类型不能为空', trigger: 'blur' }
|
||||
]*/
|
||||
},
|
||||
queryTypeOptions: [
|
||||
{ key: 'workorder_code', display_name: '工单编号' },
|
||||
{ key: 'point_code', display_name: '设备编码' }
|
||||
],
|
||||
workShopList: [],
|
||||
regionList: [],
|
||||
pointList: [],
|
||||
custerList: [],
|
||||
regionCodeParam: null,
|
||||
materialDialog: false,
|
||||
orderDialog: false,
|
||||
fullscreenLoading: false,
|
||||
materialCode: null,
|
||||
flag: 1
|
||||
}
|
||||
},
|
||||
created() {
|
||||
this.getWorkShopList()
|
||||
this.getRegionList()
|
||||
// this.getCuster()
|
||||
},
|
||||
methods: {
|
||||
item() {
|
||||
return item
|
||||
},
|
||||
// 钩子:在获取表格数据之前执行,false 则代表不获取数据
|
||||
[CRUD.HOOK.beforeRefresh]() {
|
||||
return true
|
||||
},
|
||||
[CRUD.HOOK.beforeToCU]() {
|
||||
this.setRegionName('FJ')
|
||||
},
|
||||
getWorkShopList() { // 获取车间列表
|
||||
crudMdBaseWorkShop.getWorkShopList().then(res => {
|
||||
this.workShopList = res
|
||||
})
|
||||
},
|
||||
getRegionList() { // 获取区域列表
|
||||
const param = {
|
||||
is_has_workder: true
|
||||
}
|
||||
crudSchBaseRegion.getRegionList(param).then(res => {
|
||||
this.regionList = res
|
||||
})
|
||||
},
|
||||
getCuster() { // 获取客户信息
|
||||
crudPdmBdWorkorder.getCuster().then(res => {
|
||||
this.custerList = res
|
||||
})
|
||||
},
|
||||
getPointList() { // 获取点位列表
|
||||
if (this.regionCodeParam) {
|
||||
const param = {
|
||||
region_code: this.regionCodeParam
|
||||
}
|
||||
crudSchBasePoint.getPointList(param).then(res => {
|
||||
this.pointList = res
|
||||
this.regionCodeParam = null
|
||||
})
|
||||
}
|
||||
},
|
||||
getMaterial(flag) {
|
||||
this.materialDialog = true
|
||||
this.flag = flag
|
||||
},
|
||||
getProductionOrder(code) {
|
||||
this.orderDialog = true
|
||||
this.materialCode = code
|
||||
},
|
||||
tableChanged(row, flag) {
|
||||
if (flag === 1) {
|
||||
this.form.material_name = row.material_name
|
||||
this.form.material_id = row.material_id
|
||||
this.form.material_spec = row.material_spec
|
||||
this.form.material_code = row.material_code
|
||||
this.form.half_material_code = row.half_material_code
|
||||
this.form.raw_material_code = row.raw_material_code
|
||||
this.form.plan_weight = row.total_material_qty == null ? 0 : row.total_material_qty
|
||||
} else {
|
||||
this.form.raw_material_name = row.material_name
|
||||
this.form.raw_material_id = row.material_id
|
||||
this.form.raw_material_code = row.material_code
|
||||
}
|
||||
this.form.pack_method = row.pack_method
|
||||
this.form.standing_time = row.standing_time
|
||||
const result = Object.keys(this.dict.label.vehicle_type).find(key => this.dict.label.vehicle_type[key] === row.pack_palletspec)
|
||||
if (result) {
|
||||
this.form.vehicle_type = result
|
||||
}
|
||||
},
|
||||
clearRecordMesOrder() {
|
||||
this.form.order_no = null
|
||||
this.form.order_subnum = 0
|
||||
this.form.guadansum = 0
|
||||
},
|
||||
recordMesOrder(row) { // 操作mes工单
|
||||
this.clearRecordMesOrder()
|
||||
this.form.order_no = row.forder_NO
|
||||
this.form.order_subnum = row.forder_SUBNUM
|
||||
this.form.guadansum = row.guadansum
|
||||
},
|
||||
setRegionName(data) {
|
||||
// 清空
|
||||
this.regionCodeParam = data
|
||||
var region = this.regionList.find(item => item.region_code === data)
|
||||
this.form.region_name = region.region_name
|
||||
this.getPointList()
|
||||
},
|
||||
setPointName(data) {
|
||||
var point = this.pointList.find(item => item.point_code === data)
|
||||
this.form.point_name = point.point_name
|
||||
},
|
||||
handOrderStatus(value) {
|
||||
this.crud.query.more_order_status = null
|
||||
if (value) {
|
||||
this.crud.query.more_order_status = value.toString()
|
||||
}
|
||||
this.crud.toQuery()
|
||||
},
|
||||
// 下发
|
||||
submits(row) {
|
||||
this.fullscreenLoading = true
|
||||
crudPdmBdWorkorder.submits(row).then(res => {
|
||||
this.crud.notify('下发成功', CRUD.NOTIFICATION_TYPE.SUCCESS)
|
||||
this.crud.toQuery()
|
||||
}).catch(() => {
|
||||
this.fullscreenLoading = false
|
||||
}).finally(() => {
|
||||
this.fullscreenLoading = false
|
||||
})
|
||||
},
|
||||
synchronize() {
|
||||
this.fullscreenLoading = true
|
||||
crudPdmBdWorkorder.orderSynchronize(this.crud.query).then(res => {
|
||||
this.fullscreenLoading = false
|
||||
this.crud.notify('同步成功!', CRUD.NOTIFICATION_TYPE.SUCCESS)
|
||||
}).catch(() => {
|
||||
this.fullscreenLoading = false
|
||||
}).finally(() => {
|
||||
this.fullscreenLoading = false
|
||||
})
|
||||
},
|
||||
forceFinish(row) {
|
||||
this.fullscreenLoading = true
|
||||
crudPdmBdWorkorder.forceFinish(row).then(res => {
|
||||
this.crud.notify('报工完成', CRUD.NOTIFICATION_TYPE.SUCCESS)
|
||||
this.crud.toQuery()
|
||||
}).catch(() => {
|
||||
this.fullscreenLoading = false
|
||||
}).finally(() => {
|
||||
this.fullscreenLoading = false
|
||||
})
|
||||
}
|
||||
}
|
||||
}
|
||||
</script>
|
||||
|
||||
<style scoped>
|
||||
|
||||
</style>
|
||||
Reference in New Issue
Block a user