english_classify.go 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646
  1. package english_report
  2. import (
  3. "encoding/json"
  4. "eta/eta_api/controllers"
  5. "eta/eta_api/models"
  6. "eta/eta_api/models/report_approve"
  7. "eta/eta_api/services"
  8. "eta/eta_api/utils"
  9. "fmt"
  10. "github.com/rdlucklib/rdluck_tools/paging"
  11. "sort"
  12. "time"
  13. )
  14. // EnglishClassifyController 英文分类
  15. type EnglishClassifyController struct {
  16. controllers.BaseAuthController
  17. }
  18. // ListClassify
  19. // @Title 获取分类列表
  20. // @Description 获取分类列表
  21. // @Param PageSize query int true "每页数据条数"
  22. // @Param CurrentIndex query int true "当前页页码,从1开始"
  23. // @Param KeyWord query string true "检索关键词"
  24. // @Param CompanyType query string false "产品类型,枚举值:'ficc','权益';不传默认返回全部"
  25. // @Success 200 {object} models.EnglishClassifyListResp
  26. // @router /classify/list [get]
  27. func (this *EnglishReportController) ListClassify() {
  28. br := new(models.BaseResponse).Init()
  29. defer func() {
  30. this.Data["json"] = br
  31. this.ServeJSON()
  32. }()
  33. pageSize, _ := this.GetInt("PageSize")
  34. currentIndex, _ := this.GetInt("CurrentIndex")
  35. keyWord := this.GetString("KeyWord")
  36. var startSize int
  37. if pageSize <= 0 {
  38. pageSize = utils.PageSize20
  39. }
  40. if currentIndex <= 0 {
  41. currentIndex = 1
  42. }
  43. startSize = utils.StartIndex(currentIndex, pageSize)
  44. page := paging.GetPaging(currentIndex, pageSize, 0)
  45. resp := new(models.EnglishClassifyListResp)
  46. // 处理一级分类分页的情况
  47. rootList, err := models.GetEnglishClassifyRootId(startSize, pageSize, keyWord)
  48. if err != nil {
  49. br.Msg = "获取失败"
  50. br.ErrMsg = "获取失败,Err:" + err.Error()
  51. return
  52. }
  53. var ids []int
  54. var rootIds []int
  55. rootMap := make(map[int]struct{}, 0)
  56. for _, v := range rootList {
  57. rootIds = append(rootIds, v.Id)
  58. rootMap[v.Id] = struct{}{}
  59. }
  60. total, err := models.GetEnglishClassifyListCount(keyWord)
  61. if err != nil {
  62. br.Msg = "获取失败"
  63. br.ErrMsg = "获取失败,Err:" + err.Error()
  64. return
  65. }
  66. if total == 0 {
  67. resp.List = make([]*models.EnglishClassifyList, 0)
  68. resp.Paging = page
  69. br.Data = resp
  70. br.Ret = 200
  71. br.Success = true
  72. br.Msg = "获取成功"
  73. return
  74. }
  75. page = paging.GetPaging(currentIndex, pageSize, total)
  76. //获取相关的分类ID
  77. idList, err := models.GetEnglishClassifyListByRootId(rootIds, keyWord)
  78. if err != nil {
  79. br.Msg = "获取失败"
  80. br.ErrMsg = "获取失败,Err:" + err.Error()
  81. return
  82. }
  83. secondListMap := make(map[int][]*models.EnglishClassifyList)
  84. thirdListMap := make(map[int][]*models.EnglishClassifyList)
  85. var thirdIds []int
  86. var sortChildList models.RSChildClassifyList
  87. // 三级分类-品种权限
  88. permissionMap := make(map[int][]int)
  89. if len(idList) > 0 {
  90. childIdMap := make(map[int]struct{}, 0)
  91. for _, v := range idList {
  92. if _, ok := childIdMap[v.ParentId]; !ok {
  93. ids = append(ids, v.ParentId)
  94. childIdMap[v.ParentId] = struct{}{}
  95. }
  96. if _, ok := childIdMap[v.Id]; !ok {
  97. ids = append(ids, v.Id)
  98. childIdMap[v.Id] = struct{}{}
  99. }
  100. }
  101. tmpList, err := models.GetEnglishClassifyChildByIds(ids)
  102. if err != nil {
  103. br.Msg = "获取二级分类失败"
  104. br.ErrMsg = "获取二级分类失败,Err:" + err.Error()
  105. return
  106. }
  107. for _, v := range tmpList {
  108. if _, ok := rootMap[v.ParentId]; !ok {
  109. thirdIds = append(thirdIds, v.Id)
  110. }
  111. }
  112. {
  113. classifyIds := thirdIds
  114. if len(classifyIds) > 0 {
  115. cond := fmt.Sprintf(` AND %s IN (%s)`, models.EnClassifyPermissionColumns.EnClassifyId, utils.GetOrmInReplace(len(classifyIds)))
  116. pars := make([]interface{}, 0)
  117. pars = append(pars, classifyIds)
  118. ob := new(models.EnClassifyPermission)
  119. items, e := ob.GetItemsByCondition(cond, pars, []string{}, "")
  120. if e != nil {
  121. br.Msg = "获取失败"
  122. br.ErrMsg = "获取客户权限列表失败, Err: " + e.Error()
  123. return
  124. }
  125. for _, v := range items {
  126. if permissionMap[v.EnClassifyId] == nil {
  127. permissionMap[v.EnClassifyId] = make([]int, 0)
  128. }
  129. permissionMap[v.EnClassifyId] = append(permissionMap[v.EnClassifyId], v.EnPermissionId)
  130. }
  131. }
  132. }
  133. // 处理三级分类
  134. for _, v := range tmpList {
  135. if _, ok := rootMap[v.ParentId]; !ok {
  136. if p, ok1 := permissionMap[v.Id]; ok1 {
  137. v.EnPermissions = p
  138. }
  139. thirdListMap[v.ParentId] = append(thirdListMap[v.ParentId], v)
  140. }
  141. }
  142. //处理二级分类
  143. for _, v := range tmpList {
  144. if _, ok := rootMap[v.ParentId]; ok {
  145. if child, ok1 := thirdListMap[v.Id]; ok1 {
  146. sortChildList = child
  147. sort.Sort(sortChildList)
  148. v.Child = sortChildList
  149. }
  150. secondListMap[v.ParentId] = append(secondListMap[v.ParentId], v)
  151. }
  152. }
  153. }
  154. //处理一级分类
  155. var sortList models.RSClassifyList
  156. for _, v := range rootList {
  157. if child, ok := secondListMap[v.Id]; ok {
  158. sortChildList = child
  159. sort.Sort(sortChildList)
  160. v.Child = sortChildList
  161. }
  162. sortList = append(sortList, v)
  163. }
  164. sort.Sort(sortList)
  165. resp.List = sortList
  166. resp.Paging = page
  167. br.Data = resp
  168. br.Ret = 200
  169. br.Success = true
  170. br.Msg = "获取成功"
  171. }
  172. // @Title 新增分类
  173. // @Description 新增分类接口
  174. // @Param ClassifyName int true "分类名称"
  175. // @Param ParentId query int true "父级Id 添加父级时为0"
  176. // @Param Sort query string false "排序"
  177. // @Success 200 新增成功
  178. // @router /classify/add [get]
  179. func (this *EnglishReportController) AddClassify() {
  180. br := new(models.BaseResponse).Init()
  181. defer func() {
  182. this.Data["json"] = br
  183. this.ServeJSON()
  184. }()
  185. classifyName := this.GetString("ClassifyName")
  186. parentId, _ := this.GetInt("ParentId")
  187. sort, _ := this.GetInt("Sort")
  188. // 查新父级分类是否存在
  189. rootId := 0
  190. if parentId > 0 {
  191. parentClassify, err := models.GetEnglishReportClassifyById(parentId)
  192. if err != nil {
  193. if err.Error() == utils.ErrNoRow() {
  194. br.Msg = "上级分类不存在"
  195. return
  196. }
  197. br.Msg = "查询上级分类信息失败"
  198. br.ErrMsg = "查询上级分类信息失败,Err:" + err.Error()
  199. return
  200. }
  201. if parentClassify.RootId == 0 {
  202. rootId = parentClassify.Id
  203. } else {
  204. rootId = parentClassify.RootId
  205. }
  206. }
  207. item := &models.EnglishClassify{
  208. ClassifyName: classifyName,
  209. Sort: sort,
  210. ParentId: parentId,
  211. RootId: rootId,
  212. CreateTime: time.Now(),
  213. ModifyTime: time.Now(),
  214. IsShow: 1,
  215. }
  216. counts, err := models.GetEnglishClassifyCountsByName(classifyName, parentId)
  217. if err != nil {
  218. br.Msg = "查询失败"
  219. br.ErrMsg = "查询失败,Err:" + err.Error()
  220. return
  221. }
  222. if counts > 0 {
  223. br.Msg = "该名称已存在"
  224. br.ErrMsg = "该名称已存在!"
  225. return
  226. }
  227. var newId int64
  228. newId, err = models.AddEnglishClassify(item)
  229. if err != nil {
  230. br.Msg = "保存失败"
  231. br.ErrMsg = "保存失败,Err:" + err.Error()
  232. return
  233. }
  234. if parentId == 0 { //一级目录的rootId等于自己本身
  235. item.Id = int(newId)
  236. item.RootId = int(newId)
  237. err = item.UpdateEnglishClassify([]string{"RootId"})
  238. if err != nil {
  239. br.Msg = "保存失败"
  240. br.ErrMsg = "保存失败,Err:" + err.Error()
  241. return
  242. }
  243. }
  244. br.Ret = 200
  245. br.Success = true
  246. br.Msg = "新增成功"
  247. }
  248. // @Title 编辑分类
  249. // @Description 编辑分类接口
  250. // @Param ClassifyId int true "分类Id"
  251. // @Param ClassifyName string true "分类名称"
  252. // @Param ParentId query int true "父级Id 添加父级时为0"
  253. // @Param Sort query string false "排序"
  254. // @Success 200 保存成功
  255. // @router /classify/edit [get]
  256. func (this *EnglishReportController) EditClassify() {
  257. br := new(models.BaseResponse).Init()
  258. defer func() {
  259. this.Data["json"] = br
  260. this.ServeJSON()
  261. }()
  262. classifyId, _ := this.GetInt("ClassifyId")
  263. classifyName := this.GetString("ClassifyName")
  264. parentId, _ := this.GetInt("ParentId")
  265. sort, _ := this.GetInt("Sort")
  266. if parentId == classifyId {
  267. br.Msg = "上级分类不能选择自己"
  268. return
  269. }
  270. if classifyId <= 0 {
  271. br.Msg = "参数错误"
  272. return
  273. }
  274. if classifyName == "" {
  275. br.Msg = "分类名称不可为空"
  276. return
  277. }
  278. oldItem, err := models.GetEnglishReportClassifyById(classifyId)
  279. if err != nil {
  280. if err.Error() == utils.ErrNoRow() {
  281. br.Msg = "当前分类不存在"
  282. return
  283. }
  284. br.Msg = "获取信息失败"
  285. br.ErrMsg = "获取信息失败,Err:" + err.Error()
  286. return
  287. }
  288. if oldItem.ParentId == 0 && parentId > 0 {
  289. // 一级分类变更为二级分类,禁止
  290. br.Msg = "一级分类不允许更改为二级分类或三级分类"
  291. return
  292. }
  293. var parent *models.EnglishClassify
  294. rootId := 0
  295. if parentId > 0 {
  296. parent, err = models.GetEnglishReportClassifyById(parentId)
  297. if err != nil {
  298. if err.Error() == utils.ErrNoRow() {
  299. br.Msg = "上级分类不存在"
  300. return
  301. }
  302. br.Msg = "获取信息失败"
  303. br.ErrMsg = "获取信息失败,Err:" + err.Error()
  304. return
  305. }
  306. //二级分类不允许改成三级分类
  307. if oldItem.ParentId > 0 && oldItem.ParentId == oldItem.RootId {
  308. if parent.ParentId > 0 {
  309. //即将改为为三级分类
  310. br.Msg = "二级分类不允许更改为三级分类"
  311. return
  312. }
  313. }
  314. if parent.RootId == 0 {
  315. rootId = parent.Id
  316. } else {
  317. rootId = parent.RootId
  318. }
  319. }
  320. //判断是否已存在同个名称的分类
  321. existItem, e := models.GetEnglishClassifyByClassifyNameParentId(classifyName, parentId)
  322. if e != nil {
  323. if e.Error() != utils.ErrNoRow() {
  324. br.Msg = "查询已存在的分类出错"
  325. br.ErrMsg = "查询已存在的分类出错, Err:" + e.Error()
  326. return
  327. }
  328. }
  329. if e == nil && existItem.Id != oldItem.Id {
  330. br.Msg = "分类名称:" + classifyName + "已存在"
  331. return
  332. }
  333. if parentId == 0 { //一级分类的顶级分类为自己的ID
  334. rootId = oldItem.Id
  335. }
  336. item := &models.EnglishClassify{
  337. Id: oldItem.Id,
  338. ClassifyName: classifyName,
  339. Sort: sort,
  340. ParentId: parentId,
  341. RootId: rootId,
  342. ModifyTime: time.Now(),
  343. IsShow: 1,
  344. }
  345. {
  346. // 更新研报里的分类名称
  347. err = services.UpdateEnglishReportClassifyId(oldItem, item, classifyId)
  348. if err != nil {
  349. br.Msg = err.Error()
  350. return
  351. }
  352. //更新相关联的路演视频里的分类名称
  353. err = services.UpdateEnglishVideoClassifyId(oldItem, item, classifyId)
  354. if err != nil {
  355. br.Msg = err.Error()
  356. return
  357. }
  358. }
  359. err = models.ModifyEnglishClassify(item)
  360. if err != nil {
  361. br.Msg = "保存失败"
  362. br.ErrMsg = "保存失败,Err:" + err.Error()
  363. return
  364. }
  365. err = models.UpdateEnglishReportClassifyByFirstSecondClassifyId(classifyId, parentId)
  366. if err != nil {
  367. br.Msg = "保存失败"
  368. br.ErrMsg = "保存失败,Err:" + err.Error()
  369. return
  370. }
  371. err = models.UpdateEnglishVideoClassifyByFirstSecondClassifyId(classifyId, parentId)
  372. if err != nil {
  373. br.Msg = "保存失败"
  374. br.ErrMsg = "保存失败,Err:" + err.Error()
  375. return
  376. }
  377. br.Ret = 200
  378. br.Success = true
  379. br.Msg = "保存成功"
  380. }
  381. // @Title 删除分类列表
  382. // @Description 删除分类列表
  383. // @Param ClassifyId int true "分类名称"
  384. // @Param ParentId query int true "父级Id"
  385. // @Success 200 保存成功
  386. // @router /classify/delete [get]
  387. func (this *EnglishReportController) DelClassify() {
  388. br := new(models.BaseResponse).Init()
  389. defer func() {
  390. this.Data["json"] = br
  391. this.ServeJSON()
  392. }()
  393. classifyId, _ := this.GetInt("ClassifyId")
  394. //parentId, _ := this.GetInt("ParentId")
  395. classifyInfo, err := models.GetEnglishReportClassifyById(classifyId)
  396. if err != nil {
  397. if err.Error() == utils.ErrNoRow() {
  398. br.Msg = "当前分类不存在"
  399. br.ErrMsg = "当前分类不存在"
  400. return
  401. }
  402. br.Msg = "获取分类信息失败"
  403. br.ErrMsg = "获取分类信息失败,Err:" + err.Error()
  404. return
  405. }
  406. count, err := models.GetEnglishClassifyChildCounts(classifyId)
  407. if err != nil && err.Error() != utils.ErrNoRow() {
  408. br.Msg = "获取信息失败"
  409. br.ErrMsg = "获取失败,Err:" + err.Error()
  410. return
  411. }
  412. if count > 0 {
  413. br.Msg = "请先删除该分类下关联分类"
  414. br.Ret = 403
  415. return
  416. }
  417. reportCount, e := models.GetEnglishReportCounts(classifyId, classifyInfo.ParentId)
  418. if e != nil && e.Error() != utils.ErrNoRow() {
  419. br.Msg = "获取信息失败"
  420. br.ErrMsg = "获取失败,Err:" + e.Error()
  421. return
  422. }
  423. if reportCount > 0 {
  424. br.Msg = "该分类有关联报告,不允许删除"
  425. br.Ret = 403
  426. return
  427. }
  428. videoCount, e := models.GetEnglishVideoCounts(classifyId, classifyInfo.ParentId)
  429. if e != nil && e.Error() != utils.ErrNoRow() {
  430. br.Msg = "获取信息失败"
  431. br.ErrMsg = "获取失败,Err:" + e.Error()
  432. return
  433. }
  434. if videoCount > 0 {
  435. br.Msg = "该分类有关联的路演视频,不允许删除"
  436. br.Ret = 403
  437. return
  438. }
  439. // 查询该分类是否关联了审批流
  440. flowOb := new(report_approve.ReportApproveFlow)
  441. flowCond := fmt.Sprintf(` AND %s = ? AND (%s = ? Or %s = ?)`, report_approve.ReportApproveFlowCols.ReportType, report_approve.ReportApproveFlowCols.ClassifyFirstId, report_approve.ReportApproveFlowCols.ClassifySecondId)
  442. flowPars := make([]interface{}, 0)
  443. flowPars = append(flowPars, report_approve.FlowReportTypeEnglish, classifyId, classifyId)
  444. flowCount, e := flowOb.GetCountByCondition(flowCond, flowPars)
  445. if e != nil {
  446. br.Msg = "检测失败"
  447. br.ErrMsg = "获取关联审批流失败, Err: " + e.Error()
  448. return
  449. }
  450. if flowCount > 0 {
  451. br.Msg = "该分类关联审批流,不允许删除"
  452. br.Ret = 403
  453. return
  454. }
  455. if err = models.DeleteEnglishClassify(classifyId); err != nil {
  456. br.Msg = "删除失败"
  457. br.ErrMsg = "删除报告失败, Err: " + err.Error()
  458. return
  459. }
  460. br.Ret = 200
  461. br.Success = true
  462. br.Msg = "删除成功"
  463. }
  464. // @Title 获取一级分类列表
  465. // @Description 获取一级分类列表
  466. // @Param PageSize query int true "每页数据条数"
  467. // @Param CurrentIndex query int true "当前页页码,从1开始"
  468. // @Param CompanyType query string false "产品类型,枚举值:'ficc','权益';不传默认返回全部"
  469. // @Success 200 {object} models.EnglishClassifyListResp
  470. // @router /classify/first/list [get]
  471. func (this *EnglishReportController) FistListClassify() {
  472. br := new(models.BaseResponse).Init()
  473. defer func() {
  474. this.Data["json"] = br
  475. this.ServeJSON()
  476. }()
  477. pageSize, _ := this.GetInt("PageSize")
  478. currentIndex, _ := this.GetInt("CurrentIndex")
  479. var startSize int
  480. if pageSize <= 0 {
  481. pageSize = utils.PageSize20
  482. }
  483. if currentIndex <= 0 {
  484. currentIndex = 1
  485. }
  486. startSize = utils.StartIndex(currentIndex, pageSize)
  487. rootList, err := models.GetEnglishFirstClassifyList(startSize, pageSize)
  488. if err != nil {
  489. br.Msg = "获取失败"
  490. br.ErrMsg = "获取失败,Err:" + err.Error()
  491. return
  492. }
  493. total, err := models.GetEnglishFirstClassifyListCount()
  494. if err != nil {
  495. br.Msg = "获取失败"
  496. br.ErrMsg = "获取失败,Err:" + err.Error()
  497. return
  498. }
  499. page := paging.GetPaging(currentIndex, pageSize, total)
  500. resp := new(models.EnglishClassifyListResp)
  501. if total == 0 {
  502. resp.List = make([]*models.EnglishClassifyList, 0)
  503. resp.Paging = page
  504. br.Data = resp
  505. br.Ret = 200
  506. br.Success = true
  507. br.Msg = "获取成功"
  508. return
  509. }
  510. rootMap := make(map[int]struct{}, 0)
  511. var rootIds []int
  512. for _, v := range rootList {
  513. rootMap[v.Id] = struct{}{}
  514. rootIds = append(rootIds, v.Id)
  515. }
  516. tmpList, err := models.GetEnglishSecondClassifyList(rootIds)
  517. if err != nil {
  518. br.Msg = "获取失败"
  519. br.ErrMsg = "获取失败,Err:" + err.Error()
  520. return
  521. }
  522. secondListMap := make(map[int][]*models.EnglishClassifyList)
  523. //处理二级分类
  524. for _, v := range tmpList {
  525. if _, ok := rootMap[v.ParentId]; ok {
  526. secondListMap[v.ParentId] = append(secondListMap[v.ParentId], v)
  527. }
  528. }
  529. //处理一级分类
  530. var sortList models.RSClassifyList
  531. var sortChildList models.RSChildClassifyList
  532. for _, v := range rootList {
  533. if child, ok := secondListMap[v.Id]; ok {
  534. sortChildList = child
  535. sort.Sort(sortChildList)
  536. v.Child = sortChildList
  537. }
  538. sortList = append(sortList, v)
  539. }
  540. sort.Sort(sortList)
  541. resp.List = sortList
  542. resp.Paging = page
  543. br.Data = resp
  544. br.Ret = 200
  545. br.Success = true
  546. br.Msg = "获取成功"
  547. }
  548. // PermissionEdit
  549. // @Title 编辑品种权限
  550. // @Description 编辑品种权限
  551. // @Param request body models.EnPermissionAddReq true "type json string"
  552. // @Success 200 Ret=200 操作成功
  553. // @router /permission/edit [post]
  554. func (this *EnglishClassifyController) PermissionEdit() {
  555. br := new(models.BaseResponse).Init()
  556. defer func() {
  557. if br.ErrMsg == "" {
  558. br.IsSendEmail = false
  559. }
  560. this.Data["json"] = br
  561. this.ServeJSON()
  562. }()
  563. sysUser := this.SysUser
  564. if sysUser == nil {
  565. br.Msg = "请登录"
  566. br.ErrMsg = "请登录,SysUser Is Empty"
  567. br.Ret = 408
  568. return
  569. }
  570. var req models.EnClassifyPermissionEditReq
  571. if e := json.Unmarshal(this.Ctx.Input.RequestBody, &req); e != nil {
  572. br.Msg = "参数解析异常!"
  573. br.ErrMsg = "参数解析失败,Err:" + e.Error()
  574. return
  575. }
  576. if req.ClassifyId <= 0 {
  577. br.Msg = "参数有误"
  578. return
  579. }
  580. // 更新品种权限
  581. nowTime := time.Now().Local()
  582. permissions := make([]*models.EnClassifyPermission, 0)
  583. for _, p := range req.EnPermissions {
  584. v := new(models.EnClassifyPermission)
  585. v.EnPermissionId = p
  586. v.EnClassifyId = req.ClassifyId
  587. v.CreateTime = nowTime
  588. permissions = append(permissions, v)
  589. }
  590. if e := models.ClearAndCreateEnClassifyPermissions(req.ClassifyId, permissions); e != nil {
  591. br.Msg = "保存失败"
  592. br.ErrMsg = "更新分类品种权限失败, Err: " + e.Error()
  593. return
  594. }
  595. br.Ret = 200
  596. br.Success = true
  597. br.Msg = "操作成功"
  598. }