contract_allocation.go 8.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260
  1. package cygx
  2. import (
  3. "errors"
  4. "fmt"
  5. "hongze/hz_crm_api/models"
  6. "hongze/hz_crm_api/models/company"
  7. "hongze/hz_crm_api/models/cygx"
  8. "hongze/hz_crm_api/services/alarm_msg"
  9. "hongze/hz_crm_api/utils"
  10. "strings"
  11. "time"
  12. )
  13. // GetCompanyContractPermissionNameMapById 获取合并之后的合同所对应的权限种类名称
  14. func GetCompanyContractPermissionNameMapById(companyContractIds []int) (mapContractResp map[int]string, err error) {
  15. //return
  16. lenArr := len(companyContractIds)
  17. if lenArr == 0 {
  18. return
  19. }
  20. var condition string
  21. var pars []interface{}
  22. condition += " AND company_contract_id IN (" + utils.GetOrmInReplace(lenArr) + ")"
  23. pars = append(pars, companyContractIds)
  24. companyContractList, e := company.GetCompanyContractList(condition, pars)
  25. if e != nil && e.Error() != utils.ErrNoRow() {
  26. err = errors.New("GetCompanyContractList, Err: " + e.Error())
  27. return
  28. }
  29. permissionList, e := models.GetChartPermissionList()
  30. if e != nil && e.Error() != utils.ErrNoRow() {
  31. err = errors.New("GetChartPermissionList, Err: " + e.Error())
  32. return
  33. }
  34. mappermissionName := make(map[int]string)
  35. for _, v := range permissionList {
  36. mappermissionName[v.ChartPermissionId] = v.Remark
  37. }
  38. mapContractIdPerssion := make(map[int]string) //单个合同ID所对应的套餐或者权限名称
  39. for _, v := range companyContractList {
  40. if v.RaiPackageType == 1 {
  41. mapContractIdPerssion[v.CompanyContractId] = "70w套餐"
  42. }
  43. if v.RaiPackageType == 2 {
  44. mapContractIdPerssion[v.CompanyContractId] = "45w套餐"
  45. }
  46. }
  47. companyContractPermissionList, e := company.GetCompanyContractPermissionList(condition, pars)
  48. if e != nil && e.Error() != utils.ErrNoRow() {
  49. err = errors.New("GetCompanyContractPermissionList, Err: " + e.Error())
  50. return
  51. }
  52. mapIsUpgrade := make(map[string]bool) //合同ID对应的行业是否有升级
  53. for _, v := range companyContractPermissionList {
  54. //如果开通的不是整个套餐,那么就做单独的子权限处理
  55. if strings.Count(mapContractIdPerssion[(v.CompanyContractId)], "w套餐") == 0 {
  56. if v.ChartPermissionId == utils.CHART_PERMISSION_ID_YANXUAN {
  57. if v.ExpensiveYx == 1 {
  58. mapContractIdPerssion[(v.CompanyContractId)] += utils.CHART_PERMISSION_NAME_MF_YANXUAN + "(5w),"
  59. } else if v.ExpensiveYx == 2 {
  60. mapContractIdPerssion[(v.CompanyContractId)] += utils.CHART_PERMISSION_NAME_MF_YANXUAN + "(10w),"
  61. } else {
  62. mapContractIdPerssion[(v.CompanyContractId)] += utils.CHART_PERMISSION_NAME_MF_YANXUAN + "(3w),"
  63. }
  64. } else {
  65. mapContractIdPerssion[(v.CompanyContractId)] += mappermissionName[v.ChartPermissionId] + ","
  66. if v.IsUpgrade == 1 {
  67. //合同ID,权限名称形成唯一的主键索引
  68. perssionName := mappermissionName[v.ChartPermissionId]
  69. perssionName = strings.Replace(perssionName, "(客观)", "", -1)
  70. perssionName = strings.Replace(perssionName, "(主观)", "", -1)
  71. mapIsUpgrade[fmt.Sprint(v.CompanyContractId, "perssionName", perssionName)] = true
  72. }
  73. }
  74. } else {
  75. if v.ChartPermissionId == utils.CHART_PERMISSION_ID_YANXUAN {
  76. if v.ExpensiveYx == 1 {
  77. mapContractIdPerssion[(v.CompanyContractId)] += "," + utils.CHART_PERMISSION_NAME_MF_YANXUAN + "(5w)"
  78. } else {
  79. mapContractIdPerssion[(v.CompanyContractId)] += "," + utils.CHART_PERMISSION_NAME_MF_YANXUAN + "(3w)"
  80. }
  81. }
  82. }
  83. }
  84. //合并客观权限
  85. for k, v := range mapContractIdPerssion {
  86. perssionName := v
  87. if strings.Count(v, utils.YI_YAO_NAME) == 2 {
  88. perssionName = strings.Replace(perssionName, "医药(主观)", "医药", -1)
  89. perssionName = strings.Replace(perssionName, "医药(客观)", "", -1)
  90. }
  91. if strings.Count(v, utils.XIAO_FEI_NAME) == 2 {
  92. perssionName = strings.Replace(perssionName, "消费(主观)", "消费", -1)
  93. perssionName = strings.Replace(perssionName, "消费(客观)", "", -1)
  94. }
  95. if strings.Count(v, utils.KE_JI_NAME) == 2 {
  96. perssionName = strings.Replace(perssionName, "科技(主观)", "科技", -1)
  97. perssionName = strings.Replace(perssionName, "科技(客观)", "", -1)
  98. }
  99. if strings.Count(v, utils.ZHI_ZAO_NAME) == 2 {
  100. perssionName = strings.Replace(perssionName, "智造(主观)", "智造", -1)
  101. perssionName = strings.Replace(perssionName, "智造(客观)", "", -1)
  102. }
  103. perssionName = strings.TrimRight(perssionName, ",")
  104. mapContractIdPerssion[k] = perssionName
  105. }
  106. mapContractResp = make(map[int]string, 0)
  107. //过滤多余的","
  108. for k, v := range mapContractIdPerssion {
  109. sliceName := strings.Split(v, ",")
  110. var nameArr []string
  111. for _, vName := range sliceName {
  112. if vName == "" {
  113. continue
  114. }
  115. if mapIsUpgrade[fmt.Sprint(k, "perssionName", vName)] {
  116. vName += "(升级)"
  117. }
  118. nameArr = append(nameArr, vName)
  119. }
  120. mapContractResp[k] = strings.Join(nameArr, ",")
  121. }
  122. return
  123. }
  124. // 判断合同审核通过时间是否超过九十天
  125. func GetMapIsGrayByCompanyContractIds(companyContractIds []int) (mapResp map[int]bool, err error) {
  126. lenArr := len(companyContractIds)
  127. if lenArr == 0 {
  128. return
  129. }
  130. var condition string
  131. var pars []interface{}
  132. pars = make([]interface{}, 0)
  133. condition = " AND company_contract_id IN (" + utils.GetOrmInReplace(lenArr) + ") GROUP BY company_contract_id ORDER BY create_time DESC "
  134. pars = append(pars, companyContractIds)
  135. companyContractPermissionList, e := company.GetCompanyContractPermissionList(condition, pars)
  136. if e != nil && e.Error() != utils.ErrNoRow() {
  137. err = errors.New("GetCompanyContractPermissionList, Err: " + e.Error())
  138. return
  139. }
  140. //超过九十天就置灰
  141. timeInit := time.Now().AddDate(0, 0, -180)
  142. mapResp = make(map[int]bool, 0)
  143. for _, v := range companyContractPermissionList {
  144. if v.CreateTime.Before(timeInit) {
  145. mapResp[v.CompanyContractId] = true
  146. }
  147. }
  148. return
  149. }
  150. //func init3() {
  151. // var condition string
  152. // var pars []interface{}
  153. // //默认只查询权益 2023-06-01 之后的合同
  154. // condition += ` AND c.product_id = ? AND a.start_date > ? `
  155. // pars = append(pars, 2, "2023-06-01")
  156. //
  157. // //列表页数据
  158. // list, err := cygx.GetCompanyContractListJoinCompany(condition, pars, 0, 1000)
  159. // if err != nil {
  160. // fmt.Println(err)
  161. // return
  162. // }
  163. //
  164. // for _, v := range list {
  165. // fmt.Println(v.CompanyContractId)
  166. // HandleAllocationCompanyContractByYanXuan(v.CompanyContractId)
  167. // }
  168. //
  169. // fmt.Println(len(list))
  170. //}
  171. // 如果合同只有研选的时候,自动处理派点
  172. func HandleAllocationCompanyContractByYanXuan(companyContractId int) (err error) {
  173. defer func() {
  174. if err != nil {
  175. fmt.Println(err)
  176. go alarm_msg.SendAlarmMsg(fmt.Sprint("如果合同只有研选的时候,自动处理派点失败,Err:", err.Error(), "companyContractId", companyContractId), 2)
  177. }
  178. }()
  179. var condition string
  180. var pars []interface{}
  181. pars = make([]interface{}, 0)
  182. condition = " AND company_contract_id = ? "
  183. pars = append(pars, companyContractId)
  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. if e != nil && e.Error() != utils.ErrNoRow() {
  190. err = errors.New("GetCygxAllocationCompanyContractPermissionListById, Err: " + e.Error())
  191. return
  192. }
  193. if len(companyContractPermissionList) > 1 {
  194. return
  195. }
  196. var expensiveYxmoney float64
  197. for _, v := range companyContractPermissionList {
  198. if v.ChartPermissionId != utils.CHART_PERMISSION_ID_YANXUAN {
  199. err = errors.New("没有发现研选权限: ")
  200. return
  201. }
  202. if v.ExpensiveYx == 1 {
  203. expensiveYxmoney = 5
  204. } else if v.ExpensiveYx == 2 {
  205. expensiveYxmoney = 10
  206. } else {
  207. expensiveYxmoney = 3
  208. }
  209. }
  210. var items []*cygx.CygxAllocationCompanyContract
  211. var itemsPermission []*cygx.CygxAllocationCompanyContractPermission
  212. itemPermission := new(cygx.CygxAllocationCompanyContractPermission)
  213. itemPermission.CompanyContractId = companyContractId
  214. //itemPermission.AdminId = sysUser.AdminId
  215. //itemPermission.AdminName = sysUser.RealName
  216. itemPermission.Proportion = 0
  217. itemPermission.Money = expensiveYxmoney
  218. itemPermission.MoneyAvg = 0
  219. itemPermission.ChartPermissionName = utils.CHART_PERMISSION_NAME_MF_YANXUAN
  220. itemPermission.CreateTime = time.Now()
  221. itemPermission.ModifyTime = time.Now()
  222. itemsPermission = append(itemsPermission, itemPermission)
  223. item := new(cygx.CygxAllocationCompanyContract)
  224. item.CompanyContractId = companyContractId
  225. //item.AdminId = sysUser.AdminId
  226. //item.AdminName = sysUser.RealName
  227. item.Proportion = 0
  228. item.Money = expensiveYxmoney
  229. item.RealName = utils.CHART_PERMISSION_NAME_MF_YANXUAN
  230. item.ChartPermissionName = utils.CHART_PERMISSION_NAME_MF_YANXUAN
  231. item.CreateTime = time.Now()
  232. item.ModifyTime = time.Now()
  233. items = append(items, item)
  234. e = cygx.AddAndUpdateCygxAllocationCompanyContract(items, itemsPermission, companyContractId)
  235. if e != nil {
  236. err = errors.New("AddAndUpdateCygxAllocationCompanyContract, Err: " + e.Error())
  237. return
  238. }
  239. return
  240. }