1067 lines
28 KiB
Vue
1067 lines
28 KiB
Vue
<template>
|
||
<view class="page-gray color-333 u-font-28">
|
||
<template v-if="true">
|
||
<view class="block u-p-t-32 u-p-b-32" v-if="pageData.table && pageData.table.id">
|
||
<view>桌位号</view>
|
||
<view class="font-bold u-font-32 u-m-t-16">
|
||
{{ pageData.table.name || '' }}
|
||
</view>
|
||
</view>
|
||
<view class="block">
|
||
<view class="u-p-b-24 u-m-b-24 border-bottom">
|
||
<view>选择用户</view>
|
||
<view class="u-m-t-24 u-flex u-row-between" @tap="chooseUser">
|
||
<view v-if="!pageData.user || !pageData.user.id">选择用户</view>
|
||
<view class="u-flex" v-if="pageData.user && pageData.user.id">
|
||
<up-avatar :src="pageData.user.headImg" shape="square" :size="30"></up-avatar>
|
||
|
||
<view class="u-m-l-20">
|
||
<view class="">{{ pageData.user.nickName }}</view>
|
||
</view>
|
||
<view class="u-font-24 u-m-l-30 u-text-center">
|
||
<text>余额:</text>
|
||
<text class="color-main">{{ pageData.user.amount }}</text>
|
||
</view>
|
||
<view class="u-font-24 u-m-l-30 u-text-center">
|
||
<text>积分:</text>
|
||
<text class="color-main">{{ pageData.user.accountPoints }}</text>
|
||
</view>
|
||
</view>
|
||
<uni-icons type="right" color="#999" size="20" bold></uni-icons>
|
||
</view>
|
||
</view>
|
||
<view class=" ">
|
||
<view>就餐类型</view>
|
||
<view class="u-m-t-24 u-flex">
|
||
<view class="u-flex color-666">
|
||
<up-radio-group :disabled="option.type == 'add'" v-model="pageData.eatTypes.active" placement="row">
|
||
<up-radio
|
||
:customStyle="{ marginRight: '30px' }"
|
||
v-for="(item, index) in pageData.eatTypes.list"
|
||
:key="index"
|
||
:label="item.name"
|
||
:name="item.value"
|
||
></up-radio>
|
||
</up-radio-group>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
|
||
<template v-if="pageData.user && pageData.user.id">
|
||
<view class="block">
|
||
<view class="">
|
||
<view class="u-flex border-bottom u-p-b-24">
|
||
<up-avatar :src="pageData.user.headImg" shape="square" :size="60"></up-avatar>
|
||
<!-- <image class="headeimg" src="@/static/uni.png" mode=""></image> -->
|
||
<view class="u-m-l-32">
|
||
<view class="">{{ pageData.user.nickName }}</view>
|
||
<view class="color-main u-font-24">{{ pageData.user.isVip ? '会员' : '' }}</view>
|
||
</view>
|
||
</view>
|
||
<view class="u-flex u-m-t-24 u-row-between u-font-24 color-999">
|
||
<view class="u-flex">
|
||
<view>余额</view>
|
||
<view class="color-333 u-m-l-10">{{ pageData.user.amount }}</view>
|
||
</view>
|
||
<view class="u-flex">
|
||
<view>积分</view>
|
||
<view class="color-333 u-m-l-10">{{ pageData.user.accountPoints }}</view>
|
||
</view>
|
||
<view class="u-flex">
|
||
<view class="u-text-center">订单数量</view>
|
||
<view class="color-333 u-m-l-10">{{ pageData.user.orderNumber || 0 }}</view>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
</template>
|
||
<template v-if="!pageData.shopInfo.isTableFee && pageData.table && pageData.table.id">
|
||
<!-- 不免餐位费 -->
|
||
<view class="block">
|
||
<view class=" ">
|
||
<view>用餐人数(人)</view>
|
||
<picker @change="userNumberChange" :value="userNumbers.defaultCateIndex" :range="userNumbers.list">
|
||
<view class="u-m-t-24 u-flex u-row-between">
|
||
<view class="color-333">{{ userNumbers.defaultCateIndex * 1 + 1 + '人' }}</view>
|
||
<uni-icons type="right" color="#999" size="16"></uni-icons>
|
||
</view>
|
||
</picker>
|
||
</view>
|
||
</view>
|
||
</template>
|
||
<!-- <template v-if="goods.list[0].tableId&&goods.list[0].orderId">
|
||
<view class="block" @tap="rotatingTables"
|
||
style="display: flex;align-items: center;justify-content: space-between;">
|
||
<view>转桌/并桌</view>
|
||
<uni-icons type="right" color="#999" size="16"></uni-icons>
|
||
</view>
|
||
</template> -->
|
||
</template>
|
||
|
||
<view class="block">
|
||
<view class="u-p-b-24">
|
||
<view class="font-bold">订单备注</view>
|
||
<view class="u-m-t-32 u-flex">
|
||
<uni-easyinput type="textarea" v-model="pageData.form.note" placeholder="请输入备注"></uni-easyinput>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
|
||
<view class="block u-m-b-0">
|
||
<view class="u-flex">
|
||
<view>共</view>
|
||
<view class="fen font-bold">{{ goods.list.length }}</view>
|
||
<view>份菜品</view>
|
||
</view>
|
||
|
||
<view class="goods u-m-t-32">
|
||
<view class="item u-m-b-48" @click="changeGoodsSel(index)" v-for="(item, index) in goods.list" :key="index">
|
||
<view class="u-flex u-row-between">
|
||
<view class="u-flex">
|
||
<image class="img" v-if="item.coverImg" :src="item.coverImg" mode=""></image>
|
||
<view style="background-color: #3f9eff; width: 84rpx; height: 84rpx; line-height: 84rpx; text-align: center; color: #fff" v-else>临时菜</view>
|
||
<view class="u-m-l-32">
|
||
<view class="u-flex">
|
||
<view class="u-flex u-m-r-20" v-if="item.is_wait_call" style="flex-shrink: 0">
|
||
<uni-tag text="等叫" custom-style="background-color: #FFF0DF; border-color: #FFF0DF; color: #FF9F2E;"></uni-tag>
|
||
</view>
|
||
<view class="u-m-r-20 u-flex" v-if="item.is_gift" style="flex-shrink: 0">
|
||
<uni-tag text="赠送" custom-style="background-color: #FFF0DF; border-color: #FFF0DF; color: #FF9F2E;"></uni-tag>
|
||
</view>
|
||
<view class="u-m-r-20 u-flex" v-if="item.pack_number > 0" style="flex-shrink: 0">
|
||
<uni-tag
|
||
custom-style="background-color: #E6F0FF; border-color: #E6F0FF; color: #318AFE;"
|
||
size="small"
|
||
text="打包"
|
||
inverted
|
||
type="success"
|
||
/>
|
||
</view>
|
||
<view class="u-m-r-20 u-flex" v-if="item.is_print" style="flex-shrink: 0">
|
||
<uni-tag
|
||
custom-style="background-color: #E6F0FF; border-color: #E6F0FF; color: #318AFE;"
|
||
size="small"
|
||
text="打印"
|
||
inverted
|
||
type="success"
|
||
/>
|
||
</view>
|
||
<view>
|
||
{{ item.name }}
|
||
</view>
|
||
</view>
|
||
<view class="u-font-24 color-999 u-m-t-10">{{ item.specInfo || ' ' }}</view>
|
||
</view>
|
||
</view>
|
||
<view class="">
|
||
<view class="u-relative">
|
||
<template v-if="item.is_gift">
|
||
<text class="line-th color-999">¥{{ $utils.toFixed(item.lowPrice * item.number, item) }}</text>
|
||
<view class="u-absolute" style="right: 0; bottom: 100%">
|
||
<text class="font-bold">¥0</text>
|
||
</view>
|
||
</template>
|
||
<template v-else>
|
||
<template v-if="item.discount_sale_amount && item.discount_sale_amount * 1 > 0">
|
||
<text class="line-th color-999">¥{{ $utils.toFixed(item.lowPrice * item.number, item) }}</text>
|
||
<view class="u-absolute" style="right: 0; bottom: 100%">
|
||
<text class="font-bold">¥{{ $utils.toFixed(item.discount_sale_amount * item.number, item) }}</text>
|
||
</view>
|
||
</template>
|
||
<template v-else-if="isVip && item.lowMemberPrice && item.lowMemberPrice * 1 != item.lowPrice * 1">
|
||
<text class="line-th color-999">¥{{ $utils.toFixed(item.lowPrice * item.number, item) }}</text>
|
||
<view class="u-absolute" style="right: 0; bottom: 100%">
|
||
<text class="font-bold">¥{{ $utils.toFixed(item.lowMemberPrice * item.number, item) }}</text>
|
||
</view>
|
||
</template>
|
||
<template v-else>
|
||
<view class="font-bold">
|
||
<text>¥</text>
|
||
<text class="">{{ $utils.toFixed(item.lowPrice * item.number, item) }}</text>
|
||
</view>
|
||
</template>
|
||
</template>
|
||
</view>
|
||
<view class="color-999 u-text-right u-font-24 u-m-t-12">×{{ item.number }}</view>
|
||
</view>
|
||
</view>
|
||
<template v-if="item.remark">
|
||
<view class="u-p-20 bg-gray u-m-t-16">
|
||
{{ item.remark }}
|
||
</view>
|
||
</template>
|
||
<scroll-view class="u-m-t-32" scroll-x="true" v-if="index == goods.sel">
|
||
<view class="u-flex no-wrap">
|
||
<view class="u-flex u-m-r-20" v-if="!item.is_gift">
|
||
<button class="tag" hover-class="hover-class" @tap="showModel('discount', index)">单品打折</button>
|
||
</view>
|
||
<view class="u-flex u-m-r-20">
|
||
<!-- <button class="tag" hover-class="hover-class" @tap="showModel('giveFood')">赠菜</button> -->
|
||
<button class="tag" hover-class="hover-class" @tap="toggleItem(item, 'is_gift')">{{ item.is_gift ? '取消赠送' : '赠送' }}</button>
|
||
</view>
|
||
<view class="u-flex u-m-r-20">
|
||
<button class="tag" hover-class="hover-class" @tap="showModel('packNumber', index, item)">{{ item.pack_number > 0 ? '取消打包' : '打包' }}</button>
|
||
</view>
|
||
<view class="u-flex u-m-r-20">
|
||
<button class="tag" hover-class="hover-class" @tap="toggleItem(item, 'is_wait_call')">{{ item.is_wait_call ? '取消等叫' : '等叫' }}</button>
|
||
</view>
|
||
<view class="u-flex u-m-r-20">
|
||
<button class="tag" hover-class="hover-class" @tap="toggleItem(item, 'is_print')">{{ item.is_print ? '免厨打' : '打印' }}</button>
|
||
</view>
|
||
<view class="u-flex u-m-r-20">
|
||
<button class="tag" hover-class="hover-class" @tap="showModel('remark', index)">单品备注</button>
|
||
</view>
|
||
</view>
|
||
</scroll-view>
|
||
</view>
|
||
</view>
|
||
<view class="border-bottom">
|
||
<template v-if="$seatFee && $seatFee.totalAmount">
|
||
<view class="u-flex u-row-between u-m-t-18 u-p-b-34">
|
||
<view>
|
||
<text>桌位费</text>
|
||
</view>
|
||
<view>¥{{ $seatFee.totalAmount.toFixed(2) || '0.00' }}</view>
|
||
</view>
|
||
</template>
|
||
<template v-if="$packFee > 0">
|
||
<view class="u-flex u-row-between u-m-t-18 u-p-b-34">
|
||
<view>
|
||
<text>打包费</text>
|
||
</view>
|
||
<view>¥{{ $packFee || '0.00' }}</view>
|
||
</view>
|
||
</template>
|
||
</view>
|
||
|
||
<view class="u-flex u-row-between u-m-t-38">
|
||
<view class="u-flex">
|
||
<view class="u-flex price" v-if="youhui * 1 > 0">
|
||
<view class="">优惠金额</view>
|
||
<view class="font-bold u-font-32">¥{{ $utils.toFixed(youhui) }}</view>
|
||
</view>
|
||
</view>
|
||
|
||
<view class="u-flex price u-m-l-32">
|
||
<view class="">实收金额</view>
|
||
<view class="font-bold u-font-32">¥{{ allPrice }}</view>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
|
||
<view :style="{ height: bottomHeight + 'px' }"></view>
|
||
<view class="safe-bottom fixed">
|
||
<view class="btn">
|
||
<my-button shape="circle" @click="createAnOrder">
|
||
<view class="font-bold u-font-32">
|
||
{{ pageData.shopInfo.registerType == 'before' || pageData.eatTypes.active == 'take-out' ? '结算' : '下单' }}
|
||
</view>
|
||
</my-button>
|
||
</view>
|
||
</view>
|
||
<model-discount title="菜品减免" :ref="setModel" name="discount" :price="modelData.data.salePrice" @confirm="discountconfirm"></model-discount>
|
||
<give-food title="赠菜" :ref="setModel" name="giveFood"></give-food>
|
||
<one-remark @confirm="goodsOneRemarkConfirm" title="单品备注" :ref="setModel" name="remark"></one-remark>
|
||
<pack-number @confirm="goodsOnePackNumberConfirm" title="打包" :ref="setModel" name="packNumber"></pack-number>
|
||
<!-- <edit-discount title="优惠金额" :ref="setModel" name="editMoney" :price="allPrice"></edit-discount> -->
|
||
</view>
|
||
</template>
|
||
|
||
<script setup>
|
||
import { onLoad, onReady, onShow, onHide } from '@dcloudio/uni-app';
|
||
import { ref, inject, onUnmounted, nextTick, reactive, computed, watch } from 'vue';
|
||
|
||
import modelDiscount from './components/discount';
|
||
import giveFood from './components/give-food';
|
||
import packNumber from './components/pack-number';
|
||
import oneRemark from './components/remark';
|
||
// import editDiscount from '@/pagesCreateOrder/components/edit-discount.vue'
|
||
|
||
import { getSafeBottomHeight } from '@/commons/utils/safe-bottom.js';
|
||
import go from '@/commons/utils/go.js';
|
||
import { hasPermission } from '@/commons/utils/hasPermission.js';
|
||
import { getNowCart } from '@/pagesCreateOrder/util.js';
|
||
import { number } from 'uview-plus/libs/function/test';
|
||
|
||
import { getShopInfo } from '@/http/api/shop.js';
|
||
import { getShopTableDetail } from '@/http/api/table.js';
|
||
import { getProductList } from '@/http/api/product.js';
|
||
import { createOrder, getHistoryOrder } from '@/http/api/order.js';
|
||
|
||
const models = new Map();
|
||
const modelData = reactive({
|
||
data: {},
|
||
selIndex: -1
|
||
});
|
||
const option = reactive({
|
||
id: '',
|
||
tableId: ''
|
||
});
|
||
/**
|
||
* 用餐人数
|
||
*/
|
||
const userNumbers = reactive({
|
||
list: new Array(100).fill(1).map((v, index) => {
|
||
// return index === 0 ? '无' : index + '人'
|
||
return index + 1 + '人';
|
||
}),
|
||
defaultCateIndex: 0
|
||
});
|
||
const f = reactive({});
|
||
|
||
let $goods = [];
|
||
const goods = reactive({
|
||
list: [],
|
||
sel: 0
|
||
});
|
||
const pageData = reactive({
|
||
shopInfo: {},
|
||
table: {},
|
||
user: {},
|
||
eatTypes: {
|
||
list: [
|
||
{
|
||
name: '堂食',
|
||
value: 'dine-in'
|
||
},
|
||
{
|
||
name: '外带',
|
||
value: 'take-out'
|
||
}
|
||
// ,
|
||
// {
|
||
// name: "外卖",
|
||
// value: "take-away",
|
||
// }
|
||
],
|
||
active: 'dine-in',
|
||
isShow: false
|
||
},
|
||
form: {
|
||
note: ''
|
||
},
|
||
orderInfo: {}
|
||
});
|
||
const websocketUtil = inject('websocketUtil'); // 注入 WebSocket 工具类实例
|
||
onLoad((opt) => {
|
||
Object.assign(option, opt);
|
||
console.log('opt====', opt);
|
||
if (opt.tableId || opt.tableCode) {
|
||
pageData.table.id = opt.tableId;
|
||
pageData.table.tableCode = opt.tableCode;
|
||
}
|
||
pageData.shopInfo = uni.getStorageSync('shopInfo');
|
||
getTbShopInfo();
|
||
});
|
||
let bottomHeight = ref(100);
|
||
onReady(() => {
|
||
getSafeBottomHeight('safe-bottom').then((res) => {
|
||
bottomHeight.value = res;
|
||
});
|
||
});
|
||
watch(
|
||
() => userNumbers.defaultCateIndex,
|
||
(newval) => {
|
||
updateChoseCount();
|
||
}
|
||
);
|
||
|
||
watch(
|
||
() => pageData.eatTypes.active,
|
||
(newval) => {
|
||
pageData.eatTypes.isShow = true;
|
||
changeUseType();
|
||
}
|
||
);
|
||
onShow(() => {
|
||
init();
|
||
watchChooseuser();
|
||
watchChooseTable();
|
||
});
|
||
onHide(() => {
|
||
console.log('onHide');
|
||
websocketUtil.offMessage();
|
||
});
|
||
onUnmounted(() => {
|
||
console.log('onUnmounted');
|
||
websocketUtil.offMessage();
|
||
});
|
||
|
||
/**
|
||
* 获取订单详情
|
||
* @param {Object} tableCode
|
||
*/
|
||
async function getHistoryOrderDetail(tableCode) {
|
||
let res = await getHistoryOrder({ tableCode: tableCode });
|
||
pageData.orderInfo = res;
|
||
}
|
||
|
||
//餐位费
|
||
const $seatFee = reactive({
|
||
totalNumber: 0,
|
||
totalAmount: 0
|
||
});
|
||
|
||
/**
|
||
* 打包费
|
||
*/
|
||
const $packFee = computed(() => {
|
||
let packAmount = 0;
|
||
return goods.list
|
||
.reduce((prve, cur) => {
|
||
return prve + (cur.packFee || 0) * parseFloat(cur.pack_number).toFixed(2);
|
||
}, 0)
|
||
.toFixed(2);
|
||
});
|
||
|
||
/**
|
||
* 菜品数量
|
||
*/
|
||
const goodsNumber = computed(() => {
|
||
const result = goods.list.reduce((prve, cur) => {
|
||
return prve + cur.number;
|
||
}, 0);
|
||
return result;
|
||
});
|
||
|
||
/**
|
||
* 判断是否是会员
|
||
*/
|
||
const isVip = computed(() => {
|
||
return pageData.shopInfo.isMemberPrice && pageData.user && pageData.user.id && pageData.user.isVip;
|
||
});
|
||
|
||
const discount_sale_amount = computed(() => {
|
||
return goods.list
|
||
.filter((v) => v.discount_sale_amount && v.discount_sale_amount > 0)
|
||
.reduce((a, b) => {
|
||
const lowMemberPrice = b.lowMemberPrice ? b.lowMemberPrice : b.lowPrice;
|
||
const tPrice = isVip.value ? lowMemberPrice : b.lowPrice;
|
||
return a + b.number * (tPrice - b.discount_sale_amount);
|
||
}, 0);
|
||
});
|
||
|
||
const goodsPrice = computed(() => {
|
||
const goodsTotalPrice = goods.list.reduce((prve, cur) => {
|
||
const lowMemberPrice = cur.lowMemberPrice ? cur.lowMemberPrice : cur.lowPrice;
|
||
const tPrice = Math.floor((isVip.value ? lowMemberPrice : cur.lowPrice) * cur.number * 100) / 100;
|
||
return prve + (cur.is_gift ? 0 : tPrice);
|
||
}, 0);
|
||
const tpackFee = $packFee.value > 0 ? $packFee.value * 1 : 0;
|
||
|
||
return (goodsTotalPrice - discount_sale_amount.value + tpackFee || 0).toFixed(2);
|
||
});
|
||
|
||
/**
|
||
* 实收金额
|
||
*/
|
||
const allPrice = computed(() => {
|
||
const n = goodsPrice.value * 1 + $seatFee.totalAmount;
|
||
return n.toFixed(2);
|
||
});
|
||
|
||
/**
|
||
* 计算优惠金额
|
||
*/
|
||
const youhui = computed(() => {
|
||
let goodsTotalPrice = 0;
|
||
if (pageData.user && pageData.user.id && pageData.user.isVip) {
|
||
goodsTotalPrice = goods.list.reduce((prve, cur) => {
|
||
const tPrice = cur.lowPrice * cur.number;
|
||
const tpackFee = cur.pack_number * 1 > 0 ? cur.packFee * (cur.pack_number * 1) : 0;
|
||
return prve + tPrice + tpackFee;
|
||
}, 0);
|
||
return goodsTotalPrice + $seatFee.totalAmount - allPrice.value;
|
||
} else {
|
||
return discount_sale_amount.value;
|
||
}
|
||
return (goodsTotalPrice + discount_sale_amount.value * 1).toFixed(2);
|
||
});
|
||
|
||
/**
|
||
* init
|
||
*/
|
||
async function init() {
|
||
nextTick(() => {
|
||
onMessage();
|
||
});
|
||
// 获取商品列表
|
||
$goods = await getProductList({}, 'product', false);
|
||
// console.log("商品列表===",$goods)
|
||
getTableInfo(pageData.table);
|
||
}
|
||
|
||
/**
|
||
* socket消息监听
|
||
*/
|
||
function onMessage() {
|
||
websocketUtil.offMessage();
|
||
websocketUtil.onMessage((res) => {
|
||
let msg = JSON.parse(res);
|
||
console.log(msg);
|
||
let cartItem;
|
||
if (msg.msg_id) {
|
||
websocketUtil.send(
|
||
JSON.stringify({
|
||
type: 'receipt',
|
||
msg_id: msg.msg_id
|
||
})
|
||
);
|
||
}
|
||
if (msg.status == 0) {
|
||
infoBox.showToast(msg.msg || '操作失败');
|
||
return false;
|
||
}
|
||
|
||
switch (msg.operate_type) {
|
||
case 'onboc_init':
|
||
goods.list = [];
|
||
console.log(msg.data);
|
||
msg.data.map((item) => {
|
||
cartItem = getNowCart(item, $goods, pageData.user);
|
||
console.log(cartItem);
|
||
if (cartItem.isGrounding || cartItem.is_temporary == 1) {
|
||
cartControls(cartItem, 'add');
|
||
} else {
|
||
delCart(cartItem.id);
|
||
}
|
||
});
|
||
if (pageData.eatTypes.isShow) {
|
||
if (pageData.eatTypes.active == 'take-out') {
|
||
cartItem.pack_number = cartItem.number;
|
||
} else {
|
||
cartItem.pack_number = 0;
|
||
}
|
||
let par = {
|
||
type: 'onboc',
|
||
account: uni.getStorageSync('iToken').loginId,
|
||
shop_id: uni.getStorageSync('shopInfo').id,
|
||
operate_type: 'batch',
|
||
table_code: pageData.table.tableCode,
|
||
is_pack: pageData.eatTypes.active == 'take-out' ? 1 : 0
|
||
};
|
||
updateCart(par);
|
||
}
|
||
// 是否更新就餐人数
|
||
if (!$seatFee.totalNumber) {
|
||
updateChoseCount();
|
||
}
|
||
|
||
pageData.eatTypes.isShow = false;
|
||
break;
|
||
case 'onboc_add':
|
||
case 'add':
|
||
cartItem = getNowCart(msg.data, $goods, pageData.user);
|
||
cartControls(cartItem, 'add');
|
||
break;
|
||
case 'onboc_edit':
|
||
case 'edit':
|
||
getCart();
|
||
break;
|
||
case 'onboc_del':
|
||
case 'del':
|
||
cartItem = getNowCart(msg.data, $goods, pageData.user);
|
||
cartControls(cartItem, 'del');
|
||
break;
|
||
case 'onboc_cleanup':
|
||
case 'cleanup':
|
||
goods.list = [];
|
||
$seatFee.totalNumber = 0;
|
||
$seatFee.totalAmount = 0;
|
||
userNumbers.defaultCateIndex = 0;
|
||
init();
|
||
break;
|
||
case 'product_update':
|
||
init();
|
||
break;
|
||
}
|
||
});
|
||
}
|
||
|
||
/**
|
||
* 删除购物车菜品
|
||
*/
|
||
function delCart(cartItem) {
|
||
let params = {
|
||
type: 'onboc',
|
||
account: uni.getStorageSync('iToken').loginId,
|
||
shop_id: uni.getStorageSync('shopInfo').id,
|
||
is_gift: 0,
|
||
id: cartItem.id,
|
||
operate_type: 'del',
|
||
table_code: cartItem.table_code
|
||
};
|
||
websocketUtil.send(JSON.stringify(params));
|
||
}
|
||
|
||
/**
|
||
* socket通知购物车商品数量修改处理
|
||
*/
|
||
function cartControls(cartItem, type) {
|
||
if (!pageData.table.tableCode) {
|
||
pageData.table.tableCode = cartItem.table_code;
|
||
}
|
||
let cartIndex = 0;
|
||
goods.list.map((item, index) => {
|
||
if (item.id == cartItem.id) {
|
||
cartIndex = index;
|
||
}
|
||
});
|
||
|
||
if (type == 'del') {
|
||
goods.list.splice(cartIndex, 1);
|
||
return;
|
||
}
|
||
if (type == 'add') {
|
||
goods.list.push(cartItem);
|
||
}
|
||
if (type == 'edit') {
|
||
goods.list[cartIndex].number = cartItem.number;
|
||
}
|
||
}
|
||
|
||
/**
|
||
* 获取购物车数据
|
||
*/
|
||
function getCart() {
|
||
// 初始化购物车
|
||
websocketUtil.send(
|
||
JSON.stringify({
|
||
type: 'onboc',
|
||
account: uni.getStorageSync('iToken').loginId,
|
||
shop_id: uni.getStorageSync('shopInfo').id,
|
||
operate_type: 'init',
|
||
table_code: pageData.table.tableCode
|
||
})
|
||
);
|
||
}
|
||
|
||
/**
|
||
* 获取店铺信息
|
||
*/
|
||
async function getTbShopInfo() {
|
||
const res = await getShopInfo({ id: uni.getStorageSync('shopInfo').id });
|
||
pageData.shopInfo = res;
|
||
uni.setStorageSync('shopInfo', res);
|
||
}
|
||
|
||
/**
|
||
* 获取桌台信息
|
||
*/
|
||
async function getTableInfo(opt) {
|
||
let res = {};
|
||
if (opt.id) {
|
||
res = await getShopTableDetail({ id: opt.id, tableCode: opt.tableCode });
|
||
}
|
||
Object.assign(pageData.table, res);
|
||
if (!pageData.shopInfo.isTableFee && pageData.table && pageData.table.id) {
|
||
userNumbers.list = new Array(res.maxCapacity ? res.maxCapacity * 1 : 100).fill(1).map((v, index) => {
|
||
return index + 1 + '人';
|
||
});
|
||
}
|
||
// 获取购物车数据
|
||
getCart();
|
||
// 获取购物车数据
|
||
getHistoryOrderDetail(opt.tableCode);
|
||
}
|
||
|
||
/**
|
||
* 更新选择用户
|
||
*/
|
||
function watchChooseuser() {
|
||
uni.$off('choose-user');
|
||
uni.$on('choose-user', (data) => {
|
||
pageData.user = data;
|
||
});
|
||
}
|
||
|
||
/**
|
||
* 就餐类型切换监听
|
||
*/
|
||
async function changeUseType() {
|
||
if (!goods.list.length) {
|
||
return;
|
||
}
|
||
getCart();
|
||
}
|
||
|
||
/**
|
||
* 购物车数据修改
|
||
* @param {Object} par
|
||
*/
|
||
function updateCart(par) {
|
||
websocketUtil.send(
|
||
JSON.stringify({
|
||
type: 'onboc',
|
||
account: uni.getStorageSync('iToken').loginId,
|
||
shop_id: uni.getStorageSync('shopInfo').id,
|
||
operate_type: 'edit',
|
||
table_code: pageData.table.tableCode,
|
||
...par
|
||
})
|
||
);
|
||
getCart();
|
||
}
|
||
|
||
/**
|
||
* 菜品赠送/等叫/打印修改
|
||
* @param {Object} item
|
||
*/
|
||
function toggleItem(item, key) {
|
||
let par = {
|
||
id: item.id,
|
||
product_id: item.product_id,
|
||
sku_id: item.sku_id
|
||
};
|
||
par[key] = item[key] == 0 ? 1 : 0;
|
||
updateCart(par);
|
||
}
|
||
|
||
/**
|
||
* 单品打折
|
||
* @param {Object} form
|
||
*/
|
||
async function discountconfirm(form) {
|
||
if (form.discountMoney != '.') {
|
||
let str = '';
|
||
if (form.notes) {
|
||
form.notes.forEach((ele) => {
|
||
if (ele.checked) {
|
||
str = str + ele.name + ',';
|
||
}
|
||
});
|
||
}
|
||
let lowMemberPrice = modelData.data.lowMemberPrice ? modelData.data.lowMemberPrice : modelData.data.lowPrice;
|
||
let tPrice = isVip.value ? lowMemberPrice : modelData.data.lowPrice;
|
||
let discount_sale_amount = modelData.data.is_gift ? 0 : form.discountMoney;
|
||
let par = {
|
||
id: modelData.data.id,
|
||
product_id: modelData.data.product_id,
|
||
sku_id: modelData.data.sku_id,
|
||
discount_sale_amount: discount_sale_amount,
|
||
discount_sale_note: str + form.note
|
||
};
|
||
updateCart(par);
|
||
}
|
||
}
|
||
|
||
/**
|
||
* 打包
|
||
*/
|
||
function goodsOnePackNumberConfirm(e) {
|
||
let par = {
|
||
id: modelData.data.id,
|
||
product_id: modelData.data.product_id,
|
||
sku_id: modelData.data.sku_id,
|
||
pack_number: e
|
||
};
|
||
updateCart(par);
|
||
}
|
||
|
||
/**
|
||
* 单品备注确认
|
||
* @param {Object} e
|
||
*/
|
||
async function goodsOneRemarkConfirm(e) {
|
||
let par = {
|
||
id: modelData.data.id,
|
||
product_id: modelData.data.product_id,
|
||
sku_id: modelData.data.sku_id,
|
||
remark: e.remark
|
||
};
|
||
updateCart(par);
|
||
}
|
||
|
||
/**
|
||
* 设置弹窗信息
|
||
* @param {Object} el
|
||
*/
|
||
function setModel(el) {
|
||
if (el && el.$attrs['name']) {
|
||
models.set(el.$attrs['name'], el);
|
||
}
|
||
}
|
||
|
||
/**
|
||
* 打开弹窗
|
||
* @param {Object} key
|
||
* @param {Object} index
|
||
*/
|
||
function showModel(key, index, item) {
|
||
modelData.data = goods.list[index];
|
||
modelData.selIndex = index;
|
||
const model = models.get(key);
|
||
console.log('弹窗数据===', modelData.data);
|
||
if (key == 'packNumber') {
|
||
if (modelData.data.type == 'weight' && item.pack_number <= 0) {
|
||
let par = {
|
||
id: modelData.data.id,
|
||
product_id: modelData.data.product_id,
|
||
sku_id: modelData.data.sku_id,
|
||
pack_number: 1
|
||
};
|
||
updateCart(par);
|
||
return false;
|
||
}
|
||
if (item.pack_number > 0) {
|
||
let par = {
|
||
id: modelData.data.id,
|
||
product_id: modelData.data.product_id,
|
||
sku_id: modelData.data.sku_id,
|
||
pack_number: 0
|
||
};
|
||
updateCart(par);
|
||
return false;
|
||
}
|
||
model &&
|
||
model.open({
|
||
number: item.number
|
||
});
|
||
} else {
|
||
model &&
|
||
model.open({
|
||
packNumber: modelData.data.remark || ''
|
||
});
|
||
}
|
||
}
|
||
|
||
function formatPrice(n) {
|
||
return (Math.floor(n * 100) / 100).toFixed(2);
|
||
}
|
||
|
||
function rotatingTables() {
|
||
uni.navigateTo({
|
||
url: '/pagesCreateOrder/confirm-order/rotatingTables?item=' + JSON.stringify(goods.list)
|
||
});
|
||
}
|
||
|
||
/**
|
||
* 更新就餐人数
|
||
*/
|
||
async function updateChoseCount() {
|
||
const maxCapacity = pageData.table && pageData.table.id ? pageData.table.maxCapacity || 0 : 100;
|
||
if (pageData.table && pageData.table.id && userNumbers.defaultCateIndex * 1 + 1 > maxCapacity) {
|
||
uni.$utils.showToast('当前台桌最大人数为: ' + maxCapacity);
|
||
userNumbers.defaultCateIndex = maxCapacity - 1;
|
||
return;
|
||
}
|
||
console.log(pageData.shopInfo);
|
||
console.log(!pageData.shopInfo.isTableFee);
|
||
if (!pageData.shopInfo.isTableFee && pageData.table && pageData.table.id && goods.list.length > 0) {
|
||
//不免餐位费
|
||
console.log('不免餐位费');
|
||
let seatFee = {
|
||
totalNumber: userNumbers.defaultCateIndex * 1 + 1,
|
||
totalAmount: (userNumbers.defaultCateIndex * 1 + 1) * pageData.shopInfo.tableFee
|
||
};
|
||
Object.assign($seatFee, seatFee);
|
||
userNumbers.defaultCateIndex = $seatFee.totalNumber - 1;
|
||
}
|
||
}
|
||
|
||
/**
|
||
* 选择就餐人数
|
||
* @param {Object} e
|
||
*/
|
||
function userNumberChange(e) {
|
||
userNumbers.defaultCateIndex = e.detail.value;
|
||
}
|
||
|
||
function chooseUser() {
|
||
go.to('PAGES_CHOOSE_USER');
|
||
}
|
||
|
||
function chooseTable() {
|
||
go.to('PAGES_CHOOSE_TABLE', {
|
||
...pageData.table
|
||
});
|
||
}
|
||
|
||
function watchChooseTable() {
|
||
uni.$off('choose-table');
|
||
uni.$on('choose-table', (data) => {
|
||
pageData.table = data;
|
||
console.log('台桌信息', pageData.table);
|
||
});
|
||
}
|
||
|
||
function changeGoodsSel(index) {
|
||
goods.sel = index;
|
||
}
|
||
|
||
/**
|
||
* 创建订单
|
||
*/
|
||
async function createAnOrder() {
|
||
if (pageData.shopInfo.registerType == 'before' || pageData.eatTypes.active == 'take-out') {
|
||
const canJiesuan = await hasPermission('允许收款');
|
||
if (!canJiesuan) {
|
||
return;
|
||
}
|
||
}
|
||
|
||
let vipPrice = isVip.value ? 1 : 0;
|
||
let placeNum = pageData.orderInfo ? pageData.orderInfo.placeNum + 1 : 1;
|
||
let originAmount = goodsPrice.value * 1 + youhui.value * 1;
|
||
let par = {
|
||
shopId: pageData.shopInfo.id, //店铺Id
|
||
userId: pageData.user.userId, //用户Id
|
||
tableCode: pageData.table.tableCode, //台桌编码
|
||
dineMode: pageData.eatTypes.active, //用餐模式 堂食 dine-in 外带 take-out 外卖 take-away
|
||
remark: pageData.form.note, //备注
|
||
seatNum: 0, //用餐人数
|
||
packFee: $packFee.value, //打包费
|
||
originAmount: originAmount, //订单原金额(包含打包费+餐位费) 不含折扣价格
|
||
placeNum: placeNum, //当前订单下单次数
|
||
waitCall: 0, //是否等叫 0 否 1 等叫
|
||
vipPrice: vipPrice //是否使用会员价
|
||
};
|
||
if (!pageData.shopInfo.isTableFee && pageData.table && pageData.table.id) {
|
||
par.seatNum = userNumbers.defaultCateIndex * 1 + 1;
|
||
}
|
||
if (pageData.orderInfo) {
|
||
par.orderId = pageData.orderInfo.id;
|
||
}
|
||
|
||
const res = await createOrder(par);
|
||
uni.$emit('update:createOrderIndex');
|
||
websocketUtil.send(
|
||
JSON.stringify({
|
||
type: 'onboc',
|
||
account: uni.getStorageSync('iToken').loginId,
|
||
shop_id: uni.getStorageSync('shopInfo').id,
|
||
operate_type: 'cleanup',
|
||
table_code: pageData.table.tableCode
|
||
})
|
||
);
|
||
uni.removeStorageSync('table_code');
|
||
if (pageData.shopInfo.registerType == 'before' || pageData.eatTypes.active == 'take-out') {
|
||
//先付
|
||
return go.to(
|
||
'PAGES_ORDER_PAY',
|
||
{
|
||
orderId: res.id,
|
||
isNowPay: true
|
||
},
|
||
'redirect'
|
||
);
|
||
} else {
|
||
//后付
|
||
if (option.isCreateOrderToDetail != '0') {
|
||
go.to(
|
||
'PAGES_ORDER_DETAIL',
|
||
{
|
||
id: res.id
|
||
},
|
||
'redirect'
|
||
);
|
||
} else {
|
||
uni.navigateBack({
|
||
delta: 2
|
||
});
|
||
}
|
||
}
|
||
uni.showToast({
|
||
title: '提交成功',
|
||
icon: 'none'
|
||
});
|
||
}
|
||
</script>
|
||
|
||
<style lang="scss" scoped>
|
||
.fen {
|
||
color: #ff9f2e;
|
||
}
|
||
|
||
.page-gray {
|
||
padding: 32rpx 28rpx 0 28rpx;
|
||
}
|
||
|
||
.headeimg {
|
||
width: 84rpx;
|
||
height: 84rpx;
|
||
border-radius: 12rpx 12rpx 12rpx 12rpx;
|
||
}
|
||
|
||
.block {
|
||
background-color: #fff;
|
||
padding: 32rpx 24rpx;
|
||
border-radius: 18rpx;
|
||
margin-bottom: 32rpx;
|
||
}
|
||
|
||
.textarea {
|
||
border-radius: 12rpx 12rpx 12rpx 12rpx;
|
||
padding: 32rpx 0 32rpx 24rpx;
|
||
border: 1px solid #999999;
|
||
overflow: hidden;
|
||
}
|
||
|
||
.goods {
|
||
// padding-bottom: 30rpx;
|
||
border-bottom: 1px dashed #e5e5e5;
|
||
|
||
.item {
|
||
.img {
|
||
width: 84rpx;
|
||
height: 84rpx;
|
||
border-radius: 8rpx 8rpx 8rpx 8rpx;
|
||
}
|
||
}
|
||
}
|
||
|
||
.headeimg {
|
||
width: 60rpx;
|
||
height: 60rpx;
|
||
display: flex;
|
||
background-color: #eee;
|
||
border-radius: 12rpx;
|
||
overflow: hidden;
|
||
|
||
.img {
|
||
width: 60rpx;
|
||
height: 60rpx;
|
||
}
|
||
}
|
||
|
||
.price {
|
||
color: #eb4f4f;
|
||
}
|
||
|
||
.opacity0 {
|
||
opacity: 0;
|
||
}
|
||
|
||
.fixed {
|
||
position: fixed;
|
||
}
|
||
|
||
.safe-bottom {
|
||
padding: 34rpx 28rpx;
|
||
background-color: #fff;
|
||
left: 0;
|
||
right: 0;
|
||
bottom: 0;
|
||
z-index: 10;
|
||
|
||
.btn {
|
||
padding: 0 88rpx 56rpx 88rpx;
|
||
}
|
||
}
|
||
|
||
.tag {
|
||
background-color: #fff;
|
||
border: 1px solid #e5e5e5;
|
||
line-height: inherit;
|
||
font-size: 24rpx;
|
||
color: #666666;
|
||
padding: 6rpx 16rpx;
|
||
border-radius: 100rpx;
|
||
}
|
||
|
||
.hover-class {
|
||
background-color: #e5e5e5;
|
||
}
|
||
</style>
|