contract_pre_register.go 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240
  1. package fms
  2. import (
  3. "hongze/fms_api/global"
  4. "hongze/fms_api/models/base"
  5. "hongze/fms_api/utils"
  6. "time"
  7. )
  8. // PreRegister 合同开票表
  9. type ContractPreRegister struct {
  10. PreRegisterId int `gorm:"primaryKey;column:pre_register_id" json:"pre_register_id" description:"预登记ID"`
  11. ContractRegisterId int `gorm:"column:contract_register_id" json:"contract_register_id" description:"登记ID"`
  12. InvoiceId int `gorm:"column:invoice_id" json:"invoice_id" description:"开票ID"`
  13. ArriveId int `gorm:"column:arrive_id" json:"arrive_id" description:"到款ID"`
  14. CompanyName string `json:"company_name" description:"客户名称"`
  15. Amount float64 `gorm:"column:amount" json:"amount" description:"开票换算后的金额(人民币)"`
  16. OriginAmount float64 `gorm:"column:origin_amount" json:"origin_amount" description:"开票金额"`
  17. CurrencyUnit string `gorm:"column:currency_unit" json:"currency_unit" description:"开票货币国际代码"`
  18. ArriveAmount float64 `gorm:"column:arrive_amount" json:"arrive_amount" description:"到款换算后的金额(人民币)"`
  19. ArriveOriginAmount float64 `gorm:"column:arrive_origin_amount" json:"arrive_origin_amount" description:"到款金额"`
  20. InvoiceType int `gorm:"column:invoice_type" json:"invoice_type" description:"类型: 1-开票登记; 2-到款登记;3-开票预登记;4-到款预登记"`
  21. InvoiceDate time.Time `gorm:"column:invoice_time" json:"invoice_time" description:"开票日"`
  22. ArriveDate time.Time `gorm:"column:arrive_time" json:"arrive_time" description:"到款日"`
  23. SellerId int `gorm:"column:seller_id" json:"seller_id" description:"销售ID"`
  24. SellerName string `gorm:"column:seller_name" json:"seller_name" description:"销售名称"`
  25. SellerGroupId int `gorm:"column:seller_group_id" json:"seller_group_id" description:"销售分组ID"`
  26. SellerGroupName string `gorm:"column:seller_group_name" json:"seller_group_name" description:"销售分组名称"`
  27. SellerTeamId int `gorm:"column:seller_team_id" json:"seller_team_id" description:"销售小组ID"`
  28. SellerTeamName string `gorm:"column:seller_team_name" json:"seller_team_name" description:"销售小组名称"`
  29. AdminId int `gorm:"column:admin_id" json:"admin_id" description:"操作人ID"`
  30. AdminName string `gorm:"column:admin_name" json:"admin_name" description:"操作人姓名"`
  31. Remark string `gorm:"column:remark" json:"remark" description:"备注信息"`
  32. ArriveRemark string `gorm:"column:arrive_remark" json:"arrive_remark" description:"到款备注信息"`
  33. ServiceProductId int `gorm:"column:service_product_id" json:"service_product_id" description:"套餐类型:1ficc套餐,2权益套餐"`
  34. IsPrePay int `gorm:"column:is_pre_pay" json:"is_pre_pay" description:"是否预付款: 0-不是; 1-是"`
  35. StartDate time.Time `gorm:"column:start_date" json:"start_date" description:"约定开始时间"`
  36. EndDate time.Time `gorm:"column:end_date" json:"end_date" description:"约定结束时间"`
  37. ContractType int `gorm:"column:contract_type" json:"contract_type" description:"合同类型: 1-新签; 2-续约; 3-代付; 4-补充协议"`
  38. HasPayment int `gorm:"column:has_payment" json:"has_payment" description:"是否有代付: 0-无; 1-有"`
  39. PaymentSellerId int `gorm:"column:payment_seller_id;default:0;NOT NULL" json:"payment_seller_id"` // 销售ID
  40. PaymentSellerName string `gorm:"column:payment_seller_name;NOT NULL" json:"payment_seller_name"` // 销售名称
  41. PaymentSellerGroupId int `gorm:"column:payment_seller_group_id;default:0;NOT NULL" json:"payment_seller_group_id"` // 销售分组ID
  42. PaymentSellerGroupName string `gorm:"column:payment_seller_group_name;NOT NULL" json:"payment_seller_group_name"` // 销售分组名称
  43. PaymentSellerTeamId int `gorm:"column:payment_seller_team_id;default:0;NOT NULL" json:"payment_seller_team_id"` // 销售小组ID
  44. PaymentSellerTeamName string `gorm:"column:payment_seller_team_name;NOT NULL" json:"payment_seller_team_name"` // 销售小组名称
  45. base.TimeBase
  46. }
  47. func (c *ContractPreRegister) TableName() string {
  48. return "contract_pre_register"
  49. }
  50. // ContractPreRegisterItem 合同开票/到款
  51. type ContractPreRegisterItem struct {
  52. PreRegisterId int `gorm:"primaryKey;column:pre_register_id" json:"pre_register_id" description:"预登记ID"`
  53. ContractRegisterId int `gorm:"column:contract_register_id" json:"contract_register_id" description:"登记ID"`
  54. InvoiceId int `gorm:"column:invoice_id" json:"invoice_id" description:"开票ID"`
  55. ArriveId int `gorm:"column:arrive_id" json:"arrive_id" description:"到款ID"`
  56. CompanyName string `json:"company_name" description:"客户名称"`
  57. Amount float64 `gorm:"column:amount" json:"amount" description:"开票换算后的金额(人民币)"`
  58. OriginAmount float64 `gorm:"column:origin_amount" json:"origin_amount" description:"开票金额"`
  59. CurrencyUnit string `gorm:"column:currency_unit" json:"currency_unit" description:"开票货币国际代码"`
  60. ArriveAmount float64 `gorm:"column:arrive_amount" json:"arrive_amount" description:"到款换算后的金额(人民币)"`
  61. ArriveOriginAmount float64 `gorm:"column:arrive_origin_amount" json:"arrive_origin_amount" description:"到款金额"`
  62. UnitName string `json:"unit_name" description:"货币单位名称"`
  63. InvoiceType int `gorm:"column:invoice_type" json:"invoice_type" description:"类型: 1-开票登记; 2-到款登记;3-开票预登记;4-到款预登记"`
  64. InvoiceDate string `gorm:"column:invoice_time" json:"invoice_time" description:"开票日"`
  65. ArriveDate string `gorm:"column:arrive_time" json:"arrive_time" description:"到款日"`
  66. SellerId int `gorm:"column:seller_id" json:"seller_id" description:"销售ID"`
  67. SellerName string `gorm:"column:seller_name" json:"seller_name" description:"销售名称"`
  68. PayType int `gorm:"column:pay_type" json:"pay_type" description:"付款方式:0-无;1-年付;2-半年付;3-季付;4-次付;5-异常"`
  69. Remark string `gorm:"column:remark" json:"remark" description:"开票备注信息"`
  70. ArriveRemark string `gorm:"column:arrive_remark" json:"arrive_remark" description:"到款备注信息"`
  71. ServiceProductId int `gorm:"column:service_product_id" json:"service_product_id" description:"套餐类型:1ficc套餐,2权益套餐"`
  72. IsPrePay int `gorm:"column:is_pre_pay" json:"is_pre_pay" description:"是否预付款: 0-不是; 1-是"`
  73. StartDate string `gorm:"column:start_date" json:"start_date" description:"约定开始时间"`
  74. EndDate string `gorm:"column:end_date" json:"end_date" description:"约定结束时间"`
  75. AdminId int `gorm:"column:admin_id" json:"admin_id" description:"操作人ID"`
  76. CreateTime string `gorm:"column:create_time" json:"create_time" description:"创建时间"`
  77. ContractType int `json:"contract_type" binding:"oneof=1 2 3 4" description:"合同类型: 1-新签; 2-续约; 3-代付; 4-补充协议"`
  78. HasPayment int `json:"has_payment" description:"是否有代付: 0-无; 1-有"`
  79. PaymentSellerId int `gorm:"column:payment_seller_id;default:0;NOT NULL" json:"payment_seller_id"` // 销售ID
  80. PaymentSellerName string `gorm:"column:payment_seller_name;NOT NULL" json:"payment_seller_name"` // 销售名称
  81. PaymentSellerGroupId int `gorm:"column:payment_seller_group_id;default:0;NOT NULL" json:"payment_seller_group_id"` // 销售分组ID
  82. PaymentSellerGroupName string `gorm:"column:payment_seller_group_name;NOT NULL" json:"payment_seller_group_name"` // 销售分组名称
  83. PaymentSellerTeamId int `gorm:"column:payment_seller_team_id;default:0;NOT NULL" json:"payment_seller_team_id"` // 销售小组ID
  84. PaymentSellerTeamName string `gorm:"column:payment_seller_team_name;NOT NULL" json:"payment_seller_team_name"` // 销售小组名称
  85. }
  86. // formatContractInvoice2Item 格式化ContractInvoiceItem
  87. func formatContractPreRegister2Item(item *ContractPreRegister) (formatItem *ContractPreRegisterItem) {
  88. formatItem = new(ContractPreRegisterItem)
  89. formatItem.PreRegisterId = item.PreRegisterId
  90. formatItem.ContractRegisterId = item.ContractRegisterId
  91. formatItem.InvoiceId = item.InvoiceId
  92. formatItem.ArriveId = item.ArriveId
  93. formatItem.CompanyName = item.CompanyName
  94. formatItem.Amount = item.Amount
  95. formatItem.OriginAmount = item.OriginAmount
  96. formatItem.CurrencyUnit = item.CurrencyUnit
  97. formatItem.ArriveAmount = item.ArriveAmount
  98. formatItem.ArriveOriginAmount = item.ArriveOriginAmount
  99. formatItem.InvoiceType = item.InvoiceType
  100. formatItem.InvoiceDate = utils.TimeTransferString(utils.FormatDate, item.InvoiceDate)
  101. formatItem.ArriveDate = utils.TimeTransferString(utils.FormatDate, item.ArriveDate)
  102. formatItem.SellerId = item.SellerId
  103. formatItem.SellerName = item.SellerName
  104. formatItem.Remark = item.Remark
  105. formatItem.ArriveRemark = item.ArriveRemark
  106. formatItem.IsPrePay = item.IsPrePay
  107. formatItem.ServiceProductId = item.ServiceProductId
  108. formatItem.AdminId = item.AdminId
  109. formatItem.CreateTime = utils.TimeTransferString(utils.FormatDateTime, item.CreateTime)
  110. formatItem.StartDate = item.StartDate.Format(utils.FormatDate)
  111. formatItem.EndDate = item.EndDate.Format(utils.FormatDate)
  112. formatItem.PaymentSellerId = item.PaymentSellerId
  113. formatItem.PaymentSellerName = item.PaymentSellerName
  114. formatItem.PaymentSellerGroupId = item.PaymentSellerGroupId
  115. formatItem.PaymentSellerGroupName = item.PaymentSellerGroupName
  116. formatItem.PaymentSellerTeamId = item.PaymentSellerTeamId
  117. formatItem.PaymentSellerTeamName = item.PaymentSellerTeamName
  118. formatItem.ContractType = item.ContractType
  119. formatItem.HasPayment = item.HasPayment
  120. return
  121. }
  122. // GetContractInvoiceItemPageList 获取合同开票/到款列表-分页
  123. func GetContractPreRegisterItemPageList(page base.IPage, condition string, pars []interface{}) (count int64, results []*ContractPreRegisterItem, err error) {
  124. list := make([]*ContractPreRegister, 0)
  125. query := global.DEFAULT_MYSQL.Table("contract_pre_register").
  126. Where(condition, pars...)
  127. query.Count(&count)
  128. if len(page.GetOrderItemsString()) > 0 {
  129. query = query.Order(page.GetOrderItemsString())
  130. }
  131. err = query.Limit(int(page.GetPageSize())).Offset(int(page.Offset())).Find(&list).Error
  132. if err != nil {
  133. return
  134. }
  135. for i := range list {
  136. results = append(results, formatContractPreRegister2Item(list[i]))
  137. }
  138. return
  139. }
  140. func (c *ContractPreRegister) Create() (err error) {
  141. err = global.DEFAULT_MYSQL.Create(c).Error
  142. return
  143. }
  144. func (c *ContractPreRegister) Fetch(id int) (item *ContractPreRegister, err error) {
  145. err = global.DEFAULT_MYSQL.Model(c).Where(" pre_register_id = ?", id).First(&item).Error
  146. return
  147. }
  148. func (c *ContractPreRegister) FetchByRegisterId(id int) (items []*ContractPreRegister, err error) {
  149. err = global.DEFAULT_MYSQL.Model(c).Where(" contract_register_id = ?", id).Find(&items).Error
  150. return
  151. }
  152. // 删除
  153. func (c *ContractPreRegister) Delete() (err error) {
  154. err = global.DEFAULT_MYSQL.Delete(c).Error
  155. return
  156. }
  157. func (c *ContractPreRegister) Update(updateCols []string) (err error) {
  158. err = global.DEFAULT_MYSQL.Model(c).Select(updateCols).Updates(c).Error
  159. return
  160. }
  161. // GetContractInvoiceItemList 获取开票到款列表
  162. func GetContractPreRegisterItemList(condition string, pars []interface{}) (itemList []*ContractPreRegisterItem, err error) {
  163. list := make([]*ContractPreRegister, 0)
  164. err = global.DEFAULT_MYSQL.Model(ContractPreRegister{}).
  165. Where("is_deleted = 0").
  166. Where(condition, pars...).
  167. Order("contract_invoice_id ASC").
  168. Find(&list).Error
  169. if err != nil {
  170. return
  171. }
  172. itemList = formatContractPreRegister2ItemList(list)
  173. return
  174. }
  175. // formatContractPreRegister2ItemList 格式化ContractInvoice
  176. func formatContractPreRegister2ItemList(list []*ContractPreRegister) (itemList []*ContractPreRegisterItem) {
  177. itemList = make([]*ContractPreRegisterItem, 0)
  178. for i := range list {
  179. itemList = append(itemList, &ContractPreRegisterItem{
  180. PreRegisterId: list[i].PreRegisterId,
  181. ContractRegisterId: list[i].ContractRegisterId,
  182. Amount: list[i].Amount,
  183. OriginAmount: list[i].OriginAmount,
  184. CurrencyUnit: list[i].CurrencyUnit,
  185. ArriveAmount: list[i].ArriveAmount,
  186. ArriveOriginAmount: list[i].ArriveOriginAmount,
  187. InvoiceType: list[i].InvoiceType,
  188. InvoiceDate: utils.TimeTransferString(utils.FormatDate, list[i].InvoiceDate),
  189. SellerId: list[i].SellerId,
  190. SellerName: list[i].SellerName,
  191. Remark: list[i].Remark,
  192. ServiceProductId: list[i].ServiceProductId,
  193. IsPrePay: list[i].IsPrePay,
  194. StartDate: list[i].StartDate.Format(utils.FormatDate),
  195. EndDate: list[i].StartDate.Format(utils.FormatDate),
  196. CreateTime: utils.TimeTransferString(utils.FormatDateTime, list[i].CreateTime),
  197. })
  198. }
  199. return
  200. }
  201. // ContractPreRegisterList 预登记列表
  202. type ContractPreRegisterList struct {
  203. *ContractPreRegisterItem
  204. ServicesName string `json:"services" description:"套餐名称"`
  205. ContractTypeString string `json:"contract_type_string" description:"合同类型"`
  206. }
  207. // PreRegisterDetailReq 预登记详情请求体
  208. type PreRegisterDetailReq struct {
  209. ContractRegisterId int `json:"contract_register_id" form:"contract_register_id" binding:"required,gte=1"`
  210. InvoiceType int `gorm:"column:invoice_type" json:"invoice_type" description:"类型: 1-开票登记; 2-到款登记;3-开票预登记;4-到款预登记"`
  211. PreRegisterId int `gorm:"column:pre_register_id" json:"pre_register_id" description:"预登记ID"`
  212. InvoiceId int `gorm:"column:invoice_id" json:"invoice_id" description:"开票ID"`
  213. ArriveId int `gorm:"column:arrive_id" json:"arrive_id" description:"到款ID"`
  214. DetailType int `json:"detail_type" description:"请求类型"`
  215. ContractType int `json:"contract_type" binding:"oneof=1 2 3 4" description:"合同类型: 1-新签; 2-续约; 3-代付; 4-补充协议"`
  216. HasPayment int `json:"has_payment" description:"是否有代付: 0-无; 1-有"`
  217. }
  218. // ContractPreRegisterDetail 预登记详情
  219. type ContractPreRegisterDetail struct {
  220. *ContractRegisterItem
  221. List []*ContractInvoiceDetailItem `json:"list" description:"开票到款列表"`
  222. Services []*ContractServiceAndDetail `json:"services" description:"套餐列表"`
  223. ServiceTemplateIds []int `json:"serviceTemplateIds" description:"小套餐列表"`
  224. }