@angular/cdk 18.2.0-next.0 → 18.2.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.
Files changed (164) hide show
  1. package/a11y/index.d.ts +283 -2
  2. package/coercion/private/index.d.ts +9 -0
  3. package/esm2022/a11y/a11y-module.mjs +5 -5
  4. package/esm2022/a11y/aria-describer/aria-describer.mjs +4 -4
  5. package/esm2022/a11y/focus-monitor/focus-monitor.mjs +7 -7
  6. package/esm2022/a11y/focus-trap/configurable-focus-trap-factory.mjs +4 -4
  7. package/esm2022/a11y/focus-trap/focus-trap-manager.mjs +4 -4
  8. package/esm2022/a11y/focus-trap/focus-trap.mjs +7 -7
  9. package/esm2022/a11y/high-contrast-mode/high-contrast-mode-detector.mjs +4 -4
  10. package/esm2022/a11y/input-modality/input-modality-detector.mjs +4 -4
  11. package/esm2022/a11y/interactivity-checker/interactivity-checker.mjs +4 -4
  12. package/esm2022/a11y/key-manager/list-key-manager.mjs +18 -38
  13. package/esm2022/a11y/key-manager/noop-tree-key-manager.mjs +94 -0
  14. package/esm2022/a11y/key-manager/tree-key-manager-strategy.mjs +9 -0
  15. package/esm2022/a11y/key-manager/tree-key-manager.mjs +345 -0
  16. package/esm2022/a11y/key-manager/typeahead.mjs +91 -0
  17. package/esm2022/a11y/live-announcer/live-announcer.mjs +7 -7
  18. package/esm2022/a11y/public-api.mjs +4 -1
  19. package/esm2022/accordion/accordion-item.mjs +4 -4
  20. package/esm2022/accordion/accordion-module.mjs +5 -5
  21. package/esm2022/accordion/accordion.mjs +4 -4
  22. package/esm2022/bidi/bidi-module.mjs +5 -5
  23. package/esm2022/bidi/dir.mjs +4 -4
  24. package/esm2022/bidi/directionality.mjs +4 -4
  25. package/esm2022/clipboard/clipboard-module.mjs +5 -5
  26. package/esm2022/clipboard/clipboard.mjs +4 -4
  27. package/esm2022/clipboard/copy-to-clipboard.mjs +4 -4
  28. package/esm2022/coercion/private/index.mjs +9 -0
  29. package/esm2022/coercion/private/observable.mjs +19 -0
  30. package/esm2022/coercion/private/private_public_index.mjs +5 -0
  31. package/esm2022/collections/unique-selection-dispatcher.mjs +4 -4
  32. package/esm2022/dialog/dialog-container.mjs +4 -4
  33. package/esm2022/dialog/dialog-module.mjs +5 -5
  34. package/esm2022/dialog/dialog.mjs +4 -4
  35. package/esm2022/drag-drop/directives/drag-handle.mjs +4 -4
  36. package/esm2022/drag-drop/directives/drag-placeholder.mjs +4 -4
  37. package/esm2022/drag-drop/directives/drag-preview.mjs +4 -4
  38. package/esm2022/drag-drop/directives/drag.mjs +4 -4
  39. package/esm2022/drag-drop/directives/drop-list-group.mjs +4 -4
  40. package/esm2022/drag-drop/directives/drop-list.mjs +4 -4
  41. package/esm2022/drag-drop/drag-drop-module.mjs +5 -5
  42. package/esm2022/drag-drop/drag-drop-registry.mjs +7 -7
  43. package/esm2022/drag-drop/drag-drop.mjs +4 -4
  44. package/esm2022/drag-drop/drag-ref.mjs +4 -2
  45. package/esm2022/drag-drop/preview-ref.mjs +4 -1
  46. package/esm2022/layout/breakpoints-observer.mjs +4 -4
  47. package/esm2022/layout/layout-module.mjs +5 -5
  48. package/esm2022/layout/media-matcher.mjs +4 -4
  49. package/esm2022/listbox/listbox-module.mjs +5 -5
  50. package/esm2022/listbox/listbox.mjs +7 -7
  51. package/esm2022/menu/context-menu-trigger.mjs +7 -7
  52. package/esm2022/menu/menu-aim.mjs +7 -7
  53. package/esm2022/menu/menu-bar.mjs +4 -4
  54. package/esm2022/menu/menu-base.mjs +4 -4
  55. package/esm2022/menu/menu-group.mjs +4 -4
  56. package/esm2022/menu/menu-item-checkbox.mjs +4 -4
  57. package/esm2022/menu/menu-item-radio.mjs +4 -4
  58. package/esm2022/menu/menu-item-selectable.mjs +4 -4
  59. package/esm2022/menu/menu-item.mjs +4 -4
  60. package/esm2022/menu/menu-module.mjs +5 -5
  61. package/esm2022/menu/menu-stack.mjs +4 -4
  62. package/esm2022/menu/menu-trigger-base.mjs +4 -4
  63. package/esm2022/menu/menu-trigger.mjs +4 -4
  64. package/esm2022/menu/menu.mjs +4 -4
  65. package/esm2022/observers/observe-content.mjs +14 -14
  66. package/esm2022/observers/private/shared-resize-observer.mjs +4 -4
  67. package/esm2022/overlay/dispatchers/base-overlay-dispatcher.mjs +4 -4
  68. package/esm2022/overlay/dispatchers/overlay-keyboard-dispatcher.mjs +4 -4
  69. package/esm2022/overlay/dispatchers/overlay-outside-click-dispatcher.mjs +4 -4
  70. package/esm2022/overlay/fullscreen-overlay-container.mjs +4 -4
  71. package/esm2022/overlay/overlay-container.mjs +4 -4
  72. package/esm2022/overlay/overlay-directives.mjs +7 -7
  73. package/esm2022/overlay/overlay-module.mjs +5 -5
  74. package/esm2022/overlay/overlay.mjs +4 -4
  75. package/esm2022/overlay/position/overlay-position-builder.mjs +4 -4
  76. package/esm2022/overlay/scroll/scroll-strategy-options.mjs +4 -4
  77. package/esm2022/platform/platform-module.mjs +5 -5
  78. package/esm2022/platform/platform.mjs +4 -4
  79. package/esm2022/portal/portal-directives.mjs +17 -17
  80. package/esm2022/scrolling/fixed-size-virtual-scroll.mjs +4 -4
  81. package/esm2022/scrolling/scroll-dispatcher.mjs +4 -4
  82. package/esm2022/scrolling/scrollable.mjs +4 -4
  83. package/esm2022/scrolling/scrolling-module.mjs +9 -9
  84. package/esm2022/scrolling/viewport-ruler.mjs +4 -4
  85. package/esm2022/scrolling/virtual-for-of.mjs +4 -4
  86. package/esm2022/scrolling/virtual-scroll-viewport.mjs +4 -4
  87. package/esm2022/scrolling/virtual-scrollable-element.mjs +4 -4
  88. package/esm2022/scrolling/virtual-scrollable-window.mjs +4 -4
  89. package/esm2022/scrolling/virtual-scrollable.mjs +4 -4
  90. package/esm2022/stepper/step-header.mjs +4 -4
  91. package/esm2022/stepper/step-label.mjs +4 -4
  92. package/esm2022/stepper/stepper-button.mjs +7 -7
  93. package/esm2022/stepper/stepper-module.mjs +5 -5
  94. package/esm2022/stepper/stepper.mjs +7 -7
  95. package/esm2022/table/cell.mjs +22 -22
  96. package/esm2022/table/coalesced-style-scheduler.mjs +4 -4
  97. package/esm2022/table/row.mjs +28 -28
  98. package/esm2022/table/table-module.mjs +5 -5
  99. package/esm2022/table/table.mjs +19 -19
  100. package/esm2022/table/text-column.mjs +4 -4
  101. package/esm2022/text-field/autofill.mjs +7 -7
  102. package/esm2022/text-field/autosize.mjs +4 -4
  103. package/esm2022/text-field/text-field-module.mjs +5 -5
  104. package/esm2022/tree/control/base-tree-control.mjs +7 -2
  105. package/esm2022/tree/control/flat-tree-control.mjs +8 -2
  106. package/esm2022/tree/control/nested-tree-control.mjs +11 -2
  107. package/esm2022/tree/control/tree-control.mjs +1 -1
  108. package/esm2022/tree/nested-node.mjs +9 -18
  109. package/esm2022/tree/node.mjs +4 -4
  110. package/esm2022/tree/outlet.mjs +4 -4
  111. package/esm2022/tree/padding.mjs +5 -7
  112. package/esm2022/tree/toggle.mjs +17 -10
  113. package/esm2022/tree/tree-errors.mjs +7 -6
  114. package/esm2022/tree/tree-module.mjs +5 -5
  115. package/esm2022/tree/tree.mjs +810 -70
  116. package/esm2022/version.mjs +1 -1
  117. package/fesm2022/a11y.mjs +560 -80
  118. package/fesm2022/a11y.mjs.map +1 -1
  119. package/fesm2022/accordion.mjs +10 -10
  120. package/fesm2022/accordion.mjs.map +1 -1
  121. package/fesm2022/bidi.mjs +10 -10
  122. package/fesm2022/bidi.mjs.map +1 -1
  123. package/fesm2022/cdk.mjs +1 -1
  124. package/fesm2022/cdk.mjs.map +1 -1
  125. package/fesm2022/clipboard.mjs +10 -10
  126. package/fesm2022/clipboard.mjs.map +1 -1
  127. package/fesm2022/coercion/private.mjs +19 -0
  128. package/fesm2022/coercion/private.mjs.map +1 -0
  129. package/fesm2022/collections.mjs +3 -3
  130. package/fesm2022/collections.mjs.map +1 -1
  131. package/fesm2022/dialog.mjs +10 -10
  132. package/fesm2022/dialog.mjs.map +1 -1
  133. package/fesm2022/drag-drop.mjs +37 -32
  134. package/fesm2022/drag-drop.mjs.map +1 -1
  135. package/fesm2022/layout.mjs +10 -10
  136. package/fesm2022/layout.mjs.map +1 -1
  137. package/fesm2022/listbox.mjs +10 -10
  138. package/fesm2022/listbox.mjs.map +1 -1
  139. package/fesm2022/menu.mjs +49 -49
  140. package/fesm2022/menu.mjs.map +1 -1
  141. package/fesm2022/observers/private.mjs +3 -3
  142. package/fesm2022/observers/private.mjs.map +1 -1
  143. package/fesm2022/observers.mjs +13 -13
  144. package/fesm2022/observers.mjs.map +1 -1
  145. package/fesm2022/overlay.mjs +34 -34
  146. package/fesm2022/overlay.mjs.map +1 -1
  147. package/fesm2022/platform.mjs +7 -7
  148. package/fesm2022/platform.mjs.map +1 -1
  149. package/fesm2022/portal.mjs +16 -16
  150. package/fesm2022/portal.mjs.map +1 -1
  151. package/fesm2022/scrolling.mjs +35 -35
  152. package/fesm2022/scrolling.mjs.map +1 -1
  153. package/fesm2022/stepper.mjs +22 -22
  154. package/fesm2022/stepper.mjs.map +1 -1
  155. package/fesm2022/table.mjs +76 -76
  156. package/fesm2022/table.mjs.map +1 -1
  157. package/fesm2022/text-field.mjs +13 -13
  158. package/fesm2022/text-field.mjs.map +1 -1
  159. package/fesm2022/tree.mjs +868 -118
  160. package/fesm2022/tree.mjs.map +1 -1
  161. package/package.json +7 -1
  162. package/schematics/ng-add/index.js +1 -1
  163. package/schematics/ng-add/index.mjs +1 -1
  164. package/tree/index.d.ts +303 -25
package/a11y/index.d.ts CHANGED
@@ -910,7 +910,6 @@ export declare class ListKeyManager<T extends ListKeyManagerOption> {
910
910
  private _activeItemIndex;
911
911
  private _activeItem;
912
912
  private _wrap;
913
- private readonly _letterKeyStream;
914
913
  private _typeaheadSubscription;
915
914
  private _itemChangesSubscription?;
916
915
  private _vertical;
@@ -919,12 +918,12 @@ export declare class ListKeyManager<T extends ListKeyManagerOption> {
919
918
  private _homeAndEnd;
920
919
  private _pageUpAndDown;
921
920
  private _effectRef;
921
+ private _typeahead?;
922
922
  /**
923
923
  * Predicate function that can be used to check whether an item should be skipped
924
924
  * by the key manager. By default, disabled items are skipped.
925
925
  */
926
926
  private _skipPredicateFn;
927
- private _pressedLetters;
928
927
  constructor(items: QueryList<T> | T[] | readonly T[]);
929
928
  constructor(items: Signal<T[]> | Signal<readonly T[]>, injector: Injector);
930
929
  /**
@@ -1156,6 +1155,68 @@ declare interface ManagedFocusTrap {
1156
1155
  */
1157
1156
  export declare const MESSAGES_CONTAINER_ID = "cdk-describedby-message-container";
1158
1157
 
1158
+ /**
1159
+ * @docs-private
1160
+ *
1161
+ * Opt-out of Tree of key manager behavior.
1162
+ *
1163
+ * When provided, Tree has same focus management behavior as before TreeKeyManager was introduced.
1164
+ * - Tree does not respond to keyboard interaction
1165
+ * - Tree node allows tabindex to be set by Input binding
1166
+ * - Tree node allows tabindex to be set by attribute binding
1167
+ *
1168
+ * @deprecated NoopTreeKeyManager deprecated. Use TreeKeyManager or inject a
1169
+ * TreeKeyManagerStrategy instead. To be removed in a future version.
1170
+ *
1171
+ * @breaking-change 21.0.0
1172
+ */
1173
+ export declare function NOOP_TREE_KEY_MANAGER_FACTORY<T extends TreeKeyManagerItem>(): TreeKeyManagerFactory<T>;
1174
+
1175
+ /**
1176
+ * @docs-private
1177
+ *
1178
+ * Opt-out of Tree of key manager behavior.
1179
+ *
1180
+ * When provided, Tree has same focus management behavior as before TreeKeyManager was introduced.
1181
+ * - Tree does not respond to keyboard interaction
1182
+ * - Tree node allows tabindex to be set by Input binding
1183
+ * - Tree node allows tabindex to be set by attribute binding
1184
+ *
1185
+ * @deprecated NoopTreeKeyManager deprecated. Use TreeKeyManager or inject a
1186
+ * TreeKeyManagerStrategy instead. To be removed in a future version.
1187
+ *
1188
+ * @breaking-change 21.0.0
1189
+ */
1190
+ export declare const NOOP_TREE_KEY_MANAGER_FACTORY_PROVIDER: {
1191
+ provide: InjectionToken<TreeKeyManagerFactory<any>>;
1192
+ useFactory: typeof NOOP_TREE_KEY_MANAGER_FACTORY;
1193
+ };
1194
+
1195
+ /**
1196
+ * @docs-private
1197
+ *
1198
+ * Opt-out of Tree of key manager behavior.
1199
+ *
1200
+ * When provided, Tree has same focus management behavior as before TreeKeyManager was introduced.
1201
+ * - Tree does not respond to keyboard interaction
1202
+ * - Tree node allows tabindex to be set by Input binding
1203
+ * - Tree node allows tabindex to be set by attribute binding
1204
+ *
1205
+ * @deprecated NoopTreeKeyManager deprecated. Use TreeKeyManager or inject a
1206
+ * TreeKeyManagerStrategy instead. To be removed in a future version.
1207
+ *
1208
+ * @breaking-change 21.0.0
1209
+ */
1210
+ export declare class NoopTreeKeyManager<T extends TreeKeyManagerItem> implements TreeKeyManagerStrategy<T> {
1211
+ readonly _isNoopTreeKeyManager = true;
1212
+ readonly change: Subject<T | null>;
1213
+ destroy(): void;
1214
+ onKeydown(): void;
1215
+ getActiveItemIndex(): null;
1216
+ getActiveItem(): null;
1217
+ focusItem(): void;
1218
+ }
1219
+
1159
1220
  /**
1160
1221
  * Interface used to register message elements and keep a count of how many registrations have
1161
1222
  * the same message and the reference to the message element used for the `aria-describedby`.
@@ -1173,4 +1234,224 @@ export declare interface RegisteredMessage {
1173
1234
  */
1174
1235
  export declare function removeAriaReferencedId(el: Element, attr: `aria-${string}`, id: string): void;
1175
1236
 
1237
+ /** Injection token that determines the key manager to use. */
1238
+ export declare const TREE_KEY_MANAGER: InjectionToken<TreeKeyManagerFactory<any>>;
1239
+
1240
+ /** @docs-private */
1241
+ export declare function TREE_KEY_MANAGER_FACTORY<T extends TreeKeyManagerItem>(): TreeKeyManagerFactory<T>;
1242
+
1243
+ /** @docs-private */
1244
+ export declare const TREE_KEY_MANAGER_FACTORY_PROVIDER: {
1245
+ provide: InjectionToken<TreeKeyManagerFactory<any>>;
1246
+ useFactory: typeof TREE_KEY_MANAGER_FACTORY;
1247
+ };
1248
+
1249
+ /**
1250
+ * This class manages keyboard events for trees. If you pass it a QueryList or other list of tree
1251
+ * items, it will set the active item, focus, handle expansion and typeahead correctly when
1252
+ * keyboard events occur.
1253
+ */
1254
+ export declare class TreeKeyManager<T extends TreeKeyManagerItem> implements TreeKeyManagerStrategy<T> {
1255
+ /** The index of the currently active (focused) item. */
1256
+ private _activeItemIndex;
1257
+ /** The currently active (focused) item. */
1258
+ private _activeItem;
1259
+ /** Whether or not we activate the item when it's focused. */
1260
+ private _shouldActivationFollowFocus;
1261
+ /**
1262
+ * The orientation that the tree is laid out in. In `rtl` mode, the behavior of Left and
1263
+ * Right arrow are switched.
1264
+ */
1265
+ private _horizontalOrientation;
1266
+ /**
1267
+ * Predicate function that can be used to check whether an item should be skipped
1268
+ * by the key manager.
1269
+ *
1270
+ * The default value for this doesn't skip any elements in order to keep tree items focusable
1271
+ * when disabled. This aligns with ARIA guidelines:
1272
+ * https://www.w3.org/WAI/ARIA/apg/practices/keyboard-interface/#focusabilityofdisabledcontrols.
1273
+ */
1274
+ private _skipPredicateFn;
1275
+ /** Function to determine equivalent items. */
1276
+ private _trackByFn;
1277
+ /** Synchronous cache of the items to manage. */
1278
+ private _items;
1279
+ private _typeahead?;
1280
+ private _typeaheadSubscription;
1281
+ private _hasInitialFocused;
1282
+ private _initialFocus;
1283
+ /**
1284
+ *
1285
+ * @param items List of TreeKeyManager options. Can be synchronous or asynchronous.
1286
+ * @param config Optional configuration options. By default, use 'ltr' horizontal orientation. By
1287
+ * default, do not skip any nodes. By default, key manager only calls `focus` method when items
1288
+ * are focused and does not call `activate`. If `typeaheadDefaultInterval` is `true`, use a
1289
+ * default interval of 200ms.
1290
+ */
1291
+ constructor(items: Observable<T[]> | QueryList<T> | T[], config: TreeKeyManagerOptions<T>);
1292
+ /** Stream that emits any time the focused item changes. */
1293
+ readonly change: Subject<T | null>;
1294
+ /** Cleans up the key manager. */
1295
+ destroy(): void;
1296
+ /**
1297
+ * Handles a keyboard event on the tree.
1298
+ * @param event Keyboard event that represents the user interaction with the tree.
1299
+ */
1300
+ onKeydown(event: KeyboardEvent): void;
1301
+ /** Index of the currently active item. */
1302
+ getActiveItemIndex(): number | null;
1303
+ /** The currently active item. */
1304
+ getActiveItem(): T | null;
1305
+ /** Focus the first available item. */
1306
+ private _focusFirstItem;
1307
+ /** Focus the last available item. */
1308
+ private _focusLastItem;
1309
+ /** Focus the next available item. */
1310
+ private _focusNextItem;
1311
+ /** Focus the previous available item. */
1312
+ private _focusPreviousItem;
1313
+ /**
1314
+ * Focus the provided item by index.
1315
+ * @param index The index of the item to focus.
1316
+ * @param options Additional focusing options.
1317
+ */
1318
+ focusItem(index: number, options?: {
1319
+ emitChangeEvent?: boolean;
1320
+ }): void;
1321
+ focusItem(item: T, options?: {
1322
+ emitChangeEvent?: boolean;
1323
+ }): void;
1324
+ focusItem(itemOrIndex: number | T, options?: {
1325
+ emitChangeEvent?: boolean;
1326
+ }): void;
1327
+ private _updateActiveItemIndex;
1328
+ private _setTypeAhead;
1329
+ private _findNextAvailableItemIndex;
1330
+ private _findPreviousAvailableItemIndex;
1331
+ /**
1332
+ * If the item is already expanded, we collapse the item. Otherwise, we will focus the parent.
1333
+ */
1334
+ private _collapseCurrentItem;
1335
+ /**
1336
+ * If the item is already collapsed, we expand the item. Otherwise, we will focus the first child.
1337
+ */
1338
+ private _expandCurrentItem;
1339
+ private _isCurrentItemExpanded;
1340
+ private _isItemDisabled;
1341
+ /** For all items that are the same level as the current item, we expand those items. */
1342
+ private _expandAllItemsAtCurrentItemLevel;
1343
+ private _activateCurrentItem;
1344
+ }
1345
+
1346
+ export declare type TreeKeyManagerFactory<T extends TreeKeyManagerItem> = (items: Observable<T[]> | QueryList<T> | T[], options: TreeKeyManagerOptions<T>) => TreeKeyManagerStrategy<T>;
1347
+
1348
+ /** Represents an item within a tree that can be passed to a TreeKeyManager. */
1349
+ export declare interface TreeKeyManagerItem {
1350
+ /** Whether the item is disabled. */
1351
+ isDisabled?: (() => boolean) | boolean;
1352
+ /** The user-facing label for this item. */
1353
+ getLabel?(): string;
1354
+ /** Perform the main action (i.e. selection) for this item. */
1355
+ activate(): void;
1356
+ /** Retrieves the parent for this item. This is `null` if there is no parent. */
1357
+ getParent(): TreeKeyManagerItem | null;
1358
+ /** Retrieves the children for this item. */
1359
+ getChildren(): TreeKeyManagerItem[] | Observable<TreeKeyManagerItem[]>;
1360
+ /** Determines if the item is currently expanded. */
1361
+ isExpanded: (() => boolean) | boolean;
1362
+ /** Collapses the item, hiding its children. */
1363
+ collapse(): void;
1364
+ /** Expands the item, showing its children. */
1365
+ expand(): void;
1366
+ /**
1367
+ * Focuses the item. This should provide some indication to the user that this item is focused.
1368
+ */
1369
+ focus(): void;
1370
+ /**
1371
+ * Unfocus the item. This should remove the focus state.
1372
+ */
1373
+ unfocus(): void;
1374
+ }
1375
+
1376
+ /**
1377
+ * Configuration for the TreeKeyManager.
1378
+ */
1379
+ export declare interface TreeKeyManagerOptions<T extends TreeKeyManagerItem> {
1380
+ /**
1381
+ * If true, then the key manager will call `activate` in addition to calling `focus` when a
1382
+ * particular item is focused.
1383
+ */
1384
+ shouldActivationFollowFocus?: boolean;
1385
+ /**
1386
+ * The direction in which the tree items are laid out horizontally. This influences which key
1387
+ * will be interpreted as expand or collapse.
1388
+ */
1389
+ horizontalOrientation?: 'rtl' | 'ltr';
1390
+ /**
1391
+ * If provided, navigation "skips" over items that pass the given predicate.
1392
+ *
1393
+ * If the item is to be skipped, predicate function should return false.
1394
+ */
1395
+ skipPredicate?: (item: T) => boolean;
1396
+ /**
1397
+ * If provided, determines how the key manager determines if two items are equivalent.
1398
+ *
1399
+ * It should provide a unique key for each unique tree item. If two tree items are equivalent,
1400
+ * then this function should return the same value.
1401
+ */
1402
+ trackBy?: (treeItem: T) => unknown;
1403
+ /**
1404
+ * If a value is provided, enables typeahead mode, which allows users to set the active item
1405
+ * by typing the visible label of the item.
1406
+ *
1407
+ * If a number is provided, this will be the time to wait after the last keystroke before
1408
+ * setting the active item. If `true` is provided, the default interval of 200ms will be used.
1409
+ */
1410
+ typeAheadDebounceInterval?: true | number;
1411
+ }
1412
+
1413
+ export declare interface TreeKeyManagerStrategy<T extends TreeKeyManagerItem> {
1414
+ /** Stream that emits any time the focused item changes. */
1415
+ readonly change: Subject<T | null>;
1416
+ /**
1417
+ * Cleans up the key manager.
1418
+ */
1419
+ destroy(): void;
1420
+ /**
1421
+ * Handles a keyboard event on the tree.
1422
+ *
1423
+ * @param event Keyboard event that represents the user interaction with the tree.
1424
+ */
1425
+ onKeydown(event: KeyboardEvent): void;
1426
+ /** Index of the currently active item. */
1427
+ getActiveItemIndex(): number | null;
1428
+ /** The currently active item. */
1429
+ getActiveItem(): T | null;
1430
+ /**
1431
+ * Focus the provided item by index.
1432
+ *
1433
+ * Updates the state of the currently active item. Emits to `change` stream if active item
1434
+ * Changes.
1435
+ * @param index The index of the item to focus.
1436
+ * @param options Additional focusing options.
1437
+ */
1438
+ focusItem(index: number, options?: {
1439
+ emitChangeEvent?: boolean;
1440
+ }): void;
1441
+ /**
1442
+ * Focus the provided item.
1443
+ *
1444
+ * Updates the state of the currently active item. Emits to `change` stream if active item
1445
+ * Changes.
1446
+ * @param item The item to focus. Equality is determined via the trackBy function.
1447
+ * @param options Additional focusing options.
1448
+ */
1449
+ focusItem(item: T, options?: {
1450
+ emitChangeEvent?: boolean;
1451
+ }): void;
1452
+ focusItem(itemOrIndex: number | T, options?: {
1453
+ emitChangeEvent?: boolean;
1454
+ }): void;
1455
+ }
1456
+
1176
1457
  export { }
@@ -0,0 +1,9 @@
1
+ import { Observable } from 'rxjs';
2
+
3
+ /**
4
+ * Given either an Observable or non-Observable value, returns either the original
5
+ * Observable, or wraps it in an Observable that emits the non-Observable value.
6
+ */
7
+ export declare function coerceObservable<T>(data: T | Observable<T>): Observable<T>;
8
+
9
+ export { }
@@ -17,15 +17,15 @@ export class A11yModule {
17
17
  constructor(highContrastModeDetector) {
18
18
  highContrastModeDetector._applyBodyHighContrastModeCssClasses();
19
19
  }
20
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.0-next.3", ngImport: i0, type: A11yModule, deps: [{ token: i1.HighContrastModeDetector }], target: i0.ɵɵFactoryTarget.NgModule }); }
21
- static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.1.0-next.3", ngImport: i0, type: A11yModule, imports: [ObserversModule, CdkAriaLive, CdkTrapFocus, CdkMonitorFocus], exports: [CdkAriaLive, CdkTrapFocus, CdkMonitorFocus] }); }
22
- static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.1.0-next.3", ngImport: i0, type: A11yModule, imports: [ObserversModule] }); }
20
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: A11yModule, deps: [{ token: i1.HighContrastModeDetector }], target: i0.ɵɵFactoryTarget.NgModule }); }
21
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.1.0", ngImport: i0, type: A11yModule, imports: [ObserversModule, CdkAriaLive, CdkTrapFocus, CdkMonitorFocus], exports: [CdkAriaLive, CdkTrapFocus, CdkMonitorFocus] }); }
22
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: A11yModule, imports: [ObserversModule] }); }
23
23
  }
24
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0-next.3", ngImport: i0, type: A11yModule, decorators: [{
24
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: A11yModule, decorators: [{
25
25
  type: NgModule,
26
26
  args: [{
27
27
  imports: [ObserversModule, CdkAriaLive, CdkTrapFocus, CdkMonitorFocus],
28
28
  exports: [CdkAriaLive, CdkTrapFocus, CdkMonitorFocus],
29
29
  }]
30
30
  }], ctorParameters: () => [{ type: i1.HighContrastModeDetector }] });
31
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYTExeS1tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvY2RrL2ExMXkvYTExeS1tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7OztHQU1HO0FBRUgsT0FBTyxFQUFDLGVBQWUsRUFBQyxNQUFNLHdCQUF3QixDQUFDO0FBQ3ZELE9BQU8sRUFBQyxRQUFRLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDdkMsT0FBTyxFQUFDLGVBQWUsRUFBQyxNQUFNLCtCQUErQixDQUFDO0FBQzlELE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSx5QkFBeUIsQ0FBQztBQUNyRCxPQUFPLEVBQUMsd0JBQXdCLEVBQUMsTUFBTSxrREFBa0QsQ0FBQztBQUMxRixPQUFPLEVBQUMsV0FBVyxFQUFDLE1BQU0saUNBQWlDLENBQUM7OztBQU01RCxNQUFNLE9BQU8sVUFBVTtJQUNyQixZQUFZLHdCQUFrRDtRQUM1RCx3QkFBd0IsQ0FBQyxvQ0FBb0MsRUFBRSxDQUFDO0lBQ2xFLENBQUM7cUhBSFUsVUFBVTtzSEFBVixVQUFVLFlBSFgsZUFBZSxFQUFFLFdBQVcsRUFBRSxZQUFZLEVBQUUsZUFBZSxhQUMzRCxXQUFXLEVBQUUsWUFBWSxFQUFFLGVBQWU7c0hBRXpDLFVBQVUsWUFIWCxlQUFlOztrR0FHZCxVQUFVO2tCQUp0QixRQUFRO21CQUFDO29CQUNSLE9BQU8sRUFBRSxDQUFDLGVBQWUsRUFBRSxXQUFXLEVBQUUsWUFBWSxFQUFFLGVBQWUsQ0FBQztvQkFDdEUsT0FBTyxFQUFFLENBQUMsV0FBVyxFQUFFLFlBQVksRUFBRSxlQUFlLENBQUM7aUJBQ3REIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBMTEMgQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5cbmltcG9ydCB7T2JzZXJ2ZXJzTW9kdWxlfSBmcm9tICdAYW5ndWxhci9jZGsvb2JzZXJ2ZXJzJztcbmltcG9ydCB7TmdNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtDZGtNb25pdG9yRm9jdXN9IGZyb20gJy4vZm9jdXMtbW9uaXRvci9mb2N1cy1tb25pdG9yJztcbmltcG9ydCB7Q2RrVHJhcEZvY3VzfSBmcm9tICcuL2ZvY3VzLXRyYXAvZm9jdXMtdHJhcCc7XG5pbXBvcnQge0hpZ2hDb250cmFzdE1vZGVEZXRlY3Rvcn0gZnJvbSAnLi9oaWdoLWNvbnRyYXN0LW1vZGUvaGlnaC1jb250cmFzdC1tb2RlLWRldGVjdG9yJztcbmltcG9ydCB7Q2RrQXJpYUxpdmV9IGZyb20gJy4vbGl2ZS1hbm5vdW5jZXIvbGl2ZS1hbm5vdW5jZXInO1xuXG5ATmdNb2R1bGUoe1xuICBpbXBvcnRzOiBbT2JzZXJ2ZXJzTW9kdWxlLCBDZGtBcmlhTGl2ZSwgQ2RrVHJhcEZvY3VzLCBDZGtNb25pdG9yRm9jdXNdLFxuICBleHBvcnRzOiBbQ2RrQXJpYUxpdmUsIENka1RyYXBGb2N1cywgQ2RrTW9uaXRvckZvY3VzXSxcbn0pXG5leHBvcnQgY2xhc3MgQTExeU1vZHVsZSB7XG4gIGNvbnN0cnVjdG9yKGhpZ2hDb250cmFzdE1vZGVEZXRlY3RvcjogSGlnaENvbnRyYXN0TW9kZURldGVjdG9yKSB7XG4gICAgaGlnaENvbnRyYXN0TW9kZURldGVjdG9yLl9hcHBseUJvZHlIaWdoQ29udHJhc3RNb2RlQ3NzQ2xhc3NlcygpO1xuICB9XG59XG4iXX0=
31
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYTExeS1tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvY2RrL2ExMXkvYTExeS1tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7OztHQU1HO0FBRUgsT0FBTyxFQUFDLGVBQWUsRUFBQyxNQUFNLHdCQUF3QixDQUFDO0FBQ3ZELE9BQU8sRUFBQyxRQUFRLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDdkMsT0FBTyxFQUFDLGVBQWUsRUFBQyxNQUFNLCtCQUErQixDQUFDO0FBQzlELE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSx5QkFBeUIsQ0FBQztBQUNyRCxPQUFPLEVBQUMsd0JBQXdCLEVBQUMsTUFBTSxrREFBa0QsQ0FBQztBQUMxRixPQUFPLEVBQUMsV0FBVyxFQUFDLE1BQU0saUNBQWlDLENBQUM7OztBQU01RCxNQUFNLE9BQU8sVUFBVTtJQUNyQixZQUFZLHdCQUFrRDtRQUM1RCx3QkFBd0IsQ0FBQyxvQ0FBb0MsRUFBRSxDQUFDO0lBQ2xFLENBQUM7OEdBSFUsVUFBVTsrR0FBVixVQUFVLFlBSFgsZUFBZSxFQUFFLFdBQVcsRUFBRSxZQUFZLEVBQUUsZUFBZSxhQUMzRCxXQUFXLEVBQUUsWUFBWSxFQUFFLGVBQWU7K0dBRXpDLFVBQVUsWUFIWCxlQUFlOzsyRkFHZCxVQUFVO2tCQUp0QixRQUFRO21CQUFDO29CQUNSLE9BQU8sRUFBRSxDQUFDLGVBQWUsRUFBRSxXQUFXLEVBQUUsWUFBWSxFQUFFLGVBQWUsQ0FBQztvQkFDdEUsT0FBTyxFQUFFLENBQUMsV0FBVyxFQUFFLFlBQVksRUFBRSxlQUFlLENBQUM7aUJBQ3REIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBMTEMgQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5cbmltcG9ydCB7T2JzZXJ2ZXJzTW9kdWxlfSBmcm9tICdAYW5ndWxhci9jZGsvb2JzZXJ2ZXJzJztcbmltcG9ydCB7TmdNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtDZGtNb25pdG9yRm9jdXN9IGZyb20gJy4vZm9jdXMtbW9uaXRvci9mb2N1cy1tb25pdG9yJztcbmltcG9ydCB7Q2RrVHJhcEZvY3VzfSBmcm9tICcuL2ZvY3VzLXRyYXAvZm9jdXMtdHJhcCc7XG5pbXBvcnQge0hpZ2hDb250cmFzdE1vZGVEZXRlY3Rvcn0gZnJvbSAnLi9oaWdoLWNvbnRyYXN0LW1vZGUvaGlnaC1jb250cmFzdC1tb2RlLWRldGVjdG9yJztcbmltcG9ydCB7Q2RrQXJpYUxpdmV9IGZyb20gJy4vbGl2ZS1hbm5vdW5jZXIvbGl2ZS1hbm5vdW5jZXInO1xuXG5ATmdNb2R1bGUoe1xuICBpbXBvcnRzOiBbT2JzZXJ2ZXJzTW9kdWxlLCBDZGtBcmlhTGl2ZSwgQ2RrVHJhcEZvY3VzLCBDZGtNb25pdG9yRm9jdXNdLFxuICBleHBvcnRzOiBbQ2RrQXJpYUxpdmUsIENka1RyYXBGb2N1cywgQ2RrTW9uaXRvckZvY3VzXSxcbn0pXG5leHBvcnQgY2xhc3MgQTExeU1vZHVsZSB7XG4gIGNvbnN0cnVjdG9yKGhpZ2hDb250cmFzdE1vZGVEZXRlY3RvcjogSGlnaENvbnRyYXN0TW9kZURldGVjdG9yKSB7XG4gICAgaGlnaENvbnRyYXN0TW9kZURldGVjdG9yLl9hcHBseUJvZHlIaWdoQ29udHJhc3RNb2RlQ3NzQ2xhc3NlcygpO1xuICB9XG59XG4iXX0=
@@ -209,10 +209,10 @@ export class AriaDescriber {
209
209
  _isElementNode(element) {
210
210
  return element.nodeType === this._document.ELEMENT_NODE;
211
211
  }
212
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.0-next.3", ngImport: i0, type: AriaDescriber, deps: [{ token: DOCUMENT }, { token: i1.Platform }], target: i0.ɵɵFactoryTarget.Injectable }); }
213
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.1.0-next.3", ngImport: i0, type: AriaDescriber, providedIn: 'root' }); }
212
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: AriaDescriber, deps: [{ token: DOCUMENT }, { token: i1.Platform }], target: i0.ɵɵFactoryTarget.Injectable }); }
213
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: AriaDescriber, providedIn: 'root' }); }
214
214
  }
215
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0-next.3", ngImport: i0, type: AriaDescriber, decorators: [{
215
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: AriaDescriber, decorators: [{
216
216
  type: Injectable,
217
217
  args: [{ providedIn: 'root' }]
218
218
  }], ctorParameters: () => [{ type: undefined, decorators: [{
@@ -229,4 +229,4 @@ function setMessageId(element, serviceId) {
229
229
  element.id = `${CDK_DESCRIBEDBY_ID_PREFIX}-${serviceId}-${nextId++}`;
230
230
  }
231
231
  }
232
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"aria-describer.js","sourceRoot":"","sources":["../../../../../../../src/cdk/a11y/aria-describer/aria-describer.ts"],"names":[],"mappings":"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","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.io/license\n */\n\nimport {DOCUMENT} from '@angular/common';\nimport {Inject, Injectable, OnDestroy, APP_ID, inject} from '@angular/core';\nimport {Platform} from '@angular/cdk/platform';\nimport {addAriaReferencedId, getAriaReferenceIds, removeAriaReferencedId} from './aria-reference';\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 _document: 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(\n    @Inject(DOCUMENT) _document: any,\n    /**\n     * @deprecated To be turned into a required parameter.\n     * @breaking-change 14.0.0\n     */\n    private _platform?: Platform,\n  ) {\n    this._document = _document;\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    // @breaking-change 14.0.0 Remove null check for `_platform`.\n    if (this._platform && !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"]}
232
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"aria-describer.js","sourceRoot":"","sources":["../../../../../../../src/cdk/a11y/aria-describer/aria-describer.ts"],"names":[],"mappings":"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","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.io/license\n */\n\nimport {DOCUMENT} from '@angular/common';\nimport {Inject, Injectable, OnDestroy, APP_ID, inject} from '@angular/core';\nimport {Platform} from '@angular/cdk/platform';\nimport {addAriaReferencedId, getAriaReferenceIds, removeAriaReferencedId} from './aria-reference';\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 _document: 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(\n    @Inject(DOCUMENT) _document: any,\n    /**\n     * @deprecated To be turned into a required parameter.\n     * @breaking-change 14.0.0\n     */\n    private _platform?: Platform,\n  ) {\n    this._document = _document;\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    // @breaking-change 14.0.0 Remove null check for `_platform`.\n    if (this._platform && !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"]}