zhangwei пре 3 година
родитељ
комит
7d0aceed5d
8 измењених фајлова са 1026 додато и 34 уклоњено
  1. 2 0
      package.json
  2. 447 14
      pages/index.vue
  3. 27 0
      static/svg/back-denet.svg
  4. 3 0
      static/svg/back-down.svg
  5. 17 0
      static/svg/back-top.svg
  6. 16 0
      static/svg/icon-logo.svg
  7. 4 0
      static/svg/icon-usd.svg
  8. 510 20
      yarn.lock

+ 2 - 0
package.json

@@ -33,6 +33,8 @@
     "babel-core": "7.0.0-bridge.0",
     "babel-jest": "^27.4.4",
     "jest": "^27.4.4",
+    "sass": "^1.49.11",
+    "sass-loader": "^10.2.1",
     "vue-jest": "^3.0.4"
   }
 }

+ 447 - 14
pages/index.vue

@@ -1,7 +1,83 @@
 <template>
-  <div>
-    {{JSON.stringify(detail)}}
-  </div>
+	<div class="content" :style="{ 'backgroundImage': `url(${this.back_img})` }">
+		<div class="logo">
+			<img src="/svg/icon-logo.svg" alt />
+		</div>
+		<!-- 红包 -->
+		<div class="redPacket">
+			<div class="area" v-show="area_show">
+				<div class="title">
+					<img src="/svg/icon-logo.svg" alt />
+					<span>Giveaways from: Elon Musk</span>
+				</div>
+				<div class="txt">Good Luck!</div>
+			</div>
+
+			<img src="/svg/back-top.svg" alt class="top" />
+			<img src="/svg/back-down.svg" alt class="down" />
+			<img src="/svg/icon-usd.svg" alt class="start" v-show="area_show" />
+			<!-- 内容 -->
+			<div class="head">
+				<div class="head-title">
+					<img src="/svg/icon-logo.svg" alt />
+					<span>Giveaways from: Elon Musk</span>
+				</div>
+				<div class="head-txt">Awesome! You Will Get</div>
+				<div class="head-money">
+					<img src="/svg/icon-usd.svg" alt />
+					<span class="money-txt">1.753</span>
+					<div>
+						<span>USD</span>
+					</div>
+				</div>
+			</div>
+			<div class="luck-list-title">
+				<div>0/0 People Got</div>
+				<div>Total $1 isd</div>
+			</div>
+			<div class="luck-list">
+				<div class="luck-item">
+					<img alt />
+					<div class="luck-content">
+						<div class="luck-title">123</div>
+						<div class="luck-time">123</div>
+					</div>
+					<div class="luck-money">
+						<img src="/svg/icon-logo.svg" alt />
+						<div class="luck-money-txt">123</div>
+					</div>
+					<div class="luck-king">
+						<img src="/svg/icon-logo.svg" alt />
+						<span>Luckiest Draw</span>
+					</div>
+				</div>
+			</div>
+		</div>
+		<!-- 安装 -->
+		<div class="install">
+			<div class="title">Withdraw to Wallet</div>
+			<div class="validity">
+				<span>Validity</span>
+				<span style="color: red;">23:57:32</span>
+			</div>
+
+			<div class="flow">
+				<div class="line"></div>
+
+				<div class="area_num">
+					<div class="num">1</div>
+					<span>Install DeNet</span>
+				</div>
+				<div class="tip">Used for Task Verification and Giveaways Withdrawal</div>
+				<div class="install_btn">Install</div>
+				<div class="area_num">
+					<div class="num">2</div>
+					<span>Complete Tasks by Elon Musk</span>
+				</div>
+				<div class="tip">Follow、Like tweet、Retweet (Just 1-3 minutes)</div>
+			</div>
+		</div>
+	</div>
 </template>
 
 <script>
@@ -9,14 +85,16 @@ import axios from 'axios';
 
 export default {
 	name: "index",
-	data () {
+	data() {
 		return {
+			back_img: '/svg/back-denet.svg',
+			area_show: true,
 			detail: {
 				postId: '',
 				postBizData: {
 					imagePath: ''
-        }
-      },
+				}
+			},
 			title: '',
 			twitterTitle: 'deNet',
 			jumpUrl: 'https://de-net-test.piaoquantv.com/'
@@ -55,17 +133,17 @@ export default {
 			]
 		}
 	},
-  async asyncData (params) {
-     let {route} = params;
-		 let {data} = await axios.post('https://denettestapi.piaoquantv.com/denet/post/getDetail', {
+	async asyncData(params) {
+		let { route } = params;
+		let { data } = await axios.post('https://denettestapi.piaoquantv.com/denet/post/getDetail', {
 			baseInfo: {
 				token: ''
-      },
+			},
 			params: {
 				postId: route.params.id || ''
 			}
 		})
-    if (data.code == 0) {
+		if (data.code == 0) {
 			if (data.data && data.data.postBizData && typeof data.data.postBizData == 'string') {
 				data.data.postBizData = JSON.parse(data.data.postBizData)
 			}
@@ -73,11 +151,366 @@ export default {
 			return {
 				detail: data.data,
 			}
-    }
-  }
+		}
+	},
+	mounted() {
+		//改变font-size
+		(function (doc, win) {
+			var docEI = doc.documentElement,
+				resizeEvt = 'orientationchange' in window ? 'orientataionchange' : 'resize',
+				recalc = function () {
+					var clientWidth = docEI.clientWidth;
+					if (!clientWidth) return;
+					//100是字体大小,1510是开发时浏览器窗口的宽度,等比计算
+					docEI.style.fontSize = 10 * (clientWidth / 1510) + 'px';
+				}
+
+			if (!doc.addEventListener) return;
+			win.addEventListener(resizeEvt, recalc, false);
+			doc.addEventListener('DOMContentLoaded', recalc, false);
+		})(document, window);
+		setTimeout(() => {
+			this.area_show = false
+		}, 1000)
+	}
 }
 </script>
 
-<style scoped>
+<style lang="scss" >
+html,
+body,
+#__nuxt,
+#__layout {
+	width: 100%;
+	height: 100%;
+	padding: 0;
+	margin: 0;
+}
+.content {
+	width: 100%;
+	height: 100%;
+	background-size: 100%;
+	background-repeat: no-repeat;
+	position: relative;
+	font-family: "SF Pro Display";
+	font-style: normal;
+	font-weight: 600;
+	.logo {
+		position: absolute;
+		left: 4rem;
+		top: 1.5rem;
+		img {
+			width: 107px;
+			height: 40px;
+		}
+	}
+	.redPacket {
+		position: absolute;
+		top: 9rem;
+		left: 50%;
+		width: 37.5rem;
+		margin-left: -18rem;
+		height: 65rem;
+		border-radius: 2rem;
+		// background: red;
+		overflow: hidden;
+		animation: key_packet 3s;
+		animation-delay: 6s;
+		animation-fill-mode: forwards;
+		box-shadow: 0 0 5px #888888;
+		.start {
+			position: absolute;
+			width: 10rem;
+			height: 10rem;
+			bottom: 24rem;
+			left: 50%;
+			margin-left: -5rem;
+			z-index: 3;
+		}
+		.top {
+			top: 0;
+			position: absolute;
+			width: 100%;
+			z-index: 1;
+			animation: key_top 4s;
+			animation-delay: 2s;
+			animation-fill-mode: forwards;
+		}
+		.down {
+			bottom: 0;
+			position: absolute;
+			height: 32.3rem;
+			animation: key_down 4s;
+			animation-delay: 2s;
+			animation-fill-mode: forwards;
+		}
+		.head {
+			.head-title {
+				height: 9.7rem;
+				line-height: 9.7rem;
+				background: #ef4545;
+				text-align: center;
+				border-radius: 0 586px 586px/0 0 104px 104px;
+				overflow: hidden;
+				box-shadow: 0 0 5px #888888;
+
+				img {
+					width: 3rem;
+					height: 3rem;
+					border-radius: 50%;
+
+					border: 2px solid #fff4db;
+				}
+				span {
+					font-size: 1.4rem;
+					color: #fff2d3;
+				}
+			}
+
+			.head-txt {
+				margin-top: 4.7rem;
+				font-size: 2rem;
+				text-align: center;
+				color: #ef4545;
+			}
+			.head-money {
+				display: flex;
+				align-items: center;
+				justify-content: center;
+				img {
+					width: 4rem;
+					height: 4rem;
+				}
+				span {
+					font-size: 1.3rem;
+				}
+				.money-txt {
+					font-weight: 700;
+					font-size: 4.8rem;
+					color: #000000;
+					letter-spacing: 0.3px;
+				}
+			}
+		}
+		.luck-list-title {
+			padding: 0 16px;
+			background: #fff;
+			color: #9b9b9b;
+			display: flex;
+			justify-content: space-between;
+		}
+		.luck-list {
+			background: #fff;
+			.luck-item {
+				display: flex;
+				padding: 12px 16px;
+				border-top: 1px solid #d1d1d1;
+				justify-content: space-between;
+				position: relative;
+				img:first-child {
+					border-radius: 50%;
+				}
+				.luck-king {
+					position: absolute;
+					top: 36px;
+					right: 16px;
+					display: flex;
+					align-items: center;
+					img {
+						width: 22px;
+						height: 19px;
+						margin: 0;
+					}
+					span {
+						font-weight: 500;
+						font-size: 12px;
+						line-height: 14px;
+						letter-spacing: 0.3px;
+						color: #f5b945;
+					}
+				}
+				img {
+					width: 42px;
+					height: 42px;
+					margin-right: 12px;
+				}
+				.luck-content {
+					flex: auto;
+					.luck-title {
+						font-weight: 500;
+						font-size: 16px;
+						letter-spacing: 0.3px;
+						color: #444444;
+					}
+					.luck-time {
+						font-weight: 400;
+						font-size: 12px;
+						line-height: 14px;
+
+						color: #9b9b9b;
+					}
+				}
+				.luck-money {
+					display: flex;
+					height: 17px;
+					align-items: center;
+					img {
+						width: 14px;
+						height: 14px;
+						margin-right: 6px;
+					}
+					.luck-money-txt {
+						font-weight: 500;
+						font-size: 14px;
+						/* identical to box height */
+
+						text-align: right;
+						letter-spacing: 0.3px;
 
+						color: #444444;
+					}
+				}
+			}
+		}
+		.area {
+			position: absolute;
+			z-index: 2;
+			width: 100%;
+			.title {
+				z-index: 11;
+				margin-top: 8.5rem;
+				text-align: center;
+				img {
+					width: 3rem;
+					height: 3rem;
+					border: 2px solid #fff4db;
+				}
+				span {
+					letter-spacing: 0.3px;
+					font-size: 1.6rem;
+					color: #fff2d3;
+				}
+			}
+			.txt {
+				font-size: 4rem;
+				text-align: center;
+				letter-spacing: 0.03rem;
+				color: #fff2d3;
+			}
+		}
+	}
+	.install {
+		position: absolute;
+		top: 20rem;
+		right: 28.5rem;
+		opacity: 0;
+		animation: key_install 2s;
+		animation-delay: 6s;
+		animation-fill-mode: forwards;
+		.title {
+			font-size: 4.8rem;
+			color: #000000;
+			letter-spacing: 0.3px;
+		}
+		.validity {
+			margin-top: 2rem;
+			background: rgba(166, 166, 166, 0.1);
+			width: 40rem;
+			height: 3.3rem;
+			line-height: 3.3rem;
+
+			span {
+				color: #000000;
+				font-size: 1.4rem;
+			}
+		}
+		.flow {
+			position: absolute;
+			margin-top: 4.6rem;
+			.line {
+				position: absolute;
+				height: 16rem;
+				border: 1px solid #e0e0e0;
+				top: 3rem;
+				left: 1.2rem;
+			}
+			.area_num {
+				display: flex;
+				align-items: center;
+				.num {
+					width: 2.4rem;
+					height: 2.4rem;
+					background-color: rgba(56, 154, 255, 1);
+					border-radius: 50%;
+					color: #fff;
+					text-align: center;
+					line-height: 2.4rem;
+					font-size: 1.4rem;
+				}
+				span {
+					margin-left: 1.5rem;
+					color: #000000;
+					font-size: 1.8rem;
+				}
+			}
+			.tip {
+				margin-left: 4rem;
+				margin-top: 0.7rem;
+				font-size: 1.4rem;
+				color: #a4a4a4;
+			}
+			.install_btn {
+				margin-left: 4rem;
+				margin-top: 2rem;
+				margin-bottom: 6.7rem;
+				width: 23rem;
+				height: 5.8rem;
+				background: #389aff;
+				border-radius: 10rem;
+				color: #fff;
+				line-height: 5.8rem;
+				text-align: center;
+			}
+		}
+	}
+}
+@keyframes key_install {
+	0% {
+		opacity: 0.1;
+	}
+	100% {
+		opacity: 1;
+	}
+}
+@keyframes key_packet {
+	0% {
+	}
+	100% {
+		left: 30.6rem;
+		margin-left: -18rem;
+	}
+}
+@keyframes key_top {
+	0% {
+		top: 0;
+	}
+	50% {
+		top: -30rem;
+	}
+	100% {
+		top: -36rem;
+	}
+}
+
+@keyframes key_down {
+	0% {
+		bottom: 0;
+	}
+	50% {
+		bottom: -28.3rem;
+	}
+	100% {
+		bottom: -32.3rem;
+	}
+}
 </style>

+ 27 - 0
static/svg/back-denet.svg

@@ -0,0 +1,27 @@
+<svg width="1510" height="866" viewBox="0 0 1510 866" fill="none" xmlns="http://www.w3.org/2000/svg">
+<rect width="1510" height="943" fill="url(#paint0_linear_13321_142413)"/>
+<g opacity="0.07">
+<path d="M998.14 379.892C969.277 344.064 952 298.51 952 248.921C952 199.331 969.277 153.777 998.14 117.95M1107.9 451.054C1124.83 455.484 1142.6 457.842 1160.92 457.842C1250.7 457.842 1327.25 401.213 1356.81 321.727M1357.81 178.885C1329.02 97.9473 1251.74 40 1160.92 40C1144.87 40 1129.24 41.81 1114.23 45.237" stroke="#4A4A4A" stroke-width="20" stroke-linecap="round" stroke-linejoin="round"/>
+<g clip-path="url(#clip0_13321_142413)">
+<circle cx="1162.59" cy="248.926" r="149.856" stroke="#4A4A4A" stroke-width="20"/>
+<path d="M1148.85 99.3516L1168.85 107.265V393.74L1148.85 401.654V99.3516Z" fill="#4A4A4A"/>
+</g>
+<circle cx="1045.81" cy="73.2812" r="27" fill="#FC782C"/>
+<circle cx="1045.81" cy="423.859" r="27" fill="#FC782C"/>
+<circle cx="1366.52" cy="251.555" r="27" fill="#FC782C"/>
+</g>
+<rect width="1510" height="943" fill="url(#paint1_linear_13321_142413)"/>
+<defs>
+<linearGradient id="paint0_linear_13321_142413" x1="755" y1="0" x2="755" y2="493.477" gradientUnits="userSpaceOnUse">
+<stop stop-color="#FFF8EA"/>
+<stop offset="1" stop-color="white"/>
+</linearGradient>
+<linearGradient id="paint1_linear_13321_142413" x1="755" y1="0" x2="755" y2="402" gradientUnits="userSpaceOnUse">
+<stop stop-color="#FFF8EA" stop-opacity="0"/>
+<stop offset="1" stop-color="white"/>
+</linearGradient>
+<clipPath id="clip0_13321_142413">
+<rect width="195.468" height="401.223" fill="white" transform="translate(1149.85 58.9922)"/>
+</clipPath>
+</defs>
+</svg>

+ 3 - 0
static/svg/back-down.svg

@@ -0,0 +1,3 @@
+<svg width="375" height="323" viewBox="0 0 375 323" fill="none" xmlns="http://www.w3.org/2000/svg">
+<path d="M0 0C0 0 49 28 187.5 28C326 28 375 0 375 0V323H0V0Z" fill="#EF4545"/>
+</svg>

+ 17 - 0
static/svg/back-top.svg

@@ -0,0 +1,17 @@
+<svg width="375" height="409" viewBox="0 0 375 409" fill="none" xmlns="http://www.w3.org/2000/svg">
+<g filter="url(#filter0_d_13539_7653)">
+<path d="M1.00954e-10 0H375V332.5C375 332.5 322 360.83 187.5 360.83C53 360.83 0 332.5 0 332.5L1.00954e-10 0Z" fill="#EF4545"/>
+</g>
+<defs>
+<filter id="filter0_d_13539_7653" x="-44" y="-40" width="463" height="448.83" 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 dy="4"/>
+<feGaussianBlur stdDeviation="22"/>
+<feComposite in2="hardAlpha" operator="out"/>
+<feColorMatrix type="matrix" values="0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.2 0"/>
+<feBlend mode="normal" in2="BackgroundImageFix" result="effect1_dropShadow_13539_7653"/>
+<feBlend mode="normal" in="SourceGraphic" in2="effect1_dropShadow_13539_7653" result="shape"/>
+</filter>
+</defs>
+</svg>

+ 16 - 0
static/svg/icon-logo.svg

@@ -0,0 +1,16 @@
+<svg width="107" height="40" viewBox="0 0 107 40" fill="none" xmlns="http://www.w3.org/2000/svg">
+<path d="M51.2988 12.9082V27H56.2695C60.4688 27 62.9395 24.3828 62.9395 19.9297C62.9395 15.4863 60.459 12.9082 56.2695 12.9082H51.2988ZM53.4863 14.793H56.0645C59.043 14.793 60.7031 16.6289 60.7031 19.9492C60.7031 23.2793 59.0527 25.1055 56.0645 25.1055H53.4863V14.793ZM69.3723 18.2402C70.8469 18.2402 71.843 19.3438 71.8918 20.916H66.7551C66.8625 19.3633 67.8977 18.2402 69.3723 18.2402ZM71.882 23.9824C71.5988 24.8809 70.7102 25.4863 69.509 25.4863C67.8195 25.4863 66.7453 24.3047 66.7453 22.5176V22.3906H74.0012V21.668C74.0012 18.5527 72.2238 16.541 69.3723 16.541C66.4719 16.541 64.6164 18.6895 64.6164 21.9121C64.6164 25.1543 66.4426 27.1953 69.4602 27.1953C71.8137 27.1953 73.591 25.8574 73.884 23.9824H71.882ZM78.3246 27V16.6191H78.4125L85.7172 27H87.6898V12.9082H85.5609V23.2988H85.4828L78.1781 12.9082H76.1957V27H78.3246ZM94.6402 18.2402C96.1148 18.2402 97.1109 19.3438 97.1598 20.916H92.023C92.1305 19.3633 93.1656 18.2402 94.6402 18.2402ZM97.15 23.9824C96.8668 24.8809 95.9781 25.4863 94.777 25.4863C93.0875 25.4863 92.0133 24.3047 92.0133 22.5176V22.3906H99.2691V21.668C99.2691 18.5527 97.4918 16.541 94.6402 16.541C91.7398 16.541 89.8844 18.6895 89.8844 21.9121C89.8844 25.1543 91.7105 27.1953 94.7281 27.1953C97.0816 27.1953 98.859 25.8574 99.152 23.9824H97.15ZM101.825 14.2949V16.7266H100.331V18.3965H101.825V24.2949C101.825 26.2773 102.636 27.0684 104.716 27.0684C105.184 27.0684 105.653 27.0293 105.888 26.9707V25.3008C105.751 25.3301 105.409 25.3496 105.194 25.3496C104.335 25.3496 103.944 24.9492 103.944 24.0605V18.3965H105.897V16.7266H103.944V14.2949H101.825Z" fill="black"/>
+<path d="M7.39485 29.8718C5.20124 27.1489 3.88818 23.6868 3.88818 19.918C3.88818 16.1492 5.20124 12.6871 7.39485 9.96421M15.7365 35.2802C17.0233 35.6168 18.3738 35.796 19.7662 35.796C26.5893 35.796 32.4072 31.4922 34.6534 25.4513M34.73 14.5953C32.5418 8.44404 26.6683 4.04004 19.7662 4.04004C18.5463 4.04004 17.3586 4.1776 16.2177 4.43805" stroke="black" stroke-width="1.976" stroke-linecap="round" stroke-linejoin="round"/>
+<g clip-path="url(#clip0_13321_142428)">
+<circle cx="19.8932" cy="19.9186" r="11.1611" stroke="black" stroke-width="1.976"/>
+<path d="M18.8486 8.55078L20.8246 9.15222V30.9243L18.8486 31.5257V8.55078Z" fill="black"/>
+</g>
+<circle cx="11.0173" cy="6.56958" r="2.052" fill="#FC782C"/>
+<circle cx="11.0173" cy="33.2131" r="2.052" fill="#FC782C"/>
+<circle cx="35.3914" cy="20.1184" r="2.052" fill="#FC782C"/>
+<defs>
+<clipPath id="clip0_13321_142428">
+<rect width="14.8555" height="30.4929" fill="white" transform="translate(18.9248 5.4834)"/>
+</clipPath>
+</defs>
+</svg>

+ 4 - 0
static/svg/icon-usd.svg

@@ -0,0 +1,4 @@
+<svg width="20" height="20" viewBox="0 0 20 20" fill="none" xmlns="http://www.w3.org/2000/svg">
+<rect width="20" height="20" rx="10" fill="#FFB443"/>
+<path d="M10.4871 15.4098V14.5332C12.4926 14.3738 13.6414 13.3445 13.6414 11.691C13.6414 10.2898 12.818 9.43984 11.1445 9.04141L10.4871 8.90195V6.14609C11.2973 6.25234 11.8617 6.81016 11.8816 7.51406H13.4688C13.4355 6.01992 12.2801 4.95078 10.4871 4.79141V3.875H9.5707V4.79141C7.69141 4.95742 6.5625 5.98008 6.5625 7.54727C6.5625 8.87539 7.39922 9.77852 8.9332 10.1504L9.5707 10.3098V13.2117C8.63438 13.1055 8.03008 12.5676 7.97031 11.8105H6.35C6.35664 13.3777 7.5918 14.4203 9.5707 14.5465V15.4098H10.4871ZM12.0277 11.8637C12.0277 12.6605 11.4633 13.1652 10.4871 13.225V10.4824C11.543 10.6949 12.0277 11.1332 12.0277 11.8637ZM8.19609 7.41445C8.19609 6.71055 8.77383 6.18594 9.5707 6.13945V8.70937C8.67422 8.52344 8.19609 8.07852 8.19609 7.41445Z" fill="white"/>
+</svg>

Разлика између датотеке није приказан због своје велике величине
+ 510 - 20
yarn.lock


Неке датотеке нису приказане због велике количине промена