v6 update

This commit is contained in:
Mohit Panjwani
2022-01-10 16:06:17 +05:30
parent b770e6277f
commit bdea879273
722 changed files with 19047 additions and 9186 deletions

View File

@ -0,0 +1,147 @@
<template>
<form @submit.prevent="saveEmailConfig">
<div class="grid grid-cols-1 gap-4 mb-4 md:grid-cols-2 md:mb-6">
<BaseInputGroup
:label="$t('wizard.mail.driver')"
:content-loading="isFetchingInitialData"
:error="
v$.basicMailConfig.mail_driver.$error &&
v$.basicMailConfig.mail_driver.$errors[0].$message
"
required
>
<BaseMultiselect
v-model="basicMailConfig.mail_driver"
:invalid="v$.basicMailConfig.mail_driver.$error"
:options="mailDriverStore.mail_drivers"
:can-deselect="false"
:content-loading="isFetchingInitialData"
@update:modelValue="onChangeDriver"
/>
</BaseInputGroup>
</div>
<div class="grid grid-cols-1 gap-4 mb-6 md:grid-cols-2">
<BaseInputGroup
:label="$t('wizard.mail.from_name')"
:content-loading="isFetchingInitialData"
:error="
v$.basicMailConfig.from_name.$error &&
v$.basicMailConfig.from_name.$errors[0].$message
"
required
>
<BaseInput
v-model.trim="basicMailConfig.from_name"
:invalid="v$.basicMailConfig.from_name.$error"
:content-loading="isFetchingInitialData"
type="text"
name="name"
@input="v$.basicMailConfig.from_name.$touch()"
/>
</BaseInputGroup>
<BaseInputGroup
:label="$t('wizard.mail.from_mail')"
:content-loading="isFetchingInitialData"
:error="
v$.basicMailConfig.from_mail.$error &&
v$.basicMailConfig.from_mail.$errors[0].$message
"
required
>
<BaseInput
v-model.trim="basicMailConfig.from_mail"
:invalid="v$.basicMailConfig.from_mail.$error"
:content-loading="isFetchingInitialData"
type="text"
@input="v$.basicMailConfig.from_mail.$touch()"
/>
</BaseInputGroup>
</div>
<BaseButton
:loading="isSaving"
:disabled="isSaving"
:content-loading="isFetchingInitialData"
class="mt-4"
>
<template #left="slotProps">
<BaseIcon v-if="!isSaving" name="SaveIcon" :class="slotProps.class" />
</template>
{{ $t('general.save') }}
</BaseButton>
</form>
</template>
<script setup>
import { required, email, helpers } from '@vuelidate/validators'
import useVuelidate from '@vuelidate/core'
import { useI18n } from 'vue-i18n'
import { useMailDriverStore } from '@/scripts/admin/stores/mail-driver'
import { computed } from 'vue'
const props = defineProps({
isSaving: {
type: Boolean,
require: true,
default: false,
},
isFetchingInitialData: {
type: Boolean,
require: true,
default: false,
},
})
const emit = defineEmits(['submit-data', 'on-change-driver'])
const { t } = useI18n()
const mailDriverStore = useMailDriverStore()
const basicMailConfig = computed(() => {
return mailDriverStore.basicMailConfig
})
const mailDrivers = computed(() => {
return mailDriverStore.mail_drivers
})
basicMailConfig.value.mail_driver = 'mail'
const rules = computed(() => {
return {
basicMailConfig: {
mail_driver: {
required: helpers.withMessage(t('validation.required'), required),
},
from_mail: {
required: helpers.withMessage(t('validation.required'), required),
email: helpers.withMessage(t('validation.email_incorrect'), email),
},
from_name: {
required: helpers.withMessage(t('validation.required'), required),
},
},
}
})
const v$ = useVuelidate(
rules,
computed(() => mailDriverStore)
)
function saveEmailConfig() {
v$.value.$touch()
if (!v$.value.$invalid) {
emit('submit-data', mailDriverStore.basicMailConfig)
}
return false
}
function onChangeDriver() {
v$.value.basicMailConfig.mail_driver.$touch()
emit('on-change-driver', mailDriverStore?.basicMailConfig?.mail_driver)
}
</script>

View File

@ -0,0 +1,237 @@
<template>
<form @submit.prevent="saveEmailConfig">
<div class="grid grid-cols-1 gap-4 mb-4 md:grid-cols-2 lg:mb-6 md:mb-6">
<BaseInputGroup
:label="$t('wizard.mail.driver')"
:content-loading="isFetchingInitialData"
:error="
v$.mailgunConfig.mail_driver.$error &&
v$.mailgunConfig.mail_driver.$errors[0].$message
"
required
>
<BaseMultiselect
v-model="mailgunConfig.mail_driver"
:options="mailDriverStore.mail_drivers"
:can-deselect="false"
:invalid="v$.mailgunConfig.mail_driver.$error"
:content-loading="isFetchingInitialData"
@update:modelValue="onChangeDriver"
/>
</BaseInputGroup>
<BaseInputGroup
:label="$t('wizard.mail.mailgun_domain')"
:content-loading="isFetchingInitialData"
:error="
v$.mailgunConfig.mail_mailgun_domain.$error &&
v$.mailgunConfig.mail_mailgun_domain.$errors[0].$message
"
required
>
<BaseInput
v-model.trim="mailgunConfig.mail_mailgun_domain"
:invalid="v$.mailgunConfig.mail_mailgun_domain.$error"
:content-loading="isFetchingInitialData"
type="text"
name="mailgun_domain"
@input="v$.mailgunConfig.mail_mailgun_domain.$touch()"
/>
</BaseInputGroup>
</div>
<div class="grid grid-cols-1 gap-4 mb-4 md:grid-cols-2 lg:mb-6 md:mb-6">
<BaseInputGroup
:label="$t('wizard.mail.mailgun_secret')"
:content-loading="isFetchingInitialData"
:error="
v$.mailgunConfig.mail_mailgun_secret.$error &&
v$.mailgunConfig.mail_mailgun_secret.$errors[0].$message
"
required
>
<BaseInput
v-model.trim="mailgunConfig.mail_mailgun_secret"
:invalid="v$.mailgunConfig.mail_mailgun_secret.$error"
:type="getInputType"
:content-loading="isFetchingInitialData"
name="mailgun_secret"
autocomplete="off"
data-lpignore="true"
@input="v$.mailgunConfig.mail_mailgun_secret.$touch()"
>
<template #right>
<BaseIcon
v-if="isShowPassword"
name="EyeOffIcon"
class="w-5 h-5 mr-1 text-gray-500 cursor-pointer"
@click="isShowPassword = !isShowPassword"
/>
<BaseIcon
v-else
name="EyeIcon"
class="w-5 h-5 mr-1 text-gray-500 cursor-pointer"
@click="isShowPassword = !isShowPassword"
/>
</template>
</BaseInput>
</BaseInputGroup>
<BaseInputGroup
:label="$t('wizard.mail.mailgun_endpoint')"
:content-loading="isFetchingInitialData"
:error="
v$.mailgunConfig.mail_mailgun_endpoint.$error &&
v$.mailgunConfig.mail_mailgun_endpoint.$errors[0].$message
"
required
>
<BaseInput
v-model.trim="mailgunConfig.mail_mailgun_endpoint"
:invalid="v$.mailgunConfig.mail_mailgun_endpoint.$error"
:content-loading="isFetchingInitialData"
type="text"
name="mailgun_endpoint"
@input="v$.mailgunConfig.mail_mailgun_endpoint.$touch()"
/>
</BaseInputGroup>
</div>
<div class="grid grid-cols-1 gap-4 mb-6 md:grid-cols-2">
<BaseInputGroup
:label="$t('wizard.mail.from_mail')"
:content-loading="isFetchingInitialData"
:error="
v$.mailgunConfig.from_mail.$error &&
v$.mailgunConfig.from_mail.$errors[0].$message
"
required
>
<BaseInput
v-model.trim="mailgunConfig.from_mail"
name="from_mail"
type="text"
:invalid="v$.mailgunConfig.from_mail.$error"
:content-loading="isFetchingInitialData"
@input="v$.mailgunConfig.from_mail.$touch()"
/>
</BaseInputGroup>
<BaseInputGroup
:label="$t('wizard.mail.from_name')"
:content-loading="isFetchingInitialData"
:error="
v$.mailgunConfig.from_name.$error &&
v$.mailgunConfig.from_name.$errors[0].$message
"
required
>
<BaseInput
v-model.trim="mailgunConfig.from_name"
:invalid="v$.mailgunConfig.from_name.$error"
:content-loading="isFetchingInitialData"
type="text"
name="from_name"
@input="v$.mailgunConfig.from_name.$touch()"
/>
</BaseInputGroup>
</div>
<BaseButton
:loading="loading"
:disabled="isSaving"
:content-loading="isFetchingInitialData"
class="mt-4"
>
<template #left="slotProps">
<BaseIcon v-if="!isSaving" name="SaveIcon" :class="slotProps.class" />
</template>
{{ $t('general.save') }}
</BaseButton>
</form>
</template>
<script setup>
import { required, email, helpers } from '@vuelidate/validators'
import { useI18n } from 'vue-i18n'
import useVuelidate from '@vuelidate/core'
import { useMailDriverStore } from '@/scripts/admin/stores/mail-driver'
import { computed, onMounted, ref } from 'vue'
const props = defineProps({
isSaving: {
type: Boolean,
require: true,
default: false,
},
isFetchingInitialData: {
type: Boolean,
require: true,
default: false,
},
})
const emit = defineEmits(['submit-data', 'on-change-driver'])
let isShowPassword = ref(false)
const mailDriverStore = useMailDriverStore()
const { t } = useI18n()
const mailgunConfig = computed(() => {
return mailDriverStore.mailgunConfig
})
const getInputType = computed(() => {
if (isShowPassword.value) {
return 'text'
}
return 'password'
})
mailgunConfig.value.mail_driver = 'mailgun'
const rules = computed(() => {
return {
mailgunConfig: {
mail_driver: {
required: helpers.withMessage(t('validation.required'), required),
},
mail_mailgun_domain: {
required: helpers.withMessage(t('validation.required'), required),
},
mail_mailgun_endpoint: {
required: helpers.withMessage(t('validation.required'), required),
},
mail_mailgun_secret: {
required: helpers.withMessage(t('validation.required'), required),
},
from_mail: {
required: helpers.withMessage(t('validation.required'), required),
email,
},
from_name: {
required: helpers.withMessage(t('validation.required'), required),
},
},
}
})
const v$ = useVuelidate(
rules,
computed(() => mailDriverStore)
)
function saveEmailConfig() {
v$.value.$touch()
if (!v$.value.$invalid) {
emit('submit-data', mailDriverStore.mailgunConfig)
}
return false
}
function onChangeDriver() {
v$.value.mailgunConfig.mail_driver.$touch()
emit('on-change-driver', mailDriverStore.mailgunConfig.mail_driver)
}
</script>

View File

@ -0,0 +1,278 @@
<template>
<form @submit.prevent="saveEmailConfig">
<div class="grid grid-cols-1 gap-4 mb-4 md:grid-cols-2 md:mb-6">
<BaseInputGroup
:label="$t('wizard.mail.driver')"
:content-loading="isFetchingInitialData"
:error="
v$.sesConfig.mail_driver.$error &&
v$.sesConfig.mail_driver.$errors[0].$message
"
required
>
<BaseMultiselect
v-model="sesConfig.mail_driver"
:options="mailDriverStore.mail_drivers"
:can-deselect="false"
:content-loading="isFetchingInitialData"
:invalid="v$.sesConfig.mail_driver.$error"
@update:modelValue="onChangeDriver"
/>
</BaseInputGroup>
<BaseInputGroup
:label="$t('wizard.mail.host')"
:content-loading="isFetchingInitialData"
:error="
v$.sesConfig.mail_host.$error &&
v$.sesConfig.mail_host.$errors[0].$message
"
required
>
<BaseInput
v-model.trim="sesConfig.mail_host"
:invalid="v$.sesConfig.mail_host.$error"
:content-loading="isFetchingInitialData"
type="text"
name="mail_host"
@input="v$.sesConfig.mail_host.$touch()"
/>
</BaseInputGroup>
</div>
<div class="grid grid-cols-1 gap-4 mb-4 md:grid-cols-2 md:mb-6">
<BaseInputGroup
:label="$t('wizard.mail.port')"
:content-loading="isFetchingInitialData"
:error="
v$.sesConfig.mail_port.$error &&
v$.sesConfig.mail_port.$errors[0].$message
"
required
>
<BaseInput
v-model.trim="sesConfig.mail_port"
:invalid="v$.sesConfig.mail_port.$error"
:content-loading="isFetchingInitialData"
type="text"
name="mail_port"
@input="v$.sesConfig.mail_port.$touch()"
/>
</BaseInputGroup>
<BaseInputGroup
:label="$t('wizard.mail.encryption')"
:content-loading="isFetchingInitialData"
:error="
v$.sesConfig.mail_encryption.$error &&
v$.sesConfig.mail_encryption.$errors[0].$message
"
required
>
<BaseMultiselect
v-model.trim="sesConfig.mail_encryption"
:invalid="v$.sesConfig.mail_encryption.$error"
:options="encryptions"
:content-loading="isFetchingInitialData"
@input="v$.sesConfig.mail_encryption.$touch()"
/>
</BaseInputGroup>
</div>
<div class="grid grid-cols-1 gap-4 mb-4 md:grid-cols-2 md:mb-6">
<BaseInputGroup
:label="$t('wizard.mail.from_mail')"
:content-loading="isFetchingInitialData"
:error="
v$.sesConfig.from_mail.$error &&
v$.sesConfig.from_mail.$errors[0].$message
"
required
>
<BaseInput
v-model.trim="sesConfig.from_mail"
:invalid="v$.sesConfig.from_mail.$error"
:content-loading="isFetchingInitialData"
type="text"
name="from_mail"
@input="v$.sesConfig.from_mail.$touch()"
/>
</BaseInputGroup>
<BaseInputGroup
:label="$t('wizard.mail.from_name')"
:content-loading="isFetchingInitialData"
:error="
v$.sesConfig.from_name.$error &&
v$.sesConfig.from_name.$errors[0].$message
"
required
>
<BaseInput
v-model.trim="sesConfig.from_name"
:invalid="v$.sesConfig.from_name.$error"
:content-loading="isFetchingInitialData"
type="text"
name="name"
@input="v$.sesConfig.from_name.$touch()"
/>
</BaseInputGroup>
</div>
<div class="grid grid-cols-1 gap-4 mb-6 md:grid-cols-2">
<BaseInputGroup
:label="$t('wizard.mail.ses_key')"
:content-loading="isFetchingInitialData"
:error="
v$.sesConfig.mail_ses_key.$error &&
v$.sesConfig.mail_ses_key.$errors[0].$message
"
required
>
<BaseInput
v-model.trim="sesConfig.mail_ses_key"
:invalid="v$.sesConfig.mail_ses_key.$error"
:content-loading="isFetchingInitialData"
type="text"
name="mail_ses_key"
@input="v$.sesConfig.mail_ses_key.$touch()"
/>
</BaseInputGroup>
<BaseInputGroup
:label="$t('wizard.mail.ses_secret')"
:content-loading="isFetchingInitialData"
:error="
v$.sesConfig.mail_ses_secret.$error &&
v$.sesConfig.mail_ses_secret.$errors[0].$message
"
required
>
<BaseInput
v-model.trim="sesConfig.mail_ses_secret"
:invalid="v$.sesConfig.mail_ses_secret.$error"
:type="getInputType"
:content-loading="isFetchingInitialData"
name="mail_ses_secret"
autocomplete="off"
data-lpignore="true"
@input="v$.sesConfig.mail_ses_secret.$touch()"
>
<template #right>
<BaseIcon
v-if="isShowPassword"
name="EyeOffIcon"
class="w-5 h-5 mr-1 text-gray-500 cursor-pointer"
@click="isShowPassword = !isShowPassword"
/>
<BaseIcon
v-else
name="EyeIcon"
class="w-5 h-5 mr-1 text-gray-500 cursor-pointer"
@click="isShowPassword = !isShowPassword"
/>
</template>
</BaseInput>
</BaseInputGroup>
</div>
<BaseButton
:loading="isSaving"
:disabled="isSaving"
:content-loading="isFetchingInitialData"
class="mt-4"
>
<template #left="slotProps">
<BaseIcon v-if="!isSaving" name="SaveIcon" :class="slotProps.class" />
</template>
{{ $t('general.save') }}
</BaseButton>
</form>
</template>
<script setup>
import { computed, reactive, ref } from 'vue'
import { required, email, numeric, helpers } from '@vuelidate/validators'
import useVuelidate from '@vuelidate/core'
import { useI18n } from 'vue-i18n'
import { useMailDriverStore } from '@/scripts/admin/stores/mail-driver'
const props = defineProps({
isSaving: {
type: Boolean,
require: true,
default: false,
},
isFetchingInitialData: {
type: Boolean,
require: true,
default: false,
},
})
const emit = defineEmits(['submit-data', 'on-change-driver'])
const { t } = useI18n()
const encryptions = reactive(['tls', 'ssl', 'starttls'])
let isShowPassword = ref(false)
const mailDriverStore = useMailDriverStore()
const sesConfig = computed(() => {
return mailDriverStore.sesConfig
})
sesConfig.value.mail_driver = 'ses'
const rules = computed(() => {
return {
sesConfig: {
mail_driver: {
required: helpers.withMessage(t('validation.required'), required),
},
mail_host: {
required: helpers.withMessage(t('validation.required'), required),
},
mail_port: {
required: helpers.withMessage(t('validation.required'), required),
numeric,
},
mail_ses_key: {
required: helpers.withMessage(t('validation.required'), required),
},
mail_ses_secret: {
required: helpers.withMessage(t('validation.required'), required),
},
mail_encryption: {
required: helpers.withMessage(t('validation.required'), required),
},
from_mail: {
required: helpers.withMessage(t('validation.required'), required),
email: helpers.withMessage(t('validation.email_incorrect'), email),
},
from_name: {
required: helpers.withMessage(t('validation.required'), required),
},
},
}
})
const v$ = useVuelidate(
rules,
computed(() => mailDriverStore)
)
async function saveEmailConfig() {
v$.value.$touch()
if (!v$.value.$invalid) {
emit('submit-data', mailDriverStore.sesConfig)
}
return false
}
function onChangeDriver() {
v$.value.sesConfig.mail_driver.$touch()
emit('on-change-driver', mailDriverStore.sesConfig.mail_driver)
}
</script>

View File

@ -0,0 +1,265 @@
<template>
<form @submit.prevent="saveEmailConfig">
<div class="grid grid-cols-1 gap-4 mb-4 md:grid-cols-2 md:mb-6">
<BaseInputGroup
:label="$t('wizard.mail.driver')"
:content-loading="isFetchingInitialData"
:error="
v$.smtpConfig.mail_driver.$error &&
v$.smtpConfig.mail_driver.$errors[0].$message
"
required
>
<BaseMultiselect
v-model="smtpConfig.mail_driver"
:options="mailDriverStore.mail_drivers"
:can-deselect="false"
:content-loading="isFetchingInitialData"
:invalid="v$.smtpConfig.mail_driver.$error"
@update:modelValue="onChangeDriver"
/>
</BaseInputGroup>
<BaseInputGroup
:label="$t('wizard.mail.host')"
:content-loading="isFetchingInitialData"
:error="
v$.smtpConfig.mail_host.$error &&
v$.smtpConfig.mail_host.$errors[0].$message
"
required
>
<BaseInput
v-model.trim="smtpConfig.mail_host"
:invalid="v$.smtpConfig.mail_host.$error"
:content-loading="isFetchingInitialData"
type="text"
name="mail_host"
@input="v$.smtpConfig.mail_host.$touch()"
/>
</BaseInputGroup>
</div>
<div class="grid grid-cols-1 gap-4 mb-4 md:grid-cols-2 md:mb-6">
<BaseInputGroup
:label="$t('wizard.mail.username')"
:content-loading="isFetchingInitialData"
>
<BaseInput
v-model.trim="smtpConfig.mail_username"
:content-loading="isFetchingInitialData"
type="text"
name="db_name"
/>
</BaseInputGroup>
<BaseInputGroup
:label="$t('wizard.mail.password')"
:content-loading="isFetchingInitialData"
>
<BaseInput
v-model.trim="smtpConfig.mail_password"
:type="getInputType"
:content-loading="isFetchingInitialData"
autocomplete="off"
data-lpignore="true"
name="password"
>
<template #right>
<BaseIcon
v-if="isShowPassword"
name="EyeOffIcon"
class="w-5 h-5 mr-1 text-gray-500 cursor-pointer"
@click="isShowPassword = !isShowPassword"
/>
<BaseIcon
v-else
name="EyeIcon"
class="w-5 h-5 mr-1 text-gray-500 cursor-pointer"
@click="isShowPassword = !isShowPassword"
/>
</template>
</BaseInput>
</BaseInputGroup>
</div>
<div class="grid grid-cols-1 gap-4 mb-4 md:grid-cols-2 md:mb-6">
<BaseInputGroup
:label="$t('wizard.mail.port')"
:error="
v$.smtpConfig.mail_port.$error &&
v$.smtpConfig.mail_port.$errors[0].$message
"
:content-loading="isFetchingInitialData"
required
>
<BaseInput
v-model.trim="smtpConfig.mail_port"
:invalid="v$.smtpConfig.mail_port.$error"
:content-loading="isFetchingInitialData"
type="text"
name="mail_port"
@input="v$.smtpConfig.mail_port.$touch()"
/>
</BaseInputGroup>
<BaseInputGroup
:label="$t('wizard.mail.encryption')"
:error="
v$.smtpConfig.mail_encryption.$error &&
v$.smtpConfig.mail_encryption.$errors[0].$message
"
:content-loading="isFetchingInitialData"
required
>
<BaseMultiselect
v-model.trim="smtpConfig.mail_encryption"
:options="encryptions"
:can-deselect="false"
:invalid="v$.smtpConfig.mail_encryption.$error"
:content-loading="isFetchingInitialData"
@input="v$.smtpConfig.mail_encryption.$touch()"
/>
</BaseInputGroup>
</div>
<div class="grid grid-cols-1 gap-4 mb-6 md:grid-cols-2">
<BaseInputGroup
:label="$t('wizard.mail.from_mail')"
:error="
v$.smtpConfig.from_mail.$error &&
v$.smtpConfig.from_mail.$errors[0].$message
"
:content-loading="isFetchingInitialData"
required
>
<BaseInput
v-model.trim="smtpConfig.from_mail"
:invalid="v$.smtpConfig.from_mail.$error"
:content-loading="isFetchingInitialData"
type="text"
name="from_mail"
@input="v$.smtpConfig.from_mail.$touch()"
/>
</BaseInputGroup>
<BaseInputGroup
:label="$t('wizard.mail.from_name')"
:error="
v$.smtpConfig.from_name.$error &&
v$.smtpConfig.from_name.$errors[0].$message
"
:content-loading="isFetchingInitialData"
required
>
<BaseInput
v-model.trim="smtpConfig.from_name"
:invalid="v$.smtpConfig.from_name.$error"
:content-loading="isFetchingInitialData"
type="text"
name="from_name"
@input="v$.smtpConfig.from_name.$touch()"
/>
</BaseInputGroup>
</div>
<BaseButton
:loading="isSaving"
:disabled="isSaving"
:content-loading="isFetchingInitialData"
class="mt-4"
>
<template #left="slotProps">
<BaseIcon v-if="!isSaving" name="SaveIcon" :class="slotProps.class" />
</template>
{{ $t('general.save') }}
</BaseButton>
</form>
</template>
<script setup>
import { reactive, ref, computed } from 'vue'
import { required, email, numeric, helpers } from '@vuelidate/validators'
import useVuelidate from '@vuelidate/core'
import { useI18n } from 'vue-i18n'
import { useMailDriverStore } from '@/scripts/admin/stores/mail-driver'
const props = defineProps({
isSaving: {
type: Boolean,
require: true,
default: false,
},
isFetchingInitialData: {
type: Boolean,
require: true,
default: false,
},
})
const emit = defineEmits(['submit-data', 'on-change-driver'])
let isShowPassword = ref(false)
const encryptions = reactive(['tls', 'ssl', 'starttls'])
const { t } = useI18n()
const mailDriverStore = useMailDriverStore()
const smtpConfig = computed(() => {
return mailDriverStore.smtpConfig
})
const getInputType = computed(() => {
if (isShowPassword.value) {
return 'text'
}
return 'password'
})
smtpConfig.value.mail_driver = 'smtp'
const rules = computed(() => {
return {
smtpConfig: {
mail_driver: {
required: helpers.withMessage(t('validation.required'), required),
},
mail_host: {
required: helpers.withMessage(t('validation.required'), required),
},
mail_port: {
required: helpers.withMessage(t('validation.required'), required),
numeric: helpers.withMessage(t('validation.numbers_only'), numeric),
},
mail_encryption: {
required: helpers.withMessage(t('validation.required'), required),
},
from_mail: {
required: helpers.withMessage(t('validation.required'), required),
email: helpers.withMessage(t('validation.email_incorrect'), email),
},
from_name: {
required: helpers.withMessage(t('validation.required'), required),
},
},
}
})
const v$ = useVuelidate(
rules,
computed(() => mailDriverStore)
)
async function saveEmailConfig() {
v$.value.$touch()
if (!v$.value.$invalid) {
emit('submit-data', mailDriverStore.smtpConfig)
}
return false
}
function onChangeDriver() {
v$.value.smtpConfig.mail_driver.$touch()
emit('on-change-driver', mailDriverStore.smtpConfig.mail_driver)
}
</script>