contract_allocation.go 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365
  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. "strconv"
  11. "strings"
  12. "time"
  13. )
  14. //
  15. //func init() {
  16. // fmt.Println(GetCompanyContractPermissionNameMapBymapCompamy(map[int]string{6991: "1138"}))
  17. //}
  18. // GetCompanyContractPermissionNameMapBymapCompamy 获取合并之后的合同所对应的权限种类名称
  19. func GetCompanyContractPermissionNameMapBymapCompamy(mapCompamy map[int]string) (mapContractResp map[int]string, err error) {
  20. if len(mapCompamy) == 0 {
  21. return
  22. }
  23. mapContracIdCompanyId := make(map[int]int) //建立合同ID与公司ID的map对应关系
  24. var companyContractIds []int
  25. //var companyContractIdGroup string //多个合同ID
  26. for k, v := range mapCompamy {
  27. //companyContractIdGroup += v + ","
  28. sliceContract := strings.Split(v, ",")
  29. for _, compamyContracId := range sliceContract {
  30. companyContractIdInt, _ := strconv.Atoi(compamyContracId)
  31. mapContracIdCompanyId[companyContractIdInt] = k
  32. companyContractIds = append(companyContractIds, companyContractIdInt)
  33. }
  34. }
  35. // 获取单个合同所对应的权限名称
  36. contractPermissionNameMap, e := GetCompanyContractPermissionNameMapById(companyContractIds)
  37. if e != nil {
  38. err = errors.New("GetCompanyContractPermissionNameMapById, Err: " + e.Error())
  39. return
  40. }
  41. mapContractResp = make(map[int]string, 0)
  42. for k, v := range mapCompamy {
  43. sliceContract := strings.Split(v, ",")
  44. for _, compamyContracId := range sliceContract {
  45. companyContractIdInt, _ := strconv.Atoi(compamyContracId)
  46. for k2, v2 := range contractPermissionNameMap {
  47. if companyContractIdInt == k2 {
  48. mapContractResp[k] += v2 + ","
  49. }
  50. }
  51. }
  52. }
  53. for k, v := range mapContractResp {
  54. mapContractResp[k] = strings.TrimRight(v, ",")
  55. }
  56. return
  57. }
  58. // GetCompanyContractPermissionNameMapById 获取合并之后的合同所对应的权限种类名称
  59. func GetCompanyContractPermissionNameMapById(companyContractIds []int) (mapContractResp map[int]string, err error) {
  60. //return
  61. lenArr := len(companyContractIds)
  62. if lenArr == 0 {
  63. return
  64. }
  65. var condition string
  66. var pars []interface{}
  67. condition += " AND company_contract_id IN (" + utils.GetOrmInReplace(lenArr) + ")"
  68. pars = append(pars, companyContractIds)
  69. companyContractList, e := company.GetCompanyContractList(condition, pars)
  70. if e != nil && e.Error() != utils.ErrNoRow() {
  71. err = errors.New("GetCompanyContractList, Err: " + e.Error())
  72. return
  73. }
  74. permissionList, e := models.GetChartPermissionList()
  75. if e != nil && e.Error() != utils.ErrNoRow() {
  76. err = errors.New("GetChartPermissionList, Err: " + e.Error())
  77. return
  78. }
  79. mappermissionName := make(map[int]string)
  80. for _, v := range permissionList {
  81. mappermissionName[v.ChartPermissionId] = v.Remark
  82. }
  83. mapContractIdPerssion := make(map[int]string) //单个合同ID所对应的套餐或者权限名称
  84. for _, v := range companyContractList {
  85. if v.RaiPackageType == 1 {
  86. mapContractIdPerssion[v.CompanyContractId] = "70w套餐"
  87. }
  88. if v.RaiPackageType == 2 {
  89. mapContractIdPerssion[v.CompanyContractId] = "45w套餐"
  90. }
  91. }
  92. companyContractPermissionList, e := company.GetCompanyContractPermissionList(condition, pars)
  93. if e != nil && e.Error() != utils.ErrNoRow() {
  94. err = errors.New("GetCompanyContractPermissionList, Err: " + e.Error())
  95. return
  96. }
  97. mapIsUpgrade := make(map[string]bool) //合同ID对应的行业是否有升级
  98. for _, v := range companyContractPermissionList {
  99. //如果开通的不是整个套餐,那么就做单独的子权限处理
  100. if strings.Count(mapContractIdPerssion[(v.CompanyContractId)], "w套餐") == 0 {
  101. if v.ChartPermissionId == utils.CHART_PERMISSION_ID_YANXUAN {
  102. if v.ExpensiveYx == 1 {
  103. mapContractIdPerssion[(v.CompanyContractId)] += utils.CHART_PERMISSION_NAME_MF_YANXUAN + "(5w),"
  104. } else if v.ExpensiveYx == 2 {
  105. mapContractIdPerssion[(v.CompanyContractId)] += utils.CHART_PERMISSION_NAME_MF_YANXUAN + "(10w),"
  106. } else {
  107. mapContractIdPerssion[(v.CompanyContractId)] += utils.CHART_PERMISSION_NAME_MF_YANXUAN + "(3w),"
  108. }
  109. } else {
  110. mapContractIdPerssion[(v.CompanyContractId)] += mappermissionName[v.ChartPermissionId] + ","
  111. if v.IsUpgrade == 1 {
  112. //合同ID,权限名称形成唯一的主键索引
  113. perssionName := mappermissionName[v.ChartPermissionId]
  114. perssionName = strings.Replace(perssionName, "(客观)", "", -1)
  115. perssionName = strings.Replace(perssionName, "(主观)", "", -1)
  116. mapIsUpgrade[fmt.Sprint(v.CompanyContractId, "perssionName", perssionName)] = true
  117. }
  118. }
  119. } else {
  120. if v.ChartPermissionId == utils.CHART_PERMISSION_ID_YANXUAN {
  121. if v.ExpensiveYx == 1 {
  122. mapContractIdPerssion[(v.CompanyContractId)] += "," + utils.CHART_PERMISSION_NAME_MF_YANXUAN + "(5w)"
  123. } else {
  124. mapContractIdPerssion[(v.CompanyContractId)] += "," + utils.CHART_PERMISSION_NAME_MF_YANXUAN + "(3w)"
  125. }
  126. }
  127. }
  128. }
  129. //合并客观权限
  130. for k, v := range mapContractIdPerssion {
  131. perssionName := v
  132. if strings.Count(v, utils.YI_YAO_NAME) == 2 {
  133. perssionName = strings.Replace(perssionName, "医药(主观)", "医药", -1)
  134. perssionName = strings.Replace(perssionName, "医药(客观)", "", -1)
  135. }
  136. if strings.Count(v, utils.XIAO_FEI_NAME) == 2 {
  137. perssionName = strings.Replace(perssionName, "消费(主观)", "消费", -1)
  138. perssionName = strings.Replace(perssionName, "消费(客观)", "", -1)
  139. }
  140. if strings.Count(v, utils.KE_JI_NAME) == 2 {
  141. perssionName = strings.Replace(perssionName, "科技(主观)", "科技", -1)
  142. perssionName = strings.Replace(perssionName, "科技(客观)", "", -1)
  143. }
  144. if strings.Count(v, utils.ZHI_ZAO_NAME) == 2 {
  145. perssionName = strings.Replace(perssionName, "智造(主观)", "智造", -1)
  146. perssionName = strings.Replace(perssionName, "智造(客观)", "", -1)
  147. }
  148. perssionName = strings.TrimRight(perssionName, ",")
  149. mapContractIdPerssion[k] = perssionName
  150. }
  151. mapContractResp = make(map[int]string, 0)
  152. //过滤多余的","
  153. for k, v := range mapContractIdPerssion {
  154. sliceName := strings.Split(v, ",")
  155. var nameArr []string
  156. for _, vName := range sliceName {
  157. if vName == "" {
  158. continue
  159. }
  160. if mapIsUpgrade[fmt.Sprint(k, "perssionName", vName)] {
  161. vName += "(升级)"
  162. }
  163. nameArr = append(nameArr, vName)
  164. }
  165. mapContractResp[k] = strings.Join(nameArr, ",")
  166. }
  167. return
  168. }
  169. // 判断合同审核通过时间是否超过九十天
  170. func GetMapIsGrayByCompanyContractIds(companyContractIds []int) (mapResp map[int]bool, err error) {
  171. lenArr := len(companyContractIds)
  172. if lenArr == 0 {
  173. return
  174. }
  175. var condition string
  176. var pars []interface{}
  177. pars = make([]interface{}, 0)
  178. condition = " AND company_contract_id IN (" + utils.GetOrmInReplace(lenArr) + ") GROUP BY company_contract_id ORDER BY create_time DESC "
  179. pars = append(pars, companyContractIds)
  180. companyContractPermissionList, e := company.GetCompanyContractPermissionList(condition, pars)
  181. if e != nil && e.Error() != utils.ErrNoRow() {
  182. err = errors.New("GetCompanyContractPermissionList, Err: " + e.Error())
  183. return
  184. }
  185. //超过九十天就置灰
  186. timeInit := time.Now().AddDate(0, 0, -180)
  187. mapResp = make(map[int]bool, 0)
  188. for _, v := range companyContractPermissionList {
  189. if v.CreateTime.Before(timeInit) {
  190. mapResp[v.CompanyContractId] = true
  191. }
  192. }
  193. return
  194. }
  195. //func init3() {
  196. // var condition string
  197. // var pars []interface{}
  198. // //默认只查询权益 2023-06-01 之后的合同
  199. // condition += ` AND c.product_id = ? AND a.start_date > ? `
  200. // pars = append(pars, 2, "2023-06-01")
  201. //
  202. // //列表页数据
  203. // list, err := cygx.GetCompanyContractListJoinCompany(condition, pars, 0, 1000)
  204. // if err != nil {
  205. // fmt.Println(err)
  206. // return
  207. // }
  208. //
  209. // for _, v := range list {
  210. // fmt.Println(v.CompanyContractId)
  211. // HandleAllocationCompanyContractByYanXuan(v.CompanyContractId)
  212. // }
  213. //
  214. // fmt.Println(len(list))
  215. //}
  216. // 如果合同只有研选的时候,自动处理派点
  217. func HandleAllocationCompanyContractByYanXuan(companyContractId int) (err error) {
  218. defer func() {
  219. if err != nil {
  220. fmt.Println(err)
  221. go alarm_msg.SendAlarmMsg(fmt.Sprint("如果合同只有研选的时候,自动处理派点失败,Err:", err.Error(), "companyContractId", companyContractId), 2)
  222. }
  223. }()
  224. var condition string
  225. var pars []interface{}
  226. pars = make([]interface{}, 0)
  227. condition = " AND company_contract_id = ? "
  228. pars = append(pars, companyContractId)
  229. companyContractPermissionList, e := company.GetCompanyContractPermissionList(condition, pars)
  230. if e != nil && e.Error() != utils.ErrNoRow() {
  231. err = errors.New("GetCompanyContractPermissionList, Err: " + e.Error())
  232. return
  233. }
  234. if e != nil && e.Error() != utils.ErrNoRow() {
  235. err = errors.New("GetCygxAllocationCompanyContractPermissionListById, Err: " + e.Error())
  236. return
  237. }
  238. if len(companyContractPermissionList) > 1 {
  239. return
  240. }
  241. var expensiveYxmoney float64
  242. for _, v := range companyContractPermissionList {
  243. if v.ChartPermissionId != utils.CHART_PERMISSION_ID_YANXUAN {
  244. err = errors.New("没有发现研选权限: ")
  245. return
  246. }
  247. if v.ExpensiveYx == 1 {
  248. expensiveYxmoney = 5
  249. } else if v.ExpensiveYx == 2 {
  250. expensiveYxmoney = 10
  251. } else {
  252. expensiveYxmoney = 3
  253. }
  254. }
  255. var items []*cygx.CygxAllocationCompanyContract
  256. var itemsPermission []*cygx.CygxAllocationCompanyContractPermission
  257. itemPermission := new(cygx.CygxAllocationCompanyContractPermission)
  258. itemPermission.CompanyContractId = companyContractId
  259. //itemPermission.AdminId = sysUser.AdminId
  260. //itemPermission.AdminName = sysUser.RealName
  261. itemPermission.Proportion = 0
  262. itemPermission.Money = expensiveYxmoney
  263. itemPermission.MoneyAvg = 0
  264. itemPermission.ChartPermissionName = utils.CHART_PERMISSION_NAME_MF_YANXUAN
  265. itemPermission.CreateTime = time.Now()
  266. itemPermission.ModifyTime = time.Now()
  267. itemsPermission = append(itemsPermission, itemPermission)
  268. item := new(cygx.CygxAllocationCompanyContract)
  269. item.CompanyContractId = companyContractId
  270. //item.AdminId = sysUser.AdminId
  271. //item.AdminName = sysUser.RealName
  272. item.Proportion = 0
  273. item.Money = expensiveYxmoney
  274. item.RealName = utils.CHART_PERMISSION_NAME_MF_YANXUAN
  275. item.ChartPermissionName = utils.CHART_PERMISSION_NAME_MF_YANXUAN
  276. item.CreateTime = time.Now()
  277. item.ModifyTime = time.Now()
  278. items = append(items, item)
  279. e = cygx.AddAndUpdateCygxAllocationCompanyContract(items, itemsPermission, companyContractId)
  280. if e != nil {
  281. err = errors.New("AddAndUpdateCygxAllocationCompanyContract, Err: " + e.Error())
  282. return
  283. }
  284. return
  285. }
  286. //func init() {
  287. // HandleCompanyContractPackageDifference(1229)
  288. //}
  289. // HandleCompanyContractPackageDifference 更新与上一份合同的金额的对比 '增加套餐','减少套餐','维持套餐'
  290. func HandleCompanyContractPackageDifference(companyContractId int) (err error) {
  291. defer func() {
  292. if err != nil {
  293. fmt.Println(err)
  294. go alarm_msg.SendAlarmMsg(fmt.Sprint("如果合同只有研选的时候,自动处理派点失败,Err:", err.Error(), "companyContractId", companyContractId), 2)
  295. }
  296. }()
  297. var condition string
  298. var pars []interface{}
  299. condition = " AND company_contract_id = ? "
  300. pars = append(pars, companyContractId)
  301. detail, e := company.GetCompanyContracDetail(condition, pars)
  302. if e != nil {
  303. err = errors.New("GetCompanyContracDetail, Err: " + e.Error())
  304. return
  305. }
  306. //如果不是续约合同就不做对比处理
  307. if detail.ContractType != "续约合同" {
  308. return
  309. }
  310. //获取前一份合同的信息
  311. pars = make([]interface{}, 0)
  312. condition = " AND company_id = ? AND company_contract_id < ? AND status = 1 AND product_id = ? ORDER BY company_contract_id DESC LIMIT 1 "
  313. pars = append(pars, detail.CompanyId, companyContractId, detail.ProductId)
  314. detailPrevious, e := company.GetCompanyContracDetail(condition, pars)
  315. if e != nil {
  316. err = errors.New("GetCompanyContracDetail, Err: " + e.Error())
  317. return
  318. }
  319. var packageDifference string
  320. if detail.Money > detailPrevious.Money {
  321. packageDifference = "增加套餐"
  322. } else if detail.Money < detailPrevious.Money {
  323. packageDifference = "减少套餐"
  324. } else {
  325. packageDifference = "维持套餐"
  326. }
  327. e = company.UpdateCompanyContractPackageDifference(packageDifference, companyContractId)
  328. fmt.Println(packageDifference)
  329. if e != nil {
  330. err = errors.New("UpdateCompanyContractPackageDifference, Err: " + e.Error())
  331. return
  332. }
  333. return
  334. }