123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572 |
- package contract
- import (
- "fmt"
- "github.com/gin-gonic/gin"
- "github.com/go-playground/validator/v10"
- "hongze/fms_api/controller/resp"
- "hongze/fms_api/global"
- "hongze/fms_api/models/base"
- "hongze/fms_api/models/crm"
- "hongze/fms_api/models/fms"
- "hongze/fms_api/models/system"
- crmService "hongze/fms_api/services/crm"
- fmsService "hongze/fms_api/services/fms"
- "hongze/fms_api/utils"
- "strconv"
- "strings"
- "time"
- )
- type PreRegisterController struct{}
- func (rg *PreRegisterController) List(c *gin.Context) {
- var req fms.PreRegisterListReq
- if e := c.BindQuery(&req); e != nil {
- err, ok := e.(validator.ValidationErrors)
- if !ok {
- resp.FailData("参数解析失败", "Err:"+e.Error(), c)
- return
- }
- resp.FailData("参数解析失败", err.Translate(global.Trans), c)
- return
- }
- pageSize := req.PageSize
- pageIndex := req.Current
- if pageSize <= 0 {
- pageSize = utils.PageSize20
- }
- if pageIndex <= 0 {
- pageIndex = 1
- }
- cond := ` invoice_type IN (3, 4) `
- pars := make([]interface{}, 0)
- if req.Keyword != "" {
- kw := "%" + req.Keyword + "%"
- cond += ` AND company_name LIKE ? `
- pars = append(pars, kw)
- }
-
- currencyOB := new(fms.CurrencyUnit)
- currencyCond := `enable = 1`
- currencyPars := make([]interface{}, 0)
- currencyList, e := currencyOB.List(currencyCond, currencyPars)
- if e != nil {
- resp.FailMsg("获取失败", "获取货币列表失败, Err: "+e.Error(), c)
- return
- }
- unitMap := make(map[string]string)
- for i := range currencyList {
- unitMap[currencyList[i].Code] = currencyList[i].UnitName
- }
- page := new(base.Page)
- page.SetPageSize(req.PageSize)
- page.SetCurrent(req.Current)
- sortTypeMap := map[int]bool{0: false, 1: true, 2: false}
- page.AddOrderItem(base.OrderItem{Column: "create_time", Asc: sortTypeMap[0]})
- total, list, e := fms.GetContractPreRegisterItemPageList(page, cond, pars)
- if e != nil {
- resp.FailMsg("获取失败", "获取预登记列表失败, Err: "+e.Error(), c)
- return
- }
- serviceMap := make(map[int]string, 0)
- registerIds := make([]int, 0)
- for i := range list {
- list[i].UnitName = unitMap[list[i].CurrencyUnit]
- registerIds = append(registerIds, list[i].ContractRegisterId)
- }
- if len(registerIds) > 0 {
- serviceMap, _, e = fmsService.GetContractServiceNameFormat(registerIds)
- if e != nil {
- resp.FailMsg("获取失败", e.Error(), c)
- return
- }
- }
- respList := make([]*fms.ContractPreRegisterList, 0)
- for _, v := range list {
- item := new(fms.ContractPreRegisterList)
- item.ContractPreRegisterItem = v
- item.ServicesName = serviceMap[v.ContractRegisterId]
- respList = append(respList, item)
- }
- page.SetTotal(total)
- baseData := new(base.BaseData)
- baseData.SetPage(page)
- baseData.SetList(respList)
- resp.OkData("获取成功", baseData, c)
- }
- func (rg *PreRegisterController) Add(c *gin.Context) {
- req := new(fms.PreRegisterAddReq)
- err := c.ShouldBind(&req)
- if err != nil {
- errs, ok := err.(validator.ValidationErrors)
- if !ok {
- resp.FailData("参数解析失败", "Err:"+err.Error(), c)
- return
- }
- resp.FailData("参数解析失败", errs.Translate(global.Trans), c)
- return
- }
- claims, _ := c.Get("adminInfo")
- adminInfo := claims.(*system.SysAdmin)
-
- var startDate, endDate time.Time
- if req.StartDate != "" && req.EndDate != "" {
- startDate, err = time.ParseInLocation(utils.FormatDate, req.StartDate, time.Local)
- if err != nil {
- resp.FailMsg("约定开始日期格式有误", "合同开始日期格式有误, Err: "+err.Error(), c)
- return
- }
- endDate, err = time.ParseInLocation(utils.FormatDate, req.EndDate, time.Local)
- if err != nil {
- resp.FailMsg("约定结束日期格式有误", "合同结束日期格式有误, Err: "+err.Error(), c)
- return
- }
- }
-
- sellerList, e := crmService.GetSellerDepartmentListWithGroupAndTeam()
- if e != nil {
- resp.FailData("获取销售失败", "Err:"+e.Error(), c)
- return
- }
- sellerMap := make(map[int]*crm.SellerAdminWithGroupTeam)
- for i := range sellerList {
- sellerMap[sellerList[i].SellerId] = sellerList[i]
- }
- admin := new(crm.Admin)
- sellerIds := strings.Split(req.SellerIds, ",")
- if len(sellerIds) > 2 {
- resp.Fail("最多只能选择两个销售", c)
- return
- }
- var pars []interface{}
- cond := ` admin_id in (?) `
- pars = append(pars, sellerIds)
- sellers, e := admin.List(cond, pars)
- if e != nil {
- resp.FailMsg("获取销售信息失败", "获取销售信息失败, Err: "+e.Error(), c)
- return
- }
-
- ob := new(fms.ContractRegister)
-
- ob.CompanyName = req.CompanyName
- ob.ProductIds = req.ProductIds
- ob.StartDate = startDate
- ob.EndDate = endDate
- ob.Set()
- if req.RegisterType == fms.ContractInvoiceTypePreMake {
-
-
-
-
-
- for _, v := range sellers {
- if v.DepartmentId == crm.SellerDepartmentId {
- ob.SellerId = v.AdminId
- ob.SellerName = v.AdminName
- } else if v.DepartmentId == crm.RaiSellerDepartmentId {
- ob.RaiSellerId = v.AdminId
- ob.RaiSellerName = v.AdminName
- }
- }
- }
-
- serviceAmountMap := make(map[int]float64)
- serviceList, e := fmsService.HandleContractServiceAndDetail(req.Services, true, serviceAmountMap)
- if e != nil {
- resp.FailMsg("操作失败", "获取合同套餐详情失败, Err: "+e.Error(), c)
- return
- }
- if e = fms.CreateContractRegisterAndServicesAndPayMent(ob, serviceList); e != nil {
- resp.FailMsg("操作失败", "新增合同及套餐失败, Err: "+e.Error(), c)
- return
- }
- for _, r := range req.List {
-
- rateList, e := fmsService.GetTodayCurrencyRateList()
- if e != nil {
- resp.FailMsg("操作失败", "获取今日货币汇率失败, Err: "+e.Error(), c)
- return
- }
- var rate float64
- for i := range rateList {
- if r.CurrencyUnit == rateList[i].Code {
- rate = rateList[i].RMBRate
- break
- }
- }
- if rate <= 0 {
- resp.FailMsg("操作失败", "货币汇率信息有误", c)
- return
- }
- registerDate, e := time.Parse(utils.FormatDate, r.RegisterDate)
- if e != nil {
- resp.FailMsg("日期转换失败", "日期转换失败, Err: "+e.Error(), c)
- return
- }
- v := &fms.ContractInvoice{
- ContractRegisterId: ob.ContractRegisterId,
- OriginAmount: r.Amount,
- CurrencyUnit: r.CurrencyUnit,
- InvoiceType: req.RegisterType,
- InvoiceDate: registerDate,
- AdminId: int(adminInfo.AdminId),
- AdminName: adminInfo.AdminName,
- Remark: r.Remark,
- ServiceProductId: r.ServiceProductId,
- IsPrePay: 1,
- StartDate: startDate,
- EndDate: endDate,
- TimeBase: base.TimeBase{},
- }
- v.Set()
- a, _ := strconv.ParseFloat(fmt.Sprintf("%.2f", v.OriginAmount/rate), 64)
- v.Amount = a
- if req.RegisterType == fms.ContractInvoiceTypePreMake {
- sellerItem := sellerMap[r.SellerId]
- if sellerItem == nil {
- resp.Fail("销售信息异常", c)
- return
- }
- v.SellerId = sellerItem.SellerId
- v.SellerName = sellerItem.SellerName
- v.SellerGroupId = sellerItem.GroupId
- v.SellerGroupName = sellerItem.GroupName
- v.SellerTeamId = sellerItem.TeamId
- v.SellerTeamName = sellerItem.TeamName
- }
-
- if e = v.Create(); e != nil {
- resp.FailMsg("操作失败", "新增预登记失败, Err: "+e.Error(), c)
- return
- }
-
- pp := &fms.ContractPreRegister{
- ContractRegisterId: ob.ContractRegisterId,
- CompanyName: req.CompanyName,
- InvoiceType: req.RegisterType,
- InvoiceDate: registerDate,
- AdminId: int(adminInfo.AdminId),
- AdminName: adminInfo.AdminName,
- Remark: r.Remark,
- ServiceProductId: r.ServiceProductId,
- IsPrePay: 1,
- StartDate: startDate,
- EndDate: endDate,
- TimeBase: base.TimeBase{},
- }
- pp.Set()
- if pp.InvoiceType == fms.ContractInvoiceTypePreMake {
-
- pp.InvoiceDate = registerDate
- pp.OriginAmount = r.Amount
- pp.CurrencyUnit = r.CurrencyUnit
- a, _ := strconv.ParseFloat(fmt.Sprintf("%.2f", pp.OriginAmount/rate), 64)
- pp.Amount = a
- sellerItem := sellerMap[r.SellerId]
- if sellerItem == nil {
- resp.Fail("销售信息异常", c)
- return
- }
- pp.SellerId = sellerItem.SellerId
- pp.SellerName = sellerItem.SellerName
- pp.SellerGroupId = sellerItem.GroupId
- pp.SellerGroupName = sellerItem.GroupName
- pp.SellerTeamId = sellerItem.TeamId
- pp.SellerTeamName = sellerItem.TeamName
- } else {
-
- pp.ArriveDate = registerDate
- pp.ArriveOriginAmount = r.Amount
- pp.ArriveCurrencyUnit = r.CurrencyUnit
- a, _ := strconv.ParseFloat(fmt.Sprintf("%.2f", pp.ArriveOriginAmount/rate), 64)
- pp.ArriveAmount = a
- }
-
- if e = pp.Create(); e != nil {
- resp.FailMsg("操作失败", "新增预登记失败, Err: "+e.Error(), c)
- return
- }
- }
-
- go fmsService.SummaryInvoicePaymentByContractRegisterId(ob.ContractRegisterId)
- resp.Ok("操作成功", c)
- }
- func (rg *PreRegisterController) Edit(c *gin.Context) {
- req := new(fms.PreRegisterEditReq)
- err := c.ShouldBind(&req)
- if err != nil {
- errs, ok := err.(validator.ValidationErrors)
- if !ok {
- resp.FailData("参数解析失败", "Err:"+err.Error(), c)
- return
- }
- resp.FailData("参数解析失败", errs.Translate(global.Trans), c)
- return
- }
- claims, _ := c.Get("adminInfo")
- adminInfo := claims.(*system.SysAdmin)
-
- var startDate, endDate time.Time
- if req.StartDate != "" && req.EndDate != "" {
- startDate, err = time.ParseInLocation(utils.FormatDate, req.StartDate, time.Local)
- if err != nil {
- resp.FailMsg("约定开始日期格式有误", "合同开始日期格式有误, Err: "+err.Error(), c)
- return
- }
- endDate, err = time.ParseInLocation(utils.FormatDate, req.EndDate, time.Local)
- if err != nil {
- resp.FailMsg("约定结束日期格式有误", "合同结束日期格式有误, Err: "+err.Error(), c)
- return
- }
- }
-
- sellerList, e := crmService.GetSellerDepartmentListWithGroupAndTeam()
- if e != nil {
- resp.FailData("获取销售失败", "Err:"+e.Error(), c)
- return
- }
- sellerMap := make(map[int]*crm.SellerAdminWithGroupTeam)
- for i := range sellerList {
- sellerMap[sellerList[i].SellerId] = sellerList[i]
- }
- admin := new(crm.Admin)
- sellerIds := strings.Split(req.SellerIds, ",")
- if len(sellerIds) > 2 {
- resp.Fail("最多只能选择两个销售", c)
- return
- }
- var pars []interface{}
- cond := ` admin_id in (?) `
- pars = append(pars, sellerIds)
- sellers, e := admin.List(cond, pars)
- if e != nil {
- resp.FailMsg("获取销售信息失败", "获取销售信息失败, Err: "+e.Error(), c)
- return
- }
-
- ob := new(fms.ContractRegister)
-
- ob.ContractRegisterId = req.ContractRegisterId
- ob.CompanyName = req.CompanyName
- ob.ProductIds = req.ProductIds
- ob.StartDate = startDate
- ob.EndDate = endDate
- ob.ModifyTime = time.Now().Local()
- if req.RegisterType == fms.ContractInvoiceTypePreMake {
-
-
-
-
-
- for _, v := range sellers {
- if v.DepartmentId == crm.SellerDepartmentId {
- ob.SellerId = v.AdminId
- ob.SellerName = v.AdminName
- } else if v.DepartmentId == crm.RaiSellerDepartmentId {
- ob.RaiSellerId = v.AdminId
- ob.RaiSellerName = v.AdminName
- }
- }
- }
-
- serviceAmountMap := make(map[int]float64)
- serviceList, e := fmsService.HandleContractServiceAndDetail(req.Services, true, serviceAmountMap)
- if e != nil {
- resp.FailMsg("操作失败", "获取合同套餐详情失败, Err: "+e.Error(), c)
- return
- }
- updateCols := []string{
- "ProductIds", "CompanyName", "SellerId", "SellerName", "StartDate", "EndDate",
- "RaiSellerId", "RaiSellerName", "ModifyTime",
- }
- invoiceList := make([]*fms.ContractInvoice, 0)
- for _, r := range req.List {
-
- rateList, e := fmsService.GetTodayCurrencyRateList()
- if e != nil {
- resp.FailMsg("操作失败", "获取今日货币汇率失败, Err: "+e.Error(), c)
- return
- }
- var rate float64
- for i := range rateList {
- if r.CurrencyUnit == rateList[i].Code {
- rate = rateList[i].RMBRate
- break
- }
- }
- if rate <= 0 {
- resp.FailMsg("操作失败", "货币汇率信息有误", c)
- return
- }
- registerDate, e := time.Parse(utils.FormatDate, r.RegisterDate)
- if e != nil {
- resp.FailMsg("日期转换失败", "日期转换失败, Err: "+e.Error(), c)
- return
- }
- v := &fms.ContractInvoice{
- ContractInvoiceId: r.InvoiceId,
- ContractRegisterId: ob.ContractRegisterId,
- OriginAmount: r.Amount,
- CurrencyUnit: r.CurrencyUnit,
- InvoiceType: req.RegisterType,
- InvoiceDate: registerDate,
- AdminId: int(adminInfo.AdminId),
- AdminName: adminInfo.AdminName,
- Remark: r.Remark,
- ServiceProductId: r.ServiceProductId,
- IsPrePay: 1,
- StartDate: startDate,
- EndDate: endDate,
- }
- v.TimeBase.ModifyTime = time.Now().Local()
- a, _ := strconv.ParseFloat(fmt.Sprintf("%.2f", v.OriginAmount/rate), 64)
- v.Amount = a
- if req.RegisterType == fms.ContractInvoiceTypePreMake {
- sellerItem := sellerMap[r.SellerId]
- if sellerItem == nil {
- resp.Fail("销售信息异常", c)
- return
- }
- v.SellerId = sellerItem.SellerId
- v.SellerName = sellerItem.SellerName
- v.SellerGroupId = sellerItem.GroupId
- v.SellerGroupName = sellerItem.GroupName
- v.SellerTeamId = sellerItem.TeamId
- v.SellerTeamName = sellerItem.TeamName
- }
- invoiceList = append(invoiceList, v)
- }
- invoiceUpdateCols := []string{
- "CurrencyUnit", "Amount", "InvoiceDate", "AdminId", "AdminName", "Remark",
- "ServiceProductId", "StartDate", "EndDate", "ModifyTime",
- }
-
- if e = fms.UpdateContractPreRegister(ob, updateCols, serviceList, invoiceList, invoiceUpdateCols); e != nil {
- resp.FailMsg("操作失败", "更新合同及套餐失败, Err: "+e.Error(), c)
- return
- }
-
- go fmsService.SummaryInvoicePaymentByContractRegisterId(ob.ContractRegisterId)
- resp.Ok("操作成功", c)
- }
- func (rg *PreRegisterController) Del(c *gin.Context) {
- req := new(fms.PreRegisterDelReq)
- err := c.ShouldBind(&req)
- if err != nil {
- errs, ok := err.(validator.ValidationErrors)
- if !ok {
- resp.FailData("参数解析失败", "Err:"+err.Error(), c)
- return
- }
- resp.FailData("参数解析失败", errs.Translate(global.Trans), c)
- return
- }
- ob := new(fms.ContractInvoice)
- item, e := ob.Fetch(req.InvoiceId)
- if e != nil {
- if e == utils.ErrNoRow {
- resp.Fail("合同登记不存在或已被删除", c)
- return
- }
- resp.FailMsg("获取合同登记失败", "Err:"+e.Error(), c)
- return
- }
- e = item.Delete()
- if e != nil {
- resp.FailMsg("删除记录失败", "Err:"+e.Error(), c)
- return
- }
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- resp.Ok("操作成功", c)
- }
|