feat(directory) : refonte UI des fiches + onglet rapport (LST-72)
Fiches Client / Prospect / Prestataire (onglet Rapport mis à part) : - Champs email/téléphone : composants MalioInputEmail / MalioInputPhone - Grilles en 4 colonnes (Info + blocs Contact/Adresse) - Boutons « Nouveau contact/adresse » en secondary ; « Enregistrer » en taille Malio standard ; marge form↔bouton homogène entre onglets - Bouton retour ghost (mdi:arrow-left-bold) comme Starseed - Adresse : flux CP → ville → rue (rue conditionnée au CP+ville, cascade de reset), titre du bloc = libellé saisi - Suppression d'un bloc Contact/Adresse : modal de confirmation (logique centralisée dans useDirectoryDetail) Onglet Rapport : - Bouton d'ajout en taille Malio standard, label « Ajouter » - Suppression compte-rendu : passe à la ConfirmModal partagée (remplace l'ancienne ConfirmDeleteReportModal, supprimée) - Suppression d'un document joint : ajout d'une modal de confirmation - Upload via MalioInputUpload ; bouton supprimer document aligné (mdi:delete-outline ghost) Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
This commit is contained in:
@@ -14,6 +14,7 @@ type Owner = { client?: string, prospect?: string, prestataire?: string }
|
||||
* tel quel par les deux pages.
|
||||
*/
|
||||
export function useDirectoryDetail(owner: Owner) {
|
||||
const { t } = useI18n()
|
||||
const contactService = useContactService()
|
||||
const addressService = useAddressService()
|
||||
|
||||
@@ -59,6 +60,39 @@ export function useDirectoryDetail(owner: Owner) {
|
||||
addresses.value.splice(index, 1)
|
||||
}
|
||||
|
||||
// Confirmation de suppression d'un bloc (contact / adresse) : la corbeille du
|
||||
// bloc ouvre une modal ; la suppression effective n'a lieu qu'à la confirmation.
|
||||
const removeModalOpen = ref(false)
|
||||
const pendingRemoval = ref<{ type: 'contact' | 'address', index: number } | null>(null)
|
||||
|
||||
const removeModalTitle = computed(() =>
|
||||
pendingRemoval.value?.type === 'address'
|
||||
? t('directory.addresses.deleteConfirmTitle')
|
||||
: t('directory.contacts.deleteConfirmTitle'),
|
||||
)
|
||||
const removeModalMessage = computed(() =>
|
||||
pendingRemoval.value?.type === 'address'
|
||||
? t('directory.addresses.deleteConfirmMessage')
|
||||
: t('directory.contacts.deleteConfirmMessage'),
|
||||
)
|
||||
|
||||
function askRemoveContact(index: number): void {
|
||||
pendingRemoval.value = { type: 'contact', index }
|
||||
removeModalOpen.value = true
|
||||
}
|
||||
function askRemoveAddress(index: number): void {
|
||||
pendingRemoval.value = { type: 'address', index }
|
||||
removeModalOpen.value = true
|
||||
}
|
||||
async function confirmRemove(): Promise<void> {
|
||||
const p = pendingRemoval.value
|
||||
if (!p) return
|
||||
if (p.type === 'contact') await removeContact(p.index)
|
||||
else await removeAddress(p.index)
|
||||
removeModalOpen.value = false
|
||||
pendingRemoval.value = null
|
||||
}
|
||||
|
||||
// Persistance au clic : met à jour les blocs existants, crée les nouveaux
|
||||
// blocs renseignés. Les amorces vides (sans contenu) sont ignorées.
|
||||
async function saveContacts(): Promise<void> {
|
||||
@@ -117,5 +151,12 @@ export function useDirectoryDetail(owner: Owner) {
|
||||
removeAddress,
|
||||
saveAddresses,
|
||||
load,
|
||||
// Suppression de bloc avec confirmation (modal partagée contact/adresse).
|
||||
removeModalOpen,
|
||||
removeModalTitle,
|
||||
removeModalMessage,
|
||||
askRemoveContact,
|
||||
askRemoveAddress,
|
||||
confirmRemove,
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user