123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669 |
- package contract
- import (
- "encoding/json"
- "errors"
- "fmt"
- "hongze/hongze_mobile_admin/models/custom"
- "hongze/hongze_mobile_admin/models/tables/admin"
- "hongze/hongze_mobile_admin/models/tables/approval_flow"
- "hongze/hongze_mobile_admin/models/tables/approval_flow_node"
- "hongze/hongze_mobile_admin/models/tables/company"
- "hongze/hongze_mobile_admin/models/tables/company_approval_message"
- "hongze/hongze_mobile_admin/models/tables/company_log"
- "hongze/hongze_mobile_admin/models/tables/contract"
- "hongze/hongze_mobile_admin/models/tables/contract_approval"
- "hongze/hongze_mobile_admin/models/tables/contract_approval_record"
- "hongze/hongze_mobile_admin/models/tables/contract_operation_record"
- "hongze/hongze_mobile_admin/services"
- "hongze/hongze_mobile_admin/services/flow"
- "hongze/hongze_mobile_admin/utils"
- "os"
- "strings"
- "time"
- )
- func Apply(contractId int) (err error) {
-
- contractInfo, err := GetContractDetail(contractId)
- if err != nil {
- err = errors.New("获取合同信息失败,Err:" + err.Error())
- return
- }
- if contractInfo == nil {
- err = errors.New("合同异常,没有合同信息")
- return
- }
- contractInfo.StartDateStr = contractInfo.StartDate.Format(utils.FormatDate)
- contractInfo.EndDateStr = contractInfo.EndDate.Format(utils.FormatDate)
- contractInfo.ModifyTimeStr = contractInfo.ModifyTime.Format(utils.FormatDateTime)
- contractInfo.CreateTimeStr = contractInfo.CreateTime.Format(utils.FormatDateTime)
-
- ignoreStatus := []string{"待提交", "已撤回", "已驳回"}
- if !strings.Contains(strings.Join(ignoreStatus, ","), contractInfo.Status) {
- err = errors.New("合同状态异常,不允许提交审批,当前合同状态:" + contractInfo.Status)
- return
- }
-
- applyContent := "生成新模板"
-
-
-
- if contractInfo.Status == "已驳回" {
- applyContent = "驳回重申请"
- }
-
-
-
- contractDetailByte, err := json.Marshal(contractInfo)
- if err != nil {
- err = errors.New(fmt.Sprint("合同状态异常,当前合同数据格式化失败:", err))
- return
- }
-
- var flowItemInfo *approval_flow.ApprovalFlowItem
- if contractInfo.ProductId == 1 {
- tmpFlowItemInfo, tmpErr := flow.GetApprovalFlow(3)
- if tmpErr != nil {
- err = errors.New(fmt.Sprint("查找审批流程配置失败:", tmpErr))
- return
- }
- flowItemInfo = tmpFlowItemInfo
- } else {
- tmpFlowItemInfo, tmpErr := flow.GetApprovalFlow(4)
- if tmpErr != nil {
- err = errors.New(fmt.Sprint("查找审批流程配置失败:", tmpErr))
- return
- }
- flowItemInfo = tmpFlowItemInfo
- }
- fmt.Println(flowItemInfo)
-
- contractApproval := &contract_approval.ContractApproval{
- ContractId: contractInfo.ContractId,
- Status: "待审批",
- ApplyContent: applyContent,
- ContractDetail: string(contractDetailByte),
- ApplyUserId: contractInfo.SellerId,
- ApplyUserName: contractInfo.SellerName,
- FlowId: flowItemInfo.FlowId,
- FlowVersion: flowItemInfo.CurrVersion,
- CurrNodeId: flowItemInfo.NodeList[0].NodeId,
- ModifyTime: time.Now(),
- CreateTime: time.Now(),
- }
- has, err := contractApproval.CheckPendingByContractId(contractInfo.ContractId, "contract")
- if err != nil {
- return
- }
- if has {
- err = errors.New("合同异常,不允许提交审批,存在待审核的审批单")
- return
- }
- contractApprovalRecordList := make([]*contract_approval_record.ContractApprovalRecord, 0)
- ApproveUserMap := make(map[int]approval_flow_node.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_approval_record.ContractApprovalRecord{
- Status: "待审批",
- ApproveRemark: "",
- ApproveUserId: userItem.AdminId,
- ApproveUserName: userItem.Name,
- ApproveRoleTypeCode: userItem.RoleTypeCode,
- NodeId: nodeItem.NodeId,
- NodeType: nodeItem.NodeType,
- NextNodeId: nodeItem.NextNodeId,
- CreateTime: time.Now(),
- ModifyTime: time.Now(),
- }
- contractApprovalRecordList = append(contractApprovalRecordList, contractApprovalRecord)
- ApproveUserMap[userItem.AdminId] = userItem
- }
- }
- err = contractApproval.Apply(contractApproval, contractApprovalRecordList)
- if err != nil {
- return
- }
-
- remark := "提交审批"
- _ = contract_operation_record.AddContractOperationRecord(contractInfo.ContractId, contractInfo.SellerId, contractApprovalRecordList[0].ContractApprovalRecordId, "apply", contractInfo.SellerName, remark)
-
- {
-
- go messageToNodeUser(contractApprovalRecordList[0].NodeId, contractInfo.SellerId, contractApproval.ContractApprovalId, 1, 1, contractInfo.CompanyName, applyContent)
-
- go messageToAllCcUser(contractInfo.SellerId, contractApproval.ContractApprovalId, 1, 1, contractInfo.CompanyName, applyContent)
- }
- return
- }
- func CancelApplyByContract(contractInfo *contract.Contract, opUserId int) (err error) {
- if contractInfo == nil {
- err = errors.New("审批流异常,没有审批流信息")
- return
- }
-
- if contractInfo.Status != "待审批" {
- err = errors.New("合同状态异常,不允许撤回申请,当前合同状态:" + contractInfo.Status)
- return
- }
-
- if contractInfo.SellerId != opUserId {
- err = errors.New("操作人异常,不允许撤回非本人提交的申请:" + contractInfo.Status)
- return
- }
-
- contractApproval, err := contract_approval.GetLastPendingContractApprovalByContractId(contractInfo.ContractId)
- if err != nil {
- return
- }
-
- contractApprovalRecord, err := contract_approval_record.GetCurrContractApprovalRecordByContractId(contractApproval.ContractApprovalId)
- if err != nil {
- return
- }
-
- if contractApprovalRecord.PrevNodeId > 0 {
- err = errors.New("合同已存在审批操作,不允许撤回申请")
- return
- }
-
- contractApprovalRecordList, err := contract_approval_record.GetPendingContractApprovalRecordListByContractId(contractApproval.ContractApprovalId, contractApprovalRecord.NodeId)
- if err != nil {
- return
- }
-
- err = contractApproval.Cancel(contractApproval, contractApprovalRecordList)
- if err != nil {
- return
- }
-
- remark := "撤回申请"
- _ = contract_operation_record.AddContractOperationRecord(contractInfo.ContractId, contractInfo.SellerId, contractApprovalRecord.ContractApprovalRecordId, "cancel_apply", contractInfo.SellerName, remark)
-
- for _, contractApprovalRecord := range contractApprovalRecordList {
- go company_approval_message.CancelCompanyApprovalMessage(contractApprovalRecord.ContractApprovalRecordId, 2)
- }
- return
- }
- func CancelApply(contractApprovalRecord *contract_approval_record.ContractApprovalRecord, opUserId int) (err error) {
- if contractApprovalRecord == nil {
- err = errors.New("审批流异常,没有审批流信息")
- return
- }
-
- if contractApprovalRecord.Status != "待审批" {
- err = errors.New("审批流状态异常,不允许撤回申请,当前审批流状态:" + contractApprovalRecord.Status)
- return
- }
-
- contractApproval, err := contract_approval.GetContractApprovalById(contractApprovalRecord.ContractApprovalId)
- if err != nil {
- return
- }
-
- if contractApproval.Status != "待审批" {
- err = errors.New("审批单状态异常,不允许撤回申请,当前审批单状态:" + contractApproval.Status)
- return
- }
-
- contractInfo, err := contract.GetContractById(contractApproval.ContractId)
- if err != nil {
- return
- }
-
- if contractInfo.Status != "待审批" {
- err = errors.New("合同状态异常,不允许撤回申请,当前合同状态:" + contractInfo.Status)
- return
- }
-
- if contractInfo.SellerId != opUserId {
- err = errors.New("操作人异常,不允许撤回非本人提交的申请:" + contractInfo.Status)
- return
- }
-
- contractApprovalRecordList, err := contract_approval_record.GetPendingContractApprovalRecordListByContractId(contractApproval.ContractApprovalId, contractApprovalRecord.NodeId)
- if err != nil {
- return
- }
- err = contractApproval.Cancel(contractApproval, contractApprovalRecordList)
- if err != nil {
- return
- }
-
- remark := "撤回申请"
- _ = contract_operation_record.AddContractOperationRecord(contractInfo.ContractId, contractInfo.SellerId, contractApprovalRecord.ContractApprovalRecordId, "cancel_apply", contractInfo.SellerName, remark)
-
- go company_approval_message.CancelCompanyApprovalMessage(contractApprovalRecord.ContractApprovalRecordId, 2)
- return
- }
- func Reject(contractApprovalRecord *contract_approval_record.ContractApprovalRecord, opUser *custom.AdminWx, rejectRemark string) (err error) {
- if contractApprovalRecord == nil {
- err = errors.New("审批流异常,没有审批流信息")
- return
- }
-
- if contractApprovalRecord.Status != "待审批" {
- err = errors.New("审批流状态异常,不允许驳回申请,当前审批流状态:" + contractApprovalRecord.Status)
- return
- }
-
- if contractApprovalRecord.NodeType != "check" {
- err = errors.New("当前账号没有审批权限")
- return
- }
-
- opUserId := opUser.AdminId
- opUserName := opUser.RealName
-
- if opUser.RoleTypeCode != contractApprovalRecord.ApproveRoleTypeCode {
- err = errors.New("当前账号没有审批权限")
- return
- }
- if contractApprovalRecord.ApproveUserId > 0 && contractApprovalRecord.ApproveUserId != opUserId {
- err = errors.New("当前账号没有审批权限,需要指定人操作")
- return
- }
-
- contractApproval, err := contract_approval.GetContractApprovalById(contractApprovalRecord.ContractApprovalId)
- if err != nil {
- return
- }
-
- if contractApproval.Status != "待审批" {
- err = errors.New("审批单状态异常,不允许驳回申请,当前审批单状态:" + contractApproval.Status)
- return
- }
-
- contractInfo, err := contract.GetContractById(contractApproval.ContractId)
- if err != nil {
- return
- }
-
- if contractInfo.Status != "待审批" {
- err = errors.New("合同状态异常,不允许驳回申请,当前合同状态:" + contractInfo.Status)
- return
- }
- err = contractApproval.Reject(contractApproval, contractApprovalRecord, opUserId, opUserName, rejectRemark)
- if err != nil {
- return
- }
-
- remark := "驳回申请"
- _ = contract_operation_record.AddContractOperationRecord(contractInfo.ContractId, opUserId, contractApprovalRecord.ContractApprovalRecordId, "reject", opUserName, remark)
-
- {
- content := contractInfo.CompanyName + " 合同模板已驳回"
- approvalSysUser, _ := admin.GetAdminById(contractInfo.SellerId)
- go services.AddCompanyApprovalMessage(opUserId, contractInfo.SellerId, 0, contractApprovalRecord.ContractApprovalRecordId, 2, 2, 3, contractInfo.CompanyName, content, content, approvalSysUser.Mobile)
-
- go messageToAllCcUser(opUserId, contractApprovalRecord.ContractApprovalId, 2, 3, contractInfo.CompanyName, content)
- }
- return
- }
- func Approved(contractApprovalRecord *contract_approval_record.ContractApprovalRecord, opUser *custom.AdminWx, approvedRemark string) (err error) {
- if contractApprovalRecord == nil {
- err = errors.New("审批流异常,没有审批流信息")
- return
- }
-
- if contractApprovalRecord.Status != "待审批" {
- err = errors.New("审批流状态异常,不允许审批,当前审批流状态:" + contractApprovalRecord.Status)
- return
- }
-
- if contractApprovalRecord.NodeType != "check" {
- err = errors.New("当前账号没有审批权限")
- return
- }
-
- opUserId := opUser.AdminId
- opUserName := opUser.RealName
-
- if opUser.RoleTypeCode != contractApprovalRecord.ApproveRoleTypeCode {
- err = errors.New("当前账号没有审批权限")
- return
- }
- if contractApprovalRecord.ApproveUserId > 0 && contractApprovalRecord.ApproveUserId != opUserId {
- err = errors.New("当前账号没有审批权限,需要指定人操作")
- return
- }
-
- contractApproval, err := contract_approval.GetContractApprovalById(contractApprovalRecord.ContractApprovalId)
- if err != nil {
- return
- }
-
- if contractApproval.Status != "待审批" {
- err = errors.New("审批单状态异常,不允许审批,当前审批单状态:" + contractApproval.Status)
- return
- }
-
- contractInfo, err := contract.GetContractById(contractApproval.ContractId)
- if err != nil {
- return
- }
-
- if contractInfo.Status != "待审批" {
- err = errors.New("合同状态异常,不允许审批,当前合同状态:" + contractInfo.Status)
- return
- }
-
- err = contractApproval.Approved(contractApproval, contractApprovalRecord, approvedRemark)
- if err != nil {
- return
- }
-
- remark := "审批通过"
- _ = contract_operation_record.AddContractOperationRecord(contractInfo.ContractId, opUserId, contractApprovalRecord.ContractApprovalRecordId, "approval", opUserName, remark)
-
- content := contractInfo.CompanyName + " 合同模板已审核"
- go messageToAllCcUser(opUserId, contractApprovalRecord.ContractApprovalId, 2, 2, contractInfo.CompanyName, content)
-
- if contractApprovalRecord.NextNodeId == 0 {
-
- {
- content := contractInfo.CompanyName + " 合同模板已审核"
- approvalSysUser, _ := admin.GetAdminById(contractInfo.SellerId)
- go services.AddCompanyApprovalMessage(opUserId, contractInfo.SellerId, 0, contractApprovalRecord.ContractApprovalRecordId, 2, 2, 2, contractInfo.CompanyName, content, content, approvalSysUser.Mobile)
- }
-
- go AfterApproved(contractInfo.ContractId)
- } else {
-
- flowNodeInfo, tmpErr := approval_flow_node.GetByNodeId(contractApprovalRecord.NextNodeId)
- if tmpErr != nil {
- err = tmpErr
- return
- }
-
- if flowNodeInfo.NodeType == "cc" {
- go approvedByCc(approvedRemark, contractApprovalRecord)
- } else {
-
- go messageToNodeUser(contractApprovalRecord.NextNodeId, contractInfo.SellerId, contractApproval.ContractApprovalId, 1, 1, contractInfo.CompanyName, content)
- }
- }
- return
- }
- func approvedByCc(approvedRemark string, sourceContractApprovalRecord *contract_approval_record.ContractApprovalRecord) (err error) {
-
- nextNodeId := 0
-
- contractApprovalRecordList, err := contract_approval_record.GetContractApprovalRecordListByContractIdAndNode(sourceContractApprovalRecord.ContractApprovalId, sourceContractApprovalRecord.NextNodeId)
- if err != nil {
- return
- }
-
- for _, contractApprovalRecord := range contractApprovalRecordList {
- nextNodeId = contractApprovalRecord.NextNodeId
-
- if contractApprovalRecord.Status != "待审批" {
- err = errors.New("审批流状态异常,不允许审批,当前审批流状态:" + contractApprovalRecord.Status)
- return
- }
-
- if contractApprovalRecord.NodeType != "cc" {
- err = errors.New("当前账号不是抄送权限")
- return
- }
- }
-
- contractApproval, err := contract_approval.GetContractApprovalById(sourceContractApprovalRecord.ContractApprovalId)
- if err != nil {
- return
- }
-
- contractInfo, err := contract.GetContractById(contractApproval.ContractId)
- if err != nil {
- return
- }
-
- err = contractApproval.ApprovedByCc(contractApproval, contractApprovalRecordList, approvedRemark, nextNodeId)
- if err != nil {
- return
- }
-
- if nextNodeId == 0 {
-
- {
- content := contractInfo.CompanyName + " 合同模板已审核"
- approvalSysUser, _ := admin.GetAdminById(contractInfo.SellerId)
- go services.AddCompanyApprovalMessage(sourceContractApprovalRecord.ApproveUserId, contractInfo.SellerId, 0, sourceContractApprovalRecord.ContractApprovalRecordId, 2, 2, 2, contractInfo.CompanyName, content, content, approvalSysUser.Mobile)
- }
-
- go AfterApproved(contractInfo.ContractId)
- } else {
-
- flowNodeInfo, tmpErr := approval_flow_node.GetByNodeId(nextNodeId)
- if tmpErr != nil {
- err = tmpErr
- return
- }
-
- if flowNodeInfo.NodeType == "cc" {
- go approvedByCc(approvedRemark, sourceContractApprovalRecord)
- } else {
-
-
- go messageToNodeUser(nextNodeId, contractInfo.SellerId, contractApproval.ContractApprovalId, 1, 1, contractInfo.CompanyName, contractApproval.ApplyContent)
- }
- }
- return
- }
- func messageToNodeUser(flowNodeId, createUserId, contractApprovalId, messageType, approvalStatus int, companyName, content string) (err error) {
-
- contractApprovalRecordList, err := contract_approval_record.GetContractApprovalRecordListByContractIdAndNode(contractApprovalId, flowNodeId)
- if err != nil {
- return
- }
- err = messageToUser(contractApprovalRecordList, createUserId, messageType, approvalStatus, companyName, content)
- return
- }
- func messageToAllCcUser(createUserId, contractApprovalId, messageType, approvalStatus int, companyName, content string) (err error) {
-
- contractApprovalRecordList, err := contract_approval_record.GetContractApprovalRecordListByContractApprovalId(contractApprovalId)
- if err != nil {
- return
- }
- err = messageToUser(contractApprovalRecordList, createUserId, messageType, approvalStatus, companyName, content)
- return
- }
- func messageToUser(contractApprovalRecordList []*contract_approval_record.ContractApprovalRecord, createUserId, messageType, approvalStatus int, companyName, content string) (err error) {
- for _, contractApprovalRecord := range contractApprovalRecordList {
- sysUserMobile := ""
- sysUser, _ := admin.GetAdminById(contractApprovalRecord.ApproveUserId)
- if sysUser != nil {
- sysUserMobile = sysUser.Mobile
- }
-
- receiveUserId := contractApprovalRecord.ApproveUserId
- go services.AddCompanyApprovalMessage(createUserId, receiveUserId, 0, contractApprovalRecord.ContractApprovalRecordId, messageType, 2, approvalStatus, companyName, content, content, sysUserMobile)
- }
- return
- }
- func AfterApproved(contractId int) (err error) {
- defer func() {
- if err != nil {
-
- go utils.SendEmail("异常提醒:"+utils.RunMode, "合同审批通过后,生成pdf失败,ERR:"+err.Error()+"", utils.EmailSendToUsers)
- }
- }()
- contractDetail, err := GetContractDetail(contractId)
- if err != nil {
- return
- }
-
-
- {
-
- contractHtml, tmpErr := services.GetHtmlByContractDetail(contractDetail, "pdf")
- if tmpErr != nil {
- err = tmpErr
- return
- }
-
- pdfPath := fmt.Sprint("./static/word/系统生成合同_", contractId, ".pdf")
- tmpErr = services.Html2Pdf(contractHtml, pdfPath)
- if tmpErr != nil {
- err = tmpErr
- return
- }
- defer os.Remove(pdfPath)
-
- fileName := contractDetail.ContractCode + ".pdf"
-
- resourceUrl, tmpErr := services.UploadAliyun(fileName, pdfPath)
- if tmpErr != nil {
- err = tmpErr
- return
- }
- tmpErr = contract.AddContractPdf(contractId, resourceUrl)
- if tmpErr != nil {
- err = tmpErr
- return
- }
- }
-
- {
-
- companyInfo, tmpErr := company.GetCompanyByCreditCode(contractDetail.CreditCode)
-
- if tmpErr != nil && tmpErr.Error() != utils.ErrNoRow() {
- err = tmpErr
- return
- }
-
- if companyInfo != nil {
- if companyInfo.CompanyName != contractDetail.CompanyName || companyInfo.Province != contractDetail.Province || companyInfo.City != contractDetail.City {
- companyInfo.CompanyName = contractDetail.CompanyName
- companyInfo.Province = contractDetail.Province
- companyInfo.City = contractDetail.City
- companyInfo.Address = contractDetail.Address
- tmpErr = company.ModifyCompany(companyInfo)
- if tmpErr != nil {
- err = tmpErr
- return
- }
-
- {
- companyLog := new(company_log.CompanyLog)
- companyLog.CompanyId = companyInfo.CompanyId
- companyLog.CompanyName = companyInfo.CompanyName
- companyLog.CreditCode = companyInfo.CreditCode
- companyLog.Address = companyInfo.Address
- companyLog.City = companyInfo.City
- companyLog.Province = companyInfo.Province
- companyLog.LastUpdatedTime = companyInfo.LastUpdatedTime
- companyLog.AdminId = 0
- companyLog.LogType = "modify"
- companyLog.LogCreateTime = time.Now()
- go company_log.AddCompanyLog(companyLog)
- }
- }
- }
- }
- return
- }
|