contract_expenditure_service.go 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168
  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 = contractData.Price
  40. contractsCm.Returned = "0"
  41. contractsCm.Paid = "0"
  42. contractsCm.TreeId = treeId
  43. contractsCm.ProjectId = projectId
  44. contractsCm.BidsectionId = bidsectionId
  45. contractsCm.Status = 0
  46. contractsCm.CreateTime = time.Now()
  47. contractsCm.UpdateTime = time.Now()
  48. err := s.contractDao.Add(contractsCm)
  49. if err != nil {
  50. return err
  51. }
  52. // 3.获得该标段下合同总数 - 总收入金额
  53. contractTotal, priceTotal := s.getContractTotalAndPrice(bidsectionId, projectId, 1)
  54. // 更新标段目录上合同金额和总数
  55. err = s.treeDao.UpdateContractsAndPayPrice(projectId, bidsectionId, contractTotal, priceTotal)
  56. if err != nil {
  57. return err
  58. }
  59. return nil
  60. }
  61. // 更新支出合同
  62. func (s *contractService) UpdateExpenditure(contractData *viewmodels.Contracts, projectId int, bidsectionId int, treeId int) error {
  63. // 1. 项目节存在
  64. contractsTree := s.treeContractDao.Get(treeId, bidsectionId, projectId, 1)
  65. if contractsTree.Id == 0 {
  66. return errors.New("未找到项目节")
  67. }
  68. // 2.项目节是没有合同
  69. if contractsTree.ContractId == 0 {
  70. return errors.New("该项目节上没有找到合同")
  71. }
  72. // 3.合同锁定 不能删除
  73. if contractsTree.ContractLocking == 1 {
  74. return errors.New("该合同已锁定")
  75. }
  76. // 4.合同金额不能小于回款金额
  77. paidPrice, _ := decimal.NewFromString(contractsTree.ContractsPaid)
  78. price, err := decimal.NewFromString(contractData.Price)
  79. if err != nil {
  80. return errors.New("金额填写有误")
  81. }
  82. if paidPrice.GreaterThan(price) {
  83. return errors.New(fmt.Sprintf("合同金额不能低于%s", contractsTree.ContractsPaid))
  84. }
  85. contractsCm := &models.CmContracts{}
  86. contractsCm.Id = contractsTree.ContractId
  87. contractsCm.Content = contractData.Content
  88. contractsCm.Name = contractData.Name
  89. contractsCm.Price = contractData.Price
  90. contractsCm.PartyA = contractData.PartyA
  91. contractsCm.PartyASigner = contractData.PartyASigner
  92. contractsCm.PartyB = contractData.PartyB
  93. contractsCm.PartyBSigner = contractData.PartyBSigner
  94. loc, _ := time.LoadLocation("Local")
  95. SignerTime, err := time.ParseInLocation(conf.SysTimeform, contractData.SignerTime, loc)
  96. if err != nil {
  97. return errors.New("签约时间填写异常")
  98. }
  99. contractsCm.SignerTime = SignerTime
  100. contractsCm.Remarks = contractData.Remarks
  101. columns := []string{"Content", "Name", "Price", "PartyA", "PartyASigner", "PartyB", "PartyBSigner"}
  102. err = s.contractDao.UpdateExpenditure(contractsCm, columns, projectId, bidsectionId, treeId)
  103. if err != nil {
  104. return err
  105. }
  106. // 3.获得该标段下合同总数 - 总收入金额
  107. contractTotal, priceTotal := s.getContractTotalAndPrice(bidsectionId, projectId, 1)
  108. // 更新标段目录上合同金额和总数
  109. err = s.treeDao.UpdateContractsAndPayPrice(projectId, bidsectionId, contractTotal, priceTotal)
  110. if err != nil {
  111. return err
  112. }
  113. return nil
  114. }
  115. // 删除支出合同
  116. func (s *contractService) DeleteExpenditure(projectId int, bidsectionId int, treeId int, id int) error {
  117. // 1. 项目节存在
  118. contractsTree := s.treeContractDao.Get(treeId, bidsectionId, projectId, 1)
  119. if contractsTree.Id == 0 {
  120. return errors.New("未找到项目节")
  121. }
  122. // 2.项目节是没有合同
  123. if contractsTree.ContractId == 0 {
  124. return errors.New("该项目节上没有找到合同")
  125. }
  126. // 3.合同锁定 不能删除
  127. if contractsTree.ContractLocking == 1 {
  128. return errors.New("该合同已锁定")
  129. }
  130. // 删除支出合同
  131. err := s.contractDao.DeleteExpenditure(projectId, bidsectionId, treeId, id)
  132. if err != nil {
  133. return err
  134. }
  135. // 3.获得该标段下合同总数 - 总收入金额
  136. contractTotal, priceTotal := s.getContractTotalAndPrice(bidsectionId, projectId, 1)
  137. // 更新标段目录上合同金额和总数
  138. err = s.treeDao.UpdateContractsAndPayPrice(projectId, bidsectionId, contractTotal, priceTotal)
  139. if err != nil {
  140. return err
  141. }
  142. // 4.更新回款总金额
  143. err = s.contractPaidDao.UpdatePaidTotalPrice(projectId, bidsectionId, id)
  144. if err != nil {
  145. return err
  146. }
  147. return nil
  148. }