deming/pageC/cart/ConfirmOrder.vue

706 lines
19 KiB
Vue
Raw Normal View History

2020-06-09 09:33:12 +00:00
<template>
<view class="order">
2020-07-30 12:33:16 +00:00
<view class="info-address" @click="changeAddress" v-if="JSON.stringify(addressInfo) != '{}'">
2020-06-09 09:33:12 +00:00
<image src="../static/image/2.png" class="address-icon"></image>
<view class="address">
<view class="user-info">
2020-07-06 09:32:29 +00:00
<view>{{ addressInfo.address_realname }}</view>
<view>{{ addressInfo.address_mob_phone }}</view>
2020-06-09 09:33:12 +00:00
</view>
2020-07-06 09:32:29 +00:00
<view class="address-text u-line-2">{{ addressInfo.area_info + addressInfo.address_detail }}</view>
2020-06-09 09:33:12 +00:00
</view>
<image src="../static/image/1.png" class="right"></image>
</view>
2020-07-30 12:33:16 +00:00
<view v-else class="address-none" @click="changeAddress">请选择地址</view>
2020-06-09 09:33:12 +00:00
<view class="main">
2020-06-30 10:06:50 +00:00
<view v-for="(item, index) in orderInfo.store_cart_list" :key="index">
<view class="goods-info">
<view class="store">
2020-08-04 11:08:04 +00:00
<image class="avatar" :src="orderInfo.store_list[index].store_avatar"></image>
2020-06-30 10:06:50 +00:00
<view>{{ item[0].store_name }}</view>
<image src="../static/image/1.png" class="right"></image>
</view>
<view class="goods">
<view v-for="(goods, g_index) in item" :key="g_index" class="goods-item">
<image :src="goods.goods_image_url"></image>
<view class="info">
<view class="name u-line-2">{{ goods.goods_name }}</view>
<view class="cart-info">
2020-08-18 00:52:47 +00:00
<view class="price">{{ goods.goods_price }}</view>
2020-07-14 09:43:15 +00:00
<view>×{{ goods.goods_num }}</view>
2020-06-30 10:06:50 +00:00
</view>
2020-06-09 09:33:12 +00:00
</view>
</view>
</view>
</view>
2020-06-30 10:06:50 +00:00
<view class="order-info">
2020-07-23 06:56:20 +00:00
<view @click="showCoupon({type: 2, store_id: item[0].store_id})" v-if="orderType == 1 || orderType == 5">
2020-06-30 10:06:50 +00:00
<view class="title">优惠券折扣</view>
<view class="value">
2020-07-23 06:56:20 +00:00
<view>-{{ storeCoupon[item[0].store_id] ? storeCoupon[item[0].store_id].voucher_price.toFixed(2) : '0.00' }}</view>
2020-06-30 10:06:50 +00:00
<image src="../static/image/1.png"></image>
</view>
2020-06-09 09:33:12 +00:00
</view>
2020-07-16 09:39:06 +00:00
<view>
<view class="title">运费</view>
2020-06-30 10:06:50 +00:00
<view class="value">
2020-07-16 09:39:06 +00:00
<view v-if="freight">{{ freight | setFreight(index) }}</view>
2020-06-30 10:06:50 +00:00
</view>
2020-07-16 09:39:06 +00:00
</view>
2020-07-14 01:15:51 +00:00
</view>
2020-09-01 07:00:36 +00:00
<view class="pick-up" v-if="is_selfraising == 1">
<view class="title">自提地址</view>
<view class="content">{{ orderInfo.store_list[index].store_address }}</view>
</view>
2020-07-14 01:15:51 +00:00
</view>
</view>
<view class="common-active">
2020-07-23 06:56:20 +00:00
<view @click="showCoupon({type: 1})" v-if="orderType == 1 || orderType == 5">
2020-07-14 01:15:51 +00:00
<view class="title">平台优惠券</view>
<view class="value">
2020-07-23 06:56:20 +00:00
<view>-{{ choiceCoupon.vouchertemplate_id ? choiceCoupon.voucher_price.toFixed(2) : '0.00' }}</view>
2020-07-14 01:15:51 +00:00
<image src="../static/image/1.png"></image>
</view>
</view>
2020-07-16 09:39:06 +00:00
<view @click="showDelivery=true">
2020-07-14 01:15:51 +00:00
<view class="title">配送方式</view>
<view class="value">
2020-07-16 09:39:06 +00:00
<view>{{ delivery.text }}</view>
2020-07-14 01:15:51 +00:00
<image src="../static/image/1.png"></image>
2020-06-09 09:33:12 +00:00
</view>
</view>
</view>
2020-07-18 09:43:37 +00:00
<u-popup v-model="couponStatus" mode="bottom">
2020-08-21 03:18:01 +00:00
<scroll-view class="coupon-choose" scroll-y style="height: 50vh;" v-if="this.couponType.type == 1">
2020-07-18 09:43:37 +00:00
<view class="title">优惠券详情</view>
2020-07-27 09:59:47 +00:00
<view class="text">平台优惠券</view>
2020-08-22 08:45:26 +00:00
<Coupon :couponInfo="coupon" @use="useCoupon($event)" :goodsClass="goodsClass" v-for="(coupon, index) in orderInfo.store_voucher_all_list" :key="index" :type="true" :sel="coupon.sel"></Coupon>
2020-08-21 03:18:01 +00:00
<u-empty text="无可用优惠券" mode="coupon" v-if="!orderInfo.store_voucher_all_list.length" style="height: 200rpx"></u-empty>
2020-07-23 06:56:20 +00:00
</scroll-view>
2020-08-21 03:18:01 +00:00
<scroll-view class="coupon-choose" scroll-y style="height: 50vh;" v-if="this.couponType.type == 2">
2020-07-23 06:56:20 +00:00
<view class="title">优惠券详情</view>
2020-07-27 09:59:47 +00:00
<view class="text">店铺优惠券</view>
2020-08-22 08:45:26 +00:00
<Coupon :couponInfo="coupon" @use="useCoupon($event)" :goodsClass="goodsClass" v-for="(coupon, index) in orderInfo.store_voucher_list[this.couponType.store_id]" :key="index" :type="true" :sel="coupon.sel"></Coupon>
2020-08-21 03:18:01 +00:00
<u-empty text="无可用优惠券" mode="coupon" v-if="!orderInfo.store_voucher_list[this.couponType.store_id].length" style="height: 200rpx"></u-empty>
2020-07-18 09:43:37 +00:00
</scroll-view>
</u-popup>
2020-06-10 08:06:01 +00:00
<view class="bottom">
<view class="left">
<view class="title">合计</view>
2020-07-16 09:39:06 +00:00
<view class="price">{{ totalPrice }}</view>
2020-06-10 08:06:01 +00:00
</view>
<view class="right">
2020-07-14 01:15:51 +00:00
<view class="num">共件{{ orderInfo.store_cart_list | setTotalNumber }}商品</view>
2020-07-22 10:51:48 +00:00
<view class="btn" @click="intermediate">结算</view>
2020-06-10 08:06:01 +00:00
</view>
</view>
2020-07-16 09:39:06 +00:00
<u-action-sheet :list="deliveryList" @click="setDelivery" border-radius="10" v-model="showDelivery"></u-action-sheet>
2020-06-09 09:33:12 +00:00
</view>
</template>
<script>
2020-07-20 09:17:41 +00:00
import Coupon from "@/components/mine/coupon/mine";
2020-06-09 09:33:12 +00:00
export default {
data() {
2020-06-30 10:06:50 +00:00
return {
2020-07-16 09:39:06 +00:00
showDelivery: false,
2020-06-30 10:06:50 +00:00
orderInfo: {},
totalPrice: '0.00',
2020-07-06 09:32:29 +00:00
addressInfo: {},
2020-07-16 09:39:06 +00:00
freight: {}, // 运费
isTakeawayer: '', // 是否支持骑手
deliveryList: [{
text: '快递',
value: 'express',
2020-09-01 02:39:59 +00:00
disabled: false,
2020-07-16 09:39:06 +00:00
}, {
text: '骑手',
value: 'takeawayer',
2020-09-01 02:39:59 +00:00
disabled: false,
}, {
text: '自提',
value: 'selfraising',
disabled: false,
2020-07-16 09:39:06 +00:00
}],
delivery: {
text: '快递',
value: 'express',
}, // 配送方式
2020-07-18 09:43:37 +00:00
couponList: [],
couponStatus: false,
2020-07-23 06:56:20 +00:00
couponType: {}, // 选择的优惠券
storeCoupon: {}, // 选中的店铺优惠券
2020-07-18 09:43:37 +00:00
choiceCoupon: {}, // 使用的平台优惠券
2020-07-20 09:17:41 +00:00
goodsClass: [],
2020-07-22 10:51:48 +00:00
orderType: '', // 订单类型 1 普通订单 2 拼团订单 3 秒杀订单 4 优惠券 5 购物车订单
2020-08-03 10:38:04 +00:00
debounce: true,
2020-09-01 02:39:59 +00:00
is_selfraising: 0, // 是否自提0=》否1=》是
2020-06-30 10:06:50 +00:00
}
},
2020-07-18 09:43:37 +00:00
components: {
Coupon
},
2020-06-30 10:06:50 +00:00
filters: {
2020-07-14 01:15:51 +00:00
setTotalNumber(data) {
let num = 0;
for (const key in data) {
if (data.hasOwnProperty(key)) {
2020-07-14 09:43:15 +00:00
const element = data[key];
element.forEach(item => {
num += item.goods_num;
})
2020-07-14 01:15:51 +00:00
}
}
return num;
},
2020-07-16 09:39:06 +00:00
setFreight(freight, index) {
2020-08-20 08:54:39 +00:00
return freight[index] || '0.00';
2020-07-16 09:39:06 +00:00
}
2020-06-30 10:06:50 +00:00
},
onLoad(option) {
2020-07-21 13:02:28 +00:00
this.orderType = this.$store.state.orderType;
this.orderInfo = this.$store.state.orderInfo;
2020-09-01 02:39:59 +00:00
// 判断是否可选自提
if(!this.orderInfo.is_selfraising) this.deliveryList[2].disabled = true;
2020-08-11 07:38:43 +00:00
// console.log('orderType' + this.orderType);
2020-07-30 12:33:16 +00:00
// console.log(this.orderInfo);
2020-07-23 06:56:20 +00:00
this.getGoodsClass();
2020-07-30 12:33:16 +00:00
this.setTotalPrice();
2020-07-16 09:39:06 +00:00
},
onShow() {
2020-08-03 10:38:04 +00:00
this.debounce = true;
2020-07-27 09:59:47 +00:00
this.storeCoupon = {};
this.choiceCoupon = {};
2020-07-16 09:39:06 +00:00
// 判断是不是从选择地址页面返回
if(JSON.stringify(this.$store.state.orderAddress) == '{}') {
2020-07-30 12:33:16 +00:00
if(this.orderInfo.address_info) this.$store.commit('updateAddress', this.orderInfo.address_info);
2020-07-16 09:39:06 +00:00
} else {
2020-07-30 12:33:16 +00:00
if(this.$store.getters.getOrderAddress) this.addressInfo = this.$store.state.orderAddress;
2020-07-16 09:39:06 +00:00
}
},
beforeDestroy() {
this.$store.commit('updateAddress', {});
},
watch: {
'$store.state.orderAddress'(value) {
this.addressInfo = value;
2020-07-30 12:33:16 +00:00
if(JSON.stringify(value) != '{}') this.getFreight();
2020-07-23 06:56:20 +00:00
},
2020-06-10 08:06:01 +00:00
},
methods: {
2020-07-22 10:51:48 +00:00
// 如果有pintuangroup_headid为参团不然为开团
async withImmediate(type) {
let params = {
pintuan_id: this.orderInfo.pintuan_id,
}
2020-08-06 09:52:25 +00:00
// console.log(this.orderInfo);
// console.log(this.$store.state.pintuangroup_headid);
2020-07-22 10:51:48 +00:00
if(this.orderInfo.pintuangroup_id) {
2020-09-01 02:39:59 +00:00
Object.assign(params, {
pintuangroup_headid: this.$store.state.pintuangroup_headid,
pintuangroup_id: this.orderInfo.pintuangroup_id
});
2020-07-22 10:51:48 +00:00
}
2020-08-06 09:52:25 +00:00
console.log(params);
2020-07-22 10:51:48 +00:00
this.$u.api.withImmediate(params).then(res => {
this.showGroupUser = false;
this.showInvolvementUser = false;
if(res.errCode == 0) {
this.sendOrder(0);
} else {
2020-08-03 10:38:04 +00:00
this.debounce = true;
2020-07-22 10:51:48 +00:00
this.$u.toast(res.message);
}
})
},
intermediate() {
2020-08-03 10:38:04 +00:00
if(!this.debounce) return;
this.debounce = false;
2020-07-24 11:48:57 +00:00
if(this.orderType == 2) {
this.withImmediate();
} else if(this.orderType == 1) {
this.sendOrder(0);
2020-08-11 01:46:05 +00:00
} else if(this.orderType == 3) {
this.sendOrder(0);
2020-08-05 09:38:11 +00:00
} else {
this.sendOrder(1);
2020-07-24 11:48:57 +00:00
}
2020-07-22 10:51:48 +00:00
},
2020-07-24 11:48:57 +00:00
// @params {Number} ifcart 是否是购物车商品
2020-07-22 10:51:48 +00:00
sendOrder(ifcart) {
2020-07-14 09:43:15 +00:00
// 拼接后端需要的数据形式
let id = [], temp = '';
const object = this.orderInfo.store_cart_list;
for (const key in object) {
if (object.hasOwnProperty(key)) {
const element = object[key];
element.forEach(item => {
temp = item.cart_id + '|' + item.goods_num;
id.push(temp);
temp = '';
})
}
}
2020-07-23 06:56:20 +00:00
// 拼接优惠券
let coupon = [];
for (const key in this.storeCoupon) {
if (this.storeCoupon.hasOwnProperty(key)) {
const element = this.storeCoupon[key];
temp = key + '|' + element.voucher_id;
coupon.push(temp);
temp = '';
}
}
// 平台券store_id写0
if(JSON.stringify(this.choiceCoupon) != '{}') {
coupon.push(0 + '|' + this.choiceCoupon.voucher_id)
}
2020-07-30 12:33:16 +00:00
// 验证是否选择地址
if(!this.addressInfo || JSON.stringify(this.addressInfo) == '{}') {
this.$u.toast('收货地址不能为空');
return false;
}
2020-07-21 13:02:28 +00:00
let params = {
2020-07-22 10:51:48 +00:00
ifcart: ifcart,
2020-07-14 09:43:15 +00:00
cart_id: id,
address_id: this.addressInfo.address_id,
2020-07-14 02:13:27 +00:00
buy_city_id: this.addressInfo.city_id,
2020-09-01 02:39:59 +00:00
is_selfraising: this.is_selfraising,
2020-07-21 13:02:28 +00:00
}
2020-07-24 11:48:57 +00:00
if(coupon.length) Object.assign(params, { voucher_id: coupon });
2020-07-22 10:51:48 +00:00
if(this.orderType == 2) {
2020-07-24 11:48:57 +00:00
Object.assign(params, { pintuan_id: this.orderInfo.pintuan_id });
if(this.orderInfo.pintuangroup_id) Object.assign(params, { pintuangroup_id: this.orderInfo.pintuangroup_id });
2020-07-22 10:51:48 +00:00
}
2020-07-23 06:56:20 +00:00
// console.log(params);
2020-07-21 13:02:28 +00:00
this.$u.api.sendOrder(params).then(res => {
2020-07-14 09:43:15 +00:00
if(res.errCode == 0) {
this.$u.route({
2020-07-27 09:59:47 +00:00
type: 'redirect',
2020-07-14 09:43:15 +00:00
url: '/pageC/cart/cashier',
params: {
2020-09-01 02:43:32 +00:00
ifcart: ifcart,
2020-07-14 09:43:15 +00:00
pay_sn: res.data.pay_sn,
price: res.data.order_total_amount,
2020-09-01 02:39:59 +00:00
order_id: res.data.order_list[0].order_id,
2020-07-14 09:43:15 +00:00
}
})
2020-07-22 10:51:48 +00:00
} else {
2020-08-03 10:38:04 +00:00
this.debounce = true;
2020-07-22 10:51:48 +00:00
this.$u.toast(res.message);
2020-07-14 09:43:15 +00:00
}
2020-07-14 02:13:27 +00:00
})
2020-07-06 09:32:29 +00:00
},
2020-07-23 06:56:20 +00:00
showCoupon({ type, store_id = -1 } = {}) {
this.couponType = {
2020-07-18 09:43:37 +00:00
type: type,
2020-07-23 06:56:20 +00:00
store_id: store_id
2020-07-20 09:17:41 +00:00
}
2020-07-23 06:56:20 +00:00
this.couponStatus = true;
2020-07-18 09:43:37 +00:00
},
useCoupon(coupon) {
2020-09-01 02:39:59 +00:00
// console.log(coupon)
2020-08-22 08:45:26 +00:00
if(this.couponType.type == 1){
this.choiceCoupon = {}
for(let i in this.orderInfo.store_voucher_all_list){
if(this.orderInfo.store_voucher_all_list[i].voucher_id == coupon.voucher_id && !this.orderInfo.store_voucher_all_list[i].sel){
this.orderInfo.store_voucher_all_list[i].sel = true
this.choiceCoupon = coupon;
}else{
this.orderInfo.store_voucher_all_list[i].sel = false
}
}
this.$forceUpdate()
}
2020-07-23 06:56:20 +00:00
if(this.couponType.type == 2) {
2020-08-22 08:45:26 +00:00
this.storeCoupon = {}
for(let i in this.orderInfo.store_voucher_list[this.couponType.store_id]){
console.log(this.orderInfo.store_voucher_list[this.couponType.store_id][i])
if(this.orderInfo.store_voucher_list[this.couponType.store_id][i].voucher_id == coupon.voucher_id && !this.orderInfo.store_voucher_list[this.couponType.store_id][i].sel){
this.orderInfo.store_voucher_list[this.couponType.store_id][i].sel = true
Object.assign(this.storeCoupon, {
[this.couponType.store_id]: coupon
})
}else{
this.orderInfo.store_voucher_list[this.couponType.store_id][i].sel = false
}
}
this.$forceUpdate()
2020-07-23 06:56:20 +00:00
}
// console.log(this.choiceCoupon);
// console.log(this.storeCoupon);
2020-08-22 08:45:26 +00:00
// this.couponStatus = false;
2020-07-23 06:56:20 +00:00
this.setTotalPrice(); // 计算总价
2020-07-18 09:43:37 +00:00
},
2020-07-06 09:32:29 +00:00
getFreight() {
this.$u.api.getFreight({
freight_hash: this.orderInfo.freight_hash,
city_id: this.addressInfo.city_id,
area_id: this.addressInfo.area_id,
2020-07-16 09:39:06 +00:00
delivery: this.delivery.value,
2020-07-06 09:32:29 +00:00
}).then(res => {
if(res.errCode == 0) {
2020-07-16 09:39:06 +00:00
this.freight = res.data.content;
this.isTakeawayer = res.data.delivery.takeawayer;
this.setTotalPrice(); // 计算总价
2020-07-06 09:32:29 +00:00
}
})
2020-06-30 10:06:50 +00:00
},
2020-07-23 06:56:20 +00:00
setTotalPrice() {
2020-07-16 09:39:06 +00:00
const goods = this.orderInfo.store_goods_total;
2020-08-20 03:41:58 +00:00
let [freight, price, minPrice] = [0, 0, 0];
// 运费
2020-09-01 02:39:59 +00:00
for(const key in this.freight) {
if(this.freight.hasOwnProperty(key)) {
const element = this.freight[key];
freight += Number(element);
2020-07-16 09:39:06 +00:00
}
}
// 商品价格减去优惠券
2020-07-23 06:56:20 +00:00
// 店铺
2020-09-01 02:39:59 +00:00
for(const gid in goods) {
if(goods.hasOwnProperty(gid)) {
// 计算最小价格
minPrice += 0.01;
// 每个店铺所有商品的价格
let sprice = Number(goods[gid]);
if(JSON.stringify(this.storeCoupon) != '{}') {
2020-09-01 02:39:59 +00:00
for(const cid in this.storeCoupon) {
if(this.storeCoupon.hasOwnProperty(cid)) {
const cprice = this.storeCoupon[cid];
// 商品减去优惠券价格
if(gid == cid) {
sprice -= cprice.voucher_price;
// 每个店铺最低付款 0.01
if(sprice <= 0) sprice = 0.01;
}
}
}
2020-07-23 06:56:20 +00:00
}
// 所有商品总价
price += sprice;
2020-07-23 06:56:20 +00:00
}
}
// 平台
if(JSON.stringify(this.choiceCoupon) != '{}') price -= Number(this.choiceCoupon.voucher_price);
// 每个店铺最低付款 0.01
if(price <= minPrice) price = minPrice;
2020-08-20 03:42:52 +00:00
// console.log("minPrice" + minPrice);
// console.log("freight:" + freight);
// console.log("price:" + price);
this.totalPrice = (price + freight).toFixed(2);
2020-07-16 09:39:06 +00:00
},
2020-09-01 02:39:59 +00:00
async setDelivery(index) {
// console.log(index);
2020-09-01 07:00:36 +00:00
if(index == 1) {
2020-09-02 07:32:54 +00:00
if(!this.isTakeawayer) {
this.$u.toast('此地区不支持骑手配送');
return false;
}
2020-09-01 07:00:36 +00:00
this.delivery = this.deliveryList[index];
this.getFreight();
}
2020-09-01 02:39:59 +00:00
if(index == 2) {
this.is_selfraising = 1;
for (const key in this.freight) {
if (this.freight.hasOwnProperty(key)) {
this.freight[key] = '0.00';
}
}
this.setTotalPrice(); // 计算总价
this.delivery = this.deliveryList[index];
} else {
this.is_selfraising = 0;
}
if(index == 0) {
this.delivery = this.deliveryList[index];
this.getFreight();
2020-07-16 09:39:06 +00:00
}
},
2020-06-10 08:06:01 +00:00
settlement() {
uni.navigateTo({
url: '/pageE/order/Details'
});
},
2020-07-20 09:17:41 +00:00
getGoodsClass() {
this.$u.api.getGoodsClass().then(res => {
this.goodsClass = res.data;
})
},
2020-06-10 08:06:01 +00:00
changeAddress() {
uni.navigateTo({
2020-07-16 09:39:06 +00:00
url: '/pageE/more/Address?type=choose'
2020-06-10 08:06:01 +00:00
});
}
},
2020-06-09 09:33:12 +00:00
};
</script>
<style lang="scss" scoped>
.order {
2020-06-10 08:06:01 +00:00
min-height: calc(100vh - var(--window-top));
background-color: #ECECEC;
padding-top: 1rpx;
2020-09-01 07:00:36 +00:00
padding-bottom: 200rpx;
2020-06-09 09:33:12 +00:00
.info-address {
2020-06-10 08:06:01 +00:00
padding: 30rpx;
display: flex;
align-items: center;
margin-bottom: 10rpx;
background:rgba(255,255,255,1);
.address-icon {
width: 28rpx;
height: 34rpx;
margin-right: 31rpx;
flex-shrink: 0;
}
.address {
width: 570rpx;
.user-info {
display: flex;
align-items: center;
font-size: 28rpx;
color: rgba(51,51,51,1);
margin-bottom: 20rpx;
2020-07-14 01:15:51 +00:00
> view:first-child {
margin-right: 13rpx;
}
2020-06-10 08:06:01 +00:00
}
.address-text {
font-size: 24rpx;
color: rgba(102,102,102,1);
line-height: 42rpx;
}
}
.right {
flex-shrink: 0;
margin-left: auto;
width: 12rpx;
height: 22rpx;
}
}
2020-07-30 12:33:16 +00:00
.address-none {
height: 150rpx;
line-height: 150rpx;
margin-bottom: 10rpx;
background:rgba(255,255,255,1);
text-align: center;
color: #333;
}
2020-06-10 08:06:01 +00:00
.main {
2020-07-14 01:15:51 +00:00
margin-bottom: 50rpx;
2020-06-30 10:06:50 +00:00
> view {
2020-07-14 09:43:15 +00:00
margin-bottom: 20rpx;
2020-06-30 10:06:50 +00:00
.goods-info {
background-color: #ffffff;
padding: 30rpx;
margin-bottom: 2rpx;
.store {
2020-06-09 09:33:12 +00:00
display: flex;
align-items: center;
2020-06-30 10:06:50 +00:00
margin-bottom: 20rpx;
.avatar {
width: 60rpx;
height: 60rpx;
border-radius: 50%;
margin-right: 15rpx;
2020-09-01 02:39:59 +00:00
// background-color: aquamarine;
2020-06-30 10:06:50 +00:00
}
> view {
font-size: 28rpx;
color: rgba(51,51,51,1);
margin-right: 15rpx;
2020-06-10 08:06:01 +00:00
}
2020-06-30 10:06:50 +00:00
.right {
2020-09-01 02:39:59 +00:00
margin-left: auto;
2020-06-10 08:06:01 +00:00
flex-shrink: 0;
2020-06-30 10:06:50 +00:00
width: 11rpx;
height: 22rpx;
2020-06-10 08:06:01 +00:00
}
2020-06-30 10:06:50 +00:00
}
.goods {
.goods-item {
2020-06-10 08:06:01 +00:00
display: flex;
2020-06-30 10:06:50 +00:00
align-items: center;
&:not(:last-child) {
margin-bottom: 20rpx;
}
> image {
margin-right: 30rpx;
width: 180rpx;
height: 160rpx;
border-radius: 10rpx;
2020-09-01 02:39:59 +00:00
// background-color: aqua;
2020-06-30 10:06:50 +00:00
flex-shrink: 0;
2020-06-10 08:06:01 +00:00
}
2020-06-30 10:06:50 +00:00
.info {
2020-07-06 09:32:29 +00:00
flex: 1;
2020-06-30 10:06:50 +00:00
// width: 418rpx;
height: 160rpx;
2020-06-10 08:06:01 +00:00
display: flex;
2020-06-30 10:06:50 +00:00
flex-direction: column;
2020-06-10 08:06:01 +00:00
justify-content: space-between;
2020-06-30 10:06:50 +00:00
.name {
2020-06-10 08:06:01 +00:00
font-size: 30rpx;
2020-08-08 04:07:50 +00:00
height: 88rpx;
line-height: 44rpx;
2020-06-30 10:06:50 +00:00
color: rgba(51,51,51,1);
2020-06-10 08:06:01 +00:00
}
2020-06-30 10:06:50 +00:00
.cart-info {
display: flex;
align-items: center;
justify-content: space-between;
.price {
font-size: 30rpx;
font-weight: 500;
color: rgba(255,49,49,1);
}
.u-numberbox {
border: 1rpx solid rgba(217,215,215,1);
border-radius:4px;
/deep/ .u-number-input {
margin: 0;
color: #333 !important;
border: 1rpx #D9D7D7 solid {
top: 0px;
bottom: 0px;
}
2020-06-10 08:06:01 +00:00
}
}
}
}
}
2020-06-09 09:33:12 +00:00
}
2020-06-10 08:06:01 +00:00
}
2020-06-30 10:06:50 +00:00
.order-info {
> view {
height: 98rpx;
background: rgba(255,255,255,1);
padding: 35rpx 30rpx;
2020-06-10 08:06:01 +00:00
display: flex;
align-items: center;
2020-06-30 10:06:50 +00:00
justify-content: space-between;
margin-bottom: 2rpx;
.title {
font-size: 28rpx;
color: rgba(102,102,102,1);
}
.value {
display: flex;
align-items: center;
font-size: 30rpx;
color:rgba(51,51,51,1);
> image {
width: 12rpx;
height: 22rpx;
flex-shrink: 0;
margin-left: 20rpx;
}
2020-06-10 08:06:01 +00:00
}
}
}
2020-09-01 07:00:36 +00:00
.pick-up {
padding: 30rpx;
background: rgba(255,255,255,1);
.title {
font-size: 28rpx;
color: #666666;
margin-bottom: 30rpx;
}
.content {
font-size: 30rpx;
color: #343434;
line-height: 40rpx;
}
}
2020-06-10 08:06:01 +00:00
}
}
2020-07-14 01:15:51 +00:00
.common-active {
2020-09-01 07:00:36 +00:00
padding-bottom: 30rpx;
2020-07-14 01:15:51 +00:00
> view {
height: 98rpx;
background: rgba(255,255,255,1);
padding: 35rpx 30rpx;
display: flex;
align-items: center;
justify-content: space-between;
margin-bottom: 2rpx;
.title {
font-size: 28rpx;
color: rgba(102,102,102,1);
}
.value {
display: flex;
align-items: center;
font-size: 30rpx;
color:rgba(51,51,51,1);
> image {
width: 12rpx;
height: 22rpx;
flex-shrink: 0;
margin-left: 20rpx;
}
}
}
}
2020-07-18 09:43:37 +00:00
.coupon-choose {
box-sizing: border-box;
padding: 30rpx;
.title {
padding-bottom: 30rpx;
font-size: 32rpx;
font-weight: 500;
color: rgba(51,51,51,1);
text-align: center;
}
.text {
padding-bottom: 30rpx;
font-size: 28rpx;
font-weight: 500;
color: rgba(102,102,102,1);
}
}
2020-06-10 08:06:01 +00:00
.bottom {
padding: 35rpx 30rpx;
position: fixed;
bottom: 0;
left: 0;
width: 100%;
height: 98rpx;
background-color: rgba(255,255,255,1);
box-shadow: 0rpx 10rpx 14rpx 2rpx rgba(0, 0, 0, 0.34);
display: flex;
align-items: center;
justify-content: space-between;
.left {
display: flex;
align-items: center;
font-size: 30rpx;
.title {
color:rgba(153,153,153,1);
margin-right: 10rpx;
2020-06-09 09:33:12 +00:00
}
2020-06-10 08:06:01 +00:00
.price {
color: #F40E0E;
2020-06-09 09:33:12 +00:00
}
}
2020-06-10 08:06:01 +00:00
.right {
display: flex;
align-items: center;
.num {
font-size: 26rpx;
color: rgba(153,153,153,1);
margin-right: 50rpx;
}
.btn {
width: 160rpx;
height: 60rpx;
background: rgba(255,120,15,1);
border-radius: 30rpx;
font-size: 30rpx;
color: rgba(255,255,255,1);
line-height: 60rpx;
text-align: center;
}
}
}
2020-06-09 09:33:12 +00:00
}
</style>