| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495 |
- <!--
- Case à cocher, à placer dans un composant `UiForm`
- @see https://vuetifyjs.com/en/components/checkboxes/
- -->
- <template>
- <v-checkbox
- :model-value="modelValue"
- :label="$t(fieldLabel)"
- :disabled="readonly"
- :error="error || !!fieldViolations"
- :error-messages="errorMessage || fieldViolations ? $t(fieldViolations) : ''"
- class="py-1"
- @update:model-value="onUpdate"
- />
- </template>
- <script setup lang="ts">
- import { useFieldViolation } from '~/composables/form/useFieldViolation'
- const props = defineProps({
- /**
- * v-model
- */
- modelValue: {
- type: Boolean,
- required: false,
- },
- /**
- * 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,
- 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,
- },
- /**
- * Si le champ est en état d'erreur, quel est le message d'erreur?
- */
- errorMessage: {
- type: String,
- required: false,
- default: null,
- },
- })
- const { fieldViolations, updateViolationState } = useFieldViolation(props.field)
- const fieldLabel: string = props.label ?? props.field
- const emit = defineEmits(['update:model-value'])
- const onUpdate = (event: boolean) => {
- updateViolationState(event)
- emit('update:model-value', event)
- }
- </script>
- <style scoped></style>
|