english_classify.go 16 KB

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