report_approve_node.go 9.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245
  1. package report_approve
  2. import (
  3. "eta/eta_api/utils"
  4. "fmt"
  5. "github.com/beego/beego/v2/client/orm"
  6. "strings"
  7. "time"
  8. )
  9. const (
  10. NodeApproveTypeRoll = iota + 1
  11. NodeApproveTypeAll
  12. NodeApproveTypeAny
  13. )
  14. // ReportApproveNode 报告审批节点表
  15. type ReportApproveNode struct {
  16. ReportApproveNodeId int `orm:"column(report_approve_node_id);pk" description:"报告审批节点ID"`
  17. ReportApproveFlowId int `description:"报告审批流ID"`
  18. PrevNodeId int `description:"上一个节点ID(0为开始节点)"`
  19. NextNodeId int `description:"下一个节点ID(0为结束节点)"`
  20. NodeType int `description:"节点类型:0-审批;1-抄送"`
  21. ApproveType int `description:"审批类型:1-依次审批;2-会签;3-或签"`
  22. users string `description:"审批人信息-JSON,user_type:user-用户;role-角色,user_id:用户/角色ID"`
  23. CurrVersion int `description:"当前版本号"`
  24. CreateTime time.Time `description:"创建时间"`
  25. }
  26. func (m *ReportApproveNode) TableName() string {
  27. return "report_approve_node"
  28. }
  29. func (m *ReportApproveNode) PrimaryId() string {
  30. return "report_approve_node_id"
  31. }
  32. func (m *ReportApproveNode) Create() (err error) {
  33. o := orm.NewOrmUsingDB("rddp")
  34. id, err := o.Insert(m)
  35. if err != nil {
  36. return
  37. }
  38. m.ReportApproveNodeId = int(id)
  39. return
  40. }
  41. func (m *ReportApproveNode) CreateMulti(items []*ReportApproveNode) (err error) {
  42. if len(items) == 0 {
  43. return
  44. }
  45. o := orm.NewOrmUsingDB("rddp")
  46. _, err = o.InsertMulti(len(items), items)
  47. return
  48. }
  49. func (m *ReportApproveNode) Update(cols []string) (err error) {
  50. o := orm.NewOrmUsingDB("rddp")
  51. _, err = o.Update(m, cols...)
  52. return
  53. }
  54. func (m *ReportApproveNode) Del() (err error) {
  55. o := orm.NewOrmUsingDB("rddp")
  56. sql := fmt.Sprintf(`DELETE FROM %s WHERE %s = ? LIMIT 1`, m.TableName(), m.PrimaryId())
  57. _, err = o.Raw(sql, m.ReportApproveNodeId).Exec()
  58. return
  59. }
  60. func (m *ReportApproveNode) MultiDel(menuIds []int) (err error) {
  61. if len(menuIds) == 0 {
  62. return
  63. }
  64. o := orm.NewOrmUsingDB("rddp")
  65. sql := fmt.Sprintf(`DELETE FROM %s WHERE %s IN (%s)`, m.TableName(), m.PrimaryId(), utils.GetOrmInReplace(len(menuIds)))
  66. _, err = o.Raw(sql, menuIds).Exec()
  67. return
  68. }
  69. func (m *ReportApproveNode) GetItemById(id int) (item *ReportApproveNode, err error) {
  70. o := orm.NewOrmUsingDB("rddp")
  71. sql := fmt.Sprintf(`SELECT * FROM %s WHERE %s = ? LIMIT 1`, m.TableName(), m.PrimaryId())
  72. err = o.Raw(sql, id).QueryRow(&item)
  73. return
  74. }
  75. func (m *ReportApproveNode) GetItemByCondition(condition string, pars []interface{}, orderRule string) (item *ReportApproveNode, err error) {
  76. o := orm.NewOrmUsingDB("rddp")
  77. order := ``
  78. if orderRule != "" {
  79. order = ` ORDER BY ` + orderRule
  80. }
  81. sql := fmt.Sprintf(`SELECT * FROM %s WHERE 1=1 %s %s LIMIT 1`, m.TableName(), condition, order)
  82. err = o.Raw(sql, pars).QueryRow(&item)
  83. return
  84. }
  85. func (m *ReportApproveNode) GetCountByCondition(condition string, pars []interface{}) (count int, err error) {
  86. o := orm.NewOrmUsingDB("rddp")
  87. sql := fmt.Sprintf(`SELECT COUNT(1) FROM %s WHERE 1=1 %s`, m.TableName(), condition)
  88. err = o.Raw(sql, pars).QueryRow(&count)
  89. return
  90. }
  91. func (m *ReportApproveNode) GetItemsByCondition(condition string, pars []interface{}, fieldArr []string, orderRule string) (items []*ReportApproveNode, err error) {
  92. o := orm.NewOrmUsingDB("rddp")
  93. fields := strings.Join(fieldArr, ",")
  94. if len(fieldArr) == 0 {
  95. fields = `*`
  96. }
  97. order := `ORDER BY create_time DESC`
  98. if orderRule != "" {
  99. order = ` ORDER BY ` + orderRule
  100. }
  101. sql := fmt.Sprintf(`SELECT %s FROM %s WHERE 1=1 %s %s`, fields, m.TableName(), condition, order)
  102. _, err = o.Raw(sql, pars).QueryRows(&items)
  103. return
  104. }
  105. func (m *ReportApproveNode) GetPageItemsByCondition(condition string, pars []interface{}, fieldArr []string, orderRule string, startSize, pageSize int) (items []*ReportApproveNode, err error) {
  106. o := orm.NewOrmUsingDB("rddp")
  107. fields := strings.Join(fieldArr, ",")
  108. if len(fieldArr) == 0 {
  109. fields = `*`
  110. }
  111. order := `ORDER BY create_time DESC`
  112. if orderRule != "" {
  113. order = ` ORDER BY ` + orderRule
  114. }
  115. sql := fmt.Sprintf(`SELECT %s FROM %s WHERE 1=1 %s %s LIMIT ?,?`, fields, m.TableName(), condition, order)
  116. _, err = o.Raw(sql, pars, startSize, pageSize).QueryRows(&items)
  117. return
  118. }
  119. // ReportApproveNodeItem 报告审批节点信息
  120. type ReportApproveNodeItem struct {
  121. ReportApproveNodeId int `orm:"column(report_approve_node_id);pk" description:"报告审批节点ID"`
  122. ReportApproveFlowId int `description:"报告审批流ID"`
  123. PrevNodeId int `description:"上一个节点ID(0为开始节点)"`
  124. NextNodeId int `description:"下一个节点ID(0为结束节点)"`
  125. NodeType int `description:"节点类型:0-审批;1-抄送"`
  126. ApproveType int `description:"审批类型:1-依次审批;2-会签;3-或签"`
  127. users string `description:"审批人信息-JSON,user_type:user-用户;role-角色,user_id:用户/角色ID"`
  128. CurrVersion int `description:"当前版本号"`
  129. CreateTime string `description:"创建时间"`
  130. }
  131. // FormatReportApproveNode2Item 格式化报告审批节点
  132. func FormatReportApproveNode2Item(origin *ReportApproveNode) (item *ReportApproveNodeItem) {
  133. item = new(ReportApproveNodeItem)
  134. if origin == nil {
  135. return
  136. }
  137. item.ReportApproveNodeId = origin.ReportApproveNodeId
  138. item.CreateTime = utils.TimeTransferString(utils.FormatDateTime, origin.CreateTime)
  139. return
  140. }
  141. // ReportApproveNodeAddReq 新增报告审批节点请求体
  142. type ReportApproveNodeAddReq struct {
  143. FlowName string `description:"审批流名称"`
  144. ReportType int `description:"报告类型:1-中文研报;2-英文研报;3-智能研报"`
  145. ClassifyFirstId int `description:"一级分类ID"`
  146. ClassifySecondId int `description:"二级分类ID"`
  147. }
  148. //
  149. //// ReportApproveNodeEditReq 编辑报告审批节点请求体
  150. //type ReportApproveNodeEditReq struct {
  151. // ReportApproveNodeAddReq
  152. // ReportApproveNodeId int `description:"报告审批节点ID"`
  153. // Content string `description:"内容"`
  154. // ContentStruct string `description:"内容结构"`
  155. //}
  156. //
  157. //// ReportApproveNodeRemoveReq 删除报告审批节点请求体
  158. //type ReportApproveNodeRemoveReq struct {
  159. // ReportApproveNodeId int `description:"报告审批节点ID"`
  160. //}
  161. //
  162. //// ReportApproveNodePublishReq 发布报告审批节点请求体
  163. //type ReportApproveNodePublishReq struct {
  164. // ReportApproveNodeId int `description:"报告审批节点ID"`
  165. // PublishState int `description:"1-取消发布; 2-发布"`
  166. //}
  167. //
  168. //// ReportApproveNodePrePublishReq 预发布报告审批节点请求体
  169. //type ReportApproveNodePrePublishReq struct {
  170. // ReportApproveNodeId int `description:"报告审批节点ID"`
  171. // PrePublishTime string `description:"预发布时间"`
  172. // PreMsgSend int `description:"定时发布成功后是否立即推送模版消息:0否,1是"`
  173. //}
  174. //
  175. //// ReportApproveNodeSaveContentReq 保存草稿请求体
  176. //type ReportApproveNodeSaveContentReq struct {
  177. // ReportApproveNodeId int `description:"报告审批节点ID"`
  178. // Content string `description:"内容"`
  179. // ContentStruct string `description:"内容结构"`
  180. // NoChange int `description:"内容是否未改变:1:内容未改变"`
  181. //}
  182. //
  183. //// ReportApproveNodeSaveContentResp 保存草稿响应体
  184. //type ReportApproveNodeSaveContentResp struct {
  185. // ReportApproveNodeId int `description:"报告审批节点ID"`
  186. //}
  187. //
  188. //// ReportApproveNodeSendMsgReq 消息推送请求体
  189. //type ReportApproveNodeSendMsgReq struct {
  190. // ReportApproveNodeId int `description:"报告审批节点ID"`
  191. //}
  192. //
  193. //// ReportApproveNodeMarkEditReq 标记编辑英文研报的请求数据
  194. //type ReportApproveNodeMarkEditReq struct {
  195. // ReportApproveNodeId int `description:"报告审批节点ID"`
  196. // Status int `description:"标记状态: 1-编辑中; 2-编辑完成"`
  197. //}
  198. //
  199. //// ReportApproveNodeListResp 报告审批节点
  200. //type ReportApproveNodeListResp struct {
  201. // List []*ReportApproveNodeItem
  202. // Paging *paging.PagingItem `description:"分页数据"`
  203. //}
  204. //
  205. //// ElasticReportApproveNode 报告审批节点es
  206. //type ElasticReportApproveNode struct {
  207. // ReportApproveNodeId int `description:"报告审批节点ID"`
  208. // Title string `description:"标题"`
  209. // Abstract string `description:"摘要"`
  210. // BodyContent string `description:"内容"`
  211. // PublishTime string `description:"发布时间"`
  212. // PublishState int `description:"发布状态 1-未发布 2-已发布"`
  213. // Author string `description:"作者"`
  214. // ClassifyIdFirst int `description:"一级分类ID"`
  215. // ClassifyNameFirst string `description:"一级分类名称"`
  216. // ClassifyIdSecond int `description:"二级分类ID"`
  217. // ClassifyNameSecond string `description:"二级分类名称"`
  218. // StageStr string `description:"报告期数"`
  219. // Frequency string `description:"频度"`
  220. //}
  221. //
  222. //// Report2ImgQueueReq 报告详情生成长图队列请求体
  223. //type Report2ImgQueueReq struct {
  224. // ReportType int `description:"报告类型: 1-研报; 2-报告审批节点"`
  225. // ReportCode string `description:"报告唯一编码"`
  226. //}