feat(Form): new component (#439)

Co-authored-by: Benjamin Canac <canacb1@gmail.com>
This commit is contained in:
Romain Hamel
2023-07-31 15:22:14 +02:00
committed by GitHub
parent c37a927b4e
commit a3aba1abad
22 changed files with 945 additions and 17 deletions

View File

@@ -13,6 +13,7 @@
:class="inputClass"
v-bind="$attrs"
@input="onInput"
@blur="onBlur"
>
<slot />
@@ -35,6 +36,7 @@ import { ref, computed, onMounted, defineComponent } from 'vue'
import type { PropType } from 'vue'
import { defu } from 'defu'
import UIcon from '../elements/Icon.vue'
import { useFormEvents } from '../../composables/useFormEvents'
import { classNames } from '../../utils'
import { useAppConfig } from '#imports'
// TODO: Remove
@@ -138,13 +140,15 @@ export default defineComponent({
default: () => appConfig.ui.input
}
},
emits: ['update:modelValue'],
emits: ['update:modelValue', 'blur'],
setup (props, { emit, slots }) {
// TODO: Remove
const appConfig = useAppConfig()
const ui = computed<Partial<typeof appConfig.ui.input>>(() => defu({}, props.ui, appConfig.ui.input))
const { emitFormBlur } = useFormEvents()
const input = ref<HTMLInputElement | null>(null)
const autoFocus = () => {
@@ -157,6 +161,11 @@ export default defineComponent({
emit('update:modelValue', (event.target as HTMLInputElement).value)
}
const onBlur = (event: FocusEvent) => {
emitFormBlur()
emit('blur', event)
}
onMounted(() => {
setTimeout(() => {
autoFocus()
@@ -249,7 +258,8 @@ export default defineComponent({
trailingIconName,
trailingIconClass,
trailingWrapperIconClass,
onInput
onInput,
onBlur
}
}
})