edb_source_stat.go 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119
  1. package data_stat
  2. import (
  3. "encoding/json"
  4. "eta/eta_api/controllers"
  5. "eta/eta_api/models"
  6. "eta/eta_api/models/data_stat"
  7. )
  8. // EdbSourceStatController 数据源统计表管理模块
  9. type EdbSourceStatController struct {
  10. controllers.BaseAuthController
  11. }
  12. // Column
  13. // @Title 数据源统计表自定义列列表
  14. // @Description 查询 数据源统计表自定义列列表
  15. // @Success 200 {object} data_stat.StatColumnList
  16. // @router /source_column [get]
  17. func (this *EdbSourceStatController) Column() {
  18. br := new(models.BaseResponse).Init()
  19. defer func() {
  20. this.Data["json"] = br
  21. this.ServeJSON()
  22. }()
  23. sysUser := this.SysUser
  24. if sysUser == nil {
  25. br.Msg = "请登录"
  26. br.ErrMsg = "请登录,SysUser Is Empty"
  27. br.Ret = 408
  28. return
  29. }
  30. columnType, _ := this.GetInt("ColumnType")
  31. if columnType <= 0 {
  32. br.Msg = "请选择表类型"
  33. return
  34. }
  35. tmpList, err := data_stat.GetStatColumn(columnType)
  36. if err != nil {
  37. br.Msg = "获取自定义列失败"
  38. br.ErrMsg = "获取自定义列失败,Err:" + err.Error()
  39. return
  40. }
  41. var list []*data_stat.EdbInfoStatColumnListItem
  42. for _, v := range tmpList {
  43. tmp := new(data_stat.EdbInfoStatColumnListItem)
  44. tmp.ColumnKey = v.ColumnKey
  45. tmp.IsShow = v.IsShow
  46. tmp.ColumnName = v.ColumnName
  47. tmp.Id = v.Id
  48. tmp.IsMust = v.IsMust
  49. tmp.IsSort = v.IsSort
  50. tmp.Type = v.Type
  51. list = append(list, tmp)
  52. }
  53. var statColumnList data_stat.StatColumnList
  54. statColumnList.List = list
  55. br.Ret = 200
  56. br.Success = true
  57. br.Msg = "获取成功"
  58. br.Data = statColumnList
  59. }
  60. // EditColumn
  61. // @Title 编辑数据源统计表自定义列
  62. // @Description 编辑 数据源统计表自定义列列表
  63. // @Success 200 {object} data_stat.StatColumnList
  64. // @router /source_column/edit [post]
  65. func (this *EdbSourceStatController) EditColumn() {
  66. br := new(models.BaseResponse).Init()
  67. defer func() {
  68. this.Data["json"] = br
  69. this.ServeJSON()
  70. }()
  71. sysUser := this.SysUser
  72. if sysUser == nil {
  73. br.Msg = "请登录"
  74. br.ErrMsg = "请登录,SysUser Is Empty"
  75. br.Ret = 408
  76. return
  77. }
  78. var req data_stat.EditStatColumnReq
  79. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  80. if err != nil {
  81. br.Msg = "参数解析异常!"
  82. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  83. return
  84. }
  85. if len(req.List) <= 0 {
  86. br.Msg = "请选择要修改的列"
  87. br.IsSendEmail = false
  88. return
  89. }
  90. var list []*data_stat.EdbInfoStatColumn
  91. for k, v := range req.List {
  92. if v.Id == 0 {
  93. br.Msg = "列序号不能为空"
  94. return
  95. }
  96. tmp := new(data_stat.EdbInfoStatColumn)
  97. tmp.Id = v.Id
  98. tmp.Sort = k + 1
  99. tmp.IsShow = v.IsShow
  100. list = append(list, tmp)
  101. }
  102. err = data_stat.UpdateStatColumn(list)
  103. if err != nil {
  104. br.Msg = "更新自定义列操作失败!"
  105. br.ErrMsg = "更新自定义列操作失败,Err:" + err.Error()
  106. return
  107. }
  108. br.Ret = 200
  109. br.Success = true
  110. br.Msg = "获取成功"
  111. return
  112. }