chart_theme.go 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513
  1. package data_manage
  2. import (
  3. "encoding/json"
  4. "eta/eta_api/controllers"
  5. "eta/eta_api/models"
  6. "eta/eta_api/models/data_manage"
  7. "eta/eta_api/models/data_manage/chart_theme"
  8. "eta/eta_api/models/data_manage/chart_theme/request"
  9. "eta/eta_api/services/data"
  10. "eta/eta_api/utils"
  11. "time"
  12. )
  13. // ChartThemeController
  14. // @Description: 图表主题配置模块
  15. type ChartThemeController struct {
  16. controllers.BaseAuthController
  17. }
  18. // List
  19. // @Title 获取主题列表
  20. // @Description 获取主题列表接口
  21. // @Param ChartThemeTypeId query int true "图表主题类型id"
  22. // @Success 200 {object} []*chart_theme.ChartTheme
  23. // @router /chart/theme/list [get]
  24. func (c *ChartThemeController) List() {
  25. br := new(models.BaseResponse).Init()
  26. defer func() {
  27. c.Data["json"] = br
  28. c.ServeJSON()
  29. }()
  30. sysUser := c.SysUser
  31. if sysUser == nil {
  32. br.Msg = "请登录"
  33. br.ErrMsg = "请登录,SysUser Is Empty"
  34. br.Ret = 408
  35. return
  36. }
  37. chartThemeTypeId, _ := c.GetInt("ChartThemeTypeId")
  38. if chartThemeTypeId <= 0 {
  39. br.Msg = "请选择图表样式类型"
  40. br.ErrMsg = "请选择图表样式类型"
  41. br.IsSendEmail = false
  42. return
  43. }
  44. list, err := chart_theme.GetChartThemeItemList(chartThemeTypeId)
  45. if err != nil {
  46. br.Msg = "获取失败"
  47. br.ErrMsg = "获取图表样式类型信息失败,Err:" + err.Error()
  48. return
  49. }
  50. br.Ret = 200
  51. br.Success = true
  52. br.Msg = "获取成功"
  53. br.Data = list
  54. }
  55. // TypeList
  56. // @Title 获取主题类型列表
  57. // @Description 获取主题类型列表接口
  58. // @Success 200 {object} []*chart_theme.ChartThemeType
  59. // @router /chart/theme/type/list [get]
  60. func (c *ChartThemeController) TypeList() {
  61. br := new(models.BaseResponse).Init()
  62. defer func() {
  63. c.Data["json"] = br
  64. c.ServeJSON()
  65. }()
  66. sysUser := c.SysUser
  67. if sysUser == nil {
  68. br.Msg = "请登录"
  69. br.ErrMsg = "请登录,SysUser Is Empty"
  70. br.Ret = 408
  71. return
  72. }
  73. list, err := chart_theme.GetAllChartThemeTypeList()
  74. if err != nil {
  75. br.Msg = "获取失败"
  76. br.ErrMsg = "获取图表样式类型信息失败,Err:" + err.Error()
  77. return
  78. }
  79. br.Ret = 200
  80. br.Success = true
  81. br.Msg = "获取成功"
  82. br.Data = list
  83. }
  84. // GetThemePreviewData
  85. // @Title 获取默认的预览图表数据
  86. // @Description 获取默认的预览图表数据接口
  87. // @Param ChartThemeTypeId query int true "图表主题类型id"
  88. // @Success 200 {object} data_manage.ChartInfoDetailResp
  89. // @router /chart/theme/preview_data [get]
  90. func (c *ChartThemeController) GetThemePreviewData() {
  91. br := new(models.BaseResponse).Init()
  92. defer func() {
  93. c.Data["json"] = br
  94. c.ServeJSON()
  95. }()
  96. sysUser := c.SysUser
  97. if sysUser == nil {
  98. br.Msg = "请登录"
  99. br.ErrMsg = "请登录,SysUser Is Empty"
  100. br.Ret = 408
  101. return
  102. }
  103. chartThemeTypeId, _ := c.GetInt("ChartThemeTypeId")
  104. if chartThemeTypeId <= 0 {
  105. br.Msg = "请选择图表样式类型"
  106. br.ErrMsg = "请选择图表样式类型"
  107. br.IsSendEmail = false
  108. return
  109. }
  110. chartThemeType, err := chart_theme.GetChartThemeTypeById(chartThemeTypeId)
  111. if err != nil {
  112. br.Msg = "获取失败"
  113. br.ErrMsg = "获取图表样式类型信息失败,Err:" + err.Error()
  114. return
  115. }
  116. dateType := 3 // 曲线图
  117. startYear := 5
  118. chartType := chartThemeType.ChartType
  119. // 图表额外数据参数
  120. extraConfigStr := ``
  121. edbInfoIdList := make([]int, 0) // 指标列表
  122. switch chartType {
  123. case 1, 4, 6: // 曲线图、堆积柱状图、组合图
  124. edbInfoIdList = []int{1, 2, 3, 4, 5}
  125. case 2: // 季节性
  126. dateType = 20 // 季节性图
  127. edbInfoIdList = []int{6}
  128. case 5: // 散点图
  129. edbInfoIdList = []int{7, 8}
  130. case 7: // 柱形图
  131. edbInfoIdList = []int{1, 2, 3, 4, 5}
  132. extraConfigStr = `{"EdbInfoIdList":[{"EdbInfoId":1,"Name":"指标1","NameEn":"","Source":0},{"EdbInfoId":2,"Name":"指标2","NameEn":"","Source":0},{"EdbInfoId":3,"Name":"指标3","NameEn":"","Source":0},{"EdbInfoId":4,"Name":"指标4","NameEn":"","Source":0},{"EdbInfoId":5,"Name":"指标5","NameEn":"","Source":0}],"DateList":[{"Type":2,"Date":"","Value":100,"Color":"#00f","Name":""},{"Type":1,"Date":"","Value":0,"Color":"#f00","Name":""}],"Sort":{"Sort":0,"DateIndex":0},"XEdbList":null,"YEdbList":null,"Unit":"千桶","UnitEn":""}`
  133. case 10: // 截面散点图
  134. edbInfoIdList = []int{9, 10, 11, 12, 13, 14, 15, 16, 17, 18}
  135. extraConfigStr = `{"XName":"123","XNameEn":"123","XUnitName":"无","XUnitNameEn":"none","YName":"321","YNameEn":"321","YUnitName":"无","YUnitNameEn":"none","XMinValue":"0.3686","XMaxValue":"0.3686","YMinValue":"-0.1398","YMaxValue":"-0.1398","SeriesList":[{"Name":"2021-11-21","NameEn":"2021-11-21","IsNameDefault":true,"Color":"#00f","EdbInfoList":[{"XEdbInfoId":9,"YEdbInfoId":14,"Name":"指标1","NameEn":"","XDateType":1,"XDate":"","XDateValue":0,"YDateType":1,"YDate":"","YDateValue":0,"IsShow":false},{"XEdbInfoId":10,"YEdbInfoId":15,"Name":"指标2","NameEn":"指标2","XDateType":1,"XDate":"","XDateValue":0,"YDateType":1,"YDate":"","YDateValue":0,"IsShow":false},{"XEdbInfoId":11,"YEdbInfoId":16,"Name":"指标3","NameEn":"","XDateType":1,"XDate":"","XDateValue":0,"YDateType":1,"YDate":"","YDateValue":0,"IsShow":false},{"XEdbInfoId":12,"YEdbInfoId":17,"Name":"指标4","NameEn":"指标4","XDateType":1,"XDate":"","XDateValue":0,"YDateType":1,"YDate":"","YDateValue":0,"IsShow":false},{"XEdbInfoId":13,"YEdbInfoId":18,"Name":"指标5","NameEn":"","XDateType":1,"XDate":"","XDateValue":0,"YDateType":1,"YDate":"","YDateValue":0,"IsShow":false}],"ShowTrendLine":false,"ShowFitEquation":false,"ShowRSquare":false}]}`
  136. default:
  137. br.Msg = "暂不支持该类型"
  138. br.IsSendEmail = false
  139. return
  140. }
  141. calendar := "公历"
  142. chartInfo := new(data_manage.ChartInfoView)
  143. mappingList, err := chart_theme.GetChartEdbMappingListByEdbInfoId(edbInfoIdList)
  144. if err != nil {
  145. br.Msg = "获取失败"
  146. br.ErrMsg = "获取图表,指标信息失败,Err:" + err.Error()
  147. return
  148. }
  149. switch chartType {
  150. case 6: // 散点图
  151. mappingList[0].ChartStyle = "spline"
  152. mappingList[1].ChartStyle = "spline"
  153. mappingList[2].ChartStyle = "spline"
  154. mappingList[3].ChartStyle = "column"
  155. mappingList[4].ChartStyle = "column"
  156. }
  157. yearMax := 0
  158. if dateType == utils.DateTypeNYears {
  159. for _, v := range mappingList {
  160. if v.LatestDate != "" {
  161. lastDateT, tErr := time.Parse(utils.FormatDate, v.LatestDate)
  162. if tErr != nil {
  163. br.Msg = "获取失败"
  164. br.ErrMsg = "获取图表日期信息失败,Err:" + tErr.Error()
  165. return
  166. }
  167. if lastDateT.Year() > yearMax {
  168. yearMax = lastDateT.Year()
  169. }
  170. }
  171. }
  172. }
  173. // 开始/结束日期
  174. startDate, endDate := utils.GetDateByDateTypeV2(dateType, ``, ``, startYear, yearMax)
  175. // 获取图表中的指标数据
  176. edbList, xEdbIdValue, yDataList, dataResp, err, errMsg := data.GetThemePreviewChartEdbData(chartType, calendar, startDate, endDate, mappingList, extraConfigStr, chartInfo.SeasonExtraConfig)
  177. if err != nil {
  178. br.Msg = "获取失败"
  179. if errMsg != `` {
  180. br.Msg = errMsg
  181. }
  182. br.ErrMsg = "获取图表,指标信息失败,Err:" + err.Error()
  183. return
  184. }
  185. // 单位
  186. if chartType == utils.CHART_TYPE_BAR && len(yDataList) > 0 {
  187. chartInfo.Unit = yDataList[0].Unit
  188. chartInfo.UnitEn = yDataList[0].UnitEn
  189. }
  190. resp := new(data_manage.ChartInfoDetailResp)
  191. resp.ChartInfo = chartInfo
  192. resp.EdbInfoList = edbList
  193. resp.XEdbIdValue = xEdbIdValue
  194. resp.YDataList = yDataList
  195. resp.DataResp = dataResp
  196. br.Ret = 200
  197. br.Success = true
  198. br.Msg = "获取成功"
  199. br.Data = resp
  200. }
  201. // Add
  202. // @Title 新增主题
  203. // @Description
  204. // @Param request body request.DeleteThemeConfReq true "type json string"
  205. // @Success 200 Ret=200 添加成功
  206. // @router /chart/theme/add [post]
  207. func (c *ChartThemeController) Add() {
  208. br := new(models.BaseResponse).Init()
  209. defer func() {
  210. c.Data["json"] = br
  211. c.ServeJSON()
  212. }()
  213. sysUser := c.SysUser
  214. if sysUser == nil {
  215. br.Msg = "请登录"
  216. br.ErrMsg = "请登录,SysUser Is Empty"
  217. br.Ret = 408
  218. return
  219. }
  220. var req request.AddThemeReq
  221. err := json.Unmarshal(c.Ctx.Input.RequestBody, &req)
  222. if err != nil {
  223. br.Msg = "参数解析异常!"
  224. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  225. return
  226. }
  227. if req.ChartThemeTypeId <= 0 {
  228. br.Msg = "请选择图表类型"
  229. br.IsSendEmail = false
  230. return
  231. }
  232. req.ChartThemeName = utils.TrimLRStr(req.ChartThemeName)
  233. if req.ChartThemeName == `` {
  234. br.Msg = "请输入主题名称"
  235. br.IsSendEmail = false
  236. return
  237. }
  238. // 获取系统默认配置
  239. systemChartTheme, err := chart_theme.GetSystemChartThemeItem(req.ChartThemeTypeId)
  240. if err != nil {
  241. br.Msg = "添加失败"
  242. br.ErrMsg = "添加失败,查询系统默认配置异常,Err:" + err.Error()
  243. return
  244. }
  245. chartTheme := &chart_theme.ChartTheme{
  246. ChartThemeId: 0,
  247. ChartThemeName: req.ChartThemeName,
  248. ChartThemeTypeId: req.ChartThemeTypeId,
  249. Config: systemChartTheme.Config,
  250. IsDelete: 0,
  251. SysUserId: sysUser.AdminId,
  252. SysUserRealName: sysUser.RealName,
  253. ModifyTime: time.Now(),
  254. CreateTime: time.Now(),
  255. }
  256. // 添加入库
  257. err = chartTheme.Add()
  258. if err != nil {
  259. br.Msg = "添加失败"
  260. br.ErrMsg = "添加失败,Err:" + err.Error()
  261. return
  262. }
  263. br.Ret = 200
  264. br.Success = true
  265. br.Msg = "添加成功"
  266. }
  267. // Edit
  268. // @Title 新增主题
  269. // @Description
  270. // @Param request body request.DeleteThemeConfReq true "type json string"
  271. // @Success 200 Ret=200 修改成功
  272. // @router /chart/theme/edit [post]
  273. func (c *ChartThemeController) Edit() {
  274. br := new(models.BaseResponse).Init()
  275. defer func() {
  276. c.Data["json"] = br
  277. c.ServeJSON()
  278. }()
  279. sysUser := c.SysUser
  280. if sysUser == nil {
  281. br.Msg = "请登录"
  282. br.ErrMsg = "请登录,SysUser Is Empty"
  283. br.Ret = 408
  284. return
  285. }
  286. var req request.EditThemeReq
  287. err := json.Unmarshal(c.Ctx.Input.RequestBody, &req)
  288. if err != nil {
  289. br.Msg = "参数解析异常!"
  290. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  291. return
  292. }
  293. if req.ChartThemeId < 0 {
  294. br.Msg = "请选择配置"
  295. br.IsSendEmail = false
  296. return
  297. }
  298. // 获取配置
  299. chartTheme, err := chart_theme.GetChartThemeId(req.ChartThemeId)
  300. if err != nil {
  301. if err.Error() == utils.ErrNoRow() {
  302. br.Msg = "主题不存在或已删除"
  303. br.ErrMsg = "主题不存在或已删除"
  304. br.IsSendEmail = false
  305. } else {
  306. br.Msg = "获取失败"
  307. br.ErrMsg = "获取图表配置信息失败,Err:" + err.Error()
  308. }
  309. return
  310. }
  311. // 更新
  312. chartTheme.ChartThemeName = req.ChartThemeName
  313. chartTheme.Config = req.Config
  314. chartTheme.ModifyTime = time.Now()
  315. err = chartTheme.Update([]string{"ChartThemeName", "Config", "ModifyTime"})
  316. if err != nil {
  317. br.Msg = "修改失败"
  318. br.ErrMsg = "修改失败,Err:" + err.Error()
  319. return
  320. }
  321. br.Ret = 200
  322. br.Success = true
  323. br.Msg = "修改成功"
  324. }
  325. // Delete
  326. // @Title 删除主题
  327. // @Description
  328. // @Param request body request.DeleteThemeConfReq true "type json string"
  329. // @Success 200 Ret=200 删除成功
  330. // @router /chart/theme/delete [post]
  331. func (c *ChartThemeController) Delete() {
  332. br := new(models.BaseResponse).Init()
  333. defer func() {
  334. c.Data["json"] = br
  335. c.ServeJSON()
  336. }()
  337. sysUser := c.SysUser
  338. if sysUser == nil {
  339. br.Msg = "请登录"
  340. br.ErrMsg = "请登录,SysUser Is Empty"
  341. br.Ret = 408
  342. return
  343. }
  344. var req request.DeleteThemeReq
  345. err := json.Unmarshal(c.Ctx.Input.RequestBody, &req)
  346. if err != nil {
  347. br.Msg = "参数解析异常!"
  348. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  349. return
  350. }
  351. if req.ChartThemeId < 0 {
  352. br.Msg = "请选择配置"
  353. br.IsSendEmail = false
  354. return
  355. }
  356. // 获取配置
  357. chartTheme, err := chart_theme.GetChartThemeId(req.ChartThemeId)
  358. if err != nil {
  359. if err.Error() == utils.ErrNoRow() {
  360. br.Msg = "主题不存在或已删除"
  361. br.ErrMsg = "主题不存在或已删除"
  362. br.IsSendEmail = false
  363. } else {
  364. br.Msg = "获取失败"
  365. br.ErrMsg = "获取图表配置信息失败,Err:" + err.Error()
  366. }
  367. return
  368. }
  369. if chartTheme.IsSystemTheme == 1 {
  370. br.Msg = "系统默认配置,无法删除"
  371. br.ErrMsg = "系统默认配置,无法删除"
  372. br.IsSendEmail = false
  373. return
  374. }
  375. // 更新
  376. chartTheme.IsDelete = 1
  377. err = chartTheme.Update([]string{"IsDelete"})
  378. if err != nil {
  379. br.Msg = "删除失败"
  380. br.ErrMsg = "删除失败,Err:" + err.Error()
  381. return
  382. }
  383. br.Ret = 200
  384. br.Success = true
  385. br.Msg = "删除成功"
  386. }
  387. // SetDefaultTheme
  388. // @Title 配置默认主题
  389. // @Description 配置默认主题
  390. // @Param request body request.DeleteThemeConfReq true "type json string"
  391. // @Success 200 Ret=200 配置成功
  392. // @router /chart/theme/set_default [post]
  393. func (c *ChartThemeController) SetDefaultTheme() {
  394. br := new(models.BaseResponse).Init()
  395. defer func() {
  396. c.Data["json"] = br
  397. c.ServeJSON()
  398. }()
  399. sysUser := c.SysUser
  400. if sysUser == nil {
  401. br.Msg = "请登录"
  402. br.ErrMsg = "请登录,SysUser Is Empty"
  403. br.Ret = 408
  404. return
  405. }
  406. var req request.SetDefaultThemeReq
  407. err := json.Unmarshal(c.Ctx.Input.RequestBody, &req)
  408. if err != nil {
  409. br.Msg = "参数解析异常!"
  410. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  411. return
  412. }
  413. if req.ChartThemeId < 0 {
  414. br.Msg = "请选择配置"
  415. br.IsSendEmail = false
  416. return
  417. }
  418. if req.ChartThemeTypeId < 0 {
  419. br.Msg = "请选择图表类型"
  420. br.IsSendEmail = false
  421. return
  422. }
  423. // 获取图表配置
  424. chartTheme, err := chart_theme.GetChartThemeId(req.ChartThemeId)
  425. if err != nil {
  426. if err.Error() == utils.ErrNoRow() {
  427. br.Msg = "主题不存在或已删除"
  428. br.ErrMsg = "主题不存在或已删除"
  429. br.IsSendEmail = false
  430. } else {
  431. br.Msg = "获取失败"
  432. br.ErrMsg = "获取图表配置信息失败,Err:" + err.Error()
  433. }
  434. return
  435. }
  436. // 获取图表类型
  437. chartThemeType, err := chart_theme.GetChartThemeTypeById(req.ChartThemeTypeId)
  438. if err != nil {
  439. if err.Error() == utils.ErrNoRow() {
  440. br.Msg = "获取图表类型不存在或已删除"
  441. br.ErrMsg = "获取图表类型不存在或已删除"
  442. br.IsSendEmail = false
  443. } else {
  444. br.Msg = "获取失败"
  445. br.ErrMsg = "获取图表配置信息失败,Err:" + err.Error()
  446. }
  447. return
  448. }
  449. // 判断主题与图表类型是否相符
  450. if chartTheme.ChartThemeTypeId != chartThemeType.ChartThemeTypeId {
  451. br.Msg = "主题与图表类型不符"
  452. br.ErrMsg = "主题与图表类型不符"
  453. br.IsSendEmail = false
  454. return
  455. }
  456. // 更新
  457. chartThemeType.DefaultChartThemeId = chartTheme.ChartThemeId
  458. chartThemeType.ModifyTime = time.Now()
  459. err = chartThemeType.Update([]string{"DefaultChartThemeId", "ModifyTime"})
  460. if err != nil {
  461. br.Msg = "配置失败"
  462. br.ErrMsg = "配置失败,Err:" + err.Error()
  463. return
  464. }
  465. br.Ret = 200
  466. br.Success = true
  467. br.Msg = "配置成功"
  468. }