From 752a77ffd9b83965f3309656265050e2e03e8f01 Mon Sep 17 00:00:00 2001
From: zhangqian <zhangqian@123.com>
Date: 星期二, 14 十一月 2023 14:39:22 +0800
Subject: [PATCH] 没有下发工艺参数的工序,生产中支持补充下发

---
 service/task.go          |    3 +
 service/process_model.go |   17 +++++++-
 model/process_model.go   |   20 ++++++++++
 api/v1/process_model.go  |   50 ++++++++++++++----------
 4 files changed, 67 insertions(+), 23 deletions(-)

diff --git a/api/v1/process_model.go b/api/v1/process_model.go
index c15b609..5a8e8f6 100644
--- a/api/v1/process_model.go
+++ b/api/v1/process_model.go
@@ -24,47 +24,55 @@
 	if !ok {
 		return
 	}
+
 	procedure, code := service.NewTaskService().GetProcedureById(params.ProcedureId)
 	if code != ecode.OK {
 		ctx.Fail(code)
 		return
 	}
-	var oldProcessModel *model.ProcessModel
-	if procedure.ProcessModelNumber != "" {
-		oldProcessModel, _ = service.GetProcessModelByNumber(procedure.ProcessModelNumber)
-	}
-
-	offset, limit, unShift := GetOffsetAndLimit(oldProcessModel, params.Page, params.PageSize)
-	list, total, err := service.GetProcessModelList(offset, limit, procedure.ProcessModelNumber)
+	order, err := service.NewTaskService().GetOrderByWorkOrderId(procedure.WorkOrderID)
 	if err != nil {
 		ctx.Fail(ecode.DBErr)
 		return
 	}
-
-	if unShift && oldProcessModel != nil { //绮樺湪鍓嶉潰
-		list = append([]*model.ProcessModel{oldProcessModel}, list...)
+	var oldProcessModel, newProcessModel, headProcessModel *model.ProcessModel
+	if procedure.ProcessModelNumber != "" {
+		oldProcessModel, _ = service.GetProcessModelByNumber(procedure.ProcessModelNumber)                          //鑾峰彇鏃х殑宸ヨ壓鍙傛暟
+		newProcessModel, _ = service.NewTaskService().GetProcessParams(procedure, order)                            //鑾峰彇鏂扮殑宸ヨ壓鍙傛暟
+		if newProcessModel != nil && (oldProcessModel == nil || newProcessModel.Number != oldProcessModel.Number) { //鏃х殑娌℃湁鎴栬�呯紪鍙蜂笉鍚岋紝鏇存柊
+			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
+			}
+			headProcessModel = newProcessModel
+		} else if oldProcessModel != nil {
+			headProcessModel = oldProcessModel
+		}
 	}
-	for _, processModel := range list {
-		if oldProcessModel != nil && processModel.Procedure == oldProcessModel.Procedure && processModel.Product == oldProcessModel.Product {
-			processModel.IsUpdate = processModel.Number != procedure.ProcessModelNumber
-		}
-		if processModel.IsUpdate {
-			processModel.NewNumber, processModel.NewParamsMap = processModel.Number, processModel.ParamsMap
-			processModel.Number, processModel.ParamsMap = oldProcessModel.Number, oldProcessModel.ParamsMap
-		}
+
+	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, unShift bool) {
+func GetOffsetAndLimit(head *model.ProcessModel, page, pageSize int) (offset, limit int, unShift bool) {
 	//isNew鏄鏇存柊鐨�
-	unShift = current != nil && page == 1
+	unShift = head != nil && page == 1
 	limit = pageSize
 	if unShift {
 		limit-- //濡傛灉鏄柊鐨勶紝绗竴椤靛皯鏌ヤ竴涓�
 	}
 	offset = (page - 1) * pageSize
-	if current != nil && offset > 0 { //濡傛灉鏄柊鐨勶紝绗簩椤靛紑濮嬪亸绉婚噺宸︾Щ涓�涓�
+	if head != nil && offset > 0 { //濡傛灉鏄柊鐨勶紝绗簩椤靛紑濮嬪亸绉婚噺宸︾Щ涓�涓�
 		offset--
 	}
 
diff --git a/model/process_model.go b/model/process_model.go
index 1614b26..aab6e62 100644
--- a/model/process_model.go
+++ b/model/process_model.go
@@ -33,6 +33,8 @@
 		Procedures    []string
 		CurrentNumber string
 		Numbers       []string
+		ProductNot    string
+		ProcedureNot  string
 	}
 )
 
@@ -98,6 +100,16 @@
 	return slf
 }
 
+func (slf *ProcessModelSearch) SetProductNot(product string) *ProcessModelSearch {
+	slf.ProductNot = product
+	return slf
+}
+
+func (slf *ProcessModelSearch) SetProcedureNot(procedure string) *ProcessModelSearch {
+	slf.ProcedureNot = procedure
+	return slf
+}
+
 func (slf *ProcessModelSearch) SetProcedures(procedures []string) *ProcessModelSearch {
 	slf.Procedures = procedures
 	return slf
@@ -123,6 +135,14 @@
 		db = db.Where("`procedure` = ?", slf.Procedure)
 	}
 
+	if len(slf.ProductNot) != 0 {
+		db = db.Where("product <> ?", slf.ProductNot)
+	}
+
+	if len(slf.ProcedureNot) != 0 {
+		db = db.Where("`procedure` <> ?", slf.ProcedureNot)
+	}
+
 	if len(slf.Procedures) != 0 {
 		db = db.Where("`procedure` IN (?)", slf.Procedures)
 	}
diff --git a/service/process_model.go b/service/process_model.go
index 1922fce..df31dea 100644
--- a/service/process_model.go
+++ b/service/process_model.go
@@ -7,13 +7,26 @@
 	"errors"
 )
 
-func GetProcessModelList(offset, limit int, currentNumber string) (list []*model.ProcessModel, total int64, err error) {
+func GetProcessModelList(offset, limit int, product, procedure string) (list []*model.ProcessModel, total int64, err error) {
 	device, err := model.NewDeviceSearch().SetDeviceId(conf.Conf.CurrentDeviceID).First()
 	if err != nil {
 		return
 	}
 	list, total, err = model.NewProcessModelSearch().
-		SetIsNew(true).SetOrder("id desc").SetCurrentNumber(currentNumber).
+		SetIsNew(true).SetOrder("id desc").
+		SetProduct(product).SetProcedure(procedure).
+		SetPage(offset, limit).SetProcedures(device.ProceduresArr).Find()
+	return
+}
+
+func GetOtherProcessModelList(offset, limit int, product, procedure string) (list []*model.ProcessModel, total int64, err error) {
+	device, err := model.NewDeviceSearch().SetDeviceId(conf.Conf.CurrentDeviceID).First()
+	if err != nil {
+		return
+	}
+	list, total, err = model.NewProcessModelSearch().
+		SetIsNew(true).SetOrder("id desc").
+		SetProductNot(product).SetProcedureNot(procedure).
 		SetPage(offset, limit).SetProcedures(device.ProceduresArr).Find()
 	return
 }
diff --git a/service/task.go b/service/task.go
index bebd3ff..a4e6931 100644
--- a/service/task.go
+++ b/service/task.go
@@ -173,6 +173,9 @@
 		logx.Errorf("TaskStart GetProcessModel  err:%v", err)
 		return nil, err
 	}
+	if err == gorm.ErrRecordNotFound {
+		return nil, err
+	}
 	if err == nil {
 		return data, nil
 	}

--
Gitblit v1.8.0