Browse Source

直接弹出分享

yuxingxing 2 years ago
parent
commit
236bf20f12
2 changed files with 97 additions and 23 deletions
  1. 46 12
      pages/index/diy/index_mall.vue
  2. 51 11
      pages/users/user_invoice_list/index.vue

+ 46 - 12
pages/index/diy/index_mall.vue

@@ -21,12 +21,14 @@
 				<view class="grid-box">
 					<view class="grid-group">
 						<view class="grid-item">
-							<image src="../../../static/menus/miaosha.png" mode="aspectFit" @click="menusTap('共富1580', 8)">
+							<image src="../../../static/menus/miaosha.png" mode="aspectFit"
+								@click="menusTap('共富1580', 8)">
 							</image>
 							<text>共富1580</text>
 						</view>
 						<view class="grid-item">
-							<image src="../../../static/menus/hongbao.png" mode="aspectFit" @click="menusTap('红包商城', 3)">
+							<image src="../../../static/menus/hongbao.png" mode="aspectFit"
+								@click="menusTap('红包商城', 3)">
 							</image>
 							<text>红包商城</text>
 						</view>
@@ -36,12 +38,14 @@
 							<text>积分专区</text>
 						</view>
 						<view class="grid-item">
-							<image src="../../../static/menus/chuangke.png" mode="aspectFit" @click="menusTap('创客专区', 4)">
+							<image src="../../../static/menus/chuangke.png" mode="aspectFit"
+								@click="menusTap('创客专区', 4)">
 							</image>
 							<text>创客专区</text>
 						</view>
 						<view class="grid-item">
-							<image src="../../../static/menus/chengshihehuoren.png" mode="aspectFit" @click="menusTap('城市合伙人', 5)">
+							<image src="../../../static/menus/chengshihehuoren.png" mode="aspectFit"
+								@click="menusTap('城市合伙人', 5)">
 							</image>
 							<text>城市合伙人</text>
 						</view>
@@ -108,7 +112,8 @@
 			<view class="tab-content" v-show="current >= 1">
 				<!-- 轮播 -->
 				<view class="swiper-group">
-					<u-swiper :list="swiperTabList.length == 0?swiperList:swiperTabList" indicator indicatorMode="line" circular></u-swiper>
+					<u-swiper :list="swiperTabList.length == 0 ? swiperList : swiperTabList" indicator
+						indicatorMode="line" circular></u-swiper>
 				</view>
 				<!-- 商品列表 -->
 				<goodListMall @changeTab="changeTab" :iSshowH="true" @detail="goDetail" :currentId="currentId"
@@ -127,7 +132,10 @@ import {
 import {
 	mapGetters
 } from "vuex";
-import { getAdsList, getNoticeList, getCategoryOne, getGoodsPage, getIndexData, getGoodsInfo } from '../../../api/home.js'
+import {
+	getAdsList, getNoticeList, getCategoryOne,
+	getGoodsPage, getIndexData, getGoodsInfo
+} from '../../../api/home.js'
 import {
 	goShopDetail
 } from '@/libs/order.js';
@@ -142,6 +150,11 @@ export default {
 			noticeShow: false,
 			noticeContent: '',
 			tempArr: [],
+			where: {
+				zoneType: 8,
+				current: 1,
+				size: 20,
+			},
 			tempArrBao: [
 				{
 					"id": 72,
@@ -706,15 +719,15 @@ export default {
 		}
 	},
 	methods: {
-		pullResh(){
-			if(this.current == 0){
+		pullResh() {
+			if (this.current == 0) {
 				uni.showLoading({ title: '刷新中' });
 				this.getNoticeList()
 				this.getAdsList()
 				this.getBroGoodsInfo()
 				this.getAdsTabList()
 				this.getGoodsInfo()
-			}else{
+			} else {
 				this.$refs.goodTablist.getGoodsPage()
 			}
 		},
@@ -750,15 +763,36 @@ export default {
 			})
 		},
 		menusTap(url, zoneType) {
+			let that = this
 			// #ifdef H5
 			location.href = url
 			// #endif
 			// #ifdef MP || APP-PLUS
-			uni.navigateTo({
-				url: "/pages/goods/goods_list_mall/index?zoneType=" + zoneType + "&title=" + url
-			});
+			if (zoneType == 8) {
+				//共富取消中间过渡界面
+				getGoodsInfo(that.where).then(res => {
+					let list = res.data;
+					if (that.where.zoneType == 8 && list.length == 1) {
+						// 自动跳转共富1580商品详情
+						that.godDetail(list[0])
+					}
+				})
+			} else {
+				uni.navigateTo({
+					url: "/pages/goods/goods_list_mall/index?zoneType=" + zoneType + "&title=" + url
+				});
+			}
 			// #endif
 		},
+		// 去详情页
+		godDetail(item) {
+			goShopDetail(item, this.uid).then(res => {
+				uni.navigateTo({
+					url: `/pages/goods_details/index?id=${item.id}`
+						+ "&zoneType=" + item.zoneType
+				})
+			})
+		},
 		noticeClose() {
 			this.noticeShow = false
 		},

+ 51 - 11
pages/users/user_invoice_list/index.vue

@@ -48,20 +48,22 @@
 				<image :src="imgHost + '/statics/images/noInvoice.png'"></image>
 				<view>{{ $t(`没有消费商信息哟~`) }}</view>
 			</view> -->
-			<navigator class="add-link" :url="`/pages/goods/goods_list_mall/index?zoneType=8&title=共富1580`">
+			<!-- <button v-if="isGongFu" class="add-link" :url="`/pages/goods_details/index?id=${gongFuId}&zoneType=8`">
+				{{ $t(`邀请用户立即参与`) }}</button> -->
+			<button v-if="isGongFu" class="add-link" open-type="share">
+				{{ $t(`邀请用户立即参与`) }}</button>
+			<navigator v-else class="add-link" :url="`/pages/goods/goods_list_mall/index?zoneType=8&title=共富1580`">
 				{{ $t(`邀请用户立即参与`) }}</navigator>
 		</view>
 		<view v-show="(nav === 3)">
 			<view class="list-nav3">
-				<u-empty
-						mode="permission"
-						text="您还未参与共富1580"
-						icon="http://cdn.uviewui.com/uview/empty/permission.png"
-						:height="600"
-				>
+				<u-empty mode="permission" text="您还未参与共富1580" icon="http://cdn.uviewui.com/uview/empty/permission.png"
+					:height="600">
 				</u-empty>
 			</view>
-			<navigator class="add-link" :url="`/pages/goods/goods_list_mall/index?zoneType=8&title=共富1580`">
+			<navigator v-if="isGongFu" class="add-link" :url="`/pages/goods_details/index?id=${gongFuId}&zoneType=8`">
+				{{ $t(`立即参与`) }}</navigator>
+			<navigator v-else class="add-link" :url="`/pages/goods/goods_list_mall/index?zoneType=8&title=共富1580`">
 				{{ $t(`立即参与`) }}</navigator>
 		</view>
 		<!-- #ifndef MP -->
@@ -83,7 +85,9 @@ import {
 } from '@/api/user.js';
 import {
 	postStatistics,
-	linkedBindLogList
+	linkedBindLogList,
+	getGoodsInfo,
+	postLinkedUrl
 } from '@/api/home.js';
 import {
 	orderInvoiceList
@@ -138,11 +142,20 @@ export default {
 			nav: 1, // 1:发票记录 2:抬头管理
 			page: 1,
 			limit: 300,
+			where: {
+				zoneType: 8,
+				current: 1,
+				size: 20,
+			},
 			loading: false,
 			finished: false,
 			specialInvoice: true,
+			storeInfo: {},
+			promotionShare: '',
+			isGongFu: true,
+			gongFuId: true,
 			qr_height: 200,
-			qr_width: 200
+			qr_width: 200,
 		};
 	},
 	watch: {
@@ -164,6 +177,17 @@ export default {
 		}
 	},
 	computed: mapGetters(['isLogin']),
+	/**
+	 * 用户点击右上角分享
+	 */
+	onShareAppMessage: function (res) {
+		let that = this;
+		return {
+			title: that.storeInfo.goodsName || "",
+			imageUrl: "http://wine.gzzzyd.com/test/static/img/bg.a82f9752.jpg" || that.storeInfo.image,
+			path: "/pages/goods_details/index?id=" + that.gongFuId + "&inviteCode=" + that.promotionShare,
+		};
+	},
 	onLoad(option) {
 		let that = this
 		if (option.from === 'invoice_form') {
@@ -201,6 +225,7 @@ export default {
 			}
 		},
 		getStatistics() {
+			let that = this
 			uni.showLoading({
 				title: this.$t(`加载中`)
 			});
@@ -225,7 +250,21 @@ export default {
 					}
 				}
 			});
-
+			getGoodsInfo(that.where).then(res => {
+				let list = res.data;
+				if (that.where.zoneType == 8 && list.length == 1) {
+					// 自动跳转共富1580商品详情参数准备
+					that.gongFuId = list[0].id
+					that.storeInfo = list[0]
+					that.isGongFu = true
+					// that.godDetail(list[0])
+				} else {
+					that.isGongFu = false
+				}
+			})
+			postLinkedUrl().then(res => {
+				this.promotionShare = res.data.promotionNo
+			})
 		},
 		// 菜单切换
 		navTab(nav) {
@@ -501,6 +540,7 @@ export default {
 .record-wrapper {
 	margin-top: 90rpx;
 	background-color: white;
+
 	.item {
 		padding-right: 30rpx;
 		padding-left: 30rpx;