Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
O
order-group
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
order-group-application
order-group
Commits
6e6bb6af
Commit
6e6bb6af
authored
Jul 20, 2020
by
xiaoer.li@freemud.com
Browse files
Options
Browse Files
Download
Plain Diff
Merge remote-tracking branch 'remotes/origin/feature/1.9.30_买一赠一&第X件Y折' into develop
parents
90f9b2db
c3e1658a
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
126 additions
and
32 deletions
+126
-32
shopping-cart-application-service/src/main/java/cn/freemud/service/impl/BuySendPromotionService.java
+55
-10
shopping-cart-application-service/src/main/java/cn/freemud/service/impl/XyDiscountServiceImpl.java
+71
-22
No files found.
shopping-cart-application-service/src/main/java/cn/freemud/service/impl/BuySendPromotionService.java
View file @
6e6bb6af
...
@@ -24,7 +24,6 @@ import org.springframework.stereotype.Service;
...
@@ -24,7 +24,6 @@ import org.springframework.stereotype.Service;
import
java.util.*
;
import
java.util.*
;
import
java.util.function.Function
;
import
java.util.function.Function
;
import
java.util.stream.Collectors
;
import
java.util.stream.Collectors
;
import
java.util.stream.Stream
;
/**
/**
* All rights Reserved, Designed By www.freemud.cn
* All rights Reserved, Designed By www.freemud.cn
...
@@ -60,17 +59,37 @@ public class BuySendPromotionService implements IPromotionService {
...
@@ -60,17 +59,37 @@ public class BuySendPromotionService implements IPromotionService {
if
(
CollectionUtils
.
isEmpty
(
sendActivityList
))
{
if
(
CollectionUtils
.
isEmpty
(
sendActivityList
))
{
return
;
return
;
}
}
ActivityCalculationDiscountResponseDto
.
CalculationDiscountResult
.
SendActivity
sendActivity
=
getSendActivity
(
sendActivityList
,
ActivityTypeEnum
.
TYPE_61
);
//ActivityCalculationDiscountResponseDto.CalculationDiscountResult.SendActivity sendActivity = getSendActivity(sendActivityList, ActivityTypeEnum.TYPE_61);
if
(
sendActivity
==
null
)
{
//if (sendActivity == null) {
// return;
//}
//Todo 获取多个赠品list
List
<
ActivityCalculationDiscountResponseDto
.
CalculationDiscountResult
.
SendActivity
>
sendActivityLists
=
getSendActivityList
(
ActivityTypeEnum
.
TYPE_61
,
sendActivityList
);
//Todo 获取多个赠品list
if
(
sendActivityLists
.
size
()
==
0
)
{
return
;
return
;
}
}
List
<
ActivityCalculationDiscountResponseDto
.
CalculationDiscountResult
.
SendActivity
.
SendGoods
>
sendGoodsList
=
sendActivity
.
getSendGoods
();
if
(
CollectionUtils
.
isEmpty
(
sendGoodsList
))
{
//List<ActivityCalculationDiscountResponseDto.CalculationDiscountResult.SendActivity.SendGoods> sendGoodsList = sendActivity.getSendGoods();
return
;
//if (CollectionUtils.isEmpty(sendGoodsList)) {
// return;
//}
//Integer maxNum = sendActivity.getMaxNum();
//List<String> activitySpuIds = sendGoodsList.stream().map(each -> each.getCategory()).collect(Collectors.toList());
//Map<String, ActivityCalculationDiscountResponseDto.CalculationDiscountResult.SendActivity.SendGoods> sendGoodsMap = getSendGoodsMap(sendGoodsList);
//Todo
List
<
String
>
activitySpuIds
=
new
ArrayList
<>();
Map
<
String
,
ActivityCalculationDiscountResponseDto
.
CalculationDiscountResult
.
SendActivity
.
SendGoods
>
sendGoodsMap
=
new
HashMap
<>();
Map
<
String
,
Integer
>
maxNums
=
new
HashMap
<>();
for
(
ActivityCalculationDiscountResponseDto
.
CalculationDiscountResult
.
SendActivity
activityList
:
sendActivityLists
)
{
for
(
ActivityCalculationDiscountResponseDto
.
CalculationDiscountResult
.
SendActivity
.
SendGoods
sendGood
:
activityList
.
getSendGoods
())
{
sendGoodsMap
.
put
(
sendGood
.
getCategory
(),
sendGood
);
maxNums
.
put
(
sendGood
.
getGoodsId
(),
activityList
.
getMaxNum
());
activitySpuIds
.
add
(
sendGood
.
getGoodsId
());
}
}
}
Integer
maxNum
=
sendActivity
.
getMaxNum
();
activitySpuIds
=
activitySpuIds
.
stream
().
distinct
().
collect
(
Collectors
.
toList
());
List
<
String
>
activitySpuIds
=
sendGoodsList
.
stream
().
map
(
each
->
each
.
getCategory
()).
collect
(
Collectors
.
toList
());
Map
<
String
,
ActivityCalculationDiscountResponseDto
.
CalculationDiscountResult
.
SendActivity
.
SendGoods
>
sendGoodsMap
=
getSendGoodsMap
(
sendGoodsList
);
List
<
CartGoods
>
newCartGoodsList
=
new
ArrayList
<>();
List
<
CartGoods
>
newCartGoodsList
=
new
ArrayList
<>();
for
(
CartGoods
cartGood
:
cartGoodsList
)
{
for
(
CartGoods
cartGood
:
cartGoodsList
)
{
/*if (cartGoodsList.stream().filter(c -> c.getSkuId().equals(cartGood.getSkuId())).count() >= 2){
/*if (cartGoodsList.stream().filter(c -> c.getSkuId().equals(cartGood.getSkuId())).count() >= 2){
...
@@ -92,6 +111,7 @@ public class BuySendPromotionService implements IPromotionService {
...
@@ -92,6 +111,7 @@ public class BuySendPromotionService implements IPromotionService {
Long
givePackAmount
=
0L
;
Long
givePackAmount
=
0L
;
// 优惠商品原总价格
// 优惠商品原总价格
Long
giveTotalAmount
=
0L
;
Long
giveTotalAmount
=
0L
;
/*
for (CartGoods cartGoods : newCartGoodsList) {
for (CartGoods cartGoods : newCartGoodsList) {
cartGoods.setAmount(0L);
cartGoods.setAmount(0L);
if (maxNum <= 0) {
if (maxNum <= 0) {
...
@@ -108,10 +128,22 @@ public class BuySendPromotionService implements IPromotionService {
...
@@ -108,10 +128,22 @@ public class BuySendPromotionService implements IPromotionService {
cartGoods.setOriginalAmount(cartGoods.getOriginalPrice() * cartGoods.getQty());
cartGoods.setOriginalAmount(cartGoods.getOriginalPrice() * cartGoods.getQty());
cartGoodsList.add(cartGoods);
cartGoodsList.add(cartGoods);
}
}
*/
for
(
CartGoods
cartGoods
:
newCartGoodsList
)
{
Integer
max
=
maxNums
.
get
(
cartGoods
.
getGoodsId
());
//if (max <= 0) continue;
if
(
max
<
cartGoods
.
getQty
())
{
cartGoods
.
setQty
(
max
);
}
givePackAmount
=
givePackAmount
+
cartGoods
.
getPackPrice
()
*
cartGoods
.
getQty
();
giveTotalAmount
=
giveTotalAmount
+
cartGoods
.
getOriginalPrice
()
*
cartGoods
.
getQty
();
cartGoods
.
setOriginalAmount
(
cartGoods
.
getOriginalPrice
()
*
cartGoods
.
getQty
());
cartGoodsList
.
add
(
cartGoods
);
}
Integer
activityCartQty
=
cartGoodsList
.
stream
().
filter
(
each
->
Objects
.
equals
(
each
.
getActivityType
(),
ActivityTypeEnum
.
TYPE_61
.
getCode
())).
mapToInt
(
each
->
each
.
getQty
()).
sum
();
Integer
activityCartQty
=
cartGoodsList
.
stream
().
filter
(
each
->
Objects
.
equals
(
each
.
getActivityType
(),
ActivityTypeEnum
.
TYPE_61
.
getCode
())).
mapToInt
(
each
->
each
.
getQty
()).
sum
();
ActivityTip
activityTip
=
new
ActivityTip
();
ActivityTip
activityTip
=
new
ActivityTip
();
activityTip
.
setActivityType
(
ActivityTypeEnum
.
TYPE_61
.
getCode
());
activityTip
.
setActivityType
(
ActivityTypeEnum
.
TYPE_61
.
getCode
());
activityTip
.
setActivityQty
(
sendActivity
.
getMaxNum
());
//
activityTip.setActivityQty(sendActivity.getMaxNum());
activityTip
.
setActivityCartQty
(
activityCartQty
);
activityTip
.
setActivityCartQty
(
activityCartQty
);
activityTip
.
setActivitySpuIds
(
activitySpuIds
);
activityTip
.
setActivitySpuIds
(
activitySpuIds
);
// 当maxNum>=minNum,在加入买一赠一商品时提示“您参加的买赠优惠最多赠送N件哦~”
// 当maxNum>=minNum,在加入买一赠一商品时提示“您参加的买赠优惠最多赠送N件哦~”
...
@@ -178,6 +210,19 @@ public class BuySendPromotionService implements IPromotionService {
...
@@ -178,6 +210,19 @@ public class BuySendPromotionService implements IPromotionService {
}
}
/**
/**
* 获取指定促销类型的SendActivity
*
* @param sendActivityList
* @param type
* @return
*/
private
List
<
ActivityCalculationDiscountResponseDto
.
CalculationDiscountResult
.
SendActivity
>
getSendActivityList
(
ActivityTypeEnum
type
,
List
<
ActivityCalculationDiscountResponseDto
.
CalculationDiscountResult
.
SendActivity
>
sendActivityList
)
{
List
<
ActivityCalculationDiscountResponseDto
.
CalculationDiscountResult
.
SendActivity
>
collect
=
sendActivityList
.
stream
().
filter
(
c
->
c
.
getActivityType
().
equals
(
type
.
getCode
())).
collect
(
Collectors
.
toList
());
return
collect
;
}
/**
* 筛选出spu商品中价格最低的商品,Key=spuId
* 筛选出spu商品中价格最低的商品,Key=spuId
*
*
* @param sendGoodsList
* @param sendGoodsList
...
...
shopping-cart-application-service/src/main/java/cn/freemud/service/impl/XyDiscountServiceImpl.java
View file @
6e6bb6af
...
@@ -36,36 +36,64 @@ public class XyDiscountServiceImpl implements IPromotionService {
...
@@ -36,36 +36,64 @@ public class XyDiscountServiceImpl implements IPromotionService {
@Override
@Override
public
void
updateShoppingCartGoodsDiscount
(
CouponPromotionVO
couponPromotionVO
,
ActivityQueryDto
activityQueryDto
,
ActivityCalculationDiscountResponseDto
.
CalculationDiscountResult
calculationDiscountResult
,
List
<
CartGoods
>
cartGoodsList
,
ShoppingCartGoodsResponseVo
shoppingCartGoodsResponseVo
,
UserLoginInfoDto
userLoginInfoDto
,
ShoppingCartInfoRequestVo
shoppingCartInfoRequestVo
)
{
public
void
updateShoppingCartGoodsDiscount
(
CouponPromotionVO
couponPromotionVO
,
ActivityQueryDto
activityQueryDto
,
ActivityCalculationDiscountResponseDto
.
CalculationDiscountResult
calculationDiscountResult
,
List
<
CartGoods
>
cartGoodsList
,
ShoppingCartGoodsResponseVo
shoppingCartGoodsResponseVo
,
UserLoginInfoDto
userLoginInfoDto
,
ShoppingCartInfoRequestVo
shoppingCartInfoRequestVo
)
{
ApportionGoodsDetail
apportionGoodsDetail
=
getApportionGoodsDetail
(
calculationDiscountResult
);
//ApportionGoodsDetail apportionGoodsDetail = getApportionGoodsDetail(calculationDiscountResult);
if
(
apportionGoodsDetail
!=
null
)
{
//if (apportionGoodsDetail != null) {
Optional
<
CartGoods
>
firstCartGoods
=
cartGoodsList
.
stream
().
filter
(
cartGoods
->
ObjectUtils
.
equals
(
apportionGoodsDetail
.
getGoodsId
(),
cartGoods
.
getGoodsId
())).
findFirst
();
// Optional<CartGoods> firstCartGoods = cartGoodsList.stream().filter(cartGoods -> ObjectUtils.equals(apportionGoodsDetail.getGoodsId(), cartGoods.getGoodsId())).findFirst();
if
(
firstCartGoods
.
isPresent
())
{
// if (firstCartGoods.isPresent()) {
firstCartGoods
.
get
().
setAmount
(
firstCartGoods
.
get
().
getAmount
()
-
apportionGoodsDetail
.
getActivityApportionAmount
());
// firstCartGoods.get().setAmount(firstCartGoods.get().getAmount() - apportionGoodsDetail.getActivityApportionAmount());
// }
//}
List
<
ApportionGoodsDetail
>
apportionGoodsDetail
=
getApportionGoodsDetail
(
calculationDiscountResult
);
if
(
apportionGoodsDetail
!=
null
&&
apportionGoodsDetail
.
size
()
>
0
)
{
for
(
CartGoods
cartGoods
:
cartGoodsList
)
{
for
(
ApportionGoodsDetail
detail
:
apportionGoodsDetail
)
{
if
(
detail
.
getGoodsId
().
equals
(
cartGoods
.
getGoodsId
()))
{
cartGoods
.
setAmount
(
cartGoods
.
getAmount
()
-
detail
.
getActivityApportionAmount
());
}
}
}
}
}
}
}
}
@Override
@Override
public
void
updateShoppingCartGoodsApportion
(
ShoppingCartGoodsResponseVo
shoppingCartGoodsResponseVo
,
ActivityCalculationDiscountResponseDto
.
CalculationDiscountResult
calculationDiscountResult
,
ShoppingCartGoodsDto
shoppingCartGoodsDto
,
CreateOrderVo
.
PremiumExchangeActivity
premiumExchangeActivity
,
ShoppingCartInfoRequestVo
shoppingCartInfoRequestVo
)
{
public
void
updateShoppingCartGoodsApportion
(
ShoppingCartGoodsResponseVo
shoppingCartGoodsResponseVo
,
ActivityCalculationDiscountResponseDto
.
CalculationDiscountResult
calculationDiscountResult
,
ShoppingCartGoodsDto
shoppingCartGoodsDto
,
CreateOrderVo
.
PremiumExchangeActivity
premiumExchangeActivity
,
ShoppingCartInfoRequestVo
shoppingCartInfoRequestVo
)
{
ApportionGoodsDetail
apportionGoodsDetail
=
getApportionGoodsDetail
(
calculationDiscountResult
);
//ApportionGoodsDetail apportionGoodsDetail = getApportionGoodsDetail(calculationDiscountResult);
if
(
apportionGoodsDetail
!=
null
)
{
//if (apportionGoodsDetail != null) {
Optional
<
ShoppingCartGoodsDto
.
CartGoodsDetailDto
>
firstCartGoods
=
shoppingCartGoodsDto
.
getProducts
().
stream
().
filter
(
cartGoods
->
ObjectUtils
.
equals
(
apportionGoodsDetail
.
getGoodsId
(),
cartGoods
.
getSkuId
())).
findFirst
();
// Optional<ShoppingCartGoodsDto.CartGoodsDetailDto> firstCartGoods = shoppingCartGoodsDto.getProducts().stream().filter(cartGoods -> ObjectUtils.equals(apportionGoodsDetail.getGoodsId(), cartGoods.getSkuId())).findFirst();
if
(
firstCartGoods
.
isPresent
())
{
// if (firstCartGoods.isPresent()) {
ShoppingCartGoodsDto
.
CartGoodsDetailDto
cartGoods
=
firstCartGoods
.
get
();
// ShoppingCartGoodsDto.CartGoodsDetailDto cartGoods = firstCartGoods.get();
cartGoods
.
setTotalDiscountAmount
(
cartGoods
.
getTotalDiscountAmount
()
+
apportionGoodsDetail
.
getActivityApportionAmount
().
intValue
());
// cartGoods.setTotalDiscountAmount(cartGoods.getTotalDiscountAmount() + apportionGoodsDetail.getActivityApportionAmount().intValue());
List
<
ActivityDiscountsDto
>
activityDiscountsDtoList
=
new
ArrayList
<>();
// List<ActivityDiscountsDto> activityDiscountsDtoList = new ArrayList<>();
ActivityDiscountsDto
activityDiscountsDto
=
new
ActivityDiscountsDto
();
// ActivityDiscountsDto activityDiscountsDto = new ActivityDiscountsDto();
activityDiscountsDto
.
setActivityCode
(
apportionGoodsDetail
.
getActivityCode
());
// activityDiscountsDto.setActivityCode(apportionGoodsDetail.getActivityCode());
activityDiscountsDto
.
setActivityName
(
apportionGoodsDetail
.
getActivityName
());
// activityDiscountsDto.setActivityName(apportionGoodsDetail.getActivityName());
activityDiscountsDto
.
setActivityType
(
ActivityTypeEnum
.
TYPE_104
.
getCode
());
// activityDiscountsDto.setActivityType(ActivityTypeEnum.TYPE_104.getCode());
activityDiscountsDto
.
setDiscountAmount
(
apportionGoodsDetail
.
getActivityApportionAmount
().
intValue
());
// activityDiscountsDto.setDiscountAmount(apportionGoodsDetail.getActivityApportionAmount().intValue());
activityDiscountsDtoList
.
add
(
activityDiscountsDto
);
// activityDiscountsDtoList.add(activityDiscountsDto);
cartGoods
.
setActivityDiscountsDtos
(
activityDiscountsDtoList
);
// cartGoods.setActivityDiscountsDtos(activityDiscountsDtoList);
// }
//}
List
<
ApportionGoodsDetail
>
apportionGoodsDetail
=
getApportionGoodsDetail
(
calculationDiscountResult
);
if
(
apportionGoodsDetail
!=
null
&&
apportionGoodsDetail
.
size
()
>
0
)
{
for
(
ShoppingCartGoodsDto
.
CartGoodsDetailDto
product
:
shoppingCartGoodsDto
.
getProducts
())
{
for
(
ApportionGoodsDetail
detail
:
apportionGoodsDetail
)
{
if
(
detail
.
getGoodsId
().
equals
(
product
.
getSkuId
()))
{
product
.
setTotalDiscountAmount
(
product
.
getTotalDiscountAmount
()
+
detail
.
getActivityApportionAmount
().
intValue
());
List
<
ActivityDiscountsDto
>
activityDiscountsDtoList
=
new
ArrayList
<>();
ActivityDiscountsDto
activityDiscountsDto
=
new
ActivityDiscountsDto
();
activityDiscountsDto
.
setActivityCode
(
detail
.
getActivityCode
());
activityDiscountsDto
.
setActivityName
(
detail
.
getActivityName
());
activityDiscountsDto
.
setActivityType
(
ActivityTypeEnum
.
TYPE_104
.
getCode
());
activityDiscountsDto
.
setDiscountAmount
(
detail
.
getActivityApportionAmount
().
intValue
());
activityDiscountsDtoList
.
add
(
activityDiscountsDto
);
product
.
setActivityDiscountsDtos
(
activityDiscountsDtoList
);
}
}
}
}
}
}
}
}
/*
private ApportionGoodsDetail getApportionGoodsDetail(ActivityCalculationDiscountResponseDto.CalculationDiscountResult calculationDiscountResult) {
private ApportionGoodsDetail getApportionGoodsDetail(ActivityCalculationDiscountResponseDto.CalculationDiscountResult calculationDiscountResult) {
// 遍历购物车内的商品,如果存在则进行均摊
// 遍历购物车内的商品,如果存在则进行均摊
if (calculationDiscountResult == null || CollectionUtils.isEmpty(calculationDiscountResult.getApportionGoods())) {
if (calculationDiscountResult == null || CollectionUtils.isEmpty(calculationDiscountResult.getApportionGoods())) {
...
@@ -87,8 +115,29 @@ public class XyDiscountServiceImpl implements IPromotionService {
...
@@ -87,8 +115,29 @@ public class XyDiscountServiceImpl implements IPromotionService {
}
}
return null;
return null;
}
}
*/
private
List
<
ApportionGoodsDetail
>
getApportionGoodsDetail
(
ActivityCalculationDiscountResponseDto
.
CalculationDiscountResult
calculationDiscountResult
)
{
// 遍历购物车内的商品,如果存在则进行均摊
if
(
calculationDiscountResult
==
null
||
CollectionUtils
.
isEmpty
(
calculationDiscountResult
.
getApportionGoods
()))
{
return
null
;
}
List
<
ApportionGoodsDetail
>
apportionGoodsDetail
=
new
ArrayList
<>();
for
(
ActivityCalculationDiscountResponseDto
.
CalculationDiscountResult
.
ApportionGoods
apportionGood
:
calculationDiscountResult
.
getApportionGoods
())
{
if
(!
CollectionUtils
.
isEmpty
(
apportionGood
.
getApportionDetails
()))
{
for
(
ActivityCalculationDiscountResponseDto
.
CalculationDiscountResult
.
ApportionGoods
.
ApportionDetails
apportionDetail
:
apportionGood
.
getApportionDetails
())
{
if
(
apportionDetail
.
getActivityType
().
equals
(
ActivityTypeEnum
.
TYPE_104
.
getCode
()))
{
ApportionGoodsDetail
detail
=
new
ApportionGoodsDetail
();
detail
.
setActivityApportionAmount
(
apportionDetail
.
getActivityApportionAmount
());
detail
.
setActivityCode
(
apportionDetail
.
getActivityCode
());
detail
.
setActivityName
(
apportionDetail
.
getActivityName
());
detail
.
setGoodsId
(
apportionGood
.
getGoodsId
());
apportionGoodsDetail
.
add
(
detail
);
}
}
}
}
return
apportionGoodsDetail
;
}
@Data
@Data
private
class
ApportionGoodsDetail
{
private
class
ApportionGoodsDetail
{
/**
/**
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment