chart_theme.go 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696
  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/services/eta_forum"
  11. "eta/eta_api/utils"
  12. "time"
  13. )
  14. // ChartThemeController
  15. // @Description: 图表主题配置模块
  16. type ChartThemeController struct {
  17. controllers.BaseAuthController
  18. }
  19. // List
  20. // @Title 获取主题列表
  21. // @Description 获取主题列表接口
  22. // @Param ChartThemeTypeId query int true "图表主题类型id"
  23. // @Success 200 {object} []*chart_theme.ChartTheme
  24. // @router /chart/theme/list [get]
  25. func (c *ChartThemeController) List() {
  26. br := new(models.BaseResponse).Init()
  27. defer func() {
  28. c.Data["json"] = br
  29. c.ServeJSON()
  30. }()
  31. sysUser := c.SysUser
  32. if sysUser == nil {
  33. br.Msg = "请登录"
  34. br.ErrMsg = "请登录,SysUser Is Empty"
  35. br.Ret = 408
  36. return
  37. }
  38. chartThemeTypeId, _ := c.GetInt("ChartThemeTypeId")
  39. if chartThemeTypeId <= 0 {
  40. br.Msg = "请选择图表样式类型"
  41. br.ErrMsg = "请选择图表样式类型"
  42. br.IsSendEmail = false
  43. return
  44. }
  45. list, err := chart_theme.GetChartThemeItemList(chartThemeTypeId)
  46. if err != nil {
  47. br.Msg = "获取失败"
  48. br.ErrMsg = "获取图表样式类型信息失败,Err:" + err.Error()
  49. return
  50. }
  51. // 兼容历史数据,加入新字段LineOptionList
  52. for i, v := range list {
  53. newConfig, e := data.ConvertOldChartOptions(v.Config)
  54. if e != nil {
  55. continue
  56. }
  57. list[i].Config = newConfig
  58. }
  59. br.Ret = 200
  60. br.Success = true
  61. br.Msg = "获取成功"
  62. br.Data = list
  63. }
  64. // TypeList
  65. // @Title 获取主题类型列表
  66. // @Description 获取主题类型列表接口
  67. // @Success 200 {object} []*chart_theme.ChartThemeType
  68. // @router /chart/theme/type/list [get]
  69. func (c *ChartThemeController) TypeList() {
  70. br := new(models.BaseResponse).Init()
  71. defer func() {
  72. c.Data["json"] = br
  73. c.ServeJSON()
  74. }()
  75. sysUser := c.SysUser
  76. if sysUser == nil {
  77. br.Msg = "请登录"
  78. br.ErrMsg = "请登录,SysUser Is Empty"
  79. br.Ret = 408
  80. return
  81. }
  82. list, err := chart_theme.GetAllChartThemeTypeList()
  83. if err != nil {
  84. br.Msg = "获取失败"
  85. br.ErrMsg = "获取图表样式类型信息失败,Err:" + err.Error()
  86. return
  87. }
  88. br.Ret = 200
  89. br.Success = true
  90. br.Msg = "获取成功"
  91. br.Data = list
  92. }
  93. // GetThemePreviewData
  94. // @Title 获取默认的预览图表数据
  95. // @Description 获取默认的预览图表数据接口
  96. // @Param ChartThemeTypeId query int true "图表主题类型id"
  97. // @Success 200 {object} data_manage.ChartInfoDetailResp
  98. // @router /chart/theme/preview_data [get]
  99. func (c *ChartThemeController) GetThemePreviewData() {
  100. br := new(models.BaseResponse).Init()
  101. defer func() {
  102. c.Data["json"] = br
  103. c.ServeJSON()
  104. }()
  105. sysUser := c.SysUser
  106. if sysUser == nil {
  107. br.Msg = "请登录"
  108. br.ErrMsg = "请登录,SysUser Is Empty"
  109. br.Ret = 408
  110. return
  111. }
  112. chartThemeTypeId, _ := c.GetInt("ChartThemeTypeId")
  113. if chartThemeTypeId <= 0 {
  114. br.Msg = "请选择图表样式类型"
  115. br.ErrMsg = "请选择图表样式类型"
  116. br.IsSendEmail = false
  117. return
  118. }
  119. chartThemeType, err := chart_theme.GetChartThemeTypeById(chartThemeTypeId)
  120. if err != nil {
  121. br.Msg = "获取失败"
  122. br.ErrMsg = "获取图表样式类型信息失败,Err:" + err.Error()
  123. return
  124. }
  125. dateType := 3 // 曲线图
  126. startYear := 5
  127. chartType := chartThemeType.ChartType
  128. chartInfo := new(data_manage.ChartInfoView)
  129. // 图表额外数据参数
  130. extraConfigStr := ``
  131. var barConfig data_manage.BarChartInfoReq
  132. // 开始时间,结束时间
  133. var tmpStartDate, tmpEndDate string
  134. edbInfoIdList := make([]int, 0) // 指标列表
  135. switch chartType {
  136. case 1: // 曲线图
  137. edbInfoIdList = []int{1, 2, 3, 4, 5}
  138. chartInfo.ChartName = "曲线图"
  139. case 4: // 堆积柱状图
  140. edbInfoIdList = []int{1, 2, 3, 4, 5}
  141. chartInfo.ChartName = "堆积柱状图"
  142. dateType = 5
  143. tmpStartDate = `2021-03-05`
  144. case 6: // 组合图
  145. edbInfoIdList = []int{1, 2, 3, 4, 5}
  146. chartInfo.ChartName = "组合图"
  147. dateType = 5
  148. tmpStartDate = `2021-03-05`
  149. case 2: // 季节性
  150. dateType = 20 // 季节性图
  151. edbInfoIdList = []int{6}
  152. chartInfo.ChartName = "季节性图"
  153. case 5: // 散点图
  154. edbInfoIdList = []int{7, 8}
  155. chartInfo.ChartName = "散点图"
  156. case 7: // 柱形图
  157. edbInfoIdList = []int{1, 2, 3, 4, 5}
  158. chartInfo.LeftMin = "260"
  159. chartInfo.LeftMax = "430"
  160. 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":"","Name":""},{"Type":1,"Date":"","Value":0,"Color":"","Name":""}],"Sort":{"Sort":0,"DateIndex":0},"XEdbList":null,"YEdbList":null,"Unit":"千桶","UnitEn":""}`
  161. chartInfo.ChartName = "柱形图"
  162. case 10: // 截面散点图
  163. edbInfoIdList = []int{9, 10, 11, 12, 13, 14, 15, 16, 17, 18}
  164. extraConfigStr = `{"XName":"123","XNameEn":"123","XUnitName":"无","XUnitNameEn":"none","YName":"321","YNameEn":"321","YUnitName":"无","YUnitNameEn":"none","XMinValue":"230","XMaxValue":"395","YMinValue":"380","YMaxValue":"850","SeriesList":[{"Name":"2021-11-21","NameEn":"2021-11-21","IsNameDefault":true,"Color":"","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}]}`
  165. chartInfo.ChartName = "截面散点图"
  166. case utils.CHART_TYPE_RADAR:
  167. edbInfoIdList = []int{19, 20, 21, 22, 23, 24}
  168. chartInfo.LeftMin = "10000"
  169. chartInfo.LeftMax = "60000"
  170. extraConfigStr = `{"DateList":[{"Type":3,"Date":"2023-11-01","Value":0,"Color":"","Name":""},{"Type":1,"Date":"","Value":0,"Color":"","Name":""}]}`
  171. chartInfo.ChartName = "雷达图"
  172. case utils.CHART_TYPE_SECTION_COMBINE:
  173. edbInfoIdList = []int{19, 20, 21, 22, 23, 24}
  174. chartInfo.LeftMin = "0"
  175. chartInfo.LeftMax = "4000"
  176. extraConfigStr = `{"DateConfList":[],"IsHeap":1,"XDataList":[{"Name":"内销","NameEn":""},{"Name":"出口","NameEn":""},{"Name":"销量","NameEn":""},{"Name":"产量","NameEn":""}],"UnitList":{"LeftName":"万台","LeftNameEn":"","RightName":"%","RightNameEn":"%","RightTwoName":"","RightTwoNameEn":""},"BaseChartSeriesName":"增量","SortType":0,"SeriesList":[{"ChartSeriesId":1,"SeriesName":"增量","SeriesNameEn":"","ChartStyle":"bar","ChartColor":"#FF0000","ChartWidth":2,"IsPoint":1,"IsNumber":1,"IsAxis":0,"MaxData":4000,"MinData":0,"IsOrder":true,"EdbInfoList":[{"ChartSeriesEdbMappingId":0,"ChartSeriesId":0,"EdbInfoId":0,"DateConf":{},"DateConfName":""}],"DataList":[1455,1076,2532,3729],"NoDataEdbIdList":[]},{"ChartSeriesId":2,"SeriesName":"增速","SeriesNameEn":"","ChartStyle":"line","ChartColor":"#FF0000","ChartWidth":2,"IsPoint":1,"IsNumber":1,"IsAxis":1,"MaxData":15,"MinData":10,"IsOrder":true,"EdbInfoList":[{"ChartSeriesEdbMappingId":0,"ChartSeriesId":0,"EdbInfoId":0,"DateConf":{},"DateConfName":""}],"DataList":[13,12,12,14],"NoDataEdbIdList":[]}]}`
  177. chartInfo.ChartName = "图表标题"
  178. default:
  179. br.Msg = "暂不支持该类型"
  180. br.IsSendEmail = false
  181. return
  182. }
  183. calendar := "公历"
  184. mappingList, err := chart_theme.GetChartEdbMappingListByEdbInfoId(edbInfoIdList)
  185. if err != nil {
  186. br.Msg = "获取失败"
  187. br.ErrMsg = "获取图表,指标信息失败,Err:" + err.Error()
  188. return
  189. }
  190. switch chartType {
  191. case 6: // 组合图
  192. mappingList[0].ChartStyle = "spline"
  193. mappingList[1].ChartStyle = "spline"
  194. mappingList[2].ChartStyle = "spline"
  195. mappingList[3].ChartStyle = "column"
  196. mappingList[4].ChartStyle = "column"
  197. }
  198. chartInfo.Source = chartThemeType.ChartSource
  199. chartInfo.ChartType = chartThemeType.ChartType
  200. yearMax := 0
  201. if dateType == utils.DateTypeNYears {
  202. for _, v := range mappingList {
  203. if v.LatestDate != "" {
  204. lastDateT, tErr := time.Parse(utils.FormatDate, v.LatestDate)
  205. if tErr != nil {
  206. br.Msg = "获取失败"
  207. br.ErrMsg = "获取图表日期信息失败,Err:" + tErr.Error()
  208. return
  209. }
  210. if lastDateT.Year() > yearMax {
  211. yearMax = lastDateT.Year()
  212. }
  213. }
  214. }
  215. }
  216. // 开始/结束日期
  217. startDate, endDate := utils.GetDateByDateTypeV2(dateType, tmpStartDate, tmpEndDate, startYear, yearMax)
  218. // 获取图表中的指标数据
  219. edbList, xEdbIdValue, yDataList, dataResp, err, errMsg := data.GetThemePreviewChartEdbData(chartType, calendar, startDate, endDate, mappingList, extraConfigStr, chartInfo.SeasonExtraConfig)
  220. if err != nil {
  221. br.Msg = "获取失败"
  222. if errMsg != `` {
  223. br.Msg = errMsg
  224. }
  225. br.ErrMsg = "获取图表,指标信息失败,Err:" + err.Error()
  226. return
  227. }
  228. switch chartType {
  229. case 6: // 组合图
  230. edbList[0].MaxData = 1000
  231. case 4: // 堆积柱状图
  232. edbList[0].MaxData = 2500
  233. }
  234. // 单位
  235. if chartType == utils.CHART_TYPE_BAR && len(yDataList) > 0 {
  236. chartInfo.Unit = yDataList[0].Unit
  237. chartInfo.UnitEn = yDataList[0].UnitEn
  238. }
  239. resp := new(data_manage.ChartInfoDetailResp)
  240. resp.ChartInfo = chartInfo
  241. resp.EdbInfoList = edbList
  242. resp.XEdbIdValue = xEdbIdValue
  243. resp.YDataList = yDataList
  244. resp.DataResp = dataResp
  245. resp.BarChartInfo = barConfig
  246. br.Ret = 200
  247. br.Success = true
  248. br.Msg = "获取成功"
  249. br.Data = resp
  250. }
  251. // Add
  252. // @Title 新增主题
  253. // @Description
  254. // @Param request body request.DeleteThemeConfReq true "type json string"
  255. // @Success 200 Ret=200 添加成功
  256. // @router /chart/theme/add [post]
  257. func (c *ChartThemeController) Add() {
  258. br := new(models.BaseResponse).Init()
  259. defer func() {
  260. c.Data["json"] = br
  261. c.ServeJSON()
  262. }()
  263. sysUser := c.SysUser
  264. if sysUser == nil {
  265. br.Msg = "请登录"
  266. br.ErrMsg = "请登录,SysUser Is Empty"
  267. br.Ret = 408
  268. return
  269. }
  270. var req request.AddThemeReq
  271. err := json.Unmarshal(c.Ctx.Input.RequestBody, &req)
  272. if err != nil {
  273. br.Msg = "参数解析异常!"
  274. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  275. return
  276. }
  277. if req.ChartThemeTypeId <= 0 {
  278. br.Msg = "请选择图表类型"
  279. br.IsSendEmail = false
  280. return
  281. }
  282. req.ChartThemeName = utils.TrimLRStr(req.ChartThemeName)
  283. if req.ChartThemeName == `` {
  284. br.Msg = "请输入主题名称"
  285. br.IsSendEmail = false
  286. return
  287. }
  288. // 获取系统默认配置
  289. systemChartTheme, err := chart_theme.GetSystemChartTheme(req.ChartThemeTypeId)
  290. if err != nil {
  291. br.Msg = "添加失败"
  292. br.ErrMsg = "添加失败,查询系统默认配置异常,Err:" + err.Error()
  293. return
  294. }
  295. chartTheme := &chart_theme.ChartTheme{
  296. ChartThemeId: 0,
  297. ChartThemeName: req.ChartThemeName,
  298. ChartThemeTypeId: req.ChartThemeTypeId,
  299. Config: systemChartTheme.Config,
  300. ChartImage: systemChartTheme.ChartImage,
  301. IsDelete: 0,
  302. SysUserId: sysUser.AdminId,
  303. SysUserRealName: sysUser.RealName,
  304. ModifyTime: time.Now(),
  305. CreateTime: time.Now(),
  306. }
  307. // 添加入库
  308. err = chartTheme.Add()
  309. if err != nil {
  310. br.Msg = "添加失败"
  311. br.ErrMsg = "添加失败,Err:" + err.Error()
  312. return
  313. }
  314. go eta_forum.ChartThemeSave(chartTheme)
  315. br.Ret = 200
  316. br.Success = true
  317. br.Msg = "添加成功"
  318. }
  319. // Edit
  320. // @Title 编辑主题
  321. // @Description
  322. // @Param request body request.DeleteThemeConfReq true "type json string"
  323. // @Success 200 Ret=200 修改成功
  324. // @router /chart/theme/edit [post]
  325. func (c *ChartThemeController) Edit() {
  326. br := new(models.BaseResponse).Init()
  327. defer func() {
  328. c.Data["json"] = br
  329. c.ServeJSON()
  330. }()
  331. sysUser := c.SysUser
  332. if sysUser == nil {
  333. br.Msg = "请登录"
  334. br.ErrMsg = "请登录,SysUser Is Empty"
  335. br.Ret = 408
  336. return
  337. }
  338. var req request.EditThemeReq
  339. err := json.Unmarshal(c.Ctx.Input.RequestBody, &req)
  340. if err != nil {
  341. br.Msg = "参数解析异常!"
  342. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  343. return
  344. }
  345. if req.ChartThemeId < 0 {
  346. br.Msg = "请选择配置"
  347. br.IsSendEmail = false
  348. return
  349. }
  350. // 获取配置
  351. chartTheme, err := chart_theme.GetChartThemeId(req.ChartThemeId)
  352. if err != nil {
  353. if err.Error() == utils.ErrNoRow() {
  354. br.Msg = "主题不存在或已删除"
  355. br.ErrMsg = "主题不存在或已删除"
  356. br.IsSendEmail = false
  357. } else {
  358. br.Msg = "获取失败"
  359. br.ErrMsg = "获取图表配置信息失败,Err:" + err.Error()
  360. }
  361. return
  362. }
  363. // 更新
  364. if req.ChartThemeName != `` {
  365. chartTheme.ChartThemeName = req.ChartThemeName
  366. }
  367. if req.Config != `` {
  368. chartTheme.Config = req.Config
  369. }
  370. if req.ChartImage != `` {
  371. chartTheme.ChartImage = req.ChartImage
  372. }
  373. chartTheme.ModifyTime = time.Now()
  374. err = chartTheme.Update([]string{"ChartThemeName", "Config", "ChartImage", "ModifyTime"})
  375. if err != nil {
  376. br.Msg = "修改失败"
  377. br.ErrMsg = "修改失败,Err:" + err.Error()
  378. return
  379. }
  380. go eta_forum.ChartThemeSave(chartTheme)
  381. br.Ret = 200
  382. br.Success = true
  383. br.Msg = "修改成功"
  384. }
  385. // Delete
  386. // @Title 删除主题
  387. // @Description
  388. // @Param request body request.DeleteThemeConfReq true "type json string"
  389. // @Success 200 Ret=200 删除成功
  390. // @router /chart/theme/delete [post]
  391. func (c *ChartThemeController) Delete() {
  392. br := new(models.BaseResponse).Init()
  393. defer func() {
  394. c.Data["json"] = br
  395. c.ServeJSON()
  396. }()
  397. sysUser := c.SysUser
  398. if sysUser == nil {
  399. br.Msg = "请登录"
  400. br.ErrMsg = "请登录,SysUser Is Empty"
  401. br.Ret = 408
  402. return
  403. }
  404. var req request.DeleteThemeReq
  405. err := json.Unmarshal(c.Ctx.Input.RequestBody, &req)
  406. if err != nil {
  407. br.Msg = "参数解析异常!"
  408. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  409. return
  410. }
  411. if req.ChartThemeId < 0 {
  412. br.Msg = "请选择配置"
  413. br.IsSendEmail = false
  414. return
  415. }
  416. // 获取配置
  417. chartTheme, err := chart_theme.GetChartThemeId(req.ChartThemeId)
  418. if err != nil {
  419. if err.Error() == utils.ErrNoRow() {
  420. br.Msg = "主题不存在或已删除"
  421. br.ErrMsg = "主题不存在或已删除"
  422. br.IsSendEmail = false
  423. } else {
  424. br.Msg = "获取失败"
  425. br.ErrMsg = "获取图表配置信息失败,Err:" + err.Error()
  426. }
  427. return
  428. }
  429. if chartTheme.IsSystemTheme == 1 {
  430. br.Msg = "系统默认配置,无法删除"
  431. br.ErrMsg = "系统默认配置,无法删除"
  432. br.IsSendEmail = false
  433. return
  434. }
  435. // 根据给定的图表主题类型ID获取图表主题类型
  436. chartThemeType, err := chart_theme.GetChartThemeTypeById(chartTheme.ChartThemeTypeId)
  437. if err != nil {
  438. br.Msg = "获取失败"
  439. br.ErrMsg = "获取图表主题类型信息失败,Err:" + err.Error()
  440. return
  441. }
  442. // 判断是否是配置为默认设置,如果已经设置了,那么不能删除
  443. if chartThemeType.DefaultChartThemeId == chartTheme.ChartThemeId {
  444. br.Msg = "该主题已经配置为默认设置,不允许删除"
  445. br.ErrMsg = "该主题已经配置为默认设置,不允许删除"
  446. br.IsSendEmail = false
  447. return
  448. }
  449. // 更新
  450. chartTheme.IsDelete = 1
  451. err = chartTheme.Update([]string{"IsDelete"})
  452. if err != nil {
  453. br.Msg = "删除失败"
  454. br.ErrMsg = "删除失败,Err:" + err.Error()
  455. return
  456. }
  457. go eta_forum.ChartThemeSave(chartTheme)
  458. br.Ret = 200
  459. br.Success = true
  460. br.Msg = "删除成功"
  461. }
  462. // SetDefaultTheme
  463. // @Title 配置默认主题
  464. // @Description 配置默认主题
  465. // @Param request body request.DeleteThemeConfReq true "type json string"
  466. // @Success 200 Ret=200 配置成功
  467. // @router /chart/theme/set_default [post]
  468. func (c *ChartThemeController) SetDefaultTheme() {
  469. br := new(models.BaseResponse).Init()
  470. defer func() {
  471. c.Data["json"] = br
  472. c.ServeJSON()
  473. }()
  474. sysUser := c.SysUser
  475. if sysUser == nil {
  476. br.Msg = "请登录"
  477. br.ErrMsg = "请登录,SysUser Is Empty"
  478. br.Ret = 408
  479. return
  480. }
  481. var req request.SetDefaultThemeReq
  482. err := json.Unmarshal(c.Ctx.Input.RequestBody, &req)
  483. if err != nil {
  484. br.Msg = "参数解析异常!"
  485. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  486. return
  487. }
  488. if req.ChartThemeId < 0 {
  489. br.Msg = "请选择配置"
  490. br.IsSendEmail = false
  491. return
  492. }
  493. if req.ChartThemeTypeId < 0 {
  494. br.Msg = "请选择图表类型"
  495. br.IsSendEmail = false
  496. return
  497. }
  498. // 获取图表配置
  499. chartTheme, err := chart_theme.GetChartThemeId(req.ChartThemeId)
  500. if err != nil {
  501. if err.Error() == utils.ErrNoRow() {
  502. br.Msg = "主题不存在或已删除"
  503. br.ErrMsg = "主题不存在或已删除"
  504. br.IsSendEmail = false
  505. } else {
  506. br.Msg = "获取失败"
  507. br.ErrMsg = "获取图表配置信息失败,Err:" + err.Error()
  508. }
  509. return
  510. }
  511. // 获取图表类型
  512. chartThemeType, err := chart_theme.GetChartThemeTypeById(req.ChartThemeTypeId)
  513. if err != nil {
  514. if err.Error() == utils.ErrNoRow() {
  515. br.Msg = "获取图表类型不存在或已删除"
  516. br.ErrMsg = "获取图表类型不存在或已删除"
  517. br.IsSendEmail = false
  518. } else {
  519. br.Msg = "获取失败"
  520. br.ErrMsg = "获取图表配置信息失败,Err:" + err.Error()
  521. }
  522. return
  523. }
  524. // 判断主题与图表类型是否相符
  525. if chartTheme.ChartThemeTypeId != chartThemeType.ChartThemeTypeId {
  526. br.Msg = "主题与图表类型不符"
  527. br.ErrMsg = "主题与图表类型不符"
  528. br.IsSendEmail = false
  529. return
  530. }
  531. // 更新
  532. chartThemeType.DefaultChartThemeId = chartTheme.ChartThemeId
  533. chartThemeType.ModifyTime = time.Now()
  534. err = chartThemeType.Update([]string{"DefaultChartThemeId", "ModifyTime"})
  535. if err != nil {
  536. br.Msg = "配置失败"
  537. br.ErrMsg = "配置失败,Err:" + err.Error()
  538. return
  539. }
  540. go eta_forum.ChartThemeTypeSave(chartThemeType)
  541. br.Ret = 200
  542. br.Success = true
  543. br.Msg = "配置成功"
  544. }
  545. // TypeListBySource
  546. // @Title 根据来源获取主题类型列表
  547. // @Description 获取主题类型列表接口
  548. // @Param Source query int true "图表主题类型id"
  549. // @Success 200 {object} []*chart_theme.ChartThemeType
  550. // @router /chart/theme/type/list_by_source [get]
  551. func (c *ChartThemeController) TypeListBySource() {
  552. br := new(models.BaseResponse).Init()
  553. defer func() {
  554. c.Data["json"] = br
  555. c.ServeJSON()
  556. }()
  557. sysUser := c.SysUser
  558. if sysUser == nil {
  559. br.Msg = "请登录"
  560. br.ErrMsg = "请登录,SysUser Is Empty"
  561. br.Ret = 408
  562. return
  563. }
  564. source, _ := c.GetInt("Source")
  565. if source <= 0 {
  566. br.Msg = "请选择来源"
  567. br.ErrMsg = "请选择来源"
  568. br.IsSendEmail = false
  569. return
  570. }
  571. list, err := chart_theme.GetChartThemeTypeListBySource(source)
  572. if err != nil {
  573. br.Msg = "获取失败"
  574. br.ErrMsg = "获取图表样式类型信息失败,Err:" + err.Error()
  575. return
  576. }
  577. br.Ret = 200
  578. br.Success = true
  579. br.Msg = "获取成功"
  580. br.Data = list
  581. }
  582. // ListBySource
  583. // @Title 根据来源获取主题列表
  584. // @Description 获取主题列表接口
  585. // @Param ChartType query int true "图表类型"
  586. // @Param Source query int true "来源"
  587. // @Success 200 {object} []*chart_theme.ChartTheme
  588. // @router /chart/theme/list_by_source [get]
  589. func (c *ChartThemeController) ListBySource() {
  590. br := new(models.BaseResponse).Init()
  591. defer func() {
  592. c.Data["json"] = br
  593. c.ServeJSON()
  594. }()
  595. sysUser := c.SysUser
  596. if sysUser == nil {
  597. br.Msg = "请登录"
  598. br.ErrMsg = "请登录,SysUser Is Empty"
  599. br.Ret = 408
  600. return
  601. }
  602. chartType, _ := c.GetInt("ChartType")
  603. if chartType < 0 {
  604. br.Msg = "请选择图表类型"
  605. br.ErrMsg = "请选择图表类型"
  606. br.IsSendEmail = false
  607. return
  608. }
  609. source, _ := c.GetInt("Source")
  610. if chartType < 0 {
  611. br.Msg = "请选择图表来源"
  612. br.ErrMsg = "请选择图表来源"
  613. br.IsSendEmail = false
  614. return
  615. }
  616. chartThemeType, err := chart_theme.GetChartThemeTypeByChartTypeAndSource(chartType, source)
  617. if err != nil {
  618. br.Msg = "获取失败"
  619. br.ErrMsg = "获取图表样式类型信息失败,Err:" + err.Error()
  620. return
  621. }
  622. list, err := chart_theme.GetChartThemeItemList(chartThemeType.ChartThemeTypeId)
  623. if err != nil {
  624. br.Msg = "获取失败"
  625. br.ErrMsg = "获取图表样式类型信息失败,Err:" + err.Error()
  626. return
  627. }
  628. // 兼容历史数据,加入新字段LineOptionList
  629. for i, v := range list {
  630. newConfig, e := data.ConvertOldChartOptions(v.Config)
  631. if e != nil {
  632. continue
  633. }
  634. list[i].Config = newConfig
  635. }
  636. br.Ret = 200
  637. br.Success = true
  638. br.Msg = "获取成功"
  639. br.Data = list
  640. }