ppt_report.go 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558
  1. package controllers
  2. import (
  3. "encoding/json"
  4. "eta_gn/eta_api/models"
  5. "eta_gn/eta_api/models/system"
  6. "eta_gn/eta_api/services"
  7. "eta_gn/eta_api/utils"
  8. "fmt"
  9. "github.com/rdlucklib/rdluck_tools/paging"
  10. "strconv"
  11. "strings"
  12. "time"
  13. )
  14. // ReportClassify
  15. // @Title 获取ppt报告分类
  16. // @Description 获取ppt报告分类
  17. // @Param Source query int false "来源:1-我的;2-协作;3-公共"
  18. // @Success 200 {object} models.PptReportClassifyItem
  19. // @router /report/classify [get]
  20. func (this *PptV2Controller) ReportClassify() {
  21. br := new(models.BaseResponse).Init()
  22. defer func() {
  23. if br.ErrMsg == "" {
  24. br.IsSendEmail = false
  25. }
  26. this.Data["json"] = br
  27. this.ServeJSON()
  28. }()
  29. sysUser := this.SysUser
  30. if sysUser == nil {
  31. br.Msg = "请登录"
  32. br.ErrMsg = "请登录,SysUser Is Empty"
  33. return
  34. }
  35. source, _ := this.GetInt("Source", 1)
  36. if source < 1 || source > 3 {
  37. source = 1
  38. }
  39. // 获取PPT, source:1-我的;2-协作;3-公共
  40. pptList := make([]*models.PptV2, 0)
  41. {
  42. cond := ``
  43. pars := make([]interface{}, 0)
  44. switch source {
  45. case 1:
  46. cond += ` AND admin_id = ?`
  47. pars = append(pars, sysUser.AdminId)
  48. case 2:
  49. cond += ` AND collaborate_type = ? AND FIND_IN_SET(?, collaborate_users) `
  50. pars = append(pars, utils.ReportWriteTypeGroup, sysUser.AdminId)
  51. case 3:
  52. cond += ` AND report_source = ?`
  53. pars = append(pars, utils.ReportSourceOuter)
  54. }
  55. pptOb := new(models.PptV2)
  56. list, e := pptOb.GetItemsByCondition(cond, pars, models.PptReportQueryFields, "")
  57. if e != nil {
  58. br.Msg = "获取失败"
  59. br.ErrMsg = fmt.Sprintf("获取PPT失败, %v", e)
  60. return
  61. }
  62. pptList = list
  63. }
  64. classifyPpt := make(map[int][]*models.PptReportItem)
  65. for _, v := range pptList {
  66. // 当前编辑人
  67. t := v.Format2ReportItem(v)
  68. editor, e := services.UpdatePptEditing(v.PptId, 0, sysUser.AdminId, sysUser.RealName, false)
  69. if e != nil {
  70. br.Msg = "获取失败"
  71. br.ErrMsg = fmt.Sprintf("获取PPT编辑状态失败, err: %s", e.Error())
  72. return
  73. }
  74. t.Editor = editor
  75. // 权限
  76. if source == 1 || source == 2 {
  77. t.HasAuth = true
  78. } else {
  79. if v.AdminId == sysUser.AdminId {
  80. t.HasAuth = true
  81. }
  82. if t.HasAuth == false && v.CollaborateUsers != "" {
  83. authorArr := strings.Split(v.CollaborateUsers, ",")
  84. strId := strconv.Itoa(sysUser.AdminId)
  85. if utils.InArrayByStr(authorArr, strId) {
  86. t.HasAuth = true
  87. }
  88. }
  89. }
  90. if classifyPpt[v.ClassifyId] == nil {
  91. classifyPpt[v.ClassifyId] = make([]*models.PptReportItem, 0)
  92. }
  93. classifyPpt[v.ClassifyId] = append(classifyPpt[v.ClassifyId], t)
  94. }
  95. resp := make([]*models.PptReportClassifyItem, 0)
  96. // 获取分类
  97. classifies := make([]*models.Classify, 0)
  98. {
  99. ob := new(models.Classify)
  100. cond := ` AND enabled = ? AND classify_type = ?`
  101. pars := make([]interface{}, 0)
  102. pars = append(pars, 1, utils.ReportTypePPT)
  103. list, e := ob.GetItemsByCondition(cond, pars, []string{}, "sort ASC, create_time ASC")
  104. if e != nil {
  105. br.Msg = "获取失败"
  106. br.ErrMsg = fmt.Sprintf("获取分类失败, %v", e)
  107. return
  108. }
  109. classifies = list
  110. }
  111. resp = services.GetPptReportClassifyTreeRecursive(classifies, 0, classifyPpt)
  112. br.Data = resp
  113. br.Ret = 200
  114. br.Success = true
  115. br.Msg = "获取成功"
  116. }
  117. // ReportList
  118. // @Title 获取ppt报告列表-分页
  119. // @Description 获取ppt报告列表-分页
  120. // @Param Source query int false "来源:1-我的;2-协作;3-公共"
  121. // @Param ClassifyId query int false "分类ID"
  122. // @Param Keyword query string false "搜索关键词"
  123. // @Success 200 {object} models.PptPageReportResp
  124. // @router /report/list [get]
  125. func (this *PptV2Controller) ReportList() {
  126. br := new(models.BaseResponse).Init()
  127. defer func() {
  128. if br.ErrMsg == "" {
  129. br.IsSendEmail = false
  130. }
  131. this.Data["json"] = br
  132. this.ServeJSON()
  133. }()
  134. sysUser := this.SysUser
  135. if sysUser == nil {
  136. br.Msg = "请登录"
  137. br.ErrMsg = "请登录,SysUser Is Empty"
  138. return
  139. }
  140. pageSize, _ := this.GetInt("PageSize")
  141. currentIndex, _ := this.GetInt("CurrentIndex")
  142. source, _ := this.GetInt("Source", 1)
  143. if source < 1 || source > 3 {
  144. source = 1
  145. }
  146. classifyId, _ := this.GetInt("ClassifyId", 0)
  147. keyword := this.GetString("Keyword")
  148. var startSize int
  149. if pageSize <= 0 {
  150. pageSize = utils.PageSize20
  151. }
  152. if currentIndex <= 0 {
  153. currentIndex = 1
  154. }
  155. startSize = utils.StartIndex(currentIndex, pageSize)
  156. // 获取PPT, source:1-我的;2-协作;3-公共
  157. pptList := make([]*models.PptV2, 0)
  158. cond := ``
  159. pars := make([]interface{}, 0)
  160. {
  161. switch source {
  162. case 1:
  163. cond += ` AND admin_id = ?`
  164. pars = append(pars, sysUser.AdminId)
  165. case 2:
  166. cond += ` AND collaborate_type = ? AND FIND_IN_SET(?, collaborate_users) `
  167. pars = append(pars, utils.ReportWriteTypeGroup, sysUser.AdminId)
  168. case 3:
  169. cond += ` AND report_source = ?`
  170. pars = append(pars, utils.ReportSourceOuter)
  171. }
  172. if classifyId > 0 {
  173. cond += ` AND classify_id = ?`
  174. pars = append(pars, classifyId)
  175. }
  176. keyword = strings.TrimSpace(keyword)
  177. if keyword != "" {
  178. cond += ` AND title LIKE ?`
  179. pars = append(pars, fmt.Sprint("%", keyword, "%"))
  180. }
  181. }
  182. pptOb := new(models.PptV2)
  183. total, e := pptOb.GetCountByCondition(cond, pars)
  184. if e != nil {
  185. br.Msg = "获取失败"
  186. br.ErrMsg = fmt.Sprintf("获取PPT总数失败, %v", e)
  187. return
  188. }
  189. list, e := pptOb.GetPageItemsByCondition(cond, pars, models.PptReportQueryFields, "", startSize, pageSize)
  190. if e != nil {
  191. br.Msg = "获取失败"
  192. br.ErrMsg = fmt.Sprintf("获取PPT失败, %v", e)
  193. return
  194. }
  195. pptList = list
  196. resp := new(models.PptPageReportResp)
  197. resp.List = make([]*models.PptReportItem, 0)
  198. for _, v := range pptList {
  199. // 当前编辑人
  200. t := v.Format2ReportItem(v)
  201. editor, e := services.UpdatePptEditing(v.PptId, 0, sysUser.AdminId, sysUser.RealName, false)
  202. if e != nil {
  203. br.Msg = "获取失败"
  204. br.ErrMsg = fmt.Sprintf("获取PPT编辑状态失败, err: %s", e.Error())
  205. return
  206. }
  207. t.Editor = editor
  208. // 权限
  209. if source == 1 || source == 2 {
  210. t.HasAuth = true
  211. } else {
  212. if v.AdminId == sysUser.AdminId {
  213. t.HasAuth = true
  214. }
  215. if t.HasAuth == false && v.CollaborateUsers != "" {
  216. authorArr := strings.Split(v.CollaborateUsers, ",")
  217. strId := strconv.Itoa(sysUser.AdminId)
  218. if utils.InArrayByStr(authorArr, strId) {
  219. t.HasAuth = true
  220. }
  221. }
  222. }
  223. resp.List = append(resp.List, t)
  224. }
  225. page := paging.GetPaging(currentIndex, pageSize, total)
  226. resp.Paging = page
  227. br.Data = resp
  228. br.Ret = 200
  229. br.Success = true
  230. br.Msg = "获取成功"
  231. }
  232. // CreateReport
  233. // @Title 新增ppt报告
  234. // @Description 新增ppt报告
  235. // @Param request body models.PptReportCreateReq true "type json string"
  236. // @Success 200 Ret=200 新增成功
  237. // @router /report/add [post]
  238. func (this *PptV2Controller) CreateReport() {
  239. br := new(models.BaseResponse).Init()
  240. defer func() {
  241. if br.ErrMsg == "" {
  242. br.IsSendEmail = false
  243. }
  244. this.Data["json"] = br
  245. this.ServeJSON()
  246. }()
  247. sysUser := this.SysUser
  248. if sysUser == nil {
  249. br.Msg = "请登录"
  250. br.ErrMsg = "请登录,SysUser Is Empty"
  251. return
  252. }
  253. var req models.PptReportCreateReq
  254. if e := json.Unmarshal(this.Ctx.Input.RequestBody, &req); e != nil {
  255. br.Msg = "参数解析异常"
  256. br.ErrMsg = fmt.Sprintf("参数解析失败, %v", e)
  257. return
  258. }
  259. req.Title = strings.TrimSpace(req.Title)
  260. if req.Title == "" {
  261. br.Msg = "请输入标题"
  262. return
  263. }
  264. if req.AddType != 1 && req.AddType != 2 {
  265. br.Msg = "新增方式异常"
  266. br.ErrMsg = fmt.Sprintf("新增方式异常, %d", req.AddType)
  267. return
  268. }
  269. if req.ClassifyId <= 0 {
  270. br.Msg = "请选择分类"
  271. return
  272. }
  273. if req.CollaborateType != 1 && req.CollaborateType != 2 {
  274. br.Msg = "协作方式异常"
  275. br.ErrMsg = fmt.Sprintf("协作方式异常, %d", req.CollaborateType)
  276. return
  277. }
  278. if req.CollaborateType == 2 && len(req.CollaborateUserIds) == 0 {
  279. br.Msg = "请选择协作人"
  280. return
  281. }
  282. // 新报告
  283. newItem := new(models.PptV2)
  284. newItem.Title = req.Title
  285. newItem.AddType = req.AddType
  286. newItem.ClassifyId = req.ClassifyId
  287. newItem.CollaborateType = req.CollaborateType
  288. if len(req.CollaborateUserIds) > 0 {
  289. var partnerArr []string
  290. for _, v := range req.CollaborateUserIds {
  291. partnerArr = append(partnerArr, strconv.Itoa(v))
  292. }
  293. newItem.CollaborateUsers = strings.Trim(strings.Join(partnerArr, ","), `"`)
  294. }
  295. newItem.PptVersion = 2
  296. newItem.AdminId = sysUser.AdminId
  297. newItem.AdminRealName = sysUser.RealName
  298. newItem.ReportSource = utils.ReportSourceLocal // 固定本地PPT
  299. newItem.State = models.ReportStateUnpublished // 默认未发布
  300. newItem.CreateTime = time.Now()
  301. newItem.ModifyTime = time.Now()
  302. // 继承PPT内容
  303. if req.AddType == utils.ReportAddTypeInherit && req.InheritPptId > 0 {
  304. inheritPpt, e := models.GetPptV2ById(req.InheritPptId)
  305. if e != nil {
  306. if utils.IsErrNoRow(e) {
  307. br.Msg = "被继承报告不存在"
  308. return
  309. }
  310. br.Msg = "操作失败"
  311. br.ErrMsg = fmt.Sprintf("操作失败, %v", e)
  312. return
  313. }
  314. newItem.TemplateType = inheritPpt.TemplateType
  315. newItem.BackgroundImg = inheritPpt.BackgroundImg
  316. newItem.ReportType = inheritPpt.ReportType
  317. newItem.PptDate = inheritPpt.PptDate
  318. newItem.Content = inheritPpt.Content
  319. newItem.CoverContent = inheritPpt.CoverContent
  320. newItem.TitleSetting = inheritPpt.TitleSetting
  321. }
  322. newId, e := models.AddPptV2(newItem)
  323. if e != nil {
  324. br.Msg = "操作失败"
  325. br.ErrMsg = fmt.Sprintf("新增PPT报告失败, %v", e)
  326. return
  327. }
  328. // 更新报告分类计数
  329. go func() {
  330. _ = services.UpdateClassifyReportNum(req.ClassifyId)
  331. }()
  332. resp := models.AddPptResp{
  333. PptId: newId,
  334. }
  335. br.Data = resp
  336. br.Ret = 200
  337. br.Success = true
  338. br.Msg = "操作成功"
  339. }
  340. // SubmitReport
  341. // @Title 提交报告
  342. // @Description 提交报告
  343. // @Param request body models.PptReportCreateReq true "type json string"
  344. // @Success 200 Ret=200 新增成功
  345. // @router /report/submit [post]
  346. func (this *PptV2Controller) SubmitReport() {
  347. br := new(models.BaseResponse).Init()
  348. defer func() {
  349. if br.ErrMsg == "" {
  350. br.IsSendEmail = false
  351. }
  352. this.Data["json"] = br
  353. this.ServeJSON()
  354. }()
  355. sysUser := this.SysUser
  356. if sysUser == nil {
  357. br.Msg = "请登录"
  358. br.ErrMsg = "请登录,SysUser Is Empty"
  359. return
  360. }
  361. //var req models.PptReportCreateReq
  362. //if e := json.Unmarshal(this.Ctx.Input.RequestBody, &req); e != nil {
  363. // br.Msg = "参数解析异常"
  364. // br.ErrMsg = fmt.Sprintf("参数解析失败, %v", e)
  365. // return
  366. //}
  367. br.Ret = 200
  368. br.Success = true
  369. br.Msg = "操作成功"
  370. }
  371. // AuthList
  372. // @Title 获取有权限的列表
  373. // @Description 获取有权限的列表
  374. // @Param PageSize query int true "每页数据条数"
  375. // @Param CurrentIndex query int true "当前页页码,从1开始"
  376. // @Param Keyword query string false "搜索关键词"
  377. // @Param ClassifyId query int false "分类ID"
  378. // @Success 200 {object} models.PptPageReportResp
  379. // @router /report/auth_list [get]
  380. func (this *PptV2Controller) AuthList() {
  381. br := new(models.BaseResponse).Init()
  382. defer func() {
  383. if br.ErrMsg == "" {
  384. br.IsSendEmail = false
  385. }
  386. this.Data["json"] = br
  387. this.ServeJSON()
  388. }()
  389. sysUser := this.SysUser
  390. if sysUser == nil {
  391. br.Msg = "请登录"
  392. br.ErrMsg = "请登录,SysUser Is Empty"
  393. br.Ret = 408
  394. return
  395. }
  396. pageSize, _ := this.GetInt("PageSize")
  397. currentIndex, _ := this.GetInt("CurrentIndex")
  398. keyword := this.GetString("Keyword")
  399. classifyId, _ := this.GetInt("ClassifyId", 0)
  400. var startSize int
  401. if pageSize <= 0 {
  402. pageSize = utils.PageSize20
  403. }
  404. if currentIndex <= 0 {
  405. currentIndex = 1
  406. }
  407. startSize = utils.StartIndex(currentIndex, pageSize)
  408. var pptList []*models.PptReportItem
  409. // 无相关搜索,返回空集
  410. //if keyword == `` && classifyId <= 0 {
  411. // page := paging.GetPaging(currentIndex, pageSize, 0)
  412. // resp := new(models.PptPageReportResp)
  413. // resp.Paging = page
  414. // resp.List = pptList
  415. // br.Ret = 200
  416. // br.Success = true
  417. // br.Msg = "获取成功"
  418. // br.Data = resp
  419. // return
  420. //}
  421. // 查询自己创建的以及协作人包含自己的报告
  422. var cond string
  423. var pars []interface{}
  424. cond += ` AND (admin_id = ? OR (admin_id <> ? AND FIND_IN_SET(?, collaborate_users)))`
  425. pars = append(pars, sysUser.AdminId, sysUser.AdminId, sysUser.AdminId)
  426. if classifyId > 0 {
  427. cond += ` AND classify_id = ? `
  428. pars = append(pars, classifyId)
  429. }
  430. keyword = strings.TrimSpace(keyword)
  431. if keyword != `` {
  432. cond += ` AND title LIKE ? `
  433. pars = utils.GetLikeKeywordPars(pars, keyword, 1)
  434. }
  435. pptOb := new(models.PptV2)
  436. total, e := pptOb.GetCountByCondition(cond, pars)
  437. if e != nil {
  438. br.Msg = "获取失败"
  439. br.ErrMsg = fmt.Sprintf("获取PPT总数失败, %v", e)
  440. return
  441. }
  442. list, e := pptOb.GetPageItemsByCondition(cond, pars, models.PptReportQueryFields, "", startSize, pageSize)
  443. if e != nil {
  444. br.Msg = "获取失败"
  445. br.ErrMsg = fmt.Sprintf("获取PPT失败, %v", e)
  446. return
  447. }
  448. // 分类完整路径、协作人姓名
  449. classifyIdFull := make(map[int]string)
  450. {
  451. ob := new(models.Classify)
  452. classifies, e := ob.GetItemsByCondition("", make([]interface{}, 0), []string{}, "")
  453. if e != nil {
  454. br.Msg = "获取失败"
  455. br.ErrMsg = fmt.Sprintf("获取分类失败, %v", e)
  456. return
  457. }
  458. classifyIdName := make(map[string]string)
  459. for _, v := range classifies {
  460. classifyIdName[strconv.Itoa(v.Id)] = v.ClassifyName
  461. }
  462. for _, v := range classifies {
  463. arr := strings.Split(v.LevelPath, ",")
  464. if len(arr) == 0 {
  465. continue
  466. }
  467. var nameArr []string
  468. for _, a := range arr {
  469. n := classifyIdName[a]
  470. if n == "" {
  471. continue
  472. }
  473. nameArr = append(nameArr, n)
  474. }
  475. classifyIdFull[v.Id] = strings.Join(nameArr, "/")
  476. }
  477. }
  478. adminIdName := make(map[int]string)
  479. {
  480. cond := ` AND enabled = 1`
  481. pars := make([]interface{}, 0)
  482. sysAdmin, e := system.GetSysAdminList(cond, pars, []string{}, "")
  483. if e != nil {
  484. br.Msg = "获取失败"
  485. br.ErrMsg = "获取用户失败,Err:" + e.Error()
  486. return
  487. }
  488. for _, v := range sysAdmin {
  489. adminIdName[v.AdminId] = v.RealName
  490. }
  491. }
  492. // 格式化数据
  493. for _, v := range list {
  494. t := v.Format2ReportItem(v)
  495. t.HasAuth = true // 该列表固定有权限
  496. t.FullClassify = classifyIdFull[v.ClassifyId] // 分类的完整路径
  497. // 协作人
  498. if v.CollaborateUsers != "" {
  499. var authors []models.PptReportCollaborateUser
  500. authorArr := strings.Split(v.CollaborateUsers, ",")
  501. for _, au := range authorArr {
  502. uid, _ := strconv.Atoi(au)
  503. if uid <= 0 {
  504. continue
  505. }
  506. name := adminIdName[uid]
  507. if name == "" {
  508. continue
  509. }
  510. authors = append(authors, models.PptReportCollaborateUser{
  511. AdminId: uid,
  512. RealName: name,
  513. })
  514. }
  515. t.CollaborateUsers = authors
  516. }
  517. pptList = append(pptList, t)
  518. }
  519. page := paging.GetPaging(currentIndex, pageSize, total)
  520. resp := new(models.PptPageReportResp)
  521. resp.Paging = page
  522. resp.List = pptList
  523. br.Ret = 200
  524. br.Success = true
  525. br.Msg = "获取成功"
  526. br.Data = resp
  527. }