classify.go 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142
  1. package line_feature
  2. import (
  3. "eta/eta_mobile/controllers"
  4. "eta/eta_mobile/models"
  5. "eta/eta_mobile/models/data_manage"
  6. "eta/eta_mobile/models/system"
  7. "eta/eta_mobile/services/data"
  8. "eta/eta_mobile/utils"
  9. )
  10. // LineFeaturesChartClassifyController 统计特征图表分类
  11. type LineFeaturesChartClassifyController struct {
  12. controllers.BaseAuthController
  13. }
  14. // ChartClassifyList
  15. // @Title 统计特征图表分类列表
  16. // @Description 统计特征图表分类列表接口
  17. // @Param IsShowMe query bool true "是否只看我的,true、false"
  18. // @Param Source query int true "图表类型,3:统计特征,4:滚动统计特征"
  19. // @Success 200 {object} data_manage.ChartClassifyListResp
  20. // @router /chart_classify/list [get]
  21. func (this *LineFeaturesChartClassifyController) ChartClassifyList() {
  22. br := new(models.BaseResponse).Init()
  23. defer func() {
  24. this.Data["json"] = br
  25. this.ServeJSON()
  26. }()
  27. resp := new(data_manage.ChartClassifyListResp)
  28. // 获取当前账号的不可见指标
  29. noPermissionChartIdMap := make(map[int]bool)
  30. {
  31. obj := data_manage.EdbInfoNoPermissionAdmin{}
  32. confList, err := obj.GetAllChartListByAdminId(this.SysUser.AdminId)
  33. if err != nil && err.Error() != utils.ErrNoRow() {
  34. br.Msg = "获取失败"
  35. br.ErrMsg = "获取不可见指标配置数据失败,Err:" + err.Error()
  36. return
  37. }
  38. for _, v := range confList {
  39. noPermissionChartIdMap[v.ChartInfoId] = true
  40. }
  41. }
  42. isShowMe, _ := this.GetBool("IsShowMe")
  43. if isShowMe {
  44. errMsg, err := getChartClassifyListForMe(*this.SysUser, resp)
  45. if err != nil {
  46. br.Msg = errMsg
  47. br.ErrMsg = err.Error()
  48. return
  49. }
  50. br.Ret = 200
  51. br.Success = true
  52. br.Msg = "获取成功"
  53. br.Data = resp
  54. return
  55. }
  56. source := utils.CHART_SOURCE_LINE_FEATURE_STANDARD_DEVIATION
  57. rootList, err := data_manage.GetChartClassifyByParentId(0, source)
  58. if err != nil && err.Error() != utils.ErrNoRow() {
  59. br.Msg = "获取失败"
  60. br.ErrMsg = "获取数据失败,Err:" + err.Error()
  61. return
  62. }
  63. allChartInfo, err := data_manage.GetChartInfoAll([]int{utils.CHART_SOURCE_LINE_FEATURE_STANDARD_DEVIATION, utils.CHART_SOURCE_LINE_FEATURE_PERCENTILE, utils.CHART_SOURCE_LINE_FEATURE_FREQUENCY})
  64. if err != nil && err.Error() != utils.ErrNoRow() {
  65. br.Msg = "获取失败"
  66. br.ErrMsg = "获取图表信息失败,Err:" + err.Error()
  67. return
  68. }
  69. chartInfoMap := make(map[int][]*data_manage.ChartClassifyItems)
  70. for _, v := range allChartInfo {
  71. if !isShowMe {
  72. chartInfoMap[v.ChartClassifyId] = append(chartInfoMap[v.ChartClassifyId], v)
  73. continue
  74. }
  75. if v.SysUserId != this.SysUser.AdminId {
  76. continue
  77. }
  78. chartInfoMap[v.ChartClassifyId] = append(chartInfoMap[v.ChartClassifyId], v)
  79. }
  80. rootChildMap := make(map[int][]*data_manage.ChartClassifyItems)
  81. for _, v := range rootList {
  82. rootChildMap[v.ParentId] = append(rootChildMap[v.ParentId], v)
  83. if existItems, ok := chartInfoMap[v.ChartClassifyId]; ok {
  84. v.Children = existItems
  85. } else {
  86. items := make([]*data_manage.ChartClassifyItems, 0)
  87. v.Children = items
  88. }
  89. }
  90. // 移除没有权限的图表
  91. allNodes := data.HandleNoPermissionChart(rootList, noPermissionChartIdMap)
  92. resp.AllNodes = allNodes
  93. br.Ret = 200
  94. br.Success = true
  95. br.Msg = "获取成功"
  96. br.Data = resp
  97. }
  98. // getChartClassifyListForMe 获取我创建的图表
  99. func getChartClassifyListForMe(adminInfo system.Admin, resp *data_manage.ChartClassifyListResp) (errMsg string, err error) {
  100. // 获取所有的分类
  101. rootList, err := data_manage.GetChartClassifyByParentId(0, utils.CHART_SOURCE_LINE_FEATURE_STANDARD_DEVIATION)
  102. if err != nil && err.Error() != utils.ErrNoRow() {
  103. errMsg = "获取失败"
  104. return
  105. }
  106. // /获取所有的图表
  107. allChartInfo, err := data_manage.GetChartInfoByAdminId([]int{utils.CHART_SOURCE_LINE_FEATURE_STANDARD_DEVIATION, utils.CHART_SOURCE_LINE_FEATURE_PERCENTILE, utils.CHART_SOURCE_LINE_FEATURE_FREQUENCY}, adminInfo.AdminId)
  108. if err != nil && err.Error() != utils.ErrNoRow() {
  109. errMsg = "获取失败"
  110. return
  111. }
  112. chartInfoMap := make(map[int][]*data_manage.ChartClassifyItems)
  113. for _, v := range allChartInfo {
  114. chartInfoMap[v.ChartClassifyId] = append(chartInfoMap[v.ChartClassifyId], v)
  115. }
  116. for k, v := range rootList {
  117. if existItems, ok := chartInfoMap[v.ChartClassifyId]; ok {
  118. v.Children = existItems
  119. } else {
  120. items := make([]*data_manage.ChartClassifyItems, 0)
  121. v.Children = items
  122. }
  123. rootList[k] = v
  124. }
  125. resp.AllNodes = rootList
  126. return
  127. }