cygx_activity.go 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255
  1. package cygx_activity
  2. import (
  3. "github.com/beego/beego/v2/client/orm"
  4. "time"
  5. )
  6. // 活动详情
  7. type CygxActivity struct {
  8. ActivityId int `orm:"column(activity_id);pk";description:"活动ID 等于0新增活动,大于0修改活动"`
  9. ActivityTypeId int `description:"活动类型id"`
  10. ActivityTypeName string `description:"活动类型名称"`
  11. ChartPermissionId int `description:"行业id"`
  12. ChartPermissionName string `description:"行业名称"`
  13. ChartPermissionNames string `description:"行业名称辅助字段,区分研选子分类"`
  14. Body string `description:"内容"`
  15. CreateTime time.Time `description:"创建时间"`
  16. IsLimitPeople int `description:"是否限制人数 1是,0否"`
  17. LimitPeopleNum int `description:"限制的人数数量"`
  18. CustomerTypeIds string `description:"活动可见的客户类型,多个ID用 , 隔开"`
  19. PublishStatus int `description:"发布状态 1已发布,0未发布"`
  20. LastUpdatedTime time.Time `description:"更新时间"`
  21. ActivityTime string `description:"活动时间"`
  22. ActivityTimeText string `description:"活动时间带文字"`
  23. DistinguishedGuest string `description:"嘉宾"`
  24. Host string `description:"主持人"`
  25. MainlandTell string `description:"大陆拨入号"`
  26. HongKongTell string `description:"香港拨入号"`
  27. TaiwanTell string `description:"台湾拨入号"`
  28. AmericaTell string `description:"美国拨入号"`
  29. ParticipationCode string `description:"参会密码"`
  30. Theme string `description:"主题"`
  31. Expert string `description:"专家"`
  32. ActivityName string `description:"活动名称"`
  33. ActivityNameTask string `description:"活动名称定时任务同步的时候使用"`
  34. OnlineParticipation string `description:"网络参会"`
  35. ReportLink string `description:"报告链接"`
  36. City string `description:"城市"`
  37. Address string `description:"活动地址"`
  38. Highlights string `description:"活动亮点"`
  39. Remarks string `description:"备注"`
  40. Speaker string `description:"主讲人"`
  41. ArticleId int `description:"关联报告id"`
  42. Label string `description:"标签"`
  43. LinkParticipants string `description:"链接参会"`
  44. AppAttendance string `description:"App参会"`
  45. ConferencePassword string `description:"会议密码"`
  46. TemporaryLabel string `description:"临时标签"`
  47. IsMakerShow int `description:"是否仅决策人可见 0,否 、1,是"`
  48. VisibleRange int `description:"可见范围 1,仅本组可见 、2,全部客户可见"`
  49. Scale string `description:"管理规模,空不填,1::50亿以下,2:50~100亿,3:100亿以上。多个用, 隔开"`
  50. IsShowSubjectName int `description:"小程序内是否展示标的名称 1是 ,0 否 默认0 "`
  51. IsHideAppointment int `description:"是否隐藏预约纪要按钮 1是 ,0 否 默认0 "`
  52. AdminId int `description:"销售/管理员ID"`
  53. AdminName string `description:"销售/管理员姓名"`
  54. }
  55. type CygxActivitySignup struct {
  56. Id int `orm:"column(id)" description:"自增Id"`
  57. UserId int `description:"用户id,多个用,隔开"`
  58. ActivityId int `description:"活动ID"`
  59. CreateTime time.Time `description:"创建时间"`
  60. Mobile string `description:"手机号"`
  61. Email string `description:"邮箱号"`
  62. CompanyId int `description:"公司ID"`
  63. CompanyName string `description:"公司名称"`
  64. OutboundMobile string `description:"外呼手机号"`
  65. CountryCode string `description:"手机国家区号"`
  66. Source int `description:"来源,1小程序,2后台添加"`
  67. SignupType int `description:"报名方式,1预约外呼,2自主拨入,3我要报名"`
  68. RealName string `description:"用户实际名称"`
  69. SellerName string `description:"所属销售"`
  70. YidongExamineStatus int `description:"易董活动报名审核状态0审核中,1:审核通过、2审核不通过"`
  71. }
  72. type CygxYidongActivityExamineStatus struct {
  73. Id int `orm:"column(id)" description:"自增Id"`
  74. ActivityId int `description:"活动ID"`
  75. YidongActivityId string `description:"易董活动ID"`
  76. CreateTime time.Time `description:"创建时间"`
  77. ExamineTime string `description:"审核时间"`
  78. Mobile string `description:"手机号"`
  79. YidongExamineStatus int `description:"易董活动报名审核状态0审核中,1:审核通过、2审核不通过"`
  80. }
  81. // 通过ID获取活动详情
  82. func GetAddActivityInfoById(activityIdYiDong string) (item *CygxActivity, err error) {
  83. o := orm.NewOrmUsingDB("hz_cygx")
  84. sql := `SELECT
  85. a.*
  86. FROM
  87. cygx_activity as a
  88. WHERE
  89. yidong_activity_id =? OR yidong_activity_id_by_cygx = ? LIMIT 1 `
  90. err = o.Raw(sql, activityIdYiDong, activityIdYiDong).QueryRow(&item)
  91. return
  92. }
  93. type ExamineStatusReq struct {
  94. ActivityId int `description:"活动ID"`
  95. Mobile string `description:"手机号" json:"mobile"`
  96. ExamineStatus int `description:"审核状态 1,通过、2:未通过" json:"examine_status"`
  97. }
  98. // UpdateActivitySignupNumMulti 批量修改易董报名用户审核状态
  99. func UpdateActivitySignupNumMulti(items []*ExamineStatusReq) (err error) {
  100. o := orm.NewOrmUsingDB("hz_cygx")
  101. p, err := o.Raw("UPDATE cygx_activity_signup SET yidong_examine_status = ? WHERE mobile = ? AND activity_id = ? ").Prepare()
  102. if err != nil {
  103. return
  104. }
  105. defer func() {
  106. _ = p.Close() // 别忘记关闭 statement
  107. }()
  108. if len(items) > 0 {
  109. for _, v := range items {
  110. _, err = p.Exec(v.ExamineStatus, v.Mobile, v.ActivityId)
  111. if err != nil {
  112. return
  113. }
  114. }
  115. }
  116. return
  117. }
  118. // AddActivitySignupNumMulti 批量新增易董报名用户审核状态
  119. func AddActivitySignupNumMulti(items []*CygxActivitySignup) (err error) {
  120. o := orm.NewOrmUsingDB("hz_cygx")
  121. if len(items) > 0 {
  122. //批量新增易董报名用户审核状态
  123. _, err = o.InsertMulti(len(items), items)
  124. }
  125. return
  126. }
  127. // GetActivitySignupListByActivity获取已经报名了的用户列表
  128. func GetActivitySignupListByActivity(activityId int) (items []*CygxActivitySignup, err error) {
  129. o := orm.NewOrmUsingDB("hz_cygx")
  130. sql := `SELECT * FROM cygx_activity_signup WHERE activity_id = ?`
  131. _, err = o.Raw(sql, activityId).QueryRows(&items)
  132. return
  133. }
  134. type UserAndCompanyName struct {
  135. UserId int `orm:"column(user_id);pk"`
  136. Mobile string
  137. Email string
  138. CompanyId int
  139. CompanyName string `description:"公司名称"`
  140. CountryCode string `description:"手机国家区号"`
  141. OutboundMobile string `description:"外呼手机号"`
  142. OutboundCountryCode string `description:"外呼手机号区号"`
  143. SellerName string `description:"所属销售"`
  144. RealName string `description:"真实姓名"`
  145. }
  146. func GetUserListByMobile(mobile string) (items []*UserAndCompanyName, err error) {
  147. o := orm.NewOrm()
  148. sql := ` SELECT u.*, c.company_name FROM wx_user AS u
  149. INNER JOIN company AS c ON c.company_id = u.company_id
  150. WHERE u.mobile IN (` + mobile + `)`
  151. _, err = o.Raw(sql).QueryRows(&items)
  152. return
  153. }
  154. type CygxYidongActivitySignupLog struct {
  155. Id int `orm:"column(id)" description:"自增Id"`
  156. ActivityId int `description:"活动ID"`
  157. YidongActivityId string `description:"易董活动ID"`
  158. CreateTime time.Time `description:"创建时间"`
  159. Mobile string `description:"手机号"`
  160. }
  161. // AddCygxYidongActivitySignup 记录易董传过来的报名信息
  162. func AddCygxYidongActivitySignupLog(item *CygxYidongActivitySignupLog) (err error) {
  163. o := orm.NewOrmUsingDB("hz_cygx")
  164. _, err = o.Insert(item)
  165. return
  166. }
  167. type CygxYidongActivitySignupReq struct {
  168. RealName string `description:"真实姓名" json:"real_name"`
  169. Mobile string `description:"手机号" json:"mobile"`
  170. CountryCode string `description:"手机国家区号" json:"country_code"`
  171. Email string `description:"手机号" json:"email"`
  172. CompanyName string `description:"公司名称" json:"company_name"`
  173. Job string `description:"职务" json:"job"`
  174. }
  175. // 通过纪要ID获取活动详情
  176. func GetAddActivityInfoByMobile(mobile string) (item *CygxYidongActivitySignupReq, err error) {
  177. o := orm.NewOrm()
  178. sql := ` SELECT u.*, c.company_name FROM wx_user AS u
  179. INNER JOIN company AS c ON c.company_id = u.company_id
  180. WHERE u.mobile = ?`
  181. err = o.Raw(sql, mobile).QueryRow(&item)
  182. return
  183. }
  184. // AddActivityItemsLogNumMulti 记录审核日志
  185. func AddActivityItemsLogNumMulti(items []*CygxYidongActivityExamineStatus) (err error) {
  186. o := orm.NewOrmUsingDB("hz_cygx")
  187. if len(items) > 0 {
  188. //批量添加记录审核日志
  189. _, err = o.InsertMulti(len(items), items)
  190. }
  191. return
  192. }
  193. // 我的日程
  194. type CygxMySchedule struct {
  195. Id int `orm:"column(id);pk"`
  196. ActivityId int `description:"活动ID"`
  197. UserId int `description:"用户ID"`
  198. CreateTime time.Time `description:"创建时间"`
  199. Mobile string `description:"手机号"`
  200. Email string `description:"邮箱"`
  201. CompanyId int `description:"公司id"`
  202. CompanyName string `description:"公司名称"`
  203. }
  204. // GetCygxMyScheduleList 获取我的日程数据
  205. func GetCygxMyScheduleList(activityId int) (items []*CygxMySchedule, err error) {
  206. o := orm.NewOrmUsingDB("hz_cygx")
  207. sql := `SELECT * FROM cygx_my_schedule WHERE activity_id = ?`
  208. _, err = o.Raw(sql, activityId).QueryRows(&items)
  209. return
  210. }
  211. // AddCygxMyScheduleLNumMulti 添加我的日程
  212. func AddCygxMyScheduleLNumMulti(items []*CygxMySchedule) (err error) {
  213. o := orm.NewOrmUsingDB("hz_cygx")
  214. if len(items) > 0 {
  215. //添加我的日程
  216. _, err = o.InsertMulti(len(items), items)
  217. }
  218. return
  219. }
  220. // DelCygxMyScheduleList 删除我的日程
  221. func DelCygxMyScheduleList(mobile string, activityId int) (err error) {
  222. o := orm.NewOrmUsingDB("hz_cygx")
  223. sql := ` DELETE FROM cygx_my_schedule WHERE mobile IN (` + mobile + `) AND activity_id=?`
  224. _, err = o.Raw(sql, activityId).Exec()
  225. return
  226. }
  227. // DelCygxcActivitySignup 删除我的报名信息
  228. func DelCygxcActivitySignup(mobile string, activityId int) (err error) {
  229. o := orm.NewOrmUsingDB("hz_cygx")
  230. sql := ` DELETE FROM cygx_activity_signup WHERE mobile IN (` + mobile + `) AND activity_id=?`
  231. _, err = o.Raw(sql, activityId).Exec()
  232. return
  233. }