123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462 |
- package collection
- import (
- "errors"
- "fmt"
- "hongze/hongze_yb/models/response"
- "hongze/hongze_yb/models/tables/company_product"
- "hongze/hongze_yb/models/tables/rddp/report"
- "hongze/hongze_yb/models/tables/rddp/report_chapter"
- "hongze/hongze_yb/models/tables/yb_community_video"
- "hongze/hongze_yb/models/tables/yb_road_video"
- "hongze/hongze_yb/models/tables/yb_user_collection"
- "hongze/hongze_yb/services/user"
- "hongze/hongze_yb/utils"
- "strings"
- "sync"
- "time"
- )
- const (
- CollectionTypeReport = iota + 1
- CollectionTypeVideo
- CollectionTypeRoadVideo
- )
- func AddCollection(userInfo user.UserInfo, collectionType, primaryId, extendId, sourceAgent int) (collectionId int, err error) {
- userId := int(userInfo.UserID)
- if userId <= 0 || collectionType <= 0 || primaryId <= 0 {
- return
- }
- title := ""
- nowTime := time.Now().Local()
- publishTime := nowTime
-
- var cond string
- var pars []interface{}
- cond += `user_id = ?`
- pars = append(pars, userId)
- cond += ` AND collection_type = ?`
- pars = append(pars, collectionType)
- cond += ` AND primary_id = ?`
- pars = append(pars, primaryId)
- if extendId > 0 {
- cond += ` AND extend_id = ?`
- pars = append(pars, extendId)
- }
- exist, e := yb_user_collection.GetItemByCondition(cond, pars)
- if e != nil && e != utils.ErrNoRow {
- err = errors.New("获取用户收藏失败, Err: " + e.Error())
- return
- }
- if exist != nil && exist.CollectionID > 0 {
-
- collectionId = exist.CollectionID
- if exist.State == 1 {
- return
- }
-
- exist.State = 1
- exist.CreateTime = nowTime
- exist.ModifyTime = nowTime
- updateCols := []string{"State", "CreateTime", "ModifyTime"}
- if e = exist.Update(updateCols); e != nil {
- collectionId = 0
- err = errors.New("重新收藏失败, Err: " + e.Error())
- return
- }
- return
- }
-
- switch collectionType {
- case CollectionTypeReport:
-
- if extendId > 0 {
- chapter, e := report_chapter.GetItemById(extendId)
- if e != nil {
- err = errors.New("获取章节失败, Err: " + e.Error())
- return
- }
- title = chapter.Title
- publishTime = chapter.PublishTime
- break
- }
- rp, e := report.GetPublishByReportId(primaryId)
- if e != nil {
- err = errors.New("获取报告失败, Err: " + e.Error())
- return
- }
- title = rp.Title
- publishTime = rp.PublishTime
- case CollectionTypeVideo:
- video, e := yb_community_video.GetItemById(primaryId)
- if e != nil {
- err = errors.New("获取视频失败, Err: " + e.Error())
- return
- }
- title = video.Title
- publishTime = video.PublishTime
- case CollectionTypeRoadVideo:
- roadVideo, e := yb_road_video.GetItemById(primaryId)
- if e != nil {
- err = errors.New("获取路演视频失败, Err: " + e.Error())
- return
- }
- title = roadVideo.Title
- publishTime = roadVideo.PublishTime
- default:
- err = errors.New(fmt.Sprintf("收藏类型有误, 当前收藏类型%d", collectionType))
- return
- }
- companyName := "潜在客户"
- companyStatus := "潜在"
- sellerId := 0
- if userInfo.CompanyID > 0 {
-
- companyInfo, e := company_product.GetByCompany2ProductId(userInfo.CompanyID, 1)
- if e != nil && e != utils.ErrNoRow {
- err = errors.New("获取客户信息失败, Err: " + e.Error())
- return
- }
- if companyInfo != nil && companyInfo.CompanyID > 0 {
- companyStatus = companyInfo.Status
- companyName = companyInfo.CompanyName
- sellerId = companyInfo.SellerID
- }
- }
-
- item := &yb_user_collection.YbUserCollection{
- CollectionType: collectionType,
- UserID: userId,
- RealName: userInfo.RealName,
- CompanyID: int(userInfo.CompanyID),
- CompanyName: companyName,
- CompanyStatus: companyStatus,
- SellerID: sellerId,
- PrimaryID: primaryId,
- ExtendID: extendId,
- State: 1,
- SourceAgent: sourceAgent,
- Title: title,
- PublishTime: publishTime,
- CreateTime: nowTime,
- ModifyTime: nowTime,
- }
- if e := item.Create(); e != nil {
- err = errors.New("新增收藏失败, Err: " + e.Error())
- return
- }
- collectionId = item.CollectionID
- return
- }
- func CancelCollection(userId, collectionId int) (err error) {
- item, e := yb_user_collection.GetItemById(collectionId)
- if e != nil {
- err = errors.New("获取收藏失败, Err: " + e.Error())
- return
- }
- if item.CollectionID <= 0 {
- err = errors.New("收藏信息有误")
- return
- }
- if item.State != 1 {
- err = errors.New("收藏状态有误")
- return
- }
- if item.UserID != userId {
- err = errors.New(fmt.Sprintf("收藏人信息有误, 操作人ID: %d, 被操作人ID: %d", userId, item.UserID))
- return
- }
- updateCols := []string{"State", "ModifyTime"}
- item.State = 0
- item.ModifyTime = time.Now().Local()
- if e = item.Update(updateCols); e != nil {
- err = errors.New("更新收藏失败, Err: " + e.Error())
- return
- }
- return
- }
- func GetCollectionList(userId, fromType, currPage, pageSize int, keywords string) (total int, respList []*response.CollectionList, err error) {
- respList = make([]*response.CollectionList, 0)
- if fromType <= 0 {
- fromType = 0
- }
-
- var cond string
- var pars []interface{}
- cond += `state = 1 AND user_id = ?`
- pars = append(pars, userId)
- if fromType > 0 {
- cond += ` AND collection_type = ?`
- pars = append(pars, fromType)
- }
- if keywords != "" {
- cond += ` AND title LIKE ?`
- pars = append(pars, fmt.Sprint("%", keywords, "%"))
- }
- collectionTotal, e := yb_user_collection.GetPageListTotalByCondition(cond, pars)
- if e != nil {
- err = errors.New("获取收藏列表总数失败, Err: " + e.Error())
- return
- }
- total = int(collectionTotal)
- collections, e := yb_user_collection.GetPageListByCondition(cond, pars, currPage, pageSize)
- if e != nil {
- err = errors.New("获取收藏列表失败, Err: " + e.Error())
- return
- }
-
- reportIdArr := make([]int, 0)
- chapterIdArr := make([]int, 0)
- videoIdArr := make([]int, 0)
- roadVideoIdArr := make([]int, 0)
- for i := range collections {
- switch collections[i].CollectionType {
- case CollectionTypeReport:
- if collections[i].ExtendID > 0 {
- chapterIdArr = append(chapterIdArr, collections[i].ExtendID)
- break
- }
- reportIdArr = append(reportIdArr, collections[i].PrimaryID)
- case CollectionTypeVideo:
- videoIdArr = append(videoIdArr, collections[i].PrimaryID)
- case CollectionTypeRoadVideo:
- roadVideoIdArr = append(roadVideoIdArr, collections[i].PrimaryID)
- }
- }
-
- var chapterErr, reportErr, videoErr, roadVideoErr error
- chapterMap := make(map[int]*report_chapter.ReportChapter, 0)
- reportMap := make(map[int]*report.Report, 0)
- videoMap := make(map[int]*yb_community_video.YbCommunityVideo, 0)
- roadVideoMap := make(map[int]*yb_road_video.YbRoadVideo, 0)
- wg := sync.WaitGroup{}
-
- wg.Add(1)
- go func() {
- defer wg.Done()
- if len(chapterIdArr) == 0 {
- return
- }
- chapters, e := report_chapter.GetListByChapterIds(chapterIdArr)
- if e != nil {
- chapterErr = errors.New("获取章节失败, Err: " + e.Error())
- return
- }
- for i := range chapters {
- chapterMap[chapters[i].ReportChapterId] = chapters[i]
- }
- }()
-
- wg.Add(1)
- go func() {
- defer wg.Done()
- if len(reportIdArr) == 0 {
- return
- }
- reports, e := report.GetListByReportIds(reportIdArr)
- if e != nil {
- reportErr = errors.New("获取报告失败, Err: " + e.Error())
- return
- }
- for i := range reports {
- reportMap[reports[i].Id] = reports[i]
- }
- }()
-
- wg.Add(1)
- go func() {
- defer wg.Done()
- if len(videoIdArr) == 0 {
- return
- }
- videos, e := yb_community_video.GetListByVideoIds(videoIdArr)
- if e != nil {
- videoErr = errors.New("获取视频失败, Err: " + e.Error())
- return
- }
- for i := range videos {
- videoMap[videos[i].CommunityVideoID] = videos[i]
- }
- }()
-
- wg.Add(1)
- go func() {
- defer wg.Done()
- if len(roadVideoIdArr) == 0 {
- return
- }
- roadVideos, e := yb_road_video.GetListByVideoIds(roadVideoIdArr)
- if e != nil {
- roadVideoErr = errors.New("获取视频失败, Err: " + e.Error())
- return
- }
- for i := range roadVideos {
- roadVideoMap[roadVideos[i].RoadVideoID] = roadVideos[i]
- }
- }()
- wg.Wait()
- if chapterErr != nil {
- err = chapterErr
- return
- }
- if reportErr != nil {
- err = reportErr
- return
- }
- if videoErr != nil {
- err = videoErr
- return
- }
- if roadVideoErr != nil {
- err = roadVideoErr
- return
- }
-
- titlePre := `<div style="-webkit-line-clamp: 2;-webkit-box-orient: vertical;display: -webkit-box;overflow: hidden;text-overflow: ellipsis;">`
- titleSuf := `</div>`
- highlightPre := `<span style="color:#E3B377">`
- highlightSuf := `</span>`
- for i := range collections {
- v := &response.CollectionList{
- CollectionId: collections[i].CollectionID,
- CollectionType: collections[i].CollectionType,
- PrimaryId: collections[i].PrimaryID,
- ExtendId: collections[i].ExtendID,
- CreateTime: collections[i].CreateTime.Format(utils.FormatDate),
- }
-
- switch collections[i].CollectionType {
- case CollectionTypeReport:
-
- if collections[i].ExtendID > 0 {
- cp := chapterMap[collections[i].ExtendID]
- if cp != nil {
- v.PublishTime = cp.PublishTime.Format(utils.FormatDate)
- v.ClassifyName = utils.REPORT_CHAPTER_TYPE_NAME_MAP[cp.ReportType]
- v.Author = cp.Author
- v.Title = cp.Title
- }
- break
- }
- rp := reportMap[collections[i].PrimaryID]
- if rp != nil {
- v.PublishTime = rp.PublishTime.Format(utils.FormatDate)
- v.ClassifyName = rp.ClassifyNameFirst
- v.ClassifySecondName = rp.ClassifyNameSecond
- v.Author = rp.Author
- v.Title = rp.Title
- }
- case CollectionTypeVideo:
- vd := videoMap[collections[i].PrimaryID]
- if vd != nil {
- v.PublishTime = vd.PublishTime.Format(utils.FormatDate)
- v.ImgUrl = vd.CoverImgURL
- v.Title = vd.Title
- }
- case CollectionTypeRoadVideo:
- rv := roadVideoMap[collections[i].PrimaryID]
- if rv != nil {
- v.PublishTime = rv.PublishTime.Format(utils.FormatDate)
- v.ImgUrl = rv.CoverImgURL
- v.Author = rv.AdminRealName
- v.Title = rv.Title
- }
- default:
- break
- }
-
- v.Title = fmt.Sprint(titlePre, v.Title, titleSuf)
- if keywords != "" {
- kw := fmt.Sprint(highlightPre, keywords, highlightSuf)
- v.Title = strings.ReplaceAll(v.Title, keywords, kw)
- }
- respList = append(respList, v)
- }
- return
- }
- func GetUserCollectByItem(userId, collectionType, primaryId, extendId int) (collectionId int, err error) {
- if userId <= 0 || collectionType <= 0 || primaryId <= 0 {
- return
- }
- var cond string
- var pars []interface{}
- cond += `state = 1 AND user_id = ?`
- pars = append(pars, userId)
- cond += ` AND collection_type = ?`
- pars = append(pars, collectionType)
- cond += ` AND primary_id = ?`
- pars = append(pars, primaryId)
- if extendId > 0 {
- cond += ` AND extend_id = ?`
- pars = append(pars, extendId)
- }
- item, e := yb_user_collection.GetItemByCondition(cond, pars)
- if e != nil && e != utils.ErrNoRow {
- err = errors.New("获取用户收藏失败, Err: " + e.Error())
- return
- }
- if item != nil && item.CollectionID > 0 {
- collectionId = item.CollectionID
- }
- return
- }
- func GetUserCollectByList(userId, collectionType int, primaryIds []int) (collectMap map[int]int, err error) {
- collectMap = make(map[int]int, 0)
- if userId <= 0 || collectionType <= 0 || len(primaryIds) == 0 {
- return
- }
- var cond string
- var pars []interface{}
- cond += `state = 1 AND user_id = ?`
- pars = append(pars, userId)
- cond += ` AND collection_type = ?`
- pars = append(pars, collectionType)
- cond += ` AND primary_id IN (?)`
- pars = append(pars, primaryIds)
- list, e := yb_user_collection.GetListByCondition(cond, pars)
- if e != nil {
- err = errors.New("获取用户收藏列表失败, Err: " + e.Error())
- return
- }
- for i := range list {
- if utils.InArrayByInt(primaryIds, list[i].PrimaryID) {
- collectMap[list[i].PrimaryID] = list[i].CollectionID
- }
- }
- return
- }
|