64 lines
2.5 KiB
TypeScript
64 lines
2.5 KiB
TypeScript
import { usePaginatedList } from '~/shared/composables/usePaginatedList'
|
|
|
|
/**
|
|
* Site Starseed rattache DIRECTEMENT au prestataire (M2M `provider_site`,
|
|
* RG-3.03), tel qu'embarque en LISTE (groupe site:read) pour la colonne « Site »
|
|
* du Repertoire (badges colores).
|
|
*
|
|
* Difference M3 vs M2 : au M2 les sites venaient de l'agregat dedoublonne des
|
|
* adresses (`Supplier::getSites()`) ; ici c'est une relation directe portee par
|
|
* le formulaire principal (cf. spec-back M3 § 2.12).
|
|
*/
|
|
export interface ProviderSite {
|
|
id: number
|
|
name: string
|
|
color: string
|
|
}
|
|
|
|
/**
|
|
* Categorie (type PRESTATAIRE) rattachee au prestataire, embarquee en LISTE
|
|
* (groupe category:read). La colonne « Catégories » affiche le `name` (cohérence
|
|
* M1/M2 — libellé = `name`, pas `code`).
|
|
*/
|
|
export interface ProviderCategory {
|
|
code: string
|
|
name: string
|
|
}
|
|
|
|
/**
|
|
* Vue MINIMALE d'un prestataire pour le Repertoire (datatable). Volontairement
|
|
* partielle : seuls les champs des colonnes + l'id (navigation) sont types ici.
|
|
* Le detail complet (onglets) est hors perimetre de cet ecran (ERP-140).
|
|
*/
|
|
export interface Provider {
|
|
id: number
|
|
companyName: string
|
|
categories: ProviderCategory[]
|
|
sites: ProviderSite[]
|
|
/** Date ISO de derniere modification (default:read) — colonne « Dernière activité ». */
|
|
updatedAt: string | null
|
|
isArchived: boolean
|
|
}
|
|
|
|
/**
|
|
* Repertoire prestataires (ERP-140) — simple enveloppe de `usePaginatedList<Provider>`
|
|
* sur la ressource `/providers` (pagination serveur obligatoire ; jamais de
|
|
* chargement integral en memoire). Miroir de `useSuppliersRepository` (M2).
|
|
*
|
|
* Les filtres (recherche, categories, sites, archives) sont pilotes par la page
|
|
* via `setFilters` du composable partage — la remise en page 1 est garantie. Par
|
|
* defaut, aucun `archivedOnly` n'est envoye : le back masque donc les prestataires
|
|
* archives (exclusion par defaut, spec-back § 2.11). Cocher « Voir les archivés »
|
|
* envoie `archivedOnly=true` → seules les archives sont listees (aligne sur Client).
|
|
*
|
|
* Le cloisonnement par site est applique AUTOMATIQUEMENT cote back (§ 2.13) en
|
|
* fonction de l'utilisateur — rien a filtrer cote front.
|
|
*
|
|
* Volontairement PAR INSTANCE (pas de singleton module-level) : l'etat tableau
|
|
* est propre a l'ecran Repertoire et meurt avec lui, comme tout consommateur de
|
|
* `usePaginatedList`. Aucun reset au logout a gerer.
|
|
*/
|
|
export function useProvidersRepository() {
|
|
return usePaginatedList<Provider>({ url: '/providers' })
|
|
}
|