123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512 |
- package controllers
- import (
- "hongze/hongze_cygx/models"
- "strconv"
- )
- //研选
- type ResearchController struct {
- BaseAuthController
- }
- // @Title 近期更新主题列表
- // @Description 近期更新主题列表接口
- // @Param ChartPermissionId query int true "分类ID"
- // @Success 200 {object} models.IndustrialManagementNewList
- // @router /theme/newList [get]
- func (this *ResearchController) NewList() {
- br := new(models.BaseResponse).Init()
- defer func() {
- this.Data["json"] = br
- this.ServeJSON()
- }()
- user := this.User
- if user == nil {
- br.Msg = "请重新登录"
- br.Ret = 408
- return
- }
- chartPermissionId, _ := this.GetInt("ChartPermissionId")
- if chartPermissionId < 1 {
- br.Msg = "请输入分类ID"
- return
- }
- categoryinfo, err := models.GetChartPermissionById(chartPermissionId)
- if err != nil {
- br.Msg = "获取信息失败"
- br.ErrMsg = "获取信息失败,Err:" + err.Error()
- return
- }
- list, err := models.GetIndustrialManagementNewList(categoryinfo.PermissionName)
- if err != nil {
- br.Msg = "获取信息失败"
- br.ErrMsg = "获取品种信息失败,Err:" + err.Error()
- return
- }
- mapHot := make(map[string]int)
- condition := ` ORDER BY sum_num DESC LIMIT 3 `
- listHot, err := models.GetThemeHeatList(categoryinfo.PermissionName, user.UserId, condition)
- if err != nil {
- br.Msg = "获取信息失败"
- br.ErrMsg = "获取品种信息失败,Err:" + err.Error()
- return
- }
- for _, v := range listHot {
- mapHot[v.IndustryName] = v.IndustrialManagementId
- }
- for k, v := range list {
- if mapHot[v.IndustryName] > 0 {
- list[k].IsHot = true
- }
- }
- resp := new(models.IndustrialManagementNewList)
- resp.List = list
- br.Ret = 200
- br.Success = true
- br.Msg = "获取成功"
- br.Data = resp
- }
- // @Title 用户收藏列表
- // @Description 用户收藏列表接口
- // @Param ChartPermissionId query int true "分类ID"
- // @Success 200 {object} models.ArticleCollectionLIstResp
- // @router /collectionList [get]
- func (this *ResearchController) CollectionList() {
- br := new(models.BaseResponse).Init()
- defer func() {
- this.Data["json"] = br
- this.ServeJSON()
- }()
- user := this.User
- if user == nil {
- br.Msg = "请重新登录"
- br.Ret = 408
- return
- }
- chartPermissionId, _ := this.GetInt("ChartPermissionId")
- if chartPermissionId < 1 {
- br.Msg = "请输入分类ID"
- return
- }
- categoryinfo, err := models.GetChartPermissionById(chartPermissionId)
- if err != nil {
- br.Msg = "获取信息失败"
- br.ErrMsg = "获取信息失败,Err:" + err.Error()
- return
- }
- var condition string
- condition = ` AND a.category_name LIKE '%` + categoryinfo.PermissionName + `%' AND publish_status = 1 GROUP BY a.article_id ORDER BY collect_num DESC, publish_date DESC LIMIT 15 `
- list, err := models.GetArticleCollectionList(condition, user.UserId)
- if err != nil {
- br.Msg = "获取信息失败"
- br.ErrMsg = "获取品种信息失败,Err:" + err.Error()
- return
- }
- for k, v := range list {
- if v.MyCollectNum > 0 {
- list[k].IsCollect = true
- }
- }
- resp := new(models.ArticleCollectionLIstResp)
- resp.List = list
- br.Ret = 200
- br.Success = true
- br.Msg = "获取成功"
- br.Data = resp
- }
- // @Title 主题热度/近期更新更多,列表
- // @Description 主题热度/近期更新更多,列表接口
- // @Param ChartPermissionId query int true "分类ID"
- // @Param ThemeType query int true "主题类型,1主题热度、2近期更新 默认1"
- // @Success 200 {object} models.IndustrialManagementHotListResp
- // @router /hotList [get]
- func (this *ResearchController) HotList() {
- br := new(models.BaseResponse).Init()
- defer func() {
- this.Data["json"] = br
- this.ServeJSON()
- }()
- user := this.User
- if user == nil {
- br.Msg = "请重新登录"
- br.Ret = 408
- return
- }
- chartPermissionId, _ := this.GetInt("ChartPermissionId")
- themeType, _ := this.GetInt("ThemeType")
- if chartPermissionId < 1 {
- br.Msg = "请输入分类ID"
- return
- }
- var condition string
- if themeType != 2 {
- themeType = 1
- condition = `ORDER BY sum_num DESC LIMIT 15`
- } else {
- condition = `ORDER BY publish_date DESC LIMIT 30`
- }
- categoryinfo, err := models.GetChartPermissionById(chartPermissionId)
- if err != nil {
- br.Msg = "获取信息失败"
- br.ErrMsg = "获取信息失败,Err:" + err.Error()
- return
- }
- list, err := models.GetThemeHeatList(categoryinfo.PermissionName, user.UserId, condition)
- if err != nil {
- br.Msg = "获取信息失败"
- br.ErrMsg = "获取品种信息失败,Err:" + err.Error()
- return
- }
- newMap := make(map[int]string)
- listNew, err := models.GetIndustrialManagementNewList(categoryinfo.PermissionName)
- if err != nil {
- br.Msg = "获取信息失败"
- br.ErrMsg = "获取产业最新信息失败,Err:" + err.Error()
- return
- }
- for _, v := range listNew {
- newMap[v.IndustrialManagementId] = v.IndustryName
- }
- condition = ` AND a.category_name LIKE '%` + categoryinfo.PermissionName + `%' `
- listSubjcet, err := models.GetThemeHeatSubjectList(condition)
- if err != nil {
- br.Msg = "获取信息失败"
- br.ErrMsg = "获取标的信息失败,Err:" + err.Error()
- return
- }
- mapHot := make(map[string]int)
- condition = ` ORDER BY sum_num DESC LIMIT 3 `
- listHot, err := models.GetThemeHeatList(categoryinfo.PermissionName, user.UserId, condition)
- if err != nil {
- br.Msg = "获取信息失败"
- br.ErrMsg = "获取品种信息失败,Err:" + err.Error()
- return
- }
- for _, v := range listHot {
- mapHot[v.IndustryName] = v.IndustrialManagementId
- }
- for k, v := range list {
- if newMap[v.IndustrialManagementId] != "" {
- list[k].IsNew = true
- }
- if v.FllowNum > 0 {
- list[k].IsFollw = true
- }
- for _, v2 := range listSubjcet {
- if v2.IndustrialManagementId == v.IndustrialManagementId {
- list[k].IndustrialSubjectList = append(list[k].IndustrialSubjectList, v2)
- }
- }
- if mapHot[v.IndustryName] > 0 {
- list[k].IsHot = true
- }
- }
- resp := new(models.IndustrialManagementHotListResp)
- resp.List = list
- br.Ret = 200
- br.Success = true
- br.Msg = "获取成功"
- br.Data = resp
- }
- // @Title KOL榜列表
- // @Description KOL榜列表接口
- // @Param ChartPermissionId query int true "分类ID"
- // @Success 200 {object} models.DepartmentListResp
- // @router /kolList [get]
- func (this *ResearchController) KolList() {
- br := new(models.BaseResponse).Init()
- defer func() {
- this.Data["json"] = br
- this.ServeJSON()
- }()
- user := this.User
- if user == nil {
- br.Msg = "请重新登录"
- br.Ret = 408
- return
- }
- chartPermissionId, _ := this.GetInt("ChartPermissionId")
- if chartPermissionId < 1 {
- br.Msg = "请输入分类ID"
- return
- }
- categoryinfo, err := models.GetChartPermissionById(chartPermissionId)
- if err != nil {
- br.Msg = "获取信息失败"
- br.ErrMsg = "获取信息失败,Err:" + err.Error()
- return
- }
- list, err := models.GetDepartmentList(categoryinfo.PermissionName, user.UserId)
- if err != nil {
- br.Msg = "获取信息失败"
- br.ErrMsg = "获取品种信息失败,Err:" + err.Error()
- return
- }
- listIndustrial, err := models.GetIndustrialDepartmentList(categoryinfo.PermissionName)
- if err != nil {
- br.Msg = "获取信息失败"
- br.ErrMsg = "获取品种信息失败,Err:" + err.Error()
- return
- }
- departmentMap := make(map[string]string)
- for k, v := range list {
- if v.FllowNum > 0 {
- list[k].IsFollw = true
- }
- for _, v2 := range listIndustrial {
- if v2.DepartmentId == v.DepartmentId {
- if departmentMap["D"+strconv.Itoa(v2.DepartmentId)+"In"+strconv.Itoa(v2.IndustrialManagementId)] == "" && len(list[k].List) < 4 {
- list[k].List = append(list[k].List, v2)
- departmentMap["D"+strconv.Itoa(v2.DepartmentId)+"In"+strconv.Itoa(v2.IndustrialManagementId)] = v.NickName
- }
- }
- }
- }
- resp := new(models.DepartmentListResp)
- resp.List = list
- br.Ret = 200
- br.Success = true
- br.Msg = "获取成功"
- br.Data = resp
- }
- // @Title 主题详情
- // @Description 主题详情接口
- // @Param IndustrialManagementId query int true "分类ID"
- // @Success 200 {object} models.GetThemeDetailResp
- // @router /theme/detail [get]
- func (this *ResearchController) ThemeDetail() {
- br := new(models.BaseResponse).Init()
- defer func() {
- this.Data["json"] = br
- this.ServeJSON()
- }()
- user := this.User
- if user == nil {
- br.Msg = "请重新登录"
- br.Ret = 408
- return
- }
- industrialManagementId, _ := this.GetInt("IndustrialManagementId")
- if industrialManagementId < 1 {
- br.Msg = "请输入产业ID"
- return
- }
- resp := new(models.GetThemeDetailResp)
- list, err := models.GetThemeDetail(user.UserId, industrialManagementId)
- if err != nil {
- br.Msg = "获取信息失败"
- br.ErrMsg = "获取品种信息失败,Err:" + err.Error()
- return
- }
- var itemsNull []*models.GetThemeAericleListResp
- subjectMap := make(map[string]string)
- for _, v := range list {
- resp.IndustryName = v.IndustryName
- resp.IndustrialManagementId = v.IndustrialManagementId
- itemSubJect := new(models.IndustrialSubject)
- itemSubJect.SubjectName = v.SubjectName
- itemSubJect.IndustrialSubjectId = v.IndustrialSubjectId
- if subjectMap[v.SubjectName] == "" && v.SubjectName != "" {
- resp.ListSubject = append(resp.ListSubject, itemSubJect)
- }
- subjectMap[v.SubjectName] = v.IndustryName
- if v.FllowNum > 0 {
- resp.IsFollw = true
- }
- if v.SubjectName == "" {
- item := new(models.GetThemeAericleListResp)
- item.ArticleId = v.ArticleId
- item.Title = v.Title
- item.PublishDate = v.PublishDate
- item.SubjectName = v.SubjectName
- item.DepartmentId = v.DepartmentId
- item.NickName = v.NickName
- item.Pv = v.Pv
- item.CollectNum = v.CollectNum
- itemsNull = append(itemsNull, item)
- }
- }
- for _, v := range resp.ListSubject {
- subjetcGroup := new(models.GetThemeAericleListBuSubjectResp)
- for _, v2 := range list {
- if v2.IndustrialSubjectId == v.IndustrialSubjectId {
- item := new(models.GetThemeAericleListResp)
- item.ArticleId = v2.ArticleId
- item.Title = v2.Title
- item.PublishDate = v2.PublishDate
- item.SubjectName = v2.SubjectName
- item.IndustrialSubjectId = v2.IndustrialSubjectId
- for _, v3 := range list {
- if v3.ArticleId == v2.ArticleId && v3.SubjectName != v2.SubjectName && v3.SubjectName != "" {
- item.SubjectName += "/" + v3.SubjectName
- }
- }
- item.DepartmentId = v2.DepartmentId
- item.NickName = v2.NickName
- item.Pv = v2.Pv
- item.CollectNum = v2.CollectNum
- item.MyCollectNum = v2.MyCollectNum
- if v2.MyCollectNum > 0 {
- item.IsCollect = true
- }
- resp.List = append(resp.List, item)
- //subjetcGroup.List = append(subjetcGroup.List, item)
- }
- subjetcGroup.SubjectName = v.SubjectName
- }
- }
- //当标的为空时进行合并
- if len(itemsNull) > 0 {
- for _, v := range itemsNull {
- resp.List = append(resp.List, v)
- }
- }
- br.Ret = 200
- br.Success = true
- br.Msg = "获取成功"
- br.Data = resp
- }
- // @Title 研选作者详情
- // @Description 研选作者详情接口
- // @Param DepartmentId query int true "作者ID"
- // @Success 200 {object} models.DepartmentDetailResp
- // @router /departmentId/detail [get]
- func (this *ResearchController) DepartmentIdDetail() {
- br := new(models.BaseResponse).Init()
- defer func() {
- this.Data["json"] = br
- this.ServeJSON()
- }()
- user := this.User
- if user == nil {
- br.Msg = "请重新登录"
- br.Ret = 408
- return
- }
- departmentId, _ := this.GetInt("DepartmentId")
- if departmentId < 1 {
- br.Msg = "请输入作者ID"
- return
- }
- resp := new(models.DepartmentDetailResp)
- detail, err := models.GetDepartmentDetail(user.UserId, departmentId)
- if err != nil {
- br.Msg = "获取信息失败"
- br.ErrMsg = "获取作者信息失败,Err:" + err.Error()
- return
- }
- resp.DepartmentId = detail.DepartmentId
- resp.NickName = detail.NickName
- resp.ImgUrl = detail.ImgUrl
- resp.FllowNum = detail.FllowNum
- resp.ArticleNum = detail.ArticleNum
- resp.CollectNum = detail.CollectNum
- if detail.MyFllowNum > 0 {
- resp.IsFllow = true
- }
- var condition string
- condition = ` AND a.department_id = ` + strconv.Itoa(departmentId) + ` ORDER BY a.publish_date DESC `
- list, err := models.GetArticleCollectionList(condition, user.UserId)
- if err != nil {
- br.Msg = "获取信息失败"
- br.ErrMsg = "获取文章列表失败,Err:" + err.Error()
- return
- }
- for k, v := range list {
- if v.MyCollectNum > 0 {
- list[k].IsCollect = true
- }
- }
- resp.List = list
- br.Ret = 200
- br.Success = true
- br.Msg = "获取成功"
- br.Data = resp
- }
- // @Title 文章相关热门收藏
- // @Description 文章相关热门收藏接口
- // @Param ArticleId query int true "文章ID"
- // @Success 200 {object} models.ArticleCollectionLIstResp
- // @router /article/hotList [get]
- func (this *ResearchController) ArticleHotList() {
- br := new(models.BaseResponse).Init()
- defer func() {
- this.Data["json"] = br
- this.ServeJSON()
- }()
- user := this.User
- if user == nil {
- br.Msg = "请重新登录"
- br.Ret = 408
- return
- }
- articleId, _ := this.GetInt("ArticleId")
- if articleId < 1 {
- br.Msg = "请输入分类ID"
- return
- }
- var condition string
- condition = ` AND a.article_id IN (SELECT article_id FROM cygx_industrial_article_group_management WHERE industrial_management_id IN (SELECT industrial_management_id FROM cygx_industrial_article_group_management WHERE article_id = ` + strconv.Itoa(articleId) + ` ) ) AND a.article_id != ` + strconv.Itoa(articleId) + ` AND a.category_name LIKE '%研选%' AND publish_status = 1 GROUP BY a.article_id ORDER BY collect_num DESC, publish_date DESC LIMIT 3 `
- list, err := models.GetArticleCollectionList(condition, user.UserId)
- if err != nil {
- br.Msg = "获取信息失败"
- br.ErrMsg = "获取品种信息失败,Err:" + err.Error()
- return
- }
- for k, v := range list {
- if v.MyCollectNum > 0 {
- list[k].IsCollect = true
- }
- }
- resp := new(models.ArticleCollectionLIstResp)
- resp.List = list
- br.Ret = 200
- br.Success = true
- br.Msg = "获取成功"
- br.Data = resp
- }
- // @Title 热搜关键词
- // @Description 热搜关键词接口
- // @Success 200 {object} models.UserSearchKeyWordListResp
- // @router /hotKeyWord [get]
- func (this *ResearchController) HotKeyWord() {
- br := new(models.BaseResponse).Init()
- defer func() {
- this.Data["json"] = br
- this.ServeJSON()
- }()
- user := this.User
- if user == nil {
- br.Msg = "请重新登录"
- br.Ret = 408
- return
- }
- //本来应该放在config控制器下,与未上线的代码冲突,所以放在这里
- list, err := models.GetUserSearchKeyWord()
- if err != nil {
- br.Msg = "获取信息失败"
- br.ErrMsg = "获取品种信息失败,Err:" + err.Error()
- return
- }
- resp := new(models.UserSearchKeyWordListResp)
- resp.List = list
- br.Ret = 200
- br.Success = true
- br.Msg = "获取成功"
- br.Data = resp
- }
|