@ptsecurity/mosaic 13.6.1 → 13.7.2

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