!64 【新增】订阅消息:订单发货消息订阅

Merge pull request !64 from puhui999/master
pull/65/MERGE
芋道源码 2024-07-31 05:51:17 +00:00 committed by Gitee
commit 1b385d728a
No known key found for this signature in database
GPG Key ID: 173E9B9CA92EEF8F
3 changed files with 43 additions and 13 deletions

View File

@ -233,10 +233,6 @@
sheep.$store('cart').getList(); sheep.$store('cart').getList();
} }
// #ifdef MP
sheep.$platform.useProvider('wechat').subscribeMessage(SubscribeTemplate.DELIVERY_ORDER);
// #endif
// //
sheep.$router.redirect('/pages/pay/index', { sheep.$router.redirect('/pages/pay/index', {
id: data.payOrderId, id: data.payOrderId,

View File

@ -51,7 +51,7 @@
<!-- TODO 芋艿订阅 --> <!-- TODO 芋艿订阅 -->
<!-- #ifdef MP --> <!-- #ifdef MP -->
<view class="subscribe-box ss-flex ss-m-t-44"> <view class="subscribe-box ss-flex ss-m-t-44" v-if="showSubscribeBtn">
<image class="subscribe-img" :src="sheep.$url.static('/static/img/shop/order/cargo.png')" /> <image class="subscribe-img" :src="sheep.$url.static('/static/img/shop/order/cargo.png')" />
<view class="subscribe-title ss-m-r-48 ss-m-l-16">获取实时发货信息与订单状态</view> <view class="subscribe-title ss-m-r-48 ss-m-l-16">获取实时发货信息与订单状态</view>
<view class="subscribe-start" @tap="subscribeMessage"></view> <view class="subscribe-start" @tap="subscribeMessage"></view>
@ -63,12 +63,13 @@
<script setup> <script setup>
import { onLoad, onHide, onShow } from '@dcloudio/uni-app'; import { onLoad, onHide, onShow } from '@dcloudio/uni-app';
import { reactive, computed } from 'vue'; import { reactive, computed, ref } from 'vue';
import { isEmpty } from 'lodash'; import { isEmpty } from 'lodash';
import sheep from '@/sheep'; import sheep from '@/sheep';
import PayOrderApi from '@/sheep/api/pay/order'; import PayOrderApi from '@/sheep/api/pay/order';
import { fen2yuan } from '../../sheep/hooks/useGoods'; import { fen2yuan } from '@/sheep/hooks/useGoods';
import OrderApi from '@/sheep/api/trade/order'; import OrderApi from '@/sheep/api/trade/order';
import { SubscribeTemplate } from '@/sheep/util/const';
const state = reactive({ const state = reactive({
id: 0, // id: 0, //
@ -111,7 +112,16 @@
// 退 // 退
state.result = 'paid'; state.result = 'paid';
// #ifdef MP // #ifdef MP
subscribeMessage(); uni.showModal({
title: '支付结果',
showCancel: false, //
content: "支付成功",
success: () => {
// showModal
autoSubscribeMessage();
}
})
// #endif // #endif
// //
if (state.orderType === 'goods') { if (state.orderType === 'goods') {
@ -146,13 +156,33 @@
// TODO // TODO
// #ifdef MP // #ifdef MP
const showSubscribeBtn = ref(false) //
const SUBSCRIBE_BTN_STATUS_STORAGE_KEY = "subscribe_btn_status"
function subscribeMessage() { function subscribeMessage() {
let event = ['order_dispatched']; let event = [SubscribeTemplate.DELIVERY_ORDER];
if (state.tradeOrder.type === 3) { if (state.tradeOrder.type === 3) {
event.push('groupon_finish'); // TODO puhui999:
event.push('groupon_fail'); event.push('拼团成功');
event.push('拼团失败');
} }
sheep.$platform.useProvider('wechat').subscribeMessage(event); sheep.$platform.useProvider('wechat').subscribeMessage(event, () => {
//
uni.removeStorageSync(SUBSCRIBE_BTN_STATUS_STORAGE_KEY);
uni.setStorageSync(SUBSCRIBE_BTN_STATUS_STORAGE_KEY, '已订阅');
//
showSubscribeBtn.value = false;
});
}
async function autoSubscribeMessage() {
// 1.
const subscribeBtnStatus = uni.getStorageSync(SUBSCRIBE_BTN_STATUS_STORAGE_KEY);
if (!subscribeBtnStatus) {
showSubscribeBtn.value = true;
return
}
// 2.
subscribeMessage()
} }
// #endif // #endif

View File

@ -171,7 +171,7 @@ async function getSubscribeTemplate() {
} }
// 订阅消息 // 订阅消息
function subscribeMessage(event) { function subscribeMessage(event, callback= undefined) {
let tmplIds = []; let tmplIds = [];
if (typeof event === 'string') { if (typeof event === 'string') {
const temp = subscribeEventList.find(item => item.title.includes(event)); const temp = subscribeEventList.find(item => item.title.includes(event));
@ -191,6 +191,10 @@ function subscribeMessage(event) {
uni.requestSubscribeMessage({ uni.requestSubscribeMessage({
tmplIds, tmplIds,
success: ()=>{
// 不管是拒绝还是同意都触发
callback && callback()
},
fail: (err) => { fail: (err) => {
console.log(err); console.log(err);
}, },