rai_serve_count.go 58 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667
  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. //func init() {
  387. // UpdateCygxRaiServeBillByCompanyIds()
  388. //}
  389. // 批量更新企业服务明细记录
  390. func UpdateCygxRaiServeBillByCompanyIds() (err error) {
  391. defer func() {
  392. if err != nil {
  393. fmt.Println(err)
  394. go utils.SendAlarmMsg("批量更新企业服务明细记录失败: UpdateCygxRaiServeBillByCompanyIds Err"+err.Error(), 2)
  395. }
  396. }()
  397. var delBillIds []int
  398. var startWeekDate = time.Now().AddDate(0, 0, -75).Format(utils.FormatDate) + " 23:59:59"
  399. fmt.Println("UpdateCygxRaiServeBillByCompanyIds start")
  400. companyList, e := rai_serve.GetCygxRaiServeCompanyAllList()
  401. if e != nil {
  402. err = errors.New("GetCygxRaiServeCompanyAllList, Err: " + e.Error())
  403. return
  404. }
  405. var companyIds []int
  406. var items []*rai_serve.CygxRaiServeBill
  407. for _, v := range companyList {
  408. companyIds = append(companyIds, v.CompanyId)
  409. }
  410. lencompanyId := len(companyIds)
  411. listisMakeruser, e := models.GetWxUserisMakerByCompanyIds(companyIds)
  412. if e != nil {
  413. err = errors.New("GetWxUserisMakerByCompanyIds, Err: " + e.Error())
  414. return
  415. }
  416. mapUserMaker := make(map[int]bool)
  417. mapUserMobileUserId := make(map[string]int)
  418. for _, v := range listisMakeruser {
  419. mapUserMaker[v.UserId] = true
  420. mapUserMobileUserId[v.Mobile] = v.UserId
  421. }
  422. var condition string
  423. var pars []interface{}
  424. condition = " AND art.company_id IN (" + utils.GetOrmInReplace(lencompanyId) + ") AND art.create_time > ? "
  425. pars = append(pars, companyIds, startWeekDate)
  426. fmt.Println("startWeekDate", startWeekDate)
  427. //研选专栏阅读记录内容
  428. {
  429. listYanxuanSpecialRecord, e := models.GetCygxYanxuanSpecialRecordRespListAll(condition+" GROUP BY art.user_id, art.yanxuan_special_id ORDER BY art.create_time ASC ", pars)
  430. if e != nil {
  431. err = errors.New("GetCygxYanxuanSpecialRecordRespListAll, Err: " + e.Error())
  432. return
  433. }
  434. var yanxuanspecialIds []int
  435. for _, v := range listYanxuanSpecialRecord {
  436. yanxuanspecialIds = append(yanxuanspecialIds, v.YanxuanSpecialId)
  437. }
  438. var conditionYanxuanSpecial string
  439. var parsYanxuanSpecial []interface{}
  440. conditionYanxuanSpecial += ` AND id IN (` + utils.GetOrmInReplace(len(yanxuanspecialIds)) + `) `
  441. parsYanxuanSpecial = append(parsYanxuanSpecial, yanxuanspecialIds)
  442. listYanxuanSpecial, e := models.GetYanxuanSpecialListBycondition(conditionYanxuanSpecial, parsYanxuanSpecial, 0, len(yanxuanspecialIds))
  443. if e != nil && e.Error() != utils.ErrNoRow() {
  444. err = errors.New("GetYanxuanSpecialListBycondition, Err: " + e.Error())
  445. return
  446. }
  447. mapYanxuanSpecialTitle := make(map[int]string)
  448. for _, v := range listYanxuanSpecial {
  449. mapYanxuanSpecialTitle[v.Id] = v.Title
  450. }
  451. //研选阅读明细
  452. var conditionBill string
  453. var parsBill []interface{}
  454. conditionBill = " AND source = 'yanxuanspecial' AND company_id IN (" + utils.GetOrmInReplace(lencompanyId) + ") AND view_time > ? "
  455. parsBill = append(parsBill, companyIds, startWeekDate)
  456. listBillByYanxuanspecial, e := rai_serve.GetCygxRaiServeBillListAll(conditionBill, parsBill)
  457. if e != nil {
  458. err = errors.New("GetCygxRaiServeBillListAll, Err: " + e.Error())
  459. return
  460. }
  461. mapYanxuanspecialBill := make(map[string]bool)
  462. for _, v := range listBillByYanxuanspecial {
  463. mapYanxuanspecialBill[fmt.Sprint("UID_", v.UserId, "SID_", v.SourceId)] = true
  464. }
  465. for _, v := range listYanxuanSpecialRecord {
  466. if mapYanxuanspecialBill[fmt.Sprint("UID_", v.UserId, "SID_", v.YanxuanSpecialId)] { // 如果内容存在就不插入
  467. continue
  468. }
  469. item := new(rai_serve.CygxRaiServeBill)
  470. item.Content = mapYanxuanSpecialTitle[v.YanxuanSpecialId]
  471. item.ServeTypeId = 5
  472. item.ServeTypeName = "阅读uv"
  473. item.UserId = v.UserId
  474. item.Mobile = v.Mobile
  475. item.Email = v.Email
  476. item.CompanyId = v.CompanyId
  477. item.CompanyName = v.CompanyName
  478. item.RealName = v.RealName
  479. item.RegisterPlatform = v.RegisterPlatform
  480. item.ServeCount = 0.5
  481. if mapUserMaker[v.UserId] {
  482. item.IsKp = 1
  483. item.ServeCount = item.ServeCount * 3
  484. }
  485. item.SourceId = v.YanxuanSpecialId
  486. item.Source = utils.CYGX_OBJ_YANXUANSPECIAL
  487. item.CreateTime = time.Now()
  488. item.ViewTime = v.CreateTime
  489. item.WeekStartDate, item.WeekEndDate = utils.GetMondayAndSundayByTimeString(item.ViewTime)
  490. item.MonthStartDate, item.MonthEndDate = utils.GetFirstAndLastDayOfMonth(item.ViewTime)
  491. items = append(items, item)
  492. }
  493. }
  494. //研选专栏阅读记录内容end
  495. //文章阅读记录内容
  496. {
  497. listArticleRecord, e := models.GetCygxArticleHistoryRecordAllListNoLimit(condition+" GROUP BY art.user_id, art.article_id ORDER BY art.create_time ASC ", pars)
  498. if e != nil {
  499. err = errors.New("GetCygxArticleHistoryRecordAllListNoLimit, Err: " + e.Error())
  500. return
  501. }
  502. //文章阅读明细
  503. var conditionBill string
  504. var parsBill []interface{}
  505. conditionBill = " AND source = 'article' AND company_id IN (" + utils.GetOrmInReplace(lencompanyId) + ") AND view_time > ? "
  506. parsBill = append(parsBill, companyIds, startWeekDate)
  507. listBillByArticle, e := rai_serve.GetCygxRaiServeBillListAll(conditionBill, parsBill)
  508. if e != nil {
  509. err = errors.New("GetCygxRaiServeBillListAll, Err: " + e.Error())
  510. return
  511. }
  512. mapArticleBill := make(map[string]bool)
  513. for _, v := range listBillByArticle {
  514. mapArticleBill[fmt.Sprint("UID_", v.UserId, "SID_", v.SourceId)] = true
  515. }
  516. //部分数据来源没有存用户姓名,重新查一下
  517. var userIds []int
  518. for _, v := range listArticleRecord {
  519. userIds = append(userIds, v.UserId)
  520. }
  521. ListUser, e := models.GetWxUserListByUserIdsArr(userIds)
  522. if e != nil {
  523. err = errors.New("GetWxUserListByUserIdsArr, Err: " + e.Error())
  524. return
  525. }
  526. mapUserName := make(map[int]string)
  527. for _, v := range ListUser {
  528. mapUserName[v.UserId] = v.RealName
  529. }
  530. for _, v := range listArticleRecord {
  531. if mapArticleBill[fmt.Sprint("UID_", v.UserId, "SID_", v.ArticleId)] { // 如果内容存在就不插入
  532. continue
  533. }
  534. item := new(rai_serve.CygxRaiServeBill)
  535. item.Content = v.Title
  536. item.ServeTypeId = 5
  537. item.ServeTypeName = "阅读uv"
  538. item.UserId = v.UserId
  539. item.Mobile = v.Mobile
  540. item.Email = v.Email
  541. item.CompanyId = v.CompanyId
  542. item.CompanyName = v.CompanyName
  543. item.RealName = mapUserName[v.UserId]
  544. item.RegisterPlatform = v.RegisterPlatform
  545. item.ServeCount = 0.5
  546. if mapUserMaker[v.UserId] {
  547. item.IsKp = 1
  548. item.ServeCount = item.ServeCount * 3
  549. }
  550. item.SourceId = v.ArticleId
  551. item.Source = utils.CYGX_OBJ_ARTICLE
  552. item.CreateTime = time.Now()
  553. item.ViewTime = v.CreateTime
  554. item.WeekStartDate, item.WeekEndDate = utils.GetMondayAndSundayByTimeString(item.ViewTime)
  555. item.MonthStartDate, item.MonthEndDate = utils.GetFirstAndLastDayOfMonth(item.ViewTime)
  556. if strings.Contains(v.CategoryName, "固收") {
  557. item.ChartPermissionName = utils.GU_SHOU_NAME
  558. item.ChartPermissionId = utils.GU_SHOU_ID_CHART
  559. }
  560. if strings.Contains(v.CategoryName, "策略") {
  561. item.ChartPermissionName = utils.CE_LUE_NAME
  562. item.ChartPermissionId = utils.CE_LUE_ID
  563. }
  564. items = append(items, item)
  565. }
  566. }
  567. //文章阅读记录内容 end
  568. //活动记录内容
  569. {
  570. condition = " AND art.company_id IN (" + utils.GetOrmInReplace(lencompanyId) + ") AND a.activity_time > ? "
  571. signUpDetailList, e := models.GetSignupDetailBySignupjoinactivity(condition+" ORDER BY a.activity_time ASC ", pars)
  572. if e != nil {
  573. err = errors.New("GetSignupDetailBySignupjoinactivity, Err: " + e.Error())
  574. return
  575. }
  576. //文章阅读明细
  577. var conditionBill string
  578. var parsBill []interface{}
  579. conditionBill = " AND source = 'activity' AND company_id IN (" + utils.GetOrmInReplace(lencompanyId) + ") AND view_time > ? "
  580. parsBill = append(parsBill, companyIds, startWeekDate)
  581. listBillByActivity, e := rai_serve.GetCygxRaiServeBillListAll(conditionBill, parsBill)
  582. if e != nil {
  583. err = errors.New("GetCygxRaiServeBillListAll, Err: " + e.Error())
  584. return
  585. }
  586. mapActivityeBill := make(map[string]bool)
  587. for _, v := range listBillByActivity {
  588. mapActivityeBill[fmt.Sprint("UID_", v.Mobile, "SID_", v.SourceId)] = true
  589. }
  590. mapArticleBillDel := make(map[string]bool)
  591. for _, v := range signUpDetailList {
  592. mapArticleBillDel[fmt.Sprint("UID_", v.UserId, "SID_", v.ActivityId)] = true
  593. }
  594. mapDelActivityBillDel := make(map[string]bool)
  595. for _, v := range signUpDetailList {
  596. mapDelActivityBillDel[fmt.Sprint("UID_", v.UserId, "SID_", v.ActivityId)] = true
  597. }
  598. for _, v := range listBillByActivity {
  599. if !mapDelActivityBillDel[fmt.Sprint("UID_", v.UserId, "SID_", v.SourceId)] { // 如果内容存在就插入删除ID中
  600. delBillIds = append(delBillIds, v.BillId)
  601. }
  602. }
  603. for _, v := range signUpDetailList {
  604. if v.UserId == 0 && v.Mobile != "" {
  605. v.UserId = mapUserMobileUserId[v.Mobile] // 空降的部分联系人 userid 为0这里做一下修复
  606. }
  607. if mapActivityeBill[fmt.Sprint("UID_", v.Mobile, "SID_", v.ActivityId)] { // 如果内容存在就不插入
  608. continue
  609. }
  610. item := new(rai_serve.CygxRaiServeBill)
  611. item.Content = v.ActivityName
  612. if v.ActivityType == 1 {
  613. item.ServeTypeId = 1
  614. item.ServeTypeName = "线上活动"
  615. } else {
  616. item.ServeTypeId = 2
  617. item.ServeTypeName = "线下活动"
  618. }
  619. item.UserId = v.UserId
  620. item.Mobile = v.Mobile
  621. item.Email = v.Email
  622. item.CompanyId = v.CompanyId
  623. item.CompanyName = v.CompanyName
  624. item.RealName = v.RealName
  625. //item.RegisterPlatform = v.RegisterPlatform
  626. item.ServeCount = 1
  627. if mapUserMaker[v.UserId] {
  628. item.IsKp = 1
  629. item.ServeCount = item.ServeCount * 3
  630. }
  631. item.SourceId = v.ActivityId
  632. item.Source = utils.CYGX_OBJ_ACTIVITY
  633. item.CreateTime = time.Now()
  634. item.ViewTime = v.ActivityTime
  635. item.ChartPermissionName = v.ChartPermissionName
  636. item.ChartPermissionId = v.ChartPermissionId
  637. item.WeekStartDate, item.WeekEndDate = utils.GetMondayAndSundayByTimeString(item.ViewTime)
  638. item.MonthStartDate, item.MonthEndDate = utils.GetFirstAndLastDayOfMonth(item.ViewTime)
  639. items = append(items, item)
  640. }
  641. }
  642. //活动记录内容 end
  643. //专项调研活动记录内容
  644. {
  645. condition = " AND art.company_id IN (" + utils.GetOrmInReplace(lencompanyId) + ") AND a.activity_time > ? "
  646. activitySpecialList, e := models.GetCygxActivitySpecialMeetingDetailList(condition+" ORDER BY a.activity_time ASC ", pars)
  647. if e != nil {
  648. err = errors.New("GetCygxActivitySpecialMeetingDetailList, Err: " + e.Error())
  649. return
  650. }
  651. //专项调研活动明细
  652. var conditionBill string
  653. var parsBill []interface{}
  654. conditionBill = " AND source = 'activityspecial' AND company_id IN (" + utils.GetOrmInReplace(lencompanyId) + ") AND view_time > ? "
  655. parsBill = append(parsBill, companyIds, startWeekDate)
  656. listBillByActivitySpecial, e := rai_serve.GetCygxRaiServeBillListAll(conditionBill, parsBill)
  657. if e != nil {
  658. err = errors.New("GetCygxRaiServeBillListAll, Err: " + e.Error())
  659. return
  660. }
  661. mapActivitySpecial := make(map[string]bool)
  662. for _, v := range listBillByActivitySpecial {
  663. mapActivitySpecial[fmt.Sprint("UID_", v.UserId, "SID_", v.SourceId)] = true
  664. }
  665. mapDelActivitySpecial := make(map[string]bool)
  666. for _, v := range activitySpecialList {
  667. mapDelActivitySpecial[fmt.Sprint("UID_", v.UserId, "SID_", v.ActivityId)] = true
  668. }
  669. for _, v := range listBillByActivitySpecial {
  670. if !mapDelActivitySpecial[fmt.Sprint("UID_", v.UserId, "SID_", v.SourceId)] { // 如果内容存在就插入删除ID中
  671. delBillIds = append(delBillIds, v.BillId)
  672. }
  673. }
  674. for _, v := range activitySpecialList {
  675. if mapActivitySpecial[fmt.Sprint("UID_", v.UserId, "SID_", v.ActivityId)] { // 如果内容存在就不插入
  676. continue
  677. }
  678. item := new(rai_serve.CygxRaiServeBill)
  679. item.Content = v.ResearchTheme
  680. item.ServeTypeId = 3
  681. item.ServeTypeName = "专项调研"
  682. item.UserId = v.UserId
  683. item.Mobile = v.Mobile
  684. item.Email = v.Email
  685. item.CompanyId = v.CompanyId
  686. item.CompanyName = v.CompanyName
  687. item.RealName = v.RealName
  688. //item.RegisterPlatform = v.RegisterPlatform
  689. item.ServeCount = 1
  690. if mapUserMaker[v.UserId] {
  691. item.IsKp = 1
  692. item.ServeCount = item.ServeCount * 3
  693. }
  694. item.SourceId = v.ActivityId
  695. item.Source = utils.CYGX_OBJ_ACTIVITYSPECIAL
  696. item.CreateTime = time.Now()
  697. item.ViewTime = v.ActivityTime
  698. item.ChartPermissionName = v.ChartPermissionName
  699. item.ChartPermissionId = v.ChartPermissionId
  700. item.WeekStartDate, item.WeekEndDate = utils.GetMondayAndSundayByTimeString(item.ViewTime)
  701. item.MonthStartDate, item.MonthEndDate = utils.GetFirstAndLastDayOfMonth(item.ViewTime)
  702. items = append(items, item)
  703. }
  704. }
  705. //专项调研活动记录内容 end
  706. //1v1路演
  707. {
  708. condition = " AND art.company_id IN (" + utils.GetOrmInReplace(lencompanyId) + ") AND rs.start_date > ? "
  709. calendarMeetingUserList, e := roadshow.GetRsCalendarMeetingUserList(condition+" ORDER BY rs.start_date ASC ", pars)
  710. if e != nil {
  711. err = errors.New("GetRsCalendarMeetingUserList, Err: " + e.Error())
  712. return
  713. }
  714. var rsCalendarIds []int
  715. for _, v := range calendarMeetingUserList {
  716. rsCalendarIds = append(rsCalendarIds, v.RsCalendarId)
  717. }
  718. //获取研究员信息
  719. researchers, e := roadshow.GetRsCalendarResearcherListByIds(rsCalendarIds)
  720. if e != nil {
  721. err = errors.New("GetRsCalendarResearcherListByIds, Err: " + e.Error())
  722. return
  723. }
  724. mapResearcherName := make(map[int][]string)
  725. for _, v := range researchers {
  726. mapResearcherName[v.RsCalendarId] = append(mapResearcherName[v.RsCalendarId], v.ResearcherName)
  727. }
  728. listEmail, e := models.GetAskEmail()
  729. if e != nil {
  730. err = errors.New("GetAskEmail, Err: " + e.Error())
  731. return
  732. }
  733. var ceLueResearcherName []string
  734. var guShouResearcherName []string
  735. for _, v := range listEmail {
  736. if v.ChartPermissionName == utils.CE_LUE_NAME {
  737. ceLueResearcherName = append(ceLueResearcherName, v.Name)
  738. }
  739. if v.ChartPermissionName == utils.GU_SHOU_NAME {
  740. guShouResearcherName = append(guShouResearcherName, v.Name)
  741. }
  742. }
  743. //专项调研活动明细
  744. var conditionBill string
  745. var parsBill []interface{}
  746. conditionBill = " AND source = 'rscalendar' AND company_id IN (" + utils.GetOrmInReplace(lencompanyId) + ") AND view_time > ? "
  747. parsBill = append(parsBill, companyIds, startWeekDate)
  748. listBillByRscalendar, e := rai_serve.GetCygxRaiServeBillListAll(conditionBill, parsBill)
  749. if e != nil {
  750. err = errors.New("GetCygxRaiServeBillListAll, Err: " + e.Error())
  751. return
  752. }
  753. mapRscalendarBill := make(map[string]bool)
  754. for _, v := range listBillByRscalendar {
  755. mapRscalendarBill[fmt.Sprint("UID_", v.UserId, "SID_", v.SourceId)] = true
  756. }
  757. mapDelRscalendarBill := make(map[string]bool)
  758. for _, v := range calendarMeetingUserList {
  759. mapDelRscalendarBill[fmt.Sprint("UID_", v.UserId, "SID_", v.RsCalendarId)] = true
  760. }
  761. for _, v := range listBillByRscalendar {
  762. if !mapDelRscalendarBill[fmt.Sprint("UID_", v.UserId, "SID_", v.SourceId)] { // 如果内容存在就插入删除ID中
  763. delBillIds = append(delBillIds, v.BillId)
  764. }
  765. }
  766. for _, v := range calendarMeetingUserList {
  767. if mapRscalendarBill[fmt.Sprint("UID_", v.UserId, "SID_", v.RsCalendarId)] { // 如果内容存在就不插入
  768. continue
  769. }
  770. item := new(rai_serve.CygxRaiServeBill)
  771. item.Content = strings.Join(mapResearcherName[v.RsCalendarId], ",")
  772. item.ServeTypeId = 4
  773. item.ServeTypeName = "一对一路演"
  774. item.UserId = v.UserId
  775. item.Mobile = v.Mobile
  776. item.Email = v.Email
  777. item.CompanyId = v.CompanyId
  778. item.CompanyName = v.CompanyName
  779. item.RealName = v.RealName
  780. //item.RegisterPlatform = v.RegisterPlatform
  781. item.ServeCount = 1.5
  782. if mapUserMaker[v.UserId] {
  783. item.IsKp = 1
  784. item.ServeCount = item.ServeCount * 3
  785. }
  786. item.SourceId = v.RsCalendarId
  787. item.Source = utils.CYGX_OBJ_RS_CALENDAR
  788. item.CreateTime = time.Now()
  789. item.ViewTime = v.StartDate + " " + v.StartTime
  790. item.WeekStartDate, item.WeekEndDate = utils.GetMondayAndSundayByTimeString(item.ViewTime)
  791. item.MonthStartDate, item.MonthEndDate = utils.GetFirstAndLastDayOfMonth(item.ViewTime)
  792. if utils.InArrayByStr(guShouResearcherName, item.Content) {
  793. item.ChartPermissionName = utils.GU_SHOU_NAME
  794. item.ChartPermissionId = utils.GU_SHOU_ID_CHART
  795. }
  796. if utils.InArrayByStr(ceLueResearcherName, item.Content) {
  797. item.ChartPermissionName = utils.CE_LUE_NAME
  798. item.ChartPermissionId = utils.CE_LUE_ID
  799. }
  800. items = append(items, item)
  801. }
  802. }
  803. //1v1路演 end
  804. //交流反馈
  805. {
  806. condition = " AND company_id IN (" + utils.GetOrmInReplace(lencompanyId) + ") AND create_time > ? "
  807. userFeedbackList, e := rai_serve.GetCygxUserFeedbackList(condition+" ORDER BY user_feedback_id ASC ", pars)
  808. if e != nil {
  809. err = errors.New("GetCygxUserFeedbackList, Err: " + e.Error())
  810. return
  811. }
  812. //交流反馈明细
  813. var conditionBill string
  814. var parsBill []interface{}
  815. conditionBill = " AND source = 'userfeedback' AND company_id IN (" + utils.GetOrmInReplace(lencompanyId) + ") AND view_time > ? "
  816. parsBill = append(parsBill, companyIds, startWeekDate)
  817. listBillByuserFeedback, e := rai_serve.GetCygxRaiServeBillListAll(conditionBill, parsBill)
  818. if e != nil {
  819. err = errors.New("GetCygxRaiServeBillListAll, Err: " + e.Error())
  820. return
  821. }
  822. mapRscalendarBill := make(map[string]bool)
  823. for _, v := range listBillByuserFeedback {
  824. mapRscalendarBill[fmt.Sprint("UID_", v.UserId, "SID_", v.SourceId)] = true
  825. }
  826. mapDelRscalendarBill := make(map[string]bool)
  827. for _, v := range userFeedbackList {
  828. mapDelRscalendarBill[fmt.Sprint("UID_", v.UserId, "SID_", v.UserFeedbackId)] = true
  829. }
  830. for _, v := range listBillByuserFeedback {
  831. if !mapDelRscalendarBill[fmt.Sprint("UID_", v.UserId, "SID_", v.SourceId)] { // 如果内容存在就插入删除ID中
  832. delBillIds = append(delBillIds, v.BillId)
  833. }
  834. }
  835. for _, v := range userFeedbackList {
  836. if mapRscalendarBill[fmt.Sprint("UID_", v.UserId, "SID_", v.UserFeedbackId)] { // 如果内容存在就不插入
  837. continue
  838. }
  839. item := new(rai_serve.CygxRaiServeBill)
  840. item.Content = v.Content
  841. item.ServeTypeId = 6
  842. item.ServeTypeName = "交流反馈"
  843. item.UserId = v.UserId
  844. item.Mobile = v.Mobile
  845. item.Email = v.Email
  846. item.CompanyId = v.CompanyId
  847. item.CompanyName = v.CompanyName
  848. item.RealName = v.RealName
  849. item.ServeCount = 1
  850. if mapUserMaker[v.UserId] {
  851. item.IsKp = 1
  852. item.ServeCount = item.ServeCount * 3
  853. }
  854. item.SourceId = v.UserFeedbackId
  855. item.Source = utils.CYGX_OBJ_USER_FEEDBACK
  856. item.CreateTime = time.Now()
  857. item.ViewTime = v.CreateTime
  858. item.WeekStartDate, item.WeekEndDate = utils.GetMondayAndSundayByTimeString(item.ViewTime)
  859. item.MonthStartDate, item.MonthEndDate = utils.GetFirstAndLastDayOfMonth(item.ViewTime)
  860. items = append(items, item)
  861. }
  862. }
  863. //交流反馈 end
  864. //图表浏览记录
  865. {
  866. condition = " AND b.company_id IN (" + utils.GetOrmInReplace(lencompanyId) + ") AND b.create_time > ? GROUP BY b.record_id "
  867. userChartRecordList, e := models.GetCygxChartRecordListNoLimit(condition, pars)
  868. if e != nil {
  869. err = errors.New("GetCygxChartRecordListNoLimit, Err: " + e.Error())
  870. return
  871. }
  872. //图表浏览记录明细
  873. var conditionBill string
  874. var parsBill []interface{}
  875. conditionBill = " AND source = 'newchart' AND company_id IN (" + utils.GetOrmInReplace(lencompanyId) + ") AND view_time > ? "
  876. parsBill = append(parsBill, companyIds, startWeekDate)
  877. listBillByChart, e := rai_serve.GetCygxRaiServeBillListAll(conditionBill, parsBill)
  878. if e != nil {
  879. err = errors.New("GetCygxRaiServeBillListAll, Err: " + e.Error())
  880. return
  881. }
  882. mapRscalendarBill := make(map[string]bool)
  883. for _, v := range listBillByChart {
  884. mapRscalendarBill[fmt.Sprint("UID_", v.UserId, "SID_", v.RecordId)] = true
  885. }
  886. for _, v := range userChartRecordList {
  887. if mapRscalendarBill[fmt.Sprint("UID_", v.UserId, "SID_", v.RecordId)] { // 如果内容存在就不插入
  888. continue
  889. }
  890. item := new(rai_serve.CygxRaiServeBill)
  891. item.Content = v.Title
  892. item.ServeTypeId = 7
  893. item.ServeTypeName = "图表阅读uv"
  894. item.UserId = v.UserId
  895. item.Mobile = v.Mobile
  896. item.Email = v.Email
  897. item.CompanyId = v.CompanyId
  898. item.CompanyName = v.CompanyName
  899. item.RealName = v.RealName
  900. item.ServeCount = 0.5
  901. if mapUserMaker[v.UserId] {
  902. item.IsKp = 1
  903. item.ServeCount = item.ServeCount * 3
  904. }
  905. item.SourceId = v.ChartId
  906. item.RecordId = v.RecordId
  907. item.Source = utils.CYGX_OBJ_NEWCHART
  908. item.CreateTime = time.Now()
  909. item.ViewTime = v.CreateTime
  910. item.WeekStartDate, item.WeekEndDate = utils.GetMondayAndSundayByTimeString(item.ViewTime)
  911. item.MonthStartDate, item.MonthEndDate = utils.GetFirstAndLastDayOfMonth(item.ViewTime)
  912. items = append(items, item)
  913. }
  914. }
  915. //图表浏览记录 end
  916. //活动音频记录
  917. {
  918. condition = " AND b.company_id IN (" + utils.GetOrmInReplace(lencompanyId) + ") AND b.create_time > ? GROUP BY b.id "
  919. userActivityVoiceList, e := models.GetCygxActivityVoiceHistoryListNoLimit(condition, pars)
  920. if e != nil {
  921. err = errors.New("GetCygxActivityVoiceHistoryListNoLimit, Err: " + e.Error())
  922. return
  923. }
  924. //活动音频记录 明细
  925. var conditionBill string
  926. var parsBill []interface{}
  927. conditionBill = " AND source = 'activityvoice' AND company_id IN (" + utils.GetOrmInReplace(lencompanyId) + ") AND view_time > ? "
  928. parsBill = append(parsBill, companyIds, startWeekDate)
  929. listBillActivityVoice, e := rai_serve.GetCygxRaiServeBillListAll(conditionBill, parsBill)
  930. if e != nil {
  931. err = errors.New("GetCygxRaiServeBillListAll, Err: " + e.Error())
  932. return
  933. }
  934. mapActivityVoiceBill := make(map[string]bool)
  935. for _, v := range listBillActivityVoice {
  936. mapActivityVoiceBill[fmt.Sprint("UID_", v.UserId, "SID_", v.RecordId)] = true
  937. }
  938. for _, v := range userActivityVoiceList {
  939. if mapActivityVoiceBill[fmt.Sprint("UID_", v.UserId, "SID_", v.RecordId)] { // 如果内容存在就不插入
  940. continue
  941. }
  942. item := new(rai_serve.CygxRaiServeBill)
  943. item.Content = v.VoiceName
  944. item.ServeTypeId = 8
  945. item.ServeTypeName = "路演回放"
  946. item.UserId = v.UserId
  947. item.Mobile = v.Mobile
  948. item.Email = v.Email
  949. item.CompanyId = v.CompanyId
  950. item.CompanyName = v.CompanyName
  951. item.RealName = v.RealName
  952. item.ServeCount = 0.5
  953. if mapUserMaker[v.UserId] {
  954. item.IsKp = 1
  955. item.ServeCount = item.ServeCount * 3
  956. }
  957. item.SourceId = v.ActivityVoiceId
  958. item.ActivityId = v.ActivityId
  959. item.RecordId = v.RecordId
  960. item.Source = utils.CYGX_OBJ_ACTIVITYVOICE
  961. item.CreateTime = time.Now()
  962. item.ViewTime = v.CreateTime
  963. item.WeekStartDate, item.WeekEndDate = utils.GetMondayAndSundayByTimeString(item.ViewTime)
  964. item.MonthStartDate, item.MonthEndDate = utils.GetFirstAndLastDayOfMonth(item.ViewTime)
  965. items = append(items, item)
  966. }
  967. }
  968. //活动音频记录 end
  969. //活动视频记录
  970. {
  971. condition = " AND b.company_id IN (" + utils.GetOrmInReplace(lencompanyId) + ") AND b.create_time > ? GROUP BY b.id "
  972. userActivityVideoList, e := models.GetCygxActivityVideoHistoryListNoLimit(condition, pars)
  973. if e != nil {
  974. err = errors.New("GetCygxChartRecordListNoLimit, Err: " + e.Error())
  975. return
  976. }
  977. //图表浏览记录明细
  978. var conditionBill string
  979. var parsBill []interface{}
  980. conditionBill = " AND source = 'activityvideo' AND company_id IN (" + utils.GetOrmInReplace(lencompanyId) + ") AND view_time > ? "
  981. parsBill = append(parsBill, companyIds, startWeekDate)
  982. listBillActivityVideo, e := rai_serve.GetCygxRaiServeBillListAll(conditionBill, parsBill)
  983. if e != nil {
  984. err = errors.New("GetCygxRaiServeBillListAll, Err: " + e.Error())
  985. return
  986. }
  987. mapActivityVideoBill := make(map[string]bool)
  988. for _, v := range listBillActivityVideo {
  989. mapActivityVideoBill[fmt.Sprint("UID_", v.UserId, "SID_", v.RecordId)] = true
  990. }
  991. for _, v := range userActivityVideoList {
  992. if mapActivityVideoBill[fmt.Sprint("UID_", v.UserId, "SID_", v.RecordId)] { // 如果内容存在就不插入
  993. continue
  994. }
  995. item := new(rai_serve.CygxRaiServeBill)
  996. item.Content = v.VideoName
  997. item.ServeTypeId = 8
  998. item.ServeTypeName = "路演回放"
  999. item.UserId = v.UserId
  1000. item.Mobile = v.Mobile
  1001. item.Email = v.Email
  1002. item.CompanyId = v.CompanyId
  1003. item.CompanyName = v.CompanyName
  1004. item.RealName = v.RealName
  1005. item.ServeCount = 0.5
  1006. if mapUserMaker[v.UserId] {
  1007. item.IsKp = 1
  1008. item.ServeCount = item.ServeCount * 3
  1009. }
  1010. item.SourceId = v.VideoId
  1011. item.RecordId = v.RecordId
  1012. item.ActivityId = v.ActivityId
  1013. item.Source = utils.CYGX_OBJ_ACTIVITYVIDEO
  1014. item.CreateTime = time.Now()
  1015. item.ViewTime = v.CreateTime
  1016. item.WeekStartDate, item.WeekEndDate = utils.GetMondayAndSundayByTimeString(item.ViewTime)
  1017. item.MonthStartDate, item.MonthEndDate = utils.GetFirstAndLastDayOfMonth(item.ViewTime)
  1018. items = append(items, item)
  1019. }
  1020. }
  1021. //活动视频记录 end
  1022. //报告精选阅读记录
  1023. {
  1024. condition = " AND b.company_id IN (" + utils.GetOrmInReplace(lencompanyId) + ") AND b.create_time > ? GROUP BY b.id "
  1025. userReportSelectionList, e := models.GetCygxReportSelectionHistoryRecordRespLimit(condition, pars)
  1026. if e != nil {
  1027. err = errors.New("GetCygxChartRecordListNoLimit, Err: " + e.Error())
  1028. return
  1029. }
  1030. //报告精选阅读记录 明细
  1031. var conditionBill string
  1032. var parsBill []interface{}
  1033. conditionBill = " AND source = 'reportselection' AND company_id IN (" + utils.GetOrmInReplace(lencompanyId) + ") AND view_time > ? "
  1034. parsBill = append(parsBill, companyIds, startWeekDate)
  1035. listBillReportSelection, e := rai_serve.GetCygxRaiServeBillListAll(conditionBill, parsBill)
  1036. if e != nil {
  1037. err = errors.New("GetCygxRaiServeBillListAll, Err: " + e.Error())
  1038. return
  1039. }
  1040. mapReportSelectionBill := make(map[string]bool)
  1041. for _, v := range listBillReportSelection {
  1042. mapReportSelectionBill[fmt.Sprint("UID_", v.UserId, "SID_", v.RecordId)] = true
  1043. }
  1044. for _, v := range userReportSelectionList {
  1045. if mapReportSelectionBill[fmt.Sprint("UID_", v.UserId, "SID_", v.RecordId)] { // 如果内容存在就不插入
  1046. continue
  1047. }
  1048. item := new(rai_serve.CygxRaiServeBill)
  1049. item.Content = "重点公司"
  1050. item.ServeTypeId = 5
  1051. item.ServeTypeName = "阅读uv"
  1052. item.UserId = v.UserId
  1053. item.Mobile = v.Mobile
  1054. item.Email = v.Email
  1055. item.CompanyId = v.CompanyId
  1056. item.CompanyName = v.CompanyName
  1057. item.RealName = v.RealName
  1058. item.ServeCount = 0.5
  1059. if mapUserMaker[v.UserId] {
  1060. item.IsKp = 1
  1061. item.ServeCount = item.ServeCount * 3
  1062. }
  1063. item.SourceId = v.ArticleId
  1064. item.RecordId = v.RecordId
  1065. item.Source = utils.CYGX_OBJ_REPORTSELECTION
  1066. item.CreateTime = time.Now()
  1067. item.ViewTime = v.CreateTime
  1068. item.WeekStartDate, item.WeekEndDate = utils.GetMondayAndSundayByTimeString(item.ViewTime)
  1069. item.MonthStartDate, item.MonthEndDate = utils.GetFirstAndLastDayOfMonth(item.ViewTime)
  1070. items = append(items, item)
  1071. }
  1072. }
  1073. //报告精选阅读记录 end
  1074. //产品内测阅读记录
  1075. {
  1076. condition = " AND b.company_id IN (" + utils.GetOrmInReplace(lencompanyId) + ") AND b.create_time > ? GROUP BY b.id "
  1077. userProductInteriorList, e := models.GetCygxProductInteriorHistoryListData(condition, pars)
  1078. if e != nil {
  1079. err = errors.New("GetCygxChartRecordListNoLimit, Err: " + e.Error())
  1080. return
  1081. }
  1082. //产品内测阅读记录 明细
  1083. var conditionBill string
  1084. var parsBill []interface{}
  1085. conditionBill = " AND source = 'productinterior' AND company_id IN (" + utils.GetOrmInReplace(lencompanyId) + ") AND view_time > ? "
  1086. parsBill = append(parsBill, companyIds, startWeekDate)
  1087. listBillProductInterior, e := rai_serve.GetCygxRaiServeBillListAll(conditionBill, parsBill)
  1088. if e != nil {
  1089. err = errors.New("GetCygxRaiServeBillListAll, Err: " + e.Error())
  1090. return
  1091. }
  1092. mapProductInteriorBill := make(map[string]bool)
  1093. for _, v := range listBillProductInterior {
  1094. mapProductInteriorBill[fmt.Sprint("UID_", v.UserId, "SID_", v.RecordId)] = true
  1095. }
  1096. for _, v := range userProductInteriorList {
  1097. if mapProductInteriorBill[fmt.Sprint("UID_", v.UserId, "SID_", v.RecordId)] { // 如果内容存在就不插入
  1098. continue
  1099. }
  1100. item := new(rai_serve.CygxRaiServeBill)
  1101. item.Content = v.Title
  1102. item.ServeTypeId = 5
  1103. item.ServeTypeName = "阅读uv"
  1104. item.UserId = v.UserId
  1105. item.Mobile = v.Mobile
  1106. item.Email = v.Email
  1107. item.CompanyId = v.CompanyId
  1108. item.CompanyName = v.CompanyName
  1109. item.RealName = v.RealName
  1110. item.ServeCount = 0.5
  1111. if mapUserMaker[v.UserId] {
  1112. item.IsKp = 1
  1113. item.ServeCount = item.ServeCount * 3
  1114. }
  1115. item.SourceId = v.ProductInteriorId
  1116. item.RecordId = v.RecordId
  1117. item.Source = utils.CYGX_OBJ_PRODUCTINTERIOR
  1118. item.CreateTime = time.Now()
  1119. item.ViewTime = v.CreateTime
  1120. item.WeekStartDate, item.WeekEndDate = utils.GetMondayAndSundayByTimeString(item.ViewTime)
  1121. item.MonthStartDate, item.MonthEndDate = utils.GetFirstAndLastDayOfMonth(item.ViewTime)
  1122. items = append(items, item)
  1123. }
  1124. }
  1125. //产品内测阅读记录 end
  1126. if len(items) > 0 {
  1127. var itemsAdd []*rai_serve.CygxRaiServeBill
  1128. for k, v := range items {
  1129. itemsAdd = append(itemsAdd, v)
  1130. if len(itemsAdd)%2000 == 0 {
  1131. fmt.Println(k)
  1132. e = rai_serve.AddCygxRaiServeBillMulti(itemsAdd)
  1133. if e != nil {
  1134. err = errors.New("AddCygxRaiServeBillMulti, Err: " + e.Error())
  1135. return
  1136. }
  1137. itemsAdd = make([]*rai_serve.CygxRaiServeBill, 0)
  1138. }
  1139. }
  1140. e = rai_serve.AddCygxRaiServeBillMulti(itemsAdd)
  1141. if e != nil {
  1142. err = errors.New("AddCygxRaiServeBillMulti, Err: " + e.Error())
  1143. return
  1144. }
  1145. }
  1146. fmt.Println("delBillIds", (delBillIds))
  1147. fmt.Println("UpdateCygxRaiServeBillByCompanyIds end")
  1148. return
  1149. }
  1150. // 更新周度服务明细
  1151. func UpdateCygxRaiServeBillWeek() (err error) {
  1152. defer func() {
  1153. if err != nil {
  1154. fmt.Println(err)
  1155. go utils.SendAlarmMsg("批量更新企业服务明细记录失败: UpdateCygxRaiServeBillByCompanyIds Err"+err.Error(), 2)
  1156. }
  1157. }()
  1158. now := time.Now()
  1159. weeks := 12
  1160. companyList, e := rai_serve.GetCygxRaiServeCompanyAllList()
  1161. if e != nil {
  1162. err = errors.New("GetCygxRaiServeCompanyAllList, Err: " + e.Error())
  1163. return
  1164. }
  1165. var companyIds []int
  1166. for _, v := range companyList {
  1167. companyIds = append(companyIds, v.CompanyId)
  1168. }
  1169. listCompanyUserNum, e := models.GetWxUserNumByCompanyIds(companyIds)
  1170. if e != nil {
  1171. err = errors.New("GetWxUserisMakerByCompanyIds, Err: " + e.Error())
  1172. return
  1173. }
  1174. mapCompanyUserNum := make(map[int]int) //企业对应的用户数量
  1175. for _, v := range listCompanyUserNum {
  1176. mapCompanyUserNum[v.CompanyId] = v.UserNum
  1177. }
  1178. lencompanyId := len(companyIds)
  1179. //研选阅读明细
  1180. var conditionBill string
  1181. var parsBill []interface{}
  1182. var startWeekDate = time.Now().AddDate(0, 0, -75).Format(utils.FormatDate) + " 23:59:59"
  1183. conditionBill = " AND company_id IN (" + utils.GetOrmInReplace(lencompanyId) + ") AND view_time > ? "
  1184. parsBill = append(parsBill, companyIds, startWeekDate)
  1185. listBillByYanxuanspecial, e := rai_serve.GetCygxRaiServeBillListAll(conditionBill, parsBill)
  1186. if e != nil {
  1187. err = errors.New("GetCygxRaiServeBillListAll, Err: " + e.Error())
  1188. return
  1189. }
  1190. mapWeekServeCount := make(map[string]float64)
  1191. for _, v := range listBillByYanxuanspecial {
  1192. mapWeekServeCount[fmt.Sprint("CID_", v.CompanyId, "WEEK_", v.WeekStartDate)] += v.ServeCount
  1193. }
  1194. fmt.Println(companyIds)
  1195. var items []*rai_serve.CygxRaiServeWeekBill
  1196. for _, v := range companyList {
  1197. for i := 0; i < weeks; i++ {
  1198. item := new(rai_serve.CygxRaiServeWeekBill)
  1199. // 计算当前周的周一
  1200. monday := now.AddDate(0, 0, -int(now.Weekday()-time.Monday)-i*7)
  1201. // 计算当前周的周日
  1202. sunday := monday.AddDate(0, 0, 6)
  1203. item.WeekStartDate = monday.Format(utils.FormatDate)
  1204. item.WeekEndDate = sunday.Format(utils.FormatDate)
  1205. item.CompanyId = v.CompanyId
  1206. item.CompanyName = v.CompanyName
  1207. item.UserTotal = mapCompanyUserNum[v.CompanyId]
  1208. item.WeekServeCount = mapWeekServeCount[fmt.Sprint("CID_", v.CompanyId, "WEEK_", item.WeekStartDate)]
  1209. if mapCompanyUserNum[v.CompanyId] > 0 {
  1210. item.CoverageRate = item.WeekServeCount / float64(mapCompanyUserNum[v.CompanyId]) * 100
  1211. }
  1212. item.CreateTime = time.Now()
  1213. item.ModifyTime = time.Now()
  1214. items = append(items, item)
  1215. }
  1216. }
  1217. e = rai_serve.AddCygxRaiServeWeekBillMulti(items)
  1218. if e != nil {
  1219. err = errors.New("AddCygxRaiServeWeekBillMulti, Err: " + e.Error())
  1220. return
  1221. }
  1222. return
  1223. }
  1224. func UpdateCygxRaiServeBillWeekTask() (err error) {
  1225. defer func() {
  1226. if err != nil {
  1227. fmt.Println(err)
  1228. go utils.SendAlarmMsg("批量更新企业服务明细记录失败: UpdateCygxRaiServeBillByCompanyIds Err"+err.Error(), 2)
  1229. }
  1230. }()
  1231. fmt.Println("UpdateCygxRaiServeBillWeekTask start")
  1232. now := time.Now()
  1233. weeks := 11
  1234. companyList, e := rai_serve.GetCygxRaiServeCompanyAllList()
  1235. if e != nil {
  1236. err = errors.New("GetCygxRaiServeCompanyAllList, Err: " + e.Error())
  1237. return
  1238. }
  1239. var companyIds []int
  1240. for _, v := range companyList {
  1241. companyIds = append(companyIds, v.CompanyId)
  1242. }
  1243. listCompanyUserNum, e := models.GetWxUserNumByCompanyIds(companyIds)
  1244. if e != nil {
  1245. err = errors.New("GetWxUserisMakerByCompanyIds, Err: " + e.Error())
  1246. return
  1247. }
  1248. mapCompanyUserNum := make(map[int]int) //企业对应的用户数量
  1249. for _, v := range listCompanyUserNum {
  1250. mapCompanyUserNum[v.CompanyId] = v.UserNum
  1251. }
  1252. lencompanyId := len(companyIds)
  1253. if lencompanyId == 0 {
  1254. return
  1255. }
  1256. //明细
  1257. var conditionBill string
  1258. var parsBill []interface{}
  1259. var startWeekDate = time.Now().AddDate(0, 0, -75).Format(utils.FormatDate) + " 23:59:59"
  1260. conditionBill = " AND company_id IN (" + utils.GetOrmInReplace(lencompanyId) + ") AND view_time > ? "
  1261. parsBill = append(parsBill, companyIds, startWeekDate)
  1262. listBill, e := rai_serve.GetCygxRaiServeBillListAll(conditionBill, parsBill)
  1263. if e != nil {
  1264. err = errors.New("GetCygxRaiServeBillListAll, Err: " + e.Error())
  1265. return
  1266. }
  1267. mapWeekServeCount := make(map[string]float64)
  1268. for _, v := range listBill {
  1269. mapWeekServeCount[fmt.Sprint("CID_", v.CompanyId, "WEEK_", v.WeekStartDate)] += v.ServeCount
  1270. }
  1271. var conditionWeek string
  1272. var parsWeek []interface{}
  1273. conditionWeek = ` AND week_start_date > ? `
  1274. parsWeek = append(parsWeek, startWeekDate)
  1275. listWeekBill, e := rai_serve.GetCygxRaiServeWeekBillListAll(conditionWeek, parsWeek)
  1276. if e != nil {
  1277. err = errors.New("GetCygxRaiServeWeekBillListAll, Err: " + e.Error())
  1278. return
  1279. }
  1280. //return
  1281. mapWeekbill := make(map[string]bool)
  1282. mapWeekbill2 := make(map[string]int)
  1283. mapWeekbillUserTotal := make(map[string]int)
  1284. mapWeekbillWeekServeCount := make(map[string]float64)
  1285. mapWeekbillWeekCoverageRate := make(map[string]float64)
  1286. for _, v := range listWeekBill {
  1287. mapWeekbill[fmt.Sprint("CID_", v.CompanyId, "WEEK_", v.WeekStartDate)] = true
  1288. mapWeekbill2[fmt.Sprint("CID_", v.CompanyId, "WEEK_", v.WeekStartDate)] = v.CompanyId
  1289. mapWeekbillUserTotal[fmt.Sprint("CID_", v.CompanyId, "WEEK_", v.WeekStartDate)] = v.UserTotal
  1290. mapWeekbillWeekServeCount[fmt.Sprint("CID_", v.CompanyId, "WEEK_", v.WeekStartDate)] = v.WeekServeCount
  1291. mapWeekbillWeekCoverageRate[fmt.Sprint("CID_", v.CompanyId, "WEEK_", v.WeekStartDate)] = v.CoverageRate
  1292. }
  1293. var items []*rai_serve.CygxRaiServeWeekBill
  1294. var itemsUpdate []*rai_serve.CygxRaiServeWeekBill
  1295. for _, v := range companyList {
  1296. for i := 0; i < weeks; i++ {
  1297. if i == 10 {
  1298. continue
  1299. }
  1300. item := new(rai_serve.CygxRaiServeWeekBill)
  1301. // 计算当前周的周一
  1302. monday := now.AddDate(0, 0, -int(now.Weekday()-time.Monday)-i*7)
  1303. // 计算当前周的周日
  1304. sunday := monday.AddDate(0, 0, 6)
  1305. item.WeekStartDate = monday.Format(utils.FormatDate)
  1306. item.WeekEndDate = sunday.Format(utils.FormatDate)
  1307. item.CompanyId = v.CompanyId
  1308. item.CompanyName = v.CompanyName
  1309. //超过本周的,互动总人数不做修改
  1310. if i > 0 && mapWeekbillUserTotal[fmt.Sprint("CID_", v.CompanyId, "WEEK_", item.WeekStartDate)] > 0 {
  1311. item.UserTotal = mapWeekbillUserTotal[fmt.Sprint("CID_", v.CompanyId, "WEEK_", item.WeekStartDate)]
  1312. } else {
  1313. item.UserTotal = mapCompanyUserNum[v.CompanyId]
  1314. }
  1315. item.WeekServeCount = mapWeekServeCount[fmt.Sprint("CID_", v.CompanyId, "WEEK_", item.WeekStartDate)]
  1316. if mapCompanyUserNum[v.CompanyId] > 0 {
  1317. item.CoverageRate = item.WeekServeCount / float64(mapCompanyUserNum[v.CompanyId]) * 100
  1318. }
  1319. item.CreateTime = time.Now()
  1320. item.ModifyTime = time.Now()
  1321. if mapWeekbill[fmt.Sprint("CID_", v.CompanyId, "WEEK_", item.WeekStartDate)] {
  1322. if mapWeekbillUserTotal[fmt.Sprint("CID_", v.CompanyId, "WEEK_", item.WeekStartDate)] == item.UserTotal && mapWeekbillWeekServeCount[fmt.Sprint("CID_", v.CompanyId, "WEEK_", item.WeekStartDate)] == item.WeekServeCount {
  1323. continue // 如果互动量相等,且人数相等,就不修改
  1324. }
  1325. itemsUpdate = append(itemsUpdate, item)
  1326. } else {
  1327. items = append(items, item)
  1328. }
  1329. }
  1330. }
  1331. fmt.Println("itemsadd", len(items))
  1332. if len(items) > 0 {
  1333. e = rai_serve.AddCygxRaiServeWeekBillMulti(items)
  1334. if e != nil {
  1335. err = errors.New("AddCygxRaiServeWeekBillMulti, Err: " + e.Error())
  1336. return
  1337. }
  1338. }
  1339. fmt.Println("itemsUpdate111", len(itemsUpdate))
  1340. if len(itemsUpdate) > 0 {
  1341. e = rai_serve.UpdateCygxRaiServeWeekBillMulti(itemsUpdate)
  1342. if e != nil {
  1343. err = errors.New("AddCygxRaiServeWeekBillMulti, Err: " + e.Error())
  1344. return
  1345. }
  1346. }
  1347. fmt.Println("UpdateCygxRaiServeBillWeekTask end")
  1348. return
  1349. }
  1350. //func init() {
  1351. // UpdateWeekAvg()
  1352. //}
  1353. // 更新最近四周平均覆盖率,是否标红,权限,时间,金额
  1354. func UpdateWeekAvg() (err error) {
  1355. defer func() {
  1356. if err != nil {
  1357. fmt.Println(err)
  1358. go utils.SendAlarmMsg("批量更新企业服务明细记录失败: UpdateCygxRaiServeBillByCompanyIds Err"+err.Error(), 2)
  1359. }
  1360. }()
  1361. fmt.Println(" UpdateWeekAvg start")
  1362. now := time.Now()
  1363. weeks := 3
  1364. monday := now.AddDate(0, 0, -int(now.Weekday()-time.Monday)-weeks*7)
  1365. startDate := monday.Format(utils.FormatDate)
  1366. var condition string
  1367. var pars []interface{}
  1368. condition = ` AND week_start_date >= ? `
  1369. pars = append(pars, startDate)
  1370. listWeekBill, e := rai_serve.GetCygxRaiServeWeekBillListAll(condition, pars)
  1371. if e != nil {
  1372. err = errors.New("GetCygxRaiServeWeekBillListAll, Err: " + e.Error())
  1373. return
  1374. }
  1375. mapWeekServeCount := make(map[int]float64) //四周平均率总合
  1376. for _, v := range listWeekBill {
  1377. mapWeekServeCount[v.CompanyId] += v.CoverageRate
  1378. }
  1379. //获取近四周含有Kp 的公司
  1380. condition = ""
  1381. pars = make([]interface{}, 0)
  1382. condition += ` AND week_start_date >= ? AND is_kp = 1 GROUP BY company_id `
  1383. pars = append(pars, startDate)
  1384. listIsKpWeekBill, e := rai_serve.GetCygxRaiServeBillListAll(condition, pars)
  1385. if e != nil {
  1386. err = errors.New("GetCygxRaiServeWeekBillListAll, Err: " + e.Error())
  1387. return
  1388. }
  1389. mapWeekIsKp := make(map[int]bool) //最近四周是否包含KP
  1390. for _, v := range listIsKpWeekBill {
  1391. mapWeekIsKp[v.CompanyId] = true
  1392. }
  1393. companyList, e := rai_serve.GetCygxRaiServeCompanyAllList()
  1394. if e != nil {
  1395. err = errors.New("GetCygxRaiServeCompanyAllList, Err: " + e.Error())
  1396. return
  1397. }
  1398. var formalCompanyIds []int // 当前正式客户ID
  1399. var formalNoCompanyIds []int // 当前非正式客户ID
  1400. //永续客户当做正式客户处理
  1401. for _, v := range companyList {
  1402. if v.Status == "正式" || v.Status == "永续" {
  1403. formalCompanyIds = append(formalCompanyIds, v.CompanyId)
  1404. } else {
  1405. formalNoCompanyIds = append(formalNoCompanyIds, v.CompanyId)
  1406. }
  1407. }
  1408. var itemsUpdate []*rai_serve.CygxRaiServeCompany
  1409. if len(formalCompanyIds) > 0 { //正式客户信息
  1410. condition = ""
  1411. pars = make([]interface{}, 0)
  1412. condition = ` AND product_id = 2 AND company_id IN (` + utils.GetOrmInReplace(len(formalCompanyIds)) + `) AND status = 1 AND end_date > ? `
  1413. pars = append(pars, formalCompanyIds, time.Now())
  1414. listCompanyContract, e := company.GetCompanyContractList(condition, pars)
  1415. if e != nil {
  1416. err = errors.New("GetCompanyContractList, Err: " + e.Error())
  1417. return
  1418. }
  1419. companyMoney := make(map[int]float64)
  1420. for _, v := range listCompanyContract {
  1421. companyMoney[v.CompanyId] += v.Money
  1422. }
  1423. permissionNameMapByCompanyId, e := GetCompanyReportPermissionNameMapByCompanyId(formalCompanyIds)
  1424. if e != nil {
  1425. err = errors.New("GetCompanyReportPermissionNameMapByCompanyId, Err: " + e.Error())
  1426. return
  1427. }
  1428. for _, v := range formalCompanyIds {
  1429. item := new(rai_serve.CygxRaiServeCompany)
  1430. item.CompanyId = v
  1431. item.Money = companyMoney[v]
  1432. item.PermissionName = permissionNameMapByCompanyId[v]
  1433. item.ServeCoverageRate = utils.SubFloatToString(mapWeekServeCount[v]/4, 2)
  1434. item.IsUserMaker = -1
  1435. if mapWeekIsKp[v] {
  1436. item.IsUserMaker = 1
  1437. }
  1438. itemsUpdate = append(itemsUpdate, item)
  1439. }
  1440. }
  1441. //正式客户数据修改
  1442. e = rai_serve.UpdateCygxRaiServeCompanyMulti(itemsUpdate)
  1443. if e != nil {
  1444. err = errors.New("UpdateCygxRaiServeCompanyMulti, Err: " + e.Error())
  1445. return
  1446. }
  1447. var itemsUpdateFormalNo []*rai_serve.CygxRaiServeCompany //非正式客户数据修改
  1448. var itemsUpdateFormalNoContract []*rai_serve.CygxRaiServeCompany //非正式客户没有合同的客户修改
  1449. mapContractCompanyIds := make(map[int]bool) //签过合同的试用客户ID
  1450. if len(formalNoCompanyIds) > 0 { //非正式客户信息
  1451. condition = ""
  1452. pars = make([]interface{}, 0)
  1453. 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 `
  1454. pars = append(pars, formalNoCompanyIds, time.Now())
  1455. listCompanyContractLastId, e := company.GetCompanyContractLastList(condition, pars) //获取关联的最后一笔合同信息
  1456. if e != nil {
  1457. err = errors.New("GetCompanyContractLastList, Err: " + e.Error())
  1458. return
  1459. }
  1460. var companyContractIds []int
  1461. for _, v := range listCompanyContractLastId {
  1462. companyContractIds = append(companyContractIds, v.CompanyContractId)
  1463. }
  1464. condition = ""
  1465. pars = make([]interface{}, 0)
  1466. 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 `
  1467. pars = append(pars, formalNoCompanyIds, companyContractIds, time.Now())
  1468. listCompanyContractLast, e := company.GetCompanyContractList(condition, pars)
  1469. if e != nil {
  1470. err = errors.New("GetCompanyContractList, Err: " + e.Error())
  1471. return
  1472. }
  1473. permissionNameMapByContractId, e := GetCompanyContractPermissionNameMapById(companyContractIds)
  1474. if e != nil {
  1475. err = errors.New("GetCompanyReportPermissionNameMapByCompanyId, Err: " + e.Error())
  1476. return
  1477. }
  1478. for _, v := range listCompanyContractLast {
  1479. item := new(rai_serve.CygxRaiServeCompany)
  1480. item.CompanyId = v.CompanyId
  1481. item.Money = v.Money
  1482. item.StartDate = v.StartDate
  1483. item.EndDate = v.EndDate
  1484. item.ServeCoverageRate = utils.SubFloatToString(mapWeekServeCount[v.CompanyId]/4, 2)
  1485. item.IsUserMaker = -1
  1486. if mapWeekIsKp[v.CompanyId] {
  1487. item.IsUserMaker = 1
  1488. }
  1489. item.PermissionName = permissionNameMapByContractId[v.CompanyContractId]
  1490. itemsUpdateFormalNo = append(itemsUpdateFormalNo, item)
  1491. mapContractCompanyIds[v.CompanyId] = true
  1492. }
  1493. for _, v := range formalNoCompanyIds {
  1494. if mapContractCompanyIds[v] {
  1495. continue
  1496. }
  1497. //fmt.Println(v)
  1498. item := new(rai_serve.CygxRaiServeCompany)
  1499. item.CompanyId = v
  1500. item.ServeCoverageRate = utils.SubFloatToString(mapWeekServeCount[v]/4, 2)
  1501. item.IsUserMaker = -1
  1502. if mapWeekIsKp[v] {
  1503. item.IsUserMaker = 1
  1504. }
  1505. itemsUpdateFormalNoContract = append(itemsUpdateFormalNoContract, item)
  1506. }
  1507. }
  1508. e = rai_serve.UpdateCygxRaiServeCompanyFormalNoMulti(itemsUpdateFormalNo)
  1509. if e != nil {
  1510. err = errors.New("UpdateCygxRaiServeCompanyFormalNoMulti, Err: " + e.Error())
  1511. return
  1512. }
  1513. e = rai_serve.UpdateCygxRaiServeCompanyFormalNoContractMulti(itemsUpdateFormalNoContract)
  1514. if e != nil {
  1515. err = errors.New("UpdateCygxRaiServeCompanyFormalNoMulti, Err: " + e.Error())
  1516. return
  1517. }
  1518. fmt.Println(" UpdateWeekAvg end")
  1519. return
  1520. }