rai_serve_count.go 47 KB

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