123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411 |
- <!-- 自提配送详情,自动发货详情 -->
- <template>
- <view class="page_box">
- <view class="content_box">
- <view class="card-wrap" :style="expressType !== 'selfetch' ? 'border-bottom-left-radius:0;border-bottom-right-radius:0;' : ''">
- <!-- 商品卡片 -->
- <view class="order-card-box">
- <shopro-mini-card :title="itemDetail.goods_title" :image="itemDetail.goods_image">
- <template #describe>
- <view class="order-sku u-ellipsis-1">
- <text class="order-num">数量:{{ itemDetail.goods_num || 0 }};</text>
- {{ itemDetail.goods_sku_text ? itemDetail.goods_sku_text : '' }}
- </view>
- </template>
- <template #cardBottom>
- <view class="card-price-box u-flex">
- <text class="order-price font-OPPOSANS">¥{{ itemDetail.goods_price || 0 }}</text>
- <button class="u-reset-button status-btn" v-if="itemDetail.status_name">{{ itemDetail.status_name }}</button>
- </view>
- </template>
- </shopro-mini-card>
- </view>
- <!-- 到店自提 -->
- <view class="u-flex-col u-col-center u-m-b-20 u-p-y-20" v-if="expressType == 'selfetch' && itemDetail.status_code !== 'refund_finish' && qrcodeList.length">
- <image class="qr-code--img u-m-y-20" :src="allqrcodepath" mode=""></image>
- <view class="all-qrcode-title u-m-b-20">总核销码</view>
- <view class="detail-item">
- <view class="item-title u-flex">核销码</view>
- <view class="u-flex u-row-between u-m-y-20" v-for="code in qrcodeList" :key="code.code">
- <view>
- <text :style="code.status_code !== 'nouse' ? 'color:#999' : ''" class="item-content">{{ code.code }}</text>
- <text :style="code.status_code !== 'nouse' ? 'color:#999' : ''" class="item-status u-m-x-30">{{ code.status_name }}</text>
- </view>
- <button class="u-reset-button check-code" v-if="code.status_code == 'nouse'" @tap="checkCode(code.code)">查看</button>
- </view>
- <view class="item-tip">为保障您的权益,未到店消费前请不要将提货码提供给商家</view>
- </view>
- </view>
- </view>
- <!-- 自提 -->
- <view class="detail-item u-p-20 " v-if="expressType == 'selfetch'">
- <view class="item-title">{{ storeInfo.name }}</view>
- <view class="u-flex u-row-between">
- <view class="u-m-r-20" style="flex: 3;">
- <view class="item-content">
- {{ storeInfo.province_name || '' }}{{ storeInfo.city_name || '' }}{{ storeInfo.area_name || '' }}{{ storeInfo.address || '' }}
- </view>
- <view class="item-content">营业时间:{{ storeInfo.openhours || '' }}</view>
- </view>
- <view class="u-flex-col u-col-center location-box" style="flex: 1;" @tap="openStoreMap">
- <text class="u-iconfont uicon-map-fill" style="color: #4fbbff;font-size: 34rpx;"></text>
- <text class="location-text u-m-t-10">到这去</text>
- </view>
- </view>
- </view>
- <!-- 配送 -->
- <view
- class="detail-item u-p-20"
- :style="expressType !== 'selfetch' ? 'border-top-left-radius:0;border-top-right-radius:0;' : ''"
- v-if="expressType == 'store' && itemDetail.order"
- >
- <view class="item-title">配送信息</view>
- <view class="item-content">配送地址:{{ itemDetail.order.city_name || '' }}{{ itemDetail.order.area_name || '' }}{{ itemDetail.order.address || '' }}</view>
- <view class="item-content">配送时间:{{ itemDetail.ext_arr.dispatch_date || '' }}</view>
- </view>
- <!-- 自动 -->
- <view class="detail-item u-p-20" :style="expressType !== 'selfetch' ? 'border-top-left-radius:0;border-top-right-radius:0;' : ''" v-if="expressType == 'autosend'">
- <view class="item-title">发货信息</view>
- <view v-if="itemDetail.ext_arr && itemDetail.ext_arr.autosend_type == 'params'" v-for="item in autosendList" :key="item.value" class="item-content">
- {{ item.name }}:{{ item.value }}
- </view>
- <view v-if="itemDetail.ext_arr && itemDetail.ext_arr.autosend_type == 'text'" class="item-content">{{ itemDetail.ext_arr.autosend_content }}</view>
- <view v-if="!(itemDetail.ext_arr && itemDetail.ext_arr.autosend_type)" style="color: #999;" class="item-content">暂未发货~</view>
- </view>
- </view>
- <view class="foot_box u-flex u-row-center u-col-center u-p-b-20" v-if="expressType == 'selfetch' || expressType == 'store'">
- <button class="service-btn u-reset-button u-flex u-col-center u-row-center" @tap="onService">
- <text class="u-iconfont uicon-phone-fill u-m-r-10" style="color: #fff;font-size: 40rpx;"></text>
- 联系商家
- </button>
- </view>
- <!-- 二维码弹窗 -->
- <u-popup v-model="showQrcode" border-radius="20" mode="center">
- <view class="qr-code-modal u-flex-col u-row-center u-col-center">
- <image class="qr-code-img" :src="qrcodepath" mode=""></image>
- <view class="qr-code-text">核销码:{{ qrcode }}</view>
- <button class="u-reset-button hide-qrcode" @tap="showQrcode = false">关闭</button>
- </view>
- </u-popup>
- <!-- 二维码绘制 -->
- <view class="hideCanvasView">
- <canvas class="hideCanvas" canvas-id="qrcode_img" :style="{ width: (poster.width || 1) + 'px', height: (poster.height || 1) + 'px' }"></canvas>
- </view>
- </view>
- </template>
- <script>
- import _app from '@/shopro/poster/QS-SharePoster/app.js';
- import { getSharePoster } from '@/shopro/poster/QS-SharePoster/QS-SharePoster.js';
- export default {
- components: {},
- data() {
- return {
- poster: {},
- canvasId: 'qrcode_img',
- qrcode: '', //核销总码
- qrcodeList: [], //核销码列表
- storeInfo: {}, //自提点信息
- qrcodepath: '', //单核销码
- allqrcodepath: '', //总核销码
- autosendList: [], //自动发货列表。
- itemDetail: {}, //订单商品详情
- expressType: 'express',
- barTitle: {
- express: '物流快递',
- selfetch: '到店/自提',
- store: '商家配送',
- autosend: '自动发货'
- },
- showQrcode: false //二维码弹窗
- };
- },
- computed: {},
- onLoad() {
- this.expressType = this.$Route.query.expressType;
- uni.setNavigationBarTitle({
- title: this.barTitle[this.expressType]
- });
- this.getItemGoodsDetail();
- },
- onPullDownRefresh() {
- this.getItemGoodsDetail();
- },
- methods: {
- jump(path, parmas) {
- this.$Router.push({
- path: path,
- query: parmas
- });
- },
- // 自提打开地图
- openStoreMap() {
- uni.openLocation({
- latitude: +this.storeInfo.latitude,
- longitude: +this.storeInfo.longitude,
- success: function() {
- console.log('success');
- },
- fail: err => {
- console.log(err);
- }
- });
- },
- // 跳转客服
- onService() {
- this.$tools.callPhone(this.itemDetail.store.phone);
- },
- // 查看核销码
- checkCode(code) {
- this.qrcode = code;
- this.shareFc('qrcode').then(res => {
- this.showQrcode = true;
- });
- },
- // 订单详情
- getItemGoodsDetail() {
- let that = this;
- that.$http('order.itemDetail', {
- id: that.$Route.query.orderId,
- order_item_id: that.$Route.query.orderItemId,
- type: 'dispatch'
- }).then(res => {
- uni.stopPullDownRefresh();
- if (res.code === 1) {
- that.itemDetail = res.data;
- that.qrcodeList = res.data.verify;
- that.storeInfo = res.data.store;
- if (res.data.ext_arr.autosend_content && res.data.ext_arr.autosend_type == 'params') {
- that.autosendList = JSON.parse(res.data.ext_arr.autosend_content);
- }
- if (that.expressType == 'selfetch') {
- let _arr = [];
- that.qrcodeList.forEach(code => {
- _arr.push(code.code);
- });
- that.qrcode = _arr.join(',');
- if (that.qrcodeList.length) {
- that.shareFc();
- }
- }
- }
- });
- },
- // 绘制二维码
- async shareFc(type) {
- let that = this;
- try {
- console.log('准备生成:' + new Date());
- const d = await getSharePoster({
- _this: this, //若在组件中使用 必传
- posterCanvasId: this.canvasId, //canvasId
- delayTimeScale: 20, //延时系数
- drawDelayTime: 500, //draw延时时间
- background: {
- width: 100,
- height: 100,
- backgroundColor: '#fff'
- },
- drawArray: ({ bgObj, type, bgScale }) => {
- return new Promise((rs, rj) => {
- rs([
- {
- type: 'qrcode',
- text: this.qrcode,
- size: bgObj.width,
- dx: 0,
- dy: 0,
- correctLevel: 1
- }
- ]);
- });
- },
- setCanvasWH: ({ bgObj, type, bgScale }) => {
- // 为动态设置画布宽高的方法,
- this.poster = bgObj;
- }
- });
- if (type == 'qrcode') {
- this.qrcodepath = d.poster.tempFilePath;
- } else {
- this.allqrcodepath = d.poster.tempFilePath;
- }
- } catch (e) {
- _app.hideLoading();
- _app.showToast(JSON.stringify(e));
- }
- }
- }
- };
- </script>
- <style lang="scss">
- // 二维码
- .hideCanvasView {
- position: relative;
- .hideCanvas {
- position: fixed;
- top: -99999upx;
- left: -99999upx;
- z-index: -99999;
- }
- }
- // 二维码弹窗
- .qr-code-modal {
- width: 610rpx;
- border-radius: 20rpx;
- background-color: #fff;
- margin: 0 auto;
- .qr-code-img {
- margin: 100rpx;
- width: 400rpx;
- height: 400rpx;
- }
- .qr-code-text {
- color: #999;
- font-size: 28rpx;
- }
- .hide-qrcode {
- width: 492rpx;
- line-height: 70rpx;
- background: linear-gradient(90deg, rgba(233, 180, 97, 1), rgba(238, 204, 137, 1));
- box-shadow: 0px 7rpx 6rpx 0px rgba(229, 138, 0, 0.22);
- border-radius: 35rpx;
- font-size: 28rpx;
- font-weight: 500;
- color: rgba(255, 255, 255, 1);
- margin: 30rpx;
- }
- }
- .content_box {
- padding: 20rpx;
- }
- .no-radius {
- border-radius: 0 !important;
- }
- .card-wrap {
- background-color: #fff;
- padding: 20rpx 20rpx 0;
- border-radius: 20rpx;
- }
- .order-card-box {
- height: 200rpx;
- border-bottom: 2rpx solid rgba(238, 238, 238, 0.6);
- .order-sku {
- font-size: 24rpx;
- font-weight: 400;
- color: rgba(153, 153, 153, 1);
- width: 450rpx;
- margin-bottom: 20rpx;
- .order-num {
- margin-right: 10rpx;
- }
- }
- .card-price-box {
- .status-btn {
- height: 32rpx;
- border: 1rpx solid rgba(207, 169, 114, 1);
- border-radius: 15rpx;
- font-size: 20rpx;
- font-weight: 400;
- color: rgba(168, 112, 13, 1);
- padding: 0 10rpx;
- margin-left: 20rpx;
- background: rgba(233, 183, 102, 0.16);
- }
- .order-price {
- font-size: 26rpx;
- font-weight: 600;
- color: rgba(51, 51, 51, 1);
- }
- }
- }
- .qr-code--img {
- width: 200rpx;
- height: 200rpx;
- }
- .detail-item {
- background: rgba(255, 255, 255, 1);
- border-radius: 20rpx;
- width: 100%;
- .item-title {
- font-size: 28rpx;
- font-weight: bold;
- color: rgba(51, 51, 51, 1);
- height: 60rpx;
- }
- .item-content {
- font-size: 26rpx;
- font-weight: 400;
- color: rgba(51, 51, 51, 1);
- line-height: 50rpx;
- }
- .item-status {
- font-size: 26rpx;
- font-weight: 400;
- color: rgba(179, 132, 54, 1);
- }
- .item-tip {
- font-size: 24rpx;
- font-weight: 400;
- color: rgba(196, 196, 196, 1);
- }
- .check-code {
- background: none;
- border-radius: 25rpx;
- border: 1rpx solid rgba(179, 132, 54, 1);
- padding: 0;
- width: 100rpx;
- line-height: 50rpx;
- font-size: 28rpx;
- color: rgba(179, 132, 54, 1);
- }
- .location-box {
- height: 100%;
- justify-content: center;
- position: relative;
- &::before {
- content: '';
- width: 2rpx;
- height: 94rpx;
- background: #eeeeee;
- position: absolute;
- top: 50%;
- transform: translateY(-50%);
- left: 0;
- }
- .location-icon {
- color: #4fbbff;
- margin-bottom: 20rpx;
- }
- .location-text {
- color: #999;
- font-size: 26rpx;
- }
- }
- }
- .service-btn {
- padding: 0;
- width: 710rpx;
- line-height: 80rpx;
- background: linear-gradient(90deg, rgba(233, 180, 97, 1), rgba(238, 204, 137, 1));
- box-shadow: 0px 7rpx 6rpx 0px rgba(229, 138, 0, 0.22);
- border-radius: 40rpx;
- font-size: 30rpx;
- font-weight: 500;
- color: rgba(255, 255, 255, 1);
- }
- </style>
|