123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784 |
- package contract
- 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"
- "hongze/hz_crm_api/services/flow"
- "hongze/hz_crm_api/utils"
- "math"
- "os"
- "strings"
- "time"
- )
- func Apply(contractId int) (err error, errMsg string) {
-
- contractInfo, err := GetContractDetail(contractId)
- if err != nil {
- err = errors.New("获取合同信息失败,Err:" + err.Error())
- return
- }
- if contractInfo == nil {
- err = errors.New("合同异常,没有合同信息")
- return
- }
-
- if contractInfo.ContractBusinessType == "代付合同" {
- tmpList, tmpErr := contract.GetContractRelationListByPaymentOnBehalfContractId(contractId)
- if tmpErr != nil {
- return
- }
- if len(tmpList) < 0 {
- err = errors.New("未关联业务合同")
- errMsg = "未关联业务合同"
- return
- }
-
- businessContractInfo, tmpErr := contract.GetContractById(tmpList[0].ContractId)
- if tmpErr != nil {
- err = tmpErr
- return
- }
- ok, tmpErr := CheckContractPrice(businessContractInfo, contractInfo.Price)
- if tmpErr != nil {
- err = tmpErr
- return
- }
- if !ok {
- err = errors.New("合同金额异常,不能高于业务合同金额")
- errMsg = "合同金额异常,不能高于业务合同金额"
- 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 := "生成新模板"
-
-
-
- rejectCount, err := contract.GetRejectContractCountByContractId(contractInfo.ContractId, "contract")
- if err != nil {
- if err.Error() == utils.ErrNoRow() {
- err = errors.New(fmt.Sprint("根据合同编号:", contractInfo.ContractId, " 找不到驳回记录"))
- }
- return
- }
- if rejectCount > 0 {
- applyContent = "驳回重申请"
- }
-
- lastContractApproval, err := contract.GetLastContractApprovalByContractIdAndStatus(contractInfo.ContractId, "contract")
- if err != nil && err.Error() != utils.ErrNoRow() {
- return
- }
-
- if lastContractApproval != nil && lastContractApproval.Status == "已审批" {
- applyContent = "修改重审"
- }
-
-
-
- contractDetailByte, err := json.Marshal(contractInfo)
- if err != nil {
- err = errors.New(fmt.Sprint("合同状态异常,当前合同数据格式化失败:", err))
- return
- }
-
- var flowItemInfo *system.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
- }
-
- contractApproval := &contract.ContractApproval{
- ContractId: contractInfo.ContractId,
- Status: "待审批",
- ApprovalType: "contract",
- ApplyContent: applyContent,
- ContractDetail: string(contractDetailByte),
- ApplyUserId: contractInfo.SellerId,
- ApplyUserName: contractInfo.SellerName,
- 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(contractInfo.ContractId, "contract")
- 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
- }
-
- remark := "提交审批"
- _ = contract.AddContractOperationRecord(contractInfo.ContractId, contractInfo.SellerId, contractApprovalRecordList[0].ContractApprovalRecordId, "apply", contractInfo.SellerName, remark)
-
- {
-
- go messageToNodeUser(contractApproval.CurrNodeId, 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.GetLastPendingContractApprovalByContractId(contractInfo.ContractId, "contract")
- if err != nil {
- return
- }
-
- if contractApproval.StartNodeId != contractApproval.CurrNodeId {
- err = errors.New("审批单状态异常,不允许撤回申请,当前审批单已被审批操作,进入了下一级审批节点")
- return
- }
-
- contractApprovalRecord, err := contract.GetCurrContractApprovalRecordByContractId(contractApproval.ContractApprovalId)
- if err != nil {
- return
- }
-
- if contractApprovalRecord.PrevNodeId > 0 {
- err = errors.New("合同已存在审批操作,不允许撤回申请")
- return
- }
-
- contractApprovalRecordList, err := contract.GetPendingContractApprovalRecordListByContractId(contractApproval.ContractApprovalId, contractApprovalRecord.NodeId)
- if err != nil {
- return
- }
-
- err = contractApproval.Cancel(contractApproval, contractApprovalRecordList)
- if err != nil {
- return
- }
-
- remark := "撤回申请"
- _ = contract.AddContractOperationRecord(contractInfo.ContractId, contractInfo.SellerId, contractApprovalRecord.ContractApprovalRecordId, "cancel_apply", contractInfo.SellerName, remark)
-
- for _, contractApprovalRecord := range contractApprovalRecordList {
- go company.CancelCompanyApprovalMessage(contractApprovalRecord.ContractApprovalRecordId, 2)
- }
- return
- }
- func CancelApply(contractApprovalRecord *contract.ContractApprovalRecord, opUserId int) (err error) {
- if contractApprovalRecord == nil {
- err = errors.New("审批流异常,没有审批流信息")
- return
- }
-
- if contractApprovalRecord.Status != "待审批" {
- err = errors.New("审批流状态异常,不允许撤回申请,当前审批流状态:" + contractApprovalRecord.Status)
- return
- }
-
- contractApproval, err := contract.GetContractApprovalById(contractApprovalRecord.ContractApprovalId)
- if err != nil {
- return
- }
-
- if contractApproval.Status != "待审批" {
- err = errors.New("审批单状态异常,不允许撤回申请,当前审批单状态:" + contractApproval.Status)
- return
- }
-
- if contractApproval.StartNodeId != contractApproval.CurrNodeId {
- err = errors.New("审批单状态异常,不允许撤回申请,当前审批单已被审批操作,进入了下一级审批节点")
- 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.GetPendingContractApprovalRecordListByContractId(contractApproval.ContractApprovalId, contractApprovalRecord.NodeId)
- if err != nil {
- return
- }
- err = contractApproval.Cancel(contractApproval, contractApprovalRecordList)
- if err != nil {
- return
- }
-
- remark := "撤回申请"
- _ = contract.AddContractOperationRecord(contractInfo.ContractId, contractInfo.SellerId, contractApprovalRecord.ContractApprovalRecordId, "cancel_apply", contractInfo.SellerName, remark)
-
- go company.CancelCompanyApprovalMessage(contractApprovalRecord.ContractApprovalRecordId, 2)
- return
- }
- func Reject(contractApprovalRecord *contract.ContractApprovalRecord, opUser *system.Admin, 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 contractApprovalRecord.ApproveUserId > 0 && contractApprovalRecord.ApproveUserId != opUserId {
- err = errors.New("当前账号没有审批权限,需要指定人操作")
- return
- }
-
- contractApproval, err := contract.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.AddContractOperationRecord(contractInfo.ContractId, opUserId, contractApprovalRecord.ContractApprovalRecordId, "reject", opUserName, remark)
-
- {
- content := contractInfo.CompanyName + " 合同模板已驳回"
- approvalSysUser, _ := system.GetSysAdminById(contractInfo.SellerId)
- go services.AddCompanyApprovalMessage(opUserId, contractInfo.SellerId, 0, contractApprovalRecord.ContractApprovalRecordId, 2, 2, 3, contractInfo.CompanyName, content, content, approvalSysUser.Mobile)
- }
- return
- }
- func Approved(contractApprovalRecord *contract.ContractApprovalRecord, opUser *system.Admin, 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 contractApprovalRecord.ApproveUserId > 0 && contractApprovalRecord.ApproveUserId != opUserId {
- err = errors.New("当前账号没有审批权限,需要指定人操作")
- return
- }
-
- contractApproval, err := contract.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.AddContractOperationRecord(contractInfo.ContractId, opUserId, contractApprovalRecord.ContractApprovalRecordId, "approval", opUserName, remark)
-
- content := contractInfo.CompanyName + " 合同模板已审核"
-
- if contractApprovalRecord.NextNodeId == 0 {
-
- {
- content := contractInfo.CompanyName + " 合同模板已审核"
- approvalSysUser, _ := system.GetSysAdminById(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 := system.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.ContractApprovalRecord) (err error) {
-
- nextNodeId := 0
-
- contractApprovalRecordList, err := contract.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.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
- }
-
- go messageToNodeUser(contractApprovalRecordList[0].NodeId, contractInfo.SellerId, contractApproval.ContractApprovalId, 1, 1, contractInfo.CompanyName, contractApproval.ApplyContent)
-
- if nextNodeId == 0 {
-
- {
- content := contractInfo.CompanyName + " 合同模板已审核"
- approvalSysUser, _ := system.GetSysAdminById(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 := system.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.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.GetContractApprovalRecordListByContractApprovalId(contractApprovalId)
- if err != nil {
- return
- }
- err = messageToUser(contractApprovalRecordList, createUserId, messageType, approvalStatus, companyName, content)
- return
- }
- func messageToUser(contractApprovalRecordList []*contract.ContractApprovalRecord, createUserId, 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, 0, contractApprovalRecord.ContractApprovalRecordId, messageType, 2, approvalStatus, companyName, content, content, sysUserMobile)
- }
- return
- }
- func AfterApproved(contractId int) (err error) {
- defer func() {
- if err != nil {
-
- go alarm_msg.SendAlarmMsg("合同审批通过后,生成pdf失败,Err"+err.Error(), 3)
- utils.FileLog.Info(fmt.Sprintf("合同id:%d,合同审批通过后,生成pdf失败,Err"+err.Error(), contractId))
-
- }
- }()
- contractDetail, err := GetContractDetail(contractId)
- if err != nil {
- return
- }
-
- if contractDetail.ProductId == 2 {
- mergeList := EquityMergeSubjectAndObject(contractDetail.Service)
- contractDetail.Service = mergeList
- }
-
-
- {
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- wordPath := fmt.Sprint("./static/word/系统生成合同_", contractDetail.ContractId, ".docx")
- tmpErr := services.GenerateWordV2(contractDetail, wordPath)
- if tmpErr != nil {
- err = tmpErr
- return
- }
- defer os.Remove(wordPath)
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- fileName := contractDetail.CompanyName + "_" + contractDetail.ContractCode + ".docx"
-
- if utils.RunMode != "release" {
- fileName = contractDetail.CompanyName + "_" + contractDetail.ContractCode + "_" + utils.GetRandStringNoSpecialChar(10) + ".docx"
- }
-
- resourceUrl, tmpErr := services.UploadAliyunV2(fileName, wordPath)
- 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.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.AddCompanyLog(companyLog)
- }
- }
- }
- }
-
- if contractDetail.ContractBusinessType == "代付合同" {
- go updateContractPaidPriceByPaymentOnBehalfContractId(contractDetail.ContractId, contractDetail.Price)
- }
- return
- }
- func updateContractPaidPriceByPaymentOnBehalfContractId(contractId int, price float64) (err error) {
- tmpList, tmpErr := contract.GetContractRelationListByPaymentOnBehalfContractId(contractId)
- if tmpErr != nil {
- return
- }
- if len(tmpList) < 0 {
- err = errors.New("未关联业务合同")
- return
- }
- updatePriceStr := ``
- if price > 0 {
- updatePriceStr = `+` + fmt.Sprint(price)
- } else {
- updatePriceStr = `-` + fmt.Sprint(math.Abs(price))
- }
- err = contract.UpdateBusinessContractPaidPrice(tmpList[0].ContractId, updatePriceStr)
- return
- }
|