You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
407 lines
7.9 KiB
407 lines
7.9 KiB
3 months ago
|
<template>
|
||
|
<!-- 商品分类 -->
|
||
|
<view :style="colorStyle">
|
||
|
<storeCate1 v-if="popupVisible == 0" :info="info" :pageVisible="pageVisible" ref="refresh2"></storeCate1>
|
||
|
<tuiModal :show="popupVisible == 1" custom>
|
||
|
<view class="popup">
|
||
|
<view class="body">
|
||
|
<view class="title">请选择用餐人数</view>
|
||
|
<view class="spinner-box acea-row">
|
||
|
<view v-for="(item, index) in 6" :class="{ on: index + 1 === number }" class="btn" @click="onNumber(index + 1)">
|
||
|
<view class="inner">{{ index + 1 }}</view>
|
||
|
</view>
|
||
|
<input v-model="inputNumber" :class="{ on: inputFocus }" type="number" placeholder="自定义" class="input" @focus="onFocus" @blur="onBlur" />
|
||
|
</view>
|
||
|
</view>
|
||
|
<view class="foot acea-row">
|
||
|
<button :class="{ disabled: !number }" class="btn" hover-class="none" @tap="addTableCode(number)">
|
||
|
<view class="inner">开始点餐</view>
|
||
|
</button>
|
||
|
</view>
|
||
|
</view>
|
||
|
</tuiModal>
|
||
|
</view>
|
||
|
</template>
|
||
|
|
||
|
<script>
|
||
|
import {
|
||
|
mapGetters
|
||
|
} from 'vuex';
|
||
|
import colors from "@/mixins/color";
|
||
|
import storeCate1 from './cart.vue'
|
||
|
import tuiModal from '@/components/tui-modal/index.vue'
|
||
|
import {
|
||
|
getTableData,
|
||
|
addTableCode,
|
||
|
isTableCode,
|
||
|
changeTable,
|
||
|
getStoreData,
|
||
|
} from '@/api/store.js';
|
||
|
import {
|
||
|
toLogin
|
||
|
} from '@/libs/login.js';
|
||
|
import util from '../../../utils/util.js';
|
||
|
export default {
|
||
|
computed: mapGetters(['isLogin']),
|
||
|
components: {
|
||
|
storeCate1,
|
||
|
tuiModal,
|
||
|
},
|
||
|
mixins: [colors],
|
||
|
data() {
|
||
|
return {
|
||
|
info: {},
|
||
|
number: 0,
|
||
|
inputNumber: '',
|
||
|
popupVisible: -1,
|
||
|
pageVisible: true,
|
||
|
inputFocus: false,
|
||
|
}
|
||
|
},
|
||
|
watch: {
|
||
|
inputNumber(val) {
|
||
|
this.$nextTick(() => {
|
||
|
this.number = Number(val);
|
||
|
this.inputNumber = this.number || '';
|
||
|
});
|
||
|
}
|
||
|
},
|
||
|
onLoad(options) {
|
||
|
if (options.scene) {
|
||
|
options = util.getUrlParams(decodeURIComponent(options.scene));
|
||
|
}
|
||
|
const {
|
||
|
store_id,
|
||
|
qrcode_id
|
||
|
} = options;
|
||
|
this.info = {
|
||
|
...this.info,
|
||
|
store_id,
|
||
|
qrcode_id
|
||
|
};
|
||
|
},
|
||
|
onShow() {
|
||
|
this.info.tableId = 0;
|
||
|
if (this.isLogin) {
|
||
|
this.getTableData();
|
||
|
} else {
|
||
|
toLogin()
|
||
|
}
|
||
|
},
|
||
|
onHide() {
|
||
|
this.pageVisible = false;
|
||
|
},
|
||
|
methods: {
|
||
|
// 获取桌码配置
|
||
|
getTableData() {
|
||
|
getTableData({
|
||
|
store_id: this.info.store_id
|
||
|
}).then(res => {
|
||
|
let data = res.data;
|
||
|
if (Array.isArray(data)) {
|
||
|
data = {};
|
||
|
}
|
||
|
const {
|
||
|
store_code_switch,
|
||
|
store_number_diners_window
|
||
|
} = data;
|
||
|
this.info = {
|
||
|
...this.info,
|
||
|
store_number_diners_window
|
||
|
};
|
||
|
// 门店是否开启桌码
|
||
|
if (store_code_switch == 1) {
|
||
|
this.isTableCode(store_number_diners_window);
|
||
|
} else {
|
||
|
this.$util.Tips({
|
||
|
title: '当前门店未开启桌码'
|
||
|
});
|
||
|
}
|
||
|
});
|
||
|
},
|
||
|
// 选择用餐人数
|
||
|
changeNumber(value) {
|
||
|
this.number += value;
|
||
|
},
|
||
|
// 记录桌码
|
||
|
addTableCode(number) {
|
||
|
const {
|
||
|
store_id,
|
||
|
qrcode_id,
|
||
|
tableId: y_tableId
|
||
|
} = this.info;
|
||
|
let data = {
|
||
|
store_id,
|
||
|
qrcode_id
|
||
|
};
|
||
|
if (!number) {
|
||
|
return;
|
||
|
}
|
||
|
data.number = number;
|
||
|
return new Promise((resolve, reject) => {
|
||
|
addTableCode(data).then(res => {
|
||
|
this.info = {
|
||
|
...this.info,
|
||
|
tableId: res.data.tableId
|
||
|
};
|
||
|
this.getStore();
|
||
|
resolve(y_tableId);
|
||
|
if (number) {
|
||
|
this.popupVisible = 0;
|
||
|
}
|
||
|
}).catch(err => {
|
||
|
reject(y_tableId);
|
||
|
this.$util.Tips({
|
||
|
title: err
|
||
|
});
|
||
|
});
|
||
|
});
|
||
|
},
|
||
|
// 检查桌码记录
|
||
|
isTableCode(store_number_diners_window) {
|
||
|
const {
|
||
|
store_id,
|
||
|
qrcode_id
|
||
|
} = this.info;
|
||
|
isTableCode({
|
||
|
store_id,
|
||
|
qrcode_id
|
||
|
}).then(res => {
|
||
|
const {
|
||
|
code,
|
||
|
tableId
|
||
|
} = res.data;
|
||
|
this.info = {
|
||
|
...this.info,
|
||
|
tableId
|
||
|
};
|
||
|
// 判断是不是换桌
|
||
|
if (!code) {
|
||
|
return uni.showModal({
|
||
|
title: '确定要换桌吗?',
|
||
|
content: '换桌后,您已点的商品会自动转移到新桌',
|
||
|
success: (res) => {
|
||
|
if (res.confirm) {
|
||
|
this.changeTable();
|
||
|
} else {
|
||
|
this.getStore();
|
||
|
}
|
||
|
}
|
||
|
});
|
||
|
}
|
||
|
// 判断这桌是否记录桌码
|
||
|
if (tableId) {
|
||
|
this.popupVisible = 0;
|
||
|
this.getStore();
|
||
|
} else {
|
||
|
// 是否弹出选择人数弹窗
|
||
|
this.popupVisible = store_number_diners_window == 1 ? 1 : 0;
|
||
|
if (!this.popupVisible) {
|
||
|
this.addTableCode();
|
||
|
}
|
||
|
}
|
||
|
});
|
||
|
},
|
||
|
// 处理换桌商品
|
||
|
async changeTable() {
|
||
|
const y_tableId = await this.addTableCode();
|
||
|
if (!y_tableId) {
|
||
|
return;
|
||
|
}
|
||
|
changeTable({
|
||
|
tableId: this.info.tableId,
|
||
|
y_tableId
|
||
|
}).then(() => {
|
||
|
this.$util.Tips({
|
||
|
title: '换桌完成',
|
||
|
success: this.getStore
|
||
|
});
|
||
|
}).catch(err => {
|
||
|
this.$util.Tips({
|
||
|
title: err
|
||
|
});
|
||
|
});
|
||
|
},
|
||
|
// 获取接口附近门店
|
||
|
getStore() {
|
||
|
getStoreData({
|
||
|
store_id: this.info.store_id
|
||
|
}).then(res => {
|
||
|
this.info = {
|
||
|
...this.info,
|
||
|
...res.data
|
||
|
};
|
||
|
this.$refs.refresh2.getAllCategory();
|
||
|
});
|
||
|
},
|
||
|
onNumber(number) {
|
||
|
this.number = number;
|
||
|
},
|
||
|
onFocus() {
|
||
|
this.inputFocus = true;
|
||
|
let inputNumber = this.inputNumber;
|
||
|
this.$nextTick(() => {
|
||
|
this.inputNumber = inputNumber;
|
||
|
})
|
||
|
},
|
||
|
onBlur() {
|
||
|
this.inputFocus = false;
|
||
|
}
|
||
|
},
|
||
|
}
|
||
|
</script>
|
||
|
<style scoped lang="scss">
|
||
|
/deep/.scroll-list{
|
||
|
margin-bottom: 60rpx !important;
|
||
|
}
|
||
|
/deep/.goodCate .uni-badge-left-margin .uni-badge--error {
|
||
|
background-color: #fff !important;
|
||
|
color: var(--view-theme);
|
||
|
border-color: var(--view-theme);
|
||
|
z-index: 8;
|
||
|
}
|
||
|
|
||
|
/deep/.goodCate .footer .cartIcon .uni-badge-left-margin .uni-badge--error {
|
||
|
right: 0 !important;
|
||
|
top: 10px !important;
|
||
|
}
|
||
|
|
||
|
/deep/.mask {
|
||
|
z-index: 102;
|
||
|
}
|
||
|
|
||
|
/deep/.good-cate {
|
||
|
padding: 80rpx;
|
||
|
}
|
||
|
|
||
|
.white {
|
||
|
position: fixed;
|
||
|
top: 0;
|
||
|
right: 0;
|
||
|
bottom: 0;
|
||
|
left: 0;
|
||
|
z-index: 101;
|
||
|
background: #FFFFFF;
|
||
|
}
|
||
|
|
||
|
.popup {
|
||
|
position: fixed;
|
||
|
top: 50%;
|
||
|
left: 50%;
|
||
|
z-index: 103;
|
||
|
width: 644rpx;
|
||
|
padding: 56rpx 52rpx;
|
||
|
border-radius: 32rpx;
|
||
|
background: #FFFFFF;
|
||
|
transform: translate(-50%, -50%);
|
||
|
|
||
|
.title {
|
||
|
text-align: center;
|
||
|
font-weight: 500;
|
||
|
font-size: 32rpx;
|
||
|
line-height: 52rpx;
|
||
|
color: #333333;
|
||
|
}
|
||
|
|
||
|
.passive {
|
||
|
width: 112rpx;
|
||
|
height: 56rpx;
|
||
|
background: #F5F5F5;
|
||
|
text-align: center;
|
||
|
font-family: SemiBold;
|
||
|
font-size: 31rpx;
|
||
|
line-height: 56rpx;
|
||
|
color: #333333;
|
||
|
}
|
||
|
|
||
|
.foot {
|
||
|
margin-top: 64rpx;
|
||
|
|
||
|
.btn {
|
||
|
flex: 1;
|
||
|
height: 80rpx;
|
||
|
border: 0;
|
||
|
border-radius: 40rpx;
|
||
|
background: var(--view-theme);
|
||
|
font-weight: 500;
|
||
|
font-size: 28rpx;
|
||
|
line-height: 80rpx;
|
||
|
color: #FFFFFF;
|
||
|
|
||
|
.inner {
|
||
|
height: 80rpx;
|
||
|
border-radius: 40rpx;
|
||
|
background: transparent;
|
||
|
}
|
||
|
|
||
|
&.disabled {
|
||
|
.inner {
|
||
|
background: rgba(255, 255, 255, 0.5);
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/deep/.cartList {
|
||
|
z-index: 150 !important;
|
||
|
}
|
||
|
|
||
|
.spinner-box {
|
||
|
margin: 48rpx -32rpx -40rpx 0;
|
||
|
|
||
|
.btn {
|
||
|
width: 111rpx;
|
||
|
height: 80rpx;
|
||
|
border-radius: 16rpx;
|
||
|
margin: 0 32rpx 40rpx 0;
|
||
|
background: #F5F5F5;
|
||
|
text-align: center;
|
||
|
font-family: SemiBold;
|
||
|
font-size: 32rpx;
|
||
|
line-height: 80rpx;
|
||
|
color: #999999;
|
||
|
|
||
|
.inner {
|
||
|
width: 111rpx;
|
||
|
height: 80rpx;
|
||
|
border: 2rpx solid transparent;
|
||
|
border-radius: 16rpx;
|
||
|
background-color: transparent;
|
||
|
background-clip: content-box;
|
||
|
}
|
||
|
|
||
|
&.on {
|
||
|
background: var(--view-theme);
|
||
|
color: var(--view-theme);
|
||
|
|
||
|
.inner {
|
||
|
background-color: rgba(255, 255, 255, 0.9);
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.input {
|
||
|
width: 254rpx;
|
||
|
height: 80rpx;
|
||
|
border: 2rpx solid #CCCCCC;
|
||
|
border-radius: 16rpx;
|
||
|
text-align: center;
|
||
|
font-family: SemiBold;
|
||
|
font-size: 32rpx;
|
||
|
line-height: 80rpx;
|
||
|
color: #999999;
|
||
|
|
||
|
&.on {
|
||
|
border-color: var(--view-theme);
|
||
|
color: var(--view-theme);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/deep/.input-placeholder {
|
||
|
font-weight: 500;
|
||
|
font-size: 28rpx;
|
||
|
color: #CCCCCC;
|
||
|
}
|
||
|
}
|
||
|
</style>
|