1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381 |
- package services
- import (
- "context"
- "errors"
- "fmt"
- "hongze/hongze_cygx/models"
- "hongze/hongze_cygx/models/company"
- "hongze/hongze_cygx/models/rai_serve"
- "hongze/hongze_cygx/models/roadshow"
- "hongze/hongze_cygx/utils"
- "strings"
- "time"
- )
- // var startWeekDate = time.Now().AddDate(0, 0, -75).Format(utils.FormatDate) + " 23:59:59" // 查询12周以内的数据
- //var startWeekDate = time.Now().AddDate(0, 0, -75).Format(utils.FormatDateTime) // 查询12周以内的数据
- //权益服务统计
- //上线跑的脚本
- //func initJob() {
- // UpdateRaiServeCompany() //1
- // UpdateCygxRaiServeBillByCompanyIds() //2
- // UpdateCygxRaiServeBillWeek() // 3
- // UpdateWeekAvg() // 4
- //}
- //func init() {
- // UpdateWeekAvg() //1
- //}
- //func init() {
- // UpdateRaiServeCompany() //1
- // UpdateCygxRaiServeBillByCompanyIds() //2
- // UpdateCygxRaiServeBillWeekTask() // 3
- // UpdateWeekAvg() // 4
- //}
- // 定时任务处理权益服务公司
- func UpdateRaiServeCompanyDate(cont context.Context) (err error) {
- defer func() {
- if err != nil {
- fmt.Println(err)
- go utils.SendAlarmMsg(fmt.Sprint("定时任务处理权益服务公司 失败 UpdateRaiServeCompanyDate ,err:", err.Error()), 2)
- }
- }()
- err = UpdateRaiServeCompany()
- return
- }
- // 定时任务处理权益服务记录明细
- func UpdateRaiServeBillDate(cont context.Context) (err error) {
- //func UpdateRaiServeBillDate() (err error) {
- defer func() {
- if err != nil {
- fmt.Println(err)
- go utils.SendAlarmMsg(fmt.Sprint("定时任务处理权益服务公司 失败 UpdateRaiServeBillDate ,err:", err.Error()), 2)
- }
- }()
- err = UpdateRaiServeCompany() // 处理共享机构信息
- if err != nil {
- return
- }
- err = UpdateCygxRaiServeBillByCompanyIds() // 处理个人流水记录
- if err != nil {
- return
- }
- err = UpdateCygxRaiServeBillWeekTask() // 更新周度服务明细
- if err != nil {
- return
- }
- err = UpdateWeekAvg() //更新最近四周平均覆盖率,是否标红,权限,时间,金额
- if err != nil {
- return
- }
- return
- }
- // 更新现有的权益服务客户数据
- func UpdateRaiServeCompany() (err error) {
- defer func() {
- if err != nil {
- fmt.Println(err)
- go utils.SendAlarmMsg("更新现有的权益服务客户数据失败 UpdateRaiServeCompany:"+err.Error(), 2)
- }
- }()
- var condition string
- var pars []interface{}
- 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 + `) ) `
- //pars = append(pars, utils.RAI_SERVE_GROUP_ID, utils.RAI_SERVE_GROUP_ID)
- listCompanyProduct, e := company.GetCompanyProductAndCompanyListByCondition(condition, pars)
- if e != nil {
- err = errors.New("GetCompanyProductListByCondition, Err: " + e.Error())
- return
- }
- //fmt.Println(len(listCompanyProduct))
- //return
- raiServeCompanyList, e := rai_serve.GetCygxRaiServeCompanyAllList()
- if e != nil {
- err = errors.New("GetCygxRaiServeCompanyAllList, Err: " + e.Error())
- return
- }
- mapOLdCompany := make(map[int]bool)
- mapOLdCompanyDate := make(map[int]string)
- for _, v := range raiServeCompanyList {
- mapOLdCompany[v.CompanyId] = true
- 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)
- }
- mapNewCompany := make(map[int]bool)
- var delCompanyIds []int // 需要删除的公司ID
- for _, v := range listCompanyProduct {
- mapNewCompany[v.CompanyId] = true
- }
- for _, v := range raiServeCompanyList {
- if !mapNewCompany[v.CompanyId] {
- delCompanyIds = append(delCompanyIds, v.CompanyId)
- }
- }
- var items []*rai_serve.CygxRaiServeCompany
- var itemsUpdate []*rai_serve.CygxRaiServeCompany
- for _, v := range listCompanyProduct {
- item := new(rai_serve.CygxRaiServeCompany)
- item.CompanyId = v.CompanyId
- item.CompanyName = v.CompanyName
- item.CreateTime = time.Now()
- item.SellerId = v.SellerId
- item.SellerName = v.SellerName
- item.StartDate = v.StartDate
- item.EndDate = v.EndDate
- item.ShareSeller = v.ShareSeller
- item.ShareSellerId = v.ShareSellerId
- item.Status = v.Status
- item.GroupId = v.GroupId
- item.ShareGroupId = v.ShareGroupId
- if !mapOLdCompany[v.CompanyId] {
- items = append(items, item) // 如果原有数据不存在就新增
- } else {
- 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) {
- itemsUpdate = append(itemsUpdate, item) // 新老数据不一致就进行修改
- }
- }
- }
- //fmt.Println("items", len(items))
- //fmt.Println("itemsUpadte222", len(itemsUpdate))
- //fmt.Println("delCompanyIds", len(delCompanyIds))
- //fmt.Println("delCompanyIds", (delCompanyIds))
- //return
- //先删除老的再添加新的
- e = rai_serve.AddCygxRaiServeCompanyMulti(items, itemsUpdate, delCompanyIds)
- if e != nil {
- err = errors.New("AddCygxRaiServeCompanyMulti, Err: " + e.Error())
- return
- }
- return
- }
- // GetCompanyContractPermissionNameMapById 获取合并之后的合同所对应的权限种类名称
- func GetCompanyContractPermissionNameMapById(companyContractIds []int) (mapContractResp map[int]string, err error) {
- //return
- lenArr := len(companyContractIds)
- if lenArr == 0 {
- return
- }
- var condition string
- var pars []interface{}
- condition += " AND company_contract_id IN (" + utils.GetOrmInReplace(lenArr) + ")"
- pars = append(pars, companyContractIds)
- //companyContractList, e := company.GetCompanyContractList(condition, pars)
- //if e != nil && e.Error() != utils.ErrNoRow() {
- // err = errors.New("GetCompanyContractList, Err: " + e.Error())
- // return
- //}
- permissionList, e := models.GetChartPermissionList()
- if e != nil && e.Error() != utils.ErrNoRow() {
- err = errors.New("GetChartPermissionList, Err: " + e.Error())
- return
- }
- mappermissionName := make(map[int]string)
- for _, v := range permissionList {
- if v.ProductId == 2 {
- mappermissionName[v.ChartPermissionId] = v.Remark
- }
- }
- mapContractIdPerssion := make(map[int]string) //单个合同ID所对应的套餐或者权限名称
- //for _, v := range companyContractList {
- // if v.RaiPackageType == 1 {
- // mapContractIdPerssion[v.CompanyContractId] = "70w套餐,"
- // }
- // if v.RaiPackageType == 2 {
- // mapContractIdPerssion[v.CompanyContractId] = "45w套餐,"
- // }
- //}
- companyContractPermissionList, e := company.GetCompanyContractPermissionList(condition, pars)
- if e != nil && e.Error() != utils.ErrNoRow() {
- err = errors.New("GetCompanyContractPermissionList, Err: " + e.Error())
- return
- }
- mapIsUpgrade := make(map[string]bool) //合同ID对应的行业是否有升级
- for _, v := range companyContractPermissionList {
- //如果开通的不是整个套餐,那么就做单独的子权限处理
- if strings.Count(mapContractIdPerssion[(v.CompanyContractId)], "w套餐") == 0 {
- if v.ChartPermissionId == utils.CHART_PERMISSION_ID_YANXUAN {
- if v.ExpensiveYx == 1 {
- mapContractIdPerssion[(v.CompanyContractId)] += utils.CHART_PERMISSION_NAME_MF_YANXUAN + "(5w),"
- } else if v.ExpensiveYx == 2 {
- mapContractIdPerssion[(v.CompanyContractId)] += utils.CHART_PERMISSION_NAME_MF_YANXUAN + "(10w),"
- } else {
- mapContractIdPerssion[(v.CompanyContractId)] += utils.CHART_PERMISSION_NAME_MF_YANXUAN + ","
- }
- } else {
- mapContractIdPerssion[(v.CompanyContractId)] += mappermissionName[v.ChartPermissionId] + ","
- if v.IsUpgrade == 1 {
- //合同ID,权限名称形成唯一的主键索引
- perssionName := mappermissionName[v.ChartPermissionId]
- perssionName = strings.Replace(perssionName, "(客观)", "", -1)
- perssionName = strings.Replace(perssionName, "(主观)", "", -1)
- mapIsUpgrade[fmt.Sprint(v.CompanyContractId, "perssionName", perssionName)] = true
- }
- }
- } else {
- if v.ChartPermissionId == utils.ZHUAN_JIA_ID {
- mapContractIdPerssion[(v.CompanyContractId)] += utils.ZHUAN_JIA_NAME + ","
- }
- if v.ChartPermissionId == utils.CHART_PERMISSION_ID_YANXUAN {
- if v.ExpensiveYx == 1 {
- mapContractIdPerssion[(v.CompanyContractId)] += utils.CHART_PERMISSION_NAME_MF_YANXUAN + "(5w),"
- } else if v.ExpensiveYx == 2 {
- mapContractIdPerssion[(v.CompanyContractId)] += utils.CHART_PERMISSION_NAME_MF_YANXUAN + "(10w),"
- } else {
- mapContractIdPerssion[(v.CompanyContractId)] += utils.CHART_PERMISSION_NAME_MF_YANXUAN + ","
- }
- }
- if v.ChartPermissionId == utils.YAN_XUAN_KOU_DIAN_BAO_ID {
- mapContractIdPerssion[(v.CompanyContractId)] += utils.YAN_XUAN_KOU_DIAN_BAO_NAME + ","
- }
- }
- }
- //合并客观权限
- for k, v := range mapContractIdPerssion {
- perssionName := v
- if strings.Count(v, utils.YI_YAO_NAME) == 2 {
- perssionName = strings.Replace(perssionName, "医药(主观)", "医药", -1)
- perssionName = strings.Replace(perssionName, "医药(客观)", "", -1)
- }
- if strings.Count(v, utils.XIAO_FEI_NAME) == 2 {
- perssionName = strings.Replace(perssionName, "消费(主观)", "消费", -1)
- perssionName = strings.Replace(perssionName, "消费(客观)", "", -1)
- }
- if strings.Count(v, utils.KE_JI_NAME) == 2 {
- perssionName = strings.Replace(perssionName, "科技(主观)", "科技", -1)
- perssionName = strings.Replace(perssionName, "科技(客观)", "", -1)
- }
- if strings.Count(v, utils.ZHI_ZAO_NAME) == 2 {
- perssionName = strings.Replace(perssionName, "智造(主观)", "智造", -1)
- perssionName = strings.Replace(perssionName, "智造(客观)", "", -1)
- }
- perssionName = strings.TrimRight(perssionName, ",")
- mapContractIdPerssion[k] = perssionName
- }
- mapContractResp = make(map[int]string, 0)
- //过滤多余的","
- for k, v := range mapContractIdPerssion {
- sliceName := strings.Split(v, ",")
- var nameArr []string
- for _, vName := range sliceName {
- if vName == "" {
- continue
- }
- if mapIsUpgrade[fmt.Sprint(k, "perssionName", vName)] {
- vName += "(升级)"
- }
- nameArr = append(nameArr, vName)
- }
- mapContractResp[k] = strings.Join(nameArr, ",")
- }
- return
- }
- // 根据公司ID获取目前行业所对应的正式权限
- func GetCompanyReportPermissionNameMapByCompanyId(companyIds []int) (mapContractResp map[int]string, err error) {
- lenArr := len(companyIds)
- if lenArr == 0 {
- return
- }
- var condition string
- var pars []interface{}
- condition += " AND company_id IN (" + utils.GetOrmInReplace(lenArr) + ") AND product_id = 2 AND status IN ( '正式','永续') "
- pars = append(pars, companyIds)
- permissionList, e := models.GetChartPermissionList()
- if e != nil && e.Error() != utils.ErrNoRow() {
- err = errors.New("GetChartPermissionList, Err: " + e.Error())
- return
- }
- mappermissionName := make(map[int]string)
- for _, v := range permissionList {
- if v.ProductId == 2 {
- mappermissionName[v.ChartPermissionId] = v.Remark
- }
- }
- mapContractIdPerssion := make(map[int]string) //单个合同ID所对应的套餐或者权限名称
- companyReportPermissionList, e := models.GetCompanyReportPermissionList(condition, pars)
- if e != nil && e.Error() != utils.ErrNoRow() {
- err = errors.New("GetCompanyReportPermissionList, Err: " + e.Error())
- return
- }
- mapIsUpgrade := make(map[string]bool) //合同ID对应的行业是否有升级
- for _, v := range companyReportPermissionList {
- //如果开通的不是整个套餐,那么就做单独的子权限处理
- if strings.Count(mapContractIdPerssion[(v.CompanyId)], "w套餐") == 0 {
- if v.ChartPermissionId == utils.CHART_PERMISSION_ID_YANXUAN {
- if v.ExpensiveYx == 1 {
- mapContractIdPerssion[(v.CompanyId)] += utils.CHART_PERMISSION_NAME_MF_YANXUAN + "(5w),"
- } else if v.ExpensiveYx == 2 {
- mapContractIdPerssion[(v.CompanyId)] += utils.CHART_PERMISSION_NAME_MF_YANXUAN + "(10w),"
- } else {
- mapContractIdPerssion[(v.CompanyId)] += utils.CHART_PERMISSION_NAME_MF_YANXUAN + ","
- }
- } else {
- mapContractIdPerssion[(v.CompanyId)] += mappermissionName[v.ChartPermissionId] + ","
- if v.IsUpgrade == 1 {
- //合同ID,权限名称形成唯一的主键索引
- perssionName := mappermissionName[v.ChartPermissionId]
- perssionName = strings.Replace(perssionName, "(客观)", "", -1)
- perssionName = strings.Replace(perssionName, "(主观)", "", -1)
- mapIsUpgrade[fmt.Sprint(v.CompanyId, "perssionName", perssionName)] = true
- }
- }
- } else {
- if v.ChartPermissionId == utils.ZHUAN_JIA_ID {
- mapContractIdPerssion[(v.CompanyId)] += utils.ZHUAN_JIA_NAME + ","
- }
- if v.ChartPermissionId == utils.CHART_PERMISSION_ID_YANXUAN {
- if v.ExpensiveYx == 1 {
- mapContractIdPerssion[(v.CompanyId)] += utils.CHART_PERMISSION_NAME_MF_YANXUAN + "(5w),"
- } else if v.ExpensiveYx == 2 {
- mapContractIdPerssion[(v.CompanyId)] += utils.CHART_PERMISSION_NAME_MF_YANXUAN + "(10w),"
- } else {
- mapContractIdPerssion[(v.CompanyId)] += utils.CHART_PERMISSION_NAME_MF_YANXUAN + ","
- }
- }
- if v.ChartPermissionId == utils.YAN_XUAN_KOU_DIAN_BAO_ID {
- mapContractIdPerssion[(v.CompanyId)] += utils.YAN_XUAN_KOU_DIAN_BAO_NAME + ","
- }
- }
- }
- //合并客观权限
- for k, v := range mapContractIdPerssion {
- perssionName := v
- if strings.Count(v, utils.YI_YAO_NAME) == 2 {
- perssionName = strings.Replace(perssionName, "医药(主观)", "医药", -1)
- perssionName = strings.Replace(perssionName, "医药(客观)", "", -1)
- }
- if strings.Count(v, utils.XIAO_FEI_NAME) == 2 {
- perssionName = strings.Replace(perssionName, "消费(主观)", "消费", -1)
- perssionName = strings.Replace(perssionName, "消费(客观)", "", -1)
- }
- if strings.Count(v, utils.KE_JI_NAME) == 2 {
- perssionName = strings.Replace(perssionName, "科技(主观)", "科技", -1)
- perssionName = strings.Replace(perssionName, "科技(客观)", "", -1)
- }
- if strings.Count(v, utils.ZHI_ZAO_NAME) == 2 {
- perssionName = strings.Replace(perssionName, "智造(主观)", "智造", -1)
- perssionName = strings.Replace(perssionName, "智造(客观)", "", -1)
- }
- perssionName = strings.TrimRight(perssionName, ",")
- mapContractIdPerssion[k] = perssionName
- }
- mapContractResp = make(map[int]string, 0)
- //过滤多余的","
- for k, v := range mapContractIdPerssion {
- sliceName := strings.Split(v, ",")
- var nameArr []string
- for _, vName := range sliceName {
- if vName == "" {
- continue
- }
- if mapIsUpgrade[fmt.Sprint(k, "perssionName", vName)] {
- vName += "(升级)"
- }
- nameArr = append(nameArr, vName)
- }
- mapContractResp[k] = strings.Join(nameArr, ",")
- }
- return
- }
- // Redis对列消息中的结构体
- type RaiServeBillRedis struct {
- Content string `comment:"服务内容说明"`
- UserId int `comment:"用户ID"`
- ComapnyId int `comment:"公司ID"`
- SourceId int `comment:"来源ID"`
- Source string `comment:"来源"`
- RegisterPlatform int `comment:"来源 1小程序,2:网页"`
- ViewTime time.Time `comment:"浏览时间"`
- }
- // 批量更新企业服务明细记录
- func UpdateCygxRaiServeBillByCompanyIds() (err error) {
- defer func() {
- if err != nil {
- fmt.Println(err)
- go utils.SendAlarmMsg("批量更新企业服务明细记录失败: UpdateCygxRaiServeBillByCompanyIds Err"+err.Error(), 2)
- }
- }()
- var delBillIds []int
- var startWeekDate = time.Now().AddDate(0, 0, -75).Format(utils.FormatDate) + " 23:59:59"
- fmt.Println("UpdateCygxRaiServeBillByCompanyIds start")
- companyList, e := rai_serve.GetCygxRaiServeCompanyAllList()
- if e != nil {
- err = errors.New("GetCygxRaiServeCompanyAllList, Err: " + e.Error())
- return
- }
- var companyIds []int
- var items []*rai_serve.CygxRaiServeBill
- for _, v := range companyList {
- companyIds = append(companyIds, v.CompanyId)
- }
- lencompanyId := len(companyIds)
- listisMakeruser, e := models.GetWxUserisMakerByCompanyIds(companyIds)
- if e != nil {
- err = errors.New("GetWxUserisMakerByCompanyIds, Err: " + e.Error())
- return
- }
- mapUserMaker := make(map[int]bool)
- mapUserMobileUserId := make(map[string]int)
- for _, v := range listisMakeruser {
- mapUserMaker[v.UserId] = true
- mapUserMobileUserId[v.Mobile] = v.UserId
- }
- var condition string
- var pars []interface{}
- condition = " AND art.company_id IN (" + utils.GetOrmInReplace(lencompanyId) + ") AND art.create_time > ? "
- pars = append(pars, companyIds, startWeekDate)
- fmt.Println("startWeekDate", startWeekDate)
- //研选专栏阅读记录内容
- {
- listYanxuanSpecialRecord, e := models.GetCygxYanxuanSpecialRecordRespListAll(condition+" GROUP BY art.user_id, art.yanxuan_special_id ORDER BY art.create_time ASC ", pars)
- if e != nil {
- err = errors.New("GetCygxYanxuanSpecialRecordRespListAll, Err: " + e.Error())
- return
- }
- var yanxuanspecialIds []int
- for _, v := range listYanxuanSpecialRecord {
- yanxuanspecialIds = append(yanxuanspecialIds, v.YanxuanSpecialId)
- }
- var conditionYanxuanSpecial string
- var parsYanxuanSpecial []interface{}
- conditionYanxuanSpecial += ` AND id IN (` + utils.GetOrmInReplace(len(yanxuanspecialIds)) + `) `
- parsYanxuanSpecial = append(parsYanxuanSpecial, yanxuanspecialIds)
- listYanxuanSpecial, e := models.GetYanxuanSpecialListBycondition(conditionYanxuanSpecial, parsYanxuanSpecial, 0, len(yanxuanspecialIds))
- if e != nil && e.Error() != utils.ErrNoRow() {
- err = errors.New("GetYanxuanSpecialListBycondition, Err: " + e.Error())
- return
- }
- mapYanxuanSpecialTitle := make(map[int]string)
- for _, v := range listYanxuanSpecial {
- mapYanxuanSpecialTitle[v.Id] = v.Title
- }
- //研选阅读明细
- var conditionBill string
- var parsBill []interface{}
- conditionBill = " AND source = 'yanxuanspecial' AND company_id IN (" + utils.GetOrmInReplace(lencompanyId) + ") AND view_time > ? "
- parsBill = append(parsBill, companyIds, startWeekDate)
- listBillByYanxuanspecial, e := rai_serve.GetCygxRaiServeBillListAll(conditionBill, parsBill)
- if e != nil {
- err = errors.New("GetCygxRaiServeBillListAll, Err: " + e.Error())
- return
- }
- mapYanxuanspecialBill := make(map[string]bool)
- for _, v := range listBillByYanxuanspecial {
- mapYanxuanspecialBill[fmt.Sprint("UID_", v.UserId, "SID_", v.SourceId)] = true
- }
- for _, v := range listYanxuanSpecialRecord {
- if mapYanxuanspecialBill[fmt.Sprint("UID_", v.UserId, "SID_", v.YanxuanSpecialId)] { // 如果内容存在就不插入
- continue
- }
- item := new(rai_serve.CygxRaiServeBill)
- item.Content = mapYanxuanSpecialTitle[v.YanxuanSpecialId]
- item.ServeTypeId = 5
- item.ServeTypeName = "阅读uv"
- item.UserId = v.UserId
- item.Mobile = v.Mobile
- item.Email = v.Email
- item.CompanyId = v.CompanyId
- item.CompanyName = v.CompanyName
- item.RealName = v.RealName
- item.RegisterPlatform = v.RegisterPlatform
- item.ServeCount = 0.5
- if mapUserMaker[v.UserId] {
- item.IsKp = 1
- item.ServeCount = item.ServeCount * 3
- }
- item.SourceId = v.YanxuanSpecialId
- item.Source = utils.CYGX_OBJ_YANXUANSPECIAL
- item.CreateTime = time.Now()
- item.ViewTime = v.CreateTime
- item.WeekStartDate, item.WeekEndDate = utils.GetMondayAndSundayByTimeString(item.ViewTime)
- item.MonthStartDate, item.MonthEndDate = utils.GetFirstAndLastDayOfMonth(item.ViewTime)
- items = append(items, item)
- }
- }
- //研选专栏阅读记录内容end
- //文章阅读记录内容
- {
- listArticleRecord, e := models.GetCygxArticleHistoryRecordAllListNoLimit(condition+" GROUP BY art.user_id, art.article_id ORDER BY art.create_time ASC ", pars)
- if e != nil {
- err = errors.New("GetCygxArticleHistoryRecordAllListNoLimit, Err: " + e.Error())
- return
- }
- //文章阅读明细
- var conditionBill string
- var parsBill []interface{}
- conditionBill = " AND source = 'article' AND company_id IN (" + utils.GetOrmInReplace(lencompanyId) + ") AND view_time > ? "
- parsBill = append(parsBill, companyIds, startWeekDate)
- listBillByArticle, e := rai_serve.GetCygxRaiServeBillListAll(conditionBill, parsBill)
- if e != nil {
- err = errors.New("GetCygxRaiServeBillListAll, Err: " + e.Error())
- return
- }
- mapArticleBill := make(map[string]bool)
- for _, v := range listBillByArticle {
- mapArticleBill[fmt.Sprint("UID_", v.UserId, "SID_", v.SourceId)] = true
- }
- //部分数据来源没有存用户姓名,重新查一下
- var userIds []int
- for _, v := range listArticleRecord {
- userIds = append(userIds, v.UserId)
- }
- ListUser, e := models.GetWxUserListByUserIdsArr(userIds)
- if e != nil {
- err = errors.New("GetWxUserListByUserIdsArr, Err: " + e.Error())
- return
- }
- mapUserName := make(map[int]string)
- for _, v := range ListUser {
- mapUserName[v.UserId] = v.RealName
- }
- for _, v := range listArticleRecord {
- if mapArticleBill[fmt.Sprint("UID_", v.UserId, "SID_", v.ArticleId)] { // 如果内容存在就不插入
- continue
- }
- item := new(rai_serve.CygxRaiServeBill)
- item.Content = v.Title
- item.ServeTypeId = 5
- item.ServeTypeName = "阅读uv"
- item.UserId = v.UserId
- item.Mobile = v.Mobile
- item.Email = v.Email
- item.CompanyId = v.CompanyId
- item.CompanyName = v.CompanyName
- item.RealName = mapUserName[v.UserId]
- item.RegisterPlatform = v.RegisterPlatform
- item.ServeCount = 0.5
- if mapUserMaker[v.UserId] {
- item.IsKp = 1
- item.ServeCount = item.ServeCount * 3
- }
- item.SourceId = v.ArticleId
- item.Source = utils.CYGX_OBJ_ARTICLE
- item.CreateTime = time.Now()
- item.ViewTime = v.CreateTime
- item.WeekStartDate, item.WeekEndDate = utils.GetMondayAndSundayByTimeString(item.ViewTime)
- item.MonthStartDate, item.MonthEndDate = utils.GetFirstAndLastDayOfMonth(item.ViewTime)
- if strings.Contains(v.CategoryName, "固收") {
- item.ChartPermissionName = utils.GU_SHOU_NAME
- item.ChartPermissionId = utils.GU_SHOU_ID_CHART
- }
- if strings.Contains(v.CategoryName, "策略") {
- item.ChartPermissionName = utils.CE_LUE_NAME
- item.ChartPermissionId = utils.CE_LUE_ID
- }
- items = append(items, item)
- }
- }
- //文章阅读记录内容 end
- //活动记录内容
- {
- condition = " AND art.company_id IN (" + utils.GetOrmInReplace(lencompanyId) + ") AND a.activity_time > ? "
- signUpDetailList, e := models.GetSignupDetailBySignupjoinactivity(condition+" ORDER BY a.activity_time ASC ", pars)
- if e != nil {
- err = errors.New("GetSignupDetailBySignupjoinactivity, Err: " + e.Error())
- return
- }
- //文章阅读明细
- var conditionBill string
- var parsBill []interface{}
- conditionBill = " AND source = 'activity' AND company_id IN (" + utils.GetOrmInReplace(lencompanyId) + ") AND view_time > ? "
- parsBill = append(parsBill, companyIds, startWeekDate)
- listBillByActivity, e := rai_serve.GetCygxRaiServeBillListAll(conditionBill, parsBill)
- if e != nil {
- err = errors.New("GetCygxRaiServeBillListAll, Err: " + e.Error())
- return
- }
- mapActivityeBill := make(map[string]bool)
- for _, v := range listBillByActivity {
- mapActivityeBill[fmt.Sprint("UID_", v.Mobile, "SID_", v.SourceId)] = true
- }
- mapArticleBillDel := make(map[string]bool)
- for _, v := range signUpDetailList {
- mapArticleBillDel[fmt.Sprint("UID_", v.UserId, "SID_", v.ActivityId)] = true
- }
- mapDelActivityBillDel := make(map[string]bool)
- for _, v := range signUpDetailList {
- mapDelActivityBillDel[fmt.Sprint("UID_", v.UserId, "SID_", v.ActivityId)] = true
- }
- for _, v := range listBillByActivity {
- if !mapDelActivityBillDel[fmt.Sprint("UID_", v.UserId, "SID_", v.SourceId)] { // 如果内容存在就插入删除ID中
- delBillIds = append(delBillIds, v.BillId)
- }
- }
- for _, v := range signUpDetailList {
- if v.UserId == 0 && v.Mobile != "" {
- v.UserId = mapUserMobileUserId[v.Mobile] // 空降的部分联系人 userid 为0这里做一下修复
- }
- if mapActivityeBill[fmt.Sprint("UID_", v.Mobile, "SID_", v.ActivityId)] { // 如果内容存在就不插入
- continue
- }
- item := new(rai_serve.CygxRaiServeBill)
- item.Content = v.ActivityName
- if v.ActivityType == 1 {
- item.ServeTypeId = 1
- item.ServeTypeName = "线上活动"
- } else {
- item.ServeTypeId = 2
- item.ServeTypeName = "线下活动"
- }
- item.UserId = v.UserId
- item.Mobile = v.Mobile
- item.Email = v.Email
- item.CompanyId = v.CompanyId
- item.CompanyName = v.CompanyName
- item.RealName = v.RealName
- //item.RegisterPlatform = v.RegisterPlatform
- item.ServeCount = 1
- if mapUserMaker[v.UserId] {
- item.IsKp = 1
- item.ServeCount = item.ServeCount * 3
- }
- item.SourceId = v.ActivityId
- item.Source = utils.CYGX_OBJ_ACTIVITY
- item.CreateTime = time.Now()
- item.ViewTime = v.ActivityTime
- item.ChartPermissionName = v.ChartPermissionName
- item.ChartPermissionId = v.ChartPermissionId
- item.WeekStartDate, item.WeekEndDate = utils.GetMondayAndSundayByTimeString(item.ViewTime)
- item.MonthStartDate, item.MonthEndDate = utils.GetFirstAndLastDayOfMonth(item.ViewTime)
- items = append(items, item)
- }
- }
- //活动记录内容 end
- //专项调研活动记录内容
- {
- condition = " AND art.company_id IN (" + utils.GetOrmInReplace(lencompanyId) + ") AND a.activity_time > ? "
- activitySpecialList, e := models.GetCygxActivitySpecialMeetingDetailList(condition+" ORDER BY a.activity_time ASC ", pars)
- if e != nil {
- err = errors.New("GetCygxActivitySpecialMeetingDetailList, Err: " + e.Error())
- return
- }
- //专项调研活动明细
- var conditionBill string
- var parsBill []interface{}
- conditionBill = " AND source = 'activityspecial' AND company_id IN (" + utils.GetOrmInReplace(lencompanyId) + ") AND view_time > ? "
- parsBill = append(parsBill, companyIds, startWeekDate)
- listBillByActivitySpecial, e := rai_serve.GetCygxRaiServeBillListAll(conditionBill, parsBill)
- if e != nil {
- err = errors.New("GetCygxRaiServeBillListAll, Err: " + e.Error())
- return
- }
- mapActivitySpecial := make(map[string]bool)
- for _, v := range listBillByActivitySpecial {
- mapActivitySpecial[fmt.Sprint("UID_", v.UserId, "SID_", v.SourceId)] = true
- }
- mapDelActivitySpecial := make(map[string]bool)
- for _, v := range activitySpecialList {
- mapDelActivitySpecial[fmt.Sprint("UID_", v.UserId, "SID_", v.ActivityId)] = true
- }
- for _, v := range listBillByActivitySpecial {
- if !mapDelActivitySpecial[fmt.Sprint("UID_", v.UserId, "SID_", v.SourceId)] { // 如果内容存在就插入删除ID中
- delBillIds = append(delBillIds, v.BillId)
- }
- }
- for _, v := range activitySpecialList {
- if mapActivitySpecial[fmt.Sprint("UID_", v.UserId, "SID_", v.ActivityId)] { // 如果内容存在就不插入
- continue
- }
- item := new(rai_serve.CygxRaiServeBill)
- item.Content = v.ResearchTheme
- item.ServeTypeId = 3
- item.ServeTypeName = "专项调研"
- item.UserId = v.UserId
- item.Mobile = v.Mobile
- item.Email = v.Email
- item.CompanyId = v.CompanyId
- item.CompanyName = v.CompanyName
- item.RealName = v.RealName
- //item.RegisterPlatform = v.RegisterPlatform
- item.ServeCount = 1
- if mapUserMaker[v.UserId] {
- item.IsKp = 1
- item.ServeCount = item.ServeCount * 3
- }
- item.SourceId = v.ActivityId
- item.Source = utils.CYGX_OBJ_ACTIVITYSPECIAL
- item.CreateTime = time.Now()
- item.ViewTime = v.ActivityTime
- item.ChartPermissionName = v.ChartPermissionName
- item.ChartPermissionId = v.ChartPermissionId
- item.WeekStartDate, item.WeekEndDate = utils.GetMondayAndSundayByTimeString(item.ViewTime)
- item.MonthStartDate, item.MonthEndDate = utils.GetFirstAndLastDayOfMonth(item.ViewTime)
- items = append(items, item)
- }
- }
- //专项调研活动记录内容 end
- //1v1路演
- {
- condition = " AND art.company_id IN (" + utils.GetOrmInReplace(lencompanyId) + ") AND rs.start_date > ? "
- calendarMeetingUserList, e := roadshow.GetRsCalendarMeetingUserList(condition+" ORDER BY rs.start_date ASC ", pars)
- if e != nil {
- err = errors.New("GetRsCalendarMeetingUserList, Err: " + e.Error())
- return
- }
- var rsCalendarIds []int
- for _, v := range calendarMeetingUserList {
- rsCalendarIds = append(rsCalendarIds, v.RsCalendarId)
- }
- //获取研究员信息
- researchers, e := roadshow.GetRsCalendarResearcherListByIds(rsCalendarIds)
- if e != nil {
- err = errors.New("GetRsCalendarResearcherListByIds, Err: " + e.Error())
- return
- }
- mapResearcherName := make(map[int][]string)
- for _, v := range researchers {
- mapResearcherName[v.RsCalendarId] = append(mapResearcherName[v.RsCalendarId], v.ResearcherName)
- }
- listEmail, e := models.GetAskEmail()
- if e != nil {
- err = errors.New("GetAskEmail, Err: " + e.Error())
- return
- }
- var ceLueResearcherName []string
- var guShouResearcherName []string
- for _, v := range listEmail {
- if v.ChartPermissionName == utils.CE_LUE_NAME {
- ceLueResearcherName = append(ceLueResearcherName, v.Name)
- }
- if v.ChartPermissionName == utils.GU_SHOU_NAME {
- guShouResearcherName = append(guShouResearcherName, v.Name)
- }
- }
- //专项调研活动明细
- var conditionBill string
- var parsBill []interface{}
- conditionBill = " AND source = 'rscalendar' AND company_id IN (" + utils.GetOrmInReplace(lencompanyId) + ") AND view_time > ? "
- parsBill = append(parsBill, companyIds, startWeekDate)
- listBillByRscalendar, e := rai_serve.GetCygxRaiServeBillListAll(conditionBill, parsBill)
- if e != nil {
- err = errors.New("GetCygxRaiServeBillListAll, Err: " + e.Error())
- return
- }
- mapRscalendarBill := make(map[string]bool)
- for _, v := range listBillByRscalendar {
- mapRscalendarBill[fmt.Sprint("UID_", v.UserId, "SID_", v.SourceId)] = true
- }
- mapDelRscalendarBill := make(map[string]bool)
- for _, v := range calendarMeetingUserList {
- mapDelRscalendarBill[fmt.Sprint("UID_", v.UserId, "SID_", v.RsCalendarId)] = true
- }
- for _, v := range listBillByRscalendar {
- if !mapDelRscalendarBill[fmt.Sprint("UID_", v.UserId, "SID_", v.SourceId)] { // 如果内容存在就插入删除ID中
- delBillIds = append(delBillIds, v.BillId)
- }
- }
- for _, v := range calendarMeetingUserList {
- if mapRscalendarBill[fmt.Sprint("UID_", v.UserId, "SID_", v.RsCalendarId)] { // 如果内容存在就不插入
- continue
- }
- item := new(rai_serve.CygxRaiServeBill)
- item.Content = strings.Join(mapResearcherName[v.RsCalendarId], ",")
- item.ServeTypeId = 4
- item.ServeTypeName = "一对一路演"
- item.UserId = v.UserId
- item.Mobile = v.Mobile
- item.Email = v.Email
- item.CompanyId = v.CompanyId
- item.CompanyName = v.CompanyName
- item.RealName = v.RealName
- //item.RegisterPlatform = v.RegisterPlatform
- item.ServeCount = 1.5
- if mapUserMaker[v.UserId] {
- item.IsKp = 1
- item.ServeCount = item.ServeCount * 3
- }
- item.SourceId = v.RsCalendarId
- item.Source = utils.CYGX_OBJ_RS_CALENDAR
- item.CreateTime = time.Now()
- item.ViewTime = v.StartDate + " " + v.StartTime
- item.WeekStartDate, item.WeekEndDate = utils.GetMondayAndSundayByTimeString(item.ViewTime)
- item.MonthStartDate, item.MonthEndDate = utils.GetFirstAndLastDayOfMonth(item.ViewTime)
- if utils.InArrayByStr(guShouResearcherName, item.Content) {
- item.ChartPermissionName = utils.GU_SHOU_NAME
- item.ChartPermissionId = utils.GU_SHOU_ID_CHART
- }
- if utils.InArrayByStr(ceLueResearcherName, item.Content) {
- item.ChartPermissionName = utils.CE_LUE_NAME
- item.ChartPermissionId = utils.CE_LUE_ID
- }
- items = append(items, item)
- }
- }
- //1v1路演 end
- //交流反馈
- {
- condition = " AND company_id IN (" + utils.GetOrmInReplace(lencompanyId) + ") AND create_time > ? "
- userFeedbackList, e := rai_serve.GetCygxUserFeedbackList(condition+" ORDER BY user_feedback_id ASC ", pars)
- if e != nil {
- err = errors.New("GetCygxUserFeedbackList, Err: " + e.Error())
- return
- }
- //交流反馈明细
- var conditionBill string
- var parsBill []interface{}
- conditionBill = " AND source = 'userfeedback' AND company_id IN (" + utils.GetOrmInReplace(lencompanyId) + ") AND view_time > ? "
- parsBill = append(parsBill, companyIds, startWeekDate)
- listBillByuserFeedback, e := rai_serve.GetCygxRaiServeBillListAll(conditionBill, parsBill)
- if e != nil {
- err = errors.New("GetCygxRaiServeBillListAll, Err: " + e.Error())
- return
- }
- mapRscalendarBill := make(map[string]bool)
- for _, v := range listBillByuserFeedback {
- mapRscalendarBill[fmt.Sprint("UID_", v.UserId, "SID_", v.SourceId)] = true
- }
- mapDelRscalendarBill := make(map[string]bool)
- for _, v := range userFeedbackList {
- mapDelRscalendarBill[fmt.Sprint("UID_", v.UserId, "SID_", v.UserFeedbackId)] = true
- }
- for _, v := range listBillByuserFeedback {
- if !mapDelRscalendarBill[fmt.Sprint("UID_", v.UserId, "SID_", v.SourceId)] { // 如果内容存在就插入删除ID中
- delBillIds = append(delBillIds, v.BillId)
- }
- }
- for _, v := range userFeedbackList {
- if mapRscalendarBill[fmt.Sprint("UID_", v.UserId, "SID_", v.UserFeedbackId)] { // 如果内容存在就不插入
- continue
- }
- item := new(rai_serve.CygxRaiServeBill)
- item.Content = v.Content
- item.ServeTypeId = 6
- item.ServeTypeName = "交流反馈"
- item.UserId = v.UserId
- item.Mobile = v.Mobile
- item.Email = v.Email
- item.CompanyId = v.CompanyId
- item.CompanyName = v.CompanyName
- item.RealName = v.RealName
- item.ServeCount = 1
- if mapUserMaker[v.UserId] {
- item.IsKp = 1
- item.ServeCount = item.ServeCount * 3
- }
- item.SourceId = v.UserFeedbackId
- item.Source = utils.CYGX_OBJ_USER_FEEDBACK
- item.CreateTime = time.Now()
- item.ViewTime = v.CreateTime
- item.WeekStartDate, item.WeekEndDate = utils.GetMondayAndSundayByTimeString(item.ViewTime)
- item.MonthStartDate, item.MonthEndDate = utils.GetFirstAndLastDayOfMonth(item.ViewTime)
- items = append(items, item)
- }
- }
- //交流反馈 end
- if len(items) > 0 {
- var itemsAdd []*rai_serve.CygxRaiServeBill
- for k, v := range items {
- itemsAdd = append(itemsAdd, v)
- if len(itemsAdd)%2000 == 0 {
- fmt.Println(k)
- e = rai_serve.AddCygxRaiServeBillMulti(itemsAdd)
- if e != nil {
- err = errors.New("AddCygxRaiServeBillMulti, Err: " + e.Error())
- return
- }
- itemsAdd = make([]*rai_serve.CygxRaiServeBill, 0)
- }
- }
- e = rai_serve.AddCygxRaiServeBillMulti(itemsAdd)
- if e != nil {
- err = errors.New("AddCygxRaiServeBillMulti, Err: " + e.Error())
- return
- }
- }
- fmt.Println("delBillIds", (delBillIds))
- fmt.Println("UpdateCygxRaiServeBillByCompanyIds end")
- return
- }
- // 更新周度服务明细
- func UpdateCygxRaiServeBillWeek() (err error) {
- defer func() {
- if err != nil {
- fmt.Println(err)
- go utils.SendAlarmMsg("批量更新企业服务明细记录失败: UpdateCygxRaiServeBillByCompanyIds Err"+err.Error(), 2)
- }
- }()
- now := time.Now()
- weeks := 12
- companyList, e := rai_serve.GetCygxRaiServeCompanyAllList()
- if e != nil {
- err = errors.New("GetCygxRaiServeCompanyAllList, Err: " + e.Error())
- return
- }
- var companyIds []int
- for _, v := range companyList {
- companyIds = append(companyIds, v.CompanyId)
- }
- listCompanyUserNum, e := models.GetWxUserNumByCompanyIds(companyIds)
- if e != nil {
- err = errors.New("GetWxUserisMakerByCompanyIds, Err: " + e.Error())
- return
- }
- mapCompanyUserNum := make(map[int]int) //企业对应的用户数量
- for _, v := range listCompanyUserNum {
- mapCompanyUserNum[v.CompanyId] = v.UserNum
- }
- lencompanyId := len(companyIds)
- //研选阅读明细
- var conditionBill string
- var parsBill []interface{}
- var startWeekDate = time.Now().AddDate(0, 0, -75).Format(utils.FormatDate) + " 23:59:59"
- conditionBill = " AND company_id IN (" + utils.GetOrmInReplace(lencompanyId) + ") AND view_time > ? "
- parsBill = append(parsBill, companyIds, startWeekDate)
- listBillByYanxuanspecial, e := rai_serve.GetCygxRaiServeBillListAll(conditionBill, parsBill)
- if e != nil {
- err = errors.New("GetCygxRaiServeBillListAll, Err: " + e.Error())
- return
- }
- mapWeekServeCount := make(map[string]float64)
- for _, v := range listBillByYanxuanspecial {
- mapWeekServeCount[fmt.Sprint("CID_", v.CompanyId, "WEEK_", v.WeekStartDate)] += v.ServeCount
- }
- fmt.Println(companyIds)
- var items []*rai_serve.CygxRaiServeWeekBill
- for _, v := range companyList {
- for i := 0; i < weeks; i++ {
- item := new(rai_serve.CygxRaiServeWeekBill)
- // 计算当前周的周一
- monday := now.AddDate(0, 0, -int(now.Weekday()-time.Monday)-i*7)
- // 计算当前周的周日
- sunday := monday.AddDate(0, 0, 6)
- item.WeekStartDate = monday.Format(utils.FormatDate)
- item.WeekEndDate = sunday.Format(utils.FormatDate)
- item.CompanyId = v.CompanyId
- item.CompanyName = v.CompanyName
- item.UserTotal = mapCompanyUserNum[v.CompanyId]
- item.WeekServeCount = mapWeekServeCount[fmt.Sprint("CID_", v.CompanyId, "WEEK_", item.WeekStartDate)]
- if mapCompanyUserNum[v.CompanyId] > 0 {
- item.CoverageRate = item.WeekServeCount / float64(mapCompanyUserNum[v.CompanyId]) * 100
- }
- item.CreateTime = time.Now()
- item.ModifyTime = time.Now()
- items = append(items, item)
- }
- }
- e = rai_serve.AddCygxRaiServeWeekBillMulti(items)
- if e != nil {
- err = errors.New("AddCygxRaiServeWeekBillMulti, Err: " + e.Error())
- return
- }
- return
- }
- func UpdateCygxRaiServeBillWeekTask() (err error) {
- defer func() {
- if err != nil {
- fmt.Println(err)
- go utils.SendAlarmMsg("批量更新企业服务明细记录失败: UpdateCygxRaiServeBillByCompanyIds Err"+err.Error(), 2)
- }
- }()
- fmt.Println("UpdateCygxRaiServeBillWeekTask start")
- now := time.Now()
- weeks := 11
- companyList, e := rai_serve.GetCygxRaiServeCompanyAllList()
- if e != nil {
- err = errors.New("GetCygxRaiServeCompanyAllList, Err: " + e.Error())
- return
- }
- var companyIds []int
- for _, v := range companyList {
- companyIds = append(companyIds, v.CompanyId)
- }
- listCompanyUserNum, e := models.GetWxUserNumByCompanyIds(companyIds)
- if e != nil {
- err = errors.New("GetWxUserisMakerByCompanyIds, Err: " + e.Error())
- return
- }
- mapCompanyUserNum := make(map[int]int) //企业对应的用户数量
- for _, v := range listCompanyUserNum {
- mapCompanyUserNum[v.CompanyId] = v.UserNum
- }
- lencompanyId := len(companyIds)
- if lencompanyId == 0 {
- return
- }
- //明细
- var conditionBill string
- var parsBill []interface{}
- var startWeekDate = time.Now().AddDate(0, 0, -75).Format(utils.FormatDate) + " 23:59:59"
- conditionBill = " AND company_id IN (" + utils.GetOrmInReplace(lencompanyId) + ") AND view_time > ? "
- parsBill = append(parsBill, companyIds, startWeekDate)
- listBill, e := rai_serve.GetCygxRaiServeBillListAll(conditionBill, parsBill)
- if e != nil {
- err = errors.New("GetCygxRaiServeBillListAll, Err: " + e.Error())
- return
- }
- mapWeekServeCount := make(map[string]float64)
- for _, v := range listBill {
- mapWeekServeCount[fmt.Sprint("CID_", v.CompanyId, "WEEK_", v.WeekStartDate)] += v.ServeCount
- }
- var conditionWeek string
- var parsWeek []interface{}
- conditionWeek = ` AND week_start_date > ? `
- parsWeek = append(parsWeek, startWeekDate)
- listWeekBill, e := rai_serve.GetCygxRaiServeWeekBillListAll(conditionWeek, parsWeek)
- if e != nil {
- err = errors.New("GetCygxRaiServeWeekBillListAll, Err: " + e.Error())
- return
- }
- //return
- mapWeekbill := make(map[string]bool)
- mapWeekbill2 := make(map[string]int)
- mapWeekbillUserTotal := make(map[string]int)
- mapWeekbillWeekServeCount := make(map[string]float64)
- mapWeekbillWeekCoverageRate := make(map[string]float64)
- for _, v := range listWeekBill {
- mapWeekbill[fmt.Sprint("CID_", v.CompanyId, "WEEK_", v.WeekStartDate)] = true
- mapWeekbill2[fmt.Sprint("CID_", v.CompanyId, "WEEK_", v.WeekStartDate)] = v.CompanyId
- mapWeekbillUserTotal[fmt.Sprint("CID_", v.CompanyId, "WEEK_", v.WeekStartDate)] = v.UserTotal
- mapWeekbillWeekServeCount[fmt.Sprint("CID_", v.CompanyId, "WEEK_", v.WeekStartDate)] = v.WeekServeCount
- mapWeekbillWeekCoverageRate[fmt.Sprint("CID_", v.CompanyId, "WEEK_", v.WeekStartDate)] = v.CoverageRate
- }
- var items []*rai_serve.CygxRaiServeWeekBill
- var itemsUpdate []*rai_serve.CygxRaiServeWeekBill
- for _, v := range companyList {
- for i := 0; i < weeks; i++ {
- if i == 10 {
- continue
- }
- item := new(rai_serve.CygxRaiServeWeekBill)
- // 计算当前周的周一
- monday := now.AddDate(0, 0, -int(now.Weekday()-time.Monday)-i*7)
- // 计算当前周的周日
- sunday := monday.AddDate(0, 0, 6)
- item.WeekStartDate = monday.Format(utils.FormatDate)
- item.WeekEndDate = sunday.Format(utils.FormatDate)
- item.CompanyId = v.CompanyId
- item.CompanyName = v.CompanyName
- //超过本周的,互动总人数不做修改
- if i > 0 && mapWeekbillUserTotal[fmt.Sprint("CID_", v.CompanyId, "WEEK_", item.WeekStartDate)] > 0 {
- item.UserTotal = mapWeekbillUserTotal[fmt.Sprint("CID_", v.CompanyId, "WEEK_", item.WeekStartDate)]
- } else {
- item.UserTotal = mapCompanyUserNum[v.CompanyId]
- }
- item.WeekServeCount = mapWeekServeCount[fmt.Sprint("CID_", v.CompanyId, "WEEK_", item.WeekStartDate)]
- if mapCompanyUserNum[v.CompanyId] > 0 {
- item.CoverageRate = item.WeekServeCount / float64(mapCompanyUserNum[v.CompanyId]) * 100
- }
- item.CreateTime = time.Now()
- item.ModifyTime = time.Now()
- if mapWeekbill[fmt.Sprint("CID_", v.CompanyId, "WEEK_", item.WeekStartDate)] {
- if mapWeekbillUserTotal[fmt.Sprint("CID_", v.CompanyId, "WEEK_", item.WeekStartDate)] == item.UserTotal && mapWeekbillWeekServeCount[fmt.Sprint("CID_", v.CompanyId, "WEEK_", item.WeekStartDate)] == item.WeekServeCount {
- continue // 如果互动量相等,且人数相等,就不修改
- }
- itemsUpdate = append(itemsUpdate, item)
- } else {
- items = append(items, item)
- }
- }
- }
- fmt.Println("itemsadd", len(items))
- if len(items) > 0 {
- e = rai_serve.AddCygxRaiServeWeekBillMulti(items)
- if e != nil {
- err = errors.New("AddCygxRaiServeWeekBillMulti, Err: " + e.Error())
- return
- }
- }
- fmt.Println("itemsUpdate111", len(itemsUpdate))
- if len(itemsUpdate) > 0 {
- e = rai_serve.UpdateCygxRaiServeWeekBillMulti(itemsUpdate)
- if e != nil {
- err = errors.New("AddCygxRaiServeWeekBillMulti, Err: " + e.Error())
- return
- }
- }
- fmt.Println("UpdateCygxRaiServeBillWeekTask end")
- return
- }
- //func init() {
- // UpdateWeekAvg()
- //}
- // 更新最近四周平均覆盖率,是否标红,权限,时间,金额
- func UpdateWeekAvg() (err error) {
- defer func() {
- if err != nil {
- fmt.Println(err)
- go utils.SendAlarmMsg("批量更新企业服务明细记录失败: UpdateCygxRaiServeBillByCompanyIds Err"+err.Error(), 2)
- }
- }()
- fmt.Println(" UpdateWeekAvg start")
- now := time.Now()
- weeks := 3
- monday := now.AddDate(0, 0, -int(now.Weekday()-time.Monday)-weeks*7)
- startDate := monday.Format(utils.FormatDate)
- var condition string
- var pars []interface{}
- condition = ` AND week_start_date >= ? `
- pars = append(pars, startDate)
- listWeekBill, e := rai_serve.GetCygxRaiServeWeekBillListAll(condition, pars)
- if e != nil {
- err = errors.New("GetCygxRaiServeWeekBillListAll, Err: " + e.Error())
- return
- }
- mapWeekServeCount := make(map[int]float64) //四周平均率总合
- for _, v := range listWeekBill {
- mapWeekServeCount[v.CompanyId] += v.CoverageRate
- }
- //获取近四周含有Kp 的公司
- condition = ""
- pars = make([]interface{}, 0)
- condition += ` AND week_start_date >= ? AND is_kp = 1 GROUP BY company_id `
- pars = append(pars, startDate)
- listIsKpWeekBill, e := rai_serve.GetCygxRaiServeBillListAll(condition, pars)
- if e != nil {
- err = errors.New("GetCygxRaiServeWeekBillListAll, Err: " + e.Error())
- return
- }
- mapWeekIsKp := make(map[int]bool) //最近四周是否包含KP
- for _, v := range listIsKpWeekBill {
- mapWeekIsKp[v.CompanyId] = true
- }
- companyList, e := rai_serve.GetCygxRaiServeCompanyAllList()
- if e != nil {
- err = errors.New("GetCygxRaiServeCompanyAllList, Err: " + e.Error())
- return
- }
- var formalCompanyIds []int // 当前正式客户ID
- var formalNoCompanyIds []int // 当前非正式客户ID
- //永续客户当做正式客户处理
- for _, v := range companyList {
- if v.Status == "正式" || v.Status == "永续" {
- formalCompanyIds = append(formalCompanyIds, v.CompanyId)
- } else {
- formalNoCompanyIds = append(formalNoCompanyIds, v.CompanyId)
- }
- }
- var itemsUpdate []*rai_serve.CygxRaiServeCompany
- if len(formalCompanyIds) > 0 { //正式客户信息
- condition = ""
- pars = make([]interface{}, 0)
- condition = ` AND product_id = 2 AND company_id IN (` + utils.GetOrmInReplace(len(formalCompanyIds)) + `) AND status = 1 AND end_date > ? `
- pars = append(pars, formalCompanyIds, time.Now())
- listCompanyContract, e := company.GetCompanyContractList(condition, pars)
- if e != nil {
- err = errors.New("GetCompanyContractList, Err: " + e.Error())
- return
- }
- companyMoney := make(map[int]float64)
- for _, v := range listCompanyContract {
- companyMoney[v.CompanyId] += v.Money
- }
- permissionNameMapByCompanyId, e := GetCompanyReportPermissionNameMapByCompanyId(formalCompanyIds)
- if e != nil {
- err = errors.New("GetCompanyReportPermissionNameMapByCompanyId, Err: " + e.Error())
- return
- }
- for _, v := range formalCompanyIds {
- item := new(rai_serve.CygxRaiServeCompany)
- item.CompanyId = v
- item.Money = companyMoney[v]
- item.PermissionName = permissionNameMapByCompanyId[v]
- item.ServeCoverageRate = utils.SubFloatToString(mapWeekServeCount[v]/4, 2)
- item.IsUserMaker = -1
- if mapWeekIsKp[v] {
- item.IsUserMaker = 1
- }
- itemsUpdate = append(itemsUpdate, item)
- }
- }
- //正式客户数据修改
- e = rai_serve.UpdateCygxRaiServeCompanyMulti(itemsUpdate)
- if e != nil {
- err = errors.New("UpdateCygxRaiServeCompanyMulti, Err: " + e.Error())
- return
- }
- var itemsUpdateFormalNo []*rai_serve.CygxRaiServeCompany //非正式客户数据修改
- var itemsUpdateFormalNoContract []*rai_serve.CygxRaiServeCompany //非正式客户没有合同的客户修改
- mapContractCompanyIds := make(map[int]bool) //签过合同的试用客户ID
- if len(formalNoCompanyIds) > 0 { //非正式客户信息
- condition = ""
- pars = make([]interface{}, 0)
- 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 `
- pars = append(pars, formalNoCompanyIds, time.Now())
- listCompanyContractLastId, e := company.GetCompanyContractLastList(condition, pars) //获取关联的最后一笔合同信息
- if e != nil {
- err = errors.New("GetCompanyContractLastList, Err: " + e.Error())
- return
- }
- var companyContractIds []int
- for _, v := range listCompanyContractLastId {
- companyContractIds = append(companyContractIds, v.CompanyContractId)
- }
- condition = ""
- pars = make([]interface{}, 0)
- 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 `
- pars = append(pars, formalNoCompanyIds, companyContractIds, time.Now())
- listCompanyContractLast, e := company.GetCompanyContractList(condition, pars)
- if e != nil {
- err = errors.New("GetCompanyContractList, Err: " + e.Error())
- return
- }
- permissionNameMapByContractId, e := GetCompanyContractPermissionNameMapById(companyContractIds)
- if e != nil {
- err = errors.New("GetCompanyReportPermissionNameMapByCompanyId, Err: " + e.Error())
- return
- }
- for _, v := range listCompanyContractLast {
- item := new(rai_serve.CygxRaiServeCompany)
- item.CompanyId = v.CompanyId
- item.Money = v.Money
- item.StartDate = v.StartDate
- item.EndDate = v.EndDate
- item.ServeCoverageRate = utils.SubFloatToString(mapWeekServeCount[v.CompanyId]/4, 2)
- item.IsUserMaker = -1
- if mapWeekIsKp[v.CompanyId] {
- item.IsUserMaker = 1
- }
- item.PermissionName = permissionNameMapByContractId[v.CompanyContractId]
- itemsUpdateFormalNo = append(itemsUpdateFormalNo, item)
- mapContractCompanyIds[v.CompanyId] = true
- }
- for _, v := range formalNoCompanyIds {
- if mapContractCompanyIds[v] {
- continue
- }
- //fmt.Println(v)
- item := new(rai_serve.CygxRaiServeCompany)
- item.CompanyId = v
- item.ServeCoverageRate = utils.SubFloatToString(mapWeekServeCount[v]/4, 2)
- item.IsUserMaker = -1
- if mapWeekIsKp[v] {
- item.IsUserMaker = 1
- }
- itemsUpdateFormalNoContract = append(itemsUpdateFormalNoContract, item)
- }
- }
- e = rai_serve.UpdateCygxRaiServeCompanyFormalNoMulti(itemsUpdateFormalNo)
- if e != nil {
- err = errors.New("UpdateCygxRaiServeCompanyFormalNoMulti, Err: " + e.Error())
- return
- }
- e = rai_serve.UpdateCygxRaiServeCompanyFormalNoContractMulti(itemsUpdateFormalNoContract)
- if e != nil {
- err = errors.New("UpdateCygxRaiServeCompanyFormalNoMulti, Err: " + e.Error())
- return
- }
- fmt.Println(" UpdateWeekAvg end")
- return
- }
|