jihuaqiang 3 rokov pred
rodič
commit
32d936e1ea

+ 194 - 18
components/MobileLandPage.vue

@@ -1,14 +1,69 @@
 <template>
 	<div class="mobile-land-page">
-		<div class="mobile-land-page-invited-info">
-			<img :src="detail.postBizData.postUserInfo.avatarUrl" class="invited-photo" />
-			<div class="invited-name">{{ detail.postBizData.postUserInfo.nickName }}</div>
-			<div class="invited-text">Send You Giveaway!</div>
+		<div class="mobile-land-page-invited-info" v-if="useFul && !isNFTCpd">
+			<img :src="userInfo.avatarUrl" class="invited-photo" />
+			<div class="invited-name">{{ userInfo.nickName }}</div>
+			<div class="invited-text">{{ isTreasureCpd ? 'Invite You to Hunt the Treasure' : 'Send You Giveaway!' }}</div>
+		</div>
+		<div class="mobile-land-page-icon-wrap">
+			<img class="mobile-land-page-icon" :src="iconCpd" />
 		</div>
-		<div class="mobile-land-page-icon">icon</div>
 		<div class="mobile-land-page-prize-info">
-			<template></template>
+			<template v-if="!useFul">
+				<div class="mobile-land-page-prize-info-test">
+					<!-- time-expired -->
+				</div>
+			</template>
+			<!-- 红包 -->
+			<template v-else-if="isCommonCpd">
+				<div class="mobile-land-page-prize-info-test">You are gifted an entries to earn</div>
+				<div class="mobile-land-page-prize-info-test">
+					<img v-if="!isCustomRewardCpd" class="icon" :src="currencyIconPath" />
+					<span class="pre-amount-value">{{ isCustomRewardCpd ? 1 : amountValue }}</span>
+					<span class="prize-name">{{ prize }}</span>
+					<span class="usd-amount" v-if="!isCustomRewardCpd"> (${{ usValue }})</span>
+				</div>
+			</template>
+			<!-- 抽奖 -->
+			<template v-else-if="isLottaryCpd">
+				<div class="mobile-land-page-prize-info-test">
+					You Won
+					<img v-if="!isCustomRewardCpd" class="icon" :src="currencyIconPath" />
+					<span class="pre-amount-value">{{ isCustomRewardCpd ? 1 : amountValue }}</span>
+					<FontZoom width="240" style="color: #000">
+						<span class="prize-name">{{ prize }}</span>
+					</FontZoom>
+					<span class="usd-amount" v-if="!isCustomRewardCpd"> (${{ usValue }})</span>
+				</div>
+				<div class="mobile-land-page-prize-info-test">in the Giveaway!</div>
+			</template>
+			<!-- 夺宝 -->
+			<template v-else-if="isTreasureCpd">
+				<div class="mobile-land-page-prize-info-test">Complete the quest to win</div>
+				<div class="mobile-land-page-prize-info-test">
+					<img class="icon" :src="currencyIconPath" />
+					<span class="pre-amount-value">{{ amountValue }}</span>
+					<span class="prize-name">{{ prize }}</span>
+					<span class="usd-amount"> (${{ usValue }})</span>
+					for you two!
+				</div>
+			</template>
+			<!-- NFT -->
+			<template v-else-if="isNFTCpd">
+				<div class="mobile-land-page-prize-info-test">
+					<span class="prize-name">{{ prize }}</span>
+					is in your
+				</div>
+				<div class="mobile-land-page-prize-info-test">DeNet NFT wallet!</div>
+			</template>
+			<!-- 兜底显示 -->
+			<template v-else>
+				<div class="mobile-land-page-prize-info-test"></div>
+			</template>
 		</div>
+		<FontZoom width="330">
+			<div class="mobile-land-page-tip">{{ tipCpd }}</div>
+		</FontZoom>
 		<div class="mobile-land-page-login-twitter" @click="toLogin">Login Twitter</div>
 	</div>
 </template>
@@ -16,42 +71,121 @@
 import { RewardType, PlayType } from '../types';
 import { getStorage, setStorage, removeStorage, storageKey, getOauthUrl, createWindow } from '../utils/help';
 import { postRequest } from '../http';
+import FontZoom from './FontZoom';
+
+const overTimePic = require('../static/img/icon-h5-denet.svg');
+const giveawayPic = require('../static/img/icon-h5-giveaway.svg');
+const redpackPic = require('../static/img/icon-h5-redpack.svg');
+const treasurePic = require('../static/img/icon-h5-treasure.svg');
 
 export default {
 	name: 'mobileLandPage',
 	props: {
-		detail: {
+		playType: {
+			// 玩法类型, 红包 / 抽奖 / 夺宝 / NFT
+			type: Number,
+		},
+		rewardType: {
+			// 奖品类型  货币/ 自定义奖品
+			type: Number,
+			default: 1,
+		},
+		useFul: {
+			// 红包仍在有效期,可领取
+			type: Boolean,
+			default: true,
+		},
+		userInfo: {
 			type: Object,
 			default: () => {
-				return {
-					postBizData: {},
-				};
+				return {};
 			},
 		},
-		extensionsInstallUrl: {
+		currencyIconPath: {
+			// 货币头像
+			type: String,
+			default: '',
+		},
+		amountValue: {
+			// 奖品数量
+			type: String,
+			default: '1',
+		},
+		usValue: {
+			// 转换为美金 的价值
+			type: String,
+			default: '',
+		},
+		prize: {
+			// 奖品 描述
+			type: String,
+			default: '',
+		},
+		postId: {
+			// 推文ID,用于retweer
+			type: String,
+			default: '',
+		},
+		prizePicPath: {
+			// NFT图片
 			type: String,
 			default: '',
 		},
 	},
 	data() {
 		return {
-			config: {},
 			timer: {},
 		};
 	},
 	computed: {
-		isMoneyRewardCpd() {
-			return this.rewardType === RewardType.money;
+		isCustomRewardCpd() {
+			return this.rewardType === RewardType.custom;
 		},
 		isLottaryCpd() {
 			return this.playType === PlayType.lottery;
 		},
+		isCommonCpd() {
+			return this.playType === PlayType.common;
+		},
+		isTreasureCpd() {
+			return this.playType === PlayType.Treasure;
+		},
+		isNFTCpd() {
+			return this.playType === PlayType.NFT;
+		},
+		iconCpd() {
+			if (!this.useFul) {
+				return overTimePic;
+			} else if (this.isCommonCpd) {
+				return giveawayPic;
+			} else if (this.isLottaryCpd) {
+				return redpackPic;
+			} else if (this.isTreasureCpd) {
+				return treasurePic;
+			} else if (this.isNFTCpd) {
+				return this.prizePicPath;
+			}
+			{
+				return overTimePic;
+			}
+		},
+		tipCpd() {
+			if (this.isCommonCpd) {
+				return 'to claim,  log in twitter to install Denet Chrome Extension';
+			} else if (this.isLottaryCpd) {
+				return 'To participate, login Twitter to install DeNet Chrome Extension';
+			} else if (this.isTreasureCpd) {
+				return 'To complete, log in twitter to install Denet Chrome Extension';
+			} else {
+				return 'login Twitter to install DeNet Chrome Extension';
+			}
+		},
 	},
 	methods: {
 		toLogin() {
 			let userInfo = getStorage(storageKey.userInfo);
 			if (userInfo) {
-				location.href = `/nft/list`;
+				location.href = `/course?useful=${this.useFul ? '0' : '1'}&playType=${this.playType}&rewardType=${this.rewardType}&postId=${this.postId}`;
 			} else {
 				this.twitterAuth();
 			}
@@ -95,6 +229,7 @@ export default {
 			}
 		},
 	},
+	components: { FontZoom },
 };
 </script>
 <style lang="scss" scoped>
@@ -106,9 +241,10 @@ export default {
 	flex-direction: column;
 	justify-content: space-between;
 	align-items: center;
+	padding: 0 16px;
 	&-invited-info {
-		width: 300px;
-		height: 70px;
+		width: 302px;
+		height: 72px;
 		margin-top: 28px;
 		position: relative;
 		padding-left: 81px;
@@ -134,6 +270,10 @@ export default {
 			line-height: 16px;
 			letter-spacing: 0.3px;
 			color: #000000;
+			max-width: 210px;
+			text-overflow: ellipsis;
+			white-space: nowrap;
+			overflow: hidden;
 		}
 		.invited-text {
 			font-weight: 700;
@@ -143,8 +283,44 @@ export default {
 			color: #f99d23;
 		}
 	}
-	&-icon {
+	&-icon-wrap {
+		display: flex;
 		flex: 1;
+		align-items: center;
+		.mobile-land-page-icon {
+			width: 100%;
+		}
+	}
+	&-prize-info {
+		font-style: normal;
+		font-weight: 700;
+		font-size: 18px;
+		line-height: 21px;
+		color: #000000;
+		&-test {
+			display: flex;
+			align-items: center;
+			justify-content: center;
+			.pre-amount-value {
+				margin-left: 3px;
+			}
+			.icon {
+				width: 22px;
+				height: 22px;
+				margin-left: 3px;
+			}
+			.prize-name {
+				margin: 0 3px;
+			}
+		}
+	}
+	&-tip {
+		font-weight: 400;
+		font-size: 13px;
+		line-height: 16px;
+		text-align: center;
+		color: #7b7b7b;
+		margin-top: 10px;
 	}
 	&-login-twitter {
 		width: 100%;

+ 5 - 0
nuxt.config.js

@@ -35,6 +35,11 @@ export default {
 	router: {
 		extendRoutes(routes, resolve) {
 			routes.push(
+				{
+					name: 'Course',
+					path: '/course',
+					component: resolve(__dirname, 'pages/course/index.vue'),
+				},
 				{
 					name: 'Authlogin',
 					path: '/authlogin',

+ 1 - 0
pages/auth/authLogin.vue

@@ -1,3 +1,4 @@
+<!-- 移动端 twitter授权登录中间页 -->
 <template>
 	<div class="welcome">
 		<span class="text">Success</span>

+ 181 - 0
pages/course/index.vue

@@ -0,0 +1,181 @@
+<!-- 移动端 教程页面 -->
+<template>
+	<div class="course-page">
+		<div class="course-page-tips">
+			<img class="tip-icon" src="./../../static/img/icon-h5-topc.png" />
+			<span class="tip-text">{{ tipTextCpd }}</span>
+		</div>
+		<div class="course-page-pics-wrap" :style="{ transform: translastCpd }">
+			<img class="pic" v-for="(item, index) in course" :key="index" :src="item" />
+		</div>
+		<div class="course-page-pagination">
+			<div class="spon" v-for="(item, index) in course" :key="index" :class="active === index ? 'active' : ''"></div>
+		</div>
+		<div class="course-page-btns">
+			<div v-if="active > 0" class="course-page-btns-btn back" @click="back">Back</div>
+			<div v-if="active < this.course.length - 1" class="course-page-btns-btn next" @click="next">Next</div>
+			<div v-if="active < this.course.length && (isLottaryCpd || isTreasureCpd || isCommonCpd)" @click="retweer" class="course-page-btns-btn retweer">Retweet</div>
+		</div>
+	</div>
+</template>
+
+<script>
+import { postRequest } from '../../http';
+import { PlayType } from '../../types';
+import { getQueryString } from '../../utils/help';
+
+export default {
+	name: 'course',
+	data() {
+		return {
+			active: 0,
+			course: [],
+		};
+	},
+	computed: {
+		translastCpd() {
+			return `translateX(${-this.active * 100}vw)`;
+		},
+		isLottaryCpd() {
+			return this.playType === PlayType.lottery;
+		},
+		isCommonCpd() {
+			return this.playType === PlayType.common;
+		},
+		isTreasureCpd() {
+			return this.playType === PlayType.Treasure;
+		},
+		isTimeExpiredCpd() {
+			return this.useful === '0';
+		},
+		tipTextCpd() {
+			if (this.isLottaryCpd) {
+				return 'Install DeNet chrome extension to claim your prize';
+			} else if (this.isCommonCpd || this.is) {
+				return 'Install Denet Chrome Extension to complete the quest';
+			} else {
+				return 'How to install Denet Chrome Extension';
+			}
+		},
+	},
+	methods: {
+		getCource() {
+			postRequest(`/base/guide/getAllMobilePageGuide`, {}).then(({ code, data }) => {
+				if (code == 0) {
+					console.log('%c [ data ]-78', 'font-size:13px; background:pink; color:#bf2c9f;', data);
+					if (this.useful === 1) {
+						this.course = data.withRewardGuideImages;
+					} else {
+						this.course = data.withoutRewardGuideImages;
+					}
+				}
+			});
+		},
+		next() {
+			if (this.active < this.course.length - 1) {
+				this.active++;
+			} else {
+				window.location.replace(`https://twitter.com/intent/retweet?tweet_id=${this.postId}`);
+			}
+		},
+		back() {
+			this.active--;
+		},
+		retweer() {
+			window.open(`https://twitter.com/intent/retweet?tweet_id=${this.postId}`);
+		},
+	},
+	mounted() {
+		this.getCource();
+		this.useful = getQueryString('useful');
+		this.playType = getQueryString('playType');
+		this.rewardType = getQueryString('rewardType');
+		this.postId = getQueryString('postId');
+	},
+};
+</script>
+
+<style lang="scss" scoped>
+body {
+	background-color: #f5f5f5;
+}
+.course-page {
+	min-height: 100vh;
+	max-height: 100vh;
+	overflow: hidden;
+	display: flex;
+	flex-direction: column;
+	align-items: center;
+	justify-content: space-between;
+
+	&-tips {
+		width: 100%;
+		height: 80px;
+		background: #94a7b6;
+		display: flex;
+		padding: 0 20px;
+		align-items: center;
+		font-weight: 600;
+		font-size: 16px;
+		line-height: 22px;
+		color: #fff;
+		.tip-icon {
+			width: 36px;
+			margin-right: 20px;
+		}
+	}
+	&-pics-wrap {
+		display: flex;
+		transition: all 0.5s;
+		.pic {
+			width: 100%;
+		}
+	}
+	&-pagination {
+		display: flex;
+		justify-content: center;
+		align-items: center;
+		.spon {
+			width: 8px;
+			height: 8px;
+			background: #d9d9d9;
+			margin: 0 3px;
+			border-radius: 50%;
+		}
+		.active {
+			background: #1d9bf0;
+		}
+	}
+	&-btns {
+		width: 100%;
+		display: flex;
+		padding: 0 8px 30px;
+		&-btn {
+			flex: 1;
+			margin: 0 8px;
+			height: 54px;
+			line-height: 54px;
+			text-align: center;
+			border-radius: 60px;
+		}
+		&-btn:active {
+			-webkit-tap-highlight-color: transparent;
+		}
+		.back {
+			background: rgba(29, 155, 240, 0.01);
+			border: 1px solid #e8e8e8;
+			color: #3d3d3d;
+		}
+		.next {
+			background: rgba(0, 0, 0, 0.01);
+			border: 1px solid #b5e1ff;
+			color: #1d9bf0;
+		}
+		.retweer {
+			background: #1d9bf0;
+			border: 1px solid #1d9bf0;
+			color: #fff;
+		}
+	}
+}
+</style>

+ 16 - 2
pages/index.vue

@@ -202,7 +202,19 @@
 			</div>
 			<div v-if="status == 'error'"></div>
 		</div>
-		<MobileLandPage v-if="show_moblie" :detail="detail"></MobileLandPage>
+		<MobileLandPage
+			v-if="show_moblie"
+			:playType="PlayType.common"
+			:rewardType="this.detail.postBizData.rewardType"
+			:useFul="!this.detail.postBizData.receiveTimeExpired"
+			:userInfo="this.detail.postBizData.postUserInfo"
+			:currencyIconPath="this.detail.postBizData.currencyIconPath"
+			:amountValue="isMoneyPrize ? this.detail.postBizData.amountValue : ''"
+			:usValue="isMoneyPrize ? this.detail.postBizData.usdAmountValue : ''"
+			:prize="isMoneyPrize ? this.detail.postBizData.currencySymbol : this.detail.postBizData.customizedReward"
+			:postId="this.detail.srcContentId"
+		>
+		</MobileLandPage>
 	</div>
 </template>
 
@@ -214,7 +226,8 @@ import Report from '../log-center/log';
 import { Toast } from 'vant';
 import FontAmount from '../components/FontAmount.vue';
 import MobileLandPage from '../components/MobileLandPage.vue';
-import { RewardType } from '../types';
+// eslint-disable-next-line no-unused-vars
+import { RewardType, PlayType } from '../types';
 
 var moment = require('moment');
 var ClipboardJS = require('clipboard');
@@ -238,6 +251,7 @@ export default {
 	name: 'index',
 	data() {
 		return {
+			PlayType,
 			cp_link: '',
 			appVersionCode: appVersionCode,
 			mid: '',

+ 19 - 130
pages/luckdraw.vue

@@ -5,135 +5,20 @@
 			<img class="loading" src="../static/svg/icon-loading.svg" />
 		</template>
 		<template v-else>
-			<template v-if="isMobile">
-				<!-- 手机端 -->
-				<div
-					class="small"
-					:class="{
-						bg: status === 'not-open',
-						custom: detail.postBizData.posterType === 2 && detail.postBizData.customPosterInstalled,
-					}"
-				>
-					<template v-if="status === 'not-open'">
-						<template v-if="detail.postBizData.posterType === 2 && detail.postBizData.customPosterInstalled">
-							<img class="customImg" :src="detail.postBizData.customPosterInstalled" />
-						</template>
-						<template v-else>
-							<template v-if="isMoneyPrize">
-								<img class="lottery" :src="require('../static/svg/icon-luck-mark.svg')" />
-								<div class="head">
-									<img :src="detail.postBizData.postUserInfo.avatarUrl" />
-									<span>{{ detail.postBizData.postUserInfo.nickName }}</span>
-								</div>
-								<div class="price">
-									<div class="usdt">{{ detail.postBizData.currencySymbol }} GIVEAWAY</div>
-									<div class="money">
-										<img :src="detail.postBizData.currencyIconPath" />
-										<font-amount :fontSize="60" :amount="detail.postBizData.amountValue"> </font-amount>
-									</div>
-								</div>
-								<div class="time">
-									<img class="img" :src="require('../static/svg/icon-time.svg')" />
-									{{ validity || '00:00:00' }}
-								</div>
-								<div class="box">
-									<img src="../static/subject/icon-box.png" />
-								</div>
-							</template>
-
-							<template v-else>
-								<custom-card-cover
-									:totalCount="detail.postBizData.totalCount"
-									:amountValue="detail.postBizData.amountValue"
-									:tokenSymbol="detail.postBizData.tokenSymbol"
-									:currencyIconUrl="detail.postBizData.iconPath"
-									:playType="2"
-									:validity="validity"
-									:userInfo="{
-										nickName: detail.postBizData.postUserInfo.nickName,
-										avatarUrl: detail.postBizData.postUserInfo.avatarUrl,
-									}"
-									:rewardType="detail.postBizData.rewardType"
-									:customizedReward="detail.postBizData.customizedReward"
-									:showBottomInfo="false"
-								>
-								</custom-card-cover>
-							</template>
-						</template>
-					</template>
-					<template v-else>
-						<div class="succTop">
-							<template v-if="status === 'opened'">
-								<img class="img" :src="require('../static/svg/icon-luck-rabbit.svg')" />
-								<p class="tips">Good Luck Next Time!</p>
-							</template>
-							<template v-else-if="status === 'expire'">
-								<!-- <img class="img" :src=" require('../static/svg/icon-luck-complete.svg') " />
-                                <p class="tips">This Draw is Complete</p> -->
-								<p class="expire">This Giveaways<br />expired on {{ formatTime(detail.postBizData.endTimestamp, 'MM-DD') }}</p>
-							</template>
-							<template v-else>
-								<p class="win">🎉 Awesome! You Will Get</p>
-								<div class="win-money">
-									<img :src="detail.postBizData.currencyIconPath" />
-									<font-amount :fontSize="46" :amount="receiveAmount"></font-amount>
-								</div>
-							</template>
-						</div>
-						<div class="succTitle">
-							<span>{{ detail.postBizData.receiveCount || 0 }}/{{ detail.postBizData.totalCount || 0 }} Winners</span>
-							<span v-if="isMoneyPrize">{{ detail.postBizData.receiveAmountValue }} / {{ detail.postBizData.amountValue || '' }} {{ detail.postBizData.currencySymbol || '' }}</span>
-						</div>
-						<div class="luck-list" @scroll="handleScroll($event)">
-							<div class="luck-item" v-for="(item, i) in luck_list" v-bind:key="i">
-								<div class="userLogo">
-									<img class="medal" v-if="i < 2" :src="require('../static/svg/icon-medal-' + i + '.svg')" />
-									<img class="header" v-if="item.simpleUserInfoVO.avatarUrl" :src="item.simpleUserInfoVO.avatarUrl" alt />
-									<img class="header" v-else src="/svg/icon-twitter.svg" alt />
-								</div>
-								<div class="luck-content">
-									<div class="luck-title">{{ item.simpleUserInfoVO.nickName || 'Twitter User' }}</div>
-									<div class="luck-time">{{ formatTime(item.receiveTimestamp, 'MM-DD HH:mm') }}</div>
-								</div>
-								<div class="luck-money" v-if="isMoneyPrize">
-									<img :src="item.currencyIconPath" alt />
-									<div class="luck-money-txt">{{ item.amountValue || 0 }}</div>
-								</div>
-								<div class="luck-custom-prize" v-else>winner</div>
-								<div class="luck-king" v-if="isMoneyPrize && item.maxAmount">
-									<img src="/svg/icon-king-hat.svg" alt />
-									<span>Luckiest Draw</span>
-								</div>
-							</div>
-						</div>
-					</template>
-					<div class="area-cp-link">
-						<div class="area-list">
-							<div class="item">
-								<div class="icon"><img :src="require('../static/subject/01.svg')" /></div>
-								<div class="font">Complete the tasks on tweet</div>
-							</div>
-							<div class="item">
-								<div class="icon"><img :src="require('../static/subject/02.svg')" /></div>
-								<div class="font">Open link on PC to draw</div>
-								<div class="pc"><img :src="require('../static/subject/pc.svg')" /></div>
-							</div>
-						</div>
-						<div class="area-content">
-							{{ linkHref }}
-						</div>
-						<div class="area-btn">
-							<div class="btn" :data-clipboard-text="linkHref" @click="copyLinkHandle">Copy Link</div>
-						</div>
-					</div>
-					<div class="layer" v-show="layer_show">
-						<div class="layer-box">
-							<div class="layer-txt">Unable to copy, please enter the link manually</div>
-							<div class="layer-btn" @click="layer_show = false">Done</div>
-						</div>
-					</div>
-				</div>
-			</template>
+			<!-- 手机端 -->
+			<MobileLandPage
+				v-if="isMobile"
+				:playType="PlayType.lottery"
+				:rewardType="this.detail.postBizData.rewardType"
+				:useFul="!this.detail.postBizData.receiveTimeExpired"
+				:userInfo="this.detail.postBizData.postUserInfo"
+				:currencyIconPath="this.detail.postBizData.currencyIconPath"
+				:amountValue="isMoneyPrize ? this.detail.postBizData.amountValue : ''"
+				:usValue="isMoneyPrize ? this.detail.postBizData.usdAmountValue : ''"
+				:prize="isMoneyPrize ? this.detail.postBizData.currencySymbol : this.detail.postBizData.customizedReward"
+				:postId="this.detail.srcContentId"
+			>
+			</MobileLandPage>
 			<!-- PC端 -->
 			<template v-else>
 				<div class="logo">
@@ -309,7 +194,8 @@ import { isBrowser, appType, appVersionCode, formatSecondsAsDaysOrTime } from '.
 import FontAmount from '../components/FontAmount.vue';
 import CustomCardCover from '../components/CustomCardCover.vue';
 import Report from '../log-center/log';
-import { RewardType } from '../types';
+import { RewardType, PlayType } from '../types';
+import MobileLandPage from '../components/MobileLandPage.vue';
 
 var moment = require('moment');
 var ClipboardJS = require('clipboard');
@@ -332,6 +218,7 @@ export default {
 	components: {
 		FontAmount,
 		CustomCardCover,
+		MobileLandPage,
 	},
 	head() {
 		return {
@@ -374,6 +261,7 @@ export default {
 	},
 	data() {
 		return {
+			PlayType,
 			detail: {
 				postId: '',
 				postBizData: {
@@ -452,6 +340,7 @@ export default {
 					postUserInfo: {},
 				};
 			}
+			console.log('data', data);
 			return {
 				detail: data.data,
 				customCover: data.data.postBizData && data.data.postBizData.posterType == 2 ? 1 : 0,

+ 342 - 349
pages/nft/index.vue

@@ -1,260 +1,253 @@
 <template>
-    <div class="nft-content">
-        <template v-if="isLoading">
-            <img class="loading" src="../../static/svg/icon-loading.svg" />
-        </template>
-        <template v-else>
-            <template v-if="isMobile">
-                <div class="small">
-                    <div class="banner"><img :src="detail.pageImagePath" /></div>
-                    <div class="title">Open link on PC to Buy NFT</div>
-                    <div class="desc">{{ linkHref }}</div>
-                    <div class="copy">
-                        <button class="btn" :data-clipboard-text="linkHref">Copy Link</button>
-                    </div>
-                </div>
-            </template>
-            <template v-else>
-                <div class="logo">
-                    <img src="/img/icon-logo.png" alt />
-                </div>
-                <div class="show">
-                    <div class="center">
-                        <div class="img">
-                            <img :src="detail.pageImagePath" />
-                        </div>
-                        <div class="info">
-                            <template v-if="isChrome">
-                                <div class="title">Install DeNet Plugin<br />to Buy NFT</div>
-                                <img class="buy" @click="installExtension"
-                                    src="../../static/img/icon-install-plugin.svg" />
-                            </template>
-                            <template v-else>
-                                <div class="title">Only Support to Use Chrome to buy NFT</div>
-                                <img class="buy" @click="installChrome"
-                                    src="../../static/img/icon-install-chrome.svg" />
-                            </template>
-                        </div>
-                    </div>
-                </div>
-            </template>
-        </template>
-    </div>
+	<div class="nft-content">
+		<template v-if="isLoading">
+			<img class="loading" src="../../static/svg/icon-loading.svg" />
+		</template>
+		<template v-else>
+			<MobileLandPage v-if="isMobile" :prizePicPath="detail.pageImagePath" :playType="PlayType.NFT" :prize="detail.nftProjectName" :useFul="detail.purchaseStatus === 1" :postId="detail.srcContentId"> </MobileLandPage>
+			<template v-else>
+				<div class="logo">
+					<img src="/img/icon-logo.png" alt />
+				</div>
+				<div class="show">
+					<div class="center">
+						<div class="img">
+							<img :src="detail.pageImagePath" />
+						</div>
+						<div class="info">
+							<template v-if="isChrome">
+								<div class="title">Install DeNet Plugin<br />to Buy NFT</div>
+								<img class="buy" @click="installExtension" src="../../static/img/icon-install-plugin.svg" />
+							</template>
+							<template v-else>
+								<div class="title">Only Support to Use Chrome to buy NFT</div>
+								<img class="buy" @click="installChrome" src="../../static/img/icon-install-chrome.svg" />
+							</template>
+						</div>
+					</div>
+				</div>
+			</template>
+		</template>
+	</div>
 </template>
 
 <script>
-import axios from 'axios'
-import Cookies from 'js-cookie'
+import axios from 'axios';
+import Cookies from 'js-cookie';
 import { Toast } from 'vant';
-import { isBrowser, appVersionCode, appType } from '../../utils/help.js'
-import Report from "@/log-center/log"
+import { isBrowser, appVersionCode, appType } from '../../utils/help.js';
+import Report from '@/log-center/log';
+import { PlayType } from './../../types';
 
 const api = {
-    prod: 'https://api.denetme.net',
-    pre: 'https://preapi.denetme.net',
-    test: 'https://testapi.denetme.net'
-}
+	prod: 'https://api.denetme.net',
+	pre: 'https://preapi.denetme.net',
+	test: 'https://testapi.denetme.net',
+};
 const page = {
-    prod: "https://h5.denetme.net",
-    pre: "https://preh5.denetme.net",
-    test: 'https://testh5.denetme.net'
-}
-const jumpUrl = page[process.env.NUXT_ENV.MODE] + '/'
-const baseURL = api[process.env.NUXT_ENV.MODE]
-const ClipboardJS = require('clipboard')
+	prod: 'https://h5.denetme.net',
+	pre: 'https://preh5.denetme.net',
+	test: 'https://testh5.denetme.net',
+};
+const jumpUrl = page[process.env.NUXT_ENV.MODE] + '/';
+const baseURL = api[process.env.NUXT_ENV.MODE];
+const ClipboardJS = require('clipboard');
 
 export default {
-    name: 'ntf',
-    data() {
-        return {
-            isLoading: true,
-            appVersionCode: appVersionCode,
-            jumpUrl: jumpUrl,
-            detail: {},
-            config: {},
-            title: 'DeNet Giveaway',
-            isMobile: false,
-            isChrome: false,
-            linkHref: '',
-            metaTitle: 'DeNet: An Easy Web3 Tool For GIVEAWAY / AIRDROP',
-        }
-    },
-    head() {
-        return {
-            type: '',
-            title: this.title,
-            appVersionCode: appVersionCode,
-            meta: [
-                // facebook 
-                {
-                    name: 'og:url',
-                    content: this.jumpUrl + 'nft/' + this.$route.params.id + `/${this.$route.params.account}`
-                },
-                {
-                    name: 'og:title',
-                    content: this.metaTitle
-                },
-                {
-                    name: 'og:image',
-                    content: this.detail.linkImagePath || ''
-                },
-                // twitter
-                {
-                    name: 'twitter:card',
-                    content: 'summary_large_image'
-                },
-                {
-                    name: 'twitter:url',
-                    content: this.jumpUrl + 'nft/' + this.$route.params.id + `/${this.$route.params.account}`
-                },
-                {
-                    name: 'twitter:title',
-                    content: this.metaTitle
-                },
-                {
-                    name: 'twitter:image',
-                    content: this.detail.linkImagePath || ''
-                }
-            ]
-        }
-    },
-    async asyncData(params) {
-        let { route } = params;
-        let { data } = await axios.post(`${baseURL}/denet/nft/project/getNftProjectInfo`, {
-            baseInfo: {
-                appVersionCode: appVersionCode,
-                mid: function () {
-                    return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, function (c) {
-                        var r = Math.random() * 16 | 0, v = c == 'x' ? r : (r & 0x3 | 0x8);
-                        return v.toString(16);
-                    });
-                }()
-            },
-            params: {
-                nftProjectId: route.params.id || ''
-            }
-        })
-        if (data.code == 0 && data.data !== null) {
-            return {
-                detail: data.data,
-            }
-        }
-    },
-    created() {
-        this.setCookieMid();
-        this.getConfig();
-    },
-    mounted() {
-        this.checkBrowser();
-        this.setNftInfo();
-        this.isLoading = false;
+	name: 'ntf',
+	data() {
+		return {
+			PlayType,
+			isLoading: true,
+			appVersionCode: appVersionCode,
+			jumpUrl: jumpUrl,
+			detail: {},
+			config: {},
+			title: 'DeNet Giveaway',
+			isMobile: false,
+			isChrome: false,
+			linkHref: '',
+			metaTitle: 'DeNet: An Easy Web3 Tool For GIVEAWAY / AIRDROP',
+		};
+	},
+	head() {
+		return {
+			type: '',
+			title: this.title,
+			appVersionCode: appVersionCode,
+			meta: [
+				// facebook
+				{
+					name: 'og:url',
+					content: this.jumpUrl + 'nft/' + this.$route.params.id + `/${this.$route.params.account}`,
+				},
+				{
+					name: 'og:title',
+					content: this.metaTitle,
+				},
+				{
+					name: 'og:image',
+					content: this.detail.linkImagePath || '',
+				},
+				// twitter
+				{
+					name: 'twitter:card',
+					content: 'summary_large_image',
+				},
+				{
+					name: 'twitter:url',
+					content: this.jumpUrl + 'nft/' + this.$route.params.id + `/${this.$route.params.account}`,
+				},
+				{
+					name: 'twitter:title',
+					content: this.metaTitle,
+				},
+				{
+					name: 'twitter:image',
+					content: this.detail.linkImagePath || '',
+				},
+			],
+		};
+	},
+	async asyncData(params) {
+		let { route } = params;
+		let { data } = await axios.post(`${baseURL}/denet/nft/project/getNftProjectInfo`, {
+			baseInfo: {
+				appVersionCode: appVersionCode,
+				mid: (function () {
+					return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, function (c) {
+						var r = (Math.random() * 16) | 0,
+							v = c == 'x' ? r : (r & 0x3) | 0x8;
+						return v.toString(16);
+					});
+				})(),
+			},
+			params: {
+				nftProjectId: route.params.id || '',
+			},
+		});
+		if (data.code == 0 && data.data !== null) {
+			return {
+				detail: data.data,
+			};
+		}
+	},
+	created() {
+		this.setCookieMid();
+		this.getConfig();
+	},
+	mounted() {
+		this.checkBrowser();
+		this.setNftInfo();
+		this.isLoading = false;
 
-        var clipboard = new ClipboardJS('.btn');
-        let that = this
-        clipboard.on('success', function (e) {
-            Toast('copy success');
-            // 埋点
-            that.trackingClick()
-            e.clearSelection();
-        });
-        this.pageSource = Report.pageSource.newUserLandingPage
-        // 埋点
-        if (this.isMobile) {
-            this.pageSource = Report.pageSource.mobileLandingPage
-        }
-        Report.reportLog({
-            baseInfo: {
-                appVersionCode: appVersionCode,
-                mid: this.mid,
-                pageSource: this.pageSource,
-                appType,
-                machineCode: this.mid
-            },
-            params: {
-                eventData: {
-                    businessType: Report.businessType.pageView,
-                    postId: this.detail.postId,
-                    srcContentId: this.detail.srcContentId,
-                    senderId: this.detail.srcUserId,
-                    redPacketType: 2,
-                }
-            }
-        })
-    },
-    methods: {
-        trackingClick() {
-            Report.reportLog({
-                baseInfo: {
-                    appVersionCode: appVersionCode,
-                    mid: this.mid,
-                    pageSource: this.pageSource,
-                    appType,
-                    machineCode: this.mid
-                },
-                params: {
-                    eventData: {
-                        businessType: Report.businessType.buttonClick,
-                        objectType: Report.objectType.installButton,
-                        postId: this.detail.postId,
-                        srcContentId: this.detail.srcContentId,
-                        senderId: this.detail.srcUserId,
-                        redPacketType: 2,
-                    }
-                }
-            })
-        },
-        guid() {
-            return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, function (c) {
-                var r = Math.random() * 16 | 0, v = c == 'x' ? r : (r & 0x3 | 0x8);
-                return v.toString(16);
-            });
-        },
-        setCookieMid() {
-            let _cookie_mid_arr = Cookies.get('mid') || []
-            if (_cookie_mid_arr.length > 0) {
-                this.mid = JSON.parse(_cookie_mid_arr)[0].mid
-            } else {
-                this.mid = this.guid()
-                Cookies.set('mid', JSON.stringify([{ mid: this.mid }]), { expires: 1000 })
-            }
-        },
-        installExtension() {
-            // 埋点
-            this.trackingClick()
-            let { extensionsInstallUrl } = this.config;
-            window.open(extensionsInstallUrl)
-        },
-        installChrome() {
-            window.open('https://www.google.com/chrome')
-        },
-        async getConfig() {
-            let { data } = await axios.post(`${baseURL}/denet/base/config/getFrontConfig`, {
-                baseInfo: {
-                    appVersionCode: appVersionCode,
-                    mid: this.mid
-                },
-                params: {}
-            })
-            if (data.code == 0) {
-                this.config = data.data;
-            }
-        },
-        checkBrowser() {
-            this.linkHref = window.location.href;
-            this.isChrome = isBrowser() == 'chrome';
-            this.isMobile = navigator.userAgent.match(/(phone|pad|pod|iPhone|iPod|ios|iPad|Android|Mobile|BlackBerry|IEMobile|MQQBrowser|JUC|Fennec|wOSBrowser|BrowserNG|WebOS|Symbian|Windows Phone)/i);
-        },
-        setNftInfo() {
-            let nftInfo = {
-                nftProjectId: this.detail.nftProjectId || '',
-                twitterAccount: atob(this.$route.params.account || ''),
-                createTime: Date.now(),
-                jump_type: 'nft_info',
-            };
-            Cookies.set('jump_info', JSON.stringify(nftInfo), { expires: 100 });
-        },
-    }
-}
+		var clipboard = new ClipboardJS('.btn');
+		let that = this;
+		clipboard.on('success', function (e) {
+			Toast('copy success');
+			// 埋点
+			that.trackingClick();
+			e.clearSelection();
+		});
+		this.pageSource = Report.pageSource.newUserLandingPage;
+		// 埋点
+		if (this.isMobile) {
+			this.pageSource = Report.pageSource.mobileLandingPage;
+		}
+		Report.reportLog({
+			baseInfo: {
+				appVersionCode: appVersionCode,
+				mid: this.mid,
+				pageSource: this.pageSource,
+				appType,
+				machineCode: this.mid,
+			},
+			params: {
+				eventData: {
+					businessType: Report.businessType.pageView,
+					postId: this.detail.postId,
+					srcContentId: this.detail.srcContentId,
+					senderId: this.detail.srcUserId,
+					redPacketType: 2,
+				},
+			},
+		});
+	},
+	methods: {
+		trackingClick() {
+			Report.reportLog({
+				baseInfo: {
+					appVersionCode: appVersionCode,
+					mid: this.mid,
+					pageSource: this.pageSource,
+					appType,
+					machineCode: this.mid,
+				},
+				params: {
+					eventData: {
+						businessType: Report.businessType.buttonClick,
+						objectType: Report.objectType.installButton,
+						postId: this.detail.postId,
+						srcContentId: this.detail.srcContentId,
+						senderId: this.detail.srcUserId,
+						redPacketType: 2,
+					},
+				},
+			});
+		},
+		guid() {
+			return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, function (c) {
+				var r = (Math.random() * 16) | 0,
+					v = c == 'x' ? r : (r & 0x3) | 0x8;
+				return v.toString(16);
+			});
+		},
+		setCookieMid() {
+			let _cookie_mid_arr = Cookies.get('mid') || [];
+			if (_cookie_mid_arr.length > 0) {
+				this.mid = JSON.parse(_cookie_mid_arr)[0].mid;
+			} else {
+				this.mid = this.guid();
+				Cookies.set('mid', JSON.stringify([{ mid: this.mid }]), { expires: 1000 });
+			}
+		},
+		installExtension() {
+			// 埋点
+			this.trackingClick();
+			let { extensionsInstallUrl } = this.config;
+			window.open(extensionsInstallUrl);
+		},
+		installChrome() {
+			window.open('https://www.google.com/chrome');
+		},
+		async getConfig() {
+			let { data } = await axios.post(`${baseURL}/denet/base/config/getFrontConfig`, {
+				baseInfo: {
+					appVersionCode: appVersionCode,
+					mid: this.mid,
+				},
+				params: {},
+			});
+			if (data.code == 0) {
+				this.config = data.data;
+			}
+		},
+		checkBrowser() {
+			this.linkHref = window.location.href;
+			this.isChrome = isBrowser() == 'chrome';
+			this.isMobile = navigator.userAgent.match(/(phone|pad|pod|iPhone|iPod|ios|iPad|Android|Mobile|BlackBerry|IEMobile|MQQBrowser|JUC|Fennec|wOSBrowser|BrowserNG|WebOS|Symbian|Windows Phone)/i);
+		},
+		setNftInfo() {
+			let nftInfo = {
+				nftProjectId: this.detail.nftProjectId || '',
+				twitterAccount: atob(this.$route.params.account || ''),
+				createTime: Date.now(),
+				jump_type: 'nft_info',
+			};
+			Cookies.set('jump_info', JSON.stringify(nftInfo), { expires: 100 });
+		},
+	},
+};
 </script>
 
 <style lang="scss">
@@ -262,130 +255,130 @@ html,
 body,
 #__nuxt,
 #__layout {
-    width: 100%;
-    height: 100%;
-    padding: 0;
-    margin: 0;
+	width: 100%;
+	height: 100%;
+	padding: 0;
+	margin: 0;
 }
 
 .nft-content {
-    overflow: hidden;
-    width: 100%;
-    height: 100%;
-    background: linear-gradient(180deg, #FFFFFF 0%, #F0F7FE 94.31%);
+	overflow: hidden;
+	width: 100%;
+	height: 100%;
+	background: linear-gradient(180deg, #ffffff 0%, #f0f7fe 94.31%);
 
-    .loading {
-        position: absolute;
-        transform: translate(-50%, -50%);
-        top: 50%;
-        left: 50%;
-        margin: auto;
-        width: 40px;
-        border-radius: 50%;
-    }
+	.loading {
+		position: absolute;
+		transform: translate(-50%, -50%);
+		top: 50%;
+		left: 50%;
+		margin: auto;
+		width: 40px;
+		border-radius: 50%;
+	}
 
-    .logo {
-        display: flex;
-        align-items: center;
-        height: 70px;
-        margin-left: 25px;
+	.logo {
+		display: flex;
+		align-items: center;
+		height: 70px;
+		margin-left: 25px;
 
-        img {
-            width: 99px;
-            height: 32px;
-        }
-    }
+		img {
+			width: 99px;
+			height: 32px;
+		}
+	}
 
-    .show {
-        display: flex;
-        align-items: center;
-        height: calc(100% - 70px);
+	.show {
+		display: flex;
+		align-items: center;
+		height: calc(100% - 70px);
 
-        .center {
-            display: flex;
-            margin: -50px auto 0;
-            width: 1000px;
+		.center {
+			display: flex;
+			margin: -50px auto 0;
+			width: 1000px;
 
-            .img {
-                width: 50%;
-                margin-right: 6%;
+			.img {
+				width: 50%;
+				margin-right: 6%;
 
-                img {
-                    width: 100%;
-                }
-            }
+				img {
+					width: 100%;
+				}
+			}
 
-            .info {
-                display: flex;
-                flex-direction: column;
-                justify-content: center;
-                width: 44%;
+			.info {
+				display: flex;
+				flex-direction: column;
+				justify-content: center;
+				width: 44%;
 
-                .tag {
-                    width: 25%;
-                    margin-bottom: 6px;
-                }
+				.tag {
+					width: 25%;
+					margin-bottom: 6px;
+				}
 
-                .title {
-                    color: #3A4B56;
-                    font-size: 2.2vw;
-                    font-family: 'SF Pro Display';
-                    font-weight: bold;
-                    word-break: break-word;
-                    margin-bottom: 1vw;
-                }
+				.title {
+					color: #3a4b56;
+					font-size: 2.2vw;
+					font-family: 'SF Pro Display';
+					font-weight: bold;
+					word-break: break-word;
+					margin-bottom: 1vw;
+				}
 
-                .buy {
-                    width: 75%;
-                    max-width: 263px;
-                    max-height: 64px;
-                    cursor: pointer;
-                }
-            }
-        }
-    }
+				.buy {
+					width: 75%;
+					max-width: 263px;
+					max-height: 64px;
+					cursor: pointer;
+				}
+			}
+		}
+	}
 }
 
 .small {
-    padding: 30px 20px;
+	padding: 30px 20px;
 
-    .banner {
-        width: 100%;
+	.banner {
+		width: 100%;
 
-        img {
-            width: 100%;
-        }
-    }
+		img {
+			width: 100%;
+		}
+	}
 
-    .title {
-        color: #000000;
-        font-weight: 600;
-        font-size: 20px;
-        text-align: center;
-        padding: 17px 0 12px;
-    }
+	.title {
+		color: #000000;
+		font-weight: 600;
+		font-size: 20px;
+		text-align: center;
+		padding: 17px 0 12px;
+	}
 
-    .desc {
-        color: #8A8A8A;
-        font-size: 13px;
-        padding: 0 22px;
-        word-break: break-all;
-        text-align: center;
-    }
+	.desc {
+		color: #8a8a8a;
+		font-size: 13px;
+		padding: 0 22px;
+		word-break: break-all;
+		text-align: center;
+	}
 
-    .copy {
-        margin-top: 35px;
+	.copy {
+		margin-top: 35px;
 
-        button {
-            width: 100%;
-            border: 0;
-            height: 53px;
-            color: #fff;
-            font-size: 18px;
-            font-weight: 700;
-            border-radius: 55px;
-            background: #1D9BF0;
-        }
-    }
+		button {
+			width: 100%;
+			border: 0;
+			height: 53px;
+			color: #fff;
+			font-size: 18px;
+			font-weight: 700;
+			border-radius: 55px;
+			background: #1d9bf0;
+		}
+	}
 }
-</style>
+</style>

+ 3 - 0
static/img/icon-h5-Retweet.svg

@@ -0,0 +1,3 @@
+<svg width="21" height="20" viewBox="0 0 21 20" fill="none" xmlns="http://www.w3.org/2000/svg">
+<path fill-rule="evenodd" clip-rule="evenodd" d="M6.01009 3.72763C5.71249 3.42412 5.23017 3.42412 4.93256 3.72763L2.50768 6.20064C2.16411 6.55103 2.16411 7.11931 2.50768 7.4697C2.85101 7.81985 3.40748 7.81985 3.75082 7.4697L4.59208 6.61174V13.0454C4.59208 14.8605 6.03473 16.3311 7.81341 16.3311H11.5607C12.0459 16.3311 12.44 15.9299 12.44 15.434C12.44 14.9381 12.0459 14.5369 11.5607 14.5369H7.81341C7.0051 14.5369 6.35058 13.8687 6.35058 13.0454V6.61174L7.19184 7.4697C7.53517 7.81985 8.09165 7.81985 8.43498 7.4697C8.77855 7.11931 8.77855 6.55103 8.43498 6.20064L6.01009 3.72763ZM15.8232 16.2724C16.1208 16.5759 16.6032 16.5759 16.9008 16.2724L19.3257 13.7994C19.6692 13.449 19.6692 12.8807 19.3257 12.5303C18.9823 12.1801 18.4258 12.1801 18.0825 12.5303L17.2413 13.3883V6.95456C17.2413 5.1395 15.7986 3.66886 14.0199 3.66886H10.2726C9.78741 3.66886 9.39335 4.07011 9.39335 4.566C9.39335 5.0619 9.78741 5.46314 10.2726 5.46314H14.0199C14.8282 5.46314 15.4828 6.13129 15.4828 6.95456V13.3883L14.6415 12.5303C14.2982 12.1801 13.7417 12.1801 13.3984 12.5303C13.0548 12.8807 13.0548 13.449 13.3984 13.7994L15.8232 16.2724Z" fill="white"/>
+</svg>

Rozdielové dáta súboru neboli zobrazené, pretože súbor je príliš veľký
+ 2 - 0
static/img/icon-h5-denet.svg


+ 50 - 0
static/img/icon-h5-giveaway.svg

@@ -0,0 +1,50 @@
+<svg width="250" height="255" viewBox="0 0 250 255" fill="none" xmlns="http://www.w3.org/2000/svg">
+<g opacity="0.1" filter="url(#filter0_f_24035_282608)">
+<path d="M215 225.938C215 229.769 174.482 237 124.5 237C74.5182 237 34 229.769 34 225.938C34 222.106 74.5182 219 124.5 219C174.482 219 215 222.106 215 225.938Z" fill="black"/>
+</g>
+<path d="M130.735 121.898V173.72L87.1777 193.659V137.537L130.735 121.898Z" fill="#A56C18"/>
+<path d="M175.289 137.95V192.945L129.32 173.406V122.625L175.289 137.95Z" fill="#A56C18"/>
+<path d="M132.691 155.738V211.632L85.8008 193.707V138.047L132.691 155.738Z" fill="#F9CE46"/>
+<path opacity="0.5" d="M132.691 155.725V211.619L132.475 155.88L85.8008 137.496L132.691 155.725Z" fill="url(#paint0_linear_24035_282608)"/>
+<path d="M176.28 137.656V193.701L132.703 211.626V155.732L176.28 137.656Z" fill="#FEB13E"/>
+<path opacity="0.5" d="M176.28 137.496L132.969 155.88L132.703 211.619V155.725L176.28 137.496Z" fill="url(#paint1_linear_24035_282608)"/>
+<path d="M129.375 122.111L175.451 137.914L132.665 155.528L86.2113 138.053L129.375 122.111ZM149.872 137.954C149.872 136.911 149.308 135.943 148.341 135.086C147.373 134.229 145.984 133.466 144.284 132.83C140.883 131.557 136.195 130.775 131.022 130.775C125.847 130.775 121.159 131.557 117.757 132.83C116.057 133.466 114.668 134.229 113.7 135.086C112.733 135.943 112.169 136.911 112.169 137.954C112.169 138.996 112.733 139.965 113.7 140.821C114.668 141.678 116.057 142.441 117.757 143.077C121.159 144.349 125.847 145.131 131.022 145.131C136.195 145.131 140.883 144.349 144.284 143.077C145.984 142.441 147.373 141.678 148.341 140.821C149.308 139.965 149.872 138.996 149.872 137.954Z" fill="#F9CE46" stroke="#FFD99F" stroke-width="0.4"/>
+<path d="M176.268 139.824L129.329 122.129L85.8008 139.824L129.377 121.898L176.268 139.824Z" fill="#FFBF06"/>
+<path d="M133.189 155.066L133.189 211.288" stroke="#FFD99F" stroke-width="0.4"/>
+<path opacity="0.3" d="M112.394 138.817C112.394 138.942 112.4 139.064 112.413 139.187C112.335 138.895 112.291 138.599 112.291 138.299C112.291 133.992 120.686 130.5 131.039 130.5C141.395 130.5 149.79 133.992 149.79 138.299C149.79 138.599 149.746 138.895 149.668 139.187C149.681 139.064 149.687 138.942 149.687 138.817C149.687 134.488 141.338 130.98 131.039 130.98C120.742 130.98 112.394 134.488 112.394 138.817Z" fill="white"/>
+<path opacity="0.3" d="M149.885 138.047C149.417 141.9 141.161 144.97 131.039 144.97C120.92 144.97 112.663 141.9 112.195 138.047C113.27 141.652 121.297 144.453 131.039 144.453C140.783 144.453 148.81 141.652 149.885 138.047Z" fill="white"/>
+<path opacity="0.3" d="M215.503 100.818L188.953 82.6144C188.953 82.6144 188.96 82.6155 188.955 82.6163C178.215 84.4224 163.57 117.545 163.57 117.545L191.987 137.03C199.299 122.338 204.706 114.383 215.503 100.818Z" fill="#9FA0FF"/>
+<path opacity="0.4" d="M30.3366 125.513L46.4963 109.668C46.4963 109.668 46.4919 109.67 46.4951 109.67C54.1521 109.609 68.3352 130.754 68.3352 130.754L51.0393 147.714C44.183 138.434 39.4682 133.587 30.3366 125.513Z" fill="#4092B8"/>
+<path opacity="0.4" d="M35.2926 70.4848L44.7306 61.2308C44.7306 61.2308 44.728 61.2317 44.7299 61.2317C49.2018 61.1962 57.4853 73.5455 57.4853 73.5455L47.3838 83.451C43.3795 78.0314 40.6258 75.2001 35.2926 70.4848Z" fill="#3E6EFE"/>
+<path opacity="0.3" d="M192.561 54.4547L173.366 41.2941C173.366 41.2941 173.371 41.2949 173.368 41.2955C165.603 42.6012 155.015 66.5472 155.015 66.5472L175.559 80.6346C180.846 70.0128 184.755 64.2614 192.561 54.4547Z" fill="#AB7BDB"/>
+<path d="M48.4227 28.0456L123.689 7.34749C123.689 7.34749 123.69 7.34752 123.683 7.35033C145.696 15.0231 153.798 106.996 153.798 106.996L73.2363 129.153C68.2658 89.8819 62.2638 67.4808 48.4227 28.0456Z" fill="url(#paint2_linear_24035_282608)"/>
+<path d="M117.191 39.6511L116.472 37.271C115.897 35.3669 113.783 34.3606 111.815 34.9607L83.0927 43.722C81.1254 44.3221 79.9237 46.34 80.4986 48.244L81.2172 50.6241C75.777 53.4456 72.9341 59.7866 74.7602 65.8348C76.7046 72.2751 83.2404 76.0306 89.7048 74.6703C93.8017 79.9036 100.685 82.5744 107.675 81.329L110.042 88.2082L98.8006 91.6372C98.1823 91.8258 97.6963 92.2493 97.3931 92.7699C97.1265 93.3099 97.0426 93.9471 97.2286 94.5631C97.6006 95.7952 98.9167 96.4946 100.153 96.1174L127.134 87.8876C128.37 87.5104 129.078 86.1938 128.706 84.9617C128.334 83.7297 127.017 83.0302 125.781 83.4074L114.539 86.8365L112.172 79.9574C116.104 78.2383 119.216 75.3318 121.167 71.8315C122.47 69.5382 123.241 67.0095 123.458 64.3745C129.585 61.8942 132.933 55.0932 130.997 48.6809C129.143 42.6412 123.273 38.9577 117.191 39.6511ZM79.2569 64.4632C78.1832 60.9071 79.6675 57.1823 82.6121 55.2444L86.7715 69.021C86.8983 69.441 87.0617 69.8804 87.2166 70.2919C83.6325 70.3148 80.3306 68.0194 79.2569 64.4632ZM110.214 55.479L108.55 58.7084C108.353 59.0741 108.339 59.537 108.551 59.9313L110.153 63.204C110.642 64.2166 109.755 65.3435 108.675 65.1224L105.428 64.431C104.967 64.327 104.517 64.4642 104.191 64.8082L101.874 67.197C101.107 68.0119 99.7379 67.5428 99.5853 66.4273L99.1075 62.8117C99.0454 62.4025 98.8061 62.0168 98.4321 61.7945L95.2627 60.0397C94.3037 59.5065 94.3449 58.1179 95.334 57.6327L98.4138 56.1428C98.7538 55.9474 99.0347 55.5559 99.1215 55.1319L99.6221 51.7071C99.7759 50.5899 101.181 50.1613 101.955 50.9956L104.265 53.5631C104.552 53.9036 105.001 54.0722 105.44 53.9996L108.824 53.5178C109.915 53.3686 110.717 54.5001 110.214 55.479ZM123.069 59.3251C122.971 58.8965 122.872 58.4679 122.737 58.0199L118.586 44.2713C122.114 44.2655 125.407 46.5329 126.472 50.0611C127.546 53.6173 126.07 57.3701 123.069 59.3251Z" fill="#A96F00"/>
+<defs>
+<filter id="filter0_f_24035_282608" x="16.08" y="201.08" width="216.84" height="53.84" filterUnits="userSpaceOnUse" color-interpolation-filters="sRGB">
+<feFlood flood-opacity="0" result="BackgroundImageFix"/>
+<feBlend mode="normal" in="SourceGraphic" in2="BackgroundImageFix" result="shape"/>
+<feGaussianBlur stdDeviation="8.96" result="effect1_foregroundBlur_24035_282608"/>
+</filter>
+<linearGradient id="paint0_linear_24035_282608" x1="-32048.1" y1="112043" x2="51375.9" y2="57572.9" gradientUnits="userSpaceOnUse">
+<stop stop-color="white"/>
+<stop offset="0.2" stop-color="white"/>
+<stop offset="0.3" stop-color="#9A969A"/>
+<stop offset="0.5" stop-color="white"/>
+<stop offset="0.6" stop-color="#B7BFC1"/>
+<stop offset="0.7" stop-color="white"/>
+<stop offset="1" stop-color="white"/>
+</linearGradient>
+<linearGradient id="paint1_linear_24035_282608" x1="94074.9" y1="316121" x2="266159" y2="211703" gradientUnits="userSpaceOnUse">
+<stop stop-color="#DED9D6"/>
+<stop offset="0.3" stop-color="#8B878D"/>
+<stop offset="0.5" stop-color="#F3F4F4"/>
+<stop offset="0.6" stop-color="#807B80"/>
+<stop offset="0.8" stop-color="white"/>
+<stop offset="1" stop-color="#A7A9AC"/>
+</linearGradient>
+<linearGradient id="paint2_linear_24035_282608" x1="90.8602" y1="15.5011" x2="76.4741" y2="86.0408" gradientUnits="userSpaceOnUse">
+<stop stop-color="#FFDD5E"/>
+<stop offset="1" stop-color="#FFCA00"/>
+</linearGradient>
+</defs>
+</svg>

+ 71 - 0
static/img/icon-h5-redpack.svg

@@ -0,0 +1,71 @@
+<svg width="250" height="255" viewBox="0 0 250 255" fill="none" xmlns="http://www.w3.org/2000/svg">
+<g opacity="0.15" filter="url(#filter0_f_24035_282607)">
+<path d="M212 225.938C212 229.769 172.825 237 124.5 237C76.1751 237 37 229.769 37 225.938C37 222.106 76.1751 219 124.5 219C172.825 219 212 222.106 212 225.938Z" fill="black"/>
+</g>
+<g opacity="0.5" filter="url(#filter1_d_24035_282607)">
+<path d="M46.1504 94.3627L133.591 118.112L199.441 93.2832L119.557 76.5508L46.1504 94.3627Z" fill="#FFEAD2"/>
+</g>
+<g filter="url(#filter2_df_24035_282607)">
+<path d="M46.1504 94.3627L133.591 118.112L199.441 93.2832L119.557 76.5508L46.1504 94.3627Z" fill="white"/>
+</g>
+<path d="M48.3891 165.473L47.2843 95.2401L119.575 77.6989L198.258 94.1798L194.608 148.413L48.3891 165.473Z" stroke="#9D651A" stroke-width="2.24"/>
+<path d="M199.187 96.2188L131.838 117.705L131.84 197.997L197.559 172.8" fill="#F9CE46"/>
+<path d="M46.1967 95.8906L46.1934 95.8911L47.2887 167.81L131.979 198.001L131.837 117.71L46.1967 95.8906Z" fill="#F99D23"/>
+<path d="M46.1951 97.1282L131.38 119.089L199.185 97.4517L199.225 93.2812L131.916 115.263L46.1446 94.5451H46.1426L46.1951 97.1282Z" fill="#D38217"/>
+<g style="mix-blend-mode:multiply">
+<path d="M77.7949 102.164V179.102L91.8286 184.118V105.722L77.7949 102.164Z" fill="#BC020C"/>
+</g>
+<g style="mix-blend-mode:multiply">
+<path d="M160.947 105.697V186.843L174.951 181.462V101.379L160.947 105.697Z" fill="#E10001"/>
+</g>
+<path d="M45.1055 57.8577L124.184 40.1836L199.349 55.5625L131.979 78.6156" fill="#F9CE46"/>
+<path d="M199.346 55.5508L131.976 78.6039L131.875 98.8997L131.915 98.9098L203.016 76.069" fill="#F9CE46"/>
+<g style="mix-blend-mode:multiply">
+<path d="M160.946 69.4125L160.945 69.4106V89.6024L174.949 85.1879V63.5977L160.946 69.4125Z" fill="#E10001"/>
+</g>
+<path d="M45.1062 57.8516L42.9121 77.5407L131.879 98.9053L131.98 78.6095L45.1062 57.8516Z" fill="#F99D23"/>
+<g style="mix-blend-mode:multiply">
+<path d="M77.793 65.7539V86.2647L91.8266 89.2925V69.1029L77.793 65.7539Z" fill="#BC020C"/>
+</g>
+<path d="M59.252 61.2432L131.98 78.6038L189.522 59.7266L131.718 74.4179L59.252 61.2432Z" fill="#FFF1B6"/>
+<path d="M79.8862 54.0773C79.8862 54.0773 66.5296 54.0773 67.753 58.6576C68.9765 63.2379 88.0863 63.5412 95.9324 62.6413C103.779 61.7414 113.04 61.4482 117.166 62.4897C121.291 63.5311 140.502 68.7382 147.114 69.4258C153.727 70.1133 153.333 64.9365 153.333 64.9365C153.333 64.9365 140.583 63.3895 139.956 63.3996C139.329 63.4097 124.83 55.7557 124.203 55.7557C123.576 55.7557 98.5512 52.8438 98.5512 52.8438L89.1277 52.9853L79.8862 54.0773Z" fill="#B76F18"/>
+<g style="mix-blend-mode:multiply">
+<path d="M145.436 44.4609L77.793 65.756L91.8475 69.1015L159.086 47.3325L145.436 44.4609Z" fill="#E10001"/>
+</g>
+<path d="M130.219 49.3023C130.219 49.3023 142.241 49.3023 154.738 36.4209C171.29 19.3737 173.332 30.3037 177.993 38.7464C181.805 45.6522 189.378 51.375 181.926 58.7965C161.371 79.3219 128.793 61.5063 128.793 61.5063" fill="#E10001"/>
+<path d="M119.895 45.9193C116.593 44.4167 113.618 42.2799 111.139 39.6302C106.599 34.9691 101.756 27.3049 95.8211 24.4637C80.9478 17.3051 82.6768 27.8711 78.6324 31.7841C75.2452 35.0095 68.5214 33.9479 68.1978 42.9062C67.308 69.1948 124.294 59.4074 124.294 59.4074" fill="#E10001"/>
+<path d="M123.545 57.1179C121.978 57.3505 102.959 59.9692 90.1784 52.4668C79.6225 46.289 69.1171 41.9211 68.3184 45.652C71.4629 68.1895 123.08 59.5446 124.232 59.3423L124.121 58.8975L123.545 57.1179Z" fill="#A50404"/>
+<path d="M113.722 58.6888C113.851 56.6894 114.108 54.7002 114.49 52.7334C114.541 52.147 112.913 57.9001 110.234 57.6676C107.554 57.435 108.11 59.3561 108.11 59.3561C108.11 59.3561 113.732 59.4876 113.722 58.6888Z" fill="#A50404"/>
+<path d="M173.809 45.0139C167.146 47.0361 160.664 58.6941 146.772 61.7881C144.621 62.2458 142.429 62.4896 140.23 62.5161H139.907C138.006 62.5767 135.518 60.8882 135.205 59.9782C134.356 56.8539 133.395 53.1836 135.69 50.5042C135.967 50.2559 136.155 49.9242 136.226 49.5592C136.298 49.1943 136.248 48.8161 136.085 48.482C134.177 49.0232 132.204 49.3022 130.22 49.3111L128.805 61.4443V61.5252H128.875L129.007 61.6162C131.889 63.5272 158.875 80.2811 178.268 60.9185C181.048 58.138 183.424 56.3484 184.334 53.1229C185.254 47.8248 180.603 42.9209 173.809 45.0139Z" fill="#A50404"/>
+<path d="M133.748 49.2442C129.41 54.2997 136.68 62.9042 132.908 64.6635C129.825 66.0992 124.092 61.792 118.419 61.7717C112.747 61.7515 113.364 57.4644 114.577 54.9872C115.79 52.51 113.475 46.0592 117.186 43.8651C119.734 42.2777 137.741 44.6336 133.748 49.2442Z" fill="#E10001"/>
+<path d="M134.481 56.821C135.048 59.278 138 63.0696 143.844 62.3012C149.688 61.5327 139.881 63.7774 139.881 63.7774L136.615 63.1909L134.724 61.2698L134.148 57.2254C134.148 57.2254 133.753 53.8585 134.481 56.821Z" fill="#A50404"/>
+<path d="M124.599 59.8026C122.405 58.5893 119.897 61.3597 117.339 61.5013C117.143 61.5657 116.939 61.5998 116.732 61.6024C117.288 61.7132 117.854 61.7674 118.421 61.7642C122.981 61.7642 127.582 64.5649 130.807 64.9087L131.333 64.848C129.139 64.0695 126.267 60.7329 124.599 59.8026Z" fill="#A50404"/>
+<defs>
+<filter id="filter0_f_24035_282607" x="19.08" y="201.08" width="210.84" height="53.84" filterUnits="userSpaceOnUse" color-interpolation-filters="sRGB">
+<feFlood flood-opacity="0" result="BackgroundImageFix"/>
+<feBlend mode="normal" in="SourceGraphic" in2="BackgroundImageFix" result="shape"/>
+<feGaussianBlur stdDeviation="8.96" result="effect1_foregroundBlur_24035_282607"/>
+</filter>
+<filter id="filter1_d_24035_282607" x="35.6971" y="66.0974" width="174.198" height="62.4692" filterUnits="userSpaceOnUse" color-interpolation-filters="sRGB">
+<feFlood flood-opacity="0" result="BackgroundImageFix"/>
+<feColorMatrix in="SourceAlpha" type="matrix" values="0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0" result="hardAlpha"/>
+<feOffset/>
+<feGaussianBlur stdDeviation="5.22667"/>
+<feComposite in2="hardAlpha" operator="out"/>
+<feColorMatrix type="matrix" values="0 0 0 0 1 0 0 0 0 0.917647 0 0 0 0 0.823529 0 0 0 1 0"/>
+<feBlend mode="normal" in2="BackgroundImageFix" result="effect1_dropShadow_24035_282607"/>
+<feBlend mode="normal" in="SourceGraphic" in2="effect1_dropShadow_24035_282607" result="shape"/>
+</filter>
+<filter id="filter2_df_24035_282607" x="31.9637" y="62.3641" width="181.664" height="69.9358" filterUnits="userSpaceOnUse" color-interpolation-filters="sRGB">
+<feFlood flood-opacity="0" result="BackgroundImageFix"/>
+<feColorMatrix in="SourceAlpha" type="matrix" values="0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0" result="hardAlpha"/>
+<feOffset/>
+<feGaussianBlur stdDeviation="5.22667"/>
+<feComposite in2="hardAlpha" operator="out"/>
+<feColorMatrix type="matrix" values="0 0 0 0 1 0 0 0 0 0.917647 0 0 0 0 0.823529 0 0 0 1 0"/>
+<feBlend mode="normal" in2="BackgroundImageFix" result="effect1_dropShadow_24035_282607"/>
+<feBlend mode="normal" in="SourceGraphic" in2="effect1_dropShadow_24035_282607" result="shape"/>
+<feGaussianBlur stdDeviation="7.09333" result="effect2_foregroundBlur_24035_282607"/>
+</filter>
+</defs>
+</svg>

BIN
static/img/icon-h5-topc.png


Rozdielové dáta súboru neboli zobrazené, pretože súbor je príliš veľký
+ 5 - 0
static/img/icon-h5-treasure.svg


+ 5 - 2
types/global.js

@@ -4,13 +4,16 @@
 
 /**
  * 玩法类型
- * 普通任务:common=1;
- * 抽奖:lottery=2
+ * 普通红包:common=1;
+ * 抽奖:lottery=2;
+ * 夺宝:Treasure=3;
+ * NFT
  */
 export const PlayType = {
 	common: 1,
 	lottery: 2,
 	Treasure: 3,
+	NFT: 4,
 };
 
 /**

+ 9 - 0
utils/help.js

@@ -225,3 +225,12 @@ export const getUserInfo = () => {
 		return null;
 	}
 };
+
+export function getQueryString(name) {
+	let reg = new RegExp('(^|&)' + name + '=([^&]*)(&|$)', 'i');
+	let r = window.location.search.substr(1).match(reg);
+	if (r != null) {
+		return decodeURIComponent(r[2]);
+	}
+	return null;
+}

Niektoré súbory nie sú zobrazené, pretože je v týchto rozdielových dátach zmenené mnoho súborov