2024-10-31 15:28:26 +08:00

89 lines
2.6 KiB
Vue

<template>
<view class="text-[26rpx]" :class="{'text-primary': sendSms.canGetCode.value, 'text-gray-300': !sendSms.canGetCode.value}" @click="handleSend">{{ sendSms.tips.value }}</view>
<u-code :seconds="sendSms.seconds" :change-text="sendSms.changeText" ref="smsRef" @change="sendSms.codeChange"></u-code>
<u-modal :show="show" :title="t('captchaTitle')" :confirm-text="t('confirm')" :cancel-text="t('cancel')" :show-cancel-button="true" @cancel="show = false" @confirm="handleConfirm" confirmColor="var(--primary-color)">
<view class="flex mt-[20rpx]">
<u-input :placeholder="t('captchaPlaceholder')" border="surround" v-model="formData.captcha_code"></u-input>
<image :src="captcha.image.value" class="h-[76rpx] w-[auto] ml-[20rpx]" mode="heightFix" @click="captcha.refresh()"></image>
</view>
</u-modal>
</template>
<script lang="ts" setup>
import { ref, reactive, computed } from 'vue'
import { useSendSms } from '@/hooks/useSendSms'
import { useCaptcha } from '@/hooks/useCaptcha'
import { t } from '@/locale'
const prop = defineProps({
mobile: String,
type: String,
isAgree:{
type:Boolean,
default:true
},
modelValue: {
type: String,
default: ''
}
})
const emit = defineEmits(['update:modelValue'])
const value = computed({
get() {
return prop.modelValue
},
set(value) {
emit('update:modelValue', value)
}
})
const smsRef: any = ref(null)
const sendSms = useSendSms(smsRef)
const show = ref(false)
const formData:any = reactive({
mobile: '',
captcha_code: '',
captcha_key: '',
type: prop.type
})
const captcha = useCaptcha(formData)
const handleSend = async()=> {
if (smsRef.value.canGetCode) {
formData.mobile = prop.mobile
if (!prop.isAgree) {
uni.showToast({ title: t('isAgreeTips'), icon: 'none' });
return
}
if (uni.$u.test.isEmpty(formData.mobile)) {
uni.showToast({ title: t('mobilePlaceholder'), icon: 'none' });
return
}
if (!uni.$u.test.mobile(formData.mobile)) {
uni.showToast({ title: t('mobileError'), icon: 'none' });
return
}
await captcha.refresh()
show.value = true
}
}
const handleConfirm = async()=> {
if (uni.$u.test.isEmpty(formData.captcha_code)) { uni.showToast({ title: t('captchaPlaceholder'), icon:'none' }); return }
const sendRes = await sendSms.send(formData)
if (sendRes) {
value.value = sendRes
show.value = false
} else if (sendRes === false) {
captcha.refresh()
}
}
</script>
<style>
</style>