pre_register.go 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572
  1. package contract
  2. import (
  3. "fmt"
  4. "github.com/gin-gonic/gin"
  5. "github.com/go-playground/validator/v10"
  6. "hongze/fms_api/controller/resp"
  7. "hongze/fms_api/global"
  8. "hongze/fms_api/models/base"
  9. "hongze/fms_api/models/crm"
  10. "hongze/fms_api/models/fms"
  11. "hongze/fms_api/models/system"
  12. crmService "hongze/fms_api/services/crm"
  13. fmsService "hongze/fms_api/services/fms"
  14. "hongze/fms_api/utils"
  15. "strconv"
  16. "strings"
  17. "time"
  18. )
  19. // // RegisterController 合同登记
  20. type PreRegisterController struct{}
  21. // InvoiceList
  22. // @Title 开票/到款列表
  23. // @Description 开票/到款列表
  24. // @Param Keyword query string false "关键词"
  25. // @Success 200 {object} fms.ContractInvoiceItem
  26. // @router /contract/pre_register/list [get]
  27. func (rg *PreRegisterController) List(c *gin.Context) {
  28. var req fms.PreRegisterListReq
  29. if e := c.BindQuery(&req); e != nil {
  30. err, ok := e.(validator.ValidationErrors)
  31. if !ok {
  32. resp.FailData("参数解析失败", "Err:"+e.Error(), c)
  33. return
  34. }
  35. resp.FailData("参数解析失败", err.Translate(global.Trans), c)
  36. return
  37. }
  38. pageSize := req.PageSize
  39. pageIndex := req.Current
  40. if pageSize <= 0 {
  41. pageSize = utils.PageSize20
  42. }
  43. if pageIndex <= 0 {
  44. pageIndex = 1
  45. }
  46. cond := ` invoice_type IN (3, 4) `
  47. pars := make([]interface{}, 0)
  48. if req.Keyword != "" {
  49. kw := "%" + req.Keyword + "%"
  50. cond += ` AND company_name LIKE ? `
  51. pars = append(pars, kw)
  52. }
  53. // 货币列表
  54. currencyOB := new(fms.CurrencyUnit)
  55. currencyCond := `enable = 1`
  56. currencyPars := make([]interface{}, 0)
  57. currencyList, e := currencyOB.List(currencyCond, currencyPars)
  58. if e != nil {
  59. resp.FailMsg("获取失败", "获取货币列表失败, Err: "+e.Error(), c)
  60. return
  61. }
  62. unitMap := make(map[string]string)
  63. for i := range currencyList {
  64. unitMap[currencyList[i].Code] = currencyList[i].UnitName
  65. }
  66. page := new(base.Page)
  67. page.SetPageSize(req.PageSize)
  68. page.SetCurrent(req.Current)
  69. sortTypeMap := map[int]bool{0: false, 1: true, 2: false}
  70. page.AddOrderItem(base.OrderItem{Column: "create_time", Asc: sortTypeMap[0]})
  71. total, list, e := fms.GetContractPreRegisterItemPageList(page, cond, pars)
  72. if e != nil {
  73. resp.FailMsg("获取失败", "获取预登记列表失败, Err: "+e.Error(), c)
  74. return
  75. }
  76. serviceMap := make(map[int]string, 0)
  77. registerIds := make([]int, 0)
  78. for i := range list {
  79. list[i].UnitName = unitMap[list[i].CurrencyUnit]
  80. registerIds = append(registerIds, list[i].ContractRegisterId)
  81. }
  82. if len(registerIds) > 0 {
  83. serviceMap, _, e = fmsService.GetContractServiceNameFormat(registerIds)
  84. if e != nil {
  85. resp.FailMsg("获取失败", e.Error(), c)
  86. return
  87. }
  88. }
  89. respList := make([]*fms.ContractPreRegisterList, 0)
  90. for _, v := range list {
  91. item := new(fms.ContractPreRegisterList)
  92. item.ContractPreRegisterItem = v
  93. item.ServicesName = serviceMap[v.ContractRegisterId]
  94. respList = append(respList, item)
  95. }
  96. page.SetTotal(total)
  97. baseData := new(base.BaseData)
  98. baseData.SetPage(page)
  99. baseData.SetList(respList)
  100. resp.OkData("获取成功", baseData, c)
  101. }
  102. // Add
  103. // @Title 新增到款预登记
  104. // @Description 新增到款预登记
  105. // @Param request body fms.PrepayAddReq true "type json string"
  106. // @Success 200 string "操作成功"
  107. // @router /contract/pre_register/add [post]
  108. func (rg *PreRegisterController) Add(c *gin.Context) {
  109. req := new(fms.PreRegisterAddReq)
  110. err := c.ShouldBind(&req)
  111. if err != nil {
  112. errs, ok := err.(validator.ValidationErrors)
  113. if !ok {
  114. resp.FailData("参数解析失败", "Err:"+err.Error(), c)
  115. return
  116. }
  117. resp.FailData("参数解析失败", errs.Translate(global.Trans), c)
  118. return
  119. }
  120. claims, _ := c.Get("adminInfo")
  121. adminInfo := claims.(*system.SysAdmin)
  122. // 日期校验
  123. var startDate, endDate time.Time
  124. if req.StartDate != "" && req.EndDate != "" {
  125. startDate, err = time.ParseInLocation(utils.FormatDate, req.StartDate, time.Local)
  126. if err != nil {
  127. resp.FailMsg("约定开始日期格式有误", "合同开始日期格式有误, Err: "+err.Error(), c)
  128. return
  129. }
  130. endDate, err = time.ParseInLocation(utils.FormatDate, req.EndDate, time.Local)
  131. if err != nil {
  132. resp.FailMsg("约定结束日期格式有误", "合同结束日期格式有误, Err: "+err.Error(), c)
  133. return
  134. }
  135. }
  136. // 获取销售分组信息
  137. sellerList, e := crmService.GetSellerDepartmentListWithGroupAndTeam()
  138. if e != nil {
  139. resp.FailData("获取销售失败", "Err:"+e.Error(), c)
  140. return
  141. }
  142. sellerMap := make(map[int]*crm.SellerAdminWithGroupTeam)
  143. for i := range sellerList {
  144. sellerMap[sellerList[i].SellerId] = sellerList[i]
  145. }
  146. admin := new(crm.Admin)
  147. sellerIds := strings.Split(req.SellerIds, ",")
  148. if len(sellerIds) > 2 {
  149. resp.Fail("最多只能选择两个销售", c)
  150. return
  151. }
  152. var pars []interface{}
  153. cond := ` admin_id in (?) `
  154. pars = append(pars, sellerIds)
  155. sellers, e := admin.List(cond, pars)
  156. if e != nil {
  157. resp.FailMsg("获取销售信息失败", "获取销售信息失败, Err: "+e.Error(), c)
  158. return
  159. }
  160. //新增合同
  161. ob := new(fms.ContractRegister)
  162. //ob.ContractCode = req.ContractCode
  163. ob.CompanyName = req.CompanyName
  164. ob.ProductIds = req.ProductIds
  165. ob.StartDate = startDate
  166. ob.EndDate = endDate
  167. ob.Set()
  168. if req.RegisterType == fms.ContractInvoiceTypePreMake {
  169. //sellerItem := sellerMap[r.SellerId]
  170. //if sellerItem == nil {
  171. // resp.Fail("销售信息异常", c)
  172. // return
  173. //}
  174. for _, v := range sellers {
  175. if v.DepartmentId == crm.SellerDepartmentId {
  176. ob.SellerId = v.AdminId
  177. ob.SellerName = v.AdminName
  178. } else if v.DepartmentId == crm.RaiSellerDepartmentId {
  179. ob.RaiSellerId = v.AdminId
  180. ob.RaiSellerName = v.AdminName
  181. }
  182. }
  183. }
  184. // 套餐信息
  185. serviceAmountMap := make(map[int]float64)
  186. serviceList, e := fmsService.HandleContractServiceAndDetail(req.Services, true, serviceAmountMap)
  187. if e != nil {
  188. resp.FailMsg("操作失败", "获取合同套餐详情失败, Err: "+e.Error(), c)
  189. return
  190. }
  191. if e = fms.CreateContractRegisterAndServicesAndPayMent(ob, serviceList); e != nil {
  192. resp.FailMsg("操作失败", "新增合同及套餐失败, Err: "+e.Error(), c)
  193. return
  194. }
  195. for _, r := range req.List {
  196. // 货币及汇率
  197. rateList, e := fmsService.GetTodayCurrencyRateList()
  198. if e != nil {
  199. resp.FailMsg("操作失败", "获取今日货币汇率失败, Err: "+e.Error(), c)
  200. return
  201. }
  202. var rate float64
  203. for i := range rateList {
  204. if r.CurrencyUnit == rateList[i].Code {
  205. rate = rateList[i].RMBRate
  206. break
  207. }
  208. }
  209. if rate <= 0 {
  210. resp.FailMsg("操作失败", "货币汇率信息有误", c)
  211. return
  212. }
  213. registerDate, e := time.Parse(utils.FormatDate, r.RegisterDate)
  214. if e != nil {
  215. resp.FailMsg("日期转换失败", "日期转换失败, Err: "+e.Error(), c)
  216. return
  217. }
  218. v := &fms.ContractInvoice{
  219. ContractRegisterId: ob.ContractRegisterId,
  220. OriginAmount: r.Amount,
  221. CurrencyUnit: r.CurrencyUnit,
  222. InvoiceType: req.RegisterType,
  223. InvoiceDate: registerDate,
  224. AdminId: int(adminInfo.AdminId),
  225. AdminName: adminInfo.AdminName,
  226. Remark: r.Remark,
  227. ServiceProductId: r.ServiceProductId,
  228. IsPrePay: 1,
  229. StartDate: startDate,
  230. EndDate: endDate,
  231. TimeBase: base.TimeBase{},
  232. }
  233. v.Set()
  234. a, _ := strconv.ParseFloat(fmt.Sprintf("%.2f", v.OriginAmount/rate), 64)
  235. v.Amount = a
  236. if req.RegisterType == fms.ContractInvoiceTypePreMake {
  237. sellerItem := sellerMap[r.SellerId]
  238. if sellerItem == nil {
  239. resp.Fail("销售信息异常", c)
  240. return
  241. }
  242. v.SellerId = sellerItem.SellerId
  243. v.SellerName = sellerItem.SellerName
  244. v.SellerGroupId = sellerItem.GroupId
  245. v.SellerGroupName = sellerItem.GroupName
  246. v.SellerTeamId = sellerItem.TeamId
  247. v.SellerTeamName = sellerItem.TeamName
  248. }
  249. // 新增开票到款记录
  250. if e = v.Create(); e != nil {
  251. resp.FailMsg("操作失败", "新增预登记失败, Err: "+e.Error(), c)
  252. return
  253. }
  254. //预登记列表
  255. pp := &fms.ContractPreRegister{
  256. ContractRegisterId: ob.ContractRegisterId,
  257. CompanyName: req.CompanyName,
  258. InvoiceType: req.RegisterType,
  259. InvoiceDate: registerDate,
  260. AdminId: int(adminInfo.AdminId),
  261. AdminName: adminInfo.AdminName,
  262. Remark: r.Remark,
  263. ServiceProductId: r.ServiceProductId,
  264. IsPrePay: 1,
  265. StartDate: startDate,
  266. EndDate: endDate,
  267. TimeBase: base.TimeBase{},
  268. }
  269. pp.Set()
  270. if pp.InvoiceType == fms.ContractInvoiceTypePreMake {
  271. //开票走开票字段
  272. pp.InvoiceDate = registerDate
  273. pp.OriginAmount = r.Amount
  274. pp.CurrencyUnit = r.CurrencyUnit
  275. a, _ := strconv.ParseFloat(fmt.Sprintf("%.2f", pp.OriginAmount/rate), 64)
  276. pp.Amount = a
  277. sellerItem := sellerMap[r.SellerId]
  278. if sellerItem == nil {
  279. resp.Fail("销售信息异常", c)
  280. return
  281. }
  282. pp.SellerId = sellerItem.SellerId
  283. pp.SellerName = sellerItem.SellerName
  284. pp.SellerGroupId = sellerItem.GroupId
  285. pp.SellerGroupName = sellerItem.GroupName
  286. pp.SellerTeamId = sellerItem.TeamId
  287. pp.SellerTeamName = sellerItem.TeamName
  288. } else {
  289. //到款
  290. pp.ArriveDate = registerDate
  291. pp.ArriveOriginAmount = r.Amount
  292. pp.ArriveCurrencyUnit = r.CurrencyUnit
  293. a, _ := strconv.ParseFloat(fmt.Sprintf("%.2f", pp.ArriveOriginAmount/rate), 64)
  294. pp.ArriveAmount = a
  295. }
  296. // 新增开票到款记录
  297. if e = pp.Create(); e != nil {
  298. resp.FailMsg("操作失败", "新增预登记失败, Err: "+e.Error(), c)
  299. return
  300. }
  301. }
  302. // 开票到款汇总
  303. go fmsService.SummaryInvoicePaymentByContractRegisterId(ob.ContractRegisterId)
  304. resp.Ok("操作成功", c)
  305. }
  306. // Edit
  307. // @Title 编辑预登记
  308. // @Description 编辑预登记
  309. // @Param request body fms.ContractRegisterEditReq true "type json string"
  310. // @Success 200 string "操作成功"
  311. // @router /contract/pre_register/edit [post]
  312. func (rg *PreRegisterController) Edit(c *gin.Context) {
  313. req := new(fms.PreRegisterEditReq)
  314. err := c.ShouldBind(&req)
  315. if err != nil {
  316. errs, ok := err.(validator.ValidationErrors)
  317. if !ok {
  318. resp.FailData("参数解析失败", "Err:"+err.Error(), c)
  319. return
  320. }
  321. resp.FailData("参数解析失败", errs.Translate(global.Trans), c)
  322. return
  323. }
  324. claims, _ := c.Get("adminInfo")
  325. adminInfo := claims.(*system.SysAdmin)
  326. // 日期校验
  327. var startDate, endDate time.Time
  328. if req.StartDate != "" && req.EndDate != "" {
  329. startDate, err = time.ParseInLocation(utils.FormatDate, req.StartDate, time.Local)
  330. if err != nil {
  331. resp.FailMsg("约定开始日期格式有误", "合同开始日期格式有误, Err: "+err.Error(), c)
  332. return
  333. }
  334. endDate, err = time.ParseInLocation(utils.FormatDate, req.EndDate, time.Local)
  335. if err != nil {
  336. resp.FailMsg("约定结束日期格式有误", "合同结束日期格式有误, Err: "+err.Error(), c)
  337. return
  338. }
  339. }
  340. // 获取销售分组信息
  341. sellerList, e := crmService.GetSellerDepartmentListWithGroupAndTeam()
  342. if e != nil {
  343. resp.FailData("获取销售失败", "Err:"+e.Error(), c)
  344. return
  345. }
  346. sellerMap := make(map[int]*crm.SellerAdminWithGroupTeam)
  347. for i := range sellerList {
  348. sellerMap[sellerList[i].SellerId] = sellerList[i]
  349. }
  350. admin := new(crm.Admin)
  351. sellerIds := strings.Split(req.SellerIds, ",")
  352. if len(sellerIds) > 2 {
  353. resp.Fail("最多只能选择两个销售", c)
  354. return
  355. }
  356. var pars []interface{}
  357. cond := ` admin_id in (?) `
  358. pars = append(pars, sellerIds)
  359. sellers, e := admin.List(cond, pars)
  360. if e != nil {
  361. resp.FailMsg("获取销售信息失败", "获取销售信息失败, Err: "+e.Error(), c)
  362. return
  363. }
  364. //修改合同
  365. ob := new(fms.ContractRegister)
  366. //ob.ContractCode = req.ContractCode
  367. ob.ContractRegisterId = req.ContractRegisterId
  368. ob.CompanyName = req.CompanyName
  369. ob.ProductIds = req.ProductIds
  370. ob.StartDate = startDate
  371. ob.EndDate = endDate
  372. ob.ModifyTime = time.Now().Local()
  373. if req.RegisterType == fms.ContractInvoiceTypePreMake {
  374. //sellerItem := sellerMap[r.SellerId]
  375. //if sellerItem == nil {
  376. // resp.Fail("销售信息异常", c)
  377. // return
  378. //}
  379. for _, v := range sellers {
  380. if v.DepartmentId == crm.SellerDepartmentId {
  381. ob.SellerId = v.AdminId
  382. ob.SellerName = v.AdminName
  383. } else if v.DepartmentId == crm.RaiSellerDepartmentId {
  384. ob.RaiSellerId = v.AdminId
  385. ob.RaiSellerName = v.AdminName
  386. }
  387. }
  388. }
  389. // 套餐信息
  390. serviceAmountMap := make(map[int]float64)
  391. serviceList, e := fmsService.HandleContractServiceAndDetail(req.Services, true, serviceAmountMap)
  392. if e != nil {
  393. resp.FailMsg("操作失败", "获取合同套餐详情失败, Err: "+e.Error(), c)
  394. return
  395. }
  396. updateCols := []string{
  397. "ProductIds", "CompanyName", "SellerId", "SellerName", "StartDate", "EndDate",
  398. "RaiSellerId", "RaiSellerName", "ModifyTime",
  399. }
  400. invoiceList := make([]*fms.ContractInvoice, 0)
  401. for _, r := range req.List {
  402. // 货币及汇率
  403. rateList, e := fmsService.GetTodayCurrencyRateList()
  404. if e != nil {
  405. resp.FailMsg("操作失败", "获取今日货币汇率失败, Err: "+e.Error(), c)
  406. return
  407. }
  408. var rate float64
  409. for i := range rateList {
  410. if r.CurrencyUnit == rateList[i].Code {
  411. rate = rateList[i].RMBRate
  412. break
  413. }
  414. }
  415. if rate <= 0 {
  416. resp.FailMsg("操作失败", "货币汇率信息有误", c)
  417. return
  418. }
  419. registerDate, e := time.Parse(utils.FormatDate, r.RegisterDate)
  420. if e != nil {
  421. resp.FailMsg("日期转换失败", "日期转换失败, Err: "+e.Error(), c)
  422. return
  423. }
  424. v := &fms.ContractInvoice{
  425. ContractInvoiceId: r.InvoiceId,
  426. ContractRegisterId: ob.ContractRegisterId,
  427. OriginAmount: r.Amount,
  428. CurrencyUnit: r.CurrencyUnit,
  429. InvoiceType: req.RegisterType,
  430. InvoiceDate: registerDate,
  431. AdminId: int(adminInfo.AdminId),
  432. AdminName: adminInfo.AdminName,
  433. Remark: r.Remark,
  434. ServiceProductId: r.ServiceProductId,
  435. IsPrePay: 1,
  436. StartDate: startDate,
  437. EndDate: endDate,
  438. }
  439. v.TimeBase.ModifyTime = time.Now().Local()
  440. a, _ := strconv.ParseFloat(fmt.Sprintf("%.2f", v.OriginAmount/rate), 64)
  441. v.Amount = a
  442. if req.RegisterType == fms.ContractInvoiceTypePreMake {
  443. sellerItem := sellerMap[r.SellerId]
  444. if sellerItem == nil {
  445. resp.Fail("销售信息异常", c)
  446. return
  447. }
  448. v.SellerId = sellerItem.SellerId
  449. v.SellerName = sellerItem.SellerName
  450. v.SellerGroupId = sellerItem.GroupId
  451. v.SellerGroupName = sellerItem.GroupName
  452. v.SellerTeamId = sellerItem.TeamId
  453. v.SellerTeamName = sellerItem.TeamName
  454. }
  455. invoiceList = append(invoiceList, v)
  456. }
  457. invoiceUpdateCols := []string{
  458. "CurrencyUnit", "Amount", "InvoiceDate", "AdminId", "AdminName", "Remark",
  459. "ServiceProductId", "StartDate", "EndDate", "ModifyTime",
  460. }
  461. // 更新合同登记、套餐、开票到款
  462. if e = fms.UpdateContractPreRegister(ob, updateCols, serviceList, invoiceList, invoiceUpdateCols); e != nil {
  463. resp.FailMsg("操作失败", "更新合同及套餐失败, Err: "+e.Error(), c)
  464. return
  465. }
  466. // 开票到款汇总
  467. go fmsService.SummaryInvoicePaymentByContractRegisterId(ob.ContractRegisterId)
  468. resp.Ok("操作成功", c)
  469. }
  470. // Del
  471. // @Title 删除到款预登记
  472. // @Description 删除到款预登记
  473. // @Param request body fms.ContractRegisterDelReq true "type json string"
  474. // @Success 200 string "操作成功"
  475. // @router /contract/pre_pay/del [post]
  476. func (rg *PreRegisterController) Del(c *gin.Context) {
  477. req := new(fms.PreRegisterDelReq)
  478. err := c.ShouldBind(&req)
  479. if err != nil {
  480. errs, ok := err.(validator.ValidationErrors)
  481. if !ok {
  482. resp.FailData("参数解析失败", "Err:"+err.Error(), c)
  483. return
  484. }
  485. resp.FailData("参数解析失败", errs.Translate(global.Trans), c)
  486. return
  487. }
  488. ob := new(fms.ContractInvoice)
  489. item, e := ob.Fetch(req.InvoiceId)
  490. if e != nil {
  491. if e == utils.ErrNoRow {
  492. resp.Fail("合同登记不存在或已被删除", c)
  493. return
  494. }
  495. resp.FailMsg("获取合同登记失败", "Err:"+e.Error(), c)
  496. return
  497. }
  498. e = item.Delete()
  499. if e != nil {
  500. resp.FailMsg("删除记录失败", "Err:"+e.Error(), c)
  501. return
  502. }
  503. // 操作日志
  504. //go func() {
  505. // opData := ""
  506. // opDataByte, e := json.Marshal(req)
  507. // if e != nil {
  508. // return
  509. // }
  510. // opData = string(opDataByte)
  511. //
  512. // logItem := new(fms.ContractRegisterLog)
  513. // logItem.ContractRegisterId = req.ContractRegisterId
  514. // logItem.AdminId = int(adminInfo.AdminId)
  515. // logItem.AdminName = adminInfo.RealName
  516. // logItem.OpData = opData
  517. // logItem.OpType = fms.ContractRegisterOpTypeDel
  518. // logItem.CreateTime = nowTime
  519. // if e = logItem.Create(); e != nil {
  520. // return
  521. // }
  522. //}()
  523. resp.Ok("操作成功", c)
  524. }