contract.go 6.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187
  1. package contract
  2. import (
  3. "errors"
  4. "fmt"
  5. "hongze/hongze_mobile_admin/models/custom"
  6. contractCustom "hongze/hongze_mobile_admin/models/custom/contract"
  7. contractResp "hongze/hongze_mobile_admin/models/response/contract"
  8. "hongze/hongze_mobile_admin/models/tables/contract"
  9. "hongze/hongze_mobile_admin/models/tables/contract_approval"
  10. "hongze/hongze_mobile_admin/models/tables/contract_approval_record"
  11. "hongze/hongze_mobile_admin/models/tables/contract_operation_record"
  12. "hongze/hongze_mobile_admin/models/tables/contract_service_detail"
  13. "hongze/hongze_mobile_admin/utils"
  14. "strings"
  15. "time"
  16. )
  17. //作废合同
  18. func InvalidContract(contractId int, opUser *custom.AdminWx) (err error) {
  19. //查询当前合同信息
  20. nowContract, err := contract.GetContractById(contractId)
  21. if err != nil {
  22. if err.Error() == utils.ErrNoRow() {
  23. err = errors.New(fmt.Sprint("根据合同编号:", contractId, " 找不到初始合同"))
  24. }
  25. return
  26. }
  27. if nowContract.SellerId != opUser.AdminId && opUser.RoleTypeCode != utils.ROLE_TYPE_CODE_COMPLIANCE {
  28. err = errors.New("当前账号无操作权限")
  29. return
  30. }
  31. if nowContract.Status != "已审批" {
  32. err = errors.New("合同状态异常,不允许作废,当前合同状态:" + nowContract.Status)
  33. return
  34. }
  35. //如果删除状态 >0,那么代表已经被删除了
  36. if nowContract.IsDelete > 0 {
  37. err = errors.New("该合同已删除")
  38. return
  39. }
  40. //合同作废
  41. err = contract.InvalidContract(nowContract)
  42. if err != nil {
  43. return
  44. }
  45. //添加操作日志
  46. remark := "作废合同模板"
  47. _ = contract_operation_record.AddContractOperationRecord(nowContract.ContractId, opUser.AdminId, 0, "invalid", opUser.RealName, remark)
  48. return
  49. }
  50. //根据id获取合同详情(包含服务)
  51. func GetContractDetail(contractId int) (contractDetail *contract.ContractDetail, err error) {
  52. contractDetail, err = contract.GetContractDetailById(contractId)
  53. if err != nil {
  54. if err.Error() == utils.ErrNoRow() {
  55. err = errors.New("找不到该合同")
  56. }
  57. return
  58. }
  59. serviceList, err := contractCustom.GetContractServiceAndDetailList(contractId)
  60. if err != nil {
  61. err = errors.New(fmt.Sprint("查找合同服务异常", err))
  62. return
  63. }
  64. for i := 0; len(serviceList) > i; i++ {
  65. if serviceList[i].HasDetail == "是" {
  66. list, detailErr := contract_service_detail.GetContractServiceDetailListByServiceId(serviceList[i].ContractServiceId)
  67. if detailErr != nil {
  68. err = errors.New(fmt.Sprint("查找合同服务详情异常", detailErr))
  69. return
  70. }
  71. serviceList[i].DetailList = list
  72. }
  73. }
  74. contractDetail.Service = serviceList
  75. return
  76. }
  77. //上传签回合同附件
  78. func UploadCheckBackFile(contractId int, fileUrl string, opUser *custom.AdminWx) (err error) {
  79. //获取合同信息
  80. contractInfo, err := contract.GetContractById(contractId)
  81. if err != nil {
  82. return
  83. }
  84. //合同状态判断
  85. if contractInfo.Status != "已审批" && contractInfo.Status != "已签回" {
  86. err = errors.New("合同状态异常,不允许上传签回合同附件,当前合同状态:" + contractInfo.Status)
  87. return
  88. }
  89. contractInfo.CheckBackFileUrl = fileUrl
  90. contractInfo.Status = "已签回"
  91. contractInfo.ModifyTime = time.Now()
  92. contractInfo.CheckBackFileTime = time.Now()
  93. err = contractInfo.Update([]string{"CheckBackFileUrl", "Status", "ModifyTime", "CheckBackFileTime"})
  94. if err != nil {
  95. return
  96. }
  97. //添加操作日志
  98. remark := "上传签回合同附件"
  99. _ = contract_operation_record.AddContractOperationRecord(contractInfo.ContractId, opUser.AdminId, 0, "upload", opUser.RealName, remark)
  100. return
  101. }
  102. //获取审批流和权限
  103. func GetOpButton(contractInfo *contract.ContractDetail, contractApprovalInfo *contract_approval.ContractApproval, opUser *custom.AdminWx) (contractOpButton contractResp.OpButton, flowNodeListResp [][]contract_approval_record.ContractApprovalRecord, err error) {
  104. //审批流
  105. approvalRecordList, err := contract_approval_record.GetContractApprovalRecordListByContractApprovalId(contractApprovalInfo.ContractApprovalId)
  106. if err != nil {
  107. err = errors.New("获取审批失败,Err:" + err.Error())
  108. return
  109. }
  110. flowNodeMap := make(map[int][]contract_approval_record.ContractApprovalRecord, 0)
  111. keySort := make([]int, 0)
  112. for _, approvalRecord := range approvalRecordList {
  113. //如果当前节点正好是该节点,同时审批单状态是待审批状态,然后当前账号又有权限,该账号也正是审批人,那么允许审批操作
  114. if contractApprovalInfo.CurrNodeId == approvalRecord.NodeId && contractApprovalInfo.Status == "待审批" {
  115. if opUser.AdminId == approvalRecord.ApproveUserId && approvalRecord.NodeType == "check" {
  116. contractOpButton.Approval = true
  117. }
  118. }
  119. if tmpFlowNodeList, ok := flowNodeMap[approvalRecord.NodeId]; ok {
  120. flowNodeMap[approvalRecord.NodeId] = append(tmpFlowNodeList, *approvalRecord)
  121. } else {
  122. tmpFlowNodeList := make([]contract_approval_record.ContractApprovalRecord, 1)
  123. tmpFlowNodeList[0] = *approvalRecord
  124. flowNodeMap[approvalRecord.NodeId] = tmpFlowNodeList
  125. keySort = append(keySort, approvalRecord.NodeId)
  126. }
  127. }
  128. for _, key := range keySort {
  129. flowNodeListResp = append(flowNodeListResp, flowNodeMap[key])
  130. }
  131. //是否具有签回合同权限
  132. uploadStatus := []string{"已审批", "已签回"}
  133. if opUser.RoleTypeCode == utils.ROLE_TYPE_CODE_COMPLIANCE && strings.Contains(strings.Join(uploadStatus, ","), contractInfo.Status) {
  134. contractOpButton.UploadFile = true
  135. }
  136. //作废权限
  137. if (opUser.RoleTypeCode == utils.ROLE_TYPE_CODE_COMPLIANCE || opUser.AdminId == contractInfo.SellerId) && contractInfo.Status == "已审批" {
  138. contractOpButton.Invalid = true
  139. }
  140. return
  141. }
  142. //根据合同获取合同详情
  143. func GetContractDetailByContractId(contractId int, opUser *custom.AdminWx) (contractInfo *contract.ContractDetail, flowNodeListResp [][]contract_approval_record.ContractApprovalRecord, opButton contractResp.OpButton, err error) {
  144. contractInfo, err = GetContractDetail(contractId)
  145. if err != nil {
  146. err = errors.New("获取合同详情失败,ERR:" + err.Error())
  147. return
  148. }
  149. contractInfo.StartDateStr = contractInfo.StartDate.Format(utils.FormatDate)
  150. contractInfo.EndDateStr = contractInfo.EndDate.Format(utils.FormatDate)
  151. contractInfo.ModifyTimeStr = contractInfo.ModifyTime.Format(utils.FormatDateTime)
  152. contractInfo.CreateTimeStr = contractInfo.CreateTime.Format(utils.FormatDateTime)
  153. //查询最近一次审批单信息
  154. lastApprovalInfo, err := contract_approval.GetLastContractApprovalByContractId(contractInfo.ContractId, "contract")
  155. if err != nil {
  156. if err.Error() != utils.ErrNoRow() {
  157. err = errors.New("获取最近一次审批单信息失败,ERR:" + err.Error())
  158. }
  159. err = nil
  160. return
  161. }
  162. if lastApprovalInfo != nil {
  163. //审批操作权限,上传签回文件权限
  164. tmpContractOpButton, tmpFlowNodeListResp, tmpErr := GetOpButton(contractInfo, lastApprovalInfo, opUser)
  165. if tmpErr != nil {
  166. err = errors.New("获取合同按钮权限、审批流程失败,ERR:" + tmpErr.Error())
  167. return
  168. }
  169. opButton = tmpContractOpButton
  170. flowNodeListResp = tmpFlowNodeListResp
  171. }
  172. return
  173. }