| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124 |
- <!--
- Liste déroulante dédiée à l'affichage d'objets Enum
- @see https://vuetifyjs.com/en/components/selects/
- -->
- <template>
- <main>
- <v-skeleton-loader
- v-if="pending"
- type="list-item"
- loading
- />
- <v-select
- v-else
- :value="modelValue"
- :label="$t(label ?? field)"
- :items="items"
- item-value="value"
- item-title="label"
- :no-data-text="$t('nothing-to-show') + '...'"
- :rules="rules"
- :disabled="readonly"
- :error="error || !!fieldViolations"
- :error-messages="errorMessage || (fieldViolations ? $t(fieldViolations) : '')"
- @update:modelValue="updateViolationState($event); $emit('update:modelValue', $event)"
- />
- </main>
- </template>
- <script setup lang="ts">
- import {useFieldViolation} from "~/composables/form/useFieldViolation";
- import {useEnumFetch} from "~/composables/data/useEnumFetch";
- const props = defineProps({
- /**
- * v-model
- */
- modelValue: {
- String,
- required: false,
- default: null
- },
- /**
- * Nom de l'Enum utilisée pour peupler la liste
- */
- enum: {
- type: String,
- required: true
- },
- /**
- * 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
- },
- /**
- * Définit si le champ est en lecture seule
- */
- readonly: {
- type: Boolean,
- required: 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
- },
- /**
- * Si le champ est en état d'erreur, quel est le message d'erreur ?
- */
- errorMessage: {
- type: String,
- required: false,
- default: null
- }
- })
- if (typeof props.enum === 'undefined') {
- throw new Error("missing 'enum' property for input")
- }
- const { fieldViolations, updateViolationState } = useFieldViolation(props.field)
- const { fetch } = useEnumFetch()
- const { data: items, pending } = fetch(props.enum)
- const emit = defineEmits(['update:modelValue', 'change'])
- const onModelUpdate = (event: any) => {
- updateViolationState(event)
- emit('change', event)
- emit('update:modelValue', event)
- }
- </script>
- <style scoped>
- </style>
|