ck@123911.net 3 mēneši atpakaļ
vecāks
revīzija
234889c916

+ 43 - 10
App.vue

@@ -25,7 +25,8 @@
 			userId: 0,
 			socket: null,
 			postHeader: null,
-			systemInfo: null
+			systemInfo: null,
+			push_token: null
 		},
 		beforeDestroy() {},
 		onLaunch: function(options) {
@@ -89,15 +90,47 @@
 					this.globalData.headerSign = headerSignKKK;
 				}
 			}
-			// uni.getPushClientId({
-			// 	success: (res) => {
-			// 		console.log(res.cid);
-			// 		// this.push_token = res.cid;
-			// 	},
-			// 	fail(err) {
-			// 		console.log(err)
-			// 	}
-			// })
+
+			// #ifdef APP
+			// 注释掉所有推送相关代码
+			/*
+			// 初始化推送服务 
+			try {
+				// 先设置一个计时器,延迟获取推送客户端ID
+				setTimeout(() => {
+					uni.getPushClientId({
+						success: (res) => {
+							console.log("App getPushClientId success:", res.cid);
+							// 存储推送token以便后续使用
+							this.globalData.push_token = res.cid;
+						},
+						fail: (err) => {
+							console.error("App getPushClientId fail:", err);
+							// 尝试再次获取
+							setTimeout(() => {
+								uni.getPushClientId({
+									success: (res) => {
+										console.log(
+											"App getPushClientId retry success:",
+											res.cid);
+										this.globalData.push_token = res.cid;
+									},
+									fail: (retryErr) => {
+										console.error(
+											"App getPushClientId retry fail:",
+											retryErr);
+									}
+								});
+							}, 3000); // 再等待3秒重试
+						}
+					});
+				}, 1000); // 延迟1秒再获取
+			} catch (e) {
+				console.error("getPushClientId exception:", e);
+			}
+			*/
+			// #endif
+
 			// this.$nextTick(async () => {
 			// 	for (var i = 0; i < tabbars.length; i++) {
 			// 		await this.go(tabbars[i])

+ 0 - 1
article_comments.sql

@@ -1 +0,0 @@
- 

+ 5 - 8
manifest.json

@@ -2,8 +2,8 @@
     "name" : "萌创星球",
     "appid" : "__UNI__00BD11F",
     "description" : "",
-    "versionName" : "3.0.0",
-    "versionCode" : 300,
+    "versionName" : "1.0.0",
+    "versionCode" : 100,
     "transformPx" : false,
     /* 5+App特有相关 hfhz-mrro-iqmv-igdl storygarden2024@outlook.com*/
     "app-plus" : {
@@ -32,7 +32,8 @@
             "Payment" : {},
             "Share" : {},
             "VideoPlayer" : {},
-            "Geolocation" : {}
+            "Geolocation" : {},
+            "Push" : {}
         },
         /* 应用发布信息 */
         "distribute" : {
@@ -90,11 +91,7 @@
                 "push" : {
                     "unipush" : {
                         "version" : "2",
-                        "offline" : true,
-                        "mi" : {},
-                        "oppo" : {},
-                        "vivo" : {},
-                        "honor" : {}
+                        "offline" : false
                     }
                 },
                 "geolocation" : {

+ 10 - 0
pages.json

@@ -284,6 +284,16 @@
 			"style": {
 				"navigationBarTitleText": "我的星灵"
 			}
+		}, {
+			"path": "pages/vip/index",
+			"style": {
+				"navigationBarTitleText": "VIP会员中心",
+				"navigationBarBackgroundColor": "#161616",
+				"navigationBarTextStyle": "white",
+				"app-plus": {
+					"bounce": "none"
+				}
+			}
 		}
 	],
 	"globalStyle": {

+ 14 - 11
pages/login/login.vue

@@ -119,16 +119,17 @@
 				})
 			}, 200);
 			let that = this;
-			uni.getPushClientId({
-				success: (res) => {
-					console.log("su:", res.cid);
-					that.push_token = res.cid;
-				},
-				fail(err) {
-					that.push_token = '';
-					console.log(err)
-				}
-			});
+			// 尝试使用全局存储的推送token
+			if (getApp().globalData.push_token) {
+				that.push_token = getApp().globalData.push_token;
+				console.log("使用全局推送token:", that.push_token);
+			} else {
+				// 这里不再主动获取,依赖App.vue中的获取结果
+				// 避免重复调用可能导致的问题
+				console.log("等待全局推送token初始化");
+				// 开发环境可以设置一个默认值,避免接口报错
+				that.push_token = '';
+			}
 		},
 		onShow() {
 			// let hsign = pubc.Encrypt("aboa-wifl-kwfl-zjfk-wlaa_FA0412932BAE9D98506580ADB348BEF9");
@@ -254,6 +255,8 @@
 					mask: true,
 				});
 				console.log("host", this.$apiHost + method);
+				// 添加容错处理,如果推送token为空,用随机字符串代替
+				const pushToken = this.push_token || ('dev_' + new Date().getTime());
 				uni.request({
 					url: this.$apiHost + method,
 					data: {
@@ -263,7 +266,7 @@
 						mobile: this.mobile,
 						password: this.password,
 						code: this.code,
-						push_token: this.push_token,
+						push_token: pushToken,
 						lat: this.lat,
 						lng: this.lng,
 					},

+ 14 - 11
pages/login/reg.vue

@@ -102,16 +102,17 @@
 			}, 200);
 			let that = this;
 			// #ifdef APP-PLUS
-			uni.getPushClientId({
-				success: (res) => {
-					console.log("su:", res.cid);
-					that.push_token = res.cid;
-				},
-				fail(err) {
-					that.push_token = '';
-					console.log(err)
-				}
-			});
+			// 尝试使用全局存储的推送token
+			if (getApp().globalData.push_token) {
+				that.push_token = getApp().globalData.push_token;
+				console.log("使用全局推送token:", that.push_token);
+			} else {
+				// 这里不再主动获取,依赖App.vue中的获取结果
+				// 避免重复调用可能导致的问题
+				console.log("等待全局推送token初始化");
+				// 开发环境可以设置一个默认值,避免接口报错
+				that.push_token = '';
+			}
 			// #endif
 		},
 		onShow() {
@@ -254,6 +255,8 @@
 					mask: true,
 				});
 				console.log("host", this.$apiHost + method);
+				// 添加容错处理,如果推送token为空,用随机字符串代替
+				const pushToken = this.push_token || ('dev_' + new Date().getTime());
 				uni.request({
 					url: this.$apiHost + method, //仅为示例,并非真实接口地址。
 					data: {
@@ -264,7 +267,7 @@
 						ycode: this.ycode,
 						code: this.code,
 						is_web3: this.is_web3,
-						push_token: this.push_token,
+						push_token: pushToken,
 						lat: this.lat,
 						lng: this.lng,
 					},

+ 5 - 3
pages/makedetail/makeDetail.vue

@@ -33,8 +33,10 @@
 			</view> -->
 
 			<!-- 音乐类型时显示歌词 -->
-			<view class="lyrics-overlay" v-if="queueDetail.task_type == 2" @mousedown="startDrag" @mouseup="stopDrag" @mousemove="drag">
-				<text class="lyrics-text" ref="lyricsText" :style="{ transform: `translateY(${offsetY}px)` }">{{ queueDetail.description }}</text>
+			<view class="lyrics-overlay" v-if="queueDetail.task_type == 2" @mousedown="startDrag" @mouseup="stopDrag"
+				@mousemove="drag">
+				<text class="lyrics-text" ref="lyricsText"
+					:style="{ transform: `translateY(${offsetY}px)` }">{{ queueDetail.description }}</text>
 			</view>
 
 			<!-- 音乐类型且状态为9时显示播放按钮 -->
@@ -660,7 +662,7 @@
 
 					// Define the threshold limits based on the height of the lyrics text
 					const minY = -lyricsTextHeight + 20; // Allow some space above
-					const maxY = 20;  // Allow some space below
+					const maxY = 20; // Allow some space below
 
 					// Apply the limits
 					this.offsetY = Math.min(Math.max(newOffsetY, minY), maxY);

+ 1 - 1
pages/my/my.vue

@@ -61,7 +61,7 @@
 
 			</view>
 			<view class="whiteItem">
-				<view class="btn">开启专属会员权益</view>
+				<view class="btn" @click="goPage('/pages/vip/index')">开启专属会员权益</view>
 			</view>
 			<view class="myinfo">
 				<view class="line"></view>

+ 420 - 0
pages/vip/index.vue

@@ -0,0 +1,420 @@
+<template>
+	<view class="vip-container">
+		<!-- 顶部会员信息 -->
+		<view class="vip-header">
+			<view class="vip-title">尊贵会员</view>
+			<view class="vip-expire" v-if="userInfo.isVip">VIP到期时间: {{userInfo.vipExpireDate}}</view>
+		</view>
+
+		<!-- 会员价格选择 -->
+		<view class="vip-price-options">
+			<view class="price-option" v-for="(item, index) in priceOptions" :key="index"
+				:class="{active: selectedPrice === index}" @tap="selectPrice(index)">
+				<view class="price-tag" v-if="item.tag">{{item.tag}}</view>
+				<view class="price">¥{{item.price}}</view>
+				<view class="duration">{{item.name}}</view>
+			</view>
+		</view>
+
+		<!-- 会员特权列表 -->
+		<view class="vip-privileges">
+			<view class="privileges-title">尊享特权</view>
+			<view class="privileges-list">
+				<view class="privilege-item" v-for="(item, index) in privileges" :key="index">
+					<image class="privilege-icon" :src="item.icon" mode="aspectFit"></image>
+					<view class="privilege-info">
+						<view class="privilege-name">{{item.name}}</view>
+						<view class="privilege-desc">{{item.desc}}</view>
+					</view>
+				</view>
+			</view>
+		</view>
+
+		<!-- 底部支付按钮 -->
+		<view class="bottom-pay-btn">
+			<view class="total-price">合计: <text class="price-value">¥{{priceOptions[selectedPrice].price}}</text></view>
+			<view class="pay-button" @tap="showPaymentOptions">立即续费</view>
+		</view>
+
+		<!-- 支付方式选择弹窗 -->
+		<uni-popup ref="paymentPopup" type="bottom">
+			<view class="payment-popup">
+				<view class="popup-header">
+					<view class="popup-title">选择支付方式</view>
+					<view class="popup-close" @tap="closePaymentPopup">×</view>
+				</view>
+				<view class="payment-options">
+					<view class="payment-option" @tap="selectPayment('alipay')">
+						<image class="payment-icon" src="../../static/icon/pay_ali.png" mode="aspectFit"></image>
+						<view class="payment-name">支付宝支付</view>
+						<image class="payment-select"
+							:src="paymentMethod === 'alipay' ? '' : ''"
+							mode="aspectFit"></image>
+					</view>
+					<view class="payment-option" @tap="selectPayment('wechat')">
+						<image class="payment-icon" src="../../static/icon/pay_wx.png" mode="aspectFit"></image>
+						<view class="payment-name">微信支付</view>
+						<image class="payment-select"
+							:src="paymentMethod === 'wechat' ? '' : ''"
+							mode="aspectFit"></image>
+					</view>
+				</view>
+				<view class="confirm-payment" @tap="confirmPayment">确认支付 ¥{{priceOptions[selectedPrice].price}}</view>
+			</view>
+		</uni-popup>
+	</view>
+</template>
+
+<script>
+	export default {
+		data() {
+			return {
+				userInfo: {
+					isVip: false,
+					vipExpireDate: '2023-10-23'
+				},
+				priceOptions: [{
+						name: '月度VIP',
+						price: '98.00',
+						tag: ''
+					},
+					{
+						name: '季度VIP',
+						price: '198.00',
+						tag: '推荐'
+					},
+					{
+						name: '年度VIP',
+						price: '398.00',
+						tag: ''
+					}
+				],
+				selectedPrice: 1, // 默认选中的价格选项索引
+				privileges: [{
+						name: '无限AI生成',
+						icon: '',
+						desc: '无限次使用AI创作功能'
+					},
+					{
+						name: '高级模型使用',
+						icon: '',
+						desc: '使用更高级的AI模型创作'
+					},
+					{
+						name: '优先创作队列',
+						icon: '',
+						desc: '创作请求优先处理'
+					},
+					{
+						name: 'VIP专属客服',
+						icon: '',
+						desc: '专人解答任何问题'
+					},
+					{
+						name: '尊贵身份标识',
+						icon: '',
+						desc: '展示您的VIP身份'
+					},
+					{
+						name: '高级内容访问',
+						icon: '',
+						desc: '专享更多高级内容'
+					}
+				],
+				paymentMethod: 'alipay', // 默认支付方式
+				privilegesHeight: 0, // 添加存储特权区域高度的变量
+			}
+		},
+		onLoad() {
+			// 获取用户信息,检查是否为VIP
+			this.getUserInfo();
+		},
+		onReady() {
+			// 页面渲染完成后获取vip-privileges的高度
+			this.getPrivilegesHeight();
+		},
+		methods: {
+			// 获取用户信息
+			getUserInfo() {
+				// 这里添加获取用户信息的API调用
+				// 示例数据
+				this.userInfo = {
+					isVip: true,
+					vipExpireDate: '2023-10-23'
+				};
+			},
+			// 选择价格选项
+			selectPrice(index) {
+				this.selectedPrice = index;
+			},
+			// 显示支付方式选择弹窗
+			showPaymentOptions() {
+				this.$refs.paymentPopup.open();
+			},
+			// 关闭支付方式选择弹窗
+			closePaymentPopup() {
+				this.$refs.paymentPopup.close();
+			},
+			// 选择支付方式
+			selectPayment(method) {
+				this.paymentMethod = method;
+			},
+			// 确认支付
+			confirmPayment() {
+				// 根据选择的支付方式进行支付
+				uni.showLoading({
+					title: '支付中...'
+				});
+
+				// 模拟支付过程
+				setTimeout(() => {
+					uni.hideLoading();
+					uni.showToast({
+						title: '支付成功',
+						icon: 'success'
+					});
+					this.$refs.paymentPopup.close();
+				}, 1500);
+
+				// 在实际应用中,这里会调用支付API
+				console.log('支付方式:', this.paymentMethod);
+				console.log('支付金额:', this.priceOptions[this.selectedPrice].price);
+			},
+			// 获取特权列表区域的高度
+			getPrivilegesHeight() {
+				const query = uni.createSelectorQuery().in(this);
+				query.select('.vip-privileges').boundingClientRect(data => {
+					if (data) {
+						this.privilegesHeight = data.height;
+						console.log('特权区域高度:', this.privilegesHeight);
+					} else {
+						console.log('未能获取到特权区域元素');
+						// 如果首次获取失败,可以添加延迟重试
+						setTimeout(() => {
+							this.getPrivilegesHeight();
+						}, 100);
+					}
+				}).exec();
+			},
+			// 如果需要在某些数据变化后重新获取高度
+			updatePrivilegesHeight() {
+				this.$nextTick(() => {
+					this.getPrivilegesHeight();
+				});
+			}
+		}
+	}
+</script>
+
+<style lang="scss">
+	.vip-container {
+		min-height: 100vh;
+		background-color: #161616;
+		padding-bottom: 120rpx;
+	}
+
+	.vip-header {
+		background: linear-gradient(to right, #7F28DE, #5F17DD);
+		padding: 80rpx 40rpx;
+		color: #ffffff;
+		border-radius: 0 0 30rpx 30rpx;
+	}
+
+	.vip-title {
+		font-size: 48rpx;
+		font-weight: bold;
+		margin-bottom: 20rpx;
+	}
+
+	.vip-expire {
+		font-size: 28rpx;
+		opacity: 0.8;
+	}
+
+	.vip-price-options {
+		display: flex;
+		justify-content: space-between;
+		padding: 40rpx;
+		margin-top: -60rpx;
+	}
+
+	.price-option {
+		width: 210rpx;
+		height: 240rpx;
+		background-color: #242424;
+		border-radius: 20rpx;
+		display: flex;
+		flex-direction: column;
+		justify-content: center;
+		align-items: center;
+		position: relative;
+		transition: all 0.3s;
+
+		&.active {
+			background: linear-gradient(to bottom, #9758DE, #5F17DD);
+			transform: scale(1.05);
+		}
+	}
+
+	.price-tag {
+		position: absolute;
+		top: -20rpx;
+		padding: 6rpx 20rpx;
+		background-color: #FF6B00;
+		color: #ffffff;
+		font-size: 24rpx;
+		border-radius: 20rpx;
+	}
+
+	.price {
+		font-size: 48rpx;
+		font-weight: bold;
+		color: #ffffff;
+		margin-bottom: 20rpx;
+	}
+
+	.duration {
+		font-size: 28rpx;
+		color: #cccccc;
+	}
+
+	.vip-privileges {
+		padding: 40rpx;
+	}
+
+	.privileges-title {
+		font-size: 32rpx;
+		color: #ffffff;
+		margin-bottom: 40rpx;
+		font-weight: bold;
+	}
+
+	.privileges-list {
+		display: flex;
+		flex-wrap: wrap;
+		justify-content: space-between;
+	}
+
+	.privilege-item {
+		width: 48%;
+		background-color: #242424;
+		border-radius: 16rpx;
+		padding: 30rpx;
+		margin-bottom: 30rpx;
+		display: flex;
+		align-items: center;
+	}
+
+	.privilege-icon {
+		width: 60rpx;
+		height: 60rpx;
+		margin-right: 20rpx;
+	}
+
+	.privilege-name {
+		font-size: 28rpx;
+		color: #ffffff;
+		margin-bottom: 10rpx;
+	}
+
+	.privilege-desc {
+		font-size: 24rpx;
+		color: #999999;
+	}
+
+	.bottom-pay-btn {
+		position: fixed;
+		bottom: 0;
+		left: 0;
+		right: 0;
+		display: flex;
+		align-items: center;
+		justify-content: space-between;
+		background-color: #242424;
+		padding: 30rpx 40rpx;
+		box-sizing: border-box;
+	}
+
+	.total-price {
+		color: #cccccc;
+		font-size: 28rpx;
+	}
+
+	.price-value {
+		color: #ffffff;
+		font-size: 40rpx;
+		font-weight: bold;
+	}
+
+	.pay-button {
+		background: linear-gradient(to right, #9758DE, #5F17DD);
+		color: #ffffff;
+		padding: 20rpx 60rpx;
+		border-radius: 50rpx;
+		font-size: 32rpx;
+	}
+
+	/* 支付方式选择弹窗样式 */
+	.payment-popup {
+		background-color: #242424;
+		border-radius: 30rpx 30rpx 0 0;
+		padding: 40rpx;
+	}
+
+	.popup-header {
+		display: flex;
+		justify-content: space-between;
+		align-items: center;
+		margin-bottom: 40rpx;
+	}
+
+	.popup-title {
+		font-size: 32rpx;
+		color: #ffffff;
+		font-weight: bold;
+	}
+
+	.popup-close {
+		font-size: 48rpx;
+		color: #999999;
+		line-height: 1;
+	}
+
+	.payment-options {
+		margin-bottom: 40rpx;
+	}
+
+	.payment-option {
+		display: flex;
+		align-items: center;
+		padding: 30rpx 0;
+		border-bottom: 1px solid #333333;
+	}
+
+	.payment-icon {
+		width: 60rpx;
+		height: 60rpx;
+		margin-right: 20rpx;
+	}
+
+	.payment-name {
+		flex: 1;
+		color: #ffffff;
+		font-size: 30rpx;
+	}
+
+	.payment-select {
+		width: 40rpx;
+		height: 40rpx;
+	}
+
+	.confirm-payment {
+		background: linear-gradient(to right, #9758DE, #5F17DD);
+		color: #ffffff;
+		text-align: center;
+		padding: 30rpx 0;
+		border-radius: 50rpx;
+		font-size: 32rpx;
+		margin-top: 60rpx;
+	}
+</style>

BIN
static/icon/pay_ali.png


BIN
static/icon/pay_wx.png