indicators.go 7.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279
  1. package backend
  2. import (
  3. "context"
  4. "fmt"
  5. "kpt-pasture/model"
  6. "kpt-pasture/util"
  7. "net/http"
  8. pasturePb "gitee.com/xuyiping_admin/go_proto/proto/go/backend/cow"
  9. "gitee.com/xuyiping_admin/pkg/xerr"
  10. )
  11. func (s *StoreEntry) IndicatorsComparison(ctx context.Context, req *pasturePb.IndicatorsComparisonRequest) (*model.IndicatorsComparisonResponse, error) {
  12. userModel, err := s.GetUserModel(ctx)
  13. if err != nil {
  14. return nil, xerr.WithStack(err)
  15. }
  16. indicatorsDataList := make([]*model.IndicatorsData, 0)
  17. pref := s.DB.Model(new(model.IndicatorsData)).
  18. Where("pasture_id = ?", userModel.AppPasture.Id)
  19. dataRange, err := util.GetMonthsBetween(req.DateList[0], req.DateList[1])
  20. if err != nil {
  21. return nil, xerr.WithStack(err)
  22. }
  23. pref.Where("date IN (?)", dataRange)
  24. if req.CategoryKind > 0 {
  25. pref.Where("category_type = ?", req.CategoryKind)
  26. }
  27. if len(req.KindList) > 0 {
  28. pref.Where("kind IN (?)", req.KindList)
  29. }
  30. if err = pref.Order("date,kind").Find(&indicatorsDataList).Error; err != nil {
  31. return nil, xerr.WithStack(err)
  32. }
  33. indicatorsDetailsMap, kinds, err := s.GetIndicatorsDetailsMap(ctx)
  34. if req.CategoryKind > 0 {
  35. if len(req.KindList) <= 0 {
  36. kinds = kinds[:0]
  37. }
  38. for _, v := range indicatorsDetailsMap {
  39. if v.CategoryType != req.CategoryKind {
  40. delete(indicatorsDetailsMap, v.Kind)
  41. } else {
  42. kinds = append(kinds, v.Kind)
  43. }
  44. }
  45. }
  46. if len(req.KindList) > 0 {
  47. kinds = req.KindList
  48. }
  49. if err != nil {
  50. return nil, xerr.WithStack(err)
  51. }
  52. return &model.IndicatorsComparisonResponse{
  53. Code: http.StatusOK,
  54. Msg: "ok",
  55. Data: model.IndicatorsDataSlice(indicatorsDataList).ToPB(dataRange, kinds, indicatorsDetailsMap),
  56. }, nil
  57. }
  58. func (s *StoreEntry) GetIndicatorsDetailsMap(ctx context.Context) (map[string]*model.IndicatorsDetails, []string, error) {
  59. indicatorsDetails := make(map[string]*model.IndicatorsDetails)
  60. indicatorsDetailsList, err := s.FindIndicatorsDetailsList()
  61. if err != nil {
  62. return nil, nil, xerr.WithStack(err)
  63. }
  64. kinds := make([]string, 0)
  65. for _, v := range indicatorsDetailsList {
  66. indicatorsDetails[v.Kind] = v
  67. kinds = append(kinds, v.Kind)
  68. }
  69. return indicatorsDetails, kinds, err
  70. }
  71. func (s *StoreEntry) GetIndicatorsDataByDate(pastureId int64, Kind, date string) (*model.IndicatorsData, error) {
  72. res := &model.IndicatorsData{}
  73. if err := s.DB.Model(new(model.IndicatorsData)).
  74. Where("pasture_id = ?", pastureId).
  75. Where("kind = ?", Kind).
  76. Where("date = ?", date).
  77. First(&res).Error; err != nil {
  78. return nil, xerr.WithStack(err)
  79. }
  80. return res, nil
  81. }
  82. func (s *StoreEntry) LongTermInfertility(ctx context.Context, req *pasturePb.LongTermInfertilityRequest, pagination *pasturePb.PaginationModel) (*pasturePb.LongTermInfertilityResponse, error) {
  83. userModel, err := s.GetUserModel(ctx)
  84. if err != nil {
  85. return nil, xerr.WithStack(err)
  86. }
  87. cowList := make([]*model.Cow, 0)
  88. pref := s.DB.Model(new(model.Cow)).
  89. Where("pasture_id = ?", userModel.AppPasture.Id).
  90. Where("calving_age > ?", req.CalvingAge).
  91. Where("breed_status != ?", pasturePb.BreedStatus_Pregnant)
  92. if req.EarNumber != "" {
  93. pref.Where("ear_number = ?", req.EarNumber)
  94. }
  95. if req.PenId > 0 {
  96. pref.Where("pen_id = ?", req.PenId)
  97. }
  98. var count int64
  99. if err = pref.Model(new(model.Cow)).
  100. Order("id desc").
  101. Count(&count).Limit(int(pagination.PageSize)).
  102. Offset(int(pagination.PageOffset)).
  103. Find(&cowList).Error; err != nil {
  104. return nil, xerr.WithStack(err)
  105. }
  106. breedStatusMap := s.CowBreedStatusMap()
  107. return &pasturePb.LongTermInfertilityResponse{
  108. Code: http.StatusOK,
  109. Msg: "ok",
  110. Data: &pasturePb.LongTermInfertilityData{
  111. List: model.CowSlice(cowList).LongTermInfertilityToPB(breedStatusMap),
  112. Total: int32(count),
  113. PageSize: pagination.PageSize,
  114. Page: pagination.Page,
  115. },
  116. }, nil
  117. }
  118. func (s *StoreEntry) AlreadySale(ctx context.Context, req *pasturePb.AlreadySalesReportRequest, pagination *pasturePb.PaginationModel) (*pasturePb.AlreadySalesReportResponse, error) {
  119. userModel, err := s.GetUserModel(ctx)
  120. if err != nil {
  121. return nil, xerr.WithStack(err)
  122. }
  123. pastureId := userModel.AppPasture.Id
  124. eventSaleList := make([]*model.EventSale, 0)
  125. pref := s.DB.Table(fmt.Sprintf("%s AS a", new(model.EventSale).TableName())).
  126. Select("a.id,a.dealer_name,a.sale_kind,a.sale_price,a.sale_all_weight,a.sale_all_amount,sale_cow_count,a.sale_at,a.remarks").
  127. Joins(fmt.Sprintf("JOIN %s AS b on b.sale_id = a.id", new(model.EventSaleCow).TableName())).
  128. Where("a.pasture_id = ?", pastureId).
  129. Where("a.sale_at BETWEEN ? AND ?", req.StartAt, req.EndAt)
  130. if req.BatchNumber != "" {
  131. pref.Where("b.batch_number = ?", req.BatchNumber)
  132. }
  133. if len(req.PenId) > 0 {
  134. pref.Where("b.pen_id IN ?", req.PenId)
  135. }
  136. if req.CowKind > pasturePb.CowKind_Invalid {
  137. pref.Where("b.cow_kind = ?", req.CowKind)
  138. }
  139. if err = pref.
  140. Limit(int(pagination.PageSize)).
  141. Offset(int(pagination.PageOffset)).
  142. Group("a.id").
  143. Find(&eventSaleList).Error; err != nil {
  144. return nil, xerr.WithStack(err)
  145. }
  146. result := &pasturePb.AlreadySalesReportResponse{
  147. Code: http.StatusOK,
  148. Msg: "ok",
  149. Data: &pasturePb.AlreadySalesReportData{
  150. List: make([]*pasturePb.AlreadySalesReport, 0),
  151. Total: 0,
  152. PageSize: pagination.PageSize,
  153. Page: pagination.Page,
  154. },
  155. }
  156. if len(eventSaleList) <= 0 {
  157. return result, nil
  158. }
  159. saleIds := make([]int64, 0)
  160. eventSaleMap := make(map[int64]*model.EventSale)
  161. for _, v := range eventSaleList {
  162. saleIds = append(saleIds, v.Id)
  163. eventSaleMap[v.Id] = v
  164. }
  165. eventSaleCowList := make([]*model.EventSaleCow, 0)
  166. if err = s.DB.Model(new(model.EventSaleCow)).
  167. Where("sale_id IN ?", saleIds).
  168. Where("pasture_id = ?", pastureId).
  169. Find(&eventSaleCowList).Error; err != nil {
  170. return nil, xerr.WithStack(err)
  171. }
  172. cowIds := make([]int64, 0)
  173. for _, v := range eventSaleCowList {
  174. cowIds = append(cowIds, v.CowId)
  175. }
  176. cowList := make([]*model.Cow, 0)
  177. if err = s.DB.Model(new(model.Cow)).
  178. Where("id IN ?", cowIds).
  179. Where("pasture_id = ?", pastureId).
  180. Find(&cowList).Error; err != nil {
  181. return nil, xerr.WithStack(err)
  182. }
  183. cowMap := make(map[int64]*model.Cow)
  184. for _, v := range cowList {
  185. cowMap[v.Id] = v
  186. }
  187. sourceMap := s.CowSourceMap()
  188. cowKindMap := s.CowKindMap()
  189. result.Data.Total = int32(len(eventSaleCowList))
  190. result.Data.List = model.EventSaleCowSlice(eventSaleCowList).ToPB(eventSaleMap, cowKindMap, cowMap, sourceMap)
  191. return result, nil
  192. }
  193. func (s *StoreEntry) CanSale(ctx context.Context, req *pasturePb.CanSalesReportRequest, pagination *pasturePb.PaginationModel) (*pasturePb.CanSalesReportResponse, error) {
  194. userModel, err := s.GetUserModel(ctx)
  195. if err != nil {
  196. return nil, xerr.WithStack(err)
  197. }
  198. pastureId := userModel.AppPasture.Id
  199. cowList := make([]*model.Cow, 0)
  200. var count int64
  201. pref := s.DB.Model(new(model.Cow)).
  202. Where("pasture_id = ?", pastureId).
  203. Where("current_weight BETWEEN ? AND ?", req.WeightStart*1000, req.WeightEnd*1000)
  204. if req.BatchNumber != "" {
  205. pref.Where("batch_number = ?", req.BatchNumber)
  206. }
  207. if req.CowKind > pasturePb.CowKind_Invalid {
  208. pref.Where("cow_kind = ?", req.CowKind)
  209. }
  210. if len(req.PenId) > 0 {
  211. pref.Where("pen_id IN ?", req.PenId)
  212. }
  213. if err = pref.Count(&count).
  214. Limit(int(pagination.PageSize)).
  215. Offset(int(pagination.PageOffset)).
  216. Find(&cowList).Error; err != nil {
  217. return nil, xerr.WithStack(err)
  218. }
  219. result := &pasturePb.CanSalesReportResponse{
  220. Code: http.StatusOK,
  221. Msg: "ok",
  222. Data: &pasturePb.CanSalesReportData{
  223. List: make([]*pasturePb.CanSalesReport, 0),
  224. Total: 0,
  225. PageSize: pagination.PageSize,
  226. Page: pagination.Page,
  227. },
  228. }
  229. if len(cowList) <= 0 {
  230. return result, nil
  231. }
  232. cowKindMap := s.CowKindMap()
  233. result.Data.Total = int32(count)
  234. result.Data.List = model.CowSlice(cowList).CanSaleToPB(cowKindMap)
  235. return result, nil
  236. }