cygx_activity.go 9.2 KB

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