contract_allocation.go 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120
  1. package cygx
  2. import (
  3. "errors"
  4. "hongze/hz_crm_api/models"
  5. "hongze/hz_crm_api/models/company"
  6. "hongze/hz_crm_api/utils"
  7. "strconv"
  8. "strings"
  9. )
  10. // GetCompanyContractPermissionNameMapById 获取合并之后的合同所对应的权限种类名称
  11. func GetCompanyContractPermissionNameMapById(mapCompamy map[int]string) (mapContractResp map[int]string, err error) {
  12. //return
  13. if len(mapCompamy) == 0 {
  14. return
  15. }
  16. var condition string
  17. var pars []interface{}
  18. mapContracIdCompanyId := make(map[string]int) //建立合同ID与公司ID的map对应关系
  19. var companyContractIdGroup string //多个合同ID
  20. for k, v := range mapCompamy {
  21. companyContractIdGroup += v + ","
  22. sliceContract := strings.Split(v, ",")
  23. for _, compamyContracId := range sliceContract {
  24. mapContracIdCompanyId[compamyContracId] = k
  25. }
  26. }
  27. companyContractIdGroup = strings.TrimRight(companyContractIdGroup, ",")
  28. condition += " AND company_contract_id IN (" + companyContractIdGroup + ")"
  29. companyContractList, e := company.GetCompanyContractList(condition, pars)
  30. if e != nil && e.Error() != utils.ErrNoRow() {
  31. err = errors.New("GetCompanyContractList, Err: " + e.Error())
  32. return
  33. }
  34. permissionList, e := models.GetChartPermissionList()
  35. if e != nil && e.Error() != utils.ErrNoRow() {
  36. err = errors.New("GetChartPermissionList, Err: " + e.Error())
  37. return
  38. }
  39. mappermissionName := make(map[int]string)
  40. for _, v := range permissionList {
  41. mappermissionName[v.ChartPermissionId] = v.Remark
  42. }
  43. mapContractIdPerssion := make(map[string]string) //单个合同ID所对应的套餐或者权限名称
  44. for _, v := range companyContractList {
  45. if v.RaiPackageType == 1 {
  46. mapContractIdPerssion[strconv.Itoa(v.CompanyContractId)] = "70w套餐"
  47. }
  48. if v.RaiPackageType == 2 {
  49. mapContractIdPerssion[strconv.Itoa(v.CompanyContractId)] = "45w套餐"
  50. }
  51. }
  52. companyContractPermissionList, e := company.GetCompanyContractPermissionList(condition, pars)
  53. if e != nil && e.Error() != utils.ErrNoRow() {
  54. err = errors.New("GetCompanyContractPermissionList, Err: " + e.Error())
  55. return
  56. }
  57. for _, v := range companyContractPermissionList {
  58. //如果开通的不是整个套餐,那么就做单独的子权限处理
  59. if strings.Count(mapContractIdPerssion[strconv.Itoa(v.CompanyContractId)], "w套餐") == 0 {
  60. if v.ChartPermissionId == utils.CHART_PERMISSION_ID_YANXUAN {
  61. if v.ExpensiveYx == 1 {
  62. mapContractIdPerssion[strconv.Itoa(v.CompanyContractId)] += utils.CHART_PERMISSION_NAME_MF_YANXUAN + "(5w),"
  63. } else {
  64. mapContractIdPerssion[strconv.Itoa(v.CompanyContractId)] += utils.CHART_PERMISSION_NAME_MF_YANXUAN + "(3w),"
  65. }
  66. } else {
  67. mapContractIdPerssion[strconv.Itoa(v.CompanyContractId)] += mappermissionName[v.ChartPermissionId] + ","
  68. }
  69. }
  70. }
  71. //合并客观权限
  72. for k, v := range mapContractIdPerssion {
  73. perssionName := v
  74. if strings.Count(v, utils.YI_YAO_NAME) == 2 {
  75. perssionName = strings.Replace(perssionName, "医药(主观)", "医药", -1)
  76. perssionName = strings.Replace(perssionName, "医药(客观)", "", -1)
  77. }
  78. if strings.Count(v, utils.XIAO_FEI_NAME) == 2 {
  79. perssionName = strings.Replace(perssionName, "消费(主观)", "消费", -1)
  80. perssionName = strings.Replace(perssionName, "消费(客观)", "", -1)
  81. }
  82. if strings.Count(v, utils.KE_JI_NAME) == 2 {
  83. perssionName = strings.Replace(perssionName, "科技(主观)", "科技", -1)
  84. perssionName = strings.Replace(perssionName, "科技(客观)", "", -1)
  85. }
  86. if strings.Count(v, utils.ZHI_ZAO_NAME) == 2 {
  87. perssionName = strings.Replace(perssionName, "智造(主观)", "智造", -1)
  88. perssionName = strings.Replace(perssionName, "智造(客观)", "", -1)
  89. }
  90. perssionName = strings.TrimRight(perssionName, ",")
  91. mapContractIdPerssion[k] = perssionName
  92. }
  93. mapContractResp = make(map[int]string, 0)
  94. for k, v := range mapContractIdPerssion {
  95. mapContractResp[mapContracIdCompanyId[k]] += v + ","
  96. }
  97. //过滤多余的","
  98. for k, v := range mapContractResp {
  99. sliceName := strings.Split(v, ",")
  100. var nameArr []string
  101. for _, vName := range sliceName {
  102. if vName == "" {
  103. continue
  104. }
  105. nameArr = append(nameArr, vName)
  106. }
  107. mapContractResp[k] = strings.Join(nameArr, ",")
  108. }
  109. return
  110. }