b82acdac01
Auto Tag Develop / tag (push) Successful in 9s
## Contexte (ERP-173) Les répertoires **Fournisseurs** (M2) et **Prestataires** (M3) proposaient un filtre « Inclure les archivés » (affiche actifs **+** archivés, param `includeArchived`), alors que le répertoire **Client** — la référence — propose « Voir les archivés » (affiche les archivés **seuls**, param `archivedOnly`). ## Diagnostic Le back des 3 modules (providers, repositories, export controllers) est **déjà identique** : il gère `archivedOnly` (prioritaire). Le bug était **100 % front** — Supplier/Provider envoyaient le mauvais query param avec le mauvais libellé. ## Changement (front uniquement) - Libellé : « Inclure les archivés » → « **Voir les archivés** » - Query param : `includeArchived` → `archivedOnly` (case `filter-archived-only`, state `draft/appliedArchivedOnly`) - i18n `commercial.suppliers.filters` + `technique.providers.filters` - Tests Vitest alignés (suppliersIndex, useSuppliersRepository, useProvidersRepository) Aucune modif back nécessaire : la collection et l'export XLSX consomment déjà `archivedOnly`. ## Vérifications - `make nuxt-test` : 480/480 verts - ESLint : OK sur les fichiers touchés - Les 3 répertoires (Clients / Fournisseurs / Prestataires) ont désormais un filtre archives identique. Reviewed-on: #110 Co-authored-by: tristan <tristan@yuno.malio.fr> Co-committed-by: tristan <tristan@yuno.malio.fr>
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' })
|
|
}
|