Compare commits
1 Commits
b637a6dea9
...
test
| Author | SHA1 | Date | |
|---|---|---|---|
| 0f15137c7f |
@@ -26,7 +26,7 @@
|
|||||||
<text class="u-m-l-22">积分:{{ allConfig.pointNum }}</text>
|
<text class="u-m-l-22">积分:{{ allConfig.pointNum }}</text>
|
||||||
</view>
|
</view>
|
||||||
</view>
|
</view>
|
||||||
<image :src="imgs.code" class="code"></image>
|
<!-- <image :src="imgs.code" class="code"></image> -->
|
||||||
</view>
|
</view>
|
||||||
</view>
|
</view>
|
||||||
<view class="new-menus-box">
|
<view class="new-menus-box">
|
||||||
|
|||||||
@@ -356,6 +356,17 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
cartNumber:{
|
||||||
|
//当前购物车数量
|
||||||
|
type:Number,
|
||||||
|
default:0
|
||||||
|
},
|
||||||
|
consStockList:{
|
||||||
|
type:Array,
|
||||||
|
default:()=>{
|
||||||
|
return []
|
||||||
|
}
|
||||||
|
},
|
||||||
GoodsIDInCartNumMap: {
|
GoodsIDInCartNumMap: {
|
||||||
type: Object,
|
type: Object,
|
||||||
default: () => {
|
default: () => {
|
||||||
@@ -810,13 +821,39 @@
|
|||||||
return limitUtils.canUseLimitTimeDiscount(item, cartStore.limitTimeDiscount, shopInfo, shopUserInfo.value, 'id') ?
|
return limitUtils.canUseLimitTimeDiscount(item, cartStore.limitTimeDiscount, shopInfo, shopUserInfo.value, 'id') ?
|
||||||
1 : 0;
|
1 : 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function returnStockNumber(item) {
|
||||||
|
if (!item.isAutoSoldStock) {
|
||||||
|
return 9999
|
||||||
|
}
|
||||||
|
const consList = item.consList
|
||||||
|
const matchStockList = props.consStockList.filter(v => {
|
||||||
|
return consList.find(c => c.consInfoId == v.consId)
|
||||||
|
}).map(v => {
|
||||||
|
const cItem = item.consList.find(c => c.consInfoId == v.consId)
|
||||||
|
const goodsNumber = Math.floor(v.stockNumber / cItem.surplusStock)
|
||||||
|
return {
|
||||||
|
...v,
|
||||||
|
goodsNumber
|
||||||
|
}
|
||||||
|
}).sort((a, b) => {
|
||||||
|
return a.goodsNumber - b.goodsNumber
|
||||||
|
})
|
||||||
|
|
||||||
|
const minConsStockNumber = matchStockList[0] ? matchStockList[0].goodsNumber : 9999
|
||||||
|
return minConsStockNumber
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
// 多规格 套餐 单规格添加数量
|
// 多规格 套餐 单规格添加数量
|
||||||
const shopCart = async (i) => {
|
const shopCart = async (i) => {
|
||||||
if (i == '-' && shopCartNumber.value <= (props.goods.suitNum || 1)) {
|
if (i == '-' && shopCartNumber.value <= (props.goods.suitNum || 1)) {
|
||||||
shopCartNumber.value = 0;
|
shopCartNumber.value = 0;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const stockNumber=returnStockNumber(props.goods)-(props.cartNumber||0)
|
||||||
|
console.log('stockNumber',stockNumber);
|
||||||
let res = null
|
let res = null
|
||||||
|
|
||||||
if (i == '-') {
|
if (i == '-') {
|
||||||
@@ -832,15 +869,34 @@
|
|||||||
} else {
|
} else {
|
||||||
|
|
||||||
if (!res && shopCartNumber.value < 1) {
|
if (!res && shopCartNumber.value < 1) {
|
||||||
|
|
||||||
if (props.goods.type == 'sku') {
|
if (props.goods.type == 'sku') {
|
||||||
if (!selSku.value) {
|
if (!selSku.value) {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
if(stockNumber<selSku.value.suitNum){
|
||||||
|
return uni.showToast({
|
||||||
|
title:'商品库存不足!',
|
||||||
|
icon:'error'
|
||||||
|
})
|
||||||
|
}
|
||||||
shopCartNumber.value = parseFloat(selSku.value.suitNum);
|
shopCartNumber.value = parseFloat(selSku.value.suitNum);
|
||||||
} else {
|
} else {
|
||||||
|
if(stockNumber<props.goods.suitNum){
|
||||||
|
return uni.showToast({
|
||||||
|
title:'商品库存不足!',
|
||||||
|
icon:'error'
|
||||||
|
})
|
||||||
|
}
|
||||||
shopCartNumber.value = parseFloat(props.goods.suitNum);
|
shopCartNumber.value = parseFloat(props.goods.suitNum);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
if(shopCartNumber.value>=stockNumber){
|
||||||
|
return uni.showToast({
|
||||||
|
title:'商品库存不足!',
|
||||||
|
icon:'error'
|
||||||
|
})
|
||||||
|
}
|
||||||
shopCartNumber.value++;
|
shopCartNumber.value++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -402,6 +402,8 @@
|
|||||||
|
|
||||||
<view v-for="(item,index) in goodsModalList" :key="index">
|
<view v-for="(item,index) in goodsModalList" :key="index">
|
||||||
<goodsModal :key="index" v-model="item.show" :goods="item.goods" @prveImgs="prveImgs" :orderinfo="orderinfo"
|
<goodsModal :key="index" v-model="item.show" :goods="item.goods" @prveImgs="prveImgs" :orderinfo="orderinfo"
|
||||||
|
:cartNumber="returnGoodsImCartNum(item.goods)"
|
||||||
|
:consStockList="consStockList"
|
||||||
@shareClick="shareClick" @close="goodsModalClose(index)" @websocketsendMessage="websocketsendMessage"
|
@shareClick="shareClick" @close="goodsModalClose(index)" @websocketsendMessage="websocketsendMessage"
|
||||||
@modalAdd="modalAdd" :GoodsIDInCartNumMap="GoodsIDInCartNumMap"></goodsModal>
|
@modalAdd="modalAdd" :GoodsIDInCartNumMap="GoodsIDInCartNumMap"></goodsModal>
|
||||||
</view>
|
</view>
|
||||||
|
|||||||
@@ -27,7 +27,7 @@
|
|||||||
<!-- #endif -->
|
<!-- #endif -->
|
||||||
</view>
|
</view>
|
||||||
<view class="right-icons">
|
<view class="right-icons">
|
||||||
<image class="my_info_right_qr" src="/static/icon/code.png" mode="aspectFill"></image>
|
<!-- <image class="my_info_right_qr" src="/static/icon/code.png" mode="aspectFill"></image> -->
|
||||||
<view class="msg-view" @click="viewUserMsgList">
|
<view class="msg-view" @click="viewUserMsgList">
|
||||||
<view class="msg-icon-wrapper">
|
<view class="msg-icon-wrapper">
|
||||||
<image v-if="unreadMsgCount > 0" class="my-msg-icon" src="/static/mine/msg_select.png" mode="aspectFill"></image>
|
<image v-if="unreadMsgCount > 0" class="my-msg-icon" src="/static/mine/msg_select.png" mode="aspectFill"></image>
|
||||||
|
|||||||
Reference in New Issue
Block a user