chart_info.go 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143
  1. package data_manage
  2. import (
  3. "fmt"
  4. "github.com/beego/beego/v2/client/orm"
  5. "hongze/hongze_chart_lib/utils"
  6. )
  7. // GetChartInfoRefreshData 获取图表关联的指标信息
  8. func GetChartInfoRefreshData(chartInfoId int) (baseEdbInfoArr, calculateInfoArr []*EdbInfo, err error) {
  9. o := orm.NewOrmUsingDB("data")
  10. sql := ` SELECT b.* FROM chart_edb_mapping AS a
  11. INNER JOIN edb_info AS b ON a.edb_info_id=b.edb_info_id
  12. WHERE a.chart_info_id=? `
  13. edbInfoList := make([]*EdbInfo, 0)
  14. _, err = o.Raw(sql, chartInfoId).QueryRows(&edbInfoList)
  15. if err != nil {
  16. return
  17. }
  18. for _, v := range edbInfoList {
  19. fmt.Println(v.EdbInfoId, v.EdbType)
  20. if v.EdbType == 1 {
  21. baseEdbInfoArr = append(baseEdbInfoArr, v)
  22. } else {
  23. calculateInfoArr = append(calculateInfoArr, v)
  24. newBaseEdbInfoArr, newCalculateInfoArr, err := GetChartRefreshEdbInfo(v.EdbInfoId, v.Source, 0)
  25. if err != nil {
  26. return baseEdbInfoArr, calculateInfoArr, err
  27. }
  28. baseEdbInfoArr = append(baseEdbInfoArr, newBaseEdbInfoArr...)
  29. calculateInfoArr = append(calculateInfoArr, newCalculateInfoArr...)
  30. }
  31. }
  32. return
  33. }
  34. func GetChartRefreshEdbInfo(edbInfoId, source, n int) (baseEdbInfoArr, calculateInfoArr []*EdbInfo, err error) {
  35. calculateList, err := GetEdbInfoCalculateMap(edbInfoId, source)
  36. if err != nil && err.Error() != utils.ErrNoRow() {
  37. return
  38. }
  39. n++
  40. for _, item := range calculateList {
  41. fmt.Println(item.EdbInfoId)
  42. if item.EdbType == 1 {
  43. baseEdbInfoArr = append(baseEdbInfoArr, item)
  44. } else {
  45. calculateInfoArr = append(calculateInfoArr, item)
  46. if n > 10 {
  47. return
  48. }
  49. newBaseEdbInfoArr, newCalculateInfoArr, _ := GetChartRefreshEdbInfo(item.EdbInfoId, item.Source, n)
  50. baseEdbInfoArr = append(baseEdbInfoArr, newBaseEdbInfoArr...)
  51. calculateInfoArr = append(calculateInfoArr, newCalculateInfoArr...)
  52. }
  53. }
  54. return
  55. }
  56. type ChartEdbInfoMapping struct {
  57. EdbInfoId int `description:"指标id"`
  58. SourceName string `description:"来源名称"`
  59. Source int `description:"来源id"`
  60. EdbCode string `description:"指标编码"`
  61. EdbName string `description:"指标名称"`
  62. EdbAliasName string `description:"指标名称(别名)"`
  63. EdbNameEn string `description:"英文指标名称"`
  64. EdbAliasNameEn string `description:"英文指标名称(别名)"`
  65. EdbType int `description:"指标类型:1:基础指标,2:计算指标"`
  66. Frequency string `description:"频率"`
  67. FrequencyEn string `description:"英文频率"`
  68. Unit string `description:"单位"`
  69. UnitEn string `description:"英文单位"`
  70. StartDate string `description:"起始日期"`
  71. EndDate string `description:"终止日期"`
  72. ModifyTime string `description:"指标最后更新时间"`
  73. ChartEdbMappingId int `description:"图表指标id"`
  74. ChartInfoId int `description:"图表id"`
  75. MaxData float64 `description:"上限"`
  76. MinData float64 `description:"下限"`
  77. IsOrder bool `description:"true:正序,false:逆序"`
  78. IsAxis int `description:"1:左轴,0:右轴"`
  79. EdbInfoType int `description:"1:标准指标,0:领先指标"`
  80. EdbInfoCategoryType int `description:"0:普通指标,1:预测指标"`
  81. LeadValue int `description:"领先值"`
  82. LeadUnit string `description:"领先单位"`
  83. LeadUnitEn string `description:"领先英文单位"`
  84. ChartStyle string `description:"图表类型"`
  85. ChartColor string `description:"颜色"`
  86. PredictChartColor string `description:"预测数据的颜色"`
  87. ChartWidth float64 `description:"线条大小"`
  88. ChartType int `description:"生成样式:1:曲线图,2:季节性图,3:面积图,4:柱状图,5:散点图,6:组合图"`
  89. LatestDate string `description:"数据最新日期"`
  90. LatestValue float64 `description:"数据最新值"`
  91. UniqueCode string `description:"指标唯一编码"`
  92. MinValue float64 `json:"-" description:"最小值"`
  93. MaxValue float64 `json:"-" description:"最大值"`
  94. DataList interface{}
  95. IsNullData bool `json:"-" description:"是否空数据"`
  96. }
  97. func GetChartEdbMappingList(chartInfoId int) (list []*ChartEdbInfoMapping, err error) {
  98. o := orm.NewOrmUsingDB("data")
  99. sql := ` SELECT a.*,b.source_name,b.source,b.edb_code,b.edb_name,b.edb_name_en,b.frequency,b.unit,b.unit_en,b.start_date,b.end_date,b.modify_time,b.latest_date,b.latest_value,b.unique_code,b.edb_info_type AS edb_info_category_type
  100. FROM chart_edb_mapping AS a
  101. INNER JOIN edb_info AS b ON a.edb_info_id=b.edb_info_id
  102. WHERE chart_info_id=?
  103. ORDER BY chart_edb_mapping_id ASC `
  104. _, err = o.Raw(sql, chartInfoId).QueryRows(&list)
  105. return
  106. }
  107. // BarChartInfoReq 柱方图预览请求数据
  108. type BarChartInfoReq struct {
  109. EdbInfoIdList []BarChartInfoEdbItemReq `description:"指标信息"`
  110. DateList []BarChartInfoDateReq `description:"日期配置"`
  111. Sort BarChartInfoSortReq `description:"排序"`
  112. }
  113. // BarChartInfoEdbItemReq 柱方图预览请求数据(指标相关)
  114. type BarChartInfoEdbItemReq struct {
  115. EdbInfoId int `description:"指标ID"`
  116. Name string `description:"别名"`
  117. NameEn string `description:"英文别名"`
  118. Source int `description:"1:ETA图库;2:商品价格"`
  119. }
  120. // BarChartInfoDateReq 柱方图预览请求数据(日期相关)
  121. type BarChartInfoDateReq struct {
  122. Type int `description:"配置类型"`
  123. Date string `description:"固定日期"`
  124. Value int `description:"N天的值"`
  125. Color string `description:"颜色"`
  126. Name string `description:"别名"`
  127. }
  128. // BarChartInfoSortReq 柱方图预览请求数据(排序相关)
  129. type BarChartInfoSortReq struct {
  130. Sort int `description:"排序类型,0:默认,1:升序,2:降序"`
  131. DateIndex int `description:"日期数据的下标,从0开始"`
  132. }