| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746 | <template>	<view class="">		<view class="" @touchmove.stop.prevent="a = false" @catchtouchmove="a = false" v-show="!loadFlag">			<view class="" style="">				<swiper style="height: 100vh;width: 100vw;" :circular="true" @change="swiperChange" :current="activeCurrent">					<swiper-item v-for="(item,index) in detail.images" :key="index">						<image :src="item" @click="cssClick" style="height: 100vh;width: 100vw;display: flex;" mode="aspectFill"></image>					</swiper-item>				</swiper>			</view>			<view class="bottom" :class="cssTran ? 'closeCss' : 'openCss'" v-if="!loadFlag">				<view class="num">{{indexCurrent}} / {{detail.imageslength}}</view>				<view class="nav-box">					<view class="nav-tab" @click="backClick">						<image style="width: 50upx; height: 50upx;" :src="staticUrl+'back.png'"></image>						<text style="font-size: 24upx;">返回</text>					</view>					<view class="nav-tab" @click="collectClick()">						<image style="width: 50upx; height: 50upx;" :src="isColl?staticUrl+'coll_art.png':staticUrl+'coll.png'"></image>						<text style="font-size: 24upx;">{{isColl?'已收藏':'收藏'}}</text>					</view>					<view class="nav-tab" @click="winClick(detail._id)">						<image style="width: 50upx; height: 50upx;" :src="staticUrl+'duihuan.png'"></image>						<text style="font-size: 24upx;">下载</text>					</view>					<view class="nav-tab" @click="zanClick()">						<image style="width: 50upx; height: 50upx;" :src="isZan?staticUrl+'zan_art.png':staticUrl+'zan.png'"></image>						<text style="font-size: 24upx;">{{isZan?'已点赞':'点赞'}}</text>					</view>					<view class="nav-tab">						<image style="width: 50upx; height: 50upx;" :src="staticUrl+'shares.png'"></image>						<text style="font-size: 24upx;">分享</text>											</view>				</view>			</view>			<!-- <view v-if="tipsShow" style="position: absolute;top: 0;left: 0;width: 100vw;height: 100vh;z-index: 11;" @click="tipsClick">				<image src="../../static/tips.png" style="width: 100%;height: 100%;display: flex;" mode="aspectFill"></image>			</view> -->		</view>		<view class="loading_page" v-show="loadFlag"></view>		<pop  		    ref="pop" 		    direction="center" 		    :is_close="true" 		    :is_mask="true" 		    :width="90"  		    height="fit-content" 		    :maskFun="true" 		    @watchOpen="watchOpen" 		    @watchClose="watchClose"		>		<view>			<text class="ffdfgg" v-if="detail.isplay>0" @click="opdownloadFile()">下载</text>			<text class="ffdfgg" v-else @click="duihss()">¥{{price}} 兑换下载</text>			<!-- #ifdef MP-WEIXIN -->			<text class="ffdfgg" @click="adClick()">看广告获取积分</text>			<!-- #endif -->		</view>		</pop>	</view></template><script>import pop from "@/components/ming-pop/ming-pop.vue";let videoAd = null;var w = uni.getSystemInfoSync().windowWidth;var h = uni.getSystemInfoSync().windowHeight;export default {	components: {		pop	},	data() {		return {			loadFlag: true,			loginShow: false,			detail: {},			staticUrl:'',			adIntegral: 0,			downShow: false,			downIntegral: 0,			downTitle: '',			downBtn: '',			adShow: false,						isColl: false,			isZan: false,			zanStatus: true,			collStatus: true,						cssTran: false,			indexCurrent: 1,			activeCurrent: 0,						id: 0,			mid: 0,			isplaytext:'',			price:0,						signShow: false,			signTitle: '',			w: w,			h: h,		}	},	onLoad(e) {		this.staticUrl=this.configs.staticUrl		var that = this		var index =0		that.indexCurrent = parseInt(index)+1		that.activeCurrent = parseInt(index)		that.loadFlag = false		if(e.id){			this.id=e.id			this.getinfo(this.id)		}	},	onShow() {		// #ifdef APP-PLUS		plus.navigator.setFullscreen(true); 		// #endif	},	onHide() {		// #ifdef APP-PLUS		plus.navigator.setFullscreen(false); 		// #endif 	},	onUnload(){		// #ifdef APP-PLUS		plus.navigator.setFullscreen(false); 		// #endif 	},	methods: {				getinfo(id) {			uni.showLoading({			    title: '加载中'			});			let data = {};			data.id=id			data.mid=this.mid			if(uni.getStorageSync("userinfo").token){				data.token=uni.getStorageSync("userinfo").token				this.isLogin = true			}			uni.request({				url: this.configs.webUrl+'/api/video/infotp',				data: data,				success: data => {						uni.hideLoading();						if(uni.getStorageSync("userinfo").token){							if(data.data.isvip>1){								this.price=data.data.vipprice							}else{								this.price=data.data.price							}						}else{							this.price=data.data.price						}						data.data.pricebuy=this.price						//this.info=[];												//this.info=data.data						this.detail = data.data						this.adLoad()						if(data.data.isvip>1){							if(data.data.vipprice*1==0){								this.isplaytext='VIP免费'							}						}else{							if(data.data.price*1==0){								this.isplaytext='免费视频'							}						}				},				fail: (data, code) => {					uni.hideLoading();				}			});		},		async getIsZan(){			let count = await uniCloud.callFunction({				name: 'query_count',				data: {					dbName: "wx_cover",					filter: {						"_id": this.detail._id,						"zan.user_id": this.vuex_user._id					}				},			})			this.zanStatus = false			if(count.result > 0) this.isZan = true		},		async getIsColl(){			let count = await uniCloud.callFunction({				name: 'query_count',				data: {					dbName: "wx_cover",					filter: {						"_id": this.detail._id,						"coll.user_id": this.vuex_user._id					}				},			})			this.collStatus = false			if(count.result > 0) this.isColl = true		},		opdownloadFile(){			var that=this			uni.showLoading({				title: '正在保存图片'			});			// 获取图片信息			var url = that.detail.images[that.indexCurrent-1]			var extension = url.substring(url.lastIndexOf('.') + 1)			let fileName = new Date().valueOf();			console.log(url)			uni.downloadFile({				url: url,				//filePath: wx.env.USER_DATA_PATH + '/' + fileName + '.' + extension,				success: (res) => {					var benUrl = res.tempFilePath					console.log(res)					//图片保存到本地相册					uni.saveImageToPhotosAlbum({						filePath: benUrl,						//授权成功,保存图片						success: function(data) {							uni.hideLoading()							uni.showModal({								title: '温馨提示',								content: '保存成功',								showCancel: false,								success(res) {									if (res.confirm) {																			}								}							});						},						//授权失败						fail: function(err) {							if (err.errMsg) {								console.log(err.errMsg)								//重新授权弹框确认								uni.showModal({									title: '提示',									content: '无权限,请打开下载权限后再试!',									showCancel: false,									success(res) {										if (res.confirm) {											//重新授权弹框用户点击了确定											uni.openSetting({												//进入小程序授权设置页面												success(settingdata) {													if (settingdata.authSetting['scope.writePhotosAlbum']) {														//用户打开了保存图片授权开关														uni.saveImageToPhotosAlbum({															filePath: benUrl,															success: function(data) {																uni.hideLoading()																that.adShow = true															}														});													} else {														//用户未打开保存图片到相册的授权开关														uni.showModal({															title: '温馨提示',															content: '授权失败,请稍后重新获取',															showCancel: false														});													}												}											});										}									}								});							}							uni.hideLoading()						}					});				},				fail: (error) => {					console.log(error)				}			})		},		winClick(){			if(uni.getStorageSync("userinfo").id){							}else{				uni.showModal({					title: '温馨提示',					content: '请先登后下载',					showCancel: true,					confirmText: "确定",					success: function (res) {						if (res.confirm) {							uni.navigateTo({								url:'/pages/login/login'							})						} else if (res.cancel) {													}					}				});				return false;			} 			var that = this			var downIntegral=2			if(this.detail.isplay == 0){				this.$refs.pop.show();			}else{				this.opdownloadFile()			}		},		backClick(){			uni.navigateBack()		},		collectClick() {			this.isColl=true			uni.showToast({				icon: 'none',				title: '收藏成功',				mask: true,				duration: 1000			})		},		zanClick(){			this.isZan=true			uni.showToast({				icon: 'none',				title: '点赞成功',				mask: true,				duration: 1000			})		},		cssClick() {			this.cssTran = !this.cssTran		},		swiperChange(e){			this.indexCurrent = e.detail.current + 1		},		adClick(){			var mrcs=3			var mrcsjr=0			if(uni.getStorageSync("config").mrcs && uni.getStorageSync("config").mrcsjr){				mrcs=uni.getStorageSync("config").mrcs				mrcsjr=uni.getStorageSync("config").mrcsjr			}			if(mrcsjr>=mrcs){				uni.showModal({					title: '温馨提示',					content: '每日只能看'+mrcs+'次',					showCancel: false,					confirmText: "确定",					success: function (res) {						if (res.confirm) {							//_this.dyxx()							//uni.navigateBack();						} else if (res.cancel) {													}					}				});				return false;			}			var that = this			if (videoAd) {				videoAd.show().catch(err => {				// 失败重试				// console.log("广告拉去失败")					videoAd.load().then(() => videoAd.show())				})			}		},		adLoad(){			console.log(this.detail.videoids);			var that = this			if (wx.createRewardedVideoAd) {				// 加载激励视频广告				// #ifdef MP-QQ				videoAd = wx.createRewardedVideoAd({					adUnitId: "cbe2baa6cdb9b4f2c75269d000476ee6"				});				// #endif				// #ifdef MP-WEIXIN				videoAd = wx.createRewardedVideoAd({					adUnitId: that.detail.videoids//微信广告ID				});				// #endif				//捕捉错误				videoAd.onError(err => {					// 进行适当的提示					console.log('videoAd onError', err);				});				// 监听关闭				videoAd.onClose(status => {					that.downShow = false					if ((status && status.isEnded) || status === undefined) {						// 正常播放结束,下发奖励						that.admoney()						console.log('看完广告')					} else {						uni.showToast({							icon: 'none',							title: '播放中途退出,获取失败',							mask: true,							duration: 1000						})						// 播放中途退出,进行提示						console.log('中途退出')					}				});			}		},		async userIntegral(){			var that = this			uni.showLoading({				mask: true,				title: '加载中...'			})			let data = await uniCloud.callFunction({				name: 'user_integral',				data: {					userId: that.vuex_user._id				},			})			uni.hideLoading()			if(data.result.success){				that.getUser()				that.signTitle = "<p style='font-weight: 550;font-size: 16px;'>观看成功</p><p style='padding-top: 10px;'>获得<span class='num'>"+data.result.integral+"</span>积分</p>"				that.signShow = true			}		},		watchOpen(){},		watchClose(){},		async admoney(){			var this_=this			let data = {};			if(uni.getStorageSync("userinfo").token){				data.token=uni.getStorageSync("userinfo").token			}			let [err,res] =await this.$httpas.get('/api/user/admoney',data);			if (!this.$httpas.errorCheck(err,res)) return;			if(res.data.code === 1){				uni.setStorage({//缓存配置信息					key: 'config',  					data: res.data.data				})				uni.showModal({					title: '温馨提示',					content: '获取成功 是否马上兑换',					showCancel: true,					confirmText: "兑换",					success: function (ress) {						if (ress.confirm) {							this_.duihss()						} else if (ress.cancel) {													}					}				});			}else{				uni.showToast({ title: '获取失败',icon:"none" });			}		},		duihss(){			var this_=this			let data=this.detail;			data.sum=1;			data.buytype='余额';			data.lx=1;//1 全章购买 2单集购买			data.smid=0;			data.namet=data.name			data.pricebuy=data.price			data.token = uni.getStorageSync("userinfo").token;			data.uid = uni.getStorageSync("userinfo").id; 			console.log(data);			//return false;			uni.request({				url: this.configs.webUrl+'/api/pay/videopay',				data: data,				success: resa =>{					//console.log(resa.data);					if(data.buytype=='微信'){						if(this.wxlx=='wxxcx' && resa.data.code==1){							//console.log(resa.data.code);							this.wxxcx(resa.data.data);						}else{							// #ifdef APP-PLUS														uni.navigateTo({								url:'/pages/client/webva?url='+resa.data.data							})							//plus.runtime.openURL(res.data.data);							// #endif  							// #ifdef H5							window.open(resa.data.data, "_self")							// #endif 						}					}else if(data.buytype=='余额'){						if(resa.data.code==1){							//pages/user/task/task							uni.showModal({								title: '提示',								content: '兑换成功',								showCancel: false,								success: res => {									this_.getinfo(this.id)									this_.$refs.pop.close(); 									this_.opdownloadFile()																	}							});						}else{							if(resa.data.msg=='余额不足'){								uni.showModal({									title: '提示',									content: '余额不足,看广告可以获取',									showCancel: true,									confirmText: "看广告",									success: res => {										this_.adClick()									}								});							}else{								uni.showModal({									title: '提示',									content: resa.data.msg,									showCancel: false,									success: res => {										uni.navigateBack();										}								});							}						}					}					//thia.okPay(resa)				},				fail: (data, code) => {					console.log('fail' + JSON.stringify(data));				}			});		},		// 登录		getUserInfo(){			var that = this			wx.getUserProfile({			  desc: '更新您的个人信息',			  success: (res) => {				  that.name = res.userInfo.nickName; //昵称				  that.avatar = res.userInfo.avatarUrl; //头像				  // 成功后进行登录,获取code				  that.wxlogin();			  },			  fail(err){				  uni.showToast({				  	icon: 'none',				  	title: '授权失败',				  	duration: 1500				  })			  }			})		},		//已经授权,自动登录		async wxlogin() {			let that = this;			uni.showLoading({				title: '登录中...'			});			uni.login({				provider: 'weixin',				success: function(loginRes) {					let code = loginRes.code;					that.wxloginres(code);				},			});		},		//登录后提交服务器获取进一步信息		async wxloginres(wxcode) {			let that = this;			var userId = uni.getStorageSync('userId')			var mptype			// #ifdef MP-WEIXIN				mptype = 'wx'			// #endif			// #ifdef MP-QQ				mptype = 'qq'			// #endif						let authorize = await uniCloud.callFunction({				name: 'user_authorize',				data: {					name: that.name,					avatar: that.avatar,					mptype: mptype,					code: wxcode,					userId: userId,				},			})			if(authorize.result.success){				that.$u.vuex('vuex_user',authorize.result.data)				// 登陆成功  获取收藏点赞				that.getIsZan()				that.getIsColl()				uni.showToast({					icon: 'none',					mask: true,					title: '登录成功',					duration: 1500				})				uni.removeStorageSync('userId')			}else{				uni.showToast({					icon: 'none',					mask: true,					title: authorize.result.msg,					duration: 1500				})			}			that.loginShow = false		},	},	onShareAppMessage(res) {		var that = this		setTimeout(function(){			that.adShow = false		},2000)		return {			title: '送你一张超级好看的壁纸~',			imageUrl: that.detail.images[that.indexCurrent-1],			path: '/pages/index/index?userId='+that.vuex_user._id+'&detailId='+that.detail._id+'&index='+(that.indexCurrent-1)		}	},	onShareTimeline(res) {		return {			title: '我等风也等你,近听水无声~',			imageUrl: '/static/share_bg.jpg',			path: '/pages/index/index'		}	}}</script><style lang="scss">	.bottom {		position: fixed;		left: 4%;		right: 0;		width: 92%;		height: 52px;		box-shadow: 0 0px 8px rgba(0, 0, 0, 0.06);		background: rgba(0, 0, 0, 0.94);		border-radius: 49px;		z-index: 10;		opacity: 0.8;		.num{			position: absolute;			top: -20rpx;			top: -70rpx;			left: 44%;			background: rgba(0,0,0,0.6);			color: #FFF;			padding: 4rpx 20rpx;			font-size: 12px;			border-radius: 36px;		}	}	.nav-tab {		position: relative;		width: 100%;		height: 52px;		font-size: 12px;		color: #D8D8D8;		font-weight: 400;		display: flex;		flex-direction: column;		justify-content: center;		align-items: center;	}	.nav-box {		/* position: absolute; */		display: flex;		flex-direction: row;		justify-content: space-around;		width: 100%;		box-sizing: border-box;	}	.openCss {		animation-name: openLinear;		animation-duration: 0.8s;		animation-iteration-count: 1;		bottom: 40px;	}	@keyframes openLinear {		0% {			transform: translateY(92px);		}		100% {			transform: translateY(0px);		}	}	.closeCss {		animation-name: closeLinear;		animation-duration: 0.8s;		animation-iteration-count: 1;		bottom: -52px;	}	.ffdfgg{		font-size: 28upx; 		text-align: center; 		height: 100upx; 		line-height: 100upx; 		display: block;		background: #00C657;		color: #fff;		border-radius: 10upx;		margin-top: 20upx;	}	@keyframes closeLinear {		0% {			transform: translateY(-92px);		}		100% {			transform: translateY(0px);		}	}		.u-indicator-item-number {		padding: 6rpx 16rpx;		line-height: 1;		background-color: rgba(0, 0, 0, 0.3);		border-radius: 100rpx;		font-size: 26rpx;		color: rgba(255, 255, 255, 0.8);	}</style>
 |