From dad1ae79fe78e770d88f41713b4c68fad562d9ef Mon Sep 17 00:00:00 2001
From: zhangqian <zhangqian@123.com>
Date: 星期一, 09 十月 2023 21:36:34 +0800
Subject: [PATCH] 当前使用的工艺编号置顶

---
 api/v1/process_model.go |   25 ++++++++++++++++---------
 1 files changed, 16 insertions(+), 9 deletions(-)

diff --git a/api/v1/process_model.go b/api/v1/process_model.go
index 61dad3b..8a03909 100644
--- a/api/v1/process_model.go
+++ b/api/v1/process_model.go
@@ -24,20 +24,15 @@
 	if !ok {
 		return
 	}
-
 	oldProcessModel, _ := service.GetProcessModelByNumber(params.Number)
-
-	if params.Page == 1 && oldProcessModel.IsNew { //灏戞煡涓�涓�
-		params.PageSize--
-	}
-
-	list, total, err := service.GetProcessModelList(params.Page, params.PageSize, params.Number)
+	offset, limit, push := GetOffsetAndLimit(oldProcessModel, params.Page, params.PageSize)
+	list, total, err := service.GetProcessModelList(offset, limit, params.Number)
 	if err != nil {
 		ctx.Fail(ecode.DBErr)
 		return
 	}
 
-	if params.Page == 1 && oldProcessModel.IsNew { //绮樺湪鍓嶉潰
+	if push { //绮樺湪鍓嶉潰
 		list = append([]*model.ProcessModel{oldProcessModel}, list...)
 	}
 	for _, processModel := range list {
@@ -49,6 +44,18 @@
 			processModel.Number, processModel.ParamsMap = oldProcessModel.Number, oldProcessModel.ParamsMap
 		}
 	}
-
 	ctx.ResultList(list, total)
 }
+
+func GetOffsetAndLimit(current *model.ProcessModel, page, pageSize int) (offset, limit int, push bool) {
+	offset = (page - 1) * pageSize
+	if current.IsNew {
+		offset--
+	}
+	push = current.IsNew && page == 1
+	limit = pageSize
+	if push {
+		limit--
+	}
+	return offset, limit, push
+}

--
Gitblit v1.8.0