company_apply_v2.go 83 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464
  1. package controllers
  2. import (
  3. "encoding/json"
  4. "fmt"
  5. "hongze/hz_crm_api/models"
  6. "hongze/hz_crm_api/models/company"
  7. "hongze/hz_crm_api/models/seal"
  8. "hongze/hz_crm_api/models/system"
  9. "hongze/hz_crm_api/services"
  10. "hongze/hz_crm_api/services/company_apply"
  11. contractService "hongze/hz_crm_api/services/contract"
  12. "hongze/hz_crm_api/utils"
  13. "sort"
  14. "strconv"
  15. "strings"
  16. "time"
  17. )
  18. // ApplyServiceUpdate
  19. // @Title 申请服务更新
  20. // @Description 申请服务更新接口
  21. // @Param request body company.CompanyApplyServiceUpdateReq true "type json string"
  22. // @Success Ret=200 申请成功
  23. // @router /apply/service/update [post]
  24. func (this *CompanyApplyController) ApplyServiceUpdate() {
  25. br := new(models.BaseResponse).Init()
  26. defer func() {
  27. this.Data["json"] = br
  28. this.ServeJSON()
  29. }()
  30. sysUser := this.SysUser
  31. if sysUser == nil {
  32. br.Msg = "请登录"
  33. br.ErrMsg = "请登录,SysUser Is Empty"
  34. br.Ret = 408
  35. return
  36. }
  37. var req company.CompanyApplyServiceUpdateReq
  38. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  39. if err != nil {
  40. br.Msg = "参数解析异常!"
  41. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  42. return
  43. }
  44. if req.CompanyId <= 0 {
  45. br.Msg = "参数错误"
  46. br.ErrMsg = "参数错误,客户id小于等于0"
  47. return
  48. }
  49. if req.StartDate == "" {
  50. br.Msg = "请选择合同开始日期"
  51. return
  52. }
  53. if req.EndDate == "" {
  54. br.Msg = "请选择合同结束日期"
  55. return
  56. }
  57. if req.Money <= 0 {
  58. br.Msg = "合同金额不能小于等于0"
  59. }
  60. if req.ContractType == "" {
  61. req.ContractType = "续约合同"
  62. //br.Msg = "请选择合同类型"
  63. //return
  64. }
  65. if req.PermissionIds == "" {
  66. br.Msg = "请选择权限"
  67. br.ErrMsg = "请选择权限"
  68. return
  69. }
  70. roleTypeCode := sysUser.RoleTypeCode
  71. productId := services.GetProductId(roleTypeCode)
  72. if productId == 0 {
  73. br.Msg = "参数错误"
  74. br.ErrMsg = "客户类型为:" + req.CompanyType
  75. return
  76. }
  77. //添加缓存,避免多次点击提交
  78. {
  79. deleteCache := true
  80. cacheKey := "CACHE_COMPANY_APPLY_" + strconv.Itoa(req.CompanyId) + "_" + strconv.Itoa(productId)
  81. defer func() {
  82. if deleteCache {
  83. utils.Rc.Delete(cacheKey)
  84. }
  85. }()
  86. if !utils.Rc.SetNX(cacheKey, 1, 30*time.Second) {
  87. deleteCache = false
  88. br.Msg = "系统处理中,请勿重复操作"
  89. br.ErrMsg = "系统处理中,请勿重复操作" + sysUser.RealName + ";data:" + string(this.Ctx.Input.RequestBody)
  90. return
  91. }
  92. }
  93. approveRoleTypeCode := ""
  94. if productId == 1 {
  95. approveRoleTypeCode = utils.ROLE_TYPE_CODE_FICC_ADMIN
  96. } else {
  97. approveRoleTypeCode = utils.ROLE_TYPE_CODE_RAI_ADMIN
  98. }
  99. companyProduct, err := company.GetCompanyProductByCompanyIdAndProductId(req.CompanyId, productId)
  100. if err != nil {
  101. br.Msg = "获取客户信息失败"
  102. br.ErrMsg = "获取客户信息失败"
  103. return
  104. }
  105. if companyProduct.Status != utils.COMPANY_STATUS_FORMAL && companyProduct.Status != utils.COMPANY_STATUS_TRY_OUT {
  106. br.Msg = "客户状态为:" + companyProduct.Status + ";不可进行服务更新申请"
  107. br.ErrMsg = "客户状态为:" + companyProduct.Status + ";不可进行服务更新申请"
  108. return
  109. }
  110. //客户归属判断-当前销售/咨询组共享销售
  111. if companyProduct.SellerId != sysUser.AdminId && companyProduct.ShareSellerId != sysUser.AdminId {
  112. br.Msg = "客户信息异常"
  113. br.ErrMsg = "客户信息异常,不是当前所属销售,客户所属销售:" + companyProduct.SellerName + ";当前销售:" + sysUser.AdminName
  114. return
  115. }
  116. mapPermissionIdUpgrade := make(map[int]int, 0)
  117. mapPermissionIdExpensive := make(map[int]int, 0)
  118. mapPoints := make(map[int]float64)
  119. var raicontractType string
  120. if productId == 2 {
  121. // CRM13.3改-是否为权益内部人员, 非权益内部人员只能勾选行业不能勾选单独的主客观, 勾选行业(即勾选主观的ID需要加入客观的权限ID)
  122. isRai, e := services.CheckRaiAdmin(sysUser.AdminId)
  123. if e != nil {
  124. br.Msg = "获取失败"
  125. br.ErrMsg = "判断是否为权益内部人员失败, GetRaiAdmin Err: " + e.Error()
  126. return
  127. }
  128. for _, v := range req.PointsArr {
  129. mapPoints[v.ChartPermissionId] = v.Points
  130. }
  131. var permissionIdsNew string
  132. permissionIdsNew, mapPermissionIdUpgrade, mapPermissionIdExpensive, err = services.CheckCompanyUpgradeV2(req.PermissionIds, isRai)
  133. if err != nil {
  134. br.Msg = "获取信息失败"
  135. br.ErrMsg = "获取主观客观权限信息失败,Err:" + err.Error()
  136. return
  137. }
  138. req.PermissionIds = permissionIdsNew
  139. //权益的新签合同重新定义,如果合同起始时间在新签合同起始日期 1年之内的,仍为新签合同。
  140. raicontractType = req.ContractType
  141. if raicontractType != "新签合同" {
  142. //startDateTime, _ := time.Parse(utils.FormatDate, req.StartDate)
  143. //startDateTime = startDateTime.AddDate(-1, 0, 0)
  144. totalLastYear, err := contractService.GetCompanyContractCountRaiByLastYear(req.CompanyId, req.StartDate)
  145. if err != nil {
  146. br.Msg = "获取合同信息失败"
  147. br.ErrMsg = "获取合同信息失败,Err:" + err.Error()
  148. return
  149. }
  150. if totalLastYear > 0 {
  151. raicontractType = "新签合同"
  152. req.ContractType = "新签合同"
  153. }
  154. }
  155. } else {
  156. permissionStr, err := company.GetPermissionIdById(req.PermissionIds)
  157. if err != nil {
  158. br.Msg = "获取信息失败"
  159. br.ErrMsg = "获取主观客观权限信息失败,Err:" + err.Error()
  160. return
  161. }
  162. req.PermissionIds = permissionStr
  163. }
  164. var approveUserId int
  165. var approveUserRealName string
  166. applyMethod := 5 //续约服务
  167. recordApproveContent := `正式客户申请续约`
  168. approveContent := `申请续约`
  169. messageContent := "续约申请单"
  170. operationRemark := `申请续约`
  171. operation := "service_update"
  172. //申请类型:1:试用->正式,2:冻结—>试用,3:试用延期,4:原销售申请领取流失客户,5:正式客户申请服务更新,6:正式客户补充协议
  173. if req.ContractType == "补充协议" {
  174. applyMethod = 6 //补充协议
  175. recordApproveContent = `正式客户新增补充协议`
  176. approveContent = `新增补充协议`
  177. messageContent = "补充协议申请单"
  178. operationRemark = `新增补充协议`
  179. operation = "add_agreement"
  180. }
  181. approveUser, err := company.GetApproveUser(approveRoleTypeCode)
  182. if err != nil && err.Error() != utils.ErrNoRow() {
  183. br.Msg = "获取审批信息失败"
  184. br.ErrMsg = "获取审批人信息失败,Err:" + err.Error()
  185. return
  186. }
  187. if approveUser == nil || (err != nil && err.Error() == utils.ErrNoRow()) {
  188. br.Msg = "审批用户不存在"
  189. br.ErrMsg = "审批用户不存在"
  190. return
  191. }
  192. var companyApprovalId int
  193. if req.CompanyApprovalId <= 0 {
  194. contractCode, err := company.GetCompanyContractCode()
  195. if err != nil {
  196. br.Msg = "生成合同编码失败"
  197. br.ErrMsg = "生成合同编码失败,Err:" + err.Error()
  198. return
  199. }
  200. var sealId int
  201. if productId == 2 {
  202. contractCode, err = seal.GetSealCodeRai() //权益客户合同编号格式替换
  203. if err != nil {
  204. br.Msg = "生成合同编码失败"
  205. br.ErrMsg = "生成合同编码失败,Err:" + err.Error()
  206. return
  207. }
  208. sealCount, err := seal.GetCountByDateAndCompanyId(req.StartDate, req.EndDate, req.CompanyId)
  209. if err != nil {
  210. br.Msg = "生成合同编码失败"
  211. br.ErrMsg = "获取用印合同数量信息失败,Err:" + err.Error()
  212. return
  213. }
  214. crmConfig, err := company.GetConfigDetailByCode("rai_seal_check") //权益非标合同是否校验用印提交
  215. if err != nil {
  216. br.Msg = "获取配置失败"
  217. br.ErrMsg = "获取配置失败,Err:" + err.Error()
  218. return
  219. }
  220. if sealCount == 0 && crmConfig.ConfigValue == "1" {
  221. br.Msg = "此合同暂未申请用印,请核对合同期限是否有误"
  222. return
  223. }
  224. if sealCount > 0 {
  225. sealInfo, err := seal.GetSealInfoByDateAndCompanyId(req.StartDate, req.EndDate, req.CompanyId)
  226. if err != nil {
  227. br.Msg = "生成合同编码失败"
  228. br.ErrMsg = "获取用印合同信息失败,Err:" + err.Error()
  229. return
  230. }
  231. contractCode = sealInfo.Code
  232. sealId = sealInfo.SealId
  233. }
  234. }
  235. //当前是否存在待审批的单子
  236. nowCompanyApprovalInfo, err := company.GetCompanyApprovalById(req.CompanyId, productId)
  237. if (err == nil || nowCompanyApprovalInfo != nil) || err != nil && err.Error() != utils.ErrNoRow() {
  238. br.Msg = "此客户已存在待审批的申请单,请在申请单审批完成后重新提交"
  239. br.ErrMsg = "此客户已存在待审批的申请单,请在申请单审批完成后重新提交"
  240. return
  241. }
  242. //当前待审批的合同,有且只能存在一条
  243. //count, err := company.GetCompanyContractApproveCount(req.CompanyId, productId)
  244. //if err != nil {
  245. // br.Msg = "获取信息失败"
  246. // br.ErrMsg = "判断是否已存在待审批合同失败,Err:" + err.Error()
  247. // return
  248. //}
  249. //if count > 0 {
  250. // br.Msg = "此客户已提交过申请,请在客户审批列表重新提交"
  251. // return
  252. //}
  253. contract := new(company.CompanyContract)
  254. contract.CompanyId = req.CompanyId
  255. contract.ProductId = productId
  256. contract.ProductName = companyProduct.ProductName
  257. contract.CompanyProductId = companyProduct.CompanyProductId
  258. contract.ContractType = req.ContractType
  259. contract.RaiContractType = raicontractType
  260. contract.ContractCode = contractCode
  261. contract.StartDate = req.StartDate
  262. contract.EndDate = req.EndDate
  263. contract.Money = req.Money
  264. contract.PayMethod = req.PayMethod
  265. contract.PayChannel = req.PayChannel
  266. contract.ImgUrl = req.ImgUrl
  267. contract.Status = 0
  268. contract.Source = "上传附件"
  269. contract.CreateTime = time.Now()
  270. contract.ModifyTime = time.Now()
  271. contract.PackageType = req.PackageType
  272. contract.RaiPackageType = req.RaiPackageType
  273. contract.SellerIdInit = companyProduct.SellerId
  274. contract.SellerNameInit = companyProduct.SellerName
  275. contract.ShareSellerInit = companyProduct.ShareSeller
  276. contract.ShareSellerIdInit = companyProduct.ShareSellerId
  277. contract.SellerIdLast = companyProduct.SellerId
  278. contract.SellerNameLast = companyProduct.SellerName
  279. contract.ShareSellerLast = companyProduct.ShareSeller
  280. contract.ShareSellerIdLast = companyProduct.ShareSellerId
  281. newId, err := company.AddCompanyContract(contract)
  282. if err != nil {
  283. br.Msg = "新增合同失败"
  284. br.ErrMsg = "新增合同失败,Err:" + err.Error()
  285. return
  286. }
  287. //如果用印ID > 0 建立合同ID,与用印申请表的关系
  288. if sealId > 0 {
  289. //用印作废
  290. err = seal.UpdateSealCompanyContractId(int(newId), sealId)
  291. if err != nil {
  292. br.Msg = "操作失败"
  293. br.ErrMsg = "添加用印与合同的关系失败,Err:" + err.Error()
  294. return
  295. }
  296. }
  297. go services.UpdateCompanyContractInheritEndDate(int(newId))
  298. permissionArr := strings.Split(req.PermissionIds, ",")
  299. permissionMap := make(map[int]int) //权限id的map集合,用来避免重复添加权限校验
  300. permissionNameMap, err := services.GetPermissionNameMap()
  301. if err != nil {
  302. br.Msg = "新增合同失败"
  303. br.ErrMsg = "获取权限名称失败,Err:" + err.Error()
  304. return
  305. }
  306. for _, v := range permissionArr {
  307. item := new(company.CompanyContractPermission)
  308. item.CompanyId = req.CompanyId
  309. item.CompanyContractId = int(newId)
  310. chartPermissionId, tmpErr := strconv.Atoi(v)
  311. if tmpErr != nil {
  312. err = tmpErr
  313. return
  314. }
  315. //权限id判断,避免重复添加权限
  316. if _, ok := permissionMap[chartPermissionId]; ok {
  317. continue
  318. }
  319. permissionMap[chartPermissionId] = chartPermissionId
  320. item.ChartPermissionId = chartPermissionId
  321. item.PermissionName = permissionNameMap[chartPermissionId]
  322. //如果是研选扣点包的权限,写入扣点点数
  323. item.Points = mapPoints[chartPermissionId]
  324. item.StartDate = req.StartDate
  325. item.EndDate = req.EndDate
  326. item.IsUpgrade = mapPermissionIdUpgrade[chartPermissionId]
  327. item.ExpensiveYx = mapPermissionIdExpensive[chartPermissionId]
  328. item.ModifyTime = time.Now()
  329. item.CreateTime = time.Now()
  330. err = company.AddCompanyContractPermission(item)
  331. if err != nil {
  332. br.Msg = "新增合同失败"
  333. br.ErrMsg = "新增合同权限失败,Err:" + err.Error()
  334. return
  335. }
  336. //新增日志
  337. {
  338. itemLog := new(company.CompanyContractPermissionLog)
  339. itemLog.CompanyId = req.CompanyId
  340. itemLog.CompanyContractId = int(newId)
  341. itemLog.ChartPermissionId = v
  342. itemLog.StartDate = req.StartDate
  343. itemLog.EndDate = req.EndDate
  344. itemLog.ModifyTime = time.Now()
  345. itemLog.CreateTime = time.Now()
  346. itemLog.LogCreateTime = time.Now()
  347. go company.AddCompanyContractPermissionLog(itemLog)
  348. }
  349. }
  350. approval := new(company.CompanyApproval)
  351. approval.CompanyId = req.CompanyId
  352. approval.ProductId = productId
  353. approval.ApproveStatus = "待审批"
  354. approval.ApproveUserId = 0
  355. approval.ApproveRoleTypeCode = approveRoleTypeCode
  356. approval.ApproveRealName = ""
  357. approval.ApproveTime = time.Now()
  358. approval.ApproveContent = approveContent
  359. approval.ApplyMethod = applyMethod
  360. approval.ApplyReasons = ""
  361. approval.ApplyUserId = sysUser.AdminId
  362. approval.ApplyRealName = sysUser.RealName
  363. approval.CompanyContractId = int(newId)
  364. approval.CreateTime = time.Now()
  365. approval.ModifyTime = time.Now()
  366. approval.IsFormal = companyProduct.IsFormal
  367. companyApprovalId, err = company.AddCompanyApproval(approval)
  368. if err != nil {
  369. br.Msg = "申请失败"
  370. br.ErrMsg = "申请失败,Err:" + err.Error()
  371. return
  372. }
  373. } else {
  374. // 有审批单
  375. recode, err := company.GetCompanyApprovalByApprovalId(req.CompanyApprovalId)
  376. if err != nil {
  377. br.Msg = "申请失败"
  378. br.ErrMsg = "获取审批记录失败,Err:" + err.Error()
  379. return
  380. }
  381. err = company.ModifyCompanyApplyServiceUpdate(&req, productId, recode.CompanyContractId, companyProduct.IsFormal, mapPermissionIdUpgrade, mapPermissionIdExpensive, mapPoints)
  382. if err != nil {
  383. br.Msg = "申请失败"
  384. br.ErrMsg = "申请失败,Err:" + err.Error()
  385. return
  386. }
  387. companyApprovalId = req.CompanyApprovalId
  388. }
  389. //新增操作记录
  390. {
  391. services.AddCompanyOperationRecord(req.CompanyId, companyProduct.SellerId, sysUser.AdminId, productId, approveUserId, companyProduct.CompanyName,
  392. companyProduct.ProductName, sysUser.RealName, operationRemark, operation, recordApproveContent, approveUserRealName, "", companyProduct.Status)
  393. }
  394. //新增客户产品日志
  395. {
  396. logType := "modify"
  397. go services.AddCompanyProductLog(companyProduct, this.SysUser.AdminId, logType)
  398. }
  399. //新增申请单
  400. err = company_apply.Apply(companyApprovalId, messageContent)
  401. if err != nil {
  402. br.Msg = "发起审批异常,请联系管理员"
  403. br.ErrMsg = "客户审批发起异常,Err:" + err.Error()
  404. return
  405. }
  406. br.Ret = 200
  407. br.Success = true
  408. br.Msg = "申请成功"
  409. }
  410. // ApplyTurnPositive
  411. // @Title 申请转正
  412. // @Description 申请转正接口
  413. // @Param request body company.CompanyApplyTurnPositiveReq true "type json string"
  414. // @Success Ret=200 申请成功
  415. // @router /apply/turn/positive [post]
  416. func (this *CompanyApplyController) ApplyTurnPositive() {
  417. br := new(models.BaseResponse).Init()
  418. defer func() {
  419. this.Data["json"] = br
  420. this.ServeJSON()
  421. }()
  422. sysUser := this.SysUser
  423. if sysUser == nil {
  424. br.Msg = "请登录"
  425. br.ErrMsg = "请登录,SysUser Is Empty"
  426. br.Ret = 408
  427. return
  428. }
  429. var req company.CompanyApplyTurnPositiveReq
  430. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  431. if err != nil {
  432. br.Msg = "参数解析异常!"
  433. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  434. return
  435. }
  436. wxUserId := req.WxUserId
  437. if req.CompanyId <= 0 {
  438. br.Msg = "参数错误"
  439. br.ErrMsg = "参数错误,客户id小于等于0"
  440. return
  441. }
  442. if req.StartDate == "" {
  443. br.Msg = "请选择合同开始日期"
  444. return
  445. }
  446. if req.EndDate == "" {
  447. br.Msg = "请选择合同结束日期"
  448. return
  449. }
  450. if req.Money <= 0 {
  451. br.Msg = "合同金额不能小于等于0"
  452. return
  453. }
  454. if req.PermissionIds == "" {
  455. br.Msg = "请选择权限"
  456. return
  457. }
  458. roleTypeCode := sysUser.RoleTypeCode
  459. productId := services.GetProductId(roleTypeCode)
  460. if productId == 0 {
  461. br.Msg = "参数错误"
  462. br.ErrMsg = "客户类型为:" + roleTypeCode
  463. return
  464. }
  465. //添加缓存,避免多次点击提交
  466. {
  467. deleteCache := true
  468. cacheKey := "CACHE_COMPANY_APPLY_" + strconv.Itoa(req.CompanyId) + "_" + strconv.Itoa(productId)
  469. defer func() {
  470. if deleteCache {
  471. utils.Rc.Delete(cacheKey)
  472. }
  473. }()
  474. if !utils.Rc.SetNX(cacheKey, 1, 30*time.Second) {
  475. deleteCache = false
  476. br.Msg = "系统处理中,请勿重复操作"
  477. br.ErrMsg = "系统处理中,请勿重复操作" + sysUser.RealName + ";data:" + string(this.Ctx.Input.RequestBody)
  478. return
  479. }
  480. }
  481. companyProduct, err := company.GetCompanyProductByCompanyIdAndProductId(req.CompanyId, productId)
  482. if err != nil {
  483. br.Msg = "获取客户信息失败"
  484. br.ErrMsg = "获取客户信息失败"
  485. return
  486. }
  487. if companyProduct == nil {
  488. br.Msg = "获取客户信息失败"
  489. br.ErrMsg = "客户不存在,不可提交审批:companyId:" + strconv.Itoa(req.CompanyId) + ";productId:" + strconv.Itoa(productId)
  490. return
  491. }
  492. if companyProduct.Status != utils.COMPANY_STATUS_TRY_OUT && companyProduct.InitStatus != utils.COMPANY_STATUS_FOREVER && wxUserId == 0 {
  493. br.Msg = "客户状态为:" + companyProduct.Status + ";不可进行转正申请"
  494. br.ErrMsg = "客户状态为:" + companyProduct.Status + ";不可进行转正申请"
  495. return
  496. }
  497. mapPermissionIdUpgrade := make(map[int]int) // 权益主客观、行业升级、买方研选的处理
  498. permissionNameMap := make(map[int]string) // 权益行业名称处理
  499. permissionNames := req.PermissionNames
  500. expensiveYx := 0
  501. mapPoints := make(map[int]float64)
  502. if productId == 2 {
  503. for _, v := range req.PointsArr {
  504. mapPoints[v.ChartPermissionId] = v.Points
  505. }
  506. // 给升级的产业ID加一个极大值判断处理
  507. permissionSlice := strings.Split(req.PermissionIds, ",")
  508. mapPermissionId := make(map[int]int)
  509. //var permissionIdsNew string
  510. var permissionIdOnly int //处理普通权限与升级权限同时勾选的时候的拦截
  511. expId := utils.PERMISSION_ID_YANXUAN_DIFF + utils.CHART_PERMISSION_ID_YANXUAN
  512. // 获取行业主观对应的客观ID
  513. subObjMap, e := services.GetRaiSubObjPermissionIdMap()
  514. if e != nil {
  515. br.Msg = "操作失败"
  516. br.ErrMsg = "获取行业主观对应的客观ID失败, Err: " + e.Error()
  517. return
  518. }
  519. strPermissionIdArr := make([]string, 0) // 最终过滤后的权限IDs
  520. for _, v := range permissionSlice {
  521. permissionId, _ := strconv.Atoi(v)
  522. // 研选5w的处理
  523. if permissionId == expId {
  524. //permissionIdsNew += strconv.Itoa(utils.CHART_PERMISSION_ID_YANXUAN) + ","
  525. strPermissionIdArr = append(strPermissionIdArr, strconv.Itoa(utils.CHART_PERMISSION_ID_YANXUAN))
  526. expensiveYx = 1
  527. continue
  528. }
  529. // 研选10w的处理
  530. if permissionId == utils.PERMISSION_ID_YANXUAN_10W_DIFF {
  531. //permissionIdsNew += strconv.Itoa(utils.CHART_PERMISSION_ID_YANXUAN) + ","
  532. strPermissionIdArr = append(strPermissionIdArr, strconv.Itoa(utils.CHART_PERMISSION_ID_YANXUAN))
  533. expensiveYx = 2
  534. continue
  535. }
  536. if permissionId > utils.PERMISSION_ID_UPGRADE {
  537. //permissionIdsNew += strconv.Itoa(permissionId-utils.PERMISSION_ID_UPGRADE) + ","
  538. permissionIdOnly = permissionId - utils.PERMISSION_ID_UPGRADE
  539. // 升级权限, 需要加入客观的权限
  540. subId := permissionId - utils.PERMISSION_ID_UPGRADE
  541. strPermissionIdArr = append(strPermissionIdArr, strconv.Itoa(subId))
  542. if subObjMap[subId] > 0 {
  543. strPermissionIdArr = append(strPermissionIdArr, strconv.Itoa(subObjMap[subId]))
  544. }
  545. } else {
  546. //permissionIdsNew += strconv.Itoa(permissionId) + ","
  547. strPermissionIdArr = append(strPermissionIdArr, v)
  548. permissionIdOnly = permissionId
  549. }
  550. //权益的永续客户主客观权限都开
  551. if companyProduct.InitStatus == utils.COMPANY_STATUS_FOREVER && subObjMap[permissionId] > 0 {
  552. strPermissionIdArr = append(strPermissionIdArr, strconv.Itoa(subObjMap[permissionId]))
  553. }
  554. if _, ok := mapPermissionId[permissionIdOnly]; ok {
  555. br.Msg = "权限设置有误,请重新选择"
  556. br.ErrMsg = "升级权限与普通权限重复选择!" + req.PermissionIds
  557. return
  558. }
  559. mapPermissionId[permissionIdOnly] = permissionIdOnly
  560. }
  561. req.PermissionIds = strings.Join(strPermissionIdArr, ",")
  562. //req.PermissionIds = strings.TrimRight(permissionIdsNew, ",")
  563. // 是否为权益内部人员, 非权益内部人员只能勾选行业不能勾选单独的主客观, 需要通过主观的ID去查客观的ID
  564. //isRai, e := services.CheckRaiAdmin(sysUser.AdminId)
  565. //if e != nil {
  566. // br.Msg = "获取失败"
  567. // br.ErrMsg = "判断是否为权益内部人员失败, GetRaiAdmin Err: " + e.Error()
  568. // return
  569. //}
  570. //if !isRai {
  571. //permissionStr, err := company.GetPermissionIdById(req.PermissionIds)
  572. //if err != nil {
  573. // br.Msg = "获取信息失败"
  574. // br.ErrMsg = "获取主观客观权限信息失败,Err:" + err.Error()
  575. // return
  576. //}
  577. //req.PermissionIds = permissionStr
  578. //}
  579. // 升级map
  580. if permissionNames != "" {
  581. mapPermissionIdUpgrade, err = services.PermissionIdUpgrade(permissionNames)
  582. if err != nil {
  583. br.Msg = "获取信息失败"
  584. br.ErrMsg = "处理升级信息失败,Err:" + err.Error()
  585. return
  586. }
  587. }
  588. permissionNameMap, err = services.GetPermissionNameMap()
  589. if err != nil {
  590. br.Msg = "新增合同失败"
  591. br.ErrMsg = "获取权限名称失败,Err:" + err.Error()
  592. return
  593. }
  594. }
  595. //客户归属判断
  596. if companyProduct.SellerId != sysUser.AdminId && companyProduct.ShareSellerId != sysUser.AdminId {
  597. br.Msg = "客户信息异常"
  598. br.ErrMsg = "客户信息异常,不是当前所属销售,客户所属销售:" + companyProduct.SellerName + ";当前销售:" + sysUser.AdminName
  599. return
  600. }
  601. if companyProduct.ApproveStatus == "待审批" {
  602. br.Msg = "存在待审批订单,不可重复提交"
  603. return
  604. }
  605. approveContent := `试用转正式`
  606. var approveUserId int
  607. var approveUserRealName string
  608. approveRoleTypeCode := ""
  609. if productId == 1 {
  610. approveRoleTypeCode = utils.ROLE_TYPE_CODE_FICC_ADMIN
  611. } else {
  612. approveRoleTypeCode = utils.ROLE_TYPE_CODE_RAI_ADMIN
  613. }
  614. approveUser, err := company.GetApproveUser(approveRoleTypeCode)
  615. if err != nil && err.Error() != utils.ErrNoRow() {
  616. br.Msg = "获取审批信息失败"
  617. br.ErrMsg = "获取审批人信息失败,Err:" + err.Error()
  618. return
  619. }
  620. if approveUser == nil || (err != nil && err.Error() == utils.ErrNoRow()) {
  621. br.Msg = "审批用户不存在"
  622. br.ErrMsg = "审批用户不存在"
  623. return
  624. }
  625. // 合同类型
  626. contractType := req.ContractType
  627. var raicontractType string // 权益合同类型
  628. {
  629. if contractType == "" {
  630. contractType = "新签合同"
  631. }
  632. var condition string
  633. var pars []interface{}
  634. condition += " AND product_id = ?"
  635. pars = append(pars, productId)
  636. condition += " AND status = ?"
  637. pars = append(pars, 1)
  638. list, e := company.GetCompanyContractListByCompanyId(req.CompanyId, condition, pars)
  639. if e != nil {
  640. br.Msg = "获取合同信息失败"
  641. br.ErrMsg = "获取合同信息失败,Err:" + e.Error()
  642. return
  643. }
  644. if len(list) > 0 {
  645. contractType = "续约合同"
  646. }
  647. if productId == 2 {
  648. //权益的新签合同重新定义,如果合同起始时间在新签合同起始日期 1年之内的,仍为新签合同。
  649. raicontractType = contractType
  650. if raicontractType != "新签合同" {
  651. //startDateTime, _ := time.Parse(utils.FormatDate, req.StartDate)
  652. //startDateTime = startDateTime.AddDate(-1, 0, 0)
  653. var totalLastYear int
  654. if wxUserId == 0 {
  655. totalLastYear, err = contractService.GetCompanyContractCountRaiByLastYear(req.CompanyId, req.StartDate)
  656. } else {
  657. totalLastYear, err = contractService.GetCompanyContractCountRaiByLastYearUserId(wxUserId, req.StartDate)
  658. }
  659. if err != nil {
  660. br.Msg = "获取合同信息失败"
  661. br.ErrMsg = "获取合同信息失败,Err:" + err.Error()
  662. return
  663. }
  664. if totalLastYear > 0 {
  665. raicontractType = "新签合同"
  666. }
  667. }
  668. }
  669. // 若上面的判断不是续约合同, 则继续查询是否存在正式转试用的记录,如果存在,那么合同类型是续约合同
  670. if contractType != "续约合同" {
  671. total, e := company.GetCompanyProductOperationRecordCount(companyProduct.CompanyId, companyProduct.ProductId)
  672. if e != nil {
  673. br.Msg = "查询用户信息异常"
  674. br.ErrMsg = "查询用户变更记录异常, GetCompanyProductOperationRecordCount err: " + e.Error()
  675. return
  676. }
  677. if total > 0 {
  678. contractType = "续约合同"
  679. }
  680. }
  681. }
  682. //权益合同类型,有一套单独的逻辑
  683. if productId == 2 {
  684. contractType = raicontractType
  685. }
  686. var companyApprovalId int
  687. // 全新的申请转正
  688. if req.CompanyApprovalId <= 0 {
  689. contractCode, err := company.GetCompanyContractCode()
  690. if err != nil {
  691. br.Msg = "生成合同编码失败"
  692. br.ErrMsg = "生成合同编码失败,Err:" + err.Error()
  693. return
  694. }
  695. //如果是权益的合同,合同编号另取
  696. if productId == 2 {
  697. sealCount, err := seal.GetCountByDateAndCompanyId(req.StartDate, req.EndDate, req.CompanyId)
  698. if err != nil {
  699. br.Msg = "生成合同编码失败"
  700. br.ErrMsg = "获取用印合同数量信息失败,Err:" + err.Error()
  701. return
  702. }
  703. crmConfig, err := company.GetConfigDetailByCode("rai_seal_check") //权益非标合同是否校验用印提交
  704. if err != nil {
  705. br.Msg = "获取配置失败"
  706. br.ErrMsg = "获取配置失败,Err:" + err.Error()
  707. return
  708. }
  709. if sealCount == 0 && crmConfig.ConfigValue == "1" {
  710. br.Msg = "此合同暂未申请用印,请核对合同期限是否有误"
  711. return
  712. }
  713. if sealCount > 0 {
  714. sealInfo, err := seal.GetSealInfoByDateAndCompanyId(req.StartDate, req.EndDate, req.CompanyId)
  715. if err != nil {
  716. br.Msg = "生成合同编码失败"
  717. br.ErrMsg = "获取用印合同信息失败,Err:" + err.Error()
  718. return
  719. }
  720. contractCode = sealInfo.Code
  721. }
  722. }
  723. var sealId int
  724. if productId == 2 {
  725. contractCode, err = seal.GetSealCodeRai() //权益客户合同编号格式替换
  726. if err != nil {
  727. br.Msg = "生成合同编码失败"
  728. br.ErrMsg = "生成合同编码失败,Err:" + err.Error()
  729. return
  730. }
  731. sealCount, err := seal.GetCountByDateAndCompanyId(req.StartDate, req.EndDate, req.CompanyId)
  732. if err != nil {
  733. br.Msg = "生成合同编码失败"
  734. br.ErrMsg = "获取用印合同数量信息失败,Err:" + err.Error()
  735. return
  736. }
  737. crmConfig, err := company.GetConfigDetailByCode("rai_seal_check") //权益非标合同是否校验用印提交
  738. if err != nil {
  739. br.Msg = "获取配置失败"
  740. br.ErrMsg = "获取配置失败,Err:" + err.Error()
  741. return
  742. }
  743. if sealCount == 0 && crmConfig.ConfigValue == "1" {
  744. br.Msg = "此合同暂未申请用印,请核对合同期限是否有误"
  745. return
  746. }
  747. if sealCount > 0 {
  748. sealInfo, err := seal.GetSealInfoByDateAndCompanyId(req.StartDate, req.EndDate, req.CompanyId)
  749. if err != nil {
  750. br.Msg = "生成合同编码失败"
  751. br.ErrMsg = "获取用印合同信息失败,Err:" + err.Error()
  752. return
  753. }
  754. contractCode = sealInfo.Code
  755. sealId = sealInfo.SealId
  756. }
  757. }
  758. //当前是否存在待审批的单子
  759. nowCompanyApprovalInfo, err := company.GetCompanyApprovalById(req.CompanyId, productId)
  760. if (err == nil || nowCompanyApprovalInfo != nil) || err != nil && err.Error() != utils.ErrNoRow() {
  761. br.Msg = "此客户已存在待审批的申请单,请在申请单审批完成后重新提交"
  762. br.ErrMsg = "此客户已存在待审批的申请单,请在申请单审批完成后重新提交"
  763. return
  764. }
  765. //当前待审批的合同,有且只能存在一条
  766. //count, err := company.GetCompanyContractApproveCount(req.CompanyId, productId)
  767. //if err != nil {
  768. // br.Msg = "获取信息失败"
  769. // br.ErrMsg = "判断是否已存在待审批合同失败,Err:" + err.Error()
  770. // return
  771. //}
  772. //if count > 0 {
  773. // br.Msg = "此客户已提交过申请,请在客户审批列表重新提交"
  774. // return
  775. //}
  776. contract := new(company.CompanyContract)
  777. contract.CompanyId = req.CompanyId
  778. contract.ProductId = productId
  779. contract.ContractType = contractType
  780. contract.RaiContractType = raicontractType
  781. contract.ProductName = companyProduct.ProductName
  782. contract.CompanyProductId = companyProduct.CompanyProductId
  783. contract.ContractCode = contractCode
  784. contract.StartDate = req.StartDate
  785. contract.EndDate = req.EndDate
  786. contract.Money = req.Money
  787. contract.PayMethod = req.PayMethod
  788. contract.PayChannel = req.PayChannel
  789. contract.ImgUrl = req.ImgUrl
  790. contract.Status = 0
  791. contract.Source = "上传附件"
  792. contract.PackageType = req.PackageType
  793. contract.RaiPackageType = req.RaiPackageType
  794. contract.CreateTime = time.Now()
  795. contract.ModifyTime = time.Now()
  796. contract.SellerIdInit = companyProduct.SellerId
  797. contract.SellerNameInit = companyProduct.SellerName
  798. contract.ShareSellerInit = companyProduct.ShareSeller
  799. contract.ShareSellerIdInit = companyProduct.ShareSellerId
  800. contract.SellerIdLast = companyProduct.SellerId
  801. contract.SellerNameLast = companyProduct.SellerName
  802. contract.ShareSellerLast = companyProduct.ShareSeller
  803. contract.ShareSellerIdLast = companyProduct.ShareSellerId
  804. contract.WxUserId = wxUserId
  805. newId, err := company.AddCompanyContract(contract)
  806. if err != nil {
  807. br.Msg = "新增合同失败"
  808. br.ErrMsg = "新增合同失败,Err:" + err.Error()
  809. return
  810. }
  811. //如果用印ID > 0 建立合同ID,与用印申请表的关系
  812. if sealId > 0 {
  813. //用印作废
  814. err = seal.UpdateSealCompanyContractId(int(newId), sealId)
  815. if err != nil {
  816. br.Msg = "操作失败"
  817. br.ErrMsg = "添加用印与合同的关系失败,Err:" + err.Error()
  818. return
  819. }
  820. }
  821. go services.UpdateCompanyContractInheritEndDate(int(newId))
  822. permissionArr := strings.Split(req.PermissionIds, ",")
  823. permissionMap := make(map[int]int) //权限id的map集合,用来避免重复添加权限校验
  824. permissionItems := make([]*company.CompanyContractPermission, 0)
  825. permissionLogs := make([]*company.CompanyContractPermissionLog, 0)
  826. for _, v := range permissionArr {
  827. item := new(company.CompanyContractPermission)
  828. item.CompanyId = req.CompanyId
  829. item.WxUserId = req.WxUserId
  830. item.CompanyContractId = int(newId)
  831. chartPermissionId, tmpErr := strconv.Atoi(v)
  832. if tmpErr != nil {
  833. err = tmpErr
  834. return
  835. }
  836. //权限id判断,避免重复添加权限
  837. if _, ok := permissionMap[chartPermissionId]; ok {
  838. continue
  839. }
  840. permissionMap[chartPermissionId] = chartPermissionId
  841. item.ChartPermissionId = chartPermissionId
  842. if _, ok := mapPermissionIdUpgrade[chartPermissionId]; ok {
  843. item.IsUpgrade = 1
  844. }
  845. if chartPermissionId == utils.CHART_PERMISSION_ID_YANXUAN {
  846. item.ExpensiveYx = expensiveYx
  847. }
  848. item.Points = mapPoints[chartPermissionId]
  849. item.PermissionName = permissionNameMap[chartPermissionId]
  850. item.StartDate = req.StartDate
  851. item.EndDate = req.EndDate
  852. item.ModifyTime = time.Now()
  853. item.CreateTime = time.Now()
  854. permissionItems = append(permissionItems, item)
  855. //新增日志
  856. itemLog := new(company.CompanyContractPermissionLog)
  857. itemLog.CompanyId = req.CompanyId
  858. itemLog.WxUserId = req.WxUserId
  859. itemLog.CompanyContractId = int(newId)
  860. itemLog.ChartPermissionId = v
  861. itemLog.StartDate = req.StartDate
  862. itemLog.EndDate = req.EndDate
  863. itemLog.ModifyTime = time.Now()
  864. itemLog.CreateTime = time.Now()
  865. itemLog.LogCreateTime = time.Now()
  866. permissionLogs = append(permissionLogs, itemLog)
  867. }
  868. // 批量新增company_contract_permission和log
  869. if e := company.MultiAddCompanyContractPermission(permissionItems); e != nil {
  870. br.Msg = "新增合同失败"
  871. br.ErrMsg = "批量新增合同权限失败, MultiAddCompanyContractPermission Err:" + e.Error()
  872. return
  873. }
  874. go company.MultiAddCompanyContractPermissionLog(permissionLogs)
  875. applyMethod := 1
  876. approval := new(company.CompanyApproval)
  877. approval.CompanyId = req.CompanyId
  878. approval.ProductId = productId
  879. approval.ApproveStatus = "待审批"
  880. approval.ApproveUserId = 0
  881. approval.ApproveRoleTypeCode = approveRoleTypeCode
  882. approval.ApproveRealName = ""
  883. approval.ApproveTime = time.Now()
  884. if wxUserId == 0 {
  885. approval.ApproveContent = "试用转正式"
  886. } else {
  887. approval.ApproveContent = "个人转正"
  888. userInfo, err := models.GetWxUserByUserId(wxUserId)
  889. if err != nil {
  890. br.Msg = "获取联系人异常!"
  891. br.ErrMsg = "获取联系人异常,Err:" + err.Error()
  892. return
  893. }
  894. approval.WxUserName = userInfo.RealName
  895. }
  896. approval.ApplyMethod = applyMethod
  897. approval.ApplyReasons = ""
  898. approval.ApplyUserId = sysUser.AdminId
  899. approval.ApplyRealName = sysUser.RealName
  900. approval.CreateTime = time.Now()
  901. approval.ModifyTime = time.Now()
  902. approval.CompanyContractId = int(newId)
  903. approval.IsFormal = companyProduct.IsFormal
  904. approval.WxUserId = wxUserId
  905. companyApprovalId, err = company.AddCompanyApproval(approval)
  906. if err != nil {
  907. br.Msg = "申请失败"
  908. br.ErrMsg = "申请失败,Err:" + err.Error()
  909. return
  910. }
  911. } else {
  912. // 重新申请
  913. recode, err := company.GetCompanyApprovalByApprovalId(req.CompanyApprovalId)
  914. if err != nil {
  915. br.Msg = "申请失败"
  916. br.ErrMsg = "获取审批记录失败,Err:" + err.Error()
  917. return
  918. }
  919. err = company.ModifyCompanyTurnPositive(&req, productId, recode.CompanyContractId, companyProduct.IsFormal, mapPermissionIdUpgrade, expensiveYx)
  920. if err != nil {
  921. br.Msg = "申请失败"
  922. br.ErrMsg = "申请失败,Err:" + err.Error()
  923. return
  924. }
  925. companyApprovalId = req.CompanyApprovalId
  926. }
  927. if wxUserId == 0 {
  928. //新增操作记录
  929. {
  930. remark := "申请转正"
  931. operation := "turn_positive"
  932. services.AddCompanyOperationRecord(req.CompanyId, companyProduct.SellerId, sysUser.AdminId, productId, approveUserId, companyProduct.CompanyName,
  933. companyProduct.ProductName, sysUser.RealName, remark, operation, approveContent, approveUserRealName, "", companyProduct.Status)
  934. }
  935. //新增客户产品日志
  936. {
  937. logType := "modify"
  938. go services.AddCompanyProductLog(companyProduct, this.SysUser.AdminId, logType)
  939. }
  940. }
  941. //新增申请单
  942. err = company_apply.Apply(companyApprovalId, "试用转正式申请单")
  943. if err != nil {
  944. br.Msg = "发起审批异常,请联系管理员"
  945. br.ErrMsg = "客户审批发起异常,Err:" + err.Error()
  946. return
  947. }
  948. br.Ret = 200
  949. br.Success = true
  950. br.Msg = "申请成功"
  951. }
  952. // ApplyBySystemContract
  953. // @Title 通过系统合同申请转正/服务更新
  954. // @Description 通过系统合同申请转正/服务更新接口
  955. // @Param request body company.CompanyApplyBySystemContractReq true "type json string"
  956. // @Success Ret=200 申请成功
  957. // @router /apply/systemContract [post]
  958. func (this *CompanyApplyController) ApplyBySystemContract() {
  959. br := new(models.BaseResponse).Init()
  960. defer func() {
  961. this.Data["json"] = br
  962. this.ServeJSON()
  963. }()
  964. sysUser := this.SysUser
  965. if sysUser == nil {
  966. br.Msg = "请登录"
  967. br.ErrMsg = "请登录,SysUser Is Empty"
  968. br.Ret = 408
  969. return
  970. }
  971. var req company.CompanyApplyBySystemContractReq
  972. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  973. if err != nil {
  974. br.Msg = "参数解析异常!"
  975. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  976. return
  977. }
  978. if req.CompanyId <= 0 {
  979. br.Msg = "参数错误"
  980. br.ErrMsg = "参数错误,客户id小于等于0"
  981. return
  982. }
  983. //获取客户信息
  984. companyInfo, err := company.GetCompanyById(req.CompanyId)
  985. if err != nil {
  986. br.Msg = "获取客户信息失败"
  987. br.ErrMsg = "获取客户信息失败"
  988. return
  989. }
  990. roleTypeCode := sysUser.RoleTypeCode
  991. productId := services.GetProductId(roleTypeCode)
  992. if productId == 0 {
  993. br.Msg = "参数错误"
  994. br.ErrMsg = "客户类型为:" + roleTypeCode
  995. return
  996. }
  997. //添加缓存,避免多次点击提交
  998. {
  999. deleteCache := true
  1000. cacheKey := "CACHE_COMPANY_APPLY_" + strconv.Itoa(req.CompanyId) + "_" + strconv.Itoa(productId)
  1001. defer func() {
  1002. if deleteCache {
  1003. utils.Rc.Delete(cacheKey)
  1004. }
  1005. }()
  1006. if !utils.Rc.SetNX(cacheKey, 1, 30*time.Second) {
  1007. deleteCache = false
  1008. br.Msg = "系统处理中,请勿重复操作"
  1009. br.ErrMsg = "系统处理中,请勿重复操作" + sysUser.RealName + ";data:" + string(this.Ctx.Input.RequestBody)
  1010. return
  1011. }
  1012. }
  1013. companyProduct, err := company.GetCompanyProductByCompanyIdAndProductId(req.CompanyId, productId)
  1014. if err != nil {
  1015. br.Msg = "获取客户信息失败"
  1016. br.ErrMsg = "获取客户信息失败"
  1017. return
  1018. }
  1019. if companyProduct == nil {
  1020. br.Msg = "获取客户信息失败"
  1021. br.ErrMsg = "客户不存在,不可提交审批:companyId:" + strconv.Itoa(req.CompanyId) + ";productId:" + strconv.Itoa(productId)
  1022. return
  1023. }
  1024. if companyProduct.SellerId != sysUser.AdminId && companyProduct.ShareSellerId != sysUser.AdminId {
  1025. br.Msg = "客户信息异常"
  1026. br.ErrMsg = "客户信息异常,不是当前所属销售,客户所属销售:" + companyProduct.SellerName + ";当前销售:" + sysUser.AdminName
  1027. return
  1028. }
  1029. if companyProduct.ApproveStatus == "待审批" {
  1030. br.Msg = "存在待审批订单,不可重复提交"
  1031. return
  1032. }
  1033. var approveUserId int
  1034. var approveUserRealName string
  1035. approveRoleTypeCode := ""
  1036. if productId == 1 {
  1037. approveRoleTypeCode = utils.ROLE_TYPE_CODE_FICC_ADMIN
  1038. } else {
  1039. approveRoleTypeCode = utils.ROLE_TYPE_CODE_RAI_ADMIN
  1040. }
  1041. approveUser, err := company.GetApproveUser(approveRoleTypeCode)
  1042. if err != nil && err.Error() != utils.ErrNoRow() {
  1043. br.Msg = "获取审批信息失败"
  1044. br.ErrMsg = "获取审批人信息失败,Err:" + err.Error()
  1045. return
  1046. }
  1047. if approveUser == nil || (err != nil && err.Error() == utils.ErrNoRow()) {
  1048. br.Msg = "审批用户不存在"
  1049. br.ErrMsg = "审批用户不存在"
  1050. return
  1051. }
  1052. //获取合同详情
  1053. contractDetail, err := contractService.GetContractDetail(req.ContractId)
  1054. if err != nil {
  1055. br.Msg = "查询合同异常"
  1056. br.ErrMsg = fmt.Sprint("查询合同异常,合同id:", req.ContractId, ";Err:", err.Error())
  1057. return
  1058. }
  1059. if contractDetail.ContractBusinessType != "业务合同" {
  1060. br.Msg = "合同类型异常"
  1061. br.ErrMsg = "合同类型异常,当前合同类型为:" + contractDetail.ContractBusinessType
  1062. return
  1063. }
  1064. //判断产品类型是否一致
  1065. if productId != contractDetail.ProductId {
  1066. br.Msg = "合同产品类型异常"
  1067. br.ErrMsg = fmt.Sprint("合同产品类型异常,合同产品类型Id:", contractDetail.ProductId)
  1068. return
  1069. }
  1070. //判断销售归属
  1071. if contractDetail.SellerId != sysUser.AdminId {
  1072. br.Msg = "合同异常"
  1073. br.ErrMsg = fmt.Sprint("合同归属人异常,合同申请人Id:", contractDetail.SellerId, ";当前账号:", sysUser.AdminId)
  1074. return
  1075. }
  1076. //判断合同是否该客户的(组织社会信用代码是否一致)
  1077. if contractDetail.CreditCode != companyInfo.CreditCode {
  1078. br.Msg = "合同异常,请选择社会信用码一致的合同"
  1079. br.ErrMsg = fmt.Sprint("该合同组织社会信用码与客户不符,合同的社会信用码:", contractDetail.CreditCode, ";客户的社会信用码:", companyInfo.CreditCode)
  1080. return
  1081. }
  1082. if contractDetail.Status != "已签回" {
  1083. br.Msg = "合同状态异常"
  1084. br.ErrMsg = fmt.Sprint("合同状态异常,合同状态:", contractDetail.Status)
  1085. return
  1086. }
  1087. //当前客户需要的合同状态
  1088. needContractType, err := services.GetApplyTurnContractType(req.CompanyId, productId)
  1089. if err != nil {
  1090. br.Msg = "获取失败"
  1091. br.ErrMsg = "获取合同类型失败,Err:" + err.Error()
  1092. return
  1093. }
  1094. //判断 系统需要的合同类型 与 实际提交的合同类型是否一致,如果不一致,那么不支持
  1095. if needContractType != "新签合同" && contractDetail.ContractType == "新签合同" {
  1096. br.Msg = "申请失败,该客户曾经开通过正式服务,不允许签署新签合同"
  1097. br.ErrMsg = "申请失败,该客户曾经开通过正式服务,不允许签署新签合同"
  1098. return
  1099. }
  1100. if contractDetail.ContractType == "新签合同" {
  1101. if companyProduct.Status != utils.COMPANY_STATUS_TRY_OUT {
  1102. br.Msg = "客户状态为:" + companyProduct.Status + ";不可进行转正申请"
  1103. br.ErrMsg = "客户状态为:" + companyProduct.Status + ";不可进行转正申请"
  1104. return
  1105. }
  1106. } else {
  1107. if companyProduct.Status != utils.COMPANY_STATUS_FORMAL && companyProduct.Status != utils.COMPANY_STATUS_TRY_OUT {
  1108. br.Msg = "客户状态为:" + companyProduct.Status + ";不可进行服务更新申请"
  1109. br.ErrMsg = "客户状态为:" + companyProduct.Status + ";不可进行服务更新申请"
  1110. return
  1111. }
  1112. }
  1113. //合同类型
  1114. contractType := contractDetail.ContractType
  1115. var hasContract bool //是否已经存在合同,如果存在,那么就不能是新签合同
  1116. var condition string
  1117. var pars []interface{}
  1118. condition += " AND product_id = ?"
  1119. pars = append(pars, productId)
  1120. condition += " AND status = ?"
  1121. pars = append(pars, 1)
  1122. list, err := company.GetCompanyContractListByCompanyId(req.CompanyId, condition, pars)
  1123. if err != nil {
  1124. br.Msg = "获取合同信息失败"
  1125. br.ErrMsg = "获取合同信息失败,Err:" + err.Error()
  1126. return
  1127. }
  1128. if len(list) > 0 {
  1129. hasContract = true
  1130. }
  1131. //查询是否存在正式转试用的记录,如果存在,那么合同类型是续约合同
  1132. total, err := company.GetCompanyProductOperationRecordCount(companyProduct.CompanyId, companyProduct.ProductId)
  1133. if err != nil {
  1134. br.Msg = "查询用户信息异常"
  1135. br.ErrMsg = "查询用户变更记录异常"
  1136. return
  1137. }
  1138. if total > 0 {
  1139. hasContract = true
  1140. }
  1141. if hasContract && contractType == "新签合同" {
  1142. br.Msg = "客户已存在老合同,不允许签署新签合同"
  1143. br.ErrMsg = "客户已存在老合同,不允许签署新签合同"
  1144. return
  1145. }
  1146. //合同类型 end
  1147. //获取权限id列表
  1148. permissionMap, err := contractService.GetServicePermissionMap(contractDetail.Service)
  1149. permissionArr := make([]int, 0)
  1150. for _, permissionId := range permissionMap {
  1151. permissionArr = append(permissionArr, permissionId)
  1152. }
  1153. //对权限排序
  1154. sort.Ints(permissionArr)
  1155. // CRM8.8-权益主客观此处拆分成了三级套餐, 根据contract_service写权限
  1156. // CRM8.8-如果是权益客户那么主观客观权限一起带上(暂弃)
  1157. //if companyProduct.ProductId == 2 {
  1158. // var permissionIds string
  1159. // var permissionNames string
  1160. // for _, v := range permissionArr {
  1161. // permissionIds += strconv.Itoa(v) + ","
  1162. // }
  1163. // permissionIds = strings.TrimRight(permissionIds, ",")
  1164. // listSandO, err := company.GetPermissionLookItemsSandO(permissionIds)
  1165. // if err != nil {
  1166. // br.Msg = "获取现有的合同权限信息失败"
  1167. // br.ErrMsg = "获取现有的合同权限ID信息失败,Err:" + err.Error()
  1168. // return
  1169. // }
  1170. // for _, v := range listSandO {
  1171. // permissionNames += "'" + v.PermissionName + "'" + ","
  1172. // }
  1173. // permissionNames = strings.TrimRight(permissionNames, ",")
  1174. // listPermissionByname, err := company.GetPermissionLookItemsSandOByName(permissionNames)
  1175. // if err != nil {
  1176. // br.Msg = "获取现有的合同权限信息失败"
  1177. // br.ErrMsg = "通过名称获取主观客观权限ID信息失败,Err:" + err.Error()
  1178. // return
  1179. // }
  1180. // permissionArr = make([]int, 0)
  1181. // for _, v := range listPermissionByname {
  1182. // permissionArr = append(permissionArr, v.ChartPermissionId)
  1183. // }
  1184. // //对权限排序
  1185. // sort.Ints(permissionArr)
  1186. //}
  1187. //当前已经存在的权限
  1188. currPermissionMap, err := services.GetLastContractPermissionList(companyProduct.CompanyId, companyProduct.ProductId)
  1189. if err != nil {
  1190. br.Msg = "获取现有的合同权限信息失败"
  1191. br.ErrMsg = "获取现有的合同权限信息失败,Err:" + err.Error()
  1192. return
  1193. }
  1194. //权限内日期判断校验
  1195. for _, permissionId := range permissionArr {
  1196. //研选服务不做校验
  1197. if permissionId == 31 {
  1198. continue
  1199. }
  1200. if currPermission, ok := currPermissionMap[permissionId]; ok {
  1201. currStartDate, _ := time.Parse(utils.FormatDate, currPermission.StartDate)
  1202. currEndDate, _ := time.Parse(utils.FormatDate, currPermission.EndDate)
  1203. if !(contractDetail.StartDate.After(currEndDate) || currStartDate.After(contractDetail.EndDate)) {
  1204. br.Msg = currPermission.PermissionName + "合同日期存在重复,不允许申请"
  1205. br.ErrMsg = "权限合同日期存在重复,不允许申请"
  1206. return
  1207. }
  1208. }
  1209. }
  1210. //获取客户产品套餐类型(大套餐、小套餐、无)
  1211. packageType, err := contractService.GetServicePackageType(contractDetail.Service)
  1212. raiPackageType := contractService.GetRaiServicePackageType(contractDetail.Service)
  1213. recordApproveContent := `试用转正式`
  1214. applyMethod := 1
  1215. approveContent := "试用转正式"
  1216. operationRemark := `申请转正`
  1217. operation := "turn_positive"
  1218. messageContent := "试用转正式申请单"
  1219. //申请类型:1:试用->正式,2:冻结—>试用,3:试用延期,4:原销售申请领取流失客户,5:正式客户申请服务更新,6:正式客户补充协议
  1220. if contractType != "新签合同" {
  1221. if contractType == "补充协议" {
  1222. applyMethod = 6 //补充协议
  1223. recordApproveContent = `正式客户新增补充协议`
  1224. approveContent = `新增补充协议`
  1225. operationRemark = `新增补充协议`
  1226. operation = "add_agreement"
  1227. messageContent = "补充协议申请单"
  1228. } else {
  1229. applyMethod = 5 //续约服务
  1230. recordApproveContent = `正式客户申请续约`
  1231. approveContent = `申请续约`
  1232. operationRemark = `申请续约`
  1233. operation = "service_update"
  1234. messageContent = "续约申请单"
  1235. }
  1236. }
  1237. var raicontractType string
  1238. if productId == 2 {
  1239. //权益的新签合同重新定义,如果合同起始时间在新签合同起始日期 1年之内的,仍为新签合同。
  1240. raicontractType = contractType
  1241. if raicontractType != "新签合同" {
  1242. //startDateTime := contractDetail.StartDate.AddDate(-1, 0, 0)
  1243. totalLastYear, err := contractService.GetCompanyContractCountRaiByLastYear(req.CompanyId, contractDetail.StartDate.Format(utils.FormatDate))
  1244. if err != nil {
  1245. br.Msg = "获取合同信息失败"
  1246. br.ErrMsg = "获取合同信息失败,Err:" + err.Error()
  1247. return
  1248. }
  1249. if totalLastYear > 0 {
  1250. raicontractType = "新签合同"
  1251. }
  1252. }
  1253. }
  1254. var companyApprovalId int
  1255. if req.CompanyApprovalId <= 0 {
  1256. //当前是否存在待审批的单子
  1257. nowCompanyApprovalInfo, err := company.GetCompanyApprovalById(req.CompanyId, productId)
  1258. if (err == nil || nowCompanyApprovalInfo != nil) || err != nil && err.Error() != utils.ErrNoRow() {
  1259. br.Msg = "此客户已存在待审批的申请单,请在申请单审批完成后重新提交"
  1260. br.ErrMsg = "此客户已存在待审批的申请单,请在申请单审批完成后重新提交"
  1261. return
  1262. }
  1263. ////当前待审批的合同,有且只能存在一条
  1264. //count, err := company.GetCompanyContractApproveCount(req.CompanyId, productId)
  1265. //if err != nil {
  1266. // br.Msg = "获取信息失败"
  1267. // br.ErrMsg = "判断是否已存在待审批合同失败,Err:" + err.Error()
  1268. // return
  1269. //}
  1270. //if count > 0 {
  1271. // br.Msg = "此客户已提交过申请,请在客户审批列表重新提交"
  1272. // return
  1273. //}
  1274. companyContract := &company.CompanyContract{
  1275. CompanyId: req.CompanyId,
  1276. ProductId: contractDetail.ProductId,
  1277. ContractType: contractType,
  1278. RaiContractType: raicontractType,
  1279. ProductName: companyProduct.ProductName,
  1280. CompanyProductId: companyProduct.CompanyProductId,
  1281. ContractCode: contractDetail.ContractCode,
  1282. StartDate: contractDetail.StartDate.Format(utils.FormatDate),
  1283. EndDate: contractDetail.EndDate.Format(utils.FormatDate),
  1284. Money: contractDetail.Price,
  1285. PayMethod: contractDetail.PayRemark,
  1286. PayChannel: contractDetail.PayChannel,
  1287. ImgUrl: contractDetail.CheckBackFileUrl,
  1288. Status: 0,
  1289. Source: "系统合同",
  1290. PackageType: packageType,
  1291. RaiPackageType: raiPackageType,
  1292. CreateTime: time.Now(),
  1293. ModifyTime: time.Now(),
  1294. SellerIdInit: companyProduct.SellerId,
  1295. SellerNameInit: companyProduct.SellerName,
  1296. ShareSellerInit: companyProduct.ShareSeller,
  1297. ShareSellerIdInit: companyProduct.ShareSellerId,
  1298. SellerIdLast: companyProduct.SellerId,
  1299. SellerNameLast: companyProduct.SellerName,
  1300. ShareSellerLast: companyProduct.ShareSeller,
  1301. ShareSellerIdLast: companyProduct.ShareSellerId,
  1302. }
  1303. newId, err := company.AddCompanyContract(companyContract)
  1304. if err != nil {
  1305. br.Msg = "新增合同失败"
  1306. br.ErrMsg = "新增合同失败,Err:" + err.Error()
  1307. return
  1308. }
  1309. go services.UpdateCompanyContractInheritEndDate(int(newId))
  1310. upgradeMap := make(map[int]int)
  1311. if utils.RunMode == "release" {
  1312. upgradeMap = map[int]int{22: 39, 21: 38, 20: 37, 19: 36}
  1313. } else {
  1314. upgradeMap = map[int]int{22: 37, 21: 36, 20: 35, 19: 34}
  1315. }
  1316. for _, chartPermissionId := range permissionArr {
  1317. if chartPermissionId < utils.PERMISSION_ID_UPGRADE {
  1318. item := new(company.CompanyContractPermission)
  1319. item.CompanyId = req.CompanyId
  1320. item.CompanyContractId = int(newId)
  1321. item.ChartPermissionId = chartPermissionId
  1322. item.StartDate = contractDetail.StartDate.Format(utils.FormatDate)
  1323. item.EndDate = contractDetail.EndDate.Format(utils.FormatDate)
  1324. item.ModifyTime = time.Now()
  1325. item.CreateTime = time.Now()
  1326. err = company.AddCompanyContractPermission(item)
  1327. if err != nil {
  1328. br.Msg = "新增合同失败"
  1329. br.ErrMsg = "新增合同权限失败,Err:" + err.Error()
  1330. return
  1331. }
  1332. //新增日志
  1333. {
  1334. itemLog := new(company.CompanyContractPermissionLog)
  1335. itemLog.CompanyId = req.CompanyId
  1336. itemLog.CompanyContractId = int(newId)
  1337. itemLog.ChartPermissionId = strconv.Itoa(chartPermissionId)
  1338. itemLog.StartDate = contractDetail.StartDate.Format(utils.FormatDate)
  1339. itemLog.EndDate = contractDetail.EndDate.Format(utils.FormatDate)
  1340. itemLog.ModifyTime = time.Now()
  1341. itemLog.CreateTime = time.Now()
  1342. itemLog.LogCreateTime = time.Now()
  1343. go company.AddCompanyContractPermissionLog(itemLog)
  1344. }
  1345. } else {
  1346. // 升级套餐,手动补充主客观套餐
  1347. chartPermissionId -= utils.PERMISSION_ID_UPGRADE
  1348. item := new(company.CompanyContractPermission)
  1349. item.CompanyId = req.CompanyId
  1350. item.CompanyContractId = int(newId)
  1351. item.ChartPermissionId = chartPermissionId
  1352. item.IsUpgrade = 1
  1353. item.StartDate = contractDetail.StartDate.Format(utils.FormatDate)
  1354. item.EndDate = contractDetail.EndDate.Format(utils.FormatDate)
  1355. item.ModifyTime = time.Now()
  1356. item.CreateTime = time.Now()
  1357. err = company.AddCompanyContractPermission(item)
  1358. if err != nil {
  1359. br.Msg = "新增合同失败"
  1360. br.ErrMsg = "新增合同权限失败,Err:" + err.Error()
  1361. return
  1362. }
  1363. //新增日志
  1364. {
  1365. itemLog := new(company.CompanyContractPermissionLog)
  1366. itemLog.CompanyId = req.CompanyId
  1367. itemLog.CompanyContractId = int(newId)
  1368. itemLog.ChartPermissionId = strconv.Itoa(chartPermissionId)
  1369. itemLog.StartDate = contractDetail.StartDate.Format(utils.FormatDate)
  1370. itemLog.EndDate = contractDetail.EndDate.Format(utils.FormatDate)
  1371. itemLog.ModifyTime = time.Now()
  1372. itemLog.CreateTime = time.Now()
  1373. itemLog.LogCreateTime = time.Now()
  1374. go company.AddCompanyContractPermissionLog(itemLog)
  1375. }
  1376. // 客观
  1377. upgradeChartPermissionId := upgradeMap[chartPermissionId]
  1378. upItem := new(company.CompanyContractPermission)
  1379. upItem.CompanyId = req.CompanyId
  1380. upItem.CompanyContractId = int(newId)
  1381. upItem.ChartPermissionId = upgradeChartPermissionId
  1382. upItem.IsUpgrade = 1
  1383. upItem.StartDate = contractDetail.StartDate.Format(utils.FormatDate)
  1384. upItem.EndDate = contractDetail.EndDate.Format(utils.FormatDate)
  1385. upItem.ModifyTime = time.Now()
  1386. upItem.CreateTime = time.Now()
  1387. err = company.AddCompanyContractPermission(upItem)
  1388. if err != nil {
  1389. br.Msg = "新增合同失败"
  1390. br.ErrMsg = "新增合同权限失败,Err:" + err.Error()
  1391. return
  1392. }
  1393. //新增日志
  1394. {
  1395. itemLog := new(company.CompanyContractPermissionLog)
  1396. itemLog.CompanyId = req.CompanyId
  1397. itemLog.CompanyContractId = int(newId)
  1398. itemLog.ChartPermissionId = strconv.Itoa(upgradeChartPermissionId)
  1399. itemLog.StartDate = contractDetail.StartDate.Format(utils.FormatDate)
  1400. itemLog.EndDate = contractDetail.EndDate.Format(utils.FormatDate)
  1401. itemLog.ModifyTime = time.Now()
  1402. itemLog.CreateTime = time.Now()
  1403. itemLog.LogCreateTime = time.Now()
  1404. go company.AddCompanyContractPermissionLog(itemLog)
  1405. }
  1406. }
  1407. }
  1408. approval := new(company.CompanyApproval)
  1409. approval.CompanyId = req.CompanyId
  1410. approval.ProductId = productId
  1411. approval.ApproveStatus = "待审批"
  1412. approval.ApproveUserId = 0
  1413. approval.ApproveRoleTypeCode = approveRoleTypeCode
  1414. approval.ApproveRealName = ""
  1415. approval.ApproveTime = time.Now()
  1416. approval.ApproveContent = approveContent
  1417. approval.ApplyMethod = applyMethod
  1418. approval.ApplyReasons = ""
  1419. approval.ApplyUserId = sysUser.AdminId
  1420. approval.ApplyRealName = sysUser.RealName
  1421. approval.CreateTime = time.Now()
  1422. approval.ModifyTime = time.Now()
  1423. approval.CompanyContractId = int(newId)
  1424. approval.IsFormal = companyProduct.IsFormal
  1425. companyApprovalId, err = company.AddCompanyApproval(approval)
  1426. if err != nil {
  1427. br.Msg = "申请失败"
  1428. br.ErrMsg = "申请失败,Err:" + err.Error()
  1429. return
  1430. }
  1431. } else {
  1432. recode, err := company.GetCompanyApprovalByApprovalId(req.CompanyApprovalId)
  1433. if err != nil {
  1434. br.Msg = "申请失败"
  1435. br.ErrMsg = "获取审批记录失败,Err:" + err.Error()
  1436. return
  1437. }
  1438. err = company.ModifyCompanyTurnPositiveBySystemContract(contractDetail, permissionArr, req.CompanyId, productId, req.CompanyApprovalId, recode.CompanyContractId, companyProduct.IsFormal, packageType, raiPackageType)
  1439. if err != nil {
  1440. br.Msg = "申请失败"
  1441. br.ErrMsg = "申请失败,Err:" + err.Error()
  1442. return
  1443. }
  1444. companyApprovalId = req.CompanyApprovalId
  1445. }
  1446. //新增操作记录
  1447. {
  1448. services.AddCompanyOperationRecord(req.CompanyId, companyProduct.SellerId, sysUser.AdminId, productId, approveUserId, companyProduct.CompanyName,
  1449. companyProduct.ProductName, sysUser.RealName, operationRemark, operation, recordApproveContent, approveUserRealName, "", companyProduct.Status)
  1450. }
  1451. //新增客户产品日志
  1452. {
  1453. logType := "modify"
  1454. go services.AddCompanyProductLog(companyProduct, this.SysUser.AdminId, logType)
  1455. }
  1456. err = company_apply.Apply(companyApprovalId, messageContent)
  1457. if err != nil {
  1458. br.Msg = "发起审批异常,请联系管理员"
  1459. br.ErrMsg = "客户审批发起异常,Err:" + err.Error()
  1460. return
  1461. }
  1462. //待办通知
  1463. //{
  1464. // for _, v := range approveUser {
  1465. // approveUserId = v.AdminId
  1466. // approveUserRealName = v.RealName
  1467. // mobile := v.Mobile
  1468. // err = services.AddCompanyApprovalMessage(sysUser.AdminId, approveUserId, req.CompanyId, companyApprovalId, 1, 1, 1, companyProduct.CompanyName, messageContent, messageContent, mobile)
  1469. // if err != nil {
  1470. // br.Msg = "申请失败"
  1471. // br.ErrMsg = "新增待办通知失败,Err:" + err.Error()
  1472. // return
  1473. // }
  1474. // }
  1475. //}
  1476. br.Ret = 200
  1477. br.Success = true
  1478. br.Msg = "申请成功"
  1479. }
  1480. // ApplyThaw
  1481. // @Title 申请解冻
  1482. // @Description 申请解冻接口
  1483. // @Param request body company.CompanyApplyThawReq true "type json string"
  1484. // @Success Ret=200 申请成功
  1485. // @router /apply/thaw [post]
  1486. func (this *CompanyApplyController) ApplyThaw() {
  1487. br := new(models.BaseResponse).Init()
  1488. defer func() {
  1489. this.Data["json"] = br
  1490. this.ServeJSON()
  1491. }()
  1492. sysUser := this.SysUser
  1493. if sysUser == nil {
  1494. br.Msg = "请登录"
  1495. br.ErrMsg = "请登录,SysUser Is Empty"
  1496. br.Ret = 408
  1497. return
  1498. }
  1499. var req company.CompanyApplyThawReq
  1500. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  1501. if err != nil {
  1502. br.Msg = "参数解析异常!"
  1503. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  1504. return
  1505. }
  1506. if req.CompanyId <= 0 {
  1507. br.Msg = "参数错误"
  1508. br.ErrMsg = "参数错误,客户id小于等于0"
  1509. return
  1510. }
  1511. roleTypeCode := sysUser.RoleTypeCode
  1512. productId := services.GetProductId(roleTypeCode)
  1513. if productId == 0 {
  1514. br.Msg = "参数错误"
  1515. br.ErrMsg = "客户类型为:" + roleTypeCode
  1516. return
  1517. }
  1518. if productId == utils.COMPANY_PRODUCT_FICC_ID && req.PermissionIds == "" {
  1519. br.Msg = "请勾选需要解冻的品种"
  1520. br.ErrMsg = "请勾选需要解冻的品种"
  1521. return
  1522. }
  1523. // 查询当前销售是否有重新申请的权限
  1524. receiveEnabled, _ := services.CheckCompanyReceiveButton(sysUser.AdminId)
  1525. if !receiveEnabled {
  1526. br.Msg = "无权申请"
  1527. br.ErrMsg = "无权申请"
  1528. return
  1529. }
  1530. //添加缓存,避免多次点击提交
  1531. {
  1532. deleteCache := true
  1533. cacheKey := "CACHE_COMPANY_APPLY_" + strconv.Itoa(req.CompanyId) + "_" + strconv.Itoa(productId)
  1534. defer func() {
  1535. if deleteCache {
  1536. utils.Rc.Delete(cacheKey)
  1537. }
  1538. }()
  1539. if !utils.Rc.SetNX(cacheKey, 1, 30*time.Second) {
  1540. deleteCache = false
  1541. br.Msg = "系统处理中,请勿重复操作"
  1542. br.ErrMsg = "系统处理中,请勿重复操作" + sysUser.RealName + ";data:" + string(this.Ctx.Input.RequestBody)
  1543. return
  1544. }
  1545. }
  1546. var companyApprovalCount int //某一客户申请的次数
  1547. approveRoleTypeCode := ""
  1548. if productId == 1 {
  1549. approveRoleTypeCode = utils.ROLE_TYPE_CODE_FICC_ADMIN
  1550. } else {
  1551. approveRoleTypeCode = utils.ROLE_TYPE_CODE_RAI_ADMIN
  1552. companyApprovalCount, err = company.GetCompanyApprovalCount(req.CompanyId, productId, 2)
  1553. if err != nil {
  1554. br.Msg = "获取客户信息失败"
  1555. br.ErrMsg = "获取客户申请的次数失败,Err:" + err.Error()
  1556. return
  1557. }
  1558. permissionArr := strings.Split(req.PermissionIds, ",")
  1559. //如果所选行业不属于研选订阅跟研选扣点包,那就是非研选试用客户
  1560. var isNoResearch bool
  1561. for _, v := range permissionArr {
  1562. if v != strconv.Itoa(utils.CHART_PERMISSION_ID_YANXUAN) && v != strconv.Itoa(utils.YAN_XUAN_KOU_DIAN_BAO_ID) {
  1563. isNoResearch = true
  1564. continue
  1565. }
  1566. }
  1567. if isNoResearch {
  1568. tryOutCountRai, err := company.GetRaiCompanyTryOutCountNoResearch(sysUser.AdminId)
  1569. if err != nil {
  1570. br.Msg = "判断试用客户量失败"
  1571. br.ErrMsg = "判断试用客户量失败,Err:" + err.Error()
  1572. return
  1573. }
  1574. if tryOutCountRai >= utils.COMPANY_STATUS_TRY_OUT_COUNT_RAI {
  1575. br.Msg = "非研选试用客户最多40家"
  1576. return
  1577. }
  1578. }
  1579. }
  1580. companyProduct, err := company.GetCompanyProductByCompanyIdAndProductId(req.CompanyId, productId)
  1581. if err != nil {
  1582. br.Msg = "获取客户信息失败"
  1583. br.ErrMsg = "获取客户信息失败"
  1584. return
  1585. }
  1586. if companyProduct == nil {
  1587. br.Msg = "获取客户信息失败"
  1588. br.ErrMsg = "客户不存在,不可提交审批:companyId:" + strconv.Itoa(req.CompanyId) + ";productId:" + strconv.Itoa(productId)
  1589. return
  1590. }
  1591. if companyProduct.Status != utils.COMPANY_STATUS_FREEZE {
  1592. br.Msg = "客户状态为:" + companyProduct.Status + ";不可进行解冻申请"
  1593. br.ErrMsg = "客户状态为:" + companyProduct.Status + ";不可进行解冻申请"
  1594. return
  1595. }
  1596. if companyProduct.ApproveStatus == utils.COMPANY_APPROVE_STATUS {
  1597. br.Msg = "存在待审批订单,不可重复提交"
  1598. return
  1599. }
  1600. //客户归属判断
  1601. if companyProduct.SellerId != sysUser.AdminId && companyProduct.ShareSellerId != sysUser.AdminId {
  1602. br.Msg = "客户信息异常"
  1603. br.ErrMsg = "客户信息异常,不是当前所属销售,客户所属销售:" + companyProduct.SellerName + ";当前销售:" + sysUser.AdminName
  1604. return
  1605. }
  1606. // CRM8.8(仅针对权益客户)-此处同申请试用的逻辑
  1607. if companyProduct.ProductId == utils.COMPANY_PRODUCT_RAI_ID {
  1608. reportPermissions, e := company.GetCompanyReportPermission(req.CompanyId, utils.COMPANY_PRODUCT_RAI_ID)
  1609. if e != nil {
  1610. br.Msg = "客户权限信息异常"
  1611. br.ErrMsg = "客户权限信息异常, Err: " + e.Error()
  1612. return
  1613. }
  1614. reportPermissionArr := make([]string, 0)
  1615. for i := range reportPermissions {
  1616. reportPermissionArr = append(reportPermissionArr, strconv.Itoa(reportPermissions[i].ChartPermissionId))
  1617. }
  1618. if len(reportPermissionArr) > 0 {
  1619. req.PermissionIds = strings.Join(reportPermissionArr, ",")
  1620. }
  1621. }
  1622. approveUser, err := company.GetApproveUser(approveRoleTypeCode)
  1623. if err != nil && err.Error() != utils.ErrNoRow() {
  1624. br.Msg = "获取审批信息失败"
  1625. br.ErrMsg = "获取审批人信息失败,Err:" + err.Error()
  1626. return
  1627. }
  1628. if approveUser == nil || (err != nil && err.Error() == utils.ErrNoRow()) {
  1629. br.Msg = "审批用户不存在"
  1630. br.ErrMsg = "审批用户不存在"
  1631. return
  1632. }
  1633. //申请类型:1:试用->正式,2:冻结—>试用,3:试用延期,4:原销售申请领取流失客户,5:正式客户申请服务更新,6:正式客户补充协议
  1634. approveContent := `冻结转试用`
  1635. var companyApprovalId int
  1636. if req.CompanyApprovalId <= 0 {
  1637. applyMethod := 2
  1638. approval := new(company.CompanyApproval)
  1639. approval.CompanyId = req.CompanyId
  1640. approval.ProductId = productId
  1641. approval.ApproveStatus = "待审批"
  1642. approval.ApproveUserId = 0
  1643. approval.ApproveRoleTypeCode = approveRoleTypeCode
  1644. approval.ApproveRealName = ""
  1645. approval.ApproveTime = time.Now()
  1646. approval.ApproveContent = approveContent
  1647. approval.ApplyMethod = applyMethod
  1648. approval.ApplyReasons = req.ApplyRemark
  1649. approval.ApplyUserId = sysUser.AdminId
  1650. approval.ApplyRealName = sysUser.RealName
  1651. approval.CreateTime = time.Now()
  1652. approval.ModifyTime = time.Now()
  1653. companyApprovalId, err = company.AddCompanyApproval(approval)
  1654. if err != nil {
  1655. br.Msg = "申请失败"
  1656. br.ErrMsg = "申请失败,Err:" + err.Error()
  1657. return
  1658. }
  1659. } else {
  1660. err = company.ModifyCompanyApproval(req.CompanyId, productId, req.CompanyApprovalId, approveContent, req.ApplyRemark)
  1661. if err != nil {
  1662. br.Msg = "申请失败"
  1663. br.ErrMsg = "申请失败,Err:" + err.Error()
  1664. return
  1665. }
  1666. companyApprovalId = req.CompanyApprovalId
  1667. //先删除之前申请的权限
  1668. _ = company.DeleteCompanyDelayPermission(req.CompanyApprovalId)
  1669. }
  1670. //处理权限
  1671. {
  1672. if req.PermissionIds != "" {
  1673. // CRM8.8(仅针对权益客户)-此处不再去查询主观对应的客观, 而是根据客户之前拥有的权限来操作
  1674. //permissionStr, err := company.GetPermissionIdById(req.PermissionIds)
  1675. //if err != nil {
  1676. // br.Msg = "获取信息失败"
  1677. // br.ErrMsg = "获取主观客观权限信息失败,Err:" + err.Error()
  1678. // return
  1679. //}
  1680. //req.PermissionIds = permissionStr
  1681. permissionArr := strings.Split(req.PermissionIds, ",")
  1682. for _, v := range permissionArr {
  1683. //fmt.Println(k, v)
  1684. //新增
  1685. if v != "" {
  1686. permissionId, err := strconv.Atoi(v)
  1687. if err != nil {
  1688. br.Msg = "申请失败"
  1689. br.ErrMsg = "权限格式转换失败,Err:" + err.Error()
  1690. return
  1691. }
  1692. delayItem := new(company.CompanyDelayPermission)
  1693. delayItem.CompanyId = req.CompanyId
  1694. delayItem.CompanyApplyId = companyApprovalId
  1695. delayItem.ChartPermissionId = permissionId
  1696. delayItem.StartDate = time.Now().Format(utils.FormatDate)
  1697. if productId == utils.COMPANY_PRODUCT_RAI_ID { // 权益客户试用期改为1个月。 需求池 1035
  1698. delayItem.EndDate = time.Now().AddDate(0, 1, 0).Format(utils.FormatDate)
  1699. } else {
  1700. delayItem.EndDate = time.Now().AddDate(0, 2, 0).Format(utils.FormatDate)
  1701. }
  1702. delayItem.CreateTime = time.Now()
  1703. delayItem.ModifyTime = time.Now()
  1704. err = company.AddCompanyDelayPermission(delayItem)
  1705. if err != nil {
  1706. br.Msg = "申请失败"
  1707. br.ErrMsg = "新增冻结转试用审批权限失败,Err:" + err.Error()
  1708. return
  1709. }
  1710. }
  1711. }
  1712. }
  1713. }
  1714. //新增操作记录
  1715. {
  1716. remark := "申请解冻"
  1717. operation := "thaw"
  1718. services.AddCompanyOperationRecord(req.CompanyId, companyProduct.SellerId, sysUser.AdminId, productId, 0, companyProduct.CompanyName,
  1719. companyProduct.ProductName, sysUser.RealName, remark, operation, approveContent, "", "", companyProduct.Status)
  1720. }
  1721. //新增客户产品日志
  1722. {
  1723. logType := "modify"
  1724. go services.AddCompanyProductLog(companyProduct, this.SysUser.AdminId, logType)
  1725. }
  1726. err = company_apply.Apply(companyApprovalId, "冻结转试用申请单")
  1727. if err != nil {
  1728. br.Msg = "发起审批异常,请联系管理员"
  1729. br.ErrMsg = "客户审批发起异常,Err:" + err.Error()
  1730. return
  1731. }
  1732. if companyApprovalCount == 0 && productId == 2 {
  1733. //获取王芳信息,自动审批使用
  1734. approvalUserInfo, err := system.CheckSysUserByName("王芳", utils.ROLE_TYPE_CODE_RAI_ADMIN)
  1735. if err != nil {
  1736. br.Msg = "权益客户自动审批失败,请联系管理员"
  1737. br.ErrMsg = "审批失败,Err:" + err.Error()
  1738. return
  1739. }
  1740. //数据校验(校验是否具有审批权限)
  1741. _, _, approvalRecord, err := company_apply.CheckApproveAuth(req.CompanyId, productId, approvalUserInfo)
  1742. if err != nil {
  1743. br.Msg = "权益客户自动审批失败,请联系管理员"
  1744. br.ErrMsg = "校验是否具有审批权限失败,Err:" + err.Error()
  1745. return
  1746. }
  1747. err = company_apply.Approved(approvalRecord, approvalUserInfo, "权益客首次申请解冻自动审批通过")
  1748. if err != nil {
  1749. br.Msg = "权益客户自动审批失败,请联系管理员!"
  1750. br.ErrMsg = "审核失败,Err:" + err.Error()
  1751. return
  1752. }
  1753. }
  1754. br.Ret = 200
  1755. br.Success = true
  1756. br.Msg = "申请成功"
  1757. }
  1758. // ApplyDelay
  1759. // @Title 申请延期
  1760. // @Description 申请延期接口
  1761. // @Param request body company.CompanyApplyDelayReq true "type json string"
  1762. // @Success Ret=200 申请成功
  1763. // @router /apply/delay [post]
  1764. func (this *CompanyApplyController) ApplyDelay() {
  1765. br := new(models.BaseResponse).Init()
  1766. defer func() {
  1767. this.Data["json"] = br
  1768. this.ServeJSON()
  1769. }()
  1770. sysUser := this.SysUser
  1771. if sysUser == nil {
  1772. br.Msg = "请登录"
  1773. br.ErrMsg = "请登录,SysUser Is Empty"
  1774. br.Ret = 408
  1775. return
  1776. }
  1777. var req company.CompanyApplyDelayReq
  1778. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  1779. if err != nil {
  1780. br.Msg = "参数解析异常!"
  1781. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  1782. return
  1783. }
  1784. if req.CompanyId <= 0 {
  1785. br.Msg = "参数错误"
  1786. br.ErrMsg = "参数错误,客户id小于等于0"
  1787. return
  1788. }
  1789. roleTypeCode := sysUser.RoleTypeCode
  1790. productId := services.GetProductId(roleTypeCode)
  1791. if productId == 0 {
  1792. br.Msg = "参数错误"
  1793. br.ErrMsg = "客户类型为:" + roleTypeCode
  1794. return
  1795. }
  1796. if productId == utils.COMPANY_PRODUCT_FICC_ID && req.PermissionIds == "" {
  1797. br.Msg = "请勾选需要延期的品种"
  1798. br.ErrMsg = "请勾选需要延期的品种"
  1799. return
  1800. }
  1801. //添加缓存,避免多次点击提交
  1802. {
  1803. deleteCache := true
  1804. cacheKey := "CACHE_COMPANY_APPLY_" + strconv.Itoa(req.CompanyId) + "_" + strconv.Itoa(productId)
  1805. defer func() {
  1806. if deleteCache {
  1807. utils.Rc.Delete(cacheKey)
  1808. }
  1809. }()
  1810. if !utils.Rc.SetNX(cacheKey, 1, 30*time.Second) {
  1811. deleteCache = false
  1812. br.Msg = "系统处理中,请勿重复操作"
  1813. br.ErrMsg = "系统处理中,请勿重复操作" + sysUser.RealName + ";data:" + string(this.Ctx.Input.RequestBody)
  1814. return
  1815. }
  1816. }
  1817. approveRoleTypeCode := ""
  1818. if productId == 1 {
  1819. approveRoleTypeCode = utils.ROLE_TYPE_CODE_FICC_ADMIN
  1820. } else {
  1821. approveRoleTypeCode = utils.ROLE_TYPE_CODE_RAI_ADMIN
  1822. }
  1823. companyProduct, err := company.GetCompanyProductByCompanyIdAndProductId(req.CompanyId, productId)
  1824. if err != nil {
  1825. br.Msg = "获取客户信息失败"
  1826. br.ErrMsg = "获取客户信息失败"
  1827. return
  1828. }
  1829. if companyProduct == nil {
  1830. br.Msg = "获取客户信息失败"
  1831. br.ErrMsg = "客户不存在,不可提交审批:companyId:" + strconv.Itoa(req.CompanyId) + ";productId:" + strconv.Itoa(productId)
  1832. return
  1833. }
  1834. if companyProduct.Status != utils.COMPANY_STATUS_TRY_OUT {
  1835. br.Msg = "客户状态为:" + companyProduct.Status + ";不可进行延期申请"
  1836. br.ErrMsg = "客户状态为:" + companyProduct.Status + ";不可进行延期申请"
  1837. return
  1838. }
  1839. if companyProduct.ApproveStatus == "待审批" {
  1840. br.Msg = "存在待审批订单,不可重复提交"
  1841. return
  1842. }
  1843. //客户归属判断
  1844. if companyProduct.SellerId != sysUser.AdminId && companyProduct.ShareSellerId != sysUser.AdminId {
  1845. br.Msg = "客户信息异常"
  1846. br.ErrMsg = "客户信息异常,不是当前所属销售,客户所属销售:" + companyProduct.SellerName + ";当前销售:" + sysUser.AdminName
  1847. return
  1848. }
  1849. // CRM8.8(仅针对权益客户)-申请延期的权限不再进行选择, 而是自动将所有的试用权限延期
  1850. if companyProduct.ProductId == utils.COMPANY_PRODUCT_RAI_ID {
  1851. reportPermissions, e := company.GetCompanyReportPermission(req.CompanyId, utils.COMPANY_PRODUCT_RAI_ID)
  1852. if e != nil {
  1853. br.Msg = "客户权限信息异常"
  1854. br.ErrMsg = "客户权限信息异常, Err: " + e.Error()
  1855. return
  1856. }
  1857. reportPermissionArr := make([]string, 0)
  1858. for i := range reportPermissions {
  1859. reportPermissionArr = append(reportPermissionArr, strconv.Itoa(reportPermissions[i].ChartPermissionId))
  1860. }
  1861. if len(reportPermissionArr) > 0 {
  1862. req.PermissionIds = strings.Join(reportPermissionArr, ",")
  1863. }
  1864. }
  1865. approveUser, err := company.GetApproveUser(approveRoleTypeCode)
  1866. if err != nil && err.Error() != utils.ErrNoRow() {
  1867. br.Msg = "获取审批信息失败"
  1868. br.ErrMsg = "获取审批人信息失败,Err:" + err.Error()
  1869. return
  1870. }
  1871. if approveUser == nil || (err != nil && err.Error() == utils.ErrNoRow()) {
  1872. br.Msg = "审批用户不存在"
  1873. br.ErrMsg = "审批用户不存在"
  1874. return
  1875. }
  1876. //申请类型:1:试用->正式,2:冻结—>试用,3:试用延期,4:原销售申请领取流失客户,5:正式客户申请服务更新,6:正式客户补充协议
  1877. approveContent := `试用延期`
  1878. var companyApprovalId int
  1879. utils.FileLog.Info("试用延期申请:%d", req.CompanyApprovalId)
  1880. if req.CompanyApprovalId > 0 {
  1881. utils.FileLog.Info("试用延期申请:%d", req.CompanyApprovalId)
  1882. err = company.ModifyCompanyApproval(req.CompanyId, productId, req.CompanyApprovalId, approveContent, req.ApplyRemark)
  1883. if err != nil {
  1884. br.Msg = "申请失败"
  1885. br.ErrMsg = "申请失败,Err:" + err.Error()
  1886. return
  1887. }
  1888. companyApprovalId = req.CompanyApprovalId
  1889. } else {
  1890. applyMethod := 3
  1891. approval := new(company.CompanyApproval)
  1892. approval.CompanyId = req.CompanyId
  1893. approval.ProductId = productId
  1894. approval.ApproveStatus = "待审批"
  1895. approval.ApproveUserId = 0
  1896. approval.ApproveRoleTypeCode = approveRoleTypeCode
  1897. approval.ApproveRealName = ""
  1898. approval.ApproveTime = time.Now()
  1899. approval.ApproveContent = "试用延期"
  1900. approval.ApplyMethod = applyMethod
  1901. approval.ApplyReasons = req.ApplyRemark
  1902. approval.ApplyUserId = sysUser.AdminId
  1903. approval.ApplyRealName = sysUser.RealName
  1904. approval.CreateTime = time.Now()
  1905. approval.ModifyTime = time.Now()
  1906. companyApprovalId, err = company.AddCompanyApproval(approval)
  1907. if err != nil {
  1908. br.Msg = "申请失败"
  1909. br.ErrMsg = "申请失败,Err:" + err.Error()
  1910. return
  1911. }
  1912. }
  1913. //处理权限
  1914. {
  1915. if req.PermissionIds != "" {
  1916. // CRM8.8(仅针对权益客户)-此处不再去查询主观对应的客观, 而是根据客户之前拥有的权限来操作
  1917. //permissionStr, err := company.GetPermissionIdById(req.PermissionIds)
  1918. //if err != nil {
  1919. // br.Msg = "获取信息失败"
  1920. // br.ErrMsg = "获取主观客观权限信息失败,Err:" + err.Error()
  1921. // return
  1922. //}
  1923. //req.PermissionIds = permissionStr
  1924. permissionArr := strings.Split(req.PermissionIds, ",")
  1925. //如果是编辑的话,删除原先相关的所有品种权限
  1926. if req.CompanyApprovalId > 0 {
  1927. err = company.DeleteCompanyDelayPermission(req.CompanyApprovalId)
  1928. if err != nil {
  1929. br.Msg = "申请失败"
  1930. br.ErrMsg = "删除之前的申请记录失败,Err:" + err.Error()
  1931. return
  1932. }
  1933. }
  1934. for k, v := range permissionArr {
  1935. fmt.Println(k, v)
  1936. permissionId, _ := strconv.Atoi(v)
  1937. //companyId, companyApplyId, chartPermissionId int
  1938. count, err := company.GetDelayPermissionCount(req.CompanyId, companyApprovalId, permissionId)
  1939. if err != nil && err.Error() != utils.ErrNoRow() {
  1940. br.Msg = "申请失败"
  1941. br.ErrMsg = "判断权限是否存在失败,Err:" + err.Error()
  1942. return
  1943. }
  1944. if count > 0 { //修改
  1945. err = company.ModifyCompanyDelayPermission(req.CompanyId, companyApprovalId, permissionId)
  1946. if err != nil {
  1947. br.Msg = "申请失败"
  1948. br.ErrMsg = "修改权限失败,Err:" + err.Error()
  1949. return
  1950. }
  1951. } else { //新增
  1952. if v != "" {
  1953. permissionId, err := strconv.Atoi(v)
  1954. if err != nil {
  1955. br.Msg = "申请失败"
  1956. br.ErrMsg = "权限格式转换失败,Err:" + err.Error()
  1957. return
  1958. }
  1959. delayItem := new(company.CompanyDelayPermission)
  1960. delayItem.CompanyId = req.CompanyId
  1961. delayItem.CompanyApplyId = companyApprovalId
  1962. delayItem.ChartPermissionId = permissionId
  1963. delayItem.StartDate = time.Now().Format(utils.FormatDate)
  1964. delayItem.EndDate = time.Now().AddDate(0, 2, 0).Format(utils.FormatDate)
  1965. delayItem.CreateTime = time.Now()
  1966. delayItem.ModifyTime = time.Now()
  1967. err = company.AddCompanyDelayPermission(delayItem)
  1968. if err != nil {
  1969. br.Msg = "申请失败"
  1970. br.ErrMsg = "新增延期审批权限失败,Err:" + err.Error()
  1971. return
  1972. }
  1973. }
  1974. }
  1975. }
  1976. }
  1977. }
  1978. //新增操作记录
  1979. {
  1980. remark := "申请延期"
  1981. operation := "delay"
  1982. go services.AddCompanyOperationRecord(req.CompanyId, companyProduct.SellerId, sysUser.AdminId, productId, 0, companyProduct.CompanyName,
  1983. companyProduct.ProductName, sysUser.RealName, remark, operation, approveContent, "", "", companyProduct.Status)
  1984. }
  1985. //新增客户产品日志
  1986. {
  1987. logType := "modify"
  1988. go services.AddCompanyProductLog(companyProduct, this.SysUser.AdminId, logType)
  1989. }
  1990. err = company_apply.Apply(companyApprovalId, "试用延期申请单")
  1991. if err != nil {
  1992. br.Msg = "发起审批异常,请联系管理员"
  1993. br.ErrMsg = "客户审批发起异常,Err:" + err.Error()
  1994. return
  1995. }
  1996. br.Ret = 200
  1997. br.Success = true
  1998. br.Msg = "申请成功"
  1999. }
  2000. // ApplyReceive
  2001. // @Title 申请领取
  2002. // @Description 申请领取接口
  2003. // @Param request body company.CompanyApplyReceiveReq true "type json string"
  2004. // @Success Ret=200 申请成功
  2005. // @router /apply/receive [post]
  2006. func (this *CompanyApplyController) ApplyReceive() {
  2007. br := new(models.BaseResponse).Init()
  2008. defer func() {
  2009. this.Data["json"] = br
  2010. this.ServeJSON()
  2011. }()
  2012. sysUser := this.SysUser
  2013. if sysUser == nil {
  2014. br.Msg = "请登录"
  2015. br.ErrMsg = "请登录,SysUser Is Empty"
  2016. br.Ret = 408
  2017. return
  2018. }
  2019. var req company.CompanyApplyReceiveReq
  2020. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  2021. if err != nil {
  2022. br.Msg = "参数解析异常!"
  2023. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  2024. return
  2025. }
  2026. if req.CompanyId <= 0 {
  2027. br.Msg = "参数错误"
  2028. br.ErrMsg = "参数错误,客户id小于等于0"
  2029. return
  2030. }
  2031. // 查询当前销售是否有领取客户的权限
  2032. receiveEnabled, _ := services.CheckCompanyReceiveButton(sysUser.AdminId)
  2033. if !receiveEnabled {
  2034. br.Msg = "领取失败,您目前没有领取客户的权限"
  2035. br.ErrMsg = "领取失败,您目前没有领取客户的权限"
  2036. return
  2037. }
  2038. roleTypeCode := sysUser.RoleTypeCode
  2039. productId := services.GetProductId(roleTypeCode)
  2040. if productId == 0 {
  2041. br.Msg = "参数错误"
  2042. br.ErrMsg = "客户类型为:" + roleTypeCode
  2043. return
  2044. }
  2045. //如果是权益客户,在选择非研选行业试用时,需要判断当前有多少非研选的试用客户(试用状态,且行业是非研选)
  2046. if productId == utils.COMPANY_PRODUCT_RAI_ID {
  2047. permissionArr := strings.Split(req.PermissionIds, ",")
  2048. //如果所选行业不属于研选订阅跟研选扣点包,那就是非研选试用客户
  2049. var isNoResearch bool
  2050. for _, v := range permissionArr {
  2051. if v != strconv.Itoa(utils.CHART_PERMISSION_ID_YANXUAN) && v != strconv.Itoa(utils.YAN_XUAN_KOU_DIAN_BAO_ID) {
  2052. isNoResearch = true
  2053. continue
  2054. }
  2055. }
  2056. if isNoResearch {
  2057. tryOutCountRai, err := company.GetRaiCompanyTryOutCountNoResearch(sysUser.AdminId)
  2058. if err != nil {
  2059. br.Msg = "判断试用客户量失败"
  2060. br.ErrMsg = "判断试用客户量失败,Err:" + err.Error()
  2061. return
  2062. }
  2063. if tryOutCountRai >= utils.COMPANY_STATUS_TRY_OUT_COUNT_RAI {
  2064. br.Msg = "非研选试用客户最多40家"
  2065. return
  2066. }
  2067. }
  2068. }
  2069. //添加缓存,避免多次点击提交
  2070. {
  2071. deleteCache := true
  2072. cacheKey := "CACHE_COMPANY_APPLY_" + strconv.Itoa(req.CompanyId) + "_" + strconv.Itoa(productId)
  2073. defer func() {
  2074. if deleteCache {
  2075. utils.Rc.Delete(cacheKey)
  2076. }
  2077. }()
  2078. if !utils.Rc.SetNX(cacheKey, 1, 30*time.Second) {
  2079. deleteCache = false
  2080. br.Msg = "系统处理中,请勿重复操作"
  2081. br.ErrMsg = "系统处理中,请勿重复操作" + sysUser.RealName + ";data:" + string(this.Ctx.Input.RequestBody)
  2082. return
  2083. }
  2084. }
  2085. approveRoleTypeCode := ""
  2086. if productId == 1 {
  2087. approveRoleTypeCode = utils.ROLE_TYPE_CODE_FICC_ADMIN
  2088. } else {
  2089. approveRoleTypeCode = utils.ROLE_TYPE_CODE_RAI_ADMIN
  2090. }
  2091. companyProduct, err := company.GetCompanyProductByCompanyIdAndProductId(req.CompanyId, productId)
  2092. if err != nil {
  2093. br.Msg = "获取客户信息失败"
  2094. br.ErrMsg = "获取客户信息失败"
  2095. return
  2096. }
  2097. if companyProduct == nil {
  2098. br.Msg = "获取客户信息失败"
  2099. br.ErrMsg = "客户不存在,不可提交审批:companyId:" + strconv.Itoa(req.CompanyId) + ";productId:" + strconv.Itoa(productId)
  2100. return
  2101. }
  2102. if companyProduct.Status != utils.COMPANY_STATUS_LOSE {
  2103. br.Msg = "客户状态为:" + companyProduct.Status + ";不可进行延期申请"
  2104. br.ErrMsg = "客户状态为:" + companyProduct.Status + ";不可进行延期申请"
  2105. return
  2106. }
  2107. if companyProduct.ApproveStatus == "待审批" {
  2108. br.Msg = "存在待审批订单,不可重复提交"
  2109. return
  2110. }
  2111. approveUser, err := company.GetApproveUser(approveRoleTypeCode)
  2112. if err != nil && err.Error() != utils.ErrNoRow() {
  2113. br.Msg = "获取审批信息失败"
  2114. br.ErrMsg = "获取审批人信息失败,Err:" + err.Error()
  2115. return
  2116. }
  2117. if approveUser == nil || (err != nil && err.Error() == utils.ErrNoRow()) {
  2118. br.Msg = "审批用户不存在"
  2119. br.ErrMsg = "审批用户不存在"
  2120. return
  2121. }
  2122. approveContent := `原销售申领客户`
  2123. applyMethod := 4
  2124. var companyApprovalId int
  2125. //申请类型:1:试用->正式,2:冻结—>试用,3:试用延期,4:原销售申请领取流失客户,5:正式客户申请服务更新,6:正式客户补充协议
  2126. if req.CompanyApprovalId <= 0 {
  2127. approval := new(company.CompanyApproval)
  2128. approval.CompanyId = req.CompanyId
  2129. approval.ProductId = productId
  2130. approval.ApproveStatus = "待审批"
  2131. approval.ApproveUserId = 0
  2132. approval.ApproveRoleTypeCode = approveRoleTypeCode
  2133. approval.ApproveRealName = ""
  2134. approval.ApproveTime = time.Now()
  2135. approval.ApproveContent = approveContent
  2136. approval.ApplyMethod = applyMethod
  2137. approval.ApplyReasons = req.ApplyRemark
  2138. approval.ApplyUserId = sysUser.AdminId
  2139. approval.ApplyRealName = sysUser.RealName
  2140. approval.CreateTime = time.Now()
  2141. approval.ModifyTime = time.Now()
  2142. companyApprovalId, err = company.AddCompanyApproval(approval)
  2143. if err != nil {
  2144. br.Msg = "申请失败"
  2145. br.ErrMsg = "申请失败,Err:" + err.Error()
  2146. return
  2147. }
  2148. } else {
  2149. err = company.ModifyCompanyApproval(req.CompanyId, productId, req.CompanyApprovalId, approveContent, req.ApplyRemark)
  2150. if err != nil {
  2151. br.Msg = "申请失败"
  2152. br.ErrMsg = "申请失败,Err:" + err.Error()
  2153. return
  2154. }
  2155. companyApprovalId = req.CompanyApprovalId
  2156. //先删除之前申请的权限
  2157. _ = company.DeleteCompanyDelayPermission(req.CompanyApprovalId)
  2158. }
  2159. //处理权限
  2160. {
  2161. if req.PermissionIds != "" {
  2162. permissionStr, err := company.GetPermissionIdById(req.PermissionIds)
  2163. if err != nil {
  2164. br.Msg = "获取信息失败"
  2165. br.ErrMsg = "获取主观客观权限信息失败,Err:" + err.Error()
  2166. return
  2167. }
  2168. req.PermissionIds = permissionStr
  2169. permissionArr := strings.Split(req.PermissionIds, ",")
  2170. for _, v := range permissionArr {
  2171. if v != "" {
  2172. permissionId, err := strconv.Atoi(v)
  2173. if err != nil {
  2174. br.Msg = "申请失败"
  2175. br.ErrMsg = "权限格式转换失败,Err:" + err.Error()
  2176. return
  2177. }
  2178. delayItem := new(company.CompanyDelayPermission)
  2179. delayItem.CompanyId = req.CompanyId
  2180. delayItem.CompanyApplyId = companyApprovalId
  2181. delayItem.ChartPermissionId = permissionId
  2182. delayItem.StartDate = time.Now().Format(utils.FormatDate)
  2183. if productId == utils.COMPANY_PRODUCT_RAI_ID { // 权益客户试用期改为1个月。 需求池 1035
  2184. delayItem.EndDate = time.Now().AddDate(0, 1, 0).Format(utils.FormatDate)
  2185. } else {
  2186. delayItem.EndDate = time.Now().AddDate(0, 2, 0).Format(utils.FormatDate)
  2187. }
  2188. delayItem.CreateTime = time.Now()
  2189. delayItem.ModifyTime = time.Now()
  2190. err = company.AddCompanyDelayPermission(delayItem)
  2191. if err != nil {
  2192. br.Msg = "申请失败"
  2193. br.ErrMsg = "新增领取客户审批权限失败,Err:" + err.Error()
  2194. return
  2195. }
  2196. }
  2197. }
  2198. }
  2199. }
  2200. //新增操作记录
  2201. {
  2202. remark := "申请领取"
  2203. operation := "apply_receive"
  2204. services.AddCompanyOperationRecord(req.CompanyId, companyProduct.SellerId, sysUser.AdminId, productId, 0, companyProduct.CompanyName,
  2205. companyProduct.ProductName, sysUser.RealName, remark, operation, approveContent, "", "", companyProduct.Status)
  2206. }
  2207. //新增客户产品日志
  2208. {
  2209. logType := "modify"
  2210. go services.AddCompanyProductLog(companyProduct, this.SysUser.AdminId, logType)
  2211. }
  2212. err = company_apply.Apply(companyApprovalId, "申请领取申请单")
  2213. if err != nil {
  2214. br.Msg = "发起审批异常,请联系管理员"
  2215. br.ErrMsg = "客户审批发起异常,Err:" + err.Error()
  2216. return
  2217. }
  2218. br.Ret = 200
  2219. br.Success = true
  2220. br.Msg = "申请成功"
  2221. }
  2222. // ApplyRevoke
  2223. // @Title 申请撤回
  2224. // @Description 申请撤回接口
  2225. // @Param request body company.CompanyApplyRevokeReq true "type json string"
  2226. // @Success Ret=200 成功
  2227. // @router /apply/revoke [post]
  2228. func (this *CompanyApprovalController) ApplyRevoke() {
  2229. br := new(models.BaseResponse).Init()
  2230. defer func() {
  2231. this.Data["json"] = br
  2232. this.ServeJSON()
  2233. }()
  2234. sysUser := this.SysUser
  2235. if sysUser == nil {
  2236. br.Msg = "请登录"
  2237. br.ErrMsg = "请登录,SysUser Is Empty"
  2238. br.Ret = 408
  2239. return
  2240. }
  2241. var req company.CompanyApplyRevokeReq
  2242. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  2243. if err != nil {
  2244. br.Msg = "参数解析异常!"
  2245. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  2246. return
  2247. }
  2248. if req.CompanyId <= 0 {
  2249. br.Msg = "参数错误"
  2250. br.ErrMsg = "客户Id小于等于0:"
  2251. return
  2252. }
  2253. roleTypeCode := sysUser.RoleTypeCode
  2254. productId := services.GetProductId(roleTypeCode)
  2255. if productId == 0 {
  2256. br.Msg = "参数错误"
  2257. br.ErrMsg = "客户类型为:" + roleTypeCode
  2258. return
  2259. }
  2260. //添加缓存,避免多次点击提交
  2261. {
  2262. deleteCache := true
  2263. cacheKey := "CACHE_COMPANY_APPLY_" + strconv.Itoa(req.CompanyId) + "_" + strconv.Itoa(productId)
  2264. defer func() {
  2265. if deleteCache {
  2266. utils.Rc.Delete(cacheKey)
  2267. }
  2268. }()
  2269. if !utils.Rc.SetNX(cacheKey, 1, 30*time.Second) {
  2270. deleteCache = false
  2271. br.Msg = "系统处理中,请勿重复操作"
  2272. br.ErrMsg = "系统处理中,请勿重复操作" + sysUser.RealName + ";data:" + string(this.Ctx.Input.RequestBody)
  2273. return
  2274. }
  2275. }
  2276. companyProduct, err := company.GetCompanyProductByCompanyIdAndProductId(req.CompanyId, productId)
  2277. if err != nil {
  2278. br.Msg = "获取客户信息失败"
  2279. br.ErrMsg = "获取客户信息失败"
  2280. return
  2281. }
  2282. if companyProduct == nil {
  2283. br.Msg = "获取客户信息失败"
  2284. br.ErrMsg = "客户不存在,不可提交审批:companyId:" + strconv.Itoa(req.CompanyId) + ";productId:" + strconv.Itoa(productId)
  2285. return
  2286. }
  2287. approvalItem, err := company.GetCompanyApprovalById(req.CompanyId, productId)
  2288. if err != nil {
  2289. if err.Error() == utils.ErrNoRow() {
  2290. br.Msg = "待审批信息不存在"
  2291. br.ErrMsg = "待审批信息不存在,CompanyId:" + strconv.Itoa(req.CompanyId) + ";productId:" + strconv.Itoa(productId)
  2292. return
  2293. }
  2294. br.Msg = "获取信息失败"
  2295. br.ErrMsg = "获取信息失败,Err:" + err.Error()
  2296. return
  2297. }
  2298. if approvalItem == nil {
  2299. br.Msg = "待审批信息不存在"
  2300. br.ErrMsg = "待审批信息不存在,CompanyId:" + strconv.Itoa(req.CompanyId) + ";productId:" + strconv.Itoa(productId)
  2301. return
  2302. }
  2303. if approvalItem.ApproveStatus != "待审批" {
  2304. br.Msg = "客户状态为:" + companyProduct.Status + ";不可进行撤回操作"
  2305. br.ErrMsg = "客户状态为:" + companyProduct.Status + ";不可进行撤回操作"
  2306. return
  2307. }
  2308. //撤回审批单
  2309. err = company_apply.CancelApply(approvalItem, sysUser.AdminId)
  2310. if err != nil {
  2311. br.Msg = "撤回失败"
  2312. br.ErrMsg = "撤回失败,Err:" + err.Error()
  2313. return
  2314. }
  2315. //真正撤回操作
  2316. err = company.ApplyRevoke(approvalItem.CompanyApprovalId, approvalItem.CompanyId, approvalItem.ProductId)
  2317. if err != nil {
  2318. br.Msg = "撤回失败"
  2319. br.ErrMsg = "撤回失败,Err:" + err.Error()
  2320. return
  2321. }
  2322. //新增操作记录
  2323. {
  2324. remark := "撤回"
  2325. operation := "apply_revoke"
  2326. services.AddCompanyOperationRecord(req.CompanyId, companyProduct.SellerId, sysUser.AdminId, productId, 0, companyProduct.CompanyName,
  2327. companyProduct.ProductName, sysUser.RealName, remark, operation, "", "", "", companyProduct.Status)
  2328. }
  2329. br.Ret = 200
  2330. br.Success = true
  2331. br.Msg = "撤回成功"
  2332. }