indicators_data.go 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137
  1. package model
  2. import (
  3. "fmt"
  4. "sort"
  5. pasturePb "gitee.com/xuyiping_admin/go_proto/proto/go/backend/cow"
  6. )
  7. const (
  8. AllCow = "all_cow" // 全群牛头数
  9. AdultCow = "adult_cow" // 成母牛头数
  10. AvgCalvingInterval = "avg_calving_interval" // 产犊间隔
  11. OutputNumber = "output_number" // 出栏量(销售)
  12. InputNumber = "input_number" // 入栏量(购入)
  13. SalesVolume = "sales_volume" // 销售额
  14. CalvingNumber = "calving_number" // 产犊事件总数
  15. AdultAbortionRate = "adult_abortion_rate" //成母牛流产率(全)
  16. YouthAbortionRate = "youth_abortion_rate" //青年年流产率(全)
  17. AllDieNumber = "all_die_number"
  18. DiseaseNumber = "disease_number"
  19. CureNumber = "cure_number"
  20. OutNumber = "out_number"
  21. CalfDieNumber = "calf_die_number"
  22. LactationCow = "lactation_cow"
  23. DryMilkCow = "dry_milk_cow" // 干奶牛头数
  24. ReserveCow = "reserve_cow" // 后备牛头数
  25. FirstBornSurvivalRate = "first_born_survival_rate" // 头胎牛接产成活率
  26. FirstBornDeathRate = "first_born_death_rate" // 头胎牛接产死亡率
  27. MultiparitySurvivalRate = "multiparity_survival_rate" // 成母牛接产成活率
  28. MultiparityDeathRate = "multiparity_death_rate" // 成母牛接产死亡率
  29. AvgAgeFirstMate = "avg_age_first_mate" // 平均首配日龄
  30. YouthPregnantRate = "youth_pregnant_rate" // 后备牛怀孕率
  31. MultiparityPregnantRate = "multiparity_pregnant_rate" // 成母牛怀孕率
  32. MultipartyFirstCheckRate = "multiparty_first_check_rate" //成母牛初检有胎率
  33. MultipartySecondCheckRate = "multiparty_second_check_rate" // 成母牛复检有胎率
  34. YouthFirstCheckRate = "youth_first_check_rate" // 后备牛初检有胎率
  35. YouthSecondCheckRate = "youth_second_check_rate" // 后备牛复检有胎率
  36. ForbiddenCowNumber = "forbidden_cow_number" // 禁配牛总数
  37. AvgRegistrationDays = "avg_registration_days" // 平均配准天数
  38. AvgPregnancyDays = "avg_pregnancy_days" // 平均怀孕天数
  39. AvgGestationalAge = "avg_gestational_age" // 平均受孕日龄
  40. Month17UnPregnancyRate = "month17_un_pregnancy_rate" // 17月未孕比例
  41. Month20UnPregnancyRate = "month20_un_pregnancy_rate" // 20月未孕比例
  42. Multiparty150DaysUnPregnancyRate = "multiparty_150_days_un_pregnancy_rate" // 成母牛150天未孕比例
  43. MultipartyAbortionNumber = "multiparty_abortion_number" // 成母牛流产头数
  44. MultipartyAbortionRate = "multiparty_abortion_rate" // 成母牛流产率(全)
  45. MultipartyPregnancyNumber = "multiparty_pregnancy_number" // 成母牛怀孕头数
  46. MultipartyOutNumber = "multiparty_out_number" // 成母牛淘汰头数
  47. MultipartyDieNumber = "multiparty_die_number" // 成母牛死亡头数
  48. Calving60DieRate = "calving60_die_rate" // 产后60天死亡率
  49. Calving60OutRate = "calving60_out_rate" // 产后60天淘汰率
  50. AvgDepartureWeight = "avg_departure_weight" // 出栏均重
  51. AvgSlaughterCycle = "avg_slaughter_cycle" // 平均出栏周期
  52. SurvivalLiveRate = "survival_live_rate" // 接产成活率
  53. StillbirthRate = "stillbirth_rate" // 死胎率
  54. FemaleCalfRate = "female_calf_rate" // 母犊率
  55. WeaningDailyWeight = "weaning_daily_weight" // 断奶日增重
  56. Day60DieRate = "day60_die_rate" // 60日龄死亡率
  57. )
  58. type IndicatorsData struct {
  59. Id int64 `json:"id"`
  60. PastureId int64 `json:"pastureId"`
  61. CategoryType pasturePb.IndicatorType_Kind `json:"categoryType"`
  62. CategoryName string `json:"categoryName"`
  63. Date string `json:"date"`
  64. Kind string `json:"kind"`
  65. Value string `json:"value"`
  66. CreatedAt int64 `json:"createdAt"`
  67. UpdatedAt int64 `json:"updatedAt"`
  68. }
  69. func (d *IndicatorsData) TableName() string {
  70. return "indicators_data"
  71. }
  72. type IndicatorsDataSlice []*IndicatorsData
  73. func (i IndicatorsDataSlice) ToPB(header, kinds []string, detailsMap map[string]*IndicatorsDetails) *IndicatorComparison {
  74. res := &IndicatorComparison{
  75. Headers: header,
  76. List: make([]map[string]string, 0),
  77. }
  78. if len(header) <= 0 || len(detailsMap) <= 0 || len(kinds) <= 0 || len(i) <= 0 {
  79. return res
  80. }
  81. sort.Strings(res.Headers) // 确保日期顺序一致
  82. indicatorsDataMap := make(map[string]*IndicatorsData)
  83. for _, v := range i {
  84. indicatorsDataMap[fmt.Sprintf("%s-%s", v.Kind, v.Date)] = v
  85. }
  86. dataMap := make(map[string]map[string]string)
  87. for _, kind := range kinds {
  88. if dataMap[kind] == nil {
  89. dataMap[kind] = make(map[string]string)
  90. }
  91. details := detailsMap[kind]
  92. dataMap[kind] = map[string]string{
  93. "name": details.Name,
  94. "kind": details.Kind,
  95. "unit": details.Unit,
  96. "categoryType": fmt.Sprintf("%d", details.CategoryType),
  97. "categoryName": details.CategoryName,
  98. "zh": details.Zh,
  99. }
  100. for _, v := range header {
  101. pref := fmt.Sprintf("%s-%s", kind, v)
  102. indicators, ok := indicatorsDataMap[pref]
  103. if ok {
  104. dataMap[kind][v] = indicators.Value
  105. } else {
  106. dataMap[kind][v] = ""
  107. }
  108. }
  109. }
  110. for _, data := range dataMap {
  111. res.List = append(res.List, data)
  112. }
  113. return res
  114. }
  115. type IndicatorsComparisonResponse struct {
  116. Code int32 `json:"code"`
  117. Msg string `json:"msg"`
  118. Data *IndicatorComparison `json:"data"`
  119. }
  120. type IndicatorComparison struct {
  121. Headers []string `json:"headers"`
  122. List []map[string]string `json:"list"`
  123. }