bi_dashboard.go 32 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217
  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. tmpRespGroupListItem.DashboardList = append(tmpRespGroupListItem.DashboardList, vv)
  587. }
  588. resp = append(resp, tmpRespGroupListItem)
  589. }
  590. br.Ret = 200
  591. br.Success = true
  592. br.Msg = "查询成功"
  593. br.Data = resp
  594. return
  595. }
  596. // AddDashboardClassify
  597. // @Title 新增看板分类
  598. // @Description 新增看板分类接口
  599. // @Param request body bi_dashboard.AddDashboardClassifyReq true "type json string"
  600. // @Success 200 Ret=200 新增成功
  601. // @router /classify/add [post]
  602. func (this *BIDaShboardController) AddDashboardClassify() {
  603. br := new(models.BaseResponse).Init()
  604. defer func() {
  605. this.Data["json"] = br
  606. this.ServeJSON()
  607. }()
  608. var req bi_dashboard.AddDashboardClassifyReq
  609. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  610. if err != nil {
  611. br.Msg = "参数解析异常!"
  612. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  613. return
  614. }
  615. if req.ClassifyName == "" {
  616. br.Msg = "名称不能为空"
  617. return
  618. }
  619. maxSort, err := bi_dashboard.GetBiDashboardClassifyMaxSort()
  620. if err != nil {
  621. br.Msg = "获取最大排序值失败"
  622. br.ErrMsg = "获取最大排序值失败,Err:" + err.Error()
  623. return
  624. }
  625. count, err := bi_dashboard.GetBiDashboardClassifyByName(req.ClassifyName)
  626. if err != nil {
  627. br.Msg = "获取分类名称失败"
  628. br.ErrMsg = "获取分类名称失败,Err:" + err.Error()
  629. return
  630. }
  631. if count > 0 {
  632. br.Msg = "分类名称已存在"
  633. return
  634. }
  635. item := &bi_dashboard.BiDashboardClassify{
  636. BiDashboardClassifyName: req.ClassifyName,
  637. Sort: maxSort + 1,
  638. CreateTime: time.Now(),
  639. ModifyTime: time.Now(),
  640. }
  641. _, e := bi_dashboard.AddBiDashboardClassify(item)
  642. if e != nil {
  643. err = e
  644. br.Msg = "新增失败"
  645. br.ErrMsg = "新增失败,Err:" + e.Error()
  646. return
  647. }
  648. br.Ret = 200
  649. br.Success = true
  650. br.Msg = "新增成功"
  651. //br.Data =
  652. }
  653. // EditDashboardClassify
  654. // @Title 编辑看板分类
  655. // @Description 编辑看板分类接口
  656. // @Param request body bi_dashboard.EditDashboardReq true "type json string"
  657. // @Success 200 Ret=200 编辑成功
  658. // @router /classify/edit [post]
  659. func (this *BIDaShboardController) EditDashboardClassify() {
  660. br := new(models.BaseResponse).Init()
  661. defer func() {
  662. this.Data["json"] = br
  663. this.ServeJSON()
  664. }()
  665. var req bi_dashboard.EditDashboardClassifyReq
  666. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  667. if err != nil {
  668. br.Msg = "参数解析异常!"
  669. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  670. return
  671. }
  672. if req.ClassifyName == "" {
  673. br.Msg = "标题不能为空"
  674. return
  675. }
  676. if req.BiDashboardClassifyId <= 0 {
  677. br.Msg = "参数有误"
  678. br.ErrMsg = fmt.Sprintf("参数有误, BiDashboardClassifyId: %d", req.BiDashboardClassifyId)
  679. return
  680. }
  681. item, err := bi_dashboard.GetBiDashboardClassifyById(req.BiDashboardClassifyId)
  682. if err != nil && err.Error() != utils.ErrNoRow() {
  683. br.Msg = "获取数据异常!"
  684. br.ErrMsg = "获取数据异常,Err:" + err.Error()
  685. return
  686. }
  687. // 修改
  688. item.BiDashboardClassifyName = req.ClassifyName
  689. item.ModifyTime = time.Now()
  690. err = bi_dashboard.EditDashboardClassify(item)
  691. if err != nil {
  692. br.Msg = "编辑失败"
  693. br.ErrMsg = "编辑失败,Err:" + err.Error()
  694. return
  695. }
  696. br.Ret = 200
  697. br.Success = true
  698. br.Msg = "编辑成功"
  699. br.IsAddLog = true
  700. }
  701. // Grant
  702. // @Title 分配看板权限
  703. // @Description 分配看板权限接口
  704. // @Param request body models.GrantPptReq true "type json string"
  705. // @Success 200 Ret=200 分配成功
  706. // @router /grant [post]
  707. func (this *BIDaShboardController) Grant() {
  708. br := new(models.BaseResponse).Init()
  709. defer func() {
  710. this.Data["json"] = br
  711. this.ServeJSON()
  712. }()
  713. var req bi_dashboard.GrantDashboardReq
  714. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  715. if err != nil {
  716. br.Msg = "参数解析异常!"
  717. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  718. return
  719. }
  720. if req.AdminIdStr == "" {
  721. br.Msg = "参数错误"
  722. return
  723. }
  724. if req.BiDashboardId <= 0 {
  725. br.Msg = "参数错误"
  726. return
  727. }
  728. dashboardItem, err := bi_dashboard.GetDashboardById(req.BiDashboardId)
  729. if err != nil {
  730. err = errors.New("我的看板列表查询出错:" + err.Error())
  731. br.Msg = "我的看板列表查询出错"
  732. br.ErrMsg = err.Error()
  733. return
  734. }
  735. if dashboardItem.SysAdminId != this.SysUser.AdminId {
  736. br.Msg = "无权配置"
  737. return
  738. }
  739. list := make([]*bi_dashboard.BiDashboardGrant, 0)
  740. grantAdminIdStrList := strings.Split(req.AdminIdStr, ",")
  741. lenGrantAdminIdStrList := len(grantAdminIdStrList) //指定用户的人数
  742. for _, v := range grantAdminIdStrList {
  743. grantAdminId, tmpErr := strconv.Atoi(v)
  744. if tmpErr != nil {
  745. br.Msg = "参数有误"
  746. br.ErrMsg = fmt.Sprintf("参数有误,Err:%s", tmpErr.Error())
  747. return
  748. }
  749. //如果只选择了自己作为指定的人,那么就提示他报错。如果多人,那么就过滤自己
  750. if grantAdminId == this.SysUser.AdminId {
  751. if lenGrantAdminIdStrList == 1 {
  752. br.Msg = "不能指定自己为权限用户"
  753. br.ErrMsg = fmt.Sprintf("参数有误,Err:%s", tmpErr.Error())
  754. return
  755. }
  756. continue
  757. }
  758. tmpV := &bi_dashboard.BiDashboardGrant{
  759. BiDashboardId: req.BiDashboardId,
  760. GrantAdminId: grantAdminId,
  761. CreateTime: time.Now(),
  762. }
  763. list = append(list, tmpV)
  764. }
  765. if len(list) <= 0 {
  766. br.Msg = "参数有误"
  767. br.ErrMsg = fmt.Sprintf("参数有误,Err:%s", "指定用户为空")
  768. return
  769. }
  770. err = bi_dashboard.MultiAddDashboardGrant(req.BiDashboardId, list)
  771. if err != nil {
  772. br.Msg = "分配失败"
  773. br.ErrMsg = fmt.Sprintf("分配失败,Err:%s", err.Error())
  774. return
  775. }
  776. br.Ret = 200
  777. br.Success = true
  778. br.IsAddLog = true
  779. br.Msg = "分配成功"
  780. }
  781. // Public
  782. // @Title
  783. // @Description 设置公共看板
  784. // @Param request body models.GrantPptReq true "type json string"
  785. // @Success 200 Ret=200 分配成功
  786. // @router /public [post]
  787. func (this *BIDaShboardController) Public() {
  788. br := new(models.BaseResponse).Init()
  789. defer func() {
  790. this.Data["json"] = br
  791. this.ServeJSON()
  792. }()
  793. var req bi_dashboard.PublicDashboardReq
  794. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  795. if err != nil {
  796. br.Msg = "参数解析异常!"
  797. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  798. return
  799. }
  800. item, err := bi_dashboard.GetDashboardById(req.BiDashboardId)
  801. if err != nil {
  802. br.Msg = "获取数据异常!"
  803. br.ErrMsg = "获取数据异常,Err:" + err.Error()
  804. return
  805. }
  806. item.State = 6
  807. err = bi_dashboard.EditDashboard(item)
  808. if err != nil {
  809. br.Msg = "编辑失败"
  810. br.ErrMsg = "编辑失败,Err:" + err.Error()
  811. return
  812. }
  813. br.Ret = 200
  814. br.Success = true
  815. br.IsAddLog = true
  816. br.Msg = "分配成功"
  817. }
  818. // GroupList
  819. // @Title 获取分类列表
  820. // @Description 获取分类列表接口
  821. // @Success 200 {object} models.RespGroupList
  822. // @router /classify/list [get]
  823. func (this *BIDaShboardController) ClassifyList() {
  824. br := new(models.BaseResponse).Init()
  825. defer func() {
  826. this.Data["json"] = br
  827. this.ServeJSON()
  828. }()
  829. classifyList, err := bi_dashboard.GetBiDashboardClassifyAllList()
  830. if err != nil {
  831. br.Msg = "查询失败"
  832. br.ErrMsg = "查询失败,Err:" + err.Error()
  833. return
  834. }
  835. br.Ret = 200
  836. br.Success = true
  837. br.Msg = "查询成功"
  838. br.Data = classifyList
  839. return
  840. }
  841. // CancelGrant
  842. // @Title 取消分配看板权限
  843. // @Description 取消分配看板权限
  844. // @Param request body bi_dashboard.DelDashboardReq true "type json string"
  845. // @Success 200 Ret=200 分配成功
  846. // @router /grant/cancel [post]
  847. func (this *BIDaShboardController) CancelGrant() {
  848. br := new(models.BaseResponse).Init()
  849. defer func() {
  850. this.Data["json"] = br
  851. this.ServeJSON()
  852. }()
  853. var req bi_dashboard.DelDashboardReq
  854. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  855. if err != nil {
  856. br.Msg = "参数解析异常!"
  857. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  858. return
  859. }
  860. if req.BiDashboardId <= 0 {
  861. br.Msg = "参数错误"
  862. return
  863. }
  864. item, err := bi_dashboard.GetDashboardById(req.BiDashboardId)
  865. if err != nil {
  866. br.Msg = "数据不存在"
  867. br.ErrMsg = "数据不存在,Err:" + err.Error()
  868. return
  869. }
  870. if item.SysAdminId != this.SysUser.AdminId {
  871. br.Msg = "无权配置"
  872. return
  873. }
  874. // 分配
  875. err = bi_dashboard.DeleteDashboardGrant(req.BiDashboardId)
  876. if err != nil {
  877. br.Msg = "取消失败"
  878. br.ErrMsg = "取消失败,Err:" + err.Error()
  879. return
  880. }
  881. br.Ret = 200
  882. br.Success = true
  883. br.IsAddLog = true
  884. br.Msg = "取消成功"
  885. }
  886. // GrantInfo
  887. // @Title 获取分配ppt权限详情
  888. // @Description 获取分配ppt权限详情接口
  889. // @Param BiDashboardId query int true "看板的id"
  890. // @Success 200 {object} models.GrantInfoResp
  891. // @router /grant/info [get]
  892. func (this *BIDaShboardController) GrantInfo() {
  893. br := new(models.BaseResponse).Init()
  894. defer func() {
  895. this.Data["json"] = br
  896. this.ServeJSON()
  897. }()
  898. biDashboardId, _ := this.GetInt("BiDashboardId")
  899. if biDashboardId <= 0 {
  900. br.Msg = "参数错误"
  901. return
  902. }
  903. item, err := bi_dashboard.GetDashboardById(biDashboardId)
  904. if err != nil {
  905. br.Msg = "数据不存在"
  906. br.ErrMsg = "数据不存在,Err:" + err.Error()
  907. return
  908. }
  909. if item.SysAdminId != this.SysUser.AdminId {
  910. br.Msg = "无权配置"
  911. return
  912. }
  913. grantInfoList, err := bi_dashboard.GetDashboardGrantInfo(biDashboardId)
  914. if err != nil {
  915. br.Msg = "信息获取失败"
  916. br.ErrMsg = "信息获取失败,Err:" + err.Error()
  917. return
  918. }
  919. if len(grantInfoList) <= 0 {
  920. br.Msg = "未配置"
  921. br.IsSendEmail = false
  922. br.Success = true
  923. br.Ret = 200
  924. return
  925. }
  926. var adminIdStr string
  927. adminIdsList := make([]string, 0)
  928. for _, v := range grantInfoList {
  929. adminIdsList = append(adminIdsList, strconv.Itoa(int(v.GrantAdminId)))
  930. }
  931. adminIdStr = strings.Join(adminIdsList, ",")
  932. br.Ret = 200
  933. br.Success = true
  934. br.Data = adminIdStr
  935. br.Msg = "查询成功"
  936. }
  937. // Public
  938. // @Title
  939. // @Description 撤销公共看板
  940. // @Param request body models.GrantPptReq true "type json string"
  941. // @Success 200 Ret=200 分配成功
  942. // @router /public/cancel [post]
  943. func (this *BIDaShboardController) PublicCancel() {
  944. br := new(models.BaseResponse).Init()
  945. defer func() {
  946. this.Data["json"] = br
  947. this.ServeJSON()
  948. }()
  949. var req bi_dashboard.DelDashboardReq
  950. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  951. if err != nil {
  952. br.Msg = "参数解析异常!"
  953. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  954. return
  955. }
  956. item, err := bi_dashboard.GetDashboardById(req.BiDashboardId)
  957. if err != nil && err.Error() != utils.ErrNoRow() {
  958. br.Msg = "获取数据异常!"
  959. br.ErrMsg = "获取数据异常,Err:" + err.Error()
  960. return
  961. }
  962. item.State = 1
  963. err = bi_dashboard.SaveDashboard(item)
  964. if err != nil {
  965. br.Msg = "编辑失败"
  966. br.ErrMsg = "编辑失败,Err:" + err.Error()
  967. return
  968. }
  969. br.Ret = 200
  970. br.Success = true
  971. br.IsAddLog = true
  972. br.Msg = "撤销成功"
  973. }
  974. // GroupList
  975. // @Title 获取我的首页看板
  976. // @Description 获取我的首页看板接口
  977. // @Success 200 {object} models.RespGroupList
  978. // @router /home_page [get]
  979. func (this *BIDaShboardController) HomePage() {
  980. br := new(models.BaseResponse).Init()
  981. defer func() {
  982. this.Data["json"] = br
  983. this.ServeJSON()
  984. }()
  985. item, err := bi_dashboard.GetBiDashboardHomePageById(this.SysUser.AdminId)
  986. if err != nil && err.Error() != utils.ErrNoRow() {
  987. br.Msg = "数据不存在"
  988. br.ErrMsg = "数据不存在,Err:" + err.Error()
  989. return
  990. }
  991. publicCond := ` AND state = 6 AND bi_dashboard_classify_id > 0 `
  992. publicPars := []interface{}{this.SysUser.AdminId}
  993. publicList, err := bi_dashboard.GetBiDashboardList(publicCond, publicPars)
  994. if err != nil {
  995. err = errors.New("我的看板列表查询出错:" + err.Error())
  996. return
  997. }
  998. if item.BiDashboardHomePageId == 0 && len(publicList) > 0 {
  999. item = &bi_dashboard.BiDashboardHomePage{
  1000. AdminId: publicList[0].SysAdminId,
  1001. BiDashboardId: publicList[0].BiDashboardId,
  1002. FromType: 3,
  1003. }
  1004. }
  1005. if item.BiDashboardId == 0 {
  1006. item = nil
  1007. }
  1008. br.Ret = 200
  1009. br.Success = true
  1010. br.Msg = "查询成功"
  1011. br.Data = item
  1012. return
  1013. }
  1014. // GroupList
  1015. // @Title 保存我的看板首页
  1016. // @Description保存我的看板首页接口
  1017. // @Success 200 {object} models.RespGroupList
  1018. // @router /home_page/save [post]
  1019. func (this *BIDaShboardController) HomePageSave() {
  1020. br := new(models.BaseResponse).Init()
  1021. defer func() {
  1022. this.Data["json"] = br
  1023. this.ServeJSON()
  1024. }()
  1025. var req bi_dashboard.SaveHomePageReq
  1026. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  1027. if err != nil {
  1028. br.Msg = "参数解析异常!"
  1029. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  1030. return
  1031. }
  1032. if req.BiDashboardId <= 0 {
  1033. br.Msg = "参数错误"
  1034. return
  1035. }
  1036. item, err := bi_dashboard.GetBiDashboardHomePageById(this.SysUser.AdminId)
  1037. if err != nil && err.Error() != utils.ErrNoRow() {
  1038. br.Msg = "首页看板查询失败"
  1039. br.ErrMsg = "首页看板查询失败,Err:" + err.Error()
  1040. return
  1041. }
  1042. homePageItem := &bi_dashboard.BiDashboardHomePage{
  1043. BiDashboardId: req.BiDashboardId,
  1044. AdminId: this.SysUser.AdminId,
  1045. CreateTime: time.Now(),
  1046. ModifyTime: time.Now(),
  1047. FromType: req.FromType,
  1048. }
  1049. if item.BiDashboardHomePageId > 0 {
  1050. homePageItem.BiDashboardHomePageId = item.BiDashboardHomePageId
  1051. }
  1052. err = bi_dashboard.SaveBiDashboardHomePage(homePageItem)
  1053. if err != nil {
  1054. br.Msg = "保存失败"
  1055. br.ErrMsg = "保存失败,Err:" + err.Error()
  1056. return
  1057. }
  1058. br.Ret = 200
  1059. br.Success = true
  1060. br.Msg = "保存成功"
  1061. return
  1062. }
  1063. // Editing
  1064. // @Title 标记/查询编辑状态
  1065. // @Description 标记/查询编辑状态
  1066. // @Param request body models.PPTEditingReq true "type json string"
  1067. // @Success 200 Ret=200 操作成功
  1068. // @router /editing [post]
  1069. func (this *BIDaShboardController) Editing() {
  1070. br := new(models.BaseResponse).Init()
  1071. defer func() {
  1072. if br.ErrMsg == "" {
  1073. br.IsSendEmail = false
  1074. }
  1075. this.Data["json"] = br
  1076. this.ServeJSON()
  1077. }()
  1078. sysUser := this.SysUser
  1079. if sysUser == nil {
  1080. br.Msg = "请登录"
  1081. br.ErrMsg = "请登录,SysUser Is Empty"
  1082. br.Ret = 408
  1083. return
  1084. }
  1085. var req bi_dashboard.BiDashboardEditingReq
  1086. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  1087. if err != nil {
  1088. br.Msg = "参数解析异常!"
  1089. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  1090. return
  1091. }
  1092. if req.BiDashboardId <= 0 {
  1093. br.Msg = "参数有误"
  1094. return
  1095. }
  1096. if req.Status < 0 {
  1097. br.Msg = "标记状态异常"
  1098. return
  1099. }
  1100. editor, e := services.UpdateBiDashboardEditing(req.BiDashboardId, req.Status, sysUser.AdminId, sysUser.RealName)
  1101. if e != nil {
  1102. br.Msg = "操作失败"
  1103. br.ErrMsg = "更新编辑状态失败, err: " + e.Error()
  1104. return
  1105. }
  1106. br.Data = editor
  1107. br.Ret = 200
  1108. br.Success = true
  1109. br.Msg = "操作成功"
  1110. }