help_doc.go 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183
  1. package help_doc
  2. import (
  3. "github.com/beego/beego/v2/client/orm"
  4. "github.com/rdlucklib/rdluck_tools/paging"
  5. "time"
  6. )
  7. type HelpDoc struct {
  8. Id int `orm:"column(id);pk"`
  9. ClassifyId int // 分类id
  10. Title string // 标题
  11. Author string // 作者
  12. CreateTime time.Time // 创建时间
  13. ModifyTime time.Time // 修改时间
  14. Status int // 1:未发布,2:已发布
  15. PublishTime time.Time // 发布时间
  16. Content string // 内容
  17. AdminId int // 创建人
  18. AdminRealName string // 创建人姓名
  19. Anchor string // 锚点
  20. Recommend string // 推荐
  21. }
  22. type HelpDocItem struct {
  23. Id int `orm:"column(id);pk"`
  24. ClassifyId int // 分类id
  25. Title string // 标题
  26. Author string // 作者
  27. CreateTime string // 创建时间
  28. ModifyTime string // 修改时间
  29. Status int // 1:未发布,2:已发布
  30. PublishTime string // 发布时间
  31. Content string // 内容
  32. AdminId int // 创建人
  33. AdminRealName string // 创建人姓名
  34. Anchor string // 锚点
  35. Recommend string // 推荐
  36. }
  37. func EditHelpDocClassifyId(classifyId int, classifyName string) (err error) {
  38. o := orm.NewOrm()
  39. sql := `UPDATE help_doc SET classify_name=?,modify_time=NOW() WHERE classify_id=? `
  40. _, err = o.Raw(sql, classifyId, classifyName).Exec()
  41. return
  42. }
  43. type AddHelpDocReq struct {
  44. Id int64 `description:"文章id"`
  45. ClassifyId int `description:"分类id"`
  46. Title string `description:"标题"`
  47. Author string `description:"作者"`
  48. Status int `description:"状态:1:未发布,2:已发布"`
  49. Content string `description:"内容"`
  50. AnchorData []AnchorList
  51. RecommendData []RecommendList
  52. }
  53. type AnchorList struct {
  54. AnchorId string
  55. Anchor string
  56. Child []AnchorList
  57. }
  58. type RecommendList struct {
  59. Name string
  60. Url string
  61. }
  62. func AddHelpDoc(item *HelpDoc) (lastId int64, err error) {
  63. o := orm.NewOrm()
  64. lastId, err = o.Insert(item)
  65. return
  66. }
  67. type EditHelpDocReq struct {
  68. Id int64 `description:"文章id"`
  69. ClassifyId int `description:"分类id"`
  70. Title string `description:"标题"`
  71. Author string `description:"作者"`
  72. Status int `description:"状态:1:未发布,2:已发布"`
  73. Content string `description:"内容"`
  74. AnchorData []AnchorList
  75. RecommendData []RecommendList
  76. }
  77. func EditHelpDoc(item *HelpDoc, reportId int64) (err error) {
  78. o := orm.NewOrmUsingDB("rddp")
  79. sql := `UPDATE help_doc
  80. SET
  81. classify_id =?,
  82. title = ?,
  83. author = ?,
  84. content = ?,
  85. modify_time = ?,
  86. status = ?,
  87. publish_time = ?,
  88. anchor = ?,
  89. recommend = ?
  90. WHERE id = ? `
  91. _, err = o.Raw(sql, item.ClassifyId, item.Title, item.Author, item.Content, item.ModifyTime,
  92. item.Status, item.PublishTime, item.Anchor, item.Recommend, reportId).Exec()
  93. return
  94. }
  95. func GetHelpDocById(docId int) (item *HelpDocItem, err error) {
  96. o := orm.NewOrm()
  97. sql := `SELECT * FROM help_doc WHERE id=?`
  98. err = o.Raw(sql, docId).QueryRow(&item)
  99. return
  100. }
  101. type HelpDocResp struct {
  102. Id int `orm:"column(id);pk"`
  103. ClassifyId int // 分类id
  104. Title string // 标题
  105. Author string // 作者
  106. CreateTime string // 创建时间
  107. ModifyTime string // 修改时间
  108. Status int // 1:未发布,2:已发布
  109. PublishTime string // 发布时间
  110. Content string // 内容
  111. AdminId int // 创建人
  112. AdminRealName string // 创建人姓名
  113. Anchor []AnchorList // 锚点
  114. Recommend []RecommendList // 推荐
  115. }
  116. func GetHelpDocListCount(condition string, pars []interface{}) (count int, err error) {
  117. o := orm.NewOrm()
  118. sql := `SELECT COUNT(1) AS count FROM help_doc WHERE 1=1 `
  119. if condition != "" {
  120. sql += condition
  121. }
  122. err = o.Raw(sql, pars).QueryRow(&count)
  123. return
  124. }
  125. func GetHelpDocList(condition string, pars []interface{}, startSize, pageSize int) (items []*HelpDocItem, err error) {
  126. o := orm.NewOrm()
  127. sql := `SELECT * FROM help_doc WHERE 1=1 `
  128. if condition != "" {
  129. sql += condition
  130. }
  131. sql += `ORDER BY modify_time DESC LIMIT ?,?`
  132. _, err = o.Raw(sql, pars, startSize, pageSize).QueryRows(&items)
  133. return
  134. }
  135. type HelpDocListResp struct {
  136. List []*HelpDocResp
  137. ClassifyName string
  138. Paging *paging.PagingItem `description:"分页数据"`
  139. }
  140. type PublishReq struct {
  141. DocId int
  142. Status int `description:"状态:1:未发布,2:已发布"`
  143. }
  144. // 发布报告
  145. func PublishHelpDocById(reportId, status int) (err error) {
  146. o := orm.NewOrm()
  147. sql := ``
  148. if status == 1{
  149. sql = `UPDATE help_doc SET status=1,publish_time=NULL,modify_time=NOW() WHERE id = ? `
  150. } else {
  151. sql = `UPDATE help_doc SET status=2,publish_time=now(),modify_time=NOW() WHERE id = ? `
  152. }
  153. _, err = o.Raw(sql, reportId).Exec()
  154. return
  155. }
  156. type DeleteReq struct {
  157. DocId int `description:"id"`
  158. }
  159. func DeleteHelpDoc(reportIds int) (err error) {
  160. o := orm.NewOrm()
  161. sql := ` DELETE FROM help_doc WHERE id =? `
  162. _, err = o.Raw(sql, reportIds).Exec()
  163. return
  164. }