@angular/cdk 16.0.0-next.5 → 16.0.0-rc.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 (415) hide show
  1. package/{esm2020 → esm2022}/a11y/a11y-module.mjs +4 -4
  2. package/{esm2020 → esm2022}/a11y/aria-describer/aria-describer.mjs +3 -3
  3. package/{esm2020 → esm2022}/a11y/focus-monitor/focus-monitor.mjs +5 -5
  4. package/{esm2020 → esm2022}/a11y/focus-trap/configurable-focus-trap-factory.mjs +3 -3
  5. package/{esm2020 → esm2022}/a11y/focus-trap/focus-trap-manager.mjs +3 -3
  6. package/{esm2020 → esm2022}/a11y/focus-trap/focus-trap.mjs +5 -5
  7. package/{esm2020 → esm2022}/a11y/high-contrast-mode/high-contrast-mode-detector.mjs +3 -3
  8. package/{esm2020 → esm2022}/a11y/input-modality/input-modality-detector.mjs +3 -3
  9. package/{esm2020 → esm2022}/a11y/interactivity-checker/interactivity-checker.mjs +3 -3
  10. package/{esm2020 → esm2022}/a11y/live-announcer/live-announcer.mjs +5 -5
  11. package/{esm2020 → esm2022}/accordion/accordion-item.mjs +7 -7
  12. package/{esm2020 → esm2022}/accordion/accordion-module.mjs +4 -4
  13. package/{esm2020 → esm2022}/accordion/accordion.mjs +3 -3
  14. package/{esm2020 → esm2022}/bidi/bidi-module.mjs +4 -4
  15. package/{esm2020 → esm2022}/bidi/dir.mjs +3 -3
  16. package/{esm2020 → esm2022}/bidi/directionality.mjs +3 -3
  17. package/{esm2020 → esm2022}/clipboard/clipboard-module.mjs +4 -4
  18. package/{esm2020 → esm2022}/clipboard/clipboard.mjs +3 -3
  19. package/{esm2020 → esm2022}/clipboard/copy-to-clipboard.mjs +3 -3
  20. package/{esm2020 → esm2022}/collections/unique-selection-dispatcher.mjs +3 -3
  21. package/{esm2020 → esm2022}/dialog/dialog-container.mjs +3 -3
  22. package/{esm2020 → esm2022}/dialog/dialog-module.mjs +11 -11
  23. package/{esm2020 → esm2022}/dialog/dialog.mjs +3 -3
  24. package/{esm2020 → esm2022}/drag-drop/directives/drag-handle.mjs +3 -3
  25. package/{esm2020 → esm2022}/drag-drop/directives/drag-placeholder.mjs +3 -3
  26. package/{esm2020 → esm2022}/drag-drop/directives/drag-preview.mjs +3 -3
  27. package/esm2022/drag-drop/directives/drag.mjs +489 -0
  28. package/{esm2020 → esm2022}/drag-drop/directives/drop-list-group.mjs +3 -3
  29. package/esm2022/drag-drop/directives/drop-list.mjs +348 -0
  30. package/{esm2020 → esm2022}/drag-drop/drag-drop-module.mjs +14 -14
  31. package/{esm2020 → esm2022}/drag-drop/drag-drop-registry.mjs +3 -3
  32. package/{esm2020 → esm2022}/drag-drop/drag-drop.mjs +3 -3
  33. package/{esm2020 → esm2022}/layout/breakpoints-observer.mjs +3 -3
  34. package/{esm2020 → esm2022}/layout/layout-module.mjs +4 -4
  35. package/esm2022/layout/media-matcher.mjs +95 -0
  36. package/{esm2020 → esm2022}/listbox/listbox-module.mjs +4 -4
  37. package/{esm2020 → esm2022}/listbox/listbox.mjs +11 -11
  38. package/{esm2020 → esm2022}/menu/context-menu-trigger.mjs +8 -8
  39. package/{esm2020 → esm2022}/menu/menu-aim.mjs +5 -5
  40. package/{esm2020 → esm2022}/menu/menu-bar.mjs +7 -7
  41. package/{esm2020 → esm2022}/menu/menu-base.mjs +3 -3
  42. package/{esm2020 → esm2022}/menu/menu-group.mjs +3 -3
  43. package/{esm2020 → esm2022}/menu/menu-item-checkbox.mjs +6 -6
  44. package/{esm2020 → esm2022}/menu/menu-item-radio.mjs +6 -6
  45. package/{esm2020 → esm2022}/menu/menu-item-selectable.mjs +3 -3
  46. package/{esm2020 → esm2022}/menu/menu-item.mjs +3 -3
  47. package/{esm2020 → esm2022}/menu/menu-module.mjs +20 -20
  48. package/{esm2020 → esm2022}/menu/menu-stack.mjs +3 -3
  49. package/{esm2020 → esm2022}/menu/menu-trigger-base.mjs +3 -3
  50. package/{esm2020 → esm2022}/menu/menu-trigger.mjs +6 -6
  51. package/{esm2020 → esm2022}/menu/menu.mjs +7 -7
  52. package/{esm2020 → esm2022}/observers/observe-content.mjs +10 -10
  53. package/{esm2020 → esm2022}/overlay/dispatchers/base-overlay-dispatcher.mjs +3 -3
  54. package/{esm2020 → esm2022}/overlay/dispatchers/overlay-keyboard-dispatcher.mjs +3 -3
  55. package/{esm2020 → esm2022}/overlay/dispatchers/overlay-outside-click-dispatcher.mjs +3 -3
  56. package/{esm2020 → esm2022}/overlay/fullscreen-overlay-container.mjs +3 -3
  57. package/{esm2020 → esm2022}/overlay/overlay-container.mjs +3 -3
  58. package/{esm2020 → esm2022}/overlay/overlay-directives.mjs +5 -5
  59. package/{esm2020 → esm2022}/overlay/overlay-module.mjs +4 -4
  60. package/{esm2020 → esm2022}/overlay/overlay.mjs +3 -3
  61. package/{esm2020 → esm2022}/overlay/position/overlay-position-builder.mjs +3 -3
  62. package/{esm2020 → esm2022}/overlay/scroll/scroll-strategy-options.mjs +3 -3
  63. package/{esm2020 → esm2022}/platform/platform-module.mjs +4 -4
  64. package/{esm2020 → esm2022}/platform/platform.mjs +3 -3
  65. package/esm2022/portal/portal-directives.mjs +250 -0
  66. package/{esm2020 → esm2022}/scrolling/fixed-size-virtual-scroll.mjs +9 -9
  67. package/{esm2020 → esm2022}/scrolling/scroll-dispatcher.mjs +3 -3
  68. package/{esm2020 → esm2022}/scrolling/scrollable.mjs +3 -3
  69. package/{esm2020 → esm2022}/scrolling/scrolling-module.mjs +17 -17
  70. package/{esm2020 → esm2022}/scrolling/viewport-ruler.mjs +3 -3
  71. package/{esm2020 → esm2022}/scrolling/virtual-for-of.mjs +3 -3
  72. package/{esm2020 → esm2022}/scrolling/virtual-scroll-viewport.mjs +9 -9
  73. package/{esm2020 → esm2022}/scrolling/virtual-scrollable-element.mjs +3 -3
  74. package/{esm2020 → esm2022}/scrolling/virtual-scrollable-window.mjs +3 -3
  75. package/{esm2020 → esm2022}/scrolling/virtual-scrollable.mjs +3 -3
  76. package/{esm2020 → esm2022}/stepper/step-header.mjs +3 -3
  77. package/{esm2020 → esm2022}/stepper/step-label.mjs +3 -3
  78. package/{esm2020 → esm2022}/stepper/stepper-button.mjs +5 -5
  79. package/{esm2020 → esm2022}/stepper/stepper-module.mjs +9 -9
  80. package/{esm2020 → esm2022}/stepper/stepper.mjs +5 -5
  81. package/{esm2020 → esm2022}/table/cell.mjs +15 -15
  82. package/{esm2020 → esm2022}/table/coalesced-style-scheduler.mjs +3 -3
  83. package/esm2022/table/row.mjs +271 -0
  84. package/{esm2020 → esm2022}/table/table-module.mjs +46 -46
  85. package/{esm2020 → esm2022}/table/table.mjs +19 -19
  86. package/{esm2020 → esm2022}/table/text-column.mjs +5 -5
  87. package/{esm2020 → esm2022}/text-field/autofill.mjs +5 -5
  88. package/{esm2020 → esm2022}/text-field/autosize.mjs +3 -3
  89. package/{esm2020 → esm2022}/text-field/text-field-module.mjs +4 -4
  90. package/{esm2020 → esm2022}/tree/nested-node.mjs +6 -6
  91. package/{esm2020 → esm2022}/tree/node.mjs +3 -3
  92. package/{esm2020 → esm2022}/tree/outlet.mjs +3 -3
  93. package/{esm2020 → esm2022}/tree/padding.mjs +3 -3
  94. package/{esm2020 → esm2022}/tree/toggle.mjs +3 -3
  95. package/{esm2020 → esm2022}/tree/tree-module.mjs +16 -16
  96. package/esm2022/tree/tree.mjs +349 -0
  97. package/{esm2020 → esm2022}/version.mjs +1 -1
  98. package/{fesm2020 → fesm2022}/a11y.mjs +27 -27
  99. package/{fesm2020 → fesm2022}/a11y.mjs.map +1 -1
  100. package/{fesm2020 → fesm2022}/accordion.mjs +11 -11
  101. package/{fesm2020 → fesm2022}/accordion.mjs.map +1 -1
  102. package/{fesm2020 → fesm2022}/bidi.mjs +7 -7
  103. package/{fesm2020 → fesm2022}/bidi.mjs.map +1 -1
  104. package/{fesm2015 → fesm2022}/cdk.mjs +1 -1
  105. package/{fesm2015 → fesm2022}/cdk.mjs.map +1 -1
  106. package/{fesm2020 → fesm2022}/clipboard.mjs +7 -7
  107. package/{fesm2020 → fesm2022}/clipboard.mjs.map +1 -1
  108. package/{fesm2020 → fesm2022}/collections.mjs +2 -2
  109. package/{fesm2020 → fesm2022}/collections.mjs.map +1 -1
  110. package/{fesm2020 → fesm2022}/dialog.mjs +14 -14
  111. package/{fesm2020 → fesm2022}/dialog.mjs.map +1 -1
  112. package/{fesm2020 → fesm2022}/drag-drop.mjs +36 -36
  113. package/{fesm2020 → fesm2022}/drag-drop.mjs.map +1 -1
  114. package/{fesm2015 → fesm2022}/layout.mjs +21 -12
  115. package/fesm2022/layout.mjs.map +1 -0
  116. package/{fesm2020 → fesm2022}/listbox.mjs +13 -13
  117. package/{fesm2020 → fesm2022}/listbox.mjs.map +1 -1
  118. package/{fesm2020 → fesm2022}/menu.mjs +69 -69
  119. package/{fesm2020 → fesm2022}/menu.mjs.map +1 -1
  120. package/{fesm2020 → fesm2022}/observers.mjs +9 -9
  121. package/{fesm2020 → fesm2022}/observers.mjs.map +1 -1
  122. package/{fesm2020 → fesm2022}/overlay.mjs +23 -23
  123. package/{fesm2020 → fesm2022}/overlay.mjs.map +1 -1
  124. package/{fesm2020 → fesm2022}/platform.mjs +5 -5
  125. package/{fesm2020 → fesm2022}/platform.mjs.map +1 -1
  126. package/{fesm2020 → fesm2022}/portal.mjs +21 -21
  127. package/{fesm2020 → fesm2022}/portal.mjs.map +1 -1
  128. package/{fesm2020 → fesm2022}/scrolling.mjs +46 -46
  129. package/{fesm2020 → fesm2022}/scrolling.mjs.map +1 -1
  130. package/{fesm2020 → fesm2022}/stepper.mjs +20 -20
  131. package/{fesm2020 → fesm2022}/stepper.mjs.map +1 -1
  132. package/{fesm2020 → fesm2022}/table.mjs +109 -109
  133. package/{fesm2020 → fesm2022}/table.mjs.map +1 -1
  134. package/{fesm2020 → fesm2022}/text-field.mjs +9 -9
  135. package/{fesm2020 → fesm2022}/text-field.mjs.map +1 -1
  136. package/{fesm2020 → fesm2022}/tree.mjs +37 -37
  137. package/{fesm2020 → fesm2022}/tree.mjs.map +1 -1
  138. package/layout/index.d.ts +3 -2
  139. package/package.json +77 -131
  140. package/schematics/ng-add/index.js +1 -1
  141. package/schematics/ng-add/index.mjs +1 -1
  142. package/schematics/ng-update/devkit-file-system.js +3 -2
  143. package/schematics/ng-update/devkit-file-system.mjs +3 -2
  144. package/schematics/ng-update/migrations/attribute-selectors.js +5 -8
  145. package/schematics/ng-update/migrations/attribute-selectors.mjs +5 -8
  146. package/schematics/ng-update/migrations/class-inheritance.js +8 -11
  147. package/schematics/ng-update/migrations/class-inheritance.mjs +8 -11
  148. package/schematics/ng-update/migrations/class-names.js +12 -15
  149. package/schematics/ng-update/migrations/class-names.mjs +12 -15
  150. package/schematics/ng-update/migrations/constructor-signature.js +7 -10
  151. package/schematics/ng-update/migrations/constructor-signature.mjs +7 -10
  152. package/schematics/ng-update/migrations/css-selectors.js +5 -8
  153. package/schematics/ng-update/migrations/css-selectors.mjs +5 -8
  154. package/schematics/ng-update/migrations/element-selectors.js +5 -8
  155. package/schematics/ng-update/migrations/element-selectors.mjs +5 -8
  156. package/schematics/ng-update/migrations/input-names.js +5 -8
  157. package/schematics/ng-update/migrations/input-names.mjs +5 -8
  158. package/schematics/ng-update/migrations/method-call-arguments.js +5 -8
  159. package/schematics/ng-update/migrations/method-call-arguments.mjs +5 -8
  160. package/schematics/ng-update/migrations/misc-template.js +3 -6
  161. package/schematics/ng-update/migrations/misc-template.mjs +3 -6
  162. package/schematics/ng-update/migrations/output-names.js +5 -8
  163. package/schematics/ng-update/migrations/output-names.mjs +5 -8
  164. package/schematics/ng-update/migrations/property-names.js +5 -8
  165. package/schematics/ng-update/migrations/property-names.mjs +5 -8
  166. package/schematics/ng-update/migrations/symbol-removal.js +5 -8
  167. package/schematics/ng-update/migrations/symbol-removal.mjs +5 -8
  168. package/schematics/update-tool/component-resource-collector.js +5 -3
  169. package/schematics/update-tool/component-resource-collector.mjs +5 -3
  170. package/schematics/update-tool/index.js +8 -2
  171. package/schematics/update-tool/index.mjs +8 -2
  172. package/schematics/update-tool/migration.js +10 -3
  173. package/schematics/update-tool/migration.mjs +10 -3
  174. package/schematics/update-tool/utils/virtual-host.js +3 -2
  175. package/schematics/update-tool/utils/virtual-host.mjs +3 -2
  176. package/esm2020/drag-drop/directives/drag.mjs +0 -489
  177. package/esm2020/drag-drop/directives/drop-list.mjs +0 -348
  178. package/esm2020/layout/media-matcher.mjs +0 -86
  179. package/esm2020/portal/portal-directives.mjs +0 -250
  180. package/esm2020/table/row.mjs +0 -271
  181. package/esm2020/tree/tree.mjs +0 -349
  182. package/fesm2015/a11y.mjs +0 -2409
  183. package/fesm2015/a11y.mjs.map +0 -1
  184. package/fesm2015/accordion.mjs +0 -238
  185. package/fesm2015/accordion.mjs.map +0 -1
  186. package/fesm2015/bidi.mjs +0 -150
  187. package/fesm2015/bidi.mjs.map +0 -1
  188. package/fesm2015/clipboard.mjs +0 -219
  189. package/fesm2015/clipboard.mjs.map +0 -1
  190. package/fesm2015/collections.mjs +0 -462
  191. package/fesm2015/collections.mjs.map +0 -1
  192. package/fesm2015/dialog.mjs +0 -749
  193. package/fesm2015/dialog.mjs.map +0 -1
  194. package/fesm2015/drag-drop.mjs +0 -3667
  195. package/fesm2015/drag-drop.mjs.map +0 -1
  196. package/fesm2015/layout.mjs.map +0 -1
  197. package/fesm2015/listbox.mjs +0 -888
  198. package/fesm2015/listbox.mjs.map +0 -1
  199. package/fesm2015/menu.mjs +0 -1876
  200. package/fesm2015/menu.mjs.map +0 -1
  201. package/fesm2015/observers.mjs +0 -188
  202. package/fesm2015/observers.mjs.map +0 -1
  203. package/fesm2015/overlay.mjs +0 -2998
  204. package/fesm2015/overlay.mjs.map +0 -1
  205. package/fesm2015/platform.mjs +0 -320
  206. package/fesm2015/platform.mjs.map +0 -1
  207. package/fesm2015/portal.mjs +0 -640
  208. package/fesm2015/portal.mjs.map +0 -1
  209. package/fesm2015/scrolling.mjs +0 -1515
  210. package/fesm2015/scrolling.mjs.map +0 -1
  211. package/fesm2015/stepper.mjs +0 -570
  212. package/fesm2015/stepper.mjs.map +0 -1
  213. package/fesm2015/table.mjs +0 -2271
  214. package/fesm2015/table.mjs.map +0 -1
  215. package/fesm2015/testing/selenium-webdriver.mjs +0 -396
  216. package/fesm2015/testing/selenium-webdriver.mjs.map +0 -1
  217. package/fesm2015/testing/testbed.mjs +0 -811
  218. package/fesm2015/testing/testbed.mjs.map +0 -1
  219. package/fesm2015/testing.mjs +0 -748
  220. package/fesm2015/testing.mjs.map +0 -1
  221. package/fesm2015/text-field.mjs +0 -424
  222. package/fesm2015/text-field.mjs.map +0 -1
  223. package/fesm2015/tree.mjs +0 -871
  224. package/fesm2015/tree.mjs.map +0 -1
  225. package/fesm2020/cdk.mjs +0 -7
  226. package/fesm2020/cdk.mjs.map +0 -1
  227. package/fesm2020/coercion.mjs +0 -74
  228. package/fesm2020/coercion.mjs.map +0 -1
  229. package/fesm2020/keycodes.mjs +0 -137
  230. package/fesm2020/keycodes.mjs.map +0 -1
  231. package/fesm2020/layout.mjs +0 -210
  232. package/fesm2020/layout.mjs.map +0 -1
  233. /package/{esm2020 → esm2022}/a11y/a11y_public_index.mjs +0 -0
  234. /package/{esm2020 → esm2022}/a11y/aria-describer/aria-reference.mjs +0 -0
  235. /package/{esm2020 → esm2022}/a11y/fake-event-detection.mjs +0 -0
  236. /package/{esm2020 → esm2022}/a11y/focus-trap/configurable-focus-trap-config.mjs +0 -0
  237. /package/{esm2020 → esm2022}/a11y/focus-trap/configurable-focus-trap.mjs +0 -0
  238. /package/{esm2020 → esm2022}/a11y/focus-trap/event-listener-inert-strategy.mjs +0 -0
  239. /package/{esm2020 → esm2022}/a11y/focus-trap/focus-trap-inert-strategy.mjs +0 -0
  240. /package/{esm2020 → esm2022}/a11y/index.mjs +0 -0
  241. /package/{esm2020 → esm2022}/a11y/key-manager/activedescendant-key-manager.mjs +0 -0
  242. /package/{esm2020 → esm2022}/a11y/key-manager/focus-key-manager.mjs +0 -0
  243. /package/{esm2020 → esm2022}/a11y/key-manager/list-key-manager.mjs +0 -0
  244. /package/{esm2020 → esm2022}/a11y/live-announcer/live-announcer-tokens.mjs +0 -0
  245. /package/{esm2020 → esm2022}/a11y/public-api.mjs +0 -0
  246. /package/{esm2020 → esm2022}/accordion/accordion_public_index.mjs +0 -0
  247. /package/{esm2020 → esm2022}/accordion/index.mjs +0 -0
  248. /package/{esm2020 → esm2022}/accordion/public-api.mjs +0 -0
  249. /package/{esm2020 → esm2022}/bidi/bidi_public_index.mjs +0 -0
  250. /package/{esm2020 → esm2022}/bidi/dir-document-token.mjs +0 -0
  251. /package/{esm2020 → esm2022}/bidi/index.mjs +0 -0
  252. /package/{esm2020 → esm2022}/bidi/public-api.mjs +0 -0
  253. /package/{esm2020 → esm2022}/clipboard/clipboard_public_index.mjs +0 -0
  254. /package/{esm2020 → esm2022}/clipboard/index.mjs +0 -0
  255. /package/{esm2020 → esm2022}/clipboard/pending-copy.mjs +0 -0
  256. /package/{esm2020 → esm2022}/clipboard/public-api.mjs +0 -0
  257. /package/{esm2020 → esm2022}/coercion/array.mjs +0 -0
  258. /package/{esm2020 → esm2022}/coercion/boolean-property.mjs +0 -0
  259. /package/{esm2020 → esm2022}/coercion/css-pixel-value.mjs +0 -0
  260. /package/{esm2020 → esm2022}/coercion/element.mjs +0 -0
  261. /package/{esm2020 → esm2022}/coercion/index.mjs +0 -0
  262. /package/{esm2020 → esm2022}/coercion/number-property.mjs +0 -0
  263. /package/{esm2020 → esm2022}/coercion/public-api.mjs +0 -0
  264. /package/{esm2020 → esm2022}/coercion/string-array.mjs +0 -0
  265. /package/{esm2020 → esm2022}/collections/array-data-source.mjs +0 -0
  266. /package/{esm2020 → esm2022}/collections/collection-viewer.mjs +0 -0
  267. /package/{esm2020 → esm2022}/collections/collections_public_index.mjs +0 -0
  268. /package/{esm2020 → esm2022}/collections/data-source.mjs +0 -0
  269. /package/{esm2020 → esm2022}/collections/dispose-view-repeater-strategy.mjs +0 -0
  270. /package/{esm2020 → esm2022}/collections/index.mjs +0 -0
  271. /package/{esm2020 → esm2022}/collections/public-api.mjs +0 -0
  272. /package/{esm2020 → esm2022}/collections/recycle-view-repeater-strategy.mjs +0 -0
  273. /package/{esm2020 → esm2022}/collections/selection-model.mjs +0 -0
  274. /package/{esm2020 → esm2022}/collections/tree-adapter.mjs +0 -0
  275. /package/{esm2020 → esm2022}/collections/view-repeater.mjs +0 -0
  276. /package/{esm2020 → esm2022}/dialog/dialog-config.mjs +0 -0
  277. /package/{esm2020 → esm2022}/dialog/dialog-injectors.mjs +0 -0
  278. /package/{esm2020 → esm2022}/dialog/dialog-ref.mjs +0 -0
  279. /package/{esm2020 → esm2022}/dialog/dialog_public_index.mjs +0 -0
  280. /package/{esm2020 → esm2022}/dialog/index.mjs +0 -0
  281. /package/{esm2020 → esm2022}/dialog/public-api.mjs +0 -0
  282. /package/{esm2020 → esm2022}/drag-drop/directives/assertions.mjs +0 -0
  283. /package/{esm2020 → esm2022}/drag-drop/directives/config.mjs +0 -0
  284. /package/{esm2020 → esm2022}/drag-drop/dom/client-rect.mjs +0 -0
  285. /package/{esm2020 → esm2022}/drag-drop/dom/clone-node.mjs +0 -0
  286. /package/{esm2020 → esm2022}/drag-drop/dom/parent-position-tracker.mjs +0 -0
  287. /package/{esm2020 → esm2022}/drag-drop/dom/styling.mjs +0 -0
  288. /package/{esm2020 → esm2022}/drag-drop/dom/transition-duration.mjs +0 -0
  289. /package/{esm2020 → esm2022}/drag-drop/drag-drop_public_index.mjs +0 -0
  290. /package/{esm2020 → esm2022}/drag-drop/drag-events.mjs +0 -0
  291. /package/{esm2020 → esm2022}/drag-drop/drag-parent.mjs +0 -0
  292. /package/{esm2020 → esm2022}/drag-drop/drag-ref.mjs +0 -0
  293. /package/{esm2020 → esm2022}/drag-drop/drag-utils.mjs +0 -0
  294. /package/{esm2020 → esm2022}/drag-drop/drop-list-ref.mjs +0 -0
  295. /package/{esm2020 → esm2022}/drag-drop/index.mjs +0 -0
  296. /package/{esm2020 → esm2022}/drag-drop/public-api.mjs +0 -0
  297. /package/{esm2020 → esm2022}/drag-drop/sorting/drop-list-sort-strategy.mjs +0 -0
  298. /package/{esm2020 → esm2022}/drag-drop/sorting/single-axis-sort-strategy.mjs +0 -0
  299. /package/{esm2020 → esm2022}/index.mjs +0 -0
  300. /package/{esm2020 → esm2022}/keycodes/index.mjs +0 -0
  301. /package/{esm2020 → esm2022}/keycodes/keycodes.mjs +0 -0
  302. /package/{esm2020 → esm2022}/keycodes/keycodes_public_index.mjs +0 -0
  303. /package/{esm2020 → esm2022}/keycodes/modifiers.mjs +0 -0
  304. /package/{esm2020 → esm2022}/keycodes/public-api.mjs +0 -0
  305. /package/{esm2020 → esm2022}/layout/breakpoints.mjs +0 -0
  306. /package/{esm2020 → esm2022}/layout/index.mjs +0 -0
  307. /package/{esm2020 → esm2022}/layout/layout_public_index.mjs +0 -0
  308. /package/{esm2020 → esm2022}/layout/public-api.mjs +0 -0
  309. /package/{esm2020 → esm2022}/listbox/index.mjs +0 -0
  310. /package/{esm2020 → esm2022}/listbox/listbox_public_index.mjs +0 -0
  311. /package/{esm2020 → esm2022}/listbox/public-api.mjs +0 -0
  312. /package/{esm2020 → esm2022}/menu/index.mjs +0 -0
  313. /package/{esm2020 → esm2022}/menu/menu-errors.mjs +0 -0
  314. /package/{esm2020 → esm2022}/menu/menu-interface.mjs +0 -0
  315. /package/{esm2020 → esm2022}/menu/menu_public_index.mjs +0 -0
  316. /package/{esm2020 → esm2022}/menu/pointer-focus-tracker.mjs +0 -0
  317. /package/{esm2020 → esm2022}/menu/public-api.mjs +0 -0
  318. /package/{esm2020 → esm2022}/observers/index.mjs +0 -0
  319. /package/{esm2020 → esm2022}/observers/observers_public_index.mjs +0 -0
  320. /package/{esm2020 → esm2022}/observers/public-api.mjs +0 -0
  321. /package/{esm2020 → esm2022}/overlay/dispatchers/index.mjs +0 -0
  322. /package/{esm2020 → esm2022}/overlay/index.mjs +0 -0
  323. /package/{esm2020 → esm2022}/overlay/overlay-config.mjs +0 -0
  324. /package/{esm2020 → esm2022}/overlay/overlay-ref.mjs +0 -0
  325. /package/{esm2020 → esm2022}/overlay/overlay-reference.mjs +0 -0
  326. /package/{esm2020 → esm2022}/overlay/overlay_public_index.mjs +0 -0
  327. /package/{esm2020 → esm2022}/overlay/position/connected-position.mjs +0 -0
  328. /package/{esm2020 → esm2022}/overlay/position/flexible-connected-position-strategy.mjs +0 -0
  329. /package/{esm2020 → esm2022}/overlay/position/global-position-strategy.mjs +0 -0
  330. /package/{esm2020 → esm2022}/overlay/position/position-strategy.mjs +0 -0
  331. /package/{esm2020 → esm2022}/overlay/position/scroll-clip.mjs +0 -0
  332. /package/{esm2020 → esm2022}/overlay/public-api.mjs +0 -0
  333. /package/{esm2020 → esm2022}/overlay/scroll/block-scroll-strategy.mjs +0 -0
  334. /package/{esm2020 → esm2022}/overlay/scroll/close-scroll-strategy.mjs +0 -0
  335. /package/{esm2020 → esm2022}/overlay/scroll/index.mjs +0 -0
  336. /package/{esm2020 → esm2022}/overlay/scroll/noop-scroll-strategy.mjs +0 -0
  337. /package/{esm2020 → esm2022}/overlay/scroll/reposition-scroll-strategy.mjs +0 -0
  338. /package/{esm2020 → esm2022}/overlay/scroll/scroll-strategy.mjs +0 -0
  339. /package/{esm2020 → esm2022}/platform/features/input-types.mjs +0 -0
  340. /package/{esm2020 → esm2022}/platform/features/passive-listeners.mjs +0 -0
  341. /package/{esm2020 → esm2022}/platform/features/scrolling.mjs +0 -0
  342. /package/{esm2020 → esm2022}/platform/features/shadow-dom.mjs +0 -0
  343. /package/{esm2020 → esm2022}/platform/features/test-environment.mjs +0 -0
  344. /package/{esm2020 → esm2022}/platform/index.mjs +0 -0
  345. /package/{esm2020 → esm2022}/platform/platform_public_index.mjs +0 -0
  346. /package/{esm2020 → esm2022}/platform/public-api.mjs +0 -0
  347. /package/{esm2020 → esm2022}/portal/dom-portal-outlet.mjs +0 -0
  348. /package/{esm2020 → esm2022}/portal/index.mjs +0 -0
  349. /package/{esm2020 → esm2022}/portal/portal-errors.mjs +0 -0
  350. /package/{esm2020 → esm2022}/portal/portal-injector.mjs +0 -0
  351. /package/{esm2020 → esm2022}/portal/portal.mjs +0 -0
  352. /package/{esm2020 → esm2022}/portal/portal_public_index.mjs +0 -0
  353. /package/{esm2020 → esm2022}/portal/public-api.mjs +0 -0
  354. /package/{esm2020 → esm2022}/public-api.mjs +0 -0
  355. /package/{esm2020 → esm2022}/scrolling/index.mjs +0 -0
  356. /package/{esm2020 → esm2022}/scrolling/public-api.mjs +0 -0
  357. /package/{esm2020 → esm2022}/scrolling/scrolling_public_index.mjs +0 -0
  358. /package/{esm2020 → esm2022}/scrolling/virtual-scroll-repeater.mjs +0 -0
  359. /package/{esm2020 → esm2022}/scrolling/virtual-scroll-strategy.mjs +0 -0
  360. /package/{esm2020 → esm2022}/stepper/index.mjs +0 -0
  361. /package/{esm2020 → esm2022}/stepper/public-api.mjs +0 -0
  362. /package/{esm2020 → esm2022}/stepper/stepper_public_index.mjs +0 -0
  363. /package/{esm2020 → esm2022}/table/can-stick.mjs +0 -0
  364. /package/{esm2020 → esm2022}/table/index.mjs +0 -0
  365. /package/{esm2020 → esm2022}/table/public-api.mjs +0 -0
  366. /package/{esm2020 → esm2022}/table/sticky-position-listener.mjs +0 -0
  367. /package/{esm2020 → esm2022}/table/sticky-styler.mjs +0 -0
  368. /package/{esm2020 → esm2022}/table/table-errors.mjs +0 -0
  369. /package/{esm2020 → esm2022}/table/table_public_index.mjs +0 -0
  370. /package/{esm2020 → esm2022}/table/tokens.mjs +0 -0
  371. /package/{esm2020 → esm2022}/testing/change-detection.mjs +0 -0
  372. /package/{esm2020 → esm2022}/testing/component-harness.mjs +0 -0
  373. /package/{esm2020 → esm2022}/testing/element-dimensions.mjs +0 -0
  374. /package/{esm2020 → esm2022}/testing/harness-environment.mjs +0 -0
  375. /package/{esm2020 → esm2022}/testing/index.mjs +0 -0
  376. /package/{esm2020 → esm2022}/testing/public-api.mjs +0 -0
  377. /package/{esm2020 → esm2022}/testing/selenium-webdriver/index.mjs +0 -0
  378. /package/{esm2020 → esm2022}/testing/selenium-webdriver/public-api.mjs +0 -0
  379. /package/{esm2020 → esm2022}/testing/selenium-webdriver/selenium-web-driver-element.mjs +0 -0
  380. /package/{esm2020 → esm2022}/testing/selenium-webdriver/selenium-web-driver-harness-environment.mjs +0 -0
  381. /package/{esm2020 → esm2022}/testing/selenium-webdriver/selenium-webdriver-keys.mjs +0 -0
  382. /package/{esm2020 → esm2022}/testing/test-element-errors.mjs +0 -0
  383. /package/{esm2020 → esm2022}/testing/test-element.mjs +0 -0
  384. /package/{esm2020 → esm2022}/testing/testbed/fake-events/dispatch-events.mjs +0 -0
  385. /package/{esm2020 → esm2022}/testing/testbed/fake-events/element-focus.mjs +0 -0
  386. /package/{esm2020 → esm2022}/testing/testbed/fake-events/event-objects.mjs +0 -0
  387. /package/{esm2020 → esm2022}/testing/testbed/fake-events/index.mjs +0 -0
  388. /package/{esm2020 → esm2022}/testing/testbed/fake-events/type-in-element.mjs +0 -0
  389. /package/{esm2020 → esm2022}/testing/testbed/index.mjs +0 -0
  390. /package/{esm2020 → esm2022}/testing/testbed/public-api.mjs +0 -0
  391. /package/{esm2020 → esm2022}/testing/testbed/task-state-zone-interceptor.mjs +0 -0
  392. /package/{esm2020 → esm2022}/testing/testbed/testbed-harness-environment.mjs +0 -0
  393. /package/{esm2020 → esm2022}/testing/testbed/unit-test-element.mjs +0 -0
  394. /package/{esm2020 → esm2022}/testing/text-filtering.mjs +0 -0
  395. /package/{esm2020 → esm2022}/text-field/index.mjs +0 -0
  396. /package/{esm2020 → esm2022}/text-field/public-api.mjs +0 -0
  397. /package/{esm2020 → esm2022}/text-field/text-field_public_index.mjs +0 -0
  398. /package/{esm2020 → esm2022}/tree/control/base-tree-control.mjs +0 -0
  399. /package/{esm2020 → esm2022}/tree/control/flat-tree-control.mjs +0 -0
  400. /package/{esm2020 → esm2022}/tree/control/nested-tree-control.mjs +0 -0
  401. /package/{esm2020 → esm2022}/tree/control/tree-control.mjs +0 -0
  402. /package/{esm2020 → esm2022}/tree/index.mjs +0 -0
  403. /package/{esm2020 → esm2022}/tree/public-api.mjs +0 -0
  404. /package/{esm2020 → esm2022}/tree/tree-errors.mjs +0 -0
  405. /package/{esm2020 → esm2022}/tree/tree_public_index.mjs +0 -0
  406. /package/{fesm2015 → fesm2022}/coercion.mjs +0 -0
  407. /package/{fesm2015 → fesm2022}/coercion.mjs.map +0 -0
  408. /package/{fesm2015 → fesm2022}/keycodes.mjs +0 -0
  409. /package/{fesm2015 → fesm2022}/keycodes.mjs.map +0 -0
  410. /package/{fesm2020 → fesm2022}/testing/selenium-webdriver.mjs +0 -0
  411. /package/{fesm2020 → fesm2022}/testing/selenium-webdriver.mjs.map +0 -0
  412. /package/{fesm2020 → fesm2022}/testing/testbed.mjs +0 -0
  413. /package/{fesm2020 → fesm2022}/testing/testbed.mjs.map +0 -0
  414. /package/{fesm2020 → fesm2022}/testing.mjs +0 -0
  415. /package/{fesm2020 → fesm2022}/testing.mjs.map +0 -0
package/fesm2015/tree.mjs DELETED
@@ -1,871 +0,0 @@
1
- import { SelectionModel, isDataSource } from '@angular/cdk/collections';
2
- import { isObservable, Subject, BehaviorSubject, of } from 'rxjs';
3
- import { take, filter, takeUntil } from 'rxjs/operators';
4
- import * as i0 from '@angular/core';
5
- import { InjectionToken, Directive, Inject, Optional, Component, ViewEncapsulation, ChangeDetectionStrategy, Input, ViewChild, ContentChildren, NgModule } from '@angular/core';
6
- import { coerceNumberProperty, coerceBooleanProperty } from '@angular/cdk/coercion';
7
- import * as i2 from '@angular/cdk/bidi';
8
-
9
- /** Base tree control. It has basic toggle/expand/collapse operations on a single data node. */
10
- class BaseTreeControl {
11
- constructor() {
12
- /** A selection model with multi-selection to track expansion status. */
13
- this.expansionModel = new SelectionModel(true);
14
- }
15
- /** Toggles one single data node's expanded/collapsed state. */
16
- toggle(dataNode) {
17
- this.expansionModel.toggle(this._trackByValue(dataNode));
18
- }
19
- /** Expands one single data node. */
20
- expand(dataNode) {
21
- this.expansionModel.select(this._trackByValue(dataNode));
22
- }
23
- /** Collapses one single data node. */
24
- collapse(dataNode) {
25
- this.expansionModel.deselect(this._trackByValue(dataNode));
26
- }
27
- /** Whether a given data node is expanded or not. Returns true if the data node is expanded. */
28
- isExpanded(dataNode) {
29
- return this.expansionModel.isSelected(this._trackByValue(dataNode));
30
- }
31
- /** Toggles a subtree rooted at `node` recursively. */
32
- toggleDescendants(dataNode) {
33
- this.expansionModel.isSelected(this._trackByValue(dataNode))
34
- ? this.collapseDescendants(dataNode)
35
- : this.expandDescendants(dataNode);
36
- }
37
- /** Collapse all dataNodes in the tree. */
38
- collapseAll() {
39
- this.expansionModel.clear();
40
- }
41
- /** Expands a subtree rooted at given data node recursively. */
42
- expandDescendants(dataNode) {
43
- let toBeProcessed = [dataNode];
44
- toBeProcessed.push(...this.getDescendants(dataNode));
45
- this.expansionModel.select(...toBeProcessed.map(value => this._trackByValue(value)));
46
- }
47
- /** Collapses a subtree rooted at given data node recursively. */
48
- collapseDescendants(dataNode) {
49
- let toBeProcessed = [dataNode];
50
- toBeProcessed.push(...this.getDescendants(dataNode));
51
- this.expansionModel.deselect(...toBeProcessed.map(value => this._trackByValue(value)));
52
- }
53
- _trackByValue(value) {
54
- return this.trackBy ? this.trackBy(value) : value;
55
- }
56
- }
57
-
58
- /** Flat tree control. Able to expand/collapse a subtree recursively for flattened tree. */
59
- class FlatTreeControl extends BaseTreeControl {
60
- /** Construct with flat tree data node functions getLevel and isExpandable. */
61
- constructor(getLevel, isExpandable, options) {
62
- super();
63
- this.getLevel = getLevel;
64
- this.isExpandable = isExpandable;
65
- this.options = options;
66
- if (this.options) {
67
- this.trackBy = this.options.trackBy;
68
- }
69
- }
70
- /**
71
- * Gets a list of the data node's subtree of descendent data nodes.
72
- *
73
- * To make this working, the `dataNodes` of the TreeControl must be flattened tree nodes
74
- * with correct levels.
75
- */
76
- getDescendants(dataNode) {
77
- const startIndex = this.dataNodes.indexOf(dataNode);
78
- const results = [];
79
- // Goes through flattened tree nodes in the `dataNodes` array, and get all descendants.
80
- // The level of descendants of a tree node must be greater than the level of the given
81
- // tree node.
82
- // If we reach a node whose level is equal to the level of the tree node, we hit a sibling.
83
- // If we reach a node whose level is greater than the level of the tree node, we hit a
84
- // sibling of an ancestor.
85
- for (let i = startIndex + 1; i < this.dataNodes.length && this.getLevel(dataNode) < this.getLevel(this.dataNodes[i]); i++) {
86
- results.push(this.dataNodes[i]);
87
- }
88
- return results;
89
- }
90
- /**
91
- * Expands all data nodes in the tree.
92
- *
93
- * To make this working, the `dataNodes` variable of the TreeControl must be set to all flattened
94
- * data nodes of the tree.
95
- */
96
- expandAll() {
97
- this.expansionModel.select(...this.dataNodes.map(node => this._trackByValue(node)));
98
- }
99
- }
100
-
101
- /** Nested tree control. Able to expand/collapse a subtree recursively for NestedNode type. */
102
- class NestedTreeControl extends BaseTreeControl {
103
- /** Construct with nested tree function getChildren. */
104
- constructor(getChildren, options) {
105
- super();
106
- this.getChildren = getChildren;
107
- this.options = options;
108
- if (this.options) {
109
- this.trackBy = this.options.trackBy;
110
- }
111
- }
112
- /**
113
- * Expands all dataNodes in the tree.
114
- *
115
- * To make this working, the `dataNodes` variable of the TreeControl must be set to all root level
116
- * data nodes of the tree.
117
- */
118
- expandAll() {
119
- this.expansionModel.clear();
120
- const allNodes = this.dataNodes.reduce((accumulator, dataNode) => [...accumulator, ...this.getDescendants(dataNode), dataNode], []);
121
- this.expansionModel.select(...allNodes.map(node => this._trackByValue(node)));
122
- }
123
- /** Gets a list of descendant dataNodes of a subtree rooted at given data node recursively. */
124
- getDescendants(dataNode) {
125
- const descendants = [];
126
- this._getDescendants(descendants, dataNode);
127
- // Remove the node itself
128
- return descendants.splice(1);
129
- }
130
- /** A helper function to get descendants recursively. */
131
- _getDescendants(descendants, dataNode) {
132
- descendants.push(dataNode);
133
- const childrenNodes = this.getChildren(dataNode);
134
- if (Array.isArray(childrenNodes)) {
135
- childrenNodes.forEach((child) => this._getDescendants(descendants, child));
136
- }
137
- else if (isObservable(childrenNodes)) {
138
- // TypeScript as of version 3.5 doesn't seem to treat `Boolean` like a function that
139
- // returns a `boolean` specifically in the context of `filter`, so we manually clarify that.
140
- childrenNodes.pipe(take(1), filter(Boolean)).subscribe(children => {
141
- for (const child of children) {
142
- this._getDescendants(descendants, child);
143
- }
144
- });
145
- }
146
- }
147
- }
148
-
149
- /**
150
- * Injection token used to provide a `CdkTreeNode` to its outlet.
151
- * Used primarily to avoid circular imports.
152
- * @docs-private
153
- */
154
- const CDK_TREE_NODE_OUTLET_NODE = new InjectionToken('CDK_TREE_NODE_OUTLET_NODE');
155
- /**
156
- * Outlet for nested CdkNode. Put `[cdkTreeNodeOutlet]` on a tag to place children dataNodes
157
- * inside the outlet.
158
- */
159
- class CdkTreeNodeOutlet {
160
- constructor(viewContainer, _node) {
161
- this.viewContainer = viewContainer;
162
- this._node = _node;
163
- }
164
- }
165
- CdkTreeNodeOutlet.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0-next.7", ngImport: i0, type: CdkTreeNodeOutlet, deps: [{ token: i0.ViewContainerRef }, { token: CDK_TREE_NODE_OUTLET_NODE, optional: true }], target: i0.ɵɵFactoryTarget.Directive });
166
- CdkTreeNodeOutlet.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.0-next.7", type: CdkTreeNodeOutlet, selector: "[cdkTreeNodeOutlet]", ngImport: i0 });
167
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0-next.7", ngImport: i0, type: CdkTreeNodeOutlet, decorators: [{
168
- type: Directive,
169
- args: [{
170
- selector: '[cdkTreeNodeOutlet]',
171
- }]
172
- }], ctorParameters: function () {
173
- return [{ type: i0.ViewContainerRef }, { type: undefined, decorators: [{
174
- type: Inject,
175
- args: [CDK_TREE_NODE_OUTLET_NODE]
176
- }, {
177
- type: Optional
178
- }] }];
179
- } });
180
-
181
- /** Context provided to the tree node component. */
182
- class CdkTreeNodeOutletContext {
183
- constructor(data) {
184
- this.$implicit = data;
185
- }
186
- }
187
- /**
188
- * Data node definition for the CdkTree.
189
- * Captures the node's template and a when predicate that describes when this node should be used.
190
- */
191
- class CdkTreeNodeDef {
192
- /** @docs-private */
193
- constructor(template) {
194
- this.template = template;
195
- }
196
- }
197
- CdkTreeNodeDef.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0-next.7", ngImport: i0, type: CdkTreeNodeDef, deps: [{ token: i0.TemplateRef }], target: i0.ɵɵFactoryTarget.Directive });
198
- CdkTreeNodeDef.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.0-next.7", type: CdkTreeNodeDef, selector: "[cdkTreeNodeDef]", inputs: { when: ["cdkTreeNodeDefWhen", "when"] }, ngImport: i0 });
199
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0-next.7", ngImport: i0, type: CdkTreeNodeDef, decorators: [{
200
- type: Directive,
201
- args: [{
202
- selector: '[cdkTreeNodeDef]',
203
- inputs: ['when: cdkTreeNodeDefWhen'],
204
- }]
205
- }], ctorParameters: function () { return [{ type: i0.TemplateRef }]; } });
206
-
207
- /**
208
- * Returns an error to be thrown when there is no usable data.
209
- * @docs-private
210
- */
211
- function getTreeNoValidDataSourceError() {
212
- return Error(`A valid data source must be provided.`);
213
- }
214
- /**
215
- * Returns an error to be thrown when there are multiple nodes that are missing a when function.
216
- * @docs-private
217
- */
218
- function getTreeMultipleDefaultNodeDefsError() {
219
- return Error(`There can only be one default row without a when predicate function.`);
220
- }
221
- /**
222
- * Returns an error to be thrown when there are no matching node defs for a particular set of data.
223
- * @docs-private
224
- */
225
- function getTreeMissingMatchingNodeDefError() {
226
- return Error(`Could not find a matching node definition for the provided node data.`);
227
- }
228
- /**
229
- * Returns an error to be thrown when there are tree control.
230
- * @docs-private
231
- */
232
- function getTreeControlMissingError() {
233
- return Error(`Could not find a tree control for the tree.`);
234
- }
235
- /**
236
- * Returns an error to be thrown when tree control did not implement functions for flat/nested node.
237
- * @docs-private
238
- */
239
- function getTreeControlFunctionsMissingError() {
240
- return Error(`Could not find functions for nested/flat tree in tree control.`);
241
- }
242
-
243
- /**
244
- * CDK tree component that connects with a data source to retrieve data of type `T` and renders
245
- * dataNodes with hierarchy. Updates the dataNodes when new data is provided by the data source.
246
- */
247
- class CdkTree {
248
- /**
249
- * Provides a stream containing the latest data array to render. Influenced by the tree's
250
- * stream of view window (what dataNodes are currently on screen).
251
- * Data source can be an observable of data array, or a data array to render.
252
- */
253
- get dataSource() {
254
- return this._dataSource;
255
- }
256
- set dataSource(dataSource) {
257
- if (this._dataSource !== dataSource) {
258
- this._switchDataSource(dataSource);
259
- }
260
- }
261
- constructor(_differs, _changeDetectorRef) {
262
- this._differs = _differs;
263
- this._changeDetectorRef = _changeDetectorRef;
264
- /** Subject that emits when the component has been destroyed. */
265
- this._onDestroy = new Subject();
266
- /** Level of nodes */
267
- this._levels = new Map();
268
- // TODO(tinayuangao): Setup a listener for scrolling, emit the calculated view to viewChange.
269
- // Remove the MAX_VALUE in viewChange
270
- /**
271
- * Stream containing the latest information on what rows are being displayed on screen.
272
- * Can be used by the data source to as a heuristic of what data should be provided.
273
- */
274
- this.viewChange = new BehaviorSubject({
275
- start: 0,
276
- end: Number.MAX_VALUE,
277
- });
278
- }
279
- ngOnInit() {
280
- this._dataDiffer = this._differs.find([]).create(this.trackBy);
281
- if (!this.treeControl && (typeof ngDevMode === 'undefined' || ngDevMode)) {
282
- throw getTreeControlMissingError();
283
- }
284
- }
285
- ngOnDestroy() {
286
- this._nodeOutlet.viewContainer.clear();
287
- this.viewChange.complete();
288
- this._onDestroy.next();
289
- this._onDestroy.complete();
290
- if (this._dataSource && typeof this._dataSource.disconnect === 'function') {
291
- this.dataSource.disconnect(this);
292
- }
293
- if (this._dataSubscription) {
294
- this._dataSubscription.unsubscribe();
295
- this._dataSubscription = null;
296
- }
297
- }
298
- ngAfterContentChecked() {
299
- const defaultNodeDefs = this._nodeDefs.filter(def => !def.when);
300
- if (defaultNodeDefs.length > 1 && (typeof ngDevMode === 'undefined' || ngDevMode)) {
301
- throw getTreeMultipleDefaultNodeDefsError();
302
- }
303
- this._defaultNodeDef = defaultNodeDefs[0];
304
- if (this.dataSource && this._nodeDefs && !this._dataSubscription) {
305
- this._observeRenderChanges();
306
- }
307
- }
308
- // TODO(tinayuangao): Work on keyboard traversal and actions, make sure it's working for RTL
309
- // and nested trees.
310
- /**
311
- * Switch to the provided data source by resetting the data and unsubscribing from the current
312
- * render change subscription if one exists. If the data source is null, interpret this by
313
- * clearing the node outlet. Otherwise start listening for new data.
314
- */
315
- _switchDataSource(dataSource) {
316
- if (this._dataSource && typeof this._dataSource.disconnect === 'function') {
317
- this.dataSource.disconnect(this);
318
- }
319
- if (this._dataSubscription) {
320
- this._dataSubscription.unsubscribe();
321
- this._dataSubscription = null;
322
- }
323
- // Remove the all dataNodes if there is now no data source
324
- if (!dataSource) {
325
- this._nodeOutlet.viewContainer.clear();
326
- }
327
- this._dataSource = dataSource;
328
- if (this._nodeDefs) {
329
- this._observeRenderChanges();
330
- }
331
- }
332
- /** Set up a subscription for the data provided by the data source. */
333
- _observeRenderChanges() {
334
- let dataStream;
335
- if (isDataSource(this._dataSource)) {
336
- dataStream = this._dataSource.connect(this);
337
- }
338
- else if (isObservable(this._dataSource)) {
339
- dataStream = this._dataSource;
340
- }
341
- else if (Array.isArray(this._dataSource)) {
342
- dataStream = of(this._dataSource);
343
- }
344
- if (dataStream) {
345
- this._dataSubscription = dataStream
346
- .pipe(takeUntil(this._onDestroy))
347
- .subscribe(data => this.renderNodeChanges(data));
348
- }
349
- else if (typeof ngDevMode === 'undefined' || ngDevMode) {
350
- throw getTreeNoValidDataSourceError();
351
- }
352
- }
353
- /** Check for changes made in the data and render each change (node added/removed/moved). */
354
- renderNodeChanges(data, dataDiffer = this._dataDiffer, viewContainer = this._nodeOutlet.viewContainer, parentData) {
355
- const changes = dataDiffer.diff(data);
356
- if (!changes) {
357
- return;
358
- }
359
- changes.forEachOperation((item, adjustedPreviousIndex, currentIndex) => {
360
- if (item.previousIndex == null) {
361
- this.insertNode(data[currentIndex], currentIndex, viewContainer, parentData);
362
- }
363
- else if (currentIndex == null) {
364
- viewContainer.remove(adjustedPreviousIndex);
365
- this._levels.delete(item.item);
366
- }
367
- else {
368
- const view = viewContainer.get(adjustedPreviousIndex);
369
- viewContainer.move(view, currentIndex);
370
- }
371
- });
372
- this._changeDetectorRef.detectChanges();
373
- }
374
- /**
375
- * Finds the matching node definition that should be used for this node data. If there is only
376
- * one node definition, it is returned. Otherwise, find the node definition that has a when
377
- * predicate that returns true with the data. If none return true, return the default node
378
- * definition.
379
- */
380
- _getNodeDef(data, i) {
381
- if (this._nodeDefs.length === 1) {
382
- return this._nodeDefs.first;
383
- }
384
- const nodeDef = this._nodeDefs.find(def => def.when && def.when(i, data)) || this._defaultNodeDef;
385
- if (!nodeDef && (typeof ngDevMode === 'undefined' || ngDevMode)) {
386
- throw getTreeMissingMatchingNodeDefError();
387
- }
388
- return nodeDef;
389
- }
390
- /**
391
- * Create the embedded view for the data node template and place it in the correct index location
392
- * within the data node view container.
393
- */
394
- insertNode(nodeData, index, viewContainer, parentData) {
395
- const node = this._getNodeDef(nodeData, index);
396
- // Node context that will be provided to created embedded view
397
- const context = new CdkTreeNodeOutletContext(nodeData);
398
- // If the tree is flat tree, then use the `getLevel` function in flat tree control
399
- // Otherwise, use the level of parent node.
400
- if (this.treeControl.getLevel) {
401
- context.level = this.treeControl.getLevel(nodeData);
402
- }
403
- else if (typeof parentData !== 'undefined' && this._levels.has(parentData)) {
404
- context.level = this._levels.get(parentData) + 1;
405
- }
406
- else {
407
- context.level = 0;
408
- }
409
- this._levels.set(nodeData, context.level);
410
- // Use default tree nodeOutlet, or nested node's nodeOutlet
411
- const container = viewContainer ? viewContainer : this._nodeOutlet.viewContainer;
412
- container.createEmbeddedView(node.template, context, index);
413
- // Set the data to just created `CdkTreeNode`.
414
- // The `CdkTreeNode` created from `createEmbeddedView` will be saved in static variable
415
- // `mostRecentTreeNode`. We get it from static variable and pass the node data to it.
416
- if (CdkTreeNode.mostRecentTreeNode) {
417
- CdkTreeNode.mostRecentTreeNode.data = nodeData;
418
- }
419
- }
420
- }
421
- CdkTree.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0-next.7", ngImport: i0, type: CdkTree, deps: [{ token: i0.IterableDiffers }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
422
- CdkTree.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.0-next.7", type: CdkTree, selector: "cdk-tree", inputs: { dataSource: "dataSource", treeControl: "treeControl", trackBy: "trackBy" }, host: { attributes: { "role": "tree" }, classAttribute: "cdk-tree" }, queries: [{ propertyName: "_nodeDefs", predicate: CdkTreeNodeDef, descendants: true }], viewQueries: [{ propertyName: "_nodeOutlet", first: true, predicate: CdkTreeNodeOutlet, descendants: true, static: true }], exportAs: ["cdkTree"], ngImport: i0, template: `<ng-container cdkTreeNodeOutlet></ng-container>`, isInline: true, dependencies: [{ kind: "directive", type: CdkTreeNodeOutlet, selector: "[cdkTreeNodeOutlet]" }], changeDetection: i0.ChangeDetectionStrategy.Default, encapsulation: i0.ViewEncapsulation.None });
423
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0-next.7", ngImport: i0, type: CdkTree, decorators: [{
424
- type: Component,
425
- args: [{
426
- selector: 'cdk-tree',
427
- exportAs: 'cdkTree',
428
- template: `<ng-container cdkTreeNodeOutlet></ng-container>`,
429
- host: {
430
- 'class': 'cdk-tree',
431
- 'role': 'tree',
432
- },
433
- encapsulation: ViewEncapsulation.None,
434
- // The "OnPush" status for the `CdkTree` component is effectively a noop, so we are removing it.
435
- // The view for `CdkTree` consists entirely of templates declared in other views. As they are
436
- // declared elsewhere, they are checked when their declaration points are checked.
437
- // tslint:disable-next-line:validate-decorators
438
- changeDetection: ChangeDetectionStrategy.Default,
439
- }]
440
- }], ctorParameters: function () { return [{ type: i0.IterableDiffers }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { dataSource: [{
441
- type: Input
442
- }], treeControl: [{
443
- type: Input
444
- }], trackBy: [{
445
- type: Input
446
- }], _nodeOutlet: [{
447
- type: ViewChild,
448
- args: [CdkTreeNodeOutlet, { static: true }]
449
- }], _nodeDefs: [{
450
- type: ContentChildren,
451
- args: [CdkTreeNodeDef, {
452
- // We need to use `descendants: true`, because Ivy will no longer match
453
- // indirect descendants if it's left as false.
454
- descendants: true,
455
- }]
456
- }] } });
457
- /**
458
- * Tree node for CdkTree. It contains the data in the tree node.
459
- */
460
- class CdkTreeNode {
461
- /**
462
- * The role of the tree node.
463
- * @deprecated The correct role is 'treeitem', 'group' should not be used. This input will be
464
- * removed in a future version.
465
- * @breaking-change 12.0.0 Remove this input
466
- */
467
- get role() {
468
- return 'treeitem';
469
- }
470
- set role(_role) {
471
- // TODO: move to host after View Engine deprecation
472
- this._elementRef.nativeElement.setAttribute('role', _role);
473
- }
474
- /** The tree node's data. */
475
- get data() {
476
- return this._data;
477
- }
478
- set data(value) {
479
- if (value !== this._data) {
480
- this._data = value;
481
- this._setRoleFromData();
482
- this._dataChanges.next();
483
- }
484
- }
485
- get isExpanded() {
486
- return this._tree.treeControl.isExpanded(this._data);
487
- }
488
- get level() {
489
- // If the treeControl has a getLevel method, use it to get the level. Otherwise read the
490
- // aria-level off the parent node and use it as the level for this node (note aria-level is
491
- // 1-indexed, while this property is 0-indexed, so we don't need to increment).
492
- return this._tree.treeControl.getLevel
493
- ? this._tree.treeControl.getLevel(this._data)
494
- : this._parentNodeAriaLevel;
495
- }
496
- constructor(_elementRef, _tree) {
497
- this._elementRef = _elementRef;
498
- this._tree = _tree;
499
- /** Subject that emits when the component has been destroyed. */
500
- this._destroyed = new Subject();
501
- /** Emits when the node's data has changed. */
502
- this._dataChanges = new Subject();
503
- CdkTreeNode.mostRecentTreeNode = this;
504
- this.role = 'treeitem';
505
- }
506
- ngOnInit() {
507
- this._parentNodeAriaLevel = getParentNodeAriaLevel(this._elementRef.nativeElement);
508
- this._elementRef.nativeElement.setAttribute('aria-level', `${this.level + 1}`);
509
- }
510
- ngOnDestroy() {
511
- // If this is the last tree node being destroyed,
512
- // clear out the reference to avoid leaking memory.
513
- if (CdkTreeNode.mostRecentTreeNode === this) {
514
- CdkTreeNode.mostRecentTreeNode = null;
515
- }
516
- this._dataChanges.complete();
517
- this._destroyed.next();
518
- this._destroyed.complete();
519
- }
520
- /** Focuses the menu item. Implements for FocusableOption. */
521
- focus() {
522
- this._elementRef.nativeElement.focus();
523
- }
524
- // TODO: role should eventually just be set in the component host
525
- _setRoleFromData() {
526
- if (!this._tree.treeControl.isExpandable &&
527
- !this._tree.treeControl.getChildren &&
528
- (typeof ngDevMode === 'undefined' || ngDevMode)) {
529
- throw getTreeControlFunctionsMissingError();
530
- }
531
- this.role = 'treeitem';
532
- }
533
- }
534
- /**
535
- * The most recently created `CdkTreeNode`. We save it in static variable so we can retrieve it
536
- * in `CdkTree` and set the data to it.
537
- */
538
- CdkTreeNode.mostRecentTreeNode = null;
539
- CdkTreeNode.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0-next.7", ngImport: i0, type: CdkTreeNode, deps: [{ token: i0.ElementRef }, { token: CdkTree }], target: i0.ɵɵFactoryTarget.Directive });
540
- CdkTreeNode.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.0-next.7", type: CdkTreeNode, selector: "cdk-tree-node", inputs: { role: "role" }, host: { properties: { "attr.aria-expanded": "isExpanded" }, classAttribute: "cdk-tree-node" }, exportAs: ["cdkTreeNode"], ngImport: i0 });
541
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0-next.7", ngImport: i0, type: CdkTreeNode, decorators: [{
542
- type: Directive,
543
- args: [{
544
- selector: 'cdk-tree-node',
545
- exportAs: 'cdkTreeNode',
546
- host: {
547
- 'class': 'cdk-tree-node',
548
- '[attr.aria-expanded]': 'isExpanded',
549
- },
550
- }]
551
- }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: CdkTree }]; }, propDecorators: { role: [{
552
- type: Input
553
- }] } });
554
- function getParentNodeAriaLevel(nodeElement) {
555
- let parent = nodeElement.parentElement;
556
- while (parent && !isNodeElement(parent)) {
557
- parent = parent.parentElement;
558
- }
559
- if (!parent) {
560
- if (typeof ngDevMode === 'undefined' || ngDevMode) {
561
- throw Error('Incorrect tree structure containing detached node.');
562
- }
563
- else {
564
- return -1;
565
- }
566
- }
567
- else if (parent.classList.contains('cdk-nested-tree-node')) {
568
- return coerceNumberProperty(parent.getAttribute('aria-level'));
569
- }
570
- else {
571
- // The ancestor element is the cdk-tree itself
572
- return 0;
573
- }
574
- }
575
- function isNodeElement(element) {
576
- const classList = element.classList;
577
- return !!((classList === null || classList === void 0 ? void 0 : classList.contains('cdk-nested-tree-node')) || (classList === null || classList === void 0 ? void 0 : classList.contains('cdk-tree')));
578
- }
579
-
580
- /**
581
- * Nested node is a child of `<cdk-tree>`. It works with nested tree.
582
- * By using `cdk-nested-tree-node` component in tree node template, children of the parent node will
583
- * be added in the `cdkTreeNodeOutlet` in tree node template.
584
- * The children of node will be automatically added to `cdkTreeNodeOutlet`.
585
- */
586
- class CdkNestedTreeNode extends CdkTreeNode {
587
- constructor(elementRef, tree, _differs) {
588
- super(elementRef, tree);
589
- this._differs = _differs;
590
- }
591
- ngAfterContentInit() {
592
- this._dataDiffer = this._differs.find([]).create(this._tree.trackBy);
593
- if (!this._tree.treeControl.getChildren && (typeof ngDevMode === 'undefined' || ngDevMode)) {
594
- throw getTreeControlFunctionsMissingError();
595
- }
596
- const childrenNodes = this._tree.treeControl.getChildren(this.data);
597
- if (Array.isArray(childrenNodes)) {
598
- this.updateChildrenNodes(childrenNodes);
599
- }
600
- else if (isObservable(childrenNodes)) {
601
- childrenNodes
602
- .pipe(takeUntil(this._destroyed))
603
- .subscribe(result => this.updateChildrenNodes(result));
604
- }
605
- this.nodeOutlet.changes
606
- .pipe(takeUntil(this._destroyed))
607
- .subscribe(() => this.updateChildrenNodes());
608
- }
609
- // This is a workaround for https://github.com/angular/angular/issues/23091
610
- // In aot mode, the lifecycle hooks from parent class are not called.
611
- ngOnInit() {
612
- super.ngOnInit();
613
- }
614
- ngOnDestroy() {
615
- this._clear();
616
- super.ngOnDestroy();
617
- }
618
- /** Add children dataNodes to the NodeOutlet */
619
- updateChildrenNodes(children) {
620
- const outlet = this._getNodeOutlet();
621
- if (children) {
622
- this._children = children;
623
- }
624
- if (outlet && this._children) {
625
- const viewContainer = outlet.viewContainer;
626
- this._tree.renderNodeChanges(this._children, this._dataDiffer, viewContainer, this._data);
627
- }
628
- else {
629
- // Reset the data differ if there's no children nodes displayed
630
- this._dataDiffer.diff([]);
631
- }
632
- }
633
- /** Clear the children dataNodes. */
634
- _clear() {
635
- const outlet = this._getNodeOutlet();
636
- if (outlet) {
637
- outlet.viewContainer.clear();
638
- this._dataDiffer.diff([]);
639
- }
640
- }
641
- /** Gets the outlet for the current node. */
642
- _getNodeOutlet() {
643
- const outlets = this.nodeOutlet;
644
- // Note that since we use `descendants: true` on the query, we have to ensure
645
- // that we don't pick up the outlet of a child node by accident.
646
- return outlets && outlets.find(outlet => !outlet._node || outlet._node === this);
647
- }
648
- }
649
- CdkNestedTreeNode.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0-next.7", ngImport: i0, type: CdkNestedTreeNode, deps: [{ token: i0.ElementRef }, { token: CdkTree }, { token: i0.IterableDiffers }], target: i0.ɵɵFactoryTarget.Directive });
650
- CdkNestedTreeNode.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.0-next.7", type: CdkNestedTreeNode, selector: "cdk-nested-tree-node", inputs: { role: "role", disabled: "disabled", tabIndex: "tabIndex" }, host: { classAttribute: "cdk-nested-tree-node" }, providers: [
651
- { provide: CdkTreeNode, useExisting: CdkNestedTreeNode },
652
- { provide: CDK_TREE_NODE_OUTLET_NODE, useExisting: CdkNestedTreeNode },
653
- ], queries: [{ propertyName: "nodeOutlet", predicate: CdkTreeNodeOutlet, descendants: true }], exportAs: ["cdkNestedTreeNode"], usesInheritance: true, ngImport: i0 });
654
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0-next.7", ngImport: i0, type: CdkNestedTreeNode, decorators: [{
655
- type: Directive,
656
- args: [{
657
- selector: 'cdk-nested-tree-node',
658
- exportAs: 'cdkNestedTreeNode',
659
- inputs: ['role', 'disabled', 'tabIndex'],
660
- providers: [
661
- { provide: CdkTreeNode, useExisting: CdkNestedTreeNode },
662
- { provide: CDK_TREE_NODE_OUTLET_NODE, useExisting: CdkNestedTreeNode },
663
- ],
664
- host: {
665
- 'class': 'cdk-nested-tree-node',
666
- },
667
- }]
668
- }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: CdkTree }, { type: i0.IterableDiffers }]; }, propDecorators: { nodeOutlet: [{
669
- type: ContentChildren,
670
- args: [CdkTreeNodeOutlet, {
671
- // We need to use `descendants: true`, because Ivy will no longer match
672
- // indirect descendants if it's left as false.
673
- descendants: true,
674
- }]
675
- }] } });
676
-
677
- /** Regex used to split a string on its CSS units. */
678
- const cssUnitPattern = /([A-Za-z%]+)$/;
679
- /**
680
- * Indent for the children tree dataNodes.
681
- * This directive will add left-padding to the node to show hierarchy.
682
- */
683
- class CdkTreeNodePadding {
684
- /** The level of depth of the tree node. The padding will be `level * indent` pixels. */
685
- get level() {
686
- return this._level;
687
- }
688
- set level(value) {
689
- this._setLevelInput(value);
690
- }
691
- /**
692
- * The indent for each level. Can be a number or a CSS string.
693
- * Default number 40px from material design menu sub-menu spec.
694
- */
695
- get indent() {
696
- return this._indent;
697
- }
698
- set indent(indent) {
699
- this._setIndentInput(indent);
700
- }
701
- constructor(_treeNode, _tree, _element, _dir) {
702
- this._treeNode = _treeNode;
703
- this._tree = _tree;
704
- this._element = _element;
705
- this._dir = _dir;
706
- /** Subject that emits when the component has been destroyed. */
707
- this._destroyed = new Subject();
708
- /** CSS units used for the indentation value. */
709
- this.indentUnits = 'px';
710
- this._indent = 40;
711
- this._setPadding();
712
- if (_dir) {
713
- _dir.change.pipe(takeUntil(this._destroyed)).subscribe(() => this._setPadding(true));
714
- }
715
- // In Ivy the indentation binding might be set before the tree node's data has been added,
716
- // which means that we'll miss the first render. We have to subscribe to changes in the
717
- // data to ensure that everything is up to date.
718
- _treeNode._dataChanges.subscribe(() => this._setPadding());
719
- }
720
- ngOnDestroy() {
721
- this._destroyed.next();
722
- this._destroyed.complete();
723
- }
724
- /** The padding indent value for the tree node. Returns a string with px numbers if not null. */
725
- _paddingIndent() {
726
- const nodeLevel = this._treeNode.data && this._tree.treeControl.getLevel
727
- ? this._tree.treeControl.getLevel(this._treeNode.data)
728
- : null;
729
- const level = this._level == null ? nodeLevel : this._level;
730
- return typeof level === 'number' ? `${level * this._indent}${this.indentUnits}` : null;
731
- }
732
- _setPadding(forceChange = false) {
733
- const padding = this._paddingIndent();
734
- if (padding !== this._currentPadding || forceChange) {
735
- const element = this._element.nativeElement;
736
- const paddingProp = this._dir && this._dir.value === 'rtl' ? 'paddingRight' : 'paddingLeft';
737
- const resetProp = paddingProp === 'paddingLeft' ? 'paddingRight' : 'paddingLeft';
738
- element.style[paddingProp] = padding || '';
739
- element.style[resetProp] = '';
740
- this._currentPadding = padding;
741
- }
742
- }
743
- /**
744
- * This has been extracted to a util because of TS 4 and VE.
745
- * View Engine doesn't support property rename inheritance.
746
- * TS 4.0 doesn't allow properties to override accessors or vice-versa.
747
- * @docs-private
748
- */
749
- _setLevelInput(value) {
750
- // Set to null as the fallback value so that _setPadding can fall back to the node level if the
751
- // consumer set the directive as `cdkTreeNodePadding=""`. We still want to take this value if
752
- // they set 0 explicitly.
753
- this._level = coerceNumberProperty(value, null);
754
- this._setPadding();
755
- }
756
- /**
757
- * This has been extracted to a util because of TS 4 and VE.
758
- * View Engine doesn't support property rename inheritance.
759
- * TS 4.0 doesn't allow properties to override accessors or vice-versa.
760
- * @docs-private
761
- */
762
- _setIndentInput(indent) {
763
- let value = indent;
764
- let units = 'px';
765
- if (typeof indent === 'string') {
766
- const parts = indent.split(cssUnitPattern);
767
- value = parts[0];
768
- units = parts[1] || units;
769
- }
770
- this.indentUnits = units;
771
- this._indent = coerceNumberProperty(value);
772
- this._setPadding();
773
- }
774
- }
775
- CdkTreeNodePadding.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0-next.7", ngImport: i0, type: CdkTreeNodePadding, deps: [{ token: CdkTreeNode }, { token: CdkTree }, { token: i0.ElementRef }, { token: i2.Directionality, optional: true }], target: i0.ɵɵFactoryTarget.Directive });
776
- CdkTreeNodePadding.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.0-next.7", type: CdkTreeNodePadding, selector: "[cdkTreeNodePadding]", inputs: { level: ["cdkTreeNodePadding", "level"], indent: ["cdkTreeNodePaddingIndent", "indent"] }, ngImport: i0 });
777
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0-next.7", ngImport: i0, type: CdkTreeNodePadding, decorators: [{
778
- type: Directive,
779
- args: [{
780
- selector: '[cdkTreeNodePadding]',
781
- }]
782
- }], ctorParameters: function () {
783
- return [{ type: CdkTreeNode }, { type: CdkTree }, { type: i0.ElementRef }, { type: i2.Directionality, decorators: [{
784
- type: Optional
785
- }] }];
786
- }, propDecorators: { level: [{
787
- type: Input,
788
- args: ['cdkTreeNodePadding']
789
- }], indent: [{
790
- type: Input,
791
- args: ['cdkTreeNodePaddingIndent']
792
- }] } });
793
-
794
- /**
795
- * Node toggle to expand/collapse the node.
796
- */
797
- class CdkTreeNodeToggle {
798
- /** Whether expand/collapse the node recursively. */
799
- get recursive() {
800
- return this._recursive;
801
- }
802
- set recursive(value) {
803
- this._recursive = coerceBooleanProperty(value);
804
- }
805
- constructor(_tree, _treeNode) {
806
- this._tree = _tree;
807
- this._treeNode = _treeNode;
808
- this._recursive = false;
809
- }
810
- _toggle(event) {
811
- this.recursive
812
- ? this._tree.treeControl.toggleDescendants(this._treeNode.data)
813
- : this._tree.treeControl.toggle(this._treeNode.data);
814
- event.stopPropagation();
815
- }
816
- }
817
- CdkTreeNodeToggle.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0-next.7", ngImport: i0, type: CdkTreeNodeToggle, deps: [{ token: CdkTree }, { token: CdkTreeNode }], target: i0.ɵɵFactoryTarget.Directive });
818
- CdkTreeNodeToggle.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.0-next.7", type: CdkTreeNodeToggle, selector: "[cdkTreeNodeToggle]", inputs: { recursive: ["cdkTreeNodeToggleRecursive", "recursive"] }, host: { listeners: { "click": "_toggle($event)" } }, ngImport: i0 });
819
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0-next.7", ngImport: i0, type: CdkTreeNodeToggle, decorators: [{
820
- type: Directive,
821
- args: [{
822
- selector: '[cdkTreeNodeToggle]',
823
- host: {
824
- '(click)': '_toggle($event)',
825
- },
826
- }]
827
- }], ctorParameters: function () { return [{ type: CdkTree }, { type: CdkTreeNode }]; }, propDecorators: { recursive: [{
828
- type: Input,
829
- args: ['cdkTreeNodeToggleRecursive']
830
- }] } });
831
-
832
- const EXPORTED_DECLARATIONS = [
833
- CdkNestedTreeNode,
834
- CdkTreeNodeDef,
835
- CdkTreeNodePadding,
836
- CdkTreeNodeToggle,
837
- CdkTree,
838
- CdkTreeNode,
839
- CdkTreeNodeOutlet,
840
- ];
841
- class CdkTreeModule {
842
- }
843
- CdkTreeModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0-next.7", ngImport: i0, type: CdkTreeModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
844
- CdkTreeModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.0.0-next.7", ngImport: i0, type: CdkTreeModule, declarations: [CdkNestedTreeNode,
845
- CdkTreeNodeDef,
846
- CdkTreeNodePadding,
847
- CdkTreeNodeToggle,
848
- CdkTree,
849
- CdkTreeNode,
850
- CdkTreeNodeOutlet], exports: [CdkNestedTreeNode,
851
- CdkTreeNodeDef,
852
- CdkTreeNodePadding,
853
- CdkTreeNodeToggle,
854
- CdkTree,
855
- CdkTreeNode,
856
- CdkTreeNodeOutlet] });
857
- CdkTreeModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.0.0-next.7", ngImport: i0, type: CdkTreeModule });
858
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0-next.7", ngImport: i0, type: CdkTreeModule, decorators: [{
859
- type: NgModule,
860
- args: [{
861
- exports: EXPORTED_DECLARATIONS,
862
- declarations: EXPORTED_DECLARATIONS,
863
- }]
864
- }] });
865
-
866
- /**
867
- * Generated bundle index. Do not edit.
868
- */
869
-
870
- export { BaseTreeControl, CDK_TREE_NODE_OUTLET_NODE, CdkNestedTreeNode, CdkTree, CdkTreeModule, CdkTreeNode, CdkTreeNodeDef, CdkTreeNodeOutlet, CdkTreeNodeOutletContext, CdkTreeNodePadding, CdkTreeNodeToggle, FlatTreeControl, NestedTreeControl, getTreeControlFunctionsMissingError, getTreeControlMissingError, getTreeMissingMatchingNodeDefError, getTreeMultipleDefaultNodeDefsError, getTreeNoValidDataSourceError };
871
- //# sourceMappingURL=tree.mjs.map