From 14311eec900eea7098e097be47c04a17491e3b67 Mon Sep 17 00:00:00 2001 From: zhangqian <zhangqian@123.com> Date: 星期二, 14 十一月 2023 11:37:07 +0800 Subject: [PATCH] fix --- api/v1/process_model.go | 29 +++++++++++++++++------------ 1 files changed, 17 insertions(+), 12 deletions(-) diff --git a/api/v1/process_model.go b/api/v1/process_model.go index baa40f3..2c7a898 100644 --- a/api/v1/process_model.go +++ b/api/v1/process_model.go @@ -29,20 +29,23 @@ ctx.Fail(code) return } + var oldProcessModel *model.ProcessModel + if procedure.ProcessModelNumber != "" { + oldProcessModel, _ = service.GetProcessModelByNumber(procedure.ProcessModelNumber) + } - oldProcessModel, _ := service.GetProcessModelByNumber(procedure.ProcessModelNumber) - offset, limit, push := GetOffsetAndLimit(oldProcessModel, params.Page, params.PageSize) + offset, limit, unShift := GetOffsetAndLimit(oldProcessModel, params.Page, params.PageSize) list, total, err := service.GetProcessModelList(offset, limit, procedure.ProcessModelNumber) if err != nil { ctx.Fail(ecode.DBErr) return } - if push { //绮樺湪鍓嶉潰 + if unShift && oldProcessModel != nil { //绮樺湪鍓嶉潰 list = append([]*model.ProcessModel{oldProcessModel}, list...) } for _, processModel := range list { - if processModel.Procedure == oldProcessModel.Procedure && processModel.Product == oldProcessModel.Product { + if oldProcessModel != nil && processModel.Procedure == oldProcessModel.Procedure && processModel.Product == oldProcessModel.Product { processModel.IsUpdate = processModel.Number != procedure.ProcessModelNumber } if processModel.IsUpdate { @@ -53,15 +56,17 @@ ctx.ResultList(list, total) } -func GetOffsetAndLimit(current *model.ProcessModel, page, pageSize int) (offset, limit int, push bool) { +func GetOffsetAndLimit(current *model.ProcessModel, page, pageSize int) (offset, limit int, unShift bool) { + //isNew鏄鏇存柊鐨� + unShift = current != nil && current.IsNew && page == 1 + limit = pageSize + if unShift { + limit-- //濡傛灉鏄柊鐨勶紝绗竴椤靛皯鏌ヤ竴涓� + } offset = (page - 1) * pageSize - if current.IsNew { + if current != nil && current.IsNew && 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