| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596 |
- <!--
- Champs de saisie de texte
- @see https://vuetifyjs.com/en/components/text-fields/
- -->
- <template>
- <v-text-field
- autocomplete="off"
- :value="data"
- :label="$t(label_field)"
- :rules="rules"
- :disabled="readonly"
- :type="type === 'password' ? (show ? 'text' : type) : type"
- :error="error || !!violation"
- :error-messages="errorMessage || (violation ? $t(violation) : '')"
- @change="onChange($event); $emit('change', $event)"
- @input="$emit('input', $event, field)"
- v-mask="mask"
- :append-icon="type === 'password' ? (show ? 'mdi-eye' : 'mdi-eye-off') : ''"
- @click:append="show = !show"
- />
- </template>
- <script setup lang="ts">
- import {mask} from 'vue-the-mask';
- import {ref} from "@vue/reactivity";
- import {useFieldViolation} from "~/composables/form/useFieldViolation";
- const props = defineProps({
- label: {
- type: String,
- required: false,
- default: null
- },
- field: {
- type: String,
- required: false,
- default: null
- },
- type: {
- type: String,
- required: false,
- default: null
- },
- data: {
- type: [String, Number],
- required: false,
- default: null
- },
- readonly: {
- type: Boolean,
- required: false
- },
- rules: {
- type: Array,
- required: false,
- default: () => []
- },
- error: {
- type: Boolean,
- required: false
- },
- errorMessage: {
- type: String,
- required: false,
- default: null
- },
- mask: {
- type: [Array, Boolean],
- required: false,
- default: false
- }
- })
- const { app, emit } = useNuxtApp()
- const { violation, onChange } = useFieldViolation(props.field, emit)
- const show = ref(false)
- const label_field = props.label ?? props.field
- app.directive('mask', {
- mask: (el: any, binding: any, vnode: any, oldVnode: any) => {
- if (!binding.value) return;
- mask(el, binding, vnode, oldVnode);
- }
- })
- </script>
- <style scoped>
- input:read-only{
- color: #666 !important;
- }
- </style>
|