home.go 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478
  1. package controllers
  2. import (
  3. "fmt"
  4. "github.com/rdlucklib/rdluck_tools/paging"
  5. "hongze/hongze_clpt/models"
  6. "hongze/hongze_clpt/services"
  7. "hongze/hongze_clpt/utils"
  8. "strconv"
  9. "strings"
  10. "time"
  11. )
  12. type HomeController struct {
  13. BaseAuthController
  14. }
  15. type BaseHomeController struct {
  16. BaseCommonController
  17. }
  18. type MobileHomeController struct {
  19. BaseAuthMobileController
  20. }
  21. // @Title 首页列表接口
  22. // @Description 首页列表接口
  23. // @Param PageSize query int true "每页数据条数"
  24. // @Param CurrentIndex query int true "当前页页码,从1开始"
  25. // @Param ChartPermissionId query int true "品类id,最新传0"
  26. // @Param CtagId query int true "图表子类ID"
  27. // @Param ListType query int true "列表类型,1最新,2 纪要 ,3图表 默认1"
  28. // @Success 200 {object} models.HomeArtAndChartListResp
  29. // @router /list [get]
  30. func (this *MobileHomeController) List() {
  31. br := new(models.BaseResponse).Init()
  32. defer func() {
  33. this.Data["json"] = br
  34. this.ServeJSON()
  35. }()
  36. user := this.User
  37. if user == nil {
  38. br.Msg = "请登录"
  39. br.ErrMsg = "请登录,用户信息为空"
  40. br.Ret = 408
  41. return
  42. }
  43. pageSize, _ := this.GetInt("PageSize")
  44. currentIndex, _ := this.GetInt("CurrentIndex")
  45. chartPermissionId, _ := this.GetInt("ChartPermissionId")
  46. ctagId, _ := this.GetInt("CtagId")
  47. listType, _ := this.GetInt("ListType")
  48. var startSize int
  49. if pageSize <= 0 {
  50. pageSize = utils.PageSize20
  51. }
  52. if currentIndex <= 0 {
  53. currentIndex = 1
  54. }
  55. if listType <= 0 {
  56. listType = 1
  57. }
  58. startSize = paging.StartIndex(currentIndex, pageSize)
  59. var condition string
  60. var pars []interface{}
  61. var total, chartTotal int
  62. resp := new(models.HomeArtAndChartListResp)
  63. page := paging.GetPaging(currentIndex, pageSize, total)
  64. var chartList []*models.HomeChartListResp
  65. var err error
  66. if listType == 1 {
  67. if currentIndex <= 2 {
  68. listCtagId := [10]int{1, 2, 3, 4, 5, 6, 7, 8, 9, 10}
  69. var chartIds string
  70. for _, v := range listCtagId {
  71. chartListTwo, err := models.GetChartList(`AND ctag_id = `+strconv.Itoa(v), pars, 0, 2)
  72. if err != nil {
  73. br.Msg = "获取信息失败"
  74. br.ErrMsg = "获取用户信息失败,Err:" + err.Error()
  75. return
  76. }
  77. for _, vChart := range chartListTwo {
  78. chartIds += strconv.Itoa(vChart.ChartId) + ","
  79. }
  80. }
  81. chartIds = strings.TrimRight(chartIds, ",")
  82. condition += ` AND chart_id IN (` + chartIds + `) `
  83. chartList, err = models.GetChartList(condition, pars, startSize, pageSize)
  84. if err != nil {
  85. br.Msg = "获取信息失败"
  86. br.ErrMsg = "获取用户信息失败,Err:" + err.Error()
  87. return
  88. }
  89. }
  90. } else if listType == 3 {
  91. if chartPermissionId > 0 {
  92. condition += ` AND a.ptag_id =? `
  93. pars = append(pars, chartPermissionId)
  94. }
  95. if ctagId > 0 {
  96. condition += ` AND a.ctag_id =? `
  97. pars = append(pars, ctagId)
  98. }
  99. chartList, err = models.GetChartList(condition, pars, startSize, pageSize)
  100. if err != nil {
  101. br.Msg = "获取信息失败"
  102. br.ErrMsg = "获取用户信息失败,Err:" + err.Error()
  103. return
  104. }
  105. chartTotal, err = models.GetChartCount(condition, pars)
  106. if err != nil {
  107. br.Msg = "获取信息失败"
  108. br.Msg = "获取帖子总数失败,Err:" + err.Error()
  109. return
  110. }
  111. }
  112. for k, v := range chartList {
  113. if v.PtagName != "" {
  114. chartList[k].CtagNamePc = v.PtagName
  115. }
  116. if v.CtagName != "" {
  117. chartList[k].CtagNamePc += "," + v.CtagName
  118. }
  119. if v.PtagNameTwo != "" {
  120. chartList[k].CtagNamePc += "," + v.PtagNameTwo
  121. }
  122. if v.CtagNameTwo != "" {
  123. chartList[k].CtagNamePc += "," + v.CtagNameTwo
  124. }
  125. chartList[k].IsNeedJump = true
  126. chartList[k].Source = 2
  127. if v.PtagName != "" {
  128. labelItem := new(models.LabelList)
  129. labelItem.PtagName = v.PtagName
  130. labelItem.CtagName = v.CtagName
  131. chartList[k].LabelList = append(chartList[k].LabelList, labelItem)
  132. }
  133. if v.PtagNameTwo != "" {
  134. labelItemTwo := new(models.LabelList)
  135. labelItemTwo.PtagName = v.PtagNameTwo
  136. labelItemTwo.CtagName = v.CtagNameTwo
  137. chartList[k].LabelList = append(chartList[k].LabelList, labelItemTwo)
  138. }
  139. if len(chartList[k].LabelList) == 0 {
  140. chartList[k].LabelList = make([]*models.LabelList, 0)
  141. }
  142. }
  143. if len(chartList) == 0 {
  144. chartList = make([]*models.HomeChartListResp, 0)
  145. }
  146. resp.ChartList = chartList
  147. if listType != 3 {
  148. userType, _, err := services.GetUserType(user.CompanyId)
  149. if err != nil {
  150. br.Msg = "获取信息失败"
  151. br.ErrMsg = "获取用户信息失败,Err:" + err.Error()
  152. return
  153. }
  154. condition = ` AND is_summary = 1 `
  155. if chartPermissionId > 0 {
  156. categoryId, err := models.GetCategoryIdHome(chartPermissionId)
  157. if err != nil && err.Error() != utils.ErrNoRow() {
  158. br.Msg = "获取信息失败"
  159. br.ErrMsg = "获取分类权限信息失败,Err:" + err.Error()
  160. return
  161. }
  162. categoryinfo, err := models.GetChartPermissionById(chartPermissionId)
  163. if err != nil {
  164. br.Msg = "获取信息失败"
  165. br.ErrMsg = "获取信息失败,Err:" + err.Error()
  166. return
  167. }
  168. if userType == 1 && strings.Contains(categoryinfo.PermissionName, utils.CHART_PERMISSION_NAME_YANXUAN) {
  169. resp.Paging = page
  170. br.Ret = 200
  171. br.Success = true
  172. br.Msg = "获取成功"
  173. br.Data = resp
  174. return
  175. }
  176. page = paging.GetPaging(currentIndex, pageSize, total)
  177. if categoryId != "" {
  178. condition += ` AND category_id IN(` + categoryId + `)`
  179. //condition += ` OR ( category_name LIKE '%` + utils.CHART_PERMISSION_NAME_YANXUAN + `%' AND publish_status = 1 AND is_summary = 1 )`
  180. } else {
  181. condition += ` AND category_name LIKE '%` + utils.CHART_PERMISSION_NAME_YANXUAN + `%'`
  182. }
  183. }
  184. //永续客户无法查看研选分类的内容
  185. if userType == 1 {
  186. condition += ` AND category_name NOT LIKE '%` + utils.CHART_PERMISSION_NAME_YANXUAN + `%'`
  187. }
  188. total, err = models.GetHomeCount(condition, pars)
  189. if err != nil {
  190. br.Msg = "获取信息失败"
  191. br.Msg = "获取帖子总数失败,Err:" + err.Error()
  192. return
  193. }
  194. listPublic, err := models.GetHomeListPublic(condition, pars, startSize, pageSize)
  195. if err != nil {
  196. br.Msg = "获取信息失败"
  197. br.Msg = "获取帖子数据失败,Err:" + err.Error()
  198. return
  199. }
  200. listPublic, err = services.HandleArticleCategoryImg(listPublic, user)
  201. if err != nil {
  202. br.Msg = "获取失败"
  203. br.ErrMsg = "获取报告封面图片失败, Err:" + err.Error()
  204. return
  205. }
  206. var list []*models.HomeArticle
  207. if len(listPublic) == 0 {
  208. list = make([]*models.HomeArticle, 0)
  209. } else {
  210. for _, v := range listPublic {
  211. list = append(list, &models.HomeArticle{
  212. ArticleId: v.ArticleId,
  213. Title: v.Title,
  214. Annotation: v.Annotation,
  215. Abstract: v.Abstract,
  216. ImgUrlPc: v.ImgUrlPc,
  217. PublishDate: v.PublishDate,
  218. })
  219. }
  220. }
  221. resp.List = list
  222. }
  223. if chartTotal > total {
  224. total = chartTotal
  225. }
  226. page = paging.GetPaging(currentIndex, pageSize, total)
  227. resp.Paging = page
  228. br.Ret = 200
  229. br.Success = true
  230. br.Msg = "获取成功"
  231. br.Data = resp
  232. }
  233. // @Title 首页列表接口
  234. // @Description 首页列表接口
  235. // @Param TagIds query string true "标签选择"
  236. // @Param PageSize query int true "每页数据条数"
  237. // @Param CurrentIndex query int true "当前页页码,从1开始"
  238. // @Success 200 {object} models.HomeArtAndChartListResp
  239. // @router /new [get]
  240. func (this *MobileHomeController) NewList() {
  241. br := new(models.BaseResponse).Init()
  242. defer func() {
  243. this.Data["json"] = br
  244. this.ServeJSON()
  245. }()
  246. user := this.User
  247. if user == nil {
  248. br.Msg = "请登录"
  249. br.ErrMsg = "请登录,用户信息为空"
  250. br.Ret = 408
  251. return
  252. }
  253. //uid := user.UserId
  254. pageSize, _ := this.GetInt("PageSize")
  255. currentIndex, _ := this.GetInt("CurrentIndex")
  256. tagIds := this.GetString("TagIds")
  257. var startSize int
  258. if pageSize <= 0 {
  259. pageSize = utils.PageSize20
  260. }
  261. if currentIndex <= 0 {
  262. currentIndex = 1
  263. }
  264. startSize = paging.StartIndex(currentIndex, pageSize)
  265. var condition string
  266. var conditionInit string
  267. var pars []interface{}
  268. var total int
  269. resp := new(models.HomeResourceDataListNewResp)
  270. var articleTypes, activityTypes, industries, subjectNames string
  271. if tagIds != "" {
  272. tags := strings.Split(tagIds, ",")
  273. for _, tagIdStr := range tags {
  274. tagId, err := strconv.Atoi(tagIdStr)
  275. if err != nil {
  276. br.Msg = "转换失败"
  277. br.ErrMsg = "tagid转换失败,Err:" + err.Error()
  278. return
  279. }
  280. tagInfo, err := models.GetCygxTagByTagId(tagId)
  281. if err != nil && err.Error() != utils.ErrNoRow() {
  282. br.Msg = "获取失败"
  283. br.ErrMsg = "GetCygxTagByTagId,Err:" + err.Error()
  284. return
  285. }
  286. activityTypes += tagInfo.ActivityTypes + ","
  287. articleTypes += tagInfo.ArticleTypes + ","
  288. industries += tagInfo.Industries + ","
  289. subjectNames += tagInfo.SubjectNames + ","
  290. }
  291. }
  292. articleTypes = strings.TrimRight(articleTypes,",")
  293. activityTypes = strings.TrimRight(activityTypes,",")
  294. industries = strings.TrimRight(industries,",")
  295. subjectNames = strings.TrimRight(subjectNames,",")
  296. articleTypesCond := ``
  297. if articleTypes != "" {
  298. articleTypeSlice := strings.Split(articleTypes, ",")
  299. newArticleTypeSlice := make([]string,0)
  300. for _, s := range articleTypeSlice {
  301. newArticleTypeSlice = append(newArticleTypeSlice, "'"+ s + "'")
  302. }
  303. articleTypeStr := strings.Join(newArticleTypeSlice, ",")
  304. articleTypeStr = strings.TrimRight(articleTypeStr,",")
  305. articleTypesCond += ` AND art.sub_category_name In (`+ articleTypeStr +`) `
  306. }
  307. activityTypesCond := ``
  308. if activityTypes != "" {
  309. activityTypeSlice := strings.Split(activityTypes, ",")
  310. newActivityTypeSlice := make([]string,0)
  311. for _, s := range activityTypeSlice {
  312. newActivityTypeSlice = append(newActivityTypeSlice, "'"+ s + "'")
  313. }
  314. activityTypeStr := strings.Join(newActivityTypeSlice, ",")
  315. activityTypeStr = strings.TrimRight(activityTypeStr,",")
  316. activityTypesCond += ` AND act.activity_type_name In (`+ activityTypeStr +`) `
  317. }
  318. industriesCond := ``
  319. if industries != "" {
  320. industrieSlice := strings.Split(industries, ",")
  321. newIndustrieSlice := make([]string,0)
  322. for _, s := range industrieSlice {
  323. newIndustrieSlice = append(newIndustrieSlice, "'"+ s + "'")
  324. }
  325. industrieStr := strings.Join(newIndustrieSlice, ",")
  326. industrieStr = strings.TrimRight(industrieStr, ",")
  327. industriesCond += ` AND im.industry_name In (`+ industrieStr +`) `
  328. }
  329. subjectNamesCond := ``
  330. if subjectNames != "" {
  331. subjectNameSlice := strings.Split(subjectNames, ",")
  332. newSubjectNameSlice := make([]string,0)
  333. for _, s := range subjectNameSlice {
  334. newSubjectNameSlice = append(newSubjectNameSlice, "'"+ s + "'")
  335. }
  336. subjectNameStr := strings.Join(newSubjectNameSlice, ",")
  337. subjectNameStr = strings.TrimRight(subjectNameStr, ",")
  338. subjectNamesCond += ` AND cis.subject_name In (`+ subjectNameStr +`) `
  339. }
  340. tagArticleIds, tagActivityIds, err := models.GetCygxCygxArticleListByCondition(articleTypesCond, activityTypesCond, industriesCond, subjectNamesCond)
  341. if err != nil && err.Error() != utils.ErrNoRow() {
  342. br.Msg = "获取失败"
  343. br.ErrMsg = "获取活动权限数据失败,Err:" + err.Error()
  344. return
  345. }
  346. //fmt.Println("condition:",condition)
  347. //查询近一个月的数据
  348. conditionInit = " AND publish_date > '" + time.Now().AddDate(0, 0, -30).Format(utils.FormatDateTime) + "'"
  349. //conditionInit += ` AND source IN ('newchart')`
  350. if user.CompanyId <= 1 {
  351. condition += " AND source IN ('roadshow','article') "
  352. startSize = 0
  353. pageSize = utils.PageSize5
  354. } else {
  355. condition += ` AND source NOT IN ('activity','activityspecial','newchart') ` + conditionInit
  356. conditionActivity, err := services.GetActivityonditionList(user, "", "", "", "1,2,3", "", 0, 0, "", 0, 1)
  357. if err != nil && err.Error() != utils.ErrNoRow() {
  358. br.Msg = "获取失败"
  359. br.ErrMsg = "获取活动权限数据失败,Err:" + err.Error()
  360. return
  361. }
  362. conditionActivity += ` AND art.is_limit_people = 1 AND art.publish_status = 1 `
  363. var conditionOrder string
  364. conditionOrder = ` ORDER BY art.activity_time DESC , art.active_state ASC `
  365. conditionActivity += conditionOrder
  366. listActivity, err := models.GetActivityListHomeNew(conditionActivity, 0, 200)
  367. if err != nil {
  368. br.Msg = "获取失败"
  369. br.ErrMsg = "获取可见活动数据失败,Err:" + err.Error()
  370. return
  371. }
  372. var activityIds []int
  373. for _, v := range listActivity {
  374. activityIds = append(activityIds, v.ActivityId)
  375. }
  376. lenActivityIds := len(activityIds)
  377. listActivitySpecial, _, err := services.GetActivitySpecialList(user, 1, 200, "", "", "")
  378. if err != nil {
  379. br.Msg = "获取失败"
  380. br.ErrMsg = "获取专项调研可见权限失败失败,Err:" + err.Error()
  381. return
  382. }
  383. var activityspecialIds []int
  384. for _, v := range listActivitySpecial {
  385. activityspecialIds = append(activityspecialIds, v.ActivityId)
  386. }
  387. lenActivityspecialIds := len(activityspecialIds)
  388. if tagIds != "" {
  389. if tagArticleIds != "" {
  390. condition = ` AND ((source = 'article' AND source_id IN (` + tagArticleIds + `)` + conditionInit + ` ) `
  391. if tagActivityIds != "" && lenActivityIds > 0 {
  392. condition += ` OR (source = 'activity' AND source_id IN (` + tagActivityIds + `) AND source_id IN (` + utils.GetOrmInReplace(lenActivityIds) + `) ` + conditionInit + `)) `
  393. pars = append(pars, activityIds)
  394. } else {
  395. // 无可见活动
  396. condition += ` OR (source = 'activity' AND source_id IN (0))) `
  397. }
  398. } else if tagActivityIds != "" {
  399. condition = ` AND ((source = 'article' AND source_id IN (0)) `
  400. if tagActivityIds != "" && lenActivityIds > 0 {
  401. condition += ` OR (source = 'activity' AND source_id IN (` + tagActivityIds + `) AND source_id IN (` + utils.GetOrmInReplace(lenActivityIds) + `) ` + conditionInit + `)) `
  402. pars = append(pars, activityIds)
  403. } else {
  404. // 无可见活动
  405. condition += ` OR (source = 'activity' AND source_id IN (0))) `
  406. }
  407. } else {
  408. condition += ` AND ((source = 'article' AND source_id IN (0)) OR (source = 'activity' AND source_id IN (0))) `
  409. }
  410. }
  411. if lenActivityIds > 0 && tagIds == "" {
  412. condition += ` OR ( source = 'activity' AND source_id IN (` + utils.GetOrmInReplace(lenActivityIds) + `) ` + conditionInit + ` ) `
  413. pars = append(pars, activityIds)
  414. }
  415. if lenActivityspecialIds > 0 && tagIds == "" {
  416. condition += ` OR ( source = 'activityspecial' AND source_id IN (` + utils.GetOrmInReplace(lenActivityspecialIds) + `) ` + conditionInit + ` ) `
  417. pars = append(pars, activityspecialIds)
  418. }
  419. }
  420. fmt.Println("condition:",condition)
  421. total, err = models.GetResourceDataCount(condition, pars)
  422. if err != nil {
  423. br.Msg = "获取失败"
  424. br.ErrMsg = "获取数据失败,Err:" + err.Error()
  425. return
  426. }
  427. if user.CompanyId <= 1 {
  428. total = utils.PageSize5
  429. }
  430. page := paging.GetPaging(currentIndex, pageSize, total)
  431. //Source string `description:"资源类型 报告 :article 、图表 :newchart、微路演 :roadshow、活动 :activity、活动视频:activityvideo、活动音频:activityvoice、专项调研活动:activityspecial"`
  432. list, err := services.GetResourceDataList(condition, pars, startSize, pageSize, user)
  433. if err != nil {
  434. br.Msg = "获取失败"
  435. br.ErrMsg = "获取数据失败,Err:" + err.Error()
  436. return
  437. }
  438. page = paging.GetPaging(currentIndex, pageSize, total)
  439. resp.Paging = page
  440. resp.List = list
  441. br.Ret = 200
  442. br.Success = true
  443. br.Msg = "获取成功"
  444. br.Data = resp
  445. }