71 lines
2.5 KiB
TypeScript
71 lines
2.5 KiB
TypeScript
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<ProviderDetail | null>(null)
|
|
const loading = ref(false)
|
|
const error = ref(false)
|
|
|
|
/** Recupere le detail complet (embed contacts/adresses/ribs + comptabilite). */
|
|
function fetchDetail(): Promise<ProviderDetail> {
|
|
return api.get<ProviderDetail>(
|
|
`/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<void> {
|
|
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<void> {
|
|
await api.patch(`/providers/${id}`, { isArchived }, { toast: false })
|
|
provider.value = await fetchDetail()
|
|
}
|
|
|
|
return {
|
|
provider,
|
|
loading,
|
|
error,
|
|
load,
|
|
archive: () => setArchived(true),
|
|
restore: () => setArchived(false),
|
|
}
|
|
}
|