proj_business.go 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205
  1. // ==========================================================================
  2. // This is auto-generated by gf cli tool. Fill this file as you wish.
  3. // ==========================================================================
  4. package model
  5. import (
  6. "dashoo.cn/micro/app/model/proj/internal"
  7. "dashoo.cn/opms_libary/request"
  8. "github.com/gogf/gf/os/gtime"
  9. )
  10. // ProjBusiness is the golang structure for table proj_business.
  11. type ProjBusiness internal.ProjBusiness
  12. // Fill with you ideas below.
  13. type ProjBusinessSearchReq struct {
  14. NboName string `json:"nboName"` // 项目名称
  15. CustName string `json:"custName"` // 客户名称
  16. SaleName string `json:"saleName"` // 销售姓名
  17. NboType string `json:"nboType"` // 项目类别(A类B类C类)
  18. ProductLine string `json:"productLine"` // 产品线
  19. NboSource string `json:"nboSource"` // 项目来源
  20. DistributorName string `json:"distributorName"` // 经销商/代理商名称
  21. //FilingTime *gtime.Time `json:"filingTime"` // 项目备案时间
  22. request.PageReq
  23. }
  24. type ProjBusinessRes struct {
  25. ProjBusiness
  26. CustProvinceId int `orm:"cust_province_id" json:"custProvinceId"` // 所在省ID
  27. CustProvince string `orm:"cust_province" json:"custProvince"` // 所在省
  28. CustCityId int `orm:"cust_city_id" json:"custCityId"` // 所在市ID
  29. CustCity string `orm:"cust_city" json:"custCity"` // 所在市
  30. ContractAmount float64 `json:"contractAmount"` // 合同金额
  31. ProjClosingTime *gtime.Time `json:"projClosingTime"` // 合同金额
  32. }
  33. type AddProjBusinessReq struct {
  34. NboName string `json:"nboName" v:"required#项目名称不能为空"` // 项目名称
  35. CustId int `json:"custId" v:"required|min:1#|关联客户不能为空"` // 关联客户
  36. CustName string `json:"custName" v:"required#关联客户不能为空"` // 客户名称
  37. NboSource string `json:"nboSource" v:"required#项目来源不能为空"` // 项目来源
  38. ContactId int `json:"contactId" v:"required|min:1#|关联联系人不能为空"` // 关联联系人
  39. ContactName string `json:"contactName" v:"required#联系人姓名不能为空"` // 联系人姓名
  40. ContactPostion string `json:"contactPostion"` // 联系人岗位
  41. ContactTelephone string `json:"contactTelephone"` // 联系人电话
  42. SaleId int `json:"saleId" v:"required|min:1#|归属销售不能为空"` // 归属销售
  43. SaleName string `json:"saleName" v:"required#销售姓名不能为空"` // 销售姓名
  44. SalesModel string `json:"salesModel" v:"required|in:10,20,30#销售模式不能为空|销售模式不存在"` // 销售模式(10直销20经销30代理)
  45. DistributorId int `json:"distributorId" v:"required-unless:salesModel,10#经销商/代理商不能为空"` // 经销商/代理商ID
  46. DistributorName string `json:"distributorName" v:"required-unless:salesModel,10#经销商/代理商名称不能为空"` // 经销商/代理商名称
  47. NboType string `json:"nboType"` // 项目级别(A 、B 、C 、成交、储备)
  48. ProductLine string `json:"productLine" v:"required#产品线不能为空"` // 产品线
  49. IsBig string `json:"isBig" v:"required#是否大项目不能为空"` // 是否大项目
  50. NboBudget float64 `json:"nboBudget"` // 项目预算
  51. FilingTime *gtime.Time `json:"filingTime"` // 项目备案时间
  52. PlanPurchaseTime *gtime.Time `json:"planPurchaseTime"` // 计划采购时间
  53. EstTransTime *gtime.Time `json:"estTransTime"` // 预计成交时间
  54. EstTransPrice float64 `json:"estTransPrice"` // 预计成交价格
  55. RiskProfile string `json:"riskProfile"` // 风险情况
  56. Difficulty string `json:"difficulty"` // 困难点
  57. Competitor string `json:"competitor"` // 竞争公司
  58. Intervention string `json:"intervention"` // 介入情况
  59. Remark string `json:"remark"` // 备注
  60. BidId int `json:"bidId"` // 客户招标Id
  61. BidInfo string `json:"bidInfo"` // 客户招标信息
  62. // 跟进日程
  63. //FollowTime *gtime.Time `json:"followTime" v:"required#跟进时间不能为空"` // 跟进时间
  64. //FollowUserId int `json:"followUserId"` // 关联跟进负责人
  65. //FollowUserName string `json:"followUserName"` // 跟进负责人姓名
  66. //FollowContent string `json:"followContent" v:"required#跟进内容不能为空"` // 跟进内容
  67. Products []BusinessProduct `json:"products" v:"required#产品列表不能为空"` // 产品列表
  68. //20230330 添加
  69. NextFollowTime *gtime.Time `json:"nextFollowTime"` // 下次联系时间
  70. FinalFollowTime *gtime.Time `json:"finalFollowTime"` // 最新跟进时间
  71. TechnicalSupportTime *gtime.Time `json:"technicalSupportTime"` // 技术支持时间
  72. TechnicalSupportName string `json:"technicalSupportName"` // 技术支持人员
  73. TechnicalSupportContent string `json:"technicalSupportContent"` // 技术支持内容
  74. ParentReceiver string `json:"parentReceiver"` // 总部对接人
  75. CapitalSource string `json:"capitalSource"` // 资金来源
  76. NboBudgetTime *gtime.Time `json:"nboBudgetTime"` // 项目预算期限
  77. ProductSatisfaction string `json:"productSatisfaction"` // 产品/方案满足情况
  78. PurchasingWay string `json:"purchasingWay"` // 采购方式
  79. PurchasingTime *gtime.Time `json:"purchasingTime"` // 采购时间
  80. MakerName string `json:"makerName"` // 决策人员
  81. MakerDept string `json:"makerDept"` // 决策部门
  82. DealerSalesName string `json:"dealerSalesName"` // 经销商销售人员
  83. Accendant string `json:"accendant"` // 维护部门及人员
  84. IsAdoptDashoo string `json:"isAdoptDashoo"` // 是否采纳大数技术参数
  85. }
  86. type UpdateProjBusinessReq struct {
  87. Id int `p:"id" v:"required# id不能为空"`
  88. *AddProjBusinessReq
  89. }
  90. // BusinessProduct 项目产品
  91. type BusinessProduct struct {
  92. Id int `json:"id"` // 主键
  93. BusId int `json:"busId"` // 关联项目
  94. ProdId int `json:"prodId" v:"required|min:1#|关联产品不能为空"` // 关联产品
  95. ProdName string `json:"prodName" v:"required#产品名称不能为空"` // 产品名称
  96. ProdCode string `json:"prodCode" v:"required#产品编码不能为空"` // 产品编码
  97. ProdClass string `json:"prodClass" v:"required#产品类别不能为空"` // 产品类别
  98. ProdNum int `json:"prodNum" v:"required#产品数量不能为空"` // 产品数量
  99. ProdPrice float64 `json:"prodPrice" v:"required#产品售价不能为空"` // 产品售价
  100. GuidPrice float64 `json:"guidPrice"` // 建议成交价
  101. ProdUnit string `json:"prodUnit"` // 产品单位
  102. TotalPrice int `json:"totalPrice"` // 总价
  103. Remark string `json:"remark"` // 备注
  104. }
  105. // BusinessUpgradeReq 项目升级请求
  106. type BusinessUpgradeReq struct {
  107. Id int `json:"id" v:"required|min:1#|id不能为空"` // 主键
  108. NboType string `json:"nboType" v:"required|in:10,20,30#项目级别不能为空|项目级别错误"` // 项目级别
  109. NboBudget float64 `json:"nboBudget" v:"required-unless:nboType,30#项目预算不能为空"` // 项目预算
  110. DistributorId int `json:"distributorId" ` // 经销商/代理商ID
  111. DistributorName string `json:"distributorName" ` // 经销商/代理商名称
  112. TechnicalSupportName string `json:"technicalSupportName" v:"required-unless:nboType,30#技术支持人员不能为空"` // 技术支持人员
  113. TechnicalSupportContent string `json:"technicalSupportContent" v:"required-unless:nboType,30#技术支持内容不能为空"` // 技术支持内容
  114. TechnicalSupportTime *gtime.Time `json:"technicalSupportTime" v:"required-unless:nboType,30#技术支持时间不能为空"` // 技术支持时间
  115. //CustomerSatisfaction string `json:"customerSatisfaction"` // 客户满意度 (10很满意、20满意、30较满意、40一般、50不满意)
  116. ParentReceiver string `json:"parentReceiver"` // 总部对接人
  117. NboBudgetTime *gtime.Time `json:"nboBudgetTime"` // 项目预算期限
  118. CapitalSource string `json:"capitalSource"` // 资金来源
  119. ProductSatisfaction string `json:"productSatisfaction"` // 产品/方案满足情况
  120. PurchasingWay string `json:"purchasingWay" v:"required-if:nboType,10#采购方式不能为空"` // 采购方式
  121. PurchasingTime *gtime.Time `json:"purchasingTime" v:"required-if:nboType,10#采购时间不能为空"` // 采购时间
  122. IsAdoptDashoo string `json:"isAdoptDashoo" v:"required-if:nboType,10#是否采纳大数技术参数不能为空"` // 是否采纳大数技术参数(上传附件)
  123. MakerId int `json:"makerId"` // 关联决策人
  124. MakerName string `json:"makerName"` // 决策人姓名
  125. MakerDept string `json:"makerDept"` // 决策人部门
  126. HistoricalTransactionInfo string `json:"historicalTransactionInfo"` // 经销商与客户历史成交信息
  127. DealerSalesId int `json:"dealerSalesId"` // 关联经销商销售
  128. DealerSalesName string `json:"dealerSalesName"` // 经销商销售人员
  129. Accendant string `json:"accendant"` // 维护部门及人员
  130. Remark string `json:"remark"` // 备注
  131. ProjConversionReason string `json:"projConversionReason" v:"required-if:nboType,30#转化原因不能为空"` // 项目转化原因
  132. QuotationFile string `json:"quotationFile"` // 报价单文件
  133. DashooParamFile string `json:"dashooParamFile"` // 大数参数文件
  134. }
  135. // BusinessDowngradeReq 项目降级请求
  136. type BusinessDowngradeReq struct {
  137. Id int `json:"id" v:"required|min:1#|id不能为空"` // 主键
  138. NboType string `json:"nboType" v:"required|in:10,20,30,50#项目级别不能为空|项目级别错误"` // 项目级别
  139. TechnicalSupportName string `json:"technicalSupportName"` // 技术支持人员
  140. TechnicalSupportContent string `json:"technicalSupportContent"` // 技术支持内容
  141. TechnicalSupportTime *gtime.Time `json:"technicalSupportTime"` // 技术支持时间
  142. Remark string `json:"remark" v:"required# 降级原因不能为空"` // 备注原因
  143. }
  144. // BusinessTransferReq 项目转移请求
  145. type BusinessTransferReq struct {
  146. Id int `json:"id" v:"required|min:1#|id不能为空"` // 主键
  147. UserId int `json:"userId" v:"required# 负责人不能为空"` // 负责人
  148. UserName string `json:"userName" v:"required# 负责人不能为空"` // 负责人
  149. Remark string `json:"remark"` // 备注
  150. }
  151. // BusinessToReserveReq 项目转为储备项目
  152. type BusinessToReserveReq struct {
  153. Id int `json:"id" v:"required|min:1#|id不能为空"` // 主键
  154. ProjConversionReason string `json:"projConversionReason" v:"required# 项目转化原因不能为空"` // 项目转化原因
  155. }
  156. // BusinessPrimacyContactReq 设置首要联系人请求
  157. type BusinessPrimacyContactReq struct {
  158. Id int `json:"id" v:"required|min:1#|id不能为空"` // 主键
  159. ContactId int `json:"contactId" v:"required#关联联系人不能为空"` // 关联联系人
  160. ContactName string `json:"contactName" v:"required#联系人姓名不能为空"` // 联系人姓名
  161. ContactPostion string `json:"contactPostion"` // 联系人岗位
  162. ContactTelephone string `json:"contactTelephone"` // 联系人电话
  163. Remark string `json:"remark"` // 备注
  164. }
  165. // UpdateBusinessStatusReq 更新项目状态请求
  166. type UpdateBusinessStatusReq struct {
  167. Id int `json:"id" v:"required|min:1#|id不能为空"` // 主键
  168. NboStatus string `json:"nboStatus" v:"required|in:10,20,30# 项目状态不能为空|项目状态不存在"` // 项目状态
  169. Remark string `json:"remark"` // 备注
  170. }
  171. // BusinessReq 获取项目关联信息
  172. type BusinessReq struct {
  173. BusId int64 `json:"busId" v:"required|min:1#|关联项目不能为空"` // 主键
  174. request.PageReq
  175. }
  176. // BusinessDynamicsReq 获取项目关联信息
  177. type BusinessDynamicsReq struct {
  178. BusId int64 `json:"busId" v:"required|min:1#|关联项目不能为空"` // 主键
  179. OpnType string `json:"opnType"` // 操作类型
  180. request.PageReq
  181. }