zhangqian
2023-10-09 dad1ae79fe78e770d88f41713b4c68fad562d9ef
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
}