contract_allocation.go 27 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836
  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. if v.ProductId == 2 {
  82. mappermissionName[v.ChartPermissionId] = v.Remark
  83. }
  84. }
  85. mapContractIdPerssion := make(map[int]string) //单个合同ID所对应的套餐或者权限名称
  86. for _, v := range companyContractList {
  87. if v.RaiPackageType == 1 {
  88. mapContractIdPerssion[v.CompanyContractId] = "70w套餐,"
  89. }
  90. if v.RaiPackageType == 2 {
  91. mapContractIdPerssion[v.CompanyContractId] = "45w套餐,"
  92. }
  93. }
  94. companyContractPermissionList, e := company.GetCompanyContractPermissionList(condition, pars)
  95. if e != nil && e.Error() != utils.ErrNoRow() {
  96. err = errors.New("GetCompanyContractPermissionList, Err: " + e.Error())
  97. return
  98. }
  99. mapIsUpgrade := make(map[string]bool) //合同ID对应的行业是否有升级
  100. for _, v := range companyContractPermissionList {
  101. //如果开通的不是整个套餐,那么就做单独的子权限处理
  102. if strings.Count(mapContractIdPerssion[(v.CompanyContractId)], "w套餐") == 0 {
  103. if v.ChartPermissionId == utils.CHART_PERMISSION_ID_YANXUAN {
  104. if v.ExpensiveYx == 1 {
  105. mapContractIdPerssion[(v.CompanyContractId)] += utils.CHART_PERMISSION_NAME_MF_YANXUAN + "(5w),"
  106. } else if v.ExpensiveYx == 2 {
  107. mapContractIdPerssion[(v.CompanyContractId)] += utils.CHART_PERMISSION_NAME_MF_YANXUAN + "(10w),"
  108. } else {
  109. mapContractIdPerssion[(v.CompanyContractId)] += utils.CHART_PERMISSION_NAME_MF_YANXUAN + ","
  110. }
  111. } else {
  112. mapContractIdPerssion[(v.CompanyContractId)] += mappermissionName[v.ChartPermissionId] + ","
  113. if v.IsUpgrade == 1 {
  114. //合同ID,权限名称形成唯一的主键索引
  115. perssionName := mappermissionName[v.ChartPermissionId]
  116. perssionName = strings.Replace(perssionName, "(客观)", "", -1)
  117. perssionName = strings.Replace(perssionName, "(主观)", "", -1)
  118. mapIsUpgrade[fmt.Sprint(v.CompanyContractId, "perssionName", perssionName)] = true
  119. }
  120. }
  121. } else {
  122. if v.ChartPermissionId == utils.ZHUAN_JIA_ID {
  123. mapContractIdPerssion[(v.CompanyContractId)] += utils.ZHUAN_JIA_NAME + ","
  124. }
  125. if v.ChartPermissionId == utils.CHART_PERMISSION_ID_YANXUAN {
  126. if v.ExpensiveYx == 1 {
  127. mapContractIdPerssion[(v.CompanyContractId)] += "," + utils.CHART_PERMISSION_NAME_MF_YANXUAN + "(5w),"
  128. } else if v.ExpensiveYx == 2 {
  129. mapContractIdPerssion[(v.CompanyContractId)] += "," + utils.CHART_PERMISSION_NAME_MF_YANXUAN + "(10w),"
  130. } else {
  131. mapContractIdPerssion[(v.CompanyContractId)] += utils.CHART_PERMISSION_NAME_MF_YANXUAN + ","
  132. }
  133. }
  134. if v.ChartPermissionId == utils.YAN_XUAN_KOU_DIAN_BAO_ID {
  135. mapContractIdPerssion[(v.CompanyContractId)] += utils.YAN_XUAN_KOU_DIAN_BAO_NAME + ","
  136. }
  137. }
  138. }
  139. //合并客观权限
  140. for k, v := range mapContractIdPerssion {
  141. perssionName := v
  142. if strings.Count(v, utils.YI_YAO_NAME) == 2 {
  143. perssionName = strings.Replace(perssionName, "医药(主观)", "医药", -1)
  144. perssionName = strings.Replace(perssionName, "医药(客观)", "", -1)
  145. }
  146. if strings.Count(v, utils.XIAO_FEI_NAME) == 2 {
  147. perssionName = strings.Replace(perssionName, "消费(主观)", "消费", -1)
  148. perssionName = strings.Replace(perssionName, "消费(客观)", "", -1)
  149. }
  150. if strings.Count(v, utils.KE_JI_NAME) == 2 {
  151. perssionName = strings.Replace(perssionName, "科技(主观)", "科技", -1)
  152. perssionName = strings.Replace(perssionName, "科技(客观)", "", -1)
  153. }
  154. if strings.Count(v, utils.ZHI_ZAO_NAME) == 2 {
  155. perssionName = strings.Replace(perssionName, "智造(主观)", "智造", -1)
  156. perssionName = strings.Replace(perssionName, "智造(客观)", "", -1)
  157. }
  158. perssionName = strings.TrimRight(perssionName, ",")
  159. mapContractIdPerssion[k] = perssionName
  160. }
  161. mapContractResp = make(map[int]string, 0)
  162. //过滤多余的","
  163. for k, v := range mapContractIdPerssion {
  164. sliceName := strings.Split(v, ",")
  165. var nameArr []string
  166. for _, vName := range sliceName {
  167. if vName == "" {
  168. continue
  169. }
  170. if mapIsUpgrade[fmt.Sprint(k, "perssionName", vName)] {
  171. vName += "(升级)"
  172. }
  173. nameArr = append(nameArr, vName)
  174. }
  175. mapContractResp[k] = strings.Join(nameArr, ",")
  176. }
  177. return
  178. }
  179. // GetCompanyPermissionNameStatusMapByCompanyId 通过公司ID,获取公司当下所有权限的状态信息
  180. func GetCompanyPermissionNameStatusMapByCompanyId(companyIds []int) (mapResp map[string]string, err error) {
  181. //return
  182. lenArr := len(companyIds)
  183. if lenArr == 0 {
  184. return
  185. }
  186. var condition string
  187. var pars []interface{}
  188. condition += " AND company_id IN (" + utils.GetOrmInReplace(lenArr) + ") AND product_id = 2 "
  189. pars = append(pars, companyIds)
  190. //获取所有开通买方研选正式试用的客户列表
  191. listCompanyPermission, e := company.GetCompanyReportPermissionList(condition, pars, 0, 0)
  192. if e != nil && e.Error() != utils.ErrNoRow() {
  193. err = errors.New("GetCompanyReportPermissionList, Err: " + e.Error())
  194. return
  195. }
  196. //获取行业权限ID与名称的映射关系
  197. permissionList, e := models.GetChartPermissionList()
  198. if e != nil && e.Error() != utils.ErrNoRow() {
  199. err = errors.New("GetChartPermissionList, Err: " + e.Error())
  200. return
  201. }
  202. mapResp = make(map[string]string, 0)
  203. mapChartPermission := make(map[int]string)
  204. for _, v := range permissionList {
  205. mapChartPermission[v.ChartPermissionId] = v.PermissionName
  206. }
  207. for _, v := range listCompanyPermission {
  208. if mapChartPermission[v.ChartPermissionId] == "" {
  209. continue
  210. }
  211. //公司ID与权限名称组成映射关系
  212. mapResp[fmt.Sprint(v.CompanyId, mapChartPermission[v.ChartPermissionId])] = v.Status
  213. }
  214. return
  215. }
  216. // 判断合同审核通过时间是否超过九十天
  217. func GetMapIsGrayByCompanyContractIds(companyContractIds []int) (mapResp map[int]bool, err error) {
  218. lenArr := len(companyContractIds)
  219. if lenArr == 0 {
  220. return
  221. }
  222. var condition string
  223. var pars []interface{}
  224. pars = make([]interface{}, 0)
  225. condition = " AND company_contract_id IN (" + utils.GetOrmInReplace(lenArr) + ") GROUP BY company_contract_id ORDER BY create_time DESC "
  226. pars = append(pars, companyContractIds)
  227. companyContractPermissionList, e := company.GetCompanyContractPermissionList(condition, pars)
  228. if e != nil && e.Error() != utils.ErrNoRow() {
  229. err = errors.New("GetCompanyContractPermissionList, Err: " + e.Error())
  230. return
  231. }
  232. //超过九十天就置灰
  233. timeInit := time.Now().AddDate(0, 0, -180)
  234. mapResp = make(map[int]bool, 0)
  235. for _, v := range companyContractPermissionList {
  236. if v.CreateTime.Before(timeInit) {
  237. mapResp[v.CompanyContractId] = true
  238. }
  239. }
  240. return
  241. }
  242. //func init3() {
  243. // var condition string
  244. // var pars []interface{}
  245. // //默认只查询权益 2023-06-01 之后的合同
  246. // condition += ` AND c.product_id = ? AND a.start_date > ? `
  247. // pars = append(pars, 2, "2023-06-01")
  248. //
  249. // //列表页数据
  250. // list, err := cygx.GetCompanyContractListJoinCompany(condition, pars, 0, 1000)
  251. // if err != nil {
  252. // fmt.Println(err)
  253. // return
  254. // }
  255. //
  256. // for _, v := range list {
  257. // fmt.Println(v.CompanyContractId)
  258. // HandleAllocationCompanyContractByYanXuan(v.CompanyContractId)
  259. // }
  260. //
  261. // fmt.Println(len(list))
  262. //}
  263. // 如果合同只有研选的时候,自动处理派点
  264. func HandleAllocationCompanyContractByYanXuan(companyContractId int) (err error) {
  265. defer func() {
  266. if err != nil {
  267. fmt.Println(err)
  268. go alarm_msg.SendAlarmMsg(fmt.Sprint("如果合同只有研选的时候,自动处理派点失败,Err:", err.Error(), "companyContractId", companyContractId), 2)
  269. }
  270. }()
  271. var condition string
  272. var pars []interface{}
  273. pars = make([]interface{}, 0)
  274. condition = " AND company_contract_id = ? "
  275. pars = append(pars, companyContractId)
  276. companyContractPermissionList, e := company.GetCompanyContractPermissionList(condition, pars)
  277. if e != nil && e.Error() != utils.ErrNoRow() {
  278. err = errors.New("GetCompanyContractPermissionList, Err: " + e.Error())
  279. return
  280. }
  281. if e != nil && e.Error() != utils.ErrNoRow() {
  282. err = errors.New("GetCygxAllocationCompanyContractPermissionListById, Err: " + e.Error())
  283. return
  284. }
  285. if len(companyContractPermissionList) > 2 {
  286. return
  287. }
  288. var expensiveYxmoney float64
  289. //for _, v := range companyContractPermissionList {
  290. // if v.ChartPermissionId != utils.CHART_PERMISSION_ID_YANXUAN {
  291. // err = errors.New("没有发现研选权限: ")
  292. // return
  293. // }
  294. // if v.ExpensiveYx == 1 {
  295. // expensiveYxmoney = 5
  296. // } else if v.ExpensiveYx == 2 {
  297. // expensiveYxmoney = 10
  298. // } else {
  299. // expensiveYxmoney = 3
  300. // }
  301. //}
  302. var items []*cygx.CygxAllocationCompanyContract
  303. var itemsPermission []*cygx.CygxAllocationCompanyContractPermission
  304. for _, v := range companyContractPermissionList {
  305. if v.ChartPermissionId != utils.CHART_PERMISSION_ID_YANXUAN && v.ChartPermissionId != utils.YAN_XUAN_KOU_DIAN_BAO_ID {
  306. return
  307. }
  308. if v.ChartPermissionId == utils.CHART_PERMISSION_ID_YANXUAN {
  309. expensiveYxmoney = 3
  310. }
  311. if v.ChartPermissionId == utils.YAN_XUAN_KOU_DIAN_BAO_ID {
  312. expensiveYxmoney = 0.2 * v.Points
  313. }
  314. itemPermission := new(cygx.CygxAllocationCompanyContractPermission)
  315. itemPermission.CompanyContractId = companyContractId
  316. //itemPermission.AdminId = sysUser.AdminId
  317. //itemPermission.AdminName = sysUser.RealName
  318. itemPermission.Proportion = 0
  319. itemPermission.Money = expensiveYxmoney
  320. itemPermission.MoneyAvg = 0
  321. itemPermission.ChartPermissionName = v.PermissionName
  322. itemPermission.CreateTime = time.Now()
  323. itemPermission.ModifyTime = time.Now()
  324. itemsPermission = append(itemsPermission, itemPermission)
  325. item := new(cygx.CygxAllocationCompanyContract)
  326. item.CompanyContractId = companyContractId
  327. //item.AdminId = sysUser.AdminId
  328. //item.AdminName = sysUser.RealName
  329. item.Proportion = 0
  330. item.Money = expensiveYxmoney
  331. item.RealName = v.PermissionName
  332. item.ChartPermissionName = v.PermissionName
  333. item.CreateTime = time.Now()
  334. item.ModifyTime = time.Now()
  335. items = append(items, item)
  336. }
  337. if len(items) == 0 {
  338. return
  339. }
  340. e = cygx.AddAndUpdateCygxAllocationCompanyContract(items, itemsPermission, companyContractId)
  341. if e != nil {
  342. err = errors.New("AddAndUpdateCygxAllocationCompanyContract, Err: " + e.Error())
  343. return
  344. }
  345. return
  346. }
  347. //func init() {
  348. // var condition string
  349. // var pars []interface{}
  350. //
  351. // condition = " AND status = 1 "
  352. //
  353. // list, err := company.GetCompanyContractList(condition, pars)
  354. // if err != nil {
  355. // fmt.Println(err)
  356. // return
  357. // }
  358. // fmt.Println(len(list))
  359. // //return
  360. // for _, v := range list {
  361. // fmt.Println(v.CompanyContractId)
  362. // HandleCompanyContractPackageDifference(v.CompanyContractId)
  363. // }
  364. //
  365. //}
  366. // HandleCompanyContractPackageDifference 更新与上一份合同的金额的对比 '增加套餐','减少套餐','维持套餐'
  367. func HandleCompanyContractPackageDifference(companyContractId int) (err error) {
  368. defer func() {
  369. if err != nil {
  370. fmt.Println(err)
  371. go alarm_msg.SendAlarmMsg(fmt.Sprint("更新与上一份合同的金额的对比 '增加套餐','减少套餐','维持套餐'失败,Err:", err.Error(), "companyContractId", companyContractId), 2)
  372. }
  373. }()
  374. var condition string
  375. var pars []interface{}
  376. condition = " AND company_contract_id = ? "
  377. pars = append(pars, companyContractId)
  378. detail, e := company.GetCompanyContracDetail(condition, pars)
  379. if e != nil {
  380. err = errors.New("GetCompanyContracDetail,detail Err: " + e.Error())
  381. return
  382. }
  383. //如果不是续约合同就不做对比处理
  384. if detail.ContractType != "续约合同" {
  385. return
  386. }
  387. //获取前一份合同的信息
  388. pars = make([]interface{}, 0)
  389. condition = " AND company_id = ? AND company_contract_id < ? AND status = 1 AND product_id = ? ORDER BY company_contract_id DESC LIMIT 1 "
  390. pars = append(pars, detail.CompanyId, companyContractId, detail.ProductId)
  391. detailPrevious, e := company.GetCompanyContracDetail(condition, pars)
  392. if e != nil {
  393. err = errors.New("GetCompanyContracDetail,detailPrevious Err: " + e.Error())
  394. return
  395. }
  396. var packageDifference string
  397. if detail.Money > detailPrevious.Money {
  398. packageDifference = "增加套餐"
  399. } else if detail.Money < detailPrevious.Money {
  400. packageDifference = "减少套餐"
  401. } else {
  402. packageDifference = "维持套餐"
  403. }
  404. e = company.UpdateCompanyContractPackageDifference(packageDifference, companyContractId)
  405. if e != nil {
  406. err = errors.New("UpdateCompanyContractPackageDifference, Err: " + e.Error())
  407. return
  408. }
  409. return
  410. }
  411. // HandleCompanyContractTypeByRaiXClass 所有x类试用转正的合同都记为 :打分派点
  412. func HandleCompanyContractTypeByRaiXClass(companyContractId int) (err error) {
  413. defer func() {
  414. if err != nil {
  415. go alarm_msg.SendAlarmMsg(fmt.Sprint(" 所有x类试用转正的合同都记为 :打分派点失败,HandleCompanyContractTypeByRaiXClass Err:", err.Error(), "companyContractId", companyContractId), 2)
  416. }
  417. }()
  418. var condition string
  419. var pars []interface{}
  420. condition = " AND company_contract_id = ? "
  421. pars = append(pars, companyContractId)
  422. detail, e := company.GetCompanyContracDetail(condition, pars)
  423. if e != nil {
  424. err = errors.New("GetCompanyContracDetail,detail Err: " + e.Error())
  425. return
  426. }
  427. companyProduct, e := company.GetCompanyProductByCompanyIdAndProductId(detail.CompanyId, utils.COMPANY_PRODUCT_RAI_ID)
  428. if e != nil {
  429. err = errors.New("GetCompanyProductByCompanyIdAndProductId Err: " + e.Error())
  430. return
  431. }
  432. //权益非永续客户不处理
  433. if companyProduct.Status != utils.COMPANY_STATUS_FOREVER {
  434. return
  435. }
  436. e = company.UpdateCompanyContractType("打分派点", companyContractId)
  437. if e != nil {
  438. err = errors.New("UpdateCompanyContractType, Err: " + e.Error())
  439. return
  440. }
  441. return
  442. }
  443. // HandleCompanyContractPermissionContractType 更新合同权限表中的权限名称,以及对应的行业权限类型(行业新签、行业续约)
  444. func HandleCompanyContractPermissionContractType(companyContractId int) (err error) {
  445. defer func() {
  446. if err != nil {
  447. fmt.Println(err)
  448. go alarm_msg.SendAlarmMsg(fmt.Sprint("更新合同权限表中的权限名称,以及对应的行业权限类型(行业新签、行业续约)失败,HandleCompanyContractPermissionContractType Err:", err.Error(), "companyContractId", companyContractId), 2)
  449. }
  450. }()
  451. var condition string
  452. var pars []interface{}
  453. condition = " AND company_contract_id = ? "
  454. pars = append(pars, companyContractId)
  455. detail, e := company.GetCompanyContracDetail(condition, pars)
  456. if e != nil {
  457. err = errors.New("GetCompanyContracDetail,detail Err: " + e.Error())
  458. return
  459. }
  460. //获取权限ID与名称的map映射
  461. permissionList, e := models.GetChartPermissionList()
  462. if e != nil && e.Error() != utils.ErrNoRow() {
  463. err = errors.New("GetChartPermissionList Err: " + e.Error())
  464. return
  465. }
  466. mapChartPermission := make(map[int]string)
  467. for _, v := range permissionList {
  468. mapChartPermission[v.ChartPermissionId] = v.PermissionName
  469. }
  470. companyId := detail.CompanyId
  471. //如果不是续约合同就不做对比处理
  472. pars = make([]interface{}, 0)
  473. condition = " AND company_contract_id != ? AND company_id = ? "
  474. pars = append(pars, companyContractId, companyId)
  475. //获取历史签约信息
  476. companyContractPermissionListHistory, e := company.GetCompanyContractPermissionList(condition, pars)
  477. if e != nil && e.Error() != utils.ErrNoRow() {
  478. err = errors.New("companyContractPermissionListHistory Err: " + e.Error())
  479. return
  480. }
  481. var mapHistoryPerssionName []string
  482. for _, v := range companyContractPermissionListHistory {
  483. mapHistoryPerssionName = append(mapHistoryPerssionName, mapChartPermission[v.ChartPermissionId])
  484. }
  485. pars = make([]interface{}, 0)
  486. condition = " AND company_contract_id = ? "
  487. pars = append(pars, companyContractId)
  488. //获取当前签约的合同信息
  489. companyContractPermissionLisThis, e := company.GetCompanyContractPermissionList(condition, pars)
  490. if e != nil && e.Error() != utils.ErrNoRow() {
  491. err = errors.New("companyContractPermissionLisThis Err: " + e.Error())
  492. return
  493. }
  494. var items []*company.CompanyContractPermission
  495. for _, v := range companyContractPermissionLisThis {
  496. v.PermissionName = mapChartPermission[v.ChartPermissionId]
  497. if v.PermissionName == "" {
  498. continue
  499. }
  500. //已经存在的属于行业续约、不存在的属于行业新签
  501. if utils.InArrayByStr(mapHistoryPerssionName, v.PermissionName) {
  502. v.ContractType = "行业续约"
  503. } else {
  504. v.ContractType = "行业新签"
  505. }
  506. items = append(items, v)
  507. }
  508. //批量更新合同权限表的权限行业名称,以及签约合同时,当前行业类型(行业续约、行业新签)
  509. e = company.UpdateCompanyContractPermissionMulti(items)
  510. if e != nil {
  511. err = errors.New("UpdateCompanyContractPermissionMulti Err: " + e.Error())
  512. return
  513. }
  514. return
  515. }
  516. func initCRM14_4() {
  517. //func init() {
  518. permissionList, e := models.GetChartPermissionList()
  519. if e != nil && e.Error() != utils.ErrNoRow() {
  520. fmt.Println(permissionList)
  521. return
  522. }
  523. mapChartPermission := make(map[int]string)
  524. for _, v := range permissionList {
  525. mapChartPermission[v.ChartPermissionId] = v.PermissionName
  526. }
  527. var condition string
  528. var pars []interface{}
  529. condition = " AND status = 1 AND product_id = 2 "
  530. companyContractList, e := company.GetCompanyContractList(condition, pars)
  531. if e != nil && e.Error() != utils.ErrNoRow() {
  532. fmt.Println(e)
  533. return
  534. }
  535. fmt.Println(len(companyContractList))
  536. for k, v := range companyContractList {
  537. fmt.Println(k)
  538. HandleCompanyContractPermissionContractType(v.CompanyContractId)
  539. }
  540. //var companyContractIds []int
  541. //for _, v := range companyContractList {
  542. // companyContractIds = append(companyContractIds, v.CompanyContractId)
  543. //}
  544. //condition = " AND company_contract_id IN (" + utils.GetOrmInReplace(len(companyContractIds)) + ") "
  545. //pars = append(pars, companyContractIds)
  546. //
  547. //companyContractPermissionList, e := company.GetCompanyContractPermissionList(condition, pars)
  548. //if e != nil && e.Error() != utils.ErrNoRow() {
  549. // fmt.Println(e)
  550. // return
  551. //}
  552. //
  553. //var items []*company.CompanyContractPermission
  554. //
  555. //for _, v := range companyContractPermissionList {
  556. // v.PermissionName = mapChartPermission[v.ChartPermissionId]
  557. //
  558. // items = append(items, v)
  559. //}
  560. //fmt.Println(len(items))
  561. ////return
  562. //e = company.UpdateCompanyContractPermissionMulti(items)
  563. //if e != nil && e.Error() != utils.ErrNoRow() {
  564. // fmt.Println(e)
  565. // return
  566. //}
  567. }
  568. func initCrm13_2() {
  569. var condition string
  570. var pars []interface{}
  571. condition = " AND chart_permission_id = 31 AND `status` IN ('正式','试用') AND product_id = 2 "
  572. //获取所有开通买方研选正式试用的客户列表
  573. listCompanyPermissionYx, e := company.GetCompanyReportPermissionList(condition, pars, 0, 0)
  574. if e != nil && e.Error() != utils.ErrNoRow() {
  575. fmt.Println(e)
  576. return
  577. }
  578. condition = " AND chart_permission_id = 52 "
  579. listCompanyPermissionKouDian, e := company.GetCompanyReportPermissionList(condition, pars, 0, 0)
  580. if e != nil && e.Error() != utils.ErrNoRow() {
  581. fmt.Println(e)
  582. return
  583. }
  584. mapKoud := make(map[int]bool)
  585. for _, v := range listCompanyPermissionKouDian {
  586. mapKoud[v.CompanyId] = true
  587. }
  588. //var i int
  589. var items []*company.CompanyReportPermission
  590. for k, v := range listCompanyPermissionYx {
  591. if mapKoud[v.CompanyId] {
  592. continue
  593. }
  594. permission := new(company.CompanyReportPermission)
  595. permission.CompanyId = v.CompanyId
  596. permission.ReportPermissionId = v.ReportPermissionId
  597. permission.CreatedTime = time.Now()
  598. permission.LastUpdatedTime = time.Now()
  599. permission.ChartPermissionId = 52
  600. permission.StartDate = v.StartDate
  601. permission.EndDate = v.EndDate
  602. permission.ProductId = 2
  603. permission.ProductName = "权益"
  604. permission.ModifyTime = time.Now()
  605. permission.Status = v.Status
  606. err := company.AddCompanyReportPermission(permission)
  607. if err != nil {
  608. return
  609. }
  610. fmt.Println(k)
  611. items = append(items, permission)
  612. }
  613. fmt.Println(len(items))
  614. }
  615. func initCRM_15_4() {
  616. var conditionAllocation string
  617. var parsAllocation []interface{}
  618. conditionAllocation = " AND company_contract_id IN (SELECT company_contract_id FROM cygx_allocation_company_contract_permission WHERE chart_permission_name LIKE '%研选%') GROUP BY company_contract_id "
  619. allocationCompanyContractPermissionList, err := cygx.GetCygxAllocationCompanyContractPermissionList(conditionAllocation, parsAllocation)
  620. if err != nil {
  621. fmt.Println(err)
  622. return
  623. }
  624. var companyContractIds []int
  625. for _, v := range allocationCompanyContractPermissionList {
  626. companyContractIds = append(companyContractIds, v.CompanyContractId)
  627. }
  628. lenCon := len(companyContractIds)
  629. for _, v := range companyContractIds {
  630. UpdateInitAvg(v)
  631. }
  632. fmt.Println("lenCon", lenCon)
  633. return
  634. }
  635. //func init() {
  636. // UpdateInitAvg(1249)
  637. //}
  638. // 合并研选订阅与研选扣点包,为买方研选
  639. func UpdateInit(companyContractId int) {
  640. fmt.Println(companyContractId)
  641. allocationNames := []string{"董衡", "高亦文", "吴昂迪", "冯柯然", "汪洋"}
  642. fmt.Println(allocationNames)
  643. listPerssion, err := cygx.GetCygxAllocationCompanyContractPermissionListByIdInitYx(companyContractId)
  644. if err != nil {
  645. fmt.Println(err)
  646. return
  647. }
  648. //listUser, err := cygx.GetCygxAllocationCompanyContractListById(companyContractId)
  649. //if err != nil {
  650. // fmt.Println(err)
  651. // return
  652. //}
  653. var totalMoney float64
  654. var items []*cygx.CygxAllocationCompanyContract
  655. var itemsPermission []*cygx.CygxAllocationCompanyContractPermission
  656. //var proportionSum float64 // 校验前端传过来的占比使用
  657. var AdminId int
  658. var AdminName string
  659. for _, v := range listPerssion {
  660. totalMoney += v.Money
  661. AdminId = v.AdminId
  662. AdminName = v.AdminName
  663. }
  664. fmt.Println(totalMoney)
  665. //return
  666. itemPermission := new(cygx.CygxAllocationCompanyContractPermission)
  667. itemPermission.CompanyContractId = companyContractId
  668. itemPermission.AdminId = AdminId
  669. itemPermission.AdminName = AdminName
  670. //itemPermission.Proportion = v.Money / totalMoney * 100
  671. itemPermission.Money = totalMoney
  672. itemPermission.ChartPermissionName = utils.CHART_PERMISSION_NAME_MAI_FANG_YANXUAN
  673. itemPermission.CreateTime = time.Now()
  674. itemPermission.ModifyTime = time.Now()
  675. itemsPermission = append(itemsPermission, itemPermission)
  676. for _, v := range allocationNames {
  677. item := new(cygx.CygxAllocationCompanyContract)
  678. item.CompanyContractId = companyContractId
  679. item.AdminId = AdminId
  680. item.AdminName = AdminName
  681. //item.Proportion =
  682. item.Money = totalMoney / 5
  683. item.RealName = v
  684. item.ChartPermissionName = utils.CHART_PERMISSION_NAME_MAI_FANG_YANXUAN
  685. item.CreateTime = time.Now()
  686. item.ModifyTime = time.Now()
  687. items = append(items, item)
  688. }
  689. fmt.Println(len(items))
  690. fmt.Println(len(itemsPermission))
  691. //return
  692. err = cygx.AddAndUpdateCygxAllocationCompanyContractInit(items, itemsPermission, companyContractId)
  693. fmt.Println(err)
  694. }
  695. func UpdateInitAvg(companyContractId int) {
  696. fmt.Println(companyContractId)
  697. listPerssion, err := cygx.GetCygxAllocationCompanyContractPermissionListByIdInit(companyContractId)
  698. if err != nil {
  699. fmt.Println(err)
  700. return
  701. }
  702. listUser, err := cygx.GetCygxAllocationCompanyContractListById(companyContractId)
  703. if err != nil {
  704. fmt.Println(err)
  705. return
  706. }
  707. var totalMoney float64
  708. var items []*cygx.CygxAllocationCompanyContract
  709. var itemsPermission []*cygx.CygxAllocationCompanyContractPermission
  710. //var proportionSum float64 // 校验前端传过来的占比使用
  711. for _, v := range listPerssion {
  712. totalMoney += v.Money
  713. }
  714. moneyAvg := totalMoney / float64(len(listPerssion))
  715. for _, v := range listPerssion {
  716. itemPermission := new(cygx.CygxAllocationCompanyContractPermission)
  717. itemPermission.CompanyContractId = companyContractId
  718. itemPermission.AdminId = v.AdminId
  719. itemPermission.AdminName = v.AdminName
  720. itemPermission.Proportion = v.Money / totalMoney * 100
  721. itemPermission.Money = v.Money
  722. itemPermission.MoneyAvg = moneyAvg
  723. itemPermission.ChartPermissionName = v.ChartPermissionName
  724. itemPermission.CreateTime = time.Now()
  725. itemPermission.ModifyTime = time.Now()
  726. itemsPermission = append(itemsPermission, itemPermission)
  727. fmt.Println(v.Money, "___", itemPermission.Proportion, "___", v.AllocationCompanyContractId)
  728. err = cygx.Cygx_allocation_company_contract_permissionEdit(itemPermission.Proportion, itemPermission.MoneyAvg, v.AllocationCompanyContractId)
  729. //fmt.Println("AllocationCompanyContractId", v.AllocationCompanyContractId)
  730. if err != nil {
  731. fmt.Println(err)
  732. return
  733. }
  734. }
  735. //return
  736. fmt.Println("研究员修改")
  737. //var userProportionSum float64 // 校验前端传过来的占比使用
  738. for _, v2 := range listUser {
  739. item := new(cygx.CygxAllocationCompanyContract)
  740. item.CompanyContractId = companyContractId
  741. item.AdminId = v2.AdminId
  742. item.AdminName = v2.RealName
  743. item.Proportion = v2.Money / totalMoney * 100
  744. item.Money = v2.Money
  745. item.RealName = v2.RealName
  746. item.ChartPermissionName = v2.ChartPermissionName
  747. item.CreateTime = time.Now()
  748. item.ModifyTime = time.Now()
  749. items = append(items, item)
  750. err = cygx.Cygx_allocation_company_contractEdit(item.Proportion, v2.AllocationCompanyContractId)
  751. fmt.Println("AllocationCompanyContractId", v2.AllocationCompanyContractId)
  752. if err != nil {
  753. fmt.Println(err)
  754. return
  755. }
  756. }
  757. //err = cygx.AddAndUpdateCygxAllocationCompanyContractInit(items, itemsPermission, companyContractId)
  758. //fmt.Println(err)
  759. }