From 2d6875c93b25d0b7336c7fa11e066d213259fe2e Mon Sep 17 00:00:00 2001 From: zhangqian <zhangqian@123.com> Date: 星期四, 25 四月 2024 10:02:01 +0800 Subject: [PATCH] 更改定时任务时区设置 --- api/v1/process_model.go | 59 ++++++++++++++++++++++++++++++++++++++++++++--------------- 1 files changed, 44 insertions(+), 15 deletions(-) diff --git a/api/v1/process_model.go b/api/v1/process_model.go index 61dad3b..447668c 100644 --- a/api/v1/process_model.go +++ b/api/v1/process_model.go @@ -25,30 +25,59 @@ return } - oldProcessModel, _ := service.GetProcessModelByNumber(params.Number) - - if params.Page == 1 && oldProcessModel.IsNew { //灏戞煡涓�涓� - params.PageSize-- + procedure, code := service.NewTaskService().GetProcedureById(params.ProcedureId) + if code != ecode.OK { + ctx.Fail(code) + return } - - list, total, err := service.GetProcessModelList(params.Page, params.PageSize, params.Number) + order, err := service.NewTaskService().GetOrderByWorkOrderId(procedure.WorkOrderID) if err != nil { ctx.Fail(ecode.DBErr) return } + var oldProcessModel, newProcessModel, headProcessModel *model.ProcessModel - if params.Page == 1 && oldProcessModel.IsNew { //绮樺湪鍓嶉潰 - list = append([]*model.ProcessModel{oldProcessModel}, list...) + if procedure.ProcessModelNumber != "" { + oldProcessModel, _ = service.GetProcessModelByNumber(procedure.ProcessModelNumber) //鑾峰彇鏃х殑宸ヨ壓鍙傛暟 } - for _, processModel := range list { - if processModel.Procedure == oldProcessModel.Procedure && processModel.Product == oldProcessModel.Product { - processModel.IsUpdate = processModel.Number != params.Number + newProcessModel, _ = service.NewTaskService().GetProcessParams(procedure, order) //鑾峰彇鏂扮殑宸ヨ壓鍙傛暟 + if newProcessModel != nil && (oldProcessModel == nil || newProcessModel.Number != oldProcessModel.Number) { //鏃х殑娌℃湁鎴栬�呯紪鍙蜂笉鍚岋紝鏇存柊 + if procedure.Status == model.ProcedureStatusProcessing { + newProcessModel.NewNumber, newProcessModel.NewParamsMap = newProcessModel.Number, newProcessModel.ParamsMap + if oldProcessModel != nil { + newProcessModel.Number, newProcessModel.ParamsMap = oldProcessModel.Number, oldProcessModel.ParamsMap + } else { //鏃х殑娌℃湁锛屼篃鍙互"鏇存柊"(琛ュ厖) + newProcessModel.Number, newProcessModel.ParamsMap = "", nil + } + newProcessModel.IsUpdate = true } - if processModel.IsUpdate { - processModel.NewNumber, processModel.NewParamsMap = processModel.Number, processModel.ParamsMap - processModel.Number, processModel.ParamsMap = oldProcessModel.Number, oldProcessModel.ParamsMap - } + headProcessModel = newProcessModel + } else if oldProcessModel != nil { + headProcessModel = oldProcessModel } + offset, limit, unShift := GetOffsetAndLimit(headProcessModel, params.Page, params.PageSize) + list, total, err := service.GetOtherProcessModelList(offset, limit, order.ProductName, procedure.ProceduresInfo.ProcedureName) //鑾峰彇鍏朵粬宸ヨ壓鍙傛暟 + if err != nil { + ctx.Fail(ecode.DBErr) + return + } + if unShift && headProcessModel != nil { //绮樺湪鍓嶉潰 + list = append([]*model.ProcessModel{headProcessModel}, list...) + } ctx.ResultList(list, total) } + +func GetOffsetAndLimit(head *model.ProcessModel, page, pageSize int) (offset, limit int, unShift bool) { + unShift = head != nil && page == 1 + limit = pageSize + if unShift { + limit-- //绗竴椤靛皯鏌ヤ竴涓� + } + offset = (page - 1) * pageSize + if head != nil && offset > 0 { //绗簩椤靛紑濮嬪亸绉婚噺宸︾Щ涓�涓� + offset-- + } + + return offset, limit, unShift +} -- Gitblit v1.8.0