bi_dashboard.go 32 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219
  1. package controllers
  2. import (
  3. "encoding/json"
  4. "errors"
  5. "eta/eta_api/models"
  6. "eta/eta_api/models/bi_dashboard"
  7. "eta/eta_api/models/system"
  8. "eta/eta_api/services"
  9. "eta/eta_api/utils"
  10. "fmt"
  11. "strconv"
  12. "strings"
  13. "time"
  14. )
  15. type BIDaShboardController struct {
  16. BaseAuthController
  17. }
  18. // GroupList
  19. // @Title 获取我的列表
  20. // @Description 获取我的列表接口
  21. // @Success 200 {object} models.RespGroupList
  22. // @router /my_list [get]
  23. func (this *BIDaShboardController) MyList() {
  24. br := new(models.BaseResponse).Init()
  25. defer func() {
  26. this.Data["json"] = br
  27. this.ServeJSON()
  28. }()
  29. // 获取我的看板列表
  30. privateCond := ` AND sys_admin_id = ? `
  31. privatePars := []interface{}{this.SysUser.AdminId}
  32. privateList, err := bi_dashboard.GetBiDashboardList(privateCond, privatePars)
  33. if err != nil {
  34. err = errors.New("我的看板列表查询出错:" + err.Error())
  35. return
  36. }
  37. br.Ret = 200
  38. br.Success = true
  39. br.Msg = "查询成功"
  40. br.Data = privateList
  41. return
  42. }
  43. // AddDashboard
  44. // @Title 新增看板
  45. // @Description 新增看板接口
  46. // @Param request body models.AddDashboardReq true "type json string"
  47. // @Success 200 Ret=200 新增成功
  48. // @router /add [post]
  49. func (this *BIDaShboardController) AddDashboard() {
  50. br := new(models.BaseResponse).Init()
  51. defer func() {
  52. this.Data["json"] = br
  53. this.ServeJSON()
  54. }()
  55. var req bi_dashboard.AddDashboardReq
  56. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  57. if err != nil {
  58. br.Msg = "参数解析异常!"
  59. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  60. return
  61. }
  62. if req.BiDashboardName == "" {
  63. br.Msg = "名称不能为空"
  64. return
  65. }
  66. nameItem, err := bi_dashboard.GetDashboardByName(req.BiDashboardName)
  67. if err != nil && err.Error() != utils.ErrNoRow() {
  68. br.Msg = "查询失败"
  69. br.ErrMsg = "查询失败,Err:" + err.Error()
  70. return
  71. }
  72. if nameItem != nil && nameItem.BiDashboardId > 0 {
  73. br.Msg = "名称重复"
  74. return
  75. }
  76. item := &bi_dashboard.BiDashboard{
  77. //BiDashboardClassifyId: req.ClassifyId,
  78. BiDashboardName: req.BiDashboardName,
  79. SysAdminId: this.SysUser.AdminId,
  80. SysAdminName: this.SysUser.RealName,
  81. //Sort: 0,
  82. CreateTime: time.Now(),
  83. ModifyTime: time.Now(),
  84. State: 1,
  85. }
  86. id, e := bi_dashboard.AddBiDashboard(item)
  87. if e != nil {
  88. err = e
  89. br.Msg = "新增失败"
  90. br.ErrMsg = "新增失败,Err:" + e.Error()
  91. return
  92. }
  93. detailList := make([]*bi_dashboard.BiDashboardDetail, 0)
  94. for i, v := range req.List {
  95. item := &bi_dashboard.BiDashboardDetail{
  96. BiDashboardId: int(id),
  97. Type: v.Type,
  98. UniqueCode: v.UniqueCode,
  99. Sort: i + 1,
  100. CreateTime: time.Now(),
  101. ModifyTime: time.Now(),
  102. }
  103. detailList = append(detailList, item)
  104. }
  105. err = bi_dashboard.AddBiDashboardDetailMulti(detailList)
  106. if err != nil {
  107. br.Msg = "新增详情失败"
  108. br.ErrMsg = "新增详情失败,Err:" + err.Error()
  109. return
  110. }
  111. br.Ret = 200
  112. br.Success = true
  113. br.Msg = "新增成功"
  114. //br.Data =
  115. }
  116. // EditPpt
  117. // @Title 编辑看板
  118. // @Description 编辑看板接口
  119. // @Param request body bi_dashboard.EditDashboardReq true "type json string"
  120. // @Success 200 Ret=200 编辑成功
  121. // @router /edit [post]
  122. func (this *BIDaShboardController) EditDashboard() {
  123. br := new(models.BaseResponse).Init()
  124. defer func() {
  125. this.Data["json"] = br
  126. this.ServeJSON()
  127. }()
  128. var req bi_dashboard.EditDashboardReq
  129. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  130. if err != nil {
  131. br.Msg = "参数解析异常!"
  132. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  133. return
  134. }
  135. if req.BiDashboardName == "" {
  136. br.Msg = "标题不能为空"
  137. return
  138. }
  139. item, err := bi_dashboard.GetDashboardById(req.BiDashboardId)
  140. if err != nil {
  141. br.Msg = "获取数据异常!"
  142. br.ErrMsg = "获取数据异常,Err:" + err.Error()
  143. return
  144. }
  145. // 判断权限
  146. if item.SysAdminId != this.SysUser.AdminId {
  147. br.Msg = `无权编辑`
  148. return
  149. }
  150. // 修改
  151. item.BiDashboardName = req.BiDashboardName
  152. item.ModifyTime = time.Now()
  153. err = bi_dashboard.EditDashboard(item)
  154. if err != nil {
  155. br.Msg = "编辑失败"
  156. br.ErrMsg = "编辑失败,Err:" + err.Error()
  157. return
  158. }
  159. err = bi_dashboard.DeleteBiDashboardDetail(req.BiDashboardId)
  160. if err != nil {
  161. br.Msg = "删除详情失败"
  162. br.ErrMsg = "删除详情失败,Err:" + err.Error()
  163. return
  164. }
  165. detailList := make([]*bi_dashboard.BiDashboardDetail, 0)
  166. for _, v := range req.List {
  167. item := &bi_dashboard.BiDashboardDetail{
  168. BiDashboardId: req.BiDashboardId,
  169. Type: v.Type,
  170. UniqueCode: v.UniqueCode,
  171. Sort: v.Sort,
  172. CreateTime: time.Now(),
  173. ModifyTime: time.Now(),
  174. }
  175. detailList = append(detailList, item)
  176. }
  177. err = bi_dashboard.AddBiDashboardDetailMulti(detailList)
  178. if err != nil {
  179. br.Msg = "新增详情失败"
  180. br.ErrMsg = "新增详情失败,Err:" + err.Error()
  181. return
  182. }
  183. br.Ret = 200
  184. br.Success = true
  185. br.Msg = "编辑成功"
  186. br.IsAddLog = true
  187. }
  188. // DeleteDashboard
  189. // @Title 删除看板
  190. // @Description 删除看板接口
  191. // @Param request body bi_dashboard.DelDashboardReq true "type json string"
  192. // @Success 200 Ret=200 删除成功
  193. // @router /delete [post]
  194. func (this *BIDaShboardController) DeleteDashboard() {
  195. br := new(models.BaseResponse).Init()
  196. defer func() {
  197. this.Data["json"] = br
  198. this.ServeJSON()
  199. }()
  200. var req bi_dashboard.DelDashboardReq
  201. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  202. if err != nil {
  203. br.Msg = "参数解析异常!"
  204. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  205. return
  206. }
  207. if req.BiDashboardId <= 0 {
  208. br.Msg = "参数错误"
  209. return
  210. }
  211. item, err := bi_dashboard.GetDashboardById(req.BiDashboardId)
  212. if err != nil {
  213. br.Msg = "获取数据异常!"
  214. br.ErrMsg = "获取数据异常,Err:" + err.Error()
  215. return
  216. }
  217. if item.SysAdminId != this.SysUser.AdminId {
  218. br.Msg = "无权删除"
  219. return
  220. }
  221. err = bi_dashboard.DelDashboard(req.BiDashboardId)
  222. if err != nil {
  223. br.Msg = "删除失败"
  224. br.ErrMsg = "删除失败,Err:" + err.Error()
  225. return
  226. }
  227. //如果该看板存在共享记录,则删除共享
  228. err = bi_dashboard.DeleteDashboardGrant(req.BiDashboardId)
  229. if err != nil {
  230. br.Msg = "删除失败"
  231. br.ErrMsg = "删除失败,Err:" + err.Error()
  232. return
  233. }
  234. br.Ret = 200
  235. br.Success = true
  236. br.IsAddLog = true
  237. br.Msg = "删除成功"
  238. }
  239. // DeleteDashboard
  240. // @Title 删除看板详情
  241. // @Description 删除看板详情接口
  242. // @Param request body bi_dashboard.DelDashboardDetailReq true "type json string"
  243. // @Success 200 Ret=200 删除成功
  244. // @router /detail/delete [post]
  245. func (this *BIDaShboardController) DeleteDashboardDetail() {
  246. br := new(models.BaseResponse).Init()
  247. defer func() {
  248. this.Data["json"] = br
  249. this.ServeJSON()
  250. }()
  251. var req bi_dashboard.DelDashboardDetailReq
  252. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  253. if err != nil {
  254. br.Msg = "参数解析异常!"
  255. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  256. return
  257. }
  258. if req.BiDashboardDetailId <= 0 {
  259. br.Msg = "参数错误"
  260. return
  261. }
  262. err = bi_dashboard.DeleteBiDashboardDetailByDetailId(req.BiDashboardDetailId)
  263. if err != nil {
  264. br.Msg = "删除失败"
  265. br.ErrMsg = "删除失败,Err:" + err.Error()
  266. return
  267. }
  268. br.Ret = 200
  269. br.Success = true
  270. br.IsAddLog = true
  271. br.Msg = "删除成功"
  272. }
  273. // DetailDashboard
  274. // @Title 获取看板详情
  275. // @Description 获取看板详情接口
  276. // @Param PptId query int true "PptId"
  277. // @Success 200 {object} models.PptV2
  278. // @router /detail [get]
  279. func (this *BIDaShboardController) DetailDashboard() {
  280. br := new(models.BaseResponse).Init()
  281. defer func() {
  282. if br.ErrMsg == "" {
  283. br.IsSendEmail = false
  284. }
  285. this.Data["json"] = br
  286. this.ServeJSON()
  287. }()
  288. sysUser := this.SysUser
  289. if sysUser == nil {
  290. br.Msg = "请登录"
  291. br.ErrMsg = "请登录,SysUser Is Empty"
  292. br.Ret = 408
  293. return
  294. }
  295. dashboardId, _ := this.GetInt("DashboardId")
  296. resp := new(bi_dashboard.DashboardDetailResp)
  297. dashboardItem, err := bi_dashboard.GetDashboardById(dashboardId)
  298. if err != nil {
  299. err = errors.New("我的看板列表查询出错:" + err.Error())
  300. br.Msg = "我的看板列表查询出错"
  301. br.ErrMsg = err.Error()
  302. return
  303. }
  304. grantInfoList, err := bi_dashboard.GetDashboardGrantInfo(dashboardId)
  305. if err != nil {
  306. br.Msg = "信息获取失败"
  307. br.ErrMsg = "共享信息获取失败,Err:" + err.Error()
  308. return
  309. }
  310. if len(grantInfoList) > 0 {
  311. resp.IsGrant = 1
  312. }
  313. detailList, err := bi_dashboard.GetBiDashboardDetailById(dashboardId)
  314. if err != nil {
  315. br.Msg = "详情获取失败"
  316. br.ErrMsg = "详情获取失败,Err:" + err.Error()
  317. return
  318. }
  319. editor, e := services.UpdateBiDashboardEditing(dashboardId, 0, sysUser.AdminId, sysUser.RealName)
  320. if e != nil {
  321. br.Msg = "编辑状态更新失败"
  322. br.ErrMsg = "编辑状态更新失败,Err:" + e.Error()
  323. return
  324. }
  325. resp.Editor = editor
  326. resp.BiDashboard = dashboardItem
  327. resp.List = detailList
  328. br.Ret = 200
  329. br.Success = true
  330. br.Msg = "获取成功"
  331. br.Data = resp
  332. }
  333. // MoveDashboard
  334. // @Title 移动看板详情
  335. // @Description 移动看板详情接口
  336. // @Param request body bi_dashboard.MoveDashboardDetailReq true "type json string"
  337. // @Success 200 Ret=200 移动成功
  338. // @router /detail/move [post]
  339. func (this *BIDaShboardController) MoveDashboard() {
  340. br := new(models.BaseResponse).Init()
  341. defer func() {
  342. this.Data["json"] = br
  343. this.ServeJSON()
  344. }()
  345. var req bi_dashboard.MoveDashboardDetailReq
  346. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  347. if err != nil {
  348. br.Msg = "参数解析异常!"
  349. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  350. return
  351. }
  352. if req.BiDashboardId <= 0 {
  353. br.Msg = "参数错误"
  354. return
  355. }
  356. if req.BiDashboardDetailId == req.OtherDetailId || req.BiDashboardDetailId <= 0 || req.OtherDetailId <= 0 {
  357. br.Msg = "看板Id有误"
  358. return
  359. }
  360. if req.Sort < 0 || req.OtherSort < 0 || req.Sort == req.OtherSort {
  361. br.Msg = "排序有误"
  362. return
  363. }
  364. item, err := bi_dashboard.GetDashboardById(req.BiDashboardId)
  365. if err != nil {
  366. br.Msg = "获取数据异常!"
  367. br.ErrMsg = "获取数据异常,Err:" + err.Error()
  368. return
  369. }
  370. // 判断权限
  371. if item.SysAdminId != this.SysUser.AdminId {
  372. br.Msg = `无权移动`
  373. return
  374. }
  375. // 修改
  376. detailItem := &bi_dashboard.BiDashboardDetail{
  377. BiDashboardDetailId: req.BiDashboardDetailId,
  378. Sort: req.OtherSort,
  379. ModifyTime: time.Now(),
  380. }
  381. err = bi_dashboard.EditBiDashboardDetail(detailItem)
  382. if err != nil {
  383. br.Msg = "编辑详情失败"
  384. br.ErrMsg = "编辑详情失败,Err:" + err.Error()
  385. return
  386. }
  387. otherItem := &bi_dashboard.BiDashboardDetail{
  388. BiDashboardDetailId: req.OtherDetailId,
  389. Sort: req.Sort,
  390. ModifyTime: time.Now(),
  391. }
  392. err = bi_dashboard.EditBiDashboardDetail(otherItem)
  393. if err != nil {
  394. br.Msg = "编辑详情失败"
  395. br.ErrMsg = "编辑详情失败,Err:" + err.Error()
  396. return
  397. }
  398. br.Ret = 200
  399. br.Success = true
  400. br.Msg = "编辑成功"
  401. br.IsAddLog = true
  402. }
  403. // ShareList
  404. // @Title 获取共享列表
  405. // @Description 获取共享列表接口
  406. // @Success 200 {object} models.RespGroupList
  407. // @router /share_list [get]
  408. func (this *BIDaShboardController) ShareList() {
  409. br := new(models.BaseResponse).Init()
  410. defer func() {
  411. this.Data["json"] = br
  412. this.ServeJSON()
  413. }()
  414. //myPptList := make([]*bi_dashboard.BiDashboard, 0)
  415. //otherPptList := make([]*bi_dashboard.BiDashboard, 0)
  416. grantList := bi_dashboard.RespGroupList{}
  417. // 获取我的看板列表
  418. ShareList, err := bi_dashboard.GetAllMyShareList(this.SysUser.AdminId)
  419. if err != nil {
  420. err = errors.New("我的看板列表查询出错:" + err.Error())
  421. br.ErrMsg = err.Error()
  422. br.Msg = "查询失败"
  423. return
  424. }
  425. grantList.MyList = ShareList
  426. //dashboardMap := make(map[int]*bi_dashboard.BiDashboard)
  427. adminIdList := make([]int, 0) //需要查询的创建人admin_id列表集合
  428. adminIdMap := make(map[int]int) //需要查询的创建人admin_id集合,用来去重的,避免重复id
  429. grantDashboardList, err := bi_dashboard.GetAllGrantList(this.SysUser.AdminId)
  430. if err != nil {
  431. err = errors.New("我的看板列表查询出错:" + err.Error())
  432. br.ErrMsg = err.Error()
  433. br.Msg = "查询失败"
  434. return
  435. }
  436. publicAdminIdList := make([]int, 0)
  437. publicDashboardListMap := make(map[int][]*bi_dashboard.BiDashboard)
  438. for _, v := range grantDashboardList {
  439. publicDashboardList, ok := publicDashboardListMap[v.SysAdminId]
  440. if !ok {
  441. publicDashboardList = make([]*bi_dashboard.BiDashboard, 0)
  442. publicAdminIdList = append(publicAdminIdList, v.SysAdminId)
  443. if _, ok := adminIdMap[v.SysAdminId]; !ok {
  444. adminIdList = append(adminIdList, v.SysAdminId) //需要查询的创建人admin_id列表集合
  445. adminIdMap[v.SysAdminId] = v.SysAdminId //需要查询的创建人admin_id集合,用来去重的,避免重复id
  446. }
  447. }
  448. tmp := &bi_dashboard.BiDashboard{
  449. BiDashboardId: v.BiDashboardId,
  450. BiDashboardName: v.BiDashboardName,
  451. CreateTime: v.CreateTime,
  452. ModifyTime: v.ModifyTime,
  453. Sort: v.Sort,
  454. State: v.State,
  455. SysAdminId: v.SysAdminId,
  456. SysAdminName: v.SysAdminName,
  457. }
  458. publicDashboardList = append(publicDashboardList, tmp)
  459. publicDashboardListMap[v.SysAdminId] = publicDashboardList
  460. }
  461. // 创建人信息
  462. systemAdminMap := make(map[int]*system.Admin)
  463. systemAdminList, err := system.GetAdminListByIdList(adminIdList)
  464. if err != nil {
  465. return
  466. }
  467. for _, v := range systemAdminList {
  468. systemAdminMap[v.AdminId] = v
  469. }
  470. for _, v := range publicAdminIdList {
  471. systemAdmin, ok := systemAdminMap[v]
  472. if !ok {
  473. continue
  474. }
  475. // 看板 列表信息
  476. respGroupNameListItemList, ok := publicDashboardListMap[v]
  477. if !ok {
  478. respGroupNameListItemList = make([]*bi_dashboard.BiDashboard, 0)
  479. }
  480. // ppt 分组信息
  481. tmpRespGroupListItem := &bi_dashboard.RespOtherGroupListItem{
  482. GroupId: int64(systemAdmin.AdminId),
  483. GroupName: systemAdmin.RealName,
  484. AdminId: systemAdmin.AdminId,
  485. DashboardList: respGroupNameListItemList,
  486. }
  487. grantList.OtherList = append(grantList.OtherList, tmpRespGroupListItem)
  488. }
  489. //if len(dashboradIds) > 0 {
  490. // // 通过dashboradIds列表字段获取所有的看板信息
  491. // dashboradList, tmpErr := bi_dashboard.GetDashboradByIds(dashboradIds)
  492. // if tmpErr != nil {
  493. // err = errors.New("查询dashborad详情出错:" + err.Error())
  494. // br.Msg = "查询dashborad详情出错"
  495. // br.ErrMsg = err.Error()
  496. // return
  497. // }
  498. // for _, v := range dashboradList {
  499. // dashboardMap[v.BiDashboardId] = v
  500. // }
  501. //}
  502. br.Ret = 200
  503. br.Success = true
  504. br.Msg = "查询成功"
  505. br.Data = grantList
  506. return
  507. }
  508. // PublicList
  509. // @Title 获取公共列表
  510. // @Description 获取公共列表接口
  511. // @Success 200 {object} models.RespGroupList
  512. // @router /public_list [get]
  513. func (this *BIDaShboardController) PublicList() {
  514. br := new(models.BaseResponse).Init()
  515. defer func() {
  516. this.Data["json"] = br
  517. this.ServeJSON()
  518. }()
  519. resp := make([]*bi_dashboard.RespPublicGroupListItem, 0)
  520. // 获取公共看板列表
  521. publicCond := ` AND state = 6 `
  522. publicPars := make([]interface{}, 0)
  523. publicList, err := bi_dashboard.GetBiDashboardList(publicCond, publicPars)
  524. if err != nil {
  525. err = errors.New("我的看板列表查询出错:" + err.Error())
  526. return
  527. }
  528. //dashboardMap := make(map[int]*bi_dashboard.BiDashboard)
  529. adminIdList := make([]int, 0) //需要查询的创建人admin_id列表集合
  530. adminIdMap := make(map[int]int) //需要查询的创建人admin_id集合,用来去重的,避免重复id
  531. publicAdminIdList := make([]int, 0)
  532. publicDashboardListMap := make(map[int][]*bi_dashboard.BiDashboard)
  533. publicDashboardClassifyIdMap := make(map[int]int)
  534. for _, v := range publicList {
  535. publicDashboardList, ok := publicDashboardListMap[v.SysAdminId]
  536. if !ok {
  537. publicDashboardList = make([]*bi_dashboard.BiDashboard, 0)
  538. publicAdminIdList = append(publicAdminIdList, v.SysAdminId)
  539. if _, ok := adminIdMap[v.SysAdminId]; !ok {
  540. adminIdList = append(adminIdList, v.SysAdminId) //需要查询的创建人admin_id列表集合
  541. adminIdMap[v.SysAdminId] = v.SysAdminId //需要查询的创建人admin_id集合,用来去重的,避免重复id
  542. }
  543. }
  544. tmp := &bi_dashboard.BiDashboard{
  545. BiDashboardId: v.BiDashboardId,
  546. BiDashboardClassifyId: v.BiDashboardClassifyId,
  547. BiDashboardName: v.BiDashboardName,
  548. CreateTime: v.CreateTime,
  549. ModifyTime: v.ModifyTime,
  550. Sort: v.Sort,
  551. State: v.State,
  552. SysAdminId: v.SysAdminId,
  553. SysAdminName: v.SysAdminName,
  554. }
  555. publicDashboardList = append(publicDashboardList, tmp)
  556. publicDashboardListMap[v.SysAdminId] = publicDashboardList
  557. publicDashboardClassifyIdMap[v.BiDashboardClassifyId] = v.BiDashboardClassifyId
  558. }
  559. // 创建人信息
  560. systemAdminMap := make(map[int]*system.Admin)
  561. systemAdminList, err := system.GetAdminListByIdList(adminIdList)
  562. if err != nil {
  563. return
  564. }
  565. for _, v := range systemAdminList {
  566. systemAdminMap[v.AdminId] = v
  567. }
  568. for _, v := range adminIdList {
  569. systemAdmin, ok := systemAdminMap[v]
  570. if !ok {
  571. continue
  572. }
  573. // 看板 列表信息
  574. respGroupNameListItemList, ok := publicDashboardListMap[v]
  575. if !ok {
  576. respGroupNameListItemList = make([]*bi_dashboard.BiDashboard, 0)
  577. }
  578. // ppt 分组信息
  579. tmpRespGroupListItem := &bi_dashboard.RespPublicGroupListItem{
  580. GroupId: int64(systemAdmin.AdminId),
  581. GroupName: systemAdmin.RealName,
  582. AdminId: systemAdmin.AdminId,
  583. DashboardList: make([]*bi_dashboard.BiDashboard, 0),
  584. }
  585. for _, vv := range respGroupNameListItemList {
  586. if vv.BiDashboardClassifyId == c.BiDashboardClassifyId {
  587. tmpRespGroupListItem.DashboardList = append(tmpRespGroupListItem.DashboardList, vv)
  588. tmpItem.Children = append(tmpItem.Children, tmpRespGroupListItem)
  589. }
  590. }
  591. }
  592. resp = append(resp, tmpItem)
  593. br.Ret = 200
  594. br.Success = true
  595. br.Msg = "查询成功"
  596. br.Data = resp
  597. return
  598. }
  599. // AddDashboardClassify
  600. // @Title 新增看板分类
  601. // @Description 新增看板分类接口
  602. // @Param request body bi_dashboard.AddDashboardClassifyReq true "type json string"
  603. // @Success 200 Ret=200 新增成功
  604. // @router /classify/add [post]
  605. func (this *BIDaShboardController) AddDashboardClassify() {
  606. br := new(models.BaseResponse).Init()
  607. defer func() {
  608. this.Data["json"] = br
  609. this.ServeJSON()
  610. }()
  611. var req bi_dashboard.AddDashboardClassifyReq
  612. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  613. if err != nil {
  614. br.Msg = "参数解析异常!"
  615. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  616. return
  617. }
  618. if req.ClassifyName == "" {
  619. br.Msg = "名称不能为空"
  620. return
  621. }
  622. maxSort, err := bi_dashboard.GetBiDashboardClassifyMaxSort()
  623. if err != nil {
  624. br.Msg = "获取最大排序值失败"
  625. br.ErrMsg = "获取最大排序值失败,Err:" + err.Error()
  626. return
  627. }
  628. count, err := bi_dashboard.GetBiDashboardClassifyByName(req.ClassifyName)
  629. if err != nil {
  630. br.Msg = "获取分类名称失败"
  631. br.ErrMsg = "获取分类名称失败,Err:" + err.Error()
  632. return
  633. }
  634. if count > 0 {
  635. br.Msg = "分类名称已存在"
  636. return
  637. }
  638. item := &bi_dashboard.BiDashboardClassify{
  639. BiDashboardClassifyName: req.ClassifyName,
  640. Sort: maxSort + 1,
  641. CreateTime: time.Now(),
  642. ModifyTime: time.Now(),
  643. }
  644. _, e := bi_dashboard.AddBiDashboardClassify(item)
  645. if e != nil {
  646. err = e
  647. br.Msg = "新增失败"
  648. br.ErrMsg = "新增失败,Err:" + e.Error()
  649. return
  650. }
  651. br.Ret = 200
  652. br.Success = true
  653. br.Msg = "新增成功"
  654. //br.Data =
  655. }
  656. // EditDashboardClassify
  657. // @Title 编辑看板分类
  658. // @Description 编辑看板分类接口
  659. // @Param request body bi_dashboard.EditDashboardReq true "type json string"
  660. // @Success 200 Ret=200 编辑成功
  661. // @router /classify/edit [post]
  662. func (this *BIDaShboardController) EditDashboardClassify() {
  663. br := new(models.BaseResponse).Init()
  664. defer func() {
  665. this.Data["json"] = br
  666. this.ServeJSON()
  667. }()
  668. var req bi_dashboard.EditDashboardClassifyReq
  669. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  670. if err != nil {
  671. br.Msg = "参数解析异常!"
  672. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  673. return
  674. }
  675. if req.ClassifyName == "" {
  676. br.Msg = "标题不能为空"
  677. return
  678. }
  679. if req.BiDashboardClassifyId <= 0 {
  680. br.Msg = "参数有误"
  681. br.ErrMsg = fmt.Sprintf("参数有误, BiDashboardClassifyId: %d", req.BiDashboardClassifyId)
  682. return
  683. }
  684. item, err := bi_dashboard.GetBiDashboardClassifyById(req.BiDashboardClassifyId)
  685. if err != nil && err.Error() != utils.ErrNoRow() {
  686. br.Msg = "获取数据异常!"
  687. br.ErrMsg = "获取数据异常,Err:" + err.Error()
  688. return
  689. }
  690. // 修改
  691. item.BiDashboardClassifyName = req.ClassifyName
  692. item.ModifyTime = time.Now()
  693. err = bi_dashboard.EditDashboardClassify(item)
  694. if err != nil {
  695. br.Msg = "编辑失败"
  696. br.ErrMsg = "编辑失败,Err:" + err.Error()
  697. return
  698. }
  699. br.Ret = 200
  700. br.Success = true
  701. br.Msg = "编辑成功"
  702. br.IsAddLog = true
  703. }
  704. // Grant
  705. // @Title 分配看板权限
  706. // @Description 分配看板权限接口
  707. // @Param request body models.GrantPptReq true "type json string"
  708. // @Success 200 Ret=200 分配成功
  709. // @router /grant [post]
  710. func (this *BIDaShboardController) Grant() {
  711. br := new(models.BaseResponse).Init()
  712. defer func() {
  713. this.Data["json"] = br
  714. this.ServeJSON()
  715. }()
  716. var req bi_dashboard.GrantDashboardReq
  717. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  718. if err != nil {
  719. br.Msg = "参数解析异常!"
  720. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  721. return
  722. }
  723. if req.AdminIdStr == "" {
  724. br.Msg = "参数错误"
  725. return
  726. }
  727. if req.BiDashboardId <= 0 {
  728. br.Msg = "参数错误"
  729. return
  730. }
  731. dashboardItem, err := bi_dashboard.GetDashboardById(req.BiDashboardId)
  732. if err != nil {
  733. err = errors.New("我的看板列表查询出错:" + err.Error())
  734. br.Msg = "我的看板列表查询出错"
  735. br.ErrMsg = err.Error()
  736. return
  737. }
  738. if dashboardItem.SysAdminId != this.SysUser.AdminId {
  739. br.Msg = "无权配置"
  740. return
  741. }
  742. list := make([]*bi_dashboard.BiDashboardGrant, 0)
  743. grantAdminIdStrList := strings.Split(req.AdminIdStr, ",")
  744. lenGrantAdminIdStrList := len(grantAdminIdStrList) //指定用户的人数
  745. for _, v := range grantAdminIdStrList {
  746. grantAdminId, tmpErr := strconv.Atoi(v)
  747. if tmpErr != nil {
  748. br.Msg = "参数有误"
  749. br.ErrMsg = fmt.Sprintf("参数有误,Err:%s", tmpErr.Error())
  750. return
  751. }
  752. //如果只选择了自己作为指定的人,那么就提示他报错。如果多人,那么就过滤自己
  753. if grantAdminId == this.SysUser.AdminId {
  754. if lenGrantAdminIdStrList == 1 {
  755. br.Msg = "不能指定自己为权限用户"
  756. br.ErrMsg = fmt.Sprintf("参数有误,Err:%s", tmpErr.Error())
  757. return
  758. }
  759. continue
  760. }
  761. tmpV := &bi_dashboard.BiDashboardGrant{
  762. BiDashboardId: req.BiDashboardId,
  763. GrantAdminId: grantAdminId,
  764. CreateTime: time.Now(),
  765. }
  766. list = append(list, tmpV)
  767. }
  768. if len(list) <= 0 {
  769. br.Msg = "参数有误"
  770. br.ErrMsg = fmt.Sprintf("参数有误,Err:%s", "指定用户为空")
  771. return
  772. }
  773. err = bi_dashboard.MultiAddDashboardGrant(req.BiDashboardId, list)
  774. if err != nil {
  775. br.Msg = "分配失败"
  776. br.ErrMsg = fmt.Sprintf("分配失败,Err:%s", err.Error())
  777. return
  778. }
  779. br.Ret = 200
  780. br.Success = true
  781. br.IsAddLog = true
  782. br.Msg = "分配成功"
  783. }
  784. // Public
  785. // @Title
  786. // @Description 设置公共看板
  787. // @Param request body models.GrantPptReq true "type json string"
  788. // @Success 200 Ret=200 分配成功
  789. // @router /public [post]
  790. func (this *BIDaShboardController) Public() {
  791. br := new(models.BaseResponse).Init()
  792. defer func() {
  793. this.Data["json"] = br
  794. this.ServeJSON()
  795. }()
  796. var req bi_dashboard.PublicDashboardReq
  797. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  798. if err != nil {
  799. br.Msg = "参数解析异常!"
  800. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  801. return
  802. }
  803. item, err := bi_dashboard.GetDashboardById(req.BiDashboardId)
  804. if err != nil {
  805. br.Msg = "获取数据异常!"
  806. br.ErrMsg = "获取数据异常,Err:" + err.Error()
  807. return
  808. }
  809. item.State = 6
  810. err = bi_dashboard.EditDashboard(item)
  811. if err != nil {
  812. br.Msg = "编辑失败"
  813. br.ErrMsg = "编辑失败,Err:" + err.Error()
  814. return
  815. }
  816. br.Ret = 200
  817. br.Success = true
  818. br.IsAddLog = true
  819. br.Msg = "分配成功"
  820. }
  821. // GroupList
  822. // @Title 获取分类列表
  823. // @Description 获取分类列表接口
  824. // @Success 200 {object} models.RespGroupList
  825. // @router /classify/list [get]
  826. func (this *BIDaShboardController) ClassifyList() {
  827. br := new(models.BaseResponse).Init()
  828. defer func() {
  829. this.Data["json"] = br
  830. this.ServeJSON()
  831. }()
  832. classifyList, err := bi_dashboard.GetBiDashboardClassifyAllList()
  833. if err != nil {
  834. br.Msg = "查询失败"
  835. br.ErrMsg = "查询失败,Err:" + err.Error()
  836. return
  837. }
  838. br.Ret = 200
  839. br.Success = true
  840. br.Msg = "查询成功"
  841. br.Data = classifyList
  842. return
  843. }
  844. // CancelGrant
  845. // @Title 取消分配看板权限
  846. // @Description 取消分配看板权限
  847. // @Param request body bi_dashboard.DelDashboardReq true "type json string"
  848. // @Success 200 Ret=200 分配成功
  849. // @router /grant/cancel [post]
  850. func (this *BIDaShboardController) CancelGrant() {
  851. br := new(models.BaseResponse).Init()
  852. defer func() {
  853. this.Data["json"] = br
  854. this.ServeJSON()
  855. }()
  856. var req bi_dashboard.DelDashboardReq
  857. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  858. if err != nil {
  859. br.Msg = "参数解析异常!"
  860. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  861. return
  862. }
  863. if req.BiDashboardId <= 0 {
  864. br.Msg = "参数错误"
  865. return
  866. }
  867. item, err := bi_dashboard.GetDashboardById(req.BiDashboardId)
  868. if err != nil {
  869. br.Msg = "数据不存在"
  870. br.ErrMsg = "数据不存在,Err:" + err.Error()
  871. return
  872. }
  873. if item.SysAdminId != this.SysUser.AdminId {
  874. br.Msg = "无权配置"
  875. return
  876. }
  877. // 分配
  878. err = bi_dashboard.DeleteDashboardGrant(req.BiDashboardId)
  879. if err != nil {
  880. br.Msg = "取消失败"
  881. br.ErrMsg = "取消失败,Err:" + err.Error()
  882. return
  883. }
  884. br.Ret = 200
  885. br.Success = true
  886. br.IsAddLog = true
  887. br.Msg = "取消成功"
  888. }
  889. // GrantInfo
  890. // @Title 获取分配ppt权限详情
  891. // @Description 获取分配ppt权限详情接口
  892. // @Param BiDashboardId query int true "看板的id"
  893. // @Success 200 {object} models.GrantInfoResp
  894. // @router /grant/info [get]
  895. func (this *BIDaShboardController) GrantInfo() {
  896. br := new(models.BaseResponse).Init()
  897. defer func() {
  898. this.Data["json"] = br
  899. this.ServeJSON()
  900. }()
  901. biDashboardId, _ := this.GetInt("BiDashboardId")
  902. if biDashboardId <= 0 {
  903. br.Msg = "参数错误"
  904. return
  905. }
  906. item, err := bi_dashboard.GetDashboardById(biDashboardId)
  907. if err != nil {
  908. br.Msg = "数据不存在"
  909. br.ErrMsg = "数据不存在,Err:" + err.Error()
  910. return
  911. }
  912. if item.SysAdminId != this.SysUser.AdminId {
  913. br.Msg = "无权配置"
  914. return
  915. }
  916. grantInfoList, err := bi_dashboard.GetDashboardGrantInfo(biDashboardId)
  917. if err != nil {
  918. br.Msg = "信息获取失败"
  919. br.ErrMsg = "信息获取失败,Err:" + err.Error()
  920. return
  921. }
  922. if len(grantInfoList) <= 0 {
  923. br.Msg = "未配置"
  924. br.IsSendEmail = false
  925. br.Success = true
  926. br.Ret = 200
  927. return
  928. }
  929. var adminIdStr string
  930. adminIdsList := make([]string, 0)
  931. for _, v := range grantInfoList {
  932. adminIdsList = append(adminIdsList, strconv.Itoa(int(v.GrantAdminId)))
  933. }
  934. adminIdStr = strings.Join(adminIdsList, ",")
  935. br.Ret = 200
  936. br.Success = true
  937. br.Data = adminIdStr
  938. br.Msg = "查询成功"
  939. }
  940. // Public
  941. // @Title
  942. // @Description 撤销公共看板
  943. // @Param request body models.GrantPptReq true "type json string"
  944. // @Success 200 Ret=200 分配成功
  945. // @router /public/cancel [post]
  946. func (this *BIDaShboardController) PublicCancel() {
  947. br := new(models.BaseResponse).Init()
  948. defer func() {
  949. this.Data["json"] = br
  950. this.ServeJSON()
  951. }()
  952. var req bi_dashboard.DelDashboardReq
  953. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  954. if err != nil {
  955. br.Msg = "参数解析异常!"
  956. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  957. return
  958. }
  959. item, err := bi_dashboard.GetDashboardById(req.BiDashboardId)
  960. if err != nil && err.Error() != utils.ErrNoRow() {
  961. br.Msg = "获取数据异常!"
  962. br.ErrMsg = "获取数据异常,Err:" + err.Error()
  963. return
  964. }
  965. item.State = 1
  966. err = bi_dashboard.SaveDashboard(item)
  967. if err != nil {
  968. br.Msg = "编辑失败"
  969. br.ErrMsg = "编辑失败,Err:" + err.Error()
  970. return
  971. }
  972. br.Ret = 200
  973. br.Success = true
  974. br.IsAddLog = true
  975. br.Msg = "撤销成功"
  976. }
  977. // GroupList
  978. // @Title 获取我的首页看板
  979. // @Description 获取我的首页看板接口
  980. // @Success 200 {object} models.RespGroupList
  981. // @router /home_page [get]
  982. func (this *BIDaShboardController) HomePage() {
  983. br := new(models.BaseResponse).Init()
  984. defer func() {
  985. this.Data["json"] = br
  986. this.ServeJSON()
  987. }()
  988. item, err := bi_dashboard.GetBiDashboardHomePageById(this.SysUser.AdminId)
  989. if err != nil && err.Error() != utils.ErrNoRow() {
  990. br.Msg = "数据不存在"
  991. br.ErrMsg = "数据不存在,Err:" + err.Error()
  992. return
  993. }
  994. publicCond := ` AND state = 6 AND bi_dashboard_classify_id > 0 `
  995. publicPars := []interface{}{this.SysUser.AdminId}
  996. publicList, err := bi_dashboard.GetBiDashboardList(publicCond, publicPars)
  997. if err != nil {
  998. err = errors.New("我的看板列表查询出错:" + err.Error())
  999. return
  1000. }
  1001. if item.BiDashboardHomePageId == 0 && len(publicList) > 0 {
  1002. item = &bi_dashboard.BiDashboardHomePage{
  1003. AdminId: publicList[0].SysAdminId,
  1004. BiDashboardId: publicList[0].BiDashboardId,
  1005. FromType: 3,
  1006. }
  1007. }
  1008. if item.BiDashboardId == 0 {
  1009. item = nil
  1010. }
  1011. br.Ret = 200
  1012. br.Success = true
  1013. br.Msg = "查询成功"
  1014. br.Data = item
  1015. return
  1016. }
  1017. // GroupList
  1018. // @Title 保存我的看板首页
  1019. // @Description保存我的看板首页接口
  1020. // @Success 200 {object} models.RespGroupList
  1021. // @router /home_page/save [post]
  1022. func (this *BIDaShboardController) HomePageSave() {
  1023. br := new(models.BaseResponse).Init()
  1024. defer func() {
  1025. this.Data["json"] = br
  1026. this.ServeJSON()
  1027. }()
  1028. var req bi_dashboard.SaveHomePageReq
  1029. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  1030. if err != nil {
  1031. br.Msg = "参数解析异常!"
  1032. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  1033. return
  1034. }
  1035. if req.BiDashboardId <= 0 {
  1036. br.Msg = "参数错误"
  1037. return
  1038. }
  1039. item, err := bi_dashboard.GetBiDashboardHomePageById(this.SysUser.AdminId)
  1040. if err != nil && err.Error() != utils.ErrNoRow() {
  1041. br.Msg = "首页看板查询失败"
  1042. br.ErrMsg = "首页看板查询失败,Err:" + err.Error()
  1043. return
  1044. }
  1045. homePageItem := &bi_dashboard.BiDashboardHomePage{
  1046. BiDashboardId: req.BiDashboardId,
  1047. AdminId: this.SysUser.AdminId,
  1048. CreateTime: time.Now(),
  1049. ModifyTime: time.Now(),
  1050. FromType: req.FromType,
  1051. }
  1052. if item.BiDashboardHomePageId > 0 {
  1053. homePageItem.BiDashboardHomePageId = item.BiDashboardHomePageId
  1054. }
  1055. err = bi_dashboard.SaveBiDashboardHomePage(homePageItem)
  1056. if err != nil {
  1057. br.Msg = "保存失败"
  1058. br.ErrMsg = "保存失败,Err:" + err.Error()
  1059. return
  1060. }
  1061. br.Ret = 200
  1062. br.Success = true
  1063. br.Msg = "保存成功"
  1064. return
  1065. }
  1066. // Editing
  1067. // @Title 标记/查询编辑状态
  1068. // @Description 标记/查询编辑状态
  1069. // @Param request body models.PPTEditingReq true "type json string"
  1070. // @Success 200 Ret=200 操作成功
  1071. // @router /editing [post]
  1072. func (this *BIDaShboardController) Editing() {
  1073. br := new(models.BaseResponse).Init()
  1074. defer func() {
  1075. if br.ErrMsg == "" {
  1076. br.IsSendEmail = false
  1077. }
  1078. this.Data["json"] = br
  1079. this.ServeJSON()
  1080. }()
  1081. sysUser := this.SysUser
  1082. if sysUser == nil {
  1083. br.Msg = "请登录"
  1084. br.ErrMsg = "请登录,SysUser Is Empty"
  1085. br.Ret = 408
  1086. return
  1087. }
  1088. var req bi_dashboard.BiDashboardEditingReq
  1089. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  1090. if err != nil {
  1091. br.Msg = "参数解析异常!"
  1092. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  1093. return
  1094. }
  1095. if req.BiDashboardId <= 0 {
  1096. br.Msg = "参数有误"
  1097. return
  1098. }
  1099. if req.Status < 0 {
  1100. br.Msg = "标记状态异常"
  1101. return
  1102. }
  1103. editor, e := services.UpdateBiDashboardEditing(req.BiDashboardId, req.Status, sysUser.AdminId, sysUser.RealName)
  1104. if e != nil {
  1105. br.Msg = "操作失败"
  1106. br.ErrMsg = "更新编辑状态失败, err: " + e.Error()
  1107. return
  1108. }
  1109. br.Data = editor
  1110. br.Ret = 200
  1111. br.Success = true
  1112. br.Msg = "操作成功"
  1113. }