From edb5732ebb9f4e0036e33febbdcaccaf89d46dcc Mon Sep 17 00:00:00 2001
From: zhangqian <zhangqian@123.com>
Date: 星期二, 14 十一月 2023 19:30:14 +0800
Subject: [PATCH] 工序列表是否可以更新增加工序状态判断
---
api/v1/process_model.go | 62 +++++++++++++++++++++----------
1 files changed, 42 insertions(+), 20 deletions(-)
diff --git a/api/v1/process_model.go b/api/v1/process_model.go
index 8a03909..447668c 100644
--- a/api/v1/process_model.go
+++ b/api/v1/process_model.go
@@ -24,38 +24,60 @@
if !ok {
return
}
- oldProcessModel, _ := service.GetProcessModelByNumber(params.Number)
- offset, limit, push := GetOffsetAndLimit(oldProcessModel, params.Page, params.PageSize)
- list, total, err := service.GetProcessModelList(offset, limit, params.Number)
+
+ procedure, code := service.NewTaskService().GetProcedureById(params.ProcedureId)
+ if code != ecode.OK {
+ ctx.Fail(code)
+ return
+ }
+ order, err := service.NewTaskService().GetOrderByWorkOrderId(procedure.WorkOrderID)
if err != nil {
ctx.Fail(ecode.DBErr)
return
}
+ var oldProcessModel, newProcessModel, headProcessModel *model.ProcessModel
- if push { //绮樺湪鍓嶉潰
- list = append([]*model.ProcessModel{oldProcessModel}, list...)
+ if procedure.ProcessModelNumber != "" {
+ oldProcessModel, _ = service.GetProcessModelByNumber(procedure.ProcessModelNumber) //鑾峰彇鏃х殑宸ヨ壓鍙傛暟
}
- for _, processModel := range list {
- if processModel.Procedure == oldProcessModel.Procedure && processModel.Product == oldProcessModel.Product {
- processModel.IsUpdate = processModel.Number != params.Number
+ newProcessModel, _ = service.NewTaskService().GetProcessParams(procedure, order) //鑾峰彇鏂扮殑宸ヨ壓鍙傛暟
+ if newProcessModel != nil && (oldProcessModel == nil || newProcessModel.Number != oldProcessModel.Number) { //鏃х殑娌℃湁鎴栬�呯紪鍙蜂笉鍚岋紝鏇存柊
+ if procedure.Status == model.ProcedureStatusProcessing {
+ newProcessModel.NewNumber, newProcessModel.NewParamsMap = newProcessModel.Number, newProcessModel.ParamsMap
+ if oldProcessModel != nil {
+ newProcessModel.Number, newProcessModel.ParamsMap = oldProcessModel.Number, oldProcessModel.ParamsMap
+ } else { //鏃х殑娌℃湁锛屼篃鍙互"鏇存柊"(琛ュ厖)
+ newProcessModel.Number, newProcessModel.ParamsMap = "", nil
+ }
+ newProcessModel.IsUpdate = true
}
- if processModel.IsUpdate {
- processModel.NewNumber, processModel.NewParamsMap = processModel.Number, processModel.ParamsMap
- processModel.Number, processModel.ParamsMap = oldProcessModel.Number, oldProcessModel.ParamsMap
- }
+ headProcessModel = newProcessModel
+ } else if oldProcessModel != nil {
+ headProcessModel = oldProcessModel
+ }
+
+ offset, limit, unShift := GetOffsetAndLimit(headProcessModel, params.Page, params.PageSize)
+ list, total, err := service.GetOtherProcessModelList(offset, limit, order.ProductName, procedure.ProceduresInfo.ProcedureName) //鑾峰彇鍏朵粬宸ヨ壓鍙傛暟
+ if err != nil {
+ ctx.Fail(ecode.DBErr)
+ return
+ }
+ if unShift && headProcessModel != nil { //绮樺湪鍓嶉潰
+ list = append([]*model.ProcessModel{headProcessModel}, list...)
}
ctx.ResultList(list, total)
}
-func GetOffsetAndLimit(current *model.ProcessModel, page, pageSize int) (offset, limit int, push bool) {
+func GetOffsetAndLimit(head *model.ProcessModel, page, pageSize int) (offset, limit int, unShift bool) {
+ unShift = head != nil && page == 1
+ limit = pageSize
+ if unShift {
+ limit-- //绗竴椤靛皯鏌ヤ竴涓�
+ }
offset = (page - 1) * pageSize
- if current.IsNew {
+ if head != nil && offset > 0 { //绗簩椤靛紑濮嬪亸绉婚噺宸︾Щ涓�涓�
offset--
}
- push = current.IsNew && page == 1
- limit = pageSize
- if push {
- limit--
- }
- return offset, limit, push
+
+ return offset, limit, unShift
}
--
Gitblit v1.8.0