edb_info_refresh.go 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241
  1. package data_manage
  2. import (
  3. "eta/eta_api/models"
  4. "eta/eta_api/models/data_manage"
  5. "eta/eta_api/utils"
  6. "fmt"
  7. )
  8. // RefreshSourceList
  9. // @Title 获取指标刷新配置的来源接口
  10. // @Description 获取指标刷新配置的来源接口
  11. // @Success Ret=200 获取成功
  12. // @router /edb_info/refresh/source_list [get]
  13. func (c *EdbInfoController) RefreshSourceList() {
  14. br := new(models.BaseResponse).Init()
  15. defer func() {
  16. c.Data["json"] = br
  17. c.ServeJSON()
  18. }()
  19. item := data_manage.EdbRefreshSource{}
  20. tmpList, err := item.GetAllList()
  21. if err != nil {
  22. br.Msg = "获取失败"
  23. br.ErrMsg = "获取刷新数据源失败, Err: " + err.Error()
  24. return
  25. }
  26. list := make([]data_manage.EdbRefreshSourceList, 0)
  27. tmpMap := make(map[int]data_manage.EdbRefreshSourceList, 0)
  28. for _, v := range tmpList {
  29. tmp, ok := tmpMap[v.Source]
  30. if ok {
  31. continue
  32. }
  33. tmp = data_manage.EdbRefreshSourceList{
  34. Source: v.Source,
  35. SourceName: v.SourceName,
  36. //SubSource: v.SubSource,
  37. //SubSourceName: v.SubSourceName,
  38. Child: make([]data_manage.EdbRefreshSourceList, 0),
  39. HasChild: v.HasChild,
  40. }
  41. if v.HasChild == 1 {
  42. for _, v2 := range tmpList {
  43. if v2.Source == v.Source {
  44. tmp.Child = append(tmp.Child, data_manage.EdbRefreshSourceList{
  45. Source: v.Source,
  46. SourceName: v.SourceName,
  47. SubSource: v.SubSource,
  48. SubSourceName: v.SubSourceName,
  49. HasChild: 0,
  50. })
  51. }
  52. }
  53. }
  54. tmpMap[v.Source] = tmp
  55. list = append(list, tmp)
  56. }
  57. br.Ret = 200
  58. br.Success = true
  59. br.Msg = "获取成功"
  60. br.Data = list
  61. }
  62. // RefreshClassifyList
  63. // @Title 获取指标分类列表接口
  64. // @Description 获取指标分类列表接口
  65. // @Param Source query int true "来源:1:同花顺,2:wind,3:彭博"
  66. // @Success Ret=200 获取成功
  67. // @router /edb_info/refresh/classify_list [get]
  68. func (c *EdbInfoController) RefreshClassifyList() {
  69. br := new(models.BaseResponse).Init()
  70. defer func() {
  71. c.Data["json"] = br
  72. c.ServeJSON()
  73. }()
  74. source, _ := c.GetInt("Source", utils.DATA_SOURCE_MYSTEEL_CHEMICAL)
  75. list := make([]*data_manage.BaseClassifyItems, 0)
  76. switch source {
  77. case utils.DATA_SOURCE_MYSTEEL_CHEMICAL: // 钢联
  78. rootList, err := data_manage.GetBaseFromMysteelChemicalClassifyByParentId(0)
  79. if err != nil && err.Error() != utils.ErrNoRow() {
  80. br.Msg = "获取失败"
  81. br.ErrMsg = "获取数据失败,Err:" + err.Error()
  82. return
  83. }
  84. classifyAll, err := data_manage.GetAllBaseFromMysteelChemicalClassify()
  85. if err != nil && err.Error() != utils.ErrNoRow() {
  86. br.Msg = "获取失败"
  87. br.ErrMsg = "获取数据失败,Err:" + err.Error()
  88. return
  89. }
  90. rootChildMap := make(map[int][]*data_manage.BaseClassifyItems)
  91. for _, v := range classifyAll {
  92. //tmpList, ok := rootChildMap[v.ParentId]
  93. //if !ok {
  94. // tmpList = make([]data_manage.BaseClassifyItems, 0)
  95. //}
  96. //tmpList = append(tmpList, data_manage.BaseClassifyItems{
  97. // ClassifyId: v.BaseFromMysteelChemicalClassifyId,
  98. // ClassifyName: v.ClassifyName,
  99. // ParentId: v.ParentId,
  100. // UniqueCode: fmt.Sprint(v.BaseFromMysteelChemicalClassifyId),
  101. // Children: nil,
  102. //})
  103. //rootChildMap[v.ParentId] = tmpList
  104. rootChildMap[v.ParentId] = append(rootChildMap[v.ParentId], &data_manage.BaseClassifyItems{
  105. ClassifyId: v.BaseFromMysteelChemicalClassifyId,
  106. ClassifyName: v.ClassifyName,
  107. ParentId: v.ParentId,
  108. UniqueCode: fmt.Sprint(v.BaseFromMysteelChemicalClassifyId),
  109. Children: nil,
  110. })
  111. }
  112. for _, v := range rootList {
  113. tmp := &data_manage.BaseClassifyItems{
  114. ClassifyId: v.BaseFromMysteelChemicalClassifyId,
  115. ClassifyName: v.ClassifyName,
  116. ParentId: v.ParentId,
  117. UniqueCode: fmt.Sprint(v.BaseFromMysteelChemicalClassifyId),
  118. Children: nil,
  119. }
  120. if existItems, ok := rootChildMap[v.BaseFromMysteelChemicalClassifyId]; ok {
  121. tmp.Children = existItems
  122. } else {
  123. items := make([]*data_manage.BaseClassifyItems, 0)
  124. tmp.Children = items
  125. }
  126. list = append(list, tmp)
  127. }
  128. case utils.DATA_SOURCE_YS: // 有色
  129. list = append(list, &data_manage.BaseClassifyItems{
  130. ClassifyId: 0,
  131. ClassifyName: "未分类",
  132. ParentId: 0,
  133. UniqueCode: fmt.Sprint(0),
  134. Children: nil,
  135. })
  136. rootList, err := data_manage.GetBaseFromSmmClassifyByParentId(0)
  137. if err != nil && err.Error() != utils.ErrNoRow() {
  138. br.Msg = "获取失败"
  139. br.ErrMsg = "获取数据失败,Err:" + err.Error()
  140. return
  141. }
  142. classifyAll, err := data_manage.GetAllBaseFromSmmClassify()
  143. if err != nil && err.Error() != utils.ErrNoRow() {
  144. br.Msg = "获取失败"
  145. br.ErrMsg = "获取数据失败,Err:" + err.Error()
  146. return
  147. }
  148. rootChildMap := make(map[int][]*data_manage.BaseClassifyItems)
  149. for _, v := range classifyAll {
  150. rootChildMap[v.ParentId] = append(rootChildMap[v.ParentId], &data_manage.BaseClassifyItems{
  151. ClassifyId: v.ClassifyId,
  152. ClassifyName: v.ClassifyName,
  153. ParentId: v.ParentId,
  154. UniqueCode: fmt.Sprint(v.ClassifyId),
  155. Children: nil,
  156. })
  157. }
  158. for _, v := range rootList {
  159. tmp := &data_manage.BaseClassifyItems{
  160. ClassifyId: v.ClassifyId,
  161. ClassifyName: v.ClassifyName,
  162. ParentId: v.ParentId,
  163. UniqueCode: fmt.Sprint(v.ClassifyId),
  164. Children: nil,
  165. }
  166. if existItems, ok := rootChildMap[v.ClassifyId]; ok {
  167. tmp.Children = existItems
  168. } else {
  169. items := make([]*data_manage.BaseClassifyItems, 0)
  170. tmp.Children = items
  171. }
  172. list = append(list, tmp)
  173. }
  174. default:
  175. tmpList, err := data_manage.GetAllEdbClassify()
  176. if err != nil && err.Error() != utils.ErrNoRow() {
  177. br.Msg = "获取失败"
  178. br.ErrMsg = "获取数据失败,Err:" + err.Error()
  179. return
  180. }
  181. for _, v := range tmpList {
  182. list = append(list, &data_manage.BaseClassifyItems{
  183. ClassifyId: v.ClassifyId,
  184. ClassifyName: v.ClassifyName,
  185. ParentId: v.ParentId,
  186. UniqueCode: fmt.Sprint(v.ClassifyId),
  187. Children: nil,
  188. })
  189. }
  190. list = buildTree(list, 0)
  191. //fmt.Println(result)
  192. }
  193. br.Ret = 200
  194. br.Success = true
  195. br.Msg = "获取成功"
  196. br.Data = list
  197. }
  198. // 生成多层级列表的函数
  199. // 生成多层级列表的递归函数
  200. func buildTree(items []*data_manage.BaseClassifyItems, parentId int) []*data_manage.BaseClassifyItems {
  201. var result []*data_manage.BaseClassifyItems
  202. // 遍历所有分类项
  203. for i := range items {
  204. // 找到当前节点的子节点
  205. if items[i].ParentId == parentId {
  206. // 递归构建子节点的子节点
  207. items[i].Children = buildTree(items, items[i].ClassifyId)
  208. // 将当前节点添加到结果中
  209. result = append(result, items[i])
  210. }
  211. }
  212. return result
  213. }