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

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

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

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