@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
@@ -19,1087 +19,1091 @@ import { FocusKeyManager } from '@ptsecurity/cdk/a11y';
19
19
  import { trigger, state, style, transition, group, query, animate } from '@angular/animations';
20
20
  import * as i4 from '@angular/cdk/bidi';
21
21
 
22
- /**
23
- * Injection token used to provide the parent dropdown to dropdown-specific components.
24
- * @docs-private
25
- */
26
- const MC_DROPDOWN_PANEL = new InjectionToken('MC_DROPDOWN_PANEL');
27
- /** Injection token to be used to override the default options for `mc-dropdown`. */
28
- const MC_DROPDOWN_DEFAULT_OPTIONS = new InjectionToken('mc-dropdown-default-options', {
29
- providedIn: 'root',
30
- factory: MC_DROPDOWN_DEFAULT_OPTIONS_FACTORY
31
- });
32
- /** @docs-private */
33
- // tslint:disable-next-line:naming-convention
34
- function MC_DROPDOWN_DEFAULT_OPTIONS_FACTORY() {
35
- return {
36
- overlapTriggerX: true,
37
- overlapTriggerY: false,
38
- xPosition: 'after',
39
- yPosition: 'below',
40
- backdropClass: 'cdk-overlay-transparent-backdrop',
41
- hasBackdrop: false
42
- };
22
+ /**
23
+ * Injection token used to provide the parent dropdown to dropdown-specific components.
24
+ * @docs-private
25
+ */
26
+ const MC_DROPDOWN_PANEL = new InjectionToken('MC_DROPDOWN_PANEL');
27
+ /** Injection token to be used to override the default options for `mc-dropdown`. */
28
+ const MC_DROPDOWN_DEFAULT_OPTIONS = new InjectionToken('mc-dropdown-default-options', {
29
+ providedIn: 'root',
30
+ factory: MC_DROPDOWN_DEFAULT_OPTIONS_FACTORY
31
+ });
32
+ /** @docs-private */
33
+ // tslint:disable-next-line:naming-convention
34
+ function MC_DROPDOWN_DEFAULT_OPTIONS_FACTORY() {
35
+ return {
36
+ overlapTriggerX: true,
37
+ overlapTriggerY: false,
38
+ xPosition: 'after',
39
+ yPosition: 'below',
40
+ backdropClass: 'cdk-overlay-transparent-backdrop',
41
+ hasBackdrop: false
42
+ };
43
43
  }
44
44
 
45
- /**
46
- * Dropdown content that will be rendered lazily once the dropdown is opened.
47
- */
48
- class McDropdownContent {
49
- constructor(template, componentFactoryResolver, appRef, injector, viewContainerRef, document) {
50
- this.template = template;
51
- this.componentFactoryResolver = componentFactoryResolver;
52
- this.appRef = appRef;
53
- this.injector = injector;
54
- this.viewContainerRef = viewContainerRef;
55
- this.document = document;
56
- /** Emits when the dropdown content has been attached. */
57
- this.attached = new Subject();
58
- }
59
- /**
60
- * Attaches the content with a particular context.
61
- * @docs-private
62
- */
63
- attach(context = {}) {
64
- if (!this.portal) {
65
- this.portal = new TemplatePortal(this.template, this.viewContainerRef);
66
- }
67
- this.detach();
68
- if (!this.outlet) {
69
- this.outlet = new DomPortalOutlet(this.document.createElement('div'), this.componentFactoryResolver, this.appRef, this.injector);
70
- }
71
- const element = this.template.elementRef.nativeElement;
72
- // Because we support opening the same dropdown from different triggers (which in turn have their
73
- // own `OverlayRef` panel), we have to re-insert the host element every time, otherwise we
74
- // risk it staying attached to a pane that's no longer in the DOM.
75
- element.parentNode.insertBefore(this.outlet.outletElement, element);
76
- this.portal.attach(this.outlet, context);
77
- this.attached.next();
78
- }
79
- /**
80
- * Detaches the content.
81
- * @docs-private
82
- */
83
- detach() {
84
- var _a;
85
- if ((_a = this.portal) === null || _a === void 0 ? void 0 : _a.isAttached) {
86
- this.portal.detach();
87
- }
88
- }
89
- ngOnDestroy() {
90
- var _a;
91
- (_a = this.outlet) === null || _a === void 0 ? void 0 : _a.dispose();
92
- }
93
- }
94
- /** @nocollapse */ /** @nocollapse */ McDropdownContent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: McDropdownContent, deps: [{ token: i0.TemplateRef }, { token: i0.ComponentFactoryResolver }, { token: i0.ApplicationRef }, { token: i0.Injector }, { token: i0.ViewContainerRef }, { token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Directive });
95
- /** @nocollapse */ /** @nocollapse */ McDropdownContent.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.4", type: McDropdownContent, selector: "ng-template[mcDropdownContent]", ngImport: i0 });
96
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: McDropdownContent, decorators: [{
97
- type: Directive,
98
- args: [{
99
- selector: 'ng-template[mcDropdownContent]'
100
- }]
101
- }], ctorParameters: function () {
102
- return [{ type: i0.TemplateRef }, { type: i0.ComponentFactoryResolver }, { type: i0.ApplicationRef }, { type: i0.Injector }, { type: i0.ViewContainerRef }, { type: undefined, decorators: [{
103
- type: Inject,
104
- args: [DOCUMENT]
105
- }] }];
45
+ /**
46
+ * Dropdown content that will be rendered lazily once the dropdown is opened.
47
+ */
48
+ class McDropdownContent {
49
+ constructor(template, componentFactoryResolver, appRef, injector, viewContainerRef, document) {
50
+ this.template = template;
51
+ this.componentFactoryResolver = componentFactoryResolver;
52
+ this.appRef = appRef;
53
+ this.injector = injector;
54
+ this.viewContainerRef = viewContainerRef;
55
+ this.document = document;
56
+ /** Emits when the dropdown content has been attached. */
57
+ this.attached = new Subject();
58
+ }
59
+ /**
60
+ * Attaches the content with a particular context.
61
+ * @docs-private
62
+ */
63
+ attach(context = {}) {
64
+ if (!this.portal) {
65
+ this.portal = new TemplatePortal(this.template, this.viewContainerRef);
66
+ }
67
+ this.detach();
68
+ if (!this.outlet) {
69
+ this.outlet = new DomPortalOutlet(this.document.createElement('div'), this.componentFactoryResolver, this.appRef, this.injector);
70
+ }
71
+ const element = this.template.elementRef.nativeElement;
72
+ // Because we support opening the same dropdown from different triggers (which in turn have their
73
+ // own `OverlayRef` panel), we have to re-insert the host element every time, otherwise we
74
+ // risk it staying attached to a pane that's no longer in the DOM.
75
+ element.parentNode.insertBefore(this.outlet.outletElement, element);
76
+ this.portal.attach(this.outlet, context);
77
+ this.attached.next();
78
+ }
79
+ /**
80
+ * Detaches the content.
81
+ * @docs-private
82
+ */
83
+ detach() {
84
+ var _a;
85
+ if ((_a = this.portal) === null || _a === void 0 ? void 0 : _a.isAttached) {
86
+ this.portal.detach();
87
+ }
88
+ }
89
+ ngOnDestroy() {
90
+ var _a;
91
+ (_a = this.outlet) === null || _a === void 0 ? void 0 : _a.dispose();
92
+ }
93
+ }
94
+ /** @nocollapse */ /** @nocollapse */ McDropdownContent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.7", ngImport: i0, type: McDropdownContent, deps: [{ token: i0.TemplateRef }, { token: i0.ComponentFactoryResolver }, { token: i0.ApplicationRef }, { token: i0.Injector }, { token: i0.ViewContainerRef }, { token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Directive });
95
+ /** @nocollapse */ /** @nocollapse */ McDropdownContent.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.7", type: McDropdownContent, selector: "ng-template[mcDropdownContent]", ngImport: i0 });
96
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.7", ngImport: i0, type: McDropdownContent, decorators: [{
97
+ type: Directive,
98
+ args: [{
99
+ selector: 'ng-template[mcDropdownContent]'
100
+ }]
101
+ }], ctorParameters: function () {
102
+ return [{ type: i0.TemplateRef }, { type: i0.ComponentFactoryResolver }, { type: i0.ApplicationRef }, { type: i0.Injector }, { type: i0.ViewContainerRef }, { type: undefined, decorators: [{
103
+ type: Inject,
104
+ args: [DOCUMENT]
105
+ }] }];
106
106
  } });
107
107
 
108
- // Boilerplate for applying mixins to McDropdownItem.
109
- /** @docs-private */
110
- class McDropdownItemBase {
111
- }
112
- // tslint:disable-next-line:naming-convention
113
- const McDropdownItemMixinBase = mixinDisabled(McDropdownItemBase);
114
- /**
115
- * This directive is intended to be used inside an mc-dropdown tag.
116
- * It exists mostly to set the role attribute.
117
- */
118
- class McDropdownItem extends McDropdownItemMixinBase {
119
- constructor(elementRef, focusMonitor, parentDropdownPanel) {
120
- super();
121
- this.elementRef = elementRef;
122
- this.focusMonitor = focusMonitor;
123
- this.parentDropdownPanel = parentDropdownPanel;
124
- /** Stream that emits when the dropdown item is hovered. */
125
- this.hovered = new Subject();
126
- /** Stream that emits when the menu item is focused. */
127
- this.focused = new Subject();
128
- /** Whether the dropdown item is highlighted. */
129
- this.highlighted = false;
130
- /** Whether the dropdown item acts as a trigger for a nested dropdown. */
131
- this.isNested = false;
132
- }
133
- ngAfterViewInit() {
134
- if (this.focusMonitor) {
135
- // Start monitoring the element so it gets the appropriate focused classes. We want
136
- // to show the focus style for menu items only when the focus was not caused by a
137
- // mouse or touch interaction.
138
- this.focusMonitor.monitor(this.elementRef, false);
139
- }
140
- }
141
- ngOnDestroy() {
142
- if (this.focusMonitor) {
143
- this.focusMonitor.stopMonitoring(this.elementRef);
144
- }
145
- this.hovered.complete();
146
- this.focused.complete();
147
- }
148
- resetStyles() {
149
- this.getHostElement().classList.remove('cdk-keyboard-focused');
150
- }
151
- /** Focuses the dropdown item. */
152
- focus(origin, options) {
153
- if (this.focusMonitor && origin) {
154
- this.focusMonitor.focusVia(this.getHostElement(), origin, options);
155
- }
156
- else {
157
- this.getHostElement().focus(options);
158
- }
159
- this.focused.next(this);
160
- }
161
- /** Returns the host DOM element. */
162
- getHostElement() {
163
- return this.elementRef.nativeElement;
164
- }
165
- /** Used to set the `tabindex`. */
166
- getTabIndex() {
167
- return this.disabled ? '-1' : '0';
168
- }
169
- /** Prevents the default element actions if it is disabled. */
170
- // We have to use a `HostListener` here in order to support both Ivy and ViewEngine.
171
- // In Ivy the `host` bindings will be merged when this class is extended, whereas in
172
- // ViewEngine they're overwritten.
173
- // TODO(crisbeto): we move this back into `host` once Ivy is turned on by default.
174
- // tslint:disable-next-line:no-host-decorator-in-concrete
175
- checkDisabled(event) {
176
- if (this.disabled) {
177
- event.preventDefault();
178
- event.stopPropagation();
179
- }
180
- }
181
- /** Emits to the hover stream. */
182
- // We have to use a `HostListener` here in order to support both Ivy and ViewEngine.
183
- // In Ivy the `host` bindings will be merged when this class is extended, whereas in
184
- // ViewEngine they're overwritten.
185
- // TODO(crisbeto): we move this back into `host` once Ivy is turned on by default.
186
- // tslint:disable-next-line:no-host-decorator-in-concrete
187
- handleMouseEnter() {
188
- this.hovered.next(this);
189
- }
190
- /** Gets the label to be used when determining whether the option should be focused. */
191
- getLabel() {
192
- var _a, _b;
193
- const clone = this.getHostElement().cloneNode(true);
194
- const icons = clone.querySelectorAll('[mc-icon], .mc-icon');
195
- // Strip away icons so they don't show up in the text.
196
- // tslint:disable-next-line:prefer-for-of
197
- for (let i = 0; i < icons.length; i++) {
198
- const icon = icons[i];
199
- (_a = icon.parentNode) === null || _a === void 0 ? void 0 : _a.removeChild(icon);
200
- }
201
- return ((_b = clone.textContent) === null || _b === void 0 ? void 0 : _b.trim()) || '';
202
- }
203
- haltDisabledEvents(event) {
204
- if (this.disabled) {
205
- event.preventDefault();
206
- event.stopImmediatePropagation();
207
- event.stopPropagation();
208
- }
209
- }
210
- }
211
- /** @nocollapse */ /** @nocollapse */ McDropdownItem.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: McDropdownItem, deps: [{ token: i0.ElementRef }, { token: i1.FocusMonitor }, { token: MC_DROPDOWN_PANEL, optional: true }], target: i0.ɵɵFactoryTarget.Component });
212
- /** @nocollapse */ /** @nocollapse */ McDropdownItem.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.4", type: McDropdownItem, selector: "mc-dropdown-item, [mc-dropdown-item]", inputs: { disabled: "disabled" }, host: { listeners: { "click": "checkDisabled($event)", "mouseenter": "handleMouseEnter()" }, properties: { "class.mc-dropdown-item_with-icon": "icon", "class.mc-dropdown-item_highlighted": "highlighted", "attr.disabled": "disabled || null", "attr.tabindex": "getTabIndex()" }, classAttribute: "mc-dropdown-item" }, queries: [{ propertyName: "icon", first: true, predicate: McIcon, descendants: true }], exportAs: ["mcDropdownItem"], usesInheritance: true, ngImport: i0, template: "<div class=\"mc-dropdown-item-wrapper\">\n <ng-content></ng-content>\n</div>\n<i *ngIf=\"isNested\" mc-icon=\"mc-angle-right-S_16\" class=\"mc-dropdown-trigger__icon\"></i>\n<div class=\"mc-dropdown-item-overlay\" (click)=\"haltDisabledEvents($event)\"></div>\n", styles: [".mc-dropdown-item{-webkit-user-select:none;user-select:none;display:flex;align-items:center;position:relative;box-sizing:border-box;width:100%;border:1px solid transparent;outline:none;padding:0;text-align:left;white-space:nowrap}.mc-dropdown-item:not([disabled]){cursor:pointer}.mc-dropdown-item .mc-dropdown-item__caption{margin-top:4px}.mc-dropdown-item.mc-dropdown-item_with-icon .mc-dropdown-item__caption{margin-left:24px}.mc-dropdown-item-wrapper{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:100%;padding:var(--mc-dropdown-item-size-padding, 5px 15px)}.mc-dropdown-item-wrapper [mc-icon]{padding:var(--mc-dropdown-item-size-icon-padding, 0 8px 2px 0)}.mc-dropdown-item-overlay{position:absolute;top:-1px;left:-1px;right:-1px;bottom:-1px;border-radius:inherit}.mc-dropdown__group-header{-webkit-user-select:none;user-select:none;padding:var(--mc-dropdown-item-size-padding, 6px 15px)}.mc-dropdown__group-header.mc-dropdown__group-header_small{padding:var(--mc-dropdown-item-size-padding, 8px 15px)}.mc-dropdown__divider{height:var(--mc-dropdown-divider-size-height, 1px);margin:var(--mc-dropdown-divider-size-margin, 4px 0)}\n"], components: [{ type: i2.McIcon, selector: "[mc-icon]", inputs: ["color"] }], directives: [{ type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.McIconCSSStyler, selector: "[mc-icon]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
213
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: McDropdownItem, decorators: [{
214
- type: Component,
215
- args: [{ selector: 'mc-dropdown-item, [mc-dropdown-item]', exportAs: 'mcDropdownItem', inputs: ['disabled'], host: {
216
- class: 'mc-dropdown-item',
217
- '[class.mc-dropdown-item_with-icon]': 'icon',
218
- '[class.mc-dropdown-item_highlighted]': 'highlighted',
219
- '[attr.disabled]': 'disabled || null',
220
- '[attr.tabindex]': 'getTabIndex()'
221
- }, changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, template: "<div class=\"mc-dropdown-item-wrapper\">\n <ng-content></ng-content>\n</div>\n<i *ngIf=\"isNested\" mc-icon=\"mc-angle-right-S_16\" class=\"mc-dropdown-trigger__icon\"></i>\n<div class=\"mc-dropdown-item-overlay\" (click)=\"haltDisabledEvents($event)\"></div>\n", styles: [".mc-dropdown-item{-webkit-user-select:none;user-select:none;display:flex;align-items:center;position:relative;box-sizing:border-box;width:100%;border:1px solid transparent;outline:none;padding:0;text-align:left;white-space:nowrap}.mc-dropdown-item:not([disabled]){cursor:pointer}.mc-dropdown-item .mc-dropdown-item__caption{margin-top:4px}.mc-dropdown-item.mc-dropdown-item_with-icon .mc-dropdown-item__caption{margin-left:24px}.mc-dropdown-item-wrapper{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:100%;padding:var(--mc-dropdown-item-size-padding, 5px 15px)}.mc-dropdown-item-wrapper [mc-icon]{padding:var(--mc-dropdown-item-size-icon-padding, 0 8px 2px 0)}.mc-dropdown-item-overlay{position:absolute;top:-1px;left:-1px;right:-1px;bottom:-1px;border-radius:inherit}.mc-dropdown__group-header{-webkit-user-select:none;user-select:none;padding:var(--mc-dropdown-item-size-padding, 6px 15px)}.mc-dropdown__group-header.mc-dropdown__group-header_small{padding:var(--mc-dropdown-item-size-padding, 8px 15px)}.mc-dropdown__divider{height:var(--mc-dropdown-divider-size-height, 1px);margin:var(--mc-dropdown-divider-size-margin, 4px 0)}\n"] }]
222
- }], ctorParameters: function () {
223
- return [{ type: i0.ElementRef }, { type: i1.FocusMonitor }, { type: undefined, decorators: [{
224
- type: Inject,
225
- args: [MC_DROPDOWN_PANEL]
226
- }, {
227
- type: Optional
228
- }] }];
229
- }, propDecorators: { icon: [{
230
- type: ContentChild,
231
- args: [McIcon]
232
- }], checkDisabled: [{
233
- type: HostListener,
234
- args: ['click', ['$event']]
235
- }], handleMouseEnter: [{
236
- type: HostListener,
237
- args: ['mouseenter']
108
+ // Boilerplate for applying mixins to McDropdownItem.
109
+ /** @docs-private */
110
+ class McDropdownItemBase {
111
+ }
112
+ // tslint:disable-next-line:naming-convention
113
+ const McDropdownItemMixinBase = mixinDisabled(McDropdownItemBase);
114
+ /**
115
+ * This directive is intended to be used inside an mc-dropdown tag.
116
+ * It exists mostly to set the role attribute.
117
+ */
118
+ class McDropdownItem extends McDropdownItemMixinBase {
119
+ constructor(elementRef, focusMonitor, parentDropdownPanel) {
120
+ super();
121
+ this.elementRef = elementRef;
122
+ this.focusMonitor = focusMonitor;
123
+ this.parentDropdownPanel = parentDropdownPanel;
124
+ /** Stream that emits when the dropdown item is hovered. */
125
+ this.hovered = new Subject();
126
+ /** Stream that emits when the menu item is focused. */
127
+ this.focused = new Subject();
128
+ /** Whether the dropdown item is highlighted. */
129
+ this.highlighted = false;
130
+ /** Whether the dropdown item acts as a trigger for a nested dropdown. */
131
+ this.isNested = false;
132
+ }
133
+ ngAfterViewInit() {
134
+ if (this.focusMonitor) {
135
+ // Start monitoring the element so it gets the appropriate focused classes. We want
136
+ // to show the focus style for menu items only when the focus was not caused by a
137
+ // mouse or touch interaction.
138
+ this.focusMonitor.monitor(this.elementRef, false);
139
+ }
140
+ }
141
+ ngOnDestroy() {
142
+ if (this.focusMonitor) {
143
+ this.focusMonitor.stopMonitoring(this.elementRef);
144
+ }
145
+ this.hovered.complete();
146
+ this.focused.complete();
147
+ }
148
+ resetStyles() {
149
+ this.getHostElement().classList.remove('cdk-keyboard-focused');
150
+ }
151
+ /** Focuses the dropdown item. */
152
+ focus(origin, options) {
153
+ if (this.focusMonitor && origin) {
154
+ this.focusMonitor.focusVia(this.getHostElement(), origin, options);
155
+ }
156
+ else {
157
+ this.getHostElement().focus(options);
158
+ }
159
+ this.focused.next(this);
160
+ }
161
+ /** Returns the host DOM element. */
162
+ getHostElement() {
163
+ return this.elementRef.nativeElement;
164
+ }
165
+ /** Used to set the `tabindex`. */
166
+ getTabIndex() {
167
+ return this.disabled ? '-1' : '0';
168
+ }
169
+ /** Prevents the default element actions if it is disabled. */
170
+ // We have to use a `HostListener` here in order to support both Ivy and ViewEngine.
171
+ // In Ivy the `host` bindings will be merged when this class is extended, whereas in
172
+ // ViewEngine they're overwritten.
173
+ // TODO(crisbeto): we move this back into `host` once Ivy is turned on by default.
174
+ // tslint:disable-next-line:no-host-decorator-in-concrete
175
+ checkDisabled(event) {
176
+ if (this.disabled) {
177
+ event.preventDefault();
178
+ event.stopPropagation();
179
+ }
180
+ }
181
+ /** Emits to the hover stream. */
182
+ // We have to use a `HostListener` here in order to support both Ivy and ViewEngine.
183
+ // In Ivy the `host` bindings will be merged when this class is extended, whereas in
184
+ // ViewEngine they're overwritten.
185
+ // TODO(crisbeto): we move this back into `host` once Ivy is turned on by default.
186
+ // tslint:disable-next-line:no-host-decorator-in-concrete
187
+ handleMouseEnter() {
188
+ this.hovered.next(this);
189
+ }
190
+ /** Gets the label to be used when determining whether the option should be focused. */
191
+ getLabel() {
192
+ var _a, _b;
193
+ const clone = this.getHostElement().cloneNode(true);
194
+ const icons = clone.querySelectorAll('[mc-icon], .mc-icon');
195
+ // Strip away icons so they don't show up in the text.
196
+ // tslint:disable-next-line:prefer-for-of
197
+ for (let i = 0; i < icons.length; i++) {
198
+ const icon = icons[i];
199
+ (_a = icon.parentNode) === null || _a === void 0 ? void 0 : _a.removeChild(icon);
200
+ }
201
+ return ((_b = clone.textContent) === null || _b === void 0 ? void 0 : _b.trim()) || '';
202
+ }
203
+ haltDisabledEvents(event) {
204
+ if (this.disabled) {
205
+ event.preventDefault();
206
+ event.stopImmediatePropagation();
207
+ event.stopPropagation();
208
+ }
209
+ }
210
+ }
211
+ /** @nocollapse */ /** @nocollapse */ McDropdownItem.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.7", ngImport: i0, type: McDropdownItem, deps: [{ token: i0.ElementRef }, { token: i1.FocusMonitor }, { token: MC_DROPDOWN_PANEL, optional: true }], target: i0.ɵɵFactoryTarget.Component });
212
+ /** @nocollapse */ /** @nocollapse */ McDropdownItem.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.7", type: McDropdownItem, selector: "mc-dropdown-item, [mc-dropdown-item]", inputs: { disabled: "disabled" }, host: { listeners: { "click": "checkDisabled($event)", "mouseenter": "handleMouseEnter()" }, properties: { "class.mc-dropdown-item_with-icon": "icon", "class.mc-dropdown-item_highlighted": "highlighted", "attr.disabled": "disabled || null", "attr.tabindex": "getTabIndex()" }, classAttribute: "mc-dropdown-item" }, queries: [{ propertyName: "icon", first: true, predicate: McIcon, descendants: true }], exportAs: ["mcDropdownItem"], usesInheritance: true, ngImport: i0, template: "<div class=\"mc-dropdown-item-wrapper\">\r\n <ng-content></ng-content>\r\n</div>\r\n<i *ngIf=\"isNested\" mc-icon=\"mc-angle-right-S_16\" class=\"mc-dropdown-trigger__icon\"></i>\r\n<div class=\"mc-dropdown-item-overlay\" (click)=\"haltDisabledEvents($event)\"></div>\r\n", styles: [".mc-dropdown-item{-webkit-user-select:none;user-select:none;display:flex;align-items:center;position:relative;box-sizing:border-box;width:100%;border:1px solid transparent;outline:none;padding:0;text-align:left;white-space:nowrap}.mc-dropdown-item:not([disabled]){cursor:pointer}.mc-dropdown-item .mc-dropdown-item__caption{margin-top:4px}.mc-dropdown-item.mc-dropdown-item_with-icon .mc-dropdown-item__caption{margin-left:24px}.mc-dropdown-item-wrapper{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:100%;padding:var(--mc-dropdown-item-size-padding, 5px 15px)}.mc-dropdown-item-wrapper [mc-icon]{padding:var(--mc-dropdown-item-size-icon-padding, 0 8px 2px 0)}.mc-dropdown-item-overlay{position:absolute;top:-1px;left:-1px;right:-1px;bottom:-1px;border-radius:inherit}.mc-dropdown__group-header{-webkit-user-select:none;user-select:none;padding:var(--mc-dropdown-item-size-padding, 6px 15px)}.mc-dropdown__group-header.mc-dropdown__group-header_small{padding:var(--mc-dropdown-item-size-padding, 8px 15px)}.mc-dropdown__divider{height:var(--mc-dropdown-divider-size-height, 1px);margin:var(--mc-dropdown-divider-size-margin, 4px 0)}\n"], components: [{ type: i2.McIcon, selector: "[mc-icon]", inputs: ["color"] }], directives: [{ type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.McIconCSSStyler, selector: "[mc-icon]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
213
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.7", ngImport: i0, type: McDropdownItem, decorators: [{
214
+ type: Component,
215
+ args: [{ selector: 'mc-dropdown-item, [mc-dropdown-item]', exportAs: 'mcDropdownItem', inputs: ['disabled'], host: {
216
+ class: 'mc-dropdown-item',
217
+ '[class.mc-dropdown-item_with-icon]': 'icon',
218
+ '[class.mc-dropdown-item_highlighted]': 'highlighted',
219
+ '[attr.disabled]': 'disabled || null',
220
+ '[attr.tabindex]': 'getTabIndex()'
221
+ }, changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, template: "<div class=\"mc-dropdown-item-wrapper\">\r\n <ng-content></ng-content>\r\n</div>\r\n<i *ngIf=\"isNested\" mc-icon=\"mc-angle-right-S_16\" class=\"mc-dropdown-trigger__icon\"></i>\r\n<div class=\"mc-dropdown-item-overlay\" (click)=\"haltDisabledEvents($event)\"></div>\r\n", styles: [".mc-dropdown-item{-webkit-user-select:none;user-select:none;display:flex;align-items:center;position:relative;box-sizing:border-box;width:100%;border:1px solid transparent;outline:none;padding:0;text-align:left;white-space:nowrap}.mc-dropdown-item:not([disabled]){cursor:pointer}.mc-dropdown-item .mc-dropdown-item__caption{margin-top:4px}.mc-dropdown-item.mc-dropdown-item_with-icon .mc-dropdown-item__caption{margin-left:24px}.mc-dropdown-item-wrapper{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:100%;padding:var(--mc-dropdown-item-size-padding, 5px 15px)}.mc-dropdown-item-wrapper [mc-icon]{padding:var(--mc-dropdown-item-size-icon-padding, 0 8px 2px 0)}.mc-dropdown-item-overlay{position:absolute;top:-1px;left:-1px;right:-1px;bottom:-1px;border-radius:inherit}.mc-dropdown__group-header{-webkit-user-select:none;user-select:none;padding:var(--mc-dropdown-item-size-padding, 6px 15px)}.mc-dropdown__group-header.mc-dropdown__group-header_small{padding:var(--mc-dropdown-item-size-padding, 8px 15px)}.mc-dropdown__divider{height:var(--mc-dropdown-divider-size-height, 1px);margin:var(--mc-dropdown-divider-size-margin, 4px 0)}\n"] }]
222
+ }], ctorParameters: function () {
223
+ return [{ type: i0.ElementRef }, { type: i1.FocusMonitor }, { type: undefined, decorators: [{
224
+ type: Inject,
225
+ args: [MC_DROPDOWN_PANEL]
226
+ }, {
227
+ type: Optional
228
+ }] }];
229
+ }, propDecorators: { icon: [{
230
+ type: ContentChild,
231
+ args: [McIcon]
232
+ }], checkDisabled: [{
233
+ type: HostListener,
234
+ args: ['click', ['$event']]
235
+ }], handleMouseEnter: [{
236
+ type: HostListener,
237
+ args: ['mouseenter']
238
238
  }] } });
239
239
 
240
- /**
241
- * Throws an exception for the case when dropdown trigger doesn't have a valid mc-dropdown instance
242
- * @docs-private
243
- */
244
- function throwMcDropdownMissingError() {
245
- throw Error(`mcDropdownTriggerFor: must pass in an mc-dropdown instance.
246
- Example:
247
- <mc-dropdown #dropdown="mcDropdown"></mc-dropdown>
248
- <button [mcDropdownTriggerFor]="dropdown"></button>`);
249
- }
250
- /**
251
- * Throws an exception for the case when dropdown's x-position value isn't valid.
252
- * In other words, it doesn't match 'before' or 'after'.
253
- * @docs-private
254
- */
255
- function throwMcDropdownInvalidPositionX() {
256
- throw Error(`xPosition value must be either 'before' or after'.
257
- Example: <mc-dropdown [xPosition]="'before'" #dropdown="mcDropdown"></mc-dropdown>`);
258
- }
259
- /**
260
- * Throws an exception for the case when dropdown's y-position value isn't valid.
261
- * In other words, it doesn't match 'above' or 'below'.
262
- * @docs-private
263
- */
264
- function throwMcDropdownInvalidPositionY() {
265
- throw Error(`yPosition value must be either 'above' or below'.
266
- Example: <mc-dropdown [yPosition]="'above'" #dropdown="mcDropdown"></mc-dropdown>`);
240
+ /**
241
+ * Throws an exception for the case when dropdown trigger doesn't have a valid mc-dropdown instance
242
+ * @docs-private
243
+ */
244
+ function throwMcDropdownMissingError() {
245
+ throw Error(`mcDropdownTriggerFor: must pass in an mc-dropdown instance.
246
+ Example:
247
+ <mc-dropdown #dropdown="mcDropdown"></mc-dropdown>
248
+ <button [mcDropdownTriggerFor]="dropdown"></button>`);
249
+ }
250
+ /**
251
+ * Throws an exception for the case when dropdown's x-position value isn't valid.
252
+ * In other words, it doesn't match 'before' or 'after'.
253
+ * @docs-private
254
+ */
255
+ function throwMcDropdownInvalidPositionX() {
256
+ throw Error(`xPosition value must be either 'before' or after'.
257
+ Example: <mc-dropdown [xPosition]="'before'" #dropdown="mcDropdown"></mc-dropdown>`);
258
+ }
259
+ /**
260
+ * Throws an exception for the case when dropdown's y-position value isn't valid.
261
+ * In other words, it doesn't match 'above' or 'below'.
262
+ * @docs-private
263
+ */
264
+ function throwMcDropdownInvalidPositionY() {
265
+ throw Error(`yPosition value must be either 'above' or below'.
266
+ Example: <mc-dropdown [yPosition]="'above'" #dropdown="mcDropdown"></mc-dropdown>`);
267
267
  }
268
268
 
269
- /**
270
- * Animations used by the mc-dropdown component.
271
- * @docs-private
272
- */
273
- const mcDropdownAnimations = {
274
- /**
275
- * This animation controls the dropdown panel's entry and exit from the page.
276
- *
277
- * When the dropdown panel is added to the DOM, it scales in and fades in its border.
278
- *
279
- * When the dropdown panel is removed from the DOM, it simply fades out after a brief
280
- * delay to display the ripple.
281
- */
282
- transformDropdown: trigger('transformDropdown', [
283
- state('void', style({
284
- opacity: 0,
285
- transform: 'scale(0.8)'
286
- })),
287
- transition('void => enter', group([
288
- query('.mc-dropdown__content', animate('50ms linear', style({ opacity: 1 }))),
289
- animate('50ms cubic-bezier(0, 0, 0.2, 1)', style({ transform: 'scale(1)' }))
290
- ])),
291
- transition('* => void', animate('50ms 25ms linear', style({ opacity: 0 })))
292
- ]),
293
- /**
294
- * This animation fades in the background color and content of the dropdown panel
295
- * after its containing element is scaled in.
296
- */
297
- fadeInItems: trigger('fadeInItems', [
298
- // now. Remove next time we do breaking changes.
299
- state('showing', style({ opacity: 1 })),
300
- transition('void => *', [
301
- style({ opacity: 0 }),
302
- animate('200ms 60ms cubic-bezier(0.55, 0, 0.55, 0.2)')
303
- ])
304
- ])
305
- };
306
- const fadeInItems = mcDropdownAnimations.fadeInItems;
269
+ /**
270
+ * Animations used by the mc-dropdown component.
271
+ * @docs-private
272
+ */
273
+ const mcDropdownAnimations = {
274
+ /**
275
+ * This animation controls the dropdown panel's entry and exit from the page.
276
+ *
277
+ * When the dropdown panel is added to the DOM, it scales in and fades in its border.
278
+ *
279
+ * When the dropdown panel is removed from the DOM, it simply fades out after a brief
280
+ * delay to display the ripple.
281
+ */
282
+ transformDropdown: trigger('transformDropdown', [
283
+ state('void', style({
284
+ opacity: 0,
285
+ transform: 'scale(0.8)'
286
+ })),
287
+ transition('void => enter', group([
288
+ query('.mc-dropdown__content', animate('50ms linear', style({ opacity: 1 }))),
289
+ animate('50ms cubic-bezier(0, 0, 0.2, 1)', style({ transform: 'scale(1)' }))
290
+ ])),
291
+ transition('* => void', animate('50ms 25ms linear', style({ opacity: 0 })))
292
+ ]),
293
+ /**
294
+ * This animation fades in the background color and content of the dropdown panel
295
+ * after its containing element is scaled in.
296
+ */
297
+ fadeInItems: trigger('fadeInItems', [
298
+ // now. Remove next time we do breaking changes.
299
+ state('showing', style({ opacity: 1 })),
300
+ transition('void => *', [
301
+ style({ opacity: 0 }),
302
+ animate('200ms 60ms cubic-bezier(0.55, 0, 0.55, 0.2)')
303
+ ])
304
+ ])
305
+ };
306
+ const fadeInItems = mcDropdownAnimations.fadeInItems;
307
307
  const transformDropdown = mcDropdownAnimations.transformDropdown;
308
308
 
309
- class McDropdown {
310
- constructor(elementRef, ngZone, defaultOptions) {
311
- this.elementRef = elementRef;
312
- this.ngZone = ngZone;
313
- this.defaultOptions = defaultOptions;
314
- this.navigationWithWrap = false;
315
- this._xPosition = this.defaultOptions.xPosition;
316
- this._yPosition = this.defaultOptions.yPosition;
317
- this._overlapTriggerX = this.defaultOptions.overlapTriggerX;
318
- this._overlapTriggerY = this.defaultOptions.overlapTriggerY;
319
- this._hasBackdrop = this.defaultOptions.hasBackdrop;
320
- this.triggerWidth = '';
321
- /** Config object to be passed into the dropdown's ngClass */
322
- this.classList = {};
323
- /** Current state of the panel animation. */
324
- this.panelAnimationState = 'void';
325
- /** Emits whenever an animation on the dropdown completes. */
326
- this.animationDone = new Subject();
327
- /** Class to be added to the backdrop element. */
328
- this.backdropClass = this.defaultOptions.backdropClass;
329
- /** Event emitted when the dropdown is closed. */
330
- this.closed = new EventEmitter();
331
- /** Only the direct descendant menu items. */
332
- this.directDescendantItems = new QueryList();
333
- /** Subscription to tab events on the dropdown panel */
334
- this.tabSubscription = Subscription.EMPTY;
335
- }
336
- /** Position of the dropdown in the X axis. */
337
- get xPosition() {
338
- return this._xPosition;
339
- }
340
- set xPosition(value) {
341
- if (value !== 'before' && value !== 'after') {
342
- throwMcDropdownInvalidPositionX();
343
- }
344
- this._xPosition = value;
345
- this.setPositionClasses();
346
- }
347
- /** Position of the dropdown in the Y axis. */
348
- get yPosition() {
349
- return this._yPosition;
350
- }
351
- set yPosition(value) {
352
- if (value !== 'above' && value !== 'below') {
353
- throwMcDropdownInvalidPositionY();
354
- }
355
- this._yPosition = value;
356
- this.setPositionClasses();
357
- }
358
- /** Whether the dropdown should overlap its trigger vertically. */
359
- get overlapTriggerY() {
360
- return this._overlapTriggerY;
361
- }
362
- set overlapTriggerY(value) {
363
- this._overlapTriggerY = coerceBooleanProperty(value);
364
- }
365
- /** Whether the dropdown should overlap its trigger horizontally. */
366
- get overlapTriggerX() {
367
- return this._overlapTriggerX;
368
- }
369
- set overlapTriggerX(value) {
370
- this._overlapTriggerX = coerceBooleanProperty(value);
371
- }
372
- /** Whether the dropdown has a backdrop. */
373
- get hasBackdrop() {
374
- return this._hasBackdrop;
375
- }
376
- set hasBackdrop(value) {
377
- this._hasBackdrop = coerceBooleanProperty(value);
378
- }
379
- /**
380
- * This method takes classes set on the host mc-dropdown element and applies them on the
381
- * dropdown template that displays in the overlay container. Otherwise, it's difficult
382
- * to style the containing dropdown from outside the component.
383
- * @param classes list of class names
384
- */
385
- set panelClass(classes) {
386
- const previousPanelClass = this.previousPanelClass;
387
- if (previousPanelClass && previousPanelClass.length) {
388
- previousPanelClass
389
- .split(' ')
390
- .forEach((className) => this.classList[className] = false);
391
- }
392
- this.previousPanelClass = classes;
393
- if (classes === null || classes === void 0 ? void 0 : classes.length) {
394
- classes
395
- .split(' ')
396
- .forEach((className) => this.classList[className] = true);
397
- this.elementRef.nativeElement.className = '';
398
- }
399
- }
400
- ngOnInit() {
401
- this.setPositionClasses();
402
- }
403
- ngAfterContentInit() {
404
- this.updateDirectDescendants();
405
- this.keyManager = new FocusKeyManager(this.directDescendantItems)
406
- .withTypeAhead();
407
- if (this.navigationWithWrap) {
408
- this.keyManager.withWrap();
409
- }
410
- this.tabSubscription = this.keyManager.tabOut
411
- .subscribe(() => this.closed.emit('tab'));
412
- // If a user manually (programmatically) focuses a menu item, we need to reflect that focus
413
- // change back to the key manager. Note that we don't need to unsubscribe here because focused
414
- // is internal and we know that it gets completed on destroy.
415
- this.directDescendantItems.changes
416
- .pipe(startWith(this.directDescendantItems), switchMap((items) => merge(...items.map((item) => item.focused))))
417
- .subscribe((focusedItem) => this.keyManager.updateActiveItem(focusedItem));
418
- }
419
- ngOnDestroy() {
420
- this.directDescendantItems.destroy();
421
- this.tabSubscription.unsubscribe();
422
- this.closed.complete();
423
- }
424
- /** Stream that emits whenever the hovered dropdown item changes. */
425
- hovered() {
426
- const itemChanges = this.directDescendantItems.changes;
427
- return itemChanges.pipe(startWith(this.directDescendantItems), switchMap((items) => merge(...items.map((item) => item.hovered))));
428
- }
429
- /** Handle a keyboard event from the dropdown, delegating to the appropriate action. */
430
- handleKeydown(event) {
431
- // tslint:disable-next-line:deprecation
432
- const keyCode = event.keyCode;
433
- switch (keyCode) {
434
- case ESCAPE:
435
- this.closed.emit('keydown');
436
- break;
437
- case LEFT_ARROW:
438
- if (this.parent && this.direction === 'ltr') {
439
- this.closed.emit('keydown');
440
- }
441
- break;
442
- case RIGHT_ARROW:
443
- if (this.parent && this.direction === 'rtl') {
444
- this.closed.emit('keydown');
445
- }
446
- break;
447
- default:
448
- if (keyCode === UP_ARROW || keyCode === DOWN_ARROW) {
449
- this.keyManager.setFocusOrigin('keyboard');
450
- }
451
- this.keyManager.onKeydown(event);
452
- return;
453
- }
454
- // Don't allow the event to propagate if we've already handled it, or it may
455
- // end up reaching other overlays that were opened earlier.
456
- event.stopPropagation();
457
- }
458
- /**
459
- * Focus the first item in the dropdown.
460
- * @param origin Action from which the focus originated. Used to set the correct styling.
461
- */
462
- focusFirstItem(origin = 'program') {
463
- // When the content is rendered lazily, it takes a bit before the items are inside the DOM.
464
- if (this.lazyContent) {
465
- this.ngZone.onStable
466
- .pipe(take(1))
467
- .subscribe(() => this.keyManager.setFocusOrigin(origin).setFirstItemActive());
468
- }
469
- else {
470
- this.keyManager.setFocusOrigin(origin).setFirstItemActive();
471
- }
472
- }
473
- /**
474
- * Resets the active item in the dropdown. This is used when the dropdown is opened, allowing
475
- * the user to start from the first option when pressing the down arrow.
476
- */
477
- resetActiveItem() {
478
- var _a;
479
- (_a = this.keyManager.activeItem) === null || _a === void 0 ? void 0 : _a.resetStyles();
480
- this.keyManager.setActiveItem(-1);
481
- }
482
- /**
483
- * Adds classes to the dropdown panel based on its position. Can be used by
484
- * consumers to add specific styling based on the position.
485
- * @param posX Position of the dropdown along the x axis.
486
- * @param posY Position of the dropdown along the y axis.
487
- * @docs-private
488
- */
489
- setPositionClasses(posX = this.xPosition, posY = this.yPosition) {
490
- const classes = this.classList;
491
- classes['mc-dropdown-before'] = posX === 'before';
492
- classes['mc-dropdown-after'] = posX === 'after';
493
- classes['mc-dropdown-above'] = posY === 'above';
494
- classes['mc-dropdown-below'] = posY === 'below';
495
- }
496
- /** Starts the enter animation. */
497
- startAnimation() {
498
- this.panelAnimationState = 'enter';
499
- }
500
- /** Resets the panel animation to its initial state. */
501
- resetAnimation() {
502
- this.panelAnimationState = 'void';
503
- }
504
- /** Callback that is invoked when the panel animation completes. */
505
- onAnimationDone(event) {
506
- this.animationDone.next(event);
507
- this.isAnimating = false;
508
- }
509
- onAnimationStart(event) {
510
- this.isAnimating = true;
511
- // Scroll the content element to the top as soon as the animation starts. This is necessary,
512
- // because we move focus to the first item while it's still being animated, which can throw
513
- // the browser off when it determines the scroll position. Alternatively we can move focus
514
- // when the animation is done, however moving focus asynchronously will interrupt screen
515
- // readers which are in the process of reading out the dropdown already. We take the `element`
516
- // from the `event` since we can't use a `ViewChild` to access the pane.
517
- if (event.toState === 'enter' && this.keyManager.activeItemIndex === 0) {
518
- event.element.scrollTop = 0;
519
- }
520
- }
521
- close() {
522
- const focusOrigin = this.keyManager.getFocusOrigin() === 'keyboard' ? 'keydown' : 'click';
523
- this.closed.emit(focusOrigin);
524
- }
525
- /**
526
- * Sets up a stream that will keep track of any newly-added menu items and will update the list
527
- * of direct descendants. We collect the descendants this way, because `_allItems` can include
528
- * items that are part of child menus, and using a custom way of registering items is unreliable
529
- * when it comes to maintaining the item order.
530
- */
531
- updateDirectDescendants() {
532
- this.items.changes
533
- .pipe(startWith(this.items))
534
- .subscribe((items) => {
535
- this.directDescendantItems.reset(items.filter((item) => item.parentDropdownPanel === this));
536
- this.directDescendantItems.notifyOnChanges();
537
- });
538
- }
539
- }
540
- /** @nocollapse */ /** @nocollapse */ McDropdown.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: McDropdown, deps: [{ token: i0.ElementRef }, { token: i0.NgZone }, { token: MC_DROPDOWN_DEFAULT_OPTIONS }], target: i0.ɵɵFactoryTarget.Component });
541
- /** @nocollapse */ /** @nocollapse */ McDropdown.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.4", type: McDropdown, selector: "mc-dropdown", inputs: { navigationWithWrap: "navigationWithWrap", xPosition: "xPosition", yPosition: "yPosition", overlapTriggerY: "overlapTriggerY", overlapTriggerX: "overlapTriggerX", hasBackdrop: "hasBackdrop", panelClass: ["class", "panelClass"], backdropClass: "backdropClass" }, outputs: { closed: "closed" }, providers: [
542
- { provide: MC_DROPDOWN_PANEL, useExisting: McDropdown }
543
- ], queries: [{ propertyName: "lazyContent", first: true, predicate: McDropdownContent, descendants: true }, { propertyName: "items", predicate: McDropdownItem, descendants: true }], viewQueries: [{ propertyName: "templateRef", first: true, predicate: TemplateRef, descendants: true }], exportAs: ["mcDropdown"], ngImport: i0, template: "<ng-template>\n <div class=\"mc-dropdown__panel\"\n [ngClass]=\"classList\"\n [class.mc-dropdown__panel_nested]=\"parent\"\n [style.min-width]=\"triggerWidth\"\n (keydown)=\"handleKeydown($event)\"\n (click)=\"close()\"\n [@transformDropdown]=\"panelAnimationState\"\n (@transformDropdown.start)=\"onAnimationStart($event)\"\n (@transformDropdown.done)=\"onAnimationDone($event)\"\n tabindex=\"-1\">\n\n <div class=\"mc-dropdown__content\">\n <ng-content></ng-content>\n </div>\n </div>\n</ng-template>\n", styles: [".mc-dropdown-trigger.mc-icon-button_right{padding-right:var(--mc-dropdown-trigger-size-button-right-padding, 8px)}.mc-dropdown-trigger.mc-icon-button_right.mc-icon-button_left .mc-icon_left{margin-right:0}.mc-dropdown-trigger .mc-icon_right{margin-left:var(--mc-dropdown-trigger-size-right-icon-padding, 2px)}.mc-dropdown-trigger__icon{margin-left:auto;padding-right:var(--mc-dropdown-trigger-size-right-icon-padding, 2px)}.mc-dropdown__panel{margin-top:-1px;max-width:var(--mc-dropdown-panel-size-max-width, 640px);border-width:var(--mc-dropdown-panel-size-border-width, 1px);border-style:solid;border-bottom-left-radius:var(--mc-dropdown-panel-size-border-radius, 3px);border-bottom-right-radius:var(--mc-dropdown-panel-size-border-radius, 3px);padding:var(--mc-dropdown-panel-size-padding, 4px 0)}.mc-dropdown__panel.mc-dropdown__panel_nested{border-top-left-radius:var(--mc-dropdown-panel-size-border-radius, 3px);border-top-right-radius:var(--mc-dropdown-panel-size-border-radius, 3px)}.mc-dropdown__panel.ng-animating{pointer-events:none}.mc-dropdown__content{display:flex;flex-direction:column}\n"], directives: [{ type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], animations: [
544
- mcDropdownAnimations.transformDropdown,
545
- mcDropdownAnimations.fadeInItems
546
- ], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
547
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: McDropdown, decorators: [{
548
- type: Component,
549
- args: [{ selector: 'mc-dropdown', exportAs: 'mcDropdown', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, animations: [
550
- mcDropdownAnimations.transformDropdown,
551
- mcDropdownAnimations.fadeInItems
552
- ], providers: [
553
- { provide: MC_DROPDOWN_PANEL, useExisting: McDropdown }
554
- ], template: "<ng-template>\n <div class=\"mc-dropdown__panel\"\n [ngClass]=\"classList\"\n [class.mc-dropdown__panel_nested]=\"parent\"\n [style.min-width]=\"triggerWidth\"\n (keydown)=\"handleKeydown($event)\"\n (click)=\"close()\"\n [@transformDropdown]=\"panelAnimationState\"\n (@transformDropdown.start)=\"onAnimationStart($event)\"\n (@transformDropdown.done)=\"onAnimationDone($event)\"\n tabindex=\"-1\">\n\n <div class=\"mc-dropdown__content\">\n <ng-content></ng-content>\n </div>\n </div>\n</ng-template>\n", styles: [".mc-dropdown-trigger.mc-icon-button_right{padding-right:var(--mc-dropdown-trigger-size-button-right-padding, 8px)}.mc-dropdown-trigger.mc-icon-button_right.mc-icon-button_left .mc-icon_left{margin-right:0}.mc-dropdown-trigger .mc-icon_right{margin-left:var(--mc-dropdown-trigger-size-right-icon-padding, 2px)}.mc-dropdown-trigger__icon{margin-left:auto;padding-right:var(--mc-dropdown-trigger-size-right-icon-padding, 2px)}.mc-dropdown__panel{margin-top:-1px;max-width:var(--mc-dropdown-panel-size-max-width, 640px);border-width:var(--mc-dropdown-panel-size-border-width, 1px);border-style:solid;border-bottom-left-radius:var(--mc-dropdown-panel-size-border-radius, 3px);border-bottom-right-radius:var(--mc-dropdown-panel-size-border-radius, 3px);padding:var(--mc-dropdown-panel-size-padding, 4px 0)}.mc-dropdown__panel.mc-dropdown__panel_nested{border-top-left-radius:var(--mc-dropdown-panel-size-border-radius, 3px);border-top-right-radius:var(--mc-dropdown-panel-size-border-radius, 3px)}.mc-dropdown__panel.ng-animating{pointer-events:none}.mc-dropdown__content{display:flex;flex-direction:column}\n"] }]
555
- }], ctorParameters: function () {
556
- return [{ type: i0.ElementRef }, { type: i0.NgZone }, { type: undefined, decorators: [{
557
- type: Inject,
558
- args: [MC_DROPDOWN_DEFAULT_OPTIONS]
559
- }] }];
560
- }, propDecorators: { navigationWithWrap: [{
561
- type: Input
562
- }], xPosition: [{
563
- type: Input
564
- }], yPosition: [{
565
- type: Input
566
- }], overlapTriggerY: [{
567
- type: Input
568
- }], overlapTriggerX: [{
569
- type: Input
570
- }], hasBackdrop: [{
571
- type: Input
572
- }], panelClass: [{
573
- type: Input,
574
- args: ['class']
575
- }], backdropClass: [{
576
- type: Input
577
- }], templateRef: [{
578
- type: ViewChild,
579
- args: [TemplateRef, { static: false }]
580
- }], items: [{
581
- type: ContentChildren,
582
- args: [McDropdownItem, { descendants: true }]
583
- }], lazyContent: [{
584
- type: ContentChild,
585
- args: [McDropdownContent, { static: false }]
586
- }], closed: [{
587
- type: Output
309
+ class McDropdown {
310
+ constructor(elementRef, ngZone, defaultOptions) {
311
+ this.elementRef = elementRef;
312
+ this.ngZone = ngZone;
313
+ this.defaultOptions = defaultOptions;
314
+ this.navigationWithWrap = false;
315
+ this._xPosition = this.defaultOptions.xPosition;
316
+ this._yPosition = this.defaultOptions.yPosition;
317
+ this._overlapTriggerX = this.defaultOptions.overlapTriggerX;
318
+ this._overlapTriggerY = this.defaultOptions.overlapTriggerY;
319
+ this._hasBackdrop = this.defaultOptions.hasBackdrop;
320
+ this.triggerWidth = '';
321
+ /** Config object to be passed into the dropdown's ngClass */
322
+ this.classList = {};
323
+ /** Current state of the panel animation. */
324
+ this.panelAnimationState = 'void';
325
+ /** Emits whenever an animation on the dropdown completes. */
326
+ this.animationDone = new Subject();
327
+ /** Class to be added to the backdrop element. */
328
+ this.backdropClass = this.defaultOptions.backdropClass;
329
+ /** Event emitted when the dropdown is closed. */
330
+ this.closed = new EventEmitter();
331
+ /** Only the direct descendant menu items. */
332
+ this.directDescendantItems = new QueryList();
333
+ /** Subscription to tab events on the dropdown panel */
334
+ this.tabSubscription = Subscription.EMPTY;
335
+ }
336
+ /** Position of the dropdown in the X axis. */
337
+ get xPosition() {
338
+ return this._xPosition;
339
+ }
340
+ set xPosition(value) {
341
+ if (value !== 'before' && value !== 'after') {
342
+ throwMcDropdownInvalidPositionX();
343
+ }
344
+ this._xPosition = value;
345
+ this.setPositionClasses();
346
+ }
347
+ /** Position of the dropdown in the Y axis. */
348
+ get yPosition() {
349
+ return this._yPosition;
350
+ }
351
+ set yPosition(value) {
352
+ if (value !== 'above' && value !== 'below') {
353
+ throwMcDropdownInvalidPositionY();
354
+ }
355
+ this._yPosition = value;
356
+ this.setPositionClasses();
357
+ }
358
+ /** Whether the dropdown should overlap its trigger vertically. */
359
+ get overlapTriggerY() {
360
+ return this._overlapTriggerY;
361
+ }
362
+ set overlapTriggerY(value) {
363
+ this._overlapTriggerY = coerceBooleanProperty(value);
364
+ }
365
+ /** Whether the dropdown should overlap its trigger horizontally. */
366
+ get overlapTriggerX() {
367
+ return this._overlapTriggerX;
368
+ }
369
+ set overlapTriggerX(value) {
370
+ this._overlapTriggerX = coerceBooleanProperty(value);
371
+ }
372
+ /** Whether the dropdown has a backdrop. */
373
+ get hasBackdrop() {
374
+ return this._hasBackdrop;
375
+ }
376
+ set hasBackdrop(value) {
377
+ this._hasBackdrop = coerceBooleanProperty(value);
378
+ }
379
+ /**
380
+ * This method takes classes set on the host mc-dropdown element and applies them on the
381
+ * dropdown template that displays in the overlay container. Otherwise, it's difficult
382
+ * to style the containing dropdown from outside the component.
383
+ * @param classes list of class names
384
+ */
385
+ set panelClass(classes) {
386
+ const previousPanelClass = this.previousPanelClass;
387
+ if (previousPanelClass && previousPanelClass.length) {
388
+ previousPanelClass
389
+ .split(' ')
390
+ .forEach((className) => this.classList[className] = false);
391
+ }
392
+ this.previousPanelClass = classes;
393
+ if (classes === null || classes === void 0 ? void 0 : classes.length) {
394
+ classes
395
+ .split(' ')
396
+ .forEach((className) => this.classList[className] = true);
397
+ this.elementRef.nativeElement.className = '';
398
+ }
399
+ }
400
+ ngOnInit() {
401
+ this.setPositionClasses();
402
+ }
403
+ ngAfterContentInit() {
404
+ this.updateDirectDescendants();
405
+ this.keyManager = new FocusKeyManager(this.directDescendantItems)
406
+ .withTypeAhead();
407
+ if (this.navigationWithWrap) {
408
+ this.keyManager.withWrap();
409
+ }
410
+ this.tabSubscription = this.keyManager.tabOut
411
+ .subscribe(() => this.closed.emit('tab'));
412
+ // If a user manually (programmatically) focuses a menu item, we need to reflect that focus
413
+ // change back to the key manager. Note that we don't need to unsubscribe here because focused
414
+ // is internal and we know that it gets completed on destroy.
415
+ this.directDescendantItems.changes
416
+ .pipe(startWith(this.directDescendantItems), switchMap((items) => merge(...items.map((item) => item.focused))))
417
+ .subscribe((focusedItem) => this.keyManager.updateActiveItem(focusedItem));
418
+ }
419
+ ngOnDestroy() {
420
+ this.directDescendantItems.destroy();
421
+ this.tabSubscription.unsubscribe();
422
+ this.closed.complete();
423
+ }
424
+ /** Stream that emits whenever the hovered dropdown item changes. */
425
+ hovered() {
426
+ const itemChanges = this.directDescendantItems.changes;
427
+ return itemChanges.pipe(startWith(this.directDescendantItems), switchMap((items) => merge(...items.map((item) => item.hovered))));
428
+ }
429
+ /** Handle a keyboard event from the dropdown, delegating to the appropriate action. */
430
+ handleKeydown(event) {
431
+ // tslint:disable-next-line:deprecation
432
+ const keyCode = event.keyCode;
433
+ switch (keyCode) {
434
+ case ESCAPE:
435
+ this.closed.emit('keydown');
436
+ break;
437
+ case LEFT_ARROW:
438
+ if (this.parent && this.direction === 'ltr') {
439
+ this.closed.emit('keydown');
440
+ }
441
+ break;
442
+ case RIGHT_ARROW:
443
+ if (this.parent && this.direction === 'rtl') {
444
+ this.closed.emit('keydown');
445
+ }
446
+ break;
447
+ default:
448
+ if (keyCode === UP_ARROW || keyCode === DOWN_ARROW) {
449
+ this.keyManager.setFocusOrigin('keyboard');
450
+ }
451
+ this.keyManager.onKeydown(event);
452
+ return;
453
+ }
454
+ // Don't allow the event to propagate if we've already handled it, or it may
455
+ // end up reaching other overlays that were opened earlier.
456
+ event.stopPropagation();
457
+ }
458
+ /**
459
+ * Focus the first item in the dropdown.
460
+ * @param origin Action from which the focus originated. Used to set the correct styling.
461
+ */
462
+ focusFirstItem(origin = 'program') {
463
+ // When the content is rendered lazily, it takes a bit before the items are inside the DOM.
464
+ if (this.lazyContent) {
465
+ this.ngZone.onStable
466
+ .pipe(take(1))
467
+ .subscribe(() => this.keyManager.setFocusOrigin(origin).setFirstItemActive());
468
+ }
469
+ else {
470
+ this.keyManager.setFocusOrigin(origin).setFirstItemActive();
471
+ }
472
+ }
473
+ /**
474
+ * Resets the active item in the dropdown. This is used when the dropdown is opened, allowing
475
+ * the user to start from the first option when pressing the down arrow.
476
+ */
477
+ resetActiveItem() {
478
+ var _a;
479
+ (_a = this.keyManager.activeItem) === null || _a === void 0 ? void 0 : _a.resetStyles();
480
+ this.keyManager.setActiveItem(-1);
481
+ }
482
+ /**
483
+ * Adds classes to the dropdown panel based on its position. Can be used by
484
+ * consumers to add specific styling based on the position.
485
+ * @param posX Position of the dropdown along the x axis.
486
+ * @param posY Position of the dropdown along the y axis.
487
+ * @docs-private
488
+ */
489
+ setPositionClasses(posX = this.xPosition, posY = this.yPosition) {
490
+ const classes = this.classList;
491
+ classes['mc-dropdown-before'] = posX === 'before';
492
+ classes['mc-dropdown-after'] = posX === 'after';
493
+ classes['mc-dropdown-above'] = posY === 'above';
494
+ classes['mc-dropdown-below'] = posY === 'below';
495
+ }
496
+ /** Starts the enter animation. */
497
+ startAnimation() {
498
+ this.panelAnimationState = 'enter';
499
+ }
500
+ /** Resets the panel animation to its initial state. */
501
+ resetAnimation() {
502
+ this.panelAnimationState = 'void';
503
+ }
504
+ /** Callback that is invoked when the panel animation completes. */
505
+ onAnimationDone(event) {
506
+ this.animationDone.next(event);
507
+ this.isAnimating = false;
508
+ }
509
+ onAnimationStart(event) {
510
+ this.isAnimating = true;
511
+ // Scroll the content element to the top as soon as the animation starts. This is necessary,
512
+ // because we move focus to the first item while it's still being animated, which can throw
513
+ // the browser off when it determines the scroll position. Alternatively we can move focus
514
+ // when the animation is done, however moving focus asynchronously will interrupt screen
515
+ // readers which are in the process of reading out the dropdown already. We take the `element`
516
+ // from the `event` since we can't use a `ViewChild` to access the pane.
517
+ if (event.toState === 'enter' && this.keyManager.activeItemIndex === 0) {
518
+ event.element.scrollTop = 0;
519
+ }
520
+ }
521
+ close() {
522
+ const focusOrigin = this.keyManager.getFocusOrigin() === 'keyboard' ? 'keydown' : 'click';
523
+ this.closed.emit(focusOrigin);
524
+ }
525
+ /**
526
+ * Sets up a stream that will keep track of any newly-added menu items and will update the list
527
+ * of direct descendants. We collect the descendants this way, because `_allItems` can include
528
+ * items that are part of child menus, and using a custom way of registering items is unreliable
529
+ * when it comes to maintaining the item order.
530
+ */
531
+ updateDirectDescendants() {
532
+ this.items.changes
533
+ .pipe(startWith(this.items))
534
+ .subscribe((items) => {
535
+ this.directDescendantItems.reset(items.filter((item) => item.parentDropdownPanel === this));
536
+ this.directDescendantItems.notifyOnChanges();
537
+ });
538
+ }
539
+ }
540
+ /** @nocollapse */ /** @nocollapse */ McDropdown.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.7", ngImport: i0, type: McDropdown, deps: [{ token: i0.ElementRef }, { token: i0.NgZone }, { token: MC_DROPDOWN_DEFAULT_OPTIONS }], target: i0.ɵɵFactoryTarget.Component });
541
+ /** @nocollapse */ /** @nocollapse */ McDropdown.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.7", type: McDropdown, selector: "mc-dropdown", inputs: { navigationWithWrap: "navigationWithWrap", xPosition: "xPosition", yPosition: "yPosition", overlapTriggerY: "overlapTriggerY", overlapTriggerX: "overlapTriggerX", hasBackdrop: "hasBackdrop", panelClass: ["class", "panelClass"], backdropClass: "backdropClass" }, outputs: { closed: "closed" }, providers: [
542
+ { provide: MC_DROPDOWN_PANEL, useExisting: McDropdown }
543
+ ], queries: [{ propertyName: "lazyContent", first: true, predicate: McDropdownContent, descendants: true }, { propertyName: "items", predicate: McDropdownItem, descendants: true }], viewQueries: [{ propertyName: "templateRef", first: true, predicate: TemplateRef, descendants: true }], exportAs: ["mcDropdown"], ngImport: i0, template: "<ng-template>\r\n <div class=\"mc-dropdown__panel\"\r\n [ngClass]=\"classList\"\r\n [class.mc-dropdown__panel_nested]=\"parent\"\r\n [style.min-width]=\"triggerWidth\"\r\n (keydown)=\"handleKeydown($event)\"\r\n (click)=\"close()\"\r\n [@transformDropdown]=\"panelAnimationState\"\r\n (@transformDropdown.start)=\"onAnimationStart($event)\"\r\n (@transformDropdown.done)=\"onAnimationDone($event)\"\r\n tabindex=\"-1\">\r\n\r\n <div class=\"mc-dropdown__content\">\r\n <ng-content></ng-content>\r\n </div>\r\n </div>\r\n</ng-template>\r\n", styles: [".mc-dropdown-trigger.mc-icon-button_right{padding-right:var(--mc-dropdown-trigger-size-button-right-padding, 8px)}.mc-dropdown-trigger.mc-icon-button_right.mc-icon-button_left .mc-icon_left{margin-right:0}.mc-dropdown-trigger .mc-icon_right{margin-left:var(--mc-dropdown-trigger-size-right-icon-padding, 2px)}.mc-dropdown-trigger__icon{margin-left:auto;padding-right:var(--mc-dropdown-trigger-size-right-icon-padding, 2px)}.mc-dropdown__panel{margin-top:-1px;max-width:var(--mc-dropdown-panel-size-max-width, 640px);border-width:var(--mc-dropdown-panel-size-border-width, 1px);border-style:solid;border-bottom-left-radius:var(--mc-dropdown-panel-size-border-radius, 4px);border-bottom-right-radius:var(--mc-dropdown-panel-size-border-radius, 4px);padding:var(--mc-dropdown-panel-size-padding, 4px 0)}.mc-dropdown__panel.mc-dropdown__panel_nested{border-top-left-radius:var(--mc-dropdown-panel-size-border-radius, 4px);border-top-right-radius:var(--mc-dropdown-panel-size-border-radius, 4px)}.mc-dropdown__panel.ng-animating{pointer-events:none}.mc-dropdown__content{display:flex;flex-direction:column}\n"], directives: [{ type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], animations: [
544
+ mcDropdownAnimations.transformDropdown,
545
+ mcDropdownAnimations.fadeInItems
546
+ ], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
547
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.7", ngImport: i0, type: McDropdown, decorators: [{
548
+ type: Component,
549
+ args: [{ selector: 'mc-dropdown', exportAs: 'mcDropdown', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, animations: [
550
+ mcDropdownAnimations.transformDropdown,
551
+ mcDropdownAnimations.fadeInItems
552
+ ], providers: [
553
+ { provide: MC_DROPDOWN_PANEL, useExisting: McDropdown }
554
+ ], template: "<ng-template>\r\n <div class=\"mc-dropdown__panel\"\r\n [ngClass]=\"classList\"\r\n [class.mc-dropdown__panel_nested]=\"parent\"\r\n [style.min-width]=\"triggerWidth\"\r\n (keydown)=\"handleKeydown($event)\"\r\n (click)=\"close()\"\r\n [@transformDropdown]=\"panelAnimationState\"\r\n (@transformDropdown.start)=\"onAnimationStart($event)\"\r\n (@transformDropdown.done)=\"onAnimationDone($event)\"\r\n tabindex=\"-1\">\r\n\r\n <div class=\"mc-dropdown__content\">\r\n <ng-content></ng-content>\r\n </div>\r\n </div>\r\n</ng-template>\r\n", styles: [".mc-dropdown-trigger.mc-icon-button_right{padding-right:var(--mc-dropdown-trigger-size-button-right-padding, 8px)}.mc-dropdown-trigger.mc-icon-button_right.mc-icon-button_left .mc-icon_left{margin-right:0}.mc-dropdown-trigger .mc-icon_right{margin-left:var(--mc-dropdown-trigger-size-right-icon-padding, 2px)}.mc-dropdown-trigger__icon{margin-left:auto;padding-right:var(--mc-dropdown-trigger-size-right-icon-padding, 2px)}.mc-dropdown__panel{margin-top:-1px;max-width:var(--mc-dropdown-panel-size-max-width, 640px);border-width:var(--mc-dropdown-panel-size-border-width, 1px);border-style:solid;border-bottom-left-radius:var(--mc-dropdown-panel-size-border-radius, 4px);border-bottom-right-radius:var(--mc-dropdown-panel-size-border-radius, 4px);padding:var(--mc-dropdown-panel-size-padding, 4px 0)}.mc-dropdown__panel.mc-dropdown__panel_nested{border-top-left-radius:var(--mc-dropdown-panel-size-border-radius, 4px);border-top-right-radius:var(--mc-dropdown-panel-size-border-radius, 4px)}.mc-dropdown__panel.ng-animating{pointer-events:none}.mc-dropdown__content{display:flex;flex-direction:column}\n"] }]
555
+ }], ctorParameters: function () {
556
+ return [{ type: i0.ElementRef }, { type: i0.NgZone }, { type: undefined, decorators: [{
557
+ type: Inject,
558
+ args: [MC_DROPDOWN_DEFAULT_OPTIONS]
559
+ }] }];
560
+ }, propDecorators: { navigationWithWrap: [{
561
+ type: Input
562
+ }], xPosition: [{
563
+ type: Input
564
+ }], yPosition: [{
565
+ type: Input
566
+ }], overlapTriggerY: [{
567
+ type: Input
568
+ }], overlapTriggerX: [{
569
+ type: Input
570
+ }], hasBackdrop: [{
571
+ type: Input
572
+ }], panelClass: [{
573
+ type: Input,
574
+ args: ['class']
575
+ }], backdropClass: [{
576
+ type: Input
577
+ }], templateRef: [{
578
+ type: ViewChild,
579
+ args: [TemplateRef, { static: false }]
580
+ }], items: [{
581
+ type: ContentChildren,
582
+ args: [McDropdownItem, { descendants: true }]
583
+ }], lazyContent: [{
584
+ type: ContentChild,
585
+ args: [McDropdownContent, { static: false }]
586
+ }], closed: [{
587
+ type: Output
588
588
  }] } });
589
589
 
590
- /** Injection token that determines the scroll handling while the dropdown is open. */
591
- const MC_DROPDOWN_SCROLL_STRATEGY = new InjectionToken('mc-dropdown-scroll-strategy');
592
- /** @docs-private */
593
- // tslint:disable-next-line:naming-convention
594
- function MC_DROPDOWN_SCROLL_STRATEGY_FACTORY(overlay) {
595
- return () => overlay.scrollStrategies.reposition();
596
- }
597
- /** @docs-private */
598
- const MC_DROPDOWN_SCROLL_STRATEGY_FACTORY_PROVIDER = {
599
- provide: MC_DROPDOWN_SCROLL_STRATEGY,
600
- deps: [Overlay],
601
- useFactory: MC_DROPDOWN_SCROLL_STRATEGY_FACTORY
602
- };
603
- /** Default top padding of the nested dropdown panel. */
604
- const NESTED_PANEL_TOP_PADDING = 4;
605
- const NESTED_PANEL_LEFT_PADDING = 8;
606
- /** Options for binding a passive event listener. */
607
- const passiveEventListenerOptions = normalizePassiveListenerOptions({ passive: true });
608
- /**
609
- * This directive is intended to be used in conjunction with an mc-dropdown tag. It is
610
- * responsible for toggling the display of the provided dropdown instance.
611
- */
612
- class McDropdownTrigger {
613
- constructor(overlay, elementRef, viewContainerRef, scrollStrategy, parent, dropdownItemInstance, _dir, focusMonitor) {
614
- this.overlay = overlay;
615
- this.elementRef = elementRef;
616
- this.viewContainerRef = viewContainerRef;
617
- this.scrollStrategy = scrollStrategy;
618
- this.parent = parent;
619
- this.dropdownItemInstance = dropdownItemInstance;
620
- this._dir = _dir;
621
- this.focusMonitor = focusMonitor;
622
- this.openByArrowDown = true;
623
- /**
624
- * Whether focus should be restored when the menu is closed.
625
- * Note that disabling this option can have accessibility implications
626
- * and it's up to you to manage focus, if you decide to turn it off.
627
- */
628
- this.restoreFocus = true;
629
- /** Event emitted when the associated dropdown is opened. */
630
- this.dropdownOpened = new EventEmitter();
631
- /** Event emitted when the associated dropdown is closed. */
632
- this.dropdownClosed = new EventEmitter();
633
- this._opened = false;
634
- this.overlayRef = null;
635
- this.closeSubscription = Subscription.EMPTY;
636
- this.hoverSubscription = Subscription.EMPTY;
637
- /**
638
- * Handles touch start events on the trigger.
639
- * Needs to be an arrow function so we can easily use addEventListener and removeEventListener.
640
- */
641
- this.handleTouchStart = () => this.openedBy = 'touch';
642
- elementRef.nativeElement.addEventListener('touchstart', this.handleTouchStart, passiveEventListenerOptions);
643
- if (dropdownItemInstance) {
644
- dropdownItemInstance.isNested = this.isNested();
645
- }
646
- }
647
- /** References the dropdown instance that the trigger is associated with. */
648
- get dropdown() {
649
- return this._dropdown;
650
- }
651
- set dropdown(dropdown) {
652
- if (dropdown === this._dropdown) {
653
- return;
654
- }
655
- this._dropdown = dropdown;
656
- this.closeSubscription.unsubscribe();
657
- if (dropdown) {
658
- this.closeSubscription = dropdown.closed
659
- .asObservable()
660
- .subscribe((reason) => {
661
- this.destroy(reason);
662
- // If a click closed the dropdown, we should close the entire chain of nested dropdowns.
663
- if (['click', 'tab'].includes(reason) && this.parent) {
664
- this.parent.closed.emit(reason);
665
- }
666
- });
667
- }
668
- }
669
- /** The text direction of the containing app. */
670
- get dir() {
671
- var _a;
672
- return ((_a = this._dir) === null || _a === void 0 ? void 0 : _a.value) === 'rtl' ? 'rtl' : 'ltr';
673
- }
674
- /** Whether the dropdown is open. */
675
- get opened() {
676
- return this._opened;
677
- }
678
- ngAfterContentInit() {
679
- this.check();
680
- this.handleHover();
681
- }
682
- ngOnDestroy() {
683
- if (this.overlayRef) {
684
- this.overlayRef.dispose();
685
- this.overlayRef = null;
686
- }
687
- this.elementRef.nativeElement.removeEventListener('touchstart', this.handleTouchStart, passiveEventListenerOptions);
688
- this.cleanUpSubscriptions();
689
- }
690
- /** Whether the dropdown triggers a nested dropdown or a top-level one. */
691
- isNested() {
692
- return !!(this.dropdownItemInstance && this.parent);
693
- }
694
- /** Toggles the dropdown between the open and closed states. */
695
- toggle() {
696
- // tslint:disable-next-line:no-void-expression
697
- return this._opened ? this.close() : this.open();
698
- }
699
- /** Opens the dropdown. */
700
- open() {
701
- if (this._opened) {
702
- return;
703
- }
704
- this.check();
705
- const overlayRef = this.createOverlay();
706
- const overlayConfig = overlayRef.getConfig();
707
- this.setPosition(overlayConfig.positionStrategy);
708
- overlayConfig.hasBackdrop = this.dropdown.hasBackdrop ? !this.isNested() : this.dropdown.hasBackdrop;
709
- overlayRef.attach(this.getPortal());
710
- if (this.dropdown.lazyContent) {
711
- this.dropdown.lazyContent.detach();
712
- this.dropdown.lazyContent.attach(this.data);
713
- }
714
- this.closeSubscription = this.closingActions()
715
- .subscribe(() => this.close());
716
- this.init();
717
- if (this.dropdown instanceof McDropdown) {
718
- this.dropdown.startAnimation();
719
- }
720
- }
721
- /** Closes the dropdown. */
722
- close() {
723
- this.dropdown.closed.emit();
724
- }
725
- /**
726
- * Focuses the dropdown trigger.
727
- */
728
- focus(origin, options) {
729
- if (this.focusMonitor && origin) {
730
- this.focusMonitor.focusVia(this.elementRef.nativeElement, origin, options);
731
- }
732
- else {
733
- this.elementRef.nativeElement.focus();
734
- }
735
- }
736
- /** Handles mouse presses on the trigger. */
737
- handleMousedown(event) {
738
- // Since right or middle button clicks won't trigger the `click` event,
739
- // we shouldn't consider the dropdown as opened by mouse in those cases.
740
- this.openedBy = event.button === 0 ? 'mouse' : undefined;
741
- // Since clicking on the trigger won't close the dropdown if it opens a nested dropdown,
742
- // we should prevent focus from moving onto it via click to avoid the
743
- // highlight from lingering on the dropdown item.
744
- if (this.isNested()) {
745
- event.preventDefault();
746
- }
747
- }
748
- /** Handles key presses on the trigger. */
749
- handleKeydown(event) {
750
- // tslint:disable-next-line:deprecation
751
- const keyCode = event.keyCode;
752
- if (keyCode === ENTER || keyCode === SPACE) {
753
- this.openedBy = 'keyboard';
754
- event.preventDefault();
755
- if (this.isNested()) {
756
- // Stop event propagation to avoid closing the parent dropdown.
757
- event.stopPropagation();
758
- this.open();
759
- }
760
- else {
761
- this.toggle();
762
- }
763
- }
764
- if ((this.isNested() &&
765
- ((keyCode === RIGHT_ARROW && this.dir === 'ltr') || (keyCode === LEFT_ARROW && this.dir === 'rtl'))) ||
766
- (!this.isNested() && (keyCode === DOWN_ARROW$1 && this.openByArrowDown))) {
767
- event.preventDefault();
768
- this.openedBy = 'keyboard';
769
- this.open();
770
- }
771
- }
772
- /** Handles click events on the trigger. */
773
- handleClick(event) {
774
- if (this.isNested()) {
775
- // Stop event propagation to avoid closing the parent dropdown.
776
- event.stopPropagation();
777
- this.open();
778
- }
779
- else {
780
- this.toggle();
781
- }
782
- }
783
- /** Closes the dropdown and does the necessary cleanup. */
784
- destroy(reason) {
785
- if (!this.overlayRef || !this.opened) {
786
- return;
787
- }
788
- this.lastDestroyReason = reason;
789
- this.dropdown.resetActiveItem();
790
- this.closeSubscription.unsubscribe();
791
- this.overlayRef.detach();
792
- if (this.restoreFocus && (reason === 'keydown' || !this.openedBy || !this.isNested())) {
793
- this.focus(this.openedBy);
794
- }
795
- this.openedBy = undefined;
796
- if (this.dropdown instanceof McDropdown) {
797
- this.dropdown.resetAnimation();
798
- const animationSubscription = this.dropdown.animationDone
799
- .pipe(filter((event) => event.toState === 'void'), take(1));
800
- if (this.dropdown.lazyContent) {
801
- // Wait for the exit animation to finish before detaching the content.
802
- animationSubscription
803
- .pipe(
804
- // Interrupt if the content got re-attached.
805
- takeUntil(this.dropdown.lazyContent.attached))
806
- .subscribe({
807
- next: () => this.dropdown.lazyContent.detach(),
808
- // No matter whether the content got re-attached, reset the this.dropdown.
809
- complete: () => this.setIsOpened(false)
810
- });
811
- }
812
- else {
813
- animationSubscription
814
- .subscribe(() => this.setIsOpened(false));
815
- }
816
- }
817
- else {
818
- this.setIsOpened(false);
819
- if (this.dropdown.lazyContent) {
820
- this.dropdown.lazyContent.detach();
821
- }
822
- }
823
- }
824
- /**
825
- * This method sets the dropdown state to open and focuses the first item if
826
- * the dropdown was opened via the keyboard.
827
- */
828
- init() {
829
- this.dropdown.parent = this.isNested() ? this.parent : undefined;
830
- this.dropdown.direction = this.dir;
831
- if (!this.dropdown.parent) {
832
- this.dropdown.triggerWidth = this.getWidth();
833
- }
834
- this.dropdown.focusFirstItem(this.openedBy || 'program');
835
- this.setIsOpened(true);
836
- }
837
- // set state rather than toggle to support triggers sharing a dropdown
838
- setIsOpened(isOpen) {
839
- this._opened = isOpen;
840
- // tslint:disable-next-line:no-void-expression
841
- this._opened ? this.dropdownOpened.emit() : this.dropdownClosed.emit();
842
- if (this.isNested()) {
843
- this.dropdownItemInstance.highlighted = isOpen;
844
- }
845
- }
846
- /**
847
- * This method checks that a valid instance of McDropdown has been passed into
848
- * mcDropdownTriggerFor. If not, an exception is thrown.
849
- */
850
- check() {
851
- if (!this.dropdown) {
852
- throwMcDropdownMissingError();
853
- }
854
- }
855
- /**
856
- * This method creates the overlay from the provided dropdown's template and saves its
857
- * OverlayRef so that it can be attached to the DOM when open is called.
858
- */
859
- createOverlay() {
860
- if (!this.overlayRef) {
861
- const config = this.getOverlayConfig();
862
- this.subscribeToPositions(config.positionStrategy);
863
- this.overlayRef = this.overlay.create(config);
864
- // Consume the `keydownEvents` in order to prevent them from going to another overlay.
865
- // Ideally we'd also have our keyboard event logic in here, however doing so will
866
- // break anybody that may have implemented the `McDropdownPanel` themselves.
867
- this.overlayRef.keydownEvents()
868
- .subscribe();
869
- }
870
- return this.overlayRef;
871
- }
872
- /**
873
- * This method builds the configuration object needed to create the overlay, the OverlayState.
874
- * @returns OverlayConfig
875
- */
876
- getOverlayConfig() {
877
- return new OverlayConfig({
878
- positionStrategy: this.overlay.position()
879
- .flexibleConnectedTo(this.elementRef)
880
- .withLockedPosition()
881
- .withTransformOriginOn('.mc-dropdown__panel'),
882
- backdropClass: this.dropdown.backdropClass || 'cdk-overlay-transparent-backdrop',
883
- scrollStrategy: this.scrollStrategy(),
884
- direction: this.dir
885
- });
886
- }
887
- /**
888
- * Listens to changes in the position of the overlay and sets the correct classes
889
- * on the dropdown based on the new position. This ensures the animation origin is always
890
- * correct, even if a fallback position is used for the overlay.
891
- */
892
- subscribeToPositions(position) {
893
- if (this.dropdown.setPositionClasses) {
894
- position.positionChanges
895
- .subscribe((change) => {
896
- const posX = change.connectionPair.overlayX === 'start' ? 'after' : 'before';
897
- const posY = change.connectionPair.overlayY === 'top' ? 'below' : 'above';
898
- this.dropdown.setPositionClasses(posX, posY);
899
- });
900
- }
901
- }
902
- /**
903
- * Sets the appropriate positions on a position strategy
904
- * so the overlay connects with the trigger correctly.
905
- * @param positionStrategy Strategy whose position to update.
906
- */
907
- setPosition(positionStrategy) {
908
- let [originX, originFallbackX, overlayX, overlayFallbackX] = this.dropdown.xPosition === 'before' ?
909
- ['end', 'start', 'end', 'start'] :
910
- ['start', 'end', 'start', 'end'];
911
- // tslint:disable-next-line:prefer-const
912
- let [overlayY, overlayFallbackY, originY, originFallbackY] = this.dropdown.yPosition === 'above' ?
913
- ['bottom', 'top', 'bottom', 'top'] :
914
- ['top', 'bottom', 'top', 'bottom'];
915
- let offsetY = 0;
916
- let offsetX = 0;
917
- if (this.isNested()) {
918
- // When the dropdown is nested, it should always align itself
919
- // to the edges of the trigger, instead of overlapping it.
920
- overlayFallbackX = originX = this.dropdown.xPosition === 'before' ? 'start' : 'end';
921
- originFallbackX = overlayX = originX === 'end' ? 'start' : 'end';
922
- offsetY = overlayY === 'bottom' ? NESTED_PANEL_TOP_PADDING : -NESTED_PANEL_TOP_PADDING;
923
- offsetX = NESTED_PANEL_LEFT_PADDING;
924
- }
925
- else {
926
- if (!this.dropdown.overlapTriggerY) {
927
- originY = overlayY === 'top' ? 'bottom' : 'top';
928
- originFallbackY = overlayFallbackY === 'top' ? 'bottom' : 'top';
929
- }
930
- if (!this.dropdown.overlapTriggerX) {
931
- overlayFallbackX = originX = this.dropdown.xPosition === 'before' ? 'start' : 'end';
932
- originFallbackX = overlayX = originX === 'end' ? 'start' : 'end';
933
- }
934
- }
935
- positionStrategy.withPositions([
936
- { originX, originY, overlayX, overlayY, offsetY, offsetX: -offsetX },
937
- { originX: originFallbackX, originY, overlayX: overlayFallbackX, overlayY, offsetY, offsetX },
938
- {
939
- originX,
940
- originY: originFallbackY,
941
- overlayX,
942
- overlayY: overlayFallbackY,
943
- offsetY: -offsetY,
944
- offsetX: -offsetX
945
- },
946
- {
947
- originX: originFallbackX,
948
- originY: originFallbackY,
949
- overlayX: overlayFallbackX,
950
- overlayY: overlayFallbackY,
951
- offsetY: -offsetY,
952
- offsetX: -offsetX
953
- }
954
- ]);
955
- }
956
- /** Cleans up the active subscriptions. */
957
- cleanUpSubscriptions() {
958
- this.closeSubscription.unsubscribe();
959
- this.hoverSubscription.unsubscribe();
960
- }
961
- /** Returns a stream that emits whenever an action that should close the dropdown occurs. */
962
- closingActions() {
963
- const backdrop = this.overlayRef.backdropClick();
964
- const outsidePointerEvents = this.overlayRef.outsidePointerEvents();
965
- const detachments = this.overlayRef.detachments();
966
- const parentClose = this.parent ? this.parent.closed : of();
967
- const hover = this.parent ? this.parent.hovered()
968
- .pipe(filter((active) => active !== this.dropdownItemInstance), filter(() => this._opened)) : of();
969
- return merge(backdrop, outsidePointerEvents, parentClose, hover, detachments);
970
- }
971
- /** Handles the cases where the user hovers over the trigger. */
972
- handleHover() {
973
- // Subscribe to changes in the hovered item in order to toggle the panel.
974
- if (!this.isNested()) {
975
- return;
976
- }
977
- this.hoverSubscription = this.parent.hovered()
978
- // Since we might have multiple competing triggers for the same dropdown (e.g. a nested dropdown
979
- // with different data and triggers), we have to delay it by a tick to ensure that
980
- // it won't be closed immediately after it is opened.
981
- .pipe(filter((active) => active === this.dropdownItemInstance && !active.disabled), delay(0, asapScheduler))
982
- .subscribe(() => {
983
- this.openedBy = 'mouse';
984
- // If the same dropdown is used between multiple triggers, it might still be animating
985
- // while the new trigger tries to re-open it. Wait for the animation to finish
986
- // before doing so. Also interrupt if the user moves to another item.
987
- if (this.dropdown instanceof McDropdown && this.dropdown.isAnimating) {
988
- // We need the `delay(0)` here in order to avoid
989
- // 'changed after checked' errors in some cases. See #12194.
990
- this.dropdown.animationDone
991
- .pipe(take(1), delay(0, asapScheduler), takeUntil(this.parent.hovered()))
992
- .subscribe(() => this.open());
993
- }
994
- else {
995
- this.open();
996
- }
997
- });
998
- }
999
- /** Gets the portal that should be attached to the overlay. */
1000
- getPortal() {
1001
- // Note that we can avoid this check by keeping the portal on the dropdown panel.
1002
- // While it would be cleaner, we'd have to introduce another required method on
1003
- // `McDropdownPanel`, making it harder to consume.
1004
- if (!this.portal || this.portal.templateRef !== this.dropdown.templateRef) {
1005
- this.portal = new TemplatePortal(this.dropdown.templateRef, this.viewContainerRef);
1006
- }
1007
- return this.portal;
1008
- }
1009
- getWidth() {
1010
- const nativeElement = this.elementRef.nativeElement;
1011
- const { width, borderRightWidth, borderLeftWidth } = window.getComputedStyle(nativeElement);
1012
- return `${parseInt(width) - parseInt(borderRightWidth) - parseInt(borderLeftWidth)}px`;
1013
- }
1014
- }
1015
- /** @nocollapse */ /** @nocollapse */ McDropdownTrigger.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: McDropdownTrigger, deps: [{ token: i1$1.Overlay }, { token: i0.ElementRef }, { token: i0.ViewContainerRef }, { token: MC_DROPDOWN_SCROLL_STRATEGY }, { token: McDropdown, optional: true }, { token: McDropdownItem, optional: true, self: true }, { token: i4.Directionality, optional: true }, { token: i1.FocusMonitor }], target: i0.ɵɵFactoryTarget.Directive });
1016
- /** @nocollapse */ /** @nocollapse */ McDropdownTrigger.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.4", type: McDropdownTrigger, selector: "[mcDropdownTriggerFor]", inputs: { data: ["mcDropdownTriggerData", "data"], openByArrowDown: "openByArrowDown", restoreFocus: ["mcDropdownTriggerRestoreFocus", "restoreFocus"], dropdown: ["mcDropdownTriggerFor", "dropdown"] }, outputs: { dropdownOpened: "dropdownOpened", dropdownClosed: "dropdownClosed" }, host: { listeners: { "mousedown": "handleMousedown($event)", "keydown": "handleKeydown($event)", "click": "handleClick($event)" }, properties: { "class.mc-pressed": "opened" }, classAttribute: "mc-dropdown-trigger" }, exportAs: ["mcDropdownTrigger"], ngImport: i0 });
1017
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: McDropdownTrigger, decorators: [{
1018
- type: Directive,
1019
- args: [{
1020
- selector: `[mcDropdownTriggerFor]`,
1021
- exportAs: 'mcDropdownTrigger',
1022
- host: {
1023
- class: 'mc-dropdown-trigger',
1024
- '[class.mc-pressed]': 'opened',
1025
- '(mousedown)': 'handleMousedown($event)',
1026
- '(keydown)': 'handleKeydown($event)',
1027
- '(click)': 'handleClick($event)'
1028
- }
1029
- }]
1030
- }], ctorParameters: function () {
1031
- return [{ type: i1$1.Overlay }, { type: i0.ElementRef }, { type: i0.ViewContainerRef }, { type: undefined, decorators: [{
1032
- type: Inject,
1033
- args: [MC_DROPDOWN_SCROLL_STRATEGY]
1034
- }] }, { type: McDropdown, decorators: [{
1035
- type: Optional
1036
- }] }, { type: McDropdownItem, decorators: [{
1037
- type: Optional
1038
- }, {
1039
- type: Self
1040
- }] }, { type: i4.Directionality, decorators: [{
1041
- type: Optional
1042
- }] }, { type: i1.FocusMonitor }];
1043
- }, propDecorators: { data: [{
1044
- type: Input,
1045
- args: ['mcDropdownTriggerData']
1046
- }], openByArrowDown: [{
1047
- type: Input
1048
- }], restoreFocus: [{
1049
- type: Input,
1050
- args: ['mcDropdownTriggerRestoreFocus']
1051
- }], dropdown: [{
1052
- type: Input,
1053
- args: ['mcDropdownTriggerFor']
1054
- }], dropdownOpened: [{
1055
- type: Output
1056
- }], dropdownClosed: [{
1057
- type: Output
590
+ /** Injection token that determines the scroll handling while the dropdown is open. */
591
+ const MC_DROPDOWN_SCROLL_STRATEGY = new InjectionToken('mc-dropdown-scroll-strategy');
592
+ /** @docs-private */
593
+ // tslint:disable-next-line:naming-convention
594
+ function MC_DROPDOWN_SCROLL_STRATEGY_FACTORY(overlay) {
595
+ return () => overlay.scrollStrategies.reposition();
596
+ }
597
+ /** @docs-private */
598
+ const MC_DROPDOWN_SCROLL_STRATEGY_FACTORY_PROVIDER = {
599
+ provide: MC_DROPDOWN_SCROLL_STRATEGY,
600
+ deps: [Overlay],
601
+ useFactory: MC_DROPDOWN_SCROLL_STRATEGY_FACTORY
602
+ };
603
+ /** Default top padding of the nested dropdown panel. */
604
+ const NESTED_PANEL_TOP_PADDING = 4;
605
+ const NESTED_PANEL_LEFT_PADDING = 8;
606
+ /** Options for binding a passive event listener. */
607
+ const passiveEventListenerOptions = normalizePassiveListenerOptions({ passive: true });
608
+ /**
609
+ * This directive is intended to be used in conjunction with an mc-dropdown tag. It is
610
+ * responsible for toggling the display of the provided dropdown instance.
611
+ */
612
+ class McDropdownTrigger {
613
+ constructor(overlay, elementRef, viewContainerRef, scrollStrategy, parent, dropdownItemInstance, _dir, changeDetecotrRef, focusMonitor) {
614
+ this.overlay = overlay;
615
+ this.elementRef = elementRef;
616
+ this.viewContainerRef = viewContainerRef;
617
+ this.scrollStrategy = scrollStrategy;
618
+ this.parent = parent;
619
+ this.dropdownItemInstance = dropdownItemInstance;
620
+ this._dir = _dir;
621
+ this.changeDetecotrRef = changeDetecotrRef;
622
+ this.focusMonitor = focusMonitor;
623
+ this.openByArrowDown = true;
624
+ /**
625
+ * Whether focus should be restored when the menu is closed.
626
+ * Note that disabling this option can have accessibility implications
627
+ * and it's up to you to manage focus, if you decide to turn it off.
628
+ */
629
+ this.restoreFocus = true;
630
+ /** Event emitted when the associated dropdown is opened. */
631
+ this.dropdownOpened = new EventEmitter();
632
+ /** Event emitted when the associated dropdown is closed. */
633
+ this.dropdownClosed = new EventEmitter();
634
+ this._opened = false;
635
+ this.overlayRef = null;
636
+ this.closeSubscription = Subscription.EMPTY;
637
+ this.hoverSubscription = Subscription.EMPTY;
638
+ /**
639
+ * Handles touch start events on the trigger.
640
+ * Needs to be an arrow function so we can easily use addEventListener and removeEventListener.
641
+ */
642
+ this.handleTouchStart = () => this.openedBy = 'touch';
643
+ elementRef.nativeElement.addEventListener('touchstart', this.handleTouchStart, passiveEventListenerOptions);
644
+ if (dropdownItemInstance) {
645
+ dropdownItemInstance.isNested = this.isNested();
646
+ }
647
+ }
648
+ /** References the dropdown instance that the trigger is associated with. */
649
+ get dropdown() {
650
+ return this._dropdown;
651
+ }
652
+ set dropdown(dropdown) {
653
+ if (dropdown === this._dropdown) {
654
+ return;
655
+ }
656
+ this._dropdown = dropdown;
657
+ this.closeSubscription.unsubscribe();
658
+ if (dropdown) {
659
+ this.closeSubscription = dropdown.closed
660
+ .asObservable()
661
+ .subscribe((reason) => {
662
+ this.destroy(reason);
663
+ // If a click closed the dropdown, we should close the entire chain of nested dropdowns.
664
+ if (['click', 'tab'].includes(reason) && this.parent) {
665
+ this.parent.closed.emit(reason);
666
+ }
667
+ });
668
+ }
669
+ }
670
+ /** The text direction of the containing app. */
671
+ get dir() {
672
+ var _a;
673
+ return ((_a = this._dir) === null || _a === void 0 ? void 0 : _a.value) === 'rtl' ? 'rtl' : 'ltr';
674
+ }
675
+ /** Whether the dropdown is open. */
676
+ get opened() {
677
+ return this._opened;
678
+ }
679
+ ngAfterContentInit() {
680
+ this.check();
681
+ this.handleHover();
682
+ }
683
+ ngOnDestroy() {
684
+ if (this.overlayRef) {
685
+ this.overlayRef.dispose();
686
+ this.overlayRef = null;
687
+ }
688
+ this.elementRef.nativeElement.removeEventListener('touchstart', this.handleTouchStart, passiveEventListenerOptions);
689
+ this.cleanUpSubscriptions();
690
+ }
691
+ /** Whether the dropdown triggers a nested dropdown or a top-level one. */
692
+ isNested() {
693
+ return !!(this.dropdownItemInstance && this.parent);
694
+ }
695
+ /** Toggles the dropdown between the open and closed states. */
696
+ toggle() {
697
+ // tslint:disable-next-line:no-void-expression
698
+ return this._opened ? this.close() : this.open();
699
+ }
700
+ /** Opens the dropdown. */
701
+ open() {
702
+ if (this._opened) {
703
+ return;
704
+ }
705
+ this.check();
706
+ const overlayRef = this.createOverlay();
707
+ const overlayConfig = overlayRef.getConfig();
708
+ this.setPosition(overlayConfig.positionStrategy);
709
+ overlayConfig.hasBackdrop = this.dropdown.hasBackdrop ? !this.isNested() : this.dropdown.hasBackdrop;
710
+ overlayRef.attach(this.getPortal());
711
+ if (this.dropdown.lazyContent) {
712
+ this.dropdown.lazyContent.detach();
713
+ this.dropdown.lazyContent.attach(this.data);
714
+ }
715
+ this.closeSubscription = this.closingActions()
716
+ .subscribe(() => this.close());
717
+ this.init();
718
+ if (this.dropdown instanceof McDropdown) {
719
+ this.dropdown.startAnimation();
720
+ }
721
+ }
722
+ /** Closes the dropdown. */
723
+ close() {
724
+ this.dropdown.closed.emit();
725
+ }
726
+ /**
727
+ * Focuses the dropdown trigger.
728
+ */
729
+ focus(origin, options) {
730
+ if (this.focusMonitor && origin) {
731
+ this.focusMonitor.focusVia(this.elementRef.nativeElement, origin, options);
732
+ }
733
+ else {
734
+ this.elementRef.nativeElement.focus();
735
+ }
736
+ }
737
+ /** Handles mouse presses on the trigger. */
738
+ handleMousedown(event) {
739
+ // Since right or middle button clicks won't trigger the `click` event,
740
+ // we shouldn't consider the dropdown as opened by mouse in those cases.
741
+ this.openedBy = event.button === 0 ? 'mouse' : undefined;
742
+ // Since clicking on the trigger won't close the dropdown if it opens a nested dropdown,
743
+ // we should prevent focus from moving onto it via click to avoid the
744
+ // highlight from lingering on the dropdown item.
745
+ if (this.isNested()) {
746
+ event.preventDefault();
747
+ }
748
+ }
749
+ /** Handles key presses on the trigger. */
750
+ handleKeydown(event) {
751
+ // tslint:disable-next-line:deprecation
752
+ const keyCode = event.keyCode;
753
+ if (keyCode === ENTER || keyCode === SPACE) {
754
+ this.openedBy = 'keyboard';
755
+ event.preventDefault();
756
+ if (this.isNested()) {
757
+ // Stop event propagation to avoid closing the parent dropdown.
758
+ event.stopPropagation();
759
+ this.open();
760
+ }
761
+ else {
762
+ this.toggle();
763
+ }
764
+ }
765
+ if ((this.isNested() &&
766
+ ((keyCode === RIGHT_ARROW && this.dir === 'ltr') || (keyCode === LEFT_ARROW && this.dir === 'rtl'))) ||
767
+ (!this.isNested() && (keyCode === DOWN_ARROW$1 && this.openByArrowDown))) {
768
+ event.preventDefault();
769
+ this.openedBy = 'keyboard';
770
+ this.open();
771
+ }
772
+ }
773
+ /** Handles click events on the trigger. */
774
+ handleClick(event) {
775
+ if (this.isNested()) {
776
+ // Stop event propagation to avoid closing the parent dropdown.
777
+ event.stopPropagation();
778
+ this.open();
779
+ }
780
+ else {
781
+ this.toggle();
782
+ }
783
+ }
784
+ /** Closes the dropdown and does the necessary cleanup. */
785
+ destroy(reason) {
786
+ if (!this.overlayRef || !this.opened) {
787
+ return;
788
+ }
789
+ this.lastDestroyReason = reason;
790
+ this.dropdown.resetActiveItem();
791
+ this.closeSubscription.unsubscribe();
792
+ this.overlayRef.detach();
793
+ if (this.restoreFocus && (reason === 'keydown' || !this.openedBy || !this.isNested())) {
794
+ this.focus(this.openedBy);
795
+ }
796
+ this.openedBy = undefined;
797
+ if (this.dropdown instanceof McDropdown) {
798
+ this.dropdown.resetAnimation();
799
+ const animationSubscription = this.dropdown.animationDone
800
+ .pipe(filter((event) => event.toState === 'void'), take(1));
801
+ if (this.dropdown.lazyContent) {
802
+ // Wait for the exit animation to finish before detaching the content.
803
+ animationSubscription
804
+ .pipe(
805
+ // Interrupt if the content got re-attached.
806
+ takeUntil(this.dropdown.lazyContent.attached))
807
+ .subscribe({
808
+ next: () => this.dropdown.lazyContent.detach(),
809
+ // No matter whether the content got re-attached, reset the this.dropdown.
810
+ complete: () => this.setIsOpened(false)
811
+ });
812
+ }
813
+ else {
814
+ animationSubscription
815
+ .subscribe(() => this.setIsOpened(false));
816
+ }
817
+ }
818
+ else {
819
+ this.setIsOpened(false);
820
+ if (this.dropdown.lazyContent) {
821
+ this.dropdown.lazyContent.detach();
822
+ }
823
+ }
824
+ }
825
+ /**
826
+ * This method sets the dropdown state to open and focuses the first item if
827
+ * the dropdown was opened via the keyboard.
828
+ */
829
+ init() {
830
+ this.dropdown.parent = this.isNested() ? this.parent : undefined;
831
+ this.dropdown.direction = this.dir;
832
+ if (!this.dropdown.parent) {
833
+ this.dropdown.triggerWidth = this.getWidth();
834
+ }
835
+ this.dropdown.focusFirstItem(this.openedBy || 'program');
836
+ this.setIsOpened(true);
837
+ }
838
+ // set state rather than toggle to support triggers sharing a dropdown
839
+ setIsOpened(isOpen) {
840
+ if (isOpen !== this._opened) {
841
+ this.changeDetecotrRef.markForCheck();
842
+ }
843
+ this._opened = isOpen;
844
+ // tslint:disable-next-line:no-void-expression
845
+ this._opened ? this.dropdownOpened.emit() : this.dropdownClosed.emit();
846
+ if (this.isNested()) {
847
+ this.dropdownItemInstance.highlighted = isOpen;
848
+ }
849
+ }
850
+ /**
851
+ * This method checks that a valid instance of McDropdown has been passed into
852
+ * mcDropdownTriggerFor. If not, an exception is thrown.
853
+ */
854
+ check() {
855
+ if (!this.dropdown) {
856
+ throwMcDropdownMissingError();
857
+ }
858
+ }
859
+ /**
860
+ * This method creates the overlay from the provided dropdown's template and saves its
861
+ * OverlayRef so that it can be attached to the DOM when open is called.
862
+ */
863
+ createOverlay() {
864
+ if (!this.overlayRef) {
865
+ const config = this.getOverlayConfig();
866
+ this.subscribeToPositions(config.positionStrategy);
867
+ this.overlayRef = this.overlay.create(config);
868
+ // Consume the `keydownEvents` in order to prevent them from going to another overlay.
869
+ // Ideally we'd also have our keyboard event logic in here, however doing so will
870
+ // break anybody that may have implemented the `McDropdownPanel` themselves.
871
+ this.overlayRef.keydownEvents()
872
+ .subscribe();
873
+ }
874
+ return this.overlayRef;
875
+ }
876
+ /**
877
+ * This method builds the configuration object needed to create the overlay, the OverlayState.
878
+ * @returns OverlayConfig
879
+ */
880
+ getOverlayConfig() {
881
+ return new OverlayConfig({
882
+ positionStrategy: this.overlay.position()
883
+ .flexibleConnectedTo(this.elementRef)
884
+ .withLockedPosition()
885
+ .withTransformOriginOn('.mc-dropdown__panel'),
886
+ backdropClass: this.dropdown.backdropClass || 'cdk-overlay-transparent-backdrop',
887
+ scrollStrategy: this.scrollStrategy(),
888
+ direction: this.dir
889
+ });
890
+ }
891
+ /**
892
+ * Listens to changes in the position of the overlay and sets the correct classes
893
+ * on the dropdown based on the new position. This ensures the animation origin is always
894
+ * correct, even if a fallback position is used for the overlay.
895
+ */
896
+ subscribeToPositions(position) {
897
+ if (this.dropdown.setPositionClasses) {
898
+ position.positionChanges
899
+ .subscribe((change) => {
900
+ const posX = change.connectionPair.overlayX === 'start' ? 'after' : 'before';
901
+ const posY = change.connectionPair.overlayY === 'top' ? 'below' : 'above';
902
+ this.dropdown.setPositionClasses(posX, posY);
903
+ });
904
+ }
905
+ }
906
+ /**
907
+ * Sets the appropriate positions on a position strategy
908
+ * so the overlay connects with the trigger correctly.
909
+ * @param positionStrategy Strategy whose position to update.
910
+ */
911
+ setPosition(positionStrategy) {
912
+ let [originX, originFallbackX, overlayX, overlayFallbackX] = this.dropdown.xPosition === 'before' ?
913
+ ['end', 'start', 'end', 'start'] :
914
+ ['start', 'end', 'start', 'end'];
915
+ // tslint:disable-next-line:prefer-const
916
+ let [overlayY, overlayFallbackY, originY, originFallbackY] = this.dropdown.yPosition === 'above' ?
917
+ ['bottom', 'top', 'bottom', 'top'] :
918
+ ['top', 'bottom', 'top', 'bottom'];
919
+ let offsetY = 0;
920
+ let offsetX = 0;
921
+ if (this.isNested()) {
922
+ // When the dropdown is nested, it should always align itself
923
+ // to the edges of the trigger, instead of overlapping it.
924
+ overlayFallbackX = originX = this.dropdown.xPosition === 'before' ? 'start' : 'end';
925
+ originFallbackX = overlayX = originX === 'end' ? 'start' : 'end';
926
+ offsetY = overlayY === 'bottom' ? NESTED_PANEL_TOP_PADDING : -NESTED_PANEL_TOP_PADDING;
927
+ offsetX = NESTED_PANEL_LEFT_PADDING;
928
+ }
929
+ else {
930
+ if (!this.dropdown.overlapTriggerY) {
931
+ originY = overlayY === 'top' ? 'bottom' : 'top';
932
+ originFallbackY = overlayFallbackY === 'top' ? 'bottom' : 'top';
933
+ }
934
+ if (!this.dropdown.overlapTriggerX) {
935
+ overlayFallbackX = originX = this.dropdown.xPosition === 'before' ? 'start' : 'end';
936
+ originFallbackX = overlayX = originX === 'end' ? 'start' : 'end';
937
+ }
938
+ }
939
+ positionStrategy.withPositions([
940
+ { originX, originY, overlayX, overlayY, offsetY, offsetX: -offsetX },
941
+ { originX: originFallbackX, originY, overlayX: overlayFallbackX, overlayY, offsetY, offsetX },
942
+ {
943
+ originX,
944
+ originY: originFallbackY,
945
+ overlayX,
946
+ overlayY: overlayFallbackY,
947
+ offsetY: -offsetY,
948
+ offsetX: -offsetX
949
+ },
950
+ {
951
+ originX: originFallbackX,
952
+ originY: originFallbackY,
953
+ overlayX: overlayFallbackX,
954
+ overlayY: overlayFallbackY,
955
+ offsetY: -offsetY,
956
+ offsetX: -offsetX
957
+ }
958
+ ]);
959
+ }
960
+ /** Cleans up the active subscriptions. */
961
+ cleanUpSubscriptions() {
962
+ this.closeSubscription.unsubscribe();
963
+ this.hoverSubscription.unsubscribe();
964
+ }
965
+ /** Returns a stream that emits whenever an action that should close the dropdown occurs. */
966
+ closingActions() {
967
+ const backdrop = this.overlayRef.backdropClick();
968
+ const outsidePointerEvents = this.overlayRef.outsidePointerEvents();
969
+ const detachments = this.overlayRef.detachments();
970
+ const parentClose = this.parent ? this.parent.closed : of();
971
+ const hover = this.parent ? this.parent.hovered()
972
+ .pipe(filter((active) => active !== this.dropdownItemInstance), filter(() => this._opened)) : of();
973
+ return merge(backdrop, outsidePointerEvents, parentClose, hover, detachments);
974
+ }
975
+ /** Handles the cases where the user hovers over the trigger. */
976
+ handleHover() {
977
+ // Subscribe to changes in the hovered item in order to toggle the panel.
978
+ if (!this.isNested()) {
979
+ return;
980
+ }
981
+ this.hoverSubscription = this.parent.hovered()
982
+ // Since we might have multiple competing triggers for the same dropdown (e.g. a nested dropdown
983
+ // with different data and triggers), we have to delay it by a tick to ensure that
984
+ // it won't be closed immediately after it is opened.
985
+ .pipe(filter((active) => active === this.dropdownItemInstance && !active.disabled), delay(0, asapScheduler))
986
+ .subscribe(() => {
987
+ this.openedBy = 'mouse';
988
+ // If the same dropdown is used between multiple triggers, it might still be animating
989
+ // while the new trigger tries to re-open it. Wait for the animation to finish
990
+ // before doing so. Also interrupt if the user moves to another item.
991
+ if (this.dropdown instanceof McDropdown && this.dropdown.isAnimating) {
992
+ // We need the `delay(0)` here in order to avoid
993
+ // 'changed after checked' errors in some cases. See #12194.
994
+ this.dropdown.animationDone
995
+ .pipe(take(1), delay(0, asapScheduler), takeUntil(this.parent.hovered()))
996
+ .subscribe(() => this.open());
997
+ }
998
+ else {
999
+ this.open();
1000
+ }
1001
+ });
1002
+ }
1003
+ /** Gets the portal that should be attached to the overlay. */
1004
+ getPortal() {
1005
+ // Note that we can avoid this check by keeping the portal on the dropdown panel.
1006
+ // While it would be cleaner, we'd have to introduce another required method on
1007
+ // `McDropdownPanel`, making it harder to consume.
1008
+ if (!this.portal || this.portal.templateRef !== this.dropdown.templateRef) {
1009
+ this.portal = new TemplatePortal(this.dropdown.templateRef, this.viewContainerRef);
1010
+ }
1011
+ return this.portal;
1012
+ }
1013
+ getWidth() {
1014
+ const nativeElement = this.elementRef.nativeElement;
1015
+ const { width, borderRightWidth, borderLeftWidth } = window.getComputedStyle(nativeElement);
1016
+ return `${parseInt(width) - parseInt(borderRightWidth) - parseInt(borderLeftWidth)}px`;
1017
+ }
1018
+ }
1019
+ /** @nocollapse */ /** @nocollapse */ McDropdownTrigger.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.7", ngImport: i0, type: McDropdownTrigger, deps: [{ token: i1$1.Overlay }, { token: i0.ElementRef }, { token: i0.ViewContainerRef }, { token: MC_DROPDOWN_SCROLL_STRATEGY }, { token: McDropdown, optional: true }, { token: McDropdownItem, optional: true, self: true }, { token: i4.Directionality, optional: true }, { token: i0.ChangeDetectorRef }, { token: i1.FocusMonitor }], target: i0.ɵɵFactoryTarget.Directive });
1020
+ /** @nocollapse */ /** @nocollapse */ McDropdownTrigger.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.7", type: McDropdownTrigger, selector: "[mcDropdownTriggerFor]", inputs: { data: ["mcDropdownTriggerData", "data"], openByArrowDown: "openByArrowDown", restoreFocus: ["mcDropdownTriggerRestoreFocus", "restoreFocus"], dropdown: ["mcDropdownTriggerFor", "dropdown"] }, outputs: { dropdownOpened: "dropdownOpened", dropdownClosed: "dropdownClosed" }, host: { listeners: { "mousedown": "handleMousedown($event)", "keydown": "handleKeydown($event)", "click": "handleClick($event)" }, properties: { "class.mc-pressed": "opened" }, classAttribute: "mc-dropdown-trigger" }, exportAs: ["mcDropdownTrigger"], ngImport: i0 });
1021
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.7", ngImport: i0, type: McDropdownTrigger, decorators: [{
1022
+ type: Directive,
1023
+ args: [{
1024
+ selector: `[mcDropdownTriggerFor]`,
1025
+ exportAs: 'mcDropdownTrigger',
1026
+ host: {
1027
+ class: 'mc-dropdown-trigger',
1028
+ '[class.mc-pressed]': 'opened',
1029
+ '(mousedown)': 'handleMousedown($event)',
1030
+ '(keydown)': 'handleKeydown($event)',
1031
+ '(click)': 'handleClick($event)'
1032
+ }
1033
+ }]
1034
+ }], ctorParameters: function () {
1035
+ return [{ type: i1$1.Overlay }, { type: i0.ElementRef }, { type: i0.ViewContainerRef }, { type: undefined, decorators: [{
1036
+ type: Inject,
1037
+ args: [MC_DROPDOWN_SCROLL_STRATEGY]
1038
+ }] }, { type: McDropdown, decorators: [{
1039
+ type: Optional
1040
+ }] }, { type: McDropdownItem, decorators: [{
1041
+ type: Optional
1042
+ }, {
1043
+ type: Self
1044
+ }] }, { type: i4.Directionality, decorators: [{
1045
+ type: Optional
1046
+ }] }, { type: i0.ChangeDetectorRef }, { type: i1.FocusMonitor }];
1047
+ }, propDecorators: { data: [{
1048
+ type: Input,
1049
+ args: ['mcDropdownTriggerData']
1050
+ }], openByArrowDown: [{
1051
+ type: Input
1052
+ }], restoreFocus: [{
1053
+ type: Input,
1054
+ args: ['mcDropdownTriggerRestoreFocus']
1055
+ }], dropdown: [{
1056
+ type: Input,
1057
+ args: ['mcDropdownTriggerFor']
1058
+ }], dropdownOpened: [{
1059
+ type: Output
1060
+ }], dropdownClosed: [{
1061
+ type: Output
1058
1062
  }] } });
1059
1063
 
1060
- class McDropdownModule {
1061
- }
1062
- /** @nocollapse */ /** @nocollapse */ McDropdownModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: McDropdownModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
1063
- /** @nocollapse */ /** @nocollapse */ McDropdownModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: McDropdownModule, declarations: [McDropdown,
1064
- McDropdownItem,
1065
- McDropdownTrigger,
1066
- McDropdownContent], imports: [CommonModule,
1067
- OverlayModule,
1068
- McIconModule], exports: [McDropdown,
1069
- McDropdownItem,
1070
- McDropdownTrigger,
1071
- McDropdownContent] });
1072
- /** @nocollapse */ /** @nocollapse */ McDropdownModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: McDropdownModule, providers: [MC_DROPDOWN_SCROLL_STRATEGY_FACTORY_PROVIDER], imports: [[
1073
- CommonModule,
1074
- OverlayModule,
1075
- McIconModule
1076
- ]] });
1077
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: McDropdownModule, decorators: [{
1078
- type: NgModule,
1079
- args: [{
1080
- imports: [
1081
- CommonModule,
1082
- OverlayModule,
1083
- McIconModule
1084
- ],
1085
- exports: [
1086
- McDropdown,
1087
- McDropdownItem,
1088
- McDropdownTrigger,
1089
- McDropdownContent
1090
- ],
1091
- declarations: [
1092
- McDropdown,
1093
- McDropdownItem,
1094
- McDropdownTrigger,
1095
- McDropdownContent
1096
- ],
1097
- providers: [MC_DROPDOWN_SCROLL_STRATEGY_FACTORY_PROVIDER]
1098
- }]
1064
+ class McDropdownModule {
1065
+ }
1066
+ /** @nocollapse */ /** @nocollapse */ McDropdownModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.7", ngImport: i0, type: McDropdownModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
1067
+ /** @nocollapse */ /** @nocollapse */ McDropdownModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.3.7", ngImport: i0, type: McDropdownModule, declarations: [McDropdown,
1068
+ McDropdownItem,
1069
+ McDropdownTrigger,
1070
+ McDropdownContent], imports: [CommonModule,
1071
+ OverlayModule,
1072
+ McIconModule], exports: [McDropdown,
1073
+ McDropdownItem,
1074
+ McDropdownTrigger,
1075
+ McDropdownContent] });
1076
+ /** @nocollapse */ /** @nocollapse */ McDropdownModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.3.7", ngImport: i0, type: McDropdownModule, providers: [MC_DROPDOWN_SCROLL_STRATEGY_FACTORY_PROVIDER], imports: [[
1077
+ CommonModule,
1078
+ OverlayModule,
1079
+ McIconModule
1080
+ ]] });
1081
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.7", ngImport: i0, type: McDropdownModule, decorators: [{
1082
+ type: NgModule,
1083
+ args: [{
1084
+ imports: [
1085
+ CommonModule,
1086
+ OverlayModule,
1087
+ McIconModule
1088
+ ],
1089
+ exports: [
1090
+ McDropdown,
1091
+ McDropdownItem,
1092
+ McDropdownTrigger,
1093
+ McDropdownContent
1094
+ ],
1095
+ declarations: [
1096
+ McDropdown,
1097
+ McDropdownItem,
1098
+ McDropdownTrigger,
1099
+ McDropdownContent
1100
+ ],
1101
+ providers: [MC_DROPDOWN_SCROLL_STRATEGY_FACTORY_PROVIDER]
1102
+ }]
1099
1103
  }] });
1100
1104
 
1101
- /**
1102
- * Generated bundle index. Do not edit.
1105
+ /**
1106
+ * Generated bundle index. Do not edit.
1103
1107
  */
1104
1108
 
1105
1109
  export { MC_DROPDOWN_DEFAULT_OPTIONS, MC_DROPDOWN_DEFAULT_OPTIONS_FACTORY, MC_DROPDOWN_PANEL, MC_DROPDOWN_SCROLL_STRATEGY, MC_DROPDOWN_SCROLL_STRATEGY_FACTORY, MC_DROPDOWN_SCROLL_STRATEGY_FACTORY_PROVIDER, McDropdown, McDropdownContent, McDropdownItem, McDropdownModule, McDropdownTrigger, NESTED_PANEL_LEFT_PADDING, NESTED_PANEL_TOP_PADDING, fadeInItems, mcDropdownAnimations, throwMcDropdownInvalidPositionX, throwMcDropdownInvalidPositionY, throwMcDropdownMissingError, transformDropdown };