b8dc3cb696
Auto Tag Develop / tag (push) Successful in 7s
Lot de correctifs sur l'écran Client (M1), + un retrait de règle métier et une petite fonctionnalité. ## Formulaire client (création / édition) - Boutons « ajouter un bloc » (Adresse, RIB) désactivés tant que le dernier bloc n'est pas valide. - Onglet Information : bouton Valider désactivé si aucun champ rempli (création) ; onglet Contact accessible dès la création (Information facultatif). - Champs « Relation » (Distributeur/Courtier) et « Prestation de triage » masqués par défaut, révélés seulement si une catégorie ordinaire (≠ Distributeur/Courtier) est sélectionnée. - Bloc RIB affiché uniquement si le type de règlement est LCR (création, édition, consultation) ; plus de RIB fantôme soumis. - Alignement du bas du textarea « Description » sur les autres champs. ## Recherche d'adresse (BAN) - Une erreur de l'API ne bloque plus définitivement la recherche : chaque frappe réessaie (le mode dégradé restait verrouillé). - Garde minimum 3 caractères avant l'appel à l'API. ## Répertoire client - Titres de colonne en noir 16px, corps + tags de site en 14px. ## Navigation - L'onglet actif est conservé au passage consultation ↔ édition (via history.state, hors URL). ## Règle métier - Retrait de RG-1.04 : l'onglet Information n'est plus obligatoire pour le rôle Commerciale — facultatif pour tous (back + tests + docs). Tests : suites front (Vitest) et back (PHPUnit) vertes hormis flakes d'infra connus. Reviewed-on: #76 Co-authored-by: tristan <tristan@yuno.malio.fr> Co-committed-by: tristan <tristan@yuno.malio.fr>
34 lines
1.2 KiB
TypeScript
34 lines
1.2 KiB
TypeScript
import { describe, it, expect, afterEach } from 'vitest'
|
|
import { readHistoryTab } from '../historyTab'
|
|
|
|
const KEYS = ['information', 'contact', 'address', 'accounting']
|
|
|
|
describe('readHistoryTab', () => {
|
|
afterEach(() => {
|
|
window.history.replaceState(null, '')
|
|
})
|
|
|
|
it('retourne la cle d\'onglet quand elle est presente et valide', () => {
|
|
window.history.replaceState({ tab: 'address' }, '')
|
|
expect(readHistoryTab(KEYS)).toBe('address')
|
|
})
|
|
|
|
it('retourne null quand l\'onglet n\'est pas dans les cles valides (ex: role sans Comptabilite)', () => {
|
|
window.history.replaceState({ tab: 'accounting' }, '')
|
|
expect(readHistoryTab(['information', 'contact', 'address'])).toBeNull()
|
|
})
|
|
|
|
it('retourne null sans onglet dans l\'etat d\'historique (navigation directe / refresh)', () => {
|
|
window.history.replaceState(null, '')
|
|
expect(readHistoryTab(KEYS)).toBeNull()
|
|
|
|
window.history.replaceState({ foo: 'bar' }, '')
|
|
expect(readHistoryTab(KEYS)).toBeNull()
|
|
})
|
|
|
|
it('retourne null quand la valeur n\'est pas une chaine', () => {
|
|
window.history.replaceState({ tab: 42 }, '')
|
|
expect(readHistoryTab(KEYS)).toBeNull()
|
|
})
|
|
})
|