记得上下班打卡 | git大法好,push需谨慎

Commit 52f2dc4e authored by 胡佳晨's avatar 胡佳晨

提交 结束时间未填写分段购 sku详情逻辑

增加 上个时间段 库存未售罄的库存
parent 271958c4
......@@ -715,7 +715,7 @@ public class GoblinRedisUtils {
GoblinGoodsSkuInfoVo vo = getGoodsSkuInfoVo(skuId);
HashMap<String, Object> map = CollectionUtil.mapStringObject();
if (now.isAfter(vo.getSaleStartTime())) {//普通商品已开售
lastStockToLastStock(getGoblinListCollect(skuId),null,skuId);
lastStockToLastStock(0,getGoblinListCollect(skuId), null, skuId);
map.put("vo", vo);
map.put("tagType", null);
map.put("listId", null);
......@@ -763,22 +763,30 @@ public class GoblinRedisUtils {
if (collectVo == null) {
collectVo = collectTemp;
}
lastStockToLastStock(collectVos, collectVo, skuId);
lastStockToLastStock(1,collectVos, collectVo, skuId);
return collectVo;
}
/**
* 处理上个时间段的库存
*
* @param type 类型[0-开售|1-未开售]
* @param collectVos
* @param vo
* @param skuId
*/
public void lastStockToLastStock(List<GoblinListCollectVo> collectVos, GoblinListCollectVo vo, String skuId) {
if(vo ==null ){//已开售逻辑
public void lastStockToLastStock(Integer type, List<GoblinListCollectVo> collectVos, GoblinListCollectVo vo, String skuId) {
if (vo == null && type == 0) {//已开售逻辑
for (GoblinListCollectVo collectVoItem : collectVos) {
int lastStock = getSkuStock(collectVoItem.getListId(), skuId);
int restStock = decrSkuStock(collectVoItem.getListId(), skuId, lastStock);
if (restStock < 0) {
incrSkuStock(collectVoItem.getListId(), skuId, lastStock);
} else {
incrSkuStock(null, skuId, lastStock);
}
}
} else if (vo != null && type == 1) {
LocalDateTime st = vo.getTimeStart().minusSeconds(1);
GoblinListCollectVo collectVo = null;
GoblinListCollectVo collectTemp = null;
......@@ -794,9 +802,7 @@ public class GoblinRedisUtils {
if (collectVo == null) {
collectVo = collectTemp;
}
if (collectVo == null && collectVos.size() != 0) {
} else if (collectVo != null) {
if (collectVo != null) {
//减少上个时间段sku库存
int lastStock = getSkuStock(collectVo.getListId(), skuId);
int restStock = decrSkuStock(collectVo.getListId(), skuId, lastStock);
......@@ -809,6 +815,7 @@ public class GoblinRedisUtils {
}
}
}
}
public GoblinGoodsSkuInfoVo getGoodsSkuInfoVoByUnShelves(String skuId) {
String pre = GoblinStatusConst.MarketPreStatus.getPre(skuId);
......
......@@ -175,8 +175,14 @@ public class GoblinRedisUtils {
*/
public HashMap<String, Object> getGoodsSkuInfoVo(LocalDateTime now, String skuId) {
GoblinGoodsSkuInfoVo vo = getGoodsSkuInfoVo(skuId);
GoblinListCollectVo collectVo = getCollectByNow(now,skuId);
HashMap<String, Object> map = CollectionUtil.mapStringObject();
if (now.isAfter(vo.getSaleStartTime())) {//普通商品已开售
lastStockToLastStock(0,getGoblinListCollect(skuId), null, skuId);
map.put("vo", vo);
map.put("tagType", null);
map.put("listId", null);
} else {//未开售
GoblinListCollectVo collectVo = getCollectByNow(now, skuId);
Integer tagType = null;
String listId = null;
if (collectVo != null) {
......@@ -191,11 +197,13 @@ public class GoblinRedisUtils {
map.put("vo", vo);
map.put("tagType", tagType);
map.put("listId", listId);
}
return map;
}
/**
* 根据时间获取当前分段购vo
*
* @param now
* @param skuId
* @return
......@@ -204,7 +212,6 @@ public class GoblinRedisUtils {
GoblinListCollectVo collectVo = null;
GoblinListCollectVo collectTemp = null;
List<GoblinListCollectVo> collectVos = getGoblinListCollect(skuId);
//获取当前
for (GoblinListCollectVo collectVoItem : collectVos) {
if (now.isAfter(collectVoItem.getTimeStart()) && collectVoItem.getTimeEnd() == null) {
if (collectTemp == null || collectTemp.getTimeStart().isBefore(collectVoItem.getTimeStart())) {
......@@ -215,20 +222,33 @@ public class GoblinRedisUtils {
break;
}
}
if(collectVo==null){
if (collectVo == null) {
collectVo = collectTemp;
}
lastStockToLastStock(collectVos,collectVo,skuId);
lastStockToLastStock(1,collectVos, collectVo, skuId);
return collectVo;
}
/**
* 处理上个时间段的库存
*
* @param type 类型[0-开售|1-未开售]
* @param collectVos
* @param vo
* @param skuId
*/
public void lastStockToLastStock(List<GoblinListCollectVo> collectVos ,GoblinListCollectVo vo,String skuId){
public void lastStockToLastStock(Integer type, List<GoblinListCollectVo> collectVos, GoblinListCollectVo vo, String skuId) {
if (vo == null && type == 0) {//已开售逻辑
for (GoblinListCollectVo collectVoItem : collectVos) {
int lastStock = getSkuStock(collectVoItem.getListId(), skuId);
int restStock = decrSkuStock(collectVoItem.getListId(), skuId, lastStock);
if (restStock < 0) {
incrSkuStock(collectVoItem.getListId(), skuId, lastStock);
} else {
incrSkuStock(null, skuId, lastStock);
}
}
} else if (vo != null && type == 1) {
LocalDateTime st = vo.getTimeStart().minusSeconds(1);
GoblinListCollectVo collectVo = null;
GoblinListCollectVo collectTemp = null;
......@@ -236,24 +256,25 @@ public class GoblinRedisUtils {
for (GoblinListCollectVo collectVoItem : collectVos) {
if (st.isAfter(collectVoItem.getTimeStart()) && collectVoItem.getTimeEnd() == null) {
collectTemp = collectVoItem;
}else if (st.isAfter(collectVoItem.getTimeStart()) && st.isBefore(collectVoItem.getTimeEnd())) {
} else if (st.isAfter(collectVoItem.getTimeStart()) && st.isBefore(collectVoItem.getTimeEnd())) {
collectVo = collectVoItem;
break;
}
}
if(collectVo==null){
if (collectVo == null) {
collectVo = collectTemp;
}
if(collectVo!=null){
if (collectVo != null) {
//减少上个时间段sku库存
int lastStock = getSkuStock(collectVo.getListId(),skuId);
int restStock = decrSkuStock(collectVo.getListId(),skuId,lastStock);
if(restStock<0){
int lastStock = getSkuStock(collectVo.getListId(), skuId);
int restStock = decrSkuStock(collectVo.getListId(), skuId, lastStock);
if (restStock < 0) {
//库存超过销售量 操作失败回滚库存
incrSkuStock(collectVo.getListId(),skuId,lastStock);
}else{
incrSkuStock(collectVo.getListId(), skuId, lastStock);
} else {
//上个时间段的库存增加到当前时间段
incrSkuStock(vo.getListId(),skuId,lastStock);
incrSkuStock(vo.getListId(), skuId, lastStock);
}
}
}
}
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment