From 8d2a95fc0eeabe1b13d0a914c9ec2845d42c0be3 Mon Sep 17 00:00:00 2001
From: zhangzengfei <zhangzengfei@smartai.com>
Date: 星期四, 19 十月 2023 11:32:57 +0800
Subject: [PATCH] 添加主从serf切换事件
---
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