Compare commits
	
		
			No commits in common. "bad576f5f3573d3f1d15c9852d55e8807951392c" and "433c3af1ffe0b4096162860092f6479b10d59165" have entirely different histories.
		
	
	
		
			bad576f5f3
			...
			433c3af1ff
		
	
		
| @ -1,7 +1,7 @@ | |||||||
| <script setup> | <script setup> | ||||||
| import { useI18n } from 'vue-i18n' | import { useI18n } from 'vue-i18n' | ||||||
| import {message} from '@/components/x-message/useMessage.js' | /*import {message} from '@/components/x-message/useMessage.js' | ||||||
| // message.success('success') | message.success('success')*/ | ||||||
| useHead({ | useHead({ | ||||||
|   title: useI18n().t('appSetting.appName'), |   title: useI18n().t('appSetting.appName'), | ||||||
|   meta: [ |   meta: [ | ||||||
|  | |||||||
| @ -17,7 +17,7 @@ initData() | |||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
| <template> | <template> | ||||||
|  <div v-if="show"> |  <div> | ||||||
|    <van-tabbar  v-model="active" route placeholder fixed> |    <van-tabbar  v-model="active" route placeholder fixed> | ||||||
|      <van-tabbar-item replace to="/"> |      <van-tabbar-item replace to="/"> | ||||||
|        <span>{{ $t('tabbar.home') }}</span> |        <span>{{ $t('tabbar.home') }}</span> | ||||||
|  | |||||||
| @ -1,5 +1,5 @@ | |||||||
| <script setup> | <script setup> | ||||||
| import { useAppHeaderRouteNames as routeWhiteList } from '~/config' | import { useAppFooterRouteNames as routeWhiteList } from '~/config' | ||||||
| import { homeStore } from "@/stores/home/index.js"; | import { homeStore } from "@/stores/home/index.js"; | ||||||
| const { fullLive } = homeStore() | const { fullLive } = homeStore() | ||||||
| const route = useRoute() | const route = useRoute() | ||||||
|  | |||||||
| @ -1,3 +1,2 @@ | |||||||
| 
 | 
 | ||||||
| export const useAppFooterRouteNames= ['home', 'profile'] | export const useAppFooterRouteNames= ['home', 'profile'] | ||||||
| export const useAppHeaderRouteNames= ['home', 'profile','login'] |  | ||||||
|  | |||||||
| @ -3,69 +3,37 @@ import {ref, computed, watch} from 'vue'; | |||||||
| import pinyin from 'pinyin'; | import pinyin from 'pinyin'; | ||||||
| import countryCode from './data/index.js'; | import countryCode from './data/index.js'; | ||||||
| import { useI18n } from 'vue-i18n' | import { useI18n } from 'vue-i18n' | ||||||
| import { useRouter } from 'vue-router' | 
 | ||||||
| definePageMeta({ |  | ||||||
|   title: '国家地区', |  | ||||||
|   i18n: 'countryRegion.title', |  | ||||||
| }) |  | ||||||
| const router = useRouter() |  | ||||||
| const { t, locale } = useI18n() | const { t, locale } = useI18n() | ||||||
| const value = ref(''); | const value = ref(''); | ||||||
| const alphabet = [ | const alphabet = [ | ||||||
|   '#', |  | ||||||
|   'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', |   'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', | ||||||
|   'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z' |   'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z' | ||||||
| ]; | ]; | ||||||
| 
 | 
 | ||||||
| // 常用国家的代码列表 |  | ||||||
| const frequentCountryCodes = ['CN', 'TW', 'JP', 'US']; |  | ||||||
| 
 |  | ||||||
| function groupByPinyinInitial(data) { | function groupByPinyinInitial(data) { | ||||||
|   const grouped = {}; |   const grouped = {}; | ||||||
|    |  | ||||||
|   // 先处理常用国家 |  | ||||||
|   grouped['#'] = []; |  | ||||||
|   data.forEach(country => { |   data.forEach(country => { | ||||||
|     if (frequentCountryCodes.includes(country.code)) { |     // 根据当前语言选择对应的国家名称 | ||||||
|       const countryName = locale.value === 'zh-CN' ? country.cn :  |     const countryName = locale.value === 'zh-CN' ? country.cn :  | ||||||
|                          locale.value === 'zh-TW' ? country.tw :  |                        locale.value === 'zh-TW' ? country.tw :  | ||||||
|                          locale.value === 'ja-JP' ? country.ja : |                        locale.value === 'ja-JP' ? country.ja : | ||||||
|                          country.en; |                        country.en; | ||||||
|       grouped['#'].push({ |                         | ||||||
|         ...country, |     const initial = locale.value === 'ja-JP' ? '' :  | ||||||
|         displayName: countryName |                    locale.value === 'zh-CN' || locale.value === 'zh-TW' ?  | ||||||
|       }); |                    pinyin(countryName, {style: pinyin.STYLE_FIRST_LETTER})[0][0].toUpperCase() : | ||||||
|  |                    countryName.charAt(0).toUpperCase(); | ||||||
|  |                     | ||||||
|  |     if (!grouped[initial]) { | ||||||
|  |       grouped[initial] = []; | ||||||
|     } |     } | ||||||
|  |     grouped[initial].push({ | ||||||
|  |       ...country, | ||||||
|  |       displayName: countryName | ||||||
|  |     }); | ||||||
|   }); |   }); | ||||||
| 
 | 
 | ||||||
|   // 处理其他国家 |  | ||||||
|   data.forEach(country => { |  | ||||||
|     if (!frequentCountryCodes.includes(country.code)) { |  | ||||||
|       const countryName = locale.value === 'zh-CN' ? country.cn :  |  | ||||||
|                          locale.value === 'zh-TW' ? country.tw :  |  | ||||||
|                          locale.value === 'ja-JP' ? country.ja : |  | ||||||
|                          country.en; |  | ||||||
|                           |  | ||||||
|       const initial = locale.value === 'ja-JP' ? '' :  |  | ||||||
|                      locale.value === 'zh-CN' || locale.value === 'zh-TW' ?  |  | ||||||
|                      pinyin(countryName, {style: pinyin.STYLE_FIRST_LETTER})[0][0].toUpperCase() : |  | ||||||
|                      countryName.charAt(0).toUpperCase(); |  | ||||||
|                       |  | ||||||
|       if (!grouped[initial]) { |  | ||||||
|         grouped[initial] = []; |  | ||||||
|       } |  | ||||||
|       grouped[initial].push({ |  | ||||||
|         ...country, |  | ||||||
|         displayName: countryName |  | ||||||
|       }); |  | ||||||
|     } |  | ||||||
|   }); |  | ||||||
| 
 |  | ||||||
|   if (locale.value === 'ja-JP') { |  | ||||||
|     // 日文环境下按照片假名排序 |  | ||||||
|     grouped[''] = grouped[''].sort((a, b) => a.displayName.localeCompare(b.displayName, 'ja-JP')); |  | ||||||
|   } |  | ||||||
| 
 |  | ||||||
|   return grouped; |   return grouped; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @ -91,16 +59,6 @@ const searchCountry = computed(() => { | |||||||
| 
 | 
 | ||||||
| const showIndexBar = computed(() => locale.value !== 'ja-JP') | const showIndexBar = computed(() => locale.value !== 'ja-JP') | ||||||
| 
 | 
 | ||||||
| const handleCountrySelect = (country) => { |  | ||||||
|   router.push({ |  | ||||||
|     path: '/login', |  | ||||||
|     query: { |  | ||||||
|       zone: country.zone, |  | ||||||
|       countryName: country.displayName |  | ||||||
|     } |  | ||||||
|   }) |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| initData() | initData() | ||||||
| 
 | 
 | ||||||
| // 监听语言变化,重新初始化数据 | // 监听语言变化,重新初始化数据 | ||||||
| @ -120,58 +78,20 @@ watch(locale, () => { | |||||||
|       :sticky-offset-top="55"   |       :sticky-offset-top="55"   | ||||||
|       :index-list="alphabet" |       :index-list="alphabet" | ||||||
|     > |     > | ||||||
|       <!-- 常用国家分类 --> |  | ||||||
|       <van-index-anchor index="#">{{ t('countryRegion.frequentCountry') }}</van-index-anchor> |  | ||||||
|       <van-cell  |  | ||||||
|         v-for="country in searchCountry['#']"  |  | ||||||
|         :key="country.code"  |  | ||||||
|         :title="country.displayName" |  | ||||||
|         @click="handleCountrySelect(country)" |  | ||||||
|         clickable |  | ||||||
|       > |  | ||||||
|         <div class="pr-[25px]"> +{{ country.zone }}</div> |  | ||||||
|       </van-cell> |  | ||||||
| 
 |  | ||||||
|       <!-- 其他国家按字母分类 --> |  | ||||||
|       <template v-for="(countries, index) in searchCountry" :key="index"> |       <template v-for="(countries, index) in searchCountry" :key="index"> | ||||||
|         <template v-if="index !== '#'"> |         <van-index-anchor | ||||||
|           <van-index-anchor |             :index="index" | ||||||
|               :index="index" |         ></van-index-anchor> | ||||||
|           ></van-index-anchor> |         <van-cell v-for="country in countries" :key="country.code" :title="country.displayName"> | ||||||
|           <van-cell  |           <div class="pr-[25px]"> +{{ country.zone }}</div> | ||||||
|             v-for="country in countries"  |         </van-cell> | ||||||
|             :key="country.code"  |  | ||||||
|             :title="country.displayName" |  | ||||||
|             @click="handleCountrySelect(country)" |  | ||||||
|             clickable |  | ||||||
|           > |  | ||||||
|             <div class="pr-[25px]"> +{{ country.zone }}</div> |  | ||||||
|           </van-cell> |  | ||||||
|         </template> |  | ||||||
|       </template> |       </template> | ||||||
|     </van-index-bar> |     </van-index-bar> | ||||||
| 
 | 
 | ||||||
|     <div v-else> |     <div v-else> | ||||||
|       <div class="mb-4"> |       <van-cell v-for="country in Object.values(searchCountry).flat()"  | ||||||
|         <div class="px-4 py-2 text-gray-600">{{ t('countryRegion.frequentCountry') }}</div> |                 :key="country.code"  | ||||||
|         <van-cell  |                 :title="country.displayName"> | ||||||
|           v-for="country in searchCountry['#']"  |  | ||||||
|           :key="country.code"  |  | ||||||
|           :title="country.displayName" |  | ||||||
|           @click="handleCountrySelect(country)" |  | ||||||
|           clickable |  | ||||||
|         > |  | ||||||
|           <div class="pr-[25px]"> +{{ country.zone }}</div> |  | ||||||
|         </van-cell> |  | ||||||
|       </div> |  | ||||||
| 
 |  | ||||||
|       <van-cell  |  | ||||||
|         v-for="country in Object.values(searchCountry).flat().filter(c => !frequentCountryCodes.includes(c.code))"  |  | ||||||
|         :key="country.code"  |  | ||||||
|         :title="country.displayName" |  | ||||||
|         @click="handleCountrySelect(country)" |  | ||||||
|         clickable |  | ||||||
|       > |  | ||||||
|         <div class="pr-[25px]"> +{{ country.zone }}</div> |         <div class="pr-[25px]"> +{{ country.zone }}</div> | ||||||
|       </van-cell> |       </van-cell> | ||||||
|     </div> |     </div> | ||||||
|  | |||||||
| @ -1,78 +1,16 @@ | |||||||
| <script setup> | <script setup> | ||||||
| import { useRouter, useRoute } from 'vue-router'; | import { useRouter } from 'vue-router'; | ||||||
| import { useI18n } from 'vue-i18n' |  | ||||||
| import countryCode from '../countryRegion/data/index.js' |  | ||||||
| 
 | 
 | ||||||
| const router = useRouter(); | const router = useRouter(); | ||||||
| const route = useRoute(); |  | ||||||
| const { locale } = useI18n() |  | ||||||
| 
 |  | ||||||
| definePageMeta({ | definePageMeta({ | ||||||
|   title: '登录', |   layout: 'login', | ||||||
|   i18n: 'login.title', |  | ||||||
| }) | }) | ||||||
| 
 |  | ||||||
| function goToPage() { | function goToPage() { | ||||||
|   router.push('/countryRegion'); |   router.push('/countryRegion'); | ||||||
| } | } | ||||||
| 
 | const phoneNum=ref('') | ||||||
| const phoneNum = ref('') | const code=ref('') | ||||||
| const code = ref('') | const pane=ref(0) | ||||||
| const pane = ref(0) |  | ||||||
| const showKeyboard = ref(true); |  | ||||||
| // 根据语言获取默认国家 |  | ||||||
| const getDefaultCountry = () => { |  | ||||||
|   let defaultCode = 'CN' // 默认中国大陆 |  | ||||||
|   switch (locale.value) { |  | ||||||
|     case 'zh-CN': |  | ||||||
|       defaultCode = 'CN' |  | ||||||
|       break |  | ||||||
|     case 'zh-TW': |  | ||||||
|       defaultCode = 'TW' |  | ||||||
|       break |  | ||||||
|     case 'ja-JP': |  | ||||||
|       defaultCode = 'JP' |  | ||||||
|       break |  | ||||||
|     case 'en-US': |  | ||||||
|       defaultCode = 'US' |  | ||||||
|       break |  | ||||||
|   } |  | ||||||
| 
 |  | ||||||
|   const country = countryCode.find(c => c.code === defaultCode) |  | ||||||
|   return { |  | ||||||
|     zone: country.zone, |  | ||||||
|     name: locale.value === 'zh-CN' ? country.cn : |  | ||||||
|       locale.value === 'zh-TW' ? country.tw : |  | ||||||
|         locale.value === 'ja-JP' ? country.ja : |  | ||||||
|           country.en |  | ||||||
|   } |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| const defaultCountry = getDefaultCountry() |  | ||||||
| 
 |  | ||||||
| // 获取选择的国家信息 |  | ||||||
| const selectedZone = ref(route.query.zone || defaultCountry.zone) |  | ||||||
| const selectedCountry = ref(route.query.countryName || defaultCountry.name) |  | ||||||
| 
 |  | ||||||
| // 监听语言变化,更新默认国家 |  | ||||||
| watch(locale, () => { |  | ||||||
|   if (!route.query.zone) { |  | ||||||
|     const newDefault = getDefaultCountry() |  | ||||||
|     selectedZone.value = newDefault.zone |  | ||||||
|     selectedCountry.value = newDefault.name |  | ||||||
|   } |  | ||||||
| }) |  | ||||||
| 
 |  | ||||||
| const getCode = () => { |  | ||||||
|   pane.value = 1 |  | ||||||
| } |  | ||||||
| const goBack = () => { |  | ||||||
|   code.value = '' |  | ||||||
|   pane.value = 0 |  | ||||||
| } |  | ||||||
| const goLogin = () => { |  | ||||||
|   router.push('/realAuth'); |  | ||||||
| }  |  | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
| <template> | <template> | ||||||
| @ -80,19 +18,19 @@ const goLogin = () => { | |||||||
|     <div class="w-full flex justify-center mb-[100px]"> |     <div class="w-full flex justify-center mb-[100px]"> | ||||||
|       <img class="h-[105px] w-[189px]" src="@/static/images/ghfggff.png" alt=""> |       <img class="h-[105px] w-[189px]" src="@/static/images/ghfggff.png" alt=""> | ||||||
|     </div> |     </div> | ||||||
|     <div v-if="pane === 0"> |     <div v-if="pane===0"> | ||||||
|       <div class=""> |       <div class=""> | ||||||
|         <div class="w-full flex justify-between" @click="goToPage"> |         <div class="w-full flex justify-between" @click="goToPage"> | ||||||
|           <div class="text-[16px] text-[#000]"> |           <div class="text-[16px] text-[#000]"> | ||||||
|             {{ selectedCountry }} |             中国(大陆) | ||||||
|           </div> |           </div> | ||||||
|           <div><van-icon color="#777" name="arrow" size="14" /></div> |           <div><van-icon color="#777" name="arrow" size="14" /></div> | ||||||
|         </div> |         </div> | ||||||
|         <div class="border-b-[1.7px] mt-[8px]"> |         <div class="border-b-[1.7px] mt-[8px]"> | ||||||
|           <van-field v-model="phoneNum" clearable :placeholder="$t('login.phonePlaceholder')"> |           <van-field v-model="phoneNum" clearable placeholder="请输入手机号"> | ||||||
|             <template #label> |             <template #label> | ||||||
|               <div class="text-[16px] text-[#1A1A1A] flex align-center justify-start"> |               <div class="text-[16px] text-[#1A1A1A] flex align-center justify-start"> | ||||||
|                 +{{ selectedZone }} |                 +86 | ||||||
|               </div> |               </div> | ||||||
|             </template> |             </template> | ||||||
|           </van-field> |           </van-field> | ||||||
| @ -100,45 +38,39 @@ const goLogin = () => { | |||||||
|         <div /> |         <div /> | ||||||
|       </div> |       </div> | ||||||
|       <div class="mt-[55px]"> |       <div class="mt-[55px]"> | ||||||
|         <van-button v-if="phoneNum" type="primary" block style="height: 48px" @click="getCode">{{ $t('login.getCode') |         <van-button v-if="phoneNum" type="primary"  block style="height: 48px" >获取验证码</van-button> | ||||||
|           }}</van-button> |         <van-button v-else type="primary" color="#D3D3D3"  block style="height: 48px" >获取验证码</van-button> | ||||||
|         <van-button v-else type="primary" color="#D3D3D3" block style="height: 48px">{{ $t('login.getCode') |  | ||||||
|           }}</van-button> |  | ||||||
|       </div> |       </div> | ||||||
|     </div> |     </div> | ||||||
|     <div v-else> |     <div v-else> | ||||||
|       <div class="flex mb-[16px]"> |       <div class="flex mb-[16px]"> | ||||||
|         <div class="text-[16px] text-[#BDBDBD] mr-[10px]">{{ $t('login.hasSendTo') }}</div> |         <div class="text-[16px] text-[#BDBDBD] mr-[10px]">已发送验证码至</div> | ||||||
|         <div class="text-[16px] text-[#000]">+{{ selectedZone }} {{ phoneNum }}</div> |         <div class="text-[16px] text-[#000]">15834362333</div> | ||||||
|       </div> |       </div> | ||||||
|       <van-password-input :value="code" :gutter="10" :mask="false" focused @focus="showKeyboard = true" /> |       <van-password-input | ||||||
|       <van-number-keyboard v-model="code" :show="showKeyboard" @blur="showKeyboard = false" /> |           :value="code" | ||||||
|  |           :gutter="10" | ||||||
|  |           focused | ||||||
|  |       /> | ||||||
|       <div class="text-#2B53AC text-14px"> |       <div class="text-#2B53AC text-14px"> | ||||||
|         {{ $t('login.reSend') }} |         重新发送 | ||||||
|       </div> |       </div> | ||||||
|       <div class="mt-[17px]"> |       <div class="mt-[17px]"> | ||||||
|         <van-button v-if="code.length === 6" type="primary" block style="height: 48px" @click="goLogin">{{ |         <van-button v-if="code.length === 6" type="primary"  block style="height: 48px" >登录</van-button> | ||||||
|           $t('login.login') |         <van-button v-else type="primary" color="#D3D3D3"  block style="height: 48px" >登录</van-button> | ||||||
|           }}</van-button> |  | ||||||
|         <van-button v-else type="primary" color="#D3D3D3" block style="height: 48px">{{ $t('login.login') }}</van-button> |  | ||||||
|       </div> |  | ||||||
|       <div class="mt-[17px]"> |  | ||||||
|         <van-button type="primary" @click="goBack" block style="height: 48px">{{ $t('login.back') }}</van-button> |  | ||||||
|       </div> |       </div> | ||||||
|     </div> |     </div> | ||||||
|   </div> |   </div> | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <style scoped lang="scss"> | <style scoped lang="scss"> | ||||||
| :deep(.van-cell.van-field) { | :deep(.van-cell.van-field){ | ||||||
|   padding-left: 0; |   padding-left: 0; | ||||||
| } | } | ||||||
| 
 | :deep(.van-password-input){ | ||||||
| :deep(.van-password-input) { |  | ||||||
|   margin: 0; |   margin: 0; | ||||||
| } | } | ||||||
| 
 | :deep(.van-password-input__item){ | ||||||
| :deep(.van-password-input__item) { |  | ||||||
|   border: 1px solid #E5E5E5; |   border: 1px solid #E5E5E5; | ||||||
|   width: 41px; |   width: 41px; | ||||||
|   height: 41px; |   height: 41px; | ||||||
|  | |||||||
| @ -1,119 +1,37 @@ | |||||||
| <script setup> | <script setup> | ||||||
| import { useRouter, useRoute } from 'vue-router'; |  | ||||||
| import { useI18n } from 'vue-i18n' |  | ||||||
| 
 | 
 | ||||||
| const router = useRouter(); |  | ||||||
| const route = useRoute(); |  | ||||||
| const showPicker = ref(false); |  | ||||||
| const pickerValue = ref([]); |  | ||||||
| const gender = ref('男') |  | ||||||
| const birthday = ref('') |  | ||||||
| const birthdayDate = ref([]) |  | ||||||
| const showBirthdayPicker = ref(false) |  | ||||||
| const minDate = new Date(1950, 0, 1) |  | ||||||
| const maxDate = new Date(2025, 12, 31) |  | ||||||
| 
 |  | ||||||
| const { t } = useI18n() |  | ||||||
| 
 |  | ||||||
| const columns = computed(() => [ |  | ||||||
|   { text: t('realAuth.male'), value: t('realAuth.male') }, |  | ||||||
|   { text: t('realAuth.female'), value: t('realAuth.female') }, |  | ||||||
| ]); |  | ||||||
| const onConfirm = ({ selectedValues, selectedOptions }) => { |  | ||||||
|   pickerValue.value = selectedValues |  | ||||||
|   gender.value = selectedOptions[0].text |  | ||||||
|   showPicker.value = false |  | ||||||
| } |  | ||||||
| const onBirthdayConfirm = (value) => { |  | ||||||
|   console.log(value) |  | ||||||
|   birthdayDate.value = value.selectedValues |  | ||||||
|   birthday.value = value.selectedValues.join('-') |  | ||||||
|   showBirthdayPicker.value = false |  | ||||||
| } |  | ||||||
| definePageMeta({ |  | ||||||
|   title: '实名认证', |  | ||||||
|   i18n: 'realAuth.title', |  | ||||||
| }) |  | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
| <template> | <template> | ||||||
|   <div class="px-[31px] bg-#fff w-100vw h-100vh pt-[46px]"> | <div class="px-[31px] bg-#fff w-100vw h-100vh pt-[46px]"> | ||||||
|     <van-tabs animated swipeable> |   <van-tabs> | ||||||
|       <van-tab :title="$t('realAuth.cnTab')" class="pt-[80px]"> |     <van-tab  title="大陆居民" class="pt-[80px]"> | ||||||
|         <div class="text-[#BDBDBD] text-[16px] mb-[34px]">{{ $t('realAuth.cnTabDesc') }}</div> |       <div class="text-[#BDBDBD] text-[16px] mb-[34px]">请填写身份证相关信息</div> | ||||||
|         <div class="mb-[100px]"> |       <div class="mb-[100px]"> | ||||||
|           <div class="border-b-[1.7px] mt-[8px]"> |         <div class="border-b-[1.7px] mt-[8px]"> | ||||||
|             <van-field :label="$t('realAuth.idCard')" clearable |           <van-field label="身份证号" clearable placeholder="请输入身份证号"></van-field> | ||||||
|               :placeholder="$t('realAuth.idCardPlaceholder')"></van-field> |  | ||||||
|           </div> |  | ||||||
|           <div class="border-b-[1.7px] mt-[8px]"> |  | ||||||
|             <van-field :label="$t('realAuth.name')" clearable :placeholder="$t('realAuth.namePlaceholder')"></van-field> |  | ||||||
|           </div> |  | ||||||
|         </div> |         </div> | ||||||
|         <div class="flex justify-between"> |         <div class="border-b-[1.7px] mt-[8px]"> | ||||||
|           <van-button style="width: 151px;height: 48px" color="#E9F1F8"> |           <van-field label="姓名" clearable placeholder="请输入姓名"></van-field> | ||||||
|             <div class="text-#2B53AC text-16px">{{ $t('realAuth.cancel') }}</div> |  | ||||||
|           </van-button> |  | ||||||
|           <van-button style="width: 151px;height: 48px" color="#2B53AC"> |  | ||||||
|             <div class="text-#FFFFFF text-16px">{{ $t('realAuth.confirm') }}</div> |  | ||||||
|           </van-button> |  | ||||||
|         </div> |         </div> | ||||||
|       </van-tab> |       </div> | ||||||
|       <van-tab :title="$t('realAuth.otherTab')" class="pt-[80px]"> |       <div class="flex justify-between"> | ||||||
|         <div class="text-[#BDBDBD] text-[16px] mb-[34px]">{{ $t('realAuth.otherTabDesc') }}</div> |         <van-button style="width: 151px;height: 48px" color="#E9F1F8"> | ||||||
|         <div class="mb-[100px]"> |           <div class="text-#2B53AC text-16px">取消</div> | ||||||
|           <div class="border-b-[1.7px] mt-[8px]"> |         </van-button> | ||||||
|             <van-field :label="$t('realAuth.name')" clearable :placeholder="$t('realAuth.namePlaceholder')"></van-field> |         <van-button style="width: 151px;height: 48px" color="#2B53AC"> | ||||||
|           </div> |           <div class="text-#FFFFFF text-16px">确定</div> | ||||||
|           <div class="border-b-[1.7px] mt-[8px]"> |         </van-button> | ||||||
|             <van-field v-model="gender" is-link readonly name="picker" :label="$t('realAuth.gender')" |       </div> | ||||||
|               @click="showPicker = true" /> |     </van-tab> | ||||||
| 
 |     <van-tab title="非大陆居民">内容 2</van-tab> | ||||||
|           </div> |   </van-tabs> | ||||||
|           <div class="border-b-[1.7px] mt-[8px]"> | </div> | ||||||
|             <van-field v-model="birthday" is-link readonly name="birthdayPicker" :label="$t('realAuth.birthday')" |  | ||||||
|               :placeholder="$t('realAuth.birthdayPlaceholder')" @click="showBirthdayPicker = true" /> |  | ||||||
| 
 |  | ||||||
|           </div> |  | ||||||
|           <div class="border-b-[1.7px] mt-[8px]"> |  | ||||||
|             <van-field :label="$t('realAuth.adress')" clearable |  | ||||||
|               :placeholder="$t('realAuth.adressPlaceholder')"></van-field> |  | ||||||
|           </div> |  | ||||||
|           <div class="border-b-[1.7px] mt-[8px]"> |  | ||||||
|             <van-field :label="$t('realAuth.bank')" clearable :placeholder="$t('realAuth.bankPlaceholder')"></van-field> |  | ||||||
|           </div> |  | ||||||
|           <div class="border-b-[1.7px] mt-[8px]"> |  | ||||||
|             <van-field :label="$t('realAuth.bankCard')" clearable |  | ||||||
|               :placeholder="$t('realAuth.bankCardPlaceholder')"></van-field> |  | ||||||
|           </div> |  | ||||||
|           <div class="flex justify-between mt-[100px]"> |  | ||||||
|             <van-button style="width: 151px;height: 48px" color="#E9F1F8"> |  | ||||||
|               <div class="text-#2B53AC text-16px">{{ $t('realAuth.cancel') }}</div> |  | ||||||
|             </van-button> |  | ||||||
|             <van-button style="width: 151px;height: 48px" color="#2B53AC"> |  | ||||||
|               <div class="text-#FFFFFF text-16px">{{ $t('realAuth.confirm') }}</div> |  | ||||||
|             </van-button> |  | ||||||
|           </div> |  | ||||||
|         </div> |  | ||||||
|       </van-tab> |  | ||||||
|     </van-tabs> |  | ||||||
|     <van-popup v-model:show="showPicker" destroy-on-close position="bottom"> |  | ||||||
|       <van-picker :columns="columns" :model-value="pickerValue" @confirm="onConfirm" @cancel="showPicker = false" /> |  | ||||||
|     </van-popup> |  | ||||||
|     <van-popup v-model:show="showBirthdayPicker" destroy-on-close position="bottom"> |  | ||||||
|       <van-date-picker v-model="birthdayDate" :min-date="minDate" :max-date="maxDate" |  | ||||||
|         @cancel="showBirthdayPicker = false" @confirm="onBirthdayConfirm" /> |  | ||||||
|     </van-popup> |  | ||||||
|   </div> |  | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <style scoped> | <style scoped> | ||||||
| :deep(.van-tabs__line) { | :deep(.van-tabs__line){ | ||||||
|   height: 2px; |   height: 2px; | ||||||
|   width: 107px; |   width: 107px; | ||||||
| } | } | ||||||
| 
 |  | ||||||
| :deep(.van-cell) { |  | ||||||
|   padding-left: 0; |  | ||||||
| } |  | ||||||
| </style> | </style> | ||||||
| @ -18,14 +18,10 @@ | |||||||
|     "home": "Home", |     "home": "Home", | ||||||
|     "profile": "Profile" |     "profile": "Profile" | ||||||
|   }, |   }, | ||||||
|   "login": { |   "unocss_page": { | ||||||
|     "title": "Login", |     "hello": "Hello {0}", | ||||||
|     "phonePlaceholder": "Please enter your phone number", |     "desc": "This is a simple example of Unocss in action.", | ||||||
|     "getCode": "Get verification code", |     "btn_txt": "Button" | ||||||
|     "login": "Login", |  | ||||||
|     "back": "Back", |  | ||||||
|     "hasSendTo": "Verification code has been sent to", |  | ||||||
|     "reSend": "Re-send"  |  | ||||||
|   }, |   }, | ||||||
|   "error_page": { |   "error_page": { | ||||||
|     "back_btn": "Back", |     "back_btn": "Back", | ||||||
| @ -34,38 +30,20 @@ | |||||||
|   "profile_page": { |   "profile_page": { | ||||||
|     "txt": "WIP" |     "txt": "WIP" | ||||||
|   }, |   }, | ||||||
|  |   "keepalive_page": { | ||||||
|  |     "label": "The current component will be cached" | ||||||
|  |   }, | ||||||
|  |   "counter_page": { | ||||||
|  |     "label": "This is a simple example of persisting Pinia state. To verify its effectiveness, you can refresh the interface and observe it.", | ||||||
|  |     "label_num": "Number", | ||||||
|  |     "btn_add": "Add" | ||||||
|  |   }, | ||||||
|   "prose_page": { |   "prose_page": { | ||||||
|     "btn_fetch": "Fetch", |     "btn_fetch": "Fetch", | ||||||
|     "btn_clear": "Clear", |     "btn_clear": "Clear", | ||||||
|     "btn_empty_desc": "No data" |     "btn_empty_desc": "No data" | ||||||
|   }, |   }, | ||||||
|   "countryRegion": { |   "countryRegion": { | ||||||
|     "title": "Country and Region", |     "searchPlaceholder": "Please enter the country and region" | ||||||
|     "searchPlaceholder": "Please enter the country and region", |  | ||||||
|     "frequentCountry": "Frequent" |  | ||||||
|   }, |  | ||||||
|   "realAuth": { |  | ||||||
|     "title": "Real-name Authentication", |  | ||||||
|     "cnTab": "Mainland Residents", |  | ||||||
|     "otherTab": "Non-Mainland Residents", |  | ||||||
|     "cnTabDesc": "Please fill in ID card information", |  | ||||||
|     "otherTabDesc": "Please upload personal information", |  | ||||||
|     "idCard": "ID Card Number", |  | ||||||
|     "idCardPlaceholder": "Please enter ID card number", |  | ||||||
|     "name": "Name", |  | ||||||
|     "namePlaceholder": "Please enter your name", |  | ||||||
|     "gender": "Gender", |  | ||||||
|     "male": "Male", |  | ||||||
|     "female": "Female", |  | ||||||
|     "birthday": "Date of Birth", |  | ||||||
|     "birthdayPlaceholder": "Please enter date of birth", |  | ||||||
|     "adress": "Home Address", |  | ||||||
|     "adressPlaceholder": "Please enter home address", |  | ||||||
|     "bank": "Bank", |  | ||||||
|     "bankPlaceholder": "Please select your bank", |  | ||||||
|     "bankCard": "Bank Card Number", |  | ||||||
|     "bankCardPlaceholder": "Please enter bank card number", |  | ||||||
|     "cancel": "Cancel", |  | ||||||
|     "confirm": "Confirm" |  | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  | |||||||
| @ -19,51 +19,32 @@ | |||||||
|     "home": "ホーム", |     "home": "ホーム", | ||||||
|     "profile": "マイページ" |     "profile": "マイページ" | ||||||
|   }, |   }, | ||||||
|   "login": { |   "unocss_page": { | ||||||
|     "title": "ログイン", |     "hello": "こんにちは {0}", | ||||||
|     "phonePlaceholder": "携帯番号を入力してください", |     "desc": "これは unocss の簡単な例です。", | ||||||
|     "getCode": "認証コードを取得", |     "btn_txt": "ボタン" | ||||||
|     "login": "ログイン", |  | ||||||
|     "back": "戻る", |  | ||||||
|     "hasSendTo": "認証コードは", |  | ||||||
|     "reSend": "再送" |  | ||||||
|   }, |   }, | ||||||
|   "error_page": { |   "error_page": { | ||||||
|     "back_btn": "戻る", |     "back_btn": "戻る", | ||||||
|     "txt": "ページが見つかりません" |     "txt": "ページが見つかりません" | ||||||
|   }, |   }, | ||||||
|  |   "profile_page": { | ||||||
|  |     "txt": "未完成" | ||||||
|  |   }, | ||||||
|  |   "keepalive_page": { | ||||||
|  |     "label": "このコンポーネントはキャッシュされます" | ||||||
|  |   }, | ||||||
|  |   "counter_page": { | ||||||
|  |     "label": "これは Pinia の状態永続化の簡単な例です。有効性を確認するには、ページを更新して観察してください。", | ||||||
|  |     "label_num": "数字", | ||||||
|  |     "btn_add": "増加" | ||||||
|  |   }, | ||||||
|   "prose_page": { |   "prose_page": { | ||||||
|     "btn_fetch": "取得", |     "btn_fetch": "取得", | ||||||
|     "btn_clear": "クリア", |     "btn_clear": "クリア", | ||||||
|     "btn_empty_desc": "データなし" |     "btn_empty_desc": "データなし" | ||||||
|   }, |   }, | ||||||
|   "countryRegion": { |   "countryRegion": { | ||||||
|     "title": "国と地域", |     "searchPlaceholder": "国と地域を入力してください" | ||||||
|     "searchPlaceholder": "国と地域を入力してください", |  | ||||||
|     "frequentCountry": "よく使う" |  | ||||||
|   }, |  | ||||||
|   "realAuth": { |  | ||||||
|     "title": "実名認証", |  | ||||||
|     "cnTab": "中国本土住民", |  | ||||||
|     "otherTab": "非中国本土住民", |  | ||||||
|     "cnTabDesc": "身分証情報を入力してください", |  | ||||||
|     "otherTabDesc": "個人情報をアップロードしてください", |  | ||||||
|     "idCard": "身分証番号", |  | ||||||
|     "idCardPlaceholder": "身分証番号を入力してください", |  | ||||||
|     "name": "氏名", |  | ||||||
|     "namePlaceholder": "氏名を入力してください", |  | ||||||
|     "gender": "性別", |  | ||||||
|     "male": "男性", |  | ||||||
|     "female": "女性", |  | ||||||
|     "birthday": "生年月日", |  | ||||||
|     "birthdayPlaceholder": "生年月日を入力してください", |  | ||||||
|     "adress": "住所", |  | ||||||
|     "adressPlaceholder": "住所を入力してください", |  | ||||||
|     "bank": "所属銀行", |  | ||||||
|     "bankPlaceholder": "所属銀行を選択してください", |  | ||||||
|     "bankCard": "銀行カード番号", |  | ||||||
|     "bankCardPlaceholder": "銀行カード番号を入力してください", |  | ||||||
|     "cancel": "キャンセル", |  | ||||||
|     "confirm": "確定" |  | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  | |||||||
| @ -19,55 +19,36 @@ | |||||||
|     "home": "主页", |     "home": "主页", | ||||||
|     "profile": "我的" |     "profile": "我的" | ||||||
|   }, |   }, | ||||||
|   "login": { |  | ||||||
|     "title": "登录", |  | ||||||
|     "phonePlaceholder": "请输入手机号", |  | ||||||
|     "getCode": "获取验证码", |  | ||||||
|     "login": "登录", |  | ||||||
|     "back": "返回", |  | ||||||
|     "hasSendTo": "已发送验证码至", |  | ||||||
|     "reSend": "重新发送"  |  | ||||||
|   }, |  | ||||||
|   "profile": { |   "profile": { | ||||||
|     "name": "姓名", |     "name": "姓名", | ||||||
|     "phone": "手机号" |     "phone": "手机号" | ||||||
|   }, |   }, | ||||||
|  |   "unocss_page": { | ||||||
|  |     "hello": "你好 {0}", | ||||||
|  |     "desc": "这是 unocss 一个简单例子。", | ||||||
|  |     "btn_txt": "按钮" | ||||||
|  |   }, | ||||||
|   "error_page": { |   "error_page": { | ||||||
|     "back_btn": "返回", |     "back_btn": "返回", | ||||||
|     "txt": "没有找到" |     "txt": "没有找到" | ||||||
|   }, |   }, | ||||||
|  |   "profile_page": { | ||||||
|  |     "txt": "未完成" | ||||||
|  |   }, | ||||||
|  |   "keepalive_page": { | ||||||
|  |     "label": "当前组件将会被缓存" | ||||||
|  |   }, | ||||||
|  |   "counter_page": { | ||||||
|  |     "label": "这是一个简单的持久化 Pinia 状态的例子。为了验证其有效性,你可以刷新界面并观察它。", | ||||||
|  |     "label_num": "数字", | ||||||
|  |     "btn_add": "增加" | ||||||
|  |   }, | ||||||
|   "prose_page": { |   "prose_page": { | ||||||
|     "btn_fetch": "拉取", |     "btn_fetch": "拉取", | ||||||
|     "btn_clear": "清空", |     "btn_clear": "清空", | ||||||
|     "btn_empty_desc": "暂无数据" |     "btn_empty_desc": "暂无数据" | ||||||
|   }, |   }, | ||||||
|   "countryRegion": { |   "countryRegion": { | ||||||
|     "title": "国家地区", |     "searchPlaceholder": "请输入国家和地区" | ||||||
|     "searchPlaceholder": "请输入国家和地区", |  | ||||||
|     "frequentCountry": "常用" |  | ||||||
|   }, |  | ||||||
|   "realAuth": { |  | ||||||
|     "title": "实名认证", |  | ||||||
|     "cnTab": "大陆居民", |  | ||||||
|     "otherTab": "非大陆居民", |  | ||||||
|     "cnTabDesc": "请填写身份证相关信息",  |  | ||||||
|     "otherTabDesc": "请上传个人相关信息", |  | ||||||
|     "idCard": "身份证号", |  | ||||||
|     "idCardPlaceholder": "请输入身份证号", |  | ||||||
|     "name": "姓名", |  | ||||||
|     "namePlaceholder": "请输入姓名", |  | ||||||
|     "gender": "性别", |  | ||||||
|     "male": "男", |  | ||||||
|     "female": "女", |  | ||||||
|     "birthday": "出生日期", |  | ||||||
|     "birthdayPlaceholder": "请输入出生日期", |  | ||||||
|     "adress":"家庭住址", |  | ||||||
|     "adressPlaceholder": "请输入家庭住址", |  | ||||||
|     "bank": "所属银行", |  | ||||||
|     "bankPlaceholder": "请选择所属银行", |  | ||||||
|     "bankCard": "银行卡号码", |  | ||||||
|     "bankCardPlaceholder": "请输入银行卡号码", |  | ||||||
|     "cancel": "取消", |  | ||||||
|     "confirm": "确定" |  | ||||||
|   } |   } | ||||||
| } | } | ||||||
| @ -19,52 +19,32 @@ | |||||||
|     "home": "首頁", |     "home": "首頁", | ||||||
|     "profile": "我的" |     "profile": "我的" | ||||||
|   }, |   }, | ||||||
|   "login": { |   "unocss_page": { | ||||||
|     "title": "登入", |     "hello": "你好 {0}", | ||||||
|     "phonePlaceholder": "請輸入手機號", |     "desc": "這是 unocss 一個簡單例子。", | ||||||
|     "getCode": "獲取驗證碼", |     "btn_txt": "按鈕" | ||||||
|     "login": "登入", |  | ||||||
|     "back": "返回", |  | ||||||
|     "hasSendTo": "已發送驗證碼至", |  | ||||||
|     "reSend": "重新發送"  |  | ||||||
|   }, |   }, | ||||||
|   "error_page": { |   "error_page": { | ||||||
|     "back_btn": "返回", |     "back_btn": "返回", | ||||||
|     "txt": "沒有找到" |     "txt": "沒有找到" | ||||||
|   }, |   }, | ||||||
|  |   "profile_page": { | ||||||
|  |     "txt": "未完成" | ||||||
|  |   }, | ||||||
|  |   "keepalive_page": { | ||||||
|  |     "label": "當前元件將會被快取" | ||||||
|  |   }, | ||||||
|  |   "counter_page": { | ||||||
|  |     "label": "這是一個簡單的持久化 Pinia 狀態的例子。為了驗證其有效性,你可以重新整理介面並觀察它。", | ||||||
|  |     "label_num": "數字", | ||||||
|  |     "btn_add": "增加" | ||||||
|  |   }, | ||||||
|   "prose_page": { |   "prose_page": { | ||||||
|     "btn_fetch": "拉取", |     "btn_fetch": "拉取", | ||||||
|     "btn_clear": "清空", |     "btn_clear": "清空", | ||||||
|     "btn_empty_desc": "暫無數據" |     "btn_empty_desc": "暫無數據" | ||||||
|   }, |   }, | ||||||
|   "countryRegion": { |   "countryRegion": { | ||||||
|     "title": "國家地區", |     "searchPlaceholder": "請輸入國家和地區" | ||||||
|     "searchPlaceholder": "請輸入國家和地區", |  | ||||||
|     "frequentCountry": "常用" |  | ||||||
|   }, |  | ||||||
|   "realAuth": { |  | ||||||
|     "title": "實名認證  ", |  | ||||||
|     "cnTab": "大陸居民", |  | ||||||
|     "otherTab": "非大陸居民", |  | ||||||
|     "cnTabDesc": "請填寫身份證相關信息",  |  | ||||||
|     "otherTabDesc": "請上傳個人相關信息", |  | ||||||
|     "idCard": "身份證號", |  | ||||||
|     "idCardPlaceholder": "請輸入身份證號", |  | ||||||
|     "name": "姓名", |  | ||||||
|     "namePlaceholder": "請輸入姓名", |  | ||||||
|     "gender": "性別", |  | ||||||
|     "male": "男", |  | ||||||
|     "female": "女", |  | ||||||
|     "birthday": "出生日期", |  | ||||||
|     "birthdayPlaceholder": "請輸入出生日期", |  | ||||||
|     "adress":"家庭住址", |  | ||||||
|     "adressPlaceholder": "請輸入家庭住址", |  | ||||||
|     "bank": "所屬銀行", |  | ||||||
|     "bankPlaceholder": "請選擇所屬銀行", |  | ||||||
|     "bankCard": "銀行卡號碼", |  | ||||||
|     "bankCardPlaceholder": "請輸入銀行卡號碼", |  | ||||||
|     "cancel": "取消", |  | ||||||
|     "confirm": "確定" |  | ||||||
|   } |   } | ||||||
| } | } | ||||||
| 
 |  | ||||||
|  | |||||||
| @ -137,7 +137,7 @@ export default defineNuxtConfig({ | |||||||
|   // 指定 Nuxt 应用程序的兼容性日期,确保应用程序在未来的 Nuxt 版本中保持稳定性
 |   // 指定 Nuxt 应用程序的兼容性日期,确保应用程序在未来的 Nuxt 版本中保持稳定性
 | ||||||
|   compatibilityDate: '2025-01-09', |   compatibilityDate: '2025-01-09', | ||||||
|   devServer: { |   devServer: { | ||||||
|     host: '0.0.0.0', // Set the host to 'localhost'
 |     host: 'localhost', // Set the host to 'localhost'
 | ||||||
|     port: 3000,        // Set the port to 3000 or any other port you prefer
 |     port: 3000,        // Set the port to 3000 or any other port you prefer
 | ||||||
|   }, |   }, | ||||||
| }) | }) | ||||||
		Loading…
	
		Reference in New Issue
	
	Block a user