@angular/cdk 20.0.0-next.4 → 20.0.0-next.6

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 (201) hide show
  1. package/a11y/index.d.ts +12 -11
  2. package/{a11y-module.d-7d03e079.d.ts → a11y-module.d-9e4162d8.d.ts} +4 -3
  3. package/accordion/index.d.ts +1 -1
  4. package/{activedescendant-key-manager.d-11921e3a.d.ts → activedescendant-key-manager.d-8f004111.d.ts} +3 -2
  5. package/bidi/index.d.ts +1 -1
  6. package/{bidi-module.d-f8648621.d.ts → bidi-module.d-e02fd94c.d.ts} +8 -4
  7. package/clipboard/index.d.ts +2 -1
  8. package/coercion/index.d.ts +3 -2
  9. package/collections/index.d.ts +9 -8
  10. package/{data-source.d-7cab2c9d.d.ts → data-source.d-7eda4d9a.d.ts} +2 -1
  11. package/dialog/index.d.ts +15 -14
  12. package/drag-drop/index.d.ts +10 -7
  13. package/fesm2022/{a11y-module-b228dc71.mjs → a11y-module-3f18e5c2.mjs} +30 -30
  14. package/fesm2022/a11y-module-3f18e5c2.mjs.map +1 -0
  15. package/fesm2022/a11y.mjs +32 -33
  16. package/fesm2022/a11y.mjs.map +1 -1
  17. package/fesm2022/accordion.mjs +12 -12
  18. package/fesm2022/accordion.mjs.map +1 -1
  19. package/fesm2022/{activedescendant-key-manager-1351a9d3.mjs → activedescendant-key-manager-ca3e95bd.mjs} +2 -2
  20. package/fesm2022/activedescendant-key-manager-ca3e95bd.mjs.map +1 -0
  21. package/fesm2022/{array-88e1bec3.mjs → array-88204b72.mjs} +1 -1
  22. package/fesm2022/array-88204b72.mjs.map +1 -0
  23. package/fesm2022/{bidi-module-e73b8776.mjs → bidi-module-93941905.mjs} +16 -17
  24. package/fesm2022/bidi-module-93941905.mjs.map +1 -0
  25. package/fesm2022/bidi.mjs +2 -2
  26. package/fesm2022/{breakpoints-observer-9432a91b.mjs → breakpoints-observer-9d296976.mjs} +9 -9
  27. package/fesm2022/breakpoints-observer-9d296976.mjs.map +1 -0
  28. package/fesm2022/cdk.mjs +1 -1
  29. package/fesm2022/cdk.mjs.map +1 -1
  30. package/fesm2022/clipboard.mjs +10 -10
  31. package/fesm2022/clipboard.mjs.map +1 -1
  32. package/fesm2022/coercion/private.mjs +1 -1
  33. package/fesm2022/coercion.mjs +3 -3
  34. package/fesm2022/coercion.mjs.map +1 -1
  35. package/fesm2022/collections.mjs +5 -5
  36. package/fesm2022/{css-pixel-value-447bbfe8.mjs → css-pixel-value-5ab12b77.mjs} +1 -1
  37. package/fesm2022/css-pixel-value-5ab12b77.mjs.map +1 -0
  38. package/fesm2022/{data-source-5320b6fd.mjs → data-source-a3a3a257.mjs} +1 -1
  39. package/fesm2022/data-source-a3a3a257.mjs.map +1 -0
  40. package/fesm2022/dialog.mjs +36 -37
  41. package/fesm2022/dialog.mjs.map +1 -1
  42. package/fesm2022/{directionality-ea6ab987.mjs → directionality-25132624.mjs} +13 -7
  43. package/fesm2022/directionality-25132624.mjs.map +1 -0
  44. package/fesm2022/{dispose-view-repeater-strategy-b11b87ea.mjs → dispose-view-repeater-strategy-0bf96031.mjs} +2 -2
  45. package/fesm2022/dispose-view-repeater-strategy-0bf96031.mjs.map +1 -0
  46. package/fesm2022/drag-drop.mjs +70 -58
  47. package/fesm2022/drag-drop.mjs.map +1 -1
  48. package/fesm2022/{element-08c51fcd.mjs → element-bed495ef.mjs} +1 -1
  49. package/fesm2022/element-bed495ef.mjs.map +1 -0
  50. package/fesm2022/{fake-event-detection-7055b1bd.mjs → fake-event-detection-61bf2988.mjs} +1 -1
  51. package/fesm2022/fake-event-detection-61bf2988.mjs.map +1 -0
  52. package/fesm2022/{focus-key-manager-58d29acd.mjs → focus-key-manager-f4cf48e1.mjs} +2 -2
  53. package/fesm2022/focus-key-manager-f4cf48e1.mjs.map +1 -0
  54. package/fesm2022/{focus-monitor-69f9c0f9.mjs → focus-monitor-4af46fa6.mjs} +19 -20
  55. package/fesm2022/focus-monitor-4af46fa6.mjs.map +1 -0
  56. package/fesm2022/{id-generator-ec45a122.mjs → id-generator-dd03740e.mjs} +4 -4
  57. package/fesm2022/id-generator-dd03740e.mjs.map +1 -0
  58. package/fesm2022/{keycodes-107cd3e4.mjs → keycodes-fbdb6e67.mjs} +1 -1
  59. package/fesm2022/keycodes-fbdb6e67.mjs.map +1 -0
  60. package/fesm2022/keycodes.mjs +2 -2
  61. package/fesm2022/layout.mjs +7 -7
  62. package/fesm2022/layout.mjs.map +1 -1
  63. package/fesm2022/{list-key-manager-c7b5cefb.mjs → list-key-manager-0ce9d5be.mjs} +4 -4
  64. package/fesm2022/list-key-manager-0ce9d5be.mjs.map +1 -0
  65. package/fesm2022/listbox.mjs +20 -20
  66. package/fesm2022/listbox.mjs.map +1 -1
  67. package/fesm2022/menu.mjs +74 -75
  68. package/fesm2022/menu.mjs.map +1 -1
  69. package/fesm2022/{modifiers-33a5859e.mjs → modifiers-68a3bc3a.mjs} +1 -1
  70. package/fesm2022/modifiers-68a3bc3a.mjs.map +1 -0
  71. package/fesm2022/{observable-97c0792c.mjs → observable-36bb5527.mjs} +1 -1
  72. package/fesm2022/observable-36bb5527.mjs.map +1 -0
  73. package/fesm2022/{observe-content-459e1d12.mjs → observe-content-85983868.mjs} +15 -15
  74. package/fesm2022/observe-content-85983868.mjs.map +1 -0
  75. package/fesm2022/observers/private.mjs +3 -3
  76. package/fesm2022/observers/private.mjs.map +1 -1
  77. package/fesm2022/observers.mjs +2 -2
  78. package/fesm2022/{overlay-module-6e7b742f.mjs → overlay-module-a2bddb9f.mjs} +108 -91
  79. package/fesm2022/overlay-module-a2bddb9f.mjs.map +1 -0
  80. package/fesm2022/overlay.mjs +22 -23
  81. package/fesm2022/overlay.mjs.map +1 -1
  82. package/fesm2022/{passive-listeners-c0bdc49f.mjs → passive-listeners-1189a3bc.mjs} +1 -1
  83. package/fesm2022/passive-listeners-1189a3bc.mjs.map +1 -0
  84. package/fesm2022/{platform-2be6a529.mjs → platform-3b280dd2.mjs} +4 -4
  85. package/fesm2022/platform-3b280dd2.mjs.map +1 -0
  86. package/fesm2022/platform.mjs +9 -10
  87. package/fesm2022/platform.mjs.map +1 -1
  88. package/fesm2022/{portal-directives-9cd98881.mjs → portal-directives-4da94e82.mjs} +17 -17
  89. package/fesm2022/portal-directives-4da94e82.mjs.map +1 -0
  90. package/fesm2022/portal.mjs +1 -1
  91. package/fesm2022/private.mjs +2 -2
  92. package/fesm2022/{recycle-view-repeater-strategy-c1712813.mjs → recycle-view-repeater-strategy-7fe34ce5.mjs} +2 -2
  93. package/fesm2022/recycle-view-repeater-strategy-7fe34ce5.mjs.map +1 -0
  94. package/fesm2022/{scrolling-61955dd1.mjs → scrolling-4b9e82b7.mjs} +1 -1
  95. package/fesm2022/scrolling-4b9e82b7.mjs.map +1 -0
  96. package/fesm2022/{scrolling-module-72941c9f.mjs → scrolling-module-2ed090a6.mjs} +43 -43
  97. package/fesm2022/scrolling-module-2ed090a6.mjs.map +1 -0
  98. package/fesm2022/scrolling.mjs +8 -8
  99. package/fesm2022/{selection-model-30243dba.mjs → selection-model-7800ff2c.mjs} +1 -1
  100. package/fesm2022/selection-model-7800ff2c.mjs.map +1 -0
  101. package/fesm2022/{shadow-dom-9f403d00.mjs → shadow-dom-09da63d7.mjs} +1 -1
  102. package/fesm2022/shadow-dom-09da63d7.mjs.map +1 -0
  103. package/fesm2022/stepper.mjs +31 -31
  104. package/fesm2022/stepper.mjs.map +1 -1
  105. package/fesm2022/{style-loader-9fc0a4d2.mjs → style-loader-f70e1cd6.mjs} +4 -4
  106. package/fesm2022/style-loader-f70e1cd6.mjs.map +1 -0
  107. package/fesm2022/table.mjs +92 -89
  108. package/fesm2022/table.mjs.map +1 -1
  109. package/fesm2022/{test-environment-34eef1ee.mjs → test-environment-75e095b5.mjs} +1 -1
  110. package/fesm2022/test-environment-75e095b5.mjs.map +1 -0
  111. package/fesm2022/testing/selenium-webdriver.mjs +1 -1
  112. package/fesm2022/testing/selenium-webdriver.mjs.map +1 -1
  113. package/fesm2022/testing/testbed.mjs +2 -2
  114. package/fesm2022/testing/testbed.mjs.map +1 -1
  115. package/fesm2022/testing.mjs +1 -1
  116. package/fesm2022/text-field.mjs +20 -21
  117. package/fesm2022/text-field.mjs.map +1 -1
  118. package/fesm2022/{text-filtering-0c6de6d6.mjs → text-filtering-682c2e05.mjs} +1 -1
  119. package/fesm2022/text-filtering-682c2e05.mjs.map +1 -0
  120. package/fesm2022/{tree-key-manager-2f20c79c.mjs → tree-key-manager-fb779925.mjs} +3 -3
  121. package/fesm2022/tree-key-manager-fb779925.mjs.map +1 -0
  122. package/fesm2022/tree.mjs +32 -32
  123. package/fesm2022/tree.mjs.map +1 -1
  124. package/fesm2022/{typeahead-11ae39bd.mjs → typeahead-5b1c5e41.mjs} +2 -2
  125. package/fesm2022/typeahead-5b1c5e41.mjs.map +1 -0
  126. package/fesm2022/{unique-selection-dispatcher-d0d5176e.mjs → unique-selection-dispatcher-95d71775.mjs} +4 -4
  127. package/fesm2022/unique-selection-dispatcher-95d71775.mjs.map +1 -0
  128. package/fesm2022/{visually-hidden-a6df546a.mjs → visually-hidden-912d0ccc.mjs} +4 -4
  129. package/fesm2022/visually-hidden-912d0ccc.mjs.map +1 -0
  130. package/{focus-key-manager.d-415a6958.d.ts → focus-key-manager.d-808a8cfc.d.ts} +4 -3
  131. package/{focus-monitor.d-810a02e6.d.ts → focus-monitor.d-463f4526.d.ts} +2 -1
  132. package/{harness-environment.d-4d615248.d.ts → harness-environment.d-ccca6bee.d.ts} +2 -1
  133. package/keycodes/index.d.ts +2 -1
  134. package/layout/index.d.ts +2 -1
  135. package/{list-key-manager.d-72e9a2e7.d.ts → list-key-manager.d-6b8e8454.d.ts} +2 -1
  136. package/listbox/index.d.ts +5 -4
  137. package/menu/index.d.ts +14 -13
  138. package/{number-property.d-ce316715.d.ts → number-property.d-1067cb21.d.ts} +2 -1
  139. package/{observe-content.d-c08bc882.d.ts → observe-content.d-406532a1.d.ts} +1 -1
  140. package/observers/index.d.ts +2 -2
  141. package/overlay/index.d.ts +14 -13
  142. package/{overlay-module.d-46197115.d.ts → overlay-module.d-bb9fd227.d.ts} +13 -10
  143. package/package.json +1 -1
  144. package/platform/index.d.ts +2 -17
  145. package/portal/index.d.ts +2 -2
  146. package/{portal-directives.d-fefec9d6.d.ts → portal-directives.d-7048496c.d.ts} +2 -1
  147. package/private/index.d.ts +1 -1
  148. package/schematics/ng-add/index.js +1 -1
  149. package/scrolling/index.d.ts +5 -5
  150. package/{scrolling-module.d-e4f8e471.d.ts → scrolling-module.d-a309d6c8.d.ts} +5 -4
  151. package/{selection-model.d-1a70542c.d.ts → selection-model.d-8f93f170.d.ts} +2 -1
  152. package/stepper/index.d.ts +6 -5
  153. package/table/index.d.ts +9 -8
  154. package/testing/index.d.ts +3 -2
  155. package/testing/selenium-webdriver/index.d.ts +3 -2
  156. package/testing/testbed/index.d.ts +3 -2
  157. package/text-field/index.d.ts +3 -2
  158. package/tree/index.d.ts +5 -4
  159. package/{unique-selection-dispatcher.d-7993b9f5.d.ts → unique-selection-dispatcher.d-49e3cd5f.d.ts} +2 -1
  160. package/{view-repeater.d-79039e1f.d.ts → view-repeater.d-bf5e36f0.d.ts} +2 -1
  161. package/{viewport-ruler.d-f3d3e82f.d.ts → viewport-ruler.d-5b507354.d.ts} +2 -1
  162. package/fesm2022/a11y-module-b228dc71.mjs.map +0 -1
  163. package/fesm2022/activedescendant-key-manager-1351a9d3.mjs.map +0 -1
  164. package/fesm2022/array-88e1bec3.mjs.map +0 -1
  165. package/fesm2022/backwards-compatibility-bcbe473e.mjs +0 -25
  166. package/fesm2022/backwards-compatibility-bcbe473e.mjs.map +0 -1
  167. package/fesm2022/bidi-module-e73b8776.mjs.map +0 -1
  168. package/fesm2022/breakpoints-observer-9432a91b.mjs.map +0 -1
  169. package/fesm2022/css-pixel-value-447bbfe8.mjs.map +0 -1
  170. package/fesm2022/data-source-5320b6fd.mjs.map +0 -1
  171. package/fesm2022/directionality-ea6ab987.mjs.map +0 -1
  172. package/fesm2022/dispose-view-repeater-strategy-b11b87ea.mjs.map +0 -1
  173. package/fesm2022/element-08c51fcd.mjs.map +0 -1
  174. package/fesm2022/fake-event-detection-7055b1bd.mjs.map +0 -1
  175. package/fesm2022/focus-key-manager-58d29acd.mjs.map +0 -1
  176. package/fesm2022/focus-monitor-69f9c0f9.mjs.map +0 -1
  177. package/fesm2022/id-generator-ec45a122.mjs.map +0 -1
  178. package/fesm2022/keycodes-107cd3e4.mjs.map +0 -1
  179. package/fesm2022/list-key-manager-c7b5cefb.mjs.map +0 -1
  180. package/fesm2022/modifiers-33a5859e.mjs.map +0 -1
  181. package/fesm2022/observable-97c0792c.mjs.map +0 -1
  182. package/fesm2022/observe-content-459e1d12.mjs.map +0 -1
  183. package/fesm2022/overlay-module-6e7b742f.mjs.map +0 -1
  184. package/fesm2022/passive-listeners-c0bdc49f.mjs.map +0 -1
  185. package/fesm2022/platform-2be6a529.mjs.map +0 -1
  186. package/fesm2022/portal-directives-9cd98881.mjs.map +0 -1
  187. package/fesm2022/recycle-view-repeater-strategy-c1712813.mjs.map +0 -1
  188. package/fesm2022/scrolling-61955dd1.mjs.map +0 -1
  189. package/fesm2022/scrolling-module-72941c9f.mjs.map +0 -1
  190. package/fesm2022/selection-model-30243dba.mjs.map +0 -1
  191. package/fesm2022/shadow-dom-9f403d00.mjs.map +0 -1
  192. package/fesm2022/style-loader-9fc0a4d2.mjs.map +0 -1
  193. package/fesm2022/test-environment-34eef1ee.mjs.map +0 -1
  194. package/fesm2022/text-filtering-0c6de6d6.mjs.map +0 -1
  195. package/fesm2022/tree-key-manager-2f20c79c.mjs.map +0 -1
  196. package/fesm2022/typeahead-11ae39bd.mjs.map +0 -1
  197. package/fesm2022/unique-selection-dispatcher-d0d5176e.mjs.map +0 -1
  198. package/fesm2022/visually-hidden-a6df546a.mjs.map +0 -1
  199. /package/{platform.d-0a5b4792.d.ts → platform.d-54a48c5c.d.ts} +0 -0
  200. /package/{style-loader.d-19baab84.d.ts → style-loader.d-a4916e34.d.ts} +0 -0
  201. /package/{tree-key-manager-strategy.d-603161dd.d.ts → tree-key-manager-strategy.d-e1a4bb7c.d.ts} +0 -0
@@ -10,4 +10,4 @@ function hasModifierKey(event, ...modifiers) {
10
10
  }
11
11
 
12
12
  export { hasModifierKey as h };
13
- //# sourceMappingURL=modifiers-33a5859e.mjs.map
13
+ //# sourceMappingURL=modifiers-68a3bc3a.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"modifiers-68a3bc3a.mjs","sources":["../../../../../darwin_arm64-fastbuild-ST-46c76129e412/bin/src/cdk/keycodes/modifiers.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\nexport type ModifierKey = 'altKey' | 'shiftKey' | 'ctrlKey' | 'metaKey';\n\n/**\n * Checks whether a modifier key is pressed.\n * @param event Event to be checked.\n */\nexport function hasModifierKey(event: KeyboardEvent, ...modifiers: ModifierKey[]): boolean {\n if (modifiers.length) {\n return modifiers.some(modifier => event[modifier]);\n }\n\n return event.altKey || event.shiftKey || event.ctrlKey || event.metaKey;\n}\n"],"names":[],"mappings":"AAUA;;;AAGG;SACa,cAAc,CAAC,KAAoB,EAAE,GAAG,SAAwB,EAAA;AAC9E,IAAA,IAAI,SAAS,CAAC,MAAM,EAAE;AACpB,QAAA,OAAO,SAAS,CAAC,IAAI,CAAC,QAAQ,IAAI,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAA;KACpD;AAEA,IAAA,OAAO,KAAK,CAAC,MAAM,IAAI,KAAK,CAAC,QAAQ,IAAI,KAAK,CAAC,OAAO,IAAI,KAAK,CAAC,OAAO,CAAA;AACzE;;;;"}
@@ -12,4 +12,4 @@ function coerceObservable(data) {
12
12
  }
13
13
 
14
14
  export { coerceObservable as c };
15
- //# sourceMappingURL=observable-97c0792c.mjs.map
15
+ //# sourceMappingURL=observable-36bb5527.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"observable-36bb5527.mjs","sources":["../../../../../darwin_arm64-fastbuild-ST-46c76129e412/bin/src/cdk/coercion/private/observable.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 */\nimport {Observable, isObservable, of as observableOf} from 'rxjs';\n\n/**\n * Given either an Observable or non-Observable value, returns either the original\n * Observable, or wraps it in an Observable that emits the non-Observable value.\n */\nexport function coerceObservable<T>(data: T | Observable<T>): Observable<T> {\n if (!isObservable(data)) {\n return observableOf(data);\n }\n return data;\n}\n"],"names":["observableOf"],"mappings":";;AASA;;;AAGG;AACG,SAAU,gBAAgB,CAAI,IAAuB,EAAA;AACzD,IAAA,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,EAAE;AACvB,QAAA,OAAOA,EAAY,CAAC,IAAI,CAAC,CAAA;KAC3B;AACA,IAAA,OAAO,IAAI,CAAA;AACb;;;;"}
@@ -2,7 +2,7 @@ import * as i0 from '@angular/core';
2
2
  import { Injectable, inject, NgZone, ElementRef, EventEmitter, booleanAttribute, Directive, Output, Input, NgModule } from '@angular/core';
3
3
  import { Observable, Subject } from 'rxjs';
4
4
  import { map, filter, debounceTime } from 'rxjs/operators';
5
- import { a as coerceNumberProperty, c as coerceElement } from './element-08c51fcd.mjs';
5
+ import { a as coerceNumberProperty, c as coerceElement } from './element-bed495ef.mjs';
6
6
 
7
7
  // Angular may add, remove, or edit comment nodes during change detection. We don't care about
8
8
  // these changes because they don't affect the user-preceived content, and worse it can cause
@@ -38,10 +38,10 @@ class MutationObserverFactory {
38
38
  create(callback) {
39
39
  return typeof MutationObserver === 'undefined' ? null : new MutationObserver(callback);
40
40
  }
41
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.0.0-next.3", ngImport: i0, type: MutationObserverFactory, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
42
- static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.0.0-next.3", ngImport: i0, type: MutationObserverFactory, providedIn: 'root' });
41
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.0.0-next.5", ngImport: i0, type: MutationObserverFactory, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
42
+ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.0.0-next.5", ngImport: i0, type: MutationObserverFactory, providedIn: 'root' });
43
43
  }
44
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.0.0-next.3", ngImport: i0, type: MutationObserverFactory, decorators: [{
44
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.0.0-next.5", ngImport: i0, type: MutationObserverFactory, decorators: [{
45
45
  type: Injectable,
46
46
  args: [{ providedIn: 'root' }]
47
47
  }] });
@@ -119,10 +119,10 @@ class ContentObserver {
119
119
  this._observedElements.delete(element);
120
120
  }
121
121
  }
122
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.0.0-next.3", ngImport: i0, type: ContentObserver, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
123
- static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.0.0-next.3", ngImport: i0, type: ContentObserver, providedIn: 'root' });
122
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.0.0-next.5", ngImport: i0, type: ContentObserver, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
123
+ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.0.0-next.5", ngImport: i0, type: ContentObserver, providedIn: 'root' });
124
124
  }
125
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.0.0-next.3", ngImport: i0, type: ContentObserver, decorators: [{
125
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.0.0-next.5", ngImport: i0, type: ContentObserver, decorators: [{
126
126
  type: Injectable,
127
127
  args: [{ providedIn: 'root' }]
128
128
  }], ctorParameters: () => [] });
@@ -174,10 +174,10 @@ class CdkObserveContent {
174
174
  _unsubscribe() {
175
175
  this._currentSubscription?.unsubscribe();
176
176
  }
177
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.0.0-next.3", ngImport: i0, type: CdkObserveContent, deps: [], target: i0.ɵɵFactoryTarget.Directive });
178
- static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "20.0.0-next.3", type: CdkObserveContent, isStandalone: true, selector: "[cdkObserveContent]", inputs: { disabled: ["cdkObserveContentDisabled", "disabled", booleanAttribute], debounce: "debounce" }, outputs: { event: "cdkObserveContent" }, exportAs: ["cdkObserveContent"], ngImport: i0 });
177
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.0.0-next.5", ngImport: i0, type: CdkObserveContent, deps: [], target: i0.ɵɵFactoryTarget.Directive });
178
+ static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "20.0.0-next.5", type: CdkObserveContent, isStandalone: true, selector: "[cdkObserveContent]", inputs: { disabled: ["cdkObserveContentDisabled", "disabled", booleanAttribute], debounce: "debounce" }, outputs: { event: "cdkObserveContent" }, exportAs: ["cdkObserveContent"], ngImport: i0 });
179
179
  }
180
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.0.0-next.3", ngImport: i0, type: CdkObserveContent, decorators: [{
180
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.0.0-next.5", ngImport: i0, type: CdkObserveContent, decorators: [{
181
181
  type: Directive,
182
182
  args: [{
183
183
  selector: '[cdkObserveContent]',
@@ -193,11 +193,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.0.0-next.3",
193
193
  type: Input
194
194
  }] } });
195
195
  class ObserversModule {
196
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.0.0-next.3", ngImport: i0, type: ObserversModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
197
- static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "20.0.0-next.3", ngImport: i0, type: ObserversModule, imports: [CdkObserveContent], exports: [CdkObserveContent] });
198
- static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "20.0.0-next.3", ngImport: i0, type: ObserversModule, providers: [MutationObserverFactory] });
196
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.0.0-next.5", ngImport: i0, type: ObserversModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
197
+ static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "20.0.0-next.5", ngImport: i0, type: ObserversModule, imports: [CdkObserveContent], exports: [CdkObserveContent] });
198
+ static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "20.0.0-next.5", ngImport: i0, type: ObserversModule, providers: [MutationObserverFactory] });
199
199
  }
200
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.0.0-next.3", ngImport: i0, type: ObserversModule, decorators: [{
200
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.0.0-next.5", ngImport: i0, type: ObserversModule, decorators: [{
201
201
  type: NgModule,
202
202
  args: [{
203
203
  imports: [CdkObserveContent],
@@ -207,4 +207,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.0.0-next.3",
207
207
  }] });
208
208
 
209
209
  export { ContentObserver as C, MutationObserverFactory as M, ObserversModule as O, CdkObserveContent as a };
210
- //# sourceMappingURL=observe-content-459e1d12.mjs.map
210
+ //# sourceMappingURL=observe-content-85983868.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"observe-content-85983868.mjs","sources":["../../../../../darwin_arm64-fastbuild-ST-46c76129e412/bin/src/cdk/observers/observe-content.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 {NumberInput, coerceElement, coerceNumberProperty} from '../coercion';\nimport {\n AfterContentInit,\n Directive,\n ElementRef,\n EventEmitter,\n Injectable,\n Input,\n NgModule,\n NgZone,\n OnDestroy,\n Output,\n booleanAttribute,\n inject,\n} from '@angular/core';\nimport {Observable, Observer, Subject, Subscription} from 'rxjs';\nimport {debounceTime, filter, map} from 'rxjs/operators';\n\n// Angular may add, remove, or edit comment nodes during change detection. We don't care about\n// these changes because they don't affect the user-preceived content, and worse it can cause\n// infinite change detection cycles where the change detection updates a comment, triggering the\n// MutationObserver, triggering another change detection and kicking the cycle off again.\nfunction shouldIgnoreRecord(record: MutationRecord) {\n // Ignore changes to comment text.\n if (record.type === 'characterData' && record.target instanceof Comment) {\n return true;\n }\n // Ignore addition / removal of comments.\n if (record.type === 'childList') {\n for (let i = 0; i < record.addedNodes.length; i++) {\n if (!(record.addedNodes[i] instanceof Comment)) {\n return false;\n }\n }\n for (let i = 0; i < record.removedNodes.length; i++) {\n if (!(record.removedNodes[i] instanceof Comment)) {\n return false;\n }\n }\n return true;\n }\n // Observe everything else.\n return false;\n}\n\n/**\n * Factory that creates a new MutationObserver and allows us to stub it out in unit tests.\n * @docs-private\n */\n@Injectable({providedIn: 'root'})\nexport class MutationObserverFactory {\n create(callback: MutationCallback): MutationObserver | null {\n return typeof MutationObserver === 'undefined' ? null : new MutationObserver(callback);\n }\n}\n\n/** An injectable service that allows watching elements for changes to their content. */\n@Injectable({providedIn: 'root'})\nexport class ContentObserver implements OnDestroy {\n private _mutationObserverFactory = inject(MutationObserverFactory);\n\n /** Keeps track of the existing MutationObservers so they can be reused. */\n private _observedElements = new Map<\n Element,\n {\n observer: MutationObserver | null;\n readonly stream: Subject<MutationRecord[]>;\n count: number;\n }\n >();\n\n private _ngZone = inject(NgZone);\n\n constructor(...args: unknown[]);\n constructor() {}\n\n ngOnDestroy() {\n this._observedElements.forEach((_, element) => this._cleanupObserver(element));\n }\n\n /**\n * Observe content changes on an element.\n * @param element The element to observe for content changes.\n */\n observe(element: Element): Observable<MutationRecord[]>;\n\n /**\n * Observe content changes on an element.\n * @param element The element to observe for content changes.\n */\n observe(element: ElementRef<Element>): Observable<MutationRecord[]>;\n\n observe(elementOrRef: Element | ElementRef<Element>): Observable<MutationRecord[]> {\n const element = coerceElement(elementOrRef);\n\n return new Observable((observer: Observer<MutationRecord[]>) => {\n const stream = this._observeElement(element);\n const subscription = stream\n .pipe(\n map(records => records.filter(record => !shouldIgnoreRecord(record))),\n filter(records => !!records.length),\n )\n .subscribe(records => {\n this._ngZone.run(() => {\n observer.next(records);\n });\n });\n\n return () => {\n subscription.unsubscribe();\n this._unobserveElement(element);\n };\n });\n }\n\n /**\n * Observes the given element by using the existing MutationObserver if available, or creating a\n * new one if not.\n */\n private _observeElement(element: Element): Subject<MutationRecord[]> {\n return this._ngZone.runOutsideAngular(() => {\n if (!this._observedElements.has(element)) {\n const stream = new Subject<MutationRecord[]>();\n const observer = this._mutationObserverFactory.create(mutations => stream.next(mutations));\n if (observer) {\n observer.observe(element, {\n characterData: true,\n childList: true,\n subtree: true,\n });\n }\n this._observedElements.set(element, {observer, stream, count: 1});\n } else {\n this._observedElements.get(element)!.count++;\n }\n return this._observedElements.get(element)!.stream;\n });\n }\n\n /**\n * Un-observes the given element and cleans up the underlying MutationObserver if nobody else is\n * observing this element.\n */\n private _unobserveElement(element: Element) {\n if (this._observedElements.has(element)) {\n this._observedElements.get(element)!.count--;\n if (!this._observedElements.get(element)!.count) {\n this._cleanupObserver(element);\n }\n }\n }\n\n /** Clean up the underlying MutationObserver for the specified element. */\n private _cleanupObserver(element: Element) {\n if (this._observedElements.has(element)) {\n const {observer, stream} = this._observedElements.get(element)!;\n if (observer) {\n observer.disconnect();\n }\n stream.complete();\n this._observedElements.delete(element);\n }\n }\n}\n\n/**\n * Directive that triggers a callback whenever the content of\n * its associated element has changed.\n */\n@Directive({\n selector: '[cdkObserveContent]',\n exportAs: 'cdkObserveContent',\n})\nexport class CdkObserveContent implements AfterContentInit, OnDestroy {\n private _contentObserver = inject(ContentObserver);\n private _elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n\n /** Event emitted for each change in the element's content. */\n @Output('cdkObserveContent') readonly event = new EventEmitter<MutationRecord[]>();\n\n /**\n * Whether observing content is disabled. This option can be used\n * to disconnect the underlying MutationObserver until it is needed.\n */\n @Input({alias: 'cdkObserveContentDisabled', transform: booleanAttribute})\n get disabled(): boolean {\n return this._disabled;\n }\n set disabled(value: boolean) {\n this._disabled = value;\n this._disabled ? this._unsubscribe() : this._subscribe();\n }\n private _disabled = false;\n\n /** Debounce interval for emitting the changes. */\n @Input()\n get debounce(): number {\n return this._debounce;\n }\n set debounce(value: NumberInput) {\n this._debounce = coerceNumberProperty(value);\n this._subscribe();\n }\n private _debounce: number;\n\n private _currentSubscription: Subscription | null = null;\n\n constructor(...args: unknown[]);\n constructor() {}\n\n ngAfterContentInit() {\n if (!this._currentSubscription && !this.disabled) {\n this._subscribe();\n }\n }\n\n ngOnDestroy() {\n this._unsubscribe();\n }\n\n private _subscribe() {\n this._unsubscribe();\n const stream = this._contentObserver.observe(this._elementRef);\n\n this._currentSubscription = (\n this.debounce ? stream.pipe(debounceTime(this.debounce)) : stream\n ).subscribe(this.event);\n }\n\n private _unsubscribe() {\n this._currentSubscription?.unsubscribe();\n }\n}\n\n@NgModule({\n imports: [CdkObserveContent],\n exports: [CdkObserveContent],\n providers: [MutationObserverFactory],\n})\nexport class ObserversModule {}\n"],"names":[],"mappings":"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"}
@@ -110,10 +110,10 @@ class SharedResizeObserver {
110
110
  }
111
111
  return this._observers.get(box).observe(target);
112
112
  }
113
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.0.0-next.3", ngImport: i0, type: SharedResizeObserver, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
114
- static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.0.0-next.3", ngImport: i0, type: SharedResizeObserver, providedIn: 'root' });
113
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.0.0-next.5", ngImport: i0, type: SharedResizeObserver, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
114
+ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.0.0-next.5", ngImport: i0, type: SharedResizeObserver, providedIn: 'root' });
115
115
  }
116
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.0.0-next.3", ngImport: i0, type: SharedResizeObserver, decorators: [{
116
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.0.0-next.5", ngImport: i0, type: SharedResizeObserver, decorators: [{
117
117
  type: Injectable,
118
118
  args: [{
119
119
  providedIn: 'root',
@@ -1 +1 @@
1
- {"version":3,"file":"private.mjs","sources":["../../../../../../../src/cdk/observers/private/shared-resize-observer.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 */\nimport {inject, Injectable, NgZone, OnDestroy, RendererFactory2} from '@angular/core';\nimport {Observable, Subject} from 'rxjs';\nimport {filter, shareReplay, takeUntil} from 'rxjs/operators';\n\n/**\n * Handler that logs \"ResizeObserver loop limit exceeded\" errors.\n * These errors are not shown in the Chrome console, so we log them to ensure developers are aware.\n * @param e The error\n */\nconst loopLimitExceededErrorHandler = (e: unknown) => {\n if (e instanceof ErrorEvent && e.message === 'ResizeObserver loop limit exceeded') {\n console.error(\n `${e.message}. This could indicate a performance issue with your app. See https://github.com/WICG/resize-observer/blob/master/explainer.md#error-handling`,\n );\n }\n};\n\n/**\n * A shared ResizeObserver to be used for a particular box type (content-box, border-box, or\n * device-pixel-content-box)\n */\nclass SingleBoxSharedResizeObserver {\n /** Stream that emits when the shared observer is destroyed. */\n private _destroyed = new Subject<void>();\n /** Stream of all events from the ResizeObserver. */\n private _resizeSubject = new Subject<ResizeObserverEntry[]>();\n /** ResizeObserver used to observe element resize events. */\n private _resizeObserver?: ResizeObserver;\n /** A map of elements to streams of their resize events. */\n private _elementObservables = new Map<Element, Observable<ResizeObserverEntry[]>>();\n\n constructor(\n /** The box type to observe for resizes. */\n private _box: ResizeObserverBoxOptions,\n ) {\n if (typeof ResizeObserver !== 'undefined') {\n this._resizeObserver = new ResizeObserver(entries => this._resizeSubject.next(entries));\n }\n }\n\n /**\n * Gets a stream of resize events for the given element.\n * @param target The element to observe.\n * @return The stream of resize events for the element.\n */\n observe(target: Element): Observable<ResizeObserverEntry[]> {\n if (!this._elementObservables.has(target)) {\n this._elementObservables.set(\n target,\n new Observable<ResizeObserverEntry[]>(observer => {\n const subscription = this._resizeSubject.subscribe(observer);\n this._resizeObserver?.observe(target, {box: this._box});\n return () => {\n this._resizeObserver?.unobserve(target);\n subscription.unsubscribe();\n this._elementObservables.delete(target);\n };\n }).pipe(\n filter(entries => entries.some(entry => entry.target === target)),\n // Share a replay of the last event so that subsequent calls to observe the same element\n // receive initial sizing info like the first one. Also enable ref counting so the\n // element will be automatically unobserved when there are no more subscriptions.\n shareReplay({bufferSize: 1, refCount: true}),\n takeUntil(this._destroyed),\n ),\n );\n }\n return this._elementObservables.get(target)!;\n }\n\n /** Destroys this instance. */\n destroy() {\n this._destroyed.next();\n this._destroyed.complete();\n this._resizeSubject.complete();\n this._elementObservables.clear();\n }\n}\n\n/**\n * Allows observing resize events on multiple elements using a shared set of ResizeObserver.\n * Sharing a ResizeObserver instance is recommended for better performance (see\n * https://github.com/WICG/resize-observer/issues/59).\n *\n * Rather than share a single `ResizeObserver`, this class creates one `ResizeObserver` per type\n * of observed box ('content-box', 'border-box', and 'device-pixel-content-box'). This avoids\n * later calls to `observe` with a different box type from influencing the events dispatched to\n * earlier calls.\n */\n@Injectable({\n providedIn: 'root',\n})\nexport class SharedResizeObserver implements OnDestroy {\n private _cleanupErrorListener: (() => void) | undefined;\n\n /** Map of box type to shared resize observer. */\n private _observers = new Map<ResizeObserverBoxOptions, SingleBoxSharedResizeObserver>();\n\n /** The Angular zone. */\n private _ngZone = inject(NgZone);\n\n constructor() {\n if (typeof ResizeObserver !== 'undefined' && (typeof ngDevMode === 'undefined' || ngDevMode)) {\n this._ngZone.runOutsideAngular(() => {\n const renderer = inject(RendererFactory2).createRenderer(null, null);\n this._cleanupErrorListener = renderer.listen(\n 'window',\n 'error',\n loopLimitExceededErrorHandler,\n );\n });\n }\n }\n\n ngOnDestroy() {\n for (const [, observer] of this._observers) {\n observer.destroy();\n }\n this._observers.clear();\n this._cleanupErrorListener?.();\n }\n\n /**\n * Gets a stream of resize events for the given target element and box type.\n * @param target The element to observe for resizes.\n * @param options Options to pass to the `ResizeObserver`\n * @return The stream of resize events for the element.\n */\n observe(target: Element, options?: ResizeObserverOptions): Observable<ResizeObserverEntry[]> {\n const box = options?.box || 'content-box';\n if (!this._observers.has(box)) {\n this._observers.set(box, new SingleBoxSharedResizeObserver(box));\n }\n return this._observers.get(box)!.observe(target);\n }\n}\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"private.mjs","sources":["../../../../../../darwin_arm64-fastbuild-ST-46c76129e412/bin/src/cdk/observers/private/shared-resize-observer.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 */\nimport {inject, Injectable, NgZone, OnDestroy, RendererFactory2} from '@angular/core';\nimport {Observable, Subject} from 'rxjs';\nimport {filter, shareReplay, takeUntil} from 'rxjs/operators';\n\n/**\n * Handler that logs \"ResizeObserver loop limit exceeded\" errors.\n * These errors are not shown in the Chrome console, so we log them to ensure developers are aware.\n * @param e The error\n */\nconst loopLimitExceededErrorHandler = (e: unknown) => {\n if (e instanceof ErrorEvent && e.message === 'ResizeObserver loop limit exceeded') {\n console.error(\n `${e.message}. This could indicate a performance issue with your app. See https://github.com/WICG/resize-observer/blob/master/explainer.md#error-handling`,\n );\n }\n};\n\n/**\n * A shared ResizeObserver to be used for a particular box type (content-box, border-box, or\n * device-pixel-content-box)\n */\nclass SingleBoxSharedResizeObserver {\n /** Stream that emits when the shared observer is destroyed. */\n private _destroyed = new Subject<void>();\n /** Stream of all events from the ResizeObserver. */\n private _resizeSubject = new Subject<ResizeObserverEntry[]>();\n /** ResizeObserver used to observe element resize events. */\n private _resizeObserver?: ResizeObserver;\n /** A map of elements to streams of their resize events. */\n private _elementObservables = new Map<Element, Observable<ResizeObserverEntry[]>>();\n\n constructor(\n /** The box type to observe for resizes. */\n private _box: ResizeObserverBoxOptions,\n ) {\n if (typeof ResizeObserver !== 'undefined') {\n this._resizeObserver = new ResizeObserver(entries => this._resizeSubject.next(entries));\n }\n }\n\n /**\n * Gets a stream of resize events for the given element.\n * @param target The element to observe.\n * @return The stream of resize events for the element.\n */\n observe(target: Element): Observable<ResizeObserverEntry[]> {\n if (!this._elementObservables.has(target)) {\n this._elementObservables.set(\n target,\n new Observable<ResizeObserverEntry[]>(observer => {\n const subscription = this._resizeSubject.subscribe(observer);\n this._resizeObserver?.observe(target, {box: this._box});\n return () => {\n this._resizeObserver?.unobserve(target);\n subscription.unsubscribe();\n this._elementObservables.delete(target);\n };\n }).pipe(\n filter(entries => entries.some(entry => entry.target === target)),\n // Share a replay of the last event so that subsequent calls to observe the same element\n // receive initial sizing info like the first one. Also enable ref counting so the\n // element will be automatically unobserved when there are no more subscriptions.\n shareReplay({bufferSize: 1, refCount: true}),\n takeUntil(this._destroyed),\n ),\n );\n }\n return this._elementObservables.get(target)!;\n }\n\n /** Destroys this instance. */\n destroy() {\n this._destroyed.next();\n this._destroyed.complete();\n this._resizeSubject.complete();\n this._elementObservables.clear();\n }\n}\n\n/**\n * Allows observing resize events on multiple elements using a shared set of ResizeObserver.\n * Sharing a ResizeObserver instance is recommended for better performance (see\n * https://github.com/WICG/resize-observer/issues/59).\n *\n * Rather than share a single `ResizeObserver`, this class creates one `ResizeObserver` per type\n * of observed box ('content-box', 'border-box', and 'device-pixel-content-box'). This avoids\n * later calls to `observe` with a different box type from influencing the events dispatched to\n * earlier calls.\n */\n@Injectable({\n providedIn: 'root',\n})\nexport class SharedResizeObserver implements OnDestroy {\n private _cleanupErrorListener: (() => void) | undefined;\n\n /** Map of box type to shared resize observer. */\n private _observers = new Map<ResizeObserverBoxOptions, SingleBoxSharedResizeObserver>();\n\n /** The Angular zone. */\n private _ngZone = inject(NgZone);\n\n constructor() {\n if (typeof ResizeObserver !== 'undefined' && (typeof ngDevMode === 'undefined' || ngDevMode)) {\n this._ngZone.runOutsideAngular(() => {\n const renderer = inject(RendererFactory2).createRenderer(null, null);\n this._cleanupErrorListener = renderer.listen(\n 'window',\n 'error',\n loopLimitExceededErrorHandler,\n );\n });\n }\n }\n\n ngOnDestroy() {\n for (const [, observer] of this._observers) {\n observer.destroy();\n }\n this._observers.clear();\n this._cleanupErrorListener?.();\n }\n\n /**\n * Gets a stream of resize events for the given target element and box type.\n * @param target The element to observe for resizes.\n * @param options Options to pass to the `ResizeObserver`\n * @return The stream of resize events for the element.\n */\n observe(target: Element, options?: ResizeObserverOptions): Observable<ResizeObserverEntry[]> {\n const box = options?.box || 'content-box';\n if (!this._observers.has(box)) {\n this._observers.set(box, new SingleBoxSharedResizeObserver(box));\n }\n return this._observers.get(box)!.observe(target);\n }\n}\n"],"names":[],"mappings":"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"}
@@ -1,6 +1,6 @@
1
- export { a as CdkObserveContent, C as ContentObserver, M as MutationObserverFactory, O as ObserversModule } from './observe-content-459e1d12.mjs';
1
+ export { a as CdkObserveContent, C as ContentObserver, M as MutationObserverFactory, O as ObserversModule } from './observe-content-85983868.mjs';
2
2
  import '@angular/core';
3
3
  import 'rxjs';
4
4
  import 'rxjs/operators';
5
- import './element-08c51fcd.mjs';
5
+ import './element-bed495ef.mjs';
6
6
  //# sourceMappingURL=observers.mjs.map
@@ -1,23 +1,22 @@
1
1
  import * as i0 from '@angular/core';
2
- import { inject, NgZone, Injectable, RendererFactory2, Component, ChangeDetectionStrategy, ViewEncapsulation, untracked, afterRender, afterNextRender, ElementRef, Injector, ANIMATION_MODULE_TYPE, EnvironmentInjector, ApplicationRef, InjectionToken, Directive, EventEmitter, TemplateRef, ViewContainerRef, booleanAttribute, Input, Output, NgModule } from '@angular/core';
2
+ import { inject, NgZone, Injectable, RendererFactory2, Component, ChangeDetectionStrategy, ViewEncapsulation, afterNextRender, ElementRef, Injector, ANIMATION_MODULE_TYPE, EnvironmentInjector, ApplicationRef, InjectionToken, Directive, EventEmitter, TemplateRef, ViewContainerRef, booleanAttribute, Input, Output, NgModule } from '@angular/core';
3
3
  import { DOCUMENT, Location } from '@angular/common';
4
- import { P as Platform } from './platform-2be6a529.mjs';
5
- import { _ as _bindEventWithOptions } from './backwards-compatibility-bcbe473e.mjs';
6
- import { _ as _getEventTarget } from './shadow-dom-9f403d00.mjs';
7
- import { _ as _isTestEnvironment } from './test-environment-34eef1ee.mjs';
8
- import { _ as _CdkPrivateStyleLoader } from './style-loader-9fc0a4d2.mjs';
9
- import { Subject, Subscription, merge } from 'rxjs';
10
- import { filter, takeUntil, takeWhile } from 'rxjs/operators';
11
- import { c as coerceCssPixelValue } from './css-pixel-value-447bbfe8.mjs';
12
- import { c as coerceArray } from './array-88e1bec3.mjs';
13
- import { S as ScrollDispatcher, V as ViewportRuler, a as ScrollingModule } from './scrolling-module-72941c9f.mjs';
14
- import { s as supportsScrollBehavior } from './scrolling-61955dd1.mjs';
15
- import { D as DomPortalOutlet, T as TemplatePortal, P as PortalModule } from './portal-directives-9cd98881.mjs';
16
- import { D as Directionality } from './directionality-ea6ab987.mjs';
17
- import { _ as _IdGenerator } from './id-generator-ec45a122.mjs';
18
- import { e as ESCAPE } from './keycodes-107cd3e4.mjs';
19
- import { h as hasModifierKey } from './modifiers-33a5859e.mjs';
20
- import { B as BidiModule } from './bidi-module-e73b8776.mjs';
4
+ import { P as Platform } from './platform-3b280dd2.mjs';
5
+ import { _ as _getEventTarget } from './shadow-dom-09da63d7.mjs';
6
+ import { _ as _isTestEnvironment } from './test-environment-75e095b5.mjs';
7
+ import { _ as _CdkPrivateStyleLoader } from './style-loader-f70e1cd6.mjs';
8
+ import { Subject, Subscription } from 'rxjs';
9
+ import { c as coerceCssPixelValue } from './css-pixel-value-5ab12b77.mjs';
10
+ import { c as coerceArray } from './array-88204b72.mjs';
11
+ import { S as ScrollDispatcher, V as ViewportRuler, a as ScrollingModule } from './scrolling-module-2ed090a6.mjs';
12
+ import { s as supportsScrollBehavior } from './scrolling-4b9e82b7.mjs';
13
+ import { filter, takeWhile } from 'rxjs/operators';
14
+ import { D as DomPortalOutlet, T as TemplatePortal, P as PortalModule } from './portal-directives-4da94e82.mjs';
15
+ import { D as Directionality } from './directionality-25132624.mjs';
16
+ import { _ as _IdGenerator } from './id-generator-dd03740e.mjs';
17
+ import { e as ESCAPE } from './keycodes-fbdb6e67.mjs';
18
+ import { h as hasModifierKey } from './modifiers-68a3bc3a.mjs';
19
+ import { B as BidiModule } from './bidi-module-93941905.mjs';
21
20
 
22
21
  const scrollBehaviorSupported = supportsScrollBehavior();
23
22
  /**
@@ -296,10 +295,10 @@ class ScrollStrategyOptions {
296
295
  * Allows debouncing the reposition calls.
297
296
  */
298
297
  reposition = (config) => new RepositionScrollStrategy(this._scrollDispatcher, this._viewportRuler, this._ngZone, config);
299
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.0.0-next.3", ngImport: i0, type: ScrollStrategyOptions, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
300
- static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.0.0-next.3", ngImport: i0, type: ScrollStrategyOptions, providedIn: 'root' });
298
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.0.0-next.5", ngImport: i0, type: ScrollStrategyOptions, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
299
+ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.0.0-next.5", ngImport: i0, type: ScrollStrategyOptions, providedIn: 'root' });
301
300
  }
302
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.0.0-next.3", ngImport: i0, type: ScrollStrategyOptions, decorators: [{
301
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.0.0-next.5", ngImport: i0, type: ScrollStrategyOptions, decorators: [{
303
302
  type: Injectable,
304
303
  args: [{ providedIn: 'root' }]
305
304
  }], ctorParameters: () => [] });
@@ -491,10 +490,10 @@ class BaseOverlayDispatcher {
491
490
  this.detach();
492
491
  }
493
492
  }
494
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.0.0-next.3", ngImport: i0, type: BaseOverlayDispatcher, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
495
- static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.0.0-next.3", ngImport: i0, type: BaseOverlayDispatcher, providedIn: 'root' });
493
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.0.0-next.5", ngImport: i0, type: BaseOverlayDispatcher, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
494
+ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.0.0-next.5", ngImport: i0, type: BaseOverlayDispatcher, providedIn: 'root' });
496
495
  }
497
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.0.0-next.3", ngImport: i0, type: BaseOverlayDispatcher, decorators: [{
496
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.0.0-next.5", ngImport: i0, type: BaseOverlayDispatcher, decorators: [{
498
497
  type: Injectable,
499
498
  args: [{ providedIn: 'root' }]
500
499
  }], ctorParameters: () => [] });
@@ -542,10 +541,10 @@ class OverlayKeyboardDispatcher extends BaseOverlayDispatcher {
542
541
  }
543
542
  }
544
543
  };
545
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.0.0-next.3", ngImport: i0, type: OverlayKeyboardDispatcher, deps: null, target: i0.ɵɵFactoryTarget.Injectable });
546
- static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.0.0-next.3", ngImport: i0, type: OverlayKeyboardDispatcher, providedIn: 'root' });
544
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.0.0-next.5", ngImport: i0, type: OverlayKeyboardDispatcher, deps: null, target: i0.ɵɵFactoryTarget.Injectable });
545
+ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.0.0-next.5", ngImport: i0, type: OverlayKeyboardDispatcher, providedIn: 'root' });
547
546
  }
548
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.0.0-next.3", ngImport: i0, type: OverlayKeyboardDispatcher, decorators: [{
547
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.0.0-next.5", ngImport: i0, type: OverlayKeyboardDispatcher, decorators: [{
549
548
  type: Injectable,
550
549
  args: [{ providedIn: 'root' }]
551
550
  }] });
@@ -575,11 +574,12 @@ class OverlayOutsideClickDispatcher extends BaseOverlayDispatcher {
575
574
  if (!this._isAttached) {
576
575
  const body = this._document.body;
577
576
  const eventOptions = { capture: true };
577
+ const renderer = this._renderer;
578
578
  this._cleanups = this._ngZone.runOutsideAngular(() => [
579
- _bindEventWithOptions(this._renderer, body, 'pointerdown', this._pointerDownListener, eventOptions),
580
- _bindEventWithOptions(this._renderer, body, 'click', this._clickListener, eventOptions),
581
- _bindEventWithOptions(this._renderer, body, 'auxclick', this._clickListener, eventOptions),
582
- _bindEventWithOptions(this._renderer, body, 'contextmenu', this._clickListener, eventOptions),
579
+ renderer.listen(body, 'pointerdown', this._pointerDownListener, eventOptions),
580
+ renderer.listen(body, 'click', this._clickListener, eventOptions),
581
+ renderer.listen(body, 'auxclick', this._clickListener, eventOptions),
582
+ renderer.listen(body, 'contextmenu', this._clickListener, eventOptions),
583
583
  ]);
584
584
  // click event is not fired on iOS. To make element "clickable" we are
585
585
  // setting the cursor to pointer
@@ -652,10 +652,10 @@ class OverlayOutsideClickDispatcher extends BaseOverlayDispatcher {
652
652
  }
653
653
  }
654
654
  };
655
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.0.0-next.3", ngImport: i0, type: OverlayOutsideClickDispatcher, deps: null, target: i0.ɵɵFactoryTarget.Injectable });
656
- static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.0.0-next.3", ngImport: i0, type: OverlayOutsideClickDispatcher, providedIn: 'root' });
655
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.0.0-next.5", ngImport: i0, type: OverlayOutsideClickDispatcher, deps: null, target: i0.ɵɵFactoryTarget.Injectable });
656
+ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.0.0-next.5", ngImport: i0, type: OverlayOutsideClickDispatcher, providedIn: 'root' });
657
657
  }
658
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.0.0-next.3", ngImport: i0, type: OverlayOutsideClickDispatcher, decorators: [{
658
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.0.0-next.5", ngImport: i0, type: OverlayOutsideClickDispatcher, decorators: [{
659
659
  type: Injectable,
660
660
  args: [{ providedIn: 'root' }]
661
661
  }] });
@@ -674,10 +674,10 @@ function containsPierceShadowDom(parent, child) {
674
674
  }
675
675
 
676
676
  class _CdkOverlayStyleLoader {
677
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.0.0-next.3", ngImport: i0, type: _CdkOverlayStyleLoader, deps: [], target: i0.ɵɵFactoryTarget.Component });
678
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "20.0.0-next.3", type: _CdkOverlayStyleLoader, isStandalone: true, selector: "ng-component", host: { attributes: { "cdk-overlay-style-loader": "" } }, ngImport: i0, template: '', isInline: true, styles: [".cdk-overlay-container,.cdk-global-overlay-wrapper{pointer-events:none;top:0;left:0;height:100%;width:100%}.cdk-overlay-container{position:fixed}@layer cdk-overlay{.cdk-overlay-container{z-index:1000}}.cdk-overlay-container:empty{display:none}.cdk-global-overlay-wrapper{display:flex;position:absolute}@layer cdk-overlay{.cdk-global-overlay-wrapper{z-index:1000}}.cdk-overlay-pane{position:absolute;pointer-events:auto;box-sizing:border-box;display:flex;max-width:100%;max-height:100%}@layer cdk-overlay{.cdk-overlay-pane{z-index:1000}}.cdk-overlay-backdrop{position:absolute;top:0;bottom:0;left:0;right:0;pointer-events:auto;-webkit-tap-highlight-color:rgba(0,0,0,0);opacity:0}@layer cdk-overlay{.cdk-overlay-backdrop{z-index:1000;transition:opacity 400ms cubic-bezier(0.25, 0.8, 0.25, 1)}}.cdk-overlay-backdrop-showing{opacity:1}@media(forced-colors: active){.cdk-overlay-backdrop-showing{opacity:.6}}@layer cdk-overlay{.cdk-overlay-dark-backdrop{background:rgba(0,0,0,.32)}}.cdk-overlay-transparent-backdrop{transition:visibility 1ms linear,opacity 1ms linear;visibility:hidden;opacity:1}.cdk-overlay-transparent-backdrop.cdk-overlay-backdrop-showing,.cdk-high-contrast-active .cdk-overlay-transparent-backdrop{opacity:0;visibility:visible}.cdk-overlay-backdrop-noop-animation{transition:none}.cdk-overlay-connected-position-bounding-box{position:absolute;display:flex;flex-direction:column;min-width:1px;min-height:1px}@layer cdk-overlay{.cdk-overlay-connected-position-bounding-box{z-index:1000}}.cdk-global-scrollblock{position:fixed;width:100%;overflow-y:scroll}"], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
677
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.0.0-next.5", ngImport: i0, type: _CdkOverlayStyleLoader, deps: [], target: i0.ɵɵFactoryTarget.Component });
678
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "20.0.0-next.5", type: _CdkOverlayStyleLoader, isStandalone: true, selector: "ng-component", host: { attributes: { "cdk-overlay-style-loader": "" } }, ngImport: i0, template: '', isInline: true, styles: [".cdk-overlay-container,.cdk-global-overlay-wrapper{pointer-events:none;top:0;left:0;height:100%;width:100%}.cdk-overlay-container{position:fixed}@layer cdk-overlay{.cdk-overlay-container{z-index:1000}}.cdk-overlay-container:empty{display:none}.cdk-global-overlay-wrapper{display:flex;position:absolute}@layer cdk-overlay{.cdk-global-overlay-wrapper{z-index:1000}}.cdk-overlay-pane{position:absolute;pointer-events:auto;box-sizing:border-box;display:flex;max-width:100%;max-height:100%}@layer cdk-overlay{.cdk-overlay-pane{z-index:1000}}.cdk-overlay-backdrop{position:absolute;top:0;bottom:0;left:0;right:0;pointer-events:auto;-webkit-tap-highlight-color:rgba(0,0,0,0);opacity:0}@layer cdk-overlay{.cdk-overlay-backdrop{z-index:1000;transition:opacity 400ms cubic-bezier(0.25, 0.8, 0.25, 1)}}.cdk-overlay-backdrop-showing{opacity:1}@media(forced-colors: active){.cdk-overlay-backdrop-showing{opacity:.6}}@layer cdk-overlay{.cdk-overlay-dark-backdrop{background:rgba(0,0,0,.32)}}.cdk-overlay-transparent-backdrop{transition:visibility 1ms linear,opacity 1ms linear;visibility:hidden;opacity:1}.cdk-overlay-transparent-backdrop.cdk-overlay-backdrop-showing,.cdk-high-contrast-active .cdk-overlay-transparent-backdrop{opacity:0;visibility:visible}.cdk-overlay-backdrop-noop-animation{transition:none}.cdk-overlay-connected-position-bounding-box{position:absolute;display:flex;flex-direction:column;min-width:1px;min-height:1px}@layer cdk-overlay{.cdk-overlay-connected-position-bounding-box{z-index:1000}}.cdk-global-scrollblock{position:fixed;width:100%;overflow-y:scroll}"], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
679
679
  }
680
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.0.0-next.3", ngImport: i0, type: _CdkOverlayStyleLoader, decorators: [{
680
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.0.0-next.5", ngImport: i0, type: _CdkOverlayStyleLoader, decorators: [{
681
681
  type: Component,
682
682
  args: [{ template: '', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, host: { 'cdk-overlay-style-loader': '' }, styles: [".cdk-overlay-container,.cdk-global-overlay-wrapper{pointer-events:none;top:0;left:0;height:100%;width:100%}.cdk-overlay-container{position:fixed}@layer cdk-overlay{.cdk-overlay-container{z-index:1000}}.cdk-overlay-container:empty{display:none}.cdk-global-overlay-wrapper{display:flex;position:absolute}@layer cdk-overlay{.cdk-global-overlay-wrapper{z-index:1000}}.cdk-overlay-pane{position:absolute;pointer-events:auto;box-sizing:border-box;display:flex;max-width:100%;max-height:100%}@layer cdk-overlay{.cdk-overlay-pane{z-index:1000}}.cdk-overlay-backdrop{position:absolute;top:0;bottom:0;left:0;right:0;pointer-events:auto;-webkit-tap-highlight-color:rgba(0,0,0,0);opacity:0}@layer cdk-overlay{.cdk-overlay-backdrop{z-index:1000;transition:opacity 400ms cubic-bezier(0.25, 0.8, 0.25, 1)}}.cdk-overlay-backdrop-showing{opacity:1}@media(forced-colors: active){.cdk-overlay-backdrop-showing{opacity:.6}}@layer cdk-overlay{.cdk-overlay-dark-backdrop{background:rgba(0,0,0,.32)}}.cdk-overlay-transparent-backdrop{transition:visibility 1ms linear,opacity 1ms linear;visibility:hidden;opacity:1}.cdk-overlay-transparent-backdrop.cdk-overlay-backdrop-showing,.cdk-high-contrast-active .cdk-overlay-transparent-backdrop{opacity:0;visibility:visible}.cdk-overlay-backdrop-noop-animation{transition:none}.cdk-overlay-connected-position-bounding-box{position:absolute;display:flex;flex-direction:column;min-width:1px;min-height:1px}@layer cdk-overlay{.cdk-overlay-connected-position-bounding-box{z-index:1000}}.cdk-global-scrollblock{position:fixed;width:100%;overflow-y:scroll}"] }]
683
683
  }] });
@@ -745,10 +745,10 @@ class OverlayContainer {
745
745
  _loadStyles() {
746
746
  this._styleLoader.load(_CdkOverlayStyleLoader);
747
747
  }
748
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.0.0-next.3", ngImport: i0, type: OverlayContainer, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
749
- static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.0.0-next.3", ngImport: i0, type: OverlayContainer, providedIn: 'root' });
748
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.0.0-next.5", ngImport: i0, type: OverlayContainer, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
749
+ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.0.0-next.5", ngImport: i0, type: OverlayContainer, providedIn: 'root' });
750
750
  }
751
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.0.0-next.3", ngImport: i0, type: OverlayContainer, decorators: [{
751
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.0.0-next.5", ngImport: i0, type: OverlayContainer, decorators: [{
752
752
  type: Injectable,
753
753
  args: [{ providedIn: 'root' }]
754
754
  }], ctorParameters: () => [] });
@@ -814,6 +814,8 @@ class OverlayRef {
814
814
  _scrollStrategy;
815
815
  _locationChanges = Subscription.EMPTY;
816
816
  _backdropRef = null;
817
+ _detachContentMutationObserver;
818
+ _detachContentAfterRenderRef;
817
819
  /**
818
820
  * Reference to the parent of the `_host` at the time it was detached. Used to restore
819
821
  * the `_host` to its original position in the DOM when it gets re-attached.
@@ -823,8 +825,6 @@ class OverlayRef {
823
825
  _keydownEvents = new Subject();
824
826
  /** Stream of mouse outside events dispatched to this overlay. */
825
827
  _outsidePointerEvents = new Subject();
826
- _renders = new Subject();
827
- _afterRenderRef;
828
828
  /** Reference to the currently-running `afterNextRender` call. */
829
829
  _afterNextRenderRef;
830
830
  constructor(_portalOutlet, _host, _pane, _config, _ngZone, _keyboardDispatcher, _document, _location, _outsideClickDispatcher, _animationsDisabled = false, _injector, _renderer) {
@@ -845,12 +845,6 @@ class OverlayRef {
845
845
  this._scrollStrategy.attach(this);
846
846
  }
847
847
  this._positionStrategy = _config.positionStrategy;
848
- // Users could open the overlay from an `effect`, in which case we need to
849
- // run the `afterRender` as `untracked`. We don't recommend that users do
850
- // this, but we also don't want to break users who are doing it.
851
- this._afterRenderRef = untracked(() => afterRender(() => {
852
- this._renders.next();
853
- }, { injector: this._injector }));
854
848
  }
855
849
  /** The overlay's HTML element */
856
850
  get overlayElement() {
@@ -913,6 +907,7 @@ class OverlayRef {
913
907
  }
914
908
  // Only emit the `attachments` event once all other setup is done.
915
909
  this._attachments.next();
910
+ this._completeDetachContent();
916
911
  // Track this overlay by the keyboard dispatcher
917
912
  this._keyboardDispatcher.add(this);
918
913
  if (this._config.disposeOnNavigation) {
@@ -961,6 +956,7 @@ class OverlayRef {
961
956
  const detachmentResult = this._portalOutlet.detach();
962
957
  // Only emit after everything is detached.
963
958
  this._detachments.next();
959
+ this._completeDetachContent();
964
960
  // Remove this overlay from keyboard dispatcher tracking.
965
961
  this._keyboardDispatcher.remove(this);
966
962
  // Keeping the host element in the DOM can cause scroll jank, because it still gets
@@ -993,8 +989,7 @@ class OverlayRef {
993
989
  this._detachments.next();
994
990
  }
995
991
  this._detachments.complete();
996
- this._afterRenderRef.destroy();
997
- this._renders.complete();
992
+ this._completeDetachContent();
998
993
  }
999
994
  /** Whether the overlay has attached content. */
1000
995
  hasAttached() {
@@ -1164,32 +1159,54 @@ class OverlayRef {
1164
1159
  isAdd ? element.classList.add(...classes) : element.classList.remove(...classes);
1165
1160
  }
1166
1161
  }
1167
- /** Detaches the overlay content next time the zone stabilizes. */
1162
+ /** Detaches the overlay once the content finishes animating and is removed from the DOM. */
1168
1163
  _detachContentWhenEmpty() {
1169
- // Normally we wouldn't have to explicitly run this outside the `NgZone`, however
1170
- // if the consumer is using `zone-patch-rxjs`, the `Subscription.unsubscribe` call will
1171
- // be patched to run inside the zone, which will throw us into an infinite loop.
1172
- this._ngZone.runOutsideAngular(() => {
1173
- // We can't remove the host here immediately, because the overlay pane's content
1174
- // might still be animating. This stream helps us avoid interrupting the animation
1175
- // by waiting for the pane to become empty.
1176
- const subscription = this._renders
1177
- .pipe(takeUntil(merge(this._attachments, this._detachments)))
1178
- .subscribe(() => {
1179
- // Needs a couple of checks for the pane and host, because
1180
- // they may have been removed by the time the zone stabilizes.
1181
- if (!this._pane || !this._host || this._pane.children.length === 0) {
1182
- if (this._pane && this._config.panelClass) {
1183
- this._toggleClasses(this._pane, this._config.panelClass, false);
1184
- }
1185
- if (this._host && this._host.parentElement) {
1186
- this._previousHostParent = this._host.parentElement;
1187
- this._host.remove();
1188
- }
1189
- subscription.unsubscribe();
1190
- }
1164
+ let rethrow = false;
1165
+ // Attempt to detach on the next render.
1166
+ try {
1167
+ this._detachContentAfterRenderRef = afterNextRender(() => {
1168
+ // Rethrow if we encounter an actual error detaching.
1169
+ rethrow = true;
1170
+ this._detachContent();
1171
+ }, {
1172
+ injector: this._injector,
1191
1173
  });
1192
- });
1174
+ }
1175
+ catch (e) {
1176
+ if (rethrow) {
1177
+ throw e;
1178
+ }
1179
+ // afterNextRender throws if the EnvironmentInjector is has already been destroyed.
1180
+ // This may happen in tests that don't properly flush all async work.
1181
+ // In order to avoid breaking those tests, we just detach immediately in this case.
1182
+ this._detachContent();
1183
+ }
1184
+ // Otherwise wait until the content finishes animating out and detach.
1185
+ if (globalThis.MutationObserver && this._pane) {
1186
+ this._detachContentMutationObserver ||= new globalThis.MutationObserver(() => {
1187
+ this._detachContent();
1188
+ });
1189
+ this._detachContentMutationObserver.observe(this._pane, { childList: true });
1190
+ }
1191
+ }
1192
+ _detachContent() {
1193
+ // Needs a couple of checks for the pane and host, because
1194
+ // they may have been removed by the time the zone stabilizes.
1195
+ if (!this._pane || !this._host || this._pane.children.length === 0) {
1196
+ if (this._pane && this._config.panelClass) {
1197
+ this._toggleClasses(this._pane, this._config.panelClass, false);
1198
+ }
1199
+ if (this._host && this._host.parentElement) {
1200
+ this._previousHostParent = this._host.parentElement;
1201
+ this._host.remove();
1202
+ }
1203
+ this._completeDetachContent();
1204
+ }
1205
+ }
1206
+ _completeDetachContent() {
1207
+ this._detachContentAfterRenderRef?.destroy();
1208
+ this._detachContentAfterRenderRef = undefined;
1209
+ this._detachContentMutationObserver?.disconnect();
1193
1210
  }
1194
1211
  /** Disposes of a scroll strategy. */
1195
1212
  _disposeScrollStrategy() {
@@ -2474,10 +2491,10 @@ class OverlayPositionBuilder {
2474
2491
  flexibleConnectedTo(origin) {
2475
2492
  return new FlexibleConnectedPositionStrategy(origin, this._viewportRuler, this._document, this._platform, this._overlayContainer);
2476
2493
  }
2477
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.0.0-next.3", ngImport: i0, type: OverlayPositionBuilder, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
2478
- static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.0.0-next.3", ngImport: i0, type: OverlayPositionBuilder, providedIn: 'root' });
2494
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.0.0-next.5", ngImport: i0, type: OverlayPositionBuilder, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
2495
+ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.0.0-next.5", ngImport: i0, type: OverlayPositionBuilder, providedIn: 'root' });
2479
2496
  }
2480
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.0.0-next.3", ngImport: i0, type: OverlayPositionBuilder, decorators: [{
2497
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.0.0-next.5", ngImport: i0, type: OverlayPositionBuilder, decorators: [{
2481
2498
  type: Injectable,
2482
2499
  args: [{ providedIn: 'root' }]
2483
2500
  }], ctorParameters: () => [] });
@@ -2565,10 +2582,10 @@ class Overlay {
2565
2582
  }
2566
2583
  return new DomPortalOutlet(pane, this._appRef, this._injector);
2567
2584
  }
2568
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.0.0-next.3", ngImport: i0, type: Overlay, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
2569
- static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.0.0-next.3", ngImport: i0, type: Overlay, providedIn: 'root' });
2585
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.0.0-next.5", ngImport: i0, type: Overlay, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
2586
+ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.0.0-next.5", ngImport: i0, type: Overlay, providedIn: 'root' });
2570
2587
  }
2571
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.0.0-next.3", ngImport: i0, type: Overlay, decorators: [{
2588
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.0.0-next.5", ngImport: i0, type: Overlay, decorators: [{
2572
2589
  type: Injectable,
2573
2590
  args: [{ providedIn: 'root' }]
2574
2591
  }], ctorParameters: () => [] });
@@ -2615,10 +2632,10 @@ const CDK_CONNECTED_OVERLAY_SCROLL_STRATEGY = new InjectionToken('cdk-connected-
2615
2632
  class CdkOverlayOrigin {
2616
2633
  elementRef = inject(ElementRef);
2617
2634
  constructor() { }
2618
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.0.0-next.3", ngImport: i0, type: CdkOverlayOrigin, deps: [], target: i0.ɵɵFactoryTarget.Directive });
2619
- static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "20.0.0-next.3", type: CdkOverlayOrigin, isStandalone: true, selector: "[cdk-overlay-origin], [overlay-origin], [cdkOverlayOrigin]", exportAs: ["cdkOverlayOrigin"], ngImport: i0 });
2635
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.0.0-next.5", ngImport: i0, type: CdkOverlayOrigin, deps: [], target: i0.ɵɵFactoryTarget.Directive });
2636
+ static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "20.0.0-next.5", type: CdkOverlayOrigin, isStandalone: true, selector: "[cdk-overlay-origin], [overlay-origin], [cdkOverlayOrigin]", exportAs: ["cdkOverlayOrigin"], ngImport: i0 });
2620
2637
  }
2621
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.0.0-next.3", ngImport: i0, type: CdkOverlayOrigin, decorators: [{
2638
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.0.0-next.5", ngImport: i0, type: CdkOverlayOrigin, decorators: [{
2622
2639
  type: Directive,
2623
2640
  args: [{
2624
2641
  selector: '[cdk-overlay-origin], [overlay-origin], [cdkOverlayOrigin]',
@@ -2906,10 +2923,10 @@ class CdkConnectedOverlay {
2906
2923
  this._positionSubscription.unsubscribe();
2907
2924
  this.open = false;
2908
2925
  }
2909
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.0.0-next.3", ngImport: i0, type: CdkConnectedOverlay, deps: [], target: i0.ɵɵFactoryTarget.Directive });
2910
- static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "20.0.0-next.3", type: CdkConnectedOverlay, isStandalone: true, selector: "[cdk-connected-overlay], [connected-overlay], [cdkConnectedOverlay]", inputs: { origin: ["cdkConnectedOverlayOrigin", "origin"], positions: ["cdkConnectedOverlayPositions", "positions"], positionStrategy: ["cdkConnectedOverlayPositionStrategy", "positionStrategy"], offsetX: ["cdkConnectedOverlayOffsetX", "offsetX"], offsetY: ["cdkConnectedOverlayOffsetY", "offsetY"], width: ["cdkConnectedOverlayWidth", "width"], height: ["cdkConnectedOverlayHeight", "height"], minWidth: ["cdkConnectedOverlayMinWidth", "minWidth"], minHeight: ["cdkConnectedOverlayMinHeight", "minHeight"], backdropClass: ["cdkConnectedOverlayBackdropClass", "backdropClass"], panelClass: ["cdkConnectedOverlayPanelClass", "panelClass"], viewportMargin: ["cdkConnectedOverlayViewportMargin", "viewportMargin"], scrollStrategy: ["cdkConnectedOverlayScrollStrategy", "scrollStrategy"], open: ["cdkConnectedOverlayOpen", "open"], disableClose: ["cdkConnectedOverlayDisableClose", "disableClose"], transformOriginSelector: ["cdkConnectedOverlayTransformOriginOn", "transformOriginSelector"], hasBackdrop: ["cdkConnectedOverlayHasBackdrop", "hasBackdrop", booleanAttribute], lockPosition: ["cdkConnectedOverlayLockPosition", "lockPosition", booleanAttribute], flexibleDimensions: ["cdkConnectedOverlayFlexibleDimensions", "flexibleDimensions", booleanAttribute], growAfterOpen: ["cdkConnectedOverlayGrowAfterOpen", "growAfterOpen", booleanAttribute], push: ["cdkConnectedOverlayPush", "push", booleanAttribute], disposeOnNavigation: ["cdkConnectedOverlayDisposeOnNavigation", "disposeOnNavigation", booleanAttribute] }, outputs: { backdropClick: "backdropClick", positionChange: "positionChange", attach: "attach", detach: "detach", overlayKeydown: "overlayKeydown", overlayOutsideClick: "overlayOutsideClick" }, exportAs: ["cdkConnectedOverlay"], usesOnChanges: true, ngImport: i0 });
2926
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.0.0-next.5", ngImport: i0, type: CdkConnectedOverlay, deps: [], target: i0.ɵɵFactoryTarget.Directive });
2927
+ static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "20.0.0-next.5", type: CdkConnectedOverlay, isStandalone: true, selector: "[cdk-connected-overlay], [connected-overlay], [cdkConnectedOverlay]", inputs: { origin: ["cdkConnectedOverlayOrigin", "origin"], positions: ["cdkConnectedOverlayPositions", "positions"], positionStrategy: ["cdkConnectedOverlayPositionStrategy", "positionStrategy"], offsetX: ["cdkConnectedOverlayOffsetX", "offsetX"], offsetY: ["cdkConnectedOverlayOffsetY", "offsetY"], width: ["cdkConnectedOverlayWidth", "width"], height: ["cdkConnectedOverlayHeight", "height"], minWidth: ["cdkConnectedOverlayMinWidth", "minWidth"], minHeight: ["cdkConnectedOverlayMinHeight", "minHeight"], backdropClass: ["cdkConnectedOverlayBackdropClass", "backdropClass"], panelClass: ["cdkConnectedOverlayPanelClass", "panelClass"], viewportMargin: ["cdkConnectedOverlayViewportMargin", "viewportMargin"], scrollStrategy: ["cdkConnectedOverlayScrollStrategy", "scrollStrategy"], open: ["cdkConnectedOverlayOpen", "open"], disableClose: ["cdkConnectedOverlayDisableClose", "disableClose"], transformOriginSelector: ["cdkConnectedOverlayTransformOriginOn", "transformOriginSelector"], hasBackdrop: ["cdkConnectedOverlayHasBackdrop", "hasBackdrop", booleanAttribute], lockPosition: ["cdkConnectedOverlayLockPosition", "lockPosition", booleanAttribute], flexibleDimensions: ["cdkConnectedOverlayFlexibleDimensions", "flexibleDimensions", booleanAttribute], growAfterOpen: ["cdkConnectedOverlayGrowAfterOpen", "growAfterOpen", booleanAttribute], push: ["cdkConnectedOverlayPush", "push", booleanAttribute], disposeOnNavigation: ["cdkConnectedOverlayDisposeOnNavigation", "disposeOnNavigation", booleanAttribute] }, outputs: { backdropClick: "backdropClick", positionChange: "positionChange", attach: "attach", detach: "detach", overlayKeydown: "overlayKeydown", overlayOutsideClick: "overlayOutsideClick" }, exportAs: ["cdkConnectedOverlay"], usesOnChanges: true, ngImport: i0 });
2911
2928
  }
2912
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.0.0-next.3", ngImport: i0, type: CdkConnectedOverlay, decorators: [{
2929
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.0.0-next.5", ngImport: i0, type: CdkConnectedOverlay, decorators: [{
2913
2930
  type: Directive,
2914
2931
  args: [{
2915
2932
  selector: '[cdk-connected-overlay], [connected-overlay], [cdkConnectedOverlay]',
@@ -3014,11 +3031,11 @@ const CDK_CONNECTED_OVERLAY_SCROLL_STRATEGY_PROVIDER = {
3014
3031
  };
3015
3032
 
3016
3033
  class OverlayModule {
3017
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.0.0-next.3", ngImport: i0, type: OverlayModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
3018
- static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "20.0.0-next.3", ngImport: i0, type: OverlayModule, imports: [BidiModule, PortalModule, ScrollingModule, CdkConnectedOverlay, CdkOverlayOrigin], exports: [CdkConnectedOverlay, CdkOverlayOrigin, ScrollingModule] });
3019
- static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "20.0.0-next.3", ngImport: i0, type: OverlayModule, providers: [Overlay, CDK_CONNECTED_OVERLAY_SCROLL_STRATEGY_PROVIDER], imports: [BidiModule, PortalModule, ScrollingModule, ScrollingModule] });
3034
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.0.0-next.5", ngImport: i0, type: OverlayModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
3035
+ static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "20.0.0-next.5", ngImport: i0, type: OverlayModule, imports: [BidiModule, PortalModule, ScrollingModule, CdkConnectedOverlay, CdkOverlayOrigin], exports: [CdkConnectedOverlay, CdkOverlayOrigin, ScrollingModule] });
3036
+ static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "20.0.0-next.5", ngImport: i0, type: OverlayModule, providers: [Overlay, CDK_CONNECTED_OVERLAY_SCROLL_STRATEGY_PROVIDER], imports: [BidiModule, PortalModule, ScrollingModule, ScrollingModule] });
3020
3037
  }
3021
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.0.0-next.3", ngImport: i0, type: OverlayModule, decorators: [{
3038
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.0.0-next.5", ngImport: i0, type: OverlayModule, decorators: [{
3022
3039
  type: NgModule,
3023
3040
  args: [{
3024
3041
  imports: [BidiModule, PortalModule, ScrollingModule, CdkConnectedOverlay, CdkOverlayOrigin],
@@ -3028,4 +3045,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.0.0-next.3",
3028
3045
  }] });
3029
3046
 
3030
3047
  export { BlockScrollStrategy as B, CdkOverlayOrigin as C, FlexibleConnectedPositionStrategy as F, GlobalPositionStrategy as G, NoopScrollStrategy as N, OverlayRef as O, RepositionScrollStrategy as R, STANDARD_DROPDOWN_BELOW_POSITIONS as S, Overlay as a, OverlayContainer as b, OverlayConfig as c, OverlayModule as d, STANDARD_DROPDOWN_ADJACENT_POSITIONS as e, CdkConnectedOverlay as f, OverlayPositionBuilder as g, ConnectionPositionPair as h, ScrollingVisibility as i, ConnectedOverlayPositionChange as j, validateHorizontalPosition as k, ScrollStrategyOptions as l, CloseScrollStrategy as m, OverlayOutsideClickDispatcher as n, OverlayKeyboardDispatcher as o, validateVerticalPosition as v };
3031
- //# sourceMappingURL=overlay-module-6e7b742f.mjs.map
3048
+ //# sourceMappingURL=overlay-module-a2bddb9f.mjs.map