123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260 |
- package cygx
- import (
- "errors"
- "fmt"
- "hongze/hz_crm_api/models"
- "hongze/hz_crm_api/models/company"
- "hongze/hz_crm_api/models/cygx"
- "hongze/hz_crm_api/services/alarm_msg"
- "hongze/hz_crm_api/utils"
- "strings"
- "time"
- )
- // 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 {
- 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 + "(3w),"
- }
- } 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.CHART_PERMISSION_ID_YANXUAN {
- if v.ExpensiveYx == 1 {
- mapContractIdPerssion[(v.CompanyContractId)] += "," + utils.CHART_PERMISSION_NAME_MF_YANXUAN + "(5w)"
- } else {
- mapContractIdPerssion[(v.CompanyContractId)] += "," + utils.CHART_PERMISSION_NAME_MF_YANXUAN + "(3w)"
- }
- }
- }
- }
- //合并客观权限
- 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
- }
- // 判断合同审核通过时间是否超过九十天
- func GetMapIsGrayByCompanyContractIds(companyContractIds []int) (mapResp map[int]bool, err error) {
- lenArr := len(companyContractIds)
- if lenArr == 0 {
- return
- }
- var condition string
- var pars []interface{}
- pars = make([]interface{}, 0)
- condition = " AND company_contract_id IN (" + utils.GetOrmInReplace(lenArr) + ") GROUP BY company_contract_id ORDER BY create_time DESC "
- pars = append(pars, companyContractIds)
- companyContractPermissionList, e := company.GetCompanyContractPermissionList(condition, pars)
- if e != nil && e.Error() != utils.ErrNoRow() {
- err = errors.New("GetCompanyContractPermissionList, Err: " + e.Error())
- return
- }
- //超过九十天就置灰
- timeInit := time.Now().AddDate(0, 0, -180)
- mapResp = make(map[int]bool, 0)
- for _, v := range companyContractPermissionList {
- if v.CreateTime.Before(timeInit) {
- mapResp[v.CompanyContractId] = true
- }
- }
- return
- }
- //func init3() {
- // var condition string
- // var pars []interface{}
- // //默认只查询权益 2023-06-01 之后的合同
- // condition += ` AND c.product_id = ? AND a.start_date > ? `
- // pars = append(pars, 2, "2023-06-01")
- //
- // //列表页数据
- // list, err := cygx.GetCompanyContractListJoinCompany(condition, pars, 0, 1000)
- // if err != nil {
- // fmt.Println(err)
- // return
- // }
- //
- // for _, v := range list {
- // fmt.Println(v.CompanyContractId)
- // HandleAllocationCompanyContractByYanXuan(v.CompanyContractId)
- // }
- //
- // fmt.Println(len(list))
- //}
- // 如果合同只有研选的时候,自动处理派点
- func HandleAllocationCompanyContractByYanXuan(companyContractId int) (err error) {
- defer func() {
- if err != nil {
- fmt.Println(err)
- go alarm_msg.SendAlarmMsg(fmt.Sprint("如果合同只有研选的时候,自动处理派点失败,Err:", err.Error(), "companyContractId", companyContractId), 2)
- }
- }()
- var condition string
- var pars []interface{}
- pars = make([]interface{}, 0)
- condition = " AND company_contract_id = ? "
- pars = append(pars, companyContractId)
- companyContractPermissionList, e := company.GetCompanyContractPermissionList(condition, pars)
- if e != nil && e.Error() != utils.ErrNoRow() {
- err = errors.New("GetCompanyContractPermissionList, Err: " + e.Error())
- return
- }
- if e != nil && e.Error() != utils.ErrNoRow() {
- err = errors.New("GetCygxAllocationCompanyContractPermissionListById, Err: " + e.Error())
- return
- }
- if len(companyContractPermissionList) > 1 {
- return
- }
- var expensiveYxmoney float64
- for _, v := range companyContractPermissionList {
- if v.ChartPermissionId != utils.CHART_PERMISSION_ID_YANXUAN {
- err = errors.New("没有发现研选权限: ")
- return
- }
- if v.ExpensiveYx == 1 {
- expensiveYxmoney = 5
- } else if v.ExpensiveYx == 2 {
- expensiveYxmoney = 10
- } else {
- expensiveYxmoney = 3
- }
- }
- var items []*cygx.CygxAllocationCompanyContract
- var itemsPermission []*cygx.CygxAllocationCompanyContractPermission
- itemPermission := new(cygx.CygxAllocationCompanyContractPermission)
- itemPermission.CompanyContractId = companyContractId
- //itemPermission.AdminId = sysUser.AdminId
- //itemPermission.AdminName = sysUser.RealName
- itemPermission.Proportion = 0
- itemPermission.Money = expensiveYxmoney
- itemPermission.MoneyAvg = 0
- itemPermission.ChartPermissionName = utils.CHART_PERMISSION_NAME_MF_YANXUAN
- itemPermission.CreateTime = time.Now()
- itemPermission.ModifyTime = time.Now()
- itemsPermission = append(itemsPermission, itemPermission)
- item := new(cygx.CygxAllocationCompanyContract)
- item.CompanyContractId = companyContractId
- //item.AdminId = sysUser.AdminId
- //item.AdminName = sysUser.RealName
- item.Proportion = 0
- item.Money = expensiveYxmoney
- item.RealName = utils.CHART_PERMISSION_NAME_MF_YANXUAN
- item.ChartPermissionName = utils.CHART_PERMISSION_NAME_MF_YANXUAN
- item.CreateTime = time.Now()
- item.ModifyTime = time.Now()
- items = append(items, item)
- e = cygx.AddAndUpdateCygxAllocationCompanyContract(items, itemsPermission, companyContractId)
- if e != nil {
- err = errors.New("AddAndUpdateCygxAllocationCompanyContract, Err: " + e.Error())
- return
- }
- return
- }
|