pre_register.go 16 KB

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