@ptsecurity/mosaic 13.6.0 → 13.7.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (906) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +6 -6
  3. package/_theming.scss +7238 -7128
  4. package/_visual.scss +2724 -2694
  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 -44
  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 -118
  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 -7843
  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 -44
  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 -120
  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 -9175
  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/filters/color.js +7 -7
  202. package/design-tokens/style-dictionary/filters/palette.js +7 -7
  203. package/design-tokens/style-dictionary/filters/size.js +7 -7
  204. package/design-tokens/style-dictionary/filters/typography.js +7 -7
  205. package/design-tokens/style-dictionary/formats/figma.js +104 -0
  206. package/design-tokens/style-dictionary/formats/palette.js +25 -25
  207. package/design-tokens/style-dictionary/formats/typography.js +52 -52
  208. package/design-tokens/style-dictionary/transformGroups/css.js +13 -13
  209. package/design-tokens/style-dictionary/transformGroups/figma.js +21 -0
  210. package/design-tokens/style-dictionary/transformGroups/scss.js +12 -12
  211. package/design-tokens/style-dictionary/transformGroups/ts.js +11 -11
  212. package/design-tokens/style-dictionary/transforms/attribute/figma-border.js +18 -0
  213. package/design-tokens/style-dictionary/transforms/attribute/figma-color.js +25 -0
  214. package/design-tokens/style-dictionary/transforms/attribute/figma-default.js +10 -0
  215. package/design-tokens/style-dictionary/transforms/attribute/figma-font.js +31 -0
  216. package/design-tokens/style-dictionary/transforms/attribute/figma-group.js +17 -0
  217. package/design-tokens/style-dictionary/transforms/attribute/figma-opacity.js +10 -0
  218. package/design-tokens/style-dictionary/transforms/attribute/figma-shadow.js +66 -0
  219. package/design-tokens/style-dictionary/transforms/attribute/figma-sizing.js +16 -0
  220. package/design-tokens/style-dictionary/transforms/attribute/figma-spacing.js +15 -0
  221. package/design-tokens/style-dictionary/transforms/attribute/figma-typography.js +24 -0
  222. package/design-tokens/style-dictionary/transforms/attribute/palette.js +9 -9
  223. package/design-tokens/style-dictionary/transforms/attribute/prefix.js +11 -11
  224. package/design-tokens/style-dictionary/transforms/attribute/size.js +8 -8
  225. package/design-tokens/style-dictionary/transforms/attribute/typography.js +9 -9
  226. package/design-tokens/style-dictionary/transforms/value/figma-values.js +7 -0
  227. package/divider/divider.component.d.ts +11 -11
  228. package/divider/divider.module.d.ts +8 -8
  229. package/divider/index.d.ts +1 -1
  230. package/divider/ptsecurity-mosaic-divider.d.ts +5 -5
  231. package/divider/public-api.d.ts +2 -2
  232. package/dl/dl.component.d.ts +26 -26
  233. package/dl/dl.module.d.ts +10 -10
  234. package/dl/index.d.ts +1 -1
  235. package/dl/ptsecurity-mosaic-dl.d.ts +5 -5
  236. package/dl/public-api.d.ts +2 -2
  237. package/dropdown/dropdown-animations.d.ts +11 -11
  238. package/dropdown/dropdown-content.directive.d.ts +32 -32
  239. package/dropdown/dropdown-errors.d.ts +17 -17
  240. package/dropdown/dropdown-item.component.d.ts +50 -50
  241. package/dropdown/dropdown-trigger.directive.d.ts +136 -136
  242. package/dropdown/dropdown.component.d.ts +121 -121
  243. package/dropdown/dropdown.module.d.ts +13 -13
  244. package/dropdown/dropdown.types.d.ts +53 -53
  245. package/dropdown/index.d.ts +1 -1
  246. package/dropdown/ptsecurity-mosaic-dropdown.d.ts +5 -5
  247. package/dropdown/public-api.d.ts +8 -8
  248. package/esm2020/autocomplete/autocomplete-origin.directive.mjs +21 -21
  249. package/esm2020/autocomplete/autocomplete-trigger.directive.mjs +555 -555
  250. package/esm2020/autocomplete/autocomplete.component.mjs +154 -154
  251. package/esm2020/autocomplete/autocomplete.module.mjs +34 -34
  252. package/esm2020/autocomplete/index.mjs +2 -2
  253. package/esm2020/autocomplete/ptsecurity-mosaic-autocomplete.mjs +4 -4
  254. package/esm2020/autocomplete/public-api.mjs +5 -5
  255. package/esm2020/button/button.component.mjs +137 -137
  256. package/esm2020/button/button.module.mjs +38 -38
  257. package/esm2020/button/index.mjs +2 -2
  258. package/esm2020/button/ptsecurity-mosaic-button.mjs +4 -4
  259. package/esm2020/button/public-api.mjs +3 -3
  260. package/esm2020/button-toggle/button-toggle.component.mjs +362 -362
  261. package/esm2020/button-toggle/button-toggle.module.mjs +19 -19
  262. package/esm2020/button-toggle/index.mjs +2 -2
  263. package/esm2020/button-toggle/ptsecurity-mosaic-button-toggle.mjs +4 -4
  264. package/esm2020/button-toggle/public-api.mjs +3 -3
  265. package/esm2020/card/card.component.mjs +80 -80
  266. package/esm2020/card/card.module.mjs +30 -30
  267. package/esm2020/card/index.mjs +2 -2
  268. package/esm2020/card/ptsecurity-mosaic-card.mjs +4 -4
  269. package/esm2020/card/public-api.mjs +3 -3
  270. package/esm2020/checkbox/checkbox-config.mjs +6 -6
  271. package/esm2020/checkbox/checkbox-module.mjs +19 -19
  272. package/esm2020/checkbox/checkbox-required-validator.mjs +27 -27
  273. package/esm2020/checkbox/checkbox.mjs +316 -316
  274. package/esm2020/checkbox/index.mjs +2 -2
  275. package/esm2020/checkbox/ptsecurity-mosaic-checkbox.mjs +4 -4
  276. package/esm2020/checkbox/public-api.mjs +5 -5
  277. package/esm2020/core/animation/animation.mjs +8 -8
  278. package/esm2020/core/animation/fade-animations.mjs +9 -9
  279. package/esm2020/core/animation/index.mjs +4 -4
  280. package/esm2020/core/animation/select-animations.mjs +45 -45
  281. package/esm2020/core/common-behaviors/color.mjs +30 -30
  282. package/esm2020/core/common-behaviors/common-module.mjs +83 -83
  283. package/esm2020/core/common-behaviors/constructor.mjs +2 -2
  284. package/esm2020/core/common-behaviors/disabled.mjs +17 -17
  285. package/esm2020/core/common-behaviors/error-state.mjs +31 -31
  286. package/esm2020/core/common-behaviors/index.mjs +6 -6
  287. package/esm2020/core/common-behaviors/tabindex.mjs +18 -18
  288. package/esm2020/core/error/error-options.mjs +26 -26
  289. package/esm2020/core/formatters/date/formatter.mjs +359 -359
  290. package/esm2020/core/formatters/date/templates/en-US.mjs +281 -281
  291. package/esm2020/core/formatters/date/templates/ru-RU.mjs +281 -281
  292. package/esm2020/core/formatters/index.mjs +20 -20
  293. package/esm2020/core/formatters/number/formatter.mjs +105 -105
  294. package/esm2020/core/forms/forms-module.mjs +24 -24
  295. package/esm2020/core/forms/forms.directive.mjs +66 -66
  296. package/esm2020/core/forms/index.mjs +3 -3
  297. package/esm2020/core/highlight/highlight.pipe.mjs +17 -17
  298. package/esm2020/core/highlight/index.mjs +19 -19
  299. package/esm2020/core/index.mjs +2 -2
  300. package/esm2020/core/label/label-options.mjs +4 -4
  301. package/esm2020/core/line/line.mjs +70 -70
  302. package/esm2020/core/option/action.mjs +121 -121
  303. package/esm2020/core/option/index.mjs +5 -5
  304. package/esm2020/core/option/optgroup.mjs +31 -31
  305. package/esm2020/core/option/option-module.mjs +21 -21
  306. package/esm2020/core/option/option.mjs +257 -257
  307. package/esm2020/core/overlay/overlay-position-map.mjs +244 -244
  308. package/esm2020/core/pop-up/constants.mjs +34 -34
  309. package/esm2020/core/pop-up/index.mjs +4 -4
  310. package/esm2020/core/pop-up/pop-up-trigger.mjs +239 -239
  311. package/esm2020/core/pop-up/pop-up.mjs +94 -94
  312. package/esm2020/core/ptsecurity-mosaic-core.mjs +4 -4
  313. package/esm2020/core/public-api.mjs +18 -18
  314. package/esm2020/core/select/constants.mjs +27 -27
  315. package/esm2020/core/select/errors.mjs +26 -26
  316. package/esm2020/core/select/events.mjs +2 -2
  317. package/esm2020/core/select/index.mjs +4 -4
  318. package/esm2020/core/selection/constants.mjs +6 -6
  319. package/esm2020/core/selection/index.mjs +4 -4
  320. package/esm2020/core/selection/pseudo-checkbox/pseudo-checkbox.mjs +49 -49
  321. package/esm2020/core/selection/pseudo-checkbox/pseudo-checkbox.module.mjs +18 -18
  322. package/esm2020/core/services/measure-scrollbar.service.mjs +48 -48
  323. package/esm2020/core/utils/index.mjs +2 -2
  324. package/esm2020/core/utils/public-api.mjs +2 -2
  325. package/esm2020/core/utils/utils.mjs +5 -5
  326. package/esm2020/core/validation/index.mjs +2 -2
  327. package/esm2020/core/validation/validation.mjs +118 -118
  328. package/esm2020/core/version.mjs +3 -3
  329. package/esm2020/datepicker/calendar-body.component.mjs +106 -106
  330. package/esm2020/datepicker/calendar.component.mjs +362 -362
  331. package/esm2020/datepicker/datepicker-animations.mjs +32 -32
  332. package/esm2020/datepicker/datepicker-errors.mjs +6 -6
  333. package/esm2020/datepicker/datepicker-input.directive.mjs +938 -936
  334. package/esm2020/datepicker/datepicker-intl.mjs +40 -40
  335. package/esm2020/datepicker/datepicker-module.mjs +107 -107
  336. package/esm2020/datepicker/datepicker-toggle.component.mjs +86 -86
  337. package/esm2020/datepicker/datepicker.component.mjs +404 -408
  338. package/esm2020/datepicker/index.mjs +2 -2
  339. package/esm2020/datepicker/month-view.component.mjs +257 -257
  340. package/esm2020/datepicker/multi-year-view.component.mjs +218 -218
  341. package/esm2020/datepicker/ptsecurity-mosaic-datepicker.mjs +4 -4
  342. package/esm2020/datepicker/public-api.mjs +12 -12
  343. package/esm2020/datepicker/year-view.component.mjs +253 -253
  344. package/esm2020/design-tokens/index.mjs +2 -2
  345. package/esm2020/design-tokens/legacy-2017/tokens.mjs +1167 -1137
  346. package/esm2020/design-tokens/pt-2022/tokens.mjs +1237 -1207
  347. package/esm2020/design-tokens/ptsecurity-mosaic-design-tokens.mjs +4 -4
  348. package/esm2020/design-tokens/public-api.mjs +4 -4
  349. package/esm2020/divider/divider.component.mjs +39 -39
  350. package/esm2020/divider/divider.module.mjs +18 -18
  351. package/esm2020/divider/index.mjs +2 -2
  352. package/esm2020/divider/ptsecurity-mosaic-divider.mjs +4 -4
  353. package/esm2020/divider/public-api.mjs +3 -3
  354. package/esm2020/dl/dl.component.mjs +78 -78
  355. package/esm2020/dl/dl.module.mjs +42 -42
  356. package/esm2020/dl/index.mjs +2 -2
  357. package/esm2020/dl/ptsecurity-mosaic-dl.mjs +4 -4
  358. package/esm2020/dl/public-api.mjs +3 -3
  359. package/esm2020/dropdown/dropdown-animations.mjs +41 -41
  360. package/esm2020/dropdown/dropdown-content.directive.mjs +64 -64
  361. package/esm2020/dropdown/dropdown-errors.mjs +29 -29
  362. package/esm2020/dropdown/dropdown-item.component.mjs +139 -139
  363. package/esm2020/dropdown/dropdown-trigger.directive.mjs +489 -489
  364. package/esm2020/dropdown/dropdown.component.mjs +292 -292
  365. package/esm2020/dropdown/dropdown.module.mjs +50 -50
  366. package/esm2020/dropdown/dropdown.types.mjs +24 -24
  367. package/esm2020/dropdown/index.mjs +2 -2
  368. package/esm2020/dropdown/ptsecurity-mosaic-dropdown.mjs +4 -4
  369. package/esm2020/dropdown/public-api.mjs +9 -9
  370. package/esm2020/form-field/cleaner.mjs +23 -23
  371. package/esm2020/form-field/form-field-control.mjs +5 -5
  372. package/esm2020/form-field/form-field-errors.mjs +7 -7
  373. package/esm2020/form-field/form-field.mjs +225 -225
  374. package/esm2020/form-field/form-field.module.mjs +57 -57
  375. package/esm2020/form-field/hint.mjs +34 -23
  376. package/esm2020/form-field/index.mjs +2 -2
  377. package/esm2020/form-field/password-hint.mjs +139 -139
  378. package/esm2020/form-field/prefix.mjs +13 -13
  379. package/esm2020/form-field/ptsecurity-mosaic-form-field.mjs +4 -4
  380. package/esm2020/form-field/public-api.mjs +11 -11
  381. package/esm2020/form-field/stepper.mjs +55 -55
  382. package/esm2020/form-field/suffix.mjs +13 -13
  383. package/esm2020/icon/icon.component.mjs +44 -44
  384. package/esm2020/icon/icon.module.mjs +38 -38
  385. package/esm2020/icon/index.mjs +2 -2
  386. package/esm2020/icon/ptsecurity-mosaic-icon.mjs +4 -4
  387. package/esm2020/icon/public-api.mjs +3 -3
  388. package/esm2020/index.mjs +2 -2
  389. package/esm2020/input/index.mjs +2 -2
  390. package/esm2020/input/input-errors.mjs +4 -4
  391. package/esm2020/input/input-number-validators.mjs +92 -92
  392. package/esm2020/input/input-number.mjs +163 -163
  393. package/esm2020/input/input-password.mjs +372 -372
  394. package/esm2020/input/input-value-accessor.mjs +3 -3
  395. package/esm2020/input/input.mjs +334 -334
  396. package/esm2020/input/input.module.mjs +65 -65
  397. package/esm2020/input/ptsecurity-mosaic-input.mjs +4 -4
  398. package/esm2020/input/public-api.mjs +7 -7
  399. package/esm2020/link/index.mjs +2 -2
  400. package/esm2020/link/link.component.mjs +107 -107
  401. package/esm2020/link/link.module.mjs +26 -26
  402. package/esm2020/link/ptsecurity-mosaic-link.mjs +4 -4
  403. package/esm2020/link/public-api.mjs +3 -3
  404. package/esm2020/list/index.mjs +2 -2
  405. package/esm2020/list/list-selection.component.mjs +689 -686
  406. package/esm2020/list/list.component.mjs +44 -44
  407. package/esm2020/list/list.module.mjs +55 -55
  408. package/esm2020/list/ptsecurity-mosaic-list.mjs +4 -4
  409. package/esm2020/list/public-api.mjs +4 -4
  410. package/esm2020/loader-overlay/index.mjs +2 -0
  411. package/esm2020/loader-overlay/loader-overlay.component.mjs +99 -0
  412. package/esm2020/loader-overlay/loader-overlay.module.mjs +50 -0
  413. package/esm2020/loader-overlay/ptsecurity-mosaic-loader-overlay.mjs +5 -0
  414. package/esm2020/loader-overlay/public-api.mjs +3 -0
  415. package/esm2020/modal/css-unit.pipe.mjs +17 -17
  416. package/esm2020/modal/index.mjs +2 -2
  417. package/esm2020/modal/modal-control.service.mjs +85 -85
  418. package/esm2020/modal/modal-ref.class.mjs +8 -8
  419. package/esm2020/modal/modal-util.mjs +17 -17
  420. package/esm2020/modal/modal.component.mjs +509 -501
  421. package/esm2020/modal/modal.directive.mjs +52 -52
  422. package/esm2020/modal/modal.module.mjs +72 -72
  423. package/esm2020/modal/modal.service.mjs +124 -124
  424. package/esm2020/modal/modal.type.mjs +7 -7
  425. package/esm2020/modal/ptsecurity-mosaic-modal.mjs +4 -4
  426. package/esm2020/modal/public-api.mjs +7 -7
  427. package/esm2020/navbar/index.mjs +2 -2
  428. package/esm2020/navbar/navbar-item.component.mjs +582 -582
  429. package/esm2020/navbar/navbar.component.mjs +239 -237
  430. package/esm2020/navbar/navbar.module.mjs +92 -92
  431. package/esm2020/navbar/ptsecurity-mosaic-navbar.mjs +4 -4
  432. package/esm2020/navbar/public-api.mjs +5 -5
  433. package/esm2020/navbar/vertical-navbar.animation.mjs +10 -10
  434. package/esm2020/navbar/vertical-navbar.component.mjs +114 -114
  435. package/esm2020/popover/index.mjs +2 -2
  436. package/esm2020/popover/popover-animations.mjs +16 -16
  437. package/esm2020/popover/popover-confirm.component.mjs +108 -108
  438. package/esm2020/popover/popover.component.mjs +253 -253
  439. package/esm2020/popover/popover.module.mjs +24 -24
  440. package/esm2020/popover/ptsecurity-mosaic-popover.mjs +4 -4
  441. package/esm2020/popover/public-api.mjs +5 -5
  442. package/esm2020/progress-bar/index.mjs +2 -2
  443. package/esm2020/progress-bar/progress-bar.component.mjs +42 -42
  444. package/esm2020/progress-bar/progress-bar.module.mjs +30 -30
  445. package/esm2020/progress-bar/ptsecurity-mosaic-progress-bar.mjs +4 -4
  446. package/esm2020/progress-bar/public-api.mjs +3 -3
  447. package/esm2020/progress-spinner/index.mjs +2 -2
  448. package/esm2020/progress-spinner/progress-spinner.component.mjs +46 -46
  449. package/esm2020/progress-spinner/progress-spinner.module.mjs +30 -30
  450. package/esm2020/progress-spinner/ptsecurity-mosaic-progress-spinner.mjs +4 -4
  451. package/esm2020/progress-spinner/public-api.mjs +3 -3
  452. package/esm2020/ptsecurity-mosaic.mjs +4 -4
  453. package/esm2020/public-api.mjs +2 -2
  454. package/esm2020/radio/index.mjs +2 -2
  455. package/esm2020/radio/ptsecurity-mosaic-radio.mjs +4 -4
  456. package/esm2020/radio/public-api.mjs +3 -3
  457. package/esm2020/radio/radio.component.mjs +458 -458
  458. package/esm2020/radio/radio.module.mjs +20 -20
  459. package/esm2020/select/index.mjs +2 -2
  460. package/esm2020/select/ptsecurity-mosaic-select.mjs +4 -4
  461. package/esm2020/select/public-api.mjs +4 -4
  462. package/esm2020/select/select-option.directive.mjs +65 -65
  463. package/esm2020/select/select.component.mjs +1117 -1107
  464. package/esm2020/select/select.module.mjs +73 -73
  465. package/esm2020/sidebar/index.mjs +2 -2
  466. package/esm2020/sidebar/ptsecurity-mosaic-sidebar.mjs +4 -4
  467. package/esm2020/sidebar/public-api.mjs +3 -3
  468. package/esm2020/sidebar/sidebar-animations.mjs +23 -23
  469. package/esm2020/sidebar/sidebar.component.mjs +146 -146
  470. package/esm2020/sidebar/sidebar.module.mjs +30 -30
  471. package/esm2020/sidepanel/index.mjs +2 -2
  472. package/esm2020/sidepanel/ptsecurity-mosaic-sidepanel.mjs +4 -4
  473. package/esm2020/sidepanel/public-api.mjs +7 -7
  474. package/esm2020/sidepanel/sidepanel-animations.mjs +26 -26
  475. package/esm2020/sidepanel/sidepanel-config.mjs +26 -26
  476. package/esm2020/sidepanel/sidepanel-container.component.mjs +106 -106
  477. package/esm2020/sidepanel/sidepanel-directives.mjs +159 -159
  478. package/esm2020/sidepanel/sidepanel-ref.mjs +53 -53
  479. package/esm2020/sidepanel/sidepanel.module.mjs +74 -74
  480. package/esm2020/sidepanel/sidepanel.service.mjs +167 -167
  481. package/esm2020/splitter/index.mjs +2 -2
  482. package/esm2020/splitter/ptsecurity-mosaic-splitter.mjs +4 -4
  483. package/esm2020/splitter/public-api.mjs +3 -3
  484. package/esm2020/splitter/splitter.component.mjs +482 -482
  485. package/esm2020/splitter/splitter.module.mjs +40 -40
  486. package/esm2020/table/index.mjs +2 -2
  487. package/esm2020/table/ptsecurity-mosaic-table.mjs +4 -4
  488. package/esm2020/table/public-api.mjs +3 -3
  489. package/esm2020/table/table.component.mjs +16 -16
  490. package/esm2020/table/table.module.mjs +30 -30
  491. package/esm2020/tabs/index.mjs +2 -2
  492. package/esm2020/tabs/paginated-tab-header.mjs +479 -479
  493. package/esm2020/tabs/ptsecurity-mosaic-tabs.mjs +4 -4
  494. package/esm2020/tabs/public-api.mjs +11 -11
  495. package/esm2020/tabs/tab-body.component.mjs +178 -178
  496. package/esm2020/tabs/tab-content.directive.mjs +15 -15
  497. package/esm2020/tabs/tab-group.component.mjs +350 -350
  498. package/esm2020/tabs/tab-header.component.mjs +67 -67
  499. package/esm2020/tabs/tab-label-wrapper.directive.mjs +78 -78
  500. package/esm2020/tabs/tab-label.directive.mjs +17 -17
  501. package/esm2020/tabs/tab-nav-bar/index.mjs +2 -2
  502. package/esm2020/tabs/tab-nav-bar/tab-nav-bar.mjs +110 -110
  503. package/esm2020/tabs/tab.component.mjs +133 -133
  504. package/esm2020/tabs/tabs-animations.mjs +24 -24
  505. package/esm2020/tabs/tabs.module.mjs +104 -104
  506. package/esm2020/tags/index.mjs +2 -2
  507. package/esm2020/tags/ptsecurity-mosaic-tags.mjs +4 -4
  508. package/esm2020/tags/public-api.mjs +6 -6
  509. package/esm2020/tags/tag-default-options.mjs +4 -4
  510. package/esm2020/tags/tag-input.mjs +229 -229
  511. package/esm2020/tags/tag-list.component.mjs +722 -722
  512. package/esm2020/tags/tag-text-control.mjs +2 -2
  513. package/esm2020/tags/tag.component.mjs +375 -375
  514. package/esm2020/tags/tag.module.mjs +56 -56
  515. package/esm2020/textarea/index.mjs +2 -2
  516. package/esm2020/textarea/ptsecurity-mosaic-textarea.mjs +4 -4
  517. package/esm2020/textarea/public-api.mjs +3 -3
  518. package/esm2020/textarea/textarea.component.mjs +269 -269
  519. package/esm2020/textarea/textarea.module.mjs +21 -21
  520. package/esm2020/timepicker/index.mjs +2 -2
  521. package/esm2020/timepicker/ptsecurity-mosaic-timepicker.mjs +4 -4
  522. package/esm2020/timepicker/public-api.mjs +4 -4
  523. package/esm2020/timepicker/timepicker.constants.mjs +25 -25
  524. package/esm2020/timepicker/timepicker.directive.mjs +665 -676
  525. package/esm2020/timepicker/timepicker.module.mjs +34 -34
  526. package/esm2020/toggle/index.mjs +2 -2
  527. package/esm2020/toggle/ptsecurity-mosaic-toggle.mjs +4 -4
  528. package/esm2020/toggle/public-api.mjs +3 -3
  529. package/esm2020/toggle/toggle.component.mjs +158 -158
  530. package/esm2020/toggle/toggle.module.mjs +20 -20
  531. package/esm2020/tooltip/index.mjs +2 -2
  532. package/esm2020/tooltip/ptsecurity-mosaic-tooltip.mjs +4 -4
  533. package/esm2020/tooltip/public-api.mjs +3 -3
  534. package/esm2020/tooltip/tooltip.animations.mjs +19 -19
  535. package/esm2020/tooltip/tooltip.component.mjs +295 -295
  536. package/esm2020/tooltip/tooltip.module.mjs +43 -43
  537. package/esm2020/tree/control/base-tree-control.mjs +60 -60
  538. package/esm2020/tree/control/flat-tree-control.mjs +126 -126
  539. package/esm2020/tree/control/nested-tree-control.mjs +41 -41
  540. package/esm2020/tree/control/tree-control.mjs +2 -2
  541. package/esm2020/tree/data-source/flat-data-source.mjs +162 -162
  542. package/esm2020/tree/data-source/nested-data-source.mjs +30 -30
  543. package/esm2020/tree/index.mjs +2 -2
  544. package/esm2020/tree/node.mjs +31 -31
  545. package/esm2020/tree/outlet.mjs +15 -15
  546. package/esm2020/tree/padding.directive.mjs +113 -110
  547. package/esm2020/tree/ptsecurity-mosaic-tree.mjs +4 -4
  548. package/esm2020/tree/public-api.mjs +16 -16
  549. package/esm2020/tree/toggle.mjs +80 -80
  550. package/esm2020/tree/tree-base.mjs +243 -243
  551. package/esm2020/tree/tree-errors.mjs +36 -36
  552. package/esm2020/tree/tree-option.component.mjs +248 -236
  553. package/esm2020/tree/tree-selection.component.mjs +541 -540
  554. package/esm2020/tree/tree.mjs +15 -15
  555. package/esm2020/tree/tree.module.mjs +57 -57
  556. package/esm2020/tree-select/index.mjs +2 -2
  557. package/esm2020/tree-select/ptsecurity-mosaic-tree-select.mjs +4 -4
  558. package/esm2020/tree-select/public-api.mjs +3 -3
  559. package/esm2020/tree-select/tree-select.component.mjs +939 -929
  560. package/esm2020/tree-select/tree-select.module.mjs +47 -47
  561. package/fesm2015/ptsecurity-mosaic-autocomplete.mjs +726 -726
  562. package/fesm2015/ptsecurity-mosaic-autocomplete.mjs.map +1 -1
  563. package/fesm2015/ptsecurity-mosaic-button-toggle.mjs +367 -367
  564. package/fesm2015/ptsecurity-mosaic-button-toggle.mjs.map +1 -1
  565. package/fesm2015/ptsecurity-mosaic-button.mjs +160 -160
  566. package/fesm2015/ptsecurity-mosaic-button.mjs.map +1 -1
  567. package/fesm2015/ptsecurity-mosaic-card.mjs +96 -96
  568. package/fesm2015/ptsecurity-mosaic-card.mjs.map +1 -1
  569. package/fesm2015/ptsecurity-mosaic-checkbox.mjs +348 -348
  570. package/fesm2015/ptsecurity-mosaic-checkbox.mjs.map +1 -1
  571. package/fesm2015/ptsecurity-mosaic-core.mjs +2652 -2652
  572. package/fesm2015/ptsecurity-mosaic-core.mjs.map +1 -1
  573. package/fesm2015/ptsecurity-mosaic-datepicker.mjs +2682 -2684
  574. package/fesm2015/ptsecurity-mosaic-datepicker.mjs.map +1 -1
  575. package/fesm2015/ptsecurity-mosaic-design-tokens.mjs +2433 -2343
  576. package/fesm2015/ptsecurity-mosaic-design-tokens.mjs.map +1 -1
  577. package/fesm2015/ptsecurity-mosaic-divider.mjs +48 -48
  578. package/fesm2015/ptsecurity-mosaic-divider.mjs.map +1 -1
  579. package/fesm2015/ptsecurity-mosaic-dl.mjs +108 -108
  580. package/fesm2015/ptsecurity-mosaic-dl.mjs.map +1 -1
  581. package/fesm2015/ptsecurity-mosaic-dropdown.mjs +1069 -1069
  582. package/fesm2015/ptsecurity-mosaic-dropdown.mjs.map +1 -1
  583. package/fesm2015/ptsecurity-mosaic-form-field.mjs +522 -512
  584. package/fesm2015/ptsecurity-mosaic-form-field.mjs.map +1 -1
  585. package/fesm2015/ptsecurity-mosaic-icon.mjs +73 -73
  586. package/fesm2015/ptsecurity-mosaic-icon.mjs.map +1 -1
  587. package/fesm2015/ptsecurity-mosaic-input.mjs +979 -979
  588. package/fesm2015/ptsecurity-mosaic-input.mjs.map +1 -1
  589. package/fesm2015/ptsecurity-mosaic-link.mjs +121 -121
  590. package/fesm2015/ptsecurity-mosaic-link.mjs.map +1 -1
  591. package/fesm2015/ptsecurity-mosaic-list.mjs +765 -762
  592. package/fesm2015/ptsecurity-mosaic-list.mjs.map +1 -1
  593. package/fesm2015/ptsecurity-mosaic-loader-overlay.mjs +155 -0
  594. package/fesm2015/ptsecurity-mosaic-loader-overlay.mjs.map +1 -0
  595. package/fesm2015/ptsecurity-mosaic-modal.mjs +833 -824
  596. package/fesm2015/ptsecurity-mosaic-modal.mjs.map +1 -1
  597. package/fesm2015/ptsecurity-mosaic-navbar.mjs +996 -994
  598. package/fesm2015/ptsecurity-mosaic-navbar.mjs.map +1 -1
  599. package/fesm2015/ptsecurity-mosaic-popover.mjs +364 -364
  600. package/fesm2015/ptsecurity-mosaic-popover.mjs.map +1 -1
  601. package/fesm2015/ptsecurity-mosaic-progress-bar.mjs +61 -61
  602. package/fesm2015/ptsecurity-mosaic-progress-bar.mjs.map +1 -1
  603. package/fesm2015/ptsecurity-mosaic-progress-spinner.mjs +65 -65
  604. package/fesm2015/ptsecurity-mosaic-progress-spinner.mjs.map +1 -1
  605. package/fesm2015/ptsecurity-mosaic-radio.mjs +464 -464
  606. package/fesm2015/ptsecurity-mosaic-radio.mjs.map +1 -1
  607. package/fesm2015/ptsecurity-mosaic-select.mjs +1213 -1203
  608. package/fesm2015/ptsecurity-mosaic-select.mjs.map +1 -1
  609. package/fesm2015/ptsecurity-mosaic-sidebar.mjs +185 -185
  610. package/fesm2015/ptsecurity-mosaic-sidebar.mjs.map +1 -1
  611. package/fesm2015/ptsecurity-mosaic-sidepanel.mjs +555 -555
  612. package/fesm2015/ptsecurity-mosaic-sidepanel.mjs.map +1 -1
  613. package/fesm2015/ptsecurity-mosaic-splitter.mjs +511 -511
  614. package/fesm2015/ptsecurity-mosaic-splitter.mjs.map +1 -1
  615. package/fesm2015/ptsecurity-mosaic-table.mjs +36 -36
  616. package/fesm2015/ptsecurity-mosaic-table.mjs.map +1 -1
  617. package/fesm2015/ptsecurity-mosaic-tabs.mjs +1460 -1460
  618. package/fesm2015/ptsecurity-mosaic-tabs.mjs.map +1 -1
  619. package/fesm2015/ptsecurity-mosaic-tags.mjs +1342 -1342
  620. package/fesm2015/ptsecurity-mosaic-tags.mjs.map +1 -1
  621. package/fesm2015/ptsecurity-mosaic-textarea.mjs +274 -274
  622. package/fesm2015/ptsecurity-mosaic-textarea.mjs.map +1 -1
  623. package/fesm2015/ptsecurity-mosaic-timepicker.mjs +703 -714
  624. package/fesm2015/ptsecurity-mosaic-timepicker.mjs.map +1 -1
  625. package/fesm2015/ptsecurity-mosaic-toggle.mjs +163 -163
  626. package/fesm2015/ptsecurity-mosaic-toggle.mjs.map +1 -1
  627. package/fesm2015/ptsecurity-mosaic-tooltip.mjs +344 -344
  628. package/fesm2015/ptsecurity-mosaic-tooltip.mjs.map +1 -1
  629. package/fesm2015/ptsecurity-mosaic-tree-select.mjs +954 -944
  630. package/fesm2015/ptsecurity-mosaic-tree-select.mjs.map +1 -1
  631. package/fesm2015/ptsecurity-mosaic-tree.mjs +1696 -1682
  632. package/fesm2015/ptsecurity-mosaic-tree.mjs.map +1 -1
  633. package/fesm2015/ptsecurity-mosaic.mjs +2 -2
  634. package/fesm2020/ptsecurity-mosaic-autocomplete.mjs +722 -722
  635. package/fesm2020/ptsecurity-mosaic-autocomplete.mjs.map +1 -1
  636. package/fesm2020/ptsecurity-mosaic-button-toggle.mjs +365 -365
  637. package/fesm2020/ptsecurity-mosaic-button-toggle.mjs.map +1 -1
  638. package/fesm2020/ptsecurity-mosaic-button.mjs +160 -160
  639. package/fesm2020/ptsecurity-mosaic-button.mjs.map +1 -1
  640. package/fesm2020/ptsecurity-mosaic-card.mjs +96 -96
  641. package/fesm2020/ptsecurity-mosaic-card.mjs.map +1 -1
  642. package/fesm2020/ptsecurity-mosaic-checkbox.mjs +346 -346
  643. package/fesm2020/ptsecurity-mosaic-checkbox.mjs.map +1 -1
  644. package/fesm2020/ptsecurity-mosaic-core.mjs +2681 -2681
  645. package/fesm2020/ptsecurity-mosaic-core.mjs.map +1 -1
  646. package/fesm2020/ptsecurity-mosaic-datepicker.mjs +2667 -2669
  647. package/fesm2020/ptsecurity-mosaic-datepicker.mjs.map +1 -1
  648. package/fesm2020/ptsecurity-mosaic-design-tokens.mjs +2433 -2343
  649. package/fesm2020/ptsecurity-mosaic-design-tokens.mjs.map +1 -1
  650. package/fesm2020/ptsecurity-mosaic-divider.mjs +48 -48
  651. package/fesm2020/ptsecurity-mosaic-divider.mjs.map +1 -1
  652. package/fesm2020/ptsecurity-mosaic-dl.mjs +108 -108
  653. package/fesm2020/ptsecurity-mosaic-dl.mjs.map +1 -1
  654. package/fesm2020/ptsecurity-mosaic-dropdown.mjs +1056 -1056
  655. package/fesm2020/ptsecurity-mosaic-dropdown.mjs.map +1 -1
  656. package/fesm2020/ptsecurity-mosaic-form-field.mjs +507 -497
  657. package/fesm2020/ptsecurity-mosaic-form-field.mjs.map +1 -1
  658. package/fesm2020/ptsecurity-mosaic-icon.mjs +71 -71
  659. package/fesm2020/ptsecurity-mosaic-icon.mjs.map +1 -1
  660. package/fesm2020/ptsecurity-mosaic-input.mjs +968 -968
  661. package/fesm2020/ptsecurity-mosaic-input.mjs.map +1 -1
  662. package/fesm2020/ptsecurity-mosaic-link.mjs +120 -120
  663. package/fesm2020/ptsecurity-mosaic-link.mjs.map +1 -1
  664. package/fesm2020/ptsecurity-mosaic-list.mjs +758 -755
  665. package/fesm2020/ptsecurity-mosaic-list.mjs.map +1 -1
  666. package/fesm2020/ptsecurity-mosaic-loader-overlay.mjs +153 -0
  667. package/fesm2020/ptsecurity-mosaic-loader-overlay.mjs.map +1 -0
  668. package/fesm2020/ptsecurity-mosaic-modal.mjs +828 -820
  669. package/fesm2020/ptsecurity-mosaic-modal.mjs.map +1 -1
  670. package/fesm2020/ptsecurity-mosaic-navbar.mjs +980 -978
  671. package/fesm2020/ptsecurity-mosaic-navbar.mjs.map +1 -1
  672. package/fesm2020/ptsecurity-mosaic-popover.mjs +360 -360
  673. package/fesm2020/ptsecurity-mosaic-popover.mjs.map +1 -1
  674. package/fesm2020/ptsecurity-mosaic-progress-bar.mjs +61 -61
  675. package/fesm2020/ptsecurity-mosaic-progress-bar.mjs.map +1 -1
  676. package/fesm2020/ptsecurity-mosaic-progress-spinner.mjs +65 -65
  677. package/fesm2020/ptsecurity-mosaic-progress-spinner.mjs.map +1 -1
  678. package/fesm2020/ptsecurity-mosaic-radio.mjs +462 -462
  679. package/fesm2020/ptsecurity-mosaic-radio.mjs.map +1 -1
  680. package/fesm2020/ptsecurity-mosaic-select.mjs +1208 -1198
  681. package/fesm2020/ptsecurity-mosaic-select.mjs.map +1 -1
  682. package/fesm2020/ptsecurity-mosaic-sidebar.mjs +185 -185
  683. package/fesm2020/ptsecurity-mosaic-sidebar.mjs.map +1 -1
  684. package/fesm2020/ptsecurity-mosaic-sidepanel.mjs +552 -552
  685. package/fesm2020/ptsecurity-mosaic-sidepanel.mjs.map +1 -1
  686. package/fesm2020/ptsecurity-mosaic-splitter.mjs +511 -511
  687. package/fesm2020/ptsecurity-mosaic-splitter.mjs.map +1 -1
  688. package/fesm2020/ptsecurity-mosaic-table.mjs +36 -36
  689. package/fesm2020/ptsecurity-mosaic-table.mjs.map +1 -1
  690. package/fesm2020/ptsecurity-mosaic-tabs.mjs +1445 -1445
  691. package/fesm2020/ptsecurity-mosaic-tabs.mjs.map +1 -1
  692. package/fesm2020/ptsecurity-mosaic-tags.mjs +1335 -1335
  693. package/fesm2020/ptsecurity-mosaic-tags.mjs.map +1 -1
  694. package/fesm2020/ptsecurity-mosaic-textarea.mjs +272 -272
  695. package/fesm2020/ptsecurity-mosaic-textarea.mjs.map +1 -1
  696. package/fesm2020/ptsecurity-mosaic-timepicker.mjs +700 -711
  697. package/fesm2020/ptsecurity-mosaic-timepicker.mjs.map +1 -1
  698. package/fesm2020/ptsecurity-mosaic-toggle.mjs +163 -163
  699. package/fesm2020/ptsecurity-mosaic-toggle.mjs.map +1 -1
  700. package/fesm2020/ptsecurity-mosaic-tooltip.mjs +336 -336
  701. package/fesm2020/ptsecurity-mosaic-tooltip.mjs.map +1 -1
  702. package/fesm2020/ptsecurity-mosaic-tree-select.mjs +951 -941
  703. package/fesm2020/ptsecurity-mosaic-tree-select.mjs.map +1 -1
  704. package/fesm2020/ptsecurity-mosaic-tree.mjs +1683 -1669
  705. package/fesm2020/ptsecurity-mosaic-tree.mjs.map +1 -1
  706. package/fesm2020/ptsecurity-mosaic.mjs +2 -2
  707. package/form-field/cleaner.d.ts +7 -7
  708. package/form-field/form-field-control.d.ts +37 -37
  709. package/form-field/form-field-errors.d.ts +2 -2
  710. package/form-field/form-field.d.ts +69 -69
  711. package/form-field/form-field.module.d.ts +15 -15
  712. package/form-field/hint.d.ts +14 -6
  713. package/form-field/index.d.ts +1 -1
  714. package/form-field/password-hint.d.ts +40 -40
  715. package/form-field/prefix.d.ts +5 -5
  716. package/form-field/ptsecurity-mosaic-form-field.d.ts +5 -5
  717. package/form-field/public-api.d.ts +10 -10
  718. package/form-field/stepper.d.ts +11 -11
  719. package/form-field/suffix.d.ts +5 -5
  720. package/icon/icon.component.d.ts +18 -18
  721. package/icon/icon.module.d.ts +10 -10
  722. package/icon/index.d.ts +1 -1
  723. package/icon/ptsecurity-mosaic-icon.d.ts +5 -5
  724. package/icon/public-api.d.ts +2 -2
  725. package/index.d.ts +1 -1
  726. package/input/index.d.ts +1 -1
  727. package/input/input-errors.d.ts +1 -1
  728. package/input/input-number-validators.d.ts +39 -39
  729. package/input/input-number.d.ts +33 -33
  730. package/input/input-password.d.ts +123 -123
  731. package/input/input-value-accessor.d.ts +4 -4
  732. package/input/input.d.ts +116 -116
  733. package/input/input.module.d.ts +14 -14
  734. package/input/ptsecurity-mosaic-input.d.ts +5 -5
  735. package/input/public-api.d.ts +6 -6
  736. package/link/index.d.ts +1 -1
  737. package/link/link.component.d.ts +38 -38
  738. package/link/link.module.d.ts +9 -9
  739. package/link/ptsecurity-mosaic-link.d.ts +5 -5
  740. package/link/public-api.d.ts +2 -2
  741. package/list/index.d.ts +1 -1
  742. package/list/list-selection.component.d.ts +168 -168
  743. package/list/list.component.d.ts +18 -18
  744. package/list/list.module.d.ts +11 -11
  745. package/list/ptsecurity-mosaic-list.d.ts +5 -5
  746. package/list/public-api.d.ts +3 -3
  747. package/{toggle → loader-overlay}/README.md +0 -0
  748. package/loader-overlay/index.d.ts +1 -0
  749. package/loader-overlay/loader-overlay.component.d.ts +33 -0
  750. package/loader-overlay/loader-overlay.module.d.ts +11 -0
  751. package/loader-overlay/package.json +10 -0
  752. package/loader-overlay/ptsecurity-mosaic-loader-overlay.d.ts +5 -0
  753. package/loader-overlay/public-api.d.ts +2 -0
  754. package/modal/README.md +33 -33
  755. package/modal/css-unit.pipe.d.ts +7 -7
  756. package/modal/index.d.ts +1 -1
  757. package/modal/modal-control.service.d.ts +20 -20
  758. package/modal/modal-ref.class.d.ts +36 -36
  759. package/modal/modal-util.d.ts +12 -12
  760. package/modal/modal.component.d.ts +128 -126
  761. package/modal/modal.directive.d.ts +17 -17
  762. package/modal/modal.module.d.ts +14 -14
  763. package/modal/modal.service.d.ts +33 -33
  764. package/modal/modal.type.d.ts +60 -59
  765. package/modal/ptsecurity-mosaic-modal.d.ts +5 -5
  766. package/modal/public-api.d.ts +6 -6
  767. package/navbar/README.md +41 -41
  768. package/navbar/index.d.ts +1 -1
  769. package/navbar/navbar-item.component.d.ts +161 -161
  770. package/navbar/navbar.component.d.ts +58 -58
  771. package/navbar/navbar.module.d.ts +14 -14
  772. package/navbar/ptsecurity-mosaic-navbar.d.ts +5 -5
  773. package/navbar/public-api.d.ts +4 -4
  774. package/navbar/vertical-navbar.animation.d.ts +2 -2
  775. package/navbar/vertical-navbar.component.d.ts +23 -23
  776. package/package.json +12 -4
  777. package/popover/README.md +32 -32
  778. package/popover/index.d.ts +1 -1
  779. package/popover/popover-animations.d.ts +4 -4
  780. package/popover/popover-confirm.component.d.ts +33 -33
  781. package/popover/popover.component.d.ts +74 -74
  782. package/popover/popover.module.d.ts +12 -12
  783. package/popover/ptsecurity-mosaic-popover.d.ts +5 -5
  784. package/popover/public-api.d.ts +4 -4
  785. package/prebuilt-themes/dark-theme.css +1 -1
  786. package/prebuilt-themes/default-theme.css +1 -1
  787. package/progress-bar/index.d.ts +1 -1
  788. package/progress-bar/progress-bar.component.d.ts +18 -18
  789. package/progress-bar/progress-bar.module.d.ts +9 -9
  790. package/progress-bar/ptsecurity-mosaic-progress-bar.d.ts +5 -5
  791. package/progress-bar/public-api.d.ts +2 -2
  792. package/progress-spinner/index.d.ts +1 -1
  793. package/progress-spinner/progress-spinner.component.d.ts +19 -19
  794. package/progress-spinner/progress-spinner.module.d.ts +9 -9
  795. package/progress-spinner/ptsecurity-mosaic-progress-spinner.d.ts +5 -5
  796. package/progress-spinner/public-api.d.ts +2 -2
  797. package/ptsecurity-mosaic.d.ts +5 -5
  798. package/public-api.d.ts +1 -1
  799. package/radio/index.d.ts +1 -1
  800. package/radio/ptsecurity-mosaic-radio.d.ts +5 -5
  801. package/radio/public-api.d.ts +2 -2
  802. package/radio/radio.component.d.ts +207 -207
  803. package/radio/radio.module.d.ts +10 -10
  804. package/schematics/README.md +35 -35
  805. package/select/index.d.ts +1 -1
  806. package/select/ptsecurity-mosaic-select.d.ts +5 -5
  807. package/select/public-api.d.ts +3 -3
  808. package/select/select-option.directive.d.ts +20 -20
  809. package/select/select.component.d.ts +310 -307
  810. package/select/select.module.d.ts +15 -15
  811. package/sidebar/index.d.ts +1 -1
  812. package/sidebar/ptsecurity-mosaic-sidebar.d.ts +5 -5
  813. package/sidebar/public-api.d.ts +2 -2
  814. package/sidebar/sidebar-animations.d.ts +8 -8
  815. package/sidebar/sidebar.component.d.ts +53 -53
  816. package/sidebar/sidebar.module.d.ts +8 -8
  817. package/sidepanel/index.d.ts +1 -1
  818. package/sidepanel/ptsecurity-mosaic-sidepanel.d.ts +5 -5
  819. package/sidepanel/public-api.d.ts +6 -6
  820. package/sidepanel/sidepanel-animations.d.ts +14 -14
  821. package/sidepanel/sidepanel-config.d.ts +25 -25
  822. package/sidepanel/sidepanel-container.component.d.ts +45 -45
  823. package/sidepanel/sidepanel-directives.d.ts +50 -50
  824. package/sidepanel/sidepanel-ref.d.ts +24 -24
  825. package/sidepanel/sidepanel.module.d.ts +15 -15
  826. package/sidepanel/sidepanel.service.d.ts +57 -57
  827. package/splitter/index.d.ts +1 -1
  828. package/splitter/ptsecurity-mosaic-splitter.d.ts +5 -5
  829. package/splitter/public-api.d.ts +2 -2
  830. package/splitter/splitter.component.d.ts +130 -130
  831. package/splitter/splitter.module.d.ts +9 -9
  832. package/table/index.d.ts +1 -1
  833. package/table/ptsecurity-mosaic-table.d.ts +5 -5
  834. package/table/public-api.d.ts +2 -2
  835. package/table/table.component.d.ts +5 -5
  836. package/table/table.module.d.ts +10 -10
  837. package/tabs/index.d.ts +1 -1
  838. package/tabs/paginated-tab-header.d.ts +179 -179
  839. package/tabs/ptsecurity-mosaic-tabs.d.ts +5 -5
  840. package/tabs/public-api.d.ts +10 -10
  841. package/tabs/tab-body.component.d.ts +95 -95
  842. package/tabs/tab-content.directive.d.ts +9 -9
  843. package/tabs/tab-group.component.d.ts +133 -133
  844. package/tabs/tab-header.component.d.ts +35 -35
  845. package/tabs/tab-label-wrapper.directive.d.ts +30 -30
  846. package/tabs/tab-label.directive.d.ts +9 -9
  847. package/tabs/tab-nav-bar/index.d.ts +1 -1
  848. package/tabs/tab-nav-bar/tab-nav-bar.d.ts +38 -38
  849. package/tabs/tab.component.d.ts +66 -66
  850. package/tabs/tabs-animations.d.ts +4 -4
  851. package/tabs/tabs.module.d.ts +20 -20
  852. package/tags/index.d.ts +1 -1
  853. package/tags/ptsecurity-mosaic-tags.d.ts +5 -5
  854. package/tags/public-api.d.ts +5 -5
  855. package/tags/tag-default-options.d.ts +8 -8
  856. package/tags/tag-input.d.ts +77 -77
  857. package/tags/tag-list.component.d.ts +240 -240
  858. package/tags/tag-text-control.d.ts +10 -10
  859. package/tags/tag.component.d.ts +135 -135
  860. package/tags/tag.module.d.ts +11 -11
  861. package/textarea/index.d.ts +1 -1
  862. package/textarea/ptsecurity-mosaic-textarea.d.ts +5 -5
  863. package/textarea/public-api.d.ts +2 -2
  864. package/textarea/textarea.component.d.ts +111 -111
  865. package/textarea/textarea.module.d.ts +11 -11
  866. package/timepicker/index.d.ts +1 -1
  867. package/timepicker/ptsecurity-mosaic-timepicker.d.ts +5 -5
  868. package/timepicker/public-api.d.ts +3 -3
  869. package/timepicker/timepicker.constants.d.ts +20 -20
  870. package/timepicker/timepicker.directive.d.ts +146 -147
  871. package/timepicker/timepicker.module.d.ts +11 -11
  872. package/toggle/index.d.ts +1 -1
  873. package/toggle/ptsecurity-mosaic-toggle.d.ts +5 -5
  874. package/toggle/public-api.d.ts +2 -2
  875. package/toggle/toggle.component.d.ts +54 -54
  876. package/toggle/toggle.module.d.ts +10 -10
  877. package/tooltip/index.d.ts +1 -1
  878. package/tooltip/ptsecurity-mosaic-tooltip.d.ts +5 -5
  879. package/tooltip/public-api.d.ts +2 -2
  880. package/tooltip/tooltip.animations.d.ts +8 -8
  881. package/tooltip/tooltip.component.d.ts +91 -91
  882. package/tooltip/tooltip.module.d.ts +9 -9
  883. package/tree/control/base-tree-control.d.ts +40 -40
  884. package/tree/control/flat-tree-control.d.ts +52 -52
  885. package/tree/control/nested-tree-control.d.ts +19 -19
  886. package/tree/control/tree-control.d.ts +44 -44
  887. package/tree/data-source/flat-data-source.d.ts +80 -80
  888. package/tree/data-source/nested-data-source.d.ts +15 -15
  889. package/tree/index.d.ts +1 -1
  890. package/tree/node.d.ts +34 -34
  891. package/tree/outlet.d.ts +9 -9
  892. package/tree/padding.directive.d.ts +47 -45
  893. package/tree/ptsecurity-mosaic-tree.d.ts +5 -5
  894. package/tree/public-api.d.ts +15 -15
  895. package/tree/toggle.d.ts +28 -28
  896. package/tree/tree-base.d.ts +97 -97
  897. package/tree/tree-errors.d.ts +25 -25
  898. package/tree/tree-option.component.d.ts +72 -68
  899. package/tree/tree-selection.component.d.ts +132 -132
  900. package/tree/tree.d.ts +6 -6
  901. package/tree/tree.module.d.ts +16 -16
  902. package/tree-select/index.d.ts +1 -1
  903. package/tree-select/ptsecurity-mosaic-tree-select.d.ts +5 -5
  904. package/tree-select/public-api.d.ts +2 -2
  905. package/tree-select/tree-select.component.d.ts +277 -274
  906. package/tree-select/tree-select.module.d.ts +14 -14
@@ -16,740 +16,740 @@ import * as i2 from '@angular/cdk/bidi';
16
16
  import * as i3 from '@ptsecurity/mosaic/form-field';
17
17
  import * as i4 from '@angular/cdk/scrolling';
18
18
 
19
- /**
20
- * Autocomplete IDs need to be unique across components, so this counter exists outside of
21
- * the component definition.
22
- */
23
- let uniqueAutocompleteIdCounter = 0;
24
- class McAutocompleteSelectedEvent {
25
- constructor(source, option) {
26
- this.source = source;
27
- this.option = option;
28
- }
29
- }
30
- /** Injection token to be used to override the default options for `mc-autocomplete`. */
31
- const MC_AUTOCOMPLETE_DEFAULT_OPTIONS = new InjectionToken('mc-autocomplete-default-options', {
32
- providedIn: 'root',
33
- factory: MC_AUTOCOMPLETE_DEFAULT_OPTIONS_FACTORY
34
- });
35
- // tslint:disable-next-line naming-convention
36
- function MC_AUTOCOMPLETE_DEFAULT_OPTIONS_FACTORY() {
37
- return { autoActiveFirstOption: true };
38
- }
39
- class McAutocomplete {
40
- constructor(changeDetectorRef, elementRef, defaults) {
41
- this.changeDetectorRef = changeDetectorRef;
42
- this.elementRef = elementRef;
43
- /** Unique ID to be used by autocomplete trigger's "aria-owns" property. */
44
- this.id = `mc-autocomplete-${uniqueAutocompleteIdCounter++}`;
45
- /** Whether the autocomplete panel should be visible, depending on option length. */
46
- this.showPanel = false;
47
- /** Function that maps an option's control value to its display value in the trigger. */
48
- this.displayWith = null;
49
- /** Event that is emitted whenever an option from the list is selected. */
50
- this.optionSelected = new EventEmitter();
51
- /** Event that is emitted when the autocomplete panel is opened. */
52
- this.opened = new EventEmitter();
53
- /** Event that is emitted when the autocomplete panel is closed. */
54
- this.closed = new EventEmitter();
55
- this._classList = {};
56
- this._isOpen = false;
57
- this._openOnFocus = true;
58
- this._autoActiveFirstOption = !!defaults.autoActiveFirstOption;
59
- }
60
- /**
61
- * Takes classes set on the host mc-autocomplete element and applies them to the panel
62
- * inside the overlay container to allow for easy styling.
63
- */
64
- get classList() {
65
- return this._classList;
66
- }
67
- set classList(value) {
68
- if (value && value.length) {
69
- value.split(' ')
70
- .forEach((className) => this._classList[className.trim()] = true);
71
- this.elementRef.nativeElement.className = '';
72
- }
73
- }
74
- /**
75
- * Whether the first option should be highlighted when the autocomplete panel is opened.
76
- * Can be configured globally through the `MC_AUTOCOMPLETE_DEFAULT_OPTIONS` token.
77
- */
78
- get autoActiveFirstOption() {
79
- return this._autoActiveFirstOption;
80
- }
81
- set autoActiveFirstOption(value) {
82
- this._autoActiveFirstOption = coerceBooleanProperty(value);
83
- }
84
- get isOpen() {
85
- return this._isOpen && this.showPanel;
86
- }
87
- set isOpen(value) {
88
- this._isOpen = value;
89
- }
90
- get openOnFocus() {
91
- return this._openOnFocus;
92
- }
93
- set openOnFocus(value) {
94
- this._openOnFocus = value;
95
- }
96
- ngAfterContentInit() {
97
- this.keyManager = new ActiveDescendantKeyManager(this.options);
98
- this.setVisibility();
99
- }
100
- setScrollTop(scrollTop) {
101
- if (this.panel) {
102
- this.panel.nativeElement.scrollTop = scrollTop;
103
- }
104
- }
105
- getScrollTop() {
106
- return this.panel ? this.panel.nativeElement.scrollTop : 0;
107
- }
108
- setVisibility() {
109
- this.showPanel = !!this.options.length;
110
- this._classList['mc-autocomplete_visible'] = this.showPanel;
111
- this._classList['mc-autocomplete_hidden'] = !this.showPanel;
112
- this.changeDetectorRef.markForCheck();
113
- }
114
- emitSelectEvent(option) {
115
- const event = new McAutocompleteSelectedEvent(this, option);
116
- this.optionSelected.emit(event);
117
- }
118
- onKeydown(event) {
119
- this.keyManager.onKeydown(event);
120
- }
121
- }
122
- /** @nocollapse */ /** @nocollapse */ McAutocomplete.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.7", ngImport: i0, type: McAutocomplete, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.ElementRef }, { token: MC_AUTOCOMPLETE_DEFAULT_OPTIONS }], target: i0.ɵɵFactoryTarget.Component });
123
- /** @nocollapse */ /** @nocollapse */ McAutocomplete.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.7", type: McAutocomplete, selector: "mc-autocomplete", inputs: { displayWith: "displayWith", panelWidth: "panelWidth", classList: ["class", "classList"], autoActiveFirstOption: "autoActiveFirstOption", openOnFocus: "openOnFocus" }, outputs: { optionSelected: "optionSelected", opened: "opened", closed: "closed" }, host: { classAttribute: "mc-autocomplete" }, providers: [{
124
- provide: MC_OPTION_PARENT_COMPONENT, useExisting: McAutocomplete
125
- }], queries: [{ propertyName: "options", predicate: McOption, descendants: true }, { propertyName: "optionGroups", predicate: McOptgroup }], viewQueries: [{ propertyName: "template", first: true, predicate: TemplateRef, descendants: true, static: true }, { propertyName: "panel", first: true, predicate: ["panel"], descendants: true }], exportAs: ["mcAutocomplete"], ngImport: i0, template: "<ng-template>\r\n <div class=\"mc-autocomplete-panel\" role=\"listbox\" [id]=\"id\" [ngClass]=\"classList\" #panel>\r\n <ng-content></ng-content>\r\n </div>\r\n</ng-template>\r\n", styles: [".mc-autocomplete-trigger{text-overflow:ellipsis}.mc-autocomplete-panel{visibility:hidden;position:relative;overflow:auto;-webkit-overflow-scrolling:touch;margin-top:-1px;min-width:100%;width:100%;max-width:none;max-height:var(--mc-autocomplete-size-panel-max-height, 256px);border-width:1px;border-style:solid;border-bottom-left-radius:var(--mc-autocomplete-size-panel-border-radius, 4px);border-bottom-right-radius:var(--mc-autocomplete-size-panel-border-radius, 4px);padding:var(--mc-autocomplete-size-panel-padding, 4px 0)}.mc-autocomplete-panel.mc-autocomplete_visible{visibility:visible}.mc-autocomplete-panel.mc-autocomplete_hidden{visibility:hidden}.mc-autocomplete-panel-above .mc-autocomplete-panel{border-radius:var(--mc-autocomplete-size-panel-border-radius, 4px) var(--mc-autocomplete-size-panel-border-radius, 4px) 0 0}.mc-autocomplete-panel .mc-divider-horizontal{margin-top:-1px}.cdk-high-contrast-active .mc-autocomplete-panel{outline:solid 1px}.cdk-high-contrast-active :host .mc-autocomplete-panel{outline:solid 1px}\n"], directives: [{ type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
126
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.7", ngImport: i0, type: McAutocomplete, decorators: [{
127
- type: Component,
128
- args: [{ selector: 'mc-autocomplete', exportAs: 'mcAutocomplete', host: {
129
- class: 'mc-autocomplete'
130
- }, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, providers: [{
131
- provide: MC_OPTION_PARENT_COMPONENT, useExisting: McAutocomplete
132
- }], template: "<ng-template>\r\n <div class=\"mc-autocomplete-panel\" role=\"listbox\" [id]=\"id\" [ngClass]=\"classList\" #panel>\r\n <ng-content></ng-content>\r\n </div>\r\n</ng-template>\r\n", styles: [".mc-autocomplete-trigger{text-overflow:ellipsis}.mc-autocomplete-panel{visibility:hidden;position:relative;overflow:auto;-webkit-overflow-scrolling:touch;margin-top:-1px;min-width:100%;width:100%;max-width:none;max-height:var(--mc-autocomplete-size-panel-max-height, 256px);border-width:1px;border-style:solid;border-bottom-left-radius:var(--mc-autocomplete-size-panel-border-radius, 4px);border-bottom-right-radius:var(--mc-autocomplete-size-panel-border-radius, 4px);padding:var(--mc-autocomplete-size-panel-padding, 4px 0)}.mc-autocomplete-panel.mc-autocomplete_visible{visibility:visible}.mc-autocomplete-panel.mc-autocomplete_hidden{visibility:hidden}.mc-autocomplete-panel-above .mc-autocomplete-panel{border-radius:var(--mc-autocomplete-size-panel-border-radius, 4px) var(--mc-autocomplete-size-panel-border-radius, 4px) 0 0}.mc-autocomplete-panel .mc-divider-horizontal{margin-top:-1px}.cdk-high-contrast-active .mc-autocomplete-panel{outline:solid 1px}.cdk-high-contrast-active :host .mc-autocomplete-panel{outline:solid 1px}\n"] }]
133
- }], ctorParameters: function () {
134
- return [{ type: i0.ChangeDetectorRef }, { type: i0.ElementRef }, { type: undefined, decorators: [{
135
- type: Inject,
136
- args: [MC_AUTOCOMPLETE_DEFAULT_OPTIONS]
137
- }] }];
138
- }, propDecorators: { template: [{
139
- type: ViewChild,
140
- args: [TemplateRef, { static: true }]
141
- }], panel: [{
142
- type: ViewChild,
143
- args: ['panel', { static: false }]
144
- }], options: [{
145
- type: ContentChildren,
146
- args: [McOption, { descendants: true }]
147
- }], optionGroups: [{
148
- type: ContentChildren,
149
- args: [McOptgroup]
150
- }], displayWith: [{
151
- type: Input
152
- }], panelWidth: [{
153
- type: Input
154
- }], optionSelected: [{
155
- type: Output
156
- }], opened: [{
157
- type: Output
158
- }], closed: [{
159
- type: Output
160
- }], classList: [{
161
- type: Input,
162
- args: ['class']
163
- }], autoActiveFirstOption: [{
164
- type: Input
165
- }], openOnFocus: [{
166
- type: Input
19
+ /**
20
+ * Autocomplete IDs need to be unique across components, so this counter exists outside of
21
+ * the component definition.
22
+ */
23
+ let uniqueAutocompleteIdCounter = 0;
24
+ class McAutocompleteSelectedEvent {
25
+ constructor(source, option) {
26
+ this.source = source;
27
+ this.option = option;
28
+ }
29
+ }
30
+ /** Injection token to be used to override the default options for `mc-autocomplete`. */
31
+ const MC_AUTOCOMPLETE_DEFAULT_OPTIONS = new InjectionToken('mc-autocomplete-default-options', {
32
+ providedIn: 'root',
33
+ factory: MC_AUTOCOMPLETE_DEFAULT_OPTIONS_FACTORY
34
+ });
35
+ // tslint:disable-next-line naming-convention
36
+ function MC_AUTOCOMPLETE_DEFAULT_OPTIONS_FACTORY() {
37
+ return { autoActiveFirstOption: true };
38
+ }
39
+ class McAutocomplete {
40
+ constructor(changeDetectorRef, elementRef, defaults) {
41
+ this.changeDetectorRef = changeDetectorRef;
42
+ this.elementRef = elementRef;
43
+ /** Unique ID to be used by autocomplete trigger's "aria-owns" property. */
44
+ this.id = `mc-autocomplete-${uniqueAutocompleteIdCounter++}`;
45
+ /** Whether the autocomplete panel should be visible, depending on option length. */
46
+ this.showPanel = false;
47
+ /** Function that maps an option's control value to its display value in the trigger. */
48
+ this.displayWith = null;
49
+ /** Event that is emitted whenever an option from the list is selected. */
50
+ this.optionSelected = new EventEmitter();
51
+ /** Event that is emitted when the autocomplete panel is opened. */
52
+ this.opened = new EventEmitter();
53
+ /** Event that is emitted when the autocomplete panel is closed. */
54
+ this.closed = new EventEmitter();
55
+ this._classList = {};
56
+ this._isOpen = false;
57
+ this._openOnFocus = true;
58
+ this._autoActiveFirstOption = !!defaults.autoActiveFirstOption;
59
+ }
60
+ /**
61
+ * Takes classes set on the host mc-autocomplete element and applies them to the panel
62
+ * inside the overlay container to allow for easy styling.
63
+ */
64
+ get classList() {
65
+ return this._classList;
66
+ }
67
+ set classList(value) {
68
+ if (value && value.length) {
69
+ value.split(' ')
70
+ .forEach((className) => this._classList[className.trim()] = true);
71
+ this.elementRef.nativeElement.className = '';
72
+ }
73
+ }
74
+ /**
75
+ * Whether the first option should be highlighted when the autocomplete panel is opened.
76
+ * Can be configured globally through the `MC_AUTOCOMPLETE_DEFAULT_OPTIONS` token.
77
+ */
78
+ get autoActiveFirstOption() {
79
+ return this._autoActiveFirstOption;
80
+ }
81
+ set autoActiveFirstOption(value) {
82
+ this._autoActiveFirstOption = coerceBooleanProperty(value);
83
+ }
84
+ get isOpen() {
85
+ return this._isOpen && this.showPanel;
86
+ }
87
+ set isOpen(value) {
88
+ this._isOpen = value;
89
+ }
90
+ get openOnFocus() {
91
+ return this._openOnFocus;
92
+ }
93
+ set openOnFocus(value) {
94
+ this._openOnFocus = value;
95
+ }
96
+ ngAfterContentInit() {
97
+ this.keyManager = new ActiveDescendantKeyManager(this.options);
98
+ this.setVisibility();
99
+ }
100
+ setScrollTop(scrollTop) {
101
+ if (this.panel) {
102
+ this.panel.nativeElement.scrollTop = scrollTop;
103
+ }
104
+ }
105
+ getScrollTop() {
106
+ return this.panel ? this.panel.nativeElement.scrollTop : 0;
107
+ }
108
+ setVisibility() {
109
+ this.showPanel = !!this.options.length;
110
+ this._classList['mc-autocomplete_visible'] = this.showPanel;
111
+ this._classList['mc-autocomplete_hidden'] = !this.showPanel;
112
+ this.changeDetectorRef.markForCheck();
113
+ }
114
+ emitSelectEvent(option) {
115
+ const event = new McAutocompleteSelectedEvent(this, option);
116
+ this.optionSelected.emit(event);
117
+ }
118
+ onKeydown(event) {
119
+ this.keyManager.onKeydown(event);
120
+ }
121
+ }
122
+ /** @nocollapse */ /** @nocollapse */ McAutocomplete.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: McAutocomplete, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.ElementRef }, { token: MC_AUTOCOMPLETE_DEFAULT_OPTIONS }], target: i0.ɵɵFactoryTarget.Component });
123
+ /** @nocollapse */ /** @nocollapse */ McAutocomplete.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: McAutocomplete, selector: "mc-autocomplete", inputs: { displayWith: "displayWith", panelWidth: "panelWidth", classList: ["class", "classList"], autoActiveFirstOption: "autoActiveFirstOption", openOnFocus: "openOnFocus" }, outputs: { optionSelected: "optionSelected", opened: "opened", closed: "closed" }, host: { classAttribute: "mc-autocomplete" }, providers: [{
124
+ provide: MC_OPTION_PARENT_COMPONENT, useExisting: McAutocomplete
125
+ }], queries: [{ propertyName: "options", predicate: McOption, descendants: true }, { propertyName: "optionGroups", predicate: McOptgroup }], viewQueries: [{ propertyName: "template", first: true, predicate: TemplateRef, descendants: true, static: true }, { propertyName: "panel", first: true, predicate: ["panel"], descendants: true }], exportAs: ["mcAutocomplete"], ngImport: i0, template: "<ng-template>\n <div class=\"mc-autocomplete-panel\" role=\"listbox\" [id]=\"id\" [ngClass]=\"classList\" #panel>\n <ng-content></ng-content>\n </div>\n</ng-template>\n", styles: [".mc-autocomplete-trigger{text-overflow:ellipsis}.mc-autocomplete-panel{visibility:hidden;position:relative;overflow:auto;-webkit-overflow-scrolling:touch;margin-top:-1px;min-width:100%;width:100%;max-width:none;max-height:var(--mc-autocomplete-size-panel-max-height, 256px);border-width:1px;border-style:solid;border-bottom-left-radius:var(--mc-autocomplete-size-panel-border-radius, 4px);border-bottom-right-radius:var(--mc-autocomplete-size-panel-border-radius, 4px);padding:var(--mc-autocomplete-size-panel-padding, 4px 0)}.mc-autocomplete-panel.mc-autocomplete_visible{visibility:visible}.mc-autocomplete-panel.mc-autocomplete_hidden{visibility:hidden}.mc-autocomplete-panel-above .mc-autocomplete-panel{border-radius:var(--mc-autocomplete-size-panel-border-radius, 4px) var(--mc-autocomplete-size-panel-border-radius, 4px) 0 0}.mc-autocomplete-panel .mc-divider-horizontal{margin-top:-1px}.cdk-high-contrast-active .mc-autocomplete-panel{outline:solid 1px}.cdk-high-contrast-active :host .mc-autocomplete-panel{outline:solid 1px}\n"], directives: [{ type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
126
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: McAutocomplete, decorators: [{
127
+ type: Component,
128
+ args: [{ selector: 'mc-autocomplete', exportAs: 'mcAutocomplete', host: {
129
+ class: 'mc-autocomplete'
130
+ }, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, providers: [{
131
+ provide: MC_OPTION_PARENT_COMPONENT, useExisting: McAutocomplete
132
+ }], template: "<ng-template>\n <div class=\"mc-autocomplete-panel\" role=\"listbox\" [id]=\"id\" [ngClass]=\"classList\" #panel>\n <ng-content></ng-content>\n </div>\n</ng-template>\n", styles: [".mc-autocomplete-trigger{text-overflow:ellipsis}.mc-autocomplete-panel{visibility:hidden;position:relative;overflow:auto;-webkit-overflow-scrolling:touch;margin-top:-1px;min-width:100%;width:100%;max-width:none;max-height:var(--mc-autocomplete-size-panel-max-height, 256px);border-width:1px;border-style:solid;border-bottom-left-radius:var(--mc-autocomplete-size-panel-border-radius, 4px);border-bottom-right-radius:var(--mc-autocomplete-size-panel-border-radius, 4px);padding:var(--mc-autocomplete-size-panel-padding, 4px 0)}.mc-autocomplete-panel.mc-autocomplete_visible{visibility:visible}.mc-autocomplete-panel.mc-autocomplete_hidden{visibility:hidden}.mc-autocomplete-panel-above .mc-autocomplete-panel{border-radius:var(--mc-autocomplete-size-panel-border-radius, 4px) var(--mc-autocomplete-size-panel-border-radius, 4px) 0 0}.mc-autocomplete-panel .mc-divider-horizontal{margin-top:-1px}.cdk-high-contrast-active .mc-autocomplete-panel{outline:solid 1px}.cdk-high-contrast-active :host .mc-autocomplete-panel{outline:solid 1px}\n"] }]
133
+ }], ctorParameters: function () {
134
+ return [{ type: i0.ChangeDetectorRef }, { type: i0.ElementRef }, { type: undefined, decorators: [{
135
+ type: Inject,
136
+ args: [MC_AUTOCOMPLETE_DEFAULT_OPTIONS]
137
+ }] }];
138
+ }, propDecorators: { template: [{
139
+ type: ViewChild,
140
+ args: [TemplateRef, { static: true }]
141
+ }], panel: [{
142
+ type: ViewChild,
143
+ args: ['panel', { static: false }]
144
+ }], options: [{
145
+ type: ContentChildren,
146
+ args: [McOption, { descendants: true }]
147
+ }], optionGroups: [{
148
+ type: ContentChildren,
149
+ args: [McOptgroup]
150
+ }], displayWith: [{
151
+ type: Input
152
+ }], panelWidth: [{
153
+ type: Input
154
+ }], optionSelected: [{
155
+ type: Output
156
+ }], opened: [{
157
+ type: Output
158
+ }], closed: [{
159
+ type: Output
160
+ }], classList: [{
161
+ type: Input,
162
+ args: ['class']
163
+ }], autoActiveFirstOption: [{
164
+ type: Input
165
+ }], openOnFocus: [{
166
+ type: Input
167
167
  }] } });
168
168
 
169
- /**
170
- * Directive applied to an element to make it usable
171
- * as a connection point for an autocomplete panel.
172
- */
173
- class McAutocompleteOrigin {
174
- constructor(elementRef) {
175
- this.elementRef = elementRef;
176
- }
177
- }
178
- /** @nocollapse */ /** @nocollapse */ McAutocompleteOrigin.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.7", ngImport: i0, type: McAutocompleteOrigin, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
179
- /** @nocollapse */ /** @nocollapse */ McAutocompleteOrigin.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.7", type: McAutocompleteOrigin, selector: "[mcAutocompleteOrigin]", exportAs: ["mcAutocompleteOrigin"], ngImport: i0 });
180
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.7", ngImport: i0, type: McAutocompleteOrigin, decorators: [{
181
- type: Directive,
182
- args: [{
183
- selector: '[mcAutocompleteOrigin]',
184
- exportAs: 'mcAutocompleteOrigin'
185
- }]
169
+ /**
170
+ * Directive applied to an element to make it usable
171
+ * as a connection point for an autocomplete panel.
172
+ */
173
+ class McAutocompleteOrigin {
174
+ constructor(elementRef) {
175
+ this.elementRef = elementRef;
176
+ }
177
+ }
178
+ /** @nocollapse */ /** @nocollapse */ McAutocompleteOrigin.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: McAutocompleteOrigin, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
179
+ /** @nocollapse */ /** @nocollapse */ McAutocompleteOrigin.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.11", type: McAutocompleteOrigin, selector: "[mcAutocompleteOrigin]", exportAs: ["mcAutocompleteOrigin"], ngImport: i0 });
180
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: McAutocompleteOrigin, decorators: [{
181
+ type: Directive,
182
+ args: [{
183
+ selector: '[mcAutocompleteOrigin]',
184
+ exportAs: 'mcAutocompleteOrigin'
185
+ }]
186
186
  }], ctorParameters: function () { return [{ type: i0.ElementRef }]; } });
187
187
 
188
- /**
189
- * The following style constants are necessary to save here in order
190
- * to properly calculate the scrollTop of the panel. Because we are not
191
- * actually focusing the active item, scroll must be handled manually.
192
- */
193
- /** The height of each autocomplete option. */
194
- const AUTOCOMPLETE_OPTION_HEIGHT = 32;
195
- /** The total height of the autocomplete panel. */
196
- const AUTOCOMPLETE_PANEL_HEIGHT = 256;
197
- const AUTOCOMPLETE_BORDER_WIDTH = 2;
198
- /** Injection token that determines the scroll handling while the autocomplete panel is open. */
199
- const MC_AUTOCOMPLETE_SCROLL_STRATEGY = new InjectionToken('mc-autocomplete-scroll-strategy');
200
- // tslint:disable-next-line naming-convention
201
- function MC_AUTOCOMPLETE_SCROLL_STRATEGY_FACTORY(overlay) {
202
- return () => overlay.scrollStrategies.reposition();
203
- }
204
- const MC_AUTOCOMPLETE_SCROLL_STRATEGY_FACTORY_PROVIDER = {
205
- provide: MC_AUTOCOMPLETE_SCROLL_STRATEGY,
206
- deps: [Overlay],
207
- useFactory: MC_AUTOCOMPLETE_SCROLL_STRATEGY_FACTORY
208
- };
209
- /**
210
- * Provider that allows the autocomplete to register as a ControlValueAccessor.
211
- * @docs-private
212
- */
213
- const MAT_AUTOCOMPLETE_VALUE_ACCESSOR = {
214
- provide: NG_VALUE_ACCESSOR,
215
- useExisting: forwardRef(() => McAutocompleteTrigger),
216
- multi: true
217
- };
218
- /**
219
- * Creates an error to be thrown when attempting to use an autocomplete trigger without a panel.
220
- * @docs-private
221
- */
222
- function getMcAutocompleteMissingPanelError() {
223
- return Error('Attempting to open an undefined instance of `mc-autocomplete`. ' +
224
- 'Make sure that the id passed to the `mcAutocomplete` is correct and that ' +
225
- 'you\'re attempting to open it after the ngAfterContentInit hook.');
226
- }
227
- class McAutocompleteTrigger {
228
- constructor(elementRef, viewContainerRef, changeDetectorRef, overlay, zone, scrollStrategy, dir, formField, document,
229
- // @breaking-change 8.0.0 Make `_viewportRuler` required.
230
- viewportRuler) {
231
- this.elementRef = elementRef;
232
- this.viewContainerRef = viewContainerRef;
233
- this.changeDetectorRef = changeDetectorRef;
234
- this.overlay = overlay;
235
- this.zone = zone;
236
- this.dir = dir;
237
- this.formField = formField;
238
- this.document = document;
239
- this.viewportRuler = viewportRuler;
240
- // @ts-ignore
241
- this.optionSelections = defer(() => {
242
- if (this.autocomplete && this.autocomplete.options) {
243
- return merge(...this.autocomplete.options.map((option) => option.onSelectionChange));
244
- }
245
- // If there are any subscribers before `ngAfterViewInit`, the `autocomplete` will be undefined.
246
- // Return a stream that we'll replace with the real one once everything is in place.
247
- return this.zone.onStable
248
- .asObservable()
249
- .pipe(take(1), switchMap(() => this.optionSelections));
250
- });
251
- /**
252
- * `autocomplete` attribute to be set on the input element.
253
- * @docs-private
254
- */
255
- this.autocompleteAttribute = 'off';
256
- this._autocompleteDisabled = false;
257
- this.overlayAttached = false;
258
- this.componentDestroyed = false;
259
- /** Subscription to viewport size changes. */
260
- this.viewportSubscription = Subscription.EMPTY;
261
- /**
262
- * Whether the autocomplete can open the next time it is focused. Used to prevent a focused,
263
- * closed autocomplete from being reopened if the user switches to another browser tab and then
264
- * comes back.
265
- */
266
- this.canOpenOnNextFocus = true;
267
- /** Stream of keyboard events that can close the panel. */
268
- this.closeKeyEventStream = new Subject();
269
- /** `View -> model callback called when value changes` */
270
- // tslint:disable-next-line no-empty
271
- this.onChange = () => { };
272
- /** `View -> model callback called when autocomplete has been touched` */
273
- // tslint:disable-next-line no-empty
274
- this.onTouched = () => { };
275
- /**
276
- * Event handler for when the window is blurred. Needs to be an
277
- * arrow function in order to preserve the context.
278
- */
279
- this.windowBlurHandler = () => {
280
- // If the user blurred the window while the autocomplete is focused, it means that it'll be
281
- // refocused when they come back. In this case we want to skip the first focus event, if the
282
- // pane was closed, in order to avoid reopening it unintentionally.
283
- this.canOpenOnNextFocus = this.document.activeElement !== this.elementRef.nativeElement || this.panelOpen;
284
- };
285
- // tslint:disable-next-line no-typeof-undefined
286
- if (typeof window !== 'undefined') {
287
- zone.runOutsideAngular(() => {
288
- window.addEventListener('blur', this.windowBlurHandler);
289
- });
290
- }
291
- this.scrollStrategy = scrollStrategy;
292
- }
293
- /** The currently active option, coerced to MatOption type. */
294
- get activeOption() {
295
- if (this.autocomplete && this.autocomplete.keyManager) {
296
- return this.autocomplete.keyManager.activeItem;
297
- }
298
- return null;
299
- }
300
- get panelOpen() {
301
- return this.overlayAttached && this.autocomplete.showPanel;
302
- }
303
- /**
304
- * Whether the autocomplete is disabled. When disabled, the element will
305
- * act as a regular input and the user won't be able to open the panel.
306
- */
307
- get autocompleteDisabled() {
308
- return this._autocompleteDisabled;
309
- }
310
- set autocompleteDisabled(value) {
311
- this._autocompleteDisabled = coerceBooleanProperty(value);
312
- }
313
- ngOnDestroy() {
314
- // tslint:disable-next-line no-typeof-undefined
315
- if (typeof window !== 'undefined') {
316
- window.removeEventListener('blur', this.windowBlurHandler);
317
- }
318
- this.viewportSubscription.unsubscribe();
319
- this.componentDestroyed = true;
320
- this.destroyPanel();
321
- this.closeKeyEventStream.complete();
322
- }
323
- /** Opens the autocomplete suggestion panel. */
324
- openPanel() {
325
- this.attachOverlay();
326
- }
327
- closePanel() {
328
- if (!this.overlayAttached) {
329
- return;
330
- }
331
- if (this.panelOpen) {
332
- this.autocomplete.closed.emit();
333
- }
334
- this.autocomplete.isOpen = this.overlayAttached = false;
335
- if (this.overlayRef && this.overlayRef.hasAttached()) {
336
- this.overlayRef.detach();
337
- this.closingActionsSubscription.unsubscribe();
338
- }
339
- // Note that in some cases this can end up being called after the component is destroyed.
340
- // Add a check to ensure that we don't try to run change detection on a destroyed view.
341
- if (!this.componentDestroyed) {
342
- // We need to trigger change detection manually, because
343
- // `fromEvent` doesn't seem to do it at the proper time.
344
- // This ensures that the label is reset when the
345
- // user clicks outside.
346
- this.changeDetectorRef.detectChanges();
347
- }
348
- }
349
- /**
350
- * Updates the position of the autocomplete suggestion panel to ensure that it fits all options
351
- * within the viewport.
352
- */
353
- updatePosition() {
354
- if (this.overlayAttached) {
355
- this.overlayRef.updatePosition();
356
- }
357
- }
358
- /**
359
- * A stream of actions that should close the autocomplete panel, including
360
- * when an option is selected, on blur, and when TAB is pressed.
361
- */
362
- get panelClosingActions() {
363
- return merge(this.optionSelections, this.autocomplete.keyManager.tabOut.pipe(filter(() => this.overlayAttached)), this.closeKeyEventStream, this.getOutsideClickStream(), this.overlayRef ?
364
- this.overlayRef.detachments().pipe(filter(() => this.overlayAttached)) :
365
- of()).pipe(
366
- // Normalize the output so we return a consistent type.
367
- map((event) => event instanceof McOptionSelectionChange ? event : null));
368
- }
369
- // Implemented as part of ControlValueAccessor.
370
- writeValue(value) {
371
- Promise.resolve(null).then(() => this.setTriggerValue(value));
372
- }
373
- // Implemented as part of ControlValueAccessor.
374
- registerOnChange(fn) {
375
- this.onChange = fn;
376
- }
377
- // Implemented as part of ControlValueAccessor.
378
- registerOnTouched(fn) {
379
- this.onTouched = fn;
380
- }
381
- // Implemented as part of ControlValueAccessor.
382
- setDisabledState(isDisabled) {
383
- this.elementRef.nativeElement.disabled = isDisabled;
384
- }
385
- handleKeydown(event) {
386
- // tslint:disable-next-line deprecation
387
- const keyCode = event.keyCode;
388
- // Prevent the default action on all escape key presses. This is here primarily to bring IE
389
- // in line with other browsers. By default, pressing escape on IE will cause it to revert
390
- // the input value to the one that it had on focus, however it won't dispatch any events
391
- // which means that the model value will be out of sync with the view.
392
- if (keyCode === ESCAPE) {
393
- event.preventDefault();
394
- }
395
- if (this.activeOption && keyCode === ENTER && this.panelOpen) {
396
- this.activeOption.selectViaInteraction();
397
- this.resetActiveItem();
398
- event.preventDefault();
399
- }
400
- else if (this.autocomplete) {
401
- const prevActiveItem = this.autocomplete.keyManager.activeItem;
402
- if (this.panelOpen || keyCode === TAB) {
403
- this.autocomplete.onKeydown(event);
404
- }
405
- else if (keyCode === DOWN_ARROW && this.canOpen()) {
406
- this.openPanel();
407
- }
408
- const isArrowKey = keyCode === UP_ARROW || keyCode === DOWN_ARROW;
409
- if (isArrowKey || this.autocomplete.keyManager.activeItem !== prevActiveItem) {
410
- this.scrollToOption();
411
- }
412
- }
413
- }
414
- handleInput(event) {
415
- const target = event.target;
416
- let value = target.value;
417
- // Based on `NumberValueAccessor` from forms.
418
- if (target.type === 'number') {
419
- value = value === '' ? null : parseFloat(value);
420
- }
421
- // If the input has a placeholder, IE will fire the `input` event on page load,
422
- // focus and blur, in addition to when the user actually changed the value. To
423
- // filter out all of the extra events, we save the value on focus and between
424
- // `input` events, and we check whether it changed.
425
- // See: https://connect.microsoft.com/IE/feedback/details/885747/
426
- if (this.previousValue !== value) {
427
- this.previousValue = value;
428
- this.onChange(value);
429
- if (this.canOpen() && this.document.activeElement === event.target) {
430
- this.openPanel();
431
- }
432
- }
433
- }
434
- handleFocus() {
435
- if (!this.canOpenOnNextFocus) {
436
- this.canOpenOnNextFocus = true;
437
- }
438
- else if (this.canOpen() && this.autocomplete.openOnFocus) {
439
- this.previousValue = this.elementRef.nativeElement.value;
440
- this.attachOverlay();
441
- }
442
- }
443
- handleClick($event) {
444
- if (this.canOpen() && this.document.activeElement === $event.target) {
445
- this.openPanel();
446
- }
447
- }
448
- /** Stream of clicks outside of the autocomplete panel. */
449
- getOutsideClickStream() {
450
- return merge(
451
- // tslint:disable-next-line: no-unnecessary-type-assertion
452
- fromEvent(this.document, 'click'),
453
- // tslint:disable-next-line: no-unnecessary-type-assertion
454
- fromEvent(this.document, 'touchend'))
455
- .pipe(filter((event) => {
456
- const clickTarget = event.target;
457
- const formField = this.formField ? this.formField._elementRef.nativeElement : null;
458
- const customOrigin = this.connectedTo ? this.connectedTo.elementRef.nativeElement : null;
459
- return this.overlayAttached &&
460
- clickTarget !== this.elementRef.nativeElement &&
461
- (!formField || !formField.contains(clickTarget)) &&
462
- (!customOrigin || !customOrigin.contains(clickTarget)) &&
463
- (!!this.overlayRef && !this.overlayRef.overlayElement.contains(clickTarget));
464
- }));
465
- }
466
- /**
467
- * Given that we are not actually focusing active options, we must manually adjust scroll
468
- * to reveal options below the fold. First, we find the offset of the option from the top
469
- * of the panel. If that offset is below the fold, the new scrollTop will be the offset -
470
- * the panel height + the option height, so the active option will be just visible at the
471
- * bottom of the panel. If that offset is above the top of the visible panel, the new scrollTop
472
- * will become the offset. If that offset is visible within the panel already, the scrollTop is
473
- * not adjusted.
474
- */
475
- scrollToOption() {
476
- const index = this.autocomplete.keyManager.activeItemIndex || 0;
477
- const labelCount = countGroupLabelsBeforeOption(index, this.autocomplete.options, this.autocomplete.optionGroups);
478
- const newScrollPosition = getOptionScrollPosition(index + labelCount, AUTOCOMPLETE_OPTION_HEIGHT, this.autocomplete.getScrollTop(), AUTOCOMPLETE_PANEL_HEIGHT);
479
- this.autocomplete.setScrollTop(newScrollPosition);
480
- }
481
- /**
482
- * This method listens to a stream of panel closing actions and resets the
483
- * stream every time the option list changes.
484
- */
485
- subscribeToClosingActions() {
486
- const firstStable = this.zone.onStable.asObservable()
487
- .pipe(take(1));
488
- const optionChanges = this.autocomplete.options.changes
489
- .pipe(tap(() => this.positionStrategy.reapplyLastPosition()),
490
- // Defer emitting to the stream until the next tick, because changing
491
- // bindings in here will cause "changed after checked" errors.
492
- delay(0));
493
- // When the zone is stable initially, and when the option list changes...
494
- return merge(firstStable, optionChanges)
495
- .pipe(
496
- // create a new stream of panelClosingActions, replacing any previous streams
497
- // that were created, and flatten it so our stream only emits closing events...
498
- switchMap(() => {
499
- const wasOpen = this.panelOpen;
500
- this.resetActiveItem();
501
- this.autocomplete.setVisibility();
502
- if (this.panelOpen) {
503
- this.overlayRef.updatePosition();
504
- // If the `panelOpen` state changed, we need to make sure to emit the `opened`
505
- // event, because we may not have emitted it when the panel was attached. This
506
- // can happen if the users opens the panel and there are no options, but the
507
- // options come in slightly later or as a result of the value changing.
508
- if (wasOpen !== this.panelOpen) {
509
- this.autocomplete.opened.emit();
510
- }
511
- }
512
- return this.panelClosingActions;
513
- }),
514
- // when the first closing event occurs...
515
- take(1))
516
- // set the value, close the panel, and complete.
517
- .subscribe((event) => this.setValueAndClose(event));
518
- }
519
- /** Destroys the autocomplete suggestion panel. */
520
- destroyPanel() {
521
- if (this.overlayRef) {
522
- this.closePanel();
523
- this.overlayRef.dispose();
524
- this.overlayRef = null;
525
- }
526
- }
527
- setTriggerValue(value) {
528
- const toDisplay = this.autocomplete && this.autocomplete.displayWith ?
529
- this.autocomplete.displayWith(value) :
530
- value;
531
- // Simply falling back to an empty string if the display value is falsy does not work properly.
532
- // The display value can also be the number zero and shouldn't fall back to an empty string.
533
- const inputValue = toDisplay != null ? toDisplay : '';
534
- // If it's used within a `MatFormField`, we should set it through the property so it can go
535
- // through change detection.
536
- if (this.formField) {
537
- this.formField.control.value = inputValue;
538
- }
539
- else {
540
- this.elementRef.nativeElement.value = inputValue;
541
- }
542
- this.previousValue = inputValue;
543
- }
544
- /** This method closes the panel, and if a value is specified, also sets the associated
545
- * control to that value. It will also mark the control as dirty if this interaction
546
- * stemmed from the user.
547
- */
548
- setValueAndClose(event) {
549
- if (event && event.source) {
550
- this.clearPreviousSelectedOption(event.source);
551
- this.setTriggerValue(event.source.value);
552
- this.onChange(event.source.value);
553
- this.elementRef.nativeElement.focus();
554
- this.autocomplete.emitSelectEvent(event.source);
555
- }
556
- this.closePanel();
557
- }
558
- /** Clear any previous selected option and emit a selection change event for this option */
559
- clearPreviousSelectedOption(skip) {
560
- this.autocomplete.options.forEach((option) => {
561
- if (option !== skip && option.selected) {
562
- option.deselect();
563
- }
564
- });
565
- }
566
- attachOverlay() {
567
- if (!this.autocomplete) {
568
- throw getMcAutocompleteMissingPanelError();
569
- }
570
- let overlayRef = this.overlayRef;
571
- if (!overlayRef) {
572
- this.portal = new TemplatePortal(this.autocomplete.template, this.viewContainerRef);
573
- overlayRef = this.overlay.create(this.getOverlayConfig());
574
- this.overlayRef = overlayRef;
575
- // Use the `keydownEvents` in order to take advantage of
576
- // the overlay event targeting provided by the CDK overlay.
577
- overlayRef.keydownEvents().subscribe((event) => {
578
- // Close when pressing ESCAPE or ALT + UP_ARROW, based on the a11y guidelines.
579
- // See: https://www.w3.org/TR/wai-aria-practices-1.1/#textbox-keyboard-interaction
580
- // tslint:disable-next-line deprecation
581
- if (event.keyCode === ESCAPE || (event.keyCode === UP_ARROW && event.altKey)) {
582
- this.resetActiveItem();
583
- this.closeKeyEventStream.next();
584
- }
585
- });
586
- if (this.viewportRuler) {
587
- this.viewportSubscription = this.viewportRuler.change().subscribe(() => {
588
- if (this.panelOpen && overlayRef) {
589
- overlayRef.updateSize({ width: this.getPanelWidth() });
590
- }
591
- });
592
- }
593
- }
594
- else {
595
- const position = overlayRef.getConfig().positionStrategy;
596
- // Update the trigger, panel width and direction, in case anything has changed.
597
- position.setOrigin(this.getConnectedElement());
598
- overlayRef.updateSize({ width: this.getPanelWidth() });
599
- }
600
- if (overlayRef && !overlayRef.hasAttached()) {
601
- overlayRef.attach(this.portal);
602
- this.closingActionsSubscription = this.subscribeToClosingActions();
603
- }
604
- const wasOpen = this.panelOpen;
605
- this.autocomplete.setVisibility();
606
- this.autocomplete.isOpen = this.overlayAttached = true;
607
- // We need to do an extra `panelOpen` check in here, because the
608
- // autocomplete won't be shown if there are no options.
609
- if (this.panelOpen && wasOpen !== this.panelOpen) {
610
- this.autocomplete.opened.emit();
611
- }
612
- }
613
- getOverlayConfig() {
614
- return new OverlayConfig({
615
- positionStrategy: this.getOverlayPosition(),
616
- scrollStrategy: this.scrollStrategy(),
617
- width: this.getPanelWidth(),
618
- direction: this.dir
619
- });
620
- }
621
- getOverlayPosition() {
622
- this.positionStrategy = this.overlay.position()
623
- .flexibleConnectedTo(this.getConnectedElement())
624
- .withFlexibleDimensions(false)
625
- .withPush(false)
626
- .withPositions([
627
- {
628
- originX: 'start',
629
- originY: 'bottom',
630
- overlayX: 'start',
631
- overlayY: 'top'
632
- },
633
- {
634
- originX: 'start',
635
- originY: 'top',
636
- overlayX: 'start',
637
- overlayY: 'bottom',
638
- // The overlay edge connected to the trigger should have squared corners, while
639
- // the opposite end has rounded corners. We apply a CSS class to swap the
640
- // border-radius based on the overlay position.
641
- panelClass: 'mc-autocomplete-panel-above'
642
- }
643
- ]);
644
- return this.positionStrategy;
645
- }
646
- getConnectedElement() {
647
- if (this.connectedTo) {
648
- return this.connectedTo.elementRef;
649
- }
650
- return this.formField ? this.formField.getConnectedOverlayOrigin() : this.elementRef;
651
- }
652
- getPanelWidth() {
653
- return this.autocomplete.panelWidth || this.getHostWidth() - AUTOCOMPLETE_BORDER_WIDTH;
654
- }
655
- getHostWidth() {
656
- return this.getConnectedElement().nativeElement.getBoundingClientRect().width;
657
- }
658
- /**
659
- * Resets the active item to -1 so arrow events will activate the
660
- * correct options, or to 0 if the consumer opted into it.
661
- */
662
- resetActiveItem() {
663
- if (this.autocomplete.autoActiveFirstOption) {
664
- this.autocomplete.keyManager.setFirstItemActive();
665
- }
666
- else {
667
- this.autocomplete.keyManager.setActiveItem(-1);
668
- }
669
- }
670
- canOpen() {
671
- const element = this.elementRef.nativeElement;
672
- return !element.readOnly && !element.disabled && !this._autocompleteDisabled;
673
- }
674
- }
675
- /** @nocollapse */ /** @nocollapse */ McAutocompleteTrigger.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.7", ngImport: i0, type: McAutocompleteTrigger, deps: [{ token: i0.ElementRef }, { token: i0.ViewContainerRef }, { token: i0.ChangeDetectorRef }, { token: i1$1.Overlay }, { token: i0.NgZone }, { token: MC_AUTOCOMPLETE_SCROLL_STRATEGY }, { token: i2.Directionality, optional: true }, { token: i3.McFormField, host: true, optional: true }, { token: DOCUMENT, optional: true }, { token: i4.ViewportRuler }], target: i0.ɵɵFactoryTarget.Directive });
676
- /** @nocollapse */ /** @nocollapse */ McAutocompleteTrigger.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.7", type: McAutocompleteTrigger, selector: "input[mcAutocomplete], textarea[mcAutocomplete]", inputs: { autocomplete: ["mcAutocomplete", "autocomplete"], connectedTo: ["mcAutocompleteConnectedTo", "connectedTo"], autocompleteAttribute: ["autocomplete", "autocompleteAttribute"], autocompleteDisabled: ["mcAutocompleteDisabled", "autocompleteDisabled"] }, host: { listeners: { "focusin": "handleFocus()", "blur": "onTouched()", "input": "handleInput($event)", "keydown": "handleKeydown($event)", "click": "handleClick($event)" }, properties: { "attr.autocomplete": "autocompleteAttribute" }, classAttribute: "mc-autocomplete-trigger" }, providers: [MAT_AUTOCOMPLETE_VALUE_ACCESSOR], exportAs: ["mcAutocompleteTrigger"], ngImport: i0 });
677
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.7", ngImport: i0, type: McAutocompleteTrigger, decorators: [{
678
- type: Directive,
679
- args: [{
680
- selector: `input[mcAutocomplete], textarea[mcAutocomplete]`,
681
- host: {
682
- class: 'mc-autocomplete-trigger',
683
- '[attr.autocomplete]': 'autocompleteAttribute',
684
- // Note: we use `focusin`, as opposed to `focus`, in order to open the panel
685
- // a little earlier. This avoids issues where IE delays the focusing of the input.
686
- '(focusin)': 'handleFocus()',
687
- '(blur)': 'onTouched()',
688
- '(input)': 'handleInput($event)',
689
- '(keydown)': 'handleKeydown($event)',
690
- '(click)': 'handleClick($event)'
691
- },
692
- exportAs: 'mcAutocompleteTrigger',
693
- providers: [MAT_AUTOCOMPLETE_VALUE_ACCESSOR]
694
- }]
695
- }], ctorParameters: function () {
696
- return [{ type: i0.ElementRef }, { type: i0.ViewContainerRef }, { type: i0.ChangeDetectorRef }, { type: i1$1.Overlay }, { type: i0.NgZone }, { type: undefined, decorators: [{
697
- type: Inject,
698
- args: [MC_AUTOCOMPLETE_SCROLL_STRATEGY]
699
- }] }, { type: i2.Directionality, decorators: [{
700
- type: Optional
701
- }] }, { type: i3.McFormField, decorators: [{
702
- type: Optional
703
- }, {
704
- type: Host
705
- }] }, { type: undefined, decorators: [{
706
- type: Optional
707
- }, {
708
- type: Inject,
709
- args: [DOCUMENT]
710
- }] }, { type: i4.ViewportRuler }];
711
- }, propDecorators: { autocomplete: [{
712
- type: Input,
713
- args: ['mcAutocomplete']
714
- }], connectedTo: [{
715
- type: Input,
716
- args: ['mcAutocompleteConnectedTo']
717
- }], autocompleteAttribute: [{
718
- type: Input,
719
- args: ['autocomplete']
720
- }], autocompleteDisabled: [{
721
- type: Input,
722
- args: ['mcAutocompleteDisabled']
188
+ /**
189
+ * The following style constants are necessary to save here in order
190
+ * to properly calculate the scrollTop of the panel. Because we are not
191
+ * actually focusing the active item, scroll must be handled manually.
192
+ */
193
+ /** The height of each autocomplete option. */
194
+ const AUTOCOMPLETE_OPTION_HEIGHT = 32;
195
+ /** The total height of the autocomplete panel. */
196
+ const AUTOCOMPLETE_PANEL_HEIGHT = 256;
197
+ const AUTOCOMPLETE_BORDER_WIDTH = 2;
198
+ /** Injection token that determines the scroll handling while the autocomplete panel is open. */
199
+ const MC_AUTOCOMPLETE_SCROLL_STRATEGY = new InjectionToken('mc-autocomplete-scroll-strategy');
200
+ // tslint:disable-next-line naming-convention
201
+ function MC_AUTOCOMPLETE_SCROLL_STRATEGY_FACTORY(overlay) {
202
+ return () => overlay.scrollStrategies.reposition();
203
+ }
204
+ const MC_AUTOCOMPLETE_SCROLL_STRATEGY_FACTORY_PROVIDER = {
205
+ provide: MC_AUTOCOMPLETE_SCROLL_STRATEGY,
206
+ deps: [Overlay],
207
+ useFactory: MC_AUTOCOMPLETE_SCROLL_STRATEGY_FACTORY
208
+ };
209
+ /**
210
+ * Provider that allows the autocomplete to register as a ControlValueAccessor.
211
+ * @docs-private
212
+ */
213
+ const MAT_AUTOCOMPLETE_VALUE_ACCESSOR = {
214
+ provide: NG_VALUE_ACCESSOR,
215
+ useExisting: forwardRef(() => McAutocompleteTrigger),
216
+ multi: true
217
+ };
218
+ /**
219
+ * Creates an error to be thrown when attempting to use an autocomplete trigger without a panel.
220
+ * @docs-private
221
+ */
222
+ function getMcAutocompleteMissingPanelError() {
223
+ return Error('Attempting to open an undefined instance of `mc-autocomplete`. ' +
224
+ 'Make sure that the id passed to the `mcAutocomplete` is correct and that ' +
225
+ 'you\'re attempting to open it after the ngAfterContentInit hook.');
226
+ }
227
+ class McAutocompleteTrigger {
228
+ constructor(elementRef, viewContainerRef, changeDetectorRef, overlay, zone, scrollStrategy, dir, formField, document,
229
+ // @breaking-change 8.0.0 Make `_viewportRuler` required.
230
+ viewportRuler) {
231
+ this.elementRef = elementRef;
232
+ this.viewContainerRef = viewContainerRef;
233
+ this.changeDetectorRef = changeDetectorRef;
234
+ this.overlay = overlay;
235
+ this.zone = zone;
236
+ this.dir = dir;
237
+ this.formField = formField;
238
+ this.document = document;
239
+ this.viewportRuler = viewportRuler;
240
+ // @ts-ignore
241
+ this.optionSelections = defer(() => {
242
+ if (this.autocomplete && this.autocomplete.options) {
243
+ return merge(...this.autocomplete.options.map((option) => option.onSelectionChange));
244
+ }
245
+ // If there are any subscribers before `ngAfterViewInit`, the `autocomplete` will be undefined.
246
+ // Return a stream that we'll replace with the real one once everything is in place.
247
+ return this.zone.onStable
248
+ .asObservable()
249
+ .pipe(take(1), switchMap(() => this.optionSelections));
250
+ });
251
+ /**
252
+ * `autocomplete` attribute to be set on the input element.
253
+ * @docs-private
254
+ */
255
+ this.autocompleteAttribute = 'off';
256
+ this._autocompleteDisabled = false;
257
+ this.overlayAttached = false;
258
+ this.componentDestroyed = false;
259
+ /** Subscription to viewport size changes. */
260
+ this.viewportSubscription = Subscription.EMPTY;
261
+ /**
262
+ * Whether the autocomplete can open the next time it is focused. Used to prevent a focused,
263
+ * closed autocomplete from being reopened if the user switches to another browser tab and then
264
+ * comes back.
265
+ */
266
+ this.canOpenOnNextFocus = true;
267
+ /** Stream of keyboard events that can close the panel. */
268
+ this.closeKeyEventStream = new Subject();
269
+ /** `View -> model callback called when value changes` */
270
+ // tslint:disable-next-line no-empty
271
+ this.onChange = () => { };
272
+ /** `View -> model callback called when autocomplete has been touched` */
273
+ // tslint:disable-next-line no-empty
274
+ this.onTouched = () => { };
275
+ /**
276
+ * Event handler for when the window is blurred. Needs to be an
277
+ * arrow function in order to preserve the context.
278
+ */
279
+ this.windowBlurHandler = () => {
280
+ // If the user blurred the window while the autocomplete is focused, it means that it'll be
281
+ // refocused when they come back. In this case we want to skip the first focus event, if the
282
+ // pane was closed, in order to avoid reopening it unintentionally.
283
+ this.canOpenOnNextFocus = this.document.activeElement !== this.elementRef.nativeElement || this.panelOpen;
284
+ };
285
+ // tslint:disable-next-line no-typeof-undefined
286
+ if (typeof window !== 'undefined') {
287
+ zone.runOutsideAngular(() => {
288
+ window.addEventListener('blur', this.windowBlurHandler);
289
+ });
290
+ }
291
+ this.scrollStrategy = scrollStrategy;
292
+ }
293
+ /** The currently active option, coerced to MatOption type. */
294
+ get activeOption() {
295
+ if (this.autocomplete && this.autocomplete.keyManager) {
296
+ return this.autocomplete.keyManager.activeItem;
297
+ }
298
+ return null;
299
+ }
300
+ get panelOpen() {
301
+ return this.overlayAttached && this.autocomplete.showPanel;
302
+ }
303
+ /**
304
+ * Whether the autocomplete is disabled. When disabled, the element will
305
+ * act as a regular input and the user won't be able to open the panel.
306
+ */
307
+ get autocompleteDisabled() {
308
+ return this._autocompleteDisabled;
309
+ }
310
+ set autocompleteDisabled(value) {
311
+ this._autocompleteDisabled = coerceBooleanProperty(value);
312
+ }
313
+ ngOnDestroy() {
314
+ // tslint:disable-next-line no-typeof-undefined
315
+ if (typeof window !== 'undefined') {
316
+ window.removeEventListener('blur', this.windowBlurHandler);
317
+ }
318
+ this.viewportSubscription.unsubscribe();
319
+ this.componentDestroyed = true;
320
+ this.destroyPanel();
321
+ this.closeKeyEventStream.complete();
322
+ }
323
+ /** Opens the autocomplete suggestion panel. */
324
+ openPanel() {
325
+ this.attachOverlay();
326
+ }
327
+ closePanel() {
328
+ if (!this.overlayAttached) {
329
+ return;
330
+ }
331
+ if (this.panelOpen) {
332
+ this.autocomplete.closed.emit();
333
+ }
334
+ this.autocomplete.isOpen = this.overlayAttached = false;
335
+ if (this.overlayRef && this.overlayRef.hasAttached()) {
336
+ this.overlayRef.detach();
337
+ this.closingActionsSubscription.unsubscribe();
338
+ }
339
+ // Note that in some cases this can end up being called after the component is destroyed.
340
+ // Add a check to ensure that we don't try to run change detection on a destroyed view.
341
+ if (!this.componentDestroyed) {
342
+ // We need to trigger change detection manually, because
343
+ // `fromEvent` doesn't seem to do it at the proper time.
344
+ // This ensures that the label is reset when the
345
+ // user clicks outside.
346
+ this.changeDetectorRef.detectChanges();
347
+ }
348
+ }
349
+ /**
350
+ * Updates the position of the autocomplete suggestion panel to ensure that it fits all options
351
+ * within the viewport.
352
+ */
353
+ updatePosition() {
354
+ if (this.overlayAttached) {
355
+ this.overlayRef.updatePosition();
356
+ }
357
+ }
358
+ /**
359
+ * A stream of actions that should close the autocomplete panel, including
360
+ * when an option is selected, on blur, and when TAB is pressed.
361
+ */
362
+ get panelClosingActions() {
363
+ return merge(this.optionSelections, this.autocomplete.keyManager.tabOut.pipe(filter(() => this.overlayAttached)), this.closeKeyEventStream, this.getOutsideClickStream(), this.overlayRef ?
364
+ this.overlayRef.detachments().pipe(filter(() => this.overlayAttached)) :
365
+ of()).pipe(
366
+ // Normalize the output so we return a consistent type.
367
+ map((event) => event instanceof McOptionSelectionChange ? event : null));
368
+ }
369
+ // Implemented as part of ControlValueAccessor.
370
+ writeValue(value) {
371
+ Promise.resolve(null).then(() => this.setTriggerValue(value));
372
+ }
373
+ // Implemented as part of ControlValueAccessor.
374
+ registerOnChange(fn) {
375
+ this.onChange = fn;
376
+ }
377
+ // Implemented as part of ControlValueAccessor.
378
+ registerOnTouched(fn) {
379
+ this.onTouched = fn;
380
+ }
381
+ // Implemented as part of ControlValueAccessor.
382
+ setDisabledState(isDisabled) {
383
+ this.elementRef.nativeElement.disabled = isDisabled;
384
+ }
385
+ handleKeydown(event) {
386
+ // tslint:disable-next-line deprecation
387
+ const keyCode = event.keyCode;
388
+ // Prevent the default action on all escape key presses. This is here primarily to bring IE
389
+ // in line with other browsers. By default, pressing escape on IE will cause it to revert
390
+ // the input value to the one that it had on focus, however it won't dispatch any events
391
+ // which means that the model value will be out of sync with the view.
392
+ if (keyCode === ESCAPE) {
393
+ event.preventDefault();
394
+ }
395
+ if (this.activeOption && keyCode === ENTER && this.panelOpen) {
396
+ this.activeOption.selectViaInteraction();
397
+ this.resetActiveItem();
398
+ event.preventDefault();
399
+ }
400
+ else if (this.autocomplete) {
401
+ const prevActiveItem = this.autocomplete.keyManager.activeItem;
402
+ if (this.panelOpen || keyCode === TAB) {
403
+ this.autocomplete.onKeydown(event);
404
+ }
405
+ else if (keyCode === DOWN_ARROW && this.canOpen()) {
406
+ this.openPanel();
407
+ }
408
+ const isArrowKey = keyCode === UP_ARROW || keyCode === DOWN_ARROW;
409
+ if (isArrowKey || this.autocomplete.keyManager.activeItem !== prevActiveItem) {
410
+ this.scrollToOption();
411
+ }
412
+ }
413
+ }
414
+ handleInput(event) {
415
+ const target = event.target;
416
+ let value = target.value;
417
+ // Based on `NumberValueAccessor` from forms.
418
+ if (target.type === 'number') {
419
+ value = value === '' ? null : parseFloat(value);
420
+ }
421
+ // If the input has a placeholder, IE will fire the `input` event on page load,
422
+ // focus and blur, in addition to when the user actually changed the value. To
423
+ // filter out all of the extra events, we save the value on focus and between
424
+ // `input` events, and we check whether it changed.
425
+ // See: https://connect.microsoft.com/IE/feedback/details/885747/
426
+ if (this.previousValue !== value) {
427
+ this.previousValue = value;
428
+ this.onChange(value);
429
+ if (this.canOpen() && this.document.activeElement === event.target) {
430
+ this.openPanel();
431
+ }
432
+ }
433
+ }
434
+ handleFocus() {
435
+ if (!this.canOpenOnNextFocus) {
436
+ this.canOpenOnNextFocus = true;
437
+ }
438
+ else if (this.canOpen() && this.autocomplete.openOnFocus) {
439
+ this.previousValue = this.elementRef.nativeElement.value;
440
+ this.attachOverlay();
441
+ }
442
+ }
443
+ handleClick($event) {
444
+ if (this.canOpen() && this.document.activeElement === $event.target) {
445
+ this.openPanel();
446
+ }
447
+ }
448
+ /** Stream of clicks outside of the autocomplete panel. */
449
+ getOutsideClickStream() {
450
+ return merge(
451
+ // tslint:disable-next-line: no-unnecessary-type-assertion
452
+ fromEvent(this.document, 'click'),
453
+ // tslint:disable-next-line: no-unnecessary-type-assertion
454
+ fromEvent(this.document, 'touchend'))
455
+ .pipe(filter((event) => {
456
+ const clickTarget = event.target;
457
+ const formField = this.formField ? this.formField._elementRef.nativeElement : null;
458
+ const customOrigin = this.connectedTo ? this.connectedTo.elementRef.nativeElement : null;
459
+ return this.overlayAttached &&
460
+ clickTarget !== this.elementRef.nativeElement &&
461
+ (!formField || !formField.contains(clickTarget)) &&
462
+ (!customOrigin || !customOrigin.contains(clickTarget)) &&
463
+ (!!this.overlayRef && !this.overlayRef.overlayElement.contains(clickTarget));
464
+ }));
465
+ }
466
+ /**
467
+ * Given that we are not actually focusing active options, we must manually adjust scroll
468
+ * to reveal options below the fold. First, we find the offset of the option from the top
469
+ * of the panel. If that offset is below the fold, the new scrollTop will be the offset -
470
+ * the panel height + the option height, so the active option will be just visible at the
471
+ * bottom of the panel. If that offset is above the top of the visible panel, the new scrollTop
472
+ * will become the offset. If that offset is visible within the panel already, the scrollTop is
473
+ * not adjusted.
474
+ */
475
+ scrollToOption() {
476
+ const index = this.autocomplete.keyManager.activeItemIndex || 0;
477
+ const labelCount = countGroupLabelsBeforeOption(index, this.autocomplete.options, this.autocomplete.optionGroups);
478
+ const newScrollPosition = getOptionScrollPosition(index + labelCount, AUTOCOMPLETE_OPTION_HEIGHT, this.autocomplete.getScrollTop(), AUTOCOMPLETE_PANEL_HEIGHT);
479
+ this.autocomplete.setScrollTop(newScrollPosition);
480
+ }
481
+ /**
482
+ * This method listens to a stream of panel closing actions and resets the
483
+ * stream every time the option list changes.
484
+ */
485
+ subscribeToClosingActions() {
486
+ const firstStable = this.zone.onStable.asObservable()
487
+ .pipe(take(1));
488
+ const optionChanges = this.autocomplete.options.changes
489
+ .pipe(tap(() => this.positionStrategy.reapplyLastPosition()),
490
+ // Defer emitting to the stream until the next tick, because changing
491
+ // bindings in here will cause "changed after checked" errors.
492
+ delay(0));
493
+ // When the zone is stable initially, and when the option list changes...
494
+ return merge(firstStable, optionChanges)
495
+ .pipe(
496
+ // create a new stream of panelClosingActions, replacing any previous streams
497
+ // that were created, and flatten it so our stream only emits closing events...
498
+ switchMap(() => {
499
+ const wasOpen = this.panelOpen;
500
+ this.resetActiveItem();
501
+ this.autocomplete.setVisibility();
502
+ if (this.panelOpen) {
503
+ this.overlayRef.updatePosition();
504
+ // If the `panelOpen` state changed, we need to make sure to emit the `opened`
505
+ // event, because we may not have emitted it when the panel was attached. This
506
+ // can happen if the users opens the panel and there are no options, but the
507
+ // options come in slightly later or as a result of the value changing.
508
+ if (wasOpen !== this.panelOpen) {
509
+ this.autocomplete.opened.emit();
510
+ }
511
+ }
512
+ return this.panelClosingActions;
513
+ }),
514
+ // when the first closing event occurs...
515
+ take(1))
516
+ // set the value, close the panel, and complete.
517
+ .subscribe((event) => this.setValueAndClose(event));
518
+ }
519
+ /** Destroys the autocomplete suggestion panel. */
520
+ destroyPanel() {
521
+ if (this.overlayRef) {
522
+ this.closePanel();
523
+ this.overlayRef.dispose();
524
+ this.overlayRef = null;
525
+ }
526
+ }
527
+ setTriggerValue(value) {
528
+ const toDisplay = this.autocomplete && this.autocomplete.displayWith ?
529
+ this.autocomplete.displayWith(value) :
530
+ value;
531
+ // Simply falling back to an empty string if the display value is falsy does not work properly.
532
+ // The display value can also be the number zero and shouldn't fall back to an empty string.
533
+ const inputValue = toDisplay != null ? toDisplay : '';
534
+ // If it's used within a `MatFormField`, we should set it through the property so it can go
535
+ // through change detection.
536
+ if (this.formField) {
537
+ this.formField.control.value = inputValue;
538
+ }
539
+ else {
540
+ this.elementRef.nativeElement.value = inputValue;
541
+ }
542
+ this.previousValue = inputValue;
543
+ }
544
+ /** This method closes the panel, and if a value is specified, also sets the associated
545
+ * control to that value. It will also mark the control as dirty if this interaction
546
+ * stemmed from the user.
547
+ */
548
+ setValueAndClose(event) {
549
+ if (event && event.source) {
550
+ this.clearPreviousSelectedOption(event.source);
551
+ this.setTriggerValue(event.source.value);
552
+ this.onChange(event.source.value);
553
+ this.elementRef.nativeElement.focus();
554
+ this.autocomplete.emitSelectEvent(event.source);
555
+ }
556
+ this.closePanel();
557
+ }
558
+ /** Clear any previous selected option and emit a selection change event for this option */
559
+ clearPreviousSelectedOption(skip) {
560
+ this.autocomplete.options.forEach((option) => {
561
+ if (option !== skip && option.selected) {
562
+ option.deselect();
563
+ }
564
+ });
565
+ }
566
+ attachOverlay() {
567
+ if (!this.autocomplete) {
568
+ throw getMcAutocompleteMissingPanelError();
569
+ }
570
+ let overlayRef = this.overlayRef;
571
+ if (!overlayRef) {
572
+ this.portal = new TemplatePortal(this.autocomplete.template, this.viewContainerRef);
573
+ overlayRef = this.overlay.create(this.getOverlayConfig());
574
+ this.overlayRef = overlayRef;
575
+ // Use the `keydownEvents` in order to take advantage of
576
+ // the overlay event targeting provided by the CDK overlay.
577
+ overlayRef.keydownEvents().subscribe((event) => {
578
+ // Close when pressing ESCAPE or ALT + UP_ARROW, based on the a11y guidelines.
579
+ // See: https://www.w3.org/TR/wai-aria-practices-1.1/#textbox-keyboard-interaction
580
+ // tslint:disable-next-line deprecation
581
+ if (event.keyCode === ESCAPE || (event.keyCode === UP_ARROW && event.altKey)) {
582
+ this.resetActiveItem();
583
+ this.closeKeyEventStream.next();
584
+ }
585
+ });
586
+ if (this.viewportRuler) {
587
+ this.viewportSubscription = this.viewportRuler.change().subscribe(() => {
588
+ if (this.panelOpen && overlayRef) {
589
+ overlayRef.updateSize({ width: this.getPanelWidth() });
590
+ }
591
+ });
592
+ }
593
+ }
594
+ else {
595
+ const position = overlayRef.getConfig().positionStrategy;
596
+ // Update the trigger, panel width and direction, in case anything has changed.
597
+ position.setOrigin(this.getConnectedElement());
598
+ overlayRef.updateSize({ width: this.getPanelWidth() });
599
+ }
600
+ if (overlayRef && !overlayRef.hasAttached()) {
601
+ overlayRef.attach(this.portal);
602
+ this.closingActionsSubscription = this.subscribeToClosingActions();
603
+ }
604
+ const wasOpen = this.panelOpen;
605
+ this.autocomplete.setVisibility();
606
+ this.autocomplete.isOpen = this.overlayAttached = true;
607
+ // We need to do an extra `panelOpen` check in here, because the
608
+ // autocomplete won't be shown if there are no options.
609
+ if (this.panelOpen && wasOpen !== this.panelOpen) {
610
+ this.autocomplete.opened.emit();
611
+ }
612
+ }
613
+ getOverlayConfig() {
614
+ return new OverlayConfig({
615
+ positionStrategy: this.getOverlayPosition(),
616
+ scrollStrategy: this.scrollStrategy(),
617
+ width: this.getPanelWidth(),
618
+ direction: this.dir
619
+ });
620
+ }
621
+ getOverlayPosition() {
622
+ this.positionStrategy = this.overlay.position()
623
+ .flexibleConnectedTo(this.getConnectedElement())
624
+ .withFlexibleDimensions(false)
625
+ .withPush(false)
626
+ .withPositions([
627
+ {
628
+ originX: 'start',
629
+ originY: 'bottom',
630
+ overlayX: 'start',
631
+ overlayY: 'top'
632
+ },
633
+ {
634
+ originX: 'start',
635
+ originY: 'top',
636
+ overlayX: 'start',
637
+ overlayY: 'bottom',
638
+ // The overlay edge connected to the trigger should have squared corners, while
639
+ // the opposite end has rounded corners. We apply a CSS class to swap the
640
+ // border-radius based on the overlay position.
641
+ panelClass: 'mc-autocomplete-panel-above'
642
+ }
643
+ ]);
644
+ return this.positionStrategy;
645
+ }
646
+ getConnectedElement() {
647
+ if (this.connectedTo) {
648
+ return this.connectedTo.elementRef;
649
+ }
650
+ return this.formField ? this.formField.getConnectedOverlayOrigin() : this.elementRef;
651
+ }
652
+ getPanelWidth() {
653
+ return this.autocomplete.panelWidth || this.getHostWidth() - AUTOCOMPLETE_BORDER_WIDTH;
654
+ }
655
+ getHostWidth() {
656
+ return this.getConnectedElement().nativeElement.getBoundingClientRect().width;
657
+ }
658
+ /**
659
+ * Resets the active item to -1 so arrow events will activate the
660
+ * correct options, or to 0 if the consumer opted into it.
661
+ */
662
+ resetActiveItem() {
663
+ if (this.autocomplete.autoActiveFirstOption) {
664
+ this.autocomplete.keyManager.setFirstItemActive();
665
+ }
666
+ else {
667
+ this.autocomplete.keyManager.setActiveItem(-1);
668
+ }
669
+ }
670
+ canOpen() {
671
+ const element = this.elementRef.nativeElement;
672
+ return !element.readOnly && !element.disabled && !this._autocompleteDisabled;
673
+ }
674
+ }
675
+ /** @nocollapse */ /** @nocollapse */ McAutocompleteTrigger.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: McAutocompleteTrigger, deps: [{ token: i0.ElementRef }, { token: i0.ViewContainerRef }, { token: i0.ChangeDetectorRef }, { token: i1$1.Overlay }, { token: i0.NgZone }, { token: MC_AUTOCOMPLETE_SCROLL_STRATEGY }, { token: i2.Directionality, optional: true }, { token: i3.McFormField, host: true, optional: true }, { token: DOCUMENT, optional: true }, { token: i4.ViewportRuler }], target: i0.ɵɵFactoryTarget.Directive });
676
+ /** @nocollapse */ /** @nocollapse */ McAutocompleteTrigger.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.11", type: McAutocompleteTrigger, selector: "input[mcAutocomplete], textarea[mcAutocomplete]", inputs: { autocomplete: ["mcAutocomplete", "autocomplete"], connectedTo: ["mcAutocompleteConnectedTo", "connectedTo"], autocompleteAttribute: ["autocomplete", "autocompleteAttribute"], autocompleteDisabled: ["mcAutocompleteDisabled", "autocompleteDisabled"] }, host: { listeners: { "focusin": "handleFocus()", "blur": "onTouched()", "input": "handleInput($event)", "keydown": "handleKeydown($event)", "click": "handleClick($event)" }, properties: { "attr.autocomplete": "autocompleteAttribute" }, classAttribute: "mc-autocomplete-trigger" }, providers: [MAT_AUTOCOMPLETE_VALUE_ACCESSOR], exportAs: ["mcAutocompleteTrigger"], ngImport: i0 });
677
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: McAutocompleteTrigger, decorators: [{
678
+ type: Directive,
679
+ args: [{
680
+ selector: `input[mcAutocomplete], textarea[mcAutocomplete]`,
681
+ host: {
682
+ class: 'mc-autocomplete-trigger',
683
+ '[attr.autocomplete]': 'autocompleteAttribute',
684
+ // Note: we use `focusin`, as opposed to `focus`, in order to open the panel
685
+ // a little earlier. This avoids issues where IE delays the focusing of the input.
686
+ '(focusin)': 'handleFocus()',
687
+ '(blur)': 'onTouched()',
688
+ '(input)': 'handleInput($event)',
689
+ '(keydown)': 'handleKeydown($event)',
690
+ '(click)': 'handleClick($event)'
691
+ },
692
+ exportAs: 'mcAutocompleteTrigger',
693
+ providers: [MAT_AUTOCOMPLETE_VALUE_ACCESSOR]
694
+ }]
695
+ }], ctorParameters: function () {
696
+ return [{ type: i0.ElementRef }, { type: i0.ViewContainerRef }, { type: i0.ChangeDetectorRef }, { type: i1$1.Overlay }, { type: i0.NgZone }, { type: undefined, decorators: [{
697
+ type: Inject,
698
+ args: [MC_AUTOCOMPLETE_SCROLL_STRATEGY]
699
+ }] }, { type: i2.Directionality, decorators: [{
700
+ type: Optional
701
+ }] }, { type: i3.McFormField, decorators: [{
702
+ type: Optional
703
+ }, {
704
+ type: Host
705
+ }] }, { type: undefined, decorators: [{
706
+ type: Optional
707
+ }, {
708
+ type: Inject,
709
+ args: [DOCUMENT]
710
+ }] }, { type: i4.ViewportRuler }];
711
+ }, propDecorators: { autocomplete: [{
712
+ type: Input,
713
+ args: ['mcAutocomplete']
714
+ }], connectedTo: [{
715
+ type: Input,
716
+ args: ['mcAutocompleteConnectedTo']
717
+ }], autocompleteAttribute: [{
718
+ type: Input,
719
+ args: ['autocomplete']
720
+ }], autocompleteDisabled: [{
721
+ type: Input,
722
+ args: ['mcAutocompleteDisabled']
723
723
  }] } });
724
724
 
725
- class McAutocompleteModule {
726
- }
727
- /** @nocollapse */ /** @nocollapse */ McAutocompleteModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.7", ngImport: i0, type: McAutocompleteModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
728
- /** @nocollapse */ /** @nocollapse */ McAutocompleteModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.3.7", ngImport: i0, type: McAutocompleteModule, declarations: [McAutocomplete, McAutocompleteTrigger, McAutocompleteOrigin], imports: [McOptionModule, OverlayModule, McCommonModule, CommonModule], exports: [McAutocomplete,
729
- McOptionModule,
730
- McAutocompleteTrigger,
731
- McAutocompleteOrigin,
732
- McCommonModule] });
733
- /** @nocollapse */ /** @nocollapse */ McAutocompleteModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.3.7", ngImport: i0, type: McAutocompleteModule, providers: [MC_AUTOCOMPLETE_SCROLL_STRATEGY_FACTORY_PROVIDER], imports: [[McOptionModule, OverlayModule, McCommonModule, CommonModule], McOptionModule,
734
- McCommonModule] });
735
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.7", ngImport: i0, type: McAutocompleteModule, decorators: [{
736
- type: NgModule,
737
- args: [{
738
- imports: [McOptionModule, OverlayModule, McCommonModule, CommonModule],
739
- exports: [
740
- McAutocomplete,
741
- McOptionModule,
742
- McAutocompleteTrigger,
743
- McAutocompleteOrigin,
744
- McCommonModule
745
- ],
746
- declarations: [McAutocomplete, McAutocompleteTrigger, McAutocompleteOrigin],
747
- providers: [MC_AUTOCOMPLETE_SCROLL_STRATEGY_FACTORY_PROVIDER]
748
- }]
725
+ class McAutocompleteModule {
726
+ }
727
+ /** @nocollapse */ /** @nocollapse */ McAutocompleteModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: McAutocompleteModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
728
+ /** @nocollapse */ /** @nocollapse */ McAutocompleteModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: McAutocompleteModule, declarations: [McAutocomplete, McAutocompleteTrigger, McAutocompleteOrigin], imports: [McOptionModule, OverlayModule, McCommonModule, CommonModule], exports: [McAutocomplete,
729
+ McOptionModule,
730
+ McAutocompleteTrigger,
731
+ McAutocompleteOrigin,
732
+ McCommonModule] });
733
+ /** @nocollapse */ /** @nocollapse */ McAutocompleteModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: McAutocompleteModule, providers: [MC_AUTOCOMPLETE_SCROLL_STRATEGY_FACTORY_PROVIDER], imports: [[McOptionModule, OverlayModule, McCommonModule, CommonModule], McOptionModule,
734
+ McCommonModule] });
735
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: McAutocompleteModule, decorators: [{
736
+ type: NgModule,
737
+ args: [{
738
+ imports: [McOptionModule, OverlayModule, McCommonModule, CommonModule],
739
+ exports: [
740
+ McAutocomplete,
741
+ McOptionModule,
742
+ McAutocompleteTrigger,
743
+ McAutocompleteOrigin,
744
+ McCommonModule
745
+ ],
746
+ declarations: [McAutocomplete, McAutocompleteTrigger, McAutocompleteOrigin],
747
+ providers: [MC_AUTOCOMPLETE_SCROLL_STRATEGY_FACTORY_PROVIDER]
748
+ }]
749
749
  }] });
750
750
 
751
- /**
752
- * Generated bundle index. Do not edit.
751
+ /**
752
+ * Generated bundle index. Do not edit.
753
753
  */
754
754
 
755
755
  export { AUTOCOMPLETE_BORDER_WIDTH, AUTOCOMPLETE_OPTION_HEIGHT, AUTOCOMPLETE_PANEL_HEIGHT, MAT_AUTOCOMPLETE_VALUE_ACCESSOR, MC_AUTOCOMPLETE_DEFAULT_OPTIONS, MC_AUTOCOMPLETE_DEFAULT_OPTIONS_FACTORY, MC_AUTOCOMPLETE_SCROLL_STRATEGY, MC_AUTOCOMPLETE_SCROLL_STRATEGY_FACTORY, MC_AUTOCOMPLETE_SCROLL_STRATEGY_FACTORY_PROVIDER, McAutocomplete, McAutocompleteModule, McAutocompleteOrigin, McAutocompleteSelectedEvent, McAutocompleteTrigger, getMcAutocompleteMissingPanelError };