@angular/cdk 21.0.2 → 21.1.0-next.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.
@@ -1 +1 @@
1
- {"version":3,"file":"a11y.mjs","sources":["../../../../../k8-fastbuild-ST-199a4f3c4e20/bin/src/cdk/a11y/aria-describer/aria-reference.ts","../../../../../k8-fastbuild-ST-199a4f3c4e20/bin/src/cdk/a11y/aria-describer/aria-describer.ts","../../../../../k8-fastbuild-ST-199a4f3c4e20/bin/src/cdk/a11y/key-manager/noop-tree-key-manager.ts","../../../../../k8-fastbuild-ST-199a4f3c4e20/bin/src/cdk/a11y/focus-trap/configurable-focus-trap.ts","../../../../../k8-fastbuild-ST-199a4f3c4e20/bin/src/cdk/a11y/focus-trap/event-listener-inert-strategy.ts","../../../../../k8-fastbuild-ST-199a4f3c4e20/bin/src/cdk/a11y/focus-trap/focus-trap-inert-strategy.ts","../../../../../k8-fastbuild-ST-199a4f3c4e20/bin/src/cdk/a11y/focus-trap/focus-trap-manager.ts","../../../../../k8-fastbuild-ST-199a4f3c4e20/bin/src/cdk/a11y/focus-trap/configurable-focus-trap-factory.ts"],"sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.dev/license\n */\n\n/** IDs are delimited by an empty space, as per the spec. */\nconst ID_DELIMITER = ' ';\n\n/**\n * Adds the given ID to the specified ARIA attribute on an element.\n * Used for attributes such as aria-labelledby, aria-owns, etc.\n */\nexport function addAriaReferencedId(el: Element, attr: `aria-${string}`, id: string) {\n const ids = getAriaReferenceIds(el, attr);\n id = id.trim();\n if (ids.some(existingId => existingId.trim() === id)) {\n return;\n }\n ids.push(id);\n\n el.setAttribute(attr, ids.join(ID_DELIMITER));\n}\n\n/**\n * Removes the given ID from the specified ARIA attribute on an element.\n * Used for attributes such as aria-labelledby, aria-owns, etc.\n */\nexport function removeAriaReferencedId(el: Element, attr: `aria-${string}`, id: string) {\n const ids = getAriaReferenceIds(el, attr);\n id = id.trim();\n const filteredIds = ids.filter(val => val !== id);\n\n if (filteredIds.length) {\n el.setAttribute(attr, filteredIds.join(ID_DELIMITER));\n } else {\n el.removeAttribute(attr);\n }\n}\n\n/**\n * Gets the list of IDs referenced by the given ARIA attribute on an element.\n * Used for attributes such as aria-labelledby, aria-owns, etc.\n */\nexport function getAriaReferenceIds(el: Element, attr: string): string[] {\n // Get string array of all individual ids (whitespace delimited) in the attribute value\n const attrValue = el.getAttribute(attr);\n return attrValue?.match(/\\S+/g) ?? [];\n}\n","/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.dev/license\n */\n\nimport {Injectable, OnDestroy, APP_ID, inject, DOCUMENT} from '@angular/core';\nimport {Platform} from '../../platform';\nimport {addAriaReferencedId, getAriaReferenceIds, removeAriaReferencedId} from './aria-reference';\nimport {_CdkPrivateStyleLoader, _VisuallyHiddenLoader} from '../../private';\n\n/**\n * Interface used to register message elements and keep a count of how many registrations have\n * the same message and the reference to the message element used for the `aria-describedby`.\n */\nexport interface RegisteredMessage {\n /** The element containing the message. */\n messageElement: Element;\n\n /** The number of elements that reference this message element via `aria-describedby`. */\n referenceCount: number;\n}\n\n/**\n * ID used for the body container where all messages are appended.\n * @deprecated No longer being used. To be removed.\n * @breaking-change 14.0.0\n */\nexport const MESSAGES_CONTAINER_ID = 'cdk-describedby-message-container';\n\n/**\n * ID prefix used for each created message element.\n * @deprecated To be turned into a private variable.\n * @breaking-change 14.0.0\n */\nexport const CDK_DESCRIBEDBY_ID_PREFIX = 'cdk-describedby-message';\n\n/**\n * Attribute given to each host element that is described by a message element.\n * @deprecated To be turned into a private variable.\n * @breaking-change 14.0.0\n */\nexport const CDK_DESCRIBEDBY_HOST_ATTRIBUTE = 'cdk-describedby-host';\n\n/** Global incremental identifier for each registered message element. */\nlet nextId = 0;\n\n/**\n * Utility that creates visually hidden elements with a message content. Useful for elements that\n * want to use aria-describedby to further describe themselves without adding additional visual\n * content.\n */\n@Injectable({providedIn: 'root'})\nexport class AriaDescriber implements OnDestroy {\n private _platform = inject(Platform);\n private _document = inject(DOCUMENT);\n\n /** Map of all registered message elements that have been placed into the document. */\n private _messageRegistry = new Map<string | Element, RegisteredMessage>();\n\n /** Container for all registered messages. */\n private _messagesContainer: HTMLElement | null = null;\n\n /** Unique ID for the service. */\n private readonly _id = `${nextId++}`;\n\n constructor(...args: unknown[]);\n\n constructor() {\n inject(_CdkPrivateStyleLoader).load(_VisuallyHiddenLoader);\n this._id = inject(APP_ID) + '-' + nextId++;\n }\n\n /**\n * Adds to the host element an aria-describedby reference to a hidden element that contains\n * the message. If the same message has already been registered, then it will reuse the created\n * message element.\n */\n describe(hostElement: Element, message: string, role?: string): void;\n\n /**\n * Adds to the host element an aria-describedby reference to an already-existing message element.\n */\n describe(hostElement: Element, message: HTMLElement): void;\n\n describe(hostElement: Element, message: string | HTMLElement, role?: string): void {\n if (!this._canBeDescribed(hostElement, message)) {\n return;\n }\n\n const key = getKey(message, role);\n\n if (typeof message !== 'string') {\n // We need to ensure that the element has an ID.\n setMessageId(message, this._id);\n this._messageRegistry.set(key, {messageElement: message, referenceCount: 0});\n } else if (!this._messageRegistry.has(key)) {\n this._createMessageElement(message, role);\n }\n\n if (!this._isElementDescribedByMessage(hostElement, key)) {\n this._addMessageReference(hostElement, key);\n }\n }\n\n /** Removes the host element's aria-describedby reference to the message. */\n removeDescription(hostElement: Element, message: string, role?: string): void;\n\n /** Removes the host element's aria-describedby reference to the message element. */\n removeDescription(hostElement: Element, message: HTMLElement): void;\n\n removeDescription(hostElement: Element, message: string | HTMLElement, role?: string): void {\n if (!message || !this._isElementNode(hostElement)) {\n return;\n }\n\n const key = getKey(message, role);\n\n if (this._isElementDescribedByMessage(hostElement, key)) {\n this._removeMessageReference(hostElement, key);\n }\n\n // If the message is a string, it means that it's one that we created for the\n // consumer so we can remove it safely, otherwise we should leave it in place.\n if (typeof message === 'string') {\n const registeredMessage = this._messageRegistry.get(key);\n if (registeredMessage && registeredMessage.referenceCount === 0) {\n this._deleteMessageElement(key);\n }\n }\n\n if (this._messagesContainer?.childNodes.length === 0) {\n this._messagesContainer.remove();\n this._messagesContainer = null;\n }\n }\n\n /** Unregisters all created message elements and removes the message container. */\n ngOnDestroy() {\n const describedElements = this._document.querySelectorAll(\n `[${CDK_DESCRIBEDBY_HOST_ATTRIBUTE}=\"${this._id}\"]`,\n );\n\n for (let i = 0; i < describedElements.length; i++) {\n this._removeCdkDescribedByReferenceIds(describedElements[i]);\n describedElements[i].removeAttribute(CDK_DESCRIBEDBY_HOST_ATTRIBUTE);\n }\n\n this._messagesContainer?.remove();\n this._messagesContainer = null;\n this._messageRegistry.clear();\n }\n\n /**\n * Creates a new element in the visually hidden message container element with the message\n * as its content and adds it to the message registry.\n */\n private _createMessageElement(message: string, role?: string) {\n const messageElement = this._document.createElement('div');\n setMessageId(messageElement, this._id);\n messageElement.textContent = message;\n\n if (role) {\n messageElement.setAttribute('role', role);\n }\n\n this._createMessagesContainer();\n this._messagesContainer!.appendChild(messageElement);\n this._messageRegistry.set(getKey(message, role), {messageElement, referenceCount: 0});\n }\n\n /** Deletes the message element from the global messages container. */\n private _deleteMessageElement(key: string | Element) {\n this._messageRegistry.get(key)?.messageElement?.remove();\n this._messageRegistry.delete(key);\n }\n\n /** Creates the global container for all aria-describedby messages. */\n private _createMessagesContainer() {\n if (this._messagesContainer) {\n return;\n }\n\n const containerClassName = 'cdk-describedby-message-container';\n const serverContainers = this._document.querySelectorAll(\n `.${containerClassName}[platform=\"server\"]`,\n );\n\n for (let i = 0; i < serverContainers.length; i++) {\n // When going from the server to the client, we may end up in a situation where there's\n // already a container on the page, but we don't have a reference to it. Clear the\n // old container so we don't get duplicates. Doing this, instead of emptying the previous\n // container, should be slightly faster.\n serverContainers[i].remove();\n }\n\n const messagesContainer = this._document.createElement('div');\n\n // We add `visibility: hidden` in order to prevent text in this container from\n // being searchable by the browser's Ctrl + F functionality.\n // Screen-readers will still read the description for elements with aria-describedby even\n // when the description element is not visible.\n messagesContainer.style.visibility = 'hidden';\n // Even though we use `visibility: hidden`, we still apply `cdk-visually-hidden` so that\n // the description element doesn't impact page layout.\n messagesContainer.classList.add(containerClassName);\n messagesContainer.classList.add('cdk-visually-hidden');\n\n if (!this._platform.isBrowser) {\n messagesContainer.setAttribute('platform', 'server');\n }\n\n this._document.body.appendChild(messagesContainer);\n this._messagesContainer = messagesContainer;\n }\n\n /** Removes all cdk-describedby messages that are hosted through the element. */\n private _removeCdkDescribedByReferenceIds(element: Element) {\n // Remove all aria-describedby reference IDs that are prefixed by CDK_DESCRIBEDBY_ID_PREFIX\n const originalReferenceIds = getAriaReferenceIds(element, 'aria-describedby').filter(\n id => id.indexOf(CDK_DESCRIBEDBY_ID_PREFIX) != 0,\n );\n element.setAttribute('aria-describedby', originalReferenceIds.join(' '));\n }\n\n /**\n * Adds a message reference to the element using aria-describedby and increments the registered\n * message's reference count.\n */\n private _addMessageReference(element: Element, key: string | Element) {\n const registeredMessage = this._messageRegistry.get(key)!;\n\n // Add the aria-describedby reference and set the\n // describedby_host attribute to mark the element.\n addAriaReferencedId(element, 'aria-describedby', registeredMessage.messageElement.id);\n element.setAttribute(CDK_DESCRIBEDBY_HOST_ATTRIBUTE, this._id);\n registeredMessage.referenceCount++;\n }\n\n /**\n * Removes a message reference from the element using aria-describedby\n * and decrements the registered message's reference count.\n */\n private _removeMessageReference(element: Element, key: string | Element) {\n const registeredMessage = this._messageRegistry.get(key)!;\n registeredMessage.referenceCount--;\n\n removeAriaReferencedId(element, 'aria-describedby', registeredMessage.messageElement.id);\n element.removeAttribute(CDK_DESCRIBEDBY_HOST_ATTRIBUTE);\n }\n\n /** Returns true if the element has been described by the provided message ID. */\n private _isElementDescribedByMessage(element: Element, key: string | Element): boolean {\n const referenceIds = getAriaReferenceIds(element, 'aria-describedby');\n const registeredMessage = this._messageRegistry.get(key);\n const messageId = registeredMessage && registeredMessage.messageElement.id;\n\n return !!messageId && referenceIds.indexOf(messageId) != -1;\n }\n\n /** Determines whether a message can be described on a particular element. */\n private _canBeDescribed(element: Element, message: string | HTMLElement | void): boolean {\n if (!this._isElementNode(element)) {\n return false;\n }\n\n if (message && typeof message === 'object') {\n // We'd have to make some assumptions about the description element's text, if the consumer\n // passed in an element. Assume that if an element is passed in, the consumer has verified\n // that it can be used as a description.\n return true;\n }\n\n const trimmedMessage = message == null ? '' : `${message}`.trim();\n const ariaLabel = element.getAttribute('aria-label');\n\n // We shouldn't set descriptions if they're exactly the same as the `aria-label` of the\n // element, because screen readers will end up reading out the same text twice in a row.\n return trimmedMessage ? !ariaLabel || ariaLabel.trim() !== trimmedMessage : false;\n }\n\n /** Checks whether a node is an Element node. */\n private _isElementNode(element: Node): element is Element {\n return element.nodeType === this._document.ELEMENT_NODE;\n }\n}\n\n/** Gets a key that can be used to look messages up in the registry. */\nfunction getKey(message: string | Element, role?: string): string | Element {\n return typeof message === 'string' ? `${role || ''}/${message}` : message;\n}\n\n/** Assigns a unique ID to an element, if it doesn't have one already. */\nfunction setMessageId(element: HTMLElement, serviceId: string) {\n if (!element.id) {\n element.id = `${CDK_DESCRIBEDBY_ID_PREFIX}-${serviceId}-${nextId++}`;\n }\n}\n","/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.dev/license\n */\n\nimport {Subject} from 'rxjs';\nimport {TREE_KEY_MANAGER} from './tree-key-manager';\nimport {TreeKeyManagerItem, TreeKeyManagerStrategy} from './tree-key-manager-strategy';\nimport {Provider} from '@angular/core';\n\n// NoopTreeKeyManager is a \"noop\" implementation of TreeKeyMangerStrategy. Methods are noops. Does\n// not emit to streams.\n//\n// Used for applications built before TreeKeyManager to opt-out of TreeKeyManager and revert to\n// legacy behavior.\n/**\n * @docs-private\n *\n * Opt-out of Tree of key manager behavior.\n *\n * When provided, Tree has same focus management behavior as before TreeKeyManager was introduced.\n * - Tree does not respond to keyboard interaction\n * - Tree node allows tabindex to be set by Input binding\n * - Tree node allows tabindex to be set by attribute binding\n *\n * @deprecated NoopTreeKeyManager deprecated. Use TreeKeyManager or inject a\n * TreeKeyManagerStrategy instead. To be removed in a future version.\n *\n * @breaking-change 21.0.0\n */\nexport class NoopTreeKeyManager<T extends TreeKeyManagerItem> implements TreeKeyManagerStrategy<T> {\n readonly _isNoopTreeKeyManager = true;\n\n // Provide change as required by TreeKeyManagerStrategy. NoopTreeKeyManager is a \"noop\"\n // implementation that does not emit to streams.\n readonly change = new Subject<T | null>();\n\n destroy() {\n this.change.complete();\n }\n\n onKeydown() {\n // noop\n }\n\n getActiveItemIndex() {\n // Always return null. NoopTreeKeyManager is a \"noop\" implementation that does not maintain\n // the active item.\n return null;\n }\n\n getActiveItem() {\n // Always return null. NoopTreeKeyManager is a \"noop\" implementation that does not maintain\n // the active item.\n return null;\n }\n\n focusItem() {\n // noop\n }\n}\n\n/**\n * @docs-private\n *\n * Opt-out of Tree of key manager behavior.\n *\n * When provided, Tree has same focus management behavior as before TreeKeyManager was introduced.\n * - Tree does not respond to keyboard interaction\n * - Tree node allows tabindex to be set by Input binding\n * - Tree node allows tabindex to be set by attribute binding\n *\n * @deprecated NoopTreeKeyManager deprecated. Use TreeKeyManager or inject a\n * TreeKeyManagerStrategy instead. To be removed in a future version.\n *\n * @breaking-change 21.0.0\n */\nexport const NOOP_TREE_KEY_MANAGER_FACTORY_PROVIDER: Provider = {\n provide: TREE_KEY_MANAGER,\n useFactory: () => () => new NoopTreeKeyManager(),\n};\n","/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.dev/license\n */\n\nimport {Injector, NgZone} from '@angular/core';\nimport {InteractivityChecker} from '../interactivity-checker/interactivity-checker';\nimport {ConfigurableFocusTrapConfig} from './configurable-focus-trap-config';\nimport {FocusTrap} from './focus-trap';\nimport {FocusTrapInertStrategy} from './focus-trap-inert-strategy';\nimport {FocusTrapManager, ManagedFocusTrap} from './focus-trap-manager';\n\n/**\n * Class that allows for trapping focus within a DOM element.\n *\n * This class uses a strategy pattern that determines how it traps focus.\n * See FocusTrapInertStrategy.\n */\nexport class ConfigurableFocusTrap extends FocusTrap implements ManagedFocusTrap {\n /** Whether the FocusTrap is enabled. */\n override get enabled(): boolean {\n return this._enabled;\n }\n override set enabled(value: boolean) {\n this._enabled = value;\n if (this._enabled) {\n this._focusTrapManager.register(this);\n } else {\n this._focusTrapManager.deregister(this);\n }\n }\n\n constructor(\n _element: HTMLElement,\n _checker: InteractivityChecker,\n _ngZone: NgZone,\n _document: Document,\n private _focusTrapManager: FocusTrapManager,\n private _inertStrategy: FocusTrapInertStrategy,\n config: ConfigurableFocusTrapConfig,\n injector?: Injector,\n ) {\n super(_element, _checker, _ngZone, _document, config.defer, injector);\n this._focusTrapManager.register(this);\n }\n\n /** Notifies the FocusTrapManager that this FocusTrap will be destroyed. */\n override destroy() {\n this._focusTrapManager.deregister(this);\n super.destroy();\n }\n\n /** @docs-private Implemented as part of ManagedFocusTrap. */\n _enable() {\n this._inertStrategy.preventFocus(this);\n this.toggleAnchors(true);\n }\n\n /** @docs-private Implemented as part of ManagedFocusTrap. */\n _disable() {\n this._inertStrategy.allowFocus(this);\n this.toggleAnchors(false);\n }\n}\n","/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.dev/license\n */\n\nimport {FocusTrapInertStrategy} from './focus-trap-inert-strategy';\nimport {ConfigurableFocusTrap} from './configurable-focus-trap';\n\n/**\n * Lightweight FocusTrapInertStrategy that adds a document focus event\n * listener to redirect focus back inside the FocusTrap.\n */\nexport class EventListenerFocusTrapInertStrategy implements FocusTrapInertStrategy {\n /** Focus event handler. */\n private _listener: ((e: FocusEvent) => void) | null = null;\n\n /** Adds a document event listener that keeps focus inside the FocusTrap. */\n preventFocus(focusTrap: ConfigurableFocusTrap): void {\n // Ensure there's only one listener per document\n if (this._listener) {\n focusTrap._document.removeEventListener('focus', this._listener!, true);\n }\n\n this._listener = (e: FocusEvent) => this._trapFocus(focusTrap, e);\n focusTrap._ngZone.runOutsideAngular(() => {\n focusTrap._document.addEventListener('focus', this._listener!, true);\n });\n }\n\n /** Removes the event listener added in preventFocus. */\n allowFocus(focusTrap: ConfigurableFocusTrap): void {\n if (!this._listener) {\n return;\n }\n focusTrap._document.removeEventListener('focus', this._listener!, true);\n this._listener = null;\n }\n\n /**\n * Refocuses the first element in the FocusTrap if the focus event target was outside\n * the FocusTrap.\n *\n * This is an event listener callback. The event listener is added in runOutsideAngular,\n * so all this code runs outside Angular as well.\n */\n private _trapFocus(focusTrap: ConfigurableFocusTrap, event: FocusEvent) {\n const target = event.target as HTMLElement;\n const focusTrapRoot = focusTrap._element;\n\n // Don't refocus if target was in an overlay, because the overlay might be associated\n // with an element inside the FocusTrap, ex. mat-select.\n if (target && !focusTrapRoot.contains(target) && !target.closest?.('div.cdk-overlay-pane')) {\n // Some legacy FocusTrap usages have logic that focuses some element on the page\n // just before FocusTrap is destroyed. For backwards compatibility, wait\n // to be sure FocusTrap is still enabled before refocusing.\n setTimeout(() => {\n // Check whether focus wasn't put back into the focus trap while the timeout was pending.\n if (focusTrap.enabled && !focusTrapRoot.contains(focusTrap._document.activeElement)) {\n focusTrap.focusFirstTabbableElement();\n }\n });\n }\n }\n}\n","/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.dev/license\n */\nimport {InjectionToken} from '@angular/core';\nimport {FocusTrap} from './focus-trap';\n\n/** The injection token used to specify the inert strategy. */\nexport const FOCUS_TRAP_INERT_STRATEGY = new InjectionToken<FocusTrapInertStrategy>(\n 'FOCUS_TRAP_INERT_STRATEGY',\n);\n\n/**\n * A strategy that dictates how FocusTrap should prevent elements\n * outside of the FocusTrap from being focused.\n */\nexport interface FocusTrapInertStrategy {\n /** Makes all elements outside focusTrap unfocusable. */\n preventFocus(focusTrap: FocusTrap): void;\n /** Reverts elements made unfocusable by preventFocus to their previous state. */\n allowFocus(focusTrap: FocusTrap): void;\n}\n","/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.dev/license\n */\n\nimport {Injectable} from '@angular/core';\n\n/**\n * A FocusTrap managed by FocusTrapManager.\n * Implemented by ConfigurableFocusTrap to avoid circular dependency.\n */\nexport interface ManagedFocusTrap {\n _enable(): void;\n _disable(): void;\n focusInitialElementWhenReady(): Promise<boolean>;\n}\n\n/** Injectable that ensures only the most recently enabled FocusTrap is active. */\n@Injectable({providedIn: 'root'})\nexport class FocusTrapManager {\n // A stack of the FocusTraps on the page. Only the FocusTrap at the\n // top of the stack is active.\n private _focusTrapStack: ManagedFocusTrap[] = [];\n\n /**\n * Disables the FocusTrap at the top of the stack, and then pushes\n * the new FocusTrap onto the stack.\n */\n register(focusTrap: ManagedFocusTrap): void {\n // Dedupe focusTraps that register multiple times.\n this._focusTrapStack = this._focusTrapStack.filter(ft => ft !== focusTrap);\n\n let stack = this._focusTrapStack;\n\n if (stack.length) {\n stack[stack.length - 1]._disable();\n }\n\n stack.push(focusTrap);\n focusTrap._enable();\n }\n\n /**\n * Removes the FocusTrap from the stack, and activates the\n * FocusTrap that is the new top of the stack.\n */\n deregister(focusTrap: ManagedFocusTrap): void {\n focusTrap._disable();\n\n const stack = this._focusTrapStack;\n\n const i = stack.indexOf(focusTrap);\n if (i !== -1) {\n stack.splice(i, 1);\n if (stack.length) {\n stack[stack.length - 1]._enable();\n }\n }\n }\n}\n","/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.dev/license\n */\n\nimport {Injectable, Injector, NgZone, inject, DOCUMENT} from '@angular/core';\nimport {InteractivityChecker} from '../interactivity-checker/interactivity-checker';\nimport {ConfigurableFocusTrap} from './configurable-focus-trap';\nimport {ConfigurableFocusTrapConfig} from './configurable-focus-trap-config';\nimport {EventListenerFocusTrapInertStrategy} from './event-listener-inert-strategy';\nimport {FOCUS_TRAP_INERT_STRATEGY, FocusTrapInertStrategy} from './focus-trap-inert-strategy';\nimport {FocusTrapManager} from './focus-trap-manager';\n\n/** Factory that allows easy instantiation of configurable focus traps. */\n@Injectable({providedIn: 'root'})\nexport class ConfigurableFocusTrapFactory {\n private _checker = inject(InteractivityChecker);\n private _ngZone = inject(NgZone);\n private _focusTrapManager = inject(FocusTrapManager);\n\n private _document = inject(DOCUMENT);\n private _inertStrategy: FocusTrapInertStrategy;\n\n private readonly _injector = inject(Injector);\n\n constructor(...args: unknown[]);\n\n constructor() {\n const inertStrategy = inject(FOCUS_TRAP_INERT_STRATEGY, {optional: true});\n\n // TODO split up the strategies into different modules, similar to DateAdapter.\n this._inertStrategy = inertStrategy || new EventListenerFocusTrapInertStrategy();\n }\n\n /**\n * Creates a focus-trapped region around the given element.\n * @param element The element around which focus will be trapped.\n * @param config The focus trap configuration.\n * @returns The created focus trap instance.\n */\n create(element: HTMLElement, config?: ConfigurableFocusTrapConfig): ConfigurableFocusTrap;\n\n /**\n * @deprecated Pass a config object instead of the `deferCaptureElements` flag.\n * @breaking-change 11.0.0\n */\n create(element: HTMLElement, deferCaptureElements: boolean): ConfigurableFocusTrap;\n\n create(\n element: HTMLElement,\n config: ConfigurableFocusTrapConfig | boolean = {defer: false},\n ): ConfigurableFocusTrap {\n let configObject: ConfigurableFocusTrapConfig;\n if (typeof config === 'boolean') {\n configObject = {defer: config};\n } else {\n configObject = config;\n }\n return new ConfigurableFocusTrap(\n element,\n this._checker,\n this._ngZone,\n this._document,\n this._focusTrapManager,\n this._inertStrategy,\n configObject,\n this._injector,\n );\n }\n}\n"],"names":["ID_DELIMITER","addAriaReferencedId","el","attr","id","ids","getAriaReferenceIds","trim","some","existingId","push","setAttribute","join","removeAriaReferencedId","filteredIds","filter","val","length","removeAttribute","attrValue","getAttribute","match","MESSAGES_CONTAINER_ID","CDK_DESCRIBEDBY_ID_PREFIX","CDK_DESCRIBEDBY_HOST_ATTRIBUTE","nextId","AriaDescriber","_platform","inject","Platform","_document","DOCUMENT","_messageRegistry","Map","_messagesContainer","_id","constructor","_CdkPrivateStyleLoader","load","_VisuallyHiddenLoader","APP_ID","describe","hostElement","message","role","_canBeDescribed","key","getKey","setMessageId","set","messageElement","referenceCount","has","_createMessageElement","_isElementDescribedByMessage","_addMessageReference","removeDescription","_isElementNode","_removeMessageReference","registeredMessage","get","_deleteMessageElement","childNodes","remove","ngOnDestroy","describedElements","querySelectorAll","i","_removeCdkDescribedByReferenceIds","clear","createElement","textContent","_createMessagesContainer","appendChild","delete","containerClassName","serverContainers","messagesContainer","style","visibility","classList","add","isBrowser","body","element","originalReferenceIds","indexOf","referenceIds","messageId","trimmedMessage","ariaLabel","nodeType","ELEMENT_NODE","deps","target","i0","ɵɵFactoryTarget","Injectable","ɵprov","ɵɵngDeclareInjectable","minVersion","version","ngImport","type","decorators","providedIn","serviceId","NoopTreeKeyManager","_isNoopTreeKeyManager","change","Subject","destroy","complete","onKeydown","getActiveItemIndex","getActiveItem","focusItem","NOOP_TREE_KEY_MANAGER_FACTORY_PROVIDER","provide","TREE_KEY_MANAGER","useFactory","ConfigurableFocusTrap","FocusTrap","_focusTrapManager","_inertStrategy","enabled","_enabled","value","register","deregister","_element","_checker","_ngZone","config","injector","defer","_enable","preventFocus","toggleAnchors","_disable","allowFocus","EventListenerFocusTrapInertStrategy","_listener","focusTrap","removeEventListener","e","_trapFocus","runOutsideAngular","addEventListener","event","focusTrapRoot","contains","closest","setTimeout","activeElement","focusFirstTabbableElement","FOCUS_TRAP_INERT_STRATEGY","InjectionToken","FocusTrapManager","_focusTrapStack","ft","stack","splice","ConfigurableFocusTrapFactory","InteractivityChecker","NgZone","_injector","Injector","inertStrategy","optional","create","configObject"],"mappings":"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"}
1
+ {"version":3,"file":"a11y.mjs","sources":["../../../../../k8-fastbuild-ST-199a4f3c4e20/bin/src/cdk/a11y/aria-describer/aria-reference.ts","../../../../../k8-fastbuild-ST-199a4f3c4e20/bin/src/cdk/a11y/aria-describer/aria-describer.ts","../../../../../k8-fastbuild-ST-199a4f3c4e20/bin/src/cdk/a11y/key-manager/noop-tree-key-manager.ts","../../../../../k8-fastbuild-ST-199a4f3c4e20/bin/src/cdk/a11y/focus-trap/configurable-focus-trap.ts","../../../../../k8-fastbuild-ST-199a4f3c4e20/bin/src/cdk/a11y/focus-trap/event-listener-inert-strategy.ts","../../../../../k8-fastbuild-ST-199a4f3c4e20/bin/src/cdk/a11y/focus-trap/focus-trap-inert-strategy.ts","../../../../../k8-fastbuild-ST-199a4f3c4e20/bin/src/cdk/a11y/focus-trap/focus-trap-manager.ts","../../../../../k8-fastbuild-ST-199a4f3c4e20/bin/src/cdk/a11y/focus-trap/configurable-focus-trap-factory.ts"],"sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.dev/license\n */\n\n/** IDs are delimited by an empty space, as per the spec. */\nconst ID_DELIMITER = ' ';\n\n/**\n * Adds the given ID to the specified ARIA attribute on an element.\n * Used for attributes such as aria-labelledby, aria-owns, etc.\n */\nexport function addAriaReferencedId(el: Element, attr: `aria-${string}`, id: string) {\n const ids = getAriaReferenceIds(el, attr);\n id = id.trim();\n if (ids.some(existingId => existingId.trim() === id)) {\n return;\n }\n ids.push(id);\n\n el.setAttribute(attr, ids.join(ID_DELIMITER));\n}\n\n/**\n * Removes the given ID from the specified ARIA attribute on an element.\n * Used for attributes such as aria-labelledby, aria-owns, etc.\n */\nexport function removeAriaReferencedId(el: Element, attr: `aria-${string}`, id: string) {\n const ids = getAriaReferenceIds(el, attr);\n id = id.trim();\n const filteredIds = ids.filter(val => val !== id);\n\n if (filteredIds.length) {\n el.setAttribute(attr, filteredIds.join(ID_DELIMITER));\n } else {\n el.removeAttribute(attr);\n }\n}\n\n/**\n * Gets the list of IDs referenced by the given ARIA attribute on an element.\n * Used for attributes such as aria-labelledby, aria-owns, etc.\n */\nexport function getAriaReferenceIds(el: Element, attr: string): string[] {\n // Get string array of all individual ids (whitespace delimited) in the attribute value\n const attrValue = el.getAttribute(attr);\n return attrValue?.match(/\\S+/g) ?? [];\n}\n","/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.dev/license\n */\n\nimport {Injectable, OnDestroy, APP_ID, inject, DOCUMENT} from '@angular/core';\nimport {Platform} from '../../platform';\nimport {addAriaReferencedId, getAriaReferenceIds, removeAriaReferencedId} from './aria-reference';\nimport {_CdkPrivateStyleLoader, _VisuallyHiddenLoader} from '../../private';\n\n/**\n * Interface used to register message elements and keep a count of how many registrations have\n * the same message and the reference to the message element used for the `aria-describedby`.\n */\nexport interface RegisteredMessage {\n /** The element containing the message. */\n messageElement: Element;\n\n /** The number of elements that reference this message element via `aria-describedby`. */\n referenceCount: number;\n}\n\n/**\n * ID used for the body container where all messages are appended.\n * @deprecated No longer being used. To be removed.\n * @breaking-change 14.0.0\n */\nexport const MESSAGES_CONTAINER_ID = 'cdk-describedby-message-container';\n\n/**\n * ID prefix used for each created message element.\n * @deprecated To be turned into a private variable.\n * @breaking-change 14.0.0\n */\nexport const CDK_DESCRIBEDBY_ID_PREFIX = 'cdk-describedby-message';\n\n/**\n * Attribute given to each host element that is described by a message element.\n * @deprecated To be turned into a private variable.\n * @breaking-change 14.0.0\n */\nexport const CDK_DESCRIBEDBY_HOST_ATTRIBUTE = 'cdk-describedby-host';\n\n/** Global incremental identifier for each registered message element. */\nlet nextId = 0;\n\n/**\n * Utility that creates visually hidden elements with a message content. Useful for elements that\n * want to use aria-describedby to further describe themselves without adding additional visual\n * content.\n */\n@Injectable({providedIn: 'root'})\nexport class AriaDescriber implements OnDestroy {\n private _platform = inject(Platform);\n private _document = inject(DOCUMENT);\n\n /** Map of all registered message elements that have been placed into the document. */\n private _messageRegistry = new Map<string | Element, RegisteredMessage>();\n\n /** Container for all registered messages. */\n private _messagesContainer: HTMLElement | null = null;\n\n /** Unique ID for the service. */\n private readonly _id = `${nextId++}`;\n\n constructor(...args: unknown[]);\n\n constructor() {\n inject(_CdkPrivateStyleLoader).load(_VisuallyHiddenLoader);\n this._id = inject(APP_ID) + '-' + nextId++;\n }\n\n /**\n * Adds to the host element an aria-describedby reference to a hidden element that contains\n * the message. If the same message has already been registered, then it will reuse the created\n * message element.\n */\n describe(hostElement: Element, message: string, role?: string): void;\n\n /**\n * Adds to the host element an aria-describedby reference to an already-existing message element.\n */\n describe(hostElement: Element, message: HTMLElement): void;\n\n describe(hostElement: Element, message: string | HTMLElement, role?: string): void {\n if (!this._canBeDescribed(hostElement, message)) {\n return;\n }\n\n const key = getKey(message, role);\n\n if (typeof message !== 'string') {\n // We need to ensure that the element has an ID.\n setMessageId(message, this._id);\n this._messageRegistry.set(key, {messageElement: message, referenceCount: 0});\n } else if (!this._messageRegistry.has(key)) {\n this._createMessageElement(message, role);\n }\n\n if (!this._isElementDescribedByMessage(hostElement, key)) {\n this._addMessageReference(hostElement, key);\n }\n }\n\n /** Removes the host element's aria-describedby reference to the message. */\n removeDescription(hostElement: Element, message: string, role?: string): void;\n\n /** Removes the host element's aria-describedby reference to the message element. */\n removeDescription(hostElement: Element, message: HTMLElement): void;\n\n removeDescription(hostElement: Element, message: string | HTMLElement, role?: string): void {\n if (!message || !this._isElementNode(hostElement)) {\n return;\n }\n\n const key = getKey(message, role);\n\n if (this._isElementDescribedByMessage(hostElement, key)) {\n this._removeMessageReference(hostElement, key);\n }\n\n // If the message is a string, it means that it's one that we created for the\n // consumer so we can remove it safely, otherwise we should leave it in place.\n if (typeof message === 'string') {\n const registeredMessage = this._messageRegistry.get(key);\n if (registeredMessage && registeredMessage.referenceCount === 0) {\n this._deleteMessageElement(key);\n }\n }\n\n if (this._messagesContainer?.childNodes.length === 0) {\n this._messagesContainer.remove();\n this._messagesContainer = null;\n }\n }\n\n /** Unregisters all created message elements and removes the message container. */\n ngOnDestroy() {\n const describedElements = this._document.querySelectorAll(\n `[${CDK_DESCRIBEDBY_HOST_ATTRIBUTE}=\"${this._id}\"]`,\n );\n\n for (let i = 0; i < describedElements.length; i++) {\n this._removeCdkDescribedByReferenceIds(describedElements[i]);\n describedElements[i].removeAttribute(CDK_DESCRIBEDBY_HOST_ATTRIBUTE);\n }\n\n this._messagesContainer?.remove();\n this._messagesContainer = null;\n this._messageRegistry.clear();\n }\n\n /**\n * Creates a new element in the visually hidden message container element with the message\n * as its content and adds it to the message registry.\n */\n private _createMessageElement(message: string, role?: string) {\n const messageElement = this._document.createElement('div');\n setMessageId(messageElement, this._id);\n messageElement.textContent = message;\n\n if (role) {\n messageElement.setAttribute('role', role);\n }\n\n this._createMessagesContainer();\n this._messagesContainer!.appendChild(messageElement);\n this._messageRegistry.set(getKey(message, role), {messageElement, referenceCount: 0});\n }\n\n /** Deletes the message element from the global messages container. */\n private _deleteMessageElement(key: string | Element) {\n this._messageRegistry.get(key)?.messageElement?.remove();\n this._messageRegistry.delete(key);\n }\n\n /** Creates the global container for all aria-describedby messages. */\n private _createMessagesContainer() {\n if (this._messagesContainer) {\n return;\n }\n\n const containerClassName = 'cdk-describedby-message-container';\n const serverContainers = this._document.querySelectorAll(\n `.${containerClassName}[platform=\"server\"]`,\n );\n\n for (let i = 0; i < serverContainers.length; i++) {\n // When going from the server to the client, we may end up in a situation where there's\n // already a container on the page, but we don't have a reference to it. Clear the\n // old container so we don't get duplicates. Doing this, instead of emptying the previous\n // container, should be slightly faster.\n serverContainers[i].remove();\n }\n\n const messagesContainer = this._document.createElement('div');\n\n // We add `visibility: hidden` in order to prevent text in this container from\n // being searchable by the browser's Ctrl + F functionality.\n // Screen-readers will still read the description for elements with aria-describedby even\n // when the description element is not visible.\n messagesContainer.style.visibility = 'hidden';\n // Even though we use `visibility: hidden`, we still apply `cdk-visually-hidden` so that\n // the description element doesn't impact page layout.\n messagesContainer.classList.add(containerClassName);\n messagesContainer.classList.add('cdk-visually-hidden');\n\n if (!this._platform.isBrowser) {\n messagesContainer.setAttribute('platform', 'server');\n }\n\n this._document.body.appendChild(messagesContainer);\n this._messagesContainer = messagesContainer;\n }\n\n /** Removes all cdk-describedby messages that are hosted through the element. */\n private _removeCdkDescribedByReferenceIds(element: Element) {\n // Remove all aria-describedby reference IDs that are prefixed by CDK_DESCRIBEDBY_ID_PREFIX\n const originalReferenceIds = getAriaReferenceIds(element, 'aria-describedby').filter(\n id => id.indexOf(CDK_DESCRIBEDBY_ID_PREFIX) != 0,\n );\n element.setAttribute('aria-describedby', originalReferenceIds.join(' '));\n }\n\n /**\n * Adds a message reference to the element using aria-describedby and increments the registered\n * message's reference count.\n */\n private _addMessageReference(element: Element, key: string | Element) {\n const registeredMessage = this._messageRegistry.get(key)!;\n\n // Add the aria-describedby reference and set the\n // describedby_host attribute to mark the element.\n addAriaReferencedId(element, 'aria-describedby', registeredMessage.messageElement.id);\n element.setAttribute(CDK_DESCRIBEDBY_HOST_ATTRIBUTE, this._id);\n registeredMessage.referenceCount++;\n }\n\n /**\n * Removes a message reference from the element using aria-describedby\n * and decrements the registered message's reference count.\n */\n private _removeMessageReference(element: Element, key: string | Element) {\n const registeredMessage = this._messageRegistry.get(key)!;\n registeredMessage.referenceCount--;\n\n removeAriaReferencedId(element, 'aria-describedby', registeredMessage.messageElement.id);\n element.removeAttribute(CDK_DESCRIBEDBY_HOST_ATTRIBUTE);\n }\n\n /** Returns true if the element has been described by the provided message ID. */\n private _isElementDescribedByMessage(element: Element, key: string | Element): boolean {\n const referenceIds = getAriaReferenceIds(element, 'aria-describedby');\n const registeredMessage = this._messageRegistry.get(key);\n const messageId = registeredMessage && registeredMessage.messageElement.id;\n\n return !!messageId && referenceIds.indexOf(messageId) != -1;\n }\n\n /** Determines whether a message can be described on a particular element. */\n private _canBeDescribed(element: Element, message: string | HTMLElement | void): boolean {\n if (!this._isElementNode(element)) {\n return false;\n }\n\n if (message && typeof message === 'object') {\n // We'd have to make some assumptions about the description element's text, if the consumer\n // passed in an element. Assume that if an element is passed in, the consumer has verified\n // that it can be used as a description.\n return true;\n }\n\n const trimmedMessage = message == null ? '' : `${message}`.trim();\n const ariaLabel = element.getAttribute('aria-label');\n\n // We shouldn't set descriptions if they're exactly the same as the `aria-label` of the\n // element, because screen readers will end up reading out the same text twice in a row.\n return trimmedMessage ? !ariaLabel || ariaLabel.trim() !== trimmedMessage : false;\n }\n\n /** Checks whether a node is an Element node. */\n private _isElementNode(element: Node): element is Element {\n return element.nodeType === this._document.ELEMENT_NODE;\n }\n}\n\n/** Gets a key that can be used to look messages up in the registry. */\nfunction getKey(message: string | Element, role?: string): string | Element {\n return typeof message === 'string' ? `${role || ''}/${message}` : message;\n}\n\n/** Assigns a unique ID to an element, if it doesn't have one already. */\nfunction setMessageId(element: HTMLElement, serviceId: string) {\n if (!element.id) {\n element.id = `${CDK_DESCRIBEDBY_ID_PREFIX}-${serviceId}-${nextId++}`;\n }\n}\n","/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.dev/license\n */\n\nimport {Subject} from 'rxjs';\nimport {TREE_KEY_MANAGER} from './tree-key-manager';\nimport {TreeKeyManagerItem, TreeKeyManagerStrategy} from './tree-key-manager-strategy';\nimport {Provider} from '@angular/core';\n\n// NoopTreeKeyManager is a \"noop\" implementation of TreeKeyMangerStrategy. Methods are noops. Does\n// not emit to streams.\n//\n// Used for applications built before TreeKeyManager to opt-out of TreeKeyManager and revert to\n// legacy behavior.\n/**\n * @docs-private\n *\n * Opt-out of Tree of key manager behavior.\n *\n * When provided, Tree has same focus management behavior as before TreeKeyManager was introduced.\n * - Tree does not respond to keyboard interaction\n * - Tree node allows tabindex to be set by Input binding\n * - Tree node allows tabindex to be set by attribute binding\n *\n * @deprecated NoopTreeKeyManager deprecated. Use TreeKeyManager or inject a\n * TreeKeyManagerStrategy instead. To be removed in a future version.\n *\n * @breaking-change 21.0.0\n */\nexport class NoopTreeKeyManager<T extends TreeKeyManagerItem> implements TreeKeyManagerStrategy<T> {\n readonly _isNoopTreeKeyManager = true;\n\n // Provide change as required by TreeKeyManagerStrategy. NoopTreeKeyManager is a \"noop\"\n // implementation that does not emit to streams.\n readonly change = new Subject<T | null>();\n\n destroy() {\n this.change.complete();\n }\n\n onKeydown() {\n // noop\n }\n\n getActiveItemIndex() {\n // Always return null. NoopTreeKeyManager is a \"noop\" implementation that does not maintain\n // the active item.\n return null;\n }\n\n getActiveItem() {\n // Always return null. NoopTreeKeyManager is a \"noop\" implementation that does not maintain\n // the active item.\n return null;\n }\n\n focusItem() {\n // noop\n }\n}\n\n/**\n * @docs-private\n *\n * Opt-out of Tree of key manager behavior.\n *\n * When provided, Tree has same focus management behavior as before TreeKeyManager was introduced.\n * - Tree does not respond to keyboard interaction\n * - Tree node allows tabindex to be set by Input binding\n * - Tree node allows tabindex to be set by attribute binding\n *\n * @deprecated NoopTreeKeyManager deprecated. Use TreeKeyManager or inject a\n * TreeKeyManagerStrategy instead. To be removed in a future version.\n *\n * @breaking-change 21.0.0\n */\nexport const NOOP_TREE_KEY_MANAGER_FACTORY_PROVIDER: Provider = {\n provide: TREE_KEY_MANAGER,\n useFactory: () => () => new NoopTreeKeyManager(),\n};\n","/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.dev/license\n */\n\nimport {Injector, NgZone} from '@angular/core';\nimport {InteractivityChecker} from '../interactivity-checker/interactivity-checker';\nimport {ConfigurableFocusTrapConfig} from './configurable-focus-trap-config';\nimport {FocusTrap} from './focus-trap';\nimport {FocusTrapInertStrategy} from './focus-trap-inert-strategy';\nimport {FocusTrapManager, ManagedFocusTrap} from './focus-trap-manager';\n\n/**\n * Class that allows for trapping focus within a DOM element.\n *\n * This class uses a strategy pattern that determines how it traps focus.\n * See FocusTrapInertStrategy.\n */\nexport class ConfigurableFocusTrap extends FocusTrap implements ManagedFocusTrap {\n /** Whether the FocusTrap is enabled. */\n override get enabled(): boolean {\n return this._enabled;\n }\n override set enabled(value: boolean) {\n this._enabled = value;\n if (this._enabled) {\n this._focusTrapManager.register(this);\n } else {\n this._focusTrapManager.deregister(this);\n }\n }\n\n constructor(\n _element: HTMLElement,\n _checker: InteractivityChecker,\n _ngZone: NgZone,\n _document: Document,\n private _focusTrapManager: FocusTrapManager,\n private _inertStrategy: FocusTrapInertStrategy,\n config: ConfigurableFocusTrapConfig,\n injector?: Injector,\n ) {\n super(_element, _checker, _ngZone, _document, config.defer, injector);\n this._focusTrapManager.register(this);\n }\n\n /** Notifies the FocusTrapManager that this FocusTrap will be destroyed. */\n override destroy() {\n this._focusTrapManager.deregister(this);\n super.destroy();\n }\n\n /** @docs-private Implemented as part of ManagedFocusTrap. */\n _enable() {\n this._inertStrategy.preventFocus(this);\n this.toggleAnchors(true);\n }\n\n /** @docs-private Implemented as part of ManagedFocusTrap. */\n _disable() {\n this._inertStrategy.allowFocus(this);\n this.toggleAnchors(false);\n }\n}\n","/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.dev/license\n */\n\nimport {FocusTrapInertStrategy} from './focus-trap-inert-strategy';\nimport {ConfigurableFocusTrap} from './configurable-focus-trap';\n\n/**\n * Lightweight FocusTrapInertStrategy that adds a document focus event\n * listener to redirect focus back inside the FocusTrap.\n */\nexport class EventListenerFocusTrapInertStrategy implements FocusTrapInertStrategy {\n /** Focus event handler. */\n private _listener: ((e: FocusEvent) => void) | null = null;\n\n /** Adds a document event listener that keeps focus inside the FocusTrap. */\n preventFocus(focusTrap: ConfigurableFocusTrap): void {\n // Ensure there's only one listener per document\n if (this._listener) {\n focusTrap._document.removeEventListener('focus', this._listener!, true);\n }\n\n this._listener = (e: FocusEvent) => this._trapFocus(focusTrap, e);\n focusTrap._ngZone.runOutsideAngular(() => {\n focusTrap._document.addEventListener('focus', this._listener!, true);\n });\n }\n\n /** Removes the event listener added in preventFocus. */\n allowFocus(focusTrap: ConfigurableFocusTrap): void {\n if (!this._listener) {\n return;\n }\n focusTrap._document.removeEventListener('focus', this._listener!, true);\n this._listener = null;\n }\n\n /**\n * Refocuses the first element in the FocusTrap if the focus event target was outside\n * the FocusTrap.\n *\n * This is an event listener callback. The event listener is added in runOutsideAngular,\n * so all this code runs outside Angular as well.\n */\n private _trapFocus(focusTrap: ConfigurableFocusTrap, event: FocusEvent) {\n const target = event.target as HTMLElement;\n const focusTrapRoot = focusTrap._element;\n\n // Don't refocus if target was in an overlay, because the overlay might be associated\n // with an element inside the FocusTrap, ex. mat-select.\n if (target && !focusTrapRoot.contains(target) && !target.closest?.('div.cdk-overlay-pane')) {\n // Some legacy FocusTrap usages have logic that focuses some element on the page\n // just before FocusTrap is destroyed. For backwards compatibility, wait\n // to be sure FocusTrap is still enabled before refocusing.\n setTimeout(() => {\n // Check whether focus wasn't put back into the focus trap while the timeout was pending.\n if (focusTrap.enabled && !focusTrapRoot.contains(focusTrap._document.activeElement)) {\n focusTrap.focusFirstTabbableElement();\n }\n });\n }\n }\n}\n","/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.dev/license\n */\nimport {InjectionToken} from '@angular/core';\nimport {FocusTrap} from './focus-trap';\n\n/** The injection token used to specify the inert strategy. */\nexport const FOCUS_TRAP_INERT_STRATEGY = new InjectionToken<FocusTrapInertStrategy>(\n 'FOCUS_TRAP_INERT_STRATEGY',\n);\n\n/**\n * A strategy that dictates how FocusTrap should prevent elements\n * outside of the FocusTrap from being focused.\n */\nexport interface FocusTrapInertStrategy {\n /** Makes all elements outside focusTrap unfocusable. */\n preventFocus(focusTrap: FocusTrap): void;\n /** Reverts elements made unfocusable by preventFocus to their previous state. */\n allowFocus(focusTrap: FocusTrap): void;\n}\n","/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.dev/license\n */\n\nimport {Injectable} from '@angular/core';\n\n/**\n * A FocusTrap managed by FocusTrapManager.\n * Implemented by ConfigurableFocusTrap to avoid circular dependency.\n */\nexport interface ManagedFocusTrap {\n _enable(): void;\n _disable(): void;\n focusInitialElementWhenReady(): Promise<boolean>;\n}\n\n/** Injectable that ensures only the most recently enabled FocusTrap is active. */\n@Injectable({providedIn: 'root'})\nexport class FocusTrapManager {\n // A stack of the FocusTraps on the page. Only the FocusTrap at the\n // top of the stack is active.\n private _focusTrapStack: ManagedFocusTrap[] = [];\n\n /**\n * Disables the FocusTrap at the top of the stack, and then pushes\n * the new FocusTrap onto the stack.\n */\n register(focusTrap: ManagedFocusTrap): void {\n // Dedupe focusTraps that register multiple times.\n this._focusTrapStack = this._focusTrapStack.filter(ft => ft !== focusTrap);\n\n let stack = this._focusTrapStack;\n\n if (stack.length) {\n stack[stack.length - 1]._disable();\n }\n\n stack.push(focusTrap);\n focusTrap._enable();\n }\n\n /**\n * Removes the FocusTrap from the stack, and activates the\n * FocusTrap that is the new top of the stack.\n */\n deregister(focusTrap: ManagedFocusTrap): void {\n focusTrap._disable();\n\n const stack = this._focusTrapStack;\n\n const i = stack.indexOf(focusTrap);\n if (i !== -1) {\n stack.splice(i, 1);\n if (stack.length) {\n stack[stack.length - 1]._enable();\n }\n }\n }\n}\n","/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.dev/license\n */\n\nimport {Injectable, Injector, NgZone, inject, DOCUMENT} from '@angular/core';\nimport {InteractivityChecker} from '../interactivity-checker/interactivity-checker';\nimport {ConfigurableFocusTrap} from './configurable-focus-trap';\nimport {ConfigurableFocusTrapConfig} from './configurable-focus-trap-config';\nimport {EventListenerFocusTrapInertStrategy} from './event-listener-inert-strategy';\nimport {FOCUS_TRAP_INERT_STRATEGY, FocusTrapInertStrategy} from './focus-trap-inert-strategy';\nimport {FocusTrapManager} from './focus-trap-manager';\n\n/** Factory that allows easy instantiation of configurable focus traps. */\n@Injectable({providedIn: 'root'})\nexport class ConfigurableFocusTrapFactory {\n private _checker = inject(InteractivityChecker);\n private _ngZone = inject(NgZone);\n private _focusTrapManager = inject(FocusTrapManager);\n\n private _document = inject(DOCUMENT);\n private _inertStrategy: FocusTrapInertStrategy;\n\n private readonly _injector = inject(Injector);\n\n constructor(...args: unknown[]);\n\n constructor() {\n const inertStrategy = inject(FOCUS_TRAP_INERT_STRATEGY, {optional: true});\n\n // TODO split up the strategies into different modules, similar to DateAdapter.\n this._inertStrategy = inertStrategy || new EventListenerFocusTrapInertStrategy();\n }\n\n /**\n * Creates a focus-trapped region around the given element.\n * @param element The element around which focus will be trapped.\n * @param config The focus trap configuration.\n * @returns The created focus trap instance.\n */\n create(element: HTMLElement, config?: ConfigurableFocusTrapConfig): ConfigurableFocusTrap;\n\n /**\n * @deprecated Pass a config object instead of the `deferCaptureElements` flag.\n * @breaking-change 11.0.0\n */\n create(element: HTMLElement, deferCaptureElements: boolean): ConfigurableFocusTrap;\n\n create(\n element: HTMLElement,\n config: ConfigurableFocusTrapConfig | boolean = {defer: false},\n ): ConfigurableFocusTrap {\n let configObject: ConfigurableFocusTrapConfig;\n if (typeof config === 'boolean') {\n configObject = {defer: config};\n } else {\n configObject = config;\n }\n return new ConfigurableFocusTrap(\n element,\n this._checker,\n this._ngZone,\n this._document,\n this._focusTrapManager,\n this._inertStrategy,\n configObject,\n this._injector,\n );\n }\n}\n"],"names":["ID_DELIMITER","addAriaReferencedId","el","attr","id","ids","getAriaReferenceIds","trim","some","existingId","push","setAttribute","join","removeAriaReferencedId","filteredIds","filter","val","length","removeAttribute","attrValue","getAttribute","match","MESSAGES_CONTAINER_ID","CDK_DESCRIBEDBY_ID_PREFIX","CDK_DESCRIBEDBY_HOST_ATTRIBUTE","nextId","AriaDescriber","_platform","inject","Platform","_document","DOCUMENT","_messageRegistry","Map","_messagesContainer","_id","constructor","_CdkPrivateStyleLoader","load","_VisuallyHiddenLoader","APP_ID","describe","hostElement","message","role","_canBeDescribed","key","getKey","setMessageId","set","messageElement","referenceCount","has","_createMessageElement","_isElementDescribedByMessage","_addMessageReference","removeDescription","_isElementNode","_removeMessageReference","registeredMessage","get","_deleteMessageElement","childNodes","remove","ngOnDestroy","describedElements","querySelectorAll","i","_removeCdkDescribedByReferenceIds","clear","createElement","textContent","_createMessagesContainer","appendChild","delete","containerClassName","serverContainers","messagesContainer","style","visibility","classList","add","isBrowser","body","element","originalReferenceIds","indexOf","referenceIds","messageId","trimmedMessage","ariaLabel","nodeType","ELEMENT_NODE","deps","target","i0","ɵɵFactoryTarget","Injectable","ɵprov","ɵɵngDeclareInjectable","minVersion","version","ngImport","type","decorators","providedIn","serviceId","NoopTreeKeyManager","_isNoopTreeKeyManager","change","Subject","destroy","complete","onKeydown","getActiveItemIndex","getActiveItem","focusItem","NOOP_TREE_KEY_MANAGER_FACTORY_PROVIDER","provide","TREE_KEY_MANAGER","useFactory","ConfigurableFocusTrap","FocusTrap","_focusTrapManager","_inertStrategy","enabled","_enabled","value","register","deregister","_element","_checker","_ngZone","config","injector","defer","_enable","preventFocus","toggleAnchors","_disable","allowFocus","EventListenerFocusTrapInertStrategy","_listener","focusTrap","removeEventListener","e","_trapFocus","runOutsideAngular","addEventListener","event","focusTrapRoot","contains","closest","setTimeout","activeElement","focusFirstTabbableElement","FOCUS_TRAP_INERT_STRATEGY","InjectionToken","FocusTrapManager","_focusTrapStack","ft","stack","splice","ConfigurableFocusTrapFactory","InteractivityChecker","NgZone","_injector","Injector","inertStrategy","optional","create","configObject"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AASA,MAAMA,YAAY,GAAG,GAAG;SAMRC,mBAAmBA,CAACC,EAAW,EAAEC,IAAsB,EAAEC,EAAU,EAAA;AACjF,EAAA,MAAMC,GAAG,GAAGC,mBAAmB,CAACJ,EAAE,EAAEC,IAAI,CAAC;AACzCC,EAAAA,EAAE,GAAGA,EAAE,CAACG,IAAI,EAAE;AACd,EAAA,IAAIF,GAAG,CAACG,IAAI,CAACC,UAAU,IAAIA,UAAU,CAACF,IAAI,EAAE,KAAKH,EAAE,CAAC,EAAE;AACpD,IAAA;AACF;AACAC,EAAAA,GAAG,CAACK,IAAI,CAACN,EAAE,CAAC;EAEZF,EAAE,CAACS,YAAY,CAACR,IAAI,EAAEE,GAAG,CAACO,IAAI,CAACZ,YAAY,CAAC,CAAC;AAC/C;SAMgBa,sBAAsBA,CAACX,EAAW,EAAEC,IAAsB,EAAEC,EAAU,EAAA;AACpF,EAAA,MAAMC,GAAG,GAAGC,mBAAmB,CAACJ,EAAE,EAAEC,IAAI,CAAC;AACzCC,EAAAA,EAAE,GAAGA,EAAE,CAACG,IAAI,EAAE;EACd,MAAMO,WAAW,GAAGT,GAAG,CAACU,MAAM,CAACC,GAAG,IAAIA,GAAG,KAAKZ,EAAE,CAAC;EAEjD,IAAIU,WAAW,CAACG,MAAM,EAAE;IACtBf,EAAE,CAACS,YAAY,CAACR,IAAI,EAAEW,WAAW,CAACF,IAAI,CAACZ,YAAY,CAAC,CAAC;AACvD,GAAA,MAAO;AACLE,IAAAA,EAAE,CAACgB,eAAe,CAACf,IAAI,CAAC;AAC1B;AACF;AAMgB,SAAAG,mBAAmBA,CAACJ,EAAW,EAAEC,IAAY,EAAA;AAE3D,EAAA,MAAMgB,SAAS,GAAGjB,EAAE,CAACkB,YAAY,CAACjB,IAAI,CAAC;AACvC,EAAA,OAAOgB,SAAS,EAAEE,KAAK,CAAC,MAAM,CAAC,IAAI,EAAE;AACvC;;ACpBO,MAAMC,qBAAqB,GAAG;AAO9B,MAAMC,yBAAyB,GAAG;AAOlC,MAAMC,8BAA8B,GAAG;AAG9C,IAAIC,MAAM,GAAG,CAAC;MAQDC,aAAa,CAAA;AAChBC,EAAAA,SAAS,GAAGC,MAAM,CAACC,QAAQ,CAAC;AAC5BC,EAAAA,SAAS,GAAGF,MAAM,CAACG,QAAQ,CAAC;AAG5BC,EAAAA,gBAAgB,GAAG,IAAIC,GAAG,EAAuC;AAGjEC,EAAAA,kBAAkB,GAAuB,IAAI;AAGpCC,EAAAA,GAAG,GAAG,CAAA,EAAGV,MAAM,EAAE,CAAE,CAAA;AAIpCW,EAAAA,WAAAA,GAAA;AACER,IAAAA,MAAM,CAACS,sBAAsB,CAAC,CAACC,IAAI,CAACC,qBAAqB,CAAC;IAC1D,IAAI,CAACJ,GAAG,GAAGP,MAAM,CAACY,MAAM,CAAC,GAAG,GAAG,GAAGf,MAAM,EAAE;AAC5C;AAcAgB,EAAAA,QAAQA,CAACC,WAAoB,EAAEC,OAA6B,EAAEC,IAAa,EAAA;IACzE,IAAI,CAAC,IAAI,CAACC,eAAe,CAACH,WAAW,EAAEC,OAAO,CAAC,EAAE;AAC/C,MAAA;AACF;AAEA,IAAA,MAAMG,GAAG,GAAGC,MAAM,CAACJ,OAAO,EAAEC,IAAI,CAAC;AAEjC,IAAA,IAAI,OAAOD,OAAO,KAAK,QAAQ,EAAE;AAE/BK,MAAAA,YAAY,CAACL,OAAO,EAAE,IAAI,CAACR,GAAG,CAAC;AAC/B,MAAA,IAAI,CAACH,gBAAgB,CAACiB,GAAG,CAACH,GAAG,EAAE;AAACI,QAAAA,cAAc,EAAEP,OAAO;AAAEQ,QAAAA,cAAc,EAAE;AAAC,OAAC,CAAC;KAC9E,MAAO,IAAI,CAAC,IAAI,CAACnB,gBAAgB,CAACoB,GAAG,CAACN,GAAG,CAAC,EAAE;AAC1C,MAAA,IAAI,CAACO,qBAAqB,CAACV,OAAO,EAAEC,IAAI,CAAC;AAC3C;IAEA,IAAI,CAAC,IAAI,CAACU,4BAA4B,CAACZ,WAAW,EAAEI,GAAG,CAAC,EAAE;AACxD,MAAA,IAAI,CAACS,oBAAoB,CAACb,WAAW,EAAEI,GAAG,CAAC;AAC7C;AACF;AAQAU,EAAAA,iBAAiBA,CAACd,WAAoB,EAAEC,OAA6B,EAAEC,IAAa,EAAA;IAClF,IAAI,CAACD,OAAO,IAAI,CAAC,IAAI,CAACc,cAAc,CAACf,WAAW,CAAC,EAAE;AACjD,MAAA;AACF;AAEA,IAAA,MAAMI,GAAG,GAAGC,MAAM,CAACJ,OAAO,EAAEC,IAAI,CAAC;IAEjC,IAAI,IAAI,CAACU,4BAA4B,CAACZ,WAAW,EAAEI,GAAG,CAAC,EAAE;AACvD,MAAA,IAAI,CAACY,uBAAuB,CAAChB,WAAW,EAAEI,GAAG,CAAC;AAChD;AAIA,IAAA,IAAI,OAAOH,OAAO,KAAK,QAAQ,EAAE;MAC/B,MAAMgB,iBAAiB,GAAG,IAAI,CAAC3B,gBAAgB,CAAC4B,GAAG,CAACd,GAAG,CAAC;AACxD,MAAA,IAAIa,iBAAiB,IAAIA,iBAAiB,CAACR,cAAc,KAAK,CAAC,EAAE;AAC/D,QAAA,IAAI,CAACU,qBAAqB,CAACf,GAAG,CAAC;AACjC;AACF;IAEA,IAAI,IAAI,CAACZ,kBAAkB,EAAE4B,UAAU,CAAC7C,MAAM,KAAK,CAAC,EAAE;AACpD,MAAA,IAAI,CAACiB,kBAAkB,CAAC6B,MAAM,EAAE;MAChC,IAAI,CAAC7B,kBAAkB,GAAG,IAAI;AAChC;AACF;AAGA8B,EAAAA,WAAWA,GAAA;AACT,IAAA,MAAMC,iBAAiB,GAAG,IAAI,CAACnC,SAAS,CAACoC,gBAAgB,CACvD,CAAA,CAAA,EAAI1C,8BAA8B,CAAK,EAAA,EAAA,IAAI,CAACW,GAAG,IAAI,CACpD;AAED,IAAA,KAAK,IAAIgC,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAGF,iBAAiB,CAAChD,MAAM,EAAEkD,CAAC,EAAE,EAAE;AACjD,MAAA,IAAI,CAACC,iCAAiC,CAACH,iBAAiB,CAACE,CAAC,CAAC,CAAC;AAC5DF,MAAAA,iBAAiB,CAACE,CAAC,CAAC,CAACjD,eAAe,CAACM,8BAA8B,CAAC;AACtE;AAEA,IAAA,IAAI,CAACU,kBAAkB,EAAE6B,MAAM,EAAE;IACjC,IAAI,CAAC7B,kBAAkB,GAAG,IAAI;AAC9B,IAAA,IAAI,CAACF,gBAAgB,CAACqC,KAAK,EAAE;AAC/B;AAMQhB,EAAAA,qBAAqBA,CAACV,OAAe,EAAEC,IAAa,EAAA;IAC1D,MAAMM,cAAc,GAAG,IAAI,CAACpB,SAAS,CAACwC,aAAa,CAAC,KAAK,CAAC;AAC1DtB,IAAAA,YAAY,CAACE,cAAc,EAAE,IAAI,CAACf,GAAG,CAAC;IACtCe,cAAc,CAACqB,WAAW,GAAG5B,OAAO;AAEpC,IAAA,IAAIC,IAAI,EAAE;AACRM,MAAAA,cAAc,CAACvC,YAAY,CAAC,MAAM,EAAEiC,IAAI,CAAC;AAC3C;IAEA,IAAI,CAAC4B,wBAAwB,EAAE;AAC/B,IAAA,IAAI,CAACtC,kBAAmB,CAACuC,WAAW,CAACvB,cAAc,CAAC;IACpD,IAAI,CAAClB,gBAAgB,CAACiB,GAAG,CAACF,MAAM,CAACJ,OAAO,EAAEC,IAAI,CAAC,EAAE;MAACM,cAAc;AAAEC,MAAAA,cAAc,EAAE;AAAC,KAAC,CAAC;AACvF;EAGQU,qBAAqBA,CAACf,GAAqB,EAAA;AACjD,IAAA,IAAI,CAACd,gBAAgB,CAAC4B,GAAG,CAACd,GAAG,CAAC,EAAEI,cAAc,EAAEa,MAAM,EAAE;AACxD,IAAA,IAAI,CAAC/B,gBAAgB,CAAC0C,MAAM,CAAC5B,GAAG,CAAC;AACnC;AAGQ0B,EAAAA,wBAAwBA,GAAA;IAC9B,IAAI,IAAI,CAACtC,kBAAkB,EAAE;AAC3B,MAAA;AACF;IAEA,MAAMyC,kBAAkB,GAAG,mCAAmC;IAC9D,MAAMC,gBAAgB,GAAG,IAAI,CAAC9C,SAAS,CAACoC,gBAAgB,CACtD,CAAA,CAAA,EAAIS,kBAAkB,CAAA,mBAAA,CAAqB,CAC5C;AAED,IAAA,KAAK,IAAIR,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAGS,gBAAgB,CAAC3D,MAAM,EAAEkD,CAAC,EAAE,EAAE;AAKhDS,MAAAA,gBAAgB,CAACT,CAAC,CAAC,CAACJ,MAAM,EAAE;AAC9B;IAEA,MAAMc,iBAAiB,GAAG,IAAI,CAAC/C,SAAS,CAACwC,aAAa,CAAC,KAAK,CAAC;AAM7DO,IAAAA,iBAAiB,CAACC,KAAK,CAACC,UAAU,GAAG,QAAQ;AAG7CF,IAAAA,iBAAiB,CAACG,SAAS,CAACC,GAAG,CAACN,kBAAkB,CAAC;AACnDE,IAAAA,iBAAiB,CAACG,SAAS,CAACC,GAAG,CAAC,qBAAqB,CAAC;AAEtD,IAAA,IAAI,CAAC,IAAI,CAACtD,SAAS,CAACuD,SAAS,EAAE;AAC7BL,MAAAA,iBAAiB,CAAClE,YAAY,CAAC,UAAU,EAAE,QAAQ,CAAC;AACtD;IAEA,IAAI,CAACmB,SAAS,CAACqD,IAAI,CAACV,WAAW,CAACI,iBAAiB,CAAC;IAClD,IAAI,CAAC3C,kBAAkB,GAAG2C,iBAAiB;AAC7C;EAGQT,iCAAiCA,CAACgB,OAAgB,EAAA;IAExD,MAAMC,oBAAoB,GAAG/E,mBAAmB,CAAC8E,OAAO,EAAE,kBAAkB,CAAC,CAACrE,MAAM,CAClFX,EAAE,IAAIA,EAAE,CAACkF,OAAO,CAAC/D,yBAAyB,CAAC,IAAI,CAAC,CACjD;IACD6D,OAAO,CAACzE,YAAY,CAAC,kBAAkB,EAAE0E,oBAAoB,CAACzE,IAAI,CAAC,GAAG,CAAC,CAAC;AAC1E;AAMQ2C,EAAAA,oBAAoBA,CAAC6B,OAAgB,EAAEtC,GAAqB,EAAA;IAClE,MAAMa,iBAAiB,GAAG,IAAI,CAAC3B,gBAAgB,CAAC4B,GAAG,CAACd,GAAG,CAAE;IAIzD7C,mBAAmB,CAACmF,OAAO,EAAE,kBAAkB,EAAEzB,iBAAiB,CAACT,cAAc,CAAC9C,EAAE,CAAC;IACrFgF,OAAO,CAACzE,YAAY,CAACa,8BAA8B,EAAE,IAAI,CAACW,GAAG,CAAC;IAC9DwB,iBAAiB,CAACR,cAAc,EAAE;AACpC;AAMQO,EAAAA,uBAAuBA,CAAC0B,OAAgB,EAAEtC,GAAqB,EAAA;IACrE,MAAMa,iBAAiB,GAAG,IAAI,CAAC3B,gBAAgB,CAAC4B,GAAG,CAACd,GAAG,CAAE;IACzDa,iBAAiB,CAACR,cAAc,EAAE;IAElCtC,sBAAsB,CAACuE,OAAO,EAAE,kBAAkB,EAAEzB,iBAAiB,CAACT,cAAc,CAAC9C,EAAE,CAAC;AACxFgF,IAAAA,OAAO,CAAClE,eAAe,CAACM,8BAA8B,CAAC;AACzD;AAGQ8B,EAAAA,4BAA4BA,CAAC8B,OAAgB,EAAEtC,GAAqB,EAAA;AAC1E,IAAA,MAAMyC,YAAY,GAAGjF,mBAAmB,CAAC8E,OAAO,EAAE,kBAAkB,CAAC;IACrE,MAAMzB,iBAAiB,GAAG,IAAI,CAAC3B,gBAAgB,CAAC4B,GAAG,CAACd,GAAG,CAAC;IACxD,MAAM0C,SAAS,GAAG7B,iBAAiB,IAAIA,iBAAiB,CAACT,cAAc,CAAC9C,EAAE;AAE1E,IAAA,OAAO,CAAC,CAACoF,SAAS,IAAID,YAAY,CAACD,OAAO,CAACE,SAAS,CAAC,IAAI,CAAC,CAAC;AAC7D;AAGQ3C,EAAAA,eAAeA,CAACuC,OAAgB,EAAEzC,OAAoC,EAAA;AAC5E,IAAA,IAAI,CAAC,IAAI,CAACc,cAAc,CAAC2B,OAAO,CAAC,EAAE;AACjC,MAAA,OAAO,KAAK;AACd;AAEA,IAAA,IAAIzC,OAAO,IAAI,OAAOA,OAAO,KAAK,QAAQ,EAAE;AAI1C,MAAA,OAAO,IAAI;AACb;AAEA,IAAA,MAAM8C,cAAc,GAAG9C,OAAO,IAAI,IAAI,GAAG,EAAE,GAAG,CAAA,EAAGA,OAAO,CAAA,CAAE,CAACpC,IAAI,EAAE;AACjE,IAAA,MAAMmF,SAAS,GAAGN,OAAO,CAAChE,YAAY,CAAC,YAAY,CAAC;AAIpD,IAAA,OAAOqE,cAAc,GAAG,CAACC,SAAS,IAAIA,SAAS,CAACnF,IAAI,EAAE,KAAKkF,cAAc,GAAG,KAAK;AACnF;EAGQhC,cAAcA,CAAC2B,OAAa,EAAA;IAClC,OAAOA,OAAO,CAACO,QAAQ,KAAK,IAAI,CAAC7D,SAAS,CAAC8D,YAAY;AACzD;;;;;UAvOWlE,aAAa;AAAAmE,IAAAA,IAAA,EAAA,EAAA;AAAAC,IAAAA,MAAA,EAAAC,EAAA,CAAAC,eAAA,CAAAC;AAAA,GAAA,CAAA;AAAb,EAAA,OAAAC,KAAA,GAAAH,EAAA,CAAAI,qBAAA,CAAA;AAAAC,IAAAA,UAAA,EAAA,QAAA;AAAAC,IAAAA,OAAA,EAAA,QAAA;AAAAC,IAAAA,QAAA,EAAAP,EAAA;AAAAQ,IAAAA,IAAA,EAAA7E,aAAa;gBADD;AAAM,GAAA,CAAA;;;;;;QAClBA,aAAa;AAAA8E,EAAAA,UAAA,EAAA,CAAA;UADzBP,UAAU;WAAC;AAACQ,MAAAA,UAAU,EAAE;KAAO;;;;AA4OhC,SAAS1D,MAAMA,CAACJ,OAAyB,EAAEC,IAAa,EAAA;AACtD,EAAA,OAAO,OAAOD,OAAO,KAAK,QAAQ,GAAG,CAAA,EAAGC,IAAI,IAAI,EAAE,CAAA,CAAA,EAAID,OAAO,CAAA,CAAE,GAAGA,OAAO;AAC3E;AAGA,SAASK,YAAYA,CAACoC,OAAoB,EAAEsB,SAAiB,EAAA;AAC3D,EAAA,IAAI,CAACtB,OAAO,CAAChF,EAAE,EAAE;IACfgF,OAAO,CAAChF,EAAE,GAAG,CAAGmB,EAAAA,yBAAyB,IAAImF,SAAS,CAAA,CAAA,EAAIjF,MAAM,EAAE,CAAE,CAAA;AACtE;AACF;;MC1QakF,kBAAkB,CAAA;AACpBC,EAAAA,qBAAqB,GAAG,IAAI;AAI5BC,EAAAA,MAAM,GAAG,IAAIC,OAAO,EAAY;AAEzCC,EAAAA,OAAOA,GAAA;AACL,IAAA,IAAI,CAACF,MAAM,CAACG,QAAQ,EAAE;AACxB;EAEAC,SAASA,GAAA;AAITC,EAAAA,kBAAkBA,GAAA;AAGhB,IAAA,OAAO,IAAI;AACb;AAEAC,EAAAA,aAAaA,GAAA;AAGX,IAAA,OAAO,IAAI;AACb;EAEAC,SAASA,GAAA;AAGV;AAiBM,MAAMC,sCAAsC,GAAa;AAC9DC,EAAAA,OAAO,EAAEC,gBAAgB;AACzBC,EAAAA,UAAU,EAAEA,MAAM,MAAM,IAAIb,kBAAkB;;;AC7D1C,MAAOc,qBAAsB,SAAQC,SAAS,CAAA;EAmBxCC,iBAAA;EACAC,cAAA;EAlBV,IAAaC,OAAOA,GAAA;IAClB,OAAO,IAAI,CAACC,QAAQ;AACtB;EACA,IAAaD,OAAOA,CAACE,KAAc,EAAA;IACjC,IAAI,CAACD,QAAQ,GAAGC,KAAK;IACrB,IAAI,IAAI,CAACD,QAAQ,EAAE;AACjB,MAAA,IAAI,CAACH,iBAAiB,CAACK,QAAQ,CAAC,IAAI,CAAC;AACvC,KAAA,MAAO;AACL,MAAA,IAAI,CAACL,iBAAiB,CAACM,UAAU,CAAC,IAAI,CAAC;AACzC;AACF;AAEA7F,EAAAA,WAAAA,CACE8F,QAAqB,EACrBC,QAA8B,EAC9BC,OAAe,EACftG,SAAmB,EACX6F,iBAAmC,EACnCC,cAAsC,EAC9CS,MAAmC,EACnCC,QAAmB,EAAA;AAEnB,IAAA,KAAK,CAACJ,QAAQ,EAAEC,QAAQ,EAAEC,OAAO,EAAEtG,SAAS,EAAEuG,MAAM,CAACE,KAAK,EAAED,QAAQ,CAAC;IAL7D,IAAiB,CAAAX,iBAAA,GAAjBA,iBAAiB;IACjB,IAAc,CAAAC,cAAA,GAAdA,cAAc;AAKtB,IAAA,IAAI,CAACD,iBAAiB,CAACK,QAAQ,CAAC,IAAI,CAAC;AACvC;AAGSjB,EAAAA,OAAOA,GAAA;AACd,IAAA,IAAI,CAACY,iBAAiB,CAACM,UAAU,CAAC,IAAI,CAAC;IACvC,KAAK,CAAClB,OAAO,EAAE;AACjB;AAGAyB,EAAAA,OAAOA,GAAA;AACL,IAAA,IAAI,CAACZ,cAAc,CAACa,YAAY,CAAC,IAAI,CAAC;AACtC,IAAA,IAAI,CAACC,aAAa,CAAC,IAAI,CAAC;AAC1B;AAGAC,EAAAA,QAAQA,GAAA;AACN,IAAA,IAAI,CAACf,cAAc,CAACgB,UAAU,CAAC,IAAI,CAAC;AACpC,IAAA,IAAI,CAACF,aAAa,CAAC,KAAK,CAAC;AAC3B;AACD;;MCnDYG,mCAAmC,CAAA;AAEtCC,EAAAA,SAAS,GAAqC,IAAI;EAG1DL,YAAYA,CAACM,SAAgC,EAAA;IAE3C,IAAI,IAAI,CAACD,SAAS,EAAE;AAClBC,MAAAA,SAAS,CAACjH,SAAS,CAACkH,mBAAmB,CAAC,OAAO,EAAE,IAAI,CAACF,SAAU,EAAE,IAAI,CAAC;AACzE;AAEA,IAAA,IAAI,CAACA,SAAS,GAAIG,CAAa,IAAK,IAAI,CAACC,UAAU,CAACH,SAAS,EAAEE,CAAC,CAAC;AACjEF,IAAAA,SAAS,CAACX,OAAO,CAACe,iBAAiB,CAAC,MAAK;AACvCJ,MAAAA,SAAS,CAACjH,SAAS,CAACsH,gBAAgB,CAAC,OAAO,EAAE,IAAI,CAACN,SAAU,EAAE,IAAI,CAAC;AACtE,KAAC,CAAC;AACJ;EAGAF,UAAUA,CAACG,SAAgC,EAAA;AACzC,IAAA,IAAI,CAAC,IAAI,CAACD,SAAS,EAAE;AACnB,MAAA;AACF;AACAC,IAAAA,SAAS,CAACjH,SAAS,CAACkH,mBAAmB,CAAC,OAAO,EAAE,IAAI,CAACF,SAAU,EAAE,IAAI,CAAC;IACvE,IAAI,CAACA,SAAS,GAAG,IAAI;AACvB;AASQI,EAAAA,UAAUA,CAACH,SAAgC,EAAEM,KAAiB,EAAA;AACpE,IAAA,MAAMvD,MAAM,GAAGuD,KAAK,CAACvD,MAAqB;AAC1C,IAAA,MAAMwD,aAAa,GAAGP,SAAS,CAACb,QAAQ;AAIxC,IAAA,IAAIpC,MAAM,IAAI,CAACwD,aAAa,CAACC,QAAQ,CAACzD,MAAM,CAAC,IAAI,CAACA,MAAM,CAAC0D,OAAO,GAAG,sBAAsB,CAAC,EAAE;AAI1FC,MAAAA,UAAU,CAAC,MAAK;AAEd,QAAA,IAAIV,SAAS,CAAClB,OAAO,IAAI,CAACyB,aAAa,CAACC,QAAQ,CAACR,SAAS,CAACjH,SAAS,CAAC4H,aAAa,CAAC,EAAE;UACnFX,SAAS,CAACY,yBAAyB,EAAE;AACvC;AACF,OAAC,CAAC;AACJ;AACF;AACD;;MCvDYC,yBAAyB,GAAG,IAAIC,cAAc,CACzD,2BAA2B;;MCUhBC,gBAAgB,CAAA;AAGnBC,EAAAA,eAAe,GAAuB,EAAE;EAMhD/B,QAAQA,CAACe,SAA2B,EAAA;AAElC,IAAA,IAAI,CAACgB,eAAe,GAAG,IAAI,CAACA,eAAe,CAAChJ,MAAM,CAACiJ,EAAE,IAAIA,EAAE,KAAKjB,SAAS,CAAC;AAE1E,IAAA,IAAIkB,KAAK,GAAG,IAAI,CAACF,eAAe;IAEhC,IAAIE,KAAK,CAAChJ,MAAM,EAAE;MAChBgJ,KAAK,CAACA,KAAK,CAAChJ,MAAM,GAAG,CAAC,CAAC,CAAC0H,QAAQ,EAAE;AACpC;AAEAsB,IAAAA,KAAK,CAACvJ,IAAI,CAACqI,SAAS,CAAC;IACrBA,SAAS,CAACP,OAAO,EAAE;AACrB;EAMAP,UAAUA,CAACc,SAA2B,EAAA;IACpCA,SAAS,CAACJ,QAAQ,EAAE;AAEpB,IAAA,MAAMsB,KAAK,GAAG,IAAI,CAACF,eAAe;AAElC,IAAA,MAAM5F,CAAC,GAAG8F,KAAK,CAAC3E,OAAO,CAACyD,SAAS,CAAC;AAClC,IAAA,IAAI5E,CAAC,KAAK,CAAC,CAAC,EAAE;AACZ8F,MAAAA,KAAK,CAACC,MAAM,CAAC/F,CAAC,EAAE,CAAC,CAAC;MAClB,IAAI8F,KAAK,CAAChJ,MAAM,EAAE;QAChBgJ,KAAK,CAACA,KAAK,CAAChJ,MAAM,GAAG,CAAC,CAAC,CAACuH,OAAO,EAAE;AACnC;AACF;AACF;;;;;UAvCWsB,gBAAgB;AAAAjE,IAAAA,IAAA,EAAA,EAAA;AAAAC,IAAAA,MAAA,EAAAC,EAAA,CAAAC,eAAA,CAAAC;AAAA,GAAA,CAAA;AAAhB,EAAA,OAAAC,KAAA,GAAAH,EAAA,CAAAI,qBAAA,CAAA;AAAAC,IAAAA,UAAA,EAAA,QAAA;AAAAC,IAAAA,OAAA,EAAA,QAAA;AAAAC,IAAAA,QAAA,EAAAP,EAAA;AAAAQ,IAAAA,IAAA,EAAAuD,gBAAgB;gBADJ;AAAM,GAAA,CAAA;;;;;;QAClBA,gBAAgB;AAAAtD,EAAAA,UAAA,EAAA,CAAA;UAD5BP,UAAU;WAAC;AAACQ,MAAAA,UAAU,EAAE;KAAO;;;;MCHnB0D,4BAA4B,CAAA;AAC/BhC,EAAAA,QAAQ,GAAGvG,MAAM,CAACwI,oBAAoB,CAAC;AACvChC,EAAAA,OAAO,GAAGxG,MAAM,CAACyI,MAAM,CAAC;AACxB1C,EAAAA,iBAAiB,GAAG/F,MAAM,CAACkI,gBAAgB,CAAC;AAE5ChI,EAAAA,SAAS,GAAGF,MAAM,CAACG,QAAQ,CAAC;EAC5B6F,cAAc;AAEL0C,EAAAA,SAAS,GAAG1I,MAAM,CAAC2I,QAAQ,CAAC;AAI7CnI,EAAAA,WAAAA,GAAA;AACE,IAAA,MAAMoI,aAAa,GAAG5I,MAAM,CAACgI,yBAAyB,EAAE;AAACa,MAAAA,QAAQ,EAAE;AAAK,KAAA,CAAC;IAGzE,IAAI,CAAC7C,cAAc,GAAG4C,aAAa,IAAI,IAAI3B,mCAAmC,EAAE;AAClF;AAgBA6B,EAAAA,MAAMA,CACJtF,OAAoB,EACpBiD,MAAA,GAAgD;AAACE,IAAAA,KAAK,EAAE;AAAM,GAAA,EAAA;AAE9D,IAAA,IAAIoC,YAAyC;AAC7C,IAAA,IAAI,OAAOtC,MAAM,KAAK,SAAS,EAAE;AAC/BsC,MAAAA,YAAY,GAAG;AAACpC,QAAAA,KAAK,EAAEF;OAAO;AAChC,KAAA,MAAO;AACLsC,MAAAA,YAAY,GAAGtC,MAAM;AACvB;AACA,IAAA,OAAO,IAAIZ,qBAAqB,CAC9BrC,OAAO,EACP,IAAI,CAAC+C,QAAQ,EACb,IAAI,CAACC,OAAO,EACZ,IAAI,CAACtG,SAAS,EACd,IAAI,CAAC6F,iBAAiB,EACtB,IAAI,CAACC,cAAc,EACnB+C,YAAY,EACZ,IAAI,CAACL,SAAS,CACf;AACH;;;;;UArDWH,4BAA4B;AAAAtE,IAAAA,IAAA,EAAA,EAAA;AAAAC,IAAAA,MAAA,EAAAC,EAAA,CAAAC,eAAA,CAAAC;AAAA,GAAA,CAAA;AAA5B,EAAA,OAAAC,KAAA,GAAAH,EAAA,CAAAI,qBAAA,CAAA;AAAAC,IAAAA,UAAA,EAAA,QAAA;AAAAC,IAAAA,OAAA,EAAA,QAAA;AAAAC,IAAAA,QAAA,EAAAP,EAAA;AAAAQ,IAAAA,IAAA,EAAA4D,4BAA4B;gBADhB;AAAM,GAAA,CAAA;;;;;;QAClBA,4BAA4B;AAAA3D,EAAAA,UAAA,EAAA,CAAA;UADxCP,UAAU;WAAC;AAACQ,MAAAA,UAAU,EAAE;KAAO;;;;;;;"}
package/fesm2022/cdk.mjs CHANGED
@@ -1,6 +1,6 @@
1
1
  import { Version } from '@angular/core';
2
2
 
3
- const VERSION = new Version('21.0.2');
3
+ const VERSION = new Version('21.1.0-next.1');
4
4
 
5
5
  export { VERSION };
6
6
  //# sourceMappingURL=cdk.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"cdk.mjs","sources":["../../../../../k8-fastbuild-ST-199a4f3c4e20/bin/src/cdk/version.ts"],"sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.dev/license\n */\n\nimport {Version} from '@angular/core';\n\n/** Current version of the Angular Component Development Kit. */\nexport const VERSION = new Version('21.0.2');\n"],"names":["VERSION","Version"],"mappings":";;MAWaA,OAAO,GAAG,IAAIC,OAAO,CAAC,mBAAmB;;;;"}
1
+ {"version":3,"file":"cdk.mjs","sources":["../../../../../k8-fastbuild-ST-199a4f3c4e20/bin/src/cdk/version.ts"],"sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.dev/license\n */\n\nimport {Version} from '@angular/core';\n\n/** Current version of the Angular Component Development Kit. */\nexport const VERSION = new Version('21.1.0-next.1');\n"],"names":["VERSION","Version"],"mappings":";;MAWaA,OAAO,GAAG,IAAIC,OAAO,CAAC,mBAAmB;;;;"}
@@ -14,9 +14,10 @@ import { createBlockScrollStrategy, OverlayContainer, createOverlayRef, OverlayC
14
14
  import { _IdGenerator } from './_id-generator-chunk.mjs';
15
15
  import { Directionality } from './_directionality-chunk.mjs';
16
16
  import './_style-loader-chunk.mjs';
17
- import './_visually-hidden-chunk.mjs';
17
+ import './private.mjs';
18
18
  import './_breakpoints-observer-chunk.mjs';
19
19
  import './_array-chunk.mjs';
20
+ import '@angular/platform-browser';
20
21
  import './observers.mjs';
21
22
  import './_element-chunk.mjs';
22
23
  import './_fake-event-detection-chunk.mjs';