work_cron.go 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120
  1. package crontab
  2. import (
  3. "encoding/json"
  4. "kpt-pasture/model"
  5. "kpt-pasture/module/backend"
  6. "time"
  7. "gorm.io/gorm"
  8. "gitee.com/xuyiping_admin/pkg/xerr"
  9. "gitee.com/xuyiping_admin/pkg/logger/zaplog"
  10. "go.uber.org/zap"
  11. pasturePb "gitee.com/xuyiping_admin/go_proto/proto/go/backend/cow"
  12. )
  13. // GenerateCalendarBySameTimePlan 生成同期计划的牛只
  14. func (e *Entry) GenerateCalendarBySameTimePlan(cowList []*model.Cow, sameTime *model.SameTime) (int32, error) {
  15. if len(cowList) <= 0 {
  16. return 0, nil
  17. }
  18. newCowList := make([]*model.Cow, 0)
  19. for _, cow := range cowList {
  20. if ok := e.IsExistSameTimeCow(cow, sameTime); ok {
  21. zaplog.Info("GenerateCalendarBySameTimePlan", zap.Any("sameTime", sameTime), zap.Any("cow", cow))
  22. continue
  23. }
  24. newCowList = append(newCowList, cow)
  25. }
  26. if len(newCowList) <= 0 || len(sameTime.CollateNodes) <= 0 {
  27. return 0, nil
  28. }
  29. calendarList := make([]*model.Calendar, 0)
  30. newSameTimeCowDetailList := make([]*model.SameTimeCowDetail, 0)
  31. collateNodes := make([]*pasturePb.CollateNode, 0)
  32. var _ = json.Unmarshal([]byte(sameTime.CollateNodes), &collateNodes)
  33. nowTime := time.Now()
  34. for i, collateNode := range collateNodes {
  35. showDay := nowTime.Format(model.LayoutDate2)
  36. if i > 0 {
  37. showDay = nowTime.Add(time.Hour * 24 * time.Duration(collateNode.NextNodeDay)).Format(model.LayoutDate2)
  38. }
  39. calendarName := backend.CalendarTypeMap()[pasturePb.CalendarType_PG]
  40. calendarType := pasturePb.CalendarType_PG
  41. if collateNode.SameTimeType == pasturePb.SameTimeType_RnGH {
  42. calendarName = backend.CalendarTypeMap()[pasturePb.CalendarType_RnGH]
  43. calendarType = pasturePb.CalendarType_RnGH
  44. }
  45. if collateNode.SameTimeType == pasturePb.SameTimeType_TAI {
  46. calendarName = backend.CalendarTypeMap()[pasturePb.CalendarType_Mating]
  47. calendarType = pasturePb.CalendarType_Mating
  48. }
  49. histCount := e.GetTowardSameTimeCowSum(sameTime.Id, collateNode.SameTimeType)
  50. calendarList = append(calendarList, &model.Calendar{
  51. Name: calendarName,
  52. CalendarType: calendarType,
  53. Count: int32(len(newCowList)) + int32(histCount),
  54. ShowDay: showDay,
  55. IsShow: pasturePb.IsShow_Ok,
  56. })
  57. newSameTimeCowDetailList = append(
  58. newSameTimeCowDetailList,
  59. model.NewSameTimeCowDetailList(newCowList, sameTime.Id, showDay, collateNode.SameTimeType)...,
  60. )
  61. }
  62. newSameTimeCowList := model.NewSameTimeCowList(newCowList, sameTime)
  63. if err := e.DB.Transaction(func(tx *gorm.DB) error {
  64. // 创建牛只同期日历表
  65. if err := tx.Create(calendarList).Error; err != nil {
  66. return xerr.WithStack(err)
  67. }
  68. // 创建牛只同期总表
  69. if err := tx.Create(newSameTimeCowList).Error; err != nil {
  70. return xerr.WithStack(err)
  71. }
  72. if err := tx.Create(newSameTimeCowDetailList).Error; err != nil {
  73. return xerr.WithStack(err)
  74. }
  75. return nil
  76. }); err != nil {
  77. return 0, xerr.WithStack(err)
  78. }
  79. return int32(len(newCowList)), nil
  80. }
  81. func (e *Entry) getWorkOrderCalendar(name string) []*model.Calendar {
  82. res := make([]*model.Calendar, 0)
  83. if err := e.DB.Where("name = ?", name).
  84. Where("is_show = ?", pasturePb.IsShow_Ok).
  85. Find(&res).Error; err != nil {
  86. zaplog.Error("getWorkOrderCalendar", zap.Any("err", err))
  87. }
  88. return res
  89. }
  90. // GetTowardSameTimeCowSum 获取历史未打激素牛只总数量
  91. func (e *Entry) GetTowardSameTimeCowSum(sameTimeId int64, sameTimeType pasturePb.SameTimeType_Kind) int64 {
  92. res := int64(0)
  93. if err := e.DB.Model(&model.SameTimeCowDetail{}).
  94. Where("status = ?", pasturePb.IsShow_No).
  95. Where("same_time_id = ?", sameTimeId).
  96. Where("same_time_type = ?", sameTimeType).
  97. Count(&res).Error; err != nil {
  98. zaplog.Error("GetTowardSameTimeCowSum", zap.Any("err", err))
  99. }
  100. return res
  101. }