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