912280d24e
Auto Tag Develop / tag (push) Successful in 7s
## ERP-66 — Utilitaires adresse/téléphone + autocomplétion BAN ### feat - **httpExternal** : client dédié aux API publiques externes (URL absolue, sans cookie de session, timeout). Seul point d'entrée autorisé pour un `$fetch` externe (règle frontend n°4). - **useAddressAutocomplete** : implémentation BAN (api-adresse.data.gouv.fr) — recherche ville (`type=municipality`) et adresse, mapping GeoJSON, throw en cas d'erreur/timeout (mode dégradé côté composant). La recherche d'adresse n'impose **pas** `type=housenumber` (sinon 0 résultat tant qu'aucun numéro n'est saisi) — spec-front mise à jour. - Tests Vitest : httpExternal, useAddressAutocomplete, cas limites `formatPhoneFR`. ### fix - **ClientAddressBlock** : la rue courante est toujours réinjectée dans les options de `MalioInputAutocomplete` (computed, miroir de `cityOptions`). Corrige le champ Adresse qui se vidait après validation / à l'édition d'une adresse existante (valeur pourtant persistée). Test de montage ajouté. - **useClientReferentials** : libellé des sites = numéro de département (2 premiers chiffres du code postal, déjà exposé par `/sites`) au lieu du nom. ### Vérifs - ESLint ✅ · Vitest 196/196 ✅ - Changements 100% frontend (+ doc spec). Reviewed-on: #52 Co-authored-by: tristan <tristan@yuno.malio.fr> Co-committed-by: tristan <tristan@yuno.malio.fr>
41 lines
1.5 KiB
TypeScript
41 lines
1.5 KiB
TypeScript
import { $fetch } from 'ofetch'
|
|
|
|
/**
|
|
* Options d'un appel HTTP externe.
|
|
*/
|
|
export interface HttpExternalOptions {
|
|
/** Parametres de query string (encodes par ofetch). */
|
|
query?: Record<string, string | number | undefined>
|
|
/** Timeout en millisecondes avant abandon (defaut 5000). */
|
|
timeoutMs?: number
|
|
}
|
|
|
|
/**
|
|
* Petit client HTTP pour les APIs PUBLIQUES EXTERNES (domaine tiers, hors `/api`).
|
|
*
|
|
* Pourquoi un helper dedie plutot que `useApi()` : `useApi()` est le client de
|
|
* l'API interne Starseed (baseURL `/api`, cookie JWT `credentials: 'include'`,
|
|
* parsing/erreurs Hydra, redirection `/login` sur 401, toasts i18n). Tout cela
|
|
* est inadapte — voire indesirable — pour un endpoint public externe comme la
|
|
* Base Adresse Nationale (`api-adresse.data.gouv.fr`).
|
|
*
|
|
* Ce helper est donc le SEUL point d'entree autorise pour un `$fetch` brut vers
|
|
* l'externe (cf. regle frontend n°4 : pas de `$fetch` eparpille dans les
|
|
* composants). Il :
|
|
* - cible une URL absolue (pas de baseURL `/api`) ;
|
|
* - n'envoie PAS le cookie de session (`credentials: 'omit'`) ;
|
|
* - ne retente pas (`retry: 0`) et applique un timeout ;
|
|
* - laisse remonter l'erreur (throw) — au consommateur de gerer le mode degrade.
|
|
*/
|
|
export async function httpExternal<T>(
|
|
url: string,
|
|
opts: HttpExternalOptions = {},
|
|
): Promise<T> {
|
|
return $fetch<T>(url, {
|
|
query: opts.query,
|
|
credentials: 'omit',
|
|
retry: 0,
|
|
timeout: opts.timeoutMs ?? 5000,
|
|
})
|
|
}
|