activity_special_trip.go 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446
  1. package services
  2. import (
  3. "errors"
  4. "fmt"
  5. "hongze/hongze_cygx/models"
  6. "hongze/hongze_cygx/models/company"
  7. "hongze/hongze_cygx/utils"
  8. "strconv"
  9. "strings"
  10. "time"
  11. )
  12. func SpecialTripPopupMsg(activityInfo *models.CygxActivitySpecialDetail, user *models.WxUserItem) (signupStatus int, popupMsg, popupMsg2 string, err error) {
  13. //SignupStatus int `description:"返回状态:1:成功 、2 :人数已满 、3:调研次数已用完、 4:超时"`
  14. signupStatus = 1
  15. resultTime := utils.StrTimeToTime(activityInfo.ActivityTime) //时间字符串格式转时间格式
  16. if time.Now().After(resultTime.Add(-time.Minute * 60)) {
  17. signupStatus = 4
  18. popupMsg = "活动开始前1小时内无法报名,请联系对口销售处理"
  19. return
  20. }
  21. errMsg, e := CheckTripRemainingtimesBycompany(user, activityInfo)
  22. if e != nil {
  23. err = errors.New("获取客户剩余报名次数失败 GetActivitySpecialUserType, Err: " + e.Error())
  24. return
  25. }
  26. if errMsg != "" {
  27. popupMsg = errMsg
  28. signupStatus = 3
  29. return
  30. }
  31. var condition string
  32. var pars []interface{}
  33. condition += ` AND activity_id = ? AND is_cancel = 0 `
  34. pars = append(pars, activityInfo.ActivityId)
  35. tripTota, e := models.GetActivitySpecialTripCountByActivityId(condition, pars)
  36. if e != nil {
  37. err = errors.New("GetCygxActivitySpecialDetailList, Err: " + e.Error())
  38. return
  39. }
  40. if activityInfo.LimitPeopleNum-tripTota < 1 {
  41. signupStatus = 2
  42. popupMsg = "此活动报名人数已满,请留意下期活动"
  43. return
  44. }
  45. //signupStatus = 4
  46. popupMsg = "感谢参与,本次报名会扣除一次贵司在弘则的调研点数。"
  47. popupMsg2 = "由于每场活动人数有限,如果不能参加请提前48小时取消,未及时取消导致影响其他客户报名将会维持扣点。"
  48. return
  49. }
  50. // 校验是否还有剩余次数
  51. func CheckTripRemainingtimesBycompany(user *models.WxUserItem, activityInfo *models.CygxActivitySpecialDetail) (errMsg string, err error) {
  52. msgTemplate := "您的专项调研次数已用完,如仍想参加,请与您的对口销售商议"
  53. companyId := user.CompanyId
  54. chartPermissionName := activityInfo.ChartPermissionName
  55. companyDetail, e := models.GetCompanyDetailByIdGroup(companyId)
  56. if e != nil {
  57. err = errors.New("GetCompanyDetailByIdGroup, Err:" + e.Error())
  58. return
  59. }
  60. //永续客户不限制次数
  61. if companyDetail.Status == utils.COMPANY_STATUS_FOREVER {
  62. return
  63. }
  64. var condition string
  65. var pars []interface{}
  66. condition = " AND company_id = ? AND points > 0 ORDER BY chart_permission_id DESC "
  67. pars = append(pars, companyId)
  68. activitySpecialPermissionPointsList, e := models.GetCygxActivitySpecialPermissionPointsList(condition, pars)
  69. if e != nil && e.Error() != utils.ErrNoRow() {
  70. err = errors.New("GetCygxActivitySpecialPermissionPointsList, Err:" + e.Error())
  71. return
  72. }
  73. //如果没有剩余的点数,就返回
  74. if len(activitySpecialPermissionPointsList) == 0 {
  75. errMsg = msgTemplate
  76. return
  77. }
  78. //判断是不是策略行业的活动,策略的任何一个行业有剩余点数都能参加
  79. //if chartPermissionName == utils.CE_LUE_NAME {
  80. if utils.InArrayByStr(utils.ACTIVITY_SPECIAL_TRIP_PERMISSION_NAME_OTHER, activityInfo.ChartPermissionName) {
  81. return
  82. } else {
  83. for _, v := range activitySpecialPermissionPointsList {
  84. if v.ChartPermissionName == chartPermissionName || v.ChartPermissionId == 0 {
  85. return
  86. } // 如果对应行业有剩余次数,或者是属于大套餐且有次数,那么校验也通过
  87. }
  88. }
  89. return
  90. }
  91. // GetSpecialBillMaxChartPermissionId 获取专项调研剩余点数最多的行业
  92. func GetSpecialBillMaxChartPermissionId(user *models.WxUserItem) (maxChartPermissionId int, maxChartPermissionName string, err error) {
  93. companyId := user.CompanyId
  94. var condition string
  95. var pars []interface{}
  96. condition = " AND company_id = ? AND points > 0 ORDER BY points DESC LIMIT 1 "
  97. pars = append(pars, companyId)
  98. activitySpecialPermissionPointsList, e := models.GetCygxActivitySpecialPermissionPointsList(condition, pars)
  99. if e != nil && e.Error() != utils.ErrNoRow() {
  100. err = errors.New("GetCygxActivitySpecialPermissionPointsList, Err:" + e.Error())
  101. return
  102. }
  103. for _, v := range activitySpecialPermissionPointsList {
  104. maxChartPermissionId = v.ChartPermissionId
  105. maxChartPermissionName = v.ChartPermissionName
  106. }
  107. return
  108. }
  109. // DeductTripRemainingtimesByUser 扣除用户专项调研剩余次数
  110. func DeductTripRemainingtimesByUser(user *models.WxUserItem, activityInfo *models.CygxActivitySpecialDetail) (err error) {
  111. msgTemplate := "您的专项调研次数已用完,如仍想参加,请与您的对口销售商议"
  112. companyId := user.CompanyId
  113. //chartPermissionName := activityInfo.ChartPermissionName
  114. companyProduct, e := company.GetCompanyProductByCompanyIdAndProductId(companyId, utils.COMPANY_PRODUCT_RAI_ID)
  115. if e != nil {
  116. err = errors.New("GetCompanyProductByCompanyIdAndProductId, Err:" + e.Error())
  117. return
  118. }
  119. var condition string
  120. var pars []interface{}
  121. var maxChartPermissionId int // 剩余点数最多的行业
  122. var points float64 // 剩余点数
  123. var activitySpecialPermissionPointsList []*models.CygxActivitySpecialPermissionPoints
  124. //永续客户不限次数需要单独处理
  125. if companyProduct.Status == utils.COMPANY_STATUS_FOREVER {
  126. condition = " AND company_id = ? ORDER BY points DESC LIMIT 1 "
  127. pars = append(pars, companyId)
  128. activitySpecialPermissionPointsList, e = models.GetCygxActivitySpecialPermissionPointsList(condition, pars)
  129. if e != nil && e.Error() != utils.ErrNoRow() {
  130. err = errors.New("GetCygxActivitySpecialPermissionPointsList, Err:" + e.Error())
  131. return
  132. }
  133. //如果永续客户不存在单独的行业剩余点数记录,那么就添加一条 -1 的记录作为初始化数据
  134. if len(activitySpecialPermissionPointsList) == 0 {
  135. item := new(models.CygxActivitySpecialPermissionPoints)
  136. item.CompanyId = companyProduct.CompanyId
  137. item.Points = -1
  138. item.CompanyName = companyProduct.CompanyName
  139. //item.ChartPermissionId = activityInfo.ChartPermissionId
  140. //item.ChartPermissionName = activityInfo.ChartPermissionName
  141. item.CreateTime = time.Now()
  142. item.ModifyTime = time.Now()
  143. e = models.AddCygxActivitySpecialPermissionPoints(item)
  144. if e != nil {
  145. err = errors.New("AddCygxActivitySpecialPermissionPoints, Err:" + e.Error())
  146. return
  147. }
  148. return
  149. }
  150. } else {
  151. condition = " AND company_id = ? AND points > 0 ORDER BY points DESC LIMIT 1 "
  152. pars = append(pars, companyId)
  153. //判断是不是策略、固收、周期行业的活动,如果不是策略就获取对应行业的点数 ,策略的任何一个行业有剩余点数都能参加
  154. //if chartPermissionName != utils.CE_LUE_NAME && chartPermissionName != utils.GU_SHOU_NAME {
  155. if !utils.InArrayByStr(utils.ACTIVITY_SPECIAL_TRIP_PERMISSION_NAME_OTHER, activityInfo.ChartPermissionName) {
  156. pars = make([]interface{}, 0)
  157. condition = " AND company_id = ? AND ( chart_permission_id = ? OR chart_permission_id =0 ) AND points > 0 ORDER BY points DESC LIMIT 1 "
  158. pars = append(pars, companyId, activityInfo.ChartPermissionId)
  159. }
  160. activitySpecialPermissionPointsList, e = models.GetCygxActivitySpecialPermissionPointsList(condition, pars)
  161. if e != nil && e.Error() != utils.ErrNoRow() {
  162. err = errors.New("GetCygxActivitySpecialPermissionPointsList, Err:" + e.Error())
  163. return
  164. }
  165. }
  166. //如果没有剩余的点数,就返回
  167. if len(activitySpecialPermissionPointsList) == 0 {
  168. err = errors.New(msgTemplate)
  169. return
  170. }
  171. for _, v := range activitySpecialPermissionPointsList {
  172. maxChartPermissionId = v.ChartPermissionId
  173. points = v.Points - 1
  174. }
  175. //更新对应行业剩余点数
  176. e = models.UpdateCygxActivitySpecialPermissionPoints(points, companyId, maxChartPermissionId)
  177. if e != nil {
  178. err = errors.New("UpdateCygxActivitySpecialPermissionPoints, Err:" + e.Error())
  179. return
  180. }
  181. return
  182. }
  183. // RebateTripRemainingtimesByUser 返点用户专项调研剩余次数
  184. func RebateTripRemainingtimesByUser(user *models.WxUserItem, activityInfo *models.CygxActivitySpecialDetail) (err error) {
  185. companyId := user.CompanyId
  186. //chartPermissionName := activityInfo.ChartPermissionName
  187. var condition string
  188. var pars []interface{}
  189. condition = " AND company_id = ? ORDER BY points DESC LIMIT 1 "
  190. pars = append(pars, companyId)
  191. //判断是不是策略、固收、周期行业的活动,如果不是策略就获取对应行业的点数 ,策略的任何一个行业有剩余点数都能参加
  192. //if chartPermissionName != utils.CE_LUE_NAME && chartPermissionName != utils.GU_SHOU_NAME {
  193. if !utils.InArrayByStr(utils.ACTIVITY_SPECIAL_TRIP_PERMISSION_NAME_OTHER, activityInfo.ChartPermissionName) {
  194. pars = make([]interface{}, 0)
  195. condition = " AND company_id = ? AND (chart_permission_id = ? OR chart_permission_id = 0 ) LIMIT 1 "
  196. pars = append(pars, companyId, activityInfo.ChartPermissionId)
  197. } else {
  198. lastTripBill, e := models.GetCygxActivitySpecialTripBillLastDetialByActivityId(activityInfo.ActivityId, user.UserId)
  199. if e != nil {
  200. err = errors.New("GetActivitySpecialTripCountByActivitySpecial, Err: " + e.Error())
  201. return
  202. }
  203. pars = make([]interface{}, 0)
  204. condition = " AND company_id = ? AND (chart_permission_id = ? OR chart_permission_id = 0 ) LIMIT 1 "
  205. pars = append(pars, companyId, lastTripBill.ChartPermissionId)
  206. }
  207. activitySpecialPermissionPointsList, e := models.GetCygxActivitySpecialPermissionPointsList(condition, pars)
  208. if e != nil && e.Error() != utils.ErrNoRow() {
  209. err = errors.New("GetCygxActivitySpecialPermissionPointsList, Err:" + e.Error())
  210. return
  211. }
  212. var maxChartPermissionId int // 剩余点数最多的行业(返点行业)
  213. var points float64 // 剩余点数
  214. for _, v := range activitySpecialPermissionPointsList {
  215. maxChartPermissionId = v.ChartPermissionId
  216. points = v.Points + 1
  217. }
  218. //更新对应行业剩余点数
  219. e = models.UpdateCygxActivitySpecialPermissionPoints(points, companyId, maxChartPermissionId)
  220. if e != nil {
  221. err = errors.New("UpdateCygxActivitySpecialPermissionPoints, Err:" + e.Error())
  222. return
  223. }
  224. return
  225. }
  226. // 预处理专项调研流水明细表描述内容
  227. func HandleActivitySpecialTripBillTotalText(companyId int) (totalText string, err error) {
  228. //companyId := user.CompanyId
  229. companyDetail, e := models.GetCompanyDetailByIdGroup(companyId)
  230. if e != nil {
  231. err = errors.New("GetCompanyDetailByIdGroup, Err:" + e.Error())
  232. return
  233. }
  234. var condition string
  235. var pars []interface{}
  236. pars = make([]interface{}, 0)
  237. condition = " AND company_id = ? AND points != 0 ORDER BY chart_permission_id DESC "
  238. pars = append(pars, companyId)
  239. activitySpecialPermissionPointsList, e := models.GetCygxActivitySpecialPermissionPointsList(condition, pars)
  240. if e != nil && e.Error() != utils.ErrNoRow() {
  241. err = errors.New("GetCygxActivitySpecialPermissionPointsList, Err:" + e.Error())
  242. return
  243. }
  244. //永续客户次数累加
  245. if companyDetail.Status == utils.COMPANY_STATUS_FOREVER {
  246. var points float64
  247. for _, v := range activitySpecialPermissionPointsList {
  248. points += v.Points
  249. }
  250. totalText = fmt.Sprint(points, "次") //追加永续客户展示规则(2024-02-23)
  251. return
  252. }
  253. var itemBillTotal []string
  254. itemBillTotalMap := make(map[string]string)
  255. for _, v := range activitySpecialPermissionPointsList {
  256. if v.ChartPermissionId > 0 {
  257. itemBillTotal = append(itemBillTotal, fmt.Sprint(v.ChartPermissionName, v.Points, "次")) // 行业套餐客户展示规则
  258. itemBillTotalMap[v.ChartPermissionName] = fmt.Sprint(v.ChartPermissionName, v.Points, "次")
  259. }
  260. if v.ChartPermissionId == 0 {
  261. totalText = fmt.Sprint(v.Points, "次") // 大套餐客户展示规则,
  262. }
  263. }
  264. if len(itemBillTotal) > 0 {
  265. permissionNameSlice := []string{"医药", "消费", "科技", "智造"}
  266. var itemBillTotalNew []string
  267. for _, v := range permissionNameSlice {
  268. if itemBillTotalMap[v] == "" {
  269. itemBillTotalNew = append(itemBillTotalNew, fmt.Sprint(v, "0次"))
  270. } else {
  271. itemBillTotalNew = append(itemBillTotalNew, itemBillTotalMap[v])
  272. }
  273. }
  274. totalText = strings.Join(itemBillTotalNew, "+")
  275. }
  276. return
  277. }
  278. // 用户搜专项调研操作操作行为,模板消息推送
  279. func ActivitySpecialUserRmind(user *models.WxUserItem, activityId, TripStatus int) (err error) {
  280. defer func() {
  281. if err != nil {
  282. go utils.SendAlarmMsg("用户搜专项调研操作操作行为,模板消息推送失败"+err.Error(), 2)
  283. }
  284. }()
  285. countUser, err := models.GetUserRemind(user.UserId)
  286. if err != nil {
  287. return err
  288. }
  289. if countUser == 0 {
  290. return err
  291. }
  292. var first string
  293. var keyword1 string
  294. var keyword2 string
  295. var keyword3 string
  296. var keyword4 string
  297. var remark string
  298. //获取销售手机号
  299. sellerItemQy, err := models.GetSellerByCompanyIdCheckFicc(user.CompanyId, 2)
  300. if err != nil && err.Error() != utils.ErrNoRow() {
  301. return err
  302. }
  303. if sellerItemQy != nil {
  304. sllerAndShareMobileArr, e := GetCompanySellerAndShareMobileByRai(user.CompanyId) //获取所属销售以及对应销售的手机号
  305. if e != nil {
  306. err = errors.New("GetCompanySellerAndShareMobileByRai, Err: " + e.Error())
  307. return
  308. }
  309. sllerAndShareMobiles := strings.Join(sllerAndShareMobileArr, ",")
  310. openIdList, e := models.GetWxOpenIdByMobileList(sllerAndShareMobiles)
  311. if e != nil {
  312. err = errors.New("GetSellerByAdminId, Err: " + e.Error())
  313. return
  314. }
  315. activityInfo, e := models.GetCygxActivitySpecialDetailById(user.UserId, activityId)
  316. if e != nil {
  317. err = errors.New("GetCygxActivitySpecialDetailById, Err: " + e.Error())
  318. return
  319. }
  320. if activityInfo == nil {
  321. return
  322. }
  323. //TripStatus int `description:"行程进行状态 1:预报名,2:确定行程"`
  324. if TripStatus == 1 {
  325. keyword2 = fmt.Sprint("互动:专项调研预报名,", user.RealName, "--", user.CompanyName)
  326. } else {
  327. keyword2 = fmt.Sprint("互动:活动报名,", user.RealName, "--", user.CompanyName)
  328. }
  329. keyword1 = activityInfo.ResearchTheme
  330. //keyword2 = "__"
  331. remark = "点击查看活动详情"
  332. openIdArr := make([]string, 0)
  333. for _, v := range openIdList {
  334. openIdArr = append(openIdArr, v.OpenId)
  335. }
  336. redirectUrl := utils.WX_MSG_PATH_ACTIVITY_SPECIAL_DETAIL + strconv.Itoa(activityId)
  337. sendInfo := new(SendWxTemplate)
  338. sendInfo.First = first
  339. sendInfo.Keyword1 = keyword1
  340. sendInfo.Keyword2 = keyword2
  341. sendInfo.Keyword3 = keyword3
  342. sendInfo.Keyword4 = keyword4
  343. sendInfo.Remark = remark
  344. sendInfo.TemplateId = utils.WxMsgTemplateIdArticleUserRemind
  345. sendInfo.RedirectUrl = redirectUrl
  346. sendInfo.RedirectTarget = 3
  347. sendInfo.Resource = strconv.Itoa(activityId)
  348. sendInfo.SendType = utils.TEMPLATE_MSG_CYGX_ARTICLE_ADD
  349. sendInfo.OpenIdArr = openIdArr
  350. err = PublicSendTemplateMsg(sendInfo)
  351. if err != nil {
  352. return
  353. }
  354. }
  355. return
  356. }
  357. // 确定行程用户报名模版消息推送
  358. func ActivitySpecialUserAddTrip(user *models.WxUserItem, activityId int) (err error) {
  359. defer func() {
  360. if err != nil {
  361. go utils.SendAlarmMsg("确定行程用户报名模版消息推送,模板消息推送失败"+err.Error(), 2)
  362. }
  363. }()
  364. var first string
  365. var keyword1 string
  366. var keyword2 string
  367. var keyword3 string
  368. var keyword4 string
  369. var remark string
  370. //获取销售手机号
  371. sellerItemQy, err := models.GetSellerByCompanyIdCheckFicc(user.CompanyId, 2)
  372. if err != nil && err.Error() != utils.ErrNoRow() {
  373. return err
  374. }
  375. cnf, _ := models.GetConfigByCode("tpl_msg")
  376. if cnf != nil && sellerItemQy != nil {
  377. openIdList, e := models.GetWxOpenIdByMobileList(cnf.ConfigValue + "," + sellerItemQy.Mobile)
  378. if e != nil {
  379. err = errors.New("GetSellerByAdminId, Err: " + e.Error())
  380. return
  381. }
  382. activityInfo, e := models.GetCygxActivitySpecialDetailById(user.UserId, activityId)
  383. if e != nil {
  384. err = errors.New("GetCygxActivitySpecialDetailById, Err: " + e.Error())
  385. return
  386. }
  387. if activityInfo == nil {
  388. return
  389. }
  390. keyword1 = fmt.Sprint(user.RealName, "--", user.CompanyName, "(所属销售:", sellerItemQy.RealName, ")")
  391. keyword2 = user.Mobile
  392. keyword3 = time.Now().Format(utils.FormatDateTime)
  393. keyword4 = "报名专项调研【" + activityInfo.ResearchTheme + "】 "
  394. remark = ""
  395. openIdArr := make([]string, 0)
  396. for _, v := range openIdList {
  397. openIdArr = append(openIdArr, v.OpenId)
  398. }
  399. redirectUrl := utils.WX_MSG_PATH_ACTIVITY_SPECIAL_DETAIL + strconv.Itoa(activityId)
  400. sendInfo := new(SendWxTemplate)
  401. sendInfo.First = first
  402. sendInfo.Keyword1 = keyword1
  403. sendInfo.Keyword2 = keyword2
  404. sendInfo.Keyword3 = keyword3
  405. sendInfo.Keyword4 = keyword4
  406. sendInfo.Remark = remark
  407. sendInfo.TemplateId = utils.WxMsgTemplateIdApplyXzs
  408. sendInfo.RedirectUrl = redirectUrl
  409. sendInfo.RedirectTarget = 3
  410. sendInfo.Resource = strconv.Itoa(activityId)
  411. sendInfo.SendType = utils.TEMPLATE_MSG_CYGX_ARTICLE_ADD
  412. sendInfo.OpenIdArr = openIdArr
  413. err = PublicSendTemplateMsg(sendInfo)
  414. if err != nil {
  415. return
  416. }
  417. }
  418. return
  419. }