Dining_Hall/pages/advanceOrder/index.vue

915 lines
26 KiB
Vue
Raw Normal View History

2025-01-03 10:20:58 +08:00
<template>
<view>
2025-03-14 15:15:54 +08:00
<u-loading-page :loading="showLoading" loading-text="正在加载..."></u-loading-page>
2025-02-21 10:05:11 +08:00
<view class="top-wrap">
<view class="top-cont flex justify-between align-center">
<view class="flex align-center">
2025-01-03 18:14:29 +08:00
<u-icon name="../../static/images/time.png" size="16"></u-icon>
<span style="margin-left: 5px">{{ newDate }}</span>
2025-02-21 10:05:11 +08:00
</view>
<!-- <view class="top-right-cont">
2025-01-03 18:14:29 +08:00
<span class="right-item" :class="{ active: active == 1 }" @click="active = 1">自取</span>
<span class="right-item" :class="{ active: active == 2 }" @click="active = 2">外卖</span>
2025-02-21 10:05:11 +08:00
</view> -->
</view>
</view>
2025-02-19 09:34:34 +08:00
<view class="tab-navigation">
<Tabs :tabList="tabList" @changeTab="changeTab" />
</view>
<view class="menuContent">
<scroll-view class="content-left" scroll-y="true">
2025-03-14 15:15:54 +08:00
<view class="scroll-view-item" v-for="(item,index) in typeList" :key="index" :class="tIndex == index ? 'active2' : ''" @click="changeModel(item,index)">
2025-02-19 09:34:34 +08:00
<view style="width: 100%;display: flex;flex-direction: column;align-items: center;">
2025-03-14 15:15:54 +08:00
<view>{{item.typeName}}</view>
2025-02-19 09:34:34 +08:00
</view>
</view>
2025-03-14 15:15:54 +08:00
</scroll-view>
<scroll-view class="content-right" scroll-y="true" :scroll-top="scrollLeftTop" scroll-with-animation="true">
<view v-for="(typeitem,typeindex) in typeList":key="typeindex">
<view :id="'scroll'+typeitem.typeId" style="margin: 20rpx 10rpx;font-weight: bold;font-size: 32rpx;">{{typeitem.typeName}}</view>
<view class="scroll-right-item" v-for="(item,index) in typeitem.dishesList" :key="index">
<view style="width: 100%;display: flex;align-items: center;height: 100%;">
<view style="width: 160rpx;height: 160rpx;" @click="goMenuDetail(item)" v-if="item.surplusNum>0">
<image class="image" :src="item.dishesImgUrl"></image>
</view>
<view style="width: 160rpx;height: 160rpx;position: relative;background: rgba(0,0,0,0.1);" @click="goMenuDetail(item)" v-else>
<image class="image" :src="item.dishesImgUrl" style="opacity: 0.5;"></image>
<view class="wait-btn">已售罄</view>
</view>
<view style="width: 65%;height: 100%; display: flex;position: relative;">
<view class="center-cont" @click="goMenuDetail(item)">
<view class="meal-name" style="margin-bottom: 10rpx;font-weight: bold;" :style="{color:(item.surplusNum==0? '#747474':'#000')}">{{ item.dishesName }}</view>
<view class="sale-num" style="margin-bottom: 10rpx;">
<text>月销 {{ item.monthlySales||0 }}</text>
<text style="margin-left: 20rpx;">好评率{{ item.goodProbability||0 }}%</text>
</view>
<view class="num-cont" style="margin-bottom: 10rpx;" :style="{color:(item.surplusNum==0? '#ffbe89':'#ff6816')}">
<span style="margin-right: 5px;" :style="{borderColor:(item.surplusNum==0? '#ffbe89':'#ff6816')}">{{ '库存' + item.surplusNum }}</span>
<span :style="{borderColor:(item.surplusNum==0? '#ffbe89':'#ff6816')}">{{ '限购' + item.restrictNum }}</span>
</view>
<view class="sale-price" style="margin-bottom: 10rpx;" :style="{color:(item.surplusNum==0? '#ffbe89':'#ff6816')}">
<span style="font-size: 11px"></span>
<span style="font-size: 16px">{{ (item.dishesDetailList[0].dishesPrice/100).toFixed(2) }}</span>
<span style="font-size: 20rpx;color: #666;font-weight: 400;text-decoration: line-through;margin-left: 10rpx;">{{ (item.dishesDetailList[0].dishesPrice/100).toFixed(2) }}</span>
</view>
2025-02-19 09:34:34 +08:00
</view>
2025-03-14 15:15:54 +08:00
<view class="right-cont" v-if="item.surplusNum!=0">
<u-icon v-if="item.quantity > 0"
name="../../static/images/delete.png"
size="16"
@click="handleFoodNum(1, item)"
/>
<span style="margin: 0 10px">{{ item.quantity || 0 }}</span>
<u-icon
v-if="item.quantity < item.restrictNum"
name="../../static/images/add.png"
size="16"
@click="handleFoodNum(2, item)"
/>
<u-icon v-if="item.quantity == item.restrictNum" name="../../static/images/no-add.png" size="16" />
2025-02-19 09:34:34 +08:00
</view>
</view>
</view>
2025-03-14 15:15:54 +08:00
</view>
2025-02-19 09:34:34 +08:00
</view>
2025-03-14 15:15:54 +08:00
<view v-if="typeList.length == 0&&!showLoading" class="flex justify-center align-center" style="height: 50vh">
<u-empty icon="../../static/images/not_order.png" text="暂无数据" textColor="#000" />
</view>
</scroll-view>
2025-02-19 09:34:34 +08:00
</view>
2025-01-03 16:50:09 +08:00
<!-- 购物车 -->
2025-02-21 10:05:11 +08:00
<view style="height: 60px"></view>
<view class="shop-car">
<view class="car-cont">
<view class="flex align-center" @click="openCar">
2025-01-03 16:50:09 +08:00
<u-icon name="../../static/images/shop-car.png" size="25"></u-icon>
<span class="money">
<span style="font-size: 11px"></span>
{{ totalPrice }}
</span>
2025-02-21 10:05:11 +08:00
</view>
2025-01-03 16:50:09 +08:00
2025-02-21 10:05:11 +08:00
<view>
2025-01-10 17:39:14 +08:00
<u-button shape="circle" color="#FF6816" style="width: 79px; height: 28px" @click="handleOrder">结算</u-button>
2025-02-21 10:05:11 +08:00
</view>
</view>
</view>
2025-01-03 16:50:09 +08:00
<!-- 购物车-pop -->
<u-popup :show="showCar" position="bottom" :round="12" @close="showCar = false">
2025-02-21 10:05:11 +08:00
<view class="popup-cont">
<view class="flex justify-between align-center">
<view style="font-weight: 500; font-size: 14px">已加购菜品</view>
<view style="font-weight: 400; font-size: 12px; color: #ff6816" @click="showModal = true">清空</view>
</view>
2025-01-03 16:50:09 +08:00
2025-02-21 10:05:11 +08:00
<view class="flex justify-between align-center" style="margin: 20.5px 0 12.5px">
<view class="flex align-center">
2025-02-19 09:34:34 +08:00
{{ canteenName }}/{{stallName}}
2025-01-03 16:50:09 +08:00
<span class="name-type">{{ canteenType }}</span>
2025-02-21 10:05:11 +08:00
</view>
<view>
2025-01-03 16:50:09 +08:00
{{ newDate2 }}
2025-02-21 10:05:11 +08:00
</view>
</view>
2025-01-03 16:50:09 +08:00
2025-02-21 10:05:11 +08:00
<view class="list-wrap">
2025-03-14 15:15:54 +08:00
<view class="cont-list" v-for="(food, foodIndex) in shoppingCartList">
<u-swipe-action>
<u-swipe-action-item :options="options" @click="delFood($event, food)">
<view style="width: 100%;display: flex;height: auto;">
<view>
<u-image :src="food.goodsDishesImgUrl" width="80px" height="80px" />
</view>
<view class="center-cont">
<view class="meal-name">{{ food.goodsDishesName }}</view>
<view class="sale-num">月销 {{ food.monthlySales||0 }}</view>
<view class="num-cont">
<span style="margin-right: 5px">{{ '库存' + food.surplusNum }}</span>
<span>{{ '限购' + food.restrictNum }}</span>
</view>
<view class="sale-price">
<span style="font-size: 11px"></span>
{{ (food.prefPrice/100).toFixed(2) }}
</view>
</view>
<view class="right-cont">
<view class="num-wrap" v-if="food.isDfficacy==1">
<view style="width: 26rpx;">
<u-icon
v-if="food.quantity > 0"
name="../../static/images/del.png"
size="16"
@click="handleFoodNum(1, food)"
/>
</view>
<span class="cont-num">{{ food.quantity || 0 }}</span>
<view style="width: 26rpx;">
<u-icon
v-if="food.quantity<food.restrictNum"
name="../../static/images/add2.png"
size="16"
@click="handleFoodNum(2, food)"
/>
</view>
</view>
<view v-if="food.isDfficacy==0" v-else>已失效</view>
</view>
</view>
</u-swipe-action-item>
</u-swipe-action>
</view>
2025-02-21 10:05:11 +08:00
</view>
</view>
2025-01-03 16:50:09 +08:00
</u-popup>
2025-01-03 18:14:29 +08:00
<u-modal :show="showModal" showCancelButton title="提示" @cancel="showModal = false" @confirm="clearCar">
2025-01-03 16:50:09 +08:00
<view class="slot-content" style="text-align: center">
<span>是否确认清空购物车?</span>
</view>
</u-modal>
2025-01-03 10:20:58 +08:00
</view>
</template>
<script>
2025-02-21 10:05:11 +08:00
import { getlistReserveDateAPI,getAdvanceDetailListAPI,addAdvancehoppingCartAPI,updateAdvancehoppingCartAPI,clearAdvancehoppingCartAPI,getShoppingCartListAPI } from '@/api/advanceOrder/index.js'
2025-02-19 09:34:34 +08:00
import Tabs from '@/pages/components/Tabs.vue'
2025-01-03 10:20:58 +08:00
export default {
2025-02-19 09:34:34 +08:00
components: { Tabs },
2025-01-03 10:20:58 +08:00
data() {
2025-03-14 15:15:54 +08:00
return {
showLoading:true,
2025-02-19 09:34:34 +08:00
newDate: '',
newDate2: '',
canteenId:"",
canteenName:"",
stallId:"",
stallName:"",
recipeId:"",
tabList:[],
menuData:[],
typeList:[],//菜品类型数据
typeNameList:[],
2025-03-14 15:15:54 +08:00
tIndex:0,
2025-02-19 09:34:34 +08:00
shoppingCartList:[],
// 总价格
totalPrice: 0,
showCar: false, // 购物车
showModal: false, // 清空购物车
// 添加的菜品
addFood: [],
2025-02-21 10:05:11 +08:00
options: [{
text: '删除',
style: {
backgroundColor: '#f56c6c'
}
}],
2025-03-14 15:15:54 +08:00
scrollLeftTop:0,//滚动位置
2025-01-03 10:20:58 +08:00
current: 0,
active: 1, // 1 自取 2 外卖
2025-02-19 09:34:34 +08:00
// canteenName: '宏源工业园/本周菜谱',
canteenType: '自取', // 1 自取 2 外卖
2025-01-03 10:20:58 +08:00
}
},
2025-02-19 09:34:34 +08:00
onLoad(options) {
this.canteenId = options.canteenId
this.canteenName = options.canteenName
options = JSON.parse(options.params)
// console.log(options)
this.stallId=options.stallId;
this.stallName=options.stallName;
this.recipeId=options.recipeId;
//获取预定日期
this.getReserveDate()
2025-02-21 10:05:11 +08:00
setTimeout(()=>{
//获取预定餐菜谱
this.getMenuListData()
2025-03-14 15:15:54 +08:00
},200)
2025-01-03 10:20:58 +08:00
},
methods: {
2025-02-19 09:34:34 +08:00
//获取预定日期
async getReserveDate(){
let param = {
"canteenId":this.canteenId,
"stallId":this.stallId
}
const res = await getlistReserveDateAPI(param)
this.getNowFormatDate(res.data[0])
2025-03-14 15:15:54 +08:00
this.getNowFormatDate2(res.data[0])
2025-02-19 09:34:34 +08:00
},
2025-01-03 10:20:58 +08:00
// 获取当前时间
2025-02-19 09:34:34 +08:00
getNowFormatDate(data) {
let date = new Date(data)
2025-01-03 10:20:58 +08:00
let year = date.getFullYear()
let month = (date.getMonth() + 1).toString().padStart(2, '0')
let day = date.getDate().toString().padStart(2, '0')
let week = date.getDay()
let weeks = ['日', '一', '二', '三', '四', '五', '六']
this.newDate = `${month}-${day} 星期${weeks[week]}`
},
2025-01-03 16:50:09 +08:00
// 当前时间 2025-01-03
2025-02-19 09:34:34 +08:00
getNowFormatDate2(data) {
let date = new Date(data)
2025-01-03 16:50:09 +08:00
let year = date.getFullYear()
let month = (date.getMonth() + 1).toString().padStart(2, '0')
let day = date.getDate().toString().padStart(2, '0')
this.newDate2 = `${year}-${month}-${day}`
},
2025-02-21 10:05:11 +08:00
2025-02-19 09:34:34 +08:00
// 获取菜谱
async getMenuListData() {
let param = {
"recipeId":this.recipeId,
2025-03-14 15:15:54 +08:00
"applyDate":this.newDate2,
2025-02-19 09:34:34 +08:00
}
const res = await getAdvanceDetailListAPI(param)
console.log(res, '预订餐菜谱')
if(res.code==200){
if(res.rows&&res.rows.length>0){
this.menuData = res.rows;
this.menuData.forEach(item => {
item.typeList.forEach(detail => {
detail.dishesList.forEach(food => {
this.$set(food, 'mealtimeType', item.mealtimeType)
2025-03-14 15:15:54 +08:00
this.$set(food, 'quantity', 0)
this.$set(food, 'monthlySales', food.dishesDetailList[0].monthlySales)
this.$set(food, 'goodProbability', food.dishesDetailList[0].goodProbability)
this.$set(food, 'surplusNum', food.dishesDetailList[0].surplusNum)
this.$set(food, 'restrictNum', food.dishesDetailList[0].restrictNum)
this.$set(food, 'dishesPrice', food.dishesDetailList[0].dishesPrice)
this.$set(food, 'prefPrice', food.dishesDetailList[0].prefPrice)
this.$set(food, 'dishesId', food.dishesDetailList[0].dishesId)
2025-02-19 09:34:34 +08:00
})
})
})
//获取购物车
this.getShoppingCartList()
this.tabList=[]
//处理数据
this.menuData.forEach(item=>{//渲染类型
this.tabList.push(this.handleRecipeType(item.mealtimeType))
})
this.changeTab(0)
}else{
this.menuData = [];
this.tabList=[];
this.typeList=[]
this.typeNameList=[]
2025-03-14 15:15:54 +08:00
this.tIndex=0
}
this.showLoading=false
2025-02-19 09:34:34 +08:00
}else{
uni.$u.toast(res.msg)
this.menuData = [];
this.tabList=[];
this.typeList=[]
this.typeNameList=[]
2025-03-14 15:15:54 +08:00
this.tIndex=0
this.showLoading=false
}
2025-02-19 09:34:34 +08:00
},
//菜品类型1-早餐 2-午餐 3-下午茶 4-晚餐 5-夜宵)
changeTab(index) {
this.typeList = this.menuData[index].typeList;
//左侧类别列表
this.typeNameList=[]
this.typeList.forEach(item=>{
2025-03-14 15:15:54 +08:00
this.typeNameList.push(item)
2025-02-19 09:34:34 +08:00
})
//右侧菜列表
2025-03-14 15:15:54 +08:00
this.tIndex=0;
2025-02-19 09:34:34 +08:00
},
//菜品类型(面点,粗粮,精品菜,卤菜...
2025-03-14 15:15:54 +08:00
changeModel(item,index){
this.tIndex=index;
var len = 0
if(index==0){
len=0
}else{
this.typeList.forEach((ite,i)=>{
console.log(i)
console.log(index)
if(i<index){
len = len+ite.dishesList.length
}
})
}
setTimeout(()=>{
uni.createSelectorQuery().in(this).select('#scroll'+item.typeId).boundingClientRect(res => {
console.log(res)
this.scrollLeftTop = 80 * len; // 设置滚动条距离左侧的距离
}).exec()
},100)
// this.dishesList = this.typeList[index].dishesList;
2025-02-19 09:34:34 +08:00
},
// 处理recipeType
2025-01-03 10:20:58 +08:00
handleRecipeType(type) {
if (type === 1) {
2025-02-19 09:34:34 +08:00
return '早餐'
2025-01-03 10:20:58 +08:00
} else if (type === 2) {
2025-02-19 09:34:34 +08:00
return '午餐'
2025-01-03 10:20:58 +08:00
} else if (type === 3) {
2025-02-19 09:34:34 +08:00
return '下午茶'
2025-01-03 10:20:58 +08:00
} else if (type === 4) {
2025-02-19 09:34:34 +08:00
return '晚餐'
}else if (type === 5) {
return '夜宵'
2025-01-03 10:20:58 +08:00
}
},
2025-02-21 10:05:11 +08:00
goMenuDetail(item){
uni.navigateTo({
url: `/pages/weeklyMenu/menuDetail?params=${JSON.stringify(item)}`
})
},
2025-02-19 09:34:34 +08:00
//获取预定购物车(订单)
async getShoppingCartList(){
let param = {
2025-03-14 15:15:54 +08:00
"orderType":"2",
2025-02-19 09:34:34 +08:00
"custId":uni.getStorageSync('custId'),
"canteenId":this.canteenId,
"stallId":this.stallId,
}
const res = await getShoppingCartListAPI(param)
console.log(res, '预订餐预定')
if(res.code==200){
this.shoppingCartList = res.data;
console.log(this.shoppingCartList)
2025-03-14 15:15:54 +08:00
console.log(this.menuData)
this.menuData.forEach(menuItem => {
menuItem.typeList.forEach(detail => {
detail.dishesList.forEach(food => {
this.$set(food, 'quantity', 0)
this.shoppingCartList.forEach(cartItem=>{
if(food.dishesId==cartItem.goodsDishesId){
2025-02-21 10:05:11 +08:00
let obj = {
"canteenId":this.canteenId,
"canteenName":this.canteenName,
"costModelList":food.costModelList,
"custId": uni.getStorageSync('custId'),
2025-03-14 15:15:54 +08:00
"detailId": food.detailId,
2025-02-21 10:05:11 +08:00
"detailType": food.detailType,
"extParam": null,
"goodsDishesId": cartItem.goodsDishesId,
"goodsDishesImgUrl": food.dishesImgUrl,
"goodsDishesName": cartItem.goodsDishesName,
"ifExpired": cartItem.ifExpired,
"inventoryId": cartItem.inventoryId,
"mealtimeName": cartItem.mealtimeName,
"mealtimeType": cartItem.mealtimeType,
"menuDetailId": cartItem.menuDetailId,
"menuId": cartItem.menuId,
// "orderDate": cartItem.orderDate,
2025-03-14 15:15:54 +08:00
"orderDate": cartItem.orderDate,
2025-02-21 10:05:11 +08:00
"orderType": cartItem.orderType,
"dishesDetailList":food.dishesDetailList,
"prefPrice": food.dishesDetailList[0].prefPrice,
"quantity": cartItem.quantity,
2025-03-14 15:15:54 +08:00
"restrictNum": food.dishesDetailList[0].restrictNum,
2025-02-21 10:05:11 +08:00
"salePrice": cartItem.salePrice,
"salesMode": cartItem.salesMode,
"shoppingCartId": cartItem.shoppingCartId,
"sizeJson": cartItem.sizeJson,
"sizeName": cartItem.sizeName,
"sizeType": cartItem.sizeType,
"stallId": this.stallId,
"stallName": this.stallName,
"surplusNum": cartItem.surplusNum,
"unitName": null,
"weightUnit": null
}
2025-03-14 15:15:54 +08:00
this.$set(cartItem, 'orderDetailList', [obj])
this.$set(cartItem, 'goodsDishesImgUrl', food.dishesImgUrl)
this.$set(cartItem, 'monthlySales', food.dishesDetailList[0].monthlySales)
this.$set(cartItem, 'detailId', food.detailId)
this.$set(cartItem, 'detailType', food.detailType)
this.$set(cartItem, 'dishesId', food.dishesDetailList[0].dishesId)
this.$set(cartItem, 'surplusNum', food.dishesDetailList[0].surplusNum)
this.$set(cartItem, 'restrictNum', food.dishesDetailList[0].restrictNum)
this.$set(cartItem, 'prefPrice', food.dishesDetailList[0].prefPrice)
if(cartItem.orderDate == this.newDate2){//存在且时间一致
this.$set(food, 'quantity', cartItem.quantity)
this.$set(cartItem,'isDfficacy', 1) //有效
}else{//日期不一致
this.$set(food, 'quantity', 0)
this.$set(cartItem,'isDfficacy', 0) //失效
}
2025-02-19 09:34:34 +08:00
}
})
2025-03-14 15:15:54 +08:00
})
2025-02-19 09:34:34 +08:00
})
2025-03-14 15:15:54 +08:00
})
console.log(this.shoppingCartList)
2025-02-19 09:34:34 +08:00
//计算总价
this.handleTotalPrice()
}else{
this.shoppingCartList = []
}
},
//菜谱加减操作
2025-01-03 16:50:09 +08:00
handleFoodNum(type, food) {
2025-03-14 15:15:54 +08:00
console.log(food)
2025-01-03 16:50:09 +08:00
if (type === 1) {
2025-03-14 15:15:54 +08:00
if (food.quantity > 0) {
food.quantity--
2025-02-19 09:34:34 +08:00
this.delShopCart(food)
2025-01-03 16:50:09 +08:00
}
} else {
2025-03-14 15:15:54 +08:00
if (food.quantity < food.restrictNum) {
2025-02-19 09:34:34 +08:00
this.addShopCart(food)
2025-03-14 15:15:54 +08:00
}
2025-01-03 16:50:09 +08:00
}
},
2025-02-19 09:34:34 +08:00
async addShopCart(item){
2025-03-14 15:15:54 +08:00
console.log('🚀 ~ handleFoodNum ~ type', "新增")
2025-02-19 09:34:34 +08:00
console.log(item)
let param = {
"custId":uni.getStorageSync('custId'),
2025-03-14 15:15:54 +08:00
"orderType": 2,
"orderDate":this.newDate2,
2025-02-19 09:34:34 +08:00
"canteenId":this.canteenId,
2025-03-14 15:15:54 +08:00
"stallId":this.stallId,
"mealtimeType":item.mealtimeType,
"menuId":this.recipeId,
"goodsDishesId":item.dishesId,
"goodsDishesName":item.goodsDishesName||item.dishesName,
"detailId":item.detailId,
"detailType":item.detailType,
2025-02-19 09:34:34 +08:00
"quantity":1,
}
2025-03-14 15:15:54 +08:00
console.log(param)
2025-02-19 09:34:34 +08:00
const res = await addAdvancehoppingCartAPI(param)
if(res.code==200){
this.getShoppingCartList()
2025-03-14 15:15:54 +08:00
// this.getMenuListData()
2025-02-19 09:34:34 +08:00
}
console.log(res, '添加')
},
async delShopCart(item){
2025-03-14 15:15:54 +08:00
console.log('🚀 ~ handleFoodNum ~ type', "减少")
2025-02-19 09:34:34 +08:00
console.log(item)
let param = {
"custId":uni.getStorageSync('custId'),
"shoppingCartId":'',
2025-03-14 15:15:54 +08:00
"quantity":item.quantity
}
2025-02-19 09:34:34 +08:00
this.shoppingCartList.forEach(cartItem=>{
2025-03-14 15:15:54 +08:00
if(item.dishesId==cartItem.goodsDishesId){
2025-02-19 09:34:34 +08:00
param.shoppingCartId=cartItem.shoppingCartId
}
})
console.log(param)
const res = await updateAdvancehoppingCartAPI(param)
if(res.code==200){
this.getShoppingCartList()
2025-03-14 15:15:54 +08:00
// this.getMenuListData()
2025-02-19 09:34:34 +08:00
}
},
2025-03-14 15:15:54 +08:00
//购物车滑动删除按钮
async delFood(e,item){
let param = {
"custId":uni.getStorageSync('custId'),
"shoppingCartId":item.shoppingCartId,
"quantity":0
}
console.log(param)
const res = await updateAdvancehoppingCartAPI(param)
if(res.code==200){
this.getShoppingCartList()
}
},
//购物车-清空按钮
2025-02-21 10:05:11 +08:00
clearCar(){
let arr = []
this.shoppingCartList.forEach(cartItem=>{
arr.push(cartItem.shoppingCartId)
})
try {
let param = {
"custId":uni.getStorageSync('custId'),
"shoppingCartIds":arr,
}
console.log(param)
clearAdvancehoppingCartAPI(param).then(res => {
if(res.code==200){
console.log(res)
this.menuData.forEach(menuItem => {
menuItem.typeList.forEach(detail => {
detail.dishesList.forEach(food => {
2025-03-14 15:15:54 +08:00
this.$set(food, 'quantity', 0)
2025-02-21 10:05:11 +08:00
})
})
})
this.getShoppingCartList()
this.showModal = false
}else{
this.getShoppingCartList()
this.showModal = false
}
})
} catch (error) {
console.log(error)
}
},
// 打开购物车
2025-01-03 16:50:09 +08:00
openCar() {
2025-03-14 15:15:54 +08:00
// if (this.totalPrice == 0) return
2025-01-03 16:50:09 +08:00
this.showCar = true
},
// 计算总价格与添加的菜品-购物车-每次添加删减菜品都得计算
handleTotalPrice() {
2025-03-14 15:15:54 +08:00
let total = 0
this.shoppingCartList.forEach(item => {
total +=item.quantity *(item.prefPrice/100).toFixed(2)
})
2025-02-21 10:05:11 +08:00
this.totalPrice = total.toFixed(2)
2025-03-14 15:15:54 +08:00
if (this.shoppingCartList.length == 0) this.showCar = false
2025-01-03 16:50:09 +08:00
},
2025-02-21 10:05:11 +08:00
2025-01-10 17:39:14 +08:00
// 订单结算
handleOrder() {
console.log('结算')
2025-03-14 15:15:54 +08:00
// 购物车为空 不可结算
console.log(this.shoppingCartList)
let arr = []
this.shoppingCartList.forEach(item=>{
if(item.isDfficacy == 1){//有效
arr.push(item)
}
})
if (arr.length == 0) {
uni.showToast({
title: '请添加菜品',
icon: 'none'
})
return
}
console.log(arr)
2025-01-10 17:39:14 +08:00
uni.navigateTo({
2025-03-14 15:15:54 +08:00
url: `/pages/advanceOrder/orderDetails?carList=${JSON.stringify(arr)}&canteenId=${this.canteenId}&stallId=${this.stallId}&canteenName=${this.canteenName}&stallName=${this.stallName}&totalPrice=${this.totalPrice}&orderDate=${this.newDate2}`
2025-01-10 17:39:14 +08:00
})
2025-02-19 09:34:34 +08:00
},
//垂直定位锚点
scrollToDetail(index) {
console.log('🚀 ~ scrollToDetail ~ index', index)
if (this.current != 0 && this.current == index) return
this.current = index
this.$nextTick(() => {
const query = uni.createSelectorQuery().in(this)
query
.select(`#detail-${index}`)
.boundingClientRect(rect => {
console.log('🚀 ~ scrollToDetail ~ rect', rect)
if (rect) {
setTimeout(() => {
console.log('🚀 ~ scrollToDetail ~ rect.top', rect.top)
uni.pageScrollTo({
scrollTop: rect.top - 55,
duration: 300
})
}, 100)
}
})
.exec()
})
},
2025-01-03 10:20:58 +08:00
}
}
</script>
<style lang="scss" scoped>
2025-01-03 16:50:09 +08:00
::v-deep .u-transition {
z-index: 10090 !important;
}
2025-01-03 10:20:58 +08:00
page {
background: #f9fbff;
2025-01-03 12:15:58 +08:00
position: relative;
2025-01-03 10:20:58 +08:00
}
2025-02-19 09:34:34 +08:00
.scroll-view {
white-space: nowrap;
width: 100%;
}
.scroll-view-item {
display: inline-block;
width: 160rpx;
height: 100rpx;
// line-height: 100rpx;
text-align: center;
color: #959FA4;
.activeLine{
background: #DD7D3C;
border-radius: 10upx;
width: 100rpx;
height: 6upx;
}
}
.active {
color: #DD7D3C;
font-weight: bolder;
font-size: 32rpx;
}
.tab-navigation {
display: flex;
background-color: white;
padding: 0px 16px 0 16px;
}
.menuContent{
width: 100%;
display: flex;
height: 74vh;
// background-color: #DD7D3C;
}
.content-left{
width: 20%;
height: 74vh;
}
.active2 {
color: #DD7D3C;
font-weight: bolder;
font-size: 26rpx;
}
.content-right{
width: 80%;
height: 74vh;
2025-03-14 15:15:54 +08:00
// height: auto !important;
2025-02-19 09:34:34 +08:00
}
.scroll-right-item{
width: 100%;
height: auto;
2025-03-14 15:15:54 +08:00
margin-bottom: 20rpx;
2025-02-19 09:34:34 +08:00
// background-color: #959FA4;
}
.image {
width: 160rpx;
height: 160rpx;
border-radius: 10rpx;
}
2025-01-03 18:14:29 +08:00
.top-wrap {
2025-02-19 09:34:34 +08:00
// position: fixed;
// top: 0;
// width: 100vw;
// z-index: 999;
2025-01-03 18:14:29 +08:00
}
2025-01-03 10:20:58 +08:00
.top-cont {
2025-01-03 12:15:58 +08:00
height: 55px;
padding: 0 16px;
2025-01-03 10:20:58 +08:00
background: #fff;
.top-right-cont {
background: rgba(15, 39, 75, 0.05);
border-radius: 11px 11px 11px 11px;
display: flex;
justify-content: space-around;
color: #0f274b;
font-size: 12px;
.right-item {
padding: 3px 10px;
border-radius: 11px 11px 11px 11px;
cursor: pointer;
&.active {
background: linear-gradient(180deg, #ffae82 0%, #ff6816 100%);
color: #fff;
}
}
}
}
2025-01-03 12:15:58 +08:00
.footer-cont {
2025-01-03 18:14:29 +08:00
/* height: calc(100vh - 115px); */
2025-01-03 12:15:58 +08:00
overflow: auto;
}
.left-wrap {
position: fixed;
2025-02-19 09:34:34 +08:00
// top: 55px;
2025-01-03 12:15:58 +08:00
height: calc(100vh - 115px);
overflow: auto;
2025-01-03 10:20:58 +08:00
.left-balance {
width: 88px;
height: 44px;
display: flex;
justify-content: center;
align-items: center;
font-weight: 500;
font-size: 14px;
color: #0f274b;
&.active {
background: #fff;
}
}
2025-01-03 12:15:58 +08:00
}
.right-wrap {
margin-left: 88px;
width: calc(100vw - 88px);
overflow: auto;
2025-01-03 10:20:58 +08:00
.right-balance {
padding: 0 8px;
background-color: #fff;
.top-name {
height: 44px;
font-weight: 400;
font-size: 12px;
color: rgba(15, 39, 75, 0.6);
display: flex;
align-items: center;
}
2025-01-03 16:50:09 +08:00
}
}
.cont-list {
2025-02-21 10:05:11 +08:00
// display: flex;
2025-01-03 16:50:09 +08:00
padding: 8px;
2025-02-21 10:05:11 +08:00
// position: relative;
2025-01-03 16:50:09 +08:00
/* border-bottom: 1px solid #f0f0f0; */
2025-02-19 09:34:34 +08:00
}
.center-cont {
2025-01-03 16:50:09 +08:00
display: flex;
flex-direction: column;
justify-content: space-between;
margin-left: 8px;
.meal-name {
font-weight: 500;
font-size: 14px;
color: #0f274b;
}
.sale-num {
font-weight: 400;
font-size: 12px;
color: rgba(15, 39, 75, 0.6);
line-height: 14px;
}
.num-cont {
display: flex;
align-items: center;
font-size: 10px;
color: #ff6816;
span {
border: 1px solid #ff6816;
padding: 0 2px;
border-radius: 2px;
}
}
.sale-price {
font-size: 16px;
2025-02-19 09:34:34 +08:00
font-weight: bold;
color: #ff6816;
2025-01-03 16:50:09 +08:00
}
2025-02-19 09:34:34 +08:00
}
.right-cont {
2025-01-03 16:50:09 +08:00
position: absolute;
right: 8px;
bottom: 8px;
display: flex;
align-items: center;
span {
font-weight: 400;
font-size: 12px;
color: #0f274b;
}
.num-wrap {
padding: 0 4px;
2025-01-03 12:15:58 +08:00
display: flex;
2025-01-03 16:50:09 +08:00
justify-content: space-between;
align-items: center;
width: 63px;
height: 20px;
border-radius: 13px 13px 13px 13px;
border: 1px solid rgba(15, 39, 75, 0.2);
.cont-num {
width: 20px;
height: 20px;
display: flex;
justify-content: center;
align-items: center;
font-size: 12px;
color: #0f274b;
// 第二个展示左右边框
&:nth-child(2) {
border-left: 1px solid rgba(15, 39, 75, 0.2);
border-right: 1px solid rgba(15, 39, 75, 0.2);
}
}
2025-01-03 12:15:58 +08:00
}
2025-01-03 10:20:58 +08:00
}
2025-01-03 16:50:09 +08:00
.shop-car {
height: 60px;
background: #fff;
box-shadow: 0px -1px 4px 0px rgba(0, 102, 204, 0.1);
position: fixed;
bottom: 0;
left: 0;
width: 100%;
z-index: 9999999;
.car-cont {
margin: 15px 20px 0;
display: flex;
justify-content: space-between;
align-items: center;
.money {
margin-left: 8px;
font-weight: 600;
font-size: 18px;
color: #0f274b;
}
}
}
.popup-cont {
height: 330px;
padding: 16px;
color: #0f274b;
.name-type {
margin-left: 5px;
font-weight: 400;
font-size: 10px;
color: #fff;
padding: 2px 7px;
background: linear-gradient(180deg, #ffae82 0%, #ff6816 100%);
border-radius: 11px 11px 11px 11px;
}
}
.list-wrap {
2025-03-14 15:15:54 +08:00
height: 240px;
padding-bottom: 160rpx;
2025-01-03 16:50:09 +08:00
overflow: auto;
}
2025-03-14 15:15:54 +08:00
.wait-btn {
width: 160rpx;
height: 50rpx;
line-height: 50rpx;
position: absolute;
top: 50%;
left: 50%;
margin-left: -80rpx;
margin-top: -25rpx;
text-align: center;
color: #fff;
font-size: 28rpx;
font-weight: bold;
}
2025-01-03 10:20:58 +08:00
</style>