167 lines
3.6 KiB
Vue
167 lines
3.6 KiB
Vue
|
<template>
|
||
|
<pb-layout navbar="inner" iconColor="#fff" class="buy-point-wrap" leftIcon="leftIcon" color="#fff" title="购买积分"
|
||
|
:bgStyle="bgStyle">
|
||
|
<view class="title ss-m-t-80">
|
||
|
<view class="main">购买商城积分</view>
|
||
|
<view class="sub ss-flex ss-row-center ss-m-t-55"><text style="color: #F3D3BF;"
|
||
|
class="cicon-safe"></text>订单多多·出单多多<text style="color: #F3D3BF;" class="cicon-safe"></text></view>
|
||
|
</view>
|
||
|
|
||
|
<view class="middle ss-m-t-150 ss-flex-col ss-row-center ss-col-center ss-gap-40">
|
||
|
<view class="title">积分额度选择</view>
|
||
|
<view class="sub">专属您的积分</view>
|
||
|
</view>
|
||
|
|
||
|
<view class="combo ss-m-t-90 ss-m-b-50 ss-p-x-40">
|
||
|
<button class="ss-reset-button draw-btn ui-Shadow-Main">购买5000积分/50元</button>
|
||
|
<button class="ss-reset-button draw-btn-raw ui-Shadow-Main">购买5000积分/50元</button>
|
||
|
</view>
|
||
|
|
||
|
<view class="agreement-box ss-flex ss-row-center" :class="{ shake: state.isShaking }">
|
||
|
<label class="radio ss-flex" @tap="onChange">
|
||
|
<radio :checked="state.agreeStatus" color="rgba(243, 192, 156, 1)" style="transform: scale(0.8)"
|
||
|
@tap.stop="onChange" />
|
||
|
<view class="agreement-text ss-flex ss-m-l-8">
|
||
|
我已阅读并遵守
|
||
|
<view class="tcp-text" @tap.stop="onProtocol('积分须知')"> 《积分须知》 </view>
|
||
|
</view>
|
||
|
</label>
|
||
|
</view>
|
||
|
|
||
|
</pb-layout>
|
||
|
</template>
|
||
|
|
||
|
<script setup>
|
||
|
import { ref } from 'vue'
|
||
|
|
||
|
const state = ref({
|
||
|
isShaking: false,
|
||
|
agreeStatus: false,
|
||
|
})
|
||
|
|
||
|
const bgStyle = {
|
||
|
backgroundImage: '/static/point.png',
|
||
|
imageType: 'local',
|
||
|
backgroundColor: '#fff',
|
||
|
description: '',
|
||
|
}
|
||
|
|
||
|
function onProtocol(title) {
|
||
|
|
||
|
}
|
||
|
</script>
|
||
|
|
||
|
<style lang="scss" scoped>
|
||
|
.buy-point-wrap {
|
||
|
|
||
|
.title {
|
||
|
.main {
|
||
|
font-size: 80rpx;
|
||
|
color: rgba(232, 181, 150, 1);
|
||
|
letter-spacing: 20px;
|
||
|
position: relative;
|
||
|
left: 20px;
|
||
|
}
|
||
|
|
||
|
.sub {
|
||
|
font-size: 32rpx;
|
||
|
color: #f3d3bf;
|
||
|
letter-spacing: 4px;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.middle {
|
||
|
.title {
|
||
|
font-size: 39rpx;
|
||
|
color: #fccdb1;
|
||
|
}
|
||
|
|
||
|
.title::before {
|
||
|
content: "";
|
||
|
display: block;
|
||
|
width: 80px;
|
||
|
position: relative;
|
||
|
left: -100px;
|
||
|
top: 14px;
|
||
|
border-bottom: 1px dotted #e7b493;
|
||
|
}
|
||
|
|
||
|
.title::after {
|
||
|
content: "";
|
||
|
display: block;
|
||
|
width: 80px;
|
||
|
position: relative;
|
||
|
left: 130px;
|
||
|
top: -12px;
|
||
|
border-bottom: 1px dotted #e7b493;
|
||
|
}
|
||
|
|
||
|
.sub {
|
||
|
background-color: #e7b493;
|
||
|
border-radius: 18rpx;
|
||
|
border: 1px solid #979797;
|
||
|
letter-spacing: 5px;
|
||
|
padding: 0 10rpx 0 18rpx;
|
||
|
font-size: 24rpx;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.combo {
|
||
|
|
||
|
.draw-btn {
|
||
|
height: 82rpx;
|
||
|
line-height: normal;
|
||
|
background: linear-gradient(-90deg, rgba(230, 179, 147, 1), rgba(250, 232, 218, 1));
|
||
|
border-radius: 28rpx;
|
||
|
font-size: 32rpx;
|
||
|
font-weight: 500;
|
||
|
}
|
||
|
|
||
|
.draw-btn-raw {
|
||
|
height: 82rpx;
|
||
|
line-height: normal;
|
||
|
background: transparent;
|
||
|
border-radius: 28rpx;
|
||
|
font-size: 32rpx;
|
||
|
font-weight: 500;
|
||
|
color: #e7b493;
|
||
|
border: 1px solid #E7B493;
|
||
|
margin-top: 20px;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
.agreement-box {
|
||
|
|
||
|
width: 100%;
|
||
|
|
||
|
.protocol-check {
|
||
|
transform: scale(0.7);
|
||
|
}
|
||
|
|
||
|
.agreement-text {
|
||
|
font-size: 26rpx;
|
||
|
font-weight: 500;
|
||
|
color: #999999;
|
||
|
|
||
|
.tcp-text {
|
||
|
color: rgba(243, 192, 156, 1);
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.shake {
|
||
|
animation: shake 0.05s linear 4 alternate;
|
||
|
}
|
||
|
|
||
|
@keyframes shake {
|
||
|
from {
|
||
|
transform: translateX(-5rpx);
|
||
|
}
|
||
|
|
||
|
to {
|
||
|
transform: translateX(5rpx);
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
</style>
|