statistic_service.go 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615
  1. package backend
  2. import (
  3. "bytes"
  4. "context"
  5. "encoding/json"
  6. "fmt"
  7. "kpt-tmr-group/model"
  8. "kpt-tmr-group/pkg/logger/zaplog"
  9. "kpt-tmr-group/pkg/xerr"
  10. operationPb "kpt-tmr-group/proto/go/backend/operation"
  11. "net/http"
  12. "sort"
  13. "github.com/xuri/excelize/v2"
  14. "go.uber.org/zap"
  15. )
  16. type PastureClientHandler func(ctx context.Context, pastureId int64, body interface{}) error
  17. // PastureDetailById 获取指定牧场详情
  18. func (s *StoreEntry) PastureDetailById(ctx context.Context, pastureId int64) (*model.GroupPasture, error) {
  19. result := &model.GroupPasture{Id: pastureId}
  20. if err := s.DB.Where("is_delete = ? and is_show = ?", operationPb.IsShow_OK, operationPb.IsShow_OK).First(result).Error; err != nil {
  21. return nil, xerr.WithStack(err)
  22. }
  23. return result, nil
  24. }
  25. func (s *StoreEntry) PastureHttpClient(ctx context.Context, apiUrl string, pastureId int64, body, response interface{}) error {
  26. pastureDetail, err := s.PastureDetailById(ctx, pastureId)
  27. if err != nil {
  28. zaplog.Error("SearchFormulaEstimateList", zap.Any("Err", err), zap.Int64("pastureId", pastureId))
  29. return xerr.Customf("该牧场数据错误,Err:%s", err)
  30. }
  31. pastureClient := model.NewPastureClient(pastureDetail)
  32. url := fmt.Sprintf("%s/%s", pastureDetail.Domain, apiUrl)
  33. result, err := pastureClient.DoPost(url, body)
  34. if err != nil {
  35. return xerr.WithStack(err)
  36. }
  37. zaplog.Info("PastureHttpClient", zap.String("url", url), zap.Any("request", body), zap.String("response", string(result)))
  38. if err = json.Unmarshal(result, response); err != nil {
  39. return xerr.WithStack(err)
  40. }
  41. return nil
  42. }
  43. // SearchFormulaEstimateList 配方评估
  44. func (s *StoreEntry) SearchFormulaEstimateList(ctx context.Context, req *operationPb.SearchFormulaEstimateRequest) (*model.PastureCommonResponse, error) {
  45. body := &model.PastureCommonRequest{
  46. Name: req.ApiName,
  47. Page: req.Pagination.Page,
  48. Offset: req.Pagination.PageOffset,
  49. PageCount: req.Pagination.PageSize,
  50. ReturnType: "Map",
  51. ParamMaps: &model.FormulaEstimateParams{
  52. PastureId: fmt.Sprintf("%d", req.PastureId),
  53. StartTime: req.StartTime,
  54. StopTime: req.EndTime,
  55. Search: fmt.Sprintf("%d", req.SearchType),
  56. TempletId: fmt.Sprintf("%d", req.TemplateId),
  57. Barid: fmt.Sprintf("%d", req.BarnId),
  58. },
  59. }
  60. response := &model.PastureCommonResponse{Data: &model.PastureCommonData{}}
  61. if err := s.PastureHttpClient(ctx, model.UrlDataByName, int64(req.PastureId), body, response); err != nil {
  62. return nil, xerr.WithStack(err)
  63. }
  64. return response, nil
  65. }
  66. // SearchInventoryStatistics 库存管理-库存统计
  67. func (s *StoreEntry) SearchInventoryStatistics(ctx context.Context, req *operationPb.SearchInventoryStatisticsRequest) (*model.PastureCommonResponse, error) {
  68. body := &model.PastureCommonRequest{
  69. Name: req.ApiName,
  70. Page: req.Pagination.Page,
  71. Offset: req.Pagination.PageOffset,
  72. PageCount: req.Pagination.PageSize,
  73. ReturnType: "Map",
  74. ParamMaps: &model.InventoryStatisticsParams{
  75. PastureId: fmt.Sprintf("%d", req.PastureId),
  76. StartTime: req.StartTime,
  77. StopTime: req.EndTime,
  78. FeedName: req.FeedName,
  79. },
  80. }
  81. response := &model.PastureCommonResponse{
  82. Data: &model.PastureCommonData{
  83. List: make([]*model.InventoryStatisticsList, 0),
  84. },
  85. }
  86. if err := s.PastureHttpClient(ctx, model.UrlDataByName, int64(req.PastureId), body, response); err != nil {
  87. return nil, xerr.WithStack(err)
  88. }
  89. return response, nil
  90. }
  91. // InventoryStatisticsExcelExport 库存管理-库存统计-报表导出
  92. func (s *StoreEntry) InventoryStatisticsExcelExport(ctx context.Context, req *operationPb.SearchInventoryStatisticsRequest) (*bytes.Buffer, error) {
  93. result, err := s.SearchInventoryStatistics(ctx, req)
  94. if err != nil {
  95. return nil, xerr.WithStack(err)
  96. }
  97. b, _ := json.Marshal(result.Data.List)
  98. inventoryStatisticsList := make([]*model.InventoryStatisticsList, 0)
  99. if err = json.Unmarshal(b, &inventoryStatisticsList); err != nil {
  100. return nil, xerr.Customf("牧场端返回数据错误")
  101. }
  102. file := excelize.NewFile()
  103. defer file.Close()
  104. streamWriter, err := file.NewStreamWriter(model.DefaultSheetName)
  105. if err != nil {
  106. return nil, xerr.WithStack(err)
  107. }
  108. // 表头
  109. titles := map[string][]interface{}{
  110. "A1": {"饲料名称", "期初", nil, "用料", nil, nil, nil, "期末"},
  111. "A2": {nil, "期初库存(kg)", "期初金额(元)", "入库重量(kg)", "系统出库重量(kg)", "人工用料重量(kg)", "损耗重量", "期末库存(kg)", "期末金额(kg)"},
  112. }
  113. for cell, values := range titles {
  114. if err = streamWriter.SetRow(cell, values); err != nil {
  115. return nil, xerr.WithStack(err)
  116. }
  117. }
  118. for i, item := range inventoryStatisticsList {
  119. cell, err := excelize.CoordinatesToCellName(1, i+3)
  120. if err != nil {
  121. zaplog.Error("InventoryStatisticsExcelExport CoordinatesToCellName", zap.Any("Err", err))
  122. continue
  123. }
  124. row := make([]interface{}, 0)
  125. row = append(row, item.FeedName, item.StartSum, item.StartPrice, item.LaidSum, item.UseSumXT, item.UseSumRG, item.UseSumXH, item.StopSum, item.StopPrice)
  126. if err = streamWriter.SetRow(cell, row); err != nil {
  127. return nil, xerr.WithStack(err)
  128. }
  129. }
  130. hvCell := map[string]string{
  131. "A1": "A2",
  132. "B1": "C1",
  133. "D1": "G1",
  134. "H1": "I1",
  135. }
  136. // 合并单元格
  137. for h, v := range hvCell {
  138. if err = streamWriter.MergeCell(h, v); err != nil {
  139. return nil, xerr.WithStack(err)
  140. }
  141. }
  142. // 修改样式
  143. /*style1, err := file.NewStyle(&excelize.Style{
  144. Fill: excelize.Fill{Type: "pattern", Color: []string{"#DFEBF6"}, Pattern: 1},
  145. Alignment: &excelize.Alignment{Horizontal: "center"},
  146. })
  147. if err != nil {
  148. return nil, xerr.WithStack(err)
  149. }
  150. style1, err := file.NewStyle(&excelize.Style{
  151. //Fill: excelize.Fill{Type: "pattern", Color: []string{"#DFEBF6"}, Pattern: 1},
  152. Alignment: &excelize.Alignment{Horizontal: "center"},
  153. })
  154. if err != nil {
  155. return nil, xerr.WithStack(err)
  156. }
  157. if err = file.SetCellStyle(model.DefaultSheetName, "A1", "A1", style1); err != nil {
  158. return nil, xerr.WithStack(err)
  159. }*/
  160. if err = streamWriter.Flush(); err != nil {
  161. return nil, xerr.WithStack(err)
  162. }
  163. return file.WriteToBuffer()
  164. }
  165. // SearchUserMaterialsStatistics 库存管理-用料分析
  166. func (s *StoreEntry) SearchUserMaterialsStatistics(ctx context.Context, req *operationPb.SearchUserMaterialsStatisticsRequest) (*model.PastureCommonResponse, error) {
  167. body := &model.PastureCommonRequest{
  168. Name: req.ApiName,
  169. Page: req.Pagination.Page,
  170. Offset: req.Pagination.PageOffset,
  171. PageCount: req.Pagination.PageSize,
  172. ReturnType: "Map",
  173. Checked: req.ErrorCheck,
  174. ParamMaps: &model.UserMaterialsStatisticsParams{
  175. PastureId: fmt.Sprintf("%d", req.PastureId),
  176. StartTime: req.StartTime,
  177. StopTime: req.EndTime,
  178. FeedName: req.FeedName,
  179. Typea: fmt.Sprintf("%d", req.TypeCheck),
  180. },
  181. }
  182. response := &model.PastureCommonResponse{Data: &model.PastureCommonData{
  183. List: &model.UserMaterialsList{},
  184. }}
  185. if err := s.PastureHttpClient(ctx, model.UrlReportForm, int64(req.PastureId), body, response); err != nil {
  186. return nil, xerr.WithStack(err)
  187. }
  188. return response, nil
  189. }
  190. func (s *StoreEntry) UserMaterialsStatisticsExcelExport(ctx context.Context, req *operationPb.SearchUserMaterialsStatisticsRequest) (*bytes.Buffer, error) {
  191. result, err := s.SearchUserMaterialsStatistics(ctx, req)
  192. if err != nil {
  193. return nil, xerr.WithStack(err)
  194. }
  195. b, _ := json.Marshal(result.Data.List)
  196. userMaterialsList := &model.UserMaterialsList{}
  197. if err = json.Unmarshal(b, userMaterialsList); err != nil {
  198. return nil, xerr.Customf("牧场端返回数据错误")
  199. }
  200. file := excelize.NewFile()
  201. defer file.Close()
  202. streamWriter, err := file.NewStreamWriter(model.DefaultSheetName)
  203. if err != nil {
  204. return nil, xerr.WithStack(err)
  205. }
  206. // 表数据
  207. excelValuesList := map[int][]interface{}{}
  208. cProp := make([]string, 0)
  209. for _, data2 := range userMaterialsList.Data2 {
  210. excelValuesList[1] = append(excelValuesList[1], data2.Label)
  211. for _, c := range data2.Children {
  212. excelValuesList[2] = append(excelValuesList[2], c.Label)
  213. cProp = append(cProp, c.Prop)
  214. }
  215. }
  216. for cell, values := range excelValuesList {
  217. if err = streamWriter.SetRow(fmt.Sprintf("A%d", cell), values); err != nil {
  218. return nil, xerr.WithStack(err)
  219. }
  220. delete(excelValuesList, cell)
  221. }
  222. for i, data1 := range userMaterialsList.Data1 {
  223. data1Map, ok := data1.(map[string]interface{})
  224. if ok {
  225. for _, prop := range cProp {
  226. newValue := ""
  227. if value, yes := data1Map[prop]; yes {
  228. if value != nil {
  229. switch v := value.(type) {
  230. case string:
  231. newValue = v
  232. case int, int8, int16, int32, int64, uint, uint8, uint16, uint32, uint64:
  233. newValue = fmt.Sprintf("%d", v)
  234. default:
  235. newValue = fmt.Sprintf("%v", v)
  236. }
  237. }
  238. excelValuesList[i+3] = append(excelValuesList[i+3], newValue)
  239. }
  240. }
  241. }
  242. }
  243. excelValuesKeys := make([]int, 0)
  244. for k, _ := range excelValuesList {
  245. excelValuesKeys = append(excelValuesKeys, k)
  246. }
  247. sort.Ints(excelValuesKeys)
  248. for _, v := range excelValuesKeys {
  249. if err = streamWriter.SetRow(fmt.Sprintf("A%d", v), excelValuesList[v]); err != nil {
  250. return nil, xerr.WithStack(err)
  251. }
  252. }
  253. if err = streamWriter.Flush(); err != nil {
  254. return nil, xerr.WithStack(err)
  255. }
  256. return file.WriteToBuffer()
  257. }
  258. // SearchPriceStatistics 库存管理-价格分析
  259. func (s *StoreEntry) SearchPriceStatistics(ctx context.Context, req *operationPb.SearchPriceStatisticsRequest) (*model.PastureCommonResponse, error) {
  260. body := &model.PastureCommonRequest{
  261. Name: req.ApiName,
  262. Page: req.Pagination.Page,
  263. Offset: req.Pagination.PageOffset,
  264. PageCount: req.Pagination.PageSize,
  265. ReturnType: "Map",
  266. ParamMaps: &model.PriceStatisticsParams{
  267. PastureId: fmt.Sprintf("%d", req.PastureId),
  268. StartTime: req.StartTime,
  269. StopTime: req.EndTime,
  270. FeedName: req.FeedName,
  271. },
  272. }
  273. response := &model.PastureCommonResponse{Data: &model.PastureCommonData{}}
  274. if err := s.PastureHttpClient(ctx, model.UrlReportForm, int64(req.PastureId), body, response); err != nil {
  275. return nil, xerr.WithStack(err)
  276. }
  277. return response, nil
  278. }
  279. // SearchFeedStatistics 饲喂效率-效率统计
  280. func (s *StoreEntry) SearchFeedStatistics(ctx context.Context, req *operationPb.SearchFeedStatisticsRequest) (*model.PastureCommonResponse, error) {
  281. body := &model.PastureCommonRequest{
  282. Name: req.ApiName,
  283. Page: req.Pagination.Page,
  284. Offset: req.Pagination.PageOffset,
  285. PageCount: req.Pagination.PageSize,
  286. ReturnType: "Map",
  287. ParamMaps: &model.FeedStatisticsParams{
  288. PastureId: fmt.Sprintf("%d", req.PastureId),
  289. StartTime: req.StartTime,
  290. StopTime: req.StartTime,
  291. Date: req.StartTime,
  292. FeedTName: req.FormulaTemplate,
  293. BarName: req.BarnName,
  294. CowClass: req.CattleCategoryName,
  295. Times: fmt.Sprintf("%d", req.ClassNumber),
  296. },
  297. }
  298. response := &model.PastureCommonResponse{Data: &model.PastureCommonData{}}
  299. if err := s.PastureHttpClient(ctx, model.UrlDataByName, int64(req.PastureId), body, response); err != nil {
  300. return nil, xerr.WithStack(err)
  301. }
  302. return response, nil
  303. }
  304. // FeedChartStatistics 饲喂效率图表分析
  305. func (s *StoreEntry) FeedChartStatistics(ctx context.Context, req *operationPb.FeedChartStatisticsRequest) (*model.PastureCommonResponse, error) {
  306. body := &model.FeedChartParams{
  307. ParamMaps: &model.ParamMaps{
  308. PastureId: fmt.Sprintf("%d", req.PastureId),
  309. StartTime: req.StartTime,
  310. StopTime: req.StartTime,
  311. Status: req.Status,
  312. },
  313. }
  314. url, ok := model.UrlChart[req.ApiType]
  315. if !ok {
  316. return nil, xerr.Customf("错误的接口类型:%s", req.ApiType)
  317. }
  318. response := &model.PastureCommonResponse{Data: &model.PastureCommonData{}}
  319. if err := s.PastureHttpClient(ctx, url, int64(req.PastureId), body, response); err != nil {
  320. return nil, xerr.WithStack(err)
  321. }
  322. return response, nil
  323. }
  324. // CowsAnalysis 饲喂效率-牛群评估
  325. func (s *StoreEntry) CowsAnalysis(ctx context.Context, req *operationPb.CowsAnalysisRequest) (*model.PastureCommonResponse, error) {
  326. body := &model.PastureCommonRequest{
  327. Name: req.ApiName,
  328. Page: req.Pagination.Page,
  329. Offset: req.Pagination.PageOffset,
  330. PageCount: req.Pagination.PageSize,
  331. ReturnType: "Map",
  332. ParamMaps: &model.MixFeedStatisticsParams{
  333. PastureId: fmt.Sprintf("%d", req.PastureId),
  334. StartTime: req.StartTime,
  335. StopTime: req.StartTime,
  336. },
  337. }
  338. response := &model.PastureCommonResponse{Data: &model.PastureCommonData{}}
  339. if err := s.PastureHttpClient(ctx, model.UrlDataByName, int64(req.PastureId), body, response); err != nil {
  340. return nil, xerr.WithStack(err)
  341. }
  342. return response, nil
  343. }
  344. // SearchAccuracyAggStatistics 准确性分析-汇总分析
  345. func (s *StoreEntry) SearchAccuracyAggStatistics(ctx context.Context, req *operationPb.AccuracyAggStatisticsRequest) (*model.PastureCommonResponse, error) {
  346. body := &model.FeedChartParams{
  347. ParamMaps: &model.AccuracyAggParams{
  348. PastureId: fmt.Sprintf("%d", req.PastureId),
  349. StartTime: req.StartTime,
  350. StopTime: req.EndTime,
  351. FName: req.Fname,
  352. Sort: req.Sort,
  353. Status: req.Status,
  354. Times: req.Times,
  355. Genre: req.Genre,
  356. IsDate: req.Isdate,
  357. Hlwc1: req.Hlwc1,
  358. Hlwc2: req.Hlwc2,
  359. Hlzq1: req.Hlzq1,
  360. Hlzq2: req.Hlzq2,
  361. Hlzql1: req.Hlzql1,
  362. Hlzql2: req.Hlzql2,
  363. Slwc1: req.Slwc1,
  364. Slwc2: req.Slwc2,
  365. Slzq1: req.Slzq1,
  366. Slzq2: req.Slzq2,
  367. Slzql1: req.Slzql1,
  368. Slzql2: req.Slzql2,
  369. Error: req.IsError,
  370. },
  371. }
  372. response := &model.PastureCommonResponse{Data: &model.PastureCommonData{}}
  373. if err := s.PastureHttpClient(ctx, model.UrlSummary, int64(req.PastureId), body, response); err != nil {
  374. return nil, xerr.WithStack(err)
  375. }
  376. return response, nil
  377. }
  378. // SearchMixFeedStatistics 准确性分析-混料统计
  379. func (s *StoreEntry) SearchMixFeedStatistics(ctx context.Context, req *operationPb.MixFeedStatisticsRequest) (*model.PastureCommonResponse, error) {
  380. times := ""
  381. if req.ClassNumber > 0 {
  382. times = fmt.Sprintf("%d", req.ClassNumber)
  383. }
  384. body := &model.PastureCommonRequest{
  385. Name: req.ApiName,
  386. Page: req.Pagination.Page,
  387. Offset: req.Pagination.PageOffset,
  388. PageCount: req.Pagination.PageSize,
  389. ReturnType: "Map",
  390. ParamMaps: &model.MixFeedStatisticsParams{
  391. PastureId: fmt.Sprintf("%d", req.PastureId),
  392. StartTime: req.StartTime,
  393. StopTime: req.StartTime,
  394. TmrTName: req.EquipmentName,
  395. ProjName: req.TrainNumber,
  396. Times: times,
  397. ButtonType: req.ButtonType,
  398. TempletName: req.FormulationName,
  399. Isuse: req.IsUse,
  400. Hlwc1: req.Hlwc1,
  401. Hlwc2: req.Hlwc2,
  402. Hlzq1: req.Hlzq1,
  403. Hlzq2: req.Hlzq2,
  404. Hlzql1: req.Hlzql1,
  405. Hlzql2: req.Hlzql2,
  406. Error: req.IsError,
  407. },
  408. }
  409. response := &model.PastureCommonResponse{Data: &model.PastureCommonData{}}
  410. if err := s.PastureHttpClient(ctx, model.UrlDataByName, int64(req.PastureId), body, response); err != nil {
  411. return nil, xerr.WithStack(err)
  412. }
  413. return response, nil
  414. }
  415. // SearchSprinkleStatistics 准确性分析-撒料统计
  416. func (s *StoreEntry) SearchSprinkleStatistics(ctx context.Context, req *operationPb.SprinkleStatisticsRequest) (*model.PastureCommonResponse, error) {
  417. times := ""
  418. if req.ClassNumber > 0 {
  419. times = fmt.Sprintf("%d", req.ClassNumber)
  420. }
  421. body := &model.PastureCommonRequest{
  422. Name: req.ApiName,
  423. Page: req.Pagination.Page,
  424. Offset: req.Pagination.PageOffset,
  425. PageCount: req.Pagination.PageSize,
  426. ReturnType: "Map",
  427. ParamMaps: &model.SprinkleStatisticsParams{
  428. PastureId: fmt.Sprintf("%d", req.PastureId),
  429. StartTime: req.StartTime,
  430. StopTime: req.StartTime,
  431. TmrTName: req.EquipmentName,
  432. ProjName: req.TrainNumber,
  433. Times: times,
  434. ButtonType: req.ButtonType,
  435. TempletName: req.FormulationName,
  436. Isuse: req.IsUse,
  437. Fname: req.BarnName,
  438. Slwc1: req.Slwc1,
  439. Slwc2: req.Slwc2,
  440. Slzq2: req.Slzq2,
  441. Slzq1: req.Slzq1,
  442. Slzql1: req.Slzql1,
  443. Slzql2: req.Slzql2,
  444. Error: req.IsError,
  445. },
  446. }
  447. response := &model.PastureCommonResponse{Data: &model.PastureCommonData{}}
  448. if err := s.PastureHttpClient(ctx, model.UrlDataByName, int64(req.PastureId), body, response); err != nil {
  449. return nil, xerr.WithStack(err)
  450. }
  451. return response, nil
  452. }
  453. // SearchProcessAnalysis 过程分析
  454. func (s *StoreEntry) SearchProcessAnalysis(ctx context.Context, req *operationPb.ProcessAnalysisRequest) (*model.PastureCommonResponse, error) {
  455. body := &model.PastureCommonRequest{
  456. Name: req.ApiName,
  457. Page: req.Pagination.Page,
  458. Offset: req.Pagination.PageOffset,
  459. PageCount: req.Pagination.PageSize,
  460. ReturnType: "Map",
  461. ParamMaps: &model.ProcessAnalysisParams{
  462. PastureId: fmt.Sprintf("%d", req.PastureId),
  463. StartTime: req.StartTime,
  464. StopTime: req.StartTime,
  465. TmrTName: req.TmrName,
  466. IsCompleted: "",
  467. LpPlanType: fmt.Sprintf("%d", req.PlanType),
  468. FClassId: req.MixFeedType,
  469. Hlzq1: req.Hlzq1,
  470. Hlzq2: req.Hlzq2,
  471. Hlwc1: req.Hlwc1,
  472. Hlwc2: req.Hlwc2,
  473. Slwc1: req.Slwc1,
  474. Slwc2: req.Slwc2,
  475. Slzq2: req.Slzq2,
  476. Slzq1: req.Slzq1,
  477. Error: req.ErrorRange,
  478. },
  479. }
  480. response := &model.PastureCommonResponse{Data: &model.PastureCommonData{}}
  481. if err := s.PastureHttpClient(ctx, model.UrlProcess, int64(req.PastureId), body, response); err != nil {
  482. return nil, xerr.WithStack(err)
  483. }
  484. return response, nil
  485. }
  486. // GetDataByName 共同接口
  487. func (s *StoreEntry) GetDataByName(ctx context.Context, req *operationPb.GetDataByNameRequest) (*model.PastureCommonResponse, error) {
  488. body := &model.PastureCommonRequest{
  489. Name: req.ApiName,
  490. ParamMaps: &model.GetDataByNameParams{
  491. PastureId: fmt.Sprintf("%d", req.PastureId),
  492. StartTime: req.StartTime,
  493. StopTime: req.StartTime,
  494. },
  495. }
  496. response := &model.PastureCommonResponse{Data: &model.PastureCommonData{}}
  497. if err := s.PastureHttpClient(ctx, model.UrlDataByName, int64(req.PastureId), body, response); err != nil {
  498. return nil, xerr.WithStack(err)
  499. }
  500. return response, nil
  501. }
  502. // GetTrainNumber 获取班次
  503. func (s *StoreEntry) GetTrainNumber(ctx context.Context, req *operationPb.TrainNumberRequest) (*operationPb.TrainNumberResponse, error) {
  504. body := &model.PastureCommonRequest{
  505. Name: req.ApiName,
  506. Page: req.Pagination.Page,
  507. Offset: req.Pagination.PageOffset,
  508. PageCount: req.Pagination.PageSize,
  509. ReturnType: "Map",
  510. ParamMaps: &model.TrainNumberParams{
  511. PastureId: fmt.Sprintf("%d", req.PastureId),
  512. InfoRName: req.InfoName,
  513. },
  514. }
  515. response := &model.PastureCommonResponse{Data: &model.PastureCommonData{}}
  516. if err := s.PastureHttpClient(ctx, model.UrlDataByName, int64(req.PastureId), body, response); err != nil {
  517. return nil, xerr.WithStack(err)
  518. }
  519. result := &operationPb.TrainNumberResponse{
  520. Code: http.StatusOK,
  521. Msg: "ok",
  522. Data: &operationPb.TrainNumberData{List: make([]*operationPb.FormulaOptionEnum, 0)},
  523. }
  524. if response.Data.List == nil {
  525. return result, nil
  526. }
  527. b, _ := json.Marshal(response.Data.List)
  528. trainNumberList := make([]*model.TrainNumberList, 0)
  529. if err := json.Unmarshal(b, &trainNumberList); err != nil {
  530. return nil, xerr.WithStack(err)
  531. }
  532. formulaOption := make([]*operationPb.FormulaOptionEnum, 0)
  533. if len(trainNumberList) > 0 {
  534. infoValue := trainNumberList[0].InfoValue
  535. switch infoValue {
  536. case "1":
  537. formulaOption = append(formulaOption, &operationPb.FormulaOptionEnum{
  538. Value: 1,
  539. Label: "第一班",
  540. })
  541. case "2":
  542. formulaOption = append(formulaOption, &operationPb.FormulaOptionEnum{
  543. Value: 1,
  544. Label: "第一班",
  545. }, &operationPb.FormulaOptionEnum{
  546. Value: 2,
  547. Label: "第二班",
  548. })
  549. case "3":
  550. formulaOption = append(formulaOption, &operationPb.FormulaOptionEnum{
  551. Value: 1,
  552. Label: "第一班",
  553. }, &operationPb.FormulaOptionEnum{
  554. Value: 2,
  555. Label: "第二班",
  556. }, &operationPb.FormulaOptionEnum{
  557. Value: 3,
  558. Label: "第三班",
  559. })
  560. }
  561. }
  562. result.Data.List = formulaOption
  563. return result, nil
  564. }