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` * sur la ressource `/providers` (pagination serveur obligatoire ; jamais de * chargement integral en memoire). Miroir de `useSuppliersRepository` (M2). * * Les filtres (recherche, categories, sites, inclusion des archives) sont pilotes * par la page via `setFilters` du composable partage — la remise en page 1 est * garantie. Par defaut, aucun `includeArchived` n'est envoye : le back masque * donc les prestataires archives (exclusion par defaut, spec-back § 2.11). * * 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({ url: '/providers' }) }