import { ref } from 'vue' import type { ProviderDetail } from '~/modules/technique/utils/forms/providerDetail' /** * Chargement et actions d'archivage d'un prestataire unique (ecrans Consultation / * Modification, ERP-145). Miroir de `useSupplier` (M2). Lit le detail embarque via * `GET /api/providers/{id}` (contacts / adresses + leurs sous-collections / ribs * sous `provider:item:read` / `provider:read:accounting`) — une SEULE requete * peuple les deux ecrans (embed borne, pas de N+1). * * L'en-tete `Accept: application/ld+json` est impose pour obtenir le payload Hydra * complet (avec les `@id` des relations embarquees, indispensables au pre-remplissage). * * Etat 100 % local a l'instance (refs). Les erreurs d'archivage / restauration * (notamment le 409 d'homonyme actif a la restauration) sont PROPAGEES a l'appelant, * qui decide du toast a afficher. */ export function useProvider(id: number | string) { const api = useApi() const provider = 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( `/providers/${id}`, {}, { headers: { Accept: 'application/ld+json' }, toast: false }, ) } /** Charge le detail du prestataire. En cas d'echec : `error = true`, `provider = null`. */ async function load(): Promise { loading.value = true error.value = false try { provider.value = await fetchDetail() } catch { error.value = true provider.value = null } finally { loading.value = false } } /** * Bascule l'archivage (PATCH `isArchived` SEUL — groupe provider:write:archive ; * tout autre champ => 422), puis RECHARGE le detail complet : la reponse du PATCH * ne porte que `provider:read` (ni l'embed des sous-collections ni les libelles * comptables), un simple merge laisserait l'affichage incoherent. Toute erreur est * propagee a l'appelant AVANT le rechargement. */ async function setArchived(isArchived: boolean): Promise { await api.patch(`/providers/${id}`, { isArchived }, { toast: false }) provider.value = await fetchDetail() } return { provider, loading, error, load, archive: () => setArchived(true), restore: () => setArchived(false), } }