123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140 |
- package company_contract
- import (
- "context"
- "errors"
- "fmt"
- "hongze/hongze_task/models"
- "hongze/hongze_task/models/company"
- "hongze/hongze_task/models/company_approval"
- "hongze/hongze_task/models/company_contract"
- "hongze/hongze_task/services/alarm_msg"
- "hongze/hongze_task/services/cygx"
- "hongze/hongze_task/utils"
- "strings"
- "time"
- )
- // 合同处理
- func HandleCompanyContract(cont context.Context) (err error) {
- defer func() {
- if err != nil {
- //fmt.Println("合同处理 ErrMsg:"+err.Error())
- //go utils.SendEmail(utils.APPNAME+"【"+utils.RunMode+"】"+"失败提醒", "合同处理 ErrMsg:"+err.Error(), utils.EmailSendToUsers)
- go alarm_msg.SendAlarmMsg("合同处理 ErrMsg:"+err.Error(), 3)
- }
- }()
- today := utils.GetToday(utils.FormatDate)
- total, list, err := company_contract.GetStartContractListByStartDate(today)
- if err != nil {
- fmt.Println("HandleCompanyContract Err:" + err.Error())
- utils.FileLog.Info("HandleCompanyContract Err:%s" + err.Error())
- return
- }
- fmt.Sprintln("总共d%条数据待处理", total)
- errorList := make([]string, 0)
- for _, v := range list {
- //fmt.Println(k, v.CompanyId)
- //fmt.Println(v)
- companyApproval, err := company_approval.GetCompanyApprovalByCompanyContractId(v.CompanyContractId)
- if err != nil {
- errorList = append(errorList, fmt.Sprint("合同id:", v.CompanyContractId, ";err:", err))
- continue
- }
- if companyApproval == nil {
- errorList = append(errorList, fmt.Sprint("合同id:", v.CompanyContractId, ";找不到对应的审批单"))
- continue
- }
- //客户产品信息
- companyProduct, err := models.GetCompanyProduct(v.CompanyId, v.ProductId)
- if err != nil {
- errorList = append(errorList, fmt.Sprint("合同id:", v.CompanyContractId, ";寻找客户产品时异常", ";Err:"+err.Error()))
- continue
- }
- if companyProduct == nil {
- errorList = append(errorList, fmt.Sprint("合同id:", v.CompanyContractId, ";寻找客户产品时异常2", ";Err:"+err.Error()))
- continue
- }
- //companyProduct.EndDate
- //格式化客户当前产品结束日期
- //companyProductEndDate, err := time.Parse(utils.FormatDate, companyProduct.EndDate)
- //if err != nil {
- // errorList = append(errorList,fmt.Sprint("合同id:",v.CompanyContractId,";格式化客户当前产品结束时间时异常 err:",err))
- // continue
- //}
- //格式化合同结束日期
- //contractEndDate, err := time.Parse(utils.FormatDate, v.EndDate)
- //if err != nil {
- // errorList = append(errorList,fmt.Sprint("合同id:",v.CompanyContractId,";格式化合同结束日期时异常 err:",err))
- // continue
- //}
- //如果 合同结束日期 小于 客户当前产品结束日期,那么不执行合同内容
- //if contractEndDate.Before(companyProductEndDate) {
- // errorList = append(errorList,fmt.Sprint("合同id:",v.CompanyContractId,";合同结束日期 小于 客户当前产品结束日期,不执行该合同内容"))
- // continue
- //}
- //申请类型:1:试用->正式,2:冻结—>试用,3:试用延期,4:原销售申请领取流失客户,5:正式客户申请服务更新
- switch companyApproval.ApplyMethod {
- case 1:
- e := company.TryOutToFormal(v.CompanyId, v.ProductId, utils.AdminId, v.CompanyContractId, v.StartDate, v.EndDate, utils.RealName, v.ProductName, v.PackageType, v.RaiPackageType)
- if e != nil {
- errorList = append(errorList, fmt.Sprint("合同id:", v.CompanyContractId, ";TryOutToFormal Err: ", e.Error()))
- }
- case 5, 6:
- e := company.ApplyServiceUpdate(v.CompanyId, v.ProductId, utils.AdminId, v.CompanyContractId, v.StartDate, v.EndDate, utils.RealName, v.ProductName, v.PackageType, v.RaiPackageType)
- if e != nil {
- errorList = append(errorList, fmt.Sprint("合同id:", v.CompanyContractId, ";ApplyServiceUpdate Err: ", e.Error()))
- }
- default:
- errorList = append(errorList, fmt.Sprint("合同id:", v.CompanyContractId, ";审批单类型异常"))
- continue
- }
- {
- updateSource := ``
- switch companyApproval.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"
- }
- tmpStartDate, _ := time.ParseInLocation(utils.FormatDate, v.StartDate, time.Local)
- tmpEndDate, _ := time.ParseInLocation(utils.FormatDate, v.EndDate, time.Local)
- companyProductUpdateLog := &models.CompanyProductUpdateLog{
- Id: 0,
- CompanyId: companyProduct.CompanyId,
- ProductId: companyProduct.ProductId,
- Status: companyProduct.Status,
- SellerId: companyProduct.SellerId,
- SellerName: companyProduct.SellerName,
- Source: updateSource,
- IsFormal: companyProduct.IsFormal, //是否已经转正式,0是没有转正式,1是已经转过正式
- StartDate: tmpStartDate,
- EndDate: tmpEndDate,
- CreateTime: time.Now(),
- }
- go models.AddCompanyProductUpdateLog(companyProductUpdateLog)
- }
- //研选审批通过的时候研选扣点更新
- {
- cygx.YanXuanCompanyApproval(v.CompanyId)
- }
- }
- //错误信息,批量返回错误信息
- if len(errorList) > 0 {
- err = errors.New(strings.Join(errorList, ";"))
- }
- return
- }
|