article_red.go 6.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213
  1. package services
  2. import (
  3. "errors"
  4. "fmt"
  5. "hongze/hongze_clpt/models"
  6. "hongze/hongze_clpt/utils"
  7. "strconv"
  8. "time"
  9. )
  10. //处理文章小红点
  11. func GetShowTimeLineIsRed(user *models.WxUserItem, industrialManagementId int) (isRed bool, err error) {
  12. //时间线
  13. timeLineItem := models.IndustrialToArticleCategoryRep{
  14. CategoryId: 99999,
  15. MatchTypeName: "时间线",
  16. }
  17. timeLineList, e := models.GetTimeLineReportIndustrialListRed(user.UserId, industrialManagementId, 0, 30)
  18. if e != nil {
  19. err = errors.New("GetTimeLineReportIndustrialListRed, Err: " + e.Error())
  20. return
  21. }
  22. //查询用户今天是否看过时间线
  23. haveMorningMeeting := false
  24. var morningMeetingTime string
  25. count, e := models.GetTimeLineRecordCount(user.UserId, industrialManagementId)
  26. if e != nil {
  27. err = errors.New("GetTimeLineRecordCount, Err: " + e.Error())
  28. return
  29. }
  30. var recordItem *models.CygxPageHistoryRecord
  31. if count > 1 {
  32. recordItem, e = models.GetTimeLineRecordItem(user.UserId, industrialManagementId)
  33. if e != nil {
  34. err = errors.New("GetTimeLineRecordCount, Err: " + e.Error())
  35. return
  36. }
  37. }
  38. for _, v := range timeLineList {
  39. if v.Readnum == 0 && user.CreatedTime.Before(utils.StrTimeToTime(v.PublishDate)) && utils.StrTimeToTime(utils.OnlineTime).Before(utils.StrTimeToTime(v.PublishDate)) {
  40. if v.SubCategoryName == "时间线" {
  41. haveMorningMeeting = true
  42. morningMeetingTime = v.PublishDate
  43. continue
  44. }
  45. timeLineItem.IsRed = true
  46. }
  47. }
  48. //因为无法记录用户是否看过晨会点评,所以用用户今天是否看过时间线来判断是否显示小红点,这里是判断分类的小红点
  49. timeLineRed := false
  50. if count < 2 {
  51. timeLineRed = true
  52. } else if count > 1 && recordItem.CreateTime.Before(utils.StrTimeToTime(morningMeetingTime)) {
  53. timeLineRed = true
  54. }
  55. if !timeLineItem.IsRed && timeLineRed && haveMorningMeeting {
  56. timeLineItem.IsRed = true
  57. }
  58. isRed = timeLineItem.IsRed
  59. return
  60. }
  61. // UserViewRedisData 阅读数据
  62. type UserViewRedisData struct {
  63. Mobile string `json:"mobile"`
  64. Email string `json:"email"`
  65. RealName string `json:"real_name"`
  66. CompanyName string `json:"company_name"`
  67. ViewTime string `json:"view_time" description:"阅读时间,格式:2022-02-17 13:06:13"`
  68. ProductId int `json:"product_id" description:"报告所属产品,ficc:1,权益:2"`
  69. CompanyId int `json:"company_id" description:"客户id"`
  70. }
  71. type ReportViewRecord struct {
  72. Id int `orm:"column(id);pk"`
  73. UserId int `description:"用户id"`
  74. ReportId int `description:"报告id"`
  75. Mobile string `description:"手机号"`
  76. Email string `description:"邮箱"`
  77. RealName string `description:"用户实际姓名"`
  78. CompanyName string `description:"公司名称"`
  79. CreateTime time.Time `description:"创建时间"`
  80. }
  81. // PushViewRecordNewRedisData 阅读数据加入到redis
  82. func PushViewRecordNewRedisData(reportViewRecord *ReportViewRecord, companyId int) bool {
  83. data := &UserViewRedisData{
  84. Mobile: reportViewRecord.Mobile,
  85. Email: reportViewRecord.Email,
  86. RealName: reportViewRecord.RealName,
  87. CompanyName: reportViewRecord.CompanyName,
  88. ViewTime: reportViewRecord.CreateTime.Format(utils.FormatDateTime),
  89. ProductId: 2,
  90. CompanyId: companyId,
  91. }
  92. if utils.Re == nil {
  93. err := utils.Rc.LPush(utils.CACHE_KEY_USER_VIEW, data)
  94. if err != nil {
  95. fmt.Println("PushViewRecordNewRedisData LPush Err:" + err.Error())
  96. }
  97. return true
  98. }
  99. return false
  100. }
  101. // 记录用户文章浏览记录
  102. func ArticleHistory(articleId int, user *models.WxUserItem) (err error) {
  103. defer func() {
  104. if err != nil {
  105. go utils.SendAlarmMsg("记录用户文章浏览记录,失败"+err.Error(), 2)
  106. }
  107. }()
  108. uid := user.UserId
  109. if uid == 0 {
  110. return
  111. }
  112. record := new(models.CygxArticleHistoryRecordNewpv)
  113. record.UserId = uid
  114. record.ArticleId = articleId
  115. record.CreateTime = time.Now()
  116. record.ModifyTime = time.Now()
  117. record.Mobile = user.Mobile
  118. record.Email = user.Email
  119. record.CompanyId = user.CompanyId
  120. record.CompanyName = user.CompanyName
  121. record.StopTime = 0
  122. record.OutType = 1
  123. record.Source = "WEB"
  124. recordRedis := new(ReportViewRecord)
  125. recordRedis.UserId = user.UserId
  126. recordRedis.ReportId = articleId
  127. recordRedis.Mobile = user.Mobile
  128. recordRedis.Email = user.Email
  129. recordRedis.RealName = user.RealName
  130. recordRedis.CompanyName = user.CompanyName
  131. recordRedis.CreateTime = time.Now()
  132. go PushViewRecordNewRedisData(recordRedis, user.CompanyId)
  133. _, err = models.AddCygxArticleViewRecordNewpv(record)
  134. return
  135. }
  136. // GetUserArticleHistoryRecord 获取用户已经阅读的文章ID
  137. func GetUserArticleHistoryRecord(user *models.WxUserItem) (articleIdMap map[int]bool, err error) {
  138. var condition string
  139. var pars []interface{}
  140. condition = " AND user_id = ? "
  141. pars = append(pars, user.UserId)
  142. articleIdMap = make(map[int]bool, 0)
  143. list, err := models.GetArticleHistoryRecord(condition, pars)
  144. if err != nil && err.Error() != utils.ErrNoRow() {
  145. return
  146. }
  147. for _, v := range list {
  148. articleIdMap[v.ArticleId] = true
  149. }
  150. return
  151. }
  152. // GetUserArticleHistoryIndustrialNewPublishDate 获取产业关联的的文章用户是否阅读
  153. func GetUserArticleHistoryIndustrialNewPublishDate(user *models.WxUserItem, industrialIdArr []int, articleTypeIds, resource string) (mapIndustrialArticleHistory map[int]bool, err error) {
  154. if len(industrialIdArr) == 0 {
  155. return
  156. }
  157. var condition string
  158. var pars []interface{}
  159. articleIdMap, err := GetUserArticleHistoryRecord(user)
  160. if err != nil {
  161. return
  162. }
  163. if resource == utils.REOURCE_YX {
  164. condition = ` AND a.publish_status = 1 AND a.article_type_id IN (` + articleTypeIds + `) `
  165. } else {
  166. condition = ` AND a.article_type_id = 0 AND a.article_id < ` + strconv.Itoa(utils.SummaryArticleId)
  167. }
  168. var startTime time.Time
  169. if utils.StrTimeToTime(utils.OnlineTime).After(user.CreatedTime) {
  170. startTime = utils.StrTimeToTime(utils.OnlineTime)
  171. } else {
  172. startTime = user.CreatedTime
  173. }
  174. condition += ` AND mg.industrial_management_id IN (` + utils.GetOrmInReplace(len(industrialIdArr)) + `) AND a.publish_date > ? `
  175. pars = append(pars, industrialIdArr, startTime)
  176. list, err := models.GetCygxIndustrialArticleGroupManagement(condition, pars)
  177. if err != nil {
  178. return
  179. }
  180. mapIndustrialArticle := make(map[int][]*models.CygxIndustrialArticleGroupManagementResp)
  181. //mapIndustrialArticleMax := make(map[int]int, 0)
  182. mapIndustrialArticleHistory = make(map[int]bool, 0)
  183. //mapIndustrialArticleMaxTime := make(map[int]time.Time)
  184. for _, v := range list {
  185. item := new(models.CygxIndustrialArticleGroupManagementResp)
  186. item.IndustrialManagementId = v.IndustrialManagementId
  187. item.ArticleId = v.ArticleId
  188. item.PublishDate = v.PublishDate
  189. mapIndustrialArticle[v.IndustrialManagementId] = append(mapIndustrialArticle[v.IndustrialManagementId], item)
  190. }
  191. for k, v := range mapIndustrialArticle {
  192. for _, item := range v {
  193. if !articleIdMap[item.ArticleId] {
  194. mapIndustrialArticleHistory[k] = true
  195. }
  196. }
  197. }
  198. return
  199. }