| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152 |
- <!--
- Champs de saisie de texte, à placer dans un composant `UiForm`
- @see https://vuetifyjs.com/en/components/text-fields/
- -->
- <template>
- <v-text-field
- :model-value="modelValue"
- :label="(label || field) ? $t(label ?? field) : undefined"
- :rules="rules"
- :disabled="readonly"
- :type="(type === 'password' && show) ? 'text' : type"
- :error="error || !!fieldViolations"
- :error-messages="errorMessage || (fieldViolations ? $t(fieldViolations) : '')"
- :append-icon="type === 'password' ? (show ? 'mdi-eye' : 'mdi-eye-off') : ''"
- :variant="variant"
- @click:append="show = !show"
- @update:model-value="onUpdate($event)"
- @change="onChange($event)"
- />
- <!-- v-cleave="mask"-->
- </template>
- <script setup lang="ts">
- import {ref} from "@vue/reactivity";
- import {useFieldViolation} from "~/composables/form/useFieldViolation";
- import {useNuxtApp} from "#app";
- import {useI18n} from "vue-i18n";
- import {mask} from "vue-the-mask";
- import {PropType} from "@vue/runtime-core";
- const props = defineProps({
- /**
- * v-model
- */
- modelValue: {
- type: [String, Number] as PropType<string | number | null>,
- required: false,
- default: null
- },
- /**
- * Nom de la propriété d'une entité lorsque l'input concerne cette propriété
- * - Utilisé par la validation
- * - Laisser null si le champ ne s'applique pas à une entité
- */
- field: {
- type: String,
- required: false,
- default: null
- },
- /**
- * Label du champ
- * Si non défini, c'est le nom de propriété qui est utilisé
- */
- label: {
- type: String,
- required: false,
- default: null
- },
- /**
- * Type d'input HTML
- * @see https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/button
- */
- type: {
- type: String,
- required: false,
- default: null
- },
- /**
- * Définit si le champ est en lecture seule
- */
- readonly: {
- type: Boolean,
- required: false,
- default: false
- },
- /**
- * Règles de validation
- * @see https://vuetify.cn/en/components/forms/#validation-with-submit-clear
- */
- rules: {
- type: Array,
- required: false,
- default: () => []
- },
- /**
- * Le champ est-il actuellement en état d'erreur
- */
- error: {
- type: Boolean,
- required: false,
- default: false
- },
- /**
- * Si le champ est en état d'erreur, quel est le message d'erreur?
- */
- errorMessage: {
- type: String,
- required: false,
- default: null
- },
- /**
- * Masque de saisie
- * @see https://github.com/nosir/cleave.js/
- */
- mask: {
- type: [Array, Boolean],
- required: false,
- default: false
- },
- /**
- * @see https://vuetifyjs.com/en/api/v-autocomplete/#props-variant
- */
- variant: {
- type: String,
- required: false,
- default: 'filled'
- }
- })
- const { app } = useNuxtApp()
- const i18n = useI18n()
- const { fieldViolations, updateViolationState } = useFieldViolation(props.field)
- const show = ref(false)
- const emit = defineEmits(['update:model-value', 'change'])
- const onUpdate = (event: string) => {
- emit('update:model-value', event)
- }
- const onChange = (event: Event | undefined) => {
- updateViolationState(event)
- emit('change', event)
- }
- // const label = computed(() => {
- // if (props.label)
- // })
- </script>
- <style scoped lang="scss">
- input:read-only{
- color: rgb(var(--v-theme-neutral));
- }
- </style>
|