Przeglądaj źródła

公益活动详情相关静态页完成

htc 2 tygodni temu
rodzic
commit
d3c185bc14

+ 48 - 0
pages.json

@@ -40,6 +40,54 @@
 					"style": {
 						"navigationStyle": "custom"
 					}
+				},
+				{
+					"path": "applyResult",
+					"style": {
+						"navigationStyle": "custom"
+					}
+				},
+				{
+					"path": "signSuccess",
+					"style": {
+						"navigationStyle": "custom"
+					}
+				},
+				{
+					"path": "fillNonprofitArchives",
+					"style": {
+						"navigationStyle": "custom"
+					}
+				},
+				{
+					"path": "fillNonprofitResult",
+					"style": {
+						"navigationStyle": "custom"
+					}
+				},
+				{
+					"path": "recruitsNumber",
+					"style": {
+						"navigationStyle": "custom"
+					}
+				},
+				{
+					"path": "activityApply",
+					"style": {
+						"navigationStyle": "custom"
+					}
+				},
+				{
+					"path": "applyMember",
+					"style": {
+						"navigationStyle": "custom"
+					}
+				},
+				{
+					"path": "applyMemberVindicate",
+					"style": {
+						"navigationStyle": "custom"
+					}
 				}
 			]
 		},

+ 362 - 0
pagesHome/activityApply.vue

@@ -0,0 +1,362 @@
+<template>
+	<view class="common_page adffc" :style="{'min-height':h+'px', 'padding-top':mt+'px'}">
+		<cus-header title="报名信息填写" bgColor="transparent"></cus-header>
+		<image src="https://transcend.ringzle.com/xiaozhi-app/profile/2025/09/19/54b75bc8-d926-449b-95a5-1126f700b481.png" class="top_bg_img" mode="widthFix"></image>
+		<div class="box box1">
+			<div class="box1-top">
+				<div class="title">{{'环保知识知多少?让孩子成为大自然的守护者!'}}</div>
+				<div class="tip">活动时间:{{'2025年06月01日 12:00'}}</div>
+				<div class="tip">活动地点:{{'深圳市南山区南山街道丰潭路'}}</div>
+			</div>
+			<div class="box1-bottom adfac">
+				<image src="https://transcend.ringzle.com/xiaozhi-app/profile/2025/10/10/0f8ec76b-5c24-4d79-a77e-354d3e70bb36.png"></image>
+				<text>报名时间截止前可取消并返还爱心值,截止后不可取消。</text>
+			</div>
+		</div>
+		<div class="box box2">
+			<div class="box2-title">报名信息</div>
+			<div class="box2-members" v-if="selectMemberList.length">
+				<div class="box2-members-pre adfacjb" v-for="(item,index) in selectMemberList" :key="index">
+					<div class="box2-members-pre-left">
+						<div class="ltop adfac">
+							<div class="name">{{'张琳琳'}}</div>
+							<image class="sex" v-if="item.sex==2" src="https://transcend.ringzle.com/xiaozhi-app/profile/2025/09/12/b6d1fcb3-55ba-4104-b8cd-756b963a4da8.png"></image>
+							<image class="sex" v-else-if="item.sex==1" src="https://transcend.ringzle.com/xiaozhi-app/profile/2025/09/12/a1899fd0-c468-48d9-b554-2f17b75a4157.png"></image>
+							<div class="age" :class="{'women':item.sex==2,'man':item.sex==1}">{{46}}岁</div>
+						</div>
+						<div class="lbottom">
+							身份证 {{'340123**********09'}}
+						</div>
+					</div>
+					<div class="box2-members-pre-right">
+						<image src="https://transcend.ringzle.com/xiaozhi-app/profile/2025/10/10/bf4876c8-43bf-4eeb-a153-1414e567ed10.png"></image>
+					</div>
+				</div>
+			</div>
+			<div class="box2-add adfacjc" @tap="handleAdd">
+				<image src="https://transcend.ringzle.com/xiaozhi-app/profile/2025/10/10/9aa7a091-d1fe-40a9-9a7e-846decf2d4e0.png"></image>
+				<text>添加</text>
+			</div>
+		</div>
+		<div class="box box3">
+			<div class="box3-pre adfacjb">
+				<div class="box3-pre-left">联系人姓名</div>
+				<div class="box3-pre-right">
+					<up-input v-model="submitDto.name" border="none" style="font-size: 30rpx;color: #151B29;text-align: right;" placeholder="请输入联系人姓名"></up-input>
+				</div>
+			</div>
+			<div class="box3-pre adfacjb">
+				<div class="box3-pre-left">联系人电话</div>
+				<div class="box3-pre-right">
+					<up-input v-model="submitDto.phone" border="none" style="font-size: 30rpx;color: #151B29;text-align: right;" placeholder="请输入联系人电话"></up-input>
+				</div>
+			</div>
+		</div>
+		<div class="box box4 adfacjb">
+			<div class="box4-left">专享券抵扣</div>
+			<div class="box4-right adfac" @tap="handleSelectTicket">
+				<text>{{'暂无可用专享券'}}</text>
+				<image src="https://transcend.ringzle.com/xiaozhi-app/profile/2025/10/10/4d3329f1-7421-4bde-a7dd-5175a7748f8f.png"></image>
+			</div>
+		</div>
+		<div class="cbottom">
+			<div class="cbottom-top adfac" @tap="changeAgree">
+				<image v-if="agree" src="https://transcend.ringzle.com/xiaozhi-app/profile/2025/09/12/87b5b244-d14f-43cd-991b-4ac9f48d909e.png"></image>
+				<image v-else src="https://transcend.ringzle.com/xiaozhi-app/profile/2025/09/12/b8a5cabd-57f8-4ad7-9677-f6372423c50a.png"></image>
+				<text>我已知晓并同意活动组织方获取以上我所提交的报名信息。</text>
+			</div>
+			<div class="cbottom-btn adfacjb">
+				<div class="cbottom-btn-left adffcac">
+					<div class="heart adfac">
+						<image src="https://transcend.ringzle.com/xiaozhi-app/profile/2025/10/10/ab188fd0-afcc-4d76-a1d6-de367af3e756.png"></image>
+						<text>{{300}}</text>
+					</div>
+					<div class="text">爱心值</div>
+				</div>
+				<div class="cbottom-btn-right" @click="handleApply">确定报名</div>
+			</div>
+		</div>
+	</view>
+</template>
+
+<script setup name="">
+	import CusHeader from '@/components/CusHeader/index.vue'
+	import { ref } from 'vue'
+	
+	const selectMemberList = ref([{sex:1},{sex:2}])
+	const submitDto = ref({
+		name:'',
+		phone:''
+	})
+	const agree = ref(false)
+	
+	const handleAdd = () => {
+		uni.navigateTo({
+			url:'/pagesHome/applyMember'
+		})
+	}
+	
+	const handleSelectTicket = () => {
+		uni.navigateTo({
+			url:'/pagesMy/exclusiveScroll'
+		})
+	}
+	
+	const handleApply = () => {
+		uni.navigateTo({
+			url:'/pagesHome/applyResult'
+		})
+	}
+	
+	const changeAgree = () => {
+		agree.value = !agree.value;
+	}
+</script>
+
+<style scoped lang="scss">
+	::v-deep .u-input__content__field-wrapper__field{
+		text-align: right !important;
+	}
+	
+	.common_page{
+		padding-bottom: 248rpx;
+		
+		.box{
+			margin-top: 20rpx;
+			background: #FFFFFF;
+			border-radius: 20rpx;
+			position: relative;
+		}
+		
+		.box1{
+			&-top{
+				padding: 36rpx 24rpx 24rpx;
+				border-bottom: 1rpx solid #E5E7EB;
+				&>.title{
+					font-family: PingFang-SC, PingFang-SC;
+					font-weight: bold;
+					font-size: 32rpx;
+					color: #151B29;
+					line-height: 32rpx;
+				}
+				&>.tip{
+					font-family: PingFangSC, PingFang SC;
+					font-weight: 400;
+					font-size: 24rpx;
+					color: #666666;
+					line-height: 24rpx;
+					margin-top: 30rpx;
+				}
+			}
+			&-bottom{
+				padding: 26rpx 24rpx;
+				image{
+					width: 20rpx;
+					height: 20rpx;
+				}
+				text{
+					font-family: PingFangSC, PingFang SC;
+					font-weight: 400;
+					font-size: 24rpx;
+					color: #C9A771;
+					line-height: 24rpx;
+					margin-left: 10rpx;
+				}
+			}
+		}
+	
+		.box2{
+			padding: 40rpx 24rpx 48rpx;
+			&-title{
+				font-family: PingFang-SC, PingFang-SC;
+				font-weight: bold;
+				font-size: 36rpx;
+				color: #151B29;
+				line-height: 36rpx;
+				margin-bottom: 26rpx;
+				display: inline-block;
+			}
+			&-members{
+				&-pre{
+					padding: 36rpx 0;
+					box-shadow: inset 0rpx -1rpx 0rpx 0rpx #F2F2F2;
+					&-left{
+						.ltop{
+							.name{
+								font-family: PingFang-SC, PingFang-SC;
+								font-weight: bold;
+								font-size: 32rpx;
+								color: #151B29;
+								line-height: 32rpx;
+							}
+							.sex{
+								width: 44rpx;
+								height: 32rpx;
+								margin-left: 20rpx;
+							}
+							.age{
+								border-radius: 13rpx;
+								font-family: PingFangSC, PingFang SC;
+								font-weight: 400;
+								font-size: 20rpx;
+								line-height: 24rpx;
+								padding: 4rpx 10rpx;
+								margin-left: 13rpx;
+								&.women{
+									background: rgba(244,101,122,0.14);
+									color: #F4657A;
+								}
+								&.man{
+									background: rgba(5,169,254,0.12);
+									color: #05A9FE;
+								}
+							}
+						}
+						.lbottom{
+							font-family: PingFangSC, PingFang SC;
+							font-weight: 400;
+							font-size: 24rpx;
+							color: #989998;
+							line-height: 24rpx;
+							margin-top: 24rpx;
+						}
+					}
+					&-right{
+						width: 36rpx;
+						height: 36rpx;
+						image{
+							width: 100%;
+							height: 100%;
+						}
+					}
+				}
+			}
+			&-add{
+				width: 100%;
+				height: 78rpx;
+				background: rgba(112,207,82,0.08);
+				border-radius: 24rpx;
+				border: 1rpx dotted #70CF52;
+				margin-top: 40rpx;
+				image{
+					width: 36rpx;
+					height: 36rpx;
+				}
+				text{
+					font-family: PingFang-SC, PingFang-SC;
+					font-weight: bold;
+					font-size: 28rpx;
+					color: #70CF52;
+					line-height: 40rpx;
+					margin-left: 10rpx;
+				}
+			}
+		}
+	
+		.box3{
+			&-pre{
+				padding: 36rpx 24rpx;
+				&:first-child{
+					box-shadow: inset 0rpx -1rpx 0rpx 0rpx #ECEEF5;
+				}
+				&-left{
+					font-family: PingFangSC, PingFang SC;
+					font-weight: 400;
+					font-size: 30rpx;
+					color: #151B29;
+					line-height: 36rpx;
+				}
+			}
+		}
+	
+		.box4{
+			padding: 36rpx 24rpx;
+			&-left{
+				font-family: PingFangSC, PingFang SC;
+				font-weight: 400;
+				font-size: 30rpx;
+				color: #151B29;
+				line-height: 36rpx;
+			}
+			&-right{
+				text{
+					font-family: PingFangSC, PingFang SC;
+					font-weight: 400;
+					font-size: 24rpx;
+					color: #989998;
+					line-height: 33rpx;
+				}
+				image{
+					width: 32rpx;
+					height: 32rpx;
+					margin-left: 20rpx;
+				}
+			}
+		}
+	
+		.cbottom{
+			width: 100%;
+			position: fixed;
+			left: 0;
+			right: 0;
+			bottom: 0;
+			&-top{
+				padding: 0 30rpx;
+				image{
+					width: 36rpx;
+					height: 36rpx;
+				}
+				text{
+					font-family: PingFangSC, PingFang SC;
+					font-weight: 400;
+					font-size: 24rpx;
+					color: #989998;
+					line-height: 33rpx;
+					margin-left: 16rpx;
+				}
+			}
+			&-btn{
+				background: #FFFFFF;
+				padding: 20rpx 30rpx 44rpx 36rpx;
+				margin-top: 40rpx;
+				&-left{
+					.heart{
+						image{
+							width: 30rpx;
+							height: 30rpx;
+						}
+						text{
+							font-family: PingFang-SC, PingFang-SC;
+							font-weight: bold;
+							font-size: 36rpx;
+							color: #F4657A;
+							line-height: 36rpx;
+							margin-left: 2rpx;
+						}
+					}
+					.text{
+						font-family: PingFangSC, PingFang SC;
+						font-weight: 400;
+						font-size: 24rpx;
+						color: #252525;
+						line-height: 24rpx;
+						margin-top: 11rpx;
+					}
+				}
+				&-right{
+					width: 528rpx;
+					height: 90rpx;
+					background: #B7F358;
+					border-radius: 45rpx;
+					font-family: PingFang-SC, PingFang-SC;
+					font-weight: bold;
+					font-size: 32rpx;
+					color: #151B29;
+					line-height: 90rpx;
+					text-align: center;
+					letter-spacing: 2rpx;
+				}
+			}
+		}
+	}
+</style>

+ 267 - 6
pagesHome/activityDetail.vue

@@ -39,7 +39,7 @@
 					<text>招募人数</text>
 					<div class="num"><text>{{35}}</text> /{{50}}</div>
 				</div>
-				<div class="box1-member-right adffc">
+				<div class="box1-member-right adffc" @tap="handleReviewMembers">
 					<div class="review adfac">
 						<text>查看报名人员</text>
 						<image src="https://transcend.ringzle.com/xiaozhi-app/profile/2025/10/10/b7b7531b-33fa-4ec3-841b-796be9035191.png"></image>
@@ -96,11 +96,61 @@
 				报名时间:{{'2025年06月01日 12:00'}} - {{'2025年06月15日12:00'}} 
 			</div>
 			<div class="btns adfacjb">
-				<div class="left adffcacjc" @tap="handleShare">
+				<div class="left adffcacjc" @tap="share=true">
 					<up-icon name="share-square" color="#252525" size="48rpx"></up-icon>
 					<text>分享</text>
 				</div>
-				<div class="right">立即报名</div>
+				<div class="right" @click="handleApply">立即报名</div>
+			</div>
+		</div>
+		<div class="fail" v-if="fail">
+			<div class="fbox adffcac">
+				<image class="clock" src="https://transcend.ringzle.com/xiaozhi-app/profile/2025/10/10/5fe8627b-adc4-4e24-8e86-45771d3ba5a2.png"></image>
+				<image class="close" src="https://transcend.ringzle.com/xiaozhi-app/profile/2025/10/10/3d94527a-da92-4d8b-9e99-44683c4f5c84.png" @click="fail=false"></image>
+				<image class="alert" src="https://transcend.ringzle.com/xiaozhi-app/profile/2025/10/10/fdf05bfa-5593-4448-940e-437152bbbaf9.png" mode="widthFix"></image>
+				<div class="texts adffcacjc">
+					<div class="text">您当前爱心值不足,无法报名活动</div>
+					<div class="tip">欢迎联系专属客服,了解更多公益活动,积攒爱心值</div>
+				</div>
+				<image class="down" src="https://transcend.ringzle.com/xiaozhi-app/profile/2025/10/10/c7d4983d-ca93-4833-8922-e010dd1d450a.png"></image>
+				<div class="user adfac">
+					<div class="user-left">
+						<image src="https://transcend.ringzle.com/xiaozhi-app/profile/2025/10/10/20ff1438-01a9-454c-b62c-501ed47c39a6.png"></image>
+					</div>
+					<div class="user-right">
+						<div class="name">陈婧航</div>
+						<div class="memo">@深圳善行少年基金会</div>
+					</div>
+				</div>
+				<div class="finfo adffcac">
+					<div class="finfo-code adffcacjc">
+						<image src="https://transcend.ringzle.com/xiaozhi-app/profile/2025/10/10/fbb4ac12-163e-48bd-9066-27b068078107.png"></image>
+					</div>
+					<div class="finfo-title">长按识别二维码</div>
+					<div class="finfo-tip">添加您的专属公益向导</div>
+					<div class="finfo-btn">了解善行少年</div>
+					<div class="finfo-zblj" @click="fail=false">暂不了解</div>
+				</div>
+			</div>
+		</div>
+		<div class="share" v-if="share">
+			<div class="sbox">
+				<div class="sbox-title">分享给好友</div>
+				<image class="close" src="https://transcend.ringzle.com/xiaozhi-app/profile/2025/10/10/7d1c7cf4-199a-4008-8114-ee0e1a8f0cc3.png" @click="share=false"></image>
+				<div class="sbox-items adfac">
+					<div class="sbox-items-pre adffcac">
+						<image src="https://transcend.ringzle.com/xiaozhi-app/profile/2025/10/10/a993c721-a4c7-4f5e-95cc-6451a50bfdce.png"></image>
+						<text>分享页面</text>
+					</div>
+					<div class="sbox-items-pre adffcac">
+						<image src="https://transcend.ringzle.com/xiaozhi-app/profile/2025/10/10/0c87d8a1-d7c5-466c-84aa-87ec5f163955.png"></image>
+						<text>生成海报</text>
+					</div>
+					<div class="sbox-items-pre adffcac">
+						<image src="https://transcend.ringzle.com/xiaozhi-app/profile/2025/10/10/732ac5fd-af58-44d8-9625-aaf96c24fed0.png"></image>
+						<text>分享到朋友圈</text>
+					</div>
+				</div>
 			</div>
 		</div>
 	</view>
@@ -121,10 +171,22 @@
 		'https://transcend.ringzle.com/xiaozhi-app/profile/2025/10/10/565ca09a-88e2-4c2c-a89e-98bd51fbea7f.png',
 		'https://transcend.ringzle.com/xiaozhi-app/profile/2025/10/10/565ca09a-88e2-4c2c-a89e-98bd51fbea7f.png'
 	])
+	const fail = ref(false)
+	const share = ref(false)
+	
+	const handleReviewMembers = () => {
+		uni.navigateTo({
+			url:'/pagesHome/recruitsNumber'
+		})
+	}
 	
-	const handleShare = () => {
-	  
-	};
+	const handleApply = () => {
+		uni.navigateTo({
+			url:'/pagesHome/activityApply'
+			// url:'/pagesHome/signSuccess'
+			// url:'/pagesHome/fillNonprofitArchives'
+		})
+	}
 	
 	onLoad(options=>{
 		id.value = options?.id;
@@ -416,5 +478,204 @@
 				}
 			}
 		}
+	
+		.fail{
+			position: fixed;
+			left: 0;
+			right: 0;
+			top: 0;
+			bottom: 0;
+			background: rgba(0,0,0,0.4);
+			display: flex;
+			flex-direction: column;
+			justify-content: flex-end;
+			.fbox{
+				background: #FFFFFF;
+				background-image: url('https://transcend.ringzle.com/xiaozhi-app/profile/2025/10/10/e5ca0b95-ae33-4a93-8955-fe1d5e05ed2d.png');
+				background-repeat: no-repeat;
+				background-position: top left;
+				background-size: 100% 399rpx;
+				border-radius: 24rpx 24rpx 0 0;
+				position: relative;
+				padding: 40rpx 30rpx 123rpx;
+				
+				.clock{
+					width: 219rpx;
+					height: 143rpx;
+					position: absolute;
+					left: 51rpx;
+					top: -37rpx;
+				}
+				.close{
+					width: 40rpx;
+					height: 40rpx;
+					position: absolute;
+					top: 40rpx;
+					right: 36rpx;
+				}
+				.alert{
+					width: 212rpx;
+				}
+				.texts{
+					width: 100%;
+					margin-top: 69rpx;
+					background: #FFFFFF;
+					border-radius: 24rpx;
+					border: 1rpx dotted #979797;
+					padding: 36rpx 0;
+					.text{
+						font-family: PingFang-SC, PingFang-SC;
+						font-weight: bold;
+						font-size: 36rpx;
+						color: #252525;
+						line-height: 36rpx;
+					}
+					.tip{
+						font-family: PingFangSC, PingFang SC;
+						font-weight: 400;
+						font-size: 24rpx;
+						color: #676775;
+						line-height: 26rpx;
+						margin-top: 24rpx;
+					}
+				}
+				.down{
+					width: 514rpx;
+					height: 34rpx;
+					margin-top: 20rpx;
+				}
+				.user{
+					margin-top: 30rpx;
+					width: 100%;
+					padding-left: 50rpx;
+					box-sizing: border-box;
+					&-left{
+						image{
+							width: 98rpx;
+							height: 98rpx;
+						}
+					}
+					&-right{
+						margin-left: 20rpx;
+						.name{
+							font-family: PingFang-SC, PingFang-SC;
+							font-weight: bold;
+							font-size: 32rpx;
+							color: #252525;
+							line-height: 32rpx;
+						}
+						.memo{
+							font-family: PingFang-SC, PingFang-SC;
+							font-weight: bold;
+							font-size: 24rpx;
+							color: #05A9FE;
+							line-height: 24rpx;
+							margin-top: 24rpx;
+						}
+					}
+				}
+				.finfo{
+					width: 100%;
+					margin-top: 36rpx;
+					&-code{
+						width: 310rpx;
+						height: 310rpx;
+						background: #FFFFFF;
+						border: 3rpx solid #C5E3FE;
+						image{
+							width: 244rpx;
+							height: 244rpx;
+						}
+					}
+					&-title{
+						margin-top: 24rpx;
+						font-size: 28rpx;
+						color: #252525;
+						line-height: 40rpx;
+					}
+					&-tip{
+						margin-top: 10rpx;
+						font-size: 24rpx;
+						color: #656775;
+						line-height: 40rpx;
+					}
+					&-btn{
+						width: calc(100% - 20rpx);
+						height: 90rpx;
+						background: #B7F358;
+						border-radius: 45rpx;
+						font-family: PingFang-SC, PingFang-SC;
+						font-weight: bold;
+						font-size: 32rpx;
+						color: #151B29;
+						line-height: 90rpx;
+						text-align: center;
+						margin-top: 48rpx;
+					}
+					&-zblj{
+						font-family: PingFangSC, PingFang SC;
+						font-weight: 400;
+						font-size: 28rpx;
+						color: #989998;
+						line-height: 40rpx;
+						margin-top: 48rpx;
+						padding-bottom: 5rpx;
+						border-bottom: 1rpx solid #989998;
+					}
+				}
+			}
+		}
+		
+		.share{
+			position: fixed;
+			left: 0;
+			right: 0;
+			top: 0;
+			bottom: 0;
+			background: rgba(0,0,0,0.4);
+			display: flex;
+			flex-direction: column;
+			justify-content: flex-end;
+			.sbox{
+				position: relative;
+				background: #FFFFFF;
+				border-radius: 24rpx 24rpx 0rpx 0rpx;
+				padding: 50rpx 30rpx 148rpx;
+				&-title{
+					font-family: PingFang-SC, PingFang-SC;
+					font-weight: bold;
+					font-size: 36rpx;
+					color: #151B29;
+					line-height: 36rpx;
+					text-align: center;
+				}
+				.close{
+					width: 27rpx;
+					height: 27rpx;
+					position: absolute;
+					top: 50rpx;
+					right: 40rpx;
+				}
+				&-items{
+					margin-top: 88rpx;
+					&-pre{
+						width: calc(100% / 3);
+						image{
+							width: 94rpx;
+							height: 94rpx;
+						}
+						text{
+							font-family: PingFangSC, PingFang SC;
+							font-weight: 400;
+							font-size: 26rpx;
+							color: #252525;
+							line-height: 26rpx;
+							text-align: center;
+							margin-top: 24rpx;
+						}
+					}
+				}
+			}
+		}
 	}
 </style>

+ 198 - 0
pagesHome/applyMember.vue

@@ -0,0 +1,198 @@
+<template>
+	<view class="common_page adffc" :style="{'height':h+'px', 'padding-top':mt+'px'}">
+		<cus-header title="报名信息" bgColor="#FFFFFF"></cus-header>
+		<div class="add">
+			<div class="btn adfacjc" @tap="handleAdd">
+				<image src="https://transcend.ringzle.com/xiaozhi-app/profile/2025/10/09/af9133fd-e15e-454d-9152-e4629fd0ce28.png"></image>
+				<text>添加</text>
+			</div>
+		</div>
+		<template v-if="list.length">
+			<div class="list">
+				<up-list @scrolltolower="scrolltolower" style="height: 100%;">
+					<up-list-item v-for="(item, index) in list" :key="index">
+						<div class="box adfacjb">
+							<div class="box-left adfac" @tap="handleEdit(item,index)">
+								<div class="box-left-edit">
+									<image src="https://transcend.ringzle.com/xiaozhi-app/profile/2025/10/09/7799f9f2-1dca-4af3-980b-7f6def10e22f.png"></image>
+								</div>
+								<div class="box-left-info">
+									<div class="box-left-info-top adfac">
+										<div class="name">{{'张琳琳'}}</div>
+										<image class="sex" v-if="item.sex==2" src="https://transcend.ringzle.com/xiaozhi-app/profile/2025/09/12/b6d1fcb3-55ba-4104-b8cd-756b963a4da8.png"></image>
+										<image class="sex" v-else-if="item.sex==1" src="https://transcend.ringzle.com/xiaozhi-app/profile/2025/09/12/a1899fd0-c468-48d9-b554-2f17b75a4157.png"></image>
+										<div class="age" :class="{'women':item.sex==2,'man':item.sex==1}">{{46}}岁</div>
+									</div>
+									<div class="box-left-info-bottom">
+										身份证 {{'340123**********09'}}
+									</div>
+								</div>
+							</div>
+							<div class="box-right" @tap="handleSelect(item,index)">
+								<image v-if="item.select" src="https://transcend.ringzle.com/xiaozhi-app/profile/2025/09/12/87b5b244-d14f-43cd-991b-4ac9f48d909e.png"></image>
+								<image v-else src="https://transcend.ringzle.com/xiaozhi-app/profile/2025/09/12/b8a5cabd-57f8-4ad7-9677-f6372423c50a.png"></image>
+							</div>
+						</div>
+					</up-list-item>
+				</up-list>
+			</div>
+			<div class="confirm">确定,已选择{{2}}人</div>
+		</template>
+		<template v-else>
+			<div class="empty">暂无可选人员,请添加</div>
+		</template>
+	</view>
+</template>
+
+<script setup name="">
+	import CusHeader from '@/components/CusHeader/index.vue'
+	import { ref } from 'vue'
+	
+	const list = ref([{sex:1},{sex:2},{sex:2}])
+	
+	const handleAdd = () => {
+		uni.navigateTo({
+			url:'/pagesHome/applyMemberVindicate'
+		})
+	}
+	
+	const handleEdit = (item,index) => {
+		uni.navigateTo({
+			url:'/pagesHome/applyMemberVindicate?member='+encodeURIComponent(JSON.stringify(item))
+		})
+	}
+	const handleSelect = (item,index) => {
+		
+	}
+</script>
+
+<style scoped lang="scss">
+	.common_page{
+		padding-bottom: 60rpx;
+		.add{
+			margin-top: 20rpx;
+			background: #FFFFFF;
+			border-radius: 20rpx 20rpx 0 0;
+			padding: 30rpx 24rpx 20rpx;
+			.btn{
+				width: 100%;
+				background: rgba(112,207,82,0.08);
+				border-radius: 24rpx;
+				border: 1rpx dotted #70CF52;
+				padding: 21rpx 0;
+				image{
+					width: 36rpx;
+					height: 36rpx;
+				}
+				text{
+					font-family: PingFang-SC, PingFang-SC;
+					font-weight: bold;
+					font-size: 28rpx;
+					color: #70CF52;
+					line-height: 40rpx;
+					margin-left: 18rpx;
+					letter-spacing: 2rpx;
+				}
+			}
+		}
+		
+		.list{
+			flex: 1;
+			overflow: auto;
+			background: #FFFFFF;
+			border-radius: 0 0 20rpx 20rpx;
+			padding: 0 24rpx;
+			.box{
+				padding: 37rpx 0;
+				box-shadow: inset 0rpx -1rpx 0rpx 0rpx #F2F2F2;
+				&-left{
+					width: calc(100% - 76rpx);
+					&-edit{
+						width: 36rpx;
+						height: 36rpx;
+						image{
+							width: 100%;
+							height: 100%;
+						}
+					}
+					&-info{
+						width: calc(100% - 36rpx);
+						padding-left: 20rpx;
+						box-sizing: border-box;
+						&-top{
+							.name{
+								font-family: PingFang-SC, PingFang-SC;
+								font-weight: bold;
+								font-size: 32rpx;
+								color: #151B29;
+								line-height: 32rpx;
+							}
+							.sex{
+								width: 44rpx;
+								height: 32rpx;
+								margin-left: 16rpx;
+							}
+							.age{
+								border-radius: 13rpx;
+								font-family: PingFangSC, PingFang SC;
+								font-weight: 400;
+								font-size: 20rpx;
+								line-height: 24rpx;
+								padding: 4rpx 10rpx;
+								margin-left: 13rpx;
+								&.women{
+									background: rgba(244,101,122,0.14);
+									color: #F4657A;
+								}
+								&.man{
+									background: rgba(5,169,254,0.12);
+									color: #05A9FE;
+								}
+							}
+						}
+						&-bottom{
+							font-family: PingFangSC, PingFang SC;
+							font-weight: 400;
+							font-size: 24rpx;
+							color: #989998;
+							line-height: 24rpx;
+							margin-top: 23rpx;
+						}
+					}
+				}
+				
+				&-right{
+					width: 36rpx;
+					height: 36rpx;
+					image{
+						width: 100%;
+						height: 100%;
+					}
+				}
+			}
+		}
+		
+		.confirm{
+			padding: 0 40rpx;
+			margin: 40rpx 0 64rpx;
+			display: inline-block;
+			height: 90rpx;
+			background: #B7F358;
+			border-radius: 45rpx;
+			font-family: PingFang-SC, PingFang-SC;
+			font-weight: bold;
+			font-size: 32rpx;
+			color: #151B29;
+			line-height: 90rpx;
+			text-align: center;
+			letter-spacing: 2rpx;
+		}
+		
+		.empty{
+			margin-top: 300rpx;
+			text-align: center;
+			font-size: 32rpx;
+			color: #666666;
+		}
+	}
+</style>

+ 184 - 0
pagesHome/applyMemberVindicate.vue

@@ -0,0 +1,184 @@
+<template>
+	<view class="common_page" :style="{'min-height':h+'px', 'padding-top':mt+'px'}">
+		<cus-header :title="title" bgColor="#FFFFFF"></cus-header>
+		<div class="form">
+			<div class="title">报名人员信息</div>
+			<div class="pre adfac" style="margin-top: 40rpx;">
+				<div class="pre-title"><span>*</span>人员类型</div>
+				<div class="pre-content adfac">
+					<div class="pre-content-box adfac" @tap="changeMember(1,'type')">
+						<image v-if="memberInfo.type==1" src="https://transcend.ringzle.com/xiaozhi-app/profile/2025/10/09/9efae012-a9fd-4a0d-9e14-7ec90001e712.png"></image>
+						<image v-else src="https://transcend.ringzle.com/xiaozhi-app/profile/2025/10/09/5ae64305-d1e0-4ffe-8dc0-f9d3704ac370.png"></image>
+						<text>成人</text>
+					</div>
+					<div class="pre-content-box adfac" @tap="changeMember(2,'type')">
+						<image v-if="memberInfo.type==2" src="https://transcend.ringzle.com/xiaozhi-app/profile/2025/10/09/9efae012-a9fd-4a0d-9e14-7ec90001e712.png"></image>
+						<image v-else src="https://transcend.ringzle.com/xiaozhi-app/profile/2025/10/09/5ae64305-d1e0-4ffe-8dc0-f9d3704ac370.png"></image>
+						<text>学生</text>
+					</div>
+				</div>
+			</div>
+			<div class="pre adfac">
+				<div class="pre-title"><span>*</span>姓名</div>
+				<div class="pre-content">
+					<up-input v-model="memberInfo.name" border="none" style="font-size: 30rpx;color: #252525;" placeholder="请输入姓名"></up-input>
+				</div>
+			</div>
+			<div class="pre adfac">
+				<div class="pre-title"><span>*</span>身份证</div>
+				<div class="pre-content">
+					<up-input v-model="memberInfo.idcard" border="none" style="font-size: 30rpx;color: #252525;" placeholder="请输入身份证"></up-input>
+				</div>
+			</div>
+			<div class="pre adfac">
+				<div class="pre-title"><span style="color: #FFFFFF;">*</span>义工号</div>
+				<div class="pre-content">
+					<up-input v-model="memberInfo.workNo" border="none" style="font-size: 30rpx;color: #252525;" placeholder="请输入义工号"></up-input>
+				</div>
+			</div>
+			<div class="pre adfac">
+				<div class="pre-title"><span>*</span>性别</div>
+				<div class="pre-content adfac">
+					<div class="pre-content-box adfac" @tap="changeMember(1,'sex')">
+						<image v-if="memberInfo.sex==1" src="https://transcend.ringzle.com/xiaozhi-app/profile/2025/10/09/9efae012-a9fd-4a0d-9e14-7ec90001e712.png"></image>
+						<image v-else src="https://transcend.ringzle.com/xiaozhi-app/profile/2025/10/09/5ae64305-d1e0-4ffe-8dc0-f9d3704ac370.png"></image>
+						<text>男</text>
+					</div>
+					<div class="pre-content-box adfac" @tap="changeMember(2,'sex')">
+						<image v-if="memberInfo.sex==2" src="https://transcend.ringzle.com/xiaozhi-app/profile/2025/10/09/9efae012-a9fd-4a0d-9e14-7ec90001e712.png"></image>
+						<image v-else src="https://transcend.ringzle.com/xiaozhi-app/profile/2025/10/09/5ae64305-d1e0-4ffe-8dc0-f9d3704ac370.png"></image>
+						<text>女</text>
+					</div>
+				</div>
+			</div>
+			<div class="pre adfac" v-if="memberInfo.type==2">
+				<div class="pre-title"><span>*</span>就读学校</div>
+				<div class="pre-content">
+					<up-input v-model="memberInfo.school" border="none" style="font-size: 30rpx;color: #252525;" placeholder="请输入就读学校"></up-input>
+				</div>
+			</div>
+		</div>
+		<div class="btn" @tap="handleSave">保存</div>
+	</view>
+</template>
+
+<script setup name="">
+	import CusHeader from '@/components/CusHeader/index.vue'
+	import { onLoad } from '@dcloudio/uni-app';
+	import { ref, getCurrentInstance } from 'vue'
+	const { proxy } = getCurrentInstance()
+	
+	const title = ref('添加报名人员')
+	const memberInfo = ref({
+		type:1,
+		name:'',
+		idcard:'',
+		workNo:'',
+		sex:1,
+		school:''
+	})
+	
+	const changeMember = (value,key) => {
+		memberInfo.value[key] = value;
+	}
+	
+	const handleSave = () => {
+		if(!memberInfo.value.type) return proxy.$showToast('请选择人员类型')
+		if(!memberInfo.value.name) return proxy.$showToast('请输入姓名')
+		if(!proxy.$reg.idCard(memberInfo.value.idcard)) return proxy.$showToast('请输入正确的身份证号')
+		if(!memberInfo.value.sex) return proxy.$showToast('请选择性别')
+		if(!memberInfo.value.school&&memberInfo.value.type==2) return proxy.$showToast('请输入就读学校')
+		console.log(memberInfo.value);
+	}
+	
+	onLoad((options)=>{
+		if (options.member) {
+			try {
+				const memberObject = JSON.parse(decodeURIComponent(options.member));
+				console.log('成功解析的 member 对象:', memberObject);
+				if(memberObject) title.value = '编辑报名人员';
+			} catch (e) {
+				console.error('解析 member 参数失败:', e);
+			}
+		} else {
+			console.warn('未在URL中找到 member 参数');
+		}
+	})
+</script>
+
+<style scoped lang="scss">
+	.common_page{
+		padding-bottom: 184rpx;
+		
+		.form{
+			background: #FFFFFF;
+			border-radius: 24rpx;
+			margin-top: 20rpx;
+			padding: 36rpx 24rpx 0;
+			
+			.title{
+				font-family: PingFang-SC, PingFang-SC;
+				font-weight: bold;
+				font-size: 36rpx;
+				color: #151B29;
+				line-height: 48rpx;
+			}
+		
+			.pre{
+				padding: 25rpx 0;
+				box-shadow: inset 0rpx -1rpx 0rpx 0rpx #F2F2F2;
+				&-title{
+					width: 209rpx;
+					font-family: PingFangSC, PingFang SC;
+					font-weight: 400;
+					font-size: 28rpx;
+					color: #676775;
+					line-height: 40rpx;
+					label{
+						font-family: PingFangSC, PingFang SC;
+						font-weight: 400;
+						font-size: 30rpx;
+						color: #F4657A;
+						line-height: 42rpx;
+						margin-right: 4rpx;
+					}
+				}
+				&-content{
+					width: calc(100% - 209rpx);
+					&-box{
+						width: 184rpx;
+						image{
+							width: 28rpx;
+							height: 28rpx;
+						}
+						text{
+							font-family: PingFangSC, PingFang SC;
+							font-weight: 400;
+							font-size: 30rpx;
+							color: #252525;
+							line-height: 42rpx;
+							margin-left: 16rpx;
+						}
+					}
+				}
+			}
+		}
+		
+		.btn{
+			width: calc(100% - 80rpx);
+			height: 90rpx;
+			background: #B7F358;
+			border-radius: 45rpx;
+			font-family: PingFang-SC, PingFang-SC;
+			font-weight: bold;
+			font-size: 32rpx;
+			color: #151B29;
+			line-height: 90rpx;
+			text-align: center;
+			letter-spacing: 2rpx;
+			position: fixed;
+			left: 40rpx;
+			bottom: 64rpx;
+		}
+	}
+</style>

+ 68 - 0
pagesHome/applyResult.vue

@@ -0,0 +1,68 @@
+<template>
+	<view class="common_page adffcac" :style="{'height':h+'px', 'padding-top':mt+'px'}">
+		<cus-header title="报名结果" bgColor="#FFFFFF"></cus-header>
+		<image src="https://transcend.ringzle.com/xiaozhi-app/profile/2025/10/10/27e14800-8f8f-4ebc-a8cb-77401a627225.png"></image>
+		<div class="title">报名成功</div>
+		<div class="tip">您可去我的公益里查看活动进度及详情~</div>
+		<div class="btns adfacjb">
+			<div class="btn adfacjc" @click="handleTurn('/pages/nonprofit')">我的公益</div>
+			<div class="btn adfacjc home" @click="handleTurn('/pages/home')">返回首页</div>
+		</div>
+	</view>
+</template>
+
+<script setup name="">
+	import CusHeader from '@/components/CusHeader/index.vue'
+	import { ref } from 'vue'
+	
+	const handleTurn = (url) => {
+		uni.reLaunch({ url })
+	}
+</script>
+
+<style scoped lang="scss">
+	.common_page{
+		padding: 0 30rpx 40rpx;
+		background: #FFFFFF;
+		image{
+			width: 226rpx;
+			height: 201rpx;
+			margin-top: 44rpx;
+		}
+		.title{
+			font-family: PingFang-SC, PingFang-SC;
+			font-weight: bold;
+			font-size: 40rpx;
+			color: #151B29;
+			line-height: 56rpx;
+			margin-top: 30rpx;
+		}
+		.tip{
+			font-family: PingFangSC, PingFang SC;
+			font-weight: 400;
+			font-size: 28rpx;
+			color: #676775;
+			line-height: 40rpx;
+			margin-top: 20rpx;
+		}
+		.btns{
+			width: 100%;
+			margin-top: 210rpx;
+			.btn{
+				width: calc(50% - 15rpx);
+				height: 90rpx;
+				border-radius: 45rpx;
+				border: 1rpx solid #252525;
+				font-family: PingFang-SC, PingFang-SC;
+				font-weight: bold;
+				font-size: 32rpx;
+				color: #151B29;
+				line-height: 45rpx;
+				&.home{
+					background: #B7F358;
+					border: 1rpx solid #B7F358;
+				}
+			}
+		}
+	}
+</style>

+ 176 - 0
pagesHome/fillNonprofitArchives.vue

@@ -0,0 +1,176 @@
+<template>
+	<view class="common_page" :style="{'min-height':h+'px', 'padding-top':mt+'px'}">
+		<cus-header title="填写公益档案" bgColor="transparent"></cus-header>
+		<image src="https://transcend.ringzle.com/xiaozhi-app/profile/2025/09/19/54b75bc8-d926-449b-95a5-1126f700b481.png" class="top_bg_img" mode="widthFix"></image>
+		<div class="box">
+			<div class="box-title">活动信息</div>
+			<div class="box-pre adf">
+				<div class="box-pre-left">活动名称</div>
+				<div class="box-pre-right">{{'让孩子成为小小自然守护者'}}</div>
+			</div>
+			<div class="box-pre adf">
+				<div class="box-pre-left">学生姓名</div>
+				<div class="box-pre-right">{{'周飒然'}}</div>
+			</div>
+			<div class="box-pre adf">
+				<div class="box-pre-left">参与时间</div>
+				<div class="box-pre-right">{{'2025年7月30日'}}</div>
+			</div>
+			<div class="box-pre adf">
+				<div class="box-pre-left">公益支持</div>
+				<div class="box-pre-right">{{'种植沙漠沙沙树2棵'}}</div>
+			</div>
+		</div>
+		<div class="box">
+			<div class="box-title">活动心得</div>
+			<up-textarea v-model="xxx" placeholder="请分享参加公益活动心得,至少输入10个字~" count border="none" style="height: 250rpx;margin-top: 28rpx;padding: 0;font-size: 26rpx;color: #252525;"></up-textarea>
+		</div>
+		<div class="box">
+			<div class="box-title">活动照片<text>(分享活动照片)</text></div>
+			<div class="box-img">
+				<up-upload
+					:fileList="fileList"
+					@afterRead="afterRead"
+					@delete="deletePic"
+					multiple
+					:maxCount="3"
+					width="160rpx"
+					height="160rpx"
+				>
+					<image src="https://transcend.ringzle.com/xiaozhi-app/profile/2025/09/29/b04d6b0e-0d30-4043-a2b1-d639e15e2aac.png" 
+					mode="widthFix" style="width: 160rpx;height: 160rpx;"></image>
+				</up-upload>
+			</div>
+		</div>
+		<div class="btn" @click="handleSubmit">提交</div>
+	</view>
+</template>
+
+<script setup name="">
+	import CusHeader from '@/components/CusHeader/index.vue'
+	import { ref } from 'vue'
+	
+	const xxx = ref('')
+	const fileList = ref([])
+	
+	const deletePic = (event) => {
+	  fileList.value.splice(event.index, 1);
+	};
+	
+	// 新增图片
+	const afterRead = async (event) => {
+	  let lists = [].concat(event.file);
+	  let fileListLen = fileList.value.length;
+	  lists.map((item) => {
+	    fileList.value.push({
+	      ...item,
+	      status: 'uploading',
+	      message: '上传中',
+	    });
+	  });
+	  for (let i = 0; i < lists.length; i++) {
+	    const result = await uploadFilePromise(lists[i].url);
+	    let item = fileList.value[fileListLen];
+	    fileList.value.splice(fileListLen, 1, {
+	      ...item,
+	      status: 'success',
+	      message: '',
+	      url: result,
+	    });
+	    fileListLen++;
+	  }
+	};
+	
+	const uploadFilePromise = (url) => {
+	  return new Promise((resolve, reject) => {
+	    let a = uni.uploadFile({
+	      url: 'http://192.168.2.21:7001/upload', // 仅为示例,非真实的接口地址
+	      filePath: url,
+	      name: 'file',
+	      formData: {
+	        user: 'test',
+	      },
+	      success: (res) => {
+	        setTimeout(() => {
+	          resolve(res.data.data);
+	        }, 1000);
+	      },
+	    });
+	  });
+	};
+	
+	const handleSubmit = () => {
+		uni.navigateTo({
+			url:'/pagesHome/fillNonprofitResult'
+		})
+	}
+</script>
+
+<style scoped lang="scss">
+	.common_page{
+		padding-bottom: 64rpx;
+		
+		.box{
+			background: #FFFFFF;
+			border-radius: 24rpx;
+			margin-top: 20rpx;
+			padding: 36rpx 24rpx;
+			position: relative;
+			
+			&-title{
+				font-family: PingFang-SC, PingFang-SC;
+				font-weight: bold;
+				font-size: 36rpx;
+				color: #151B29;
+				line-height: 48rpx;
+				text{
+					font-weight: 400;
+					font-size: 26rpx;
+					color: #B2B2B2;
+					line-height: 37rpx;
+					margin-left: 16rpx;
+				}
+			}
+			
+			&-pre{
+				margin-top: 35rpx;
+				&-left{
+					width: 160rpx;
+					font-family: PingFangSC, PingFang SC;
+					font-weight: 400;
+					font-size: 28rpx;
+					color: #676775;
+					line-height: 30rpx;
+					text-align: left;
+				}
+				&-right{
+					width: calc(100% - 160rpx);
+					font-family: PingFangSC, PingFang SC;
+					font-weight: 400;
+					font-size: 30rpx;
+					color: #252525;
+					line-height: 30rpx;
+				}
+			}
+			
+			&-img{
+				margin-top: 47rpx;
+			}
+		}
+		
+		.btn{
+			width: calc(100% - 32rpx);
+			height: 90rpx;
+			background: #B7F358;
+			border-radius: 45rpx;
+			font-family: PingFang-SC, PingFang-SC;
+			font-weight: bold;
+			font-size: 32rpx;
+			color: #151B29;
+			line-height: 90rpx;
+			text-align: center;
+			letter-spacing: 2rpx;
+			margin: 40rpx auto 0;
+		}
+	}
+</style>

+ 68 - 0
pagesHome/fillNonprofitResult.vue

@@ -0,0 +1,68 @@
+<template>
+	<view class="common_page adffcac" :style="{'height':h+'px', 'padding-top':mt+'px'}">
+		<cus-header title="填写公益档案" bgColor="#FFFFFF"></cus-header>
+		<image src="https://transcend.ringzle.com/xiaozhi-app/profile/2025/10/10/27e14800-8f8f-4ebc-a8cb-77401a627225.png"></image>
+		<div class="title">公益档案提交成功</div>
+		<div class="tip">您可去我的公益里查看活动进度及详情~</div>
+		<div class="btns adfacjb">
+			<div class="btn adfacjc" @click="handleTurn('/pages/nonprofit')">我的公益</div>
+			<div class="btn adfacjc home" @click="handleTurn('/pages/home')">返回首页</div>
+		</div>
+	</view>
+</template>
+
+<script setup name="">
+	import CusHeader from '@/components/CusHeader/index.vue'
+	import { ref } from 'vue'
+	
+	const handleTurn = (url) => {
+		uni.reLaunch({ url })
+	}
+</script>
+
+<style scoped lang="scss">
+	.common_page{
+		padding: 0 30rpx 40rpx;
+		background: #FFFFFF;
+		image{
+			width: 226rpx;
+			height: 201rpx;
+			margin-top: 44rpx;
+		}
+		.title{
+			font-family: PingFang-SC, PingFang-SC;
+			font-weight: bold;
+			font-size: 40rpx;
+			color: #151B29;
+			line-height: 56rpx;
+			margin-top: 30rpx;
+		}
+		.tip{
+			font-family: PingFangSC, PingFang SC;
+			font-weight: 400;
+			font-size: 28rpx;
+			color: #676775;
+			line-height: 40rpx;
+			margin-top: 20rpx;
+		}
+		.btns{
+			width: 100%;
+			margin-top: 210rpx;
+			.btn{
+				width: calc(50% - 15rpx);
+				height: 90rpx;
+				border-radius: 45rpx;
+				border: 1rpx solid #252525;
+				font-family: PingFang-SC, PingFang-SC;
+				font-weight: bold;
+				font-size: 32rpx;
+				color: #151B29;
+				line-height: 45rpx;
+				&.home{
+					background: #B7F358;
+					border: 1rpx solid #B7F358;
+				}
+			}
+		}
+	}
+</style>

+ 106 - 0
pagesHome/recruitsNumber.vue

@@ -0,0 +1,106 @@
+<template>
+	<view class="common_page adffc" :style="{'height':h+'px', 'padding-top':mt+'px'}">
+		<cus-header title="招募人数" bgColor="#FFFFFF"></cus-header>
+		<div class="box num">
+			<div class="num-pre">招募人数<text>{{50}}人</text></div>
+			<div class="num-pre line">已报名<text>{{35}}人</text></div>
+			<div class="num-pre">最少报名人数<text>{{40}}人</text></div>
+		</div>
+		<div class="box list" v-if="list.length">
+			<div class="list-pre adfacjb" v-for="(item,index) in list" :key="index">
+				<div class="list-pre-left adfac">
+					<image src="https://transcend.ringzle.com/xiaozhi-app/profile/2025/10/10/a56db26d-4149-4f6a-8272-2c3d4af0a6a8.png"></image>
+					<text>{{'张**'}}</text>
+				</div>
+				<div class="list-pre-right">{{'2025-07-17 09:35:01'}}</div>
+			</div>
+		</div>
+		<div class="empty adffcacjc" v-else>
+			暂无善行少年报名<br>期待您的参与
+		</div>
+	</view>
+</template>
+
+<script setup name="">
+	import CusHeader from '@/components/CusHeader/index.vue'
+	import { ref } from 'vue'
+	
+	const list = ref([1,1,1])
+</script>
+
+<style scoped lang="scss">
+	.common_page{
+		.box{
+			margin-top: 20rpx;
+			background: #FFFFFF;
+			border-radius: 24rpx;
+		}
+		
+		.num{
+			padding: 6rpx 24rpx 30rpx;
+			display: flex;
+			flex-wrap: wrap;
+			&-pre{
+				width: 50%;
+				margin-top: 24rpx;
+				font-family: PingFangSC, PingFang SC;
+				font-weight: 400;
+				font-size: 30rpx;
+				color: #676775;
+				line-height: 42rpx;
+				&.line{
+					border-left: 1rpx solid #E5E0E0;
+					padding-left: 40rpx;
+					box-sizing: border-box;
+				}
+				text{
+					font-weight: bold;
+					color: #176892;
+					margin-left: 24rpx;
+				}
+			}
+		}
+	
+		.list{
+			padding: 0 24rpx;
+			flex: 1;
+			overflow: auto;
+			&-pre{
+				padding: 32rpx 0;
+				box-shadow: inset 0rpx -1rpx 0rpx 0rpx #F2F2F2;
+				&-left{
+					image{
+						width: 64rpx;
+						height: 64rpx;
+					}
+					text{
+						font-family: PingFang-SC, PingFang-SC;
+						font-weight: bold;
+						font-size: 30rpx;
+						color: #252525;
+						line-height: 42rpx;
+						margin-left: 30rpx;
+					}
+				}
+				&-right{
+					font-family: PingFangSC, PingFang SC;
+					font-weight: 400;
+					font-size: 28rpx;
+					color: #676775;
+					line-height: 40rpx;
+					text-align: right;
+				}
+			}
+		}
+	
+		.empty{
+			flex: 1;
+			font-family: PingFangSC, PingFang SC;
+			font-weight: 400;
+			font-size: 30rpx;
+			color: #252525;
+			line-height: 42rpx;
+			text-align: center;
+		}
+	}
+</style>

+ 60 - 0
pagesHome/signSuccess.vue

@@ -0,0 +1,60 @@
+<template>
+	<view class="common_page adffcac" :style="{'height':h+'px', 'padding-top':mt+'px'}">
+		<cus-header title="签到成功" bgColor="#FFFFFF"></cus-header>
+		<image src="https://transcend.ringzle.com/xiaozhi-app/profile/2025/10/10/27e14800-8f8f-4ebc-a8cb-77401a627225.png"></image>
+		<div class="title">签到成功</div>
+		<div class="tip">快去参加活动吧~</div>
+		<div class="btn" @click="handleTurn('/pages/home')">返回首页</div>
+	</view>
+</template>
+
+<script setup name="">
+	import CusHeader from '@/components/CusHeader/index.vue'
+	import { ref } from 'vue'
+	
+	const handleTurn = (url) => {
+		uni.reLaunch({ url })
+	}
+</script>
+
+<style scoped lang="scss">
+	.common_page{
+		padding: 0 30rpx 40rpx;
+		background: #FFFFFF;
+		image{
+			width: 226rpx;
+			height: 201rpx;
+			margin-top: 44rpx;
+		}
+		.title{
+			font-family: PingFang-SC, PingFang-SC;
+			font-weight: bold;
+			font-size: 40rpx;
+			color: #151B29;
+			line-height: 56rpx;
+			margin-top: 30rpx;
+		}
+		.tip{
+			font-family: PingFangSC, PingFang SC;
+			font-weight: 400;
+			font-size: 28rpx;
+			color: #676775;
+			line-height: 40rpx;
+			margin-top: 20rpx;
+		}
+		.btn{
+			width: 100%;
+			height: 90rpx;
+			border-radius: 45rpx;
+			background: #B7F358;
+			font-family: PingFang-SC, PingFang-SC;
+			font-weight: bold;
+			font-size: 32rpx;
+			color: #151B29;
+			line-height: 90rpx;
+			text-align: center;
+			margin-top: 100rpx;
+			letter-spacing: 2rpx;
+		}
+	}
+</style>

+ 1 - 1
pagesMy/familyMember.vue

@@ -4,7 +4,7 @@
 		<div class="add">
 			<div class="btn adfacjc" @tap="handleAdd">
 				<image src="https://transcend.ringzle.com/xiaozhi-app/profile/2025/10/09/af9133fd-e15e-454d-9152-e4629fd0ce28.png"></image>
-				<text>新增家庭成员</text>
+				<text>添加</text>
 			</div>
 		</div>
 		<template v-if="list.length">