contract_expenditure_service.go 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172
  1. /*
  2. * @description: 合同支出业务相关
  3. * @Author: CP
  4. * @Date: 2020-12-21 15:35:03
  5. * @FilePath: \construction_management\services\contract_expenditure_service.go
  6. */
  7. package services
  8. import (
  9. "errors"
  10. "fmt"
  11. "time"
  12. "github.com/shopspring/decimal"
  13. "go.mod/conf"
  14. "go.mod/models"
  15. "go.mod/web/viewmodels"
  16. )
  17. // 新增支出合同
  18. func (s *contractService) AddExpenditure(contractData *viewmodels.Contracts, projectId int, bidsectionId int, treeId int) error {
  19. // 1. 项目节存在
  20. contracts := s.treeContractDao.Get(treeId, bidsectionId, projectId, 1)
  21. if contracts.Id == 0 {
  22. return errors.New("未找到项目节")
  23. }
  24. // k := int32(projectId)
  25. // 2.项目节是没有合同
  26. if contracts.ContractId != 0 {
  27. return errors.New("该项目节上已经存在合同")
  28. }
  29. // 2-1.查找合同编号是否存在
  30. codeData := s.contractDao.GetByCode(projectId, bidsectionId, contractData.Code, 2)
  31. if len(codeData) != 0 {
  32. return errors.New("该合同编号已经存在")
  33. }
  34. // 3.新增合同 --合计标段上的金额
  35. contractsCm := &models.CmContracts{}
  36. contractsCm.Code = contractData.Code
  37. contractsCm.Name = contractData.Name
  38. contractsCm.ContractsType = 2
  39. contractsCm.Price = fmt.Sprintf("%.2f", contractData.Price)
  40. // contractsCm.Price = contractData.Price
  41. contractsCm.Returned = "0"
  42. contractsCm.Paid = "0"
  43. contractsCm.ContractDeductionTotal = "0"
  44. contractsCm.TreeId = treeId
  45. contractsCm.ProjectId = projectId
  46. contractsCm.BidsectionId = bidsectionId
  47. contractsCm.Status = 0
  48. contractsCm.CreateTime = time.Now()
  49. contractsCm.UpdateTime = time.Now()
  50. err := s.contractDao.Add(contractsCm)
  51. if err != nil {
  52. return err
  53. }
  54. // 3.获得该标段下合同总数 - 总收入金额
  55. contractTotal, priceTotal := s.getContractTotalAndPrice(bidsectionId, projectId, 1)
  56. // 更新标段目录上合同金额和总数
  57. err = s.treeDao.UpdateContractsAndPayPrice(projectId, bidsectionId, contractTotal, priceTotal)
  58. if err != nil {
  59. return err
  60. }
  61. return nil
  62. }
  63. // 更新支出合同
  64. func (s *contractService) UpdateExpenditure(contractData *viewmodels.Contracts, projectId int, bidsectionId int, treeId int) error {
  65. // 1. 项目节存在
  66. contractsTree := s.treeContractDao.Get(treeId, bidsectionId, projectId, 1)
  67. if contractsTree.Id == 0 {
  68. return errors.New("未找到项目节")
  69. }
  70. // 2.项目节是没有合同
  71. if contractsTree.ContractId == 0 {
  72. return errors.New("该项目节上没有找到合同")
  73. }
  74. // 3.合同锁定 不能删除
  75. if contractsTree.ContractLocking == 1 {
  76. return errors.New("该合同已锁定")
  77. }
  78. // 4.合同金额不能小于回款金额
  79. paidPrice, _ := decimal.NewFromString(contractsTree.ContractsPaid)
  80. price := decimal.NewFromFloat(contractData.Price)
  81. // price, err := decimal.NewFromString(contractData.Price)
  82. // if err != nil {
  83. // return errors.New("金额填写有误")
  84. // }
  85. if paidPrice.GreaterThan(price) {
  86. return errors.New(fmt.Sprintf("合同金额不能低于%s", contractsTree.ContractsPaid))
  87. }
  88. contractsCm := &models.CmContracts{}
  89. contractsCm.Id = contractsTree.ContractId
  90. contractsCm.Content = contractData.Content
  91. contractsCm.Name = contractData.Name
  92. contractsCm.Price = fmt.Sprintf("%.2f", contractData.Price)
  93. contractsCm.PartyA = contractData.PartyA
  94. contractsCm.PartyASigner = contractData.PartyASigner
  95. contractsCm.PartyB = contractData.PartyB
  96. contractsCm.PartyBSigner = contractData.PartyBSigner
  97. loc, _ := time.LoadLocation("Local")
  98. SignerTime, err := time.ParseInLocation(conf.SysTimeform, contractData.SignerTime, loc)
  99. if err != nil {
  100. return errors.New("签约时间填写异常")
  101. }
  102. contractsCm.SignerTime = SignerTime
  103. contractsCm.Remarks = contractData.Remarks
  104. columns := []string{"Content", "Name", "Price", "PartyA", "PartyASigner", "PartyB", "PartyBSigner"}
  105. err = s.contractDao.UpdateExpenditure(contractsCm, columns, projectId, bidsectionId, treeId)
  106. if err != nil {
  107. return err
  108. }
  109. // 3.获得该标段下合同总数 - 总收入金额
  110. contractTotal, priceTotal := s.getContractTotalAndPrice(bidsectionId, projectId, 1)
  111. // 更新标段目录上合同金额和总数
  112. err = s.treeDao.UpdateContractsAndPayPrice(projectId, bidsectionId, contractTotal, priceTotal)
  113. if err != nil {
  114. return err
  115. }
  116. return nil
  117. }
  118. // 删除支出合同
  119. func (s *contractService) DeleteExpenditure(projectId int, bidsectionId int, treeId int, id int) error {
  120. // 1. 项目节存在
  121. contractsTree := s.treeContractDao.Get(treeId, bidsectionId, projectId, 1)
  122. if contractsTree.Id == 0 {
  123. return errors.New("未找到项目节")
  124. }
  125. // 2.项目节是没有合同
  126. if contractsTree.ContractId == 0 {
  127. return errors.New("该项目节上没有找到合同")
  128. }
  129. // 3.合同锁定 不能删除
  130. if contractsTree.ContractLocking == 1 {
  131. return errors.New("该合同已锁定")
  132. }
  133. // 删除支出合同
  134. err := s.contractDao.DeleteExpenditure(projectId, bidsectionId, treeId, id)
  135. if err != nil {
  136. return err
  137. }
  138. // 3.获得该标段下合同总数 - 总收入金额
  139. contractTotal, priceTotal := s.getContractTotalAndPrice(bidsectionId, projectId, 1)
  140. // 更新标段目录上合同金额和总数
  141. err = s.treeDao.UpdateContractsAndPayPrice(projectId, bidsectionId, contractTotal, priceTotal)
  142. if err != nil {
  143. return err
  144. }
  145. // 4.更新回款总金额
  146. err = s.contractPaidDao.UpdatePaidTotalPrice(projectId, bidsectionId, id)
  147. if err != nil {
  148. return err
  149. }
  150. return nil
  151. }