chart_theme.go 22 KB

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