zhangqian
2023-12-08 84fb8e390b83dc9482524c12d7af6c93405c3fc1
service/report_work.go
@@ -5,7 +5,12 @@
   "apsClient/constvar"
   "apsClient/model"
   "apsClient/model/request"
   "apsClient/pkg/logx"
   "apsClient/pkg/snowflake"
   "encoding/json"
   "errors"
   "github.com/jinzhu/gorm"
   "github.com/spf13/cast"
   "time"
)
@@ -29,37 +34,67 @@
   for _, worker := range procedure.ProceduresInfo.Workers {
      if params.WorkerID == worker.WorkerID {
         workerName = worker.WorkerName
         if worker.StartTime < nowTs {
            startTs = worker.StartTime
         }
      }
   }
   if workerName == "" {
      return errors.New("没有找到当前值班人员")
   }
   if startTs == 0 {
      return errors.New("没有找到当前值班人员开始时间")
   finishAmount := params.ReportAmount
   lastReportWork, err := GetLastReportWork(params.ProcedureId)
   if err == nil {
      if params.ReportAmount < lastReportWork.ReportAmount {
         return errors.New("报工数量不能少于上次报工数")
      }
      finishAmount = params.ReportAmount - lastReportWork.ReportAmount
      startTs = lastReportWork.EndTime
   } else {
      startTs = procedure.RealStartTime
   }
   record := &model.ReportWork{
      ProceduresID: params.ProcedureId,
      WorkOrderID:  procedure.WorkOrderID,
      DeviceID:     procedure.DeviceID,
      DeviceName:   procedure.ProceduresInfo.DeviceName,
      ProcedureID:  procedure.ProcedureID,
      Channel:      procedure.Channel,
      StartTime:    startTs,
      EndTime:      nowTs,
      ReportAmount: params.ReportAmount,
      WorkerID:     params.WorkerID,
      WorkerName:   workerName,
      ProceduresID:       params.ProcedureId,
      ProductProcedureID: procedure.ProductProcedureID,
      WorkOrderID:        procedure.WorkOrderID,
      DeviceID:           procedure.DeviceID,
      DeviceName:         procedure.ProceduresInfo.DeviceName,
      ProcedureID:        procedure.ProcedureID,
      StartTime:          startTs,
      EndTime:            nowTs,
      ReportAmount:       params.ReportAmount,
      FinishAmount:       finishAmount,
      WorkerID:           params.WorkerID,
      WorkerName:         workerName,
      WorkerTime:         nowTs - startTs,
      BarCode:            cast.ToString(snowflake.GenerateID()),
   }
   err = model.WithTransaction(func(db *gorm.DB) error {
      err = model.NewReportWorkSearch(db).Create(record)
      if err != nil {
         return err
      }
   err = model.NewReportWorkSearch(nil).Create(record)
      content, err := json.Marshal(record)
      if err != nil {
         return err
      }
      err = model.NewReportsToCloudSearch(db).Create(&model.ReportsToCloud{
         ReportType: constvar.ReportTypeReportWork,
         Content:    string(content),
      })
      if err != nil {
         return err
      }
      return nil
   })
   if err != nil {
      logx.Errorf("save report work transaction error: %v", err)
      return err
   }
   PlcCacheSet(conf.Conf.CurrentDeviceID, procedure.Channel, constvar.PlcCacheKeyFinishNumber, params.ReportAmount)
   err = NewProgressService().UpdateProgressByProceduresId(procedure.ID, params.ReportAmount)
   return nil
}