| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270 |
- <template>
- <div>
- <div class="bg-white w-full py-[60px] px-[30px] !rounded-[var(--rounded-big)]">
- <div class="flex items-end justify-center mb-[30px]">
- <div class="text-[18px] cursor-pointer text-[#999] leading-[24px] oppoSans-R" :class="{ '!text-[#333] font-600': type == item.type,'mr-[70px]': (index+1) != registerType.length }" v-for="(item,index) in registerType" @click="type = item.type">{{item.title }}</div>
- </div>
- <el-form :model="formData" ref="formRef" :rules="formRules" :validate-on-rule-change="false">
- <div v-show="type == 'username'">
- <el-form-item prop="username">
- <div class="flex-1 h-[50px] border-[1px] border-solid border-[#ccc] rounded-[8px] flex items-center">
- <el-input v-model="formData.username" :placeholder="t('usernamePlaceholder')" clearable :inline-message="true" :readonly="real_name_input" @click="real_name_input = false" @blur="real_name_input = true">
- <template #prefix>
- <span class="iconfont icon-woV6xx1 !mr-[14px]"></span>
- </template>
- </el-input>
- </div>
- </el-form-item>
- <el-form-item prop="password">
- <div class="flex-1 h-[50px] border-[1px] border-solid border-[#ccc] rounded-[8px] flex items-center">
- <el-input v-model="formData.password" :placeholder="t('passwordPlaceholder')" type="password" clearable :show-password="true" :readonly="password_input" @click="password_input = false" @blur="password_input = true" >
- <template #prefix>
- <span class="iconfont icon-mima !mr-[14px]"></span>
- </template>
- </el-input>
- </div>
- </el-form-item>
- <el-form-item prop="confirm_password">
- <div class="flex-1 h-[50px] border-[1px] border-solid border-[#ccc] rounded-[8px] flex items-center">
- <el-input v-model="formData.confirm_password" :placeholder="t('confirmPasswordPlaceholder')" type="password" clearable :show-password="true" :readonly="confirm_password_input" @click="confirm_password_input = false" @blur="confirm_password_input = true" >
- <template #prefix>
- <span class="iconfont icon-mima !mr-[14px]"></span>
- </template>
- </el-input>
- </div>
- </el-form-item>
- </div>
- <div v-show="type == 'mobile' || configStore.login.is_bind_mobile">
- <el-form-item prop="mobile">
- <div class="flex-1 h-[50px] border-[1px] border-solid border-[#ccc] rounded-[8px] flex items-center">
- <el-input v-model="formData.mobile" :placeholder="t('mobilePlaceholder')" clearable>
- <template #prefix>
- <span class="iconfont icon-shoujiV6xx !mr-[14px]"></span>
- </template>
- </el-input>
- </div>
- </el-form-item>
- <el-form-item prop="mobile_code">
- <div class="flex-1 h-[50px] border-[1px] border-solid border-[#ccc] rounded-[8px] flex items-center">
- <el-input v-model="formData.mobile_code" :placeholder="t('codePlaceholder')">
- <template #prefix>
- <span class="iconfont icon-a-zhibao5 !mr-[14px]"></span>
- </template>
- <template #suffix>
- <sms-code :mobile="formData.mobile" type="login" v-model="formData.mobile_key" @click="sendSmsCode" ref="smsCodeRef"></sms-code>
- </template>
- </el-input>
- </div>
- </el-form-item>
- </div>
- <div v-show="type == 'username'">
- <el-form-item prop="captcha_code">
- <div class="flex-1 h-[50px] border-[1px] border-solid border-[#ccc] rounded-[8px] flex items-center">
- <el-input v-model="formData.captcha_code" :placeholder="t('captchaPlaceholder')">
- <template #prefix>
- <span class="iconfont icon-a-zhibao5 !mr-[14px]"></span>
- </template>
- <template #suffix>
- <div class="py-0 leading-none">
- <el-image :src="captcha.image.value" class="h-[30px] cursor-pointer" @click="captcha.refresh()"></el-image>
- </div>
- </template>
- </el-input>
- </div>
- </el-form-item>
- </div>
- <div class="flex justify-end">
- <el-button type="primary" link @click="typeChange" class="!text-[12px]">{{ t('haveAccount') }},{{ t('toLogin') }}</el-button>
- </div>
- <div class="mt-[20px]">
- <el-button type="primary" class="w-full !h-[50px] !rounded-[8px] oppoSans-M" size="large" @click="handleRegister" :loading="loading">{{ loading ? t('registering') : t('register') }}</el-button>
- </div>
- <div class="text-[12px] leading-[24px] flex items-center w-full mt-[20px]" v-if="configStore.login.agreement_show">
- <span class="iconfont text-primary mr-[5px]" :class="isAgree ? 'icon-xuanze1' : 'icon-checkbox_nol'" @click="isAgree = !isAgree"></span>
- {{ t('registerAgreeTips') }}
- <NuxtLink :to="service">
- <span class="text-primary mx-[4px]">{{ t('userAgreement') }}</span>
- </NuxtLink>
- {{ t('and') }}
- <NuxtLink :to="privacy">
- <span class="text-primary mx-[4px]">{{ t('privacyAgreement') }}</span>
- </NuxtLink>
- </div>
- </el-form>
- </div>
- </div>
- </template>
- <script lang="ts" setup>
- import { ref,reactive,computed } from 'vue'
- import { usernameRegister, mobileRegister, wechatCheck } from '@/app/api/auth'
- import useMemberStore from '@/stores/member'
- import useConfigStore from '@/stores/config'
- import { FormInstance } from 'element-plus'
- definePageMeta({
- layout: "container"
- });
- const memberStore = useMemberStore()
- const configStore = useConfigStore()
- configStore.getLoginConfig()
- // 跳转
- const service = ref('')
- const privacy = ref('')
- if(location.pathname.indexOf('web') != -1){
- service.value = '/web/auth/agreement?key=service'
- privacy.value = '/web/auth/agreement?key=privacy'
- }else{
- service.value = '/auth/agreement?key=service'
- privacy.value = '/auth/agreement?key=privacy'
- }
- const type = ref('')
- const registerType = computed(() => {
- const value = []
- configStore.login.is_username && (value.push({ type: 'username', title: t('usernameRegister') }))
- configStore.login.is_mobile && !configStore.login.is_bind_mobile && (value.push({ type: 'mobile', title: t('mobileRegister') }))
- type.value = value[0] ? value[0].type : ''
- return value
- })
- const loading = ref(false)
- const formData = reactive({
- username: '',
- password: '',
- confirm_password: '',
- mobile: '',
- mobile_code: '',
- mobile_key: '',
- captcha_key: '',
- captcha_code: ''
- })
- const formRules = computed(() => {
- return {
- 'username': {
- type: 'string',
- required: type.value == 'username',
- message: t('usernamePlaceholder'),
- trigger: ['blur', 'change'],
- },
- 'password': {
- type: 'string',
- required: type.value == 'username',
- message: t('passwordPlaceholder'),
- trigger: ['blur', 'change']
- },
- 'confirm_password': [
- {
- type: 'string',
- required: type.value == 'username',
- message: t('confirmPasswordPlaceholder'),
- trigger: ['blur', 'change']
- },
- {
- validator(rule: any, value: string, callback: any) {
- return value == formData.password
- },
- message: t('confirmPasswordError'),
- trigger: ['change', 'blur'],
- }
- ],
- 'mobile': [
- {
- type: 'string',
- required: type.value == 'mobile' || configStore.login.is_bind_mobile,
- message: t('mobilePlaceholder'),
- trigger: ['blur', 'change'],
- },
- {
- validator(rule: any, value: string, callback: any) {
- if (type.value != 'mobile' && !configStore.login.is_bind_mobile) return true
- else return test.mobile(value)
- },
- message: t('mobileError'),
- trigger: ['change', 'blur'],
- }
- ],
- 'mobile_code': {
- type: 'string',
- required: type.value == 'mobile' || configStore.login.is_bind_mobile,
- message: t('codePlaceholder'),
- trigger: ['blur', 'change']
- },
- 'captcha_code': {
- type: 'string',
- required: type.value == 'username',
- message: t('captchaPlaceholder'),
- trigger: ['blur', 'change'],
- }
- }
- })
- const isAgree = ref(false)
- const formRef = ref<FormInstance>()
- const handleRegister = async () => {
- await formRef.value?.validate(async (valid, fields) => {
- if (valid) {
- if (configStore.login.agreement_show && !isAgree.value) {
- ElMessage.error(t('isAgreeTips'))
- return false;
- }
- if (loading.value) return
- loading.value = true
- const register = type.value == 'username' ? usernameRegister : mobileRegister
- register(formData).then((res: any) => {
- memberStore.setToken(res.data.token)
- memberStore.logClose()
- }).catch(() => {
- loading.value = false
- captcha.refresh()
- })
- }
- })
- }
- let show = ref(false)
- const wechatCheckFn = () =>{
- wechatCheck().then((res:any) =>{
- show.value = res.data
- })
- }
- wechatCheckFn()
- // 验证码
- const captcha = useCaptcha(formData)
- captcha.refresh()
- // 获取手机验证码
- const smsCodeRef = ref<AnyObject | null>(null)
- const sendSmsCode = async () => {
- await formRef.value?.validateField('mobile', async (valid, fields) => {
- if (valid) {
- smsCodeRef.value?.send()
- }
- })
- }
- //去登录
- const emit = defineEmits(['typeChange'])
- const typeChange = ()=>{
- emit('typeChange','login')
- }
- const real_name_input = ref(true)
- const password_input = ref(true)
- const confirm_password_input = ref(true)
- </script>
- <style lang="scss" scoped>
- :deep(.el-checkbox.el-checkbox--large){
- height: 0px;
- margin-right: 5px;
- }
- </style>
|