553 lines
13 KiB
Vue
553 lines
13 KiB
Vue
<!-- 业主认证表单页 -->
|
||
<template>
|
||
<s-layout title="业主认证">
|
||
<view class="auth-page">
|
||
<scroll-view scroll-y class="form-scroll">
|
||
<!-- 小区名称 -->
|
||
<view class="form-item">
|
||
<text class="form-label">小区名称</text>
|
||
<view class="form-value">
|
||
<text class="value-text">融侨馨苑</text>
|
||
<image class="arrow-icon" src="/static/img/right-icon-black.png" mode="aspectFit" />
|
||
</view>
|
||
</view>
|
||
|
||
<!-- 序号:楼号/单元/号 -->
|
||
<view class="form-item form-row">
|
||
<text class="form-label">序号</text>
|
||
<view class="row-inputs">
|
||
<view class="col-item">
|
||
<input class="col-input" v-model="state.form.building" />
|
||
<text class="col-label">号楼</text>
|
||
</view>
|
||
<view class="col-item">
|
||
<input class="col-input" v-model="state.form.unit" />
|
||
<text class="col-label">单元</text>
|
||
</view>
|
||
<view class="col-item">
|
||
<input class="col-input" v-model="state.form.room" />
|
||
<text class="col-label">号</text>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
|
||
<!-- 是否产权人 -->
|
||
<view class="form-item">
|
||
<text class="form-label">是否产权人</text>
|
||
<view class="checkbox-group">
|
||
<label class="checkbox-item" @tap="state.form.isOwner = true">
|
||
<view :class="['checkbox-box', { active: state.form.isOwner }]">
|
||
<text v-if="state.form.isOwner" class="check-mark">✓</text>
|
||
</view>
|
||
<text class="checkbox-text">是</text>
|
||
</label>
|
||
<label class="checkbox-item" @tap="state.form.isOwner = false">
|
||
<view :class="['checkbox-box', { active: !state.form.isOwner && state.form.isOwner !== null }]">
|
||
<text v-if="!state.form.isOwner && state.form.isOwner !== null" class="check-mark">✓</text>
|
||
</view>
|
||
<text class="checkbox-text">否</text>
|
||
</label>
|
||
</view>
|
||
</view>
|
||
|
||
<!-- 与产权人关系 -->
|
||
<view class="form-item">
|
||
<text class="form-label">与产权人关系</text>
|
||
<view class="form-value" @tap="showRelationPicker">
|
||
<text class="value-text placeholder-color">{{ state.form.relation || '请输入' }}</text>
|
||
<image class="arrow-icon" src="/static/img/right-icon-black.png" mode="aspectFit" />
|
||
</view>
|
||
</view>
|
||
|
||
<!-- 姓名 -->
|
||
<view class="form-item">
|
||
<text class="form-label">姓名</text>
|
||
<view class="form-value">
|
||
<input
|
||
v-model="state.form.name"
|
||
class="form-input"
|
||
placeholder="请输入姓名"
|
||
placeholder-class="placeholder"
|
||
placeholder-style="color: #333333"
|
||
/>
|
||
<image class="arrow-icon" src="/static/img/right-icon-black.png" mode="aspectFit" />
|
||
</view>
|
||
</view>
|
||
|
||
<!-- 手机号 -->
|
||
<view class="form-item">
|
||
<text class="form-label">手机号</text>
|
||
<view class="form-value">
|
||
<input
|
||
v-model="state.form.phone"
|
||
class="form-input"
|
||
type="number"
|
||
maxlength="11"
|
||
placeholder="请输入手机号"
|
||
placeholder-class="placeholder"
|
||
placeholder-style="color: #333333"
|
||
/>
|
||
<image class="arrow-icon" src="/static/img/right-icon-black.png" mode="aspectFit" />
|
||
</view>
|
||
</view>
|
||
|
||
<!-- 证件类型 -->
|
||
<view class="form-item">
|
||
<text class="form-label">证件类型</text>
|
||
<view class="form-value" @tap="showIdTypePicker">
|
||
<text class="value-text placeholder-color">{{ state.form.idType || '请选择证件类型' }}</text>
|
||
<image class="arrow-icon" src="/static/img/right-icon-black.png" mode="aspectFit" />
|
||
</view>
|
||
</view>
|
||
|
||
<!-- 证件号 -->
|
||
<view class="form-item">
|
||
<text class="form-label">证件号</text>
|
||
<view class="form-value">
|
||
<input
|
||
v-model="state.form.idNumber"
|
||
class="form-input"
|
||
placeholder="请输入证件号"
|
||
placeholder-class="placeholder"
|
||
placeholder-style="color: #333333"
|
||
/>
|
||
<image class="arrow-icon" src="/static/img/right-icon-black.png" mode="aspectFit" />
|
||
</view>
|
||
</view>
|
||
|
||
<!-- 性别 -->
|
||
<view class="form-item">
|
||
<text class="form-label">性别</text>
|
||
<view class="form-value" @tap="showGenderPicker">
|
||
<text class="value-text placeholder-color">{{ state.form.gender || '请选择' }}</text>
|
||
<image class="arrow-icon" src="/static/img/right-icon-black.png" mode="aspectFit" />
|
||
</view>
|
||
</view>
|
||
|
||
<!-- 出生日期 -->
|
||
<view class="form-item">
|
||
<text class="form-label">出生日期</text>
|
||
<view class="form-value" @click="triggerDatePicker">
|
||
<uni-datetime-picker
|
||
ref="datePickerRef"
|
||
v-model="state.form.birthday"
|
||
type="date"
|
||
:border="false"
|
||
@change="onDateChange"
|
||
class="form-date"
|
||
/>
|
||
<image class="arrow-icon" src="/static/img/right-icon-black.png" mode="aspectFit" />
|
||
</view>
|
||
</view>
|
||
|
||
<!-- 上传附件 -->
|
||
<view class="form-section-title">
|
||
<text>上传附件</text>
|
||
</view>
|
||
<view class="upload-area">
|
||
<view class="upload-btn" @tap="handleUpload">
|
||
<view class="upload-icon-wrapper">
|
||
<text class="upload-folder-icon">📁</text>
|
||
</view>
|
||
<text class="upload-text">选择文件</text>
|
||
</view>
|
||
</view>
|
||
</scroll-view>
|
||
|
||
<!-- 底部按钮 -->
|
||
<view class="bottom-btn-wrapper">
|
||
<button class="submit-btn" @tap="handleSubmit">下一步</button>
|
||
</view>
|
||
</view>
|
||
</s-layout>
|
||
</template>
|
||
|
||
<script setup>
|
||
import { reactive, ref } from 'vue';
|
||
|
||
// 表单数据
|
||
const state = reactive({
|
||
form: {
|
||
community: '融侨馨苑',
|
||
building: '',
|
||
unit: '',
|
||
room: '',
|
||
isOwner: true,
|
||
relation: '',
|
||
name: '',
|
||
phone: '',
|
||
idType: '',
|
||
idNumber: '',
|
||
gender: '',
|
||
birthday: ''
|
||
}
|
||
});
|
||
|
||
// 显示关系选择器
|
||
const showRelationPicker = () => {
|
||
uni.showActionSheet({
|
||
itemList: ['本人', '配偶', '父母', '子女', '其他'],
|
||
success: (res) => {
|
||
const relations = ['本人', '配偶', '父母', '子女', '其他'];
|
||
state.form.relation = relations[res.tapIndex];
|
||
}
|
||
});
|
||
};
|
||
|
||
// 显示证件类型选择器
|
||
const showIdTypePicker = () => {
|
||
uni.showActionSheet({
|
||
itemList: ['身份证', '护照', '军官证', '港澳通行证'],
|
||
success: (res) => {
|
||
const types = ['身份证', '护照', '军官证', '港澳通行证'];
|
||
state.form.idType = types[res.tapIndex];
|
||
}
|
||
});
|
||
};
|
||
|
||
// 显示性别选择器
|
||
const showGenderPicker = () => {
|
||
uni.showActionSheet({
|
||
itemList: ['男', '女'],
|
||
success: (res) => {
|
||
state.form.gender = res.tapIndex === 0 ? '男' : '女';
|
||
}
|
||
});
|
||
};
|
||
|
||
// 日期选择回调
|
||
const onDateChange = (e) => {
|
||
console.log('选择的日期:', e);
|
||
};
|
||
|
||
// 点击整行触发日期选择器
|
||
const datePickerRef = ref(null);
|
||
const triggerDatePicker = () => {
|
||
if (datePickerRef.value) {
|
||
// uni-datetime-picker 内部有 show 方法可以打开弹窗
|
||
const picker = datePickerRef.value.$children?.[0] || datePickerRef.value;
|
||
if (picker.show) {
|
||
picker.show();
|
||
}
|
||
}
|
||
};
|
||
|
||
// 上传附件
|
||
const handleUpload = () => {
|
||
uni.chooseMessageFile({
|
||
count: 1,
|
||
type: 'file',
|
||
success: (res) => {
|
||
console.log('选择文件:', res.tempFiles[0]);
|
||
}
|
||
});
|
||
};
|
||
|
||
// 提交表单
|
||
const handleSubmit = () => {
|
||
console.log('提交表单:', state.form);
|
||
|
||
// 跳转到提交成功页
|
||
uni.redirectTo({
|
||
url: '/pages/index/auth-success'
|
||
});
|
||
};
|
||
</script>
|
||
|
||
<style lang="scss" scoped>
|
||
/* 页面容器 */
|
||
.auth-page {
|
||
background-color: #F5F5F5;
|
||
}
|
||
|
||
/* 表单滚动区域 */
|
||
.form-scroll {
|
||
height: calc(100vh - 176rpx - 250rpx);
|
||
padding-top: 20rpx;
|
||
}
|
||
|
||
/* 表单项 - 上下结构 */
|
||
.form-item {
|
||
background-color: #FFFFFF;
|
||
padding: 24rpx 32rpx;
|
||
display: flex;
|
||
flex-direction: column;
|
||
border-bottom: 1rpx solid #F0F0F0;
|
||
}
|
||
|
||
/* 标签文字 - 上方 */
|
||
.form-label {
|
||
font-size: 28rpx;
|
||
color: #333333;
|
||
font-weight: 500;
|
||
margin-bottom: 16rpx;
|
||
}
|
||
|
||
/* 值区域 - 下方 */
|
||
.form-value {
|
||
display: flex;
|
||
align-items: center;
|
||
|
||
.value-text {
|
||
font-size: 28rpx;
|
||
flex: 1;
|
||
|
||
// 已选中值:深色加粗
|
||
&:not(.placeholder-color) {
|
||
color: #222222;
|
||
font-weight: 600;
|
||
}
|
||
}
|
||
|
||
.placeholder-color {
|
||
color: #666666;
|
||
}
|
||
|
||
.form-input {
|
||
flex: 1;
|
||
font-size: 28rpx;
|
||
color: #666666;
|
||
}
|
||
|
||
.form-date{
|
||
width:100%;
|
||
}
|
||
|
||
.arrow-icon, .calendar-icon {
|
||
width: 24rpx;
|
||
height: 24rpx;
|
||
opacity: 0.4;
|
||
}
|
||
|
||
.calendar-icon {
|
||
opacity: 0.6;
|
||
}
|
||
|
||
/* 右侧箭头图标(日期字段用) */
|
||
.date-arrow-icon {
|
||
width: 24rpx;
|
||
height: 24rpx;
|
||
opacity: 0.4;
|
||
flex-shrink: 0;
|
||
margin-left: 8rpx;
|
||
}
|
||
}
|
||
|
||
/* 占位符样式 */
|
||
:deep(.placeholder) {
|
||
color: #666666 !important;
|
||
}
|
||
|
||
/* 日期选择器 - 融入表单整体风格 + 橙色主题 */
|
||
.form-value {
|
||
:deep(.uni-date-editor--x) {
|
||
padding: 0 !important;
|
||
border: none !important;
|
||
background: transparent !important;
|
||
}
|
||
|
||
:deep(.uni-date-x) {
|
||
border: none !important;
|
||
justify-content: flex-start !important;
|
||
background: transparent !important;
|
||
padding: 0 !important;
|
||
}
|
||
|
||
:deep(.uni-date__x-input) {
|
||
font-size: 28rpx !important;
|
||
color: #333333 !important;
|
||
padding-left: 0 !important;
|
||
background: transparent !important;
|
||
|
||
&::placeholder {
|
||
color: #CCCCCC !important;
|
||
}
|
||
}
|
||
|
||
/* 隐藏日历图标、清除图标 */
|
||
:deep(.uni-icons),
|
||
:deep(.uni-date__icon-clear) {
|
||
display: none !important;
|
||
}
|
||
}
|
||
|
||
/* 全局覆盖 datetime-picker 弹窗橙色主题 */
|
||
:deep(.uni-datetime-picker--btn) {
|
||
background-color: #FF6B35 !important;
|
||
}
|
||
|
||
/* 选中日期 - 蓝色圆圈 → 橙色 */
|
||
:deep(.uni-calendar-item--checked) {
|
||
background-color: #FF6B35 !important;
|
||
border-color: #fff !important;
|
||
}
|
||
|
||
/* 今天标记点 - 红色 → 橙色 */
|
||
:deep(.uni-calendar-item--isDay) {
|
||
background-color: #FF6B35 !important;
|
||
}
|
||
|
||
/* 范围选中的起止日期 */
|
||
:deep(.uni-calendar-item--before-checked),
|
||
:deep(.uni-calendar-item--after-checked) {
|
||
background-color: #FF6B35 !important;
|
||
}
|
||
|
||
/* 序号行 - 三列:文字和输入框同行 */
|
||
.form-row {
|
||
.row-inputs {
|
||
display: flex;
|
||
align-items: center;
|
||
|
||
.col-item {
|
||
display: flex;
|
||
align-items: center;
|
||
margin-right: 24rpx;
|
||
flex:1;
|
||
|
||
&:last-child {
|
||
margin-right: 0;
|
||
}
|
||
|
||
.col-label {
|
||
font-size: 26rpx;
|
||
color: #666666;
|
||
margin-left: 8rpx;
|
||
}
|
||
|
||
.col-input {
|
||
font-size: 28rpx;
|
||
color: #333333;
|
||
width: 100rpx;
|
||
padding-bottom: 8rpx;
|
||
border-bottom: 1rpx solid #E5E5E5;
|
||
flex:1;
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
/* 单选 - checkbox方框样式 */
|
||
.checkbox-group {
|
||
display: flex;
|
||
align-items: center;
|
||
gap: 48rpx;
|
||
|
||
.checkbox-item {
|
||
display: flex;
|
||
align-items: center;
|
||
margin-right:80rpx;
|
||
|
||
.checkbox-box {
|
||
width: 36rpx;
|
||
height: 36rpx;
|
||
border-radius: 6rpx;
|
||
border: 2rpx solid #DDDDDD;
|
||
margin-right: 12rpx;
|
||
display: flex;
|
||
align-items: center;
|
||
justify-content: center;
|
||
transition: all 0.2s;
|
||
|
||
&.active {
|
||
background-color: #FF7B54;
|
||
border-color: #FF7B54;
|
||
|
||
.check-mark {
|
||
color: #FFFFFF;
|
||
font-size: 24rpx;
|
||
line-height: 1;
|
||
}
|
||
}
|
||
}
|
||
|
||
.checkbox-text {
|
||
font-size: 28rpx;
|
||
color: #666666;
|
||
}
|
||
}
|
||
}
|
||
|
||
/* 区块标题 */
|
||
.form-section-title {
|
||
padding: 32rpx 32rpx 20rpx;
|
||
|
||
text {
|
||
font-size: 28rpx;
|
||
color: #333333;
|
||
font-weight: 500;
|
||
}
|
||
}
|
||
|
||
/* 上传区域 */
|
||
.upload-area {
|
||
background-color: #FFFFFF;
|
||
padding: 32rpx;
|
||
|
||
.upload-btn {
|
||
width: 180rpx;
|
||
height: 180rpx;
|
||
border: 2rpx dashed #DDDDDD;
|
||
border-radius: 16rpx;
|
||
display: flex;
|
||
flex-direction: column;
|
||
align-items: center;
|
||
justify-content: center;
|
||
|
||
&:active {
|
||
border-color: #FF7B54;
|
||
background-color: rgba(255, 123, 84, 0.02);
|
||
}
|
||
|
||
.upload-icon-wrapper {
|
||
margin-bottom: 12rpx;
|
||
|
||
.upload-folder-icon {
|
||
font-size: 56rpx;
|
||
opacity: 0.4;
|
||
}
|
||
}
|
||
|
||
.upload-text {
|
||
font-size: 24rpx;
|
||
color: #999999;
|
||
}
|
||
}
|
||
}
|
||
|
||
/* 底部按钮 */
|
||
.bottom-btn-wrapper {
|
||
position: fixed;
|
||
left: 0;
|
||
right: 0;
|
||
bottom: 0;
|
||
padding: 24rpx 38rpx;
|
||
padding-bottom: calc(24rpx + env(safe-area-inset-bottom));
|
||
background-color: #F5F5F5;
|
||
|
||
.submit-btn {
|
||
width: 100%;
|
||
height: 96rpx;
|
||
background: linear-gradient(135deg, #FF8A65 0%, #FF6B35 100%);
|
||
border-radius: 48rpx;
|
||
border: none;
|
||
font-size: 32rpx;
|
||
font-weight: 500;
|
||
color: #FFFFFF;
|
||
display: flex;
|
||
align-items: center;
|
||
justify-content: center;
|
||
box-shadow: 0 8rpx 24rpx rgba(255, 107, 53, 0.3);
|
||
|
||
&::after {
|
||
border: none;
|
||
}
|
||
|
||
&:active {
|
||
opacity: 0.9;
|
||
transform: scale(0.98);
|
||
}
|
||
}
|
||
}
|
||
</style>
|