|
@@ -8,7 +8,6 @@ import ( |
|
@@ -8,7 +8,6 @@ import ( |
|
8
|
"gitlab.fjmaimaimai.com/allied-creation/allied-creation-cooperation/pkg/domain"
|
8
|
"gitlab.fjmaimaimai.com/allied-creation/allied-creation-cooperation/pkg/domain"
|
|
9
|
"gitlab.fjmaimaimai.com/allied-creation/allied-creation-cooperation/pkg/domain/service"
|
9
|
"gitlab.fjmaimaimai.com/allied-creation/allied-creation-cooperation/pkg/domain/service"
|
|
10
|
"gitlab.fjmaimaimai.com/allied-creation/allied-creation-cooperation/pkg/infrastructure/repository"
|
10
|
"gitlab.fjmaimaimai.com/allied-creation/allied-creation-cooperation/pkg/infrastructure/repository"
|
|
11
|
- "gitlab.fjmaimaimai.com/allied-creation/allied-creation-cooperation/pkg/log"
|
|
|
|
12
|
)
|
11
|
)
|
|
13
|
|
12
|
|
|
14
|
type ConfirmDividendsIncentivesEstimateService struct {
|
13
|
type ConfirmDividendsIncentivesEstimateService struct {
|
|
@@ -17,26 +16,10 @@ type ConfirmDividendsIncentivesEstimateService struct { |
|
@@ -17,26 +16,10 @@ type ConfirmDividendsIncentivesEstimateService struct { |
|
17
|
}
|
16
|
}
|
|
18
|
|
17
|
|
|
19
|
// Confirm 确认业绩分红预算
|
18
|
// Confirm 确认业绩分红预算
|
|
20
|
-func (domainService *ConfirmDividendsIncentivesEstimateService) Confirm(orderGoods []*domain.OrderGood, companyId int64, orgId int64) ([]*service.DividendsEstimateDetail, error) {
|
|
|
|
21
|
- var cooperationContractRepository domain.CooperationContractRepository // 共创合约仓储
|
|
|
|
22
|
- var cooperationProjectRepository domain.CooperationProjectRepository // 共创项目仓储
|
19
|
+func (domainService *ConfirmDividendsIncentivesEstimateService) Confirm(orderGoods []*domain.OrderGood, companyId int64, orgId int64, cooperationContractsMap map[string]*domain.CooperationContract, cooperationProjectsMap map[string]*domain.CooperationProject) ([]*service.DividendsEstimateDetail, error) {
|
|
23
|
var dividendsOrderRepository domain.DividendsOrderRepository // 分红订单仓储
|
20
|
var dividendsOrderRepository domain.DividendsOrderRepository // 分红订单仓储
|
|
24
|
var dividendsReturnedOrderRepository domain.DividendsReturnedOrderRepository // 分红退货单仓储
|
21
|
var dividendsReturnedOrderRepository domain.DividendsReturnedOrderRepository // 分红退货单仓储
|
|
25
|
|
22
|
|
|
26
|
- // 共创合约仓储初始化
|
|
|
|
27
|
- if repo, err := repository.NewCooperationContractRepository(domainService.transactionContext); err != nil {
|
|
|
|
28
|
- return nil, err
|
|
|
|
29
|
- } else {
|
|
|
|
30
|
- cooperationContractRepository = repo
|
|
|
|
31
|
- }
|
|
|
|
32
|
-
|
|
|
|
33
|
- // 共创项目仓储初始化
|
|
|
|
34
|
- if repo, err := repository.NewCooperationProjectRepository(domainService.transactionContext); err != nil {
|
|
|
|
35
|
- return nil, err
|
|
|
|
36
|
- } else {
|
|
|
|
37
|
- cooperationProjectRepository = repo
|
|
|
|
38
|
- }
|
|
|
|
39
|
-
|
|
|
|
40
|
// 分红订单仓储初始化
|
23
|
// 分红订单仓储初始化
|
|
41
|
if repo, err := repository.NewDividendsOrderRepository(domainService.transactionContext); err != nil {
|
24
|
if repo, err := repository.NewDividendsOrderRepository(domainService.transactionContext); err != nil {
|
|
42
|
return nil, err
|
25
|
return nil, err
|
|
@@ -51,29 +34,9 @@ func (domainService *ConfirmDividendsIncentivesEstimateService) Confirm(orderGoo |
|
@@ -51,29 +34,9 @@ func (domainService *ConfirmDividendsIncentivesEstimateService) Confirm(orderGoo |
|
51
|
dividendsReturnedOrderRepository = repo
|
34
|
dividendsReturnedOrderRepository = repo
|
|
52
|
}
|
35
|
}
|
|
53
|
|
36
|
|
|
54
|
- // 查询共创合约
|
|
|
|
55
|
- cooperationContractsMap := make(map[string]*domain.CooperationContract, 0)
|
|
|
|
56
|
- if count, cooperationContractsFound, err := cooperationContractRepository.Find(map[string]interface{}{
|
|
|
|
57
|
- "companyId": companyId,
|
|
|
|
58
|
- "orgId": orgId,
|
|
|
|
59
|
- "offsetLimit": false,
|
|
|
|
60
|
- }); err != nil {
|
|
|
|
61
|
- return nil, err
|
|
|
|
62
|
- } else {
|
|
|
|
63
|
- if count > 0 {
|
|
|
|
64
|
- for _, cooperationContractFound := range cooperationContractsFound {
|
|
|
|
65
|
- cooperationContractsMap[cooperationContractFound.CooperationContractNumber] = cooperationContractFound
|
|
|
|
66
|
- }
|
|
|
|
67
|
- }
|
|
|
|
68
|
- }
|
|
|
|
69
|
-
|
|
|
|
70
|
// 确认业绩分红预算
|
37
|
// 确认业绩分红预算
|
|
71
|
var dividendsEstimateDetails []*service.DividendsEstimateDetail
|
38
|
var dividendsEstimateDetails []*service.DividendsEstimateDetail
|
|
72
|
for _, orderGood := range orderGoods {
|
39
|
for _, orderGood := range orderGoods {
|
|
73
|
- log.Logger.Info("业绩分红预算产品", map[string]interface{}{
|
|
|
|
74
|
- "orderGood": orderGood,
|
|
|
|
75
|
- })
|
|
|
|
76
|
-
|
|
|
|
77
|
if orderGood.CooperationContractNumber == "" {
|
40
|
if orderGood.CooperationContractNumber == "" {
|
|
78
|
var orderNumber string
|
41
|
var orderNumber string
|
|
79
|
if orderGood.DividendsOrderNumber != "" {
|
42
|
if orderGood.DividendsOrderNumber != "" {
|
|
@@ -93,9 +56,8 @@ func (domainService *ConfirmDividendsIncentivesEstimateService) Confirm(orderGoo |
|
@@ -93,9 +56,8 @@ func (domainService *ConfirmDividendsIncentivesEstimateService) Confirm(orderGoo |
|
93
|
continue
|
56
|
continue
|
|
94
|
}
|
57
|
}
|
|
95
|
|
58
|
|
|
96
|
- var cooperationContract *domain.CooperationContract
|
|
|
|
97
|
-
|
|
|
|
98
|
// 获取合约
|
59
|
// 获取合约
|
|
|
|
60
|
+ var cooperationContract *domain.CooperationContract
|
|
99
|
if _, ok := cooperationContractsMap[orderGood.CooperationContractNumber]; !ok {
|
61
|
if _, ok := cooperationContractsMap[orderGood.CooperationContractNumber]; !ok {
|
|
100
|
var orderNumber string
|
62
|
var orderNumber string
|
|
101
|
if orderGood.DividendsOrderNumber != "" {
|
63
|
if orderGood.DividendsOrderNumber != "" {
|
|
@@ -115,52 +77,6 @@ func (domainService *ConfirmDividendsIncentivesEstimateService) Confirm(orderGoo |
|
@@ -115,52 +77,6 @@ func (domainService *ConfirmDividendsIncentivesEstimateService) Confirm(orderGoo |
|
115
|
continue
|
77
|
continue
|
|
116
|
} else {
|
78
|
} else {
|
|
117
|
cooperationContract = cooperationContractsMap[orderGood.CooperationContractNumber]
|
79
|
cooperationContract = cooperationContractsMap[orderGood.CooperationContractNumber]
|
|
118
|
- }
|
|
|
|
119
|
-
|
|
|
|
120
|
- //cooperationContract, err := cooperationContractRepository.FindOne(map[string]interface{}{
|
|
|
|
121
|
- // "cooperationContractNumber": orderGood.CooperationContractNumber,
|
|
|
|
122
|
- // "companyId": orderGood.CompanyId,
|
|
|
|
123
|
- // "orgId": orderGood.OrgId,
|
|
|
|
124
|
- //})
|
|
|
|
125
|
- //if err != nil {
|
|
|
|
126
|
- // var orderNumber string
|
|
|
|
127
|
- // if orderGood.DividendsOrderNumber != "" {
|
|
|
|
128
|
- // orderNumber = orderGood.DividendsOrderNumber
|
|
|
|
129
|
- // } else {
|
|
|
|
130
|
- // orderNumber = orderGood.DividendsReturnedOrderNumber
|
|
|
|
131
|
- // }
|
|
|
|
132
|
- // dividendsEstimateDetails = append(dividendsEstimateDetails, &service.DividendsEstimateDetail{
|
|
|
|
133
|
- // DividendsUser: nil,
|
|
|
|
134
|
- // DividendsParticipateType: 0,
|
|
|
|
135
|
- // DividendsStage: 0,
|
|
|
|
136
|
- // DividendsAmount: 0,
|
|
|
|
137
|
- // OrderOrReturnedOrderNumber: orderNumber,
|
|
|
|
138
|
- // IsSuccessfully: false,
|
|
|
|
139
|
- // Reason: "共创合约错误",
|
|
|
|
140
|
- // })
|
|
|
|
141
|
- // continue
|
|
|
|
142
|
- //}
|
|
|
|
143
|
- if cooperationContract == nil {
|
|
|
|
144
|
- var orderNumber string
|
|
|
|
145
|
- if orderGood.DividendsOrderNumber != "" {
|
|
|
|
146
|
- orderNumber = orderGood.DividendsOrderNumber
|
|
|
|
147
|
- } else {
|
|
|
|
148
|
- orderNumber = orderGood.DividendsReturnedOrderNumber
|
|
|
|
149
|
- }
|
|
|
|
150
|
- dividendsEstimateDetails = append(dividendsEstimateDetails, &service.DividendsEstimateDetail{
|
|
|
|
151
|
- DividendsUser: nil,
|
|
|
|
152
|
- DividendsParticipateType: 0,
|
|
|
|
153
|
- DividendsStage: 0,
|
|
|
|
154
|
- DividendsAmount: 0,
|
|
|
|
155
|
- OrderOrReturnedOrderNumber: orderNumber,
|
|
|
|
156
|
- IsSuccessfully: false,
|
|
|
|
157
|
- Reason: "共创合约" + orderGood.CooperationContractNumber + "不存在",
|
|
|
|
158
|
- })
|
|
|
|
159
|
- continue
|
|
|
|
160
|
- } else {
|
|
|
|
161
|
- log.Logger.Info("产品相关的合约", map[string]interface{}{
|
|
|
|
162
|
- "cooperationContract": cooperationContract,
|
|
|
|
163
|
- })
|
|
|
|
164
|
if cooperationContract.Status == 2 {
|
80
|
if cooperationContract.Status == 2 {
|
|
165
|
var orderNumber string
|
81
|
var orderNumber string
|
|
166
|
if orderGood.DividendsOrderNumber != "" {
|
82
|
if orderGood.DividendsOrderNumber != "" {
|
|
@@ -181,49 +97,24 @@ func (domainService *ConfirmDividendsIncentivesEstimateService) Confirm(orderGoo |
|
@@ -181,49 +97,24 @@ func (domainService *ConfirmDividendsIncentivesEstimateService) Confirm(orderGoo |
|
181
|
}
|
97
|
}
|
|
182
|
}
|
98
|
}
|
|
183
|
|
99
|
|
|
184
|
- // 获取共创项目
|
|
|
|
185
|
- if cooperationContract.CooperationProjectNumber != "" {
|
|
|
|
186
|
- cooperationProject, err := cooperationProjectRepository.FindOne(map[string]interface{}{
|
|
|
|
187
|
- "cooperationProjectNumber": cooperationContract.CooperationProjectNumber,
|
|
|
|
188
|
- "companyId": cooperationContract.Company.CompanyId,
|
|
|
|
189
|
- "orgId": cooperationContract.Org.OrgId,
|
|
|
|
190
|
- })
|
|
|
|
191
|
- if err != nil {
|
|
|
|
192
|
- var orderNumber string
|
|
|
|
193
|
- if orderGood.DividendsOrderNumber != "" {
|
|
|
|
194
|
- orderNumber = orderGood.DividendsOrderNumber
|
|
|
|
195
|
- } else {
|
|
|
|
196
|
- orderNumber = orderGood.DividendsReturnedOrderNumber
|
|
|
|
197
|
- }
|
|
|
|
198
|
- dividendsEstimateDetails = append(dividendsEstimateDetails, &service.DividendsEstimateDetail{
|
|
|
|
199
|
- DividendsUser: nil,
|
|
|
|
200
|
- DividendsParticipateType: 0,
|
|
|
|
201
|
- DividendsStage: 0,
|
|
|
|
202
|
- DividendsAmount: 0,
|
|
|
|
203
|
- OrderOrReturnedOrderNumber: orderNumber,
|
|
|
|
204
|
- IsSuccessfully: false,
|
|
|
|
205
|
- Reason: "共创项目" + cooperationContract.CooperationProjectNumber + "查询错误",
|
|
|
|
206
|
- })
|
|
|
|
207
|
- continue
|
|
|
|
208
|
- }
|
|
|
|
209
|
- if cooperationProject == nil {
|
|
|
|
210
|
- var orderNumber string
|
|
|
|
211
|
- if orderGood.DividendsOrderNumber != "" {
|
|
|
|
212
|
- orderNumber = orderGood.DividendsOrderNumber
|
|
|
|
213
|
- } else {
|
|
|
|
214
|
- orderNumber = orderGood.DividendsReturnedOrderNumber
|
|
|
|
215
|
- }
|
|
|
|
216
|
- dividendsEstimateDetails = append(dividendsEstimateDetails, &service.DividendsEstimateDetail{
|
|
|
|
217
|
- DividendsUser: nil,
|
|
|
|
218
|
- DividendsParticipateType: 0,
|
|
|
|
219
|
- DividendsStage: 0,
|
|
|
|
220
|
- DividendsAmount: 0,
|
|
|
|
221
|
- OrderOrReturnedOrderNumber: orderNumber,
|
|
|
|
222
|
- IsSuccessfully: false,
|
|
|
|
223
|
- Reason: "共创项目" + cooperationContract.CooperationProjectNumber + "已结束或不存在",
|
|
|
|
224
|
- })
|
|
|
|
225
|
- continue
|
100
|
+ // 判断共创项目是否存在
|
|
|
|
101
|
+ if _, ok := cooperationProjectsMap[cooperationContract.CooperationProjectNumber]; !ok {
|
|
|
|
102
|
+ var orderNumber string
|
|
|
|
103
|
+ if orderGood.DividendsOrderNumber != "" {
|
|
|
|
104
|
+ orderNumber = orderGood.DividendsOrderNumber
|
|
|
|
105
|
+ } else {
|
|
|
|
106
|
+ orderNumber = orderGood.DividendsReturnedOrderNumber
|
|
226
|
}
|
107
|
}
|
|
|
|
108
|
+ dividendsEstimateDetails = append(dividendsEstimateDetails, &service.DividendsEstimateDetail{
|
|
|
|
109
|
+ DividendsUser: nil,
|
|
|
|
110
|
+ DividendsParticipateType: 0,
|
|
|
|
111
|
+ DividendsStage: 0,
|
|
|
|
112
|
+ DividendsAmount: 0,
|
|
|
|
113
|
+ OrderOrReturnedOrderNumber: orderNumber,
|
|
|
|
114
|
+ IsSuccessfully: false,
|
|
|
|
115
|
+ Reason: "共创项目" + cooperationContract.CooperationProjectNumber + "已结束或不存在",
|
|
|
|
116
|
+ })
|
|
|
|
117
|
+ continue
|
|
227
|
}
|
118
|
}
|
|
228
|
|
119
|
|
|
229
|
if orderGood.DividendsOrderNumber != "" { // 获取分红订单
|
120
|
if orderGood.DividendsOrderNumber != "" { // 获取分红订单
|
|
@@ -408,95 +299,109 @@ func (domainService *ConfirmDividendsIncentivesEstimateService) Confirm(orderGoo |
|
@@ -408,95 +299,109 @@ func (domainService *ConfirmDividendsIncentivesEstimateService) Confirm(orderGoo |
|
408
|
}
|
299
|
}
|
|
409
|
}
|
300
|
}
|
|
410
|
// 计算分红
|
301
|
// 计算分红
|
|
411
|
- for _, undertaker := range cooperationContract.Undertakers {
|
|
|
|
412
|
- // 添加承接人分红退货预算信息详情
|
|
|
|
413
|
- if dividendsIncentivesRuleMatched.DividendsIncentivesPercentage > 0 {
|
|
|
|
414
|
- undertakerDividendsAmount, _ := decimal.NewFromFloat(orderGood.OrderGoodAmount).Mul(decimal.NewFromFloat(dividendsIncentivesRuleMatched.DividendsIncentivesPercentage).Div(decimal.NewFromFloat(100))).Float64()
|
|
|
|
415
|
- dividendsEstimateDetails = append(dividendsEstimateDetails, &service.DividendsEstimateDetail{
|
|
|
|
416
|
- DividendsUser: &domain.User{
|
|
|
|
417
|
- UserId: undertaker.UserId,
|
|
|
|
418
|
- UserBaseId: undertaker.UserBaseId,
|
|
|
|
419
|
- Org: undertaker.Org,
|
|
|
|
420
|
- Orgs: undertaker.Orgs,
|
|
|
|
421
|
- Department: undertaker.Department,
|
|
|
|
422
|
- Roles: undertaker.Roles,
|
|
|
|
423
|
- UserInfo: undertaker.UserInfo,
|
|
|
|
424
|
- UserType: undertaker.UserType,
|
|
|
|
425
|
- UserName: undertaker.UserInfo.UserName,
|
|
|
|
426
|
- UserPhone: undertaker.UserPhone,
|
|
|
|
427
|
- Status: undertaker.Status,
|
|
|
|
428
|
- Company: undertaker.Company,
|
|
|
|
429
|
- },
|
|
|
|
430
|
- DividendsParticipateType: domain.UNDERTAKER,
|
|
|
|
431
|
- DividendsStage: dividendsIncentivesRuleMatched.DividendsIncentivesStage,
|
|
|
|
432
|
- DividendsAmount: -undertakerDividendsAmount,
|
|
|
|
433
|
- OrderOrReturnedOrderNumber: dividendsReturnedOrder.DividendsReturnedOrderNumber,
|
|
|
|
434
|
- IsSuccessfully: true,
|
|
|
|
435
|
- CooperationContractUndertakerId: undertaker.UndertakerId,
|
|
|
|
436
|
- DividendsPercentage: dividendsIncentivesRuleMatched.DividendsIncentivesPercentage,
|
|
|
|
437
|
- })
|
|
|
|
438
|
- }
|
|
|
|
439
|
-
|
|
|
|
440
|
- // 添加推荐人分红退货预算信息详情
|
|
|
|
441
|
- if undertaker.Referrer != nil {
|
|
|
|
442
|
- if dividendsIncentivesRuleMatched.ReferrerPercentage > 0 {
|
|
|
|
443
|
- referrerDividendsAmount, _ := decimal.NewFromFloat(orderGood.OrderGoodAmount).Mul(decimal.NewFromFloat(dividendsIncentivesRuleMatched.ReferrerPercentage).Div(decimal.NewFromFloat(100))).Float64()
|
302
|
+ if len(cooperationContract.Undertakers) <= 0 {
|
|
|
|
303
|
+ dividendsEstimateDetails = append(dividendsEstimateDetails, &service.DividendsEstimateDetail{
|
|
|
|
304
|
+ DividendsUser: nil,
|
|
|
|
305
|
+ DividendsParticipateType: 0,
|
|
|
|
306
|
+ DividendsStage: 0,
|
|
|
|
307
|
+ DividendsAmount: 0,
|
|
|
|
308
|
+ OrderOrReturnedOrderNumber: orderGood.DividendsReturnedOrderNumber,
|
|
|
|
309
|
+ IsSuccessfully: false,
|
|
|
|
310
|
+ Reason: "合约承接人不存在",
|
|
|
|
311
|
+ })
|
|
|
|
312
|
+ continue
|
|
|
|
313
|
+ } else {
|
|
|
|
314
|
+ for _, undertaker := range cooperationContract.Undertakers {
|
|
|
|
315
|
+ // 添加承接人分红退货预算信息详情
|
|
|
|
316
|
+ if dividendsIncentivesRuleMatched.DividendsIncentivesPercentage > 0 {
|
|
|
|
317
|
+ undertakerDividendsAmount, _ := decimal.NewFromFloat(orderGood.OrderGoodAmount).Mul(decimal.NewFromFloat(dividendsIncentivesRuleMatched.DividendsIncentivesPercentage).Div(decimal.NewFromFloat(100))).Float64()
|
|
444
|
dividendsEstimateDetails = append(dividendsEstimateDetails, &service.DividendsEstimateDetail{
|
318
|
dividendsEstimateDetails = append(dividendsEstimateDetails, &service.DividendsEstimateDetail{
|
|
445
|
DividendsUser: &domain.User{
|
319
|
DividendsUser: &domain.User{
|
|
446
|
- UserId: undertaker.Referrer.UserId,
|
|
|
|
447
|
- UserBaseId: undertaker.Referrer.UserBaseId,
|
|
|
|
448
|
- Org: undertaker.Referrer.Org,
|
|
|
|
449
|
- Orgs: undertaker.Referrer.Orgs,
|
|
|
|
450
|
- Department: undertaker.Referrer.Department,
|
|
|
|
451
|
- Roles: undertaker.Referrer.Roles,
|
|
|
|
452
|
- UserInfo: undertaker.Referrer.UserInfo,
|
|
|
|
453
|
- UserType: undertaker.Referrer.UserType,
|
|
|
|
454
|
- UserName: undertaker.Referrer.UserName,
|
|
|
|
455
|
- UserPhone: undertaker.Referrer.UserPhone,
|
|
|
|
456
|
- Company: undertaker.Referrer.Company,
|
320
|
+ UserId: undertaker.UserId,
|
|
|
|
321
|
+ UserBaseId: undertaker.UserBaseId,
|
|
|
|
322
|
+ Org: undertaker.Org,
|
|
|
|
323
|
+ Orgs: undertaker.Orgs,
|
|
|
|
324
|
+ Department: undertaker.Department,
|
|
|
|
325
|
+ Roles: undertaker.Roles,
|
|
|
|
326
|
+ UserInfo: undertaker.UserInfo,
|
|
|
|
327
|
+ UserType: undertaker.UserType,
|
|
|
|
328
|
+ UserName: undertaker.UserInfo.UserName,
|
|
|
|
329
|
+ UserPhone: undertaker.UserPhone,
|
|
|
|
330
|
+ Status: undertaker.Status,
|
|
|
|
331
|
+ Company: undertaker.Company,
|
|
457
|
},
|
332
|
},
|
|
458
|
- DividendsParticipateType: domain.REFERRER,
|
333
|
+ DividendsParticipateType: domain.UNDERTAKER,
|
|
459
|
DividendsStage: dividendsIncentivesRuleMatched.DividendsIncentivesStage,
|
334
|
DividendsStage: dividendsIncentivesRuleMatched.DividendsIncentivesStage,
|
|
460
|
- DividendsAmount: -referrerDividendsAmount,
|
335
|
+ DividendsAmount: -undertakerDividendsAmount,
|
|
461
|
OrderOrReturnedOrderNumber: dividendsReturnedOrder.DividendsReturnedOrderNumber,
|
336
|
OrderOrReturnedOrderNumber: dividendsReturnedOrder.DividendsReturnedOrderNumber,
|
|
462
|
IsSuccessfully: true,
|
337
|
IsSuccessfully: true,
|
|
463
|
CooperationContractUndertakerId: undertaker.UndertakerId,
|
338
|
CooperationContractUndertakerId: undertaker.UndertakerId,
|
|
464
|
- DividendsPercentage: dividendsIncentivesRuleMatched.ReferrerPercentage,
|
339
|
+ DividendsPercentage: dividendsIncentivesRuleMatched.DividendsIncentivesPercentage,
|
|
465
|
})
|
340
|
})
|
|
466
|
}
|
341
|
}
|
|
467
|
- }
|
|
|
|
468
|
|
342
|
|
|
469
|
- // 添加关联业务员分红退货预算信息详情
|
|
|
|
470
|
- if undertaker.Salesman != nil {
|
|
|
|
471
|
- if dividendsIncentivesRuleMatched.SalesmanPercentage > 0 {
|
|
|
|
472
|
- salesmanDividendsAmount, _ := decimal.NewFromFloat(orderGood.OrderGoodAmount).Mul(decimal.NewFromFloat(dividendsIncentivesRuleMatched.SalesmanPercentage).Div(decimal.NewFromFloat(100))).Float64()
|
|
|
|
473
|
- dividendsEstimateDetails = append(dividendsEstimateDetails, &service.DividendsEstimateDetail{
|
|
|
|
474
|
- DividendsUser: &domain.User{
|
|
|
|
475
|
- UserId: undertaker.Salesman.UserId,
|
|
|
|
476
|
- UserBaseId: undertaker.Salesman.UserBaseId,
|
|
|
|
477
|
- Org: undertaker.Salesman.Org,
|
|
|
|
478
|
- Orgs: undertaker.Salesman.Orgs,
|
|
|
|
479
|
- Department: undertaker.Salesman.Department,
|
|
|
|
480
|
- Roles: undertaker.Salesman.Roles,
|
|
|
|
481
|
- UserInfo: undertaker.Salesman.UserInfo,
|
|
|
|
482
|
- UserType: undertaker.Salesman.UserType,
|
|
|
|
483
|
- UserName: undertaker.Salesman.UserInfo.UserName,
|
|
|
|
484
|
- UserPhone: undertaker.Salesman.UserPhone,
|
|
|
|
485
|
- Company: undertaker.Salesman.Company,
|
|
|
|
486
|
- },
|
|
|
|
487
|
- DividendsParticipateType: domain.SALESMAN,
|
|
|
|
488
|
- DividendsStage: dividendsIncentivesRuleMatched.DividendsIncentivesStage,
|
|
|
|
489
|
- DividendsAmount: -salesmanDividendsAmount,
|
|
|
|
490
|
- OrderOrReturnedOrderNumber: dividendsReturnedOrder.DividendsReturnedOrderNumber,
|
|
|
|
491
|
- IsSuccessfully: true,
|
|
|
|
492
|
- CooperationContractUndertakerId: undertaker.UndertakerId,
|
|
|
|
493
|
- DividendsPercentage: dividendsIncentivesRuleMatched.SalesmanPercentage,
|
|
|
|
494
|
- })
|
343
|
+ // 添加推荐人分红退货预算信息详情
|
|
|
|
344
|
+ if undertaker.Referrer != nil {
|
|
|
|
345
|
+ if dividendsIncentivesRuleMatched.ReferrerPercentage > 0 {
|
|
|
|
346
|
+ referrerDividendsAmount, _ := decimal.NewFromFloat(orderGood.OrderGoodAmount).Mul(decimal.NewFromFloat(dividendsIncentivesRuleMatched.ReferrerPercentage).Div(decimal.NewFromFloat(100))).Float64()
|
|
|
|
347
|
+ dividendsEstimateDetails = append(dividendsEstimateDetails, &service.DividendsEstimateDetail{
|
|
|
|
348
|
+ DividendsUser: &domain.User{
|
|
|
|
349
|
+ UserId: undertaker.Referrer.UserId,
|
|
|
|
350
|
+ UserBaseId: undertaker.Referrer.UserBaseId,
|
|
|
|
351
|
+ Org: undertaker.Referrer.Org,
|
|
|
|
352
|
+ Orgs: undertaker.Referrer.Orgs,
|
|
|
|
353
|
+ Department: undertaker.Referrer.Department,
|
|
|
|
354
|
+ Roles: undertaker.Referrer.Roles,
|
|
|
|
355
|
+ UserInfo: undertaker.Referrer.UserInfo,
|
|
|
|
356
|
+ UserType: undertaker.Referrer.UserType,
|
|
|
|
357
|
+ UserName: undertaker.Referrer.UserName,
|
|
|
|
358
|
+ UserPhone: undertaker.Referrer.UserPhone,
|
|
|
|
359
|
+ Company: undertaker.Referrer.Company,
|
|
|
|
360
|
+ },
|
|
|
|
361
|
+ DividendsParticipateType: domain.REFERRER,
|
|
|
|
362
|
+ DividendsStage: dividendsIncentivesRuleMatched.DividendsIncentivesStage,
|
|
|
|
363
|
+ DividendsAmount: -referrerDividendsAmount,
|
|
|
|
364
|
+ OrderOrReturnedOrderNumber: dividendsReturnedOrder.DividendsReturnedOrderNumber,
|
|
|
|
365
|
+ IsSuccessfully: true,
|
|
|
|
366
|
+ CooperationContractUndertakerId: undertaker.UndertakerId,
|
|
|
|
367
|
+ DividendsPercentage: dividendsIncentivesRuleMatched.ReferrerPercentage,
|
|
|
|
368
|
+ })
|
|
|
|
369
|
+ }
|
|
|
|
370
|
+ }
|
|
|
|
371
|
+
|
|
|
|
372
|
+ // 添加关联业务员分红退货预算信息详情
|
|
|
|
373
|
+ if undertaker.Salesman != nil {
|
|
|
|
374
|
+ if dividendsIncentivesRuleMatched.SalesmanPercentage > 0 {
|
|
|
|
375
|
+ salesmanDividendsAmount, _ := decimal.NewFromFloat(orderGood.OrderGoodAmount).Mul(decimal.NewFromFloat(dividendsIncentivesRuleMatched.SalesmanPercentage).Div(decimal.NewFromFloat(100))).Float64()
|
|
|
|
376
|
+ dividendsEstimateDetails = append(dividendsEstimateDetails, &service.DividendsEstimateDetail{
|
|
|
|
377
|
+ DividendsUser: &domain.User{
|
|
|
|
378
|
+ UserId: undertaker.Salesman.UserId,
|
|
|
|
379
|
+ UserBaseId: undertaker.Salesman.UserBaseId,
|
|
|
|
380
|
+ Org: undertaker.Salesman.Org,
|
|
|
|
381
|
+ Orgs: undertaker.Salesman.Orgs,
|
|
|
|
382
|
+ Department: undertaker.Salesman.Department,
|
|
|
|
383
|
+ Roles: undertaker.Salesman.Roles,
|
|
|
|
384
|
+ UserInfo: undertaker.Salesman.UserInfo,
|
|
|
|
385
|
+ UserType: undertaker.Salesman.UserType,
|
|
|
|
386
|
+ UserName: undertaker.Salesman.UserInfo.UserName,
|
|
|
|
387
|
+ UserPhone: undertaker.Salesman.UserPhone,
|
|
|
|
388
|
+ Company: undertaker.Salesman.Company,
|
|
|
|
389
|
+ },
|
|
|
|
390
|
+ DividendsParticipateType: domain.SALESMAN,
|
|
|
|
391
|
+ DividendsStage: dividendsIncentivesRuleMatched.DividendsIncentivesStage,
|
|
|
|
392
|
+ DividendsAmount: -salesmanDividendsAmount,
|
|
|
|
393
|
+ OrderOrReturnedOrderNumber: dividendsReturnedOrder.DividendsReturnedOrderNumber,
|
|
|
|
394
|
+ IsSuccessfully: true,
|
|
|
|
395
|
+ CooperationContractUndertakerId: undertaker.UndertakerId,
|
|
|
|
396
|
+ DividendsPercentage: dividendsIncentivesRuleMatched.SalesmanPercentage,
|
|
|
|
397
|
+ })
|
|
|
|
398
|
+ }
|
|
495
|
}
|
399
|
}
|
|
496
|
}
|
400
|
}
|
|
497
|
}
|
401
|
}
|
|
498
|
}
|
402
|
}
|
|
499
|
}
|
403
|
}
|
|
|
|
404
|
+
|
|
500
|
return dividendsEstimateDetails, nil
|
405
|
return dividendsEstimateDetails, nil
|
|
501
|
}
|
406
|
}
|
|
502
|
|
407
|
|