cygx_morning_meeting_reviews.go 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172
  1. package cygx
  2. import (
  3. "errors"
  4. "github.com/beego/beego/v2/client/orm"
  5. "github.com/rdlucklib/rdluck_tools/paging"
  6. "time"
  7. )
  8. // CygxMorningMeetingReviews [...]
  9. type CygxMorningMeetingReviews struct {
  10. Id int `orm:"column(id);pk"`
  11. MeetingTime time.Time `json:"meetingTime"` // 晨会日期
  12. PublishTime time.Time `json:"publishTime"` // 发布日期
  13. CreateTime time.Time `json:"createTime"`
  14. ModifyTime time.Time `json:"modifyTime"`
  15. Status int `json:"status"` // 0:未发布,1:已发布
  16. PartNums int `json:"partNums"` // 段落数
  17. IndustryNames string `json:"industryName"` // 产业名称
  18. OpUserId int `description:"操作人编号"`
  19. OpUserName string `description:"操作人名称"`
  20. }
  21. // 添加晨报点评
  22. func AddCygxMorningMeetingReviews(item *CygxMorningMeetingReviews) (id int64, err error) {
  23. o := orm.NewOrmUsingDB("hz_cygx")
  24. id, err = o.Insert(item)
  25. return
  26. }
  27. // 列表
  28. func GetCygxMorningMeetingReviewsList(condition string, pars []interface{}, startSize, pageSize int) (items []*CygxMorningMeetingReviews, err error) {
  29. o := orm.NewOrmUsingDB("hz_cygx")
  30. sql := `SELECT * FROM cygx_morning_meeting_reviews WHERE 1=1 `
  31. if condition != "" {
  32. sql += condition
  33. }
  34. sql += ` LIMIT ?,? `
  35. _, err = o.Raw(sql, pars, startSize, pageSize).QueryRows(&items)
  36. return
  37. }
  38. func GetCygxMorningMeetingReviewsListCount(condition string, pars []interface{}) (count int, err error) {
  39. o := orm.NewOrmUsingDB("hz_cygx")
  40. sql := `SELECT COUNT(1) AS count FROM cygx_morning_meeting_reviews WHERE 1=1 `
  41. if condition != "" {
  42. sql += condition
  43. }
  44. err = o.Raw(sql, pars).QueryRow(&count)
  45. return
  46. }
  47. type CygxMorningMeetingReviewItem struct {
  48. Id int `orm:"column(id);pk"`
  49. MeetingTime string `json:"meetingTime"` // 晨会日期
  50. PublishTime string `json:"publishTime"` // 发布日期
  51. CreateTime string `json:"createTime"`
  52. ModifyTime string `json:"modifyTime"`
  53. Status int `json:"status"` // 0:未发布,1:已发布
  54. PartNums int `json:"partNums"` // 段落数
  55. IndustryNames string `json:"industryName"` // 产业名称
  56. Pv int `description:"PV"`
  57. Uv int `description:"UV"`
  58. OpUserName string `description:"操作人名称"`
  59. }
  60. type CygxMorningMeetingReviewsList struct {
  61. List []*CygxMorningMeetingReviewItem
  62. Paging *paging.PagingItem `description:"分页数据"`
  63. }
  64. func GetMorningMeetingReviewById(reviewId int) (item *CygxMorningMeetingReviews, err error) {
  65. o := orm.NewOrmUsingDB("hz_cygx")
  66. sql := `SELECT * FROM cygx_morning_meeting_reviews WHERE id=?`
  67. err = o.Raw(sql, reviewId).QueryRow(&item)
  68. return
  69. }
  70. // 发布报告
  71. func PublishMorningMeetingReviewById(reviewId int) (err error) {
  72. o := orm.NewOrmUsingDB("hz_cygx")
  73. sql := `UPDATE cygx_morning_meeting_reviews SET status=1,publish_time=now(),modify_time=NOW() WHERE id = ? `
  74. _, err = o.Raw(sql, reviewId).Exec()
  75. return
  76. }
  77. // 发布报告
  78. func UpdateMorningMeetingReviewStatusById(status, reviewId int) (err error) {
  79. o := orm.NewOrmUsingDB("hz_cygx")
  80. sql := `UPDATE cygx_morning_meeting_reviews SET status= ?,publish_time=now(),modify_time=NOW() WHERE id = ? `
  81. _, err = o.Raw(sql, status, reviewId).Exec()
  82. return
  83. }
  84. type MorningReviewPublishReq struct {
  85. ReviewIds string `description:"晨会id,多个用英文逗号隔开"`
  86. }
  87. type MorningReviewPublishCancelReq struct {
  88. ReviewId int `description:"晨会id"`
  89. }
  90. type MorningReviewApproveSubmiteq struct {
  91. ReviewId int `description:"晨会id"`
  92. Status int `description:"0:未发布,1:已发布,2:待审核、3:已驳回、4:已撤回、5:未提交"`
  93. }
  94. // 取消发布报告
  95. func PublishCancelMorningMeetingReview(reviewId int) (err error) {
  96. o := orm.NewOrmUsingDB("hz_cygx")
  97. sql := ` UPDATE cygx_morning_meeting_reviews SET status=0,publish_time=null WHERE id =? `
  98. _, err = o.Raw(sql, reviewId).Exec()
  99. return
  100. }
  101. type MorningReviewDeleteReq struct {
  102. ReviewId int `description:"晨会id"`
  103. }
  104. // DeleteMorningReviewAndChapter 删除晨会点评及章节
  105. func DeleteMorningReviewAndChapter(reviewId int) (err error) {
  106. reviewInfo, err := GetMorningMeetingReviewById(reviewId)
  107. if err != nil {
  108. err = errors.New("报告信息有误, Err: " + err.Error())
  109. return
  110. }
  111. if reviewInfo.Status == 1 {
  112. err = errors.New("报告已发布,不可删除")
  113. return
  114. }
  115. err = DeleteMorningMeeting(reviewId)
  116. if err != nil {
  117. err = errors.New("删除失败, Err: " + err.Error())
  118. return
  119. }
  120. err = DeleteMorningMeetingChapter(reviewId)
  121. if err != nil {
  122. err = errors.New("删除失败, Err: " + err.Error())
  123. return
  124. }
  125. return
  126. }
  127. // 删除晨会点评
  128. func DeleteMorningMeeting(reviewId int) (err error) {
  129. o := orm.NewOrmUsingDB("hz_cygx")
  130. sql := ` DELETE FROM cygx_morning_meeting_reviews WHERE id =? `
  131. _, err = o.Raw(sql, reviewId).Exec()
  132. return
  133. }
  134. // 更新晨报点评
  135. func UpdateCygxMorningMeetingReviews(item *CygxMorningMeetingReviews) (err error) {
  136. o := orm.NewOrmUsingDB("hz_cygx")
  137. sql := `UPDATE cygx_morning_meeting_reviews
  138. SET
  139. meeting_time =?,
  140. publish_time = ?,
  141. modify_time = ?,
  142. part_nums = ?,
  143. industry_names = ?,
  144. op_user_id = ?,
  145. op_user_name = ?,
  146. status = ?
  147. WHERE id = ? `
  148. _, err = o.Raw(sql, item.MeetingTime, item.PublishTime, item.ModifyTime, item.PartNums, item.IndustryNames, item.OpUserId, item.OpUserName, item.Status, item.Id).Exec()
  149. return
  150. }