event_cow_log.go 8.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220
  1. package backend
  2. import (
  3. "context"
  4. "fmt"
  5. "kpt-pasture/model"
  6. "kpt-pasture/util"
  7. "strconv"
  8. "strings"
  9. "gitee.com/xuyiping_admin/pkg/xerr"
  10. pasturePb "gitee.com/xuyiping_admin/go_proto/proto/go/backend/cow"
  11. )
  12. func (s *StoreEntry) SubmitEventLog(ctx context.Context, pastureId int64, cow *model.Cow, eventType pasturePb.EventType_Kind, req interface{}) *model.EventCowLog {
  13. var (
  14. desc, remarks = "", ""
  15. eventTypeName = s.EventTypeMap()[eventType]
  16. eventAt = int64(0)
  17. eventCategoryMap = s.eventCategoryMap()
  18. penMap = s.PenMap(ctx, pastureId)
  19. cowTypeMap = s.CowTypeMap()
  20. operationUser = &model.SystemUser{}
  21. )
  22. switch eventType {
  23. case pasturePb.EventType_Enter:
  24. data := req.(*pasturePb.EventEnterRequest)
  25. eventAt = int64(data.EnterAt)
  26. remarks = data.Remarks
  27. sourceMap := s.CowSourceMap()
  28. sex := "公"
  29. if data.Sex == pasturePb.Genders_Female {
  30. sex = "母"
  31. }
  32. desc = fmt.Sprintf("性别: %s; 栏舍: %s; 体重: %s kg; 价格: %s; 来源: %s;", sex, penMap[cow.PenId].Name,
  33. strconv.FormatFloat(float64(data.Weight), 'f', 2, 64),
  34. strconv.FormatFloat(float64(data.Price), 'f', 2, 64), sourceMap[cow.SourceKind])
  35. case pasturePb.EventType_Transfer_Ben:
  36. data := req.(*model.EventTransferGroup)
  37. transferAt, _ := util.TimeParseLocal(model.LayoutTime, data.TransferDate)
  38. eventAt = transferAt.Unix()
  39. remarks = data.Remarks
  40. operationUser.Id = data.OperationId
  41. operationUser.Name = data.OperationName
  42. desc = fmt.Sprintf("转出栏舍: %s; 转入栏舍: %s", penMap[data.PenOutId].Name, penMap[data.PenInId].Name)
  43. case pasturePb.EventType_Body_Score:
  44. case pasturePb.EventType_Disease:
  45. data := req.(*model.EventCowDisease)
  46. eventAt = data.DiseaseAt
  47. remarks = data.Remarks
  48. operationUser.Id = int64(data.OperationId)
  49. operationUser.Name = data.OperationName
  50. desc = fmt.Sprintf("疾病名称: %s; 状态: 治疗中;", data.DiseaseName)
  51. case pasturePb.EventType_Pregnancy_Check:
  52. data := req.(*PregnantCheckBatchModel)
  53. eventAt = int64(data.PregnantCheckAt)
  54. if data.PregnantCheckResult == pasturePb.PregnantCheckResult_Pregnant {
  55. desc += fmt.Sprintf("孕检方式: %s; 孕检结果: %s", s.PregnantCheckMethodMap()[data.PregnantCheckMethod], s.MatingResultMap()[pasturePb.MatingResult_Pregnant])
  56. }
  57. if data.PregnantCheckResult == pasturePb.PregnantCheckResult_UnPregnant {
  58. desc += fmt.Sprintf("孕检方式: %s", s.PregnantCheckMethodMap()[data.PregnantCheckMethod])
  59. if cow.BreedStatus == pasturePb.BreedStatus_Abort {
  60. desc += fmt.Sprintf("; 复检结果: %s", s.MatingResultMap()[pasturePb.MatingResult_Abort])
  61. }
  62. if cow.BreedStatus == pasturePb.BreedStatus_Empty {
  63. desc += fmt.Sprintf("; 孕检结果: %s", s.MatingResultMap()[pasturePb.MatingResult_Empty])
  64. }
  65. }
  66. operationUser.Id = data.OperationUser.Id
  67. operationUser.Name = data.OperationUser.Name
  68. remarks = data.Remarks
  69. case pasturePb.EventType_Estrus:
  70. data := req.(*model.EventEstrus)
  71. eventAt = data.PlanDay
  72. isMating := "否"
  73. if data.IsMating == pasturePb.IsShow_Ok {
  74. isMating = "是"
  75. }
  76. desc = fmt.Sprintf("发情揭发方式:%s;是否配种:%s;", s.ExposeEstrusTypeMap()[data.ExposeEstrusType], isMating)
  77. operationUser.Id = data.OperationId
  78. operationUser.Name = data.OperationName
  79. remarks = data.Remarks
  80. case pasturePb.EventType_Calving:
  81. data := req.(*pasturePb.EventCalving)
  82. eventAt = int64(data.CalvingAt)
  83. desc = fmt.Sprintf("怀孕天数:%d;难产等级: %s;产子数量: %d;", cow.PregnancyAge, s.CalvingLevelMap()[data.CalvingLevel], data.ChildNumber)
  84. if data.CalvingLevel > pasturePb.CalvingLevel_Natural_Childbirth {
  85. desc += fmt.Sprintf("难产原因: %s", s.DystociaReasonMap()[data.DystociaReason])
  86. }
  87. ly, qy, die := 0, 0, 0
  88. earNumber := ""
  89. if len(data.CalfItemList) > 0 {
  90. for _, v := range data.CalfItemList {
  91. if v.IsLive == pasturePb.IsShow_Ok && v.IsAdoption == pasturePb.IsShow_No {
  92. qy++
  93. }
  94. if v.IsLive == pasturePb.IsShow_No {
  95. die++
  96. }
  97. if v.IsAdoption == pasturePb.IsShow_Ok {
  98. ly++
  99. earNumber += fmt.Sprintf("犊牛耳号: %s,出生体重: %s KG;", v.EarNumber, strconv.FormatFloat(float64(v.Weight), 'f', 2, 64))
  100. }
  101. }
  102. }
  103. desc += fmt.Sprintf("留养: %d个 %s;弃养: %d; 死亡: %d个", ly, earNumber, qy, die)
  104. operationUser.Id = int64(data.OperationId)
  105. operationUser.Name = data.OperationName
  106. remarks = data.Remarks
  107. case pasturePb.EventType_Seme_Time:
  108. data := req.(*pasturePb.EventSameTime)
  109. eventAt = int64(data.SameTimeAt)
  110. desc = fmt.Sprintf("同期名称: %s;激素名称: %s;剂量:%f;操作人: %s", data.SameTimeTypeName, data.DrugsName, data.Usage, data.OperationName)
  111. operationUser.Id = int64(data.OperationId)
  112. operationUser.Name = data.OperationName
  113. remarks = data.Remarks
  114. case pasturePb.EventType_Mating:
  115. data := req.(*model.EventMatingCheckBatchModel)
  116. eventAt = data.MatingAt
  117. desc = fmt.Sprintf("配种公牛: %s;配种结果:未知", data.FrozenSemen.BullId)
  118. operationUser.Id = data.OperationUser.Id
  119. operationUser.Name = data.OperationUser.Name
  120. remarks = data.Remarks
  121. case pasturePb.EventType_Birth:
  122. eventAt = cow.BirthAt
  123. desc = fmt.Sprintf("出生体重: %s KG;母号:%s;父号: %s", strconv.FormatFloat(float64(cow.BirthWeight)/1000, 'f', 2, 64), cow.MotherNumber, cow.FatherNumber)
  124. case pasturePb.EventType_Death:
  125. data := req.(*model.EventDeparture)
  126. eventAt = data.DepartureAt
  127. desc = fmt.Sprintf("死亡原因: %s", data.ReasonName)
  128. operationUser.Id = data.OperationId
  129. operationUser.Name = data.OperationName
  130. case pasturePb.EventType_Transfer_Out:
  131. case pasturePb.EventType_Transfer_In:
  132. case pasturePb.EventType_Out:
  133. data := req.(*model.EventDeparture)
  134. eventAt = data.DepartureAt
  135. desc = fmt.Sprintf("淘汰原因: %s", data.ReasonName)
  136. operationUser.Id = data.OperationId
  137. operationUser.Name = data.OperationName
  138. case pasturePb.EventType_Immunication:
  139. data := req.(*model.EventImmunizationPlan)
  140. eventAt = data.RealityDay
  141. desc = fmt.Sprintf("免疫名称: %s;药物名称: %s;剂量: %d %s", data.PlanName, data.DrugsName, data.Usage, data.UnitName)
  142. operationUser.Id = data.OperationId
  143. operationUser.Name = data.OperationName
  144. case pasturePb.EventType_Weaning:
  145. data := req.(*pasturePb.EventWeaningBatch)
  146. eventAt = int64(data.WeaningAt)
  147. operationUser.Id = int64(data.OperationId)
  148. operationUser.Name = data.OperationName
  149. remarks = data.Remarks
  150. for _, v := range data.Items {
  151. if int64(v.CowId) == cow.Id {
  152. desc = fmt.Sprintf("具体体重: %s", strconv.FormatFloat(float64(v.Weight), 'f', 2, 64))
  153. break
  154. }
  155. }
  156. case pasturePb.EventType_Sale:
  157. data := req.(*pasturePb.EventCowSale)
  158. eventAt = int64(data.SaleAt)
  159. for _, v := range data.CowIds {
  160. if int64(v) == cow.Id {
  161. desc = fmt.Sprintf("经销商: %s,单价: %s", data.DealerName, strconv.FormatFloat(float64(data.SalePrice), 'f', 2, 64))
  162. break
  163. }
  164. }
  165. case pasturePb.EventType_Abort:
  166. data := req.(*AbortionCheckBatchModel)
  167. eventAt = data.EventAbortion.AbortionAt
  168. operationUser.Id = data.OperationUser.Id
  169. operationUser.Name = data.OperationUser.Name
  170. remarks = data.EventAbortion.Remarks
  171. desc = fmt.Sprintf("流产原因: %s", data.EventAbortion.AbortionReasonsName)
  172. case pasturePb.EventType_Weight:
  173. data := req.(*pasturePb.EventWeight)
  174. eventAt = int64(data.WeightAt)
  175. operationUser.Id = int64(data.OperationId)
  176. operationUser.Name = data.OperationName
  177. remarks = data.Remarks
  178. desc = fmt.Sprintf("日龄: %d;体重: %s kg", cow.DayAge, strconv.FormatFloat(float64(data.Weight), 'f', 2, 64))
  179. case pasturePb.EventType_Castrated:
  180. case pasturePb.EventType_Insect_Repellent:
  181. }
  182. newEventCowLogModel := &model.EventCowLogModel{
  183. Cow: cow,
  184. CowTypeName: cowTypeMap[cow.CowType],
  185. OperationUser: operationUser,
  186. EventCategoryKind: eventCategoryMap[eventType],
  187. EventAt: eventAt,
  188. EventType: eventType,
  189. EventTypeName: eventTypeName,
  190. Description: desc,
  191. Remarks: remarks,
  192. PenName: penMap[cow.PenId].Name,
  193. }
  194. return model.NewEventCowLog(newEventCowLogModel)
  195. }
  196. func (s *StoreEntry) UpdateMatingResultEventCowLogByCowId(ctx context.Context, cowId int64, newResult string) error {
  197. newEventCowLog := &model.EventCowLog{CowId: cowId}
  198. if err := s.DB.Table(newEventCowLog.TableName()).
  199. Where("cow_id = ?", cowId).
  200. Where("event_category_kind = ?", pasturePb.EventCategory_Breed).
  201. Where("event_type = ?", pasturePb.EventType_Mating).
  202. Order("id desc").
  203. First(newEventCowLog).Error; err != nil {
  204. return xerr.WithStack(err)
  205. } else {
  206. desc := strings.ReplaceAll(newEventCowLog.EventDescription, "未知", newResult)
  207. if err = s.DB.Table(newEventCowLog.TableName()).
  208. Where("id = ?", newEventCowLog.Id).
  209. Update("event_description", desc).Error; err != nil {
  210. return xerr.WithStack(err)
  211. }
  212. }
  213. return nil
  214. }