<template>
	<view class="content">
		<view class="box">
			<view class="title flex">
				<view class="title-font">分享文案</view>
				<view class="title-btn" @click="comfirm()">复制文案</view>
			</view>
			<view class="box-info">
				<view class="info-title">{{ info.title }}</view>
				<view class="info-tip">{{ info.comment }}</view>
				<view class="info-url">{{ url }}</view>
			</view>
			<view class="title flex" style="margin-top: 20rpx;">
				<view class="title-font">
					分享素材
					<text>(已选{{ nowlen }}/{{ alllen }})</text>
				</view>
			</view>
			<view class="image-box">
				<view class="image-item" v-for="(item, index) in imageBox" @click="change(item)">
					<image :src="item.url" mode=""></image>
					<view class="isxuan" v-if="item.isxuan"></view>
				</view>
			</view>
		</view>
		<view class="btn" @click="onDown()">下载</view>
	</view>
</template>

<script>
import sunuiGrand from '@/components/sunui-grand/sunui-grand.vue';
import { reply_detail, short_link } from '@/api/activity.js';
import uniCopy from '@/js_sdk/xb-copy/uni-copy.js';
export default {
	data() {
		return {
			info: {},
			url: '',
			imageBox: [],
			alllen: '',
			nowlen: ''
		};
	},
	components: {
		sunuiGrand
	},
	onLoad(opt) {
		this.id = opt.id;
	},
	onShow() {
		this.imageBox = [];
		this.loadData();
	},
	onReachBottom() {},
	onReady() {},
	methods: {
		loadData() {
			const obj = this;
			reply_detail({}, this.id).then(({ data }) => {
				data.pics.forEach(e => {
					let u = {
						isxuan: true,
						url: e
					};
					obj.imageBox.push(u);
				});
				this.alllen = obj.imageBox.length;
				this.nowlen = obj.imageBox.length;
				this.info = data;
			});
			short_link({ url: 'pages/zc/plDetail?id=' + this.id }).then(({ data }) => {
				console.log(data);
				this.url = data.link;
			});
		},
		change(opt) {
			if (opt.isxuan) {
				opt.isxuan = false;
				this.nowlen -= 1;
			} else {
				opt.isxuan = true;
				this.nowlen += 1;
			}
		},
		comfirm() {
			let text = this.info.comment + this.url;
			const result = uniCopy(text);
			if (result === false) {
				uni.showToast({
					title: '不支持'
				});
			} else {
				uni.showToast({
					title: '复制成功',
					icon: 'none'
				});
			}
		},
		onDown() {
			let that = this;
			let index = 0;
			let list = [];
			that.imageBox.forEach(e => {
				if (e.isxuan) {
					list.push(e.url);
				}
			});
			// console.log('触发下载图片');
			// 第一步,先调用授权功能
			uni.authorize({
				scope: 'scope.writePhotosAlbum',
				success() {
					// 1 授权成功遍历所有要下载的图片
					if (list && list.length > 0) {
						// console.log(that.pathList, '============查看有没有图片数据=============>');
						let i = 1;
						list.forEach(item => {
							// 1.1 调用下载api方法
							uni.showLoading({
								title: '下载第' + i + '图片中,共' + list.length + '张'
							});
							uni.downloadFile({
								url: item, // 获取要下载的服务器里的图片地址
								success: res => {
									// 1.2 获取远程图片地址后,将图片地址缓存到本地
									if (res.statusCode === 200) {
										// console.log(res, '============下载后的图片地址=============>');
										uni.saveImageToPhotosAlbum({
											filePath: res.tempFilePath, // 把远程的图片地址及图片保存到本地
											success: function(res) {
												// 1.3保存成功后弹框提示保存成功
												i += 1;
												uni.showToast({
													title: '保存成功',
													icon: 'none'
												});
											},
											fail: function(res) {
												// console.log(res, '============fail=============>');
												// 1.4保存失败给用户弹框提示
												uni.showToast({
													title: '保存失败',
													icon: 'none'
												});
												if (res.errMsg == 'saveImageToPhotosAlbum:fail cancel') {
													return;
												}
											}
										});
									}
								}
							});
						});
					} else {
						uni.showToast({
							title: '暂无数据',
							icon: 'none'
						});
					}
				},
				fail() {
					// 2、授权失败 弹框再次要求授权
					uni.showModal({
						title: '您需要授权相册权限',
						success(res) {
							// 2.1点击确认按钮就调取授权设置页面
							if (res.confirm) {
								// 2.2 开启授权设置页面
								uni.openSetting({
									success(res) {},
									fail(res) {}
								});
							}
						}
					});
				}
			});
		}
	}
};
</script>

<style lang="scss">
page,
.content {
	min-height: 100%;
	height: auto;
	background: #f8f8f8;
}
.box {
	width: 730rpx;
	margin: 20rpx auto 0;
	border-radius: 20rpx;
	background: #ffffff;
	padding: 20rpx;
	.title {
		.title-font {
			font-size: 32rpx;
			font-family: PingFang SC;
			font-weight: 800;
			color: #303030;
			text {
				display: inline-block;
				margin-left: 10rpx;
				color: #999999;
				font-size: 28rpx;
				font-family: PingFang SC;
				font-weight: 500;
			}
		}
		.title-btn {
			width: 150rpx;
			height: 50rpx;
			display: flex;
			justify-content: center;
			align-items: center;
			border: 1px solid #e66f6f;
			border-radius: 30rpx;
			color: #e66f6f;
		}
	}
	.box-info {
		background: #f6f6f6;
		width: 700rpx;
		padding: 20rpx;
		margin: 20rpx auto 0;
		.info-title {
			font-size: 28rpx;
			font-family: PingFang SC;
			font-weight: 800;
			color: #303030;
		}
		.info-tip {
			font-size: 26rpx;
			font-family: PingFang SC;
			font-weight: 500;
			color: #303030;
		}
		.info-url {
			margin-top: 20rpx;
			font-size: 26rpx;
			font-family: PingFang SC;
			font-weight: 500;
			color: #666666;
		}
	}
	.image-box {
		margin-top: 20rpx;
		display: flex;
		align-items: center;
		flex-wrap: wrap;
		.image-item {
			margin: 10rpx;
			position: relative;
			width: 33%;
			height: 300rpx;
			.isxuan {
				position: absolute;
				top: 20rpx;
				right: 20rpx;
				width: 30rpx;
				height: 30rpx;
				border-radius: 50%;
				background: #e04b4b;
			}
			image {
				width: 100%;
				height: 100%;
			}
		}
	}
}
.btn {
	margin: 0 auto;
	position: fixed;
	bottom: 20rpx;
	left: 0;
	right: 0;
	width: 710rpx;
	height: 80rpx;
	display: flex;
	justify-content: center;
	align-items: center;
	background: #e04b4b;
	color: #ffffff;
	font-size: 26rpx;
	font-family: PingFang SC;
	font-weight: 500;
	border-radius: 50rpx;
}
</style>