@ktortu/aaa 0.1.0-beta.0 → 0.9.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +27 -9
- package/cdk/styles/tabs.css +100 -21
- package/fesm2022/ktortu-aaa-button.mjs +18 -11
- package/fesm2022/ktortu-aaa-button.mjs.map +1 -1
- package/fesm2022/ktortu-aaa-card.mjs +29 -4
- package/fesm2022/ktortu-aaa-card.mjs.map +1 -1
- package/fesm2022/ktortu-aaa-cdk.mjs +59 -15
- package/fesm2022/ktortu-aaa-cdk.mjs.map +1 -1
- package/fesm2022/ktortu-aaa-dialog.mjs +134 -24
- package/fesm2022/ktortu-aaa-dialog.mjs.map +1 -1
- package/fesm2022/ktortu-aaa-forms.mjs +748 -294
- package/fesm2022/ktortu-aaa-forms.mjs.map +1 -1
- package/fesm2022/ktortu-aaa-i18n.mjs +139 -0
- package/fesm2022/ktortu-aaa-i18n.mjs.map +1 -0
- package/fesm2022/ktortu-aaa-menu.mjs +38 -13
- package/fesm2022/ktortu-aaa-menu.mjs.map +1 -1
- package/fesm2022/ktortu-aaa-snackbar.mjs +465 -0
- package/fesm2022/ktortu-aaa-snackbar.mjs.map +1 -0
- package/fesm2022/ktortu-aaa-tabs.mjs +319 -42
- package/fesm2022/ktortu-aaa-tabs.mjs.map +1 -1
- package/fesm2022/ktortu-aaa-tooltip.mjs +3 -2
- package/fesm2022/ktortu-aaa-tooltip.mjs.map +1 -1
- package/fesm2022/ktortu-aaa.mjs +2 -0
- package/fesm2022/ktortu-aaa.mjs.map +1 -1
- package/forms/checkbox/checkbox-group.css +0 -8
- package/forms/chips/chip-list.css +5 -0
- package/forms/radio/radio-group.css +0 -8
- package/forms/styles/field-box.css +152 -2
- package/forms/styles/field-pending.css +46 -0
- package/forms/styles/select-panel.css +4 -0
- package/forms/styles/tokens.css +3 -0
- package/menu/menu.css +8 -4
- package/package.json +9 -1
- package/snackbar/snackbar-tokens.css +53 -0
- package/snackbar/snackbar.css +175 -0
- package/styles/forms.css +1 -0
- package/styles/snackbar.css +9 -0
- package/styles/styles.css +1 -0
- package/types/ktortu-aaa-button.d.ts +22 -8
- package/types/ktortu-aaa-card.d.ts +24 -4
- package/types/ktortu-aaa-cdk.d.ts +38 -0
- package/types/ktortu-aaa-dialog.d.ts +129 -31
- package/types/ktortu-aaa-forms.d.ts +503 -160
- package/types/ktortu-aaa-i18n.d.ts +77 -0
- package/types/ktortu-aaa-menu.d.ts +15 -8
- package/types/ktortu-aaa-snackbar.d.ts +275 -0
- package/types/ktortu-aaa-tabs.d.ts +130 -13
- package/types/ktortu-aaa-tooltip.d.ts +5 -0
- package/types/ktortu-aaa.d.ts +2 -0
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ktortu-aaa-dialog.mjs","sources":["../../../../projects/ktortu/aaa/dialog/dialog-title.directive.ts","../../../../projects/ktortu/aaa/dialog/dialog-description.directive.ts","../../../../projects/ktortu/aaa/dialog/dialog-close.directive.ts","../../../../projects/ktortu/aaa/dialog/dialog-structure.ts","../../../../projects/ktortu/aaa/dialog/dialog-config.ts","../../../../projects/ktortu/aaa/dialog/dialog-container.ts","../../../../projects/ktortu/aaa/dialog/dialog-opener.ts","../../../../projects/ktortu/aaa/dialog/public-api.ts","../../../../projects/ktortu/aaa/dialog/ktortu-aaa-dialog.ts"],"sourcesContent":["import { DialogRef } from '@angular/cdk/dialog';\nimport { Directive, ElementRef, Renderer2, afterNextRender, inject } from '@angular/core';\nimport { KtIdGenerator } from '@ktortu/aaa/cdk';\n\n/**\n * À poser sur le titre VISIBLE (idéalement un `<h2>`) du contenu d'un CDK Dialog.\n * Câble `aria-labelledby` du conteneur de dialogue.\n *\n * Pourquoi écrire l'attribut directement (Renderer2) plutôt que seulement `_addAriaLabelledBy` :\n * sous change detection ZONELESS (cas par défaut moderne), le `markForCheck()` interne du\n * conteneur ne rafraîchit pas ses host bindings à l'ouverture, donc l'attribut n'apparaîtrait\n * jamais. On écrit donc l'attribut nous-mêmes (fiable, indépendant de la CD) ET on alimente la\n * file CDK pour rester cohérent si un cycle de CD survient ensuite.\n *\n * @example\n * ```html\n * <h2 ktDialogTitle>Renommer le fichier</h2>\n * ```\n */\n@Directive({\n selector: '[ktDialogTitle]',\n host: { '[id]': 'id' },\n})\nexport class KtDialogTitle {\n private readonly dialogRef = inject<DialogRef<unknown>>(DialogRef, { optional: true });\n private readonly host = inject<ElementRef<HTMLElement>>(ElementRef).nativeElement;\n private readonly renderer = inject(Renderer2);\n private readonly idGen = inject(KtIdGenerator);\n\n /** Id de l'hôte câblé en `aria-labelledby` : préserve un id fourni par le consommateur, sinon en génère un. */\n readonly id = this.host.id || this.dialogRef?.config.ariaLabelledBy || `kt-dialog-title-${this.idGen.generateId()}`;\n\n constructor() {\n const preConfigured = this.dialogRef?.config.ariaLabelledBy;\n if (!preConfigured) {\n if (this.dialogRef) {\n this.dialogRef.config.ariaLabelledBy = this.id;\n }\n afterNextRender(() => {\n const container = this.host.closest('.cdk-dialog-container');\n if (container) this.renderer.setAttribute(container, 'aria-labelledby', this.id);\n });\n }\n }\n}\n","import { DialogRef } from '@angular/cdk/dialog';\nimport { Directive, ElementRef, OnDestroy, OnInit, Renderer2, afterNextRender, inject } from '@angular/core';\nimport { KtIdGenerator } from '@ktortu/aaa/cdk';\n\n/**\n * À poser sur le paragraphe descriptif COURT du dialog : câble `aria-describedby` du conteneur\n * (texte lu par le lecteur d'écran juste après le titre, à l'ouverture).\n *\n * ⚠️ Ne JAMAIS appliquer sur un formulaire ou un long contenu : `aria-describedby` concatène\n * tout le texte du nœud et serait lu d'un bloc à l'ouverture. Réserver à une phrase de contexte.\n *\n * Écriture directe de l'attribut (Renderer2) pour la même raison que `ktDialogTitle` :\n * fiabilité sous change detection zoneless. La config est tenue à jour pour cohérence CDK.\n *\n * @example\n * ```html\n * <p ktDialogDescription>Cette action est définitive.</p>\n * ```\n */\n@Directive({\n selector: '[ktDialogDescription]',\n host: { '[id]': 'id' },\n})\nexport class KtDialogDescription implements OnInit, OnDestroy {\n private readonly dialogRef = inject<DialogRef<unknown>>(DialogRef, { optional: true });\n private readonly host = inject<ElementRef<HTMLElement>>(ElementRef).nativeElement;\n private readonly renderer = inject(Renderer2);\n private readonly idGen = inject(KtIdGenerator);\n\n /** Id de l'hôte câblé en `aria-describedby` : préserve un id fourni par le consommateur, sinon en génère un. */\n readonly id = this.host.id || this.dialogRef?.config.ariaDescribedBy || `kt-dialog-desc-${this.idGen.generateId()}`;\n\n constructor() {\n const preConfigured = this.dialogRef?.config.ariaDescribedBy;\n if (!preConfigured) {\n if (this.dialogRef) {\n this.dialogRef.config.ariaDescribedBy = this.id;\n }\n afterNextRender(() => {\n const container = this.host.closest('.cdk-dialog-container');\n if (container) this.renderer.setAttribute(container, 'aria-describedby', this.id);\n });\n }\n }\n\n ngOnInit(): void {\n if (this.dialogRef && this.dialogRef.config.ariaDescribedBy !== this.id) {\n this.dialogRef.config.ariaDescribedBy = this.id;\n }\n }\n\n ngOnDestroy(): void {\n if (this.dialogRef?.config.ariaDescribedBy === this.id) {\n this.dialogRef.config.ariaDescribedBy = null;\n }\n }\n}\n","import { DialogRef } from '@angular/cdk/dialog';\nimport { Directive, ElementRef, afterNextRender, inject, input, isDevMode } from '@angular/core';\n\n/**\n * Ferme le CDK Dialog au clic, avec un résultat optionnel renvoyé à l'ouvreur via\n * `DialogRef.close(result)`. Se compose avec `[ktButton]` sur le même `<button>`.\n *\n * Réservé au DISMISS simple (Annuler / Fermer). Pour valider un formulaire, injectez\n * `DialogRef` dans votre composant et appelez `close(valeur)` après validation.\n *\n * @example\n * ```html\n * <button ktButton ktDialogClose>Annuler</button>\n * <button ktButton [ktDialogClose]=\"'confirm'\">Confirmer</button>\n * ```\n */\n@Directive({\n selector: '[ktDialogClose]',\n host: {\n '[attr.type]': 'buttonType',\n '(click)': 'close()',\n },\n})\nexport class KtDialogClose {\n private readonly dialogRef = inject<DialogRef<unknown>>(DialogRef, { optional: true });\n private readonly host = inject<ElementRef<HTMLElement>>(ElementRef).nativeElement;\n\n /**\n * Valeur renvoyée à l'ouvreur via `DialogRef.close(result)`. Liée par l'alias `ktDialogClose`\n * (= nom du sélecteur), d'où l'usage `[ktDialogClose]=\"'confirm'\"`. @default undefined\n */\n readonly dialogResult = input<unknown>(undefined, { alias: 'ktDialogClose' });\n\n // Force type=\"button\" sur un <button> (évite le submit implicite dans un <form>).\n protected readonly buttonType = this.host.tagName === 'BUTTON' ? 'button' : null;\n\n constructor() {\n // Garde-fou a11y (dev) : un bouton de fermeture doit avoir un nom accessible (WCAG 4.1.2).\n afterNextRender(() => {\n if (!isDevMode()) return;\n\n const named =\n (this.host.textContent ?? '').trim().length > 0 ||\n this.host.hasAttribute('aria-label') ||\n this.host.hasAttribute('aria-labelledby');\n if (!named) {\n console.warn(\n '[ktDialogClose] Bouton de fermeture sans nom accessible (WCAG 4.1.2) : ' +\n 'ajoutez du texte visible, aria-label ou aria-labelledby.',\n );\n }\n });\n }\n\n protected close(): void {\n this.dialogRef?.close(this.dialogResult());\n }\n}\n","import { DestroyRef, Directive, ElementRef, inject } from '@angular/core';\nimport { DialogRef } from '@angular/cdk/dialog';\n\nimport { createKtSheetDrag } from '@ktortu/aaa/cdk';\n\n/**\n * En-tête RICHE et OPTIONNEL du dialog : rangée flex pour composer une icône, le titre et/ou un\n * bouton de fermeture. Marqueur structurel sans logique — la mise en forme (flex, padding de\n * région, reset du padding du [ktDialogTitle] qu'il enveloppe) vit dans `dialog.css`.\n *\n * Sépare le LAYOUT (cette région) de l'ÉTIQUETTE ACCESSIBLE ([ktDialogTitle], qui garde\n * aria-labelledby). En usage simple — titre nu sans header — [ktDialogTitle] conserve son propre\n * padding : ce header n'est à utiliser que pour les en-têtes composés (icône, close top-right…).\n *\n * @example\n * ```html\n * <header ktDialogHeader>\n * <h2 ktDialogTitle>Titre</h2>\n * <button ktButton ktDialogClose aria-label=\"Fermer\">✕</button>\n * </header>\n * ```\n */\n@Directive({ selector: '[ktDialogHeader]' })\nexport class KtDialogHeader {}\n\n/**\n * Zone de contenu du dialog. Marqueur structurel sans logique : la mise en forme\n * (rythme vertical) vit dans `dialog.css` via le sélecteur `[ktDialogContent]`.\n *\n * @example\n * ```html\n * <div ktDialogContent>…</div>\n * ```\n */\n@Directive({ selector: '[ktDialogContent]' })\nexport class KtDialogContent {}\n\n/**\n * Barre d'actions du dialog (rangée de boutons). Marqueur structurel sans logique :\n * la mise en forme (flex, gap, sticky bas pour le Reflow AAA) vit dans `dialog.css`\n * via le sélecteur `[ktDialogActions]`.\n *\n * @example\n * ```html\n * <footer ktDialogActions>\n * <button ktButton ktDialogClose>Annuler</button>\n * <button ktButton [ktDialogClose]=\"'ok'\">Valider</button>\n * </footer>\n * ```\n */\n@Directive({ selector: '[ktDialogActions]' })\nexport class KtDialogActions {}\n\n/**\n * Marque l'élément à focaliser à l'ouverture. À coupler avec la config CDK\n * `autoFocus: '[ktDialogFocusInitial]'` (incluse dans `provideKtDialogDefaults`).\n * Permet d'éviter que le focus initial tombe sur une action destructrice.\n *\n * @example\n * ```html\n * <input ktDialogFocusInitial type=\"text\" />\n * ```\n */\n@Directive({ selector: '[ktDialogFocusInitial]' })\nexport class KtDialogFocusInitial {}\n\n/**\n * Poignée de préhension d'un dialog en mode `sheet` (bottom-sheet) : drag-to-dismiss vers le bas,\n * FACTORISÉ avec le Select via `createKtSheetDrag` (@ktortu/aaa). Geste DOUBLÉ par Échap + bouton\n * Fermer + clic sur le scrim (WCAG 2.5.1) — décoratif (`aria-hidden`).\n *\n * À poser sur la barre de préhension, premier enfant du contenu d'un dialog ouvert avec une\n * présentation `sheet` / `centered-sheet`. Le drag n'est actif que si le dialog est EFFECTIVEMENT\n * en mode sheet (la pane porte `kt-dialog--sheet`) — pas de dépendance au viewport : un `sheet`\n * toujours-bottom-sheet se drague aussi à la souris.\n *\n * @example\n * ```html\n * <div ktDialogContent>\n * <div ktDialogSheetHandle></div>\n * …\n * </div>\n * ```\n */\n@Directive({\n selector: '[ktDialogSheetHandle]',\n host: {\n '(pointerdown)': 'onStart($event)',\n '(mousedown)': '$event.preventDefault()',\n 'aria-hidden': 'true',\n },\n})\nexport class KtDialogSheetHandle {\n private readonly dialogRef = inject<DialogRef<unknown>>(DialogRef, { optional: true });\n private readonly host = inject<ElementRef<HTMLElement>>(ElementRef).nativeElement;\n private readonly destroyRef = inject(DestroyRef);\n\n // La feuille translatée = le conteneur CDK (position:fixed en mode sheet), trouvé en remontant.\n private readonly drag = createKtSheetDrag({\n pane: () => this.host.closest<HTMLElement>('.cdk-dialog-container'),\n onDismiss: () => this.dialogRef?.close(),\n draggingClass: 'kt-dialog-sheet--dragging',\n });\n\n constructor() {\n this.destroyRef.onDestroy(() => this.drag.destroy());\n }\n\n protected onStart(event: PointerEvent): void {\n // Actif seulement quand la PRÉSENTATION choisie par le dev est `sheet` (classe sur la pane).\n const pane = this.host.closest('.cdk-overlay-pane');\n if (!pane?.classList.contains('kt-dialog--sheet')) return;\n this.drag.start(event);\n }\n}\n","import { DEFAULT_DIALOG_CONFIG, DialogConfig } from '@angular/cdk/dialog';\nimport { Provider } from '@angular/core';\n\n/**\n * Valeurs par défaut orientées AAA pour `@angular/cdk/dialog`.\n * - `ariaModal: true` : explicite (le CDK le laisse OFF par défaut).\n * - `restoreFocus: true` : rend le focus au déclencheur à la fermeture.\n * - `panelClass` / `backdropClass` : crochets de style consommés par `dialog.css`.\n *\n * Pour focaliser un élément précis à l'ouverture (ex. éviter un bouton destructeur),\n * passez `autoFocus: '[ktDialogFocusInitial]'` dans la config d'ouverture et posez la\n * directive `ktDialogFocusInitial` sur la cible.\n */\nexport const KT_DIALOG_AAA_DEFAULTS: DialogConfig = {\n role: 'dialog',\n ariaModal: true,\n autoFocus: '[ktDialogFocusInitial]',\n restoreFocus: true,\n hasBackdrop: true,\n panelClass: 'kt-dialog',\n backdropClass: 'kt-dialog__backdrop',\n};\n\n/**\n * Enregistre les valeurs par défaut AAA du dialog au niveau application.\n * À ajouter aux `providers` de `app.config.ts`. `overrides` permet d'ajuster sans\n * tout réécrire (ex. `provideKtDialogDefaults({ maxWidth: '40rem' })`).\n */\nexport function provideKtDialogDefaults(overrides?: Partial<DialogConfig>): Provider {\n return {\n provide: DEFAULT_DIALOG_CONFIG,\n useValue: { ...KT_DIALOG_AAA_DEFAULTS, ...overrides },\n };\n}\n\n/**\n * Présentation du dialog, CHOISIE EXPLICITEMENT PAR LE DÉVELOPPEUR à l'ouverture (option\n * `presentation` de `injectKtDialogOpener`). Aucune bascule CSS automatique : le dev décide.\n * - `centered` : toujours centré (ex. confirmation) — DÉFAUT ;\n * - `fullscreen` : toujours plein écran (desktop compris) ;\n * - `sheet` : toujours bottom-sheet (desktop compris) ;\n * - `centered-fullscreen` : centré sur desktop, plein écran sur téléphone compact ;\n * - `centered-sheet` : centré sur desktop, bottom-sheet sur téléphone compact.\n * Les variantes `centered-*` sont résolues EN JS à l'ouverture (signal `KtViewport.isCompact()`), pas par le CSS —\n * la classe CSS finale est donc toujours une présentation CONCRÈTE (centered/fullscreen/sheet).\n */\nexport type KtDialogPresentation = 'centered' | 'fullscreen' | 'sheet' | 'centered-fullscreen' | 'centered-sheet';\n\n/** panelClass d'une présentation CONCRÈTE (sans variante responsive). */\nfunction concreteDialogPanelClass(p: 'centered' | 'fullscreen' | 'sheet'): string[] {\n if (p === 'fullscreen') return ['kt-dialog', 'kt-dialog--fullscreen'];\n if (p === 'sheet') return ['kt-dialog', 'kt-dialog--sheet'];\n return ['kt-dialog'];\n}\n\n/**\n * Résout une `KtDialogPresentation` (responsive comprise) en panelClass concret. Pour les variantes\n * `centered-*`, l'appelant fournit `compact` (= `KtViewport.isCompact()`, largeur seule) — centré\n * sur desktop, plein écran / sheet sur écran compact. Fonction pure (testable sans DOM).\n * Appelée par `injectKtDialogOpener` à chaque ouverture ; exportée pour un usage direct éventuel.\n */\nexport function resolveKtDialogPanelClass(presentation: KtDialogPresentation = 'centered', compact = false): string[] {\n if (presentation === 'centered' || presentation === 'fullscreen' || presentation === 'sheet') {\n return concreteDialogPanelClass(presentation);\n }\n if (presentation === 'centered-fullscreen') {\n return concreteDialogPanelClass(compact ? 'fullscreen' : 'centered');\n }\n return concreteDialogPanelClass(compact ? 'sheet' : 'centered'); // 'centered-sheet'\n}\n","import { Component, ElementRef, OnInit, signal, inject, PLATFORM_ID } from '@angular/core';\nimport { isPlatformBrowser } from '@angular/common';\nimport { CdkDialogContainer, DialogRef } from '@angular/cdk/dialog';\nimport { PortalModule } from '@angular/cdk/portal';\n\n@Component({\n selector: 'kt-dialog-container',\n imports: [PortalModule],\n host: {\n class: 'cdk-dialog-container kt-dialog-container',\n tabindex: '-1',\n '[attr.id]': '_config.id || null',\n '[attr.role]': '_config.role',\n '[attr.aria-modal]': '_config.ariaModal',\n '[attr.aria-labelledby]': '_config.ariaLabel ? null : _ariaLabelledByQueue[0]',\n '[attr.aria-label]': '_config.ariaLabel',\n '[attr.aria-describedby]': '_config.ariaDescribedBy || null',\n '[class.kt-dialog-container--sheet]': 'isSheet()',\n '[class.kt-dialog-container--closing]': 'isClosing()',\n },\n template: `\n <div class=\"kt-dialog-container__layout\">\n <ng-template cdkPortalOutlet></ng-template>\n </div>\n `,\n})\nexport class KtDialogContainer extends CdkDialogContainer implements OnInit {\n private readonly dialogRef = inject(DialogRef);\n private readonly elementRef = inject(ElementRef);\n private readonly host = this.elementRef.nativeElement as HTMLElement;\n private readonly platformId = inject(PLATFORM_ID);\n\n protected readonly isClosing = signal(false);\n\n constructor() {\n super();\n // Monkey-patch de dialogRef.close pour intercepter toutes les demandes de fermeture\n const originalClose = this.dialogRef.close.bind(this.dialogRef);\n this.dialogRef.close = (result?: unknown) => {\n this.animateAndClose(result, originalClose);\n };\n }\n\n ngOnInit(): void {\n // Si la fermeture par clic extérieur/Échap est autorisée, on l'écoute pour lancer l'animation\n if (!this._config.disableClose) {\n this.dialogRef.backdropClick.subscribe(() => this.dialogRef.close());\n this.dialogRef.keydownEvents.subscribe((event: KeyboardEvent) => {\n if (event.key === 'Escape') {\n event.preventDefault();\n this.dialogRef.close();\n }\n });\n }\n }\n\n protected isSheet(): boolean {\n return this._config.panelClass?.includes('kt-dialog--sheet') ?? false;\n }\n\n private animateAndClose(result: unknown, originalCloseFn: (r?: unknown) => void): void {\n if (this.isClosing()) return;\n this.isClosing.set(true);\n\n if (!isPlatformBrowser(this.platformId)) {\n originalCloseFn(result);\n return;\n }\n\n // Récupérer la durée de transition configurée en CSS (ex: \"150ms\" ou \"0.2s\")\n const styles = window.getComputedStyle(this.host);\n const durationStr = styles.transitionDuration || '0s';\n const durationMs = parseFloat(durationStr) * (durationStr.includes('ms') ? 1 : 1000);\n\n if (durationMs === 0) {\n originalCloseFn(result);\n return;\n }\n\n // Écouter la fin de la transition sur la propriété 'translate'\n const onTransitionEnd = (event: TransitionEvent) => {\n if (event.target === this.host && event.propertyName === 'translate') {\n this.host.removeEventListener('transitionend', onTransitionEnd);\n originalCloseFn(result);\n }\n };\n this.host.addEventListener('transitionend', onTransitionEnd);\n\n // Sécurité (au cas où la transition n'aboutirait pas)\n setTimeout(() => {\n this.host.removeEventListener('transitionend', onTransitionEnd);\n originalCloseFn(result);\n }, durationMs + 50);\n }\n}\n","import { DIALOG_DATA, Dialog, DialogConfig, DialogRef } from '@angular/cdk/dialog';\nimport { ComponentType } from '@angular/cdk/portal';\nimport { ViewContainerRef, inject } from '@angular/core';\nimport { KtViewport, KtIdGenerator } from '@ktortu/aaa/cdk';\n\nimport { KtDialogPresentation, resolveKtDialogPanelClass } from './dialog-config';\nimport { KtDialogContainer } from './dialog-container';\n\n/**\n * Sucre typé pour récupérer les données injectées dans un composant de dialogue (`DIALOG_DATA`).\n * À appeler en contexte d'injection (ex. initialiseur de champ).\n *\n * @example\n * ```ts\n * interface RenameData { currentName: string; }\n *\n * @Component({ … })\n * export class RenameDialog {\n * protected readonly data = injectKtDialogData<RenameData>();\n * // this.data.currentName → string\n * }\n * ```\n */\nexport function injectKtDialogData<T>(): T {\n return inject<T>(DIALOG_DATA);\n}\n\n/** Config d'ouverture sans le champ `data` (fourni séparément, typé), enrichie de `presentation`. */\ntype OpenerConfig<D, R, C> = Omit<DialogConfig<D, DialogRef<R, C>>, 'data'> & {\n /** Présentation du dialog (cf. `KtDialogPresentation`) — choisie par le dev. Résolue à CHAQUE\n ouverture : les variantes responsive lisent le signal d'écran compact. Défaut : `'centered'`.\n Combinée à un éventuel `panelClass` additionnel. */\n presentation?: KtDialogPresentation;\n};\n\n/**\n * Crée un ouvreur de dialog **typé et centralisé**, en contexte d'injection.\n * Le contrat (composant + type de `data` + type de résultat + config par défaut) est défini\n * UNE fois ; l'ouvreur renvoyé est une closure appelable ensuite n'importe où dans la classe\n * (handlers compris), 100 % typée, sans nouvel `inject`.\n *\n * Conserve le `ViewContainerRef` du contexte appelant (le dialog hérite donc de l'arbre logique\n * d'injection), reste testable (TestBed fournit `Dialog`) et sans état global (SSR-safe).\n *\n * @example\n * // co-localisé avec le composant\n * export const injectRenameDialog = () =>\n * injectKtDialogOpener<RenameDialog, RenameData, string>(RenameDialog, { autoFocus: '[ktDialogFocusInitial]' });\n *\n * // dans un composant/service consommateur\n * private readonly openRename = injectRenameDialog();\n * rename() { this.openRename({ currentName: 'X' }).closed.subscribe(n => { n: string | undefined }); }\n */\n// Compteur de dialogues pour générer des IDs uniques d'accessibilité SSR-safe.\n\n// Surcharge sans data (D = void) : l'ouvreur ne prend aucun argument (la config par défaut suffit).\nexport function injectKtDialogOpener<C, R = unknown>(\n component: ComponentType<C>,\n baseConfig?: OpenerConfig<void, R, C>,\n): () => DialogRef<R, C>;\n// Surcharge avec data typée.\nexport function injectKtDialogOpener<C, D, R = unknown>(\n component: ComponentType<C>,\n baseConfig?: OpenerConfig<D, R, C>,\n): (data: D, config?: OpenerConfig<D, R, C>) => DialogRef<R, C>;\n\nexport function injectKtDialogOpener<C, D, R = unknown>(\n component: ComponentType<C>,\n baseConfig?: OpenerConfig<D, R, C>,\n) {\n const dialog = inject(Dialog);\n const viewport = inject(KtViewport);\n // Optionnel : hors d'un arbre de vue (ex. service root), il n'y a pas de ViewContainerRef.\n const viewContainerRef = inject(ViewContainerRef, { optional: true }) ?? undefined;\n const idGen = inject(KtIdGenerator);\n\n return (data?: D, config?: OpenerConfig<D, R, C>): DialogRef<R, C> => {\n // La présentation (choisie par le dev) est résolue ICI, à l'ouverture : les variantes\n // responsive lisent le signal d'écran compact. Le panelClass final = présentation concrète + extras.\n const { presentation, panelClass, ...rest } = { ...baseConfig, ...config };\n const extra = panelClass ? (Array.isArray(panelClass) ? panelClass : [panelClass]) : [];\n // Dédoublonné : une classe déjà fournie par la présentation (ex. `kt-dialog`) et repassée\n // en `panelClass` par le consommateur ne doit pas apparaître deux fois.\n const merged = [...new Set([...resolveKtDialogPanelClass(presentation, viewport.isCompact()), ...extra])];\n\n const uid = idGen.generateId();\n const titleId = `kt-dialog-title-${uid}`;\n const descId = `kt-dialog-desc-${uid}`;\n\n return dialog.open<R, D, C>(component, {\n viewContainerRef,\n container: KtDialogContainer,\n ariaLabelledBy: titleId,\n ariaDescribedBy: descId,\n ...rest,\n panelClass: merged,\n data,\n } as DialogConfig<D, DialogRef<R, C>>);\n };\n}\n","import { KtDialogTitle } from './dialog-title.directive';\nimport { KtDialogDescription } from './dialog-description.directive';\nimport { KtDialogClose } from './dialog-close.directive';\nimport {\n KtDialogHeader,\n KtDialogContent,\n KtDialogActions,\n KtDialogFocusInitial,\n KtDialogSheetHandle,\n} from './dialog-structure';\n\nexport * from './dialog-title.directive';\nexport * from './dialog-description.directive';\nexport * from './dialog-close.directive';\nexport * from './dialog-structure';\nexport * from './dialog-config';\nexport * from './dialog-opener';\nexport * from './dialog-container';\n\n/**\n * Import ergonomique de toute la famille dialog en une fois :\n * `imports: [KT_DIALOG]` au lieu d'énumérer chaque directive structurelle.\n */\nexport const KT_DIALOG = [\n KtDialogHeader,\n KtDialogTitle,\n KtDialogDescription,\n KtDialogContent,\n KtDialogActions,\n KtDialogClose,\n KtDialogFocusInitial,\n KtDialogSheetHandle,\n] as const;\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"ktortu-aaa-dialog.mjs","sources":["../../../../projects/ktortu/aaa/dialog/dialog-title.directive.ts","../../../../projects/ktortu/aaa/dialog/dialog-description.directive.ts","../../../../projects/ktortu/aaa/dialog/dialog-close.directive.ts","../../../../projects/ktortu/aaa/dialog/dialog-structure.ts","../../../../projects/ktortu/aaa/dialog/dialog-config.ts","../../../../projects/ktortu/aaa/dialog/dialog-container.ts","../../../../projects/ktortu/aaa/dialog/dialog-opener.ts","../../../../projects/ktortu/aaa/dialog/public-api.ts","../../../../projects/ktortu/aaa/dialog/ktortu-aaa-dialog.ts"],"sourcesContent":["import { DialogRef } from '@angular/cdk/dialog';\nimport { Directive, ElementRef, Renderer2, afterNextRender, inject } from '@angular/core';\nimport { KtIdGenerator } from '@ktortu/aaa/cdk';\n\n/**\n * À poser sur le titre VISIBLE (idéalement un `<h2>`) du contenu d'un CDK Dialog.\n * Câble `aria-labelledby` du conteneur de dialogue.\n *\n * Pourquoi écrire l'attribut directement (Renderer2) plutôt que seulement `_addAriaLabelledBy` :\n * sous change detection ZONELESS (cas par défaut moderne), le `markForCheck()` interne du\n * conteneur ne rafraîchit pas ses host bindings à l'ouverture, donc l'attribut n'apparaîtrait\n * jamais. On écrit donc l'attribut nous-mêmes (fiable, indépendant de la CD) ET on alimente la\n * file CDK pour rester cohérent si un cycle de CD survient ensuite.\n *\n * @example\n * ```html\n * <h2 ktDialogTitle>Renommer le fichier</h2>\n * ```\n */\n@Directive({\n selector: '[ktDialogTitle]',\n host: { '[id]': 'id' },\n})\nexport class KtDialogTitle {\n private readonly dialogRef = inject<DialogRef<unknown>>(DialogRef, { optional: true });\n private readonly host = inject<ElementRef<HTMLElement>>(ElementRef).nativeElement;\n private readonly renderer = inject(Renderer2);\n private readonly idGen = inject(KtIdGenerator);\n\n /**\n * Id de l'hôte câblé en `aria-labelledby` : préserve un id fourni par le consommateur, sinon en génère un.\n * @default `host.id` ?? `dialogRef.config.ariaLabelledBy` ?? `kt-dialog-title-<généré>`\n */\n readonly id =\n this.host.id || this.dialogRef?.config.ariaLabelledBy || `kt-dialog-title-${this.idGen.generateId('dialog')}`;\n\n constructor() {\n const preConfigured = this.dialogRef?.config.ariaLabelledBy;\n if (!preConfigured) {\n if (this.dialogRef) {\n this.dialogRef.config.ariaLabelledBy = this.id;\n }\n afterNextRender(() => {\n const container = this.host.closest('.cdk-dialog-container');\n if (container) this.renderer.setAttribute(container, 'aria-labelledby', this.id);\n });\n }\n }\n}\n","import { DialogRef } from '@angular/cdk/dialog';\nimport { Directive, ElementRef, OnDestroy, OnInit, Renderer2, afterNextRender, inject } from '@angular/core';\nimport { KtIdGenerator } from '@ktortu/aaa/cdk';\n\n/**\n * À poser sur le paragraphe descriptif COURT du dialog : câble `aria-describedby` du conteneur\n * (texte lu par le lecteur d'écran juste après le titre, à l'ouverture).\n *\n * ⚠️ Ne JAMAIS appliquer sur un formulaire ou un long contenu : `aria-describedby` concatène\n * tout le texte du nœud et serait lu d'un bloc à l'ouverture. Réserver à une phrase de contexte.\n *\n * Écriture directe de l'attribut (Renderer2) pour la même raison que `ktDialogTitle` :\n * fiabilité sous change detection zoneless. La config est tenue à jour pour cohérence CDK.\n *\n * @example\n * ```html\n * <p ktDialogDescription>Cette action est définitive.</p>\n * ```\n */\n@Directive({\n selector: '[ktDialogDescription]',\n host: { '[id]': 'id' },\n})\nexport class KtDialogDescription implements OnInit, OnDestroy {\n private readonly dialogRef = inject<DialogRef<unknown>>(DialogRef, { optional: true });\n private readonly host = inject<ElementRef<HTMLElement>>(ElementRef).nativeElement;\n private readonly renderer = inject(Renderer2);\n private readonly idGen = inject(KtIdGenerator);\n\n /**\n * Id de l'hôte câblé en `aria-describedby` : préserve un id fourni par le consommateur, sinon en génère un.\n * @default `host.id` ?? `dialogRef.config.ariaDescribedBy` ?? `kt-dialog-desc-<généré>`\n */\n readonly id =\n this.host.id || this.dialogRef?.config.ariaDescribedBy || `kt-dialog-desc-${this.idGen.generateId('dialog')}`;\n\n constructor() {\n const preConfigured = this.dialogRef?.config.ariaDescribedBy;\n if (!preConfigured) {\n if (this.dialogRef) {\n this.dialogRef.config.ariaDescribedBy = this.id;\n }\n afterNextRender(() => {\n const container = this.host.closest('.cdk-dialog-container');\n if (container) this.renderer.setAttribute(container, 'aria-describedby', this.id);\n });\n }\n }\n\n ngOnInit(): void {\n // Asymétrie ASSUMÉE avec `ktDialogTitle` : la description peut porter un `id` d'hôte fourni par\n // le consommateur ; on aligne alors `config.ariaDescribedBy` dessus (le host binding live du\n // conteneur reflète la valeur). Un titre est posé une fois et n'a pas ce besoin.\n if (this.dialogRef && this.dialogRef.config.ariaDescribedBy !== this.id) {\n this.dialogRef.config.ariaDescribedBy = this.id;\n }\n }\n\n ngOnDestroy(): void {\n if (this.dialogRef?.config.ariaDescribedBy === this.id) {\n this.dialogRef.config.ariaDescribedBy = null;\n }\n }\n}\n","import { DialogRef } from '@angular/cdk/dialog';\nimport { Directive, ElementRef, afterNextRender, inject, input, isDevMode } from '@angular/core';\n\n/**\n * Ferme le CDK Dialog au clic, avec un résultat optionnel renvoyé à l'ouvreur via\n * `DialogRef.close(result)`. Se compose avec `[ktButton]` sur le même `<button>`.\n *\n * Réservé au DISMISS simple (Annuler / Fermer). Pour valider un formulaire, injectez\n * `DialogRef` dans votre composant et appelez `close(valeur)` après validation.\n *\n * @example\n * ```html\n * <button ktButton ktDialogClose>Annuler</button>\n * <button ktButton [ktDialogClose]=\"'confirm'\">Confirmer</button>\n * ```\n */\n@Directive({\n selector: '[ktDialogClose]',\n host: {\n '[attr.type]': 'buttonType',\n '(click)': 'close()',\n },\n})\nexport class KtDialogClose {\n private readonly dialogRef = inject<DialogRef<unknown>>(DialogRef, { optional: true });\n private readonly host = inject<ElementRef<HTMLElement>>(ElementRef).nativeElement;\n\n /**\n * Valeur renvoyée à l'ouvreur via `DialogRef.close(result)`. Liée par l'alias `ktDialogClose`\n * (= nom du sélecteur), d'où l'usage `[ktDialogClose]=\"'confirm'\"`. @default undefined\n */\n readonly dialogResult = input<unknown>(undefined, { alias: 'ktDialogClose' });\n\n // Force type=\"button\" sur un <button> (évite le submit implicite dans un <form>).\n protected readonly buttonType = this.host.tagName === 'BUTTON' ? 'button' : null;\n\n constructor() {\n // Garde-fou a11y (dev) : un bouton de fermeture doit avoir un nom accessible (WCAG 4.1.2).\n afterNextRender(() => {\n if (!isDevMode()) return;\n\n const named =\n (this.host.textContent ?? '').trim().length > 0 ||\n this.host.hasAttribute('aria-label') ||\n this.host.hasAttribute('aria-labelledby');\n if (!named) {\n console.warn(\n '[ktDialogClose] Bouton de fermeture sans nom accessible (WCAG 4.1.2) : ' +\n 'ajoutez du texte visible, aria-label ou aria-labelledby.',\n );\n }\n });\n }\n\n protected close(): void {\n this.dialogRef?.close(this.dialogResult());\n }\n}\n","import { DestroyRef, Directive, ElementRef, inject } from '@angular/core';\nimport { DialogRef } from '@angular/cdk/dialog';\n\nimport { createKtSheetDrag } from '@ktortu/aaa/cdk';\n\n/**\n * En-tête RICHE et OPTIONNEL du dialog : rangée flex pour composer une icône, le titre et/ou un\n * bouton de fermeture. Marqueur structurel sans logique — la mise en forme (flex, padding de\n * région, reset du padding du [ktDialogTitle] qu'il enveloppe) vit dans `dialog.css`.\n *\n * Sépare le LAYOUT (cette région) de l'ÉTIQUETTE ACCESSIBLE ([ktDialogTitle], qui garde\n * aria-labelledby). En usage simple — titre nu sans header — [ktDialogTitle] conserve son propre\n * padding : ce header n'est à utiliser que pour les en-têtes composés (icône, close top-right…).\n *\n * @example\n * ```html\n * <header ktDialogHeader>\n * <h2 ktDialogTitle>Titre</h2>\n * <button ktButton ktDialogClose aria-label=\"Fermer\">✕</button>\n * </header>\n * ```\n */\n@Directive({ selector: '[ktDialogHeader]' })\nexport class KtDialogHeader {}\n\n/**\n * Zone de contenu du dialog. Marqueur structurel sans logique : la mise en forme\n * (rythme vertical) vit dans `dialog.css` via le sélecteur `[ktDialogContent]`.\n *\n * @example\n * ```html\n * <div ktDialogContent>…</div>\n * ```\n */\n@Directive({ selector: '[ktDialogContent]' })\nexport class KtDialogContent {}\n\n/**\n * Barre d'actions du dialog (rangée de boutons). Marqueur structurel sans logique :\n * la mise en forme (flex, gap, sticky bas pour le Reflow AAA) vit dans `dialog.css`\n * via le sélecteur `[ktDialogActions]`.\n *\n * @example\n * ```html\n * <footer ktDialogActions>\n * <button ktButton ktDialogClose>Annuler</button>\n * <button ktButton [ktDialogClose]=\"'ok'\">Valider</button>\n * </footer>\n * ```\n */\n@Directive({ selector: '[ktDialogActions]' })\nexport class KtDialogActions {}\n\n/**\n * Marque l'élément à focaliser à l'ouverture. À coupler avec la config CDK\n * `autoFocus: '[ktDialogFocusInitial]'` (incluse dans `provideKtDialogDefaults`).\n * Permet d'éviter que le focus initial tombe sur une action destructrice.\n *\n * @example\n * ```html\n * <input ktDialogFocusInitial type=\"text\" />\n * ```\n */\n@Directive({ selector: '[ktDialogFocusInitial]' })\nexport class KtDialogFocusInitial {}\n\n/**\n * Poignée de préhension d'un dialog en mode `sheet` (bottom-sheet) : drag-to-dismiss vers le bas,\n * FACTORISÉ avec le Select via `createKtSheetDrag` (@ktortu/aaa). Geste DOUBLÉ par Échap + bouton\n * Fermer + clic sur le scrim (WCAG 2.5.1) — décoratif (`aria-hidden`).\n *\n * À poser sur la barre de préhension, premier enfant du contenu d'un dialog ouvert avec une\n * présentation `sheet` / `centered-sheet`. Le drag n'est actif que si le dialog est EFFECTIVEMENT\n * en mode sheet (la pane porte `kt-dialog--sheet`) — pas de dépendance au viewport : un `sheet`\n * toujours-bottom-sheet se drague aussi à la souris.\n *\n * @example\n * ```html\n * <div ktDialogContent>\n * <div ktDialogSheetHandle></div>\n * …\n * </div>\n * ```\n */\n@Directive({\n selector: '[ktDialogSheetHandle]',\n host: {\n '(pointerdown)': 'onStart($event)',\n '(mousedown)': '$event.preventDefault()',\n 'aria-hidden': 'true',\n },\n})\nexport class KtDialogSheetHandle {\n private readonly dialogRef = inject<DialogRef<unknown>>(DialogRef, { optional: true });\n private readonly host = inject<ElementRef<HTMLElement>>(ElementRef).nativeElement;\n private readonly destroyRef = inject(DestroyRef);\n\n // La feuille translatée = le conteneur CDK (position:fixed en mode sheet), trouvé en remontant.\n private readonly drag = createKtSheetDrag({\n pane: () => this.host.closest<HTMLElement>('.cdk-dialog-container'),\n onDismiss: () => this.dialogRef?.close(),\n draggingClass: 'kt-dialog-sheet--dragging',\n });\n\n constructor() {\n this.destroyRef.onDestroy(() => this.drag.destroy());\n }\n\n protected onStart(event: PointerEvent): void {\n // Actif seulement quand la PRÉSENTATION choisie par le dev est `sheet` (classe sur la pane).\n const pane = this.host.closest('.cdk-overlay-pane');\n if (!pane?.classList.contains('kt-dialog--sheet')) return;\n this.drag.start(event);\n }\n}\n","import { DEFAULT_DIALOG_CONFIG, DialogConfig } from '@angular/cdk/dialog';\nimport { Provider } from '@angular/core';\n\n/**\n * Valeurs par défaut orientées AAA pour `@angular/cdk/dialog`.\n * - `ariaModal: true` : explicite (le CDK le laisse OFF par défaut).\n * - `restoreFocus: true` : rend le focus au déclencheur à la fermeture.\n * - `panelClass` / `backdropClass` : crochets de style consommés par `dialog.css`.\n *\n * Pour focaliser un élément précis à l'ouverture (ex. éviter un bouton destructeur),\n * passez `autoFocus: '[ktDialogFocusInitial]'` dans la config d'ouverture et posez la\n * directive `ktDialogFocusInitial` sur la cible.\n *\n * @example\n * ```ts\n * // valeur de base, généralement consommée via provideKtDialogDefaults()\n * provideKtDialogDefaults({ ...KT_DIALOG_AAA_DEFAULTS });\n * ```\n */\nexport const KT_DIALOG_AAA_DEFAULTS: DialogConfig = {\n role: 'dialog',\n ariaModal: true,\n autoFocus: '[ktDialogFocusInitial]',\n restoreFocus: true,\n hasBackdrop: true,\n panelClass: 'kt-dialog',\n backdropClass: 'kt-dialog__backdrop',\n};\n\n/**\n * Enregistre les valeurs par défaut AAA du dialog au niveau application.\n * À ajouter aux `providers` de `app.config.ts`. `overrides` permet d'ajuster sans\n * tout réécrire (ex. `provideKtDialogDefaults({ maxWidth: '40rem' })`).\n *\n * @example\n * ```ts\n * // app.config.ts\n * export const appConfig: ApplicationConfig = {\n * providers: [provideKtDialogDefaults({ maxWidth: '40rem' })],\n * };\n * ```\n * @param overrides Surcharges partielles fusionnées par-dessus `KT_DIALOG_AAA_DEFAULTS`.\n * @returns Un `Provider` pour le token `DEFAULT_DIALOG_CONFIG`.\n */\nexport function provideKtDialogDefaults(overrides?: Partial<DialogConfig>): Provider {\n return {\n provide: DEFAULT_DIALOG_CONFIG,\n useValue: { ...KT_DIALOG_AAA_DEFAULTS, ...overrides },\n };\n}\n\n/**\n * Présentation du dialog, CHOISIE EXPLICITEMENT PAR LE DÉVELOPPEUR à l'ouverture (option\n * `presentation` de `injectKtDialogOpener`). Aucune bascule CSS automatique : le dev décide.\n * - `centered` : toujours centré (ex. confirmation) — DÉFAUT ;\n * - `fullscreen` : toujours plein écran (desktop compris) ;\n * - `sheet` : toujours bottom-sheet (desktop compris) ;\n * - `centered-fullscreen` : centré sur desktop, plein écran sur téléphone compact ;\n * - `centered-sheet` : centré sur desktop, bottom-sheet sur téléphone compact.\n * Les variantes `centered-*` sont résolues EN JS à l'ouverture (signal `KtViewport.isCompact()`), pas par le CSS —\n * la classe CSS finale est donc toujours une présentation CONCRÈTE (centered/fullscreen/sheet).\n */\nexport type KtDialogPresentation = 'centered' | 'fullscreen' | 'sheet' | 'centered-fullscreen' | 'centered-sheet';\n\n/** panelClass d'une présentation CONCRÈTE (sans variante responsive). */\nfunction concreteDialogPanelClass(p: 'centered' | 'fullscreen' | 'sheet'): string[] {\n if (p === 'fullscreen') return ['kt-dialog', 'kt-dialog--fullscreen'];\n if (p === 'sheet') return ['kt-dialog', 'kt-dialog--sheet'];\n return ['kt-dialog'];\n}\n\n/**\n * Résout une `KtDialogPresentation` (responsive comprise) en panelClass concret. Pour les variantes\n * `centered-*`, l'appelant fournit `compact` (= `KtViewport.isCompact()`, largeur seule) — centré\n * sur desktop, plein écran / sheet sur écran compact. Fonction pure (testable sans DOM).\n * Appelée par `injectKtDialogOpener` à chaque ouverture ; exportée pour un usage direct éventuel.\n *\n * @example\n * ```ts\n * resolveKtDialogPanelClass('sheet'); // ['kt-dialog', 'kt-dialog--sheet']\n * resolveKtDialogPanelClass('centered-sheet', true); // bottom-sheet sur écran compact\n * ```\n * @param presentation Présentation choisie par le dev (responsive comprise). Défaut `'centered'`.\n * @param compact `true` quand l'écran est compact (= `KtViewport.isCompact()`), pour résoudre les variantes `centered-*`. Défaut `false`.\n * @returns La liste des classes CSS de la présentation concrète résolue.\n */\nexport function resolveKtDialogPanelClass(presentation: KtDialogPresentation = 'centered', compact = false): string[] {\n if (presentation === 'centered' || presentation === 'fullscreen' || presentation === 'sheet') {\n return concreteDialogPanelClass(presentation);\n }\n if (presentation === 'centered-fullscreen') {\n return concreteDialogPanelClass(compact ? 'fullscreen' : 'centered');\n }\n return concreteDialogPanelClass(compact ? 'sheet' : 'centered'); // 'centered-sheet'\n}\n","import {\n ChangeDetectionStrategy,\n Component,\n DestroyRef,\n ElementRef,\n OnInit,\n afterNextRender,\n isDevMode,\n signal,\n inject,\n PLATFORM_ID,\n} from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { isPlatformBrowser } from '@angular/common';\nimport { CdkDialogContainer, DialogRef } from '@angular/cdk/dialog';\nimport { PortalModule } from '@angular/cdk/portal';\n\n@Component({\n selector: 'kt-dialog-container',\n changeDetection: ChangeDetectionStrategy.OnPush,\n imports: [PortalModule],\n host: {\n class: 'cdk-dialog-container kt-dialog-container',\n tabindex: '-1',\n '[attr.id]': '_config.id || null',\n '[attr.role]': '_config.role',\n '[attr.aria-modal]': '_config.ariaModal',\n '[attr.aria-labelledby]': '_config.ariaLabel ? null : _ariaLabelledByQueue[0]',\n '[attr.aria-label]': '_config.ariaLabel',\n '[attr.aria-describedby]': '_config.ariaDescribedBy || null',\n '[class.kt-dialog-container--sheet]': 'isSheet()',\n '[class.kt-dialog-container--closing]': 'isClosing()',\n },\n template: `\n <div class=\"kt-dialog-container__layout\">\n <ng-template cdkPortalOutlet></ng-template>\n </div>\n `,\n})\nexport class KtDialogContainer extends CdkDialogContainer implements OnInit {\n private readonly dialogRef = inject(DialogRef);\n private readonly elementRef = inject(ElementRef);\n private readonly host = this.elementRef.nativeElement as HTMLElement;\n private readonly platformId = inject(PLATFORM_ID);\n private readonly destroyRef = inject(DestroyRef);\n\n protected readonly isClosing = signal(false);\n\n constructor() {\n super();\n // Monkey-patch de dialogRef.close pour intercepter toutes les demandes de fermeture\n const originalClose = this.dialogRef.close.bind(this.dialogRef);\n this.dialogRef.close = (result?: unknown) => {\n this.animateAndClose(result, originalClose);\n };\n\n // L'ouvreur pré-réserve des ids titre/description ; les directives [ktDialogTitle]/[ktDialogDescription]\n // les adoptent. En leur absence, ces ids pointent dans le vide. Au rendu (navigateur) :\n // - aria-describedby orphelin → on RETIRE l'attribut (pas de description fournie) ;\n // - aucun nom accessible (ni titre ni aria-label) → warn dev (WCAG 4.1.2).\n afterNextRender(() => {\n const doc = this.host.ownerDocument;\n\n const describedBy = this.host.getAttribute('aria-describedby');\n if (describedBy && !doc.getElementById(describedBy)) {\n this.host.removeAttribute('aria-describedby');\n }\n\n if (!isDevMode()) return;\n const labelledBy = this.host.getAttribute('aria-labelledby');\n const hasName = !!this.host.getAttribute('aria-label') || (!!labelledBy && !!doc.getElementById(labelledBy));\n if (!hasName) {\n console.warn(\n '[ktDialog] dialog sans nom accessible : ajoutez un [ktDialogTitle] (ou `aria-label` via la config d’ouverture) — WCAG 4.1.2.',\n );\n }\n });\n }\n\n ngOnInit(): void {\n // Si la fermeture par clic extérieur/Échap est autorisée, on l'écoute pour lancer l'animation\n if (!this._config.disableClose) {\n this.dialogRef.backdropClick.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(() => this.dialogRef.close());\n this.dialogRef.keydownEvents.pipe(takeUntilDestroyed(this.destroyRef)).subscribe((event: KeyboardEvent) => {\n if (event.key === 'Escape') {\n event.preventDefault();\n this.dialogRef.close();\n }\n });\n }\n }\n\n protected isSheet(): boolean {\n return this._config.panelClass?.includes('kt-dialog--sheet') ?? false;\n }\n\n private animateAndClose(result: unknown, originalCloseFn: (r?: unknown) => void): void {\n if (this.isClosing()) return;\n this.isClosing.set(true);\n\n if (!isPlatformBrowser(this.platformId)) {\n originalCloseFn(result);\n return;\n }\n\n // Récupérer la durée de transition configurée en CSS (ex: \"150ms\" ou \"0.2s\")\n const styles = window.getComputedStyle(this.host);\n const durationStr = styles.transitionDuration || '0s';\n const durationMs = parseFloat(durationStr) * (durationStr.includes('ms') ? 1 : 1000);\n\n if (durationMs === 0) {\n originalCloseFn(result);\n return;\n }\n\n // Écouter la fin de la transition sur la propriété 'translate'\n const onTransitionEnd = (event: TransitionEvent) => {\n if (event.target === this.host && event.propertyName === 'translate') {\n this.host.removeEventListener('transitionend', onTransitionEnd);\n originalCloseFn(result);\n }\n };\n this.host.addEventListener('transitionend', onTransitionEnd);\n\n // Sécurité (au cas où la transition n'aboutirait pas)\n setTimeout(() => {\n this.host.removeEventListener('transitionend', onTransitionEnd);\n originalCloseFn(result);\n }, durationMs + 50);\n }\n}\n","import { DIALOG_DATA, Dialog, DialogConfig, DialogRef } from '@angular/cdk/dialog';\nimport { ComponentType } from '@angular/cdk/portal';\nimport { ViewContainerRef, inject } from '@angular/core';\nimport { KtViewport, KtIdGenerator } from '@ktortu/aaa/cdk';\n\nimport { KtDialogPresentation, resolveKtDialogPanelClass } from './dialog-config';\nimport { KtDialogContainer } from './dialog-container';\n\n/**\n * ⚠️ API BAS-NIVEAU — n'utilisez PAS ceci par défaut. Pour implémenter un dialog, passez par\n * {@link defineKtDialog} et son `injectData()` (qui lie le type des données à l'ouvreur).\n *\n * Sucre typé pour récupérer les données injectées dans un composant de dialogue (`DIALOG_DATA`).\n * Le type `T` est affirmé ICI indépendamment de l'ouvreur : rien ne garantit qu'il corresponde au\n * type passé à `injectKtDialogOpener` → risque de divergence silencieuse. À réserver à un cas où\n * `defineKtDialog` ne convient pas.\n */\nexport function injectKtDialogData<T>(): T {\n return inject<T>(DIALOG_DATA);\n}\n\n/** Config d'ouverture sans le champ `data` (fourni séparément, typé), enrichie de `presentation`. */\nexport type KtDialogOpenerConfig<D, R, C> = Omit<DialogConfig<D, DialogRef<R, C>>, 'data'> & {\n /** Présentation du dialog (cf. `KtDialogPresentation`) — choisie par le dev. Résolue à CHAQUE\n ouverture : les variantes responsive lisent le signal d'écran compact. Défaut : `'centered'`.\n Combinée à un éventuel `panelClass` additionnel. */\n presentation?: KtDialogPresentation;\n};\n\n/**\n * ⚠️ API BAS-NIVEAU — n'utilisez PAS ceci par défaut. Pour implémenter un dialog, passez par\n * {@link defineKtDialog} puis son `injectOpener(...)` : il fixe données + résultat une seule fois et\n * les partage avec `injectData()`/`injectRef()`. N'appelez `injectKtDialogOpener` directement que\n * dans un cas avancé où le contrat groupé de `defineKtDialog` ne convient pas.\n *\n * Crée un ouvreur de dialog typé en contexte d'injection : le contrat (composant + type de `data` +\n * type de résultat + config par défaut) est figé via les génériques `<Composant, Data, Résultat>`\n * (qu'il faut répéter — d'où la préférence pour `defineKtDialog`). L'ouvreur renvoyé est une closure\n * appelable n'importe où dans la classe, 100 % typée, sans nouvel `inject`.\n *\n * Conserve le `ViewContainerRef` du contexte appelant (le dialog hérite donc de l'arbre logique\n * d'injection), reste testable (TestBed fournit `Dialog`) et sans état global (SSR-safe).\n *\n * @param component Composant à monter dans le dialog.\n * @param baseConfig Config d'ouverture par défaut (sans `data`), enrichie de `presentation` ; fusionnée à chaque ouverture.\n * @returns Une closure d'ouverture typée : `() => DialogRef` (sans data) ou `(data, config?) => DialogRef` (avec data).\n * @see {@link defineKtDialog} — la façon recommandée d'obtenir cet ouvreur.\n */\n// Surcharge sans data (D = void) : l'ouvreur ne prend aucun argument (la config par défaut suffit).\nexport function injectKtDialogOpener<C, R = unknown>(\n component: ComponentType<C>,\n baseConfig?: KtDialogOpenerConfig<void, R, C>,\n): () => DialogRef<R, C>;\n// Surcharge avec data typée.\nexport function injectKtDialogOpener<C, D, R = unknown>(\n component: ComponentType<C>,\n baseConfig?: KtDialogOpenerConfig<D, R, C>,\n): (data: D, config?: KtDialogOpenerConfig<D, R, C>) => DialogRef<R, C>;\n\nexport function injectKtDialogOpener<C, D, R = unknown>(\n component: ComponentType<C>,\n baseConfig?: KtDialogOpenerConfig<D, R, C>,\n) {\n const dialog = inject(Dialog);\n const viewport = inject(KtViewport);\n // Optionnel : hors d'un arbre de vue (ex. service root), il n'y a pas de ViewContainerRef.\n const viewContainerRef = inject(ViewContainerRef, { optional: true }) ?? undefined;\n const idGen = inject(KtIdGenerator);\n\n return (data?: D, config?: KtDialogOpenerConfig<D, R, C>): DialogRef<R, C> => {\n // La présentation (choisie par le dev) est résolue ICI, à l'ouverture : les variantes\n // responsive lisent le signal d'écran compact. Le panelClass final = présentation concrète + extras.\n const { presentation, panelClass, ...rest } = { ...baseConfig, ...config };\n const extra = panelClass ? (Array.isArray(panelClass) ? panelClass : [panelClass]) : [];\n // Dédoublonné : une classe déjà fournie par la présentation (ex. `kt-dialog`) et repassée\n // en `panelClass` par le consommateur ne doit pas apparaître deux fois.\n const merged = [...new Set([...resolveKtDialogPanelClass(presentation, viewport.isCompact()), ...extra])];\n\n const uid = idGen.generateId('dialog');\n const titleId = `kt-dialog-title-${uid}`;\n const descId = `kt-dialog-desc-${uid}`;\n\n return dialog.open<R, D, C>(component, {\n viewContainerRef,\n container: KtDialogContainer,\n ariaLabelledBy: titleId,\n ariaDescribedBy: descId,\n ...rest,\n panelClass: merged,\n data,\n } as DialogConfig<D, DialogRef<R, C>>);\n };\n}\n\n/**\n * Contrat de dialog typé renvoyé par `defineKtDialog` : les trois accès (données, référence,\n * ouvreur) dérivent des MÊMES génériques `D`/`R`, déclarés une seule fois — impossible donc que\n * le type des données ou du résultat diverge entre le composant et l'ouvreur.\n *\n * @template D Type des données injectées (`void` si aucune).\n * @template R Type du résultat renvoyé à la fermeture.\n */\nexport interface KtDialogContract<D, R> {\n /** Données injectées (à appeler en contexte d'injection DANS le composant de dialog). */\n injectData(): D;\n /** Référence typée du dialog : `close()` n'accepte QUE le résultat `R` (sûreté de fermeture). */\n injectRef(): DialogRef<R>;\n /** Ouvreur typé CO-LOCALISÉ pour ce composant (cf. `injectKtDialogOpener`). */\n injectOpener<C>(\n component: ComponentType<C>,\n baseConfig?: KtDialogOpenerConfig<D, R, C>,\n ): (data: D, config?: KtDialogOpenerConfig<D, R, C>) => DialogRef<R, C>;\n}\n\n/**\n * ✅ STRATÉGIE PAR DÉFAUT pour implémenter un dialog `@ktortu/aaa`. Toute nouvelle dialog DOIT être\n * écrite ainsi. N'utilisez `injectKtDialogData` / `injectKtDialogOpener` directement QUE dans un cas\n * avancé non couvert ici.\n *\n * Définit le contrat typé du dialog (données `D` + résultat `R`) en UN SEUL endroit, co-localisé avec\n * le composant. Renvoie trois accès liés aux mêmes types — `injectData()` (données), `injectRef()`\n * (référence dont `close()` n'accepte que `R`) et `injectOpener()` (ouvreur) — d'où l'impossibilité\n * d'une divergence de type entre composant et ouvreur.\n *\n * Recette à copier pour CHAQUE dialog :\n * 1. `interface XxxData { … }` (ou `void` si aucune donnée) ;\n * 2. `const xxxDialog = defineKtDialog<XxxData, Résultat>();` ;\n * 3. dans le composant : `injectData()` pour lire la donnée, `injectRef()` pour fermer avec résultat ;\n * 4. `export const injectXxxDialog = () => xxxDialog.injectOpener(XxxDialog);` (co-localisé) ;\n * 5. côté consommateur : `private readonly openXxx = injectXxxDialog();` (initialiseur de champ).\n *\n * Convention de fermeture : annuler / fermer SANS résultat via la directive `[ktDialogClose]`\n * (→ `undefined`) ; renvoyer un résultat via `ref.close(résultat)` (typé `R`). Passer un résultat par\n * `[ktDialogClose]=\"x\"` reste possible mais N'EST PAS typé (la directive ignore `R`).\n *\n * @example\n * ```ts\n * // ─── rename-dialog.ts : composant + contrat + ouvreur, co-localisés ───\n * export interface RenameData { currentName: string; }\n *\n * const renameDialog = defineKtDialog<RenameData, string>(); // D et R déclarés UNE seule fois\n *\n * @Component({\n * imports: [KtButton, KtDialogImports],\n * template: `\n * <h2 ktDialogTitle>Renommer</h2>\n * <footer ktDialogActions>\n * <button ktButton ktDialogClose>Annuler</button> // ferme sans résultat (undefined)\n * <button ktButton (click)=\"submit()\">Renommer</button> // ferme avec résultat typé\n * </footer>`,\n * })\n * export class RenameDialog {\n * protected readonly data = renameDialog.injectData(); // RenameData garanti\n * private readonly ref = renameDialog.injectRef(); // DialogRef<string>\n * protected submit() { this.ref.close('nouveau-nom'); } // close(result?: string) — typé\n * }\n *\n * export const injectRenameDialog = () => renameDialog.injectOpener(RenameDialog);\n *\n * // ─── consommateur ───\n * private readonly openRename = injectRenameDialog(); // initialiseur de champ = contexte d'injection\n * rename() {\n * this.openRename({ currentName: 'X' }).closed.subscribe(name => {\n * // name: string | undefined\n * });\n * }\n * ```\n */\nexport function defineKtDialog<D = void, R = unknown>(): KtDialogContract<D, R> {\n return {\n injectData: () => inject<D>(DIALOG_DATA),\n injectRef: () => inject(DialogRef) as DialogRef<R>,\n injectOpener: <C>(component: ComponentType<C>, baseConfig?: KtDialogOpenerConfig<D, R, C>) =>\n injectKtDialogOpener<C, D, R>(component, baseConfig) as (\n data: D,\n config?: KtDialogOpenerConfig<D, R, C>,\n ) => DialogRef<R, C>,\n };\n}\n","import { KtDialogTitle } from './dialog-title.directive';\nimport { KtDialogDescription } from './dialog-description.directive';\nimport { KtDialogClose } from './dialog-close.directive';\nimport {\n KtDialogHeader,\n KtDialogContent,\n KtDialogActions,\n KtDialogFocusInitial,\n KtDialogSheetHandle,\n} from './dialog-structure';\n\nexport * from './dialog-title.directive';\nexport * from './dialog-description.directive';\nexport * from './dialog-close.directive';\nexport * from './dialog-structure';\nexport * from './dialog-config';\n// Point d'entrée recommandé pour implémenter un dialog : `defineKtDialog<Data, Résultat>()`\n// (contrat typé co-localisé → injectData / injectRef / injectOpener). Les fonctions bas-niveau\n// `injectKtDialogData` / `injectKtDialogOpener` restent exportées mais sont à éviter par défaut.\nexport * from './dialog-opener';\nexport * from './dialog-container';\n\n/**\n * Import ergonomique de toute la famille dialog en une fois :\n * `imports: [KtDialogImports]` au lieu d'énumérer chaque directive structurelle.\n */\nexport const KtDialogImports = [\n KtDialogHeader,\n KtDialogTitle,\n KtDialogDescription,\n KtDialogContent,\n KtDialogActions,\n KtDialogClose,\n KtDialogFocusInitial,\n KtDialogSheetHandle,\n] as const;\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":[],"mappings":"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"}
|