event_check.go 8.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238
  1. package backend
  2. import (
  3. "context"
  4. "fmt"
  5. "kpt-pasture/model"
  6. "time"
  7. "go.uber.org/zap"
  8. "gitee.com/xuyiping_admin/pkg/logger/zaplog"
  9. pasturePb "gitee.com/xuyiping_admin/go_proto/proto/go/backend/cow"
  10. "gitee.com/xuyiping_admin/pkg/xerr"
  11. )
  12. // EventMatingCheckBatchModel 批量配种
  13. type EventMatingCheckBatchModel struct {
  14. CowList []*model.Cow
  15. FrozenSemen *model.FrozenSemen
  16. OperationUser *model.SystemUser
  17. }
  18. // PregnantCheckBatchModel 批量孕检
  19. type PregnantCheckBatchModel struct {
  20. EventPregnancyCheck *model.EventPregnantCheck
  21. Cow *model.Cow
  22. OperationUser *model.SystemUser
  23. PregnantCheckAt int32 // 孕检日期
  24. PregnantCheckResult pasturePb.PregnantCheckResult_Kind // 孕检结果
  25. PregnantCheckMethod pasturePb.PregnantCheckMethod_Kind // 孕检方式
  26. Remarks string
  27. LastMating *model.EventMating
  28. }
  29. // MatingTimes 更新配次
  30. type MatingTimes struct {
  31. Mt int32
  32. CowId int64
  33. EventMatingId int64
  34. }
  35. func (s *StoreEntry) EnterCheck(ctx context.Context, req *pasturePb.EventEnterRequest) error {
  36. var count int64
  37. if err := s.DB.Model(new(model.Cow)).Where("ear_number = ?", req.EarNumber).Count(&count).Error; err != nil {
  38. return xerr.WithStack(err)
  39. }
  40. if count > 0 {
  41. return xerr.Custom("该牛只已存在")
  42. }
  43. return nil
  44. }
  45. func (s *StoreEntry) MatingCreateCheck(ctx context.Context, pastureId int64, req *pasturePb.EventMating) (*EventMatingCheckBatchModel, error) {
  46. if len(req.CowIds) <= 0 {
  47. return nil, xerr.Custom("请选择相关牛只")
  48. }
  49. cowIds := make([]int64, 0)
  50. for _, v := range req.CowIds {
  51. cowIds = append(cowIds, int64(v))
  52. }
  53. if len(cowIds) > 20 {
  54. return nil, xerr.Custom("最多只能选择50只牛只")
  55. }
  56. cowList, err := s.GetCowInfoByCowIds(ctx, pastureId, cowIds)
  57. if err != nil {
  58. return nil, xerr.WithStack(err)
  59. }
  60. operationUser, err := s.GetSystemUserById(ctx, int64(req.OperationId))
  61. if err != nil {
  62. return nil, xerr.WithStack(err)
  63. }
  64. frozenSemen := &model.FrozenSemen{}
  65. if err = s.DB.Where("bull_id = ?", req.FrozenSemenNumber).
  66. First(frozenSemen).Error; err != nil {
  67. return nil, xerr.Custom("未找到冻精信息")
  68. }
  69. if frozenSemen.Quantity < req.FrozenSemenCount {
  70. return nil, xerr.Custom("冻精数量不足")
  71. }
  72. for _, cow := range cowList {
  73. if cow.Sex != pasturePb.Genders_Female {
  74. return nil, xerr.Customf("牛只: %d,不是母牛", cow.Id)
  75. }
  76. if int64(req.MatingAt) < cow.LastMatingAt {
  77. return nil, xerr.Customf("牛只: %d,最近一次配种时间: %d,不能小于本次配种时间: %d", cow.Id, cow.LastMatingAt, req.MatingAt)
  78. }
  79. if int64(req.MatingAt) < cow.LastPregnantCheckAt {
  80. return nil, xerr.Customf("牛只: %d,最近一次孕检时间: %d,不能小于本次配种时间: %d", cow.Id, cow.LastPregnantCheckAt, req.MatingAt)
  81. }
  82. if int64(req.MatingAt) < cow.LastAbortionAt {
  83. return nil, xerr.Customf("牛只: %d,最近一次流产时间: %d,不能小于本次配种时间: %d", cow.Id, cow.LastAbortionAt, req.MatingAt)
  84. }
  85. if int64(req.MatingAt) < cow.BirthAt {
  86. return nil, xerr.Customf("牛只: %d,出生时间: %d,不能小于本次配种时间: %d", cow.Id, cow.BirthAt, req.MatingAt)
  87. }
  88. if cow.BreedStatus == pasturePb.BreedStatus_Pregnant || cow.BreedStatus == pasturePb.BreedStatus_No_Mating {
  89. return nil, xerr.Customf("牛只: %d,当前状态为: %s,不能进行配种", cow.Id, cow.BreedStatus.String())
  90. }
  91. }
  92. return &EventMatingCheckBatchModel{
  93. CowList: cowList,
  94. FrozenSemen: frozenSemen,
  95. OperationUser: operationUser,
  96. }, nil
  97. }
  98. func (s *StoreEntry) PregnantCheckDataCheck(ctx context.Context, pastureId int64, req *pasturePb.EventPregnantCheckBatch) ([]*PregnantCheckBatchModel, error) {
  99. if len(req.Items) <= 0 {
  100. return nil, xerr.Custom("请选择相关牛只数据")
  101. }
  102. pregnantCheckBatchModelList := make([]*PregnantCheckBatchModel, 0)
  103. cowInfo := &model.Cow{}
  104. var err error
  105. for _, item := range req.Items {
  106. cowInfo, err = s.GetCowInfoByCowId(ctx, pastureId, int64(item.CowId))
  107. if err != nil {
  108. return nil, xerr.WithStack(err)
  109. }
  110. if cowInfo.Sex != pasturePb.Genders_Female {
  111. return nil, xerr.Customf("牛只: %d,不是母牛", cowInfo.Id)
  112. }
  113. operationUser, err := s.GetSystemUserById(ctx, int64(item.OperationId))
  114. if err != nil {
  115. zaplog.Error("PregnantCheckDataCheck", zap.Any("id", item.OperationId), zap.Any("error", err.Error()))
  116. return nil, xerr.Customf("获取操作人员信息失败")
  117. }
  118. // 过滤掉没有配种状态的牛只
  119. if cowInfo.BreedStatus != pasturePb.BreedStatus_Breeding && cowInfo.BreedStatus != pasturePb.BreedStatus_Pregnant {
  120. return nil, xerr.Customf("牛只: %s 未参加配种,不能进行孕检", cowInfo.EarNumber)
  121. }
  122. if cowInfo.LastMatingAt <= 0 {
  123. return nil, xerr.Customf("牛只: %s,最近一次配种数据异常", cowInfo.EarNumber)
  124. }
  125. itemEventPregnantCheck, err := s.FindEventPregnantCheckIsExIstByCowId(ctx, cowInfo)
  126. if err != nil {
  127. return nil, xerr.WithStack(err)
  128. }
  129. if itemEventPregnantCheck.Id <= 0 {
  130. return nil, xerr.Customf("未发现该牛只: %s 孕检数据", cowInfo.EarNumber)
  131. }
  132. lastEventMating, err := s.FindLastEventMatingByCowId(ctx, pastureId, cowInfo.Id)
  133. if err != nil {
  134. return nil, xerr.WithStack(err)
  135. }
  136. if lastEventMating == nil || lastEventMating.Status == pasturePb.IsShow_No {
  137. return nil, xerr.Customf("未发现该牛只: %s 配种数据", cowInfo.EarNumber)
  138. }
  139. pregnantCheckBatchModelList = append(pregnantCheckBatchModelList, &PregnantCheckBatchModel{
  140. Cow: cowInfo,
  141. OperationUser: operationUser,
  142. PregnantCheckAt: item.PregnantCheckAt,
  143. PregnantCheckMethod: item.PregnantCheckMethod,
  144. PregnantCheckResult: item.PregnantCheckResult,
  145. Remarks: item.Remarks,
  146. EventPregnancyCheck: itemEventPregnantCheck,
  147. LastMating: lastEventMating,
  148. })
  149. }
  150. return pregnantCheckBatchModelList, nil
  151. }
  152. func (s *StoreEntry) EstrusCheckDataCheck(ctx context.Context, userModel *model.UserModel, items []*pasturePb.EventNaturalEstrusItems) ([]*model.EventEstrus, []*model.EventMating, error) {
  153. eventEstrusList := make([]*model.EventEstrus, 0)
  154. eventMatingList := make([]*model.EventMating, 0)
  155. unMatingReasonsMap := s.UnMatingReasonsMap()
  156. for _, item := range items {
  157. cowInfo, err := s.GetCowInfoByCowId(ctx, userModel.AppPasture.Id, int64(item.CowId))
  158. if err != nil {
  159. return nil, nil, xerr.Custom("牛只信息不存在")
  160. }
  161. if cowInfo.Sex != pasturePb.Genders_Female {
  162. return nil, nil, xerr.Custom("该牛只不是母牛")
  163. }
  164. existsEventEstrus, isExists, err := s.FindEventEstrusByCowId(ctx, userModel.AppPasture.Id, int64(item.CowId))
  165. if err != nil {
  166. return nil, nil, xerr.WithStack(err)
  167. }
  168. // 如果存在,并且是脖环揭发则跳过
  169. if isExists {
  170. if existsEventEstrus.ExposeEstrusType == pasturePb.ExposeEstrusType_Neck_Ring {
  171. zaplog.Info("EventNaturalEstrusBatch", zap.Any("existsEventEstrus", existsEventEstrus), zap.Any("item", item))
  172. continue
  173. }
  174. realityDay := time.Unix(existsEventEstrus.RealityDay, 0).Format(model.LayoutDate2)
  175. planDay := time.Unix(int64(item.EstrusAt), 0).Format(model.LayoutDate2)
  176. if realityDay == planDay {
  177. return nil, nil, xerr.Customf("该牛只:%d,今天已经提交过发情数据", item.CowId)
  178. }
  179. }
  180. operationUser, _ := s.GetSystemUserById(ctx, int64(item.OperationId))
  181. item.OperationName = operationUser.Name
  182. newEventEstrus := model.NewEventEstrus(userModel.AppPasture.Id, cowInfo, pasturePb.ExposeEstrusType_Natural_Estrus,
  183. pasturePb.IsShow_Ok, item.IsMating, item.EstrusAt, operationUser, userModel.SystemUser)
  184. fmt.Println("item.IsMating", item.IsMating, item.UnMatingReasonsKind)
  185. if item.IsMating == pasturePb.IsShow_Ok {
  186. newEventMating := model.NewEventMating(userModel.AppPasture.Id, cowInfo, time.Now().Unix(), pasturePb.ExposeEstrusType_Natural_Estrus)
  187. eventMatingList = append(eventMatingList, newEventMating)
  188. } else {
  189. newEventEstrus.UnMatingReasonsKind = item.UnMatingReasonsKind
  190. newEventEstrus.UnMatingReasonsName = unMatingReasonsMap[item.UnMatingReasonsKind]
  191. }
  192. newEventEstrus.Remarks = item.Remarks
  193. eventEstrusList = append(eventEstrusList, newEventEstrus)
  194. }
  195. return eventEstrusList, eventMatingList, nil
  196. }