bill.go 9.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322
  1. package models
  2. import (
  3. "hongze/hongze_api/utils"
  4. "rdluck_tools/orm"
  5. "time"
  6. )
  7. type BillDetailResp struct {
  8. RealName string `description:"用户实际名称"`
  9. TogetherDay string `description:"相伴天数"`
  10. CreateDate string `description:"创建时间"`
  11. FirstReadReportType string `description:"首次阅读报告类型"`
  12. FirstReadReportTitle string `description:"首次阅读报告标题"`
  13. ListenReportCount int `description:"收听报告次数"`
  14. ListenReportDuration float64 `description:"收听报告时长"`
  15. MaxReadReportDate string `description:"阅读报告最多的一天"`
  16. MaxReadReportCount int `description:"阅读报告最多的一天,报告数量"`
  17. LatestReadReportDate string `description:"阅读报告时间最晚的一天"`
  18. LatestReadReportTime string `description:"阅读报告时间最晚的一天,最晚的时间"`
  19. LatestReadReportDateDuration string `description:"阅读报告时间最晚的一天,总共阅读报告的时长"`
  20. MaxOpenReportClassify string `description:"打开次数最多报告的栏目"`
  21. MaxOpenReportCount string `description:"打开次数最多报告的栏目下,用户阅读的报告数"`
  22. TotalReadDuration string `description:"总阅读时长"`
  23. TotalReportDayCount string `description:"总阅读晨报数"`
  24. TotalReportWeekCount string `description:"总阅读周报数"`
  25. TotalReportMonthCount string `description:"总阅读月报数"`
  26. TotalReportTwoWeekCount string `description:"总阅读双周报数"`
  27. TotalReportRddpCount string `description:"总阅读点评数"`
  28. LearnDay string `description:"连续学习天数"`
  29. }
  30. type ReadReportType struct {
  31. ReportType string
  32. CreateTime time.Time
  33. Title string
  34. Stage int
  35. }
  36. func GetRddpMinReportType(uid int) (item *ReadReportType, err error) {
  37. o := orm.NewOrm()
  38. o.Using("rddp")
  39. sql := `SELECT 'rddp' AS report_type,MIN(a.create_time) AS create_time,b.title,b.stage FROM report_view_record AS a
  40. INNER JOIN report AS b ON a.report_id=b.id
  41. WHERE a.user_id=? `
  42. err = o.Raw(sql, uid).QueryRow(&item)
  43. return
  44. }
  45. func GetWeekMinReportType(uid int) (item *ReadReportType, err error) {
  46. o := orm.NewOrm()
  47. sql := `SELECT b.type AS report_type,MIN(a.created_time) AS create_time,b.research_report_name AS title,b.periods AS stage FROM user_view_history AS a
  48. INNER JOIN research_report AS b ON a.research_report_id=b.research_report_id
  49. WHERE a.user_id=? `
  50. err = o.Raw(sql, uid).QueryRow(&item)
  51. return
  52. }
  53. func GetFirstReportInfo(uid int) (firstReadReportType, firstReadReportTitle string, err error) {
  54. rddpFlag := true
  55. weekFlag := true
  56. rddpMinReportItem, err := GetRddpMinReportType(uid)
  57. if err != nil {
  58. if err.Error() == utils.ErrNoRow() {
  59. rddpFlag = false
  60. } else {
  61. return
  62. }
  63. }
  64. if rddpMinReportItem == nil {
  65. rddpFlag = false
  66. }
  67. weekMinReportItem, err := GetWeekMinReportType(uid)
  68. if err != nil {
  69. if err.Error() == utils.ErrNoRow() {
  70. weekFlag = false
  71. } else {
  72. return
  73. }
  74. }
  75. if weekMinReportItem == nil {
  76. weekFlag = false
  77. }
  78. if rddpFlag && weekFlag {
  79. if rddpMinReportItem.CreateTime.After(weekMinReportItem.CreateTime) {
  80. firstReadReportType = rddpMinReportItem.ReportType
  81. firstReadReportTitle = rddpMinReportItem.Title
  82. } else {
  83. firstReadReportType = weekMinReportItem.ReportType
  84. firstReadReportTitle = weekMinReportItem.Title
  85. }
  86. } else {
  87. if rddpFlag == false && weekFlag {
  88. firstReadReportType = weekMinReportItem.ReportType
  89. firstReadReportTitle = weekMinReportItem.Title
  90. }
  91. if rddpFlag && weekFlag == false {
  92. firstReadReportType = rddpMinReportItem.ReportType
  93. firstReadReportTitle = rddpMinReportItem.Title
  94. }
  95. }
  96. return
  97. }
  98. type Listen struct {
  99. Count int
  100. VideoPlaySeconds float64
  101. }
  102. func GetRddpListen(uid int) (item *Listen, err error) {
  103. o := orm.NewOrm()
  104. o.Using("rddp")
  105. sql := ` SELECT COUNT(1),SUM(b.video_play_seconds) FROM report_audio_record AS a
  106. INNER JOIN report AS b ON a.report_id=b.id
  107. WHERE user_id=? LIMIT 1`
  108. err = o.Raw(sql, uid).QueryRow(&item)
  109. return
  110. }
  111. func GetWeekListen(uid int) (item *Listen, err error) {
  112. o := orm.NewOrm()
  113. sql := `SELECT COUNT(1) AS count,SUM(b.video_play_seconds) AS video_play_seconds FROM voice_record AS a
  114. INNER JOIN teleconference AS b ON a.teleconference_id=b.teleconference_id
  115. WHERE a.uid=? LIMIT 1`
  116. err = o.Raw(sql, uid).QueryRow(&item)
  117. return
  118. }
  119. func GetListenInfo(uid int) (count int, videoPlaySeconds float64, err error) {
  120. rddpFlag := true
  121. weekFlag := true
  122. rddpListenItem, err := GetRddpListen(uid)
  123. if err != nil {
  124. if err.Error() == utils.ErrNoRow() {
  125. rddpFlag = false
  126. } else {
  127. return
  128. }
  129. }
  130. if rddpListenItem == nil {
  131. rddpFlag = false
  132. }
  133. weekListenItem, err := GetWeekListen(uid)
  134. if err != nil {
  135. if err.Error() == utils.ErrNoRow() {
  136. weekFlag = false
  137. } else {
  138. return
  139. }
  140. }
  141. if weekListenItem == nil {
  142. weekFlag = false
  143. }
  144. if rddpFlag && weekFlag {
  145. count = rddpListenItem.Count + weekListenItem.Count
  146. videoPlaySeconds = rddpListenItem.VideoPlaySeconds + weekListenItem.VideoPlaySeconds
  147. } else {
  148. if rddpFlag == false && weekFlag {
  149. count = weekListenItem.Count
  150. videoPlaySeconds = weekListenItem.VideoPlaySeconds
  151. }
  152. if rddpFlag && weekFlag == false {
  153. count = rddpListenItem.Count
  154. videoPlaySeconds = rddpListenItem.VideoPlaySeconds
  155. }
  156. }
  157. return
  158. }
  159. type MaxReadReportCount struct {
  160. Count int
  161. CreateDate time.Time
  162. }
  163. func GetRddpMaxReadReportCount(uid int) (item *MaxReadReportCount, err error) {
  164. o := orm.NewOrm()
  165. o.Using("rddp")
  166. sql := ` SELECT DATE(create_time)AS create_date,COUNT(1) AS count FROM report_view_record AS a
  167. WHERE a.user_id=?
  168. GROUP BY DATE(create_time)
  169. ORDER BY num DESC
  170. LIMIT 1 `
  171. err = o.Raw(sql, uid).QueryRow(&item)
  172. return
  173. }
  174. func GetWeekMaxReadReportCount(uid int) (item *MaxReadReportCount, err error) {
  175. o := orm.NewOrm()
  176. sql := ` SELECT DATE(a.created_time)AS create_date,COUNT(1) AS count FROM user_view_history AS a
  177. WHERE a.user_id=?
  178. GROUP BY DATE(created_time)
  179. ORDER BY num DESC
  180. LIMIT 1 `
  181. err = o.Raw(sql, uid).QueryRow(&item)
  182. return
  183. }
  184. func GetMaxReadReportInfo(uid int) (count int, createDate time.Time, err error) {
  185. rddpFlag := true
  186. weekFlag := true
  187. rddpReadReportItem, err := GetRddpMaxReadReportCount(uid)
  188. if err != nil {
  189. if err.Error() == utils.ErrNoRow() {
  190. rddpFlag = false
  191. } else {
  192. return
  193. }
  194. }
  195. if rddpReadReportItem == nil {
  196. rddpFlag = false
  197. }
  198. weekReadReportItem, err := GetWeekMaxReadReportCount(uid)
  199. if err != nil {
  200. if err.Error() == utils.ErrNoRow() {
  201. weekFlag = false
  202. } else {
  203. return
  204. }
  205. }
  206. if weekReadReportItem == nil {
  207. weekFlag = false
  208. }
  209. if rddpFlag && weekFlag {
  210. if rddpReadReportItem.Count>weekReadReportItem.Count {
  211. count=rddpReadReportItem.Count
  212. createDate=rddpReadReportItem.CreateDate
  213. }else{
  214. count=weekReadReportItem.Count
  215. createDate=weekReadReportItem.CreateDate
  216. }
  217. } else {
  218. if rddpFlag == false && weekFlag {
  219. count=weekReadReportItem.Count
  220. createDate=weekReadReportItem.CreateDate
  221. }
  222. if rddpFlag && weekFlag == false {
  223. count=rddpReadReportItem.Count
  224. createDate=rddpReadReportItem.CreateDate
  225. }
  226. }
  227. return
  228. }
  229. //
  230. //
  231. //type MaxReadReportCount struct {
  232. // Count int
  233. // CreateDate time.Time
  234. //}
  235. //
  236. //func GetRddpMaxReadReportCount(uid int) (item *MaxReadReportCount, err error) {
  237. // o := orm.NewOrm()
  238. // o.Using("rddp")
  239. // sql := ` SELECT DATE(create_time)AS create_date,COUNT(1) AS count FROM report_view_record AS a
  240. // WHERE a.user_id=?
  241. // GROUP BY DATE(create_time)
  242. // ORDER BY num DESC
  243. // LIMIT 1 `
  244. // err = o.Raw(sql, uid).QueryRow(&item)
  245. // return
  246. //}
  247. //
  248. //func GetWeekMaxReadReportCount(uid int) (item *MaxReadReportCount, err error) {
  249. // o := orm.NewOrm()
  250. // sql := ` SELECT DATE(a.created_time)AS create_date,COUNT(1) AS count FROM user_view_history AS a
  251. // WHERE a.user_id=?
  252. // GROUP BY DATE(created_time)
  253. // ORDER BY num DESC
  254. // LIMIT 1 `
  255. // err = o.Raw(sql, uid).QueryRow(&item)
  256. // return
  257. //}
  258. //
  259. //func GetMaxReadReportInfo(uid int) (count int, createDate time.Time, err error) {
  260. // rddpFlag := true
  261. // weekFlag := true
  262. // rddpReadReportItem, err := GetRddpMaxReadReportCount(uid)
  263. // if err != nil {
  264. // if err.Error() == utils.ErrNoRow() {
  265. // rddpFlag = false
  266. // } else {
  267. // return
  268. // }
  269. // }
  270. // if rddpReadReportItem == nil {
  271. // rddpFlag = false
  272. // }
  273. // weekReadReportItem, err := GetWeekMaxReadReportCount(uid)
  274. // if err != nil {
  275. // if err.Error() == utils.ErrNoRow() {
  276. // weekFlag = false
  277. // } else {
  278. // return
  279. // }
  280. // }
  281. // if weekReadReportItem == nil {
  282. // weekFlag = false
  283. // }
  284. //
  285. // if rddpFlag && weekFlag {
  286. // if rddpReadReportItem.Count>weekReadReportItem.Count {
  287. // count=rddpReadReportItem.Count
  288. // createDate=rddpReadReportItem.CreateDate
  289. // }else{
  290. // count=weekReadReportItem.Count
  291. // createDate=weekReadReportItem.CreateDate
  292. // }
  293. // } else {
  294. // if rddpFlag == false && weekFlag {
  295. // count=weekReadReportItem.Count
  296. // createDate=weekReadReportItem.CreateDate
  297. // }
  298. // if rddpFlag && weekFlag == false {
  299. // count=rddpReadReportItem.Count
  300. // createDate=rddpReadReportItem.CreateDate
  301. // }
  302. // }
  303. // return
  304. //}