123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509 |
- package seal
- import (
- "errors"
- "fmt"
- "hongze/hongze_mobile_admin/models/custom"
- sealResp "hongze/hongze_mobile_admin/models/response/seal"
- "hongze/hongze_mobile_admin/models/tables/admin"
- "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/seal"
- "hongze/hongze_mobile_admin/services"
- contractService "hongze/hongze_mobile_admin/services/contract"
- "hongze/hongze_mobile_admin/utils"
- "mime/multipart"
- "strings"
- "time"
- )
- func AddSeal(userId, contractId, fileNum int, userName, use, useCompanyName, companyName, creditCode, serviceType, sealType, remark, fileUrl string) (sealInfo *seal.Seal, err error) {
- if !strings.Contains(strings.Join(seal.EnumUse, ","), use) {
- err = errors.New("用印用途异常")
- return
- }
- if !strings.Contains(strings.Join(seal.EnumServiceType, ","), serviceType) {
- err = errors.New("业务类型异常")
- return
- }
- sealCode, err := seal.GetSealCode()
- if err != nil {
- return
- }
- sealInfo = &seal.Seal{
- Code: sealCode,
- UserId: userId,
- UserName: userName,
- Use: use,
- CompanyName: companyName,
- UseCompanyName: useCompanyName,
- CreditCode: creditCode,
- ServiceType: serviceType,
- SealType: sealType,
- Status: "待提交",
- Remark: remark,
- FileUrl: fileUrl,
- FileNum: fileNum,
- ContractId: contractId,
- ModifyTime: time.Now(),
- CreateTime: time.Now(),
- }
- err = seal.AddSeal(sealInfo)
- if err != nil {
- err = errors.New("新增用印失败")
- return
- }
-
- err = seal.AddSealOperationRecord(sealInfo.SealId, userId, 0, "apply", userName, "提交审批", "")
- if err != nil {
- err = errors.New("新增用印日志失败")
- return
- }
- return
- }
- func Edit(sealId, userId, contractId, fileNum int, use, companyName, userCompanyName, creditCode, serviceType, sealType, remark, fileUrl, userName string) (sealInfo *seal.Seal, err error) {
- if !strings.Contains(strings.Join(seal.EnumUse, ","), use) {
- err = errors.New("用印用途异常")
- return
- }
- if !strings.Contains(strings.Join(seal.EnumServiceType, ","), serviceType) {
- err = errors.New("业务类型异常")
- return
- }
-
- sealInfo, err = seal.GetSealInfoById(sealId)
- if err != nil {
- if err.Error() == utils.ErrNoRow() {
- err = errors.New(fmt.Sprint("根据用印编号:", sealId, " 找不到该用印"))
- }
- return
- }
- if sealInfo.UserId != userId {
- err = errors.New("当前账号无操作权限")
- return
- }
- ignoreStatus := []string{"待提交", "已撤回", "已驳回"}
- if !strings.Contains(strings.Join(ignoreStatus, ","), sealInfo.Status) {
- err = errors.New("用印状态异常,不允许修改,当前用印状态:" + sealInfo.Status)
- return
- }
-
- sealInfo.Use = use
- sealInfo.CompanyName = companyName
- sealInfo.UseCompanyName = userCompanyName
- sealInfo.CreditCode = creditCode
- sealInfo.ServiceType = serviceType
- sealInfo.SealType = sealType
- sealInfo.Remark = remark
- sealInfo.FileUrl = fileUrl
- sealInfo.FileNum = fileNum
- sealInfo.ContractId = contractId
- sealInfo.CreateTime = time.Now()
- sealInfo.ModifyTime = time.Now()
- sealInfo.Status = "待提交"
- err = sealInfo.Update([]string{"Use", "CompanyName", "UseCompanyName", "CreditCode", "ServiceType", "SealType", "Remark", "FileUrl", "FileNum", "ContractId", "CreateTime", "ModifyTime", "Status"})
- if err != nil {
- err = errors.New("新增用印日志失败")
- return
- }
-
- err = seal.AddSealOperationRecord(sealInfo.SealId, userId, 0, "edit", userName, "重提审批", "")
- if err != nil {
- err = errors.New("编辑用印日志失败")
- return
- }
- return
- }
- func CheckEdit(sealInfo *seal.Seal, approvalInfo *contract_approval.ContractApproval, approvalRecord *contract_approval_record.ContractApprovalRecord, fileNum int, fileUrl, use, sealType, remark string, opUser *custom.AdminWx) (err error) {
- if !strings.Contains(strings.Join(seal.EnumUse, ","), use) {
- err = errors.New("用印用途异常")
- return
- }
-
- if opUser.RoleTypeCode != utils.ROLE_TYPE_CODE_COMPLIANCE {
- err = errors.New("当前账号无修改权限")
- return
- }
-
- if sealInfo.Status != "待审批" {
- err = errors.New("用印状态异常,不允许修改,当前用印状态:" + sealInfo.Status)
- return
- }
-
- updateCol := make([]string, 0)
- updateContent := make([]string, 0)
- if sealInfo.Use != use {
- updateCol = append(updateCol, "Use")
- updateContent = append(updateContent, "用印用途")
- }
- if sealInfo.SealType != sealType {
- updateCol = append(updateCol, "SealType")
- updateContent = append(updateContent, "加盖何种印章")
- }
- if sealInfo.Remark != remark {
- updateCol = append(updateCol, "Remark")
- updateContent = append(updateContent, "备注")
- }
- if sealInfo.FileNum != fileNum {
- updateCol = append(updateCol, "FileNum")
- updateContent = append(updateContent, "文件份数")
- }
- if sealInfo.FileUrl != fileUrl {
- updateCol = append(updateCol, "FileUrl")
- updateContent = append(updateContent, "文件附件")
- }
- fmt.Println(updateCol)
- if len(updateCol) <= 0 {
- err = errors.New("没有变更信息")
- return
- }
- content := "用印修改:" + opUser.RealName + "修改了" + strings.Join(updateContent, "、")
-
- originFlowType := GetFlowTypeBySealType(sealInfo.SealType)
- reqFlowType := GetFlowTypeBySealType(sealType)
-
-
-
- if originFlowType != reqFlowType {
-
- err = CheckReject(sealInfo, approvalInfo, approvalRecord, opUser, "")
- if err != nil {
- return
- }
-
- sealInfo.Use = use
- sealInfo.SealType = sealType
- sealInfo.Remark = remark
- sealInfo.FileNum = fileNum
- sealInfo.FileUrl = fileUrl
- sealInfo.ModifyTime = time.Now()
- checkEdit(sealInfo, updateCol, approvalRecord.ContractApprovalRecordId, content, opUser)
-
- sealInfo, tmpErr := seal.GetSealInfoById(sealInfo.SealId)
- if tmpErr != nil {
- err = tmpErr
- return
- }
-
- err = CheckApply(sealInfo, opUser)
- if err != nil {
- return
- }
- } else {
-
- sealInfo.Use = use
- sealInfo.SealType = sealType
- sealInfo.Remark = remark
- sealInfo.FileNum = fileNum
- sealInfo.FileUrl = fileUrl
- sealInfo.ModifyTime = time.Now()
- checkEdit(sealInfo, updateCol, approvalRecord.ContractApprovalRecordId, content, opUser)
-
- err = Approved(sealInfo, approvalInfo, approvalRecord, opUser, "")
- }
- return
- }
- func checkEdit(sealInfo *seal.Seal, updateCol []string, approvalRecordId int, content string, opUser *custom.AdminWx) {
- _ = sealInfo.Update(updateCol)
-
- _ = seal.AddSealOperationRecord(sealInfo.SealId, opUser.AdminId, approvalRecordId, "edit", opUser.RealName, "审批人修改信息", "")
-
- sysUserMobile := ""
- sysUser, _ := admin.GetAdminById(opUser.AdminId)
- if sysUser != nil {
- sysUserMobile = sysUser.Mobile
- }
- go services.AddCompanyApprovalMessage(opUser.AdminId, sealInfo.UserId, 0, approvalRecordId, 3, sourceType, 2, sealInfo.CompanyName, content, content, sysUserMobile)
- return
- }
- func Invalid(sealId int, opUser *custom.AdminWx, isInvalidContract bool) (err error) {
-
- sealInfo, err := seal.GetSealInfoById(sealId)
- if err != nil {
- if err.Error() == utils.ErrNoRow() {
- err = errors.New(fmt.Sprint("根据用印编号:", sealId, " 找不到初始用印"))
- }
- return
- }
- if sealInfo.UserId != opUser.AdminId && opUser.RoleTypeCode != utils.ROLE_TYPE_CODE_COMPLIANCE {
- err = errors.New("当前账号无操作权限")
- return
- }
- if sealInfo.Status != "已审批" {
- err = errors.New("用印状态异常,不允许作废,当前用印状态:" + sealInfo.Status)
- return
- }
-
- if sealInfo.IsDelete > 0 {
- err = errors.New("该用印已删除")
- return
- }
-
- err = seal.Invalid(sealInfo)
- if err != nil {
- return
- }
-
- err = seal.AddSealOperationRecord(sealInfo.SealId, opUser.AdminId, 0, "invalid", opUser.RealName, "作废审批", "")
- if err != nil {
- err = errors.New("新增用印日志失败")
- return
- }
-
- if sealInfo.ContractId > 0 && isInvalidContract {
- err = contractService.InvalidContract(sealInfo.ContractId, opUser)
- if err != nil {
- utils.ApiLog.Println("作废用印时,同步作废合同失败,Err:", err.Error())
- }
- }
-
- contractApproval, err := contract_approval.GetLastContractApprovalByContractId(sealInfo.SealId, "seal")
- if err != nil {
- err = nil
- return
- }
-
- if contractApproval != nil {
-
- contractApprovalRecordList, tmpErr := contract_approval_record.GetContractApprovalRecordListByContractApprovalId(contractApproval.ContractApprovalId)
- if tmpErr != nil {
- return
- }
- content := fmt.Sprint("作废", sealInfo.CompanyName, "用印申请")
- for _, contractApprovalRecord := range contractApprovalRecordList {
- if contractApprovalRecord.NodeType == "check" {
-
- sysUserMobile := ""
- sysUser, _ := admin.GetAdminById(contractApprovalRecord.ApproveUserId)
- if sysUser != nil {
- sysUserMobile = sysUser.Mobile
- }
- go services.AddCompanyApprovalMessage(opUser.AdminId, contractApprovalRecord.ApproveUserId, 0, contractApprovalRecord.ContractApprovalRecordId, 3, sourceType, 2, sealInfo.CompanyName, content, content, sysUserMobile)
- }
- }
- }
-
-
-
- return
- }
- func UploadCheckBackFileByFile(sealId int, ext string, fileMulti multipart.File, opUser *custom.AdminWx) (sealInfo *seal.Seal, err error) {
-
- sealInfo, err = seal.GetSealInfoById(sealId)
- if err != nil {
- return
- }
-
- if sealInfo.Status != "已审批" && sealInfo.Status != "已签回" {
- err = errors.New("用印状态异常,不允许上传签回用印附件,当前用印状态:" + sealInfo.Status)
- return
- }
- fileName := ``
-
- fileName = sealInfo.CompanyName + "_" + sealInfo.Code + "(签回)"
- if sealInfo.ContractId > 0 {
-
- contractInfo, tmpErr := contract.GetContractById(sealInfo.ContractId)
- if tmpErr != nil {
- err = tmpErr
- return
- }
-
- fileName = contractInfo.CompanyName + "_" + contractInfo.ContractCode + "(签回)"
- }
-
- if utils.RunMode != "release" {
- fileName += "_" + utils.GetRandStringNoSpecialChar(10)
- }
- fileName += ext
-
- resourceUrl, err := services.UploadToOssAndFileName(fileMulti, fileName)
- if err != nil {
- err = errors.New("文件保存失败,Err:" + err.Error())
- return
- }
- sealInfo.CheckBackFileUrl = resourceUrl
- sealInfo.Status = "已签回"
- sealInfo.ModifyTime = time.Now()
- sealInfo.CheckBackFileTime = time.Now()
- err = sealInfo.Update([]string{"CheckBackFileUrl", "Status", "ModifyTime", "CheckBackFileTime"})
- if err != nil {
- return
- }
- return
- }
- func UploadCheckBackFile(sealId int, fileUrl string, opUser *custom.AdminWx) (sealInfo *seal.Seal, err error) {
-
- sealInfo, err = seal.GetSealInfoById(sealId)
- if err != nil {
- return
- }
-
- if sealInfo.Status != "已审批" && sealInfo.Status != "已签回" {
- err = errors.New("用印状态异常,不允许上传签回用印附件,当前用印状态:" + sealInfo.Status)
- return
- }
- sealInfo.CheckBackFileUrl = fileUrl
- sealInfo.Status = "已签回"
- sealInfo.ModifyTime = time.Now()
- sealInfo.CheckBackFileTime = time.Now()
- err = sealInfo.Update([]string{"CheckBackFileUrl", "Status", "ModifyTime", "CheckBackFileTime"})
- if err != nil {
- return
- }
- return
- }
- func GetOpButton(sealInfo *seal.Seal, contractApprovalInfo *contract_approval.ContractApproval, opUser *custom.AdminWx) (sealOpButton sealResp.OpButton, flowNodeListResp [][]contract_approval_record.ContractApprovalRecord, err error) {
-
- approvalRecordList, err := contract_approval_record.GetContractApprovalRecordListByContractApprovalId(contractApprovalInfo.ContractApprovalId)
- if err != nil {
- err = errors.New("获取审批失败,Err:" + err.Error())
- return
- }
-
- if contractApprovalInfo.Status == "待审批" {
- if contractApprovalInfo.ApplyUserId == opUser.AdminId && contractApprovalInfo.CurrNodeId > contractApprovalInfo.StartNodeId {
- sealInfo.Status = "处理中"
- }
- }
- flowNodeMap := make(map[int][]contract_approval_record.ContractApprovalRecord, 0)
- keySort := make([]int, 0)
- for _, approvalRecord := range approvalRecordList {
-
- if contractApprovalInfo.CurrNodeId == approvalRecord.NodeId && contractApprovalInfo.Status == "待审批" {
- if opUser.AdminId == approvalRecord.ApproveUserId && approvalRecord.NodeType == "check" {
- sealOpButton.Approval = true
- }
-
- if opUser.AdminId == approvalRecord.ApproveUserId && opUser.RoleTypeCode == utils.ROLE_TYPE_CODE_COMPLIANCE && approvalRecord.NodeType == "check" {
- sealOpButton.CheckEdit = true
- }
- }
-
- if contractApprovalInfo.CurrNodeId == approvalRecord.NodeId && approvalRecord.PrevNodeId == 0 && contractApprovalInfo.Status == "待审批" {
-
- if opUser.AdminId == sealInfo.UserId {
- sealOpButton.Cancel = true
- }
- }
- if tmpFlowNodeList, ok := flowNodeMap[approvalRecord.NodeId]; ok {
- flowNodeMap[approvalRecord.NodeId] = append(tmpFlowNodeList, *approvalRecord)
- } else {
- tmpFlowNodeList := make([]contract_approval_record.ContractApprovalRecord, 1)
- tmpFlowNodeList[0] = *approvalRecord
- flowNodeMap[approvalRecord.NodeId] = tmpFlowNodeList
- keySort = append(keySort, approvalRecord.NodeId)
- }
-
- if contractApprovalInfo.Status == "待审批" {
- if approvalRecord.ApproveUserId == opUser.AdminId && approvalRecord.NodeId < contractApprovalInfo.CurrNodeId && approvalRecord.NodeType != "cc" {
- sealInfo.Status = "处理中"
- }
- }
- }
- for _, key := range keySort {
- flowNodeListResp = append(flowNodeListResp, flowNodeMap[key])
- }
-
- if opUser.AdminId == sealInfo.UserId && sealInfo.Status == "已审批" {
- sealOpButton.Invalid = true
- }
-
- uploadStatus := []string{"已审批", "已签回"}
- if opUser.RoleTypeCode == utils.ROLE_TYPE_CODE_COMPLIANCE && strings.Contains(strings.Join(uploadStatus, ","), sealInfo.Status) {
- sealOpButton.UploadFile = true
- }
-
- editStatus := []string{"已驳回", "待提交", "已撤回"}
- if opUser.AdminId == sealInfo.UserId && strings.Contains(strings.Join(editStatus, ","), sealInfo.Status) {
- sealOpButton.Edit = true
- }
- return
- }
- func GetSealDetailBySealId(sealId int, opUser *custom.AdminWx) (sealInfo *seal.Seal, flowNodeListResp [][]contract_approval_record.ContractApprovalRecord, opButton sealResp.OpButton, err error) {
- sealInfo, err = seal.GetSealInfoById(sealId)
- if err != nil {
- err = errors.New("获取合同详情失败,ERR:" + err.Error())
- return
- }
-
- lastApprovalInfo, err := contract_approval.GetLastContractApprovalByContractId(sealInfo.SealId, "seal")
- if err != nil {
- if err.Error() != utils.ErrNoRow() {
- err = errors.New("获取最近一次审批单信息失败,ERR:" + err.Error())
- }
- err = nil
- return
- }
- if lastApprovalInfo != nil {
-
- tmpSealOpButton, tmpFlowNodeListResp, tmpErr := GetOpButton(sealInfo, lastApprovalInfo, opUser)
- if tmpErr != nil {
- err = errors.New("获取用印按钮权限、审批流程失败,Err:" + tmpErr.Error())
- return
- }
- opButton = tmpSealOpButton
- flowNodeListResp = tmpFlowNodeListResp
- }
- return
- }
|