ppt_report.go 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568
  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 (admin_id = ? OR 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 (admin_id = ? OR FIND_IN_SET(?, collaborate_users)) `
  167. pars = append(pars, utils.ReportWriteTypeGroup, sysUser.AdminId, 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. req.AddType = 1
  266. }
  267. if req.ClassifyId <= 0 {
  268. br.Msg = "请选择分类"
  269. return
  270. }
  271. if req.CollaborateType != 1 && req.CollaborateType != 2 {
  272. br.Msg = "协作方式异常"
  273. br.ErrMsg = fmt.Sprintf("协作方式异常, %d", req.CollaborateType)
  274. return
  275. }
  276. if req.CollaborateType == 2 && len(req.CollaborateUserIds) == 0 {
  277. br.Msg = "请选择协作人"
  278. return
  279. }
  280. // 新报告
  281. newItem := new(models.PptV2)
  282. newItem.Title = req.Title
  283. newItem.AddType = req.AddType
  284. newItem.ClassifyId = req.ClassifyId
  285. newItem.CollaborateType = req.CollaborateType
  286. if len(req.CollaborateUserIds) > 0 {
  287. var partnerArr []string
  288. for _, v := range req.CollaborateUserIds {
  289. partnerArr = append(partnerArr, strconv.Itoa(v))
  290. }
  291. newItem.CollaborateUsers = strings.Trim(strings.Join(partnerArr, ","), `"`)
  292. }
  293. newItem.PptVersion = 2
  294. newItem.AdminId = sysUser.AdminId
  295. newItem.AdminRealName = sysUser.RealName
  296. newItem.ReportSource = utils.ReportSourceLocal // 固定本地PPT
  297. newItem.State = models.ReportStateUnpublished // 默认未发布
  298. newItem.CreateTime = time.Now()
  299. newItem.ModifyTime = time.Now()
  300. // 继承PPT内容
  301. if req.AddType == utils.ReportAddTypeInherit && req.InheritPptId > 0 {
  302. inheritPpt, e := models.GetPptV2ById(req.InheritPptId)
  303. if e != nil {
  304. if utils.IsErrNoRow(e) {
  305. br.Msg = "被继承报告不存在"
  306. return
  307. }
  308. br.Msg = "操作失败"
  309. br.ErrMsg = fmt.Sprintf("操作失败, %v", e)
  310. return
  311. }
  312. newItem.TemplateType = inheritPpt.TemplateType
  313. newItem.BackgroundImg = inheritPpt.BackgroundImg
  314. newItem.ReportType = inheritPpt.ReportType
  315. newItem.PptDate = inheritPpt.PptDate
  316. newItem.Content = inheritPpt.Content
  317. newItem.CoverContent = inheritPpt.CoverContent
  318. newItem.TitleSetting = inheritPpt.TitleSetting
  319. }
  320. // 非继承PPT,有内容时写入内容(如合并PPT时)
  321. if req.InheritPptId <= 0 {
  322. newItem.TemplateType = req.FirstPage.TemplateType
  323. newItem.BackgroundImg = req.FirstPage.ImgUrl
  324. newItem.ReportType = req.FirstPage.ReportType
  325. newItem.PptDate = req.FirstPage.PptDate
  326. newItem.Content = req.Content
  327. newItem.CoverContent = req.CoverContent
  328. newItem.TitleSetting = req.TitleSetting
  329. }
  330. newId, e := models.AddPptV2(newItem)
  331. if e != nil {
  332. br.Msg = "操作失败"
  333. br.ErrMsg = fmt.Sprintf("新增PPT报告失败, %v", e)
  334. return
  335. }
  336. // 更新报告分类计数
  337. go func() {
  338. _ = services.UpdateClassifyReportNum(req.ClassifyId)
  339. }()
  340. resp := models.AddPptResp{
  341. PptId: newId,
  342. }
  343. br.Data = resp
  344. br.Ret = 200
  345. br.Success = true
  346. br.Msg = "操作成功"
  347. }
  348. // SubmitReport
  349. // @Title 提交报告
  350. // @Description 提交报告
  351. // @Param request body models.PptReportCreateReq true "type json string"
  352. // @Success 200 Ret=200 新增成功
  353. // @router /report/submit [post]
  354. func (this *PptV2Controller) SubmitReport() {
  355. br := new(models.BaseResponse).Init()
  356. defer func() {
  357. if br.ErrMsg == "" {
  358. br.IsSendEmail = false
  359. }
  360. this.Data["json"] = br
  361. this.ServeJSON()
  362. }()
  363. sysUser := this.SysUser
  364. if sysUser == nil {
  365. br.Msg = "请登录"
  366. br.ErrMsg = "请登录,SysUser Is Empty"
  367. return
  368. }
  369. //var req models.PptReportCreateReq
  370. //if e := json.Unmarshal(this.Ctx.Input.RequestBody, &req); e != nil {
  371. // br.Msg = "参数解析异常"
  372. // br.ErrMsg = fmt.Sprintf("参数解析失败, %v", e)
  373. // return
  374. //}
  375. br.Ret = 200
  376. br.Success = true
  377. br.Msg = "操作成功"
  378. }
  379. // AuthList
  380. // @Title 获取有权限的列表
  381. // @Description 获取有权限的列表
  382. // @Param PageSize query int true "每页数据条数"
  383. // @Param CurrentIndex query int true "当前页页码,从1开始"
  384. // @Param Keyword query string false "搜索关键词"
  385. // @Param ClassifyId query int false "分类ID"
  386. // @Success 200 {object} models.PptPageReportResp
  387. // @router /report/auth_list [get]
  388. func (this *PptV2Controller) AuthList() {
  389. br := new(models.BaseResponse).Init()
  390. defer func() {
  391. if br.ErrMsg == "" {
  392. br.IsSendEmail = false
  393. }
  394. this.Data["json"] = br
  395. this.ServeJSON()
  396. }()
  397. sysUser := this.SysUser
  398. if sysUser == nil {
  399. br.Msg = "请登录"
  400. br.ErrMsg = "请登录,SysUser Is Empty"
  401. br.Ret = 408
  402. return
  403. }
  404. pageSize, _ := this.GetInt("PageSize")
  405. currentIndex, _ := this.GetInt("CurrentIndex")
  406. keyword := this.GetString("Keyword")
  407. classifyId, _ := this.GetInt("ClassifyId", 0)
  408. var startSize int
  409. if pageSize <= 0 {
  410. pageSize = utils.PageSize20
  411. }
  412. if currentIndex <= 0 {
  413. currentIndex = 1
  414. }
  415. startSize = utils.StartIndex(currentIndex, pageSize)
  416. var pptList []*models.PptReportItem
  417. // 无相关搜索,返回空集
  418. //if keyword == `` && classifyId <= 0 {
  419. // page := paging.GetPaging(currentIndex, pageSize, 0)
  420. // resp := new(models.PptPageReportResp)
  421. // resp.Paging = page
  422. // resp.List = pptList
  423. // br.Ret = 200
  424. // br.Success = true
  425. // br.Msg = "获取成功"
  426. // br.Data = resp
  427. // return
  428. //}
  429. // 查询自己创建的以及协作人包含自己的报告
  430. var cond string
  431. var pars []interface{}
  432. cond += ` AND (admin_id = ? OR (admin_id <> ? AND FIND_IN_SET(?, collaborate_users)))`
  433. pars = append(pars, sysUser.AdminId, sysUser.AdminId, sysUser.AdminId)
  434. if classifyId > 0 {
  435. cond += ` AND classify_id = ? `
  436. pars = append(pars, classifyId)
  437. }
  438. keyword = strings.TrimSpace(keyword)
  439. if keyword != `` {
  440. cond += ` AND title LIKE ? `
  441. pars = utils.GetLikeKeywordPars(pars, keyword, 1)
  442. }
  443. pptOb := new(models.PptV2)
  444. total, e := pptOb.GetCountByCondition(cond, pars)
  445. if e != nil {
  446. br.Msg = "获取失败"
  447. br.ErrMsg = fmt.Sprintf("获取PPT总数失败, %v", e)
  448. return
  449. }
  450. list, e := pptOb.GetPageItemsByCondition(cond, pars, models.PptReportQueryFields, "", startSize, pageSize)
  451. if e != nil {
  452. br.Msg = "获取失败"
  453. br.ErrMsg = fmt.Sprintf("获取PPT失败, %v", e)
  454. return
  455. }
  456. // 分类完整路径、协作人姓名
  457. classifyIdFull := make(map[int]string)
  458. {
  459. ob := new(models.Classify)
  460. classifies, e := ob.GetItemsByCondition("", make([]interface{}, 0), []string{}, "")
  461. if e != nil {
  462. br.Msg = "获取失败"
  463. br.ErrMsg = fmt.Sprintf("获取分类失败, %v", e)
  464. return
  465. }
  466. classifyIdName := make(map[string]string)
  467. for _, v := range classifies {
  468. classifyIdName[strconv.Itoa(v.Id)] = v.ClassifyName
  469. }
  470. for _, v := range classifies {
  471. arr := strings.Split(v.LevelPath, ",")
  472. if len(arr) == 0 {
  473. continue
  474. }
  475. var nameArr []string
  476. for _, a := range arr {
  477. n := classifyIdName[a]
  478. if n == "" {
  479. continue
  480. }
  481. nameArr = append(nameArr, n)
  482. }
  483. classifyIdFull[v.Id] = strings.Join(nameArr, "/")
  484. }
  485. }
  486. adminIdName := make(map[int]string)
  487. {
  488. cond := ` AND enabled = 1`
  489. pars := make([]interface{}, 0)
  490. sysAdmin, e := system.GetSysAdminList(cond, pars, []string{}, "")
  491. if e != nil {
  492. br.Msg = "获取失败"
  493. br.ErrMsg = "获取用户失败,Err:" + e.Error()
  494. return
  495. }
  496. for _, v := range sysAdmin {
  497. adminIdName[v.AdminId] = v.RealName
  498. }
  499. }
  500. // 格式化数据
  501. for _, v := range list {
  502. t := v.Format2ReportItem(v)
  503. t.HasAuth = true // 该列表固定有权限
  504. t.FullClassify = classifyIdFull[v.ClassifyId] // 分类的完整路径
  505. // 协作人
  506. if v.CollaborateUsers != "" {
  507. var authors []models.PptReportCollaborateUser
  508. authorArr := strings.Split(v.CollaborateUsers, ",")
  509. for _, au := range authorArr {
  510. uid, _ := strconv.Atoi(au)
  511. if uid <= 0 {
  512. continue
  513. }
  514. name := adminIdName[uid]
  515. if name == "" {
  516. continue
  517. }
  518. authors = append(authors, models.PptReportCollaborateUser{
  519. AdminId: uid,
  520. RealName: name,
  521. })
  522. }
  523. t.CollaborateUsers = authors
  524. }
  525. pptList = append(pptList, t)
  526. }
  527. page := paging.GetPaging(currentIndex, pageSize, total)
  528. resp := new(models.PptPageReportResp)
  529. resp.Paging = page
  530. resp.List = pptList
  531. br.Ret = 200
  532. br.Success = true
  533. br.Msg = "获取成功"
  534. br.Data = resp
  535. }