import { ref } from 'vue' import type { ClientDetail } from '~/modules/commercial/utils/clientConsultation' /** * Chargement et actions d'archivage d'un client unique (ecran « Consultation * client », 1.11). Lit le detail embarque via `GET /api/clients/{id}` (contacts / * adresses / ribs sous `client:item:read` / `client:read:accounting`) et expose * les bascules d'archivage (PATCH `isArchived` SEUL — tout autre champ => 422). * * L'en-tete `Accept: application/ld+json` est impose pour obtenir le payload * Hydra complet (sans lui, API Platform 4 renvoie une representation reduite). * * Etat 100 % local a l'instance (refs) — aucune persistance URL. Les erreurs * d'archivage/restauration (notamment le 409 RG-1.23 : homonyme actif a la * restauration) sont PROPAGEES a l'appelant, qui decide du toast a afficher. */ export function useClient(id: number | string) { const api = useApi() const client = ref(null) const loading = ref(false) const error = ref(false) /** Recupere le detail complet (embed contacts/adresses/ribs + comptabilite). */ function fetchDetail(): Promise { return api.get( `/clients/${id}`, {}, { headers: { Accept: 'application/ld+json' }, toast: false }, ) } /** Charge le detail du client. En cas d'echec : `error = true`, `client = null`. */ async function load(): Promise { loading.value = true error.value = false try { client.value = await fetchDetail() } catch { error.value = true client.value = null } finally { loading.value = false } } /** * Bascule l'archivage (PATCH `isArchived` SEUL — tout autre champ => 422), * puis RECHARGE le detail complet : la reponse du PATCH ne porte que le groupe * `client:read` (ni l'embed contacts/adresses/ribs ni les libelles des * referentiels comptables), un simple merge laisserait l'affichage incoherent. * Toute erreur (notamment le 409 d'homonyme actif a la restauration, RG-1.23) * est propagee a l'appelant AVANT le rechargement. */ async function setArchived(isArchived: boolean): Promise { await api.patch(`/clients/${id}`, { isArchived }, { toast: false }) client.value = await fetchDetail() } return { client, loading, error, load, archive: () => setArchived(true), restore: () => setArchived(false), } }