@ptsecurity/mosaic 13.3.0 → 13.5.0

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 (922) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +6 -6
  3. package/_theming.scss +7091 -6885
  4. package/_visual.scss +2690 -2580
  5. package/autocomplete/autocomplete-origin.directive.d.ts +12 -12
  6. package/autocomplete/autocomplete-trigger.directive.d.ts +167 -167
  7. package/autocomplete/autocomplete.component.d.ts +73 -73
  8. package/autocomplete/autocomplete.module.d.ts +12 -12
  9. package/autocomplete/index.d.ts +1 -1
  10. package/autocomplete/ptsecurity-mosaic-autocomplete.d.ts +5 -5
  11. package/autocomplete/public-api.d.ts +4 -4
  12. package/button/button.component.d.ts +40 -40
  13. package/button/button.module.d.ts +10 -10
  14. package/button/index.d.ts +1 -1
  15. package/button/ptsecurity-mosaic-button.d.ts +5 -5
  16. package/button/public-api.d.ts +2 -2
  17. package/button-toggle/button-toggle.component.d.ts +141 -141
  18. package/button-toggle/button-toggle.module.d.ts +9 -9
  19. package/button-toggle/index.d.ts +1 -1
  20. package/button-toggle/ptsecurity-mosaic-button-toggle.d.ts +5 -5
  21. package/button-toggle/public-api.d.ts +2 -2
  22. package/card/card.component.d.ts +26 -26
  23. package/card/card.module.d.ts +10 -10
  24. package/card/index.d.ts +1 -1
  25. package/card/ptsecurity-mosaic-card.d.ts +5 -5
  26. package/card/public-api.d.ts +2 -2
  27. package/checkbox/README.md +1 -1
  28. package/checkbox/checkbox-config.d.ts +13 -13
  29. package/checkbox/checkbox-module.d.ts +9 -9
  30. package/checkbox/checkbox-required-validator.d.ts +13 -13
  31. package/checkbox/checkbox.d.ts +140 -140
  32. package/checkbox/index.d.ts +1 -1
  33. package/checkbox/ptsecurity-mosaic-checkbox.d.ts +5 -5
  34. package/checkbox/public-api.d.ts +4 -4
  35. package/core/animation/animation.d.ts +6 -6
  36. package/core/animation/fade-animations.d.ts +2 -2
  37. package/core/animation/index.d.ts +3 -3
  38. package/core/animation/select-animations.d.ts +12 -12
  39. package/core/common-behaviors/color.d.ts +19 -19
  40. package/core/common-behaviors/common-module.d.ts +25 -25
  41. package/core/common-behaviors/constructor.d.ts +9 -9
  42. package/core/common-behaviors/disabled.d.ts +8 -8
  43. package/core/common-behaviors/error-state.d.ts +25 -25
  44. package/core/common-behaviors/index.d.ts +5 -5
  45. package/core/common-behaviors/tabindex.d.ts +8 -8
  46. package/core/error/error-options.d.ts +14 -14
  47. package/core/formatters/date/formatter.d.ts +203 -203
  48. package/core/formatters/date/templates/en-US.d.ts +74 -74
  49. package/core/formatters/date/templates/ru-RU.d.ts +74 -74
  50. package/core/formatters/index.d.ts +9 -9
  51. package/core/formatters/number/formatter.d.ts +27 -27
  52. package/core/forms/forms-module.d.ts +7 -7
  53. package/core/forms/forms.directive.d.ts +22 -22
  54. package/core/forms/index.d.ts +2 -2
  55. package/core/highlight/highlight.pipe.d.ts +7 -7
  56. package/core/highlight/index.d.ts +9 -9
  57. package/core/index.d.ts +1 -1
  58. package/core/label/label-options.d.ts +13 -13
  59. package/core/line/line.d.ts +28 -28
  60. package/core/option/action.d.ts +42 -42
  61. package/core/option/index.d.ts +4 -4
  62. package/core/option/optgroup.d.ts +16 -16
  63. package/core/option/option-module.d.ts +11 -11
  64. package/core/option/option.d.ts +115 -115
  65. package/core/overlay/overlay-position-map.d.ts +34 -34
  66. package/core/pop-up/constants.d.ts +29 -29
  67. package/core/pop-up/index.d.ts +3 -3
  68. package/core/pop-up/pop-up-trigger.d.ts +70 -70
  69. package/core/pop-up/pop-up.d.ts +36 -36
  70. package/core/ptsecurity-mosaic-core.d.ts +5 -5
  71. package/core/public-api.d.ts +17 -17
  72. package/core/select/constants.d.ts +23 -23
  73. package/core/select/errors.d.ts +19 -19
  74. package/core/select/events.d.ts +1 -1
  75. package/core/select/index.d.ts +3 -3
  76. package/core/selection/constants.d.ts +4 -4
  77. package/core/selection/index.d.ts +3 -3
  78. package/core/selection/pseudo-checkbox/pseudo-checkbox.d.ts +21 -21
  79. package/core/selection/pseudo-checkbox/pseudo-checkbox.module.d.ts +8 -8
  80. package/core/services/measure-scrollbar.service.d.ts +11 -11
  81. package/core/utils/index.d.ts +1 -1
  82. package/core/utils/public-api.d.ts +1 -1
  83. package/core/utils/utils.d.ts +2 -2
  84. package/core/validation/index.d.ts +1 -1
  85. package/core/validation/validation.d.ts +18 -16
  86. package/core/version.d.ts +2 -2
  87. package/datepicker/calendar-body.component.d.ts +63 -63
  88. package/datepicker/calendar.component.d.ts +151 -151
  89. package/datepicker/datepicker-animations.d.ts +9 -9
  90. package/datepicker/datepicker-errors.d.ts +2 -2
  91. package/datepicker/datepicker-input.directive.d.ts +178 -172
  92. package/datepicker/datepicker-intl.d.ts +32 -32
  93. package/datepicker/datepicker-module.d.ts +20 -20
  94. package/datepicker/datepicker-toggle.component.d.ts +35 -35
  95. package/datepicker/datepicker.component.d.ts +158 -158
  96. package/datepicker/index.d.ts +1 -1
  97. package/datepicker/month-view.component.d.ts +93 -93
  98. package/datepicker/multi-year-view.component.d.ts +72 -72
  99. package/datepicker/ptsecurity-mosaic-datepicker.d.ts +5 -5
  100. package/datepicker/public-api.d.ts +11 -11
  101. package/datepicker/year-view.component.d.ts +90 -90
  102. package/design-tokens/index.d.ts +1 -1
  103. package/design-tokens/legacy-2017/tokens/components/alert.json5 +83 -0
  104. package/design-tokens/legacy-2017/tokens/components/autocomplete.json5 +11 -0
  105. package/design-tokens/legacy-2017/tokens/components/badge.json5 +174 -0
  106. package/design-tokens/legacy-2017/tokens/components/button-toggle.json5 +10 -0
  107. package/design-tokens/legacy-2017/tokens/components/button.json5 +142 -0
  108. package/design-tokens/legacy-2017/tokens/components/card.json5 +51 -0
  109. package/design-tokens/legacy-2017/tokens/components/checkbox.json5 +97 -0
  110. package/design-tokens/legacy-2017/tokens/components/datepicker.json5 +64 -0
  111. package/design-tokens/legacy-2017/tokens/components/divider.json5 +8 -0
  112. package/design-tokens/legacy-2017/tokens/components/dl.json5 +38 -0
  113. package/design-tokens/legacy-2017/tokens/components/dropdown.json5 +48 -0
  114. package/design-tokens/legacy-2017/tokens/components/form-field.json5 +92 -0
  115. package/design-tokens/legacy-2017/tokens/components/forms.json5 +52 -0
  116. package/design-tokens/legacy-2017/tokens/components/icon.json5 +104 -0
  117. package/design-tokens/legacy-2017/tokens/components/input.json5 +12 -0
  118. package/design-tokens/legacy-2017/tokens/components/link.json5 +50 -0
  119. package/design-tokens/legacy-2017/tokens/components/list.json5 +13 -0
  120. package/design-tokens/legacy-2017/tokens/components/modal.json5 +81 -0
  121. package/design-tokens/legacy-2017/tokens/components/navbar.json5 +70 -0
  122. package/design-tokens/legacy-2017/tokens/components/optgroup.json5 +10 -0
  123. package/design-tokens/legacy-2017/tokens/components/option.json5 +12 -0
  124. package/design-tokens/legacy-2017/tokens/components/popover.json5 +68 -0
  125. package/design-tokens/legacy-2017/tokens/components/popup.json5 +18 -0
  126. package/design-tokens/legacy-2017/tokens/components/progress-bar.json5 +13 -0
  127. package/design-tokens/legacy-2017/tokens/components/progress-spinner.json5 +7 -0
  128. package/design-tokens/legacy-2017/tokens/components/radio.json5 +44 -0
  129. package/design-tokens/legacy-2017/tokens/components/select.json5 +24 -0
  130. package/design-tokens/legacy-2017/tokens/components/sidepanel.json5 +32 -0
  131. package/design-tokens/legacy-2017/tokens/components/table.json5 +15 -0
  132. package/design-tokens/legacy-2017/tokens/components/tabs.json5 +101 -0
  133. package/design-tokens/legacy-2017/tokens/components/tags.json5 +134 -0
  134. package/design-tokens/legacy-2017/tokens/components/textarea.json5 +12 -0
  135. package/design-tokens/legacy-2017/tokens/components/timepicker.json5 +7 -0
  136. package/design-tokens/legacy-2017/tokens/components/toggle.json5 +79 -0
  137. package/design-tokens/legacy-2017/tokens/components/tooltip.json5 +83 -0
  138. package/design-tokens/legacy-2017/tokens/components/tree.json5 +15 -0
  139. package/design-tokens/legacy-2017/tokens/properties/aliases.json5 +3 -0
  140. package/design-tokens/legacy-2017/tokens/properties/colors.json5 +118 -0
  141. package/design-tokens/legacy-2017/tokens/properties/font.json5 +12 -0
  142. package/design-tokens/legacy-2017/tokens/properties/globals.json5 +49 -0
  143. package/design-tokens/legacy-2017/tokens/properties/padding.json5 +3 -0
  144. package/design-tokens/legacy-2017/tokens/properties/palette.json5 +163 -0
  145. package/design-tokens/legacy-2017/tokens/properties/typography.json5 +175 -0
  146. package/design-tokens/legacy-2017/tokens.d.ts +7839 -7758
  147. package/design-tokens/pt-2022/tokens/components/alert.json5 +83 -0
  148. package/design-tokens/pt-2022/tokens/components/autocomplete.json5 +11 -0
  149. package/design-tokens/pt-2022/tokens/components/badge.json5 +174 -0
  150. package/design-tokens/pt-2022/tokens/components/button-toggle.json5 +10 -0
  151. package/design-tokens/pt-2022/tokens/components/button.json5 +142 -0
  152. package/design-tokens/pt-2022/tokens/components/card.json5 +51 -0
  153. package/design-tokens/pt-2022/tokens/components/checkbox.json5 +97 -0
  154. package/design-tokens/pt-2022/tokens/components/datepicker.json5 +64 -0
  155. package/design-tokens/pt-2022/tokens/components/divider.json5 +8 -0
  156. package/design-tokens/pt-2022/tokens/components/dl.json5 +38 -0
  157. package/design-tokens/pt-2022/tokens/components/dropdown.json5 +48 -0
  158. package/design-tokens/pt-2022/tokens/components/form-field.json5 +92 -0
  159. package/design-tokens/pt-2022/tokens/components/forms.json5 +52 -0
  160. package/design-tokens/pt-2022/tokens/components/icon.json5 +104 -0
  161. package/design-tokens/pt-2022/tokens/components/input.json5 +12 -0
  162. package/design-tokens/pt-2022/tokens/components/link.json5 +50 -0
  163. package/design-tokens/pt-2022/tokens/components/list.json5 +13 -0
  164. package/design-tokens/pt-2022/tokens/components/modal.json5 +81 -0
  165. package/design-tokens/pt-2022/tokens/components/navbar.json5 +70 -0
  166. package/design-tokens/pt-2022/tokens/components/optgroup.json5 +10 -0
  167. package/design-tokens/pt-2022/tokens/components/option.json5 +12 -0
  168. package/design-tokens/pt-2022/tokens/components/popover.json5 +68 -0
  169. package/design-tokens/pt-2022/tokens/components/popup.json5 +18 -0
  170. package/design-tokens/pt-2022/tokens/components/progress-bar.json5 +13 -0
  171. package/design-tokens/pt-2022/tokens/components/progress-spinner.json5 +7 -0
  172. package/design-tokens/pt-2022/tokens/components/radio.json5 +44 -0
  173. package/design-tokens/pt-2022/tokens/components/select.json5 +24 -0
  174. package/design-tokens/pt-2022/tokens/components/sidepanel.json5 +32 -0
  175. package/design-tokens/pt-2022/tokens/components/table.json5 +15 -0
  176. package/design-tokens/pt-2022/tokens/components/tabs.json5 +101 -0
  177. package/design-tokens/pt-2022/tokens/components/tags.json5 +137 -0
  178. package/design-tokens/pt-2022/tokens/components/textarea.json5 +12 -0
  179. package/design-tokens/pt-2022/tokens/components/timepicker.json5 +7 -0
  180. package/design-tokens/pt-2022/tokens/components/toggle.json5 +79 -0
  181. package/design-tokens/pt-2022/tokens/components/tooltip.json5 +83 -0
  182. package/design-tokens/pt-2022/tokens/components/tree.json5 +15 -0
  183. package/design-tokens/pt-2022/tokens/properties/aliases.json5 +3 -0
  184. package/design-tokens/pt-2022/tokens/properties/colors.json5 +120 -0
  185. package/design-tokens/pt-2022/tokens/properties/font.json5 +15 -0
  186. package/design-tokens/pt-2022/tokens/properties/globals.json5 +49 -0
  187. package/design-tokens/pt-2022/tokens/properties/padding.json5 +3 -0
  188. package/design-tokens/pt-2022/tokens/properties/palette.json5 +233 -0
  189. package/design-tokens/pt-2022/tokens/properties/typography.json5 +175 -0
  190. package/design-tokens/pt-2022/tokens.d.ts +9171 -8795
  191. package/design-tokens/ptsecurity-mosaic-design-tokens.d.ts +5 -5
  192. package/design-tokens/public-api.d.ts +3 -3
  193. package/design-tokens/style-dictionary/build.js +63 -0
  194. package/design-tokens/style-dictionary/configs/css.js +13 -0
  195. package/design-tokens/style-dictionary/configs/index.js +48 -0
  196. package/design-tokens/style-dictionary/configs/js.js +9 -0
  197. package/design-tokens/style-dictionary/configs/scss.js +23 -0
  198. package/design-tokens/style-dictionary/filters/color.js +7 -0
  199. package/design-tokens/style-dictionary/filters/palette.js +7 -0
  200. package/design-tokens/style-dictionary/filters/size.js +7 -0
  201. package/design-tokens/style-dictionary/filters/typography.js +7 -0
  202. package/design-tokens/style-dictionary/formats/palette.js +25 -0
  203. package/design-tokens/style-dictionary/formats/typography.js +52 -0
  204. package/design-tokens/style-dictionary/transformGroups/css.js +13 -0
  205. package/design-tokens/style-dictionary/transformGroups/scss.js +12 -0
  206. package/design-tokens/style-dictionary/transformGroups/ts.js +11 -0
  207. package/design-tokens/style-dictionary/transforms/attribute/palette.js +9 -0
  208. package/design-tokens/style-dictionary/transforms/attribute/prefix.js +11 -0
  209. package/design-tokens/style-dictionary/transforms/attribute/size.js +8 -0
  210. package/design-tokens/style-dictionary/transforms/attribute/typography.js +9 -0
  211. package/divider/divider.component.d.ts +11 -11
  212. package/divider/divider.module.d.ts +8 -8
  213. package/divider/index.d.ts +1 -1
  214. package/divider/ptsecurity-mosaic-divider.d.ts +5 -5
  215. package/divider/public-api.d.ts +2 -2
  216. package/dl/dl.component.d.ts +26 -26
  217. package/dl/dl.module.d.ts +10 -10
  218. package/dl/index.d.ts +1 -1
  219. package/dl/ptsecurity-mosaic-dl.d.ts +5 -5
  220. package/dl/public-api.d.ts +2 -2
  221. package/dropdown/dropdown-animations.d.ts +11 -11
  222. package/dropdown/dropdown-content.directive.d.ts +32 -32
  223. package/dropdown/dropdown-errors.d.ts +17 -17
  224. package/dropdown/dropdown-item.component.d.ts +50 -50
  225. package/dropdown/dropdown-trigger.directive.d.ts +136 -135
  226. package/dropdown/dropdown.component.d.ts +121 -121
  227. package/dropdown/dropdown.module.d.ts +13 -13
  228. package/dropdown/dropdown.types.d.ts +53 -53
  229. package/dropdown/index.d.ts +1 -1
  230. package/dropdown/ptsecurity-mosaic-dropdown.d.ts +5 -5
  231. package/dropdown/public-api.d.ts +8 -8
  232. package/esm2020/autocomplete/autocomplete-origin.directive.mjs +21 -21
  233. package/esm2020/autocomplete/autocomplete-trigger.directive.mjs +555 -555
  234. package/esm2020/autocomplete/autocomplete.component.mjs +154 -154
  235. package/esm2020/autocomplete/autocomplete.module.mjs +34 -34
  236. package/esm2020/autocomplete/index.mjs +2 -2
  237. package/esm2020/autocomplete/ptsecurity-mosaic-autocomplete.mjs +4 -4
  238. package/esm2020/autocomplete/public-api.mjs +5 -5
  239. package/esm2020/button/button.component.mjs +137 -137
  240. package/esm2020/button/button.module.mjs +38 -38
  241. package/esm2020/button/index.mjs +2 -2
  242. package/esm2020/button/ptsecurity-mosaic-button.mjs +4 -4
  243. package/esm2020/button/public-api.mjs +3 -3
  244. package/esm2020/button-toggle/button-toggle.component.mjs +362 -362
  245. package/esm2020/button-toggle/button-toggle.module.mjs +19 -19
  246. package/esm2020/button-toggle/index.mjs +2 -2
  247. package/esm2020/button-toggle/ptsecurity-mosaic-button-toggle.mjs +4 -4
  248. package/esm2020/button-toggle/public-api.mjs +3 -3
  249. package/esm2020/card/card.component.mjs +80 -80
  250. package/esm2020/card/card.module.mjs +30 -30
  251. package/esm2020/card/index.mjs +2 -2
  252. package/esm2020/card/ptsecurity-mosaic-card.mjs +4 -4
  253. package/esm2020/card/public-api.mjs +3 -3
  254. package/esm2020/checkbox/checkbox-config.mjs +6 -6
  255. package/esm2020/checkbox/checkbox-module.mjs +19 -19
  256. package/esm2020/checkbox/checkbox-required-validator.mjs +27 -27
  257. package/esm2020/checkbox/checkbox.mjs +316 -315
  258. package/esm2020/checkbox/index.mjs +2 -2
  259. package/esm2020/checkbox/ptsecurity-mosaic-checkbox.mjs +4 -4
  260. package/esm2020/checkbox/public-api.mjs +5 -5
  261. package/esm2020/core/animation/animation.mjs +8 -8
  262. package/esm2020/core/animation/fade-animations.mjs +9 -9
  263. package/esm2020/core/animation/index.mjs +4 -4
  264. package/esm2020/core/animation/select-animations.mjs +45 -45
  265. package/esm2020/core/common-behaviors/color.mjs +30 -30
  266. package/esm2020/core/common-behaviors/common-module.mjs +83 -83
  267. package/esm2020/core/common-behaviors/constructor.mjs +2 -2
  268. package/esm2020/core/common-behaviors/disabled.mjs +17 -17
  269. package/esm2020/core/common-behaviors/error-state.mjs +31 -31
  270. package/esm2020/core/common-behaviors/index.mjs +6 -6
  271. package/esm2020/core/common-behaviors/tabindex.mjs +18 -18
  272. package/esm2020/core/error/error-options.mjs +26 -26
  273. package/esm2020/core/formatters/date/formatter.mjs +359 -359
  274. package/esm2020/core/formatters/date/templates/en-US.mjs +281 -281
  275. package/esm2020/core/formatters/date/templates/ru-RU.mjs +281 -281
  276. package/esm2020/core/formatters/index.mjs +20 -20
  277. package/esm2020/core/formatters/number/formatter.mjs +105 -105
  278. package/esm2020/core/forms/forms-module.mjs +24 -24
  279. package/esm2020/core/forms/forms.directive.mjs +66 -66
  280. package/esm2020/core/forms/index.mjs +3 -3
  281. package/esm2020/core/highlight/highlight.pipe.mjs +17 -17
  282. package/esm2020/core/highlight/index.mjs +19 -19
  283. package/esm2020/core/index.mjs +2 -2
  284. package/esm2020/core/label/label-options.mjs +4 -4
  285. package/esm2020/core/line/line.mjs +70 -70
  286. package/esm2020/core/option/action.mjs +121 -121
  287. package/esm2020/core/option/index.mjs +5 -5
  288. package/esm2020/core/option/optgroup.mjs +31 -31
  289. package/esm2020/core/option/option-module.mjs +21 -21
  290. package/esm2020/core/option/option.mjs +257 -257
  291. package/esm2020/core/overlay/overlay-position-map.mjs +244 -244
  292. package/esm2020/core/pop-up/constants.mjs +34 -34
  293. package/esm2020/core/pop-up/index.mjs +4 -4
  294. package/esm2020/core/pop-up/pop-up-trigger.mjs +239 -239
  295. package/esm2020/core/pop-up/pop-up.mjs +94 -94
  296. package/esm2020/core/ptsecurity-mosaic-core.mjs +4 -4
  297. package/esm2020/core/public-api.mjs +18 -18
  298. package/esm2020/core/select/constants.mjs +27 -27
  299. package/esm2020/core/select/errors.mjs +26 -26
  300. package/esm2020/core/select/events.mjs +2 -2
  301. package/esm2020/core/select/index.mjs +4 -4
  302. package/esm2020/core/selection/constants.mjs +6 -6
  303. package/esm2020/core/selection/index.mjs +4 -4
  304. package/esm2020/core/selection/pseudo-checkbox/pseudo-checkbox.mjs +37 -37
  305. package/esm2020/core/selection/pseudo-checkbox/pseudo-checkbox.module.mjs +18 -18
  306. package/esm2020/core/services/measure-scrollbar.service.mjs +48 -48
  307. package/esm2020/core/utils/index.mjs +2 -2
  308. package/esm2020/core/utils/public-api.mjs +2 -2
  309. package/esm2020/core/utils/utils.mjs +5 -5
  310. package/esm2020/core/validation/index.mjs +2 -2
  311. package/esm2020/core/validation/validation.mjs +118 -89
  312. package/esm2020/core/version.mjs +3 -3
  313. package/esm2020/datepicker/calendar-body.component.mjs +106 -106
  314. package/esm2020/datepicker/calendar.component.mjs +362 -362
  315. package/esm2020/datepicker/datepicker-animations.mjs +32 -32
  316. package/esm2020/datepicker/datepicker-errors.mjs +6 -6
  317. package/esm2020/datepicker/datepicker-input.directive.mjs +936 -900
  318. package/esm2020/datepicker/datepicker-intl.mjs +40 -40
  319. package/esm2020/datepicker/datepicker-module.mjs +107 -107
  320. package/esm2020/datepicker/datepicker-toggle.component.mjs +86 -86
  321. package/esm2020/datepicker/datepicker.component.mjs +408 -408
  322. package/esm2020/datepicker/index.mjs +2 -2
  323. package/esm2020/datepicker/month-view.component.mjs +257 -257
  324. package/esm2020/datepicker/multi-year-view.component.mjs +218 -218
  325. package/esm2020/datepicker/ptsecurity-mosaic-datepicker.mjs +4 -4
  326. package/esm2020/datepicker/public-api.mjs +12 -12
  327. package/esm2020/datepicker/year-view.component.mjs +253 -253
  328. package/esm2020/design-tokens/index.mjs +2 -2
  329. package/esm2020/design-tokens/legacy-2017/tokens.mjs +1133 -1052
  330. package/esm2020/design-tokens/pt-2022/tokens.mjs +1203 -1112
  331. package/esm2020/design-tokens/ptsecurity-mosaic-design-tokens.mjs +4 -4
  332. package/esm2020/design-tokens/public-api.mjs +4 -4
  333. package/esm2020/divider/divider.component.mjs +39 -39
  334. package/esm2020/divider/divider.module.mjs +18 -18
  335. package/esm2020/divider/index.mjs +2 -2
  336. package/esm2020/divider/ptsecurity-mosaic-divider.mjs +4 -4
  337. package/esm2020/divider/public-api.mjs +3 -3
  338. package/esm2020/dl/dl.component.mjs +78 -78
  339. package/esm2020/dl/dl.module.mjs +42 -42
  340. package/esm2020/dl/index.mjs +2 -2
  341. package/esm2020/dl/ptsecurity-mosaic-dl.mjs +4 -4
  342. package/esm2020/dl/public-api.mjs +3 -3
  343. package/esm2020/dropdown/dropdown-animations.mjs +41 -41
  344. package/esm2020/dropdown/dropdown-content.directive.mjs +64 -64
  345. package/esm2020/dropdown/dropdown-errors.mjs +29 -29
  346. package/esm2020/dropdown/dropdown-item.component.mjs +139 -139
  347. package/esm2020/dropdown/dropdown-trigger.directive.mjs +489 -485
  348. package/esm2020/dropdown/dropdown.component.mjs +292 -292
  349. package/esm2020/dropdown/dropdown.module.mjs +50 -50
  350. package/esm2020/dropdown/dropdown.types.mjs +24 -24
  351. package/esm2020/dropdown/index.mjs +2 -2
  352. package/esm2020/dropdown/ptsecurity-mosaic-dropdown.mjs +4 -4
  353. package/esm2020/dropdown/public-api.mjs +9 -9
  354. package/esm2020/form-field/cleaner.mjs +23 -23
  355. package/esm2020/form-field/form-field-control.mjs +5 -5
  356. package/esm2020/form-field/form-field-errors.mjs +7 -7
  357. package/esm2020/form-field/form-field.mjs +225 -225
  358. package/esm2020/form-field/form-field.module.mjs +57 -57
  359. package/esm2020/form-field/hint.mjs +23 -23
  360. package/esm2020/form-field/index.mjs +2 -2
  361. package/esm2020/form-field/password-hint.mjs +134 -134
  362. package/esm2020/form-field/prefix.mjs +13 -13
  363. package/esm2020/form-field/ptsecurity-mosaic-form-field.mjs +4 -4
  364. package/esm2020/form-field/public-api.mjs +11 -11
  365. package/esm2020/form-field/stepper.mjs +55 -55
  366. package/esm2020/form-field/suffix.mjs +13 -13
  367. package/esm2020/icon/icon.component.mjs +44 -44
  368. package/esm2020/icon/icon.module.mjs +38 -38
  369. package/esm2020/icon/index.mjs +2 -2
  370. package/esm2020/icon/ptsecurity-mosaic-icon.mjs +4 -4
  371. package/esm2020/icon/public-api.mjs +3 -3
  372. package/esm2020/index.mjs +2 -2
  373. package/esm2020/input/index.mjs +2 -2
  374. package/esm2020/input/input-errors.mjs +4 -4
  375. package/esm2020/input/input-number-validators.mjs +92 -92
  376. package/esm2020/input/input-number.mjs +163 -163
  377. package/esm2020/input/input-password.mjs +368 -368
  378. package/esm2020/input/input-value-accessor.mjs +3 -3
  379. package/esm2020/input/input.mjs +334 -334
  380. package/esm2020/input/input.module.mjs +65 -65
  381. package/esm2020/input/ptsecurity-mosaic-input.mjs +4 -4
  382. package/esm2020/input/public-api.mjs +7 -7
  383. package/esm2020/link/index.mjs +2 -2
  384. package/esm2020/link/link.component.mjs +107 -107
  385. package/esm2020/link/link.module.mjs +26 -26
  386. package/esm2020/link/ptsecurity-mosaic-link.mjs +4 -4
  387. package/esm2020/link/public-api.mjs +3 -3
  388. package/esm2020/list/index.mjs +2 -2
  389. package/esm2020/list/list-selection.component.mjs +686 -687
  390. package/esm2020/list/list.component.mjs +44 -44
  391. package/esm2020/list/list.module.mjs +55 -55
  392. package/esm2020/list/ptsecurity-mosaic-list.mjs +4 -4
  393. package/esm2020/list/public-api.mjs +4 -4
  394. package/esm2020/modal/css-unit.pipe.mjs +17 -17
  395. package/esm2020/modal/index.mjs +2 -2
  396. package/esm2020/modal/modal-control.service.mjs +85 -85
  397. package/esm2020/modal/modal-ref.class.mjs +8 -8
  398. package/esm2020/modal/modal-util.mjs +17 -17
  399. package/esm2020/modal/modal.component.mjs +501 -501
  400. package/esm2020/modal/modal.directive.mjs +52 -52
  401. package/esm2020/modal/modal.module.mjs +72 -72
  402. package/esm2020/modal/modal.service.mjs +124 -124
  403. package/esm2020/modal/modal.type.mjs +7 -7
  404. package/esm2020/modal/ptsecurity-mosaic-modal.mjs +4 -4
  405. package/esm2020/modal/public-api.mjs +7 -7
  406. package/esm2020/navbar/index.mjs +2 -2
  407. package/esm2020/navbar/navbar-item.component.mjs +582 -584
  408. package/esm2020/navbar/navbar.component.mjs +237 -237
  409. package/esm2020/navbar/navbar.module.mjs +92 -92
  410. package/esm2020/navbar/ptsecurity-mosaic-navbar.mjs +4 -4
  411. package/esm2020/navbar/public-api.mjs +5 -5
  412. package/esm2020/navbar/vertical-navbar.animation.mjs +10 -10
  413. package/esm2020/navbar/vertical-navbar.component.mjs +114 -114
  414. package/esm2020/popover/index.mjs +2 -2
  415. package/esm2020/popover/popover-animations.mjs +16 -16
  416. package/esm2020/popover/popover-confirm.component.mjs +108 -108
  417. package/esm2020/popover/popover.component.mjs +253 -253
  418. package/esm2020/popover/popover.module.mjs +24 -24
  419. package/esm2020/popover/ptsecurity-mosaic-popover.mjs +4 -4
  420. package/esm2020/popover/public-api.mjs +5 -5
  421. package/esm2020/progress-bar/index.mjs +2 -2
  422. package/esm2020/progress-bar/progress-bar.component.mjs +42 -42
  423. package/esm2020/progress-bar/progress-bar.module.mjs +30 -30
  424. package/esm2020/progress-bar/ptsecurity-mosaic-progress-bar.mjs +4 -4
  425. package/esm2020/progress-bar/public-api.mjs +3 -3
  426. package/esm2020/progress-spinner/index.mjs +2 -2
  427. package/esm2020/progress-spinner/progress-spinner.component.mjs +46 -46
  428. package/esm2020/progress-spinner/progress-spinner.module.mjs +30 -30
  429. package/esm2020/progress-spinner/ptsecurity-mosaic-progress-spinner.mjs +4 -4
  430. package/esm2020/progress-spinner/public-api.mjs +3 -3
  431. package/esm2020/ptsecurity-mosaic.mjs +4 -4
  432. package/esm2020/public-api.mjs +2 -2
  433. package/esm2020/radio/index.mjs +2 -2
  434. package/esm2020/radio/ptsecurity-mosaic-radio.mjs +4 -4
  435. package/esm2020/radio/public-api.mjs +3 -3
  436. package/esm2020/radio/radio.component.mjs +458 -458
  437. package/esm2020/radio/radio.module.mjs +20 -20
  438. package/esm2020/select/index.mjs +2 -2
  439. package/esm2020/select/ptsecurity-mosaic-select.mjs +4 -4
  440. package/esm2020/select/public-api.mjs +4 -4
  441. package/esm2020/select/select-option.directive.mjs +65 -65
  442. package/esm2020/select/select.component.mjs +1107 -1110
  443. package/esm2020/select/select.module.mjs +73 -73
  444. package/esm2020/sidebar/index.mjs +2 -2
  445. package/esm2020/sidebar/ptsecurity-mosaic-sidebar.mjs +4 -4
  446. package/esm2020/sidebar/public-api.mjs +3 -3
  447. package/esm2020/sidebar/sidebar-animations.mjs +23 -23
  448. package/esm2020/sidebar/sidebar.component.mjs +146 -146
  449. package/esm2020/sidebar/sidebar.module.mjs +30 -30
  450. package/esm2020/sidepanel/index.mjs +2 -2
  451. package/esm2020/sidepanel/ptsecurity-mosaic-sidepanel.mjs +4 -4
  452. package/esm2020/sidepanel/public-api.mjs +7 -7
  453. package/esm2020/sidepanel/sidepanel-animations.mjs +26 -26
  454. package/esm2020/sidepanel/sidepanel-config.mjs +26 -26
  455. package/esm2020/sidepanel/sidepanel-container.component.mjs +106 -106
  456. package/esm2020/sidepanel/sidepanel-directives.mjs +159 -159
  457. package/esm2020/sidepanel/sidepanel-ref.mjs +53 -53
  458. package/esm2020/sidepanel/sidepanel.module.mjs +74 -74
  459. package/esm2020/sidepanel/sidepanel.service.mjs +167 -167
  460. package/esm2020/splitter/index.mjs +2 -2
  461. package/esm2020/splitter/ptsecurity-mosaic-splitter.mjs +4 -4
  462. package/esm2020/splitter/public-api.mjs +3 -3
  463. package/esm2020/splitter/splitter.component.mjs +482 -482
  464. package/esm2020/splitter/splitter.module.mjs +40 -40
  465. package/esm2020/table/index.mjs +2 -2
  466. package/esm2020/table/ptsecurity-mosaic-table.mjs +4 -4
  467. package/esm2020/table/public-api.mjs +3 -3
  468. package/esm2020/table/table.component.mjs +16 -16
  469. package/esm2020/table/table.module.mjs +30 -30
  470. package/esm2020/tabs/index.mjs +2 -2
  471. package/esm2020/tabs/paginated-tab-header.mjs +479 -479
  472. package/esm2020/tabs/ptsecurity-mosaic-tabs.mjs +4 -4
  473. package/esm2020/tabs/public-api.mjs +11 -11
  474. package/esm2020/tabs/tab-body.component.mjs +178 -178
  475. package/esm2020/tabs/tab-content.directive.mjs +15 -15
  476. package/esm2020/tabs/tab-group.component.mjs +350 -350
  477. package/esm2020/tabs/tab-header.component.mjs +67 -67
  478. package/esm2020/tabs/tab-label-wrapper.directive.mjs +78 -78
  479. package/esm2020/tabs/tab-label.directive.mjs +17 -17
  480. package/esm2020/tabs/tab-nav-bar/index.mjs +2 -2
  481. package/esm2020/tabs/tab-nav-bar/tab-nav-bar.mjs +110 -110
  482. package/esm2020/tabs/tab.component.mjs +133 -133
  483. package/esm2020/tabs/tabs-animations.mjs +24 -24
  484. package/esm2020/tabs/tabs.module.mjs +104 -104
  485. package/esm2020/tags/index.mjs +2 -2
  486. package/esm2020/tags/ptsecurity-mosaic-tags.mjs +4 -4
  487. package/esm2020/tags/public-api.mjs +6 -6
  488. package/esm2020/tags/tag-default-options.mjs +4 -4
  489. package/esm2020/tags/tag-input.mjs +229 -229
  490. package/esm2020/tags/tag-list.component.mjs +722 -722
  491. package/esm2020/tags/tag-text-control.mjs +2 -2
  492. package/esm2020/tags/tag.component.mjs +375 -377
  493. package/esm2020/tags/tag.module.mjs +56 -56
  494. package/esm2020/textarea/index.mjs +2 -2
  495. package/esm2020/textarea/ptsecurity-mosaic-textarea.mjs +4 -4
  496. package/esm2020/textarea/public-api.mjs +3 -3
  497. package/esm2020/textarea/textarea.component.mjs +269 -269
  498. package/esm2020/textarea/textarea.module.mjs +21 -21
  499. package/esm2020/timepicker/index.mjs +2 -2
  500. package/esm2020/timepicker/ptsecurity-mosaic-timepicker.mjs +4 -4
  501. package/esm2020/timepicker/public-api.mjs +4 -4
  502. package/esm2020/timepicker/timepicker.constants.mjs +25 -25
  503. package/esm2020/timepicker/timepicker.directive.mjs +676 -653
  504. package/esm2020/timepicker/timepicker.module.mjs +34 -34
  505. package/esm2020/toggle/index.mjs +2 -2
  506. package/esm2020/toggle/ptsecurity-mosaic-toggle.mjs +4 -4
  507. package/esm2020/toggle/public-api.mjs +3 -3
  508. package/esm2020/toggle/toggle.component.mjs +158 -158
  509. package/esm2020/toggle/toggle.module.mjs +20 -20
  510. package/esm2020/tooltip/index.mjs +2 -2
  511. package/esm2020/tooltip/ptsecurity-mosaic-tooltip.mjs +4 -4
  512. package/esm2020/tooltip/public-api.mjs +3 -3
  513. package/esm2020/tooltip/tooltip.animations.mjs +19 -19
  514. package/esm2020/tooltip/tooltip.component.mjs +295 -295
  515. package/esm2020/tooltip/tooltip.module.mjs +43 -43
  516. package/esm2020/tree/control/base-tree-control.mjs +60 -60
  517. package/esm2020/tree/control/flat-tree-control.mjs +123 -123
  518. package/esm2020/tree/control/nested-tree-control.mjs +41 -41
  519. package/esm2020/tree/control/tree-control.mjs +2 -2
  520. package/esm2020/tree/data-source/flat-data-source.mjs +162 -162
  521. package/esm2020/tree/data-source/nested-data-source.mjs +30 -30
  522. package/esm2020/tree/index.mjs +2 -2
  523. package/esm2020/tree/node.mjs +31 -31
  524. package/esm2020/tree/outlet.mjs +15 -15
  525. package/esm2020/tree/padding.directive.mjs +110 -113
  526. package/esm2020/tree/ptsecurity-mosaic-tree.mjs +4 -4
  527. package/esm2020/tree/public-api.mjs +16 -16
  528. package/esm2020/tree/toggle.mjs +80 -80
  529. package/esm2020/tree/tree-base.mjs +243 -243
  530. package/esm2020/tree/tree-errors.mjs +36 -36
  531. package/esm2020/tree/tree-option.component.mjs +236 -234
  532. package/esm2020/tree/tree-selection.component.mjs +540 -535
  533. package/esm2020/tree/tree.mjs +15 -15
  534. package/esm2020/tree/tree.module.mjs +57 -53
  535. package/esm2020/tree-select/index.mjs +2 -2
  536. package/esm2020/tree-select/ptsecurity-mosaic-tree-select.mjs +4 -4
  537. package/esm2020/tree-select/public-api.mjs +3 -3
  538. package/esm2020/tree-select/tree-select.component.mjs +924 -925
  539. package/esm2020/tree-select/tree-select.module.mjs +47 -47
  540. package/fesm2015/ptsecurity-mosaic-autocomplete.mjs +726 -726
  541. package/fesm2015/ptsecurity-mosaic-autocomplete.mjs.map +1 -1
  542. package/fesm2015/ptsecurity-mosaic-button-toggle.mjs +367 -367
  543. package/fesm2015/ptsecurity-mosaic-button-toggle.mjs.map +1 -1
  544. package/fesm2015/ptsecurity-mosaic-button.mjs +160 -160
  545. package/fesm2015/ptsecurity-mosaic-button.mjs.map +1 -1
  546. package/fesm2015/ptsecurity-mosaic-card.mjs +96 -96
  547. package/fesm2015/ptsecurity-mosaic-card.mjs.map +1 -1
  548. package/fesm2015/ptsecurity-mosaic-checkbox.mjs +349 -348
  549. package/fesm2015/ptsecurity-mosaic-checkbox.mjs.map +1 -1
  550. package/fesm2015/ptsecurity-mosaic-core.mjs +2642 -2613
  551. package/fesm2015/ptsecurity-mosaic-core.mjs.map +1 -1
  552. package/fesm2015/ptsecurity-mosaic-datepicker.mjs +2687 -2649
  553. package/fesm2015/ptsecurity-mosaic-datepicker.mjs.map +1 -1
  554. package/fesm2015/ptsecurity-mosaic-design-tokens.mjs +2426 -2173
  555. package/fesm2015/ptsecurity-mosaic-design-tokens.mjs.map +1 -1
  556. package/fesm2015/ptsecurity-mosaic-divider.mjs +48 -48
  557. package/fesm2015/ptsecurity-mosaic-divider.mjs.map +1 -1
  558. package/fesm2015/ptsecurity-mosaic-dl.mjs +108 -108
  559. package/fesm2015/ptsecurity-mosaic-dl.mjs.map +1 -1
  560. package/fesm2015/ptsecurity-mosaic-dropdown.mjs +1069 -1065
  561. package/fesm2015/ptsecurity-mosaic-dropdown.mjs.map +1 -1
  562. package/fesm2015/ptsecurity-mosaic-form-field.mjs +506 -506
  563. package/fesm2015/ptsecurity-mosaic-form-field.mjs.map +1 -1
  564. package/fesm2015/ptsecurity-mosaic-icon.mjs +73 -73
  565. package/fesm2015/ptsecurity-mosaic-icon.mjs.map +1 -1
  566. package/fesm2015/ptsecurity-mosaic-input.mjs +975 -975
  567. package/fesm2015/ptsecurity-mosaic-input.mjs.map +1 -1
  568. package/fesm2015/ptsecurity-mosaic-link.mjs +121 -121
  569. package/fesm2015/ptsecurity-mosaic-link.mjs.map +1 -1
  570. package/fesm2015/ptsecurity-mosaic-list.mjs +762 -763
  571. package/fesm2015/ptsecurity-mosaic-list.mjs.map +1 -1
  572. package/fesm2015/ptsecurity-mosaic-modal.mjs +824 -824
  573. package/fesm2015/ptsecurity-mosaic-modal.mjs.map +1 -1
  574. package/fesm2015/ptsecurity-mosaic-navbar.mjs +993 -995
  575. package/fesm2015/ptsecurity-mosaic-navbar.mjs.map +1 -1
  576. package/fesm2015/ptsecurity-mosaic-popover.mjs +364 -364
  577. package/fesm2015/ptsecurity-mosaic-popover.mjs.map +1 -1
  578. package/fesm2015/ptsecurity-mosaic-progress-bar.mjs +61 -61
  579. package/fesm2015/ptsecurity-mosaic-progress-bar.mjs.map +1 -1
  580. package/fesm2015/ptsecurity-mosaic-progress-spinner.mjs +65 -65
  581. package/fesm2015/ptsecurity-mosaic-progress-spinner.mjs.map +1 -1
  582. package/fesm2015/ptsecurity-mosaic-radio.mjs +464 -464
  583. package/fesm2015/ptsecurity-mosaic-radio.mjs.map +1 -1
  584. package/fesm2015/ptsecurity-mosaic-select.mjs +1203 -1205
  585. package/fesm2015/ptsecurity-mosaic-select.mjs.map +1 -1
  586. package/fesm2015/ptsecurity-mosaic-sidebar.mjs +185 -185
  587. package/fesm2015/ptsecurity-mosaic-sidebar.mjs.map +1 -1
  588. package/fesm2015/ptsecurity-mosaic-sidepanel.mjs +555 -555
  589. package/fesm2015/ptsecurity-mosaic-sidepanel.mjs.map +1 -1
  590. package/fesm2015/ptsecurity-mosaic-splitter.mjs +511 -511
  591. package/fesm2015/ptsecurity-mosaic-splitter.mjs.map +1 -1
  592. package/fesm2015/ptsecurity-mosaic-table.mjs +36 -36
  593. package/fesm2015/ptsecurity-mosaic-table.mjs.map +1 -1
  594. package/fesm2015/ptsecurity-mosaic-tabs.mjs +1460 -1460
  595. package/fesm2015/ptsecurity-mosaic-tabs.mjs.map +1 -1
  596. package/fesm2015/ptsecurity-mosaic-tags.mjs +1342 -1344
  597. package/fesm2015/ptsecurity-mosaic-tags.mjs.map +1 -1
  598. package/fesm2015/ptsecurity-mosaic-textarea.mjs +274 -274
  599. package/fesm2015/ptsecurity-mosaic-textarea.mjs.map +1 -1
  600. package/fesm2015/ptsecurity-mosaic-timepicker.mjs +718 -695
  601. package/fesm2015/ptsecurity-mosaic-timepicker.mjs.map +1 -1
  602. package/fesm2015/ptsecurity-mosaic-toggle.mjs +163 -163
  603. package/fesm2015/ptsecurity-mosaic-toggle.mjs.map +1 -1
  604. package/fesm2015/ptsecurity-mosaic-tooltip.mjs +344 -344
  605. package/fesm2015/ptsecurity-mosaic-tooltip.mjs.map +1 -1
  606. package/fesm2015/ptsecurity-mosaic-tree-select.mjs +940 -940
  607. package/fesm2015/ptsecurity-mosaic-tree-select.mjs.map +1 -1
  608. package/fesm2015/ptsecurity-mosaic-tree.mjs +1682 -1676
  609. package/fesm2015/ptsecurity-mosaic-tree.mjs.map +1 -1
  610. package/fesm2015/ptsecurity-mosaic.mjs +2 -2
  611. package/fesm2020/ptsecurity-mosaic-autocomplete.mjs +722 -722
  612. package/fesm2020/ptsecurity-mosaic-autocomplete.mjs.map +1 -1
  613. package/fesm2020/ptsecurity-mosaic-button-toggle.mjs +365 -365
  614. package/fesm2020/ptsecurity-mosaic-button-toggle.mjs.map +1 -1
  615. package/fesm2020/ptsecurity-mosaic-button.mjs +160 -160
  616. package/fesm2020/ptsecurity-mosaic-button.mjs.map +1 -1
  617. package/fesm2020/ptsecurity-mosaic-card.mjs +96 -96
  618. package/fesm2020/ptsecurity-mosaic-card.mjs.map +1 -1
  619. package/fesm2020/ptsecurity-mosaic-checkbox.mjs +347 -346
  620. package/fesm2020/ptsecurity-mosaic-checkbox.mjs.map +1 -1
  621. package/fesm2020/ptsecurity-mosaic-core.mjs +2671 -2642
  622. package/fesm2020/ptsecurity-mosaic-core.mjs.map +1 -1
  623. package/fesm2020/ptsecurity-mosaic-datepicker.mjs +2672 -2635
  624. package/fesm2020/ptsecurity-mosaic-datepicker.mjs.map +1 -1
  625. package/fesm2020/ptsecurity-mosaic-design-tokens.mjs +2426 -2173
  626. package/fesm2020/ptsecurity-mosaic-design-tokens.mjs.map +1 -1
  627. package/fesm2020/ptsecurity-mosaic-divider.mjs +48 -48
  628. package/fesm2020/ptsecurity-mosaic-divider.mjs.map +1 -1
  629. package/fesm2020/ptsecurity-mosaic-dl.mjs +108 -108
  630. package/fesm2020/ptsecurity-mosaic-dl.mjs.map +1 -1
  631. package/fesm2020/ptsecurity-mosaic-dropdown.mjs +1056 -1052
  632. package/fesm2020/ptsecurity-mosaic-dropdown.mjs.map +1 -1
  633. package/fesm2020/ptsecurity-mosaic-form-field.mjs +491 -491
  634. package/fesm2020/ptsecurity-mosaic-form-field.mjs.map +1 -1
  635. package/fesm2020/ptsecurity-mosaic-icon.mjs +71 -71
  636. package/fesm2020/ptsecurity-mosaic-icon.mjs.map +1 -1
  637. package/fesm2020/ptsecurity-mosaic-input.mjs +964 -964
  638. package/fesm2020/ptsecurity-mosaic-input.mjs.map +1 -1
  639. package/fesm2020/ptsecurity-mosaic-link.mjs +120 -120
  640. package/fesm2020/ptsecurity-mosaic-link.mjs.map +1 -1
  641. package/fesm2020/ptsecurity-mosaic-list.mjs +755 -756
  642. package/fesm2020/ptsecurity-mosaic-list.mjs.map +1 -1
  643. package/fesm2020/ptsecurity-mosaic-modal.mjs +820 -820
  644. package/fesm2020/ptsecurity-mosaic-modal.mjs.map +1 -1
  645. package/fesm2020/ptsecurity-mosaic-navbar.mjs +977 -979
  646. package/fesm2020/ptsecurity-mosaic-navbar.mjs.map +1 -1
  647. package/fesm2020/ptsecurity-mosaic-popover.mjs +360 -360
  648. package/fesm2020/ptsecurity-mosaic-popover.mjs.map +1 -1
  649. package/fesm2020/ptsecurity-mosaic-progress-bar.mjs +61 -61
  650. package/fesm2020/ptsecurity-mosaic-progress-bar.mjs.map +1 -1
  651. package/fesm2020/ptsecurity-mosaic-progress-spinner.mjs +65 -65
  652. package/fesm2020/ptsecurity-mosaic-progress-spinner.mjs.map +1 -1
  653. package/fesm2020/ptsecurity-mosaic-radio.mjs +462 -462
  654. package/fesm2020/ptsecurity-mosaic-radio.mjs.map +1 -1
  655. package/fesm2020/ptsecurity-mosaic-select.mjs +1198 -1201
  656. package/fesm2020/ptsecurity-mosaic-select.mjs.map +1 -1
  657. package/fesm2020/ptsecurity-mosaic-sidebar.mjs +185 -185
  658. package/fesm2020/ptsecurity-mosaic-sidebar.mjs.map +1 -1
  659. package/fesm2020/ptsecurity-mosaic-sidepanel.mjs +552 -552
  660. package/fesm2020/ptsecurity-mosaic-sidepanel.mjs.map +1 -1
  661. package/fesm2020/ptsecurity-mosaic-splitter.mjs +511 -511
  662. package/fesm2020/ptsecurity-mosaic-splitter.mjs.map +1 -1
  663. package/fesm2020/ptsecurity-mosaic-table.mjs +36 -36
  664. package/fesm2020/ptsecurity-mosaic-table.mjs.map +1 -1
  665. package/fesm2020/ptsecurity-mosaic-tabs.mjs +1445 -1445
  666. package/fesm2020/ptsecurity-mosaic-tabs.mjs.map +1 -1
  667. package/fesm2020/ptsecurity-mosaic-tags.mjs +1335 -1337
  668. package/fesm2020/ptsecurity-mosaic-tags.mjs.map +1 -1
  669. package/fesm2020/ptsecurity-mosaic-textarea.mjs +272 -272
  670. package/fesm2020/ptsecurity-mosaic-textarea.mjs.map +1 -1
  671. package/fesm2020/ptsecurity-mosaic-timepicker.mjs +715 -692
  672. package/fesm2020/ptsecurity-mosaic-timepicker.mjs.map +1 -1
  673. package/fesm2020/ptsecurity-mosaic-toggle.mjs +163 -163
  674. package/fesm2020/ptsecurity-mosaic-toggle.mjs.map +1 -1
  675. package/fesm2020/ptsecurity-mosaic-tooltip.mjs +336 -336
  676. package/fesm2020/ptsecurity-mosaic-tooltip.mjs.map +1 -1
  677. package/fesm2020/ptsecurity-mosaic-tree-select.mjs +937 -938
  678. package/fesm2020/ptsecurity-mosaic-tree-select.mjs.map +1 -1
  679. package/fesm2020/ptsecurity-mosaic-tree.mjs +1669 -1663
  680. package/fesm2020/ptsecurity-mosaic-tree.mjs.map +1 -1
  681. package/fesm2020/ptsecurity-mosaic.mjs +2 -2
  682. package/form-field/cleaner.d.ts +7 -7
  683. package/form-field/form-field-control.d.ts +37 -37
  684. package/form-field/form-field-errors.d.ts +2 -2
  685. package/form-field/form-field.d.ts +69 -69
  686. package/form-field/form-field.module.d.ts +15 -15
  687. package/form-field/hint.d.ts +6 -6
  688. package/form-field/index.d.ts +1 -1
  689. package/form-field/password-hint.d.ts +40 -40
  690. package/form-field/prefix.d.ts +5 -5
  691. package/form-field/ptsecurity-mosaic-form-field.d.ts +5 -5
  692. package/form-field/public-api.d.ts +10 -10
  693. package/form-field/stepper.d.ts +11 -11
  694. package/form-field/suffix.d.ts +5 -5
  695. package/icon/icon.component.d.ts +18 -18
  696. package/icon/icon.module.d.ts +10 -10
  697. package/icon/index.d.ts +1 -1
  698. package/icon/ptsecurity-mosaic-icon.d.ts +5 -5
  699. package/icon/public-api.d.ts +2 -2
  700. package/index.d.ts +1 -1
  701. package/input/index.d.ts +1 -1
  702. package/input/input-errors.d.ts +1 -1
  703. package/input/input-number-validators.d.ts +39 -39
  704. package/input/input-number.d.ts +33 -33
  705. package/input/input-password.d.ts +121 -121
  706. package/input/input-value-accessor.d.ts +4 -4
  707. package/input/input.d.ts +116 -116
  708. package/input/input.module.d.ts +14 -14
  709. package/input/ptsecurity-mosaic-input.d.ts +5 -5
  710. package/input/public-api.d.ts +6 -6
  711. package/link/index.d.ts +1 -1
  712. package/link/link.component.d.ts +38 -38
  713. package/link/link.module.d.ts +9 -9
  714. package/link/ptsecurity-mosaic-link.d.ts +5 -5
  715. package/link/public-api.d.ts +2 -2
  716. package/list/index.d.ts +1 -1
  717. package/list/list-selection.component.d.ts +168 -168
  718. package/list/list.component.d.ts +18 -18
  719. package/list/list.module.d.ts +11 -11
  720. package/list/ptsecurity-mosaic-list.d.ts +5 -5
  721. package/list/public-api.d.ts +3 -3
  722. package/modal/README.md +33 -33
  723. package/modal/css-unit.pipe.d.ts +7 -7
  724. package/modal/index.d.ts +1 -1
  725. package/modal/modal-control.service.d.ts +20 -20
  726. package/modal/modal-ref.class.d.ts +36 -36
  727. package/modal/modal-util.d.ts +12 -12
  728. package/modal/modal.component.d.ts +126 -126
  729. package/modal/modal.directive.d.ts +17 -17
  730. package/modal/modal.module.d.ts +14 -14
  731. package/modal/modal.service.d.ts +33 -33
  732. package/modal/modal.type.d.ts +59 -59
  733. package/modal/ptsecurity-mosaic-modal.d.ts +5 -5
  734. package/modal/public-api.d.ts +6 -6
  735. package/navbar/README.md +41 -41
  736. package/navbar/index.d.ts +1 -1
  737. package/navbar/navbar-item.component.d.ts +161 -161
  738. package/navbar/navbar.component.d.ts +58 -58
  739. package/navbar/navbar.module.d.ts +14 -14
  740. package/navbar/ptsecurity-mosaic-navbar.d.ts +5 -5
  741. package/navbar/public-api.d.ts +4 -4
  742. package/navbar/vertical-navbar.animation.d.ts +2 -2
  743. package/navbar/vertical-navbar.component.d.ts +23 -23
  744. package/package.json +13 -10
  745. package/popover/README.md +32 -32
  746. package/popover/index.d.ts +1 -1
  747. package/popover/popover-animations.d.ts +4 -4
  748. package/popover/popover-confirm.component.d.ts +33 -33
  749. package/popover/popover.component.d.ts +74 -74
  750. package/popover/popover.module.d.ts +12 -12
  751. package/popover/ptsecurity-mosaic-popover.d.ts +5 -5
  752. package/popover/public-api.d.ts +4 -4
  753. package/prebuilt-themes/dark-theme.css +1 -1
  754. package/prebuilt-themes/default-theme.css +1 -1
  755. package/progress-bar/index.d.ts +1 -1
  756. package/progress-bar/progress-bar.component.d.ts +18 -18
  757. package/progress-bar/progress-bar.module.d.ts +9 -9
  758. package/progress-bar/ptsecurity-mosaic-progress-bar.d.ts +5 -5
  759. package/progress-bar/public-api.d.ts +2 -2
  760. package/progress-spinner/index.d.ts +1 -1
  761. package/progress-spinner/progress-spinner.component.d.ts +19 -19
  762. package/progress-spinner/progress-spinner.module.d.ts +9 -9
  763. package/progress-spinner/ptsecurity-mosaic-progress-spinner.d.ts +5 -5
  764. package/progress-spinner/public-api.d.ts +2 -2
  765. package/ptsecurity-mosaic.d.ts +5 -5
  766. package/public-api.d.ts +1 -1
  767. package/radio/index.d.ts +1 -1
  768. package/radio/ptsecurity-mosaic-radio.d.ts +5 -5
  769. package/radio/public-api.d.ts +2 -2
  770. package/radio/radio.component.d.ts +207 -207
  771. package/radio/radio.module.d.ts +10 -10
  772. package/schematics/README.md +35 -35
  773. package/select/index.d.ts +1 -1
  774. package/select/ptsecurity-mosaic-select.d.ts +5 -5
  775. package/select/public-api.d.ts +3 -3
  776. package/select/select-option.directive.d.ts +20 -20
  777. package/select/select.component.d.ts +307 -307
  778. package/select/select.module.d.ts +15 -15
  779. package/sidebar/index.d.ts +1 -1
  780. package/sidebar/ptsecurity-mosaic-sidebar.d.ts +5 -5
  781. package/sidebar/public-api.d.ts +2 -2
  782. package/sidebar/sidebar-animations.d.ts +8 -8
  783. package/sidebar/sidebar.component.d.ts +53 -53
  784. package/sidebar/sidebar.module.d.ts +8 -8
  785. package/sidepanel/index.d.ts +1 -1
  786. package/sidepanel/ptsecurity-mosaic-sidepanel.d.ts +5 -5
  787. package/sidepanel/public-api.d.ts +6 -6
  788. package/sidepanel/sidepanel-animations.d.ts +14 -14
  789. package/sidepanel/sidepanel-config.d.ts +25 -25
  790. package/sidepanel/sidepanel-container.component.d.ts +45 -45
  791. package/sidepanel/sidepanel-directives.d.ts +50 -50
  792. package/sidepanel/sidepanel-ref.d.ts +24 -24
  793. package/sidepanel/sidepanel.module.d.ts +15 -15
  794. package/sidepanel/sidepanel.service.d.ts +57 -57
  795. package/splitter/index.d.ts +1 -1
  796. package/splitter/ptsecurity-mosaic-splitter.d.ts +5 -5
  797. package/splitter/public-api.d.ts +2 -2
  798. package/splitter/splitter.component.d.ts +130 -130
  799. package/splitter/splitter.module.d.ts +9 -9
  800. package/table/index.d.ts +1 -1
  801. package/table/ptsecurity-mosaic-table.d.ts +5 -5
  802. package/table/public-api.d.ts +2 -2
  803. package/table/table.component.d.ts +5 -5
  804. package/table/table.module.d.ts +10 -10
  805. package/tabs/index.d.ts +1 -1
  806. package/tabs/paginated-tab-header.d.ts +179 -179
  807. package/tabs/ptsecurity-mosaic-tabs.d.ts +5 -5
  808. package/tabs/public-api.d.ts +10 -10
  809. package/tabs/tab-body.component.d.ts +95 -95
  810. package/tabs/tab-content.directive.d.ts +9 -9
  811. package/tabs/tab-group.component.d.ts +133 -133
  812. package/tabs/tab-header.component.d.ts +35 -35
  813. package/tabs/tab-label-wrapper.directive.d.ts +30 -30
  814. package/tabs/tab-label.directive.d.ts +9 -9
  815. package/tabs/tab-nav-bar/index.d.ts +1 -1
  816. package/tabs/tab-nav-bar/tab-nav-bar.d.ts +38 -38
  817. package/tabs/tab.component.d.ts +66 -66
  818. package/tabs/tabs-animations.d.ts +4 -4
  819. package/tabs/tabs.module.d.ts +20 -20
  820. package/tags/index.d.ts +1 -1
  821. package/tags/ptsecurity-mosaic-tags.d.ts +5 -5
  822. package/tags/public-api.d.ts +5 -5
  823. package/tags/tag-default-options.d.ts +8 -8
  824. package/tags/tag-input.d.ts +77 -77
  825. package/tags/tag-list.component.d.ts +240 -240
  826. package/tags/tag-text-control.d.ts +10 -10
  827. package/tags/tag.component.d.ts +135 -135
  828. package/tags/tag.module.d.ts +11 -11
  829. package/textarea/index.d.ts +1 -1
  830. package/textarea/ptsecurity-mosaic-textarea.d.ts +5 -5
  831. package/textarea/public-api.d.ts +2 -2
  832. package/textarea/textarea.component.d.ts +111 -111
  833. package/textarea/textarea.module.d.ts +11 -11
  834. package/timepicker/index.d.ts +1 -1
  835. package/timepicker/ptsecurity-mosaic-timepicker.d.ts +5 -5
  836. package/timepicker/public-api.d.ts +3 -3
  837. package/timepicker/timepicker.constants.d.ts +20 -20
  838. package/timepicker/timepicker.directive.d.ts +147 -142
  839. package/timepicker/timepicker.module.d.ts +11 -11
  840. package/toggle/index.d.ts +1 -1
  841. package/toggle/ptsecurity-mosaic-toggle.d.ts +5 -5
  842. package/toggle/public-api.d.ts +2 -2
  843. package/toggle/toggle.component.d.ts +54 -54
  844. package/toggle/toggle.module.d.ts +10 -10
  845. package/tooltip/index.d.ts +1 -1
  846. package/tooltip/ptsecurity-mosaic-tooltip.d.ts +5 -5
  847. package/tooltip/public-api.d.ts +2 -2
  848. package/tooltip/tooltip.animations.d.ts +8 -8
  849. package/tooltip/tooltip.component.d.ts +91 -91
  850. package/tooltip/tooltip.module.d.ts +9 -9
  851. package/tree/control/base-tree-control.d.ts +40 -40
  852. package/tree/control/flat-tree-control.d.ts +48 -48
  853. package/tree/control/nested-tree-control.d.ts +19 -19
  854. package/tree/control/tree-control.d.ts +44 -44
  855. package/tree/data-source/flat-data-source.d.ts +80 -80
  856. package/tree/data-source/nested-data-source.d.ts +15 -15
  857. package/tree/index.d.ts +1 -1
  858. package/tree/node.d.ts +34 -34
  859. package/tree/outlet.d.ts +9 -9
  860. package/tree/padding.directive.d.ts +45 -47
  861. package/tree/ptsecurity-mosaic-tree.d.ts +5 -5
  862. package/tree/public-api.d.ts +15 -15
  863. package/tree/toggle.d.ts +28 -28
  864. package/tree/tree-base.d.ts +97 -97
  865. package/tree/tree-errors.d.ts +25 -25
  866. package/tree/tree-option.component.d.ts +68 -68
  867. package/tree/tree-selection.component.d.ts +132 -130
  868. package/tree/tree.d.ts +6 -6
  869. package/tree/tree.module.d.ts +16 -16
  870. package/tree-select/index.d.ts +1 -1
  871. package/tree-select/ptsecurity-mosaic-tree-select.d.ts +5 -5
  872. package/tree-select/public-api.d.ts +2 -2
  873. package/tree-select/tree-select.component.d.ts +269 -269
  874. package/tree-select/tree-select.module.d.ts +14 -14
  875. package/schematics/collection.json +0 -4
  876. package/schematics/migration.json +0 -10
  877. package/schematics/ng-update/data/attribute-selectors.d.ts +0 -2
  878. package/schematics/ng-update/data/attribute-selectors.js +0 -5
  879. package/schematics/ng-update/data/attribute-selectors.js.map +0 -1
  880. package/schematics/ng-update/data/class-names.d.ts +0 -2
  881. package/schematics/ng-update/data/class-names.js +0 -5
  882. package/schematics/ng-update/data/class-names.js.map +0 -1
  883. package/schematics/ng-update/data/constructor-checks.d.ts +0 -2
  884. package/schematics/ng-update/data/constructor-checks.js +0 -5
  885. package/schematics/ng-update/data/constructor-checks.js.map +0 -1
  886. package/schematics/ng-update/data/css-selectors.d.ts +0 -2
  887. package/schematics/ng-update/data/css-selectors.js +0 -5
  888. package/schematics/ng-update/data/css-selectors.js.map +0 -1
  889. package/schematics/ng-update/data/element-selectors.d.ts +0 -2
  890. package/schematics/ng-update/data/element-selectors.js +0 -5
  891. package/schematics/ng-update/data/element-selectors.js.map +0 -1
  892. package/schematics/ng-update/data/index.d.ts +0 -10
  893. package/schematics/ng-update/data/index.js +0 -14
  894. package/schematics/ng-update/data/index.js.map +0 -1
  895. package/schematics/ng-update/data/input-names.d.ts +0 -2
  896. package/schematics/ng-update/data/input-names.js +0 -35
  897. package/schematics/ng-update/data/input-names.js.map +0 -1
  898. package/schematics/ng-update/data/method-call-checks.d.ts +0 -2
  899. package/schematics/ng-update/data/method-call-checks.js +0 -5
  900. package/schematics/ng-update/data/method-call-checks.js.map +0 -1
  901. package/schematics/ng-update/data/output-names.d.ts +0 -2
  902. package/schematics/ng-update/data/output-names.js +0 -5
  903. package/schematics/ng-update/data/output-names.js.map +0 -1
  904. package/schematics/ng-update/data/property-names.d.ts +0 -2
  905. package/schematics/ng-update/data/property-names.js +0 -5
  906. package/schematics/ng-update/data/property-names.js.map +0 -1
  907. package/schematics/ng-update/data/symbol-removal.d.ts +0 -2
  908. package/schematics/ng-update/data/symbol-removal.js +0 -5
  909. package/schematics/ng-update/data/symbol-removal.js.map +0 -1
  910. package/schematics/ng-update/index.d.ts +0 -2
  911. package/schematics/ng-update/index.js +0 -23
  912. package/schematics/ng-update/index.js.map +0 -1
  913. package/schematics/ng-update/update-9.0.0/mosaic-symbols.json +0 -255
  914. package/schematics/ng-update/update-9.0.0/secondary-entry-points-migration.d.ts +0 -7
  915. package/schematics/ng-update/update-9.0.0/secondary-entry-points-migration.js +0 -154
  916. package/schematics/ng-update/update-9.0.0/secondary-entry-points-migration.js.map +0 -1
  917. package/schematics/ng-update/upgrade-data.d.ts +0 -2
  918. package/schematics/ng-update/upgrade-data.js +0 -17
  919. package/schematics/ng-update/upgrade-data.js.map +0 -1
  920. package/schematics/tsconfig.json +0 -29
  921. package/schematics/tsconfig.lib-test.json +0 -8
  922. package/schematics/tsconfig.lib.json +0 -17
@@ -1,1707 +1,1713 @@
1
- import * as i2 from '@angular/common';
1
+ import * as i2$1 from '@angular/common';
2
2
  import { CommonModule } from '@angular/common';
3
3
  import * as i0 from '@angular/core';
4
- import { Directive, Input, ViewChild, ContentChildren, forwardRef, Inject, Component, ViewEncapsulation, ChangeDetectionStrategy, InjectionToken, EventEmitter, ContentChild, Output, Optional, QueryList, Attribute, NgModule } from '@angular/core';
4
+ import { Directive, Input, ViewChild, ContentChildren, forwardRef, Inject, Optional, Component, ViewEncapsulation, ChangeDetectionStrategy, InjectionToken, EventEmitter, ContentChild, Output, QueryList, Attribute, NgModule } from '@angular/core';
5
5
  import * as i1 from '@ptsecurity/mosaic/core';
6
6
  import { mixinDisabled, MC_OPTION_ACTION_PARENT, McPseudoCheckbox, McOptionActionComponent, MultipleMode, getMcSelectNonArrayValueError, McPseudoCheckboxModule } from '@ptsecurity/mosaic/core';
7
- import * as i3 from '@angular/cdk/bidi';
8
- import { coerceBooleanProperty, coerceNumberProperty } from '@angular/cdk/coercion';
7
+ import { BehaviorSubject, Subject, Observable, of, merge, asyncScheduler } from 'rxjs';
8
+ import * as i1$1 from 'rxjs/internal/scheduler/AsyncScheduler';
9
+ import { AsyncScheduler } from 'rxjs/internal/scheduler/AsyncScheduler';
10
+ import * as i2 from '@angular/cdk/bidi';
11
+ import { coerceNumberProperty, coerceBooleanProperty } from '@angular/cdk/coercion';
9
12
  import { TreeSizePaddingLeft } from '@ptsecurity/mosaic/design-tokens';
10
- import { BehaviorSubject, Subject, Observable, of, merge } from 'rxjs';
11
13
  import { takeUntil, map, take, delay } from 'rxjs/operators';
12
14
  import { TAB, hasModifierKey, SPACE, LEFT_ARROW, RIGHT_ARROW, isVerticalMovement, isSelectAll, isCopy, DOWN_ARROW, UP_ARROW, ENTER, HOME, END, PAGE_UP, PAGE_DOWN } from '@ptsecurity/cdk/keycodes';
13
15
  import { McDropdownTrigger } from '@ptsecurity/mosaic/dropdown';
14
16
  import { McTooltipTrigger } from '@ptsecurity/mosaic/tooltip';
15
- import * as i1$1 from '@angular/cdk/clipboard';
17
+ import * as i2$2 from '@angular/cdk/clipboard';
16
18
  import { SelectionModel, DataSource } from '@angular/cdk/collections';
17
19
  import { NG_VALUE_ACCESSOR } from '@angular/forms';
18
20
  import { FocusKeyManager } from '@ptsecurity/cdk/a11y';
19
21
 
20
- /** Context provided to the tree node component. */
21
- class McTreeNodeOutletContext {
22
- constructor(data) {
23
- this.$implicit = data;
24
- }
25
- }
26
- /**
27
- * Data node definition for the McTree.
28
- * Captures the node's template and a when predicate that describes when this node should be used.
29
- */
30
- class McTreeNodeDef {
31
- /** @docs-private */
32
- constructor(template) {
33
- this.template = template;
34
- }
35
- }
36
- /** @nocollapse */ /** @nocollapse */ McTreeNodeDef.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: McTreeNodeDef, deps: [{ token: i0.TemplateRef }], target: i0.ɵɵFactoryTarget.Directive });
37
- /** @nocollapse */ /** @nocollapse */ McTreeNodeDef.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.4", type: McTreeNodeDef, selector: "[mcTreeNodeDef]", inputs: { when: ["mcTreeNodeDefWhen", "when"], data: ["mcTreeNode", "data"] }, ngImport: i0 });
38
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: McTreeNodeDef, decorators: [{
39
- type: Directive,
40
- args: [{
41
- selector: '[mcTreeNodeDef]',
42
- inputs: ['when: mcTreeNodeDefWhen']
43
- }]
44
- }], ctorParameters: function () { return [{ type: i0.TemplateRef }]; }, propDecorators: { data: [{
45
- type: Input,
46
- args: ['mcTreeNode']
22
+ /** Context provided to the tree node component. */
23
+ class McTreeNodeOutletContext {
24
+ constructor(data) {
25
+ this.$implicit = data;
26
+ }
27
+ }
28
+ /**
29
+ * Data node definition for the McTree.
30
+ * Captures the node's template and a when predicate that describes when this node should be used.
31
+ */
32
+ class McTreeNodeDef {
33
+ /** @docs-private */
34
+ constructor(template) {
35
+ this.template = template;
36
+ }
37
+ }
38
+ /** @nocollapse */ /** @nocollapse */ McTreeNodeDef.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.7", ngImport: i0, type: McTreeNodeDef, deps: [{ token: i0.TemplateRef }], target: i0.ɵɵFactoryTarget.Directive });
39
+ /** @nocollapse */ /** @nocollapse */ McTreeNodeDef.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.7", type: McTreeNodeDef, selector: "[mcTreeNodeDef]", inputs: { when: ["mcTreeNodeDefWhen", "when"], data: ["mcTreeNode", "data"] }, ngImport: i0 });
40
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.7", ngImport: i0, type: McTreeNodeDef, decorators: [{
41
+ type: Directive,
42
+ args: [{
43
+ selector: '[mcTreeNodeDef]',
44
+ inputs: ['when: mcTreeNodeDefWhen']
45
+ }]
46
+ }], ctorParameters: function () { return [{ type: i0.TemplateRef }]; }, propDecorators: { data: [{
47
+ type: Input,
48
+ args: ['mcTreeNode']
47
49
  }] } });
48
50
 
49
- class McTreeNodeOutlet {
50
- constructor(viewContainer, changeDetectorRef) {
51
- this.viewContainer = viewContainer;
52
- this.changeDetectorRef = changeDetectorRef;
53
- }
54
- }
55
- /** @nocollapse */ /** @nocollapse */ McTreeNodeOutlet.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: McTreeNodeOutlet, deps: [{ token: i0.ViewContainerRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Directive });
56
- /** @nocollapse */ /** @nocollapse */ McTreeNodeOutlet.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.4", type: McTreeNodeOutlet, selector: "[mcTreeNodeOutlet]", ngImport: i0 });
57
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: McTreeNodeOutlet, decorators: [{
58
- type: Directive,
59
- args: [{ selector: '[mcTreeNodeOutlet]' }]
51
+ class McTreeNodeOutlet {
52
+ constructor(viewContainer, changeDetectorRef) {
53
+ this.viewContainer = viewContainer;
54
+ this.changeDetectorRef = changeDetectorRef;
55
+ }
56
+ }
57
+ /** @nocollapse */ /** @nocollapse */ McTreeNodeOutlet.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.7", ngImport: i0, type: McTreeNodeOutlet, deps: [{ token: i0.ViewContainerRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Directive });
58
+ /** @nocollapse */ /** @nocollapse */ McTreeNodeOutlet.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.7", type: McTreeNodeOutlet, selector: "[mcTreeNodeOutlet]", ngImport: i0 });
59
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.7", ngImport: i0, type: McTreeNodeOutlet, decorators: [{
60
+ type: Directive,
61
+ args: [{ selector: '[mcTreeNodeOutlet]' }]
60
62
  }], ctorParameters: function () { return [{ type: i0.ViewContainerRef }, { type: i0.ChangeDetectorRef }]; } });
61
63
 
62
- /**
63
- * Returns an error to be thrown when there is no usable data.
64
- * @docs-private
65
- */
66
- function getTreeNoValidDataSourceError() {
67
- return Error(`A valid data source must be provided.`);
68
- }
69
- /**
70
- * Returns an error to be thrown when there are multiple nodes that are missing a when function.
71
- * @docs-private
72
- */
73
- function getTreeMultipleDefaultNodeDefsError() {
74
- return Error(`There can only be one default row without a when predicate function.`);
75
- }
76
- /**
77
- * Returns an error to be thrown when there are no matching node defs for a particular set of data.
78
- * @docs-private
79
- */
80
- function getTreeMissingMatchingNodeDefError() {
81
- return Error(`Could not find a matching node definition for the provided node data.`);
82
- }
83
- /**
84
- * Returns an error to be thrown when there are tree control.
85
- * @docs-private
86
- */
87
- function getTreeControlMissingError() {
88
- return Error(`Could not find a tree control for the tree.`);
89
- }
90
- /**
91
- * Returns an error to be thrown when tree control did not implement functions for flat/nested node.
92
- * @docs-private
93
- */
94
- function getTreeControlFunctionsMissingError() {
95
- return Error(`Could not find functions for nested/flat tree in tree control.`);
64
+ /**
65
+ * Returns an error to be thrown when there is no usable data.
66
+ * @docs-private
67
+ */
68
+ function getTreeNoValidDataSourceError() {
69
+ return Error(`A valid data source must be provided.`);
70
+ }
71
+ /**
72
+ * Returns an error to be thrown when there are multiple nodes that are missing a when function.
73
+ * @docs-private
74
+ */
75
+ function getTreeMultipleDefaultNodeDefsError() {
76
+ return Error(`There can only be one default row without a when predicate function.`);
77
+ }
78
+ /**
79
+ * Returns an error to be thrown when there are no matching node defs for a particular set of data.
80
+ * @docs-private
81
+ */
82
+ function getTreeMissingMatchingNodeDefError() {
83
+ return Error(`Could not find a matching node definition for the provided node data.`);
84
+ }
85
+ /**
86
+ * Returns an error to be thrown when there are tree control.
87
+ * @docs-private
88
+ */
89
+ function getTreeControlMissingError() {
90
+ return Error(`Could not find a tree control for the tree.`);
91
+ }
92
+ /**
93
+ * Returns an error to be thrown when tree control did not implement functions for flat/nested node.
94
+ * @docs-private
95
+ */
96
+ function getTreeControlFunctionsMissingError() {
97
+ return Error(`Could not find functions for nested/flat tree in tree control.`);
96
98
  }
97
99
 
98
- class McTreeBase {
99
- constructor(differs, changeDetectorRef) {
100
- this.differs = differs;
101
- this.changeDetectorRef = changeDetectorRef;
102
- // TODO(tinayuangao): Setup a listener for scrolling, emit the calculated view to viewChange.
103
- // Remove the MAX_VALUE in viewChange
104
- /**
105
- * Stream containing the latest information on what rows are being displayed on screen.
106
- * Can be used by the data source to as a heuristic of what data should be provided.
107
- */
108
- this.viewChange = new BehaviorSubject({ start: 0, end: Number.MAX_VALUE });
109
- /** Subject that emits when the component has been destroyed. */
110
- this.onDestroy = new Subject();
111
- /** Level of nodes */
112
- this.levels = new Map();
113
- }
114
- /**
115
- * Provides a stream containing the latest data array to render. Influenced by the tree's
116
- * stream of view window (what dataNodes are currently on screen).
117
- * Data source can be an observable of data array, or a dara array to render.
118
- */
119
- get dataSource() {
120
- return this._dataSource;
121
- }
122
- set dataSource(dataSource) {
123
- if (this._dataSource !== dataSource) {
124
- this.switchDataSource(dataSource);
125
- }
126
- }
127
- ngOnInit() {
128
- this.dataDiffer = this.differs.find([]).create(this.trackBy);
129
- if (!this.treeControl) {
130
- throw getTreeControlMissingError();
131
- }
132
- }
133
- ngOnDestroy() {
134
- this.nodeOutlet.viewContainer.clear();
135
- this.onDestroy.next();
136
- this.onDestroy.complete();
137
- // tslint:disable-next-line:no-unbound-method
138
- if (this._dataSource && typeof this.dataSource.disconnect === 'function') {
139
- this.dataSource.disconnect(this);
140
- }
141
- if (this.dataSubscription) {
142
- this.dataSubscription.unsubscribe();
143
- this.dataSubscription = null;
144
- }
145
- }
146
- ngAfterContentChecked() {
147
- const defaultNodeDefs = this.nodeDefs.filter((def) => !def.when);
148
- if (defaultNodeDefs.length > 1) {
149
- throw getTreeMultipleDefaultNodeDefsError();
150
- }
151
- this.defaultNodeDef = defaultNodeDefs[0];
152
- if (this.dataSource && this.nodeDefs && !this.dataSubscription) {
153
- this.observeRenderChanges();
154
- }
155
- }
156
- /** Check for changes made in the data and render each change (node added/removed/moved). */
157
- renderNodeChanges(data, dataDiffer = this.dataDiffer, viewContainer = this.nodeOutlet.viewContainer, parentData) {
158
- const changes = dataDiffer.diff(data);
159
- if (!changes) {
160
- return;
161
- }
162
- changes.forEachOperation((item, adjustedPreviousIndex, currentIndex) => {
163
- if (item.previousIndex == null) {
164
- this.insertNode(data[currentIndex], currentIndex, viewContainer, parentData);
165
- }
166
- else if (currentIndex == null) {
167
- viewContainer.remove(adjustedPreviousIndex);
168
- this.levels.delete(item.item);
169
- }
170
- else {
171
- const view = viewContainer.get(adjustedPreviousIndex);
172
- viewContainer.move(view, currentIndex);
173
- }
174
- });
175
- this.changeDetectorRef.detectChanges();
176
- }
177
- /**
178
- * Finds the matching node definition that should be used for this node data. If there is only
179
- * one node definition, it is returned. Otherwise, find the node definition that has a when
180
- * predicate that returns true with the data. If none return true, return the default node
181
- * definition.
182
- */
183
- getNodeDef(data, i) {
184
- if (this.nodeDefs.length === 1) {
185
- return this.nodeDefs.first;
186
- }
187
- const nodeDef = this.nodeDefs.find((def) => def.when && def.when(i, data)) || this.defaultNodeDef;
188
- if (!nodeDef) {
189
- throw getTreeMissingMatchingNodeDefError();
190
- }
191
- return nodeDef;
192
- }
193
- /**
194
- * Create the embedded view for the data node template and place it in the correct index location
195
- * within the data node view container.
196
- */
197
- insertNode(nodeData, index, viewContainer, parentData) {
198
- const node = this.getNodeDef(nodeData, index);
199
- // Node context that will be provided to created embedded view
200
- const context = new McTreeNodeOutletContext(nodeData);
201
- // If the tree is flat tree, then use the `getLevel` function in flat tree control
202
- // Otherwise, use the level of parent node.
203
- if (this.treeControl.getLevel) {
204
- context.level = this.treeControl.getLevel(nodeData);
205
- /* tslint:disable-next-line:no-typeof-undefined */
206
- }
207
- else if (typeof parentData !== 'undefined' && this.levels.has(parentData)) {
208
- context.level = this.levels.get(parentData) + 1;
209
- }
210
- else {
211
- context.level = 0;
212
- }
213
- this.levels.set(nodeData, context.level);
214
- // Use default tree nodeOutlet, or nested node's nodeOutlet
215
- const container = viewContainer ? viewContainer : this.nodeOutlet.viewContainer;
216
- container.createEmbeddedView(node.template, context, index);
217
- // Set the data to just created `McTreeNode`.
218
- // The `McTreeNode` created from `createEmbeddedView` will be saved in static variable
219
- // `mostRecentTreeNode`. We get it from static variable and pass the node data to it.
220
- if (McTreeNode.mostRecentTreeNode) {
221
- McTreeNode.mostRecentTreeNode.data = nodeData;
222
- }
223
- }
224
- /** Set up a subscription for the data provided by the data source. */
225
- observeRenderChanges() {
226
- let dataStream;
227
- // Cannot use `instanceof DataSource` since the data source could be a literal with
228
- // `connect` function and may not extends DataSource.
229
- // tslint:disable-next-line:no-unbound-method
230
- if (typeof this._dataSource.connect === 'function') {
231
- dataStream = this._dataSource.connect(this);
232
- }
233
- else if (this._dataSource instanceof Observable) {
234
- dataStream = this._dataSource;
235
- }
236
- else if (Array.isArray(this._dataSource)) {
237
- dataStream = of(this._dataSource);
238
- }
239
- if (dataStream) {
240
- this.dataSubscription = dataStream
241
- .pipe(takeUntil(this.onDestroy))
242
- .subscribe((data) => this.renderNodeChanges(data));
243
- }
244
- else {
245
- throw getTreeNoValidDataSourceError();
246
- }
247
- }
248
- /**
249
- * Switch to the provided data source by resetting the data and unsubscribing from the current
250
- * render change subscription if one exists. If the data source is null, interpret this by
251
- * clearing the node outlet. Otherwise start listening for new data.
252
- */
253
- switchDataSource(dataSource) {
254
- // tslint:disable-next-line:no-unbound-method
255
- if (this._dataSource && typeof this._dataSource.disconnect === 'function') {
256
- this.dataSource.disconnect(this);
257
- }
258
- if (this.dataSubscription) {
259
- this.dataSubscription.unsubscribe();
260
- this.dataSubscription = null;
261
- }
262
- // Remove the all dataNodes if there is now no data source
263
- if (!dataSource) {
264
- this.nodeOutlet.viewContainer.clear();
265
- }
266
- this._dataSource = dataSource;
267
- if (this.nodeDefs) {
268
- this.observeRenderChanges();
269
- }
270
- }
271
- }
272
- /** @nocollapse */ /** @nocollapse */ McTreeBase.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: McTreeBase, deps: [{ token: i0.IterableDiffers }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Directive });
273
- /** @nocollapse */ /** @nocollapse */ McTreeBase.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.4", type: McTreeBase, inputs: { treeControl: "treeControl", trackBy: "trackBy", dataSource: "dataSource" }, queries: [{ propertyName: "nodeDefs", predicate: McTreeNodeDef }], viewQueries: [{ propertyName: "nodeOutlet", first: true, predicate: McTreeNodeOutlet, descendants: true, static: true }], ngImport: i0 });
274
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: McTreeBase, decorators: [{
275
- type: Directive
276
- }], ctorParameters: function () { return [{ type: i0.IterableDiffers }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { treeControl: [{
277
- type: Input
278
- }], trackBy: [{
279
- type: Input
280
- }], nodeOutlet: [{
281
- type: ViewChild,
282
- args: [McTreeNodeOutlet, { static: true }]
283
- }], nodeDefs: [{
284
- type: ContentChildren,
285
- args: [McTreeNodeDef]
286
- }], dataSource: [{
287
- type: Input
288
- }] } });
289
- class McTreeNode {
290
- constructor(elementRef, tree) {
291
- this.elementRef = elementRef;
292
- this.tree = tree;
293
- this.destroyed = new Subject();
294
- McTreeNode.mostRecentTreeNode = this;
295
- }
296
- get data() {
297
- return this._data;
298
- }
299
- set data(value) {
300
- this._data = value;
301
- }
302
- get isExpanded() {
303
- return this.tree.treeControl.isExpanded(this.data);
304
- }
305
- get level() {
306
- return this.tree.treeControl.getLevel ? this.tree.treeControl.getLevel(this._data) : 0;
307
- }
308
- ngOnDestroy() {
309
- this.destroyed.next();
310
- this.destroyed.complete();
311
- }
312
- focus() {
313
- this.elementRef.nativeElement.focus();
314
- }
315
- }
316
- /**
317
- * The most recently created `McTreeNode`. We save it in static variable so we can retrieve it
318
- * in `McTree` and set the data to it.
319
- */
320
- McTreeNode.mostRecentTreeNode = null;
321
- /** @nocollapse */ /** @nocollapse */ McTreeNode.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: McTreeNode, deps: [{ token: i0.ElementRef }, { token: forwardRef(() => McTreeBase) }], target: i0.ɵɵFactoryTarget.Directive });
322
- /** @nocollapse */ /** @nocollapse */ McTreeNode.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.4", type: McTreeNode, selector: "mc-tree-node", exportAs: ["mcTreeNode"], ngImport: i0 });
323
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: McTreeNode, decorators: [{
324
- type: Directive,
325
- args: [{
326
- selector: 'mc-tree-node',
327
- exportAs: 'mcTreeNode'
328
- }]
329
- }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: McTreeBase, decorators: [{
330
- type: Inject,
331
- args: [forwardRef(() => McTreeBase)]
100
+ class McTreeBase {
101
+ constructor(differs, changeDetectorRef) {
102
+ this.differs = differs;
103
+ this.changeDetectorRef = changeDetectorRef;
104
+ // TODO(tinayuangao): Setup a listener for scrolling, emit the calculated view to viewChange.
105
+ // Remove the MAX_VALUE in viewChange
106
+ /**
107
+ * Stream containing the latest information on what rows are being displayed on screen.
108
+ * Can be used by the data source to as a heuristic of what data should be provided.
109
+ */
110
+ this.viewChange = new BehaviorSubject({ start: 0, end: Number.MAX_VALUE });
111
+ /** Subject that emits when the component has been destroyed. */
112
+ this.onDestroy = new Subject();
113
+ /** Level of nodes */
114
+ this.levels = new Map();
115
+ }
116
+ /**
117
+ * Provides a stream containing the latest data array to render. Influenced by the tree's
118
+ * stream of view window (what dataNodes are currently on screen).
119
+ * Data source can be an observable of data array, or a dara array to render.
120
+ */
121
+ get dataSource() {
122
+ return this._dataSource;
123
+ }
124
+ set dataSource(dataSource) {
125
+ if (this._dataSource !== dataSource) {
126
+ this.switchDataSource(dataSource);
127
+ }
128
+ }
129
+ ngOnInit() {
130
+ this.dataDiffer = this.differs.find([]).create(this.trackBy);
131
+ if (!this.treeControl) {
132
+ throw getTreeControlMissingError();
133
+ }
134
+ }
135
+ ngOnDestroy() {
136
+ this.nodeOutlet.viewContainer.clear();
137
+ this.onDestroy.next();
138
+ this.onDestroy.complete();
139
+ // tslint:disable-next-line:no-unbound-method
140
+ if (this._dataSource && typeof this.dataSource.disconnect === 'function') {
141
+ this.dataSource.disconnect(this);
142
+ }
143
+ if (this.dataSubscription) {
144
+ this.dataSubscription.unsubscribe();
145
+ this.dataSubscription = null;
146
+ }
147
+ }
148
+ ngAfterContentChecked() {
149
+ const defaultNodeDefs = this.nodeDefs.filter((def) => !def.when);
150
+ if (defaultNodeDefs.length > 1) {
151
+ throw getTreeMultipleDefaultNodeDefsError();
152
+ }
153
+ this.defaultNodeDef = defaultNodeDefs[0];
154
+ if (this.dataSource && this.nodeDefs && !this.dataSubscription) {
155
+ this.observeRenderChanges();
156
+ }
157
+ }
158
+ /** Check for changes made in the data and render each change (node added/removed/moved). */
159
+ renderNodeChanges(data, dataDiffer = this.dataDiffer, viewContainer = this.nodeOutlet.viewContainer, parentData) {
160
+ const changes = dataDiffer.diff(data);
161
+ if (!changes) {
162
+ return;
163
+ }
164
+ changes.forEachOperation((item, adjustedPreviousIndex, currentIndex) => {
165
+ if (item.previousIndex == null) {
166
+ this.insertNode(data[currentIndex], currentIndex, viewContainer, parentData);
167
+ }
168
+ else if (currentIndex == null) {
169
+ viewContainer.remove(adjustedPreviousIndex);
170
+ this.levels.delete(item.item);
171
+ }
172
+ else {
173
+ const view = viewContainer.get(adjustedPreviousIndex);
174
+ viewContainer.move(view, currentIndex);
175
+ }
176
+ });
177
+ this.changeDetectorRef.detectChanges();
178
+ }
179
+ /**
180
+ * Finds the matching node definition that should be used for this node data. If there is only
181
+ * one node definition, it is returned. Otherwise, find the node definition that has a when
182
+ * predicate that returns true with the data. If none return true, return the default node
183
+ * definition.
184
+ */
185
+ getNodeDef(data, i) {
186
+ if (this.nodeDefs.length === 1) {
187
+ return this.nodeDefs.first;
188
+ }
189
+ const nodeDef = this.nodeDefs.find((def) => def.when && def.when(i, data)) || this.defaultNodeDef;
190
+ if (!nodeDef) {
191
+ throw getTreeMissingMatchingNodeDefError();
192
+ }
193
+ return nodeDef;
194
+ }
195
+ /**
196
+ * Create the embedded view for the data node template and place it in the correct index location
197
+ * within the data node view container.
198
+ */
199
+ insertNode(nodeData, index, viewContainer, parentData) {
200
+ const node = this.getNodeDef(nodeData, index);
201
+ // Node context that will be provided to created embedded view
202
+ const context = new McTreeNodeOutletContext(nodeData);
203
+ // If the tree is flat tree, then use the `getLevel` function in flat tree control
204
+ // Otherwise, use the level of parent node.
205
+ if (this.treeControl.getLevel) {
206
+ context.level = this.treeControl.getLevel(nodeData);
207
+ /* tslint:disable-next-line:no-typeof-undefined */
208
+ }
209
+ else if (typeof parentData !== 'undefined' && this.levels.has(parentData)) {
210
+ context.level = this.levels.get(parentData) + 1;
211
+ }
212
+ else {
213
+ context.level = 0;
214
+ }
215
+ this.levels.set(nodeData, context.level);
216
+ // Use default tree nodeOutlet, or nested node's nodeOutlet
217
+ const container = viewContainer ? viewContainer : this.nodeOutlet.viewContainer;
218
+ container.createEmbeddedView(node.template, context, index);
219
+ // Set the data to just created `McTreeNode`.
220
+ // The `McTreeNode` created from `createEmbeddedView` will be saved in static variable
221
+ // `mostRecentTreeNode`. We get it from static variable and pass the node data to it.
222
+ if (McTreeNode.mostRecentTreeNode) {
223
+ McTreeNode.mostRecentTreeNode.data = nodeData;
224
+ }
225
+ }
226
+ /** Set up a subscription for the data provided by the data source. */
227
+ observeRenderChanges() {
228
+ let dataStream;
229
+ // Cannot use `instanceof DataSource` since the data source could be a literal with
230
+ // `connect` function and may not extends DataSource.
231
+ // tslint:disable-next-line:no-unbound-method
232
+ if (typeof this._dataSource.connect === 'function') {
233
+ dataStream = this._dataSource.connect(this);
234
+ }
235
+ else if (this._dataSource instanceof Observable) {
236
+ dataStream = this._dataSource;
237
+ }
238
+ else if (Array.isArray(this._dataSource)) {
239
+ dataStream = of(this._dataSource);
240
+ }
241
+ if (dataStream) {
242
+ this.dataSubscription = dataStream
243
+ .pipe(takeUntil(this.onDestroy))
244
+ .subscribe((data) => this.renderNodeChanges(data));
245
+ }
246
+ else {
247
+ throw getTreeNoValidDataSourceError();
248
+ }
249
+ }
250
+ /**
251
+ * Switch to the provided data source by resetting the data and unsubscribing from the current
252
+ * render change subscription if one exists. If the data source is null, interpret this by
253
+ * clearing the node outlet. Otherwise start listening for new data.
254
+ */
255
+ switchDataSource(dataSource) {
256
+ // tslint:disable-next-line:no-unbound-method
257
+ if (this._dataSource && typeof this._dataSource.disconnect === 'function') {
258
+ this.dataSource.disconnect(this);
259
+ }
260
+ if (this.dataSubscription) {
261
+ this.dataSubscription.unsubscribe();
262
+ this.dataSubscription = null;
263
+ }
264
+ // Remove the all dataNodes if there is now no data source
265
+ if (!dataSource) {
266
+ this.nodeOutlet.viewContainer.clear();
267
+ }
268
+ this._dataSource = dataSource;
269
+ if (this.nodeDefs) {
270
+ this.observeRenderChanges();
271
+ }
272
+ }
273
+ }
274
+ /** @nocollapse */ /** @nocollapse */ McTreeBase.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.7", ngImport: i0, type: McTreeBase, deps: [{ token: i0.IterableDiffers }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Directive });
275
+ /** @nocollapse */ /** @nocollapse */ McTreeBase.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.7", type: McTreeBase, inputs: { treeControl: "treeControl", trackBy: "trackBy", dataSource: "dataSource" }, queries: [{ propertyName: "nodeDefs", predicate: McTreeNodeDef }], viewQueries: [{ propertyName: "nodeOutlet", first: true, predicate: McTreeNodeOutlet, descendants: true, static: true }], ngImport: i0 });
276
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.7", ngImport: i0, type: McTreeBase, decorators: [{
277
+ type: Directive
278
+ }], ctorParameters: function () { return [{ type: i0.IterableDiffers }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { treeControl: [{
279
+ type: Input
280
+ }], trackBy: [{
281
+ type: Input
282
+ }], nodeOutlet: [{
283
+ type: ViewChild,
284
+ args: [McTreeNodeOutlet, { static: true }]
285
+ }], nodeDefs: [{
286
+ type: ContentChildren,
287
+ args: [McTreeNodeDef]
288
+ }], dataSource: [{
289
+ type: Input
290
+ }] } });
291
+ class McTreeNode {
292
+ constructor(elementRef, tree) {
293
+ this.elementRef = elementRef;
294
+ this.tree = tree;
295
+ this.destroyed = new Subject();
296
+ McTreeNode.mostRecentTreeNode = this;
297
+ }
298
+ get data() {
299
+ return this._data;
300
+ }
301
+ set data(value) {
302
+ this._data = value;
303
+ }
304
+ get isExpanded() {
305
+ return this.tree.treeControl.isExpanded(this.data);
306
+ }
307
+ get level() {
308
+ return this.tree.treeControl.getLevel ? this.tree.treeControl.getLevel(this._data) : 0;
309
+ }
310
+ ngOnDestroy() {
311
+ this.destroyed.next();
312
+ this.destroyed.complete();
313
+ }
314
+ focus() {
315
+ this.elementRef.nativeElement.focus();
316
+ }
317
+ }
318
+ /**
319
+ * The most recently created `McTreeNode`. We save it in static variable so we can retrieve it
320
+ * in `McTree` and set the data to it.
321
+ */
322
+ McTreeNode.mostRecentTreeNode = null;
323
+ /** @nocollapse */ /** @nocollapse */ McTreeNode.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.7", ngImport: i0, type: McTreeNode, deps: [{ token: i0.ElementRef }, { token: forwardRef(() => McTreeBase) }], target: i0.ɵɵFactoryTarget.Directive });
324
+ /** @nocollapse */ /** @nocollapse */ McTreeNode.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.7", type: McTreeNode, selector: "mc-tree-node", exportAs: ["mcTreeNode"], ngImport: i0 });
325
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.7", ngImport: i0, type: McTreeNode, decorators: [{
326
+ type: Directive,
327
+ args: [{
328
+ selector: 'mc-tree-node',
329
+ exportAs: 'mcTreeNode'
330
+ }]
331
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: McTreeBase, decorators: [{
332
+ type: Inject,
333
+ args: [forwardRef(() => McTreeBase)]
332
334
  }] }]; } });
333
335
 
334
- class McTreeNodeToggleBase {
335
- }
336
- // tslint:disable-next-line:naming-convention
337
- const McTreeNodeToggleMixinBase = mixinDisabled(McTreeNodeToggleBase);
338
- /** @docs-private */
339
- class McTreeNodeToggleBaseDirective extends McTreeNodeToggleMixinBase {
340
- constructor(tree, treeNode) {
341
- super();
342
- this.tree = tree;
343
- this.treeNode = treeNode;
344
- this._recursive = false;
345
- this.tree.treeControl.filterValue
346
- .pipe(map((value) => value?.length > 0))
347
- .subscribe((state) => this.disabled = state);
348
- }
349
- get recursive() {
350
- return this._recursive;
351
- }
352
- set recursive(value) {
353
- this._recursive = coerceBooleanProperty(value);
354
- }
355
- get iconState() {
356
- return this.tree.treeControl.isExpanded(this.node);
357
- }
358
- toggle(event) {
359
- if (this.disabled) {
360
- return;
361
- }
362
- this.recursive
363
- ? this.tree.treeControl.toggleDescendants(this.treeNode.data)
364
- : this.tree.treeControl.toggle(this.treeNode.data);
365
- event.stopPropagation();
366
- }
367
- }
368
- /** @nocollapse */ /** @nocollapse */ McTreeNodeToggleBaseDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: McTreeNodeToggleBaseDirective, deps: [{ token: McTreeBase }, { token: McTreeNode }], target: i0.ɵɵFactoryTarget.Directive });
369
- /** @nocollapse */ /** @nocollapse */ McTreeNodeToggleBaseDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.4", type: McTreeNodeToggleBaseDirective, inputs: { node: "node", recursive: ["mcTreeNodeToggleRecursive", "recursive"] }, usesInheritance: true, ngImport: i0 });
370
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: McTreeNodeToggleBaseDirective, decorators: [{
371
- type: Directive
372
- }], ctorParameters: function () { return [{ type: McTreeBase }, { type: McTreeNode }]; }, propDecorators: { node: [{
373
- type: Input
374
- }], recursive: [{
375
- type: Input,
376
- args: ['mcTreeNodeToggleRecursive']
336
+ /** Regex used to split a string on its CSS units. */
337
+ const cssUnitPattern = /([A-Za-z%]+)$/;
338
+ class McTreeNodePadding {
339
+ constructor(treeNode, tree, renderer, element, dir) {
340
+ this.treeNode = treeNode;
341
+ this.tree = tree;
342
+ this.renderer = renderer;
343
+ this.element = element;
344
+ this.dir = dir;
345
+ this._indent = 20;
346
+ /** CSS units used for the indentation value. */
347
+ this.indentUnits = 'px';
348
+ this.baseLeftPadding = parseInt(TreeSizePaddingLeft);
349
+ this.iconWidth = 24;
350
+ this.destroyed = new Subject();
351
+ this.dir?.change?.pipe(takeUntil(this.destroyed))
352
+ .subscribe(() => this.setPadding());
353
+ }
354
+ get level() {
355
+ return this._level;
356
+ }
357
+ set level(value) {
358
+ this.setLevelInput(value);
359
+ }
360
+ get indent() {
361
+ return this._indent;
362
+ }
363
+ set indent(indent) {
364
+ this.setIndentInput(indent);
365
+ }
366
+ get leftPadding() {
367
+ return (this.withIcon ? 0 : this.iconWidth) + this.baseLeftPadding;
368
+ }
369
+ ngOnInit() {
370
+ this.withIcon = this.tree.treeControl.isExpandable(this.treeNode.data);
371
+ this.setPadding();
372
+ }
373
+ ngOnDestroy() {
374
+ this.destroyed.next();
375
+ this.destroyed.complete();
376
+ }
377
+ paddingIndent() {
378
+ const nodeLevel = (this.treeNode.data && this.tree.treeControl.getLevel)
379
+ ? this.tree.treeControl.getLevel(this.treeNode.data)
380
+ : 0;
381
+ const level = this.level || nodeLevel;
382
+ return level > 0 ? `${(level * this._indent) + this.leftPadding}px` : `${this.leftPadding}px`;
383
+ }
384
+ /**
385
+ * This has been extracted to a util because of TS 4 and VE.
386
+ * View Engine doesn't support property rename inheritance.
387
+ * TS 4.0 doesn't allow properties to override accessors or vice-versa.
388
+ * @docs-private
389
+ */
390
+ setLevelInput(value) {
391
+ // Set to null as the fallback value so that _setPadding can fall back to the node level if the
392
+ // consumer set the directive as `mcTreeNodePadding=""`. We still want to take this value if
393
+ // they set 0 explicitly.
394
+ this._level = coerceNumberProperty(value, null);
395
+ this.setPadding();
396
+ }
397
+ /**
398
+ * This has been extracted to a util because of TS 4 and VE.
399
+ * View Engine doesn't support property rename inheritance.
400
+ * TS 4.0 doesn't allow properties to override accessors or vice-versa.
401
+ * @docs-private
402
+ */
403
+ setIndentInput(indent) {
404
+ let value = indent;
405
+ let units = 'px';
406
+ if (typeof indent === 'string') {
407
+ const parts = indent.split(cssUnitPattern);
408
+ value = parts[0];
409
+ units = parts[1] || units;
410
+ }
411
+ this.indentUnits = units;
412
+ this._indent = coerceNumberProperty(value);
413
+ this.setPadding();
414
+ }
415
+ setPadding() {
416
+ const padding = this.paddingIndent();
417
+ const paddingProp = this.dir?.value === 'rtl' ? 'paddingRight' : 'paddingLeft';
418
+ this.renderer.setStyle(this.element.nativeElement, paddingProp, padding);
419
+ }
420
+ }
421
+ /** @nocollapse */ /** @nocollapse */ McTreeNodePadding.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.7", ngImport: i0, type: McTreeNodePadding, deps: [{ token: McTreeNode }, { token: McTreeBase }, { token: i0.Renderer2 }, { token: i0.ElementRef }, { token: i2.Directionality, optional: true }], target: i0.ɵɵFactoryTarget.Directive });
422
+ /** @nocollapse */ /** @nocollapse */ McTreeNodePadding.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.7", type: McTreeNodePadding, selector: "[mcTreeNodePadding]", inputs: { indent: ["mcTreeNodePaddingIndent", "indent"] }, exportAs: ["mcTreeNodePadding"], ngImport: i0 });
423
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.7", ngImport: i0, type: McTreeNodePadding, decorators: [{
424
+ type: Directive,
425
+ args: [{
426
+ selector: '[mcTreeNodePadding]',
427
+ exportAs: 'mcTreeNodePadding'
428
+ }]
429
+ }], ctorParameters: function () { return [{ type: McTreeNode }, { type: McTreeBase }, { type: i0.Renderer2 }, { type: i0.ElementRef }, { type: i2.Directionality, decorators: [{
430
+ type: Optional
431
+ }] }]; }, propDecorators: { indent: [{
432
+ type: Input,
433
+ args: ['mcTreeNodePaddingIndent']
377
434
  }] } });
378
- class McTreeNodeToggleComponent extends McTreeNodeToggleBaseDirective {
379
- }
380
- /** @nocollapse */ /** @nocollapse */ McTreeNodeToggleComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: McTreeNodeToggleComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
381
- /** @nocollapse */ /** @nocollapse */ McTreeNodeToggleComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.4", type: McTreeNodeToggleComponent, selector: "mc-tree-node-toggle", inputs: { disabled: "disabled" }, host: { listeners: { "click": "toggle($event)" }, properties: { "class.mc-expanded": "iconState", "attr.disabled": "disabled || null" }, classAttribute: "mc-tree-node-toggle" }, exportAs: ["mcTreeNodeToggle"], usesInheritance: true, ngImport: i0, template: `<i class="mc mc-icon mc-angle-down-S_16"></i>`, isInline: true, styles: [".mc-tree-node-toggle{display:flex;align-items:center;justify-content:center;flex-shrink:0;height:100%;padding-left:var(--mc-tree-size-toggle-padding, 4px);padding-right:var(--mc-tree-size-toggle-padding, 4px);cursor:pointer}.mc-tree-node-toggle .mc-icon{transform:rotate(-90deg)}.mc-tree-node-toggle.mc-expanded .mc-icon{transform:rotate(0)}.mc-tree-node-toggle[disabled]{cursor:default}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
382
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: McTreeNodeToggleComponent, decorators: [{
383
- type: Component,
384
- args: [{ selector: 'mc-tree-node-toggle', exportAs: 'mcTreeNodeToggle', template: `<i class="mc mc-icon mc-angle-down-S_16"></i>`, host: {
385
- class: 'mc-tree-node-toggle',
386
- '[class.mc-expanded]': 'iconState',
387
- '[attr.disabled]': 'disabled || null',
388
- '(click)': 'toggle($event)'
389
- }, inputs: ['disabled'], encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, styles: [".mc-tree-node-toggle{display:flex;align-items:center;justify-content:center;flex-shrink:0;height:100%;padding-left:var(--mc-tree-size-toggle-padding, 4px);padding-right:var(--mc-tree-size-toggle-padding, 4px);cursor:pointer}.mc-tree-node-toggle .mc-icon{transform:rotate(-90deg)}.mc-tree-node-toggle.mc-expanded .mc-icon{transform:rotate(0)}.mc-tree-node-toggle[disabled]{cursor:default}\n"] }]
390
- }] });
391
- class McTreeNodeToggleDirective extends McTreeNodeToggleBaseDirective {
392
- }
393
- /** @nocollapse */ /** @nocollapse */ McTreeNodeToggleDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: McTreeNodeToggleDirective, deps: null, target: i0.ɵɵFactoryTarget.Directive });
394
- /** @nocollapse */ /** @nocollapse */ McTreeNodeToggleDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.4", type: McTreeNodeToggleDirective, selector: "[mc-tree-node-toggle], [mcTreeNodeToggle]", host: { listeners: { "click": "toggle($event)" }, properties: { "attr.disabled": "disabled || null" } }, exportAs: ["mcTreeNodeToggle"], usesInheritance: true, ngImport: i0 });
395
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: McTreeNodeToggleDirective, decorators: [{
396
- type: Directive,
397
- args: [{
398
- selector: '[mc-tree-node-toggle], [mcTreeNodeToggle]',
399
- exportAs: 'mcTreeNodeToggle',
400
- host: {
401
- '[attr.disabled]': 'disabled || null',
402
- '(click)': 'toggle($event)'
403
- }
404
- }]
435
+
436
+ class McTreeNodeToggleBase {
437
+ }
438
+ // tslint:disable-next-line:naming-convention
439
+ const McTreeNodeToggleMixinBase = mixinDisabled(McTreeNodeToggleBase);
440
+ /** @docs-private */
441
+ class McTreeNodeToggleBaseDirective extends McTreeNodeToggleMixinBase {
442
+ constructor(tree, treeNode) {
443
+ super();
444
+ this.tree = tree;
445
+ this.treeNode = treeNode;
446
+ this._recursive = false;
447
+ this.tree.treeControl.filterValue
448
+ .pipe(map((value) => value?.length > 0))
449
+ .subscribe((state) => this.disabled = state);
450
+ }
451
+ get recursive() {
452
+ return this._recursive;
453
+ }
454
+ set recursive(value) {
455
+ this._recursive = coerceBooleanProperty(value);
456
+ }
457
+ get iconState() {
458
+ return this.tree.treeControl.isExpanded(this.node);
459
+ }
460
+ toggle(event) {
461
+ if (this.disabled) {
462
+ return;
463
+ }
464
+ this.recursive
465
+ ? this.tree.treeControl.toggleDescendants(this.treeNode.data)
466
+ : this.tree.treeControl.toggle(this.treeNode.data);
467
+ event.stopPropagation();
468
+ }
469
+ }
470
+ /** @nocollapse */ /** @nocollapse */ McTreeNodeToggleBaseDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.7", ngImport: i0, type: McTreeNodeToggleBaseDirective, deps: [{ token: McTreeBase }, { token: McTreeNode }], target: i0.ɵɵFactoryTarget.Directive });
471
+ /** @nocollapse */ /** @nocollapse */ McTreeNodeToggleBaseDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.7", type: McTreeNodeToggleBaseDirective, inputs: { node: "node", recursive: ["mcTreeNodeToggleRecursive", "recursive"] }, usesInheritance: true, ngImport: i0 });
472
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.7", ngImport: i0, type: McTreeNodeToggleBaseDirective, decorators: [{
473
+ type: Directive
474
+ }], ctorParameters: function () { return [{ type: McTreeBase }, { type: McTreeNode }]; }, propDecorators: { node: [{
475
+ type: Input
476
+ }], recursive: [{
477
+ type: Input,
478
+ args: ['mcTreeNodeToggleRecursive']
479
+ }] } });
480
+ class McTreeNodeToggleComponent extends McTreeNodeToggleBaseDirective {
481
+ }
482
+ /** @nocollapse */ /** @nocollapse */ McTreeNodeToggleComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.7", ngImport: i0, type: McTreeNodeToggleComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
483
+ /** @nocollapse */ /** @nocollapse */ McTreeNodeToggleComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.7", type: McTreeNodeToggleComponent, selector: "mc-tree-node-toggle", inputs: { disabled: "disabled" }, host: { listeners: { "click": "toggle($event)" }, properties: { "class.mc-expanded": "iconState", "attr.disabled": "disabled || null" }, classAttribute: "mc-tree-node-toggle" }, exportAs: ["mcTreeNodeToggle"], usesInheritance: true, ngImport: i0, template: `<i class="mc mc-icon mc-angle-down-S_16"></i>`, isInline: true, styles: [".mc-tree-node-toggle{display:flex;align-items:center;justify-content:center;flex-shrink:0;height:100%;padding-left:var(--mc-tree-size-toggle-padding, 4px);padding-right:var(--mc-tree-size-toggle-padding, 4px);cursor:pointer}.mc-tree-node-toggle .mc-icon{transform:rotate(-90deg)}.mc-tree-node-toggle.mc-expanded .mc-icon{transform:rotate(0)}.mc-tree-node-toggle[disabled]{cursor:default}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
484
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.7", ngImport: i0, type: McTreeNodeToggleComponent, decorators: [{
485
+ type: Component,
486
+ args: [{ selector: 'mc-tree-node-toggle', exportAs: 'mcTreeNodeToggle', template: `<i class="mc mc-icon mc-angle-down-S_16"></i>`, host: {
487
+ class: 'mc-tree-node-toggle',
488
+ '[class.mc-expanded]': 'iconState',
489
+ '[attr.disabled]': 'disabled || null',
490
+ '(click)': 'toggle($event)'
491
+ }, inputs: ['disabled'], encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, styles: [".mc-tree-node-toggle{display:flex;align-items:center;justify-content:center;flex-shrink:0;height:100%;padding-left:var(--mc-tree-size-toggle-padding, 4px);padding-right:var(--mc-tree-size-toggle-padding, 4px);cursor:pointer}.mc-tree-node-toggle .mc-icon{transform:rotate(-90deg)}.mc-tree-node-toggle.mc-expanded .mc-icon{transform:rotate(0)}.mc-tree-node-toggle[disabled]{cursor:default}\n"] }]
492
+ }] });
493
+ class McTreeNodeToggleDirective extends McTreeNodeToggleBaseDirective {
494
+ }
495
+ /** @nocollapse */ /** @nocollapse */ McTreeNodeToggleDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.7", ngImport: i0, type: McTreeNodeToggleDirective, deps: null, target: i0.ɵɵFactoryTarget.Directive });
496
+ /** @nocollapse */ /** @nocollapse */ McTreeNodeToggleDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.7", type: McTreeNodeToggleDirective, selector: "[mc-tree-node-toggle], [mcTreeNodeToggle]", host: { listeners: { "click": "toggle($event)" }, properties: { "attr.disabled": "disabled || null" } }, exportAs: ["mcTreeNodeToggle"], usesInheritance: true, ngImport: i0 });
497
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.7", ngImport: i0, type: McTreeNodeToggleDirective, decorators: [{
498
+ type: Directive,
499
+ args: [{
500
+ selector: '[mc-tree-node-toggle], [mcTreeNodeToggle]',
501
+ exportAs: 'mcTreeNodeToggle',
502
+ host: {
503
+ '[attr.disabled]': 'disabled || null',
504
+ '(click)': 'toggle($event)'
505
+ }
506
+ }]
405
507
  }] });
406
508
 
407
- /**
408
- * Injection token used to provide the parent component to options.
409
- */
410
- const MC_TREE_OPTION_PARENT_COMPONENT = new InjectionToken('MC_TREE_OPTION_PARENT_COMPONENT');
411
- class McTreeOptionChange {
412
- constructor(source, isUserInput = false) {
413
- this.source = source;
414
- this.isUserInput = isUserInput;
415
- }
416
- }
417
- let uniqueIdCounter = 0;
418
- class McTreeOption extends McTreeNode {
419
- constructor(elementRef, changeDetectorRef, ngZone, tree) {
420
- super(elementRef, tree);
421
- this.changeDetectorRef = changeDetectorRef;
422
- this.ngZone = ngZone;
423
- this.tree = tree;
424
- this.onFocus = new Subject();
425
- this.onBlur = new Subject();
426
- this._disabled = false;
427
- this.onSelectionChange = new EventEmitter();
428
- this._selected = false;
429
- this._id = `mc-tree-option-${uniqueIdCounter++}`;
430
- this.hasFocus = false;
431
- }
432
- get externalPseudoCheckbox() {
433
- return !!this.pseudoCheckbox;
434
- }
435
- get value() {
436
- return this._value;
437
- }
438
- set value(value) {
439
- this._value = value;
440
- }
441
- get disabled() {
442
- return this._disabled || this.tree.disabled;
443
- }
444
- set disabled(value) {
445
- const newValue = coerceBooleanProperty(value);
446
- if (newValue !== this._disabled) {
447
- this._disabled = newValue;
448
- }
449
- }
450
- get showCheckbox() {
451
- return this._showCheckbox !== undefined ? this._showCheckbox : this.tree.showCheckbox;
452
- }
453
- set showCheckbox(value) {
454
- this._showCheckbox = coerceBooleanProperty(value);
455
- }
456
- get selected() {
457
- return this._selected;
458
- }
459
- set selected(value) {
460
- const isSelected = coerceBooleanProperty(value);
461
- if (isSelected !== this._selected) {
462
- this.setSelected(isSelected);
463
- }
464
- }
465
- get id() {
466
- return this._id;
467
- }
468
- get viewValue() {
469
- // TODO: Add input property alternative for node envs.
470
- return (this.getHostElement().textContent || '').trim();
471
- }
472
- get isExpandable() {
473
- return !this.toggleElement?.disabled && this.tree.treeControl.isExpandable(this.data);
474
- }
475
- ngAfterContentInit() {
476
- this.value = this.tree.treeControl.getValue(this.data);
477
- }
478
- toggle() {
479
- this.selected = !this.selected;
480
- }
481
- setSelected(selected) {
482
- if (this._selected === selected || !this.tree.selectionModel) {
483
- return;
484
- }
485
- this._selected = selected;
486
- if (selected) {
487
- this.tree.selectionModel.select(this.data);
488
- }
489
- else {
490
- this.tree.selectionModel.deselect(this.data);
491
- }
492
- this.changeDetectorRef.markForCheck();
493
- }
494
- focus(focusOrigin) {
495
- if (focusOrigin === 'program') {
496
- return;
497
- }
498
- if (this.disabled || this.hasFocus || this.actionButton?.hasFocus) {
499
- return;
500
- }
501
- this.elementRef.nativeElement.focus();
502
- this.onFocus.next({ option: this });
503
- Promise.resolve().then(() => {
504
- this.hasFocus = true;
505
- this.changeDetectorRef.markForCheck();
506
- });
507
- }
508
- blur() {
509
- // When animations are enabled, Angular may end up removing the option from the DOM a little
510
- // earlier than usual, causing it to be blurred and throwing off the logic in the tree
511
- // that moves focus not the next item. To work around the issue, we defer marking the option
512
- // as not focused until the next time the zone stabilizes.
513
- this.ngZone.onStable
514
- .asObservable()
515
- .pipe(take(1))
516
- .subscribe(() => {
517
- this.ngZone.run(() => {
518
- if (this.actionButton?.hasFocus) {
519
- return;
520
- }
521
- this.onBlur.next({ option: this });
522
- });
523
- });
524
- }
525
- getHeight() {
526
- const clientRects = this.elementRef.nativeElement.getClientRects();
527
- if (clientRects.length) {
528
- return clientRects[0].height;
529
- }
530
- return 0;
531
- }
532
- select(setFocus = true) {
533
- if (this._selected) {
534
- return;
535
- }
536
- this._selected = true;
537
- if (setFocus && !this.hasFocus) {
538
- this.focus();
539
- }
540
- this.changeDetectorRef.markForCheck();
541
- this.emitSelectionChangeEvent();
542
- }
543
- deselect() {
544
- if (!this._selected) {
545
- return;
546
- }
547
- this._selected = false;
548
- this.changeDetectorRef.markForCheck();
549
- }
550
- onKeydown($event) {
551
- if (!this.actionButton) {
552
- return;
553
- }
554
- if ($event.keyCode === TAB && !$event.shiftKey && !this.actionButton.hasFocus) {
555
- this.actionButton.focus();
556
- $event.preventDefault();
557
- }
558
- }
559
- selectViaInteraction($event) {
560
- if (this.disabled) {
561
- return;
562
- }
563
- this.changeDetectorRef.markForCheck();
564
- this.emitSelectionChangeEvent(true);
565
- const shiftKey = $event ? hasModifierKey($event, 'shiftKey') : false;
566
- const ctrlKey = $event ? hasModifierKey($event, 'ctrlKey') : false;
567
- this.tree.setSelectedOptionsByClick(this, shiftKey, ctrlKey);
568
- }
569
- emitSelectionChangeEvent(isUserInput = false) {
570
- this.onSelectionChange.emit(new McTreeOptionChange(this, isUserInput));
571
- }
572
- getHostElement() {
573
- return this.elementRef.nativeElement;
574
- }
575
- markForCheck() {
576
- this.changeDetectorRef.markForCheck();
577
- }
578
- }
579
- /** @nocollapse */ /** @nocollapse */ McTreeOption.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: McTreeOption, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: i0.NgZone }, { token: MC_TREE_OPTION_PARENT_COMPONENT }], target: i0.ɵɵFactoryTarget.Component });
580
- /** @nocollapse */ /** @nocollapse */ McTreeOption.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.4", type: McTreeOption, selector: "mc-tree-option", inputs: { disabled: "disabled", showCheckbox: "showCheckbox" }, outputs: { onSelectionChange: "onSelectionChange" }, host: { listeners: { "focusin": "focus()", "blur": "blur()", "click": "selectViaInteraction($event)", "keydown": "onKeydown($event)" }, properties: { "class.mc-selected": "selected", "class.mc-focused": "hasFocus", "class.mc-action-button-focused": "actionButton?.active", "attr.id": "id", "attr.tabindex": "-1", "attr.disabled": "disabled || null" }, classAttribute: "mc-tree-option" }, providers: [
581
- { provide: McTreeNode, useExisting: McTreeOption },
582
- { provide: MC_OPTION_ACTION_PARENT, useExisting: McTreeOption }
583
- ], queries: [{ propertyName: "toggleElement", first: true, predicate: McTreeNodeToggleDirective, descendants: true }, { propertyName: "pseudoCheckbox", first: true, predicate: McPseudoCheckbox, descendants: true }, { propertyName: "actionButton", first: true, predicate: McOptionActionComponent, descendants: true }, { propertyName: "tooltipTrigger", first: true, predicate: McTooltipTrigger, descendants: true }, { propertyName: "dropdownTrigger", first: true, predicate: McDropdownTrigger, descendants: true }], exportAs: ["mcTreeOption"], usesInheritance: true, ngImport: i0, template: "<ng-content select=\"mc-tree-node-toggle, [mc-tree-node-toggle], [mcTreeNodeToggle]\"></ng-content>\n\n<ng-container [ngSwitch]=\"externalPseudoCheckbox\">\n <ng-content *ngSwitchCase=\"true\" select=\"mc-pseudo-checkbox\"></ng-content>\n\n <ng-container *ngSwitchCase=\"false\">\n <mc-pseudo-checkbox\n *ngIf=\"showCheckbox\"\n [state]=\"selected ? 'checked' : 'unchecked'\"\n [disabled]=\"disabled\">\n </mc-pseudo-checkbox>\n </ng-container>\n</ng-container>\n\n<ng-content select=\"mc-checkbox\"></ng-content>\n\n<ng-content select=\"[mc-icon]\"></ng-content>\n\n<ng-content select=\"mc-progress-spinner\"></ng-content>\n\n<span class=\"mc-option-text mc-no-select\"><ng-content></ng-content></span>\n\n<ng-content select=\"mc-option-action\"></ng-content>\n\n<div class=\"mc-option-overlay\"></div>\n", styles: [".mc-tree-option{box-sizing:border-box;display:flex;align-items:center;height:var(--mc-tree-size-node-height, 32px);word-wrap:break-word;border:2px solid transparent}.mc-tree-option .mc-option-text{display:inline-block;flex-grow:1;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;margin-right:var(--mc-tree-size-padding-right, 16px)}.mc-tree-option>.mc-icon{margin-right:var(--mc-tree-size-icon-padding, 8px);cursor:pointer}.mc-tree-option>.mc-progress-spinner{margin-right:8px}.mc-tree-option:focus{outline:none}.mc-tree-option:not([disabled]){cursor:pointer}.mc-tree-option>.mc-pseudo-checkbox,.mc-tree-option>.mc-checkbox{margin-right:var(--mc-tree-size-icon-padding, 8px)}.mc-tree-option .mc-option-action{display:none}.mc-tree-option:not([disabled]):hover .mc-option-action,.mc-tree-option:not([disabled]).mc-focused .mc-option-action,.mc-tree-option:not([disabled]).mc-action-button-focused .mc-option-action{display:flex}\n"], components: [{ type: i1.McPseudoCheckbox, selector: "mc-pseudo-checkbox", inputs: ["state", "disabled"] }], directives: [{ type: i2.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i2.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
584
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: McTreeOption, decorators: [{
585
- type: Component,
586
- args: [{ selector: 'mc-tree-option', exportAs: 'mcTreeOption', host: {
587
- class: 'mc-tree-option',
588
- '[class.mc-selected]': 'selected',
589
- '[class.mc-focused]': 'hasFocus',
590
- '[class.mc-action-button-focused]': 'actionButton?.active',
591
- '[attr.id]': 'id',
592
- '[attr.tabindex]': '-1',
593
- '[attr.disabled]': 'disabled || null',
594
- '(focusin)': 'focus()',
595
- '(blur)': 'blur()',
596
- '(click)': 'selectViaInteraction($event)',
597
- '(keydown)': 'onKeydown($event)'
598
- }, changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, providers: [
599
- { provide: McTreeNode, useExisting: McTreeOption },
600
- { provide: MC_OPTION_ACTION_PARENT, useExisting: McTreeOption }
601
- ], template: "<ng-content select=\"mc-tree-node-toggle, [mc-tree-node-toggle], [mcTreeNodeToggle]\"></ng-content>\n\n<ng-container [ngSwitch]=\"externalPseudoCheckbox\">\n <ng-content *ngSwitchCase=\"true\" select=\"mc-pseudo-checkbox\"></ng-content>\n\n <ng-container *ngSwitchCase=\"false\">\n <mc-pseudo-checkbox\n *ngIf=\"showCheckbox\"\n [state]=\"selected ? 'checked' : 'unchecked'\"\n [disabled]=\"disabled\">\n </mc-pseudo-checkbox>\n </ng-container>\n</ng-container>\n\n<ng-content select=\"mc-checkbox\"></ng-content>\n\n<ng-content select=\"[mc-icon]\"></ng-content>\n\n<ng-content select=\"mc-progress-spinner\"></ng-content>\n\n<span class=\"mc-option-text mc-no-select\"><ng-content></ng-content></span>\n\n<ng-content select=\"mc-option-action\"></ng-content>\n\n<div class=\"mc-option-overlay\"></div>\n", styles: [".mc-tree-option{box-sizing:border-box;display:flex;align-items:center;height:var(--mc-tree-size-node-height, 32px);word-wrap:break-word;border:2px solid transparent}.mc-tree-option .mc-option-text{display:inline-block;flex-grow:1;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;margin-right:var(--mc-tree-size-padding-right, 16px)}.mc-tree-option>.mc-icon{margin-right:var(--mc-tree-size-icon-padding, 8px);cursor:pointer}.mc-tree-option>.mc-progress-spinner{margin-right:8px}.mc-tree-option:focus{outline:none}.mc-tree-option:not([disabled]){cursor:pointer}.mc-tree-option>.mc-pseudo-checkbox,.mc-tree-option>.mc-checkbox{margin-right:var(--mc-tree-size-icon-padding, 8px)}.mc-tree-option .mc-option-action{display:none}.mc-tree-option:not([disabled]):hover .mc-option-action,.mc-tree-option:not([disabled]).mc-focused .mc-option-action,.mc-tree-option:not([disabled]).mc-action-button-focused .mc-option-action{display:flex}\n"] }]
602
- }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: i0.NgZone }, { type: undefined, decorators: [{
603
- type: Inject,
604
- args: [MC_TREE_OPTION_PARENT_COMPONENT]
605
- }] }]; }, propDecorators: { toggleElement: [{
606
- type: ContentChild,
607
- args: [McTreeNodeToggleDirective]
608
- }], pseudoCheckbox: [{
609
- type: ContentChild,
610
- args: [McPseudoCheckbox]
611
- }], actionButton: [{
612
- type: ContentChild,
613
- args: [McOptionActionComponent]
614
- }], tooltipTrigger: [{
615
- type: ContentChild,
616
- args: [McTooltipTrigger]
617
- }], dropdownTrigger: [{
618
- type: ContentChild,
619
- args: [McDropdownTrigger]
620
- }], disabled: [{
621
- type: Input
622
- }], showCheckbox: [{
623
- type: Input
624
- }], onSelectionChange: [{
625
- type: Output
626
- }] } });
509
+ class McTree extends McTreeBase {
510
+ }
511
+ /** @nocollapse */ /** @nocollapse */ McTree.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.7", ngImport: i0, type: McTree, deps: null, target: i0.ɵɵFactoryTarget.Component });
512
+ /** @nocollapse */ /** @nocollapse */ McTree.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.7", type: McTree, selector: "mc-tree", host: { classAttribute: "mc-tree" }, exportAs: ["mcTree"], usesInheritance: true, ngImport: i0, template: `<ng-container mcTreeNodeOutlet></ng-container>`, isInline: true, styles: [".mc-tree{display:block}\n"], directives: [{ type: McTreeNodeOutlet, selector: "[mcTreeNodeOutlet]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
513
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.7", ngImport: i0, type: McTree, decorators: [{
514
+ type: Component,
515
+ args: [{ selector: 'mc-tree', exportAs: 'mcTree', template: `<ng-container mcTreeNodeOutlet></ng-container>`, host: {
516
+ class: 'mc-tree'
517
+ }, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, styles: [".mc-tree{display:block}\n"] }]
518
+ }] });
627
519
 
628
- /** Regex used to split a string on its CSS units. */
629
- const cssUnitPattern = /([A-Za-z%]+)$/;
630
- class McTreeNodePadding {
631
- constructor(treeNode, tree, renderer, element, option, dir) {
632
- this.treeNode = treeNode;
633
- this.tree = tree;
634
- this.renderer = renderer;
635
- this.element = element;
636
- this.option = option;
637
- this.dir = dir;
638
- this._indent = 20;
639
- /** CSS units used for the indentation value. */
640
- this.indentUnits = 'px';
641
- this.baseLeftPadding = parseInt(TreeSizePaddingLeft);
642
- this.iconWidth = 24;
643
- this.destroyed = new Subject();
644
- this.dir?.change?.pipe(takeUntil(this.destroyed))
645
- .subscribe(() => this.setPadding());
646
- }
647
- get level() {
648
- return this._level;
649
- }
650
- set level(value) {
651
- this.setLevelInput(value);
652
- }
653
- get indent() {
654
- return this._indent;
655
- }
656
- set indent(indent) {
657
- this.setIndentInput(indent);
658
- }
659
- get leftPadding() {
660
- return (this.withIcon ? 0 : this.iconWidth) + this.baseLeftPadding;
661
- }
662
- ngAfterViewInit() {
663
- this.withIcon = !!this.option.toggleElement;
664
- this.setPadding();
665
- }
666
- ngOnDestroy() {
667
- this.destroyed.next();
668
- this.destroyed.complete();
669
- }
670
- paddingIndent() {
671
- const nodeLevel = (this.treeNode.data && this.tree.treeControl.getLevel)
672
- ? this.tree.treeControl.getLevel(this.treeNode.data)
673
- : 0;
674
- const level = this.level || nodeLevel;
675
- return level > 0 ? `${(level * this._indent) + this.leftPadding}px` : `${this.leftPadding}px`;
676
- }
677
- /**
678
- * This has been extracted to a util because of TS 4 and VE.
679
- * View Engine doesn't support property rename inheritance.
680
- * TS 4.0 doesn't allow properties to override accessors or vice-versa.
681
- * @docs-private
682
- */
683
- setLevelInput(value) {
684
- // Set to null as the fallback value so that _setPadding can fall back to the node level if the
685
- // consumer set the directive as `mcTreeNodePadding=""`. We still want to take this value if
686
- // they set 0 explicitly.
687
- this._level = coerceNumberProperty(value, null);
688
- this.setPadding();
689
- }
690
- /**
691
- * This has been extracted to a util because of TS 4 and VE.
692
- * View Engine doesn't support property rename inheritance.
693
- * TS 4.0 doesn't allow properties to override accessors or vice-versa.
694
- * @docs-private
695
- */
696
- setIndentInput(indent) {
697
- let value = indent;
698
- let units = 'px';
699
- if (typeof indent === 'string') {
700
- const parts = indent.split(cssUnitPattern);
701
- value = parts[0];
702
- units = parts[1] || units;
703
- }
704
- this.indentUnits = units;
705
- this._indent = coerceNumberProperty(value);
706
- this.setPadding();
707
- }
708
- setPadding() {
709
- const padding = this.paddingIndent();
710
- const paddingProp = this.dir?.value === 'rtl' ? 'paddingRight' : 'paddingLeft';
711
- this.renderer.setStyle(this.element.nativeElement, paddingProp, padding);
712
- }
713
- }
714
- /** @nocollapse */ /** @nocollapse */ McTreeNodePadding.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: McTreeNodePadding, deps: [{ token: McTreeNode }, { token: McTreeBase }, { token: i0.Renderer2 }, { token: i0.ElementRef }, { token: McTreeOption }, { token: i3.Directionality, optional: true }], target: i0.ɵɵFactoryTarget.Directive });
715
- /** @nocollapse */ /** @nocollapse */ McTreeNodePadding.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.4", type: McTreeNodePadding, selector: "[mcTreeNodePadding]", inputs: { indent: ["mcTreeNodePaddingIndent", "indent"] }, exportAs: ["mcTreeNodePadding"], ngImport: i0 });
716
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: McTreeNodePadding, decorators: [{
717
- type: Directive,
718
- args: [{
719
- selector: '[mcTreeNodePadding]',
720
- exportAs: 'mcTreeNodePadding'
721
- }]
722
- }], ctorParameters: function () { return [{ type: McTreeNode }, { type: McTreeBase }, { type: i0.Renderer2 }, { type: i0.ElementRef }, { type: McTreeOption }, { type: i3.Directionality, decorators: [{
723
- type: Optional
724
- }] }]; }, propDecorators: { indent: [{
725
- type: Input,
726
- args: ['mcTreeNodePaddingIndent']
520
+ /**
521
+ * Injection token used to provide the parent component to options.
522
+ */
523
+ const MC_TREE_OPTION_PARENT_COMPONENT = new InjectionToken('MC_TREE_OPTION_PARENT_COMPONENT');
524
+ class McTreeOptionChange {
525
+ constructor(source, isUserInput = false) {
526
+ this.source = source;
527
+ this.isUserInput = isUserInput;
528
+ }
529
+ }
530
+ let uniqueIdCounter = 0;
531
+ class McTreeOption extends McTreeNode {
532
+ constructor(elementRef, changeDetectorRef, ngZone, tree) {
533
+ super(elementRef, tree);
534
+ this.changeDetectorRef = changeDetectorRef;
535
+ this.ngZone = ngZone;
536
+ this.tree = tree;
537
+ this.onFocus = new Subject();
538
+ this.onBlur = new Subject();
539
+ this._disabled = false;
540
+ this.onSelectionChange = new EventEmitter();
541
+ this._selected = false;
542
+ this._id = `mc-tree-option-${uniqueIdCounter++}`;
543
+ this.hasFocus = false;
544
+ }
545
+ get externalPseudoCheckbox() {
546
+ return !!this.pseudoCheckbox;
547
+ }
548
+ get value() {
549
+ return this._value;
550
+ }
551
+ set value(value) {
552
+ this._value = value;
553
+ }
554
+ get disabled() {
555
+ return this._disabled || this.tree.disabled;
556
+ }
557
+ set disabled(value) {
558
+ const newValue = coerceBooleanProperty(value);
559
+ if (newValue !== this._disabled) {
560
+ this._disabled = newValue;
561
+ }
562
+ }
563
+ get showCheckbox() {
564
+ return this._showCheckbox !== undefined ? this._showCheckbox : this.tree.showCheckbox;
565
+ }
566
+ set showCheckbox(value) {
567
+ this._showCheckbox = coerceBooleanProperty(value);
568
+ }
569
+ get selected() {
570
+ return this._selected;
571
+ }
572
+ set selected(value) {
573
+ const isSelected = coerceBooleanProperty(value);
574
+ if (isSelected !== this._selected) {
575
+ this.setSelected(isSelected);
576
+ }
577
+ }
578
+ get id() {
579
+ return this._id;
580
+ }
581
+ get viewValue() {
582
+ // TODO: Add input property alternative for node envs.
583
+ return (this.getHostElement().textContent || '').trim();
584
+ }
585
+ get isExpandable() {
586
+ return !this.toggleElement?.disabled && this.tree.treeControl.isExpandable(this.data);
587
+ }
588
+ ngAfterContentInit() {
589
+ this.value = this.tree.treeControl.getValue(this.data);
590
+ }
591
+ toggle() {
592
+ this.selected = !this.selected;
593
+ }
594
+ setSelected(selected) {
595
+ if (this._selected === selected || !this.tree.selectionModel) {
596
+ return;
597
+ }
598
+ this._selected = selected;
599
+ if (selected) {
600
+ this.tree.selectionModel.select(this.data);
601
+ }
602
+ else {
603
+ this.tree.selectionModel.deselect(this.data);
604
+ }
605
+ this.changeDetectorRef.markForCheck();
606
+ }
607
+ focus(focusOrigin) {
608
+ if (focusOrigin === 'program') {
609
+ return;
610
+ }
611
+ if (this.disabled || this.actionButton?.hasFocus) {
612
+ return;
613
+ }
614
+ this.elementRef.nativeElement.focus();
615
+ if (!this.hasFocus) {
616
+ this.onFocus.next({ option: this });
617
+ Promise.resolve().then(() => {
618
+ this.hasFocus = true;
619
+ this.changeDetectorRef.markForCheck();
620
+ });
621
+ }
622
+ }
623
+ blur() {
624
+ // When animations are enabled, Angular may end up removing the option from the DOM a little
625
+ // earlier than usual, causing it to be blurred and throwing off the logic in the tree
626
+ // that moves focus not the next item. To work around the issue, we defer marking the option
627
+ // as not focused until the next time the zone stabilizes.
628
+ this.ngZone.onStable
629
+ .asObservable()
630
+ .pipe(take(1))
631
+ .subscribe(() => {
632
+ this.ngZone.run(() => {
633
+ if (this.actionButton?.hasFocus) {
634
+ return;
635
+ }
636
+ this.onBlur.next({ option: this });
637
+ });
638
+ });
639
+ }
640
+ getHeight() {
641
+ const clientRects = this.elementRef.nativeElement.getClientRects();
642
+ if (clientRects.length) {
643
+ return clientRects[0].height;
644
+ }
645
+ return 0;
646
+ }
647
+ select(setFocus = true) {
648
+ if (this._selected) {
649
+ return;
650
+ }
651
+ this._selected = true;
652
+ if (setFocus && !this.hasFocus) {
653
+ this.focus();
654
+ }
655
+ this.changeDetectorRef.markForCheck();
656
+ this.emitSelectionChangeEvent();
657
+ }
658
+ deselect() {
659
+ if (!this._selected) {
660
+ return;
661
+ }
662
+ this._selected = false;
663
+ this.changeDetectorRef.markForCheck();
664
+ }
665
+ onKeydown($event) {
666
+ if (!this.actionButton) {
667
+ return;
668
+ }
669
+ if ($event.keyCode === TAB && !$event.shiftKey && !this.actionButton.hasFocus) {
670
+ this.actionButton.focus();
671
+ $event.preventDefault();
672
+ }
673
+ }
674
+ selectViaInteraction($event) {
675
+ if (this.disabled) {
676
+ return;
677
+ }
678
+ this.changeDetectorRef.markForCheck();
679
+ this.emitSelectionChangeEvent(true);
680
+ const shiftKey = $event ? hasModifierKey($event, 'shiftKey') : false;
681
+ const ctrlKey = $event ? hasModifierKey($event, 'ctrlKey') : false;
682
+ this.tree.setSelectedOptionsByClick(this, shiftKey, ctrlKey);
683
+ }
684
+ emitSelectionChangeEvent(isUserInput = false) {
685
+ this.onSelectionChange.emit(new McTreeOptionChange(this, isUserInput));
686
+ }
687
+ getHostElement() {
688
+ return this.elementRef.nativeElement;
689
+ }
690
+ markForCheck() {
691
+ this.changeDetectorRef.markForCheck();
692
+ }
693
+ }
694
+ /** @nocollapse */ /** @nocollapse */ McTreeOption.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.7", ngImport: i0, type: McTreeOption, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: i0.NgZone }, { token: MC_TREE_OPTION_PARENT_COMPONENT }], target: i0.ɵɵFactoryTarget.Component });
695
+ /** @nocollapse */ /** @nocollapse */ McTreeOption.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.7", type: McTreeOption, selector: "mc-tree-option", inputs: { disabled: "disabled", showCheckbox: "showCheckbox" }, outputs: { onSelectionChange: "onSelectionChange" }, host: { listeners: { "focusin": "focus()", "blur": "blur()", "click": "selectViaInteraction($event)", "keydown": "onKeydown($event)" }, properties: { "class.mc-selected": "selected", "class.mc-focused": "hasFocus", "class.mc-action-button-focused": "actionButton?.active", "attr.id": "id", "attr.tabindex": "-1", "attr.disabled": "disabled || null" }, classAttribute: "mc-tree-option" }, providers: [
696
+ { provide: McTreeNode, useExisting: McTreeOption },
697
+ { provide: MC_OPTION_ACTION_PARENT, useExisting: McTreeOption }
698
+ ], queries: [{ propertyName: "toggleElement", first: true, predicate: ["mcTreeNodeToggle"], descendants: true }, { propertyName: "pseudoCheckbox", first: true, predicate: McPseudoCheckbox, descendants: true }, { propertyName: "actionButton", first: true, predicate: McOptionActionComponent, descendants: true }, { propertyName: "tooltipTrigger", first: true, predicate: McTooltipTrigger, descendants: true }, { propertyName: "dropdownTrigger", first: true, predicate: McDropdownTrigger, descendants: true }], exportAs: ["mcTreeOption"], usesInheritance: true, ngImport: i0, template: "<ng-content select=\"mc-tree-node-toggle, [mc-tree-node-toggle], [mcTreeNodeToggle]\"></ng-content>\r\n\r\n<ng-container [ngSwitch]=\"externalPseudoCheckbox\">\r\n <ng-content *ngSwitchCase=\"true\" select=\"mc-pseudo-checkbox\"></ng-content>\r\n\r\n <ng-container *ngSwitchCase=\"false\">\r\n <mc-pseudo-checkbox\r\n *ngIf=\"showCheckbox\"\r\n [state]=\"selected ? 'checked' : 'unchecked'\"\r\n [disabled]=\"disabled\">\r\n </mc-pseudo-checkbox>\r\n </ng-container>\r\n</ng-container>\r\n\r\n<ng-content select=\"mc-checkbox\"></ng-content>\r\n\r\n<ng-content select=\"[mc-icon]\"></ng-content>\r\n\r\n<ng-content select=\"mc-progress-spinner\"></ng-content>\r\n\r\n<span class=\"mc-option-text mc-no-select\"><ng-content></ng-content></span>\r\n\r\n<ng-content select=\"mc-option-action\"></ng-content>\r\n\r\n<div class=\"mc-option-overlay\"></div>\r\n", styles: [".mc-tree-option{box-sizing:border-box;display:flex;align-items:center;height:var(--mc-tree-size-node-height, 32px);word-wrap:break-word;border:2px solid transparent}.mc-tree-option .mc-option-text{display:inline-block;flex-grow:1;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;margin-right:var(--mc-tree-size-padding-right, 16px)}.mc-tree-option>.mc-icon{margin-right:var(--mc-tree-size-icon-padding, 8px);cursor:pointer}.mc-tree-option>.mc-progress-spinner{margin-right:8px}.mc-tree-option:focus{outline:none}.mc-tree-option:not([disabled]){cursor:pointer}.mc-tree-option>.mc-pseudo-checkbox,.mc-tree-option>.mc-checkbox{margin-right:var(--mc-tree-size-icon-padding, 8px)}.mc-tree-option .mc-option-action{display:none}.mc-tree-option:not([disabled]):hover .mc-option-action,.mc-tree-option:not([disabled]).mc-focused .mc-option-action,.mc-tree-option:not([disabled]).mc-action-button-focused .mc-option-action{display:flex}\n"], components: [{ type: i1.McPseudoCheckbox, selector: "mc-pseudo-checkbox", inputs: ["state", "disabled"] }], directives: [{ type: i2$1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i2$1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { type: i2$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
699
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.7", ngImport: i0, type: McTreeOption, decorators: [{
700
+ type: Component,
701
+ args: [{ selector: 'mc-tree-option', exportAs: 'mcTreeOption', host: {
702
+ class: 'mc-tree-option',
703
+ '[class.mc-selected]': 'selected',
704
+ '[class.mc-focused]': 'hasFocus',
705
+ '[class.mc-action-button-focused]': 'actionButton?.active',
706
+ '[attr.id]': 'id',
707
+ '[attr.tabindex]': '-1',
708
+ '[attr.disabled]': 'disabled || null',
709
+ '(focusin)': 'focus()',
710
+ '(blur)': 'blur()',
711
+ '(click)': 'selectViaInteraction($event)',
712
+ '(keydown)': 'onKeydown($event)'
713
+ }, changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, providers: [
714
+ { provide: McTreeNode, useExisting: McTreeOption },
715
+ { provide: MC_OPTION_ACTION_PARENT, useExisting: McTreeOption }
716
+ ], template: "<ng-content select=\"mc-tree-node-toggle, [mc-tree-node-toggle], [mcTreeNodeToggle]\"></ng-content>\r\n\r\n<ng-container [ngSwitch]=\"externalPseudoCheckbox\">\r\n <ng-content *ngSwitchCase=\"true\" select=\"mc-pseudo-checkbox\"></ng-content>\r\n\r\n <ng-container *ngSwitchCase=\"false\">\r\n <mc-pseudo-checkbox\r\n *ngIf=\"showCheckbox\"\r\n [state]=\"selected ? 'checked' : 'unchecked'\"\r\n [disabled]=\"disabled\">\r\n </mc-pseudo-checkbox>\r\n </ng-container>\r\n</ng-container>\r\n\r\n<ng-content select=\"mc-checkbox\"></ng-content>\r\n\r\n<ng-content select=\"[mc-icon]\"></ng-content>\r\n\r\n<ng-content select=\"mc-progress-spinner\"></ng-content>\r\n\r\n<span class=\"mc-option-text mc-no-select\"><ng-content></ng-content></span>\r\n\r\n<ng-content select=\"mc-option-action\"></ng-content>\r\n\r\n<div class=\"mc-option-overlay\"></div>\r\n", styles: [".mc-tree-option{box-sizing:border-box;display:flex;align-items:center;height:var(--mc-tree-size-node-height, 32px);word-wrap:break-word;border:2px solid transparent}.mc-tree-option .mc-option-text{display:inline-block;flex-grow:1;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;margin-right:var(--mc-tree-size-padding-right, 16px)}.mc-tree-option>.mc-icon{margin-right:var(--mc-tree-size-icon-padding, 8px);cursor:pointer}.mc-tree-option>.mc-progress-spinner{margin-right:8px}.mc-tree-option:focus{outline:none}.mc-tree-option:not([disabled]){cursor:pointer}.mc-tree-option>.mc-pseudo-checkbox,.mc-tree-option>.mc-checkbox{margin-right:var(--mc-tree-size-icon-padding, 8px)}.mc-tree-option .mc-option-action{display:none}.mc-tree-option:not([disabled]):hover .mc-option-action,.mc-tree-option:not([disabled]).mc-focused .mc-option-action,.mc-tree-option:not([disabled]).mc-action-button-focused .mc-option-action{display:flex}\n"] }]
717
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: i0.NgZone }, { type: undefined, decorators: [{
718
+ type: Inject,
719
+ args: [MC_TREE_OPTION_PARENT_COMPONENT]
720
+ }] }]; }, propDecorators: { toggleElement: [{
721
+ type: ContentChild,
722
+ args: ['mcTreeNodeToggle']
723
+ }], pseudoCheckbox: [{
724
+ type: ContentChild,
725
+ args: [McPseudoCheckbox]
726
+ }], actionButton: [{
727
+ type: ContentChild,
728
+ args: [McOptionActionComponent]
729
+ }], tooltipTrigger: [{
730
+ type: ContentChild,
731
+ args: [McTooltipTrigger]
732
+ }], dropdownTrigger: [{
733
+ type: ContentChild,
734
+ args: [McDropdownTrigger]
735
+ }], disabled: [{
736
+ type: Input
737
+ }], showCheckbox: [{
738
+ type: Input
739
+ }], onSelectionChange: [{
740
+ type: Output
727
741
  }] } });
728
742
 
729
- class McTree extends McTreeBase {
743
+ /** Base tree control. It has basic toggle/expand/collapse operations on a single data node. */
744
+ /* tslint:disable-next-line:naming-convention */
745
+ class BaseTreeControl {
746
+ constructor() {
747
+ /** A selection model with multi-selection to track expansion status. */
748
+ this.expansionModel = new SelectionModel(true);
749
+ this.filterModel = new SelectionModel(true);
750
+ this.filterValue = new BehaviorSubject('');
751
+ }
752
+ /** Toggles one single data node's expanded/collapsed state. */
753
+ toggle(dataNode) {
754
+ if (this.filterValue.value) {
755
+ return;
756
+ }
757
+ this.expansionModel.toggle(dataNode);
758
+ }
759
+ /** Expands one single data node. */
760
+ expand(dataNode) {
761
+ if (this.filterValue.value) {
762
+ return;
763
+ }
764
+ this.expansionModel.select(dataNode);
765
+ }
766
+ /** Collapses one single data node. */
767
+ collapse(dataNode) {
768
+ if (this.filterValue.value) {
769
+ return;
770
+ }
771
+ this.expansionModel.deselect(dataNode);
772
+ }
773
+ /** Whether a given data node is expanded or not. Returns true if the data node is expanded. */
774
+ isExpanded(dataNode) {
775
+ return this.expansionModel.isSelected(dataNode);
776
+ }
777
+ /** Toggles a subtree rooted at `node` recursively. */
778
+ toggleDescendants(dataNode) {
779
+ this.expansionModel.isSelected(dataNode)
780
+ ? this.collapseDescendants(dataNode)
781
+ : this.expandDescendants(dataNode);
782
+ }
783
+ /** Collapse all dataNodes in the tree. */
784
+ collapseAll() {
785
+ this.expansionModel.clear();
786
+ }
787
+ /** Expands a subtree rooted at given data node recursively. */
788
+ expandDescendants(dataNode) {
789
+ const toBeProcessed = [dataNode];
790
+ toBeProcessed.push(...this.getDescendants(dataNode));
791
+ this.expansionModel.select(...toBeProcessed);
792
+ }
793
+ /** Collapses a subtree rooted at given data node recursively. */
794
+ collapseDescendants(dataNode) {
795
+ const toBeProcessed = [dataNode];
796
+ toBeProcessed.push(...this.getDescendants(dataNode));
797
+ this.expansionModel.deselect(...toBeProcessed);
798
+ }
730
799
  }
731
- /** @nocollapse */ /** @nocollapse */ McTree.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: McTree, deps: null, target: i0.ɵɵFactoryTarget.Component });
732
- /** @nocollapse */ /** @nocollapse */ McTree.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.4", type: McTree, selector: "mc-tree", host: { classAttribute: "mc-tree" }, exportAs: ["mcTree"], usesInheritance: true, ngImport: i0, template: `<ng-container mcTreeNodeOutlet></ng-container>`, isInline: true, styles: [".mc-tree{display:block}\n"], directives: [{ type: McTreeNodeOutlet, selector: "[mcTreeNodeOutlet]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
733
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: McTree, decorators: [{
734
- type: Component,
735
- args: [{ selector: 'mc-tree', exportAs: 'mcTree', template: `<ng-container mcTreeNodeOutlet></ng-container>`, host: {
736
- class: 'mc-tree'
737
- }, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, styles: [".mc-tree{display:block}\n"] }]
738
- }] });
739
800
 
740
- /** Base tree control. It has basic toggle/expand/collapse operations on a single data node. */
741
- /* tslint:disable-next-line:naming-convention */
742
- class BaseTreeControl {
743
- constructor() {
744
- /** A selection model with multi-selection to track expansion status. */
745
- this.expansionModel = new SelectionModel(true);
746
- this.filterModel = new SelectionModel(true);
747
- this.filterValue = new BehaviorSubject('');
748
- }
749
- /** Toggles one single data node's expanded/collapsed state. */
750
- toggle(dataNode) {
751
- if (this.filterValue.value) {
752
- return;
753
- }
754
- this.expansionModel.toggle(dataNode);
755
- }
756
- /** Expands one single data node. */
757
- expand(dataNode) {
758
- if (this.filterValue.value) {
759
- return;
760
- }
761
- this.expansionModel.select(dataNode);
762
- }
763
- /** Collapses one single data node. */
764
- collapse(dataNode) {
765
- if (this.filterValue.value) {
766
- return;
767
- }
768
- this.expansionModel.deselect(dataNode);
769
- }
770
- /** Whether a given data node is expanded or not. Returns true if the data node is expanded. */
771
- isExpanded(dataNode) {
772
- return this.expansionModel.isSelected(dataNode);
773
- }
774
- /** Toggles a subtree rooted at `node` recursively. */
775
- toggleDescendants(dataNode) {
776
- this.expansionModel.isSelected(dataNode)
777
- ? this.collapseDescendants(dataNode)
778
- : this.expandDescendants(dataNode);
779
- }
780
- /** Collapse all dataNodes in the tree. */
781
- collapseAll() {
782
- this.expansionModel.clear();
783
- }
784
- /** Expands a subtree rooted at given data node recursively. */
785
- expandDescendants(dataNode) {
786
- const toBeProcessed = [dataNode];
787
- toBeProcessed.push(...this.getDescendants(dataNode));
788
- this.expansionModel.select(...toBeProcessed);
789
- }
790
- /** Collapses a subtree rooted at given data node recursively. */
791
- collapseDescendants(dataNode) {
792
- const toBeProcessed = [dataNode];
793
- toBeProcessed.push(...this.getDescendants(dataNode));
794
- this.expansionModel.deselect(...toBeProcessed);
795
- }
796
- }
797
-
798
- function defaultCompareValues(firstValue, secondValue) {
799
- return firstValue === secondValue;
800
- }
801
- function defaultCompareViewValues(firstViewValue, secondViewValue) {
802
- return RegExp(secondViewValue, 'gi').test(firstViewValue);
803
- }
804
- /** Flat tree control. Able to expand/collapse a subtree recursively for flattened tree. */
805
- class FlatTreeControl extends BaseTreeControl {
806
- /** Construct with flat tree data node functions getLevel, isExpandable, getValue and getViewValue. */
807
- constructor(getLevel, isExpandable,
808
- /** getValue will be used to determine if the tree contains value or not. Used in method hasValue */
809
- getValue,
810
- /** getViewValue will be used for filter nodes. Returned value will be first argument in filterNodesFunction */
811
- getViewValue,
812
- /** compareValues will be used to comparing values. */
813
- compareValues = defaultCompareValues,
814
- /** compareValues will be used to comparing values. */
815
- compareViewValues = defaultCompareViewValues) {
816
- super();
817
- this.getLevel = getLevel;
818
- this.isExpandable = isExpandable;
819
- this.getValue = getValue;
820
- this.getViewValue = getViewValue;
821
- this.compareValues = compareValues;
822
- this.compareViewValues = compareViewValues;
823
- }
824
- /**
825
- * Gets a list of the data node's subtree of descendent data nodes.
826
- *
827
- * To make this working, the `dataNodes` of the TreeControl must be flattened tree nodes
828
- * with correct levels.
829
- */
830
- getDescendants(dataNode) {
831
- const startIndex = this.dataNodes.indexOf(dataNode);
832
- const results = [];
833
- // Goes through flattened tree nodes in the `dataNodes` array, and get all descendants.
834
- // The level of descendants of a tree node must be greater than the level of the given
835
- // tree node.
836
- // If we reach a node whose level is equal to the level of the tree node, we hit a sibling.
837
- // If we reach a node whose level is greater than the level of the tree node, we hit a
838
- // sibling of an ancestor.
839
- for (let i = startIndex + 1; i < this.dataNodes.length && this.getLevel(dataNode) < this.getLevel(this.dataNodes[i]); i++) {
840
- results.push(this.dataNodes[i]);
841
- }
842
- return results;
843
- }
844
- /**
845
- * Expands all data nodes in the tree.
846
- *
847
- * To make this working, the `dataNodes` variable of the TreeControl must be set to all flattened
848
- * data nodes of the tree.
849
- */
850
- expandAll() {
851
- this.expansionModel.select(...this.dataNodes);
852
- }
853
- getParents(node, result) {
854
- if (node.parent) {
855
- result.unshift(node.parent);
856
- return this.getParents(node.parent, result);
857
- }
858
- else {
859
- return result;
860
- }
861
- }
862
- hasValue(value) {
863
- return this.dataNodes.find((node) => this.compareValues(this.getValue(node), value));
864
- }
865
- filterNodes(value) {
866
- this.saveExpansionState();
867
- this.filterModel.clear();
868
- this.expansionModel.clear();
869
- const filteredNodes = this.dataNodes
870
- .filter((node) => this.compareViewValues(this.getViewValue(node), value));
871
- const filteredNodesWithTheirParents = new Set();
872
- filteredNodes.forEach((filteredNode) => {
873
- this.getParents(filteredNode, [])
874
- .forEach((node) => {
875
- filteredNodesWithTheirParents.add(node);
876
- this.expandDataNode(node);
877
- });
878
- filteredNodesWithTheirParents.add(filteredNode);
879
- this.expandDataNode(filteredNode);
880
- if (this.isExpandable(filteredNode)) {
881
- const childNodeLevel = this.getLevel(filteredNode) + 1;
882
- this.getDescendants(filteredNode)
883
- .filter((childNode) => this.getLevel(childNode) === childNodeLevel)
884
- .filter((childNode) => !this.isExpandable(childNode) || !this.hasFilteredDescendant(childNode, filteredNodes))
885
- .forEach((childNode) => {
886
- filteredNodesWithTheirParents.add(childNode);
887
- this.expandDataNode(childNode);
888
- });
889
- }
890
- });
891
- this.filterModel.select(...Array.from(filteredNodesWithTheirParents));
892
- this.filterValue.next(value);
893
- this.restoreExpansionState();
894
- }
895
- expandDataNode(dataNode) {
896
- if (this.isExpandable(dataNode)) {
897
- this.expansionModel.select(dataNode);
898
- }
899
- }
900
- saveExpansionState() {
901
- if (this.filterValue.value === '') {
902
- this.expandedItemsBeforeFiltration = this.expansionModel.selected;
903
- }
904
- }
905
- restoreExpansionState() {
906
- if (this.filterValue.value === '') {
907
- this.expansionModel.clear();
908
- this.expansionModel.select(...this.expandedItemsBeforeFiltration);
909
- }
910
- }
911
- hasFilteredDescendant(dataNode, filteredNodes) {
912
- const filteredViewValues = filteredNodes
913
- .map((node) => this.getViewValue(node));
914
- return this.getDescendants(dataNode)
915
- .filter((node) => filteredViewValues.includes(this.getViewValue(node)))
916
- .length > 0;
917
- }
801
+ function defaultCompareValues(firstValue, secondValue) {
802
+ return firstValue === secondValue;
803
+ }
804
+ function defaultCompareViewValues(firstViewValue, secondViewValue) {
805
+ return RegExp(secondViewValue, 'gi').test(firstViewValue);
806
+ }
807
+ /** Flat tree control. Able to expand/collapse a subtree recursively for flattened tree. */
808
+ class FlatTreeControl extends BaseTreeControl {
809
+ /** Construct with flat tree data node functions getLevel, isExpandable, getValue and getViewValue. */
810
+ constructor(getLevel, isExpandable,
811
+ /** getValue will be used to determine if the tree contains value or not. Used in method hasValue */
812
+ getValue,
813
+ /** getViewValue will be used for filter nodes. Returned value will be first argument in filterNodesFunction */
814
+ getViewValue,
815
+ /** compareValues will be used to comparing values. */
816
+ compareValues = defaultCompareValues,
817
+ /** compareValues will be used to comparing values. */
818
+ compareViewValues = defaultCompareViewValues) {
819
+ super();
820
+ this.getLevel = getLevel;
821
+ this.isExpandable = isExpandable;
822
+ this.getValue = getValue;
823
+ this.getViewValue = getViewValue;
824
+ this.compareValues = compareValues;
825
+ this.compareViewValues = compareViewValues;
826
+ }
827
+ /**
828
+ * Gets a list of the data node's subtree of descendent data nodes.
829
+ *
830
+ * To make this working, the `dataNodes` of the TreeControl must be flattened tree nodes
831
+ * with correct levels.
832
+ */
833
+ getDescendants(dataNode) {
834
+ const startIndex = this.dataNodes.indexOf(dataNode);
835
+ const results = [];
836
+ // Goes through flattened tree nodes in the `dataNodes` array, and get all descendants.
837
+ // The level of descendants of a tree node must be greater than the level of the given
838
+ // tree node.
839
+ // If we reach a node whose level is equal to the level of the tree node, we hit a sibling.
840
+ // If we reach a node whose level is greater than the level of the tree node, we hit a
841
+ // sibling of an ancestor.
842
+ for (let i = startIndex + 1; i < this.dataNodes.length && this.getLevel(dataNode) < this.getLevel(this.dataNodes[i]); i++) {
843
+ results.push(this.dataNodes[i]);
844
+ }
845
+ return results;
846
+ }
847
+ /**
848
+ * Expands all data nodes in the tree.
849
+ *
850
+ * To make this working, the `dataNodes` variable of the TreeControl must be set to all flattened
851
+ * data nodes of the tree.
852
+ */
853
+ expandAll() {
854
+ this.expansionModel.select(...this.dataNodes);
855
+ }
856
+ getParents(node, result) {
857
+ if (node.parent) {
858
+ result.unshift(node.parent);
859
+ return this.getParents(node.parent, result);
860
+ }
861
+ else {
862
+ return result;
863
+ }
864
+ }
865
+ hasValue(value) {
866
+ return this.dataNodes.find((node) => this.compareValues(this.getValue(node), value));
867
+ }
868
+ filterNodes(value) {
869
+ this.saveExpansionState();
870
+ this.filterModel.clear();
871
+ this.expansionModel.clear();
872
+ const filteredNodes = this.dataNodes
873
+ .filter((node) => this.compareViewValues(this.getViewValue(node), value));
874
+ const filteredNodesWithTheirParents = new Set();
875
+ filteredNodes.forEach((filteredNode) => {
876
+ this.getParents(filteredNode, [])
877
+ .forEach((node) => {
878
+ filteredNodesWithTheirParents.add(node);
879
+ this.expandDataNode(node);
880
+ });
881
+ filteredNodesWithTheirParents.add(filteredNode);
882
+ this.expandDataNode(filteredNode);
883
+ if (this.isExpandable(filteredNode)) {
884
+ const childNodeLevel = this.getLevel(filteredNode) + 1;
885
+ this.getDescendants(filteredNode)
886
+ .filter((childNode) => this.getLevel(childNode) === childNodeLevel)
887
+ .filter((childNode) => !this.isExpandable(childNode) || !this.hasFilteredDescendant(childNode, filteredNodes))
888
+ .forEach((childNode) => {
889
+ filteredNodesWithTheirParents.add(childNode);
890
+ this.expandDataNode(childNode);
891
+ });
892
+ }
893
+ });
894
+ this.filterModel.select(...Array.from(filteredNodesWithTheirParents));
895
+ this.filterValue.next(value);
896
+ this.restoreExpansionState();
897
+ }
898
+ expandDataNode(dataNode) {
899
+ if (this.isExpandable(dataNode)) {
900
+ this.expansionModel.select(dataNode);
901
+ }
902
+ }
903
+ saveExpansionState() {
904
+ if (this.filterValue.value === '') {
905
+ this.expandedItemsBeforeFiltration = this.expansionModel.selected;
906
+ }
907
+ }
908
+ restoreExpansionState() {
909
+ if (this.filterValue.value === '') {
910
+ this.expansionModel.clear();
911
+ this.expansionModel.select(...this.expandedItemsBeforeFiltration);
912
+ }
913
+ }
914
+ hasFilteredDescendant(dataNode, filteredNodes) {
915
+ const filteredViewValues = filteredNodes
916
+ .map((node) => this.getViewValue(node));
917
+ return this.getDescendants(dataNode)
918
+ .filter((node) => filteredViewValues.includes(this.getViewValue(node)))
919
+ .length > 0;
920
+ }
918
921
  }
919
922
 
920
- /* tslint:disable:no-empty */
921
- const MC_SELECTION_TREE_VALUE_ACCESSOR = {
922
- provide: NG_VALUE_ACCESSOR,
923
- useExisting: forwardRef(() => McTreeSelection),
924
- multi: true
925
- };
926
- class McTreeSelectAllEvent {
927
- constructor(source, options) {
928
- this.source = source;
929
- this.options = options;
930
- }
931
- }
932
- class McTreeCopyEvent {
933
- constructor(source, option) {
934
- this.source = source;
935
- this.option = option;
936
- }
937
- }
938
- class McTreeNavigationChange {
939
- constructor(source, option) {
940
- this.source = source;
941
- this.option = option;
942
- }
943
- }
944
- class McTreeSelectionChange {
945
- constructor(source, option) {
946
- this.source = source;
947
- this.option = option;
948
- }
949
- }
950
- class McTreeSelection extends McTreeBase {
951
- constructor(elementRef, differs, changeDetectorRef, multiple, clipboard) {
952
- super(differs, changeDetectorRef);
953
- this.elementRef = elementRef;
954
- this.clipboard = clipboard;
955
- this.renderedOptions = new QueryList();
956
- this.resetFocusedItemOnBlur = true;
957
- this.multipleMode = null;
958
- this.userTabIndex = null;
959
- this.navigationChange = new EventEmitter();
960
- this.selectionChange = new EventEmitter();
961
- this.onSelectAll = new EventEmitter();
962
- this.onCopy = new EventEmitter();
963
- this.sortedNodes = [];
964
- this._autoSelect = true;
965
- this._noUnselectLast = true;
966
- this._disabled = false;
967
- this._tabIndex = 0;
968
- this.destroy = new Subject();
969
- /** `View -> model callback called when value changes` */
970
- this.onChange = () => { };
971
- /** `View -> model callback called when select has been touched` */
972
- this.onTouched = () => { };
973
- this.updateRenderedOptions = () => {
974
- const orderedOptions = [];
975
- this.sortedNodes.forEach((node) => {
976
- const found = this.unorderedOptions.find((option) => option.value === this.treeControl.getValue(node));
977
- if (found) {
978
- orderedOptions.push(found);
979
- }
980
- });
981
- this.renderedOptions.reset(orderedOptions);
982
- this.renderedOptions.notifyOnChanges();
983
- this.updateScrollSize();
984
- };
985
- if (multiple === MultipleMode.CHECKBOX || multiple === MultipleMode.KEYBOARD) {
986
- this.multipleMode = multiple;
987
- }
988
- else if (multiple !== null) {
989
- this.multipleMode = MultipleMode.CHECKBOX;
990
- }
991
- if (this.multipleMode === MultipleMode.CHECKBOX) {
992
- this.autoSelect = false;
993
- this.noUnselectLast = false;
994
- }
995
- this.selectionModel = new SelectionModel(this.multiple);
996
- }
997
- get autoSelect() {
998
- return this._autoSelect;
999
- }
1000
- set autoSelect(value) {
1001
- this._autoSelect = coerceBooleanProperty(value);
1002
- }
1003
- get optionFocusChanges() {
1004
- return merge(...this.renderedOptions.map((option) => option.onFocus));
1005
- }
1006
- get optionBlurChanges() {
1007
- return merge(...this.renderedOptions.map((option) => option.onBlur));
1008
- }
1009
- get multiple() {
1010
- return !!this.multipleMode;
1011
- }
1012
- get noUnselectLast() {
1013
- return this._noUnselectLast;
1014
- }
1015
- set noUnselectLast(value) {
1016
- this._noUnselectLast = coerceBooleanProperty(value);
1017
- }
1018
- get disabled() {
1019
- return this._disabled;
1020
- }
1021
- set disabled(rawValue) {
1022
- const value = coerceBooleanProperty(rawValue);
1023
- if (this._disabled !== value) {
1024
- this._disabled = value;
1025
- this.markOptionsForCheck();
1026
- }
1027
- }
1028
- get tabIndex() {
1029
- return this.disabled ? -1 : this._tabIndex;
1030
- }
1031
- set tabIndex(value) {
1032
- this._tabIndex = value;
1033
- this.userTabIndex = value;
1034
- }
1035
- get showCheckbox() {
1036
- return this.multipleMode === MultipleMode.CHECKBOX;
1037
- }
1038
- get isEmpty() {
1039
- return this.sortedNodes.length === 0;
1040
- }
1041
- ngAfterContentInit() {
1042
- this.unorderedOptions.changes
1043
- .subscribe(this.updateRenderedOptions);
1044
- this.keyManager = new FocusKeyManager(this.renderedOptions)
1045
- .withVerticalOrientation(true)
1046
- .withHorizontalOrientation(null);
1047
- this.keyManager.change
1048
- .pipe(takeUntil(this.destroy))
1049
- .subscribe(() => {
1050
- if (this.keyManager.activeItem) {
1051
- this.emitNavigationEvent(this.keyManager.activeItem);
1052
- // todo need check this logic
1053
- if (this.autoSelect && !this.keyManager.activeItem.disabled) {
1054
- this.updateOptionsFocus();
1055
- }
1056
- }
1057
- });
1058
- this.keyManager.tabOut
1059
- .pipe(takeUntil(this.destroy))
1060
- .subscribe(() => this.allowFocusEscape());
1061
- this.selectionModel.changed
1062
- .pipe(takeUntil(this.destroy))
1063
- .subscribe(() => {
1064
- this.onChange(this.getSelectedValues());
1065
- this.renderedOptions.notifyOnChanges();
1066
- });
1067
- this.renderedOptions.changes
1068
- .pipe(takeUntil(this.destroy), delay(0))
1069
- .subscribe((options) => {
1070
- this.resetOptions();
1071
- // Check to see if we need to update our tab index
1072
- this.updateTabIndex();
1073
- const selectedValues = this.multiple ? this.getSelectedValues() : [this.getSelectedValues()];
1074
- options.forEach((option) => {
1075
- if (selectedValues.includes(option.value)) {
1076
- option.select(false);
1077
- }
1078
- else {
1079
- option.deselect();
1080
- }
1081
- option.markForCheck();
1082
- });
1083
- });
1084
- }
1085
- ngOnDestroy() {
1086
- this.destroy.next();
1087
- this.destroy.complete();
1088
- }
1089
- focus($event) {
1090
- if (this.renderedOptions.length === 0 || this.isFocusReceivedFromNestedOption($event)) {
1091
- return;
1092
- }
1093
- this.keyManager.setFocusOrigin('keyboard');
1094
- this.keyManager.setFirstItemActive();
1095
- this.keyManager.setFocusOrigin('program');
1096
- }
1097
- blur() {
1098
- if (!this.hasFocusedOption() && this.resetFocusedItemOnBlur) {
1099
- this.keyManager.setActiveItem(-1);
1100
- }
1101
- this.onTouched();
1102
- this.changeDetectorRef.markForCheck();
1103
- }
1104
- onKeyDown(event) {
1105
- this.keyManager.setFocusOrigin('keyboard');
1106
- // tslint:disable-next-line: deprecation
1107
- const keyCode = event.keyCode;
1108
- if ([SPACE, LEFT_ARROW, RIGHT_ARROW].includes(keyCode) || isVerticalMovement(event)) {
1109
- event.preventDefault();
1110
- }
1111
- if (this.multiple && isSelectAll(event)) {
1112
- this.selectAllOptions();
1113
- return;
1114
- }
1115
- else if (isCopy(event)) {
1116
- this.copyActiveOption();
1117
- return;
1118
- }
1119
- else if (keyCode === TAB) {
1120
- this.keyManager.tabOut.next();
1121
- return;
1122
- }
1123
- else if (keyCode === LEFT_ARROW && this.keyManager.activeItem?.isExpandable) {
1124
- this.treeControl.collapse(this.keyManager.activeItem.data);
1125
- return;
1126
- }
1127
- else if (keyCode === RIGHT_ARROW && this.keyManager.activeItem?.isExpandable) {
1128
- this.treeControl.expand(this.keyManager.activeItem.data);
1129
- return;
1130
- }
1131
- else if (keyCode === DOWN_ARROW) {
1132
- this.keyManager.setNextItemActive();
1133
- }
1134
- else if (keyCode === UP_ARROW) {
1135
- this.keyManager.setPreviousItemActive();
1136
- }
1137
- else if ([SPACE, ENTER].includes(keyCode)) {
1138
- this.toggleFocusedOption();
1139
- return;
1140
- }
1141
- else if (keyCode === HOME) {
1142
- this.keyManager.setFirstItemActive();
1143
- }
1144
- else if (keyCode === END) {
1145
- this.keyManager.setLastItemActive();
1146
- }
1147
- else if (keyCode === PAGE_UP) {
1148
- this.keyManager.setPreviousPageItemActive();
1149
- }
1150
- else if (keyCode === PAGE_DOWN) {
1151
- this.keyManager.setNextPageItemActive();
1152
- }
1153
- if (this.keyManager.activeItem) {
1154
- this.setSelectedOptionsByKey(this.keyManager.activeItem, hasModifierKey(event, 'shiftKey'), hasModifierKey(event, 'ctrlKey'));
1155
- }
1156
- }
1157
- updateScrollSize() {
1158
- if (!this.renderedOptions.first) {
1159
- return;
1160
- }
1161
- this.keyManager.withScrollSize(Math.floor(this.getHeight() / this.renderedOptions.first.getHeight()));
1162
- }
1163
- setSelectedOptionsByKey(option, shiftKey, ctrlKey) {
1164
- if (shiftKey && this.multiple) {
1165
- this.setSelectedOptions(option);
1166
- this.emitChangeEvent(option);
1167
- }
1168
- else if (ctrlKey) {
1169
- if (!this.canDeselectLast(option)) {
1170
- return;
1171
- }
1172
- }
1173
- else if (this.autoSelect) {
1174
- this.selectionModel.clear();
1175
- this.selectionModel.toggle(option.data);
1176
- this.emitChangeEvent(option);
1177
- }
1178
- }
1179
- setSelectedOptionsByClick(option, shiftKey, ctrlKey) {
1180
- if (!shiftKey && !ctrlKey) {
1181
- this.keyManager.setActiveItem(option);
1182
- }
1183
- if (shiftKey && this.multiple) {
1184
- this.setSelectedOptions(option);
1185
- }
1186
- else if (ctrlKey) {
1187
- if (!this.canDeselectLast(option)) {
1188
- return;
1189
- }
1190
- this.selectionModel.toggle(option.data);
1191
- }
1192
- else if (this.autoSelect) {
1193
- this.selectionModel.clear();
1194
- this.selectionModel.toggle(option.data);
1195
- }
1196
- else {
1197
- this.selectionModel.toggle(option.data);
1198
- }
1199
- this.emitChangeEvent(option);
1200
- }
1201
- setSelectedOptions(option) {
1202
- const selectedOptionState = option.selected;
1203
- let fromIndex = this.keyManager.previousActiveItemIndex;
1204
- let toIndex = this.keyManager.previousActiveItemIndex = this.keyManager.activeItemIndex;
1205
- if (toIndex === fromIndex) {
1206
- return;
1207
- }
1208
- if (fromIndex > toIndex) {
1209
- [fromIndex, toIndex] = [toIndex, fromIndex];
1210
- }
1211
- this.renderedOptions
1212
- .toArray()
1213
- .slice(fromIndex, toIndex + 1)
1214
- .filter((item) => !item.disabled)
1215
- .forEach((renderedOption) => {
1216
- const isLastRenderedOption = renderedOption === this.keyManager.activeItem;
1217
- if (isLastRenderedOption && renderedOption.selected && this.noUnselectLast) {
1218
- return;
1219
- }
1220
- renderedOption.setSelected(!selectedOptionState);
1221
- });
1222
- }
1223
- setFocusedOption(option) {
1224
- this.keyManager.setActiveItem(option);
1225
- }
1226
- toggleFocusedOption() {
1227
- const focusedOption = this.keyManager.activeItem;
1228
- if (focusedOption && (!focusedOption.selected || this.canDeselectLast(focusedOption))) {
1229
- focusedOption.toggle();
1230
- this.emitChangeEvent(focusedOption);
1231
- }
1232
- }
1233
- renderNodeChanges(data, dataDiffer = this.dataDiffer, viewContainer = this.nodeOutlet.viewContainer, parentData) {
1234
- super.renderNodeChanges(data, dataDiffer, viewContainer, parentData);
1235
- this.sortedNodes = this.getSortedNodes(viewContainer);
1236
- this.nodeOutlet.changeDetectorRef.detectChanges();
1237
- }
1238
- emitNavigationEvent(option) {
1239
- this.navigationChange.emit(new McTreeNavigationChange(this, option));
1240
- }
1241
- emitChangeEvent(option) {
1242
- this.selectionChange.emit(new McTreeNavigationChange(this, option));
1243
- }
1244
- selectAllOptions() {
1245
- const optionsToSelect = this.renderedOptions
1246
- .filter((option) => !option.disabled);
1247
- optionsToSelect
1248
- .forEach((option) => option.setSelected(true));
1249
- this.onSelectAll.emit(new McTreeSelectAllEvent(this, optionsToSelect));
1250
- }
1251
- copyActiveOption() {
1252
- if (this.onCopy.observers.length) {
1253
- this.onCopy.emit(new McTreeCopyEvent(this, this.keyManager.activeItem));
1254
- }
1255
- else {
1256
- this.onCopyDefaultHandler();
1257
- }
1258
- }
1259
- writeValue(value) {
1260
- if (this.multiple && value && !Array.isArray(value)) {
1261
- throw getMcSelectNonArrayValueError();
1262
- }
1263
- if (value) {
1264
- this.setOptionsFromValues(this.multiple ? value : [value]);
1265
- }
1266
- else {
1267
- this.selectionModel.clear();
1268
- }
1269
- }
1270
- registerOnChange(fn) {
1271
- this.onChange = fn;
1272
- }
1273
- registerOnTouched(fn) {
1274
- this.onTouched = fn;
1275
- }
1276
- /**
1277
- * Sets the disabled state of the control. Implemented as a part of ControlValueAccessor.
1278
- */
1279
- setDisabledState(isDisabled) {
1280
- this._disabled = isDisabled;
1281
- this.changeDetectorRef.markForCheck();
1282
- }
1283
- setOptionsFromValues(values) {
1284
- this.selectionModel.clear();
1285
- const valuesToSelect = values.reduce((result, value) => {
1286
- return this.treeControl.hasValue(value) ? [...result, this.treeControl.hasValue(value)] : [...result];
1287
- }, []);
1288
- this.selectionModel.select(...valuesToSelect);
1289
- }
1290
- getSelectedValues() {
1291
- const selectedValues = this.selectionModel.selected.map((selected) => this.treeControl.getValue(selected));
1292
- return this.multiple ? selectedValues : selectedValues[0];
1293
- }
1294
- getItemHeight() {
1295
- return this.renderedOptions.first ? this.renderedOptions.first.getHeight() : 0;
1296
- }
1297
- onCopyDefaultHandler() {
1298
- this.clipboard?.copy(this.keyManager.activeItem.value);
1299
- }
1300
- getHeight() {
1301
- const clientRects = this.elementRef.nativeElement.getClientRects();
1302
- if (clientRects.length) {
1303
- return clientRects[0].height;
1304
- }
1305
- return 0;
1306
- }
1307
- updateTabIndex() {
1308
- this._tabIndex = this.renderedOptions.length === 0 ? -1 : 0;
1309
- }
1310
- getSortedNodes(viewContainer) {
1311
- const array = [];
1312
- for (let i = 0; i < viewContainer.length; i++) {
1313
- const viewRef = viewContainer.get(i);
1314
- array.push(viewRef.context.$implicit);
1315
- }
1316
- return array;
1317
- }
1318
- allowFocusEscape() {
1319
- if (this._tabIndex !== -1) {
1320
- this._tabIndex = -1;
1321
- setTimeout(() => {
1322
- this._tabIndex = this.userTabIndex || 0;
1323
- this.changeDetectorRef.markForCheck();
1324
- });
1325
- }
1326
- }
1327
- resetOptions() {
1328
- this.dropSubscriptions();
1329
- this.listenToOptionsFocus();
1330
- }
1331
- dropSubscriptions() {
1332
- if (this.optionFocusSubscription) {
1333
- this.optionFocusSubscription.unsubscribe();
1334
- this.optionFocusSubscription = null;
1335
- }
1336
- if (this.optionBlurSubscription) {
1337
- this.optionBlurSubscription.unsubscribe();
1338
- this.optionBlurSubscription = null;
1339
- }
1340
- }
1341
- listenToOptionsFocus() {
1342
- this.optionFocusSubscription = this.optionFocusChanges
1343
- .subscribe((event) => {
1344
- const index = this.renderedOptions.toArray().indexOf(event.option);
1345
- this.renderedOptions
1346
- .filter((option) => option.hasFocus)
1347
- .forEach((option) => option.hasFocus = false);
1348
- if (this.isValidIndex(index)) {
1349
- this.keyManager.updateActiveItem(index);
1350
- }
1351
- });
1352
- this.optionBlurSubscription = this.optionBlurChanges
1353
- .subscribe(() => this.blur());
1354
- }
1355
- /**
1356
- * Utility to ensure all indexes are valid.
1357
- * @param index The index to be checked.
1358
- * @returns True if the index is valid for our list of options.
1359
- */
1360
- isValidIndex(index) {
1361
- return index >= 0 && index < this.renderedOptions.length;
1362
- }
1363
- /** Checks whether any of the options is focused. */
1364
- hasFocusedOption() {
1365
- return this.renderedOptions.some((option) => option.hasFocus);
1366
- }
1367
- markOptionsForCheck() {
1368
- this.renderedOptions.forEach((option) => option.markForCheck());
1369
- }
1370
- updateOptionsFocus() {
1371
- this.renderedOptions
1372
- .filter((option) => option.hasFocus)
1373
- .forEach((option) => option.hasFocus = false);
1374
- }
1375
- canDeselectLast(option) {
1376
- return !(this.noUnselectLast && this.selectionModel.selected.length === 1 && option.selected);
1377
- }
1378
- isFocusReceivedFromNestedOption($event) {
1379
- if (!$event || !$event.relatedTarget) {
1380
- return false;
1381
- }
1382
- return $event.relatedTarget.classList.contains('mc-tree-option');
1383
- }
1384
- }
1385
- /** @nocollapse */ /** @nocollapse */ McTreeSelection.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: McTreeSelection, deps: [{ token: i0.ElementRef }, { token: i0.IterableDiffers }, { token: i0.ChangeDetectorRef }, { token: 'multiple', attribute: true }, { token: i1$1.Clipboard, optional: true }], target: i0.ɵɵFactoryTarget.Component });
1386
- /** @nocollapse */ /** @nocollapse */ McTreeSelection.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.4", type: McTreeSelection, selector: "mc-tree-selection", inputs: { treeControl: "treeControl", autoSelect: "autoSelect", noUnselectLast: "noUnselectLast", disabled: "disabled", tabIndex: "tabIndex" }, outputs: { navigationChange: "navigationChange", selectionChange: "selectionChange", onSelectAll: "onSelectAll", onCopy: "onCopy" }, host: { listeners: { "blur": "blur()", "focus": "focus($event)", "keydown": "onKeyDown($event)", "window:resize": "updateScrollSize()" }, properties: { "attr.tabindex": "tabIndex", "attr.disabled": "disabled || null" }, classAttribute: "mc-tree-selection" }, providers: [
1387
- MC_SELECTION_TREE_VALUE_ACCESSOR,
1388
- { provide: MC_TREE_OPTION_PARENT_COMPONENT, useExisting: McTreeSelection },
1389
- { provide: McTreeBase, useExisting: McTreeSelection }
1390
- ], queries: [{ propertyName: "unorderedOptions", predicate: McTreeOption }], viewQueries: [{ propertyName: "nodeOutlet", first: true, predicate: McTreeNodeOutlet, descendants: true, static: true }], exportAs: ["mcTreeSelection"], usesInheritance: true, ngImport: i0, template: '<ng-container mcTreeNodeOutlet></ng-container>', isInline: true, styles: [".mc-tree-selection{display:block}\n"], directives: [{ type: McTreeNodeOutlet, selector: "[mcTreeNodeOutlet]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
1391
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: McTreeSelection, decorators: [{
1392
- type: Component,
1393
- args: [{ selector: 'mc-tree-selection', exportAs: 'mcTreeSelection', template: '<ng-container mcTreeNodeOutlet></ng-container>', host: {
1394
- class: 'mc-tree-selection',
1395
- '[attr.tabindex]': 'tabIndex',
1396
- '[attr.disabled]': 'disabled || null',
1397
- '(blur)': 'blur()',
1398
- '(focus)': 'focus($event)',
1399
- '(keydown)': 'onKeyDown($event)',
1400
- '(window:resize)': 'updateScrollSize()'
1401
- }, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, providers: [
1402
- MC_SELECTION_TREE_VALUE_ACCESSOR,
1403
- { provide: MC_TREE_OPTION_PARENT_COMPONENT, useExisting: McTreeSelection },
1404
- { provide: McTreeBase, useExisting: McTreeSelection }
1405
- ], styles: [".mc-tree-selection{display:block}\n"] }]
1406
- }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.IterableDiffers }, { type: i0.ChangeDetectorRef }, { type: i1.MultipleMode, decorators: [{
1407
- type: Attribute,
1408
- args: ['multiple']
1409
- }] }, { type: i1$1.Clipboard, decorators: [{
1410
- type: Optional
1411
- }] }]; }, propDecorators: { nodeOutlet: [{
1412
- type: ViewChild,
1413
- args: [McTreeNodeOutlet, { static: true }]
1414
- }], unorderedOptions: [{
1415
- type: ContentChildren,
1416
- args: [McTreeOption]
1417
- }], treeControl: [{
1418
- type: Input
1419
- }], navigationChange: [{
1420
- type: Output
1421
- }], selectionChange: [{
1422
- type: Output
1423
- }], onSelectAll: [{
1424
- type: Output
1425
- }], onCopy: [{
1426
- type: Output
1427
- }], autoSelect: [{
1428
- type: Input
1429
- }], noUnselectLast: [{
1430
- type: Input
1431
- }], disabled: [{
1432
- type: Input
1433
- }], tabIndex: [{
1434
- type: Input
923
+ /* tslint:disable:no-empty */
924
+ const MC_SELECTION_TREE_VALUE_ACCESSOR = {
925
+ provide: NG_VALUE_ACCESSOR,
926
+ useExisting: forwardRef(() => McTreeSelection),
927
+ multi: true
928
+ };
929
+ class McTreeSelectAllEvent {
930
+ constructor(source, options) {
931
+ this.source = source;
932
+ this.options = options;
933
+ }
934
+ }
935
+ class McTreeCopyEvent {
936
+ constructor(source, option) {
937
+ this.source = source;
938
+ this.option = option;
939
+ }
940
+ }
941
+ class McTreeNavigationChange {
942
+ constructor(source, option) {
943
+ this.source = source;
944
+ this.option = option;
945
+ }
946
+ }
947
+ class McTreeSelectionChange {
948
+ constructor(source, option) {
949
+ this.source = source;
950
+ this.option = option;
951
+ }
952
+ }
953
+ class McTreeSelection extends McTreeBase {
954
+ constructor(elementRef, scheduler, differs, changeDetectorRef, multiple, clipboard) {
955
+ super(differs, changeDetectorRef);
956
+ this.elementRef = elementRef;
957
+ this.scheduler = scheduler;
958
+ this.clipboard = clipboard;
959
+ this.renderedOptions = new QueryList();
960
+ this.resetFocusedItemOnBlur = true;
961
+ this.multipleMode = null;
962
+ this.userTabIndex = null;
963
+ this.navigationChange = new EventEmitter();
964
+ this.selectionChange = new EventEmitter();
965
+ this.onSelectAll = new EventEmitter();
966
+ this.onCopy = new EventEmitter();
967
+ this.sortedNodes = [];
968
+ this._autoSelect = true;
969
+ this._noUnselectLast = true;
970
+ this._disabled = false;
971
+ this._tabIndex = 0;
972
+ this.destroy = new Subject();
973
+ /** `View -> model callback called when value changes` */
974
+ this.onChange = () => { };
975
+ /** `View -> model callback called when select has been touched` */
976
+ this.onTouched = () => { };
977
+ this.updateRenderedOptions = () => {
978
+ const orderedOptions = [];
979
+ this.sortedNodes.forEach((node) => {
980
+ const found = this.unorderedOptions.find((option) => option.value === this.treeControl.getValue(node));
981
+ if (found) {
982
+ orderedOptions.push(found);
983
+ }
984
+ });
985
+ this.renderedOptions.reset(orderedOptions);
986
+ this.renderedOptions.notifyOnChanges();
987
+ this.updateScrollSize();
988
+ };
989
+ if (multiple === MultipleMode.CHECKBOX || multiple === MultipleMode.KEYBOARD) {
990
+ this.multipleMode = multiple;
991
+ }
992
+ else if (multiple !== null) {
993
+ this.multipleMode = MultipleMode.CHECKBOX;
994
+ }
995
+ if (this.multipleMode === MultipleMode.CHECKBOX) {
996
+ this.autoSelect = false;
997
+ this.noUnselectLast = false;
998
+ }
999
+ this.selectionModel = new SelectionModel(this.multiple);
1000
+ }
1001
+ get autoSelect() {
1002
+ return this._autoSelect;
1003
+ }
1004
+ set autoSelect(value) {
1005
+ this._autoSelect = coerceBooleanProperty(value);
1006
+ }
1007
+ get optionFocusChanges() {
1008
+ return merge(...this.renderedOptions.map((option) => option.onFocus));
1009
+ }
1010
+ get optionBlurChanges() {
1011
+ return merge(...this.renderedOptions.map((option) => option.onBlur));
1012
+ }
1013
+ get multiple() {
1014
+ return !!this.multipleMode;
1015
+ }
1016
+ get noUnselectLast() {
1017
+ return this._noUnselectLast;
1018
+ }
1019
+ set noUnselectLast(value) {
1020
+ this._noUnselectLast = coerceBooleanProperty(value);
1021
+ }
1022
+ get disabled() {
1023
+ return this._disabled;
1024
+ }
1025
+ set disabled(rawValue) {
1026
+ const value = coerceBooleanProperty(rawValue);
1027
+ if (this._disabled !== value) {
1028
+ this._disabled = value;
1029
+ this.markOptionsForCheck();
1030
+ }
1031
+ }
1032
+ get tabIndex() {
1033
+ return this.disabled ? -1 : this._tabIndex;
1034
+ }
1035
+ set tabIndex(value) {
1036
+ this._tabIndex = value;
1037
+ this.userTabIndex = value;
1038
+ }
1039
+ get showCheckbox() {
1040
+ return this.multipleMode === MultipleMode.CHECKBOX;
1041
+ }
1042
+ get isEmpty() {
1043
+ return this.sortedNodes.length === 0;
1044
+ }
1045
+ ngAfterContentInit() {
1046
+ this.unorderedOptions.changes
1047
+ .subscribe(this.updateRenderedOptions);
1048
+ this.keyManager = new FocusKeyManager(this.renderedOptions)
1049
+ .withVerticalOrientation(true)
1050
+ .withHorizontalOrientation(null);
1051
+ this.keyManager.change
1052
+ .pipe(takeUntil(this.destroy))
1053
+ .subscribe(() => {
1054
+ if (this.keyManager.activeItem) {
1055
+ this.emitNavigationEvent(this.keyManager.activeItem);
1056
+ // todo need check this logic
1057
+ if (this.autoSelect && !this.keyManager.activeItem.disabled) {
1058
+ this.updateOptionsFocus();
1059
+ }
1060
+ }
1061
+ });
1062
+ this.keyManager.tabOut
1063
+ .pipe(takeUntil(this.destroy))
1064
+ .subscribe(() => this.allowFocusEscape());
1065
+ this.selectionModel.changed
1066
+ .pipe(takeUntil(this.destroy))
1067
+ .subscribe(() => {
1068
+ this.onChange(this.getSelectedValues());
1069
+ this.renderedOptions.notifyOnChanges();
1070
+ });
1071
+ this.renderedOptions.changes
1072
+ .pipe(takeUntil(this.destroy), delay(0, this.scheduler))
1073
+ .subscribe((options) => {
1074
+ this.resetOptions();
1075
+ // Check to see if we need to update our tab index
1076
+ this.updateTabIndex();
1077
+ const selectedValues = this.multiple ? this.getSelectedValues() : [this.getSelectedValues()];
1078
+ options.forEach((option) => {
1079
+ if (selectedValues.includes(option.value)) {
1080
+ option.select(false);
1081
+ }
1082
+ else {
1083
+ option.deselect();
1084
+ }
1085
+ option.markForCheck();
1086
+ });
1087
+ });
1088
+ }
1089
+ ngOnDestroy() {
1090
+ this.destroy.next();
1091
+ this.destroy.complete();
1092
+ }
1093
+ focus($event) {
1094
+ if (this.renderedOptions.length === 0 || this.isFocusReceivedFromNestedOption($event)) {
1095
+ return;
1096
+ }
1097
+ this.keyManager.setFocusOrigin('keyboard');
1098
+ this.keyManager.setFirstItemActive();
1099
+ this.keyManager.setFocusOrigin('program');
1100
+ }
1101
+ blur() {
1102
+ if (!this.hasFocusedOption() && this.resetFocusedItemOnBlur) {
1103
+ this.keyManager.setActiveItem(-1);
1104
+ }
1105
+ this.onTouched();
1106
+ this.changeDetectorRef.markForCheck();
1107
+ }
1108
+ onKeyDown(event) {
1109
+ this.keyManager.setFocusOrigin('keyboard');
1110
+ // tslint:disable-next-line: deprecation
1111
+ const keyCode = event.keyCode;
1112
+ if ([SPACE, LEFT_ARROW, RIGHT_ARROW].includes(keyCode) || isVerticalMovement(event)) {
1113
+ event.preventDefault();
1114
+ }
1115
+ if (this.multiple && isSelectAll(event)) {
1116
+ this.selectAllOptions();
1117
+ event.preventDefault();
1118
+ return;
1119
+ }
1120
+ else if (isCopy(event)) {
1121
+ this.copyActiveOption();
1122
+ return;
1123
+ }
1124
+ else if (keyCode === TAB) {
1125
+ this.keyManager.tabOut.next();
1126
+ return;
1127
+ }
1128
+ else if (keyCode === LEFT_ARROW && this.keyManager.activeItem?.isExpandable) {
1129
+ this.treeControl.collapse(this.keyManager.activeItem.data);
1130
+ return;
1131
+ }
1132
+ else if (keyCode === RIGHT_ARROW && this.keyManager.activeItem?.isExpandable) {
1133
+ this.treeControl.expand(this.keyManager.activeItem.data);
1134
+ return;
1135
+ }
1136
+ else if (keyCode === DOWN_ARROW) {
1137
+ this.keyManager.setNextItemActive();
1138
+ }
1139
+ else if (keyCode === UP_ARROW) {
1140
+ this.keyManager.setPreviousItemActive();
1141
+ }
1142
+ else if ([SPACE, ENTER].includes(keyCode)) {
1143
+ this.toggleFocusedOption();
1144
+ return;
1145
+ }
1146
+ else if (keyCode === HOME) {
1147
+ this.keyManager.setFirstItemActive();
1148
+ }
1149
+ else if (keyCode === END) {
1150
+ this.keyManager.setLastItemActive();
1151
+ }
1152
+ else if (keyCode === PAGE_UP) {
1153
+ this.keyManager.setPreviousPageItemActive();
1154
+ }
1155
+ else if (keyCode === PAGE_DOWN) {
1156
+ this.keyManager.setNextPageItemActive();
1157
+ }
1158
+ if (this.keyManager.activeItem && isVerticalMovement(event)) {
1159
+ this.setSelectedOptionsByKey(this.keyManager.activeItem, hasModifierKey(event, 'shiftKey'), hasModifierKey(event, 'ctrlKey'));
1160
+ }
1161
+ }
1162
+ updateScrollSize() {
1163
+ if (!this.renderedOptions.first) {
1164
+ return;
1165
+ }
1166
+ this.keyManager.withScrollSize(Math.floor(this.getHeight() / this.renderedOptions.first.getHeight()));
1167
+ }
1168
+ setSelectedOptionsByKey(option, shiftKey, ctrlKey) {
1169
+ if (shiftKey && this.multiple) {
1170
+ this.selectActiveOptions();
1171
+ this.emitChangeEvent(option);
1172
+ }
1173
+ else if (ctrlKey) {
1174
+ if (!this.canDeselectLast(option)) {
1175
+ return;
1176
+ }
1177
+ }
1178
+ else if (this.autoSelect) {
1179
+ this.selectionModel.clear();
1180
+ this.selectionModel.toggle(option.data);
1181
+ this.emitChangeEvent(option);
1182
+ }
1183
+ }
1184
+ setSelectedOptionsByClick(option, shiftKey, ctrlKey) {
1185
+ if (!shiftKey && !ctrlKey) {
1186
+ this.keyManager.setActiveItem(option);
1187
+ }
1188
+ if (shiftKey && this.multiple) {
1189
+ this.selectActiveOptions();
1190
+ }
1191
+ else if (ctrlKey) {
1192
+ if (!this.canDeselectLast(option)) {
1193
+ return;
1194
+ }
1195
+ this.selectionModel.toggle(option.data);
1196
+ this.keyManager.setActiveItem(option);
1197
+ }
1198
+ else if (this.autoSelect) {
1199
+ this.selectionModel.clear();
1200
+ this.selectionModel.toggle(option.data);
1201
+ }
1202
+ else {
1203
+ this.selectionModel.toggle(option.data);
1204
+ }
1205
+ this.emitChangeEvent(option);
1206
+ }
1207
+ selectActiveOptions() {
1208
+ const options = this.renderedOptions.toArray();
1209
+ let fromIndex = this.keyManager.previousActiveItemIndex;
1210
+ let toIndex = this.keyManager.previousActiveItemIndex = this.keyManager.activeItemIndex;
1211
+ const selectedOptionState = options[fromIndex].selected;
1212
+ if (toIndex === fromIndex) {
1213
+ return;
1214
+ }
1215
+ if (fromIndex > toIndex) {
1216
+ [fromIndex, toIndex] = [toIndex, fromIndex];
1217
+ }
1218
+ options
1219
+ .slice(fromIndex, toIndex + 1)
1220
+ .filter((item) => !item.disabled)
1221
+ .forEach((renderedOption) => {
1222
+ if (!selectedOptionState && this.noUnselectLast && this.selectionModel.selected.length === 1) {
1223
+ return;
1224
+ }
1225
+ renderedOption.setSelected(selectedOptionState);
1226
+ });
1227
+ }
1228
+ setFocusedOption(option) {
1229
+ this.keyManager.setActiveItem(option);
1230
+ }
1231
+ toggleFocusedOption() {
1232
+ const focusedOption = this.keyManager.activeItem;
1233
+ if (focusedOption && (!focusedOption.selected || this.canDeselectLast(focusedOption))) {
1234
+ focusedOption.toggle();
1235
+ this.emitChangeEvent(focusedOption);
1236
+ }
1237
+ }
1238
+ renderNodeChanges(data, dataDiffer = this.dataDiffer, viewContainer = this.nodeOutlet.viewContainer, parentData) {
1239
+ super.renderNodeChanges(data, dataDiffer, viewContainer, parentData);
1240
+ this.sortedNodes = this.getSortedNodes(viewContainer);
1241
+ this.nodeOutlet.changeDetectorRef.detectChanges();
1242
+ }
1243
+ emitNavigationEvent(option) {
1244
+ this.navigationChange.emit(new McTreeNavigationChange(this, option));
1245
+ }
1246
+ emitChangeEvent(option) {
1247
+ this.selectionChange.emit(new McTreeNavigationChange(this, option));
1248
+ }
1249
+ selectAllOptions() {
1250
+ const optionsToSelect = this.renderedOptions
1251
+ .filter((option) => !option.disabled);
1252
+ optionsToSelect
1253
+ .forEach((option) => option.setSelected(true));
1254
+ this.onSelectAll.emit(new McTreeSelectAllEvent(this, optionsToSelect));
1255
+ }
1256
+ copyActiveOption() {
1257
+ if (this.onCopy.observers.length) {
1258
+ this.onCopy.emit(new McTreeCopyEvent(this, this.keyManager.activeItem));
1259
+ }
1260
+ else {
1261
+ this.onCopyDefaultHandler();
1262
+ }
1263
+ }
1264
+ writeValue(value) {
1265
+ if (this.multiple && value && !Array.isArray(value)) {
1266
+ throw getMcSelectNonArrayValueError();
1267
+ }
1268
+ if (value) {
1269
+ this.setOptionsFromValues(this.multiple ? value : [value]);
1270
+ }
1271
+ else {
1272
+ this.selectionModel.clear();
1273
+ }
1274
+ }
1275
+ registerOnChange(fn) {
1276
+ this.onChange = fn;
1277
+ }
1278
+ registerOnTouched(fn) {
1279
+ this.onTouched = fn;
1280
+ }
1281
+ /**
1282
+ * Sets the disabled state of the control. Implemented as a part of ControlValueAccessor.
1283
+ */
1284
+ setDisabledState(isDisabled) {
1285
+ this._disabled = isDisabled;
1286
+ this.changeDetectorRef.markForCheck();
1287
+ }
1288
+ setOptionsFromValues(values) {
1289
+ this.selectionModel.clear();
1290
+ const valuesToSelect = values.reduce((result, value) => {
1291
+ return this.treeControl.hasValue(value) ? [...result, this.treeControl.hasValue(value)] : [...result];
1292
+ }, []);
1293
+ this.selectionModel.select(...valuesToSelect);
1294
+ }
1295
+ getSelectedValues() {
1296
+ const selectedValues = this.selectionModel.selected.map((selected) => this.treeControl.getValue(selected));
1297
+ return this.multiple ? selectedValues : selectedValues[0];
1298
+ }
1299
+ getItemHeight() {
1300
+ return this.renderedOptions.first ? this.renderedOptions.first.getHeight() : 0;
1301
+ }
1302
+ onCopyDefaultHandler() {
1303
+ this.clipboard?.copy(this.keyManager.activeItem.value);
1304
+ }
1305
+ getHeight() {
1306
+ const clientRects = this.elementRef.nativeElement.getClientRects();
1307
+ if (clientRects.length) {
1308
+ return clientRects[0].height;
1309
+ }
1310
+ return 0;
1311
+ }
1312
+ updateTabIndex() {
1313
+ this._tabIndex = this.renderedOptions.length === 0 ? -1 : 0;
1314
+ }
1315
+ getSortedNodes(viewContainer) {
1316
+ const array = [];
1317
+ for (let i = 0; i < viewContainer.length; i++) {
1318
+ const viewRef = viewContainer.get(i);
1319
+ array.push(viewRef.context.$implicit);
1320
+ }
1321
+ return array;
1322
+ }
1323
+ allowFocusEscape() {
1324
+ if (this._tabIndex !== -1) {
1325
+ this._tabIndex = -1;
1326
+ setTimeout(() => {
1327
+ this._tabIndex = this.userTabIndex || 0;
1328
+ this.changeDetectorRef.markForCheck();
1329
+ });
1330
+ }
1331
+ }
1332
+ resetOptions() {
1333
+ this.dropSubscriptions();
1334
+ this.listenToOptionsFocus();
1335
+ }
1336
+ dropSubscriptions() {
1337
+ if (this.optionFocusSubscription) {
1338
+ this.optionFocusSubscription.unsubscribe();
1339
+ this.optionFocusSubscription = null;
1340
+ }
1341
+ if (this.optionBlurSubscription) {
1342
+ this.optionBlurSubscription.unsubscribe();
1343
+ this.optionBlurSubscription = null;
1344
+ }
1345
+ }
1346
+ listenToOptionsFocus() {
1347
+ this.optionFocusSubscription = this.optionFocusChanges
1348
+ .subscribe((event) => {
1349
+ const index = this.renderedOptions.toArray().indexOf(event.option);
1350
+ this.renderedOptions
1351
+ .filter((option) => option.hasFocus)
1352
+ .forEach((option) => option.hasFocus = false);
1353
+ if (this.isValidIndex(index)) {
1354
+ this.keyManager.updateActiveItem(index);
1355
+ }
1356
+ });
1357
+ this.optionBlurSubscription = this.optionBlurChanges
1358
+ .subscribe(() => this.blur());
1359
+ }
1360
+ /**
1361
+ * Utility to ensure all indexes are valid.
1362
+ * @param index The index to be checked.
1363
+ * @returns True if the index is valid for our list of options.
1364
+ */
1365
+ isValidIndex(index) {
1366
+ return index >= 0 && index < this.renderedOptions.length;
1367
+ }
1368
+ /** Checks whether any of the options is focused. */
1369
+ hasFocusedOption() {
1370
+ return this.renderedOptions.some((option) => option.hasFocus);
1371
+ }
1372
+ markOptionsForCheck() {
1373
+ this.renderedOptions.forEach((option) => option.markForCheck());
1374
+ }
1375
+ updateOptionsFocus() {
1376
+ this.renderedOptions
1377
+ .filter((option) => option.hasFocus)
1378
+ .forEach((option) => option.hasFocus = false);
1379
+ }
1380
+ canDeselectLast(option) {
1381
+ return !(this.noUnselectLast && this.selectionModel.selected.length === 1 && option.selected);
1382
+ }
1383
+ isFocusReceivedFromNestedOption($event) {
1384
+ if (!$event || !$event.relatedTarget) {
1385
+ return false;
1386
+ }
1387
+ return $event.relatedTarget.classList.contains('mc-tree-option');
1388
+ }
1389
+ }
1390
+ /** @nocollapse */ /** @nocollapse */ McTreeSelection.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.7", ngImport: i0, type: McTreeSelection, deps: [{ token: i0.ElementRef }, { token: i1$1.AsyncScheduler }, { token: i0.IterableDiffers }, { token: i0.ChangeDetectorRef }, { token: 'multiple', attribute: true }, { token: i2$2.Clipboard, optional: true }], target: i0.ɵɵFactoryTarget.Component });
1391
+ /** @nocollapse */ /** @nocollapse */ McTreeSelection.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.7", type: McTreeSelection, selector: "mc-tree-selection", inputs: { treeControl: "treeControl", autoSelect: "autoSelect", noUnselectLast: "noUnselectLast", disabled: "disabled", tabIndex: "tabIndex" }, outputs: { navigationChange: "navigationChange", selectionChange: "selectionChange", onSelectAll: "onSelectAll", onCopy: "onCopy" }, host: { listeners: { "blur": "blur()", "focus": "focus($event)", "keydown": "onKeyDown($event)", "window:resize": "updateScrollSize()" }, properties: { "attr.tabindex": "tabIndex", "attr.disabled": "disabled || null" }, classAttribute: "mc-tree-selection" }, providers: [
1392
+ MC_SELECTION_TREE_VALUE_ACCESSOR,
1393
+ { provide: MC_TREE_OPTION_PARENT_COMPONENT, useExisting: McTreeSelection },
1394
+ { provide: McTreeBase, useExisting: McTreeSelection }
1395
+ ], queries: [{ propertyName: "unorderedOptions", predicate: McTreeOption }], viewQueries: [{ propertyName: "nodeOutlet", first: true, predicate: McTreeNodeOutlet, descendants: true, static: true }], exportAs: ["mcTreeSelection"], usesInheritance: true, ngImport: i0, template: '<ng-container mcTreeNodeOutlet></ng-container>', isInline: true, styles: [".mc-tree-selection{display:block}\n"], directives: [{ type: McTreeNodeOutlet, selector: "[mcTreeNodeOutlet]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
1396
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.7", ngImport: i0, type: McTreeSelection, decorators: [{
1397
+ type: Component,
1398
+ args: [{ selector: 'mc-tree-selection', exportAs: 'mcTreeSelection', template: '<ng-container mcTreeNodeOutlet></ng-container>', host: {
1399
+ class: 'mc-tree-selection',
1400
+ '[attr.tabindex]': 'tabIndex',
1401
+ '[attr.disabled]': 'disabled || null',
1402
+ '(blur)': 'blur()',
1403
+ '(focus)': 'focus($event)',
1404
+ '(keydown)': 'onKeyDown($event)',
1405
+ '(window:resize)': 'updateScrollSize()'
1406
+ }, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, providers: [
1407
+ MC_SELECTION_TREE_VALUE_ACCESSOR,
1408
+ { provide: MC_TREE_OPTION_PARENT_COMPONENT, useExisting: McTreeSelection },
1409
+ { provide: McTreeBase, useExisting: McTreeSelection }
1410
+ ], styles: [".mc-tree-selection{display:block}\n"] }]
1411
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1$1.AsyncScheduler }, { type: i0.IterableDiffers }, { type: i0.ChangeDetectorRef }, { type: i1.MultipleMode, decorators: [{
1412
+ type: Attribute,
1413
+ args: ['multiple']
1414
+ }] }, { type: i2$2.Clipboard, decorators: [{
1415
+ type: Optional
1416
+ }] }]; }, propDecorators: { nodeOutlet: [{
1417
+ type: ViewChild,
1418
+ args: [McTreeNodeOutlet, { static: true }]
1419
+ }], unorderedOptions: [{
1420
+ type: ContentChildren,
1421
+ args: [McTreeOption]
1422
+ }], treeControl: [{
1423
+ type: Input
1424
+ }], navigationChange: [{
1425
+ type: Output
1426
+ }], selectionChange: [{
1427
+ type: Output
1428
+ }], onSelectAll: [{
1429
+ type: Output
1430
+ }], onCopy: [{
1431
+ type: Output
1432
+ }], autoSelect: [{
1433
+ type: Input
1434
+ }], noUnselectLast: [{
1435
+ type: Input
1436
+ }], disabled: [{
1437
+ type: Input
1438
+ }], tabIndex: [{
1439
+ type: Input
1435
1440
  }] } });
1436
1441
 
1437
- const MC_TREE_DIRECTIVES = [
1438
- McTreeNodeOutlet,
1439
- McTreeNodeDef,
1440
- McTreeNode,
1441
- McTreeNodePadding,
1442
- McTree,
1443
- McTreeSelection,
1444
- McTreeOption,
1445
- McTreeNodeToggleComponent,
1446
- McTreeNodeToggleDirective
1447
- ];
1448
- class McTreeModule {
1449
- }
1450
- /** @nocollapse */ /** @nocollapse */ McTreeModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: McTreeModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
1451
- /** @nocollapse */ /** @nocollapse */ McTreeModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: McTreeModule, declarations: [McTreeNodeOutlet,
1452
- McTreeNodeDef,
1453
- McTreeNode,
1454
- McTreeNodePadding,
1455
- McTree,
1456
- McTreeSelection,
1457
- McTreeOption,
1458
- McTreeNodeToggleComponent,
1459
- McTreeNodeToggleDirective], imports: [CommonModule, McPseudoCheckboxModule], exports: [McTreeNodeOutlet,
1460
- McTreeNodeDef,
1461
- McTreeNode,
1462
- McTreeNodePadding,
1463
- McTree,
1464
- McTreeSelection,
1465
- McTreeOption,
1466
- McTreeNodeToggleComponent,
1467
- McTreeNodeToggleDirective] });
1468
- /** @nocollapse */ /** @nocollapse */ McTreeModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: McTreeModule, imports: [[CommonModule, McPseudoCheckboxModule]] });
1469
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: McTreeModule, decorators: [{
1470
- type: NgModule,
1471
- args: [{
1472
- imports: [CommonModule, McPseudoCheckboxModule],
1473
- exports: MC_TREE_DIRECTIVES,
1474
- declarations: MC_TREE_DIRECTIVES
1475
- }]
1442
+ const MC_TREE_DIRECTIVES = [
1443
+ McTreeNodeOutlet,
1444
+ McTreeNodeDef,
1445
+ McTreeNode,
1446
+ McTreeNodePadding,
1447
+ McTree,
1448
+ McTreeSelection,
1449
+ McTreeOption,
1450
+ McTreeNodeToggleComponent,
1451
+ McTreeNodeToggleDirective
1452
+ ];
1453
+ class McTreeModule {
1454
+ }
1455
+ /** @nocollapse */ /** @nocollapse */ McTreeModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.7", ngImport: i0, type: McTreeModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
1456
+ /** @nocollapse */ /** @nocollapse */ McTreeModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.3.7", ngImport: i0, type: McTreeModule, declarations: [McTreeNodeOutlet,
1457
+ McTreeNodeDef,
1458
+ McTreeNode,
1459
+ McTreeNodePadding,
1460
+ McTree,
1461
+ McTreeSelection,
1462
+ McTreeOption,
1463
+ McTreeNodeToggleComponent,
1464
+ McTreeNodeToggleDirective], imports: [CommonModule, McPseudoCheckboxModule], exports: [McTreeNodeOutlet,
1465
+ McTreeNodeDef,
1466
+ McTreeNode,
1467
+ McTreeNodePadding,
1468
+ McTree,
1469
+ McTreeSelection,
1470
+ McTreeOption,
1471
+ McTreeNodeToggleComponent,
1472
+ McTreeNodeToggleDirective] });
1473
+ /** @nocollapse */ /** @nocollapse */ McTreeModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.3.7", ngImport: i0, type: McTreeModule, providers: [{ provide: AsyncScheduler, useValue: asyncScheduler }], imports: [[CommonModule, McPseudoCheckboxModule]] });
1474
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.7", ngImport: i0, type: McTreeModule, decorators: [{
1475
+ type: NgModule,
1476
+ args: [{
1477
+ imports: [CommonModule, McPseudoCheckboxModule],
1478
+ exports: MC_TREE_DIRECTIVES,
1479
+ declarations: MC_TREE_DIRECTIVES,
1480
+ providers: [{ provide: AsyncScheduler, useValue: asyncScheduler }]
1481
+ }]
1476
1482
  }] });
1477
1483
 
1478
- /** Nested tree control. Able to expand/collapse a subtree recursively for NestedNode type. */
1479
- class NestedTreeControl extends BaseTreeControl {
1480
- /** Construct with nested tree function getChildren. */
1481
- constructor(getChildren) {
1482
- super();
1483
- this.getChildren = getChildren;
1484
- }
1485
- /**
1486
- * Expands all dataNodes in the tree.
1487
- *
1488
- * To make this working, the `dataNodes` variable of the TreeControl must be set to all root level
1489
- * data nodes of the tree.
1490
- */
1491
- expandAll() {
1492
- this.expansionModel.clear();
1493
- const allNodes = this.dataNodes.reduce((accumulator, dataNode) => [...accumulator, ...this.getDescendants(dataNode), dataNode], []);
1494
- this.expansionModel.select(...allNodes);
1495
- }
1496
- /** Gets a list of descendant dataNodes of a subtree rooted at given data node recursively. */
1497
- getDescendants(dataNode) {
1498
- const descendants = [];
1499
- this._getDescendants(descendants, dataNode);
1500
- return descendants.splice(1);
1501
- }
1502
- /** A helper function to get descendants recursively. */
1503
- // todo нужно придумать другое название и понять в чем отличие между getDescendants и _getDescendants
1504
- /* tslint:disable-next-line:naming-convention */
1505
- _getDescendants(descendants, dataNode) {
1506
- descendants.push(dataNode);
1507
- this.getChildren(dataNode)
1508
- .pipe(take(1))
1509
- .subscribe((children) => {
1510
- if (children && children.length > 0) {
1511
- children.forEach((child) => this._getDescendants(descendants, child));
1512
- }
1513
- });
1514
- }
1484
+ /** Nested tree control. Able to expand/collapse a subtree recursively for NestedNode type. */
1485
+ class NestedTreeControl extends BaseTreeControl {
1486
+ /** Construct with nested tree function getChildren. */
1487
+ constructor(getChildren) {
1488
+ super();
1489
+ this.getChildren = getChildren;
1490
+ }
1491
+ /**
1492
+ * Expands all dataNodes in the tree.
1493
+ *
1494
+ * To make this working, the `dataNodes` variable of the TreeControl must be set to all root level
1495
+ * data nodes of the tree.
1496
+ */
1497
+ expandAll() {
1498
+ this.expansionModel.clear();
1499
+ const allNodes = this.dataNodes.reduce((accumulator, dataNode) => [...accumulator, ...this.getDescendants(dataNode), dataNode], []);
1500
+ this.expansionModel.select(...allNodes);
1501
+ }
1502
+ /** Gets a list of descendant dataNodes of a subtree rooted at given data node recursively. */
1503
+ getDescendants(dataNode) {
1504
+ const descendants = [];
1505
+ this._getDescendants(descendants, dataNode);
1506
+ return descendants.splice(1);
1507
+ }
1508
+ /** A helper function to get descendants recursively. */
1509
+ // todo нужно придумать другое название и понять в чем отличие между getDescendants и _getDescendants
1510
+ /* tslint:disable-next-line:naming-convention */
1511
+ _getDescendants(descendants, dataNode) {
1512
+ descendants.push(dataNode);
1513
+ this.getChildren(dataNode)
1514
+ .pipe(take(1))
1515
+ .subscribe((children) => {
1516
+ if (children && children.length > 0) {
1517
+ children.forEach((child) => this._getDescendants(descendants, child));
1518
+ }
1519
+ });
1520
+ }
1515
1521
  }
1516
1522
 
1517
- /**
1518
- * Tree flattener to convert a normal type of node to node with children & level information.
1519
- * Transform nested nodes of type `T` to flattened nodes of type `F`.
1520
- *
1521
- * For example, the input data of type `T` is nested, and contains its children data:
1522
- * SomeNode: {
1523
- * key: 'Fruits',
1524
- * children: [
1525
- * NodeOne: {
1526
- * key: 'Apple',
1527
- * },
1528
- * NodeTwo: {
1529
- * key: 'Pear',
1530
- * }
1531
- * ]
1532
- * }
1533
- * After flattener flatten the tree, the structure will become
1534
- * SomeNode: {
1535
- * key: 'Fruits',
1536
- * expandable: true,
1537
- * level: 1
1538
- * },
1539
- * NodeOne: {
1540
- * key: 'Apple',
1541
- * expandable: false,
1542
- * level: 2
1543
- * },
1544
- * NodeTwo: {
1545
- * key: 'Pear',
1546
- * expandable: false,
1547
- * level: 2
1548
- * }
1549
- * and the output flattened type is `F` with additional information.
1550
- */
1551
- class McTreeFlattener {
1552
- constructor(transformFunction, getLevel, isExpandable, getChildren) {
1553
- this.transformFunction = transformFunction;
1554
- this.getLevel = getLevel;
1555
- this.isExpandable = isExpandable;
1556
- this.getChildren = getChildren;
1557
- }
1558
- flattenNode(node, level, resultNodes, parent) {
1559
- const flatNode = this.transformFunction(node, level, parent);
1560
- resultNodes.push(flatNode);
1561
- if (this.isExpandable(flatNode)) {
1562
- const childrenNodes = this.getChildren(node);
1563
- if (childrenNodes) {
1564
- if (Array.isArray(childrenNodes)) {
1565
- this.flattenChildren(childrenNodes, level, resultNodes, flatNode);
1566
- }
1567
- else {
1568
- childrenNodes
1569
- .pipe(take(1))
1570
- .subscribe((children) => {
1571
- this.flattenChildren(children, level, resultNodes, flatNode);
1572
- });
1573
- }
1574
- }
1575
- }
1576
- return resultNodes;
1577
- }
1578
- flattenChildren(children, level, resultNodes, parent) {
1579
- children.forEach((child) => {
1580
- this.flattenNode(child, level + 1, resultNodes, parent);
1581
- });
1582
- }
1583
- /**
1584
- * Flatten a list of node type T to flattened version of node F.
1585
- * Please note that type T may be nested, and the length of `structuredData` may be different
1586
- * from that of returned list `F[]`.
1587
- */
1588
- flattenNodes(structuredData) {
1589
- const resultNodes = [];
1590
- structuredData.forEach((node) => this.flattenNode(node, 0, resultNodes, null));
1591
- return resultNodes;
1592
- }
1593
- /**
1594
- * Expand flattened node with current expansion status.
1595
- * The returned list may have different length.
1596
- */
1597
- expandFlattenedNodes(nodes, treeControl) {
1598
- const results = [];
1599
- const currentExpand = [];
1600
- currentExpand[0] = true;
1601
- nodes.forEach((node) => {
1602
- let expand = true;
1603
- for (let i = 0; i <= this.getLevel(node); i++) {
1604
- expand = expand && currentExpand[i];
1605
- }
1606
- if (expand) {
1607
- results.push(node);
1608
- }
1609
- if (this.isExpandable(node)) {
1610
- currentExpand[this.getLevel(node) + 1] = treeControl.isExpanded(node);
1611
- }
1612
- });
1613
- return results;
1614
- }
1615
- }
1616
- var McTreeDataSourceChangeTypes;
1617
- (function (McTreeDataSourceChangeTypes) {
1618
- McTreeDataSourceChangeTypes["Expansion"] = "expansion";
1619
- McTreeDataSourceChangeTypes["Filter"] = "filter";
1620
- })(McTreeDataSourceChangeTypes || (McTreeDataSourceChangeTypes = {}));
1621
- /**
1622
- * Data source for flat tree.
1623
- * The data source need to handle expansion/collapsion of the tree node and change the data feed
1624
- * to `McTree`.
1625
- * The nested tree nodes of type `T` are flattened through `MсTreeFlattener`, and converted
1626
- * to type `F` for `McTree` to consume.
1627
- */
1628
- class McTreeFlatDataSource extends DataSource {
1629
- constructor(treeControl, treeFlattener, initialData = []) {
1630
- super();
1631
- this.treeControl = treeControl;
1632
- this.treeFlattener = treeFlattener;
1633
- this.flattenedData = new BehaviorSubject([]);
1634
- this.expandedData = new BehaviorSubject([]);
1635
- this.filteredData = new BehaviorSubject([]);
1636
- this._data = new BehaviorSubject(initialData);
1637
- }
1638
- get data() {
1639
- return this._data.value;
1640
- }
1641
- set data(value) {
1642
- this._data.next(value);
1643
- this.flattenedData.next(this.treeFlattener.flattenNodes(this.data));
1644
- this.treeControl.dataNodes = this.flattenedData.value;
1645
- }
1646
- connect(collectionViewer) {
1647
- return merge(collectionViewer.viewChange, this.treeControl.expansionModel.changed
1648
- .pipe(map((value) => ({ type: McTreeDataSourceChangeTypes.Expansion, value }))), this.treeControl.filterValue
1649
- .pipe(map((value) => ({ type: McTreeDataSourceChangeTypes.Filter, value }))), this.flattenedData)
1650
- .pipe(map((changeObj) => {
1651
- if (changeObj.type === McTreeDataSourceChangeTypes.Filter) {
1652
- if (changeObj.value && changeObj.value.length > 0) {
1653
- return this.filterHandler();
1654
- }
1655
- else {
1656
- return this.expansionHandler(changeObj.value);
1657
- }
1658
- }
1659
- return this.expansionHandler(changeObj.value);
1660
- }));
1661
- }
1662
- filterHandler() {
1663
- this.filteredData.next(this.treeControl.filterModel.selected);
1664
- return this.filteredData.value;
1665
- }
1666
- expansionHandler(_change) {
1667
- const expandedNodes = this.treeFlattener.expandFlattenedNodes(this.flattenedData.value, this.treeControl);
1668
- this.expandedData.next(expandedNodes);
1669
- return this.expandedData.value;
1670
- }
1671
- disconnect() {
1672
- // no op
1673
- }
1523
+ /**
1524
+ * Tree flattener to convert a normal type of node to node with children & level information.
1525
+ * Transform nested nodes of type `T` to flattened nodes of type `F`.
1526
+ *
1527
+ * For example, the input data of type `T` is nested, and contains its children data:
1528
+ * SomeNode: {
1529
+ * key: 'Fruits',
1530
+ * children: [
1531
+ * NodeOne: {
1532
+ * key: 'Apple',
1533
+ * },
1534
+ * NodeTwo: {
1535
+ * key: 'Pear',
1536
+ * }
1537
+ * ]
1538
+ * }
1539
+ * After flattener flatten the tree, the structure will become
1540
+ * SomeNode: {
1541
+ * key: 'Fruits',
1542
+ * expandable: true,
1543
+ * level: 1
1544
+ * },
1545
+ * NodeOne: {
1546
+ * key: 'Apple',
1547
+ * expandable: false,
1548
+ * level: 2
1549
+ * },
1550
+ * NodeTwo: {
1551
+ * key: 'Pear',
1552
+ * expandable: false,
1553
+ * level: 2
1554
+ * }
1555
+ * and the output flattened type is `F` with additional information.
1556
+ */
1557
+ class McTreeFlattener {
1558
+ constructor(transformFunction, getLevel, isExpandable, getChildren) {
1559
+ this.transformFunction = transformFunction;
1560
+ this.getLevel = getLevel;
1561
+ this.isExpandable = isExpandable;
1562
+ this.getChildren = getChildren;
1563
+ }
1564
+ flattenNode(node, level, resultNodes, parent) {
1565
+ const flatNode = this.transformFunction(node, level, parent);
1566
+ resultNodes.push(flatNode);
1567
+ if (this.isExpandable(flatNode)) {
1568
+ const childrenNodes = this.getChildren(node);
1569
+ if (childrenNodes) {
1570
+ if (Array.isArray(childrenNodes)) {
1571
+ this.flattenChildren(childrenNodes, level, resultNodes, flatNode);
1572
+ }
1573
+ else {
1574
+ childrenNodes
1575
+ .pipe(take(1))
1576
+ .subscribe((children) => {
1577
+ this.flattenChildren(children, level, resultNodes, flatNode);
1578
+ });
1579
+ }
1580
+ }
1581
+ }
1582
+ return resultNodes;
1583
+ }
1584
+ flattenChildren(children, level, resultNodes, parent) {
1585
+ children.forEach((child) => {
1586
+ this.flattenNode(child, level + 1, resultNodes, parent);
1587
+ });
1588
+ }
1589
+ /**
1590
+ * Flatten a list of node type T to flattened version of node F.
1591
+ * Please note that type T may be nested, and the length of `structuredData` may be different
1592
+ * from that of returned list `F[]`.
1593
+ */
1594
+ flattenNodes(structuredData) {
1595
+ const resultNodes = [];
1596
+ structuredData.forEach((node) => this.flattenNode(node, 0, resultNodes, null));
1597
+ return resultNodes;
1598
+ }
1599
+ /**
1600
+ * Expand flattened node with current expansion status.
1601
+ * The returned list may have different length.
1602
+ */
1603
+ expandFlattenedNodes(nodes, treeControl) {
1604
+ const results = [];
1605
+ const currentExpand = [];
1606
+ currentExpand[0] = true;
1607
+ nodes.forEach((node) => {
1608
+ let expand = true;
1609
+ for (let i = 0; i <= this.getLevel(node); i++) {
1610
+ expand = expand && currentExpand[i];
1611
+ }
1612
+ if (expand) {
1613
+ results.push(node);
1614
+ }
1615
+ if (this.isExpandable(node)) {
1616
+ currentExpand[this.getLevel(node) + 1] = treeControl.isExpanded(node);
1617
+ }
1618
+ });
1619
+ return results;
1620
+ }
1621
+ }
1622
+ var McTreeDataSourceChangeTypes;
1623
+ (function (McTreeDataSourceChangeTypes) {
1624
+ McTreeDataSourceChangeTypes["Expansion"] = "expansion";
1625
+ McTreeDataSourceChangeTypes["Filter"] = "filter";
1626
+ })(McTreeDataSourceChangeTypes || (McTreeDataSourceChangeTypes = {}));
1627
+ /**
1628
+ * Data source for flat tree.
1629
+ * The data source need to handle expansion/collapsion of the tree node and change the data feed
1630
+ * to `McTree`.
1631
+ * The nested tree nodes of type `T` are flattened through `MсTreeFlattener`, and converted
1632
+ * to type `F` for `McTree` to consume.
1633
+ */
1634
+ class McTreeFlatDataSource extends DataSource {
1635
+ constructor(treeControl, treeFlattener, initialData = []) {
1636
+ super();
1637
+ this.treeControl = treeControl;
1638
+ this.treeFlattener = treeFlattener;
1639
+ this.flattenedData = new BehaviorSubject([]);
1640
+ this.expandedData = new BehaviorSubject([]);
1641
+ this.filteredData = new BehaviorSubject([]);
1642
+ this._data = new BehaviorSubject(initialData);
1643
+ }
1644
+ get data() {
1645
+ return this._data.value;
1646
+ }
1647
+ set data(value) {
1648
+ this._data.next(value);
1649
+ this.flattenedData.next(this.treeFlattener.flattenNodes(this.data));
1650
+ this.treeControl.dataNodes = this.flattenedData.value;
1651
+ }
1652
+ connect(collectionViewer) {
1653
+ return merge(collectionViewer.viewChange, this.treeControl.expansionModel.changed
1654
+ .pipe(map((value) => ({ type: McTreeDataSourceChangeTypes.Expansion, value }))), this.treeControl.filterValue
1655
+ .pipe(map((value) => ({ type: McTreeDataSourceChangeTypes.Filter, value }))), this.flattenedData)
1656
+ .pipe(map((changeObj) => {
1657
+ if (changeObj.type === McTreeDataSourceChangeTypes.Filter) {
1658
+ if (changeObj.value && changeObj.value.length > 0) {
1659
+ return this.filterHandler();
1660
+ }
1661
+ else {
1662
+ return this.expansionHandler(changeObj.value);
1663
+ }
1664
+ }
1665
+ return this.expansionHandler(changeObj.value);
1666
+ }));
1667
+ }
1668
+ filterHandler() {
1669
+ this.filteredData.next(this.treeControl.filterModel.selected);
1670
+ return this.filteredData.value;
1671
+ }
1672
+ expansionHandler(_change) {
1673
+ const expandedNodes = this.treeFlattener.expandFlattenedNodes(this.flattenedData.value, this.treeControl);
1674
+ this.expandedData.next(expandedNodes);
1675
+ return this.expandedData.value;
1676
+ }
1677
+ disconnect() {
1678
+ // no op
1679
+ }
1674
1680
  }
1675
1681
 
1676
- /**
1677
- * Data source for nested tree.
1678
- *
1679
- * The data source for nested tree doesn't have to consider node flattener, or the way to expand
1680
- * or collapse. The expansion/collapsion will be handled by TreeControl and each non-leaf node.
1681
- */
1682
- class McTreeNestedDataSource extends DataSource {
1683
- constructor() {
1684
- super(...arguments);
1685
- /* tslint:disable-next-line:naming-convention */
1686
- this._data = new BehaviorSubject([]);
1687
- }
1688
- get data() {
1689
- return this._data.value;
1690
- }
1691
- set data(value) {
1692
- this._data.next(value);
1693
- }
1694
- connect(collectionViewer) {
1695
- return merge(...[collectionViewer.viewChange, this._data])
1696
- .pipe(map(() => this.data));
1697
- }
1698
- disconnect() {
1699
- // no op
1700
- }
1682
+ /**
1683
+ * Data source for nested tree.
1684
+ *
1685
+ * The data source for nested tree doesn't have to consider node flattener, or the way to expand
1686
+ * or collapse. The expansion/collapsion will be handled by TreeControl and each non-leaf node.
1687
+ */
1688
+ class McTreeNestedDataSource extends DataSource {
1689
+ constructor() {
1690
+ super(...arguments);
1691
+ /* tslint:disable-next-line:naming-convention */
1692
+ this._data = new BehaviorSubject([]);
1693
+ }
1694
+ get data() {
1695
+ return this._data.value;
1696
+ }
1697
+ set data(value) {
1698
+ this._data.next(value);
1699
+ }
1700
+ connect(collectionViewer) {
1701
+ return merge(...[collectionViewer.viewChange, this._data])
1702
+ .pipe(map(() => this.data));
1703
+ }
1704
+ disconnect() {
1705
+ // no op
1706
+ }
1701
1707
  }
1702
1708
 
1703
- /**
1704
- * Generated bundle index. Do not edit.
1709
+ /**
1710
+ * Generated bundle index. Do not edit.
1705
1711
  */
1706
1712
 
1707
1713
  export { BaseTreeControl, FlatTreeControl, MC_SELECTION_TREE_VALUE_ACCESSOR, MC_TREE_OPTION_PARENT_COMPONENT, McTree, McTreeBase, McTreeCopyEvent, McTreeFlatDataSource, McTreeFlattener, McTreeModule, McTreeNavigationChange, McTreeNestedDataSource, McTreeNode, McTreeNodeDef, McTreeNodeOutlet, McTreeNodeOutletContext, McTreeNodePadding, McTreeNodeToggleBase, McTreeNodeToggleBaseDirective, McTreeNodeToggleComponent, McTreeNodeToggleDirective, McTreeNodeToggleMixinBase, McTreeOption, McTreeOptionChange, McTreeSelectAllEvent, McTreeSelection, McTreeSelectionChange, NestedTreeControl, defaultCompareValues, defaultCompareViewValues };