pre_register.go 16 KB

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