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.
1200 lines
29 KiB
1200 lines
29 KiB
<template>
|
|
<view class="sureOrder">
|
|
<view>
|
|
<u-navbar title="确认订单" :border-bottom="false" title-color="#333" :background="background"></u-navbar>
|
|
</view>
|
|
<view class="buyType">
|
|
<view class="toDoor" :class="buyType=='sm'?'':'toDoor-dis'" @click="handleSwichDelivery(DeliveryTypeEnum.EXPRESS.value,'sm')">
|
|
送货上门
|
|
</view>
|
|
<view class="toDoor" :class="buyType=='zq'?'':'toDoor-dis'" @click="handleSwichDelivery(DeliveryTypeEnum.EXTRACT.value,'zq')">
|
|
到店自取
|
|
</view>
|
|
<view class="toDoor-on" :style="{'left': buyType=='sm'?'0':'350rpx'}">{{buyType=='zq'?'到店自取':'送货上门'}}</view>
|
|
</view>
|
|
<view class="getSelf" >
|
|
<view class="address" v-if="buyType=='sm'" @click="onSelectAddress">
|
|
<view class="addAddress">
|
|
<view class="tip" v-if="!order.address">请点击添加收货地址</view>
|
|
<view class="info" v-else>
|
|
<view class="name">{{ order.address.name}}<text>{{ order.address.phone }}</text></view>
|
|
<view class="detail">
|
|
<text v-for="(region, idx) in order.address.region" :key="idx">{{ region }}</text>
|
|
<text>{{ order.address.detail }}</text>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
<view class="leftImg">
|
|
<image :src="$picUrl+'/static/order/left.png'"></image>
|
|
</view>
|
|
</view>
|
|
<view class="shopAddress" v-if="buyType=='zq'">
|
|
<view class="info" v-if="order.extractShop.shop_id">
|
|
<view class="a">
|
|
<view class="youTime">
|
|
{{ order.extractShop.shop_name }}
|
|
</view>
|
|
<view class="leftImg" @click="onSelectExtractPoint()">
|
|
切换
|
|
<image :src="$picUrl+'/static/order/left.png'" mode=""></image>
|
|
</view>
|
|
</view>
|
|
<view class="b">
|
|
{{ order.extractShop.region.province }} {{ order.extractShop.region.city }}{{ order.extractShop.region.region }} {{ order.extractShop.address }}
|
|
</view>
|
|
<view class="lookMap">
|
|
<image :src="$picUrl+'/static/user/address.png'" mode="" class="addressIcon"></image>
|
|
<view class="range">
|
|
距您{{distance_unit}}
|
|
</view>
|
|
<view class="checkMap" @click="openMap(order.extractShop)">
|
|
查看地图
|
|
</view>
|
|
<image :src="$picUrl+'/static/order/left.png'" mode="" class="rightIcon"></image>
|
|
</view>
|
|
</view>
|
|
<view class="tip" v-else @click="onSelectExtractPoint()">请选择门店<image :src="$picUrl+'/static/order/left.png'" mode=""></image></view>
|
|
<view class="pickUp">
|
|
<view class="pickPeople">
|
|
<view class="title">
|
|
取件人
|
|
</view>
|
|
<view class="name">
|
|
<input class="input" placeholder="请填写联系人姓名" v-model="linkman" />
|
|
<image :src="$picUrl+'/static/order/edit.png'" mode="" class="edit"></image>
|
|
</view>
|
|
</view>
|
|
<view class="pickPeople">
|
|
<view class="title">
|
|
预留电话
|
|
</view>
|
|
<view class="name">
|
|
<input class="input" placeholder="请填写联系电话" v-model="phone" />
|
|
<image :src="$picUrl+'/static/order/edit.png'" mode="" class="edit"></image>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
|
|
</view>
|
|
<view class="preTime" v-if="buyType=='zq'">
|
|
<view class="left">
|
|
<view class="bagImg">
|
|
<image :src="$picUrl+'/static/order/bag.png'" mode="" class="bag"></image>
|
|
街边取
|
|
</view>
|
|
<view class="preText">
|
|
如果您不方便,只需要在街边稍候,送到您的手上
|
|
</view>
|
|
</view>
|
|
<view class="switch">
|
|
<switch />
|
|
</view>
|
|
</view>
|
|
<view class="time" v-if="buyType=='zq'">
|
|
<view class="youTime">
|
|
预计到货时间
|
|
</view>
|
|
<view class="leftImg" @click="openPicker(1)">
|
|
<text v-if="timer" class="leftText">{{timer}}</text>
|
|
<text v-else>请选择</text>
|
|
<image :src="$picUrl+'/static/order/left.png'" mode=""></image>
|
|
</view>
|
|
</view>
|
|
<view class="time" v-if="buyType=='sm'">
|
|
<view class="youTime">
|
|
您期待的收货时间
|
|
</view>
|
|
<view class="leftImg" @click="openPicker(2)">
|
|
<text v-if="timer" class="leftText">{{timer}}</text>
|
|
<text v-else>请选择</text>
|
|
<image :src="$picUrl+'/static/order/left.png'" mode=""></image>
|
|
</view>
|
|
</view>
|
|
<view class="goodsDetail">
|
|
<view class="goodsType">
|
|
<image :src="$picUrl+'/static/order/bag.png'" mode="" class="bag"></image>
|
|
<text>大白兔家电</text>
|
|
<image :src="$picUrl+'/static/order/left.png'" mode="" class="leftIcon"></image>
|
|
</view>
|
|
<view class="goods" v-for="(item, index) in order.goodsList" :key="index">
|
|
<view class="goodsImg">
|
|
<image :src="item.goods_image" mode=""></image>
|
|
</view>
|
|
<view class="goodsInfo">
|
|
<view class="goodsName">
|
|
{{ item.goods_name }}
|
|
</view>
|
|
<view class="goodsPrice">
|
|
¥ <text>{{item.goods_price_min}}</text>
|
|
</view>
|
|
</view>
|
|
<view class="goodsNum">
|
|
x{{ item.total_num }}
|
|
</view>
|
|
</view>
|
|
</view>
|
|
<view class="time">
|
|
<view class="youTime" style="width: 60rpx;">
|
|
留言
|
|
</view>
|
|
<input type="textarea" placeholder="建议留言前先和店家沟通" v-model="remark" style="width:100%;" maxlength="100" />
|
|
</view>
|
|
<view class="orderTips">
|
|
<view class="orderTitle">
|
|
<view class="total">
|
|
商品总额
|
|
</view>
|
|
<view class="price">
|
|
¥{{ order.orderTotalPrice }}
|
|
</view>
|
|
</view>
|
|
<view class="orderTitle" v-if="order.address">
|
|
<view class="total">
|
|
运费
|
|
</view>
|
|
<view class="price" v-if="order.isIntraRegion">
|
|
+¥{{ order.expressPrice }}
|
|
</view>
|
|
<view class="price" v-else>
|
|
不在配送范围
|
|
</view>
|
|
</view>
|
|
<view class="orderTitle">
|
|
<view class="total">
|
|
商品数量
|
|
</view>
|
|
<view class="price">
|
|
<text class="couponNum">1件</text>
|
|
</view>
|
|
</view>
|
|
<view class="orderTitle">
|
|
<view class="total">
|
|
优惠券
|
|
</view>
|
|
<view class="price" v-if="order.couponList.length > 0" @click="handleShowPopup">
|
|
<text class="couponNum" v-if="order.couponId > 0">-¥{{ order.couponMoney }}</text>
|
|
<text class="couponNum" v-else>{{order.couponList.length}}张可用</text>
|
|
<image :src="$picUrl+'/static/order/left.png'"></image>
|
|
</view>
|
|
<view class="price" v-else>
|
|
<text class="couponNum">无优惠券可用</text>
|
|
<image :src="$picUrl+'/static/order/left.png'"></image>
|
|
</view>
|
|
</view>
|
|
<view class="line">
|
|
|
|
</view>
|
|
<view class="amount">
|
|
<view class="left">
|
|
|
|
</view>
|
|
<view class="right">
|
|
<text class="totalNum">共1件,合计:</text>
|
|
<text class="allPrice">¥{{ order.orderPayPrice }}</text>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
<view class="payType">
|
|
<view class="itemType">
|
|
<view class="payName">
|
|
<image src="/static/order/wChat.png" mode="" class="payIcon"></image>
|
|
微信支付
|
|
</view>
|
|
<image src="/static/order/right.png" mode="" class="chose"></image>
|
|
</view>
|
|
<view class="line">
|
|
|
|
</view>
|
|
<view class="itemType">
|
|
<view class="" v-for="(item,index) in payMethList" :key="index" @click="chosePayType(item)">
|
|
<view class="payName">
|
|
<image src="/static/order/friends.png" mode="" class="payIcon"></image>
|
|
余额支付
|
|
</view>
|
|
<image src="/static/order/right.png" mode="" class="chose" v-if="payType==item.method"></image>
|
|
</view>
|
|
</view>
|
|
<view class="line">
|
|
|
|
</view>
|
|
<!-- <view class="itemType">
|
|
<view class="payName">
|
|
<image src="/static/order/shop.png" mode="" class="payIcon"></image>
|
|
到店支付
|
|
</view>
|
|
|
|
</view> -->
|
|
</view>
|
|
<view class="footer">
|
|
<view class="meetPrice">
|
|
应付款
|
|
<text class="type">¥</text>
|
|
<text class="price">{{order.orderPayPrice}}</text>
|
|
</view>
|
|
<view class="btn">
|
|
提交订单
|
|
</view>
|
|
</view>
|
|
<!-- 优惠券弹出框 -->
|
|
<u-popup v-model="showPopup" mode="bottom">
|
|
<view class="popup__coupon">
|
|
<view class="coupon__title f-30">选择优惠券</view>
|
|
<!-- 优惠券列表 -->
|
|
<view class="coupon-list">
|
|
<scroll-view :scroll-y="true" style="height: 565rpx;">
|
|
<view class="coupon-item" v-for="(item, index) in order.couponList" :key="index">
|
|
<view class="item-wrapper" :class="[item.is_apply ? 'color-' + CouponColors[index % CouponColors.length] : 'color-gray']"
|
|
@click="handleSelectCoupon(index)">
|
|
<view class="coupon-type">{{ CouponTypeEnum[item.coupon_type].name }}</view>
|
|
<view class="tip dis-flex flex-dir-column flex-x-center">
|
|
<view v-if="item.coupon_type == CouponTypeEnum.FULL_DISCOUNT.value">
|
|
<text class="f-30">¥</text>
|
|
<text class="money">{{ item.reduce_price }}</text>
|
|
</view>
|
|
<text class="money" v-if="item.coupon_type == CouponTypeEnum.DISCOUNT.value">{{ item.discount }}折</text>
|
|
<text class="pay-line">满{{ item.min_price }}元可用</text>
|
|
</view>
|
|
<view class="split-line"></view>
|
|
<view class="content dis-flex flex-dir-column flex-x-between">
|
|
<view class="title">{{ item.name }}</view>
|
|
<view class="bottom dis-flex flex-y-center">
|
|
<view class="time flex-box">
|
|
<block v-if="item.start_time === item.end_time">{{ item.start_time }} 当天有效</block>
|
|
<block v-else>{{ item.start_time }}~{{ item.end_time }}</block>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
</scroll-view>
|
|
</view>
|
|
<!-- 不使用优惠券 -->
|
|
<view class="coupon__do_not dis-flex flex-y-center flex-x-center">
|
|
<view class="control dis-flex flex-y-center flex-x-center" @click="handleNotUseCoupon()">
|
|
<text class="f-26">不使用优惠券</text>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
</u-popup>
|
|
<u-picker mode="time" v-model="show1" :params="params" @confirm="confirm"></u-picker>
|
|
</view>
|
|
</template>
|
|
|
|
<script>
|
|
import * as Verify from '@/utils/verify'
|
|
import * as CheckoutApi from '@/api/checkout'
|
|
import * as SharpCheckoutApi from '@/api/sharp/checkout'
|
|
import * as BargainCheckoutApi from '@/api/bargain/checkout'
|
|
import * as GrouponCheckoutApi from '@/api/groupon/checkout'
|
|
import { CouponTypeEnum } from '@/common/enum/coupon'
|
|
import { OrderTypeEnum, DeliveryTypeEnum } from '@/common/enum/order'
|
|
|
|
const CouponColors = ['red', 'blue', 'violet', 'yellow']
|
|
|
|
// 根据指定mode获取对应的api类
|
|
const getCheckoutApi = (mode) => {
|
|
const apiEnum = {
|
|
buyNow: CheckoutApi,
|
|
cart: CheckoutApi,
|
|
bargain: BargainCheckoutApi,
|
|
sharp: SharpCheckoutApi,
|
|
groupon: GrouponCheckoutApi
|
|
}
|
|
return apiEnum[mode]
|
|
}
|
|
|
|
// 根据指定mode获取param
|
|
const getModeParam = (mode, options) => {
|
|
const param = {}
|
|
// 结算模式: 立即购买
|
|
if (mode === 'buyNow') {
|
|
param.goodsId = options.goodsId
|
|
param.goodsNum = options.goodsNum
|
|
param.goodsSkuId = options.goodsSkuId
|
|
}
|
|
// 结算模式: 购物车
|
|
if (mode === 'cart') {
|
|
param.cartIds = options.cartIds
|
|
}
|
|
// 结算模式: 砍价活动
|
|
if (mode === 'bargain') {
|
|
param.taskId = options.taskId
|
|
param.goodsSkuId = options.goodsSkuId
|
|
}
|
|
// 结算模式: 整点秒杀
|
|
if (mode === 'sharp') {
|
|
param.activeTimeId = options.activeTimeId
|
|
param.sharpGoodsId = options.sharpGoodsId
|
|
param.goodsSkuId = options.goodsSkuId
|
|
param.goodsNum = options.goodsNum
|
|
}
|
|
// 结算模式: 多人拼团
|
|
if (mode === 'groupon') {
|
|
param.grouponGoodsId = options.grouponGoodsId
|
|
param.taskId = options.taskId
|
|
param.goodsSkuId = options.goodsSkuId
|
|
param.goodsNum = options.goodsNum
|
|
param.stepPeople = options.stepPeople
|
|
}
|
|
return param
|
|
}
|
|
|
|
export default {
|
|
data() {
|
|
return {
|
|
params: {
|
|
year: true,
|
|
month: true,
|
|
day: true,
|
|
hour: true,
|
|
minute: true,
|
|
second: true
|
|
},
|
|
show1: false,
|
|
background: {
|
|
background: 'url(https://www.royaum.com.cn/static/news/login-bg.png) center top no-repeat',
|
|
backgroundSize: '100% auto',
|
|
},
|
|
// 枚举类
|
|
OrderTypeEnum,
|
|
DeliveryTypeEnum,
|
|
CouponTypeEnum,
|
|
// 当前页面参数
|
|
options: {},
|
|
// 配送方式
|
|
isShowTab: false,
|
|
DeliveryTypeEnum,
|
|
curDelivery: null,
|
|
// 自提信息
|
|
selectedShopId: 0, // 选择的门店ID
|
|
linkman: '', // 自提联系人
|
|
phone: '', // 自提联系电话
|
|
// 优惠券颜色组
|
|
CouponColors,
|
|
// 选择的优惠券
|
|
selectCouponId: 0,
|
|
// 是否使用积分抵扣
|
|
isUsePoints: false,
|
|
// 买家留言
|
|
remark: '',
|
|
// 禁用submit按钮
|
|
disabled: false,
|
|
// 是否显示积分说明
|
|
showPoints: false,
|
|
// 是否显示优惠券弹窗
|
|
showPopup: false,
|
|
// 订单信息 (从后端api中获取)
|
|
order: {
|
|
// 商品列表
|
|
goodsList: [],
|
|
// 优惠券列表
|
|
couponList: [],
|
|
// 是否存在收货地址
|
|
existAddress: false,
|
|
// 默认收货地址
|
|
address: null,
|
|
// 是否存在收货地址
|
|
existAddress: false,
|
|
// 当前用户收货城市是否存在配送规则中
|
|
isIntraRegion: true,
|
|
// 是否存在错误
|
|
hasError: false,
|
|
// 错误信息
|
|
errorMsg: '',
|
|
},
|
|
// 个人信息
|
|
personal: {},
|
|
buyType:'sm',
|
|
// 商城设置
|
|
setting: {},
|
|
timer: "",
|
|
distance_unit: ""
|
|
}
|
|
},
|
|
|
|
/**
|
|
* 生命周期函数--监听页面加载
|
|
*/
|
|
onLoad(options) {
|
|
this.options = options;
|
|
console.log(options)
|
|
// 注册全局事件订阅: 选择自提门店
|
|
uni.$on('syncSelectedId', selectedId => {
|
|
this.selectedShopId = selectedId
|
|
})
|
|
},
|
|
|
|
/**
|
|
* 生命周期函数--监听页面的卸载
|
|
*/
|
|
onUnload() {
|
|
// 卸载全局事件订阅: 选择自提门店
|
|
uni.$off('syncSelectedId')
|
|
},
|
|
|
|
/**
|
|
* 生命周期函数--监听页面显示
|
|
*/
|
|
onShow() {
|
|
// 获取当前订单信息
|
|
this.getOrderData()
|
|
},
|
|
|
|
methods: {
|
|
openPicker() {
|
|
this.show1 = true;
|
|
},
|
|
confirm(e){
|
|
this.timer = e.year+'-'+e.month+'-'+e.day+' '+e.hour+':'+e.minute+':'+e.second
|
|
},
|
|
// 获取订单数据
|
|
getOrderData() {
|
|
const app = this
|
|
const { options: { mode } } = app
|
|
// 请求的参数
|
|
const params = app.getRequestParam()
|
|
// 请求api
|
|
getCheckoutApi(mode)
|
|
.order(mode, params)
|
|
.then(result => app.initData(result.data))
|
|
.catch(err => err)
|
|
},
|
|
|
|
// 初始化数据
|
|
initData({ order, setting, personal }) {
|
|
const app = this
|
|
app.order = order
|
|
app.personal = personal
|
|
app.setting = setting
|
|
// 显示错误信息
|
|
if (order.hasError) {
|
|
app.showToast(order.errorMsg, 3000)
|
|
}
|
|
// 当前选择的配送方式
|
|
app.curDelivery = order.delivery
|
|
// 如果只有一种配送方式则不显示选项卡
|
|
app.isShowTab = setting.deliveryType.length > 1
|
|
// 上门自提联系信息
|
|
if (app.linkman === '') {
|
|
app.linkman = order.lastExtract.linkman
|
|
}
|
|
if (app.phone === '') {
|
|
app.phone = order.lastExtract.phone
|
|
}
|
|
},
|
|
|
|
// 获取api请求的参数
|
|
getRequestParam() {
|
|
const app = this
|
|
const { options } = app
|
|
// 结算模式的固定参数
|
|
const modeParam = getModeParam(options.mode, options)
|
|
// 订单结算参数(用户选择)
|
|
const orderParam = {
|
|
delivery: app.curDelivery || 0,
|
|
shopId: app.selectedShopId || 0,
|
|
couponId: app.selectCouponId || 0,
|
|
isUsePoints: app.isUsePoints ? 1 : 0,
|
|
}
|
|
return { ...orderParam, ...modeParam }
|
|
},
|
|
|
|
// 切换配送方式
|
|
handleSwichDelivery(key,val) {
|
|
this.curDelivery = key
|
|
this.getOrderData()
|
|
this.buyType = val;
|
|
},
|
|
|
|
// 显示积分说明
|
|
handleShowPoints() {
|
|
this.showPoints = true
|
|
},
|
|
|
|
// 显示优惠券弹窗
|
|
handleShowPopup() {
|
|
this.showPopup = true
|
|
},
|
|
|
|
// 选择优惠券
|
|
handleSelectCoupon(index) {
|
|
const app = this
|
|
const { couponList } = app.order
|
|
// 当前选择的优惠券
|
|
const couponItem = couponList[index]
|
|
// 判断是否在适用范围
|
|
if (!couponItem.is_apply) {
|
|
app.showToast(couponItem.not_apply_info)
|
|
return
|
|
}
|
|
// 记录选中的优惠券id
|
|
app.selectCouponId = couponItem.user_coupon_id
|
|
// 重新获取订单信息
|
|
app.getOrderData()
|
|
// 隐藏优惠券弹层
|
|
app.showPopup = false
|
|
},
|
|
|
|
// 不使用优惠券
|
|
handleNotUseCoupon() {
|
|
const app = this
|
|
app.selectCouponId = 0
|
|
// 重新获取订单信息
|
|
app.getOrderData()
|
|
// 隐藏优惠券弹层
|
|
app.showPopup = false
|
|
},
|
|
|
|
// 快递配送:选择收货地址
|
|
onSelectAddress() {
|
|
this.$navTo('pages/address/index', { from: 'checkout' })
|
|
},
|
|
|
|
// 上门自提:选择自提点
|
|
onSelectExtractPoint() {
|
|
this.$navTo('pages/shop/extract', { selectedId: this.selectedShopId })
|
|
},
|
|
|
|
// 跳转到商品详情页
|
|
onTargetGoods(goodsId) {
|
|
this.$navTo('pages/goods/detail', { goodsId })
|
|
},
|
|
|
|
// 订单提交
|
|
onSubmitOrder() {
|
|
const app = this
|
|
if (app.disabled) {
|
|
return false
|
|
}
|
|
// 表单验证
|
|
if (!app.onVerifyFrom()) {
|
|
return false
|
|
}
|
|
// 按钮禁用
|
|
app.disabled = true
|
|
// 请求api
|
|
getCheckoutApi(app.options.mode)
|
|
.submit(app.options.mode, app.getFormData())
|
|
.then(result => {
|
|
// 订单创建成功: 跳转到订单支付页
|
|
const orderId = result.data.orderId
|
|
setTimeout(() => {
|
|
this.$navTo('pages/checkout/cashier/index', { orderId }, 'redirectTo')
|
|
}, 100)
|
|
})
|
|
.catch(res => app.showToast(res.errMsg, 3000))
|
|
.finally(() => setTimeout(() => app.disabled = false, 800))
|
|
},
|
|
|
|
// 跳转到我的订单(等待1秒)
|
|
navToMyOrder() {
|
|
setTimeout(() => {
|
|
this.$navTo('pages/order/index', {}, 'redirectTo')
|
|
}, 1000)
|
|
},
|
|
|
|
// 表单提交的数据
|
|
getFormData() {
|
|
const app = this
|
|
const { options } = app
|
|
// 表单数据
|
|
const form = {
|
|
delivery: app.curDelivery,
|
|
couponId: app.selectCouponId || 0,
|
|
shopId: app.selectedShopId || 0,
|
|
linkman: app.linkman,
|
|
phone: app.phone,
|
|
isUsePoints: app.isUsePoints ? 1 : 0,
|
|
remark: app.remark || '',
|
|
}
|
|
// 获取不同模式的参数
|
|
const modeParam = getModeParam(options.mode, options)
|
|
return { ...form, ...modeParam }
|
|
},
|
|
|
|
// 表单验证
|
|
onVerifyFrom() {
|
|
const app = this
|
|
if (app.hasError) {
|
|
app.showToast(app.errorMsg, 3000)
|
|
return false
|
|
}
|
|
// 验证自提填写的联系方式
|
|
if (app.curDelivery == DeliveryTypeEnum.EXTRACT.value) {
|
|
app.linkman = app.linkman.trim()
|
|
app.phone = app.phone.trim()
|
|
if (app.selectedShopId <= 0) {
|
|
app.showToast('请选择自提的门店')
|
|
return false
|
|
}
|
|
if (Verify.isEmpty(app.linkman)) {
|
|
app.showToast('请填写自提联系人')
|
|
return false
|
|
}
|
|
if (Verify.isEmpty(app.phone)) {
|
|
app.showToast('请填写自提联系电话')
|
|
return false
|
|
}
|
|
if (!Verify.isPhone(app.phone)) {
|
|
app.showToast('请输入正确的联系电话')
|
|
return false
|
|
}
|
|
}
|
|
return true
|
|
},
|
|
|
|
// 显示toast信息
|
|
showToast(title, duration = 2000) {
|
|
this.$refs.uToast.show({ title, duration })
|
|
}
|
|
|
|
}
|
|
}
|
|
</script>
|
|
|
|
<style lang="scss" scoped>
|
|
.sureOrder {
|
|
width: 750rpx;
|
|
min-height: 750rpx;
|
|
padding-bottom: 120rpx;
|
|
background: url('https://www.royaum.com.cn/static/news/login-bg.png') center top no-repeat;
|
|
background-size: 100% auto;
|
|
}
|
|
|
|
.buyType {
|
|
width: 700rpx;
|
|
margin: 30rpx auto 0;
|
|
position: relative;
|
|
height: 88rpx;
|
|
.toDoor {
|
|
width: 50%;
|
|
height: 74rpx;
|
|
background-color: rgba(255, 255, 255, 0.5);
|
|
font-size: 28rpx;
|
|
font-weight: 500;
|
|
color: #606060;
|
|
line-height: 74rpx;
|
|
text-align: center;
|
|
float: left;
|
|
margin-top: 14rpx;
|
|
float: left;
|
|
&-on{
|
|
width: 350rpx;
|
|
height: 88rpx;
|
|
background-color: #FFF;
|
|
text-align: center;
|
|
font-size: 34rpx;
|
|
font-weight: 400;
|
|
color: #000;
|
|
line-height: 88rpx;
|
|
position: absolute;
|
|
bottom: 0;
|
|
left: 0;
|
|
z-index: 2;
|
|
border-radius: 10rpx 10rpx 0 0;
|
|
}
|
|
&-dis{
|
|
border-radius: 10rpx 10rpx 0 0;
|
|
}
|
|
}
|
|
}
|
|
|
|
.getSelf {
|
|
width: 700rpx;
|
|
margin: 0 auto;
|
|
background-image: url('https://www.royaum.com.cn/static/order/map.png');
|
|
background-size: 100%;
|
|
min-height: 160rpx;
|
|
padding: 14rpx 46rpx 0 32rpx;
|
|
box-sizing: border-box;
|
|
|
|
}
|
|
|
|
.leftText {
|
|
font-size: 24rpx;
|
|
font-weight: 400;
|
|
color: #F21A1C;
|
|
line-height: 28rpx;
|
|
}
|
|
.shopAddress {
|
|
max-height: 260rpx;
|
|
padding-bottom: 20rpx;
|
|
overflow: hidden;
|
|
.tip{
|
|
font-size: 24rpx;
|
|
color: #F32E2E;
|
|
display: flex;
|
|
align-items: center;
|
|
justify-content: space-between;
|
|
image{
|
|
width: 12rpx;
|
|
height: 18rpx;
|
|
}
|
|
}
|
|
.pickUp {
|
|
display: flex;
|
|
justify-content: space-around;
|
|
margin-top: 16rpx;
|
|
.pickPeople {
|
|
flex: 1;
|
|
&:first-child{
|
|
margin-right: 20rpx;
|
|
}
|
|
.title {
|
|
font-size: 24rpx;
|
|
font-weight: 400;
|
|
color: #838383;
|
|
}
|
|
|
|
.name {
|
|
margin-top: 10rpx;
|
|
display: flex;
|
|
align-items: center;
|
|
input{
|
|
width: 200rpx;
|
|
line-height: 60rpx;
|
|
font-size: 24rpx;
|
|
color: #2C2C2C;
|
|
display: block;
|
|
}
|
|
.edit {
|
|
width: 30rpx;
|
|
height: 30rpx;
|
|
margin-left: 10rpx;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
.a{
|
|
display: flex;
|
|
align-items: center;
|
|
justify-content: space-between;
|
|
.youTime {
|
|
font-size: 28rpx;
|
|
font-weight: 600;
|
|
color: #1D1D1D;
|
|
}
|
|
|
|
.leftImg {
|
|
font-size: 24rpx;
|
|
font-weight: 400;
|
|
color: #F42B17;
|
|
image {
|
|
width: 12rpx;
|
|
height: 18rpx;
|
|
margin-left: 16rpx;
|
|
}
|
|
}
|
|
}
|
|
.b{
|
|
font-size: 24rpx;
|
|
color: #838383;
|
|
line-height: 50rpx;
|
|
}
|
|
.lookMap {
|
|
display: flex;
|
|
align-items: center;
|
|
margin-top: 8rpx;
|
|
margin-bottom: 10rpx;
|
|
.addressIcon {
|
|
width: 23rpx;
|
|
height: 26rpx;
|
|
margin-right: 14rpx;
|
|
}
|
|
|
|
.range {
|
|
font-size: 20rpx;
|
|
font-weight: 400;
|
|
color: #F42B17;
|
|
line-height: 26rpx;
|
|
padding-right: 10rpx;
|
|
border-right: 2rpx solid #D9D9D9;
|
|
margin-right: 10rpx;
|
|
}
|
|
|
|
.checkMap {
|
|
font-size: 20rpx;
|
|
font-weight: 400;
|
|
color: #2B2B2B;
|
|
line-height: 26rpx;
|
|
margin-right: 24rpx;
|
|
}
|
|
|
|
.rightIcon {
|
|
width: 12rpx;
|
|
height: 18rpx;
|
|
}
|
|
}
|
|
}
|
|
.address {
|
|
width: 100%;
|
|
display: flex;
|
|
height: 120rpx;
|
|
align-items: center;
|
|
justify-content: space-between;
|
|
padding: 0 22rpx 0 32rpx;
|
|
box-sizing: border-box;
|
|
.addAddress {
|
|
font-size: 28rpx;
|
|
font-weight: 500;
|
|
// color: #F32E2E;
|
|
color: #212121;
|
|
.info{
|
|
flex: 1;
|
|
.name{
|
|
font-size: 28rpx;
|
|
color: #212121;
|
|
text{
|
|
margin-left: 20rpx;
|
|
color: #666;
|
|
}
|
|
}
|
|
.detail{
|
|
margin-top: 10rpx;
|
|
font-size: 26rpx;
|
|
}
|
|
}
|
|
.tip{
|
|
font-size: 30rpx;
|
|
font-weight: 500;
|
|
color: #F32E2E;
|
|
}
|
|
}
|
|
|
|
.leftImg {
|
|
width: 12rpx;
|
|
height: 18rpx;
|
|
image {
|
|
width: 100%;
|
|
height: 100%;
|
|
display: block;
|
|
}
|
|
}
|
|
}
|
|
.ziqu{
|
|
overflow: hidden;
|
|
padding: 0 22rpx 0 32rpx;
|
|
}
|
|
.preTime {
|
|
width: 700rpx;
|
|
height: 140rpx;
|
|
background: #FFFFFF;
|
|
border-radius: 10rpx;
|
|
margin: 12rpx 0 0 26rpx;
|
|
display: flex;
|
|
justify-content: space-between;
|
|
padding: 34rpx 0 0 30rpx;
|
|
box-sizing: border-box;
|
|
.left {
|
|
.bagImg {
|
|
font-size: 24rpx;
|
|
font-weight: 400;
|
|
color: #000000;
|
|
display: flex;
|
|
align-items: center;
|
|
.bag {
|
|
width: 35rpx;
|
|
height: 35rpx;
|
|
margin-right: 10rpx;
|
|
}
|
|
}
|
|
|
|
}
|
|
|
|
.preText {
|
|
font-size: 24rpx;
|
|
font-weight: 400;
|
|
color: #959595;
|
|
margin-top: 15rpx;
|
|
}
|
|
}
|
|
|
|
.time {
|
|
display: flex;
|
|
width: 694rpx;
|
|
height: 90rpx;
|
|
background: #FFFFFF;
|
|
border-radius: 10rpx;
|
|
opacity: 1;
|
|
margin: 12rpx 0 0 26rpx;
|
|
align-items: center;
|
|
justify-content: space-between;
|
|
padding: 0 32rpx 0 28rpx;
|
|
|
|
.youTime {
|
|
font-size: 24rpx;
|
|
font-weight: 400;
|
|
color: #000000;
|
|
}
|
|
|
|
.leftImg {
|
|
font-size: 24rpx;
|
|
font-weight: 400;
|
|
color: #9E9E9E;
|
|
image {
|
|
width: 12rpx;
|
|
height: 18rpx;
|
|
margin-left: 16rpx;
|
|
}
|
|
}
|
|
}
|
|
|
|
.goodsDetail {
|
|
width: 694rpx;
|
|
min-height: 266rpx;
|
|
background: #FFFFFF;
|
|
border-radius: 10rpx 10rpx 10rpx 10rpx;
|
|
opacity: 1;
|
|
margin: 12rpx 0 0 26rpx;
|
|
padding: 32rpx 24rpx 24rpx 12rpx;
|
|
|
|
.goodsType {
|
|
display: flex;
|
|
align-items: center;
|
|
font-size: 28rpx;
|
|
font-family: PingFang SC, PingFang SC;
|
|
font-weight: 500;
|
|
color: #333333;
|
|
|
|
.bag {
|
|
width: 30rpx;
|
|
height: 30rpx;
|
|
margin-right: 20rpx;
|
|
}
|
|
|
|
.leftIcon {
|
|
width: 18rpx;
|
|
height: 18rpx;
|
|
margin-left: 20rpx;
|
|
}
|
|
}
|
|
|
|
.goods {
|
|
display: flex;
|
|
align-items: center;
|
|
margin-top: 28rpx;
|
|
|
|
.goodsImg {
|
|
width: 162rpx;
|
|
height: 148rpx;
|
|
border-radius: 0rpx 0rpx 0rpx 0rpx;
|
|
opacity: 1;
|
|
|
|
image {
|
|
width: 100%;
|
|
height: 100%;
|
|
}
|
|
}
|
|
|
|
.goodsInfo {
|
|
margin-left: 20rpx;
|
|
|
|
.goodsName {
|
|
min-height: 40rpx;
|
|
font-size: 28rpx;
|
|
font-family: PingFang SC, PingFang SC;
|
|
font-weight: 400;
|
|
color: #1E1E1E;
|
|
line-height: 40rpx;
|
|
margin-bottom: 4rpx;
|
|
}
|
|
|
|
.goodsPrice {
|
|
height: 50rpx;
|
|
font-size: 24rpx;
|
|
font-family: PingFang SC, PingFang SC;
|
|
font-weight: 600;
|
|
color: #F21A1C;
|
|
line-height: 50rpx;
|
|
|
|
text {
|
|
font-size: 36rpx;
|
|
}
|
|
}
|
|
}
|
|
|
|
.goodsNum {
|
|
font-size: 28rpx;
|
|
font-family: PingFang SC, PingFang SC;
|
|
font-weight: 500;
|
|
color: #1E1E1E;
|
|
margin-left: 150rpx;
|
|
}
|
|
}
|
|
}
|
|
|
|
.orderTips {
|
|
width: 694rpx;
|
|
height: 342rpx;
|
|
background: #FFFFFF;
|
|
border-radius: 10rpx 10rpx 10rpx 10rpx;
|
|
opacity: 1;
|
|
margin: 12rpx 0 0 26rpx;
|
|
padding: 22rpx 36rpx 24rpx 24rpx;
|
|
|
|
.orderTitle {
|
|
margin-bottom: 24rpx;
|
|
display: flex;
|
|
justify-content: space-between;
|
|
height: 34rpx;
|
|
font-family: PingFang SC, PingFang SC;
|
|
font-weight: 400;
|
|
color: #2D2D2D;
|
|
line-height: 34rpx;
|
|
|
|
.total {
|
|
font-size: 24rpx;
|
|
}
|
|
|
|
.price {
|
|
.couponNum {
|
|
font-size: 28rpx;
|
|
color: #F42B17;
|
|
}
|
|
|
|
font-size: 28rpx;
|
|
|
|
image {
|
|
width: 18rpx;
|
|
height: 18rpx;
|
|
margin-left: 18rpx;
|
|
}
|
|
}
|
|
}
|
|
|
|
.amount {
|
|
display: flex;
|
|
justify-content: space-between;
|
|
margin-top: 20rpx;
|
|
|
|
.left {
|
|
width: 20rpx;
|
|
height: 34rpx;
|
|
}
|
|
|
|
.right {
|
|
display: flex;
|
|
align-items: center;
|
|
|
|
.totalNum {
|
|
height: 34rpx;
|
|
font-size: 24rpx;
|
|
font-family: PingFang SC, PingFang SC;
|
|
font-weight: 400;
|
|
color: #000000;
|
|
line-height: 34rpx;
|
|
}
|
|
|
|
.allPrice {
|
|
font-size: 28rpx;
|
|
font-family: PingFang SC, PingFang SC;
|
|
font-weight: 600;
|
|
color: #F42B17;
|
|
line-height: 34rpx;
|
|
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
.line {
|
|
width: 100%;
|
|
height: 0rpx;
|
|
opacity: 1;
|
|
border: 2rpx solid #F1F1F1;
|
|
}
|
|
|
|
.payType {
|
|
width: 694rpx;
|
|
height: 270rpx;
|
|
background: #FFFFFF;
|
|
border-radius: 10rpx 10rpx 10rpx 10rpx;
|
|
opacity: 1;
|
|
margin: 12rpx 0 0rpx 26rpx;
|
|
padding: 24rpx 26rpx 0;
|
|
|
|
.line {
|
|
margin-bottom: 24rpx;
|
|
}
|
|
|
|
.itemType {
|
|
display: flex;
|
|
justify-content: space-between;
|
|
align-items: center;
|
|
margin-bottom: 28rpx;
|
|
|
|
.payName {
|
|
display: flex;
|
|
align-items: center;
|
|
height: 42rpx;
|
|
font-size: 24rpx;
|
|
font-family: PingFang SC, PingFang SC;
|
|
font-weight: 400;
|
|
color: #000000;
|
|
line-height: 42rpx;
|
|
|
|
.payIcon {
|
|
width: 42rpx;
|
|
height: 42rpx;
|
|
margin-right: 16rpx;
|
|
}
|
|
}
|
|
|
|
.chose {
|
|
width: 34rpx;
|
|
height: 24rpx;
|
|
margin-right: 26rpx;
|
|
}
|
|
}
|
|
}
|
|
|
|
.footer {
|
|
width: 100%;
|
|
height: 120rpx;
|
|
position: fixed;
|
|
background-color: #FFF;
|
|
bottom: 0;
|
|
display: flex;
|
|
justify-content: space-between;
|
|
align-items: center;
|
|
|
|
.meetPrice {
|
|
margin-left: 26rpx;
|
|
font-size: 24rpx;
|
|
font-family: PingFang SC, PingFang SC;
|
|
font-weight: 400;
|
|
color: #000000;
|
|
|
|
.type {
|
|
font-size: 24rpx;
|
|
font-family: PingFang SC, PingFang SC;
|
|
font-weight: 400;
|
|
color: #F42B17;
|
|
margin-left: 12rpx;
|
|
}
|
|
|
|
.price {
|
|
font-size: 40rpx;
|
|
font-family: PingFang SC, PingFang SC;
|
|
font-weight: 600;
|
|
color: #F42B17;
|
|
}
|
|
}
|
|
|
|
.btn {
|
|
width: 214rpx;
|
|
height: 74rpx;
|
|
background: linear-gradient(180deg, #FD5D06 0%, #F3211A 100%);
|
|
border-radius: 100rpx 100rpx 100rpx 100rpx;
|
|
opacity: 1;
|
|
text-align: center;
|
|
font-size: 28rpx;
|
|
font-family: PingFang SC, PingFang SC;
|
|
font-weight: 500;
|
|
color: #FFFFFF;
|
|
line-height: 74rpx;
|
|
margin-right: 20rpx;
|
|
}
|
|
}
|
|
</style> |