1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129 |
- package company_apply
- import (
- "encoding/json"
- "errors"
- "fmt"
- "hongze/hz_crm_api/models/company"
- "hongze/hz_crm_api/models/contract"
- "hongze/hz_crm_api/models/system"
- "hongze/hz_crm_api/services"
- "hongze/hz_crm_api/services/alarm_msg"
- cygxService "hongze/hz_crm_api/services/cygx"
- "hongze/hz_crm_api/services/flow"
- "hongze/hz_crm_api/utils"
- "strings"
- "time"
- )
- var sourceType = 1
- func Apply(companyApprovalId int, messageContent string) (err error) {
-
- recodeInfo, err := company.GetCompanyApprovalByApprovalId(companyApprovalId)
- if err != nil {
- err = errors.New("获取合同信息失败,Err:" + err.Error())
- return
- }
- if recodeInfo == nil {
- err = errors.New("客户单异常,找不到客户单信息")
- return
- }
-
- companyInfo, err := company.GetCompanyById(recodeInfo.CompanyId)
- if err != nil {
- err = errors.New("获取合同信息失败,Err:" + err.Error())
- return
- }
- if companyInfo == nil {
- err = errors.New("客户信息异常,找不到客户信息")
- return
- }
-
- ignoreStatus := []string{"待审批", "已撤回", "驳回"}
- if !strings.Contains(strings.Join(ignoreStatus, ","), recodeInfo.ApproveStatus) {
- err = errors.New("客户单状态异常,不允许提交审批,当前客户单状态:" + recodeInfo.ApproveStatus)
- return
- }
-
- applyContent := `试用转正式`
- switch recodeInfo.ApplyMethod {
- case 1:
- applyContent = `试用转正式`
- case 2:
- applyContent = `冻结转试用`
- case 3:
- applyContent = `试用延期`
- case 4:
- applyContent = `原销售申领客户`
- case 5:
- applyContent = `续约申请`
- case 6:
- applyContent = `补充协议`
- }
- contractDetailByte, err := json.Marshal(recodeInfo)
- if err != nil {
- err = errors.New(fmt.Sprint("合同状态异常,当前合同数据格式化失败:", err))
- return
- }
-
- var flowItemInfo *system.ApprovalFlowItem
- if recodeInfo.ProductId == 1 {
- tmpFlowItemInfo, tmpErr := flow.GetApprovalFlow(1)
- if tmpErr != nil {
- err = errors.New(fmt.Sprint("查找审批流程配置失败:", tmpErr))
- return
- }
- flowItemInfo = tmpFlowItemInfo
- } else {
- tmpFlowItemInfo, tmpErr := flow.GetApprovalFlow(2)
- if tmpErr != nil {
- err = errors.New(fmt.Sprint("查找审批流程配置失败:", tmpErr))
- return
- }
- flowItemInfo = tmpFlowItemInfo
- }
-
- contractApproval := &contract.ContractApproval{
- ContractId: recodeInfo.CompanyApprovalId,
- Status: "待审批",
- ApprovalType: "company",
- ApplyContent: applyContent,
- ContractDetail: string(contractDetailByte),
- ApplyUserId: recodeInfo.ApplyUserId,
- ApplyUserName: recodeInfo.ApplyRealName,
- FlowId: flowItemInfo.FlowId,
- FlowVersion: flowItemInfo.CurrVersion,
- CurrNodeId: flowItemInfo.NodeList[0].NodeId,
- StartNodeId: flowItemInfo.NodeList[0].NodeId,
- ModifyTime: time.Now(),
- CreateTime: time.Now(),
- }
- has, err := contractApproval.CheckPendingByContractId(recodeInfo.CompanyApprovalId, "company")
- if err != nil {
- return
- }
- if has {
- err = errors.New("客户单异常,不允许提交审批,存在待审核的客户单")
- return
- }
- contractApprovalRecordList := make([]*contract.ContractApprovalRecord, 0)
- ApproveUserMap := make(map[int]system.User)
- for _, nodeItem := range flowItemInfo.NodeList {
-
- if len(nodeItem.UserList) <= 0 {
- err = errors.New(fmt.Sprint("审批流程异常,没有可审批的人员,Err:", err))
- return
- }
- for _, userItem := range nodeItem.UserList {
- contractApprovalRecord := &contract.ContractApprovalRecord{
- Status: "待审批",
- ApproveRemark: "",
- ApproveUserId: userItem.AdminId,
- ApproveUserName: userItem.Name,
- ApproveRoleTypeCode: userItem.RoleTypeCode,
- NodeId: nodeItem.NodeId,
- NodeType: nodeItem.NodeType,
- NextNodeId: nodeItem.NextNodeId,
- PrevNodeId: nodeItem.PrevNodeId,
- AuditType: nodeItem.AuditType,
- CreateTime: time.Now(),
- ModifyTime: time.Now(),
- }
- contractApprovalRecordList = append(contractApprovalRecordList, contractApprovalRecord)
- ApproveUserMap[userItem.AdminId] = userItem
- }
- }
- err = contractApproval.Apply2(contractApproval, contractApprovalRecordList)
- if err != nil {
- return
- }
-
- {
-
- go messageToNodeUser(contractApproval.CurrNodeId, recodeInfo.ApplyUserId, companyInfo.CompanyId, contractApproval.ContractId, contractApproval.ContractApprovalId, 1, 1, companyInfo.CompanyName, messageContent)
- }
- return
- }
- func CancelApply(recordInfo *company.CompanyApproval, opUserId int) (err error) {
- if recordInfo == nil {
- err = errors.New("客户单异常,没有客户单信息")
- return
- }
-
- if recordInfo.ApproveStatus != "待审批" {
- err = errors.New("客户单状态异常,不允许撤回申请,当前客户单状态:" + recordInfo.ApproveStatus)
- return
- }
-
- if recordInfo.ApplyUserId != opUserId {
- err = errors.New(fmt.Sprint("操作人异常,不允许撤回非本人提交的申请;客户单发起人:", recordInfo.ApplyUserId, ";撤销人:", opUserId))
- return
- }
-
- approval, err := contract.GetLastPendingContractApprovalByContractId(recordInfo.CompanyApprovalId, "company")
- if err != nil {
- return
- }
-
- if approval.StartNodeId != approval.CurrNodeId {
- err = errors.New("审批单状态异常,不允许撤回申请,当前审批单已被审批操作,进入了下一级审批节点")
- return
- }
-
- approvalRecord, err := contract.GetCurrContractApprovalRecordByContractId(approval.ContractApprovalId)
- if err != nil {
- return
- }
-
- if approvalRecord.PrevNodeId > 0 {
- err = errors.New("合同已存在审批操作,不允许撤回申请")
- return
- }
-
- approvalRecordList, err := contract.GetPendingContractApprovalRecordListByContractId(approval.ContractApprovalId, approvalRecord.NodeId)
- if err != nil {
- return
- }
-
- err = approval.Cancel(approval, approvalRecordList)
- if err != nil {
- return
- }
-
-
-
-
-
- go company.CancelCompanyApprovalMessage(approval.ContractId, 2)
- return
- }
- func Reject(approvalRecord *contract.ContractApprovalRecord, opUser *system.Admin, rejectRemark string) (err error) {
- if approvalRecord == nil {
- err = errors.New("审批流异常,没有审批流信息")
- return
- }
-
- if approvalRecord.Status != "待审批" {
- err = errors.New("审批流状态异常,不允许驳回申请,当前审批流状态:" + approvalRecord.Status)
- return
- }
-
- if approvalRecord.NodeType != "check" {
- err = errors.New("当前账号没有审批权限")
- return
- }
-
- opUserId := opUser.AdminId
- opUserName := opUser.RealName
-
-
-
-
-
- if approvalRecord.ApproveUserId > 0 && approvalRecord.ApproveUserId != opUserId {
- err = errors.New("当前账号没有审批权限,需要指定人操作")
- return
- }
-
- approval, err := contract.GetContractApprovalById(approvalRecord.ContractApprovalId)
- if err != nil {
- return
- }
-
- if approval.Status != "待审批" {
- err = errors.New("审批单状态异常,不允许驳回申请,当前审批单状态:" + approval.Status)
- return
- }
-
- recordInfo, err := company.GetCompanyApprovalByCompanyApprovalId(approval.ContractId)
- if err != nil {
- return
- }
-
- if recordInfo.ApproveStatus != "待审批" {
- err = errors.New("客户单状态异常,不允许驳回申请,当前客户单状态:" + recordInfo.ApproveStatus)
- return
- }
-
- companyInfo, err := company.GetCompanyById(recordInfo.CompanyId)
- if err != nil {
- return
- }
- err = approval.Reject(approval, approvalRecord, opUserId, opUserName, rejectRemark)
- if err != nil {
- return
- }
-
-
-
-
- go afterReject(approval.ContractId, opUserId, opUserName, rejectRemark)
-
- {
-
- content := companyInfo.CompanyName + " " + recordInfo.ApproveContent + "审批驳回"
- approvalSysUser, _ := system.GetSysAdminById(approval.ApplyUserId)
- go services.AddCompanyApprovalMessage(opUserId, approval.ApplyUserId, companyInfo.CompanyId, approval.ContractId, 2, sourceType, 3, companyInfo.CompanyName, content, content, approvalSysUser.Mobile)
- }
- return
- }
- func Approved(approvalRecord *contract.ContractApprovalRecord, opUser *system.Admin, approvedRemark string) (err error) {
- if approvalRecord == nil {
- err = errors.New("审批流异常,没有审批流信息")
- return
- }
-
- if approvalRecord.Status != "待审批" {
- err = errors.New("审批流状态异常,不允许审批,当前审批流状态:" + approvalRecord.Status)
- return
- }
-
- if approvalRecord.NodeType != "check" {
- err = errors.New("当前账号没有审批权限")
- return
- }
-
- opUserId := opUser.AdminId
-
-
-
-
-
-
- if approvalRecord.ApproveUserId > 0 && approvalRecord.ApproveUserId != opUserId {
- err = errors.New("当前账号没有审批权限,需要指定人操作")
- return
- }
-
- approval, err := contract.GetContractApprovalById(approvalRecord.ContractApprovalId)
- if err != nil {
- return
- }
-
- if approval.Status != "待审批" {
- err = errors.New("审批单状态异常,不允许审批,当前审批单状态:" + approval.Status)
- return
- }
-
- recordInfo, err := company.GetCompanyApprovalByCompanyApprovalId(approval.ContractId)
- if err != nil {
- return
- }
-
- if recordInfo.ApproveStatus != "待审批" {
- err = errors.New("客户单状态异常,不允许审批,当前客户单状态:" + recordInfo.ApproveStatus)
- return
- }
-
- companyInfo, err := company.GetCompanyById(recordInfo.CompanyId)
- if err != nil {
- return
- }
- err = approval.Approved(approval, approvalRecord, approvedRemark)
- if err != nil {
- return
- }
-
-
-
-
- content := companyInfo.CompanyName + " " + recordInfo.ApproveContent + "审批通过"
-
- if approvalRecord.NextNodeId == 0 {
-
- {
- approvalSysUser, _ := system.GetSysAdminById(approval.ApplyUserId)
- go services.AddCompanyApprovalMessage(opUserId, approval.ApplyUserId, companyInfo.CompanyId, approval.ContractId, 2, sourceType, 2, companyInfo.CompanyName, content, content, approvalSysUser.Mobile)
- }
-
- go func() {
- _ = afterApproved(recordInfo.CompanyApprovalId, opUser.AdminId, opUser.RealName)
-
- if recordInfo.ProductId == 2 && recordInfo.CompanyContractId > 0 {
-
- cygxService.UpdateCygxCompanyUserType(recordInfo.CompanyContractId)
-
-
- contractInfo, tmpErr := company.GetCompanyContractDetail(recordInfo.CompanyId, recordInfo.ProductId, recordInfo.CompanyContractId)
- if tmpErr != nil {
- err = errors.New(fmt.Sprint("待审批信息不存在,CompanyId:", recordInfo.CompanyId, ";productId:", recordInfo.ProductId, ";Err:"+tmpErr.Error()))
- return
- }
- if contractInfo == nil {
- err = errors.New(fmt.Sprint("待审批信息不存在,CompanyId:", recordInfo.CompanyId, ";productId:", recordInfo.ProductId))
- return
- }
-
- contractStartDate, tmpErr := time.Parse(utils.FormatDate, contractInfo.StartDate)
- if tmpErr != nil {
- err = errors.New("合同开始时间转换失败,Err:" + tmpErr.Error())
- return
- }
- if time.Now().After(contractStartDate) {
- cygxService.ActivitySpecialCompanyApproval(recordInfo.CompanyId, recordInfo.CompanyContractId, companyInfo.CompanyName)
-
- }
-
-
- services.AddCompanyApprovalMessageRai(recordInfo.CompanyId, recordInfo.CompanyContractId, recordInfo.ApplyRealName, companyInfo.CompanyName)
-
- services.AddCompanyApprovalMessageWangYang(recordInfo.CompanyId, recordInfo.CompanyContractId, recordInfo.ApplyRealName, companyInfo.CompanyName)
- cygxService.YanXuanCompanyApproval(recordInfo.CompanyId, recordInfo.CompanyContractId)
-
- cygxService.HandleCompanyContractPackageDifference(recordInfo.CompanyContractId)
- cygxService.HandleCompanyContractPermissionContractType(recordInfo.CompanyContractId)
- }
- }()
- } else {
-
- flowNodeInfo, tmpErr := system.GetByNodeId(approvalRecord.NextNodeId)
- if tmpErr != nil {
- err = tmpErr
- return
- }
-
- if flowNodeInfo.NodeType == "cc" {
- go approvedByCc(approvedRemark, approvalRecord)
- } else {
-
- go messageToNodeUser(approvalRecord.NextNodeId, approval.ApplyUserId, companyInfo.CompanyId, approval.ContractId, approval.ContractApprovalId, 1, 1, companyInfo.CompanyName, content)
- }
- }
- return
- }
- func approvedByCc(approvedRemark string, sourceApprovalRecord *contract.ContractApprovalRecord) (err error) {
-
- nextNodeId := 0
-
- approvalRecordList, err := contract.GetContractApprovalRecordListByContractIdAndNode(sourceApprovalRecord.ContractApprovalId, sourceApprovalRecord.NextNodeId)
- if err != nil {
- return
- }
-
- for _, contractApprovalRecord := range approvalRecordList {
- nextNodeId = contractApprovalRecord.NextNodeId
-
- if contractApprovalRecord.Status != "待审批" {
- err = errors.New("审批流状态异常,不允许审批,当前审批流状态:" + contractApprovalRecord.Status)
- return
- }
-
- if contractApprovalRecord.NodeType != "cc" {
- err = errors.New("当前账号不是抄送权限")
- return
- }
- }
-
- approval, err := contract.GetContractApprovalById(sourceApprovalRecord.ContractApprovalId)
- if err != nil {
- return
- }
-
- recordInfo, err := company.GetCompanyApprovalByCompanyApprovalId(approval.ContractId)
- if err != nil {
- return
- }
-
- if recordInfo.ApproveStatus != "待审批" {
- err = errors.New("客户单状态异常,不允许审批,当前客户单状态:" + recordInfo.ApproveStatus)
- return
- }
-
- companyInfo, err := company.GetCompanyById(recordInfo.CompanyId)
- if err != nil {
- return
- }
-
- err = approval.ApprovedByCc(approval, approvalRecordList, approvedRemark, nextNodeId)
- if err != nil {
- return
- }
- content := companyInfo.CompanyName + " " + recordInfo.ApproveContent + "审批通过"
-
- go messageToNodeUser(approvalRecordList[0].NodeId, approval.ApplyUserId, companyInfo.CompanyId, approval.ContractId, approval.ContractApprovalId, 1, 1, companyInfo.CompanyName, content)
-
- if nextNodeId == 0 {
-
- {
- approvalSysUser, _ := system.GetSysAdminById(approval.ApplyUserId)
- go services.AddCompanyApprovalMessage(sourceApprovalRecord.ApproveUserId, approval.ApplyUserId, companyInfo.CompanyId, approval.ContractId, 2, sourceType, 2, companyInfo.CompanyName, content, content, approvalSysUser.Mobile)
- }
-
- go afterApproved(recordInfo.CompanyApprovalId, sourceApprovalRecord.ApproveUserId, sourceApprovalRecord.ApproveUserName)
- } else {
-
- flowNodeInfo, tmpErr := system.GetByNodeId(nextNodeId)
- if tmpErr != nil {
- err = tmpErr
- return
- }
-
- if flowNodeInfo.NodeType == "cc" {
- go approvedByCc(approvedRemark, sourceApprovalRecord)
- } else {
-
-
- go messageToNodeUser(nextNodeId, approval.ApplyUserId, companyInfo.CompanyId, approval.ContractId, approval.ContractApprovalId, 1, 1, companyInfo.CompanyName, content)
- }
- }
- return
- }
- func messageToNodeUser(flowNodeId, createUserId, companyId, companyApprovalId, contractApprovalId, messageType, approvalStatus int, companyName, content string) (err error) {
-
- contractApprovalRecordList, err := contract.GetContractApprovalRecordListByContractIdAndNode(contractApprovalId, flowNodeId)
- if err != nil {
- return
- }
- err = messageToUser(contractApprovalRecordList, createUserId, companyId, companyApprovalId, messageType, approvalStatus, companyName, content)
- return
- }
- func messageToAllCcUser(createUserId, companyId, companyApprovalId, contractApprovalId, messageType, approvalStatus int, companyName, content string) (err error) {
-
- contractApprovalRecordList, err := contract.GetContractApprovalRecordListByContractApprovalId(contractApprovalId)
- if err != nil {
- return
- }
- err = messageToUser(contractApprovalRecordList, createUserId, companyId, companyApprovalId, messageType, approvalStatus, companyName, content)
- return
- }
- func messageToUser(contractApprovalRecordList []*contract.ContractApprovalRecord, createUserId, companyId, companyApprovalId, messageType, approvalStatus int, companyName, content string) (err error) {
- for _, contractApprovalRecord := range contractApprovalRecordList {
- sysUserMobile := ""
- sysUser, _ := system.GetSysAdminById(contractApprovalRecord.ApproveUserId)
- if sysUser != nil {
- sysUserMobile = sysUser.Mobile
- }
-
- receiveUserId := contractApprovalRecord.ApproveUserId
- go services.AddCompanyApprovalMessage(createUserId, receiveUserId, companyId, companyApprovalId, messageType, sourceType, approvalStatus, companyName, content, content, sysUserMobile)
- }
- return
- }
- func afterApproved(companyApprovalId int, opUserId int, opUserName string) (err error) {
- defer func() {
- if err != nil {
-
- go alarm_msg.SendAlarmMsg("客户审批通过后,处理客户失败,Err:"+err.Error(), 3)
-
- }
- }()
- opUser := system.Admin{
- AdminId: opUserId,
- RealName: opUserName,
- }
-
- recodeInfo, err := company.GetCompanyApprovalByApprovalId(companyApprovalId)
- if err != nil {
- err = errors.New("获取合同信息失败,Err:" + err.Error())
- return
- }
- if recodeInfo == nil {
- err = errors.New("客户单异常,找不到客户单信息")
- return
- }
-
- companyInfo, err := company.GetCompanyById(recodeInfo.CompanyId)
- if err != nil {
- err = errors.New("获取合同信息失败,Err:" + err.Error())
- return
- }
- if companyInfo == nil {
- err = errors.New("客户信息异常,找不到客户信息")
- return
- }
-
- companyProduct, err := company.GetCompanyProductByCompanyIdAndProductId(recodeInfo.CompanyId, recodeInfo.ProductId)
- if err != nil {
- err = errors.New(fmt.Sprint("获取信息客户产品失败", ";Err:"+err.Error()))
- return
- }
- if companyProduct == nil {
- err = errors.New("获取信息客户产品失败2")
- return
- }
-
- logSellerId := recodeInfo.ApplyUserId
- logSellerName := recodeInfo.ApplyRealName
- isAddCompanyProductUpdateLog := true
- companyReportPermissionList := make([]*company.CompanyReportPermission, 0)
- var startDate, endDate string
- switch recodeInfo.ApplyMethod {
- case 1:
-
- contractInfo, tmpErr := company.GetCompanyContractDetail(recodeInfo.CompanyId, recodeInfo.ProductId, recodeInfo.CompanyContractId)
- if tmpErr != nil {
- err = errors.New(fmt.Sprint("待审批信息不存在,CompanyId:", recodeInfo.CompanyId, ";productId:", recodeInfo.ProductId, ";Err:"+tmpErr.Error()))
- return
- }
- if contractInfo == nil {
- err = errors.New(fmt.Sprint("待审批信息不存在,CompanyId:", recodeInfo.CompanyId, ";productId:", recodeInfo.ProductId))
- return
- }
-
- contractStartDate, tmpErr := time.Parse(utils.FormatDate, contractInfo.StartDate)
- if tmpErr != nil {
- err = errors.New("合同开始时间转换失败,Err:" + tmpErr.Error())
- return
- }
-
- contractEndDate, tmpErr := time.Parse(utils.FormatDate, contractInfo.EndDate)
- if tmpErr != nil {
- err = errors.New("合同结束时间转换失败,Err:" + tmpErr.Error())
- return
- }
-
-
-
-
-
-
-
-
- if companyProduct.Status == utils.COMPANY_STATUS_FOREVER && companyProduct.ProductId == 2 {
- contractInfo.StartDate = contractStartDate.AddDate(0, 4, 0).Format(utils.FormatDate)
- contractInfo.EndDate = contractEndDate.AddDate(0, 4, 0).Format(utils.FormatDate)
- startDate = contractInfo.StartDate
- endDate = contractInfo.EndDate
- companyReportPermissionList, tmpErr = company.TryOutToFormalXClassRai(recodeInfo.CompanyId, recodeInfo.ProductId, opUser.AdminId, recodeInfo.CompanyApprovalId, contractInfo.CompanyContractId, contractInfo.StartDate, contractInfo.EndDate, opUser.RealName, companyProduct.ProductName, contractInfo.RaiPackageType)
- if tmpErr != nil {
- err = errors.New("试用转正式失败,Err:" + tmpErr.Error())
- return
- }
- } else {
-
- if time.Now().After(contractStartDate) {
- startDate = contractInfo.StartDate
- endDate = contractInfo.EndDate
- companyReportPermissionList, tmpErr = company.TryOutToFormal(recodeInfo.CompanyId, recodeInfo.ProductId, opUser.AdminId, recodeInfo.CompanyApprovalId, contractInfo.CompanyContractId, contractInfo.StartDate, contractInfo.EndDate, opUser.RealName, companyProduct.ProductName, contractInfo.PackageType, contractInfo.RaiPackageType)
- if tmpErr != nil {
- err = errors.New("试用转正式失败,Err:" + tmpErr.Error())
- return
- }
- } else {
- tmpErr = company.ApplyApproveContract(recodeInfo.CompanyId, recodeInfo.ProductId, recodeInfo.CompanyApprovalId, contractInfo.CompanyContractId)
- if tmpErr != nil {
- err = errors.New("试用转正式失败,Err:" + tmpErr.Error())
- return
- }
-
- isAddCompanyProductUpdateLog = false
- }
-
- if contractEndDate.After(companyProduct.ContractEndDate) {
- companyProduct.ContractEndDate = contractEndDate
- cols := make([]string, 0)
- cols = append(cols, "ContractEndDate")
- _ = companyProduct.Update(cols)
- }
- }
- case 2:
-
- if companyProduct.InitStatus == utils.COMPANY_STATUS_FOREVER && companyProduct.ProductId == utils.COMPANY_PRODUCT_RAI_ID {
- tmpCompanyReportPermissionList, tmpStartDate, tmpEndDate, tmpErr := company.FreezeToTryOutXClassRai(recodeInfo.CompanyId, recodeInfo.ProductId, opUser.AdminId, recodeInfo.CompanyApprovalId, recodeInfo.ApplyUserId, opUser.RealName, companyProduct.ProductName)
- if tmpErr != nil {
- err = errors.New("冻结转试用失败,Err:" + tmpErr.Error())
- return
- }
- companyReportPermissionList = tmpCompanyReportPermissionList
- startDate = tmpStartDate
- endDate = tmpEndDate
- } else {
- tmpCompanyReportPermissionList, tmpStartDate, tmpEndDate, tmpErr := company.FreezeToTryOut(recodeInfo.CompanyId, recodeInfo.ProductId, opUser.AdminId, recodeInfo.CompanyApprovalId, recodeInfo.ApplyUserId, opUser.RealName, companyProduct.ProductName)
- if tmpErr != nil {
- err = errors.New("冻结转试用失败,Err:" + tmpErr.Error())
- return
- }
- companyReportPermissionList = tmpCompanyReportPermissionList
- startDate = tmpStartDate
- endDate = tmpEndDate
- }
- case 3:
- tmpCompanyReportPermissionList, tmpEndDate, tmpErr := company.TryOutDelay(recodeInfo.CompanyId, recodeInfo.ProductId, opUser.AdminId, recodeInfo.CompanyApprovalId, opUser.RealName, companyProduct.EndDate, companyProduct.ProductName)
- if tmpErr != nil {
- err = errors.New("试用延期失败,Err:" + tmpErr.Error())
- return
- }
- companyReportPermissionList = tmpCompanyReportPermissionList
- startDate = companyProduct.StartDate
- endDate = tmpEndDate
- case 4:
- sellerItem, tmpErr := system.GetSysAdminById(recodeInfo.ApplyUserId)
- if tmpErr != nil {
- err = errors.New("找不到申请的销售,Err:" + tmpErr.Error())
- return
- }
- companyReportPermissionList, startDate, endDate, tmpErr = company.ApplyReceive(recodeInfo.CompanyId, recodeInfo.ProductId, opUser.AdminId, recodeInfo.CompanyApprovalId, sellerItem, opUser.RealName, companyProduct.ProductName, sellerItem.RealName, sellerItem.AdminId)
- if tmpErr != nil {
- err = errors.New("原销售申请领取流失客户失败,Err:" + tmpErr.Error())
- return
- }
- logSellerId = sellerItem.AdminId
- logSellerName = sellerItem.RealName
- case 5, 6:
-
- contractInfo, tmpErr := company.GetCompanyContractDetail(recodeInfo.CompanyId, recodeInfo.ProductId, recodeInfo.CompanyContractId)
- if tmpErr != nil {
- err = errors.New(fmt.Sprint("正式客户申请服务更新失败,待审批合同信息不存在,CompanyId:", recodeInfo.CompanyId, ";productId:", recodeInfo.ProductId, ";Err:"+tmpErr.Error()))
- return
- }
- if contractInfo == nil {
- err = errors.New(fmt.Sprint("正式客户申请服务更新失败,待审批合同信息不存在2,CompanyId:", recodeInfo.CompanyId, ";productId:", recodeInfo.ProductId))
- return
- }
-
- contractStartDate, tmpErr := time.Parse(utils.FormatDate, contractInfo.StartDate)
- if tmpErr != nil {
- err = errors.New(fmt.Sprint("正式客户申请服务更新失败,合同开始时间转换失败;Err:" + tmpErr.Error()))
- return
- }
-
- contractEndDate, tmpErr := time.Parse(utils.FormatDate, contractInfo.EndDate)
- if tmpErr != nil {
- err = errors.New(fmt.Sprint("正式客户申请服务更新失败,合同结束时间转换失败;Err:" + tmpErr.Error()))
- return
- }
-
-
-
-
-
-
-
-
- if time.Now().After(contractStartDate) {
-
- contactHandleCompanyRenewalRecord(contractInfo)
- startDate = contractInfo.StartDate
- endDate = contractInfo.EndDate
- companyReportPermissionList, err = company.ApplyServiceUpdate(recodeInfo.CompanyId, recodeInfo.ProductId, opUser.AdminId, recodeInfo.CompanyApprovalId, recodeInfo.CompanyContractId, companyProduct.StartDate, contractInfo.EndDate, opUser.RealName, companyProduct.ProductName, contractInfo.PackageType, contractInfo.RaiPackageType)
- if err != nil {
- err = errors.New(fmt.Sprint("正式客户申请服务更新失败,执行失败;Err:" + err.Error()))
- return
- }
- } else {
- tmpErr = company.ApplyApproveContract(recodeInfo.CompanyId, recodeInfo.ProductId, recodeInfo.CompanyApprovalId, recodeInfo.CompanyContractId)
- if tmpErr != nil {
- err = errors.New(fmt.Sprint("正式客户申请服务更新失败,执行失败2;Err:" + tmpErr.Error()))
- return
- }
-
- isAddCompanyProductUpdateLog = false
- }
-
- if contractEndDate.After(companyProduct.ContractEndDate) {
- companyProduct.ContractEndDate = contractEndDate
- cols := make([]string, 0)
- cols = append(cols, "ContractEndDate")
- _ = companyProduct.Update(cols)
- }
- default:
- err = errors.New(fmt.Sprint("无效的审批状态,CompanyId:", recodeInfo.CompanyId, ";productId:", recodeInfo.ProductId, ";ApplyMethod:", recodeInfo.ApplyMethod, ";ApproveStatus:", recodeInfo.ApproveStatus))
- return
- }
-
- {
- productLog := new(company.CompanyProductLog)
- productLog.CompanyProductId = companyProduct.CompanyProductId
- productLog.CompanyId = companyProduct.CompanyId
- productLog.ProductId = companyProduct.ProductId
- productLog.ProductName = companyProduct.ProductName
- productLog.CompanyName = companyProduct.CompanyName
- productLog.CompanyName = companyProduct.CompanyName
- productLog.Source = companyProduct.Source
- productLog.Reasons = companyProduct.Reasons
- productLog.Status = companyProduct.Status
- productLog.IndustryId = companyProduct.IndustryId
- productLog.IndustryName = companyProduct.IndustryName
- productLog.SellerId = companyProduct.SellerId
- productLog.SellerName = companyProduct.SellerName
- productLog.GroupId = companyProduct.GroupId
- productLog.DepartmentId = companyProduct.DepartmentId
- productLog.IsSuspend = companyProduct.IsSuspend
- productLog.SuspendTime = companyProduct.SuspendTime
- productLog.ApproveStatus = companyProduct.ApproveStatus
- productLog.FreezeTime = companyProduct.FreezeTime
- productLog.Remark = companyProduct.Remark
- productLog.StartDate = companyProduct.StartDate
- productLog.EndDate = companyProduct.EndDate
- productLog.CreateTime = companyProduct.CreateTime
- productLog.ModifyTime = companyProduct.ModifyTime
- productLog.LoseReason = companyProduct.LoseReason
- productLog.LossTime = companyProduct.LossTime
- productLog.LogType = "modify"
- productLog.LogCreateTime = time.Now()
- productLog.AdminId = opUserId
- go company.AddCompanyProductLog(productLog)
- }
-
- {
- remark := "审批"
- operation := "approve"
- approveContent := "审批通过"
- services.AddCompanyOperationRecord(recodeInfo.CompanyId, companyProduct.SellerId, opUserId, recodeInfo.ProductId, opUserId, companyProduct.CompanyName,
- companyProduct.ProductName, opUserName, remark, operation, approveContent, opUserName, "", companyProduct.Status)
- }
-
- if isAddCompanyProductUpdateLog {
- updateSource := ``
- switch recodeInfo.ApplyMethod {
- case 1:
- updateSource = `turn_positive`
- case 2:
- updateSource = "thaw"
- case 3:
- updateSource = "delay"
- case 4:
- updateSource = "apply_receive"
- case 5:
- updateSource = "service_update"
- case 6:
- updateSource = "add_agreement"
- }
- startDateTime, _ := time.ParseInLocation(utils.FormatDate, startDate, time.Local)
- endDateTime, _ := time.ParseInLocation(utils.FormatDate, endDate, time.Local)
- companyProductUpdateLog := &company.CompanyProductUpdateLog{
- Id: 0,
- CompanyId: companyProduct.CompanyId,
- ProductId: companyProduct.ProductId,
- Status: companyProduct.Status,
- SellerId: logSellerId,
- SellerName: logSellerName,
- Source: updateSource,
- StartDate: startDateTime,
- EndDate: endDateTime,
- RealEndDate: startDateTime,
- IsFormal: companyProduct.IsFormal,
- CreateTime: time.Now(),
- }
- go company.AddCompanyProductUpdateLog(companyProductUpdateLog)
-
- if recodeInfo.ApplyMethod == 2 || recodeInfo.ApplyMethod == 3 || recodeInfo.ApplyMethod == 4 {
- companyProductTryOutUpdateLog := &company.CompanyProductTryOutUpdateLog{
- Id: 0,
- CompanyId: companyProduct.CompanyId,
- ProductId: companyProduct.ProductId,
- SellerId: logSellerId,
- SellerName: logSellerName,
- Source: updateSource,
- StartDate: startDateTime,
- EndDate: endDateTime,
- RealEndDate: startDateTime,
- IsStop: 0,
- CreateTime: time.Now(),
- }
- go company.AddCompanyProductTryOutUpdateLog(companyProductTryOutUpdateLog, companyReportPermissionList)
- }
- }
- return
- }
- func contactHandleCompanyRenewalRecord(contractInfo *company.CompanyContractDetail) {
- var err error
- defer func() {
- if err != nil {
- utils.FileLog.Error("合同处理完成后的续约异常记录," + err.Error())
- }
- }()
-
- if contractInfo.ContractType != `续约合同` {
- return
- }
- day := time.Now().Format(utils.FormatDate)
-
- lastContract, tmpErr := company.GetLastContractListByEndDate(contractInfo.CompanyId, contractInfo.ProductId, contractInfo.EndDate)
- if tmpErr != nil {
- err = errors.New(fmt.Sprint("合同id:", contractInfo.CompanyContractId, ";通过最近一份合同的日期获取早于该合同的最晚一份合同失败,ERR:", tmpErr))
- return
- }
-
- betweenDay, tmpErr := utils.GetDaysBetween2Date(utils.FormatDate, day, lastContract.EndDate)
- if tmpErr != nil {
- err = errors.New(fmt.Sprint("合同id:", contractInfo.CompanyContractId, ";计算两个日期相差的天数失败,ERR:", tmpErr))
- return
- }
- source := 2
-
- if betweenDay > 60 {
- source = 3
- }
-
- companyProductItem, tmpErr := company.GetCompanyProductItemByCompanyId(contractInfo.CompanyId, contractInfo.ProductId)
- if tmpErr != nil {
- err = errors.New(fmt.Sprint("合同id:", contractInfo.CompanyContractId, ";GetCompanyProductItemByCompanyId失败,ERR:", tmpErr))
- return
- }
- var shareSellerId int
- var shareSellerName string
- if companyProductItem.IsShare == 1 {
- shareSellerId = companyProductItem.ShareSellerId
- shareSellerName = companyProductItem.ShareSeller
- }
- item := &company.CompanyRenewalRecord{
- Id: 0,
- CompanyId: contractInfo.CompanyId,
- ProductId: contractInfo.ProductId,
- Source: source,
- SellerId: companyProductItem.SellerId,
- SellerName: companyProductItem.SellerName,
- ShareSellerId: shareSellerId,
- ShareSellerName: shareSellerName,
- CreateTime: time.Now(),
- ModifyTime: time.Now(),
- }
- tmpErr = item.Add()
- if tmpErr != nil {
- err = errors.New(fmt.Sprint("合同id:", contractInfo.CompanyContractId, ";添加续约异常记录失败,ERR:", tmpErr))
- }
- return
- }
- func afterReject(companyApprovalId, opUserId int, opUserName, remark string) (err error) {
- defer func() {
- if err != nil {
- fmt.Println("异常提醒:"+utils.RunMode, "客户审批失败后,客户操作异常,ERR:"+err.Error()+"", utils.EmailSendToUsers)
- go alarm_msg.SendAlarmMsg("客户审批驳回后,客户操作异常,Err:"+err.Error(), 3)
-
- }
- }()
-
- recodeInfo, err := company.GetCompanyApprovalByApprovalId(companyApprovalId)
- if err != nil {
- err = errors.New("获取合同信息失败,Err:" + err.Error())
- return
- }
- if recodeInfo == nil {
- err = errors.New("客户单异常,找不到客户单信息")
- return
- }
-
- companyInfo, err := company.GetCompanyById(recodeInfo.CompanyId)
- if err != nil {
- err = errors.New("获取合同信息失败,Err:" + err.Error())
- return
- }
- if companyInfo == nil {
- err = errors.New("客户信息异常,找不到客户信息")
- return
- }
-
- companyProduct, err := company.GetCompanyProductByCompanyIdAndProductId(recodeInfo.CompanyId, recodeInfo.ProductId)
- if err != nil {
- err = errors.New(fmt.Sprint("获取信息客户产品失败", ";Err:"+err.Error()))
- return
- }
- if companyProduct == nil {
- err = errors.New("获取信息客户产品失败2")
- return
- }
- approveStatus := "驳回"
- err = company.ApproveRefuse(recodeInfo.CompanyId, recodeInfo.ProductId, approveStatus, remark)
- if err != nil {
- err = errors.New("客户单审批驳回失败,Err:" + err.Error())
- return
- }
-
- {
- productLog := new(company.CompanyProductLog)
- productLog.CompanyProductId = companyProduct.CompanyProductId
- productLog.CompanyId = companyProduct.CompanyId
- productLog.ProductId = companyProduct.ProductId
- productLog.ProductName = companyProduct.ProductName
- productLog.CompanyName = companyProduct.CompanyName
- productLog.CompanyName = companyProduct.CompanyName
- productLog.Source = companyProduct.Source
- productLog.Reasons = companyProduct.Reasons
- productLog.Status = companyProduct.Status
- productLog.IndustryId = companyProduct.IndustryId
- productLog.IndustryName = companyProduct.IndustryName
- productLog.SellerId = companyProduct.SellerId
- productLog.SellerName = companyProduct.SellerName
- productLog.GroupId = companyProduct.GroupId
- productLog.DepartmentId = companyProduct.DepartmentId
- productLog.IsSuspend = companyProduct.IsSuspend
- productLog.SuspendTime = companyProduct.SuspendTime
- productLog.ApproveStatus = companyProduct.ApproveStatus
- productLog.FreezeTime = companyProduct.FreezeTime
- productLog.Remark = companyProduct.Remark
- productLog.StartDate = companyProduct.StartDate
- productLog.EndDate = companyProduct.EndDate
- productLog.CreateTime = companyProduct.CreateTime
- productLog.ModifyTime = companyProduct.ModifyTime
- productLog.LoseReason = companyProduct.LoseReason
- productLog.LossTime = companyProduct.LossTime
- productLog.LogType = "modify"
- productLog.LogCreateTime = time.Now()
- productLog.AdminId = opUserId
- go company.AddCompanyProductLog(productLog)
- }
-
- {
- remark := "审批"
- operation := "approve"
- approveContent := "审批驳回"
- services.AddCompanyOperationRecord(recodeInfo.CompanyId, companyProduct.SellerId, opUserId, recodeInfo.ProductId, opUserId, companyProduct.CompanyName,
- companyProduct.ProductName, opUserName, remark, operation, approveContent, opUserName, remark, companyProduct.Status)
- }
- return
- }
- func CheckApproveAuth(companyId, productId int, opUser *system.Admin) (approvalItem *company.CompanyApproval, approvalInfo *contract.ContractApproval, approvalRecord *contract.ContractApprovalRecord, err error) {
-
- approvalItem, err = company.GetCompanyApprovalById(companyId, productId)
- if err != nil {
- err = errors.New("获取客户单失败,Err:" + err.Error())
- return
- }
-
- if approvalItem.ApproveStatus != "待审批" {
- err = errors.New("客户单状态异常,不允许操作申请,当前客户单状态:" + approvalItem.ApproveStatus)
- return
- }
-
- approvalInfo, err = contract.GetLastContractApprovalByContractId(approvalItem.CompanyApprovalId, "company")
- if err != nil {
- err = errors.New("获取审批单失败,Err:" + err.Error())
- return
- }
- if approvalInfo.Status != "待审批" {
- err = errors.New("当前审批单状态异常,不允许审批,审批单状态:" + approvalInfo.Status)
- return
- }
-
- approvalRecordList, err := contract.GetContractApprovalRecordListByContractApprovalIdAndNodeId(approvalInfo.ContractApprovalId, approvalInfo.CurrNodeId)
- if err != nil {
- err = errors.New("获取审批失败,Err:" + err.Error())
- return
- }
- for _, tmpApprovalRecord := range approvalRecordList {
- if tmpApprovalRecord.NodeType == "check" && tmpApprovalRecord.ApproveUserId == opUser.AdminId {
- approvalRecord = tmpApprovalRecord
- }
- }
- if approvalRecord == nil {
- err = errors.New("当前账号没有审批权限")
- return
- }
- return
- }
|