frontend: normalize auth oauth i18n and error toasts
This commit is contained in:
@@ -5,7 +5,7 @@
|
||||
:data-testid="`${testIdPrefix}-create-account-email`"
|
||||
type="email"
|
||||
class="input w-full"
|
||||
placeholder="you@example.com"
|
||||
:placeholder="t('auth.emailPlaceholder')"
|
||||
:disabled="isSubmitting || isSendingCode"
|
||||
/>
|
||||
<input
|
||||
@@ -13,7 +13,7 @@
|
||||
:data-testid="`${testIdPrefix}-create-account-password`"
|
||||
type="password"
|
||||
class="input w-full"
|
||||
placeholder="Password"
|
||||
:placeholder="t('auth.passwordPlaceholder')"
|
||||
:disabled="isSubmitting"
|
||||
/>
|
||||
<div v-if="turnstileEnabled && turnstileSiteKey" class="space-y-2">
|
||||
@@ -26,16 +26,16 @@
|
||||
/>
|
||||
</div>
|
||||
<div class="flex gap-3">
|
||||
<input
|
||||
v-model="verifyCode"
|
||||
:data-testid="`${testIdPrefix}-create-account-verify-code`"
|
||||
type="text"
|
||||
<input
|
||||
v-model="verifyCode"
|
||||
:data-testid="`${testIdPrefix}-create-account-verify-code`"
|
||||
type="text"
|
||||
inputmode="numeric"
|
||||
maxlength="6"
|
||||
class="input min-w-0 flex-1"
|
||||
placeholder="123456"
|
||||
:disabled="isSubmitting"
|
||||
/>
|
||||
maxlength="6"
|
||||
class="input min-w-0 flex-1"
|
||||
placeholder="123456"
|
||||
:disabled="isSubmitting"
|
||||
/>
|
||||
<button
|
||||
:data-testid="`${testIdPrefix}-create-account-send-code`"
|
||||
type="button"
|
||||
@@ -74,7 +74,7 @@
|
||||
:disabled="isSubmitting || !email.trim() || password.length < 6 || (invitationCodeEnabled && !invitationCode.trim())"
|
||||
@click="handleSubmit"
|
||||
>
|
||||
{{ isSubmitting ? t('common.processing') : 'Create account' }}
|
||||
{{ isSubmitting ? t('common.processing') : t('auth.createAccount') }}
|
||||
</button>
|
||||
<button
|
||||
type="button"
|
||||
@@ -82,18 +82,8 @@
|
||||
:disabled="isSubmitting"
|
||||
@click="emitSwitchToBind"
|
||||
>
|
||||
I already have an account
|
||||
{{ t('auth.alreadyHaveAccount') }}
|
||||
</button>
|
||||
<transition name="fade">
|
||||
<p v-if="sendCodeError" class="text-sm text-red-600 dark:text-red-400">
|
||||
{{ sendCodeError }}
|
||||
</p>
|
||||
</transition>
|
||||
<transition name="fade">
|
||||
<p v-if="errorMessage" class="text-sm text-red-600 dark:text-red-400">
|
||||
{{ errorMessage }}
|
||||
</p>
|
||||
</transition>
|
||||
</form>
|
||||
</template>
|
||||
|
||||
@@ -102,6 +92,7 @@ import { onMounted, onUnmounted, ref, watch } from 'vue'
|
||||
import { useI18n } from 'vue-i18n'
|
||||
import TurnstileWidget from '@/components/TurnstileWidget.vue'
|
||||
import { getPublicSettings, sendPendingOAuthVerifyCode } from '@/api/auth'
|
||||
import { useAppStore } from '@/stores'
|
||||
|
||||
export type PendingOAuthCreateAccountPayload = {
|
||||
email: string
|
||||
@@ -123,6 +114,7 @@ const emit = defineEmits<{
|
||||
}>()
|
||||
|
||||
const { t } = useI18n()
|
||||
const appStore = useAppStore()
|
||||
|
||||
const email = ref('')
|
||||
const password = ref('')
|
||||
@@ -148,6 +140,21 @@ watch(
|
||||
{ immediate: true }
|
||||
)
|
||||
|
||||
watch(sendCodeError, value => {
|
||||
if (value) {
|
||||
appStore.showError(value)
|
||||
}
|
||||
})
|
||||
|
||||
watch(
|
||||
() => props.errorMessage,
|
||||
value => {
|
||||
if (value) {
|
||||
appStore.showError(value)
|
||||
}
|
||||
}
|
||||
)
|
||||
|
||||
function clearCountdown() {
|
||||
if (countdownTimer) {
|
||||
clearInterval(countdownTimer)
|
||||
|
||||
Reference in New Issue
Block a user