refactor(frontend) : extract CustomFieldDisplay shared component

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
This commit is contained in:
2026-03-08 14:37:43 +01:00
parent b696b5aa1f
commit a3fde7a191
3 changed files with 189 additions and 229 deletions

View File

@@ -213,79 +213,12 @@
</div>
<!-- Custom Fields Display - Editable or Read-only -->
<div v-if="displayedCustomFields.length" class="mt-4 pt-4 border-t border-gray-200">
<h4 class="font-semibold text-sm text-gray-700 mb-3">
Champs personnalisés
</h4>
<div class="grid grid-cols-1 md:grid-cols-2 gap-4">
<div
v-for="(field, index) in displayedCustomFields"
:key="resolveFieldKey(field, index)"
class="form-control"
>
<label class="label">
<span class="label-text text-sm">{{ resolveFieldName(field) }}</span>
<span v-if="resolveFieldRequired(field)" class="label-text-alt text-error">*</span>
</label>
<template v-if="isEditMode && !resolveFieldReadOnly(field)">
<input
v-if="resolveFieldType(field) === 'text'"
v-model="field.value"
type="text"
class="input input-bordered input-sm"
:required="resolveFieldRequired(field)"
@blur="updateComponentCustomField(field)"
>
<input
v-else-if="resolveFieldType(field) === 'number'"
v-model="field.value"
type="number"
class="input input-bordered input-sm"
:required="resolveFieldRequired(field)"
@blur="updateComponentCustomField(field)"
>
<select
v-else-if="resolveFieldType(field) === 'select'"
v-model="field.value"
class="select select-bordered select-sm"
:required="resolveFieldRequired(field)"
@change="updateComponentCustomField(field)"
>
<option value="">
Sélectionner...
</option>
<option v-for="option in resolveFieldOptions(field)" :key="option" :value="option">
{{ option }}
</option>
</select>
<div v-else-if="resolveFieldType(field) === 'boolean'" class="flex items-center gap-2">
<input
v-model="field.value"
type="checkbox"
class="checkbox checkbox-sm"
true-value="true"
false-value="false"
@change="updateComponentCustomField(field)"
>
<span class="text-sm">{{ String(field.value).toLowerCase() === 'true' ? 'Oui' : 'Non' }}</span>
</div>
<input
v-else-if="resolveFieldType(field) === 'date'"
v-model="field.value"
type="date"
class="input input-bordered input-sm"
:required="resolveFieldRequired(field)"
@blur="updateComponentCustomField(field)"
>
</template>
<template v-else>
<div class="input input-bordered input-sm bg-base-200">
{{ formatFieldDisplayValue(field) }}
</div>
</template>
</div>
</div>
</div>
<CommonCustomFieldDisplay
:fields="displayedCustomFields"
:is-edit-mode="isEditMode"
:columns="2"
@field-blur="updateComponentCustomField"
/>
<div class="mt-4 pt-4 border-t border-gray-200 space-y-3">
<div class="flex items-center justify-between">
@@ -381,15 +314,6 @@ import {
documentIcon,
downloadDocument,
} from '~/shared/utils/documentDisplayUtils'
import {
resolveFieldKey,
resolveFieldName,
resolveFieldType,
resolveFieldOptions,
resolveFieldRequired,
resolveFieldReadOnly,
formatFieldDisplayValue,
} from '~/shared/utils/entityCustomFieldLogic'
import { useEntityDocuments } from '~/composables/useEntityDocuments'
import { useEntityProductDisplay } from '~/composables/useEntityProductDisplay'
import { useEntityCustomFields } from '~/composables/useEntityCustomFields'