123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134 |
- 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 {
-
-
- 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 := "审批通过"
- if companyProduct.InitStatus == utils.COMPANY_STATUS_FOREVER && companyProduct.ProductId == 2 {
-
- endDateContent := utils.GetLastDayOfQuarter(time.Now()).Format(utils.FormatDate)
- approveContent += ",试用延期至" + endDateContent
- }
- 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
- }
|