3
0
Fork 0

feat(shareRegiest): 分享注册逻辑迁移

This commit is contained in:
woody 2025-09-01 18:00:47 +08:00
parent 7563c45987
commit f6387859cf
11 changed files with 1920 additions and 1171 deletions

View File

@ -14,9 +14,9 @@ export default {
'pages/login/index', 'pages/login/index',
// 'pages/wechatPay/bfPay/', // 'pages/wechatPay/bfPay/',
// 'pages/wechatPay/hfPay/', // 'pages/wechatPay/hfPay/',
// 'pages/shareArea/hiList', 'pages/shareArea/hiList',
// 'pages/shareArea/hiOrder', 'pages/shareArea/hiOrder',
// 'pages/pay/hiPay' 'pages/pay/hiPay',
] ]
if (whiteList.indexOf(options.path) !== -1) return if (whiteList.indexOf(options.path) !== -1) return
this.$store.dispatch('GetInfo') this.$store.dispatch('GetInfo')

View File

@ -0,0 +1,311 @@
<template>
<view class="default-share-page">
<!-- 背景图片替代CSS background -->
<img
class="share-bg-image"
src="/static/images/share-bg.jpg"
mode="scaleToFill"
crossorigin="anonymous"
@load="onBackgroundImageLoad"
@error="onBackgroundImageError"
/>
<view class="share-wrapper">
<view class="portal-frame" :class="{ 'is-loaded': isLoaded }">
<!-- 二维码样式区域 - 用户自定义样式位置 -->
<view class="qr-code-outer">
<img
class="qr-code"
:src="qrCodeImage"
mode="aspectFit"
v-if="qrCodeImage"
/>
<view v-else class="qr-code-placeholder">
<view class="loader"></view>
</view>
</view>
<!-- 会员编号样式区域 - 用户自定义样式位置 -->
<text
class="member-code-text"
style="
font-size: 30rpx;
color: #fff;
font-weight: bold;
margin-top: 20rpx;
"
>{{ desensitization(userInfo.memberCode) }}</text
>
</view>
</view>
</view>
</template>
<script>
import html2canvas from 'html2canvas'
export default {
name: 'DefaultSharePage',
props: {
qrCodeImage: {
type: String,
default: '',
},
userInfo: {
type: Object,
default: () => ({}),
},
isWechat: {
type: Boolean,
default: false,
},
isLoaded: {
type: Boolean,
default: false,
},
},
data() {
return {
backgroundImageLoaded: false,
shareButtonShow: true,
}
},
methods: {
desensitization(str) {
if (!str) return ''
if (str.length <= 8) return str.slice(0, 4) + '****'
const len = str.length - 6
const placeholder = '*'.repeat(len)
return str.slice(0, 4) + placeholder + str.slice(-2)
},
//
onBackgroundImageLoad() {
this.backgroundImageLoaded = true
console.log('默认场景背景图片加载成功')
},
//
onBackgroundImageError(e) {
console.error('默认场景背景图片加载失败:', e)
},
async sharePage() {
if (!this.qrCodeImage) {
uni.showToast({
title: '二维码尚未生成',
icon: 'none',
})
return
}
uni.showLoading({ title: '加载中...' })
try {
this.shareButtonShow = false
await this.$nextTick()
await this.capturePageWithHtml2Canvas()
} catch (error) {
uni.hideLoading()
uni.showToast({ title: '图片生成失败,请稍后重试', icon: 'none' })
console.error('sharePage error:', error)
} finally {
//
this.shareButtonShow = true
}
},
// 使html2canvas
async capturePageWithHtml2Canvas() {
console.log('开始使用html2canvas截取页面')
return new Promise((resolve, reject) => {
//
const waitForImages = () => {
if (!this.backgroundImageLoaded || !this.qrCodeImage) {
setTimeout(waitForImages, 100)
return
}
//
setTimeout(() => {
const element = this.$el
if (!element) {
reject(new Error('找不到组件容器'))
return
}
console.log(
'开始html2canvas截取容器尺寸:',
element.offsetWidth,
'x',
element.offsetHeight
)
html2canvas(element, {
useCORS: true,
allowTaint: true,
backgroundColor: null,
scale: 2,
dpi: 400,
logging: true,
width: element.offsetWidth,
height: element.offsetHeight,
windowWidth: element.offsetWidth,
windowHeight: element.offsetHeight,
scrollX: 0,
scrollY: 0,
x: 0,
y: 0,
})
.then(canvas => {
const dataUrl = canvas.toDataURL('image/jpeg', 1)
this.$emit('share-generated', dataUrl)
resolve()
})
.catch(err => {
console.error('html2canvas截取失败:', err)
reject(err)
})
}, 1000)
}
//
waitForImages()
})
},
},
}
</script>
<style lang="scss" scoped>
.default-share-page {
position: relative;
width: 100%;
height: 100%;
display: flex;
flex-direction: column;
align-items: center;
}
/* 背景图片样式 */
.share-bg-image {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
z-index: 1;
}
.share-wrapper {
position: absolute;
z-index: 2;
top: 320rpx;
display: flex;
flex-direction: column;
align-items: center;
}
.portal-frame {
padding: 32rpx;
width: 520rpx;
border-radius: 40rpx;
display: flex;
box-sizing: border-box;
flex-direction: column;
align-items: center;
margin: 0 auto;
opacity: 0;
transform: translateY(20rpx);
transition: all 0.3s ease;
}
.portal-frame.is-loaded {
opacity: 1;
transform: translateY(0);
}
/* 二维码样式区域 - 用户自定义样式位置 */
.qr-code-outer {
width: 300rpx;
height: 300rpx;
background: rgba(255, 255, 255, 0.98);
border-radius: 20rpx;
box-shadow: 0px 8rpx 20rpx rgba(50, 50, 90, 0.06);
border: 1px solid #f0f0f0;
display: flex;
align-items: center;
justify-content: center;
padding: 12rpx;
box-sizing: border-box;
}
.qr-code,
.qr-code-placeholder {
width: 100%;
height: 100%;
}
.qr-code {
border-radius: 16rpx;
}
.qr-code-placeholder {
display: flex;
align-items: center;
justify-content: center;
}
.loader {
width: 100rpx;
height: 100rpx;
border: 8rpx solid rgba(0, 0, 0, 0.1);
border-left-color: #0072ff;
border-radius: 50%;
animation: spin 1s linear infinite;
}
@keyframes spin {
to {
transform: rotate(360deg);
}
}
/* 会员编号样式区域 - 用户自定义样式位置 */
.member-code-text {
/* 用户可以在这里自定义会员编号的样式 */
}
/* 下载按钮样式 */
.share-button {
margin-top: 28rpx;
width: 280rpx;
height: 72rpx;
line-height: 72rpx;
color: #fff;
border-radius: 36rpx;
font-size: 26rpx;
font-weight: 500;
background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
box-shadow: 0 5rpx 12rpx 0 rgba(102, 126, 234, 0.2);
border: none;
padding: 0;
text-align: center;
transition: all 0.3s ease;
letter-spacing: 1rpx;
}
button.share-button {
padding: 0;
line-height: 72rpx;
border: none;
}
.share-button:active {
transform: translateY(1rpx);
box-shadow: 0 4rpx 10rpx rgba(102, 126, 234, 0.4);
background: linear-gradient(135deg, #5a67d8 0%, #6b46c1 100%);
}
</style>

View File

@ -0,0 +1,501 @@
<template>
<view ref="specialSharePage" class="special-share-page">
<!-- 特殊场景背景图片 -->
<image
class="share-bg-image"
:src="specialBackgroundImage"
mode="scaleToFill"
crossorigin="anonymous"
@load="onBackgroundImageLoad"
@error="onBackgroundImageError"
v-if="specialBackgroundImage"
></image>
<!-- 加载状态 -->
<view
class="loading-container"
v-if="!specialBackgroundImage || isLoadingBackground"
>
<view class="loader"></view>
<text class="loading-text">{{
isLoadingBackground ? '正在获取背景图片...' : '正在加载分享背景...'
}}</text>
</view>
<view
class="share-wrapper"
v-if="specialBackgroundImage && !isLoadingBackground"
>
<view class="portal-frame" :class="{ 'is-loaded': isLoaded }">
<view class="qr-code-outer special-qr-style">
<image
class="qr-code"
:src="qrCodeImage"
mode="aspectFit"
v-if="qrCodeImage"
></image>
<view v-else class="qr-code-placeholder">
<view class="loader"></view>
</view>
</view>
<text
class="member-code-text special-member-code-style"
style="
font-size: 30rpx;
color: #005bac;
font-weight: bold;
margin-top: 20rpx;
"
>{{ desensitization(userInfo.memberCode) }}</text
>
</view>
</view>
</view>
</template>
<script>
import { snapdom } from '@zumer/snapdom'
import html2canvas from 'html2canvas'
import { getSharedImg } from '@/config/login'
export default {
name: 'SpecialSharePage',
props: {
qrCodeImage: {
type: String,
default: '',
},
userInfo: {
type: Object,
default: () => ({}),
},
isWechat: {
type: Boolean,
default: false,
},
isLoaded: {
type: Boolean,
default: false,
},
// specialBackgroundImage prop
//
skipImageVerification: {
type: Boolean,
default: false,
},
},
data() {
return {
backgroundImageLoaded: false,
imageLoadRetryCount: 0,
maxRetryCount: 3,
specialBackgroundImage: '', //
isLoadingBackground: false, //
}
},
created() {
this.getBackgroundImage()
},
methods: {
desensitization(str) {
if (!str) return ''
if (str.length <= 8) return str.slice(0, 4) + '****'
const len = str.length - 6
const placeholder = '*'.repeat(len)
return str.slice(0, 4) + placeholder + str.slice(-2)
},
//
onBackgroundImageLoad() {
this.backgroundImageLoaded = true
console.log('特殊场景背景图片加载成功')
},
//
onBackgroundImageError(e) {
console.error('特殊场景背景图片加载失败:', e)
this.backgroundImageLoaded = false
this.imageLoadRetryCount++
//
if (this.imageLoadRetryCount < this.maxRetryCount) {
console.log(
`图片加载失败,重试中 (${this.imageLoadRetryCount}/${this.maxRetryCount})`
)
this.$emit('background-image-retry', this.imageLoadRetryCount)
} else {
this.$emit('background-image-error', e)
}
},
//
async getBackgroundImage() {
if (this.skipImageVerification) {
this.specialBackgroundImage = '' //
this.backgroundImageLoaded = true
return
}
if (this.specialBackgroundImage) {
// 使
this.backgroundImageLoaded = true
return
}
this.isLoadingBackground = true
try {
const result = await getSharedImg()
if (result && result.code === 200 && result.data) {
this.specialBackgroundImage =
'data:image/png;base64,' + result.data.base64
this.backgroundImageLoaded = true
} else {
this.backgroundImageLoaded = false
this.imageLoadRetryCount++
}
} catch (error) {
this.backgroundImageLoaded = false
this.imageLoadRetryCount++
if (this.imageLoadRetryCount < this.maxRetryCount) {
this.$emit('background-image-retry', this.imageLoadRetryCount)
} else {
this.$emit('background-image-error', error)
}
} finally {
this.isLoadingBackground = false
}
return this.specialBackgroundImage
},
async generateShareImage() {
// await this.getBackgroundImage()
try {
this.$nextTick(() => {
const info = uni.getSystemInfoSync()
console.log(info.platform, '.....info')
if (info.platform === 'ios') {
console.log('iOS detected, using html2canvas for capturing.')
this.capturePageWithHtml2Canvas()
} else {
console.log('Non-iOS detected, using snapdom for capturing.')
this.capturePageWithSnapDom()
}
})
} catch (error) {
uni.hideLoading()
uni.showToast({ title: '图片生成失败,请稍后重试', icon: 'none' })
}
},
// 使html2canvas (For iOS)
async capturePageWithHtml2Canvas() {
return new Promise(async (resolve, reject) => {
//
const waitForImages = async () => {
//
if (this.isLoadingBackground) {
console.log('等待背景图片接口调用完成...')
setTimeout(waitForImages, 100)
return
}
//
if (!this.backgroundImageLoaded) {
console.log('等待背景图片加载完成...')
setTimeout(waitForImages, 100)
return
}
//
if (!this.qrCodeImage) {
console.log('等待二维码生成...')
setTimeout(waitForImages, 100)
return
}
//
if (!this.specialBackgroundImage) {
console.log('等待特殊背景图片参数...')
setTimeout(waitForImages, 100)
return
}
console.log('所有图片准备就绪开始使用html2canvas截图...')
//
setTimeout(() => {
const element = this.$el
if (!element) {
uni.hideLoading()
reject(new Error('找不到组件容器'))
return
}
html2canvas(element, {
useCORS: true,
allowTaint: true,
backgroundColor: null,
scale: 2, //
dpi: 300,
width: element.offsetWidth,
height: element.offsetHeight,
})
.then(canvas => {
const dataUrl = canvas.toDataURL('image/jpeg', 1.0)
uni.hideLoading()
// this.handleShareGenerated(dataUrl)
this.$emit('share-generated', dataUrl)
resolve()
})
.catch(err => {
uni.hideLoading()
console.error('html2canvas截取失败:', err)
uni.showToast({
title: '图片生成失败,请稍后重试',
icon: 'none',
})
reject(err)
})
}, 1000)
}
//
waitForImages()
})
},
// 使snapDOM
async capturePageWithSnapDom() {
return new Promise(async (resolve, reject) => {
//
const waitForImages = async () => {
//
if (this.isLoadingBackground) {
console.log('等待背景图片接口调用完成...')
setTimeout(waitForImages, 100)
return
}
//
if (!this.backgroundImageLoaded) {
console.log('等待背景图片加载完成...')
setTimeout(waitForImages, 100)
return
}
//
if (!this.qrCodeImage) {
console.log('等待二维码生成...')
setTimeout(waitForImages, 100)
return
}
//
if (!this.specialBackgroundImage) {
console.log('等待特殊背景图片参数...')
setTimeout(waitForImages, 100)
return
}
console.log('所有图片准备就绪,开始截图...')
//
setTimeout(async () => {
const element = this.$el
if (!element) {
reject(new Error('找不到组件容器'))
return
}
try {
//
const rect = element.getBoundingClientRect()
const offsetWidth = element.offsetWidth
const offsetHeight = element.offsetHeight
const scrollWidth = element.scrollWidth
const scrollHeight = element.scrollHeight
const clientWidth = element.clientWidth
const clientHeight = element.clientHeight
//
const elementWidth = Math.max(
offsetWidth,
scrollWidth,
clientWidth,
rect.width
)
const elementHeight = Math.max(
offsetHeight,
scrollHeight,
clientHeight,
rect.height
)
setTimeout(async () => {
try {
const result = await snapdom(element, {
width: elementWidth,
height: elementHeight,
quality: 1,
compress: false,
// useProxy: true,
})
const canvas = await result.toCanvas()
const dataUrl = canvas.toDataURL('image/jpeg')
uni.hideLoading()
// this.handleShareGenerated(dataUrl)
this.$emit('share-generated', dataUrl)
resolve()
} catch (err) {
uni.hideLoading()
console.error('snapDOM截取失败:', err)
uni.showToast({
title: '图片生成失败,请稍后重试',
icon: 'none',
})
reject(err)
}
}, 500)
} catch (err) {
uni.hideLoading()
console.error('snapDOM初始化失败:', err)
uni.showToast({
title: '图片生成失败,请稍后重试',
icon: 'none',
})
reject(err)
}
}, 1000)
}
//
waitForImages()
})
},
},
}
</script>
<style lang="scss" scoped>
.special-share-page {
position: relative;
width: 100%;
height: 100%;
display: flex;
flex-direction: column;
align-items: center;
}
/* 背景图片样式 */
.share-bg-image {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
z-index: 1;
}
/* 加载状态 */
.loading-container {
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
display: flex;
flex-direction: column;
align-items: center;
z-index: 2;
}
.loading-text {
margin-top: 20rpx;
font-size: 28rpx;
color: #666;
}
.share-wrapper {
position: absolute;
z-index: 2;
bottom: 22%;
display: flex;
flex-direction: column;
align-items: center;
}
.portal-frame {
padding: 32rpx;
width: 520rpx;
border-radius: 40rpx;
display: flex;
box-sizing: border-box;
flex-direction: column;
align-items: center;
margin: 0 auto;
opacity: 0;
transform: translateY(20rpx);
transition: all 0.3s ease;
}
.portal-frame.is-loaded {
opacity: 1;
transform: translateY(0);
}
/* 特殊场景二维码样式区域 - 用户自定义样式位置 */
.qr-code-outer {
width: 400rpx;
height: 400rpx;
border-radius: 20rpx;
display: flex;
align-items: center;
justify-content: center;
padding: 12rpx;
box-sizing: border-box;
}
.qr-code,
.qr-code-placeholder {
width: 100%;
height: 100%;
}
.qr-code {
border-radius: 16rpx;
}
.qr-code-placeholder {
display: flex;
align-items: center;
justify-content: center;
}
.loader {
width: 100rpx;
height: 100rpx;
border: 8rpx solid rgba(0, 0, 0, 0.1);
border-left-color: #0072ff;
border-radius: 50%;
animation: spin 1s linear infinite;
}
@keyframes spin {
to {
transform: rotate(360deg);
}
}
/* 特殊场景会员编号样式区域 - 用户自定义样式位置 */
.member-code-text {
/* 用户可以在这里自定义会员编号的样式 */
}
/* 特殊场景下的会员编号样式 */
.special-member-code-style {
/* 用户可以在这里自定义特殊场景下的会员编号样式 */
/* 例如:不同的位置、颜色、字体等 */
}
</style>

View File

@ -110,7 +110,7 @@ export const waresinfo = params =>
//hi粉确认订单 //hi粉确认订单
export const fansConfirm = params => export const fansConfirm = params =>
http.post('/sale/api/order/fans-confirm-order', params) http.post('/sale/api/retail-order/fans-confirm-order', params)
//购物车注册下单校验弹框 //购物车注册下单校验弹框
export const energyShop = params => export const energyShop = params =>
http.post('/sale/api/wares/query-energy-silo', params) http.post('/sale/api/wares/query-energy-silo', params)

View File

@ -6,9 +6,12 @@ export const captchaImage = params => http.get('/code', { params })
export const login = params => export const login = params =>
http.post('/retail-member/api/retail-auth/login', params) http.post('/retail-member/api/retail-auth/login', params)
export const autoLogin = params =>
http.post('/member/api/retail-auth/auto-login', params)
//用户信息 //用户信息
export const getInfo = params => export const getInfo = params =>
http.get('/retail-member/api/retail-member/get-info', { params }) http.get('/member/api/retail-member/get-info', { params })
//获取个人资料 //获取个人资料
export const getData = params => export const getData = params =>
@ -99,12 +102,9 @@ export const indexPopScreen = params =>
export const getMenuList = params => export const getMenuList = params =>
http.get('/system/api/menu/list', { params }) http.get('/system/api/menu/list', { params })
//海粉默认登录H5扫码使用
export const autoLogin = params =>
http.post('/retail-member/auth/api/auto-login', params)
//海粉商品 //海粉商品
export const queryWares = params => export const queryWares = params =>
http.post('/sale/api/wares/query-spe-wares-copy', params) http.get('/sale/api/wares/list-wares-share', { params })
//保存礼品地址 //保存礼品地址
export const saveGiftAddress = params => export const saveGiftAddress = params =>
http.post('/retail-member/api/retail-member-gift/update-gift', params) http.post('/retail-member/api/retail-member-gift/update-gift', params)
@ -117,7 +117,7 @@ export const getUserAwards = params =>
//获取安置人编号 //获取安置人编号
export const fansConvertCode = params => export const fansConvertCode = params =>
http.get('/retail-member/api/retail-member/fans-convert-code/' + params) http.get('/member/api/member/fans-convert-code/' + params)
//获取荣誉奖衔 //获取荣誉奖衔
export const getIndexAwards = params => export const getIndexAwards = params =>

View File

@ -19,7 +19,7 @@ module.exports = vm => {
//#ifdef DEV_SERVER //#ifdef DEV_SERVER
console.log('DEV_SERVER') console.log('DEV_SERVER')
config.baseURL = 'https://t-bl.beida777.com/prod-api' config.baseURL = 'http://192.168.0.86:8080'
//#endif //#endif
//#ifdef QA_SERVER //#ifdef QA_SERVER

View File

@ -4,77 +4,28 @@
style="display: flex; flex-direction: column; height: 100vh" style="display: flex; flex-direction: column; height: 100vh"
> >
<view id="shareContainer" class="share-container"> <view id="shareContainer" class="share-container">
<!-- 微信环境只有在未生成分享图时才显示原始内容 --> <!-- 默认场景 -->
<template v-if="!isWechat || (isWechat && !generatedImageUrl)"> <DefaultSharePage
<!-- 背景图片替代CSS background --> :qrCodeImage="qrCodeImage"
<img :userInfo="userInfo"
class="share-bg-image" :isWechat="isWechat"
src="/static/images/share-bg.jpg" :isLoaded="isLoaded"
mode="scaleToFill" @share-generated="handleShareGenerated"
crossorigin="anonymous" ref="defaultSharePage"
@load="onBackgroundImageLoad"
@error="onBackgroundImageError"
/> />
<view class="share-wrapper">
<view class="portal-frame" :class="{ 'is-loaded': isLoaded }">
<view class="qr-code-outer">
<img
class="qr-code"
:src="qrCodeImage"
mode="aspectFit"
v-if="qrCodeImage"
/>
<view v-else class="qr-code-placeholder">
<view class="loader"></view>
</view>
</view>
<div
style="
font-size: 18rpx;
color: #fff;
font-weight: bold;
margin-top: 10rpx;
text-align: center;
display: flex;
align-items: center;
justify-content: center;
"
>
{{ desensitization(userInfo.memberCode) }}
</div>
<div v-if="!isWechat" class="share-button" @click="sharePage">
保存图片并分享
</div>
<img
v-if="isWechat"
class="share-btn"
style="margin-top: 30rpx"
src="/static/images/share-btn.svg"
mode="scaleToFill"
/>
</view>
<!-- <image
class="share-bg-logo"
src="/static/images/share-logo.png"
mode="scaleToFill"
></image> -->
</view>
</template>
<!-- 微信环境全屏图片显示 -->
<view <view
class="wechat-fullscreen-overlay" class="wechat-fullscreen-overlay"
v-show="isWechat && generatedImageUrl" v-show="(isWechat || userInfo.sharePosterImage) && generatedImageUrl"
@click="closeFullscreenImage"
> >
<image <img
class="fullscreen-image" class="fullscreen-image"
:src="generatedImageUrl" :src="generatedImageUrl"
mode="scaleToFill" width="100%"
@load="onGeneratedImageLoad" height="100%"
@error="onGeneratedImageError"
@click.stop="" @click.stop=""
></image> />
</view> </view>
</view> </view>
<cl-tabbar class="tabbar" :current="2" /> <cl-tabbar class="tabbar" :current="2" />
@ -82,54 +33,58 @@
</template> </template>
<script> <script>
import html2canvas from 'html2canvas' import { fansCode as getShareCode } from '@/config/goods'
import { getShareCode } from '@/config/share'
import clTabbar from '@/components/cl-tabbar.vue' import clTabbar from '@/components/cl-tabbar.vue'
import DefaultSharePage from '@/components/share/DefaultSharePage.vue'
export default { export default {
name: 'ShareQRCode', name: 'ShareQRCode',
components: { components: {
'cl-tabbar': clTabbar, 'cl-tabbar': clTabbar,
DefaultSharePage,
}, },
data() { data() {
return { return {
qrCodeImage: '', qrCodeImage: '',
// Set canvas dimensions. It's better to get device screen width for this.
canvasWidth: 375, canvasWidth: 375,
canvasHeight: 800, canvasHeight: 800,
isLoaded: false, isLoaded: false,
shareButtonShow: true, isWechat: false,
isWechat: false, // generatedImageUrl: '',
generatedImageUrl: '', // URL
backgroundImageLoaded: false, //
userInfo: uni.getStorageSync('User'), userInfo: uni.getStorageSync('User'),
sourceVisible: true,
} }
}, },
computed: {
isSpecialScene() {
return this.userInfo && this.userInfo.sharePosterImage
},
isDefaultScene() {
return !this.isSpecialScene
},
},
onLoad() { onLoad() {
this.checkWechatEnvironment() this.checkWechatEnvironment()
this.handleGetShareCode() this.handleGetShareCode()
// Get screen width to set canvas width dynamically //
uni.getSystemInfo({ uni.getSystemInfo({
success: res => { success: res => {
this.canvasWidth = res.windowWidth this.canvasWidth = res.windowWidth
this.canvasHeight = res.windowHeight this.canvasHeight = res.windowHeight
}, },
}) })
uni.showLoading({
title: '加载中...',
mask: true,
})
}, },
onReady() { onReady() {
// Use a short timeout to ensure the initial render is complete before animation //
setTimeout(() => { setTimeout(() => {
this.isLoaded = true this.isLoaded = true
}, 100) }, 100)
}, },
methods: { methods: {
desensitization(str) {
if (!str) return ''
if (str.length <= 8) return str.slice(0, 4) + '****'
const len = str.length - 6
const placeholder = '*'.repeat(len)
return str.slice(0, 4) + placeholder + str.slice(-2)
},
// //
checkWechatEnvironment() { checkWechatEnvironment() {
const ua = navigator.userAgent.toLowerCase() const ua = navigator.userAgent.toLowerCase()
@ -137,18 +92,14 @@ export default {
console.log('微信环境检测:', this.isWechat) console.log('微信环境检测:', this.isWechat)
}, },
//
handleGetShareCode() { handleGetShareCode() {
// Don't show loading toast, use the placeholder loader instead
// uni.showLoading({ title: '...' })
getShareCode() getShareCode()
.then(res => { .then(res => {
// The screenshot shows the base64 string is in data.datStr
if (res.code === 200 && res.data && res.data.dataStr) { if (res.code === 200 && res.data && res.data.dataStr) {
this.qrCodeImage = 'data:image/png;base64,' + res.data.dataStr this.qrCodeImage = 'data:image/png;base64,' + res.data.dataStr
this.$nextTick(() => { this.$nextTick(() => {
if (this.isWechat) { this.generateShareImage()
this.sharePage()
}
}) })
} else { } else {
uni.showToast({ uni.showToast({
@ -166,162 +117,38 @@ export default {
}) })
}, },
async sharePage() { //
if (!this.qrCodeImage) { async generateShareImage() {
uni.showToast({
title: '二维码尚未生成',
icon: 'none',
})
return
}
// 使html2canvas
uni.showLoading({ title: '加载中...' })
try { try {
// DOM if (this.isSpecialScene) {
this.shareButtonShow = false await this.$refs.specialSharePage.generateShareImage()
await this.$nextTick() } else {
//
// 使html2canvas await this.$refs.defaultSharePage.sharePage()
await this.capturePageWithHtml2Canvas() }
} catch (error) { } catch (error) {
console.error('生成分享图片失败:', error)
}
},
//
handleShareGenerated(dataUrl) {
uni.hideLoading() uni.hideLoading()
uni.showToast({ title: '图片生成失败,请稍后重试', icon: 'none' }) this.$nextTick(() => {
console.error('sharePage error:', error) this.sourceVisible = false
} finally {
//
this.shareButtonShow = true
}
},
//
onGeneratedImageLoad() {
console.log('生成的图片加载成功')
},
//
onGeneratedImageError(e) {
console.error('生成的图片加载失败:', e)
uni.showToast({
title: '图片显示失败',
icon: 'none',
}) })
}, uni.hideLoading()
//
closeFullscreenImage() {
this.generatedImageUrl = ''
console.log('关闭全屏图片')
},
//
onBackgroundImageLoad() {
this.backgroundImageLoaded = true
console.log('背景图片加载成功')
},
//
onBackgroundImageError(e) {
console.error('背景图片加载失败:', e)
},
// 使html2canvas
async capturePageWithHtml2Canvas() {
console.log('开始使用html2canvas截取页面')
return new Promise((resolve, reject) => {
//
const waitForImages = () => {
if (!this.backgroundImageLoaded || !this.qrCodeImage) {
setTimeout(waitForImages, 100)
return
}
//
setTimeout(() => {
const element = document.getElementById('shareContainer')
if (!element) {
reject(new Error('找不到页面容器'))
return
}
console.log(
'开始html2canvas截取容器尺寸:',
element.offsetWidth,
'x',
element.offsetHeight
)
html2canvas(element, {
useCORS: true,
allowTaint: true,
backgroundColor: null,
scale: 2,
dpi: 400,
logging: true, // 便
width: element.offsetWidth,
height: element.offsetHeight,
windowWidth: element.offsetWidth,
windowHeight: element.offsetHeight,
scrollX: 0,
scrollY: 0,
x: 0,
y: 0,
})
.then(canvas => {
const dataUrl = canvas.toDataURL('image/jpeg', 1)
//
if (this.isWechat) { if (this.isWechat) {
// //
this.generatedImageUrl = dataUrl this.generatedImageUrl = dataUrl
uni.hideLoading()
} else { } else {
// //
this.downloadImage(dataUrl) if (this.isSpecialScene) {
uni.hideLoading() //
uni.showToast({ this.generatedImageUrl = dataUrl
title: '图片已开始下载',
icon: 'success',
})
} }
resolve()
})
.catch(err => {
console.error('html2canvas截取失败:', err)
reject(err)
})
}, 1000) // 1000ms
} }
//
waitForImages()
})
},
//
loadImage(src) {
return new Promise((resolve, reject) => {
const img = new Image()
img.crossOrigin = 'anonymous'
img.onload = () => {
console.log(
`图片加载成功: ${src.substring(0, 50)}...`,
`${img.width}x${img.height}`
)
resolve(img)
}
img.onerror = error => {
console.error(`图片加载失败: ${src}`, error)
reject(new Error(`图片加载失败: ${src}`))
}
img.src = src
})
}, },
// //
@ -349,172 +176,33 @@ export default {
align-items: center; align-items: center;
} }
/* 背景图片样式 */
.share-bg-image {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
z-index: 1;
}
.share-bg {
width: 100%;
height: 100%;
img {
width: 100%;
height: 100%;
}
}
.share-wrapper {
position: absolute;
z-index: 2;
top: 370rpx;
display: flex;
flex-direction: column;
align-items: center;
}
.share-bg-logo {
width: 100%;
height: 360rpx;
// margin-top: -60rpx;
}
.portal-frame {
padding: 32rpx;
width: 520rpx;
border-radius: 40rpx;
display: flex;
box-sizing: border-box;
flex-direction: column;
align-items: center;
margin: 0 auto;
text-align: center;
}
.portal-frame.is-loaded {
opacity: 1;
transform: translateY(0);
}
/* The single white card for the QR code */
.qr-code-outer {
width: 300rpx; /* 从400rpx缩小到320rpx */
height: 300rpx; /* 从400rpx缩小到320rpx */
background: rgba(255, 255, 255, 0.98);
border-radius: 20rpx; /* 从24rpx减小到20rpx */
box-shadow: 0px 8rpx 20rpx rgba(50, 50, 90, 0.06);
border: 1px solid #f0f0f0;
display: flex;
align-items: center;
justify-content: center;
padding: 12rpx; /* 从16rpx减小到12rpx */
box-sizing: border-box;
}
/* The image and the placeholder both live inside the outer card */
.qr-code,
.qr-code-placeholder {
width: 100%;
height: 100%;
}
.qr-code {
border-radius: 16rpx;
}
.qr-code-placeholder {
display: flex;
align-items: center;
justify-content: center;
}
.loader {
width: 100rpx;
height: 100rpx;
border: 8rpx solid rgba(0, 0, 0, 0.1);
border-left-color: #0072ff;
border-radius: 50%;
animation: spin 1s linear infinite;
}
@keyframes spin {
to {
transform: rotate(360deg);
}
}
.tip {
font-size: 30rpx;
color: #888;
}
.share-button {
margin-top: 58rpx; /* 从32rpx减小到28rpx */
width: 380rpx; /* 设置固定宽度 */
color: #fff;
border-radius: 36rpx; /* 从44rpx减小到36rpx */
font-size: 16rpx; /* 从30rpx减小到26rpx */
font-weight: 500;
padding: 12rpx 0;
display: flex;
align-items: flex-start;
justify-content: center;
background: linear-gradient(
135deg,
#d4af37 0%,
#ffd700 30%,
#b8860b 70%,
#8b7355 100%
);
// box-shadow: 0 5rpx 12rpx 0 rgba(102, 126, 234, 0.2);
border: none;
border-radius: 70rpx;
text-align: center;
letter-spacing: 1rpx;
}
/* 微信环境全屏覆盖样式 */ /* 微信环境全屏覆盖样式 */
.wechat-fullscreen-overlay { .wechat-fullscreen-overlay {
position: absolute; position: absolute;
top: 0; top: 0;
left: 0; left: 0;
width: 100vw; width: 100vw;
height: 100%; /* 减去tab栏高度 */ height: 100%;
background-color: transparent;
background-color: transparent; /* 移除背景色 */
z-index: 999; z-index: 999;
display: flex; display: flex;
flex-direction: column; flex-direction: column;
align-items: stretch; /* 拉伸对齐 */ align-items: stretch;
justify-content: stretch; /* 拉伸对齐 */ justify-content: stretch;
padding: 0; padding: 0;
margin: 0; margin: 0;
} }
.fullscreen-image { .fullscreen-image {
width: 100vw; width: 100vw;
height: 100%; /* 减去tab栏高度 */ height: 100%;
object-fit: cover; /* 覆盖整个容器,可能会裁剪 */ object-fit: cover;
margin: 0; margin: 0;
padding: 0; padding: 0;
border: none; border: none;
display: block; display: block;
} }
@media screen and (max-height: 667px) {
.tabbar {
height: 70px !important;
}
}
@media screen and (min-height: 812px) {
/* iPhone X及以上机型 */
.tabbar {
height: 80px !important;
}
}
.tabbar { .tabbar {
position: static; position: static;
bottom: 0; bottom: 0;
@ -524,8 +212,17 @@ export default {
:v-deep .u-tabbar--fixed { :v-deep .u-tabbar--fixed {
height: 100px !important; height: 100px !important;
} }
// ::v-deep .u-safe-area-inset-bottom { }
// display: none !important;
// } @media screen and (max-height: 667px) {
.tabbar {
height: 70px !important;
}
}
@media screen and (min-height: 812px) {
.tabbar {
height: 80px !important;
}
} }
</style> </style>

View File

@ -11,63 +11,113 @@
<template> <template>
<view class="tit">{{ '待支付金额' }}</view> <view class="tit">{{ '待支付金额' }}</view>
<view class="tit1"> <view class="tit1">
{{ paramsPost.orderAmount | numberToCurrency }} {{ paramsPost.orderAmount | numberToCurrency }}
</view> </view>
<view class="tit2" <!-- <view class="tit2"
>{{ '请在' }} <view class="tit3">{{ countDown }}</view >{{ '请在' }} <view class="tit3">{{ countDown }}</view
>{{ '内完成支付,否则订单将会被自动取消' }} >{{ '内完成支付,否则订单将会被自动取消' }}
</view> </view> -->
</template> </template>
<!-- 暂时隐藏 --> <!-- 暂时隐藏 -->
<view v-if="false" class="kuang"> <view class="kuang">
<u-collapse <view>
:value="activeNames"
ref="collapse"
@open="change"
@close="close"
accordion
:border="false"
>
<u-collapse-item name="1">
<view slot="title" class="pf"> <view slot="title" class="pf">
<img src="@/static/images/under_pay.png" alt="" /> <img src="@/static/images/under_pay.png" alt="" />
<view>{{ '在线支付' }}</view> <view>{{ '在线支付' }}</view>
</view> </view>
<view class="flex_ac" v-show="this.payList.pay11"> <view
class="flex_ac"
v-show="payList[PAY_AUTH[PAY_TYPE.BAO_FU_WECHAT]]"
>
<view class="flex_ac_i"> <view class="flex_ac_i">
<img src="@/static/images/pay_i2.png" alt="" /> <img src="@/static/images/pay_i2.png" alt="" />
<view>{{ '宝付微信支付' }}</view> <view>{{ '宝付微信支付' }}</view>
</view> </view>
<u-radio-group v-model="whatPay"> <u-radio-group v-model="whatPay">
<u-radio activeColor="red" size="14" label="" :name="11"> <u-radio
activeColor="#005BAC"
size="18"
label=""
:name="PAY_TYPE.BAO_FU_WECHAT"
>
</u-radio> </u-radio>
</u-radio-group> </u-radio-group>
</view> </view>
<view class="flex_ac" v-show="this.payList.pay12"> <view
class="flex_ac"
v-show="payList[PAY_AUTH[PAY_TYPE.BAO_FU_WECHAT_SCAN]]"
>
<view class="flex_ac_i"> <view class="flex_ac_i">
<img src="@/static/images/pay_i2.png" alt="" /> <img src="@/static/images/pay_i2.png" alt="" />
<view>{{ '宝付微信扫码' }}</view> <view>{{ '宝付微信扫码' }}</view>
</view> </view>
<u-radio-group v-model="whatPay"> <u-radio-group v-model="whatPay">
<u-radio activeColor="red" size="14" label="" :name="12"> <u-radio
activeColor="#005BAC"
size="18"
label=""
:name="PAY_TYPE.BAO_FU_WECHAT_SCAN"
>
</u-radio> </u-radio>
</u-radio-group> </u-radio-group>
</view> </view>
<view
<view class="flex_ac" v-show="this.payList.pay13"> class="flex_ac"
v-show="payList[PAY_AUTH[PAY_TYPE.HUI_FU_WECHAT]]"
>
<view class="flex_ac_i"> <view class="flex_ac_i">
<img src="@/static/images/pay_i2.png" alt="" /> <img src="@/static/images/pay_i2.png" alt="" />
<view>{{ '汇付微信支付' }}</view> <view>{{ '汇付微信支付' }}</view>
</view> </view>
<u-radio-group v-model="whatPay"> <u-radio-group v-model="whatPay">
<u-radio activeColor="red" size="14" label="" :name="13"> <u-radio
activeColor="#005BAC"
size="18"
label=""
:name="PAY_TYPE.HUI_FU_WECHAT"
>
</u-radio> </u-radio>
</u-radio-group> </u-radio-group>
</view> </view>
<view class="flex_ac1" v-show="this.payList.pay15"> <!-- 微信支付 -->
<view class="flex_ac" v-show="payList[PAY_AUTH[PAY_TYPE.WECHAT_PAY]]">
<view class="flex_ac_i">
<img src="@/static/images/pay_i2.png" alt="" />
<view>{{ '微信支付' }}</view>
</view>
<u-radio-group v-model="whatPay">
<u-radio
activeColor="#005BAC"
size="18"
label=""
:name="PAY_TYPE.WECHAT_PAY"
>
</u-radio>
</u-radio-group>
</view>
<!-- 支付宝支付 -->
<view class="flex_ac" v-show="payList[PAY_AUTH[PAY_TYPE.ALI_PAY]]">
<view class="flex_ac_i">
<img src="@/static/images/pay_i3.png" alt="" />
<view>{{ '支付宝支付' }}</view>
</view>
<u-radio-group v-model="whatPay">
<u-radio
activeColor="#005BAC"
size="18"
label=""
:name="PAY_TYPE.ALI_PAY"
>
</u-radio>
</u-radio-group>
</view>
<view
class="flex_ac1"
v-show="payList[PAY_AUTH[PAY_TYPE.HUI_FU_BANK_CARD]]"
>
<view class="flex_ac_i"> <view class="flex_ac_i">
<img src="@/static/images/jdBank.jpg" alt="" /> <img src="@/static/images/jdBank.jpg" alt="" />
<view>{{ '汇付银行卡' }} ({{ '暂不支持信用卡' }})</view> <view>{{ '汇付银行卡' }} </view>
</view> </view>
<view class="pad"> <view class="pad">
<view <view
@ -77,14 +127,16 @@
@click.prevent="selPayRadio('hf' + index)" @click.prevent="selPayRadio('hf' + index)"
> >
<view class="flax_i"> <view class="flax_i">
{{ item.bankName }} ({{ item.bankNo }}) <view>{{ item.bankName }} ({{ item.bankNo }})</view>
<view class="fixBind" @click="fixBind(item)">解绑</view>
</view> </view>
<u-radio-group v-model="whatPay"> <u-radio-group v-model="whatPay">
<u-radio <u-radio
activeColor="red" activeColor="#005BAC"
size="14" size="18"
label="" label=""
:name="'hf' + index" :name="PAY_TYPE.HUI_FU_BANK_CARD + index"
> >
</u-radio> </u-radio>
</u-radio-group> </u-radio-group>
@ -95,51 +147,31 @@
</view> </view>
</view> </view>
</view> </view>
<view class="flex_ac" v-show="this.payList.pay32"> <view
class="flex_ac"
v-show="payList[PAY_AUTH[PAY_TYPE.TONG_LIAN_WECHAT]]"
>
<view class="flex_ac_i"> <view class="flex_ac_i">
<img src="@/static/images/pay_i2.png" alt="" /> <img src="@/static/images/pay_i2.png" alt="" />
<view>通联微信支付</view> <view>通联微信支付</view>
</view> </view>
<u-radio-group v-model="whatPay">
<u-radio activeColor="red" size="14" label="" :name="32">
</u-radio>
</u-radio-group>
</view>
<view class="flex_ac1" v-show="this.payList.pay33">
<view class="flex_ac_i">
<img src="@/static/images/jdBank.jpg" alt="" />
<view>{{ '通联银行卡' }} ({{ '暂不支持信用卡' }})</view>
</view>
<view class="pad">
<view
v-for="(item, index) in tlList"
:key="index"
class="pay_flax flex_bet"
@click.prevent="selPayRadio('tl' + index)"
>
<view class="flax_i">
{{ item.bankName }} ({{ item.bankNo }})
</view>
<u-radio-group v-model="whatPay"> <u-radio-group v-model="whatPay">
<u-radio <u-radio
activeColor="red" activeColor="#005BAC"
size="14" size="18"
label="" label=""
:name="'tl' + index" :name="PAY_TYPE.TONG_LIAN_WECHAT"
> >
</u-radio> </u-radio>
</u-radio-group> </u-radio-group>
</view> </view>
<view class="pay_flax flax_i" @click="bindBank('tl')"> <view
<img class="img1" src="@/static/images/addto.png" alt="" /> class="flex_ac1"
<view>{{ '绑定银行卡' }}</view> v-show="payList[PAY_AUTH[PAY_TYPE.JING_DONG_BANK_CARD]]"
</view> >
</view>
</view>
<view class="flex_ac1" v-show="this.payList.pay4">
<view class="flex_ac_i"> <view class="flex_ac_i">
<img src="@/static/images/jdBank.jpg" alt="" /> <img src="@/static/images/jdBank.jpg" alt="" />
<view>{{ '京东银行卡' }} ({{ '暂不支持信用卡' }})</view> <view>{{ '京东银行卡' }}</view>
</view> </view>
<view class="pad"> <view class="pad">
<view <view
@ -153,10 +185,10 @@
</view> </view>
<u-radio-group v-model="whatPay"> <u-radio-group v-model="whatPay">
<u-radio <u-radio
activeColor="red" activeColor="#005BAC"
size="14" size="18"
label="" label=""
:name="'jd' + index" :name="PAY_TYPE.JING_DONG_BANK_CARD + index"
> >
</u-radio> </u-radio>
</u-radio-group> </u-radio-group>
@ -167,8 +199,59 @@
</view> </view>
</view> </view>
</view> </view>
</u-collapse-item> <view
</u-collapse> class="flex_ac"
v-show="payList[PAY_AUTH[PAY_TYPE.JING_DONG_H5]]"
>
<view class="flex_ac_i">
<img src="@/static/images/jdBank.jpg" alt="" />
<view>京东收银台</view>
</view>
<u-radio-group v-model="whatPay">
<u-radio
activeColor="#005BAC"
size="18"
label=""
:name="PAY_TYPE.JING_DONG_H5"
>
</u-radio>
</u-radio-group>
</view>
<view
class="flex_ac1"
v-show="payList[PAY_AUTH[PAY_TYPE.TONG_LIAN_BANK_CARD]]"
>
<view class="flex_ac_i">
<img src="@/static/images/jdBank.jpg" alt="" />
<view>{{ '通联银行卡' }}</view>
</view>
<view class="pad">
<view
v-for="(item, index) in tlList"
:key="index"
class="pay_flax flex_bet"
@click.prevent="selPayRadio('tl' + index)"
>
<view class="flax_i">
{{ item.bankName }} ({{ item.bankNo }})
</view>
<u-radio-group v-model="whatPay">
<u-radio
activeColor="#005BAC"
size="18"
label=""
:name="PAY_TYPE.TONG_LIAN_BANK_CARD + index"
>
</u-radio>
</u-radio-group>
</view>
<view class="pay_flax flax_i" @click="bindBank('tl')">
<img class="img1" src="@/static/images/addto.png" alt="" />
<view>{{ '绑定银行卡' }}</view>
</view>
</view>
</view>
</view>
</view> </view>
</view> </view>
<!-- 底部 --> <!-- 底部 -->
@ -225,7 +308,10 @@
<div ref="qrCodeUrlWx" class="qrcode"></div> <div ref="qrCodeUrlWx" class="qrcode"></div>
</view> </view>
</u-popup> </u-popup>
<hiSuccess @successClose="successClose" ref="hiSuccess"></hiSuccess> <successDialog
@successClose="successClose"
ref="successDialog"
></successDialog>
</view> </view>
</template> </template>
@ -234,15 +320,24 @@ import * as api from '@/config/pay.js'
import QRCode from 'qrcodejs2' import QRCode from 'qrcodejs2'
import { removeToken } from '@/config/auth.js' import { removeToken } from '@/config/auth.js'
import hiSuccess from '@/components/hiSuccess.vue' import successDialog from '@/components/successDialog.vue'
import * as act from '@/config/activity.js' import * as act from '@/config/activity.js'
import {
PAY_REDIRECT_URL,
PAY_TYPE,
PAY_CHANEL,
PAY_AUTH,
} from '@/util/constant.js'
var payStatus var payStatus
let getRegisterInfoTimeoutFlag = null
export default { export default {
components: { components: {
hiSuccess, successDialog,
}, },
data() { data() {
return { return {
PAY_TYPE,
PAY_AUTH,
payList: {}, payList: {},
isLoading: false, isLoading: false,
clockTime: '', clockTime: '',
@ -257,12 +352,12 @@ export default {
}, },
paramsPost: '', paramsPost: '',
isShare: false, // isShare: false, //
userInfo: '', userInfo: uni.getStorageSync('User'),
activeNames: 1, activeNames: 1,
whatPay: '', whatPay: '',
hfList: [], hfList: [],
jdList: [], jdList: [],
businessType: '', businessType: 1,
isBank: '', isBank: '',
isPw: false, isPw: false,
codeValue: '', codeValue: '',
@ -271,9 +366,7 @@ export default {
sucPay: 0, sucPay: 0,
content: '支付成功', content: '支付成功',
wxPopup: false, wxPopup: false,
luckydrawData: {},
isRecharge: false, isRecharge: false,
czJe: '',
tlList: [], tlList: [],
} }
}, },
@ -286,74 +379,22 @@ export default {
) )
this.pkCountry = uni.getStorageSync('pkCountry') this.pkCountry = uni.getStorageSync('pkCountry')
// if (this.paramsPost.isRecharge) {
// this.isRecharge = this.paramsPost.isRecharge
// this.businessType = 3
// uni.setNavigationBarTitle({
// title: ''
// });
// } else {
// uni.setNavigationBarTitle({
// title: ''
// });
// this.isRecharge = false
// if (JSON.parse(options.paramsPost).orderType == 4) {
this.orderCode = this.paramsPost.orderCode this.orderCode = this.paramsPost.orderCode
// this.luckydrawData = this.paramsPost.luckydrawData
// //
// this.businessType = 4 //
// this.specialArea = this.paramsPost.specialArea
// this.getLuckdrawDetail()
// } else {
// this.userInfo = uni.getStorageSync('User')
// if (
// this.userInfo.registerFans == 0
// ) {
// this.isShare = true
// }
// this.specialArea =
// this.paramsPost.specialArea || this.paramsPost.orderType
// this.orderCode = this.paramsPost.orderCode
// this.businessType = options.businessType
// // this.getInfo()
// //
// this.getOrderInfo()
// if (!this.isShare) {
// //
// this.getSpendInfo()
// }
// }
// }
// //
this.getPayConfig() this.getPayConfig()
this.downTime()
// clearInterval(this.clockTime)
}, },
onShow() { onShow() {
// //
// this.getBankList() // this.getBankList()
}, },
methods: { onUnload() {
// clearTimeout(getRegisterInfoTimeoutFlag)
getLuckdrawDetail() { clearInterval(payStatus)
//
act
.getLuckdrawDetail({
pkBaseId: this.luckydrawData.pkBaseId,
payNum: this.luckydrawData.payNum,
})
.then(res => {
if (res.code == 200) {
this.orderData.orderAmount = res.data.toBePaidMoney
this.payDetail = res.data
// this.downTime()
}
})
}, },
methods: {
closewxPopup() { closewxPopup() {
this.wxPopup = false this.wxPopup = false
this.$refs.qrCodeUrlWx.innerHTML = '' this.$refs.qrCodeUrlWx.innerHTML = ''
@ -384,10 +425,18 @@ export default {
}, },
fansOrder() { fansOrder() {
api.fansOrder(this.orderCode).then(res => { api.fansOrder(this.orderCode).then(res => {
if (res.data) {
this.isLoading = false this.isLoading = false
this.isPw = false this.isPw = false
uni.hideLoading()
removeToken() removeToken()
this.$refs.hiSuccess.showSuccess(res.data)
this.$refs.successDialog.showSuccess(res.data)
} else {
getRegisterInfoTimeoutFlag = setTimeout(() => {
this.fansOrder()
}, 3000)
}
}) })
}, },
payPw() { payPw() {
@ -411,7 +460,7 @@ export default {
url(obj).then(res => { url(obj).then(res => {
if (res.code == 200) { if (res.code == 200) {
// this.isPw = false // this.isPw = false
// this.$refs.hiSuccess.showSuccess(res.data) // this.$refs.successDialog.showSuccess(res.data)
uni.showToast({ uni.showToast({
title: res.msg, title: res.msg,
icon: 'none', icon: 'none',
@ -431,66 +480,50 @@ export default {
} }
}) })
}, },
quickPay(cz) { async quickPay() {
// if (
if (typeof this.whatPay == 'number') { ![
if (this.whatPay == 12) { PAY_TYPE.HUI_FU_BANK_CARD,
this.scanPayBfWx(5) PAY_TYPE.JING_DONG_BANK_CARD,
} else if (this.whatPay == 13) { PAY_TYPE.TONG_LIAN_BANK_CARD,
this.scanPayBfWx(6) ].includes(this.whatPay.slice(0, 2))
} else if (this.whatPay == 11) { ) {
this.scanPayBfWxJump(5) if ([PAY_TYPE.JING_DONG_H5].includes(this.whatPay)) {
} else if (this.whatPay == 32) { this.redirectPay(PAY_CHANEL[this.whatPay])
this.scanPayTlWxJump(3) } else if (
[PAY_TYPE.BAO_FU_WECHAT_SCAN, PAY_TYPE.HUI_FU_WECHAT].includes(
this.whatPay
)
) {
this.scanPayBfWx(PAY_CHANEL[this.whatPay])
} else if (this.whatPay == PAY_TYPE.WECHAT_PAY) {
this.scanPayWx(PAY_CHANEL[this.whatPay])
} else if (this.whatPay == PAY_TYPE.ALI_PAY) {
this.scanPayAl(PAY_CHANEL[this.whatPay])
} }
} else { } else {
if (this.whatPay.slice(0, 2) == 'hf') { const indexed = this.whatPay.slice(2, 4)
let indexed = this.whatPay.slice(2, 4) const payTypeEnum = this.whatPay.slice(0, 2)
let params = { const bankListMap = {
businessType: 1, // [PAY_TYPE.HUI_FU_BANK_CARD]: this.hfList[indexed].bindCode,
businessCode: this.orderCode, [PAY_TYPE.JING_DONG_BANK_CARD]: this.jdList[indexed].bindCode,
payChannel: 6, // [PAY_TYPE.TONG_LIAN_BANK_CARD]: this.tlList[indexed].bindCode,
}
this.bindCode = bankListMap[payTypeEnum]
const params = {
businessType: this.businessType, //
payChannel: PAY_CHANEL[payTypeEnum],
payType: 3, // payType: 3, //
bindCode: this.hfList[indexed].bindCode, bindCode: bankListMap[payTypeEnum],
} }
api.unifiedorder(params).then(response => { Object.assign(params, {
this.isBank = 'hf'
this.bindCode = this.hfList[indexed].bindCode
this.isPw = true
})
this.checkPayStatus(params)
} else if (this.whatPay.slice(0, 2) == 'jd') {
let indexed = this.whatPay.slice(2, 4)
let params = {
businessType: 1, //
businessCode: this.orderCode, businessCode: this.orderCode,
payChannel: 4, //
payType: 3, //
bindCode: this.jdList[indexed].bindCode,
}
api.unifiedorder(params).then(response => {
this.isBank = 'jd'
this.bindCode = this.jdList[indexed].bindCode
this.isPw = true
}) })
this.checkPayStatus(params)
} else if (this.whatPay.slice(0, 2) == 'tl') {
let indexed = this.whatPay.slice(2, 4)
let params = {
businessType: 1, //
businessCode: this.orderCode,
payChannel: 3, //
payType: 3, //
bindCode: this.tlList[indexed].bindCode,
}
api.unifiedorder(params).then(response => { api.unifiedorder(params).then(response => {
this.isBank = 'tl' this.isBank = this.whatPay.slice(0, 2)
this.bindCode = this.tlList[indexed].bindCode
this.isPw = true this.isPw = true
})
this.checkPayStatus(params) this.checkPayStatus(params)
} })
} }
}, },
// //
@ -527,6 +560,47 @@ export default {
}) })
this.checkPayStatus(params) this.checkPayStatus(params)
}, },
redirectPay(payChannel) {
this.getPayAuthToken(payChannel).then(url => {
if (navigator.userAgent.includes('MicroMessenger')) {
window.location.href = url
} else {
window.open(url)
}
})
},
getPayAuthToken(payChannel) {
return new Promise((resolve, reject) => {
const extParam = {
isRecharge: false,
orderCode: this.orderCode,
specialArea: 1,
isSharePay: true,
}
// extParamJSONbase64
const extParamBase64 = btoa(JSON.stringify(extParam))
const params = {
payChannel: payChannel,
payType: 2,
appletFlag: 0,
businessType: this.businessType,
businessCode: this.orderCode,
extParam: extParamBase64,
}
api.unifiedorder(params).then(res => {
if (res.code === 200) {
resolve(res.data)
this.checkPayStatus(params)
} else {
uni.showToast({
title: res.msg,
icon: 'none',
})
reject(res.msg)
}
})
})
},
scanPayBfWx(val) { scanPayBfWx(val) {
let params = { let params = {
businessType: 1, businessType: 1,
@ -567,9 +641,7 @@ export default {
getPayConfig() { getPayConfig() {
api.payConfig().then(res => { api.payConfig().then(res => {
this.payList = res.data this.payList = res.data
this.$nextTick(() => {
this.$refs.collapse.init()
})
this.$forceUpdate() this.$forceUpdate()
}) })
}, },
@ -588,18 +660,7 @@ export default {
}) })
this.$forceUpdate() this.$forceUpdate()
}, },
getOrderInfo() {
api
.orderInfo({
specialArea: this.specialArea,
orderCode: this.orderCode,
pkSettleCountry: this.pkCountry,
})
.then(res => {
this.orderData = res.data
this.downTime()
})
},
downTime() { downTime() {
let that = this let that = this
this.clockTime = setInterval(() => { this.clockTime = setInterval(() => {
@ -639,7 +700,12 @@ export default {
clearInterval(payStatus) clearInterval(payStatus)
this.wxPopup = false this.wxPopup = false
// this.showSucce = true // this.showSucce = true
uni.showLoading({
title: '正在获取注册信息,请不要关闭当前页面',
})
setTimeout(() => {
this.fansOrder() this.fansOrder()
}, 2000)
} else { } else {
api.payStatus(data).then(res => { api.payStatus(data).then(res => {
that.sucPay = res.data that.sucPay = res.data
@ -753,10 +819,9 @@ export default {
.flex_ac { .flex_ac {
display: flex; display: flex;
align-items: center; align-items: center;
width: 100%;
justify-content: space-between; justify-content: space-between;
border-bottom: 1px solid rgba(0, 0, 0, 0.1); border-bottom: 1px solid rgba(0, 0, 0, 0.1);
padding: 18rpx 0; padding: 18rpx 20rpx;
} }
.flex_ac1 { .flex_ac1 {
@ -766,7 +831,7 @@ export default {
width: 100%; width: 100%;
justify-content: space-between; justify-content: space-between;
border-bottom: 1px solid rgba(0, 0, 0, 0.1); border-bottom: 1px solid rgba(0, 0, 0, 0.1);
padding: 18rpx 0; // padding: 18rpx 0;
} }
.flex_ac_i { .flex_ac_i {
@ -786,10 +851,6 @@ export default {
} }
} }
::v-deep .u-collapse-item__content__text {
padding: 0px 15px;
}
.pad { .pad {
width: 100%; width: 100%;
display: flex; display: flex;

View File

@ -1,36 +1,50 @@
<template> <template>
<view class="contain"> <view class="contain">
<view class="zhan"></view> <!-- 头部营销区域 -->
<view class="goodList"> <view class="header-section">
<view v-for="item in goodList" <view class="hero-content">
:key="item.waresCode" <view class="hero-title">
class="goodList_i" <text class="hero-main">新人专享特惠</text>
<text class="hero-sub">精选好物·品质优选</text>
</view>
<!-- <view class="promotion-banner">
<text class="promo-text">限时优惠·新人福利</text>
</view> -->
</view>
</view>
<view class="goods-container">
<scroll-view
class="goodList"
scroll-y="true"
enhanced
:show-scrollbar="false"
> >
<img :src="item.cover1" <view v-for="item in goodList" :key="item.waresCode" class="goodList_i">
class="cover" <img :src="item.cover1" class="cover" alt="" />
alt="">
<view class="goodList_ir"> <view class="goodList_ir">
<view class="tit1"> <view class="tit1">
{{ item.waresName }} {{ item.waresName }}
</view> </view>
<view class="sales">
销量:{{ item.sales |seles}}
</view>
<view class="goodList_ib"> <view class="goodList_ib">
<view> <view class="price-container">
{{ item.waresPrice | numberToCurrency}} <!-- <text class="currency"></text> -->
<text class="price">{{
item.waresPrice | numberToCurrency
}}</text>
</view> </view>
<!-- <img @click.stop="addCar(item)" <!-- <img @click.stop="addCar(item)"
src="@/static/images/cart.png" src="@/static/images/cart.png"
alt=""> --> alt=""> -->
</view> </view>
<view class="toBuy" @click.stop="goBuy(item)">立即购买</view> <view class="toBuy" @click.stop="goBuy(item)">立即购买</view>
</view> </view>
</view> </view>
<view class="zhan2"></view> <view class="list-bottom">
<text class="bottom-text"> 已显示全部商品 </text>
</view>
</scroll-view>
</view> </view>
</view> </view>
</template> </template>
@ -40,138 +54,468 @@ import * as api from '@/config/login.js'
import { setToken } from '@/config/auth.js' import { setToken } from '@/config/auth.js'
export default { export default {
data(){ data() {
return{ return {
pkParent:'', pkParent: '',
goodList:[], goodList: [],
placeParent:'' placeParent: '',
} }
}, },
filters:{ filters: {
seles(value){ seles(value) {
if (value > 999) {
if(value>999){
return 999 + '+' return 999 + '+'
}else{ } else {
return value return value
} }
},
}
}, },
onLoad(options) { onLoad(options) {
this.pkParent = options.pkParent this.pkParent = options.pkParent
this.getToken() this.getToken()
}, },
methods:{ methods: {
getToken(){ getToken() {
api.autoLogin({ api
pkParent:this.pkParent .autoLogin({
}).then(res=>{ pkParent: this.pkParent,
})
.then(res => {
setToken(res.data.access_token, res.data.expires_in) setToken(res.data.access_token, res.data.expires_in)
this.getList() this.getList()
this.getCode() this.getCode()
}) })
}, },
getCode(){ getCode() {
api.fansConvertCode( api.fansConvertCode(this.pkParent).then(res => {
this.pkParent this.placeParent = res.data
).then(res=>{
this.placeParent = res.msg
uni.setStorageSync('placeParent', this.placeParent) uni.setStorageSync('placeParent', this.placeParent)
}) })
}, },
getList(){ getList() {
api.queryWares({ api
shareMemberCode:this.pkParent .queryWares({
}).then(res=>{ shareMemberCode: this.pkParent,
})
.then(res => {
this.goodList = res.data this.goodList = res.data
}) })
}, },
goBuy(item){ goBuy(item) {
uni.navigateTo({ url: '/pages/shareArea/hiOrder?allData=' + JSON.stringify(item)}) const params = {
} ...item,
pkParent: this.pkParent,
} }
uni.navigateTo({
url: '/pages/shareArea/hiOrder?allData=' + JSON.stringify(item),
})
},
},
} }
</script> </script>
<style lang="scss" scoped> <style lang="scss" scoped>
.contain{ .contain {
background: #fff; background: linear-gradient(
height: 100vh; 135deg,
background: url('~@/static/images/hf1.jpg') no-repeat; #005bac 0%,
background-size: cover; #0066cc 50%,
padding: 0 20px; #f5f7fa 50%,
#e8f4f8 100%
);
min-height: 100vh;
display: flex;
flex-direction: column;
} }
.zhan{
height: 36%; //
.header-section {
background: linear-gradient(135deg, #005bac 0%, #0066cc 100%);
padding: 50rpx 32rpx 60rpx;
animation: slideDown 0.6s ease-out;
.hero-content {
text-align: center;
.hero-title {
margin-bottom: 24rpx;
.hero-main {
display: block;
color: #fff;
font-size: 40rpx;
font-weight: 700;
margin-bottom: 8rpx;
animation: fadeInUp 0.8s ease-out 0.2s both;
}
.hero-sub {
display: block;
color: rgba(255, 255, 255, 0.9);
font-size: 26rpx;
font-weight: 400;
animation: fadeInUp 0.8s ease-out 0.4s both;
}
}
.promotion-banner {
background: linear-gradient(
135deg,
#ff6b35 0%,
#f7931e 50%,
#ffd700 100%
);
border-radius: 30rpx;
padding: 18rpx 36rpx;
box-shadow: 0 8rpx 24rpx rgba(255, 107, 53, 0.4);
animation:
fadeInUp 0.8s ease-out 0.6s both,
promoBreathe 3s ease-in-out infinite 1s;
position: relative;
overflow: hidden;
border: 2rpx solid rgba(255, 255, 255, 0.3);
&::after {
content: '';
position: absolute;
top: 0;
left: -100%;
width: 100%;
height: 100%;
background: linear-gradient(
90deg,
transparent,
rgba(255, 255, 255, 0.4),
transparent
);
animation: shimmer 2.5s ease-in-out infinite;
}
.promo-text {
color: #fff;
font-size: 28rpx;
font-weight: 700;
text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.3);
position: relative;
z-index: 2;
}
}
}
} }
//
.goods-container {
flex: 1;
background: #f8fafc;
border-radius: 40rpx 40rpx 0 0;
margin-top: -40rpx;
position: relative;
z-index: 3;
padding: 32rpx 24rpx 0;
animation: fadeIn 0.8s ease-out 0.3s both;
.section-title {
text-align: center;
margin-bottom: 24rpx;
padding: 20rpx 0;
.title-text {
display: block;
color: #1e293b;
font-size: 32rpx;
font-weight: 600;
margin-bottom: 8rpx;
}
.title-desc {
display: block;
color: #64748b;
font-size: 24rpx;
}
}
}
//
.goodList { .goodList {
padding: 40rpx; height: calc(100vh - 400rpx);
height: 55vh; padding: 0 8rpx;
overflow-y: auto;
background: url('~@/static/images/hf2.png') no-repeat;
background-size: cover;
.goodList_i { .goodList_i {
display: flex; display: flex;
border-bottom: 1px solid #eee; background: #ffffff;
padding: 60rpx 60rpx 30rpx 60rpx;
// background: url('~@/static/images/hf3.png') no-repeat;
// background-size: cover;
border-radius: 20rpx; border-radius: 20rpx;
background-image: linear-gradient(to bottom, #fefbf8, #fadf97); margin-bottom: 24rpx;
margin-bottom: 20rpx; padding: 24rpx;
.goodList_ir { box-shadow: 0 4rpx 16rpx rgba(0, 91, 172, 0.06);
margin-left: 40rpx; border: 1rpx solid rgba(0, 91, 172, 0.1);
transition: all 0.3s ease;
animation: slideInUp 0.6s ease-out both;
opacity: 0;
&:hover {
transform: translateY(-4rpx);
box-shadow: 0 12rpx 32rpx rgba(0, 91, 172, 0.15);
}
.cover {
width: 240rpx;
height: 240rpx;
background: #f8fafc;
border: 1rpx solid #e2e8f0;
border-radius: 16rpx;
flex-shrink: 0;
overflow: hidden;
}
.goodList_ir {
margin-left: 24rpx;
flex: 1; flex: 1;
display: flex; display: flex;
flex-direction: column; flex-direction: column;
justify-content: space-between; justify-content: space-between;
font-size: 24rpx;
font-family: Microsoft YaHei; .tit1 {
font-weight: 400; color: #1e293b;
color: #333333; font-size: 32rpx;
.goodList_ib {
display: flex;
align-items: center;
justify-content: space-between;
font-size: 24px;
font-family: Source Han Sans CN;
font-weight: 600; font-weight: 600;
color: #a36b28; line-height: 1.4;
margin-bottom: 16rpx;
display: -webkit-box;
-webkit-line-clamp: 2;
-webkit-box-orient: vertical;
overflow: hidden;
}
.sales {
color: #64748b;
font-size: 24rpx;
font-weight: 400;
margin-bottom: 16rpx;
}
.goodList_ib {
margin-bottom: 24rpx;
.price-container {
display: flex;
align-items: baseline;
.currency {
color: #ff6b35;
font-size: 24rpx;
font-weight: 600;
margin-right: 4rpx;
}
.price {
color: #ff6b35;
font-size: 36rpx;
font-weight: 700;
}
}
img { img {
width: 56rpx; width: 56rpx;
height: 56rpx; height: 56rpx;
} }
} }
.toBuy {
background: #005bac;
color: #ffffff;
padding: 20rpx 0;
text-align: center;
border-radius: 12rpx;
font-size: 28rpx;
font-weight: 600;
border: none;
transition: all 0.3s ease;
position: relative;
overflow: hidden;
&::before {
content: '';
position: absolute;
top: 0;
left: -100%;
width: 100%;
height: 100%;
background: linear-gradient(
90deg,
transparent,
rgba(255, 255, 255, 0.2),
transparent
);
transition: left 0.5s;
}
&:hover {
background: #0066cc;
transform: translateY(-2rpx);
box-shadow: 0 6rpx 16rpx rgba(0, 91, 172, 0.3);
&::before {
left: 100%;
} }
} }
&:active {
transform: scale(0.98);
}
}
}
}
.list-bottom {
text-align: center;
padding: 40rpx 0 60rpx;
.bottom-text {
color: #64748b;
font-size: 24rpx;
}
}
}
//
@keyframes slideDown {
from {
opacity: 0;
transform: translateY(-50rpx);
}
to {
opacity: 1;
transform: translateY(0);
}
}
@keyframes fadeIn {
from {
opacity: 0;
}
to {
opacity: 1;
}
}
@keyframes fadeInUp {
from {
opacity: 0;
transform: translateY(30rpx);
}
to {
opacity: 1;
transform: translateY(0);
}
}
@keyframes slideInUp {
from {
opacity: 0;
transform: translateY(40rpx);
}
to {
opacity: 1;
transform: translateY(0);
}
}
@keyframes pulse {
0%,
100% {
transform: scale(1);
}
50% {
transform: scale(1.02);
}
}
@keyframes promoBreathe {
0%,
100% {
transform: scale(1);
box-shadow: 0 8rpx 24rpx rgba(255, 107, 53, 0.4);
}
50% {
transform: scale(1.05);
box-shadow: 0 12rpx 32rpx rgba(255, 107, 53, 0.6);
}
}
@keyframes shimmer {
0% {
left: -100%;
}
50% {
left: -100%;
}
100% {
left: 100%;
}
}
//
.goodList_i:nth-child(1) {
animation-delay: 0.1s;
}
.goodList_i:nth-child(2) {
animation-delay: 0.2s;
}
.goodList_i:nth-child(3) {
animation-delay: 0.3s;
}
.goodList_i:nth-child(4) {
animation-delay: 0.4s;
}
.goodList_i:nth-child(5) {
animation-delay: 0.5s;
}
.goodList_i:nth-child(n + 6) {
animation-delay: 0.6s;
}
//
@media (max-width: 750rpx) {
.header-section {
padding: 40rpx 24rpx 50rpx;
.hero-content {
.hero-title .hero-main {
font-size: 36rpx;
}
}
}
.goodList {
.goodList_i {
padding: 20rpx;
.cover { .cover {
width: 200rpx; width: 200rpx;
height: 200rpx; height: 200rpx;
background: #ffffff;
border: 1px solid #eeeeee;
border-radius: 10rpx;
margin-bottom: 40px;
} }
.toBuy{
color: #fff; .goodList_ir {
background: #005BAC; margin-left: 20rpx;
padding: 10rpx 0;
text-align: center; .tit1 {
border-radius: 10rpx; font-size: 28rpx;
font-size: 20px; }
.goodList_ib {
.price-container {
.price {
font-size: 32rpx;
}
}
}
.toBuy {
padding: 18rpx 0;
font-size: 26rpx;
}
}
}
} }
}
.tit1{
color: #93561f;
font-size: 16px;
font-weight: 700;
}
.sales{
color: #923f32;
font-size: 10px;
font-weight: 700;
} }
</style> </style>

View File

@ -1,9 +1,3 @@
<!--
* @Descripttion:
* @version:
* @Author: kBank
* @Date: 2022-11-21 15:11:22
-->
<template> <template>
<view class="content"> <view class="content">
<!-- <view class="index_header"> <!-- <view class="index_header">
@ -14,67 +8,50 @@
<view class="subTxt"> <view class="subTxt">
<view class="subTxt1">{{ '会员信息' }}</view> <view class="subTxt1">{{ '会员信息' }}</view>
</view> </view>
<u-form <u-form :model="form" labelWidth="75" :rules="rules" ref="uForm">
:model="form"
labelAlign="right"
labelWidth="75"
:rules="rules"
ref="uForm"
>
<view class="kuang"> <view class="kuang">
<u-form-item :label="'会员姓名'" prop="memberName"> <u-form-item
:label="'会员姓名'"
prop="memberName"
borderBottom
required
>
<u-input <u-input
:placeholder="'请输入会员姓名'" :placeholder="'请输入会员姓名'"
v-model.trim="form.memberName" v-model.trim="form.memberName"
border="none"
/> />
</u-form-item> </u-form-item>
<u-form-item :label="'联系方式'" prop="phone"> <u-form-item :label="'联系方式'" prop="phone" borderBottom required>
<u-input <u-input
:placeholder="'请输入联系方式'" :placeholder="'请输入联系方式'"
type="number" type="number"
v-model.trim="form.phone" v-model.trim="form.phone"
:maxlength="user.pkSettleCountry == 1 ? 11 : 20" :maxlength="user.pkSettleCountry == 1 ? 11 : 20"
border="none"
/> />
</u-form-item> </u-form-item>
<u-form-item :label="'自然国家'" @tap="changeCountry(0)"> <!-- <u-form-item
<view class="disFlex justBwn ge"> v-if="[80, 90].includes(gradeValue) && provinceList.length"
<view class="disFlex"> @click="regionSelectHandle"
<img class="countImg" :src="form.pkCountryImg" alt="" /> required
<view>{{ form.pkCountryLabel }}</view> label="会员区域"
borderBottom
prop="regionProvince"
>
<view class="disFlex justBwn">
<view v-if="regionAddress.length">
{{ regionAddress.map(item => item.name).join('-') }}
</view> </view>
<u-icon name="arrow-down"></u-icon> <view
v-else
class="uni-input-placeholder input-placeholder"
style="position: relative !important"
>请选择区域</view
>
<u-icon name="arrow-right"></u-icon>
</view> </view>
</u-form-item> </u-form-item> -->
<u-form-item :label="'结算国家'">
<view class="disFlex justBwn ge hui">
<view class="disFlex">
<img class="countImg" :src="form.pkSettleCountryImg" alt="" />
<view>{{ form.pkSettleCountryLabel }}</view>
</view>
<u-icon name="arrow-down"></u-icon>
</view>
</u-form-item>
<u-form-item :label="'运输方式'">
<view class="pickerHui">
<u-input
v-model="form.transTypeVal"
disabled
border="none"
></u-input>
<u-icon name="arrow-down"></u-icon>
</view>
</u-form-item>
<u-form-item :label="'发货方式'">
<view class="pickerHui">
<u-input
v-model="form.deliveryName"
disabled
:placeholder="'请选择发货方式'"
border="none"
></u-input>
<u-icon name="arrow-down"></u-icon>
</view>
</u-form-item>
</view> </view>
<view class="subTxt"> <view class="subTxt">
<view class="subTxt1">收货人信息</view> <view class="subTxt1">收货人信息</view>
@ -82,23 +59,35 @@
<view class="kuang"> <view class="kuang">
<view class="disFlex tit_t"> <view class="disFlex tit_t">
<view></view> <view></view>
<!-- <view class="lan" @click="addAdress">新增收货人地址</view> -->
</view> </view>
<u-form-item :label="'收货人'" prop="recName"> <u-form-item :label="'收货人'" prop="recName" borderBottom required>
<u-input <u-input
v-model.trim="form.recName" v-model.trim="form.recName"
:placeholder="'请输入收货人'" :placeholder="'请输入收货人'"
border="none"
/> />
</u-form-item> </u-form-item>
<u-form-item :label="'收货电话'" prop="recPhone"> <u-form-item
:label="'收货电话'"
prop="recPhone"
borderBottom
required
>
<u-input <u-input
v-model.trim="form.recPhone" v-model.trim="form.recPhone"
type="number" type="number"
maxlength="20" maxlength="20"
:placeholder="'请输入收货电话'" :placeholder="'请输入收货电话'"
border="none"
/> />
</u-form-item> </u-form-item>
<u-form-item :label="'收货地址'" prop="diqu" @click="getDiqu"> <u-form-item
:label="'收货地址'"
prop="diqu"
@click="getDiqu"
required
borderBottom
>
<view class="picker"> <view class="picker">
<u-input <u-input
v-model.trim="form.diqu" v-model.trim="form.diqu"
@ -108,17 +97,22 @@
<u-icon name="arrow-down"></u-icon> <u-icon name="arrow-down"></u-icon>
</view> </view>
</u-form-item> </u-form-item>
<u-form-item :label="'详细地址'" prop="recAddress"> <u-form-item
required
:label="'详细地址'"
prop="recAddress"
borderBottom
>
<u--textarea <u--textarea
v-model.trim="form.recAddress" v-model.trim="form.recAddress"
maxlength="200" maxlength="200"
:placeholder="'请输入详细地址'" :placeholder="'请输入详细地址'"
></u--textarea> ></u--textarea>
</u-form-item> </u-form-item>
<u-form-item :label="'邮费'"> <u-form-item :label="'邮费'" borderBottom>
<u-input disabled v-model="form.postage" /> <u-input disabled v-model="form.postage" />
</u-form-item> </u-form-item>
<u-form-item :label="'备注'"> <u-form-item :label="'备注'" borderBottom>
<u--textarea <u--textarea
v-model="form.remark" v-model="form.remark"
:placeholder="'请输入备注'" :placeholder="'请输入备注'"
@ -126,36 +120,6 @@
</u-form-item> </u-form-item>
</view> </view>
</u-form> </u-form>
<!-- <view class="kuang">
<view class="kuang_t">
<view class="kuang_tl">
<view class="sTit">{{'商品主图'}}</view>
<img :src="allData.cover1"
alt="">
<view class="sTit">{{'商品名称'}}</view>
<view class="cTit">{{ allData.waresName }}</view>
</view>
<view class="kuang_tr">
<view class="sTit">{{'产品'}}</view>
<view v-for="item,index in allData.specsSkuParamsList"
:key="index">
<view class="cTit">
{{ item.productName }}{{ item.specsName }}*{{ item.quantity }}
</view>
</view>
</view>
</view>
<view class="kuang_t">
<view class="kuang_tl">
<view class="sTit">{{'商品价格'}}()</view>
<view class="cTit">{{ allData.waresPrice | numberToCurrency }}</view>
</view>
<view class="kuang_tr">
<view class="sTit">{{'商品数量'}}</view>
<view class="cTit">{{ allData.quantity }}</view>
</view>
</view>
</view> -->
<view class="subTxt"> <view class="subTxt">
<view class="subTxt1">商品信息</view> <view class="subTxt1">商品信息</view>
</view> </view>
@ -172,7 +136,7 @@
</view> </view>
<view class="goodList_ib"> <view class="goodList_ib">
<view class="tit2"> <view class="tit2">
{{ allData.waresPrice | numberToCurrency }} {{ allData.waresPrice | numberToCurrency }}
</view> </view>
<!-- <view class="tit3">业绩: {{ item.achieve | numberToCurrency | isLocal}}</view> --> <!-- <view class="tit3">业绩: {{ item.achieve | numberToCurrency | isLocal}}</view> -->
</view> </view>
@ -205,19 +169,6 @@
</view> </view>
</view> </view>
</view> </view>
<view class="kuang disFlex">
<u-checkbox-group
v-model="agreementShow"
shape="circle"
activeColor="#005BAC"
@change="checkboxChange"
>
<u-checkbox :name="1"> </u-checkbox>
</u-checkbox-group>
<view class="tit3">{{ '请阅读并同意' }}</view>
<view class="tit2" @click="toAgree"> {{ '购买协议' }}</view>
</view>
</view> </view>
<!-- 占空 --> <!-- 占空 -->
<view style="height: 150rpx"></view> <view style="height: 150rpx"></view>
@ -226,8 +177,8 @@
<view class="footer"> <view class="footer">
<view class="footer_l"> <view class="footer_l">
<view class="disFlex"> <view class="disFlex">
<view class="h1">{{ '总价' }}</view> <view class="h1">总价</view>
<view class="r1">¥{{ allData.waresPrice | numberToCurrency }}</view> <view class="r1">{{ allData.waresPrice | numberToCurrency }}</view>
</view> </view>
<!-- <view class="disFlex"> <!-- <view class="disFlex">
<view class="h1">{{'业绩'}}</view> <view class="h1">{{'业绩'}}</view>
@ -256,12 +207,18 @@
:columns="countryList" :columns="countryList"
keyName="label" keyName="label"
></u-picker> ></u-picker>
<agreement ref="agreement"></agreement>
<v-address <v-address
ref="address" ref="address"
:defaultCode="defaultCode" :defaultCode="defaultCode"
@addressData="addressData" @addressData="addressData"
></v-address> ></v-address>
<RegionAddress
ref="regionAddress"
:provinceList="provinceList"
:cityList="cityList"
:countyList="countyList"
@setAddress="setRegionAddress"
></RegionAddress>
</view> </view>
</template> </template>
@ -269,15 +226,18 @@
import address from '@/components/address.vue' import address from '@/components/address.vue'
import * as api from '@/config/goods' import * as api from '@/config/goods'
import * as regiest from '@/config/regiest' import * as regiest from '@/config/regiest'
import regionSelect from '@/pages/commonMixins/regionSelect'
import RegionAddress from '@/components/region-address.vue'
import agreement from '@/components/agreement.vue'
export default { export default {
mixins: [regionSelect],
components: { components: {
'v-address': address, 'v-address': address,
agreement, RegionAddress,
}, },
data() { data() {
return { return {
regionAddress: [],
specialArea: 7, specialArea: 7,
isCountry: false, isCountry: false,
defaultCode: [], defaultCode: [],
@ -293,6 +253,12 @@ export default {
pkCountry: '', pkCountry: '',
pkCountryLabel: '', pkCountryLabel: '',
pkCountryImg: '', pkCountryImg: '',
pkGradeVal: '',
memberName: 'windsword',
phone: 13333332211,
recName: '啊啊啊',
recPhone: '123333321221',
recAddress: '3123',
}, },
deliList: [], deliList: [],
diqu: '', diqu: '',
@ -356,6 +322,7 @@ export default {
countryList: [], countryList: [],
placeParent: '', placeParent: '',
user: '', user: '',
gradeValue: '',
} }
}, },
onLoad(options) { onLoad(options) {
@ -378,6 +345,23 @@ export default {
}, },
onShow() {}, onShow() {},
methods: { methods: {
getRegiestLevel() {
const params = {
firstCheck: 0,
specialArea: this.specialArea,
shopList: this.shoppingArr.map(id => {
return {
shoppingId: id,
}
}),
}
},
regionSelectHandle() {
this.$refs.regionAddress.setShow(this.provinceList[0].pkId)
},
setRegionAddress(area) {
this.regionAddress = area
},
phonePass(rule, value, callback) { phonePass(rule, value, callback) {
if (!value) { if (!value) {
callback(new Error('请输入联系电话')) callback(new Error('请输入联系电话'))
@ -386,21 +370,8 @@ export default {
if (value.length < 6 || value.length > 20) { if (value.length < 6 || value.length > 20) {
callback(new Error('请输入正确联系方式')) callback(new Error('请输入正确联系方式'))
return false return false
} else { }
regiest
.validPhone({
memberName: this.form.memberName,
phone: this.form.phone,
placeParent: this.placeParent,
})
.then(res => {
if (res.code == 200) {
callback() callback()
} else {
callback(new Error(res.msg))
}
})
}
}, },
getCountry() { getCountry() {
regiest.countryList().then(res => { regiest.countryList().then(res => {
@ -450,29 +421,31 @@ export default {
// url: '/pages/address/index', // url: '/pages/address/index',
// }) // })
// }, // },
toAgree() {
// agreeMent
this.$refs.agreement.openDig()
},
getGenerate() { getGenerate() {
api.generate().then(res => { api.generate().then(res => {
uni.setStorageSync('mToken', res.msg) uni.setStorageSync('mToken', res.msg)
}) })
}, },
goBuy() { goBuy() {
this.$refs.uForm.validate().then(res => { const extParams = {}
if (this.agreementShow.length == 0) { if ([80, 90].includes(this.gradeValue) && this.provinceList.length) {
if (!this.regionAddress.length) {
uni.showToast({ uni.showToast({
title: '请阅读并同意购买协议', title: '请选择会员区域',
icon: 'none', icon: 'none',
duration: 1500,
}) })
return return
} }
extParams.regionProvince = this.regionAddress[0]?.pkId || -1
extParams.regionCity = this.regionAddress[1]?.pkId || -1
extParams.regionCounty = this.regionAddress[2]?.pkId || -1
}
this.$refs.uForm.validate().then(res => {
this.isLoading = true this.isLoading = true
api api
.fansConfirm( .fansConfirm(
Object.assign({}, this.form, { Object.assign({}, this.form, extParams, {
waresList: this.waresList, waresList: this.waresList,
}) })
) )
@ -492,9 +465,14 @@ export default {
pkWares: this.allData.pkId, pkWares: this.allData.pkId,
skuList: [], skuList: [],
} }
this.allData.specsSkuParamsList.forEach(item => { console.log(
'%c [ carList ]-419',
'font-size:13px; background:#b131b9; color:#f575fd;',
this.allData
)
this.allData.productGroup.forEach(item => {
carList.skuList.push({ carList.skuList.push({
pkWaresSku: item.pkWaresSpecsSku, pkWaresSku: item.pkSkuId,
quantity: item.quantity, quantity: item.quantity,
}) })
}) })
@ -547,7 +525,7 @@ export default {
} }
.kuang { .kuang {
// margin-top: 20rpx; // margin-top: 20rpx;
padding: 20rpx 40rpx; // padding: 20rpx 40rpx;
background: #fff; background: #fff;
// box-shadow: 0px 2px 10px 0px rgba(204, 204, 204, 0.5); // box-shadow: 0px 2px 10px 0px rgba(204, 204, 204, 0.5);
// border-radius: 10px 10px 10px 10px; // border-radius: 10px 10px 10px 10px;
@ -573,22 +551,16 @@ export default {
display: flex; display: flex;
justify-content: space-between; justify-content: space-between;
width: 100%; width: 100%;
border-width: 0.5px !important;
border-color: #dadbde !important;
border-style: solid;
border-radius: 4px;
padding: 6px 9px; padding: 6px 9px;
} }
.pickerHui { .pickerHui {
display: flex; display: flex;
justify-content: space-between; justify-content: space-between;
width: 100%; width: 100%;
border-width: 0.5px !important;
border-color: #dadbde !important;
border-style: solid;
border-radius: 4px; border-radius: 4px;
padding: 6px 9px; // padding: 6px 9px;
background: #f5f7fa; // background: #f5f7fa;
} }
.kuang_t { .kuang_t {
display: flex; display: flex;
@ -784,4 +756,9 @@ export default {
background: #f6f6f6; background: #f6f6f6;
padding: 0 28rpx 28rpx 28rpx; padding: 0 28rpx 28rpx 28rpx;
} }
.u-form-item {
::v-deep .u-form-item__body {
padding: 20rpx 30rpx !important;
}
}
</style> </style>

View File

@ -10,48 +10,55 @@
<!-- <view class="index_header"> <!-- <view class="index_header">
<view>注册</view> <view>注册</view>
</view> --> </view> -->
<view class="title">欢迎注册</view>
<!-- <view class="tit" v-if="!pkCountry">{{ '嗨粉扫天下' }}</view> --> <!-- <view class="tit" v-if="!pkCountry">{{ '嗨粉扫天下' }}</view> -->
<!-- 海粉 --> <!-- 海粉 -->
<view class="formed1"> <view class="formed1">
<u-form :model="form" labelWidth="90px" ref="uForm" :rules="rules"> <u-form :model="form" labelWidth="80px" ref="uForm" :rules="rules">
<u-form-item label="推荐编号" prop="parentCode"> <u-form-item label="" prop="memberCode">
<u-input v-model="form.parentCode" disabled> </u-input> <u-input v-model="form.memberCode" type="number" disabled>
<u--text
:text="howHeader"
slot="prefix"
margin="0 3px 0 0"
type="tips"
></u--text>
</u-input>
</u-form-item> </u-form-item>
<u-form-item label="会员姓名" prop="memberName"> <u-form-item label="" prop="memberName">
<u-input <u-input
v-model="form.memberName" v-model="form.memberName"
:placeholder="'请输入会员姓名'" :placeholder="'请输入会员姓名'"
/> />
</u-form-item> </u-form-item>
<u-form-item label="联系方式" prop="phone"> <u-form-item label="" prop="phone">
<u-input <u-input
v-model="form.phone" v-model="form.phone"
@blur="setMemberCode"
:placeholder="'请输入联系方式'" :placeholder="'请输入联系方式'"
type="number" type="number"
maxlength="20" maxlength="20"
/> />
</u-form-item> </u-form-item>
<u-form-item label="登录密码" prop="loginPwd"> <u-form-item label="" prop="loginPassword">
<u-input <u-input
:password="isPwd" :password="isPwd"
:placeholder="'请输入登录密码'" :placeholder="'请输入登录密码'"
v-model="form.loginPwd" v-model="form.loginPassword"
> >
<template #suffix> <template slot="suffix">
<u-icon name="eye" @tap="isPwd = !isPwd" v-if="!isPwd"></u-icon> <u-icon name="eye" @tap="isPwd = !isPwd" v-if="!isPwd"></u-icon>
<u-icon name="eye-off" @tap="isPwd = !isPwd" v-else></u-icon> <u-icon name="eye-off" @tap="isPwd = !isPwd" v-else></u-icon>
</template> </template>
</u-input> </u-input>
</u-form-item> </u-form-item>
<u-form-item label="支付密码" prop="payPwd"> <u-form-item label="" prop="payPassword">
<u-input <u-input
:password="isPwd2" :password="isPwd2"
:placeholder="'请输入支付密码'" :placeholder="'请输入支付密码'"
v-model="form.payPwd" v-model="form.payPassword"
> >
<template #suffix> <template slot="suffix">
<u-icon <u-icon
name="eye" name="eye"
@tap="isPwd2 = !isPwd2" @tap="isPwd2 = !isPwd2"
@ -61,9 +68,9 @@
</template> </template>
</u-input> </u-input>
</u-form-item> </u-form-item>
<u-form-item label="验证码" prop="smsCode"> <u-form-item label="" prop="code">
<u-input v-model="form.smsCode" :placeholder="'请输入验证码'"> <u-input v-model="form.code" :placeholder="'请输入验证码'">
<template #suffix> <template slot="suffix">
<view class="getCode" @tap="getVilCode">{{ getCode }}</view> <view class="getCode" @tap="getVilCode">{{ getCode }}</view>
</template> </template>
</u-input> </u-input>
@ -130,10 +137,10 @@
</view> </view>
</u-form-item> </u-form-item>
<u-form-item label="" <u-form-item label=""
prop="loginPwd"> prop="loginPassword">
<u-input :password="isPwd1" <u-input :password="isPwd1"
:placeholder="'请输入登录密码'" :placeholder="'请输入登录密码'"
v-model="form.loginPwd"> v-model="form.loginPassword">
<template slot="suffix"> <template slot="suffix">
<u-icon name="eye" <u-icon name="eye"
@tap="isPwd1=!isPwd1" @tap="isPwd1=!isPwd1"
@ -145,10 +152,10 @@
</u-input> </u-input>
</u-form-item> </u-form-item>
<u-form-item label="" <u-form-item label=""
prop="payPwd"> prop="payPassword">
<u-input :password="isPwd2" <u-input :password="isPwd2"
:placeholder="'请输入支付密码'" :placeholder="'请输入支付密码'"
v-model="form.payPwd"> v-model="form.payPassword">
<template slot="suffix"> <template slot="suffix">
<u-icon name="eye" <u-icon name="eye"
@tap="isPwd2=!isPwd2" @tap="isPwd2=!isPwd2"
@ -176,52 +183,12 @@
</view> --> </view> -->
</view> </view>
<u-modal <view class="mask" v-if="isTrue"> </view>
:show="showSuccessModal"
title="注册成功"
:show-cancel-button="true"
cancel-text="复制"
confirm-text="自动登录"
@confirm="onModalConfirm"
@cancel="onModalCancel"
@close="showSuccessModal = false"
>
<view class="slot-content" v-if="successData">
<view class="success-item">
<text class="item-label">会员编号:</text>
<text class="item-value">{{ successData.memberCode }}</text>
</view>
<view class="success-item">
<text class="item-label">会员姓名:</text>
<text class="item-value">{{ successData.memberName }}</text>
</view>
<view class="success-item">
<text class="item-label">联系方式:</text>
<text class="item-value">{{ successData.phone }}</text>
</view>
<view class="success-item">
<text class="item-label">登录密码:</text>
<text class="item-value">{{ successData.loginPassword }}</text>
</view>
<view class="success-item">
<text class="item-label">支付密码:</text>
<text class="item-value">{{ successData.payPassword }}</text>
</view>
</view>
</u-modal>
</view> </view>
</template> </template>
<script> <script>
import * as api from '@/config/goods' import * as api from '@/config/goods'
import {
getMemberCode,
getPhoneCode,
getRegister,
autoLogin,
} from '@/config/share'
import { setToken } from '@/config/auth.js'
import store from '@/store'
export default { export default {
components: {}, components: {},
data() { data() {
@ -231,11 +198,6 @@ export default {
pkParent: '', pkParent: '',
form: { form: {
memberName: '', memberName: '',
smsCode: '',
loginPwd: '',
payPwd: '',
parentCode: '',
phone: '',
}, },
isLoading: false, isLoading: false,
getCode: '获取验证码', getCode: '获取验证码',
@ -248,13 +210,11 @@ export default {
isPwd: true, isPwd: true,
isPwd1: true, isPwd1: true,
isPwd2: true, isPwd2: true,
showSuccessModal: false,
successData: null,
rules: { rules: {
parentCode: [ memberCode: [
{ {
required: true, required: true,
message: '请输入推荐编号', asyncValidator: this.memberCodeRule,
trigger: ['blur'], trigger: ['blur'],
}, },
], ],
@ -272,21 +232,21 @@ export default {
trigger: ['blur'], trigger: ['blur'],
}, },
], ],
smsCode: [ code: [
{ {
required: true, required: true,
message: '请输入验证码', message: '请输入验证码',
trigger: ['blur'], trigger: ['blur'],
}, },
], ],
loginPwd: [ loginPassword: [
{ {
required: true, required: true,
message: '请输入登录密码', message: '请输入登录密码',
trigger: ['blur'], trigger: ['blur'],
}, },
], ],
payPwd: [ payPassword: [
{ {
required: true, required: true,
message: '请输入支付密码', message: '请输入支付密码',
@ -316,14 +276,14 @@ export default {
trigger: ['change', 'blur'], trigger: ['change', 'blur'],
}, },
], ],
loginPwd: [ loginPassword: [
{ {
required: true, required: true,
message: '请输入登录密码', message: '请输入登录密码',
trigger: ['change', 'blur'], trigger: ['change', 'blur'],
}, },
], ],
payPwd: [ payPassword: [
{ {
required: true, required: true,
message: '请输入支付密码', message: '请输入支付密码',
@ -336,9 +296,10 @@ export default {
onReady() {}, onReady() {},
onLoad(options) { onLoad(options) {
this.pkParent = options.code this.pkParent = options.code
this.pkCountry = options.country || '' this.pkCountry = 1
this.getGenerate()
if (this.pkCountry) { if (this.pkCountry) {
// this.getCountry() this.getCountry()
this.form.pkCountry = this.pkCountry this.form.pkCountry = this.pkCountry
uni.setStorageSync('pkCountry', this.pkCountry) uni.setStorageSync('pkCountry', this.pkCountry)
uni.redirectTo({ uni.redirectTo({
@ -354,22 +315,11 @@ export default {
}, },
onShow() {}, onShow() {},
methods: { methods: {
getUseInfo() { setMemberCode() {
getUseInfo().then(res => { // this.form.memberCode = this.form.phone
this.userInfo = res.data this.$set(this.form, 'memberCode', this.form.phone)
})
},
selCountry() {
uni.showModal({
title: '提示',
content: '确认更换自然国',
success: res => {
if (res.confirm) {
this.isCountry = true
}
},
})
}, },
memberCodeRule(rule, value, callback) { memberCodeRule(rule, value, callback) {
if (!value) { if (!value) {
callback(new Error('请输入会员编号')) callback(new Error('请输入会员编号'))
@ -388,99 +338,42 @@ export default {
} }
}, },
getHeader() { getHeader() {
getMemberCode(this.pkParent).then(res => { api.checkShare().then(res => {
this.$set(this.form, 'parentCode', res.data) if (res.code != 200) {
console.log(this.form) this.isTrue = true
} else {
this.isTrue = false
}
}) })
// api.prefix(this.pkParent).then((res) => { // api.prefix(this.pkParent).then((res) => {
// this.howHeader = res.msg // this.howHeader = res.msg
// }) // })
}, },
getGenerate() { getGenerate() {
return new Promise((resolve, reject) => {
api.generate().then(res => { api.generate().then(res => {
resolve(res)
uni.setStorageSync('mToken', res.msg) uni.setStorageSync('mToken', res.msg)
}) })
})
}, },
toLogin() { toLogin() {
this.$refs.uForm.validate().then(() => { this.$refs.uForm.validate().then(res => {
this.isLoading = true this.isLoading = true
getRegister(Object.assign({}, this.form, { parentCode: this.pkParent })) api
.regShareMember(
Object.assign({}, this.form, { parent: this.pkParent })
)
.then(res => { .then(res => {
this.isLoading = false this.isLoading = false
if (res.code == 200) { if (res.code == 200) {
this.successData = res.data uni.redirectTo({
this.showSuccessModal = true url:
} else { '/pages/shareRegist/success?allData=' +
uni.showToast({ JSON.stringify(res.data),
title: res.msg || '注册失败',
icon: 'none',
}) })
} }
}) })
.catch(() => {
this.isLoading = false
uni.showToast({
title: '注册请求失败',
icon: 'none',
})
})
})
},
onModalConfirm() {
if (this.successData) {
this.handleAutoLogin(this.successData)
}
},
onModalCancel() {
if (this.successData) {
const modalContent = `会员编号: ${this.successData.memberCode}\n会员姓名: ${this.successData.memberName}\n联系方式: ${this.successData.phone}\n登录密码: ${this.successData.loginPassword}\n支付密码: ${this.successData.payPassword}`
uni.setClipboardData({
data: modalContent,
success: function () {
uni.showToast({
title: '复制成功',
icon: 'success',
})
},
})
}
},
handleAutoLogin(loginData) {
autoLogin({
username: loginData.memberCode,
password: loginData.loginPassword,
uuid: loginData.uuid,
})
.then(loginRes => {
if (loginRes.code === 200) {
uni.showToast({
title: '登录成功',
icon: 'success',
duration: 1500,
})
setToken(loginRes.data.access_token)
store.dispatch('GetInfo').then(res => {
uni.switchTab({ url: '/pages/index/index' })
})
// setTimeout(() => {
// uni.reLaunch({
// url: '/pages/index/index',
// })
// }, 1500)
} else {
uni.showToast({
title: loginRes.msg || '自动登录失败',
icon: 'none',
})
}
})
.catch(err => {
console.log(err)
uni.showToast({
title: '自动登录请求失败',
icon: 'none',
})
}) })
}, },
hiLogin() { hiLogin() {
@ -526,9 +419,9 @@ export default {
// //
getVilCode() { getVilCode() {
this.startTime() this.startTime()
getPhoneCode({ api
.verification({
phone: this.form.phone, phone: this.form.phone,
parentCode: this.pkParent,
}) })
.then(res => {}) .then(res => {})
.catch(err => { .catch(err => {
@ -558,11 +451,10 @@ export default {
<style lang="scss" scoped> <style lang="scss" scoped>
.content1 { .content1 {
background: linear-gradient(-45deg, #005bac, #0077c2, #0099e0, #00bfff); background-image: url('@/static/images/haiRgeiest1.jpg');
background-size: 400% 400%; background-size: 100%;
animation: gradient 15s ease infinite; background-repeat: no-repeat;
height: 100vh; height: 100vh;
overflow: auto;
} }
.content { .content {
background-image: url('@/static/images/huan.jpg'); background-image: url('@/static/images/huan.jpg');
@ -572,13 +464,14 @@ export default {
background-position: center; background-position: center;
height: 100vh; height: 100vh;
} }
.title { .tit {
font-size: 48rpx; font-size: 48px;
font-weight: bold; font-family: PangMenZhengDao-Regular, PangMenZhengDao;
color: #333; font-weight: 400;
color: #ffffff;
text-align: center; text-align: center;
padding-top: 120rpx; padding-top: 80px;
padding-bottom: 80rpx; margin-bottom: 20px;
} }
.index_header { .index_header {
background: #f9f9f9; background: #f9f9f9;
@ -597,10 +490,8 @@ export default {
padding: 0 120rpx; padding: 0 120rpx;
} }
.formed1 { .formed1 {
margin: 0 40rpx; padding: 0 120rpx;
padding: 40rpx 30rpx; padding-top: 550rpx;
background-color: rgba(255, 255, 255, 0.85);
border-radius: 16rpx;
} }
.getCode { .getCode {
font-size: 10px; font-size: 10px;
@ -634,37 +525,4 @@ export default {
height: 100vh; height: 100vh;
top: 0; top: 0;
} }
@keyframes gradient {
0% {
background-position: 0% 50%;
}
50% {
background-position: 100% 50%;
}
100% {
background-position: 0% 50%;
}
}
.slot-content {
padding: 30rpx 20rpx;
font-size: 28rpx;
}
.success-item {
display: flex;
justify-content: space-between;
align-items: center;
padding: 10rpx 0;
}
.item-label {
color: #606266;
margin-right: 20rpx;
flex-shrink: 0;
}
.item-value {
color: #303133;
word-break: break-all;
text-align: right;
}
</style> </style>