rai_serve_count.go 48 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381
  1. package services
  2. import (
  3. "context"
  4. "errors"
  5. "fmt"
  6. "hongze/hongze_cygx/models"
  7. "hongze/hongze_cygx/models/company"
  8. "hongze/hongze_cygx/models/rai_serve"
  9. "hongze/hongze_cygx/models/roadshow"
  10. "hongze/hongze_cygx/utils"
  11. "strings"
  12. "time"
  13. )
  14. // var startWeekDate = time.Now().AddDate(0, 0, -75).Format(utils.FormatDate) + " 23:59:59" // 查询12周以内的数据
  15. //var startWeekDate = time.Now().AddDate(0, 0, -75).Format(utils.FormatDateTime) // 查询12周以内的数据
  16. //权益服务统计
  17. //上线跑的脚本
  18. //func initJob() {
  19. // UpdateRaiServeCompany() //1
  20. // UpdateCygxRaiServeBillByCompanyIds() //2
  21. // UpdateCygxRaiServeBillWeek() // 3
  22. // UpdateWeekAvg() // 4
  23. //}
  24. //func init() {
  25. // UpdateWeekAvg() //1
  26. //}
  27. //func init() {
  28. // UpdateRaiServeCompany() //1
  29. // UpdateCygxRaiServeBillByCompanyIds() //2
  30. // UpdateCygxRaiServeBillWeekTask() // 3
  31. // UpdateWeekAvg() // 4
  32. //}
  33. // 定时任务处理权益服务公司
  34. func UpdateRaiServeCompanyDate(cont context.Context) (err error) {
  35. defer func() {
  36. if err != nil {
  37. fmt.Println(err)
  38. go utils.SendAlarmMsg(fmt.Sprint("定时任务处理权益服务公司 失败 UpdateRaiServeCompanyDate ,err:", err.Error()), 2)
  39. }
  40. }()
  41. err = UpdateRaiServeCompany()
  42. return
  43. }
  44. // 定时任务处理权益服务记录明细
  45. func UpdateRaiServeBillDate(cont context.Context) (err error) {
  46. //func UpdateRaiServeBillDate() (err error) {
  47. defer func() {
  48. if err != nil {
  49. fmt.Println(err)
  50. go utils.SendAlarmMsg(fmt.Sprint("定时任务处理权益服务公司 失败 UpdateRaiServeBillDate ,err:", err.Error()), 2)
  51. }
  52. }()
  53. err = UpdateRaiServeCompany() // 处理共享机构信息
  54. if err != nil {
  55. return
  56. }
  57. err = UpdateCygxRaiServeBillByCompanyIds() // 处理个人流水记录
  58. if err != nil {
  59. return
  60. }
  61. err = UpdateCygxRaiServeBillWeekTask() // 更新周度服务明细
  62. if err != nil {
  63. return
  64. }
  65. err = UpdateWeekAvg() //更新最近四周平均覆盖率,是否标红,权限,时间,金额
  66. if err != nil {
  67. return
  68. }
  69. return
  70. }
  71. // 更新现有的权益服务客户数据
  72. func UpdateRaiServeCompany() (err error) {
  73. defer func() {
  74. if err != nil {
  75. fmt.Println(err)
  76. go utils.SendAlarmMsg("更新现有的权益服务客户数据失败 UpdateRaiServeCompany:"+err.Error(), 2)
  77. }
  78. }()
  79. var condition string
  80. var pars []interface{}
  81. condition = ` AND p.product_id = 2 AND (p.group_id IN (` + utils.RAI_SERVE_GROUP_ID + `) OR p.share_group_id IN (` + utils.RAI_SERVE_GROUP_ID + `) ) `
  82. //pars = append(pars, utils.RAI_SERVE_GROUP_ID, utils.RAI_SERVE_GROUP_ID)
  83. listCompanyProduct, e := company.GetCompanyProductAndCompanyListByCondition(condition, pars)
  84. if e != nil {
  85. err = errors.New("GetCompanyProductListByCondition, Err: " + e.Error())
  86. return
  87. }
  88. //fmt.Println(len(listCompanyProduct))
  89. //return
  90. raiServeCompanyList, e := rai_serve.GetCygxRaiServeCompanyAllList()
  91. if e != nil {
  92. err = errors.New("GetCygxRaiServeCompanyAllList, Err: " + e.Error())
  93. return
  94. }
  95. mapOLdCompany := make(map[int]bool)
  96. mapOLdCompanyDate := make(map[int]string)
  97. for _, v := range raiServeCompanyList {
  98. mapOLdCompany[v.CompanyId] = true
  99. mapOLdCompanyDate[v.CompanyId] = fmt.Sprint(v.CompanyId, v.CompanyName, v.SellerId, v.StartDate, v.EndDate, v.ShareSeller, v.ShareSellerId, v.Status, v.GroupId, v.ShareGroupId)
  100. }
  101. mapNewCompany := make(map[int]bool)
  102. var delCompanyIds []int // 需要删除的公司ID
  103. for _, v := range listCompanyProduct {
  104. mapNewCompany[v.CompanyId] = true
  105. }
  106. for _, v := range raiServeCompanyList {
  107. if !mapNewCompany[v.CompanyId] {
  108. delCompanyIds = append(delCompanyIds, v.CompanyId)
  109. }
  110. }
  111. var items []*rai_serve.CygxRaiServeCompany
  112. var itemsUpdate []*rai_serve.CygxRaiServeCompany
  113. for _, v := range listCompanyProduct {
  114. item := new(rai_serve.CygxRaiServeCompany)
  115. item.CompanyId = v.CompanyId
  116. item.CompanyName = v.CompanyName
  117. item.CreateTime = time.Now()
  118. item.SellerId = v.SellerId
  119. item.SellerName = v.SellerName
  120. item.StartDate = v.StartDate
  121. item.EndDate = v.EndDate
  122. item.ShareSeller = v.ShareSeller
  123. item.ShareSellerId = v.ShareSellerId
  124. item.Status = v.Status
  125. item.GroupId = v.GroupId
  126. item.ShareGroupId = v.ShareGroupId
  127. if !mapOLdCompany[v.CompanyId] {
  128. items = append(items, item) // 如果原有数据不存在就新增
  129. } else {
  130. if mapOLdCompanyDate[v.CompanyId] != fmt.Sprint(v.CompanyId, v.CompanyName, v.SellerId, v.StartDate, v.EndDate, v.ShareSeller, v.ShareSellerId, v.Status, v.GroupId, v.ShareGroupId) {
  131. itemsUpdate = append(itemsUpdate, item) // 新老数据不一致就进行修改
  132. }
  133. }
  134. }
  135. //fmt.Println("items", len(items))
  136. //fmt.Println("itemsUpadte222", len(itemsUpdate))
  137. //fmt.Println("delCompanyIds", len(delCompanyIds))
  138. //fmt.Println("delCompanyIds", (delCompanyIds))
  139. //return
  140. //先删除老的再添加新的
  141. e = rai_serve.AddCygxRaiServeCompanyMulti(items, itemsUpdate, delCompanyIds)
  142. if e != nil {
  143. err = errors.New("AddCygxRaiServeCompanyMulti, Err: " + e.Error())
  144. return
  145. }
  146. return
  147. }
  148. // GetCompanyContractPermissionNameMapById 获取合并之后的合同所对应的权限种类名称
  149. func GetCompanyContractPermissionNameMapById(companyContractIds []int) (mapContractResp map[int]string, err error) {
  150. //return
  151. lenArr := len(companyContractIds)
  152. if lenArr == 0 {
  153. return
  154. }
  155. var condition string
  156. var pars []interface{}
  157. condition += " AND company_contract_id IN (" + utils.GetOrmInReplace(lenArr) + ")"
  158. pars = append(pars, companyContractIds)
  159. //companyContractList, e := company.GetCompanyContractList(condition, pars)
  160. //if e != nil && e.Error() != utils.ErrNoRow() {
  161. // err = errors.New("GetCompanyContractList, Err: " + e.Error())
  162. // return
  163. //}
  164. permissionList, e := models.GetChartPermissionList()
  165. if e != nil && e.Error() != utils.ErrNoRow() {
  166. err = errors.New("GetChartPermissionList, Err: " + e.Error())
  167. return
  168. }
  169. mappermissionName := make(map[int]string)
  170. for _, v := range permissionList {
  171. if v.ProductId == 2 {
  172. mappermissionName[v.ChartPermissionId] = v.Remark
  173. }
  174. }
  175. mapContractIdPerssion := make(map[int]string) //单个合同ID所对应的套餐或者权限名称
  176. //for _, v := range companyContractList {
  177. // if v.RaiPackageType == 1 {
  178. // mapContractIdPerssion[v.CompanyContractId] = "70w套餐,"
  179. // }
  180. // if v.RaiPackageType == 2 {
  181. // mapContractIdPerssion[v.CompanyContractId] = "45w套餐,"
  182. // }
  183. //}
  184. companyContractPermissionList, e := company.GetCompanyContractPermissionList(condition, pars)
  185. if e != nil && e.Error() != utils.ErrNoRow() {
  186. err = errors.New("GetCompanyContractPermissionList, Err: " + e.Error())
  187. return
  188. }
  189. mapIsUpgrade := make(map[string]bool) //合同ID对应的行业是否有升级
  190. for _, v := range companyContractPermissionList {
  191. //如果开通的不是整个套餐,那么就做单独的子权限处理
  192. if strings.Count(mapContractIdPerssion[(v.CompanyContractId)], "w套餐") == 0 {
  193. if v.ChartPermissionId == utils.CHART_PERMISSION_ID_YANXUAN {
  194. if v.ExpensiveYx == 1 {
  195. mapContractIdPerssion[(v.CompanyContractId)] += utils.CHART_PERMISSION_NAME_MF_YANXUAN + "(5w),"
  196. } else if v.ExpensiveYx == 2 {
  197. mapContractIdPerssion[(v.CompanyContractId)] += utils.CHART_PERMISSION_NAME_MF_YANXUAN + "(10w),"
  198. } else {
  199. mapContractIdPerssion[(v.CompanyContractId)] += utils.CHART_PERMISSION_NAME_MF_YANXUAN + ","
  200. }
  201. } else {
  202. mapContractIdPerssion[(v.CompanyContractId)] += mappermissionName[v.ChartPermissionId] + ","
  203. if v.IsUpgrade == 1 {
  204. //合同ID,权限名称形成唯一的主键索引
  205. perssionName := mappermissionName[v.ChartPermissionId]
  206. perssionName = strings.Replace(perssionName, "(客观)", "", -1)
  207. perssionName = strings.Replace(perssionName, "(主观)", "", -1)
  208. mapIsUpgrade[fmt.Sprint(v.CompanyContractId, "perssionName", perssionName)] = true
  209. }
  210. }
  211. } else {
  212. if v.ChartPermissionId == utils.ZHUAN_JIA_ID {
  213. mapContractIdPerssion[(v.CompanyContractId)] += utils.ZHUAN_JIA_NAME + ","
  214. }
  215. if v.ChartPermissionId == utils.CHART_PERMISSION_ID_YANXUAN {
  216. if v.ExpensiveYx == 1 {
  217. mapContractIdPerssion[(v.CompanyContractId)] += utils.CHART_PERMISSION_NAME_MF_YANXUAN + "(5w),"
  218. } else if v.ExpensiveYx == 2 {
  219. mapContractIdPerssion[(v.CompanyContractId)] += utils.CHART_PERMISSION_NAME_MF_YANXUAN + "(10w),"
  220. } else {
  221. mapContractIdPerssion[(v.CompanyContractId)] += utils.CHART_PERMISSION_NAME_MF_YANXUAN + ","
  222. }
  223. }
  224. if v.ChartPermissionId == utils.YAN_XUAN_KOU_DIAN_BAO_ID {
  225. mapContractIdPerssion[(v.CompanyContractId)] += utils.YAN_XUAN_KOU_DIAN_BAO_NAME + ","
  226. }
  227. }
  228. }
  229. //合并客观权限
  230. for k, v := range mapContractIdPerssion {
  231. perssionName := v
  232. if strings.Count(v, utils.YI_YAO_NAME) == 2 {
  233. perssionName = strings.Replace(perssionName, "医药(主观)", "医药", -1)
  234. perssionName = strings.Replace(perssionName, "医药(客观)", "", -1)
  235. }
  236. if strings.Count(v, utils.XIAO_FEI_NAME) == 2 {
  237. perssionName = strings.Replace(perssionName, "消费(主观)", "消费", -1)
  238. perssionName = strings.Replace(perssionName, "消费(客观)", "", -1)
  239. }
  240. if strings.Count(v, utils.KE_JI_NAME) == 2 {
  241. perssionName = strings.Replace(perssionName, "科技(主观)", "科技", -1)
  242. perssionName = strings.Replace(perssionName, "科技(客观)", "", -1)
  243. }
  244. if strings.Count(v, utils.ZHI_ZAO_NAME) == 2 {
  245. perssionName = strings.Replace(perssionName, "智造(主观)", "智造", -1)
  246. perssionName = strings.Replace(perssionName, "智造(客观)", "", -1)
  247. }
  248. perssionName = strings.TrimRight(perssionName, ",")
  249. mapContractIdPerssion[k] = perssionName
  250. }
  251. mapContractResp = make(map[int]string, 0)
  252. //过滤多余的","
  253. for k, v := range mapContractIdPerssion {
  254. sliceName := strings.Split(v, ",")
  255. var nameArr []string
  256. for _, vName := range sliceName {
  257. if vName == "" {
  258. continue
  259. }
  260. if mapIsUpgrade[fmt.Sprint(k, "perssionName", vName)] {
  261. vName += "(升级)"
  262. }
  263. nameArr = append(nameArr, vName)
  264. }
  265. mapContractResp[k] = strings.Join(nameArr, ",")
  266. }
  267. return
  268. }
  269. // 根据公司ID获取目前行业所对应的正式权限
  270. func GetCompanyReportPermissionNameMapByCompanyId(companyIds []int) (mapContractResp map[int]string, err error) {
  271. lenArr := len(companyIds)
  272. if lenArr == 0 {
  273. return
  274. }
  275. var condition string
  276. var pars []interface{}
  277. condition += " AND company_id IN (" + utils.GetOrmInReplace(lenArr) + ") AND product_id = 2 AND status IN ( '正式','永续') "
  278. pars = append(pars, companyIds)
  279. permissionList, e := models.GetChartPermissionList()
  280. if e != nil && e.Error() != utils.ErrNoRow() {
  281. err = errors.New("GetChartPermissionList, Err: " + e.Error())
  282. return
  283. }
  284. mappermissionName := make(map[int]string)
  285. for _, v := range permissionList {
  286. if v.ProductId == 2 {
  287. mappermissionName[v.ChartPermissionId] = v.Remark
  288. }
  289. }
  290. mapContractIdPerssion := make(map[int]string) //单个合同ID所对应的套餐或者权限名称
  291. companyReportPermissionList, e := models.GetCompanyReportPermissionList(condition, pars)
  292. if e != nil && e.Error() != utils.ErrNoRow() {
  293. err = errors.New("GetCompanyReportPermissionList, Err: " + e.Error())
  294. return
  295. }
  296. mapIsUpgrade := make(map[string]bool) //合同ID对应的行业是否有升级
  297. for _, v := range companyReportPermissionList {
  298. //如果开通的不是整个套餐,那么就做单独的子权限处理
  299. if strings.Count(mapContractIdPerssion[(v.CompanyId)], "w套餐") == 0 {
  300. if v.ChartPermissionId == utils.CHART_PERMISSION_ID_YANXUAN {
  301. if v.ExpensiveYx == 1 {
  302. mapContractIdPerssion[(v.CompanyId)] += utils.CHART_PERMISSION_NAME_MF_YANXUAN + "(5w),"
  303. } else if v.ExpensiveYx == 2 {
  304. mapContractIdPerssion[(v.CompanyId)] += utils.CHART_PERMISSION_NAME_MF_YANXUAN + "(10w),"
  305. } else {
  306. mapContractIdPerssion[(v.CompanyId)] += utils.CHART_PERMISSION_NAME_MF_YANXUAN + ","
  307. }
  308. } else {
  309. mapContractIdPerssion[(v.CompanyId)] += mappermissionName[v.ChartPermissionId] + ","
  310. if v.IsUpgrade == 1 {
  311. //合同ID,权限名称形成唯一的主键索引
  312. perssionName := mappermissionName[v.ChartPermissionId]
  313. perssionName = strings.Replace(perssionName, "(客观)", "", -1)
  314. perssionName = strings.Replace(perssionName, "(主观)", "", -1)
  315. mapIsUpgrade[fmt.Sprint(v.CompanyId, "perssionName", perssionName)] = true
  316. }
  317. }
  318. } else {
  319. if v.ChartPermissionId == utils.ZHUAN_JIA_ID {
  320. mapContractIdPerssion[(v.CompanyId)] += utils.ZHUAN_JIA_NAME + ","
  321. }
  322. if v.ChartPermissionId == utils.CHART_PERMISSION_ID_YANXUAN {
  323. if v.ExpensiveYx == 1 {
  324. mapContractIdPerssion[(v.CompanyId)] += utils.CHART_PERMISSION_NAME_MF_YANXUAN + "(5w),"
  325. } else if v.ExpensiveYx == 2 {
  326. mapContractIdPerssion[(v.CompanyId)] += utils.CHART_PERMISSION_NAME_MF_YANXUAN + "(10w),"
  327. } else {
  328. mapContractIdPerssion[(v.CompanyId)] += utils.CHART_PERMISSION_NAME_MF_YANXUAN + ","
  329. }
  330. }
  331. if v.ChartPermissionId == utils.YAN_XUAN_KOU_DIAN_BAO_ID {
  332. mapContractIdPerssion[(v.CompanyId)] += utils.YAN_XUAN_KOU_DIAN_BAO_NAME + ","
  333. }
  334. }
  335. }
  336. //合并客观权限
  337. for k, v := range mapContractIdPerssion {
  338. perssionName := v
  339. if strings.Count(v, utils.YI_YAO_NAME) == 2 {
  340. perssionName = strings.Replace(perssionName, "医药(主观)", "医药", -1)
  341. perssionName = strings.Replace(perssionName, "医药(客观)", "", -1)
  342. }
  343. if strings.Count(v, utils.XIAO_FEI_NAME) == 2 {
  344. perssionName = strings.Replace(perssionName, "消费(主观)", "消费", -1)
  345. perssionName = strings.Replace(perssionName, "消费(客观)", "", -1)
  346. }
  347. if strings.Count(v, utils.KE_JI_NAME) == 2 {
  348. perssionName = strings.Replace(perssionName, "科技(主观)", "科技", -1)
  349. perssionName = strings.Replace(perssionName, "科技(客观)", "", -1)
  350. }
  351. if strings.Count(v, utils.ZHI_ZAO_NAME) == 2 {
  352. perssionName = strings.Replace(perssionName, "智造(主观)", "智造", -1)
  353. perssionName = strings.Replace(perssionName, "智造(客观)", "", -1)
  354. }
  355. perssionName = strings.TrimRight(perssionName, ",")
  356. mapContractIdPerssion[k] = perssionName
  357. }
  358. mapContractResp = make(map[int]string, 0)
  359. //过滤多余的","
  360. for k, v := range mapContractIdPerssion {
  361. sliceName := strings.Split(v, ",")
  362. var nameArr []string
  363. for _, vName := range sliceName {
  364. if vName == "" {
  365. continue
  366. }
  367. if mapIsUpgrade[fmt.Sprint(k, "perssionName", vName)] {
  368. vName += "(升级)"
  369. }
  370. nameArr = append(nameArr, vName)
  371. }
  372. mapContractResp[k] = strings.Join(nameArr, ",")
  373. }
  374. return
  375. }
  376. // Redis对列消息中的结构体
  377. type RaiServeBillRedis struct {
  378. Content string `comment:"服务内容说明"`
  379. UserId int `comment:"用户ID"`
  380. ComapnyId int `comment:"公司ID"`
  381. SourceId int `comment:"来源ID"`
  382. Source string `comment:"来源"`
  383. RegisterPlatform int `comment:"来源 1小程序,2:网页"`
  384. ViewTime time.Time `comment:"浏览时间"`
  385. }
  386. // 批量更新企业服务明细记录
  387. func UpdateCygxRaiServeBillByCompanyIds() (err error) {
  388. defer func() {
  389. if err != nil {
  390. fmt.Println(err)
  391. go utils.SendAlarmMsg("批量更新企业服务明细记录失败: UpdateCygxRaiServeBillByCompanyIds Err"+err.Error(), 2)
  392. }
  393. }()
  394. var delBillIds []int
  395. var startWeekDate = time.Now().AddDate(0, 0, -75).Format(utils.FormatDate) + " 23:59:59"
  396. fmt.Println("UpdateCygxRaiServeBillByCompanyIds start")
  397. companyList, e := rai_serve.GetCygxRaiServeCompanyAllList()
  398. if e != nil {
  399. err = errors.New("GetCygxRaiServeCompanyAllList, Err: " + e.Error())
  400. return
  401. }
  402. var companyIds []int
  403. var items []*rai_serve.CygxRaiServeBill
  404. for _, v := range companyList {
  405. companyIds = append(companyIds, v.CompanyId)
  406. }
  407. lencompanyId := len(companyIds)
  408. listisMakeruser, e := models.GetWxUserisMakerByCompanyIds(companyIds)
  409. if e != nil {
  410. err = errors.New("GetWxUserisMakerByCompanyIds, Err: " + e.Error())
  411. return
  412. }
  413. mapUserMaker := make(map[int]bool)
  414. mapUserMobileUserId := make(map[string]int)
  415. for _, v := range listisMakeruser {
  416. mapUserMaker[v.UserId] = true
  417. mapUserMobileUserId[v.Mobile] = v.UserId
  418. }
  419. var condition string
  420. var pars []interface{}
  421. condition = " AND art.company_id IN (" + utils.GetOrmInReplace(lencompanyId) + ") AND art.create_time > ? "
  422. pars = append(pars, companyIds, startWeekDate)
  423. fmt.Println("startWeekDate", startWeekDate)
  424. //研选专栏阅读记录内容
  425. {
  426. listYanxuanSpecialRecord, e := models.GetCygxYanxuanSpecialRecordRespListAll(condition+" GROUP BY art.user_id, art.yanxuan_special_id ORDER BY art.create_time ASC ", pars)
  427. if e != nil {
  428. err = errors.New("GetCygxYanxuanSpecialRecordRespListAll, Err: " + e.Error())
  429. return
  430. }
  431. var yanxuanspecialIds []int
  432. for _, v := range listYanxuanSpecialRecord {
  433. yanxuanspecialIds = append(yanxuanspecialIds, v.YanxuanSpecialId)
  434. }
  435. var conditionYanxuanSpecial string
  436. var parsYanxuanSpecial []interface{}
  437. conditionYanxuanSpecial += ` AND id IN (` + utils.GetOrmInReplace(len(yanxuanspecialIds)) + `) `
  438. parsYanxuanSpecial = append(parsYanxuanSpecial, yanxuanspecialIds)
  439. listYanxuanSpecial, e := models.GetYanxuanSpecialListBycondition(conditionYanxuanSpecial, parsYanxuanSpecial, 0, len(yanxuanspecialIds))
  440. if e != nil && e.Error() != utils.ErrNoRow() {
  441. err = errors.New("GetYanxuanSpecialListBycondition, Err: " + e.Error())
  442. return
  443. }
  444. mapYanxuanSpecialTitle := make(map[int]string)
  445. for _, v := range listYanxuanSpecial {
  446. mapYanxuanSpecialTitle[v.Id] = v.Title
  447. }
  448. //研选阅读明细
  449. var conditionBill string
  450. var parsBill []interface{}
  451. conditionBill = " AND source = 'yanxuanspecial' AND company_id IN (" + utils.GetOrmInReplace(lencompanyId) + ") AND view_time > ? "
  452. parsBill = append(parsBill, companyIds, startWeekDate)
  453. listBillByYanxuanspecial, e := rai_serve.GetCygxRaiServeBillListAll(conditionBill, parsBill)
  454. if e != nil {
  455. err = errors.New("GetCygxRaiServeBillListAll, Err: " + e.Error())
  456. return
  457. }
  458. mapYanxuanspecialBill := make(map[string]bool)
  459. for _, v := range listBillByYanxuanspecial {
  460. mapYanxuanspecialBill[fmt.Sprint("UID_", v.UserId, "SID_", v.SourceId)] = true
  461. }
  462. for _, v := range listYanxuanSpecialRecord {
  463. if mapYanxuanspecialBill[fmt.Sprint("UID_", v.UserId, "SID_", v.YanxuanSpecialId)] { // 如果内容存在就不插入
  464. continue
  465. }
  466. item := new(rai_serve.CygxRaiServeBill)
  467. item.Content = mapYanxuanSpecialTitle[v.YanxuanSpecialId]
  468. item.ServeTypeId = 5
  469. item.ServeTypeName = "阅读uv"
  470. item.UserId = v.UserId
  471. item.Mobile = v.Mobile
  472. item.Email = v.Email
  473. item.CompanyId = v.CompanyId
  474. item.CompanyName = v.CompanyName
  475. item.RealName = v.RealName
  476. item.RegisterPlatform = v.RegisterPlatform
  477. item.ServeCount = 0.5
  478. if mapUserMaker[v.UserId] {
  479. item.IsKp = 1
  480. item.ServeCount = item.ServeCount * 3
  481. }
  482. item.SourceId = v.YanxuanSpecialId
  483. item.Source = utils.CYGX_OBJ_YANXUANSPECIAL
  484. item.CreateTime = time.Now()
  485. item.ViewTime = v.CreateTime
  486. item.WeekStartDate, item.WeekEndDate = utils.GetMondayAndSundayByTimeString(item.ViewTime)
  487. item.MonthStartDate, item.MonthEndDate = utils.GetFirstAndLastDayOfMonth(item.ViewTime)
  488. items = append(items, item)
  489. }
  490. }
  491. //研选专栏阅读记录内容end
  492. //文章阅读记录内容
  493. {
  494. listArticleRecord, e := models.GetCygxArticleHistoryRecordAllListNoLimit(condition+" GROUP BY art.user_id, art.article_id ORDER BY art.create_time ASC ", pars)
  495. if e != nil {
  496. err = errors.New("GetCygxArticleHistoryRecordAllListNoLimit, Err: " + e.Error())
  497. return
  498. }
  499. //文章阅读明细
  500. var conditionBill string
  501. var parsBill []interface{}
  502. conditionBill = " AND source = 'article' AND company_id IN (" + utils.GetOrmInReplace(lencompanyId) + ") AND view_time > ? "
  503. parsBill = append(parsBill, companyIds, startWeekDate)
  504. listBillByArticle, e := rai_serve.GetCygxRaiServeBillListAll(conditionBill, parsBill)
  505. if e != nil {
  506. err = errors.New("GetCygxRaiServeBillListAll, Err: " + e.Error())
  507. return
  508. }
  509. mapArticleBill := make(map[string]bool)
  510. for _, v := range listBillByArticle {
  511. mapArticleBill[fmt.Sprint("UID_", v.UserId, "SID_", v.SourceId)] = true
  512. }
  513. //部分数据来源没有存用户姓名,重新查一下
  514. var userIds []int
  515. for _, v := range listArticleRecord {
  516. userIds = append(userIds, v.UserId)
  517. }
  518. ListUser, e := models.GetWxUserListByUserIdsArr(userIds)
  519. if e != nil {
  520. err = errors.New("GetWxUserListByUserIdsArr, Err: " + e.Error())
  521. return
  522. }
  523. mapUserName := make(map[int]string)
  524. for _, v := range ListUser {
  525. mapUserName[v.UserId] = v.RealName
  526. }
  527. for _, v := range listArticleRecord {
  528. if mapArticleBill[fmt.Sprint("UID_", v.UserId, "SID_", v.ArticleId)] { // 如果内容存在就不插入
  529. continue
  530. }
  531. item := new(rai_serve.CygxRaiServeBill)
  532. item.Content = v.Title
  533. item.ServeTypeId = 5
  534. item.ServeTypeName = "阅读uv"
  535. item.UserId = v.UserId
  536. item.Mobile = v.Mobile
  537. item.Email = v.Email
  538. item.CompanyId = v.CompanyId
  539. item.CompanyName = v.CompanyName
  540. item.RealName = mapUserName[v.UserId]
  541. item.RegisterPlatform = v.RegisterPlatform
  542. item.ServeCount = 0.5
  543. if mapUserMaker[v.UserId] {
  544. item.IsKp = 1
  545. item.ServeCount = item.ServeCount * 3
  546. }
  547. item.SourceId = v.ArticleId
  548. item.Source = utils.CYGX_OBJ_ARTICLE
  549. item.CreateTime = time.Now()
  550. item.ViewTime = v.CreateTime
  551. item.WeekStartDate, item.WeekEndDate = utils.GetMondayAndSundayByTimeString(item.ViewTime)
  552. item.MonthStartDate, item.MonthEndDate = utils.GetFirstAndLastDayOfMonth(item.ViewTime)
  553. if strings.Contains(v.CategoryName, "固收") {
  554. item.ChartPermissionName = utils.GU_SHOU_NAME
  555. item.ChartPermissionId = utils.GU_SHOU_ID_CHART
  556. }
  557. if strings.Contains(v.CategoryName, "策略") {
  558. item.ChartPermissionName = utils.CE_LUE_NAME
  559. item.ChartPermissionId = utils.CE_LUE_ID
  560. }
  561. items = append(items, item)
  562. }
  563. }
  564. //文章阅读记录内容 end
  565. //活动记录内容
  566. {
  567. condition = " AND art.company_id IN (" + utils.GetOrmInReplace(lencompanyId) + ") AND a.activity_time > ? "
  568. signUpDetailList, e := models.GetSignupDetailBySignupjoinactivity(condition+" ORDER BY a.activity_time ASC ", pars)
  569. if e != nil {
  570. err = errors.New("GetSignupDetailBySignupjoinactivity, Err: " + e.Error())
  571. return
  572. }
  573. //文章阅读明细
  574. var conditionBill string
  575. var parsBill []interface{}
  576. conditionBill = " AND source = 'activity' AND company_id IN (" + utils.GetOrmInReplace(lencompanyId) + ") AND view_time > ? "
  577. parsBill = append(parsBill, companyIds, startWeekDate)
  578. listBillByActivity, e := rai_serve.GetCygxRaiServeBillListAll(conditionBill, parsBill)
  579. if e != nil {
  580. err = errors.New("GetCygxRaiServeBillListAll, Err: " + e.Error())
  581. return
  582. }
  583. mapActivityeBill := make(map[string]bool)
  584. for _, v := range listBillByActivity {
  585. mapActivityeBill[fmt.Sprint("UID_", v.Mobile, "SID_", v.SourceId)] = true
  586. }
  587. mapArticleBillDel := make(map[string]bool)
  588. for _, v := range signUpDetailList {
  589. mapArticleBillDel[fmt.Sprint("UID_", v.UserId, "SID_", v.ActivityId)] = true
  590. }
  591. mapDelActivityBillDel := make(map[string]bool)
  592. for _, v := range signUpDetailList {
  593. mapDelActivityBillDel[fmt.Sprint("UID_", v.UserId, "SID_", v.ActivityId)] = true
  594. }
  595. for _, v := range listBillByActivity {
  596. if !mapDelActivityBillDel[fmt.Sprint("UID_", v.UserId, "SID_", v.SourceId)] { // 如果内容存在就插入删除ID中
  597. delBillIds = append(delBillIds, v.BillId)
  598. }
  599. }
  600. for _, v := range signUpDetailList {
  601. if v.UserId == 0 && v.Mobile != "" {
  602. v.UserId = mapUserMobileUserId[v.Mobile] // 空降的部分联系人 userid 为0这里做一下修复
  603. }
  604. if mapActivityeBill[fmt.Sprint("UID_", v.Mobile, "SID_", v.ActivityId)] { // 如果内容存在就不插入
  605. continue
  606. }
  607. item := new(rai_serve.CygxRaiServeBill)
  608. item.Content = v.ActivityName
  609. if v.ActivityType == 1 {
  610. item.ServeTypeId = 1
  611. item.ServeTypeName = "线上活动"
  612. } else {
  613. item.ServeTypeId = 2
  614. item.ServeTypeName = "线下活动"
  615. }
  616. item.UserId = v.UserId
  617. item.Mobile = v.Mobile
  618. item.Email = v.Email
  619. item.CompanyId = v.CompanyId
  620. item.CompanyName = v.CompanyName
  621. item.RealName = v.RealName
  622. //item.RegisterPlatform = v.RegisterPlatform
  623. item.ServeCount = 1
  624. if mapUserMaker[v.UserId] {
  625. item.IsKp = 1
  626. item.ServeCount = item.ServeCount * 3
  627. }
  628. item.SourceId = v.ActivityId
  629. item.Source = utils.CYGX_OBJ_ACTIVITY
  630. item.CreateTime = time.Now()
  631. item.ViewTime = v.ActivityTime
  632. item.ChartPermissionName = v.ChartPermissionName
  633. item.ChartPermissionId = v.ChartPermissionId
  634. item.WeekStartDate, item.WeekEndDate = utils.GetMondayAndSundayByTimeString(item.ViewTime)
  635. item.MonthStartDate, item.MonthEndDate = utils.GetFirstAndLastDayOfMonth(item.ViewTime)
  636. items = append(items, item)
  637. }
  638. }
  639. //活动记录内容 end
  640. //专项调研活动记录内容
  641. {
  642. condition = " AND art.company_id IN (" + utils.GetOrmInReplace(lencompanyId) + ") AND a.activity_time > ? "
  643. activitySpecialList, e := models.GetCygxActivitySpecialMeetingDetailList(condition+" ORDER BY a.activity_time ASC ", pars)
  644. if e != nil {
  645. err = errors.New("GetCygxActivitySpecialMeetingDetailList, Err: " + e.Error())
  646. return
  647. }
  648. //专项调研活动明细
  649. var conditionBill string
  650. var parsBill []interface{}
  651. conditionBill = " AND source = 'activityspecial' AND company_id IN (" + utils.GetOrmInReplace(lencompanyId) + ") AND view_time > ? "
  652. parsBill = append(parsBill, companyIds, startWeekDate)
  653. listBillByActivitySpecial, e := rai_serve.GetCygxRaiServeBillListAll(conditionBill, parsBill)
  654. if e != nil {
  655. err = errors.New("GetCygxRaiServeBillListAll, Err: " + e.Error())
  656. return
  657. }
  658. mapActivitySpecial := make(map[string]bool)
  659. for _, v := range listBillByActivitySpecial {
  660. mapActivitySpecial[fmt.Sprint("UID_", v.UserId, "SID_", v.SourceId)] = true
  661. }
  662. mapDelActivitySpecial := make(map[string]bool)
  663. for _, v := range activitySpecialList {
  664. mapDelActivitySpecial[fmt.Sprint("UID_", v.UserId, "SID_", v.ActivityId)] = true
  665. }
  666. for _, v := range listBillByActivitySpecial {
  667. if !mapDelActivitySpecial[fmt.Sprint("UID_", v.UserId, "SID_", v.SourceId)] { // 如果内容存在就插入删除ID中
  668. delBillIds = append(delBillIds, v.BillId)
  669. }
  670. }
  671. for _, v := range activitySpecialList {
  672. if mapActivitySpecial[fmt.Sprint("UID_", v.UserId, "SID_", v.ActivityId)] { // 如果内容存在就不插入
  673. continue
  674. }
  675. item := new(rai_serve.CygxRaiServeBill)
  676. item.Content = v.ResearchTheme
  677. item.ServeTypeId = 3
  678. item.ServeTypeName = "专项调研"
  679. item.UserId = v.UserId
  680. item.Mobile = v.Mobile
  681. item.Email = v.Email
  682. item.CompanyId = v.CompanyId
  683. item.CompanyName = v.CompanyName
  684. item.RealName = v.RealName
  685. //item.RegisterPlatform = v.RegisterPlatform
  686. item.ServeCount = 1
  687. if mapUserMaker[v.UserId] {
  688. item.IsKp = 1
  689. item.ServeCount = item.ServeCount * 3
  690. }
  691. item.SourceId = v.ActivityId
  692. item.Source = utils.CYGX_OBJ_ACTIVITYSPECIAL
  693. item.CreateTime = time.Now()
  694. item.ViewTime = v.ActivityTime
  695. item.ChartPermissionName = v.ChartPermissionName
  696. item.ChartPermissionId = v.ChartPermissionId
  697. item.WeekStartDate, item.WeekEndDate = utils.GetMondayAndSundayByTimeString(item.ViewTime)
  698. item.MonthStartDate, item.MonthEndDate = utils.GetFirstAndLastDayOfMonth(item.ViewTime)
  699. items = append(items, item)
  700. }
  701. }
  702. //专项调研活动记录内容 end
  703. //1v1路演
  704. {
  705. condition = " AND art.company_id IN (" + utils.GetOrmInReplace(lencompanyId) + ") AND rs.start_date > ? "
  706. calendarMeetingUserList, e := roadshow.GetRsCalendarMeetingUserList(condition+" ORDER BY rs.start_date ASC ", pars)
  707. if e != nil {
  708. err = errors.New("GetRsCalendarMeetingUserList, Err: " + e.Error())
  709. return
  710. }
  711. var rsCalendarIds []int
  712. for _, v := range calendarMeetingUserList {
  713. rsCalendarIds = append(rsCalendarIds, v.RsCalendarId)
  714. }
  715. //获取研究员信息
  716. researchers, e := roadshow.GetRsCalendarResearcherListByIds(rsCalendarIds)
  717. if e != nil {
  718. err = errors.New("GetRsCalendarResearcherListByIds, Err: " + e.Error())
  719. return
  720. }
  721. mapResearcherName := make(map[int][]string)
  722. for _, v := range researchers {
  723. mapResearcherName[v.RsCalendarId] = append(mapResearcherName[v.RsCalendarId], v.ResearcherName)
  724. }
  725. listEmail, e := models.GetAskEmail()
  726. if e != nil {
  727. err = errors.New("GetAskEmail, Err: " + e.Error())
  728. return
  729. }
  730. var ceLueResearcherName []string
  731. var guShouResearcherName []string
  732. for _, v := range listEmail {
  733. if v.ChartPermissionName == utils.CE_LUE_NAME {
  734. ceLueResearcherName = append(ceLueResearcherName, v.Name)
  735. }
  736. if v.ChartPermissionName == utils.GU_SHOU_NAME {
  737. guShouResearcherName = append(guShouResearcherName, v.Name)
  738. }
  739. }
  740. //专项调研活动明细
  741. var conditionBill string
  742. var parsBill []interface{}
  743. conditionBill = " AND source = 'rscalendar' AND company_id IN (" + utils.GetOrmInReplace(lencompanyId) + ") AND view_time > ? "
  744. parsBill = append(parsBill, companyIds, startWeekDate)
  745. listBillByRscalendar, e := rai_serve.GetCygxRaiServeBillListAll(conditionBill, parsBill)
  746. if e != nil {
  747. err = errors.New("GetCygxRaiServeBillListAll, Err: " + e.Error())
  748. return
  749. }
  750. mapRscalendarBill := make(map[string]bool)
  751. for _, v := range listBillByRscalendar {
  752. mapRscalendarBill[fmt.Sprint("UID_", v.UserId, "SID_", v.SourceId)] = true
  753. }
  754. mapDelRscalendarBill := make(map[string]bool)
  755. for _, v := range calendarMeetingUserList {
  756. mapDelRscalendarBill[fmt.Sprint("UID_", v.UserId, "SID_", v.RsCalendarId)] = true
  757. }
  758. for _, v := range listBillByRscalendar {
  759. if !mapDelRscalendarBill[fmt.Sprint("UID_", v.UserId, "SID_", v.SourceId)] { // 如果内容存在就插入删除ID中
  760. delBillIds = append(delBillIds, v.BillId)
  761. }
  762. }
  763. for _, v := range calendarMeetingUserList {
  764. if mapRscalendarBill[fmt.Sprint("UID_", v.UserId, "SID_", v.RsCalendarId)] { // 如果内容存在就不插入
  765. continue
  766. }
  767. item := new(rai_serve.CygxRaiServeBill)
  768. item.Content = strings.Join(mapResearcherName[v.RsCalendarId], ",")
  769. item.ServeTypeId = 4
  770. item.ServeTypeName = "一对一路演"
  771. item.UserId = v.UserId
  772. item.Mobile = v.Mobile
  773. item.Email = v.Email
  774. item.CompanyId = v.CompanyId
  775. item.CompanyName = v.CompanyName
  776. item.RealName = v.RealName
  777. //item.RegisterPlatform = v.RegisterPlatform
  778. item.ServeCount = 1.5
  779. if mapUserMaker[v.UserId] {
  780. item.IsKp = 1
  781. item.ServeCount = item.ServeCount * 3
  782. }
  783. item.SourceId = v.RsCalendarId
  784. item.Source = utils.CYGX_OBJ_RS_CALENDAR
  785. item.CreateTime = time.Now()
  786. item.ViewTime = v.StartDate + " " + v.StartTime
  787. item.WeekStartDate, item.WeekEndDate = utils.GetMondayAndSundayByTimeString(item.ViewTime)
  788. item.MonthStartDate, item.MonthEndDate = utils.GetFirstAndLastDayOfMonth(item.ViewTime)
  789. if utils.InArrayByStr(guShouResearcherName, item.Content) {
  790. item.ChartPermissionName = utils.GU_SHOU_NAME
  791. item.ChartPermissionId = utils.GU_SHOU_ID_CHART
  792. }
  793. if utils.InArrayByStr(ceLueResearcherName, item.Content) {
  794. item.ChartPermissionName = utils.CE_LUE_NAME
  795. item.ChartPermissionId = utils.CE_LUE_ID
  796. }
  797. items = append(items, item)
  798. }
  799. }
  800. //1v1路演 end
  801. //交流反馈
  802. {
  803. condition = " AND company_id IN (" + utils.GetOrmInReplace(lencompanyId) + ") AND create_time > ? "
  804. userFeedbackList, e := rai_serve.GetCygxUserFeedbackList(condition+" ORDER BY user_feedback_id ASC ", pars)
  805. if e != nil {
  806. err = errors.New("GetCygxUserFeedbackList, Err: " + e.Error())
  807. return
  808. }
  809. //交流反馈明细
  810. var conditionBill string
  811. var parsBill []interface{}
  812. conditionBill = " AND source = 'userfeedback' AND company_id IN (" + utils.GetOrmInReplace(lencompanyId) + ") AND view_time > ? "
  813. parsBill = append(parsBill, companyIds, startWeekDate)
  814. listBillByuserFeedback, e := rai_serve.GetCygxRaiServeBillListAll(conditionBill, parsBill)
  815. if e != nil {
  816. err = errors.New("GetCygxRaiServeBillListAll, Err: " + e.Error())
  817. return
  818. }
  819. mapRscalendarBill := make(map[string]bool)
  820. for _, v := range listBillByuserFeedback {
  821. mapRscalendarBill[fmt.Sprint("UID_", v.UserId, "SID_", v.SourceId)] = true
  822. }
  823. mapDelRscalendarBill := make(map[string]bool)
  824. for _, v := range userFeedbackList {
  825. mapDelRscalendarBill[fmt.Sprint("UID_", v.UserId, "SID_", v.UserFeedbackId)] = true
  826. }
  827. for _, v := range listBillByuserFeedback {
  828. if !mapDelRscalendarBill[fmt.Sprint("UID_", v.UserId, "SID_", v.SourceId)] { // 如果内容存在就插入删除ID中
  829. delBillIds = append(delBillIds, v.BillId)
  830. }
  831. }
  832. for _, v := range userFeedbackList {
  833. if mapRscalendarBill[fmt.Sprint("UID_", v.UserId, "SID_", v.UserFeedbackId)] { // 如果内容存在就不插入
  834. continue
  835. }
  836. item := new(rai_serve.CygxRaiServeBill)
  837. item.Content = v.Content
  838. item.ServeTypeId = 6
  839. item.ServeTypeName = "交流反馈"
  840. item.UserId = v.UserId
  841. item.Mobile = v.Mobile
  842. item.Email = v.Email
  843. item.CompanyId = v.CompanyId
  844. item.CompanyName = v.CompanyName
  845. item.RealName = v.RealName
  846. item.ServeCount = 1
  847. if mapUserMaker[v.UserId] {
  848. item.IsKp = 1
  849. item.ServeCount = item.ServeCount * 3
  850. }
  851. item.SourceId = v.UserFeedbackId
  852. item.Source = utils.CYGX_OBJ_USER_FEEDBACK
  853. item.CreateTime = time.Now()
  854. item.ViewTime = v.CreateTime
  855. item.WeekStartDate, item.WeekEndDate = utils.GetMondayAndSundayByTimeString(item.ViewTime)
  856. item.MonthStartDate, item.MonthEndDate = utils.GetFirstAndLastDayOfMonth(item.ViewTime)
  857. items = append(items, item)
  858. }
  859. }
  860. //交流反馈 end
  861. if len(items) > 0 {
  862. var itemsAdd []*rai_serve.CygxRaiServeBill
  863. for k, v := range items {
  864. itemsAdd = append(itemsAdd, v)
  865. if len(itemsAdd)%2000 == 0 {
  866. fmt.Println(k)
  867. e = rai_serve.AddCygxRaiServeBillMulti(itemsAdd)
  868. if e != nil {
  869. err = errors.New("AddCygxRaiServeBillMulti, Err: " + e.Error())
  870. return
  871. }
  872. itemsAdd = make([]*rai_serve.CygxRaiServeBill, 0)
  873. }
  874. }
  875. e = rai_serve.AddCygxRaiServeBillMulti(itemsAdd)
  876. if e != nil {
  877. err = errors.New("AddCygxRaiServeBillMulti, Err: " + e.Error())
  878. return
  879. }
  880. }
  881. fmt.Println("delBillIds", (delBillIds))
  882. fmt.Println("UpdateCygxRaiServeBillByCompanyIds end")
  883. return
  884. }
  885. // 更新周度服务明细
  886. func UpdateCygxRaiServeBillWeek() (err error) {
  887. defer func() {
  888. if err != nil {
  889. fmt.Println(err)
  890. go utils.SendAlarmMsg("批量更新企业服务明细记录失败: UpdateCygxRaiServeBillByCompanyIds Err"+err.Error(), 2)
  891. }
  892. }()
  893. now := time.Now()
  894. weeks := 12
  895. companyList, e := rai_serve.GetCygxRaiServeCompanyAllList()
  896. if e != nil {
  897. err = errors.New("GetCygxRaiServeCompanyAllList, Err: " + e.Error())
  898. return
  899. }
  900. var companyIds []int
  901. for _, v := range companyList {
  902. companyIds = append(companyIds, v.CompanyId)
  903. }
  904. listCompanyUserNum, e := models.GetWxUserNumByCompanyIds(companyIds)
  905. if e != nil {
  906. err = errors.New("GetWxUserisMakerByCompanyIds, Err: " + e.Error())
  907. return
  908. }
  909. mapCompanyUserNum := make(map[int]int) //企业对应的用户数量
  910. for _, v := range listCompanyUserNum {
  911. mapCompanyUserNum[v.CompanyId] = v.UserNum
  912. }
  913. lencompanyId := len(companyIds)
  914. //研选阅读明细
  915. var conditionBill string
  916. var parsBill []interface{}
  917. var startWeekDate = time.Now().AddDate(0, 0, -75).Format(utils.FormatDate) + " 23:59:59"
  918. conditionBill = " AND company_id IN (" + utils.GetOrmInReplace(lencompanyId) + ") AND view_time > ? "
  919. parsBill = append(parsBill, companyIds, startWeekDate)
  920. listBillByYanxuanspecial, e := rai_serve.GetCygxRaiServeBillListAll(conditionBill, parsBill)
  921. if e != nil {
  922. err = errors.New("GetCygxRaiServeBillListAll, Err: " + e.Error())
  923. return
  924. }
  925. mapWeekServeCount := make(map[string]float64)
  926. for _, v := range listBillByYanxuanspecial {
  927. mapWeekServeCount[fmt.Sprint("CID_", v.CompanyId, "WEEK_", v.WeekStartDate)] += v.ServeCount
  928. }
  929. fmt.Println(companyIds)
  930. var items []*rai_serve.CygxRaiServeWeekBill
  931. for _, v := range companyList {
  932. for i := 0; i < weeks; i++ {
  933. item := new(rai_serve.CygxRaiServeWeekBill)
  934. // 计算当前周的周一
  935. monday := now.AddDate(0, 0, -int(now.Weekday()-time.Monday)-i*7)
  936. // 计算当前周的周日
  937. sunday := monday.AddDate(0, 0, 6)
  938. item.WeekStartDate = monday.Format(utils.FormatDate)
  939. item.WeekEndDate = sunday.Format(utils.FormatDate)
  940. item.CompanyId = v.CompanyId
  941. item.CompanyName = v.CompanyName
  942. item.UserTotal = mapCompanyUserNum[v.CompanyId]
  943. item.WeekServeCount = mapWeekServeCount[fmt.Sprint("CID_", v.CompanyId, "WEEK_", item.WeekStartDate)]
  944. if mapCompanyUserNum[v.CompanyId] > 0 {
  945. item.CoverageRate = item.WeekServeCount / float64(mapCompanyUserNum[v.CompanyId]) * 100
  946. }
  947. item.CreateTime = time.Now()
  948. item.ModifyTime = time.Now()
  949. items = append(items, item)
  950. }
  951. }
  952. e = rai_serve.AddCygxRaiServeWeekBillMulti(items)
  953. if e != nil {
  954. err = errors.New("AddCygxRaiServeWeekBillMulti, Err: " + e.Error())
  955. return
  956. }
  957. return
  958. }
  959. func UpdateCygxRaiServeBillWeekTask() (err error) {
  960. defer func() {
  961. if err != nil {
  962. fmt.Println(err)
  963. go utils.SendAlarmMsg("批量更新企业服务明细记录失败: UpdateCygxRaiServeBillByCompanyIds Err"+err.Error(), 2)
  964. }
  965. }()
  966. fmt.Println("UpdateCygxRaiServeBillWeekTask start")
  967. now := time.Now()
  968. weeks := 11
  969. companyList, e := rai_serve.GetCygxRaiServeCompanyAllList()
  970. if e != nil {
  971. err = errors.New("GetCygxRaiServeCompanyAllList, Err: " + e.Error())
  972. return
  973. }
  974. var companyIds []int
  975. for _, v := range companyList {
  976. companyIds = append(companyIds, v.CompanyId)
  977. }
  978. listCompanyUserNum, e := models.GetWxUserNumByCompanyIds(companyIds)
  979. if e != nil {
  980. err = errors.New("GetWxUserisMakerByCompanyIds, Err: " + e.Error())
  981. return
  982. }
  983. mapCompanyUserNum := make(map[int]int) //企业对应的用户数量
  984. for _, v := range listCompanyUserNum {
  985. mapCompanyUserNum[v.CompanyId] = v.UserNum
  986. }
  987. lencompanyId := len(companyIds)
  988. if lencompanyId == 0 {
  989. return
  990. }
  991. //明细
  992. var conditionBill string
  993. var parsBill []interface{}
  994. var startWeekDate = time.Now().AddDate(0, 0, -75).Format(utils.FormatDate) + " 23:59:59"
  995. conditionBill = " AND company_id IN (" + utils.GetOrmInReplace(lencompanyId) + ") AND view_time > ? "
  996. parsBill = append(parsBill, companyIds, startWeekDate)
  997. listBill, e := rai_serve.GetCygxRaiServeBillListAll(conditionBill, parsBill)
  998. if e != nil {
  999. err = errors.New("GetCygxRaiServeBillListAll, Err: " + e.Error())
  1000. return
  1001. }
  1002. mapWeekServeCount := make(map[string]float64)
  1003. for _, v := range listBill {
  1004. mapWeekServeCount[fmt.Sprint("CID_", v.CompanyId, "WEEK_", v.WeekStartDate)] += v.ServeCount
  1005. }
  1006. var conditionWeek string
  1007. var parsWeek []interface{}
  1008. conditionWeek = ` AND week_start_date > ? `
  1009. parsWeek = append(parsWeek, startWeekDate)
  1010. listWeekBill, e := rai_serve.GetCygxRaiServeWeekBillListAll(conditionWeek, parsWeek)
  1011. if e != nil {
  1012. err = errors.New("GetCygxRaiServeWeekBillListAll, Err: " + e.Error())
  1013. return
  1014. }
  1015. //return
  1016. mapWeekbill := make(map[string]bool)
  1017. mapWeekbill2 := make(map[string]int)
  1018. mapWeekbillUserTotal := make(map[string]int)
  1019. mapWeekbillWeekServeCount := make(map[string]float64)
  1020. mapWeekbillWeekCoverageRate := make(map[string]float64)
  1021. for _, v := range listWeekBill {
  1022. mapWeekbill[fmt.Sprint("CID_", v.CompanyId, "WEEK_", v.WeekStartDate)] = true
  1023. mapWeekbill2[fmt.Sprint("CID_", v.CompanyId, "WEEK_", v.WeekStartDate)] = v.CompanyId
  1024. mapWeekbillUserTotal[fmt.Sprint("CID_", v.CompanyId, "WEEK_", v.WeekStartDate)] = v.UserTotal
  1025. mapWeekbillWeekServeCount[fmt.Sprint("CID_", v.CompanyId, "WEEK_", v.WeekStartDate)] = v.WeekServeCount
  1026. mapWeekbillWeekCoverageRate[fmt.Sprint("CID_", v.CompanyId, "WEEK_", v.WeekStartDate)] = v.CoverageRate
  1027. }
  1028. var items []*rai_serve.CygxRaiServeWeekBill
  1029. var itemsUpdate []*rai_serve.CygxRaiServeWeekBill
  1030. for _, v := range companyList {
  1031. for i := 0; i < weeks; i++ {
  1032. if i == 10 {
  1033. continue
  1034. }
  1035. item := new(rai_serve.CygxRaiServeWeekBill)
  1036. // 计算当前周的周一
  1037. monday := now.AddDate(0, 0, -int(now.Weekday()-time.Monday)-i*7)
  1038. // 计算当前周的周日
  1039. sunday := monday.AddDate(0, 0, 6)
  1040. item.WeekStartDate = monday.Format(utils.FormatDate)
  1041. item.WeekEndDate = sunday.Format(utils.FormatDate)
  1042. item.CompanyId = v.CompanyId
  1043. item.CompanyName = v.CompanyName
  1044. //超过本周的,互动总人数不做修改
  1045. if i > 0 && mapWeekbillUserTotal[fmt.Sprint("CID_", v.CompanyId, "WEEK_", item.WeekStartDate)] > 0 {
  1046. item.UserTotal = mapWeekbillUserTotal[fmt.Sprint("CID_", v.CompanyId, "WEEK_", item.WeekStartDate)]
  1047. } else {
  1048. item.UserTotal = mapCompanyUserNum[v.CompanyId]
  1049. }
  1050. item.WeekServeCount = mapWeekServeCount[fmt.Sprint("CID_", v.CompanyId, "WEEK_", item.WeekStartDate)]
  1051. if mapCompanyUserNum[v.CompanyId] > 0 {
  1052. item.CoverageRate = item.WeekServeCount / float64(mapCompanyUserNum[v.CompanyId]) * 100
  1053. }
  1054. item.CreateTime = time.Now()
  1055. item.ModifyTime = time.Now()
  1056. if mapWeekbill[fmt.Sprint("CID_", v.CompanyId, "WEEK_", item.WeekStartDate)] {
  1057. if mapWeekbillUserTotal[fmt.Sprint("CID_", v.CompanyId, "WEEK_", item.WeekStartDate)] == item.UserTotal && mapWeekbillWeekServeCount[fmt.Sprint("CID_", v.CompanyId, "WEEK_", item.WeekStartDate)] == item.WeekServeCount {
  1058. continue // 如果互动量相等,且人数相等,就不修改
  1059. }
  1060. itemsUpdate = append(itemsUpdate, item)
  1061. } else {
  1062. items = append(items, item)
  1063. }
  1064. }
  1065. }
  1066. fmt.Println("itemsadd", len(items))
  1067. if len(items) > 0 {
  1068. e = rai_serve.AddCygxRaiServeWeekBillMulti(items)
  1069. if e != nil {
  1070. err = errors.New("AddCygxRaiServeWeekBillMulti, Err: " + e.Error())
  1071. return
  1072. }
  1073. }
  1074. fmt.Println("itemsUpdate111", len(itemsUpdate))
  1075. if len(itemsUpdate) > 0 {
  1076. e = rai_serve.UpdateCygxRaiServeWeekBillMulti(itemsUpdate)
  1077. if e != nil {
  1078. err = errors.New("AddCygxRaiServeWeekBillMulti, Err: " + e.Error())
  1079. return
  1080. }
  1081. }
  1082. fmt.Println("UpdateCygxRaiServeBillWeekTask end")
  1083. return
  1084. }
  1085. //func init() {
  1086. // UpdateWeekAvg()
  1087. //}
  1088. // 更新最近四周平均覆盖率,是否标红,权限,时间,金额
  1089. func UpdateWeekAvg() (err error) {
  1090. defer func() {
  1091. if err != nil {
  1092. fmt.Println(err)
  1093. go utils.SendAlarmMsg("批量更新企业服务明细记录失败: UpdateCygxRaiServeBillByCompanyIds Err"+err.Error(), 2)
  1094. }
  1095. }()
  1096. fmt.Println(" UpdateWeekAvg start")
  1097. now := time.Now()
  1098. weeks := 3
  1099. monday := now.AddDate(0, 0, -int(now.Weekday()-time.Monday)-weeks*7)
  1100. startDate := monday.Format(utils.FormatDate)
  1101. var condition string
  1102. var pars []interface{}
  1103. condition = ` AND week_start_date >= ? `
  1104. pars = append(pars, startDate)
  1105. listWeekBill, e := rai_serve.GetCygxRaiServeWeekBillListAll(condition, pars)
  1106. if e != nil {
  1107. err = errors.New("GetCygxRaiServeWeekBillListAll, Err: " + e.Error())
  1108. return
  1109. }
  1110. mapWeekServeCount := make(map[int]float64) //四周平均率总合
  1111. for _, v := range listWeekBill {
  1112. mapWeekServeCount[v.CompanyId] += v.CoverageRate
  1113. }
  1114. //获取近四周含有Kp 的公司
  1115. condition = ""
  1116. pars = make([]interface{}, 0)
  1117. condition += ` AND week_start_date >= ? AND is_kp = 1 GROUP BY company_id `
  1118. pars = append(pars, startDate)
  1119. listIsKpWeekBill, e := rai_serve.GetCygxRaiServeBillListAll(condition, pars)
  1120. if e != nil {
  1121. err = errors.New("GetCygxRaiServeWeekBillListAll, Err: " + e.Error())
  1122. return
  1123. }
  1124. mapWeekIsKp := make(map[int]bool) //最近四周是否包含KP
  1125. for _, v := range listIsKpWeekBill {
  1126. mapWeekIsKp[v.CompanyId] = true
  1127. }
  1128. companyList, e := rai_serve.GetCygxRaiServeCompanyAllList()
  1129. if e != nil {
  1130. err = errors.New("GetCygxRaiServeCompanyAllList, Err: " + e.Error())
  1131. return
  1132. }
  1133. var formalCompanyIds []int // 当前正式客户ID
  1134. var formalNoCompanyIds []int // 当前非正式客户ID
  1135. //永续客户当做正式客户处理
  1136. for _, v := range companyList {
  1137. if v.Status == "正式" || v.Status == "永续" {
  1138. formalCompanyIds = append(formalCompanyIds, v.CompanyId)
  1139. } else {
  1140. formalNoCompanyIds = append(formalNoCompanyIds, v.CompanyId)
  1141. }
  1142. }
  1143. var itemsUpdate []*rai_serve.CygxRaiServeCompany
  1144. if len(formalCompanyIds) > 0 { //正式客户信息
  1145. condition = ""
  1146. pars = make([]interface{}, 0)
  1147. condition = ` AND product_id = 2 AND company_id IN (` + utils.GetOrmInReplace(len(formalCompanyIds)) + `) AND status = 1 AND end_date > ? `
  1148. pars = append(pars, formalCompanyIds, time.Now())
  1149. listCompanyContract, e := company.GetCompanyContractList(condition, pars)
  1150. if e != nil {
  1151. err = errors.New("GetCompanyContractList, Err: " + e.Error())
  1152. return
  1153. }
  1154. companyMoney := make(map[int]float64)
  1155. for _, v := range listCompanyContract {
  1156. companyMoney[v.CompanyId] += v.Money
  1157. }
  1158. permissionNameMapByCompanyId, e := GetCompanyReportPermissionNameMapByCompanyId(formalCompanyIds)
  1159. if e != nil {
  1160. err = errors.New("GetCompanyReportPermissionNameMapByCompanyId, Err: " + e.Error())
  1161. return
  1162. }
  1163. for _, v := range formalCompanyIds {
  1164. item := new(rai_serve.CygxRaiServeCompany)
  1165. item.CompanyId = v
  1166. item.Money = companyMoney[v]
  1167. item.PermissionName = permissionNameMapByCompanyId[v]
  1168. item.ServeCoverageRate = utils.SubFloatToString(mapWeekServeCount[v]/4, 2)
  1169. item.IsUserMaker = -1
  1170. if mapWeekIsKp[v] {
  1171. item.IsUserMaker = 1
  1172. }
  1173. itemsUpdate = append(itemsUpdate, item)
  1174. }
  1175. }
  1176. //正式客户数据修改
  1177. e = rai_serve.UpdateCygxRaiServeCompanyMulti(itemsUpdate)
  1178. if e != nil {
  1179. err = errors.New("UpdateCygxRaiServeCompanyMulti, Err: " + e.Error())
  1180. return
  1181. }
  1182. var itemsUpdateFormalNo []*rai_serve.CygxRaiServeCompany //非正式客户数据修改
  1183. var itemsUpdateFormalNoContract []*rai_serve.CygxRaiServeCompany //非正式客户没有合同的客户修改
  1184. mapContractCompanyIds := make(map[int]bool) //签过合同的试用客户ID
  1185. if len(formalNoCompanyIds) > 0 { //非正式客户信息
  1186. condition = ""
  1187. pars = make([]interface{}, 0)
  1188. condition = ` AND product_id = 2 AND company_id IN (` + utils.GetOrmInReplace(len(formalNoCompanyIds)) + `) AND status = 1 AND end_date < ? GROUP BY company_id ORDER BY company_contract_id DESC `
  1189. pars = append(pars, formalNoCompanyIds, time.Now())
  1190. listCompanyContractLastId, e := company.GetCompanyContractLastList(condition, pars) //获取关联的最后一笔合同信息
  1191. if e != nil {
  1192. err = errors.New("GetCompanyContractLastList, Err: " + e.Error())
  1193. return
  1194. }
  1195. var companyContractIds []int
  1196. for _, v := range listCompanyContractLastId {
  1197. companyContractIds = append(companyContractIds, v.CompanyContractId)
  1198. }
  1199. condition = ""
  1200. pars = make([]interface{}, 0)
  1201. condition = ` AND product_id = 2 AND company_id IN (` + utils.GetOrmInReplace(len(formalNoCompanyIds)) + `) AND status = 1 AND company_contract_id IN (` + utils.GetOrmInReplace(len(companyContractIds)) + `) AND end_date < ? GROUP BY company_id ORDER BY company_contract_id DESC `
  1202. pars = append(pars, formalNoCompanyIds, companyContractIds, time.Now())
  1203. listCompanyContractLast, e := company.GetCompanyContractList(condition, pars)
  1204. if e != nil {
  1205. err = errors.New("GetCompanyContractList, Err: " + e.Error())
  1206. return
  1207. }
  1208. permissionNameMapByContractId, e := GetCompanyContractPermissionNameMapById(companyContractIds)
  1209. if e != nil {
  1210. err = errors.New("GetCompanyReportPermissionNameMapByCompanyId, Err: " + e.Error())
  1211. return
  1212. }
  1213. for _, v := range listCompanyContractLast {
  1214. item := new(rai_serve.CygxRaiServeCompany)
  1215. item.CompanyId = v.CompanyId
  1216. item.Money = v.Money
  1217. item.StartDate = v.StartDate
  1218. item.EndDate = v.EndDate
  1219. item.ServeCoverageRate = utils.SubFloatToString(mapWeekServeCount[v.CompanyId]/4, 2)
  1220. item.IsUserMaker = -1
  1221. if mapWeekIsKp[v.CompanyId] {
  1222. item.IsUserMaker = 1
  1223. }
  1224. item.PermissionName = permissionNameMapByContractId[v.CompanyContractId]
  1225. itemsUpdateFormalNo = append(itemsUpdateFormalNo, item)
  1226. mapContractCompanyIds[v.CompanyId] = true
  1227. }
  1228. for _, v := range formalNoCompanyIds {
  1229. if mapContractCompanyIds[v] {
  1230. continue
  1231. }
  1232. //fmt.Println(v)
  1233. item := new(rai_serve.CygxRaiServeCompany)
  1234. item.CompanyId = v
  1235. item.ServeCoverageRate = utils.SubFloatToString(mapWeekServeCount[v]/4, 2)
  1236. item.IsUserMaker = -1
  1237. if mapWeekIsKp[v] {
  1238. item.IsUserMaker = 1
  1239. }
  1240. itemsUpdateFormalNoContract = append(itemsUpdateFormalNoContract, item)
  1241. }
  1242. }
  1243. e = rai_serve.UpdateCygxRaiServeCompanyFormalNoMulti(itemsUpdateFormalNo)
  1244. if e != nil {
  1245. err = errors.New("UpdateCygxRaiServeCompanyFormalNoMulti, Err: " + e.Error())
  1246. return
  1247. }
  1248. e = rai_serve.UpdateCygxRaiServeCompanyFormalNoContractMulti(itemsUpdateFormalNoContract)
  1249. if e != nil {
  1250. err = errors.New("UpdateCygxRaiServeCompanyFormalNoMulti, Err: " + e.Error())
  1251. return
  1252. }
  1253. fmt.Println(" UpdateWeekAvg end")
  1254. return
  1255. }