@ptsecurity/mosaic 13.6.1 → 13.7.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (907) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +6 -6
  3. package/_theming.scss +7238 -7141
  4. package/_visual.scss +2724 -2695
  5. package/autocomplete/autocomplete-origin.directive.d.ts +12 -12
  6. package/autocomplete/autocomplete-trigger.directive.d.ts +167 -167
  7. package/autocomplete/autocomplete.component.d.ts +73 -73
  8. package/autocomplete/autocomplete.module.d.ts +12 -12
  9. package/autocomplete/index.d.ts +1 -1
  10. package/autocomplete/ptsecurity-mosaic-autocomplete.d.ts +5 -5
  11. package/autocomplete/public-api.d.ts +4 -4
  12. package/button/button.component.d.ts +40 -40
  13. package/button/button.module.d.ts +10 -10
  14. package/button/index.d.ts +1 -1
  15. package/button/ptsecurity-mosaic-button.d.ts +5 -5
  16. package/button/public-api.d.ts +2 -2
  17. package/button-toggle/button-toggle.component.d.ts +141 -141
  18. package/button-toggle/button-toggle.module.d.ts +9 -9
  19. package/button-toggle/index.d.ts +1 -1
  20. package/button-toggle/ptsecurity-mosaic-button-toggle.d.ts +5 -5
  21. package/button-toggle/public-api.d.ts +2 -2
  22. package/card/card.component.d.ts +26 -26
  23. package/card/card.module.d.ts +10 -10
  24. package/card/index.d.ts +1 -1
  25. package/card/ptsecurity-mosaic-card.d.ts +5 -5
  26. package/card/public-api.d.ts +2 -2
  27. package/checkbox/README.md +1 -1
  28. package/checkbox/checkbox-config.d.ts +13 -13
  29. package/checkbox/checkbox-module.d.ts +9 -9
  30. package/checkbox/checkbox-required-validator.d.ts +13 -13
  31. package/checkbox/checkbox.d.ts +140 -140
  32. package/checkbox/index.d.ts +1 -1
  33. package/checkbox/ptsecurity-mosaic-checkbox.d.ts +5 -5
  34. package/checkbox/public-api.d.ts +4 -4
  35. package/core/animation/animation.d.ts +6 -6
  36. package/core/animation/fade-animations.d.ts +2 -2
  37. package/core/animation/index.d.ts +3 -3
  38. package/core/animation/select-animations.d.ts +12 -12
  39. package/core/common-behaviors/color.d.ts +19 -19
  40. package/core/common-behaviors/common-module.d.ts +25 -25
  41. package/core/common-behaviors/constructor.d.ts +9 -9
  42. package/core/common-behaviors/disabled.d.ts +8 -8
  43. package/core/common-behaviors/error-state.d.ts +25 -25
  44. package/core/common-behaviors/index.d.ts +5 -5
  45. package/core/common-behaviors/tabindex.d.ts +8 -8
  46. package/core/error/error-options.d.ts +14 -14
  47. package/core/formatters/date/formatter.d.ts +203 -203
  48. package/core/formatters/date/templates/en-US.d.ts +74 -74
  49. package/core/formatters/date/templates/ru-RU.d.ts +74 -74
  50. package/core/formatters/index.d.ts +9 -9
  51. package/core/formatters/number/formatter.d.ts +27 -27
  52. package/core/forms/forms-module.d.ts +7 -7
  53. package/core/forms/forms.directive.d.ts +22 -22
  54. package/core/forms/index.d.ts +2 -2
  55. package/core/highlight/highlight.pipe.d.ts +7 -7
  56. package/core/highlight/index.d.ts +9 -9
  57. package/core/index.d.ts +1 -1
  58. package/core/label/label-options.d.ts +13 -13
  59. package/core/line/line.d.ts +28 -28
  60. package/core/option/action.d.ts +42 -42
  61. package/core/option/index.d.ts +4 -4
  62. package/core/option/optgroup.d.ts +16 -16
  63. package/core/option/option-module.d.ts +11 -11
  64. package/core/option/option.d.ts +115 -115
  65. package/core/overlay/overlay-position-map.d.ts +34 -34
  66. package/core/pop-up/constants.d.ts +29 -29
  67. package/core/pop-up/index.d.ts +3 -3
  68. package/core/pop-up/pop-up-trigger.d.ts +70 -70
  69. package/core/pop-up/pop-up.d.ts +36 -36
  70. package/core/ptsecurity-mosaic-core.d.ts +5 -5
  71. package/core/public-api.d.ts +17 -17
  72. package/core/select/constants.d.ts +23 -23
  73. package/core/select/errors.d.ts +19 -19
  74. package/core/select/events.d.ts +1 -1
  75. package/core/select/index.d.ts +3 -3
  76. package/core/selection/constants.d.ts +4 -4
  77. package/core/selection/index.d.ts +3 -3
  78. package/core/selection/pseudo-checkbox/pseudo-checkbox.d.ts +30 -30
  79. package/core/selection/pseudo-checkbox/pseudo-checkbox.module.d.ts +8 -8
  80. package/core/services/measure-scrollbar.service.d.ts +11 -11
  81. package/core/utils/index.d.ts +1 -1
  82. package/core/utils/public-api.d.ts +1 -1
  83. package/core/utils/utils.d.ts +2 -2
  84. package/core/validation/index.d.ts +1 -1
  85. package/core/validation/validation.d.ts +18 -18
  86. package/core/version.d.ts +2 -2
  87. package/datepicker/calendar-body.component.d.ts +63 -63
  88. package/datepicker/calendar.component.d.ts +151 -151
  89. package/datepicker/datepicker-animations.d.ts +9 -9
  90. package/datepicker/datepicker-errors.d.ts +2 -2
  91. package/datepicker/datepicker-input.directive.d.ts +178 -178
  92. package/datepicker/datepicker-intl.d.ts +32 -32
  93. package/datepicker/datepicker-module.d.ts +20 -20
  94. package/datepicker/datepicker-toggle.component.d.ts +35 -35
  95. package/datepicker/datepicker.component.d.ts +158 -158
  96. package/datepicker/index.d.ts +1 -1
  97. package/datepicker/month-view.component.d.ts +93 -93
  98. package/datepicker/multi-year-view.component.d.ts +72 -72
  99. package/datepicker/ptsecurity-mosaic-datepicker.d.ts +5 -5
  100. package/datepicker/public-api.d.ts +11 -11
  101. package/datepicker/year-view.component.d.ts +90 -90
  102. package/design-tokens/index.d.ts +1 -1
  103. package/design-tokens/legacy-2017/tokens/components/alert.json5 +83 -83
  104. package/design-tokens/legacy-2017/tokens/components/autocomplete.json5 +11 -11
  105. package/design-tokens/legacy-2017/tokens/components/badge.json5 +174 -174
  106. package/design-tokens/legacy-2017/tokens/components/button-toggle.json5 +10 -10
  107. package/design-tokens/legacy-2017/tokens/components/button.json5 +142 -142
  108. package/design-tokens/legacy-2017/tokens/components/card.json5 +51 -51
  109. package/design-tokens/legacy-2017/tokens/components/checkbox.json5 +97 -97
  110. package/design-tokens/legacy-2017/tokens/components/datepicker.json5 +64 -64
  111. package/design-tokens/legacy-2017/tokens/components/divider.json5 +14 -14
  112. package/design-tokens/legacy-2017/tokens/components/dl.json5 +38 -38
  113. package/design-tokens/legacy-2017/tokens/components/dropdown.json5 +48 -48
  114. package/design-tokens/legacy-2017/tokens/components/form-field.json5 +92 -92
  115. package/design-tokens/legacy-2017/tokens/components/forms.json5 +52 -52
  116. package/design-tokens/legacy-2017/tokens/components/icon.json5 +104 -104
  117. package/design-tokens/legacy-2017/tokens/components/input.json5 +12 -12
  118. package/design-tokens/legacy-2017/tokens/components/link.json5 +50 -50
  119. package/design-tokens/legacy-2017/tokens/components/list.json5 +13 -13
  120. package/design-tokens/legacy-2017/tokens/components/loader-overlay.json5 +23 -0
  121. package/design-tokens/legacy-2017/tokens/components/modal.json5 +81 -81
  122. package/design-tokens/legacy-2017/tokens/components/navbar.json5 +70 -70
  123. package/design-tokens/legacy-2017/tokens/components/optgroup.json5 +10 -10
  124. package/design-tokens/legacy-2017/tokens/components/option.json5 +12 -12
  125. package/design-tokens/legacy-2017/tokens/components/popover.json5 +68 -68
  126. package/design-tokens/legacy-2017/tokens/components/popup.json5 +16 -16
  127. package/design-tokens/legacy-2017/tokens/components/progress-bar.json5 +13 -13
  128. package/design-tokens/legacy-2017/tokens/components/progress-spinner.json5 +7 -7
  129. package/design-tokens/legacy-2017/tokens/components/radio.json5 +45 -45
  130. package/design-tokens/legacy-2017/tokens/components/select.json5 +24 -24
  131. package/design-tokens/legacy-2017/tokens/components/sidepanel.json5 +44 -44
  132. package/design-tokens/legacy-2017/tokens/components/table.json5 +15 -15
  133. package/design-tokens/legacy-2017/tokens/components/tabs.json5 +101 -101
  134. package/design-tokens/legacy-2017/tokens/components/tags.json5 +134 -134
  135. package/design-tokens/legacy-2017/tokens/components/textarea.json5 +12 -12
  136. package/design-tokens/legacy-2017/tokens/components/timepicker.json5 +7 -7
  137. package/design-tokens/legacy-2017/tokens/components/toggle.json5 +79 -79
  138. package/design-tokens/legacy-2017/tokens/components/tooltip.json5 +83 -83
  139. package/design-tokens/legacy-2017/tokens/components/tree.json5 +15 -15
  140. package/design-tokens/legacy-2017/tokens/properties/aliases.json5 +3 -3
  141. package/design-tokens/legacy-2017/tokens/properties/colors.json5 +119 -119
  142. package/design-tokens/legacy-2017/tokens/properties/font.json5 +12 -12
  143. package/design-tokens/legacy-2017/tokens/properties/globals.json5 +49 -49
  144. package/design-tokens/legacy-2017/tokens/properties/padding.json5 +3 -3
  145. package/design-tokens/legacy-2017/tokens/properties/palette.json5 +163 -163
  146. package/design-tokens/legacy-2017/tokens/properties/typography.json5 +175 -175
  147. package/design-tokens/legacy-2017/tokens.d.ts +7873 -7844
  148. package/design-tokens/pt-2022/tokens/components/alert.json5 +83 -83
  149. package/design-tokens/pt-2022/tokens/components/autocomplete.json5 +11 -11
  150. package/design-tokens/pt-2022/tokens/components/badge.json5 +174 -174
  151. package/design-tokens/pt-2022/tokens/components/button-toggle.json5 +10 -10
  152. package/design-tokens/pt-2022/tokens/components/button.json5 +142 -142
  153. package/design-tokens/pt-2022/tokens/components/card.json5 +51 -51
  154. package/design-tokens/pt-2022/tokens/components/checkbox.json5 +97 -97
  155. package/design-tokens/pt-2022/tokens/components/datepicker.json5 +64 -64
  156. package/design-tokens/pt-2022/tokens/components/divider.json5 +14 -14
  157. package/design-tokens/pt-2022/tokens/components/dl.json5 +38 -38
  158. package/design-tokens/pt-2022/tokens/components/dropdown.json5 +48 -48
  159. package/design-tokens/pt-2022/tokens/components/form-field.json5 +92 -92
  160. package/design-tokens/pt-2022/tokens/components/forms.json5 +52 -52
  161. package/design-tokens/pt-2022/tokens/components/icon.json5 +104 -104
  162. package/design-tokens/pt-2022/tokens/components/input.json5 +12 -12
  163. package/design-tokens/pt-2022/tokens/components/link.json5 +50 -50
  164. package/design-tokens/pt-2022/tokens/components/list.json5 +13 -13
  165. package/design-tokens/pt-2022/tokens/components/loader-overlay.json5 +23 -0
  166. package/design-tokens/pt-2022/tokens/components/modal.json5 +81 -81
  167. package/design-tokens/pt-2022/tokens/components/navbar.json5 +70 -70
  168. package/design-tokens/pt-2022/tokens/components/optgroup.json5 +10 -10
  169. package/design-tokens/pt-2022/tokens/components/option.json5 +12 -12
  170. package/design-tokens/pt-2022/tokens/components/popover.json5 +68 -68
  171. package/design-tokens/pt-2022/tokens/components/popup.json5 +16 -16
  172. package/design-tokens/pt-2022/tokens/components/progress-bar.json5 +13 -13
  173. package/design-tokens/pt-2022/tokens/components/progress-spinner.json5 +7 -7
  174. package/design-tokens/pt-2022/tokens/components/radio.json5 +45 -45
  175. package/design-tokens/pt-2022/tokens/components/select.json5 +24 -24
  176. package/design-tokens/pt-2022/tokens/components/sidepanel.json5 +44 -44
  177. package/design-tokens/pt-2022/tokens/components/table.json5 +15 -15
  178. package/design-tokens/pt-2022/tokens/components/tabs.json5 +101 -101
  179. package/design-tokens/pt-2022/tokens/components/tags.json5 +137 -137
  180. package/design-tokens/pt-2022/tokens/components/textarea.json5 +12 -12
  181. package/design-tokens/pt-2022/tokens/components/timepicker.json5 +7 -7
  182. package/design-tokens/pt-2022/tokens/components/toggle.json5 +79 -79
  183. package/design-tokens/pt-2022/tokens/components/tooltip.json5 +83 -83
  184. package/design-tokens/pt-2022/tokens/components/tree.json5 +15 -15
  185. package/design-tokens/pt-2022/tokens/properties/aliases.json5 +3 -3
  186. package/design-tokens/pt-2022/tokens/properties/colors.json5 +122 -122
  187. package/design-tokens/pt-2022/tokens/properties/font.json5 +15 -15
  188. package/design-tokens/pt-2022/tokens/properties/globals.json5 +49 -49
  189. package/design-tokens/pt-2022/tokens/properties/padding.json5 +3 -3
  190. package/design-tokens/pt-2022/tokens/properties/palette.json5 +232 -232
  191. package/design-tokens/pt-2022/tokens/properties/typography.json5 +175 -175
  192. package/design-tokens/pt-2022/tokens.d.ts +9205 -9176
  193. package/design-tokens/ptsecurity-mosaic-design-tokens.d.ts +5 -5
  194. package/design-tokens/public-api.d.ts +3 -3
  195. package/design-tokens/style-dictionary/build.js +76 -63
  196. package/design-tokens/style-dictionary/configs/css.js +13 -13
  197. package/design-tokens/style-dictionary/configs/figma.js +11 -0
  198. package/design-tokens/style-dictionary/configs/index.js +48 -48
  199. package/design-tokens/style-dictionary/configs/js.js +9 -9
  200. package/design-tokens/style-dictionary/configs/scss.js +23 -23
  201. package/design-tokens/style-dictionary/figma-types.js +41 -0
  202. package/design-tokens/style-dictionary/filters/color.js +7 -7
  203. package/design-tokens/style-dictionary/filters/palette.js +7 -7
  204. package/design-tokens/style-dictionary/filters/size.js +7 -7
  205. package/design-tokens/style-dictionary/filters/typography.js +7 -7
  206. package/design-tokens/style-dictionary/formats/figma.js +104 -0
  207. package/design-tokens/style-dictionary/formats/palette.js +25 -25
  208. package/design-tokens/style-dictionary/formats/typography.js +52 -52
  209. package/design-tokens/style-dictionary/transformGroups/css.js +13 -13
  210. package/design-tokens/style-dictionary/transformGroups/figma.js +21 -0
  211. package/design-tokens/style-dictionary/transformGroups/scss.js +12 -12
  212. package/design-tokens/style-dictionary/transformGroups/ts.js +11 -11
  213. package/design-tokens/style-dictionary/transforms/attribute/figma-border.js +18 -0
  214. package/design-tokens/style-dictionary/transforms/attribute/figma-color.js +25 -0
  215. package/design-tokens/style-dictionary/transforms/attribute/figma-default.js +10 -0
  216. package/design-tokens/style-dictionary/transforms/attribute/figma-font.js +31 -0
  217. package/design-tokens/style-dictionary/transforms/attribute/figma-group.js +17 -0
  218. package/design-tokens/style-dictionary/transforms/attribute/figma-opacity.js +10 -0
  219. package/design-tokens/style-dictionary/transforms/attribute/figma-shadow.js +66 -0
  220. package/design-tokens/style-dictionary/transforms/attribute/figma-sizing.js +16 -0
  221. package/design-tokens/style-dictionary/transforms/attribute/figma-spacing.js +15 -0
  222. package/design-tokens/style-dictionary/transforms/attribute/figma-typography.js +24 -0
  223. package/design-tokens/style-dictionary/transforms/attribute/palette.js +9 -9
  224. package/design-tokens/style-dictionary/transforms/attribute/prefix.js +11 -11
  225. package/design-tokens/style-dictionary/transforms/attribute/size.js +8 -8
  226. package/design-tokens/style-dictionary/transforms/attribute/typography.js +9 -9
  227. package/design-tokens/style-dictionary/transforms/value/figma-values.js +7 -0
  228. package/divider/divider.component.d.ts +11 -11
  229. package/divider/divider.module.d.ts +8 -8
  230. package/divider/index.d.ts +1 -1
  231. package/divider/ptsecurity-mosaic-divider.d.ts +5 -5
  232. package/divider/public-api.d.ts +2 -2
  233. package/dl/dl.component.d.ts +26 -26
  234. package/dl/dl.module.d.ts +10 -10
  235. package/dl/index.d.ts +1 -1
  236. package/dl/ptsecurity-mosaic-dl.d.ts +5 -5
  237. package/dl/public-api.d.ts +2 -2
  238. package/dropdown/dropdown-animations.d.ts +11 -11
  239. package/dropdown/dropdown-content.directive.d.ts +32 -32
  240. package/dropdown/dropdown-errors.d.ts +17 -17
  241. package/dropdown/dropdown-item.component.d.ts +50 -50
  242. package/dropdown/dropdown-trigger.directive.d.ts +136 -136
  243. package/dropdown/dropdown.component.d.ts +121 -121
  244. package/dropdown/dropdown.module.d.ts +13 -13
  245. package/dropdown/dropdown.types.d.ts +53 -53
  246. package/dropdown/index.d.ts +1 -1
  247. package/dropdown/ptsecurity-mosaic-dropdown.d.ts +5 -5
  248. package/dropdown/public-api.d.ts +8 -8
  249. package/esm2020/autocomplete/autocomplete-origin.directive.mjs +21 -21
  250. package/esm2020/autocomplete/autocomplete-trigger.directive.mjs +555 -555
  251. package/esm2020/autocomplete/autocomplete.component.mjs +154 -154
  252. package/esm2020/autocomplete/autocomplete.module.mjs +34 -34
  253. package/esm2020/autocomplete/index.mjs +2 -2
  254. package/esm2020/autocomplete/ptsecurity-mosaic-autocomplete.mjs +4 -4
  255. package/esm2020/autocomplete/public-api.mjs +5 -5
  256. package/esm2020/button/button.component.mjs +137 -137
  257. package/esm2020/button/button.module.mjs +38 -38
  258. package/esm2020/button/index.mjs +2 -2
  259. package/esm2020/button/ptsecurity-mosaic-button.mjs +4 -4
  260. package/esm2020/button/public-api.mjs +3 -3
  261. package/esm2020/button-toggle/button-toggle.component.mjs +362 -362
  262. package/esm2020/button-toggle/button-toggle.module.mjs +19 -19
  263. package/esm2020/button-toggle/index.mjs +2 -2
  264. package/esm2020/button-toggle/ptsecurity-mosaic-button-toggle.mjs +4 -4
  265. package/esm2020/button-toggle/public-api.mjs +3 -3
  266. package/esm2020/card/card.component.mjs +80 -80
  267. package/esm2020/card/card.module.mjs +30 -30
  268. package/esm2020/card/index.mjs +2 -2
  269. package/esm2020/card/ptsecurity-mosaic-card.mjs +4 -4
  270. package/esm2020/card/public-api.mjs +3 -3
  271. package/esm2020/checkbox/checkbox-config.mjs +6 -6
  272. package/esm2020/checkbox/checkbox-module.mjs +19 -19
  273. package/esm2020/checkbox/checkbox-required-validator.mjs +27 -27
  274. package/esm2020/checkbox/checkbox.mjs +316 -316
  275. package/esm2020/checkbox/index.mjs +2 -2
  276. package/esm2020/checkbox/ptsecurity-mosaic-checkbox.mjs +4 -4
  277. package/esm2020/checkbox/public-api.mjs +5 -5
  278. package/esm2020/core/animation/animation.mjs +8 -8
  279. package/esm2020/core/animation/fade-animations.mjs +9 -9
  280. package/esm2020/core/animation/index.mjs +4 -4
  281. package/esm2020/core/animation/select-animations.mjs +45 -45
  282. package/esm2020/core/common-behaviors/color.mjs +30 -30
  283. package/esm2020/core/common-behaviors/common-module.mjs +83 -83
  284. package/esm2020/core/common-behaviors/constructor.mjs +2 -2
  285. package/esm2020/core/common-behaviors/disabled.mjs +17 -17
  286. package/esm2020/core/common-behaviors/error-state.mjs +31 -31
  287. package/esm2020/core/common-behaviors/index.mjs +6 -6
  288. package/esm2020/core/common-behaviors/tabindex.mjs +18 -18
  289. package/esm2020/core/error/error-options.mjs +26 -26
  290. package/esm2020/core/formatters/date/formatter.mjs +359 -359
  291. package/esm2020/core/formatters/date/templates/en-US.mjs +281 -281
  292. package/esm2020/core/formatters/date/templates/ru-RU.mjs +281 -281
  293. package/esm2020/core/formatters/index.mjs +20 -20
  294. package/esm2020/core/formatters/number/formatter.mjs +105 -105
  295. package/esm2020/core/forms/forms-module.mjs +24 -24
  296. package/esm2020/core/forms/forms.directive.mjs +66 -66
  297. package/esm2020/core/forms/index.mjs +3 -3
  298. package/esm2020/core/highlight/highlight.pipe.mjs +17 -17
  299. package/esm2020/core/highlight/index.mjs +19 -19
  300. package/esm2020/core/index.mjs +2 -2
  301. package/esm2020/core/label/label-options.mjs +4 -4
  302. package/esm2020/core/line/line.mjs +70 -70
  303. package/esm2020/core/option/action.mjs +121 -121
  304. package/esm2020/core/option/index.mjs +5 -5
  305. package/esm2020/core/option/optgroup.mjs +31 -31
  306. package/esm2020/core/option/option-module.mjs +21 -21
  307. package/esm2020/core/option/option.mjs +257 -257
  308. package/esm2020/core/overlay/overlay-position-map.mjs +244 -244
  309. package/esm2020/core/pop-up/constants.mjs +34 -34
  310. package/esm2020/core/pop-up/index.mjs +4 -4
  311. package/esm2020/core/pop-up/pop-up-trigger.mjs +239 -239
  312. package/esm2020/core/pop-up/pop-up.mjs +94 -94
  313. package/esm2020/core/ptsecurity-mosaic-core.mjs +4 -4
  314. package/esm2020/core/public-api.mjs +18 -18
  315. package/esm2020/core/select/constants.mjs +27 -27
  316. package/esm2020/core/select/errors.mjs +26 -26
  317. package/esm2020/core/select/events.mjs +2 -2
  318. package/esm2020/core/select/index.mjs +4 -4
  319. package/esm2020/core/selection/constants.mjs +6 -6
  320. package/esm2020/core/selection/index.mjs +4 -4
  321. package/esm2020/core/selection/pseudo-checkbox/pseudo-checkbox.mjs +49 -49
  322. package/esm2020/core/selection/pseudo-checkbox/pseudo-checkbox.module.mjs +18 -18
  323. package/esm2020/core/services/measure-scrollbar.service.mjs +48 -48
  324. package/esm2020/core/utils/index.mjs +2 -2
  325. package/esm2020/core/utils/public-api.mjs +2 -2
  326. package/esm2020/core/utils/utils.mjs +5 -5
  327. package/esm2020/core/validation/index.mjs +2 -2
  328. package/esm2020/core/validation/validation.mjs +118 -118
  329. package/esm2020/core/version.mjs +3 -3
  330. package/esm2020/datepicker/calendar-body.component.mjs +106 -106
  331. package/esm2020/datepicker/calendar.component.mjs +362 -362
  332. package/esm2020/datepicker/datepicker-animations.mjs +32 -32
  333. package/esm2020/datepicker/datepicker-errors.mjs +6 -6
  334. package/esm2020/datepicker/datepicker-input.directive.mjs +938 -938
  335. package/esm2020/datepicker/datepicker-intl.mjs +40 -40
  336. package/esm2020/datepicker/datepicker-module.mjs +107 -107
  337. package/esm2020/datepicker/datepicker-toggle.component.mjs +86 -86
  338. package/esm2020/datepicker/datepicker.component.mjs +404 -404
  339. package/esm2020/datepicker/index.mjs +2 -2
  340. package/esm2020/datepicker/month-view.component.mjs +257 -257
  341. package/esm2020/datepicker/multi-year-view.component.mjs +218 -218
  342. package/esm2020/datepicker/ptsecurity-mosaic-datepicker.mjs +4 -4
  343. package/esm2020/datepicker/public-api.mjs +12 -12
  344. package/esm2020/datepicker/year-view.component.mjs +253 -253
  345. package/esm2020/design-tokens/index.mjs +2 -2
  346. package/esm2020/design-tokens/legacy-2017/tokens.mjs +1167 -1138
  347. package/esm2020/design-tokens/pt-2022/tokens.mjs +1237 -1208
  348. package/esm2020/design-tokens/ptsecurity-mosaic-design-tokens.mjs +4 -4
  349. package/esm2020/design-tokens/public-api.mjs +4 -4
  350. package/esm2020/divider/divider.component.mjs +39 -39
  351. package/esm2020/divider/divider.module.mjs +18 -18
  352. package/esm2020/divider/index.mjs +2 -2
  353. package/esm2020/divider/ptsecurity-mosaic-divider.mjs +4 -4
  354. package/esm2020/divider/public-api.mjs +3 -3
  355. package/esm2020/dl/dl.component.mjs +78 -78
  356. package/esm2020/dl/dl.module.mjs +42 -42
  357. package/esm2020/dl/index.mjs +2 -2
  358. package/esm2020/dl/ptsecurity-mosaic-dl.mjs +4 -4
  359. package/esm2020/dl/public-api.mjs +3 -3
  360. package/esm2020/dropdown/dropdown-animations.mjs +41 -41
  361. package/esm2020/dropdown/dropdown-content.directive.mjs +64 -64
  362. package/esm2020/dropdown/dropdown-errors.mjs +29 -29
  363. package/esm2020/dropdown/dropdown-item.component.mjs +139 -139
  364. package/esm2020/dropdown/dropdown-trigger.directive.mjs +489 -489
  365. package/esm2020/dropdown/dropdown.component.mjs +292 -292
  366. package/esm2020/dropdown/dropdown.module.mjs +50 -50
  367. package/esm2020/dropdown/dropdown.types.mjs +24 -24
  368. package/esm2020/dropdown/index.mjs +2 -2
  369. package/esm2020/dropdown/ptsecurity-mosaic-dropdown.mjs +4 -4
  370. package/esm2020/dropdown/public-api.mjs +9 -9
  371. package/esm2020/form-field/cleaner.mjs +23 -23
  372. package/esm2020/form-field/form-field-control.mjs +5 -5
  373. package/esm2020/form-field/form-field-errors.mjs +7 -7
  374. package/esm2020/form-field/form-field.mjs +225 -225
  375. package/esm2020/form-field/form-field.module.mjs +57 -57
  376. package/esm2020/form-field/hint.mjs +34 -23
  377. package/esm2020/form-field/index.mjs +2 -2
  378. package/esm2020/form-field/password-hint.mjs +139 -139
  379. package/esm2020/form-field/prefix.mjs +13 -13
  380. package/esm2020/form-field/ptsecurity-mosaic-form-field.mjs +4 -4
  381. package/esm2020/form-field/public-api.mjs +11 -11
  382. package/esm2020/form-field/stepper.mjs +55 -55
  383. package/esm2020/form-field/suffix.mjs +13 -13
  384. package/esm2020/icon/icon.component.mjs +44 -44
  385. package/esm2020/icon/icon.module.mjs +38 -38
  386. package/esm2020/icon/index.mjs +2 -2
  387. package/esm2020/icon/ptsecurity-mosaic-icon.mjs +4 -4
  388. package/esm2020/icon/public-api.mjs +3 -3
  389. package/esm2020/index.mjs +2 -2
  390. package/esm2020/input/index.mjs +2 -2
  391. package/esm2020/input/input-errors.mjs +4 -4
  392. package/esm2020/input/input-number-validators.mjs +92 -92
  393. package/esm2020/input/input-number.mjs +163 -163
  394. package/esm2020/input/input-password.mjs +372 -372
  395. package/esm2020/input/input-value-accessor.mjs +3 -3
  396. package/esm2020/input/input.mjs +334 -334
  397. package/esm2020/input/input.module.mjs +65 -65
  398. package/esm2020/input/ptsecurity-mosaic-input.mjs +4 -4
  399. package/esm2020/input/public-api.mjs +7 -7
  400. package/esm2020/link/index.mjs +2 -2
  401. package/esm2020/link/link.component.mjs +107 -107
  402. package/esm2020/link/link.module.mjs +26 -26
  403. package/esm2020/link/ptsecurity-mosaic-link.mjs +4 -4
  404. package/esm2020/link/public-api.mjs +3 -3
  405. package/esm2020/list/index.mjs +2 -2
  406. package/esm2020/list/list-selection.component.mjs +689 -686
  407. package/esm2020/list/list.component.mjs +44 -44
  408. package/esm2020/list/list.module.mjs +55 -55
  409. package/esm2020/list/ptsecurity-mosaic-list.mjs +4 -4
  410. package/esm2020/list/public-api.mjs +4 -4
  411. package/esm2020/loader-overlay/index.mjs +2 -0
  412. package/esm2020/loader-overlay/loader-overlay.component.mjs +99 -0
  413. package/esm2020/loader-overlay/loader-overlay.module.mjs +50 -0
  414. package/esm2020/loader-overlay/ptsecurity-mosaic-loader-overlay.mjs +5 -0
  415. package/esm2020/loader-overlay/public-api.mjs +3 -0
  416. package/esm2020/modal/css-unit.pipe.mjs +17 -17
  417. package/esm2020/modal/index.mjs +2 -2
  418. package/esm2020/modal/modal-control.service.mjs +85 -85
  419. package/esm2020/modal/modal-ref.class.mjs +8 -8
  420. package/esm2020/modal/modal-util.mjs +17 -17
  421. package/esm2020/modal/modal.component.mjs +509 -501
  422. package/esm2020/modal/modal.directive.mjs +52 -52
  423. package/esm2020/modal/modal.module.mjs +72 -72
  424. package/esm2020/modal/modal.service.mjs +124 -124
  425. package/esm2020/modal/modal.type.mjs +7 -7
  426. package/esm2020/modal/ptsecurity-mosaic-modal.mjs +4 -4
  427. package/esm2020/modal/public-api.mjs +7 -7
  428. package/esm2020/navbar/index.mjs +2 -2
  429. package/esm2020/navbar/navbar-item.component.mjs +582 -582
  430. package/esm2020/navbar/navbar.component.mjs +239 -237
  431. package/esm2020/navbar/navbar.module.mjs +92 -92
  432. package/esm2020/navbar/ptsecurity-mosaic-navbar.mjs +4 -4
  433. package/esm2020/navbar/public-api.mjs +5 -5
  434. package/esm2020/navbar/vertical-navbar.animation.mjs +10 -10
  435. package/esm2020/navbar/vertical-navbar.component.mjs +114 -114
  436. package/esm2020/popover/index.mjs +2 -2
  437. package/esm2020/popover/popover-animations.mjs +16 -16
  438. package/esm2020/popover/popover-confirm.component.mjs +108 -108
  439. package/esm2020/popover/popover.component.mjs +253 -253
  440. package/esm2020/popover/popover.module.mjs +24 -24
  441. package/esm2020/popover/ptsecurity-mosaic-popover.mjs +4 -4
  442. package/esm2020/popover/public-api.mjs +5 -5
  443. package/esm2020/progress-bar/index.mjs +2 -2
  444. package/esm2020/progress-bar/progress-bar.component.mjs +42 -42
  445. package/esm2020/progress-bar/progress-bar.module.mjs +30 -30
  446. package/esm2020/progress-bar/ptsecurity-mosaic-progress-bar.mjs +4 -4
  447. package/esm2020/progress-bar/public-api.mjs +3 -3
  448. package/esm2020/progress-spinner/index.mjs +2 -2
  449. package/esm2020/progress-spinner/progress-spinner.component.mjs +46 -46
  450. package/esm2020/progress-spinner/progress-spinner.module.mjs +30 -30
  451. package/esm2020/progress-spinner/ptsecurity-mosaic-progress-spinner.mjs +4 -4
  452. package/esm2020/progress-spinner/public-api.mjs +3 -3
  453. package/esm2020/ptsecurity-mosaic.mjs +4 -4
  454. package/esm2020/public-api.mjs +2 -2
  455. package/esm2020/radio/index.mjs +2 -2
  456. package/esm2020/radio/ptsecurity-mosaic-radio.mjs +4 -4
  457. package/esm2020/radio/public-api.mjs +3 -3
  458. package/esm2020/radio/radio.component.mjs +458 -458
  459. package/esm2020/radio/radio.module.mjs +20 -20
  460. package/esm2020/select/index.mjs +2 -2
  461. package/esm2020/select/ptsecurity-mosaic-select.mjs +4 -4
  462. package/esm2020/select/public-api.mjs +4 -4
  463. package/esm2020/select/select-option.directive.mjs +65 -65
  464. package/esm2020/select/select.component.mjs +1117 -1117
  465. package/esm2020/select/select.module.mjs +73 -73
  466. package/esm2020/sidebar/index.mjs +2 -2
  467. package/esm2020/sidebar/ptsecurity-mosaic-sidebar.mjs +4 -4
  468. package/esm2020/sidebar/public-api.mjs +3 -3
  469. package/esm2020/sidebar/sidebar-animations.mjs +23 -23
  470. package/esm2020/sidebar/sidebar.component.mjs +146 -146
  471. package/esm2020/sidebar/sidebar.module.mjs +30 -30
  472. package/esm2020/sidepanel/index.mjs +2 -2
  473. package/esm2020/sidepanel/ptsecurity-mosaic-sidepanel.mjs +4 -4
  474. package/esm2020/sidepanel/public-api.mjs +7 -7
  475. package/esm2020/sidepanel/sidepanel-animations.mjs +26 -26
  476. package/esm2020/sidepanel/sidepanel-config.mjs +26 -26
  477. package/esm2020/sidepanel/sidepanel-container.component.mjs +106 -106
  478. package/esm2020/sidepanel/sidepanel-directives.mjs +159 -159
  479. package/esm2020/sidepanel/sidepanel-ref.mjs +53 -53
  480. package/esm2020/sidepanel/sidepanel.module.mjs +74 -74
  481. package/esm2020/sidepanel/sidepanel.service.mjs +167 -167
  482. package/esm2020/splitter/index.mjs +2 -2
  483. package/esm2020/splitter/ptsecurity-mosaic-splitter.mjs +4 -4
  484. package/esm2020/splitter/public-api.mjs +3 -3
  485. package/esm2020/splitter/splitter.component.mjs +482 -482
  486. package/esm2020/splitter/splitter.module.mjs +40 -40
  487. package/esm2020/table/index.mjs +2 -2
  488. package/esm2020/table/ptsecurity-mosaic-table.mjs +4 -4
  489. package/esm2020/table/public-api.mjs +3 -3
  490. package/esm2020/table/table.component.mjs +16 -16
  491. package/esm2020/table/table.module.mjs +30 -30
  492. package/esm2020/tabs/index.mjs +2 -2
  493. package/esm2020/tabs/paginated-tab-header.mjs +479 -479
  494. package/esm2020/tabs/ptsecurity-mosaic-tabs.mjs +4 -4
  495. package/esm2020/tabs/public-api.mjs +11 -11
  496. package/esm2020/tabs/tab-body.component.mjs +178 -178
  497. package/esm2020/tabs/tab-content.directive.mjs +15 -15
  498. package/esm2020/tabs/tab-group.component.mjs +350 -350
  499. package/esm2020/tabs/tab-header.component.mjs +67 -67
  500. package/esm2020/tabs/tab-label-wrapper.directive.mjs +78 -78
  501. package/esm2020/tabs/tab-label.directive.mjs +17 -17
  502. package/esm2020/tabs/tab-nav-bar/index.mjs +2 -2
  503. package/esm2020/tabs/tab-nav-bar/tab-nav-bar.mjs +110 -110
  504. package/esm2020/tabs/tab.component.mjs +133 -133
  505. package/esm2020/tabs/tabs-animations.mjs +24 -24
  506. package/esm2020/tabs/tabs.module.mjs +104 -104
  507. package/esm2020/tags/index.mjs +2 -2
  508. package/esm2020/tags/ptsecurity-mosaic-tags.mjs +4 -4
  509. package/esm2020/tags/public-api.mjs +6 -6
  510. package/esm2020/tags/tag-default-options.mjs +4 -4
  511. package/esm2020/tags/tag-input.mjs +229 -229
  512. package/esm2020/tags/tag-list.component.mjs +722 -722
  513. package/esm2020/tags/tag-text-control.mjs +2 -2
  514. package/esm2020/tags/tag.component.mjs +375 -375
  515. package/esm2020/tags/tag.module.mjs +56 -56
  516. package/esm2020/textarea/index.mjs +2 -2
  517. package/esm2020/textarea/ptsecurity-mosaic-textarea.mjs +4 -4
  518. package/esm2020/textarea/public-api.mjs +3 -3
  519. package/esm2020/textarea/textarea.component.mjs +269 -269
  520. package/esm2020/textarea/textarea.module.mjs +21 -21
  521. package/esm2020/timepicker/index.mjs +2 -2
  522. package/esm2020/timepicker/ptsecurity-mosaic-timepicker.mjs +4 -4
  523. package/esm2020/timepicker/public-api.mjs +4 -4
  524. package/esm2020/timepicker/timepicker.constants.mjs +25 -25
  525. package/esm2020/timepicker/timepicker.directive.mjs +665 -665
  526. package/esm2020/timepicker/timepicker.module.mjs +34 -34
  527. package/esm2020/toggle/index.mjs +2 -2
  528. package/esm2020/toggle/ptsecurity-mosaic-toggle.mjs +4 -4
  529. package/esm2020/toggle/public-api.mjs +3 -3
  530. package/esm2020/toggle/toggle.component.mjs +158 -158
  531. package/esm2020/toggle/toggle.module.mjs +20 -20
  532. package/esm2020/tooltip/index.mjs +2 -2
  533. package/esm2020/tooltip/ptsecurity-mosaic-tooltip.mjs +4 -4
  534. package/esm2020/tooltip/public-api.mjs +3 -3
  535. package/esm2020/tooltip/tooltip.animations.mjs +19 -19
  536. package/esm2020/tooltip/tooltip.component.mjs +295 -295
  537. package/esm2020/tooltip/tooltip.module.mjs +43 -43
  538. package/esm2020/tree/control/base-tree-control.mjs +60 -60
  539. package/esm2020/tree/control/flat-tree-control.mjs +126 -126
  540. package/esm2020/tree/control/nested-tree-control.mjs +41 -41
  541. package/esm2020/tree/control/tree-control.mjs +2 -2
  542. package/esm2020/tree/data-source/flat-data-source.mjs +162 -162
  543. package/esm2020/tree/data-source/nested-data-source.mjs +30 -30
  544. package/esm2020/tree/index.mjs +2 -2
  545. package/esm2020/tree/node.mjs +31 -31
  546. package/esm2020/tree/outlet.mjs +15 -15
  547. package/esm2020/tree/padding.directive.mjs +113 -113
  548. package/esm2020/tree/ptsecurity-mosaic-tree.mjs +4 -4
  549. package/esm2020/tree/public-api.mjs +16 -16
  550. package/esm2020/tree/toggle.mjs +80 -80
  551. package/esm2020/tree/tree-base.mjs +243 -243
  552. package/esm2020/tree/tree-errors.mjs +36 -36
  553. package/esm2020/tree/tree-option.component.mjs +248 -248
  554. package/esm2020/tree/tree-selection.component.mjs +541 -540
  555. package/esm2020/tree/tree.mjs +15 -15
  556. package/esm2020/tree/tree.module.mjs +57 -57
  557. package/esm2020/tree-select/index.mjs +2 -2
  558. package/esm2020/tree-select/ptsecurity-mosaic-tree-select.mjs +4 -4
  559. package/esm2020/tree-select/public-api.mjs +3 -3
  560. package/esm2020/tree-select/tree-select.component.mjs +939 -939
  561. package/esm2020/tree-select/tree-select.module.mjs +47 -47
  562. package/fesm2015/ptsecurity-mosaic-autocomplete.mjs +726 -726
  563. package/fesm2015/ptsecurity-mosaic-autocomplete.mjs.map +1 -1
  564. package/fesm2015/ptsecurity-mosaic-button-toggle.mjs +367 -367
  565. package/fesm2015/ptsecurity-mosaic-button-toggle.mjs.map +1 -1
  566. package/fesm2015/ptsecurity-mosaic-button.mjs +160 -160
  567. package/fesm2015/ptsecurity-mosaic-button.mjs.map +1 -1
  568. package/fesm2015/ptsecurity-mosaic-card.mjs +96 -96
  569. package/fesm2015/ptsecurity-mosaic-card.mjs.map +1 -1
  570. package/fesm2015/ptsecurity-mosaic-checkbox.mjs +348 -348
  571. package/fesm2015/ptsecurity-mosaic-checkbox.mjs.map +1 -1
  572. package/fesm2015/ptsecurity-mosaic-core.mjs +2652 -2652
  573. package/fesm2015/ptsecurity-mosaic-core.mjs.map +1 -1
  574. package/fesm2015/ptsecurity-mosaic-datepicker.mjs +2682 -2682
  575. package/fesm2015/ptsecurity-mosaic-datepicker.mjs.map +1 -1
  576. package/fesm2015/ptsecurity-mosaic-design-tokens.mjs +2432 -2345
  577. package/fesm2015/ptsecurity-mosaic-design-tokens.mjs.map +1 -1
  578. package/fesm2015/ptsecurity-mosaic-divider.mjs +48 -48
  579. package/fesm2015/ptsecurity-mosaic-divider.mjs.map +1 -1
  580. package/fesm2015/ptsecurity-mosaic-dl.mjs +108 -108
  581. package/fesm2015/ptsecurity-mosaic-dl.mjs.map +1 -1
  582. package/fesm2015/ptsecurity-mosaic-dropdown.mjs +1069 -1069
  583. package/fesm2015/ptsecurity-mosaic-dropdown.mjs.map +1 -1
  584. package/fesm2015/ptsecurity-mosaic-form-field.mjs +522 -512
  585. package/fesm2015/ptsecurity-mosaic-form-field.mjs.map +1 -1
  586. package/fesm2015/ptsecurity-mosaic-icon.mjs +73 -73
  587. package/fesm2015/ptsecurity-mosaic-icon.mjs.map +1 -1
  588. package/fesm2015/ptsecurity-mosaic-input.mjs +979 -979
  589. package/fesm2015/ptsecurity-mosaic-input.mjs.map +1 -1
  590. package/fesm2015/ptsecurity-mosaic-link.mjs +121 -121
  591. package/fesm2015/ptsecurity-mosaic-link.mjs.map +1 -1
  592. package/fesm2015/ptsecurity-mosaic-list.mjs +765 -762
  593. package/fesm2015/ptsecurity-mosaic-list.mjs.map +1 -1
  594. package/fesm2015/ptsecurity-mosaic-loader-overlay.mjs +155 -0
  595. package/fesm2015/ptsecurity-mosaic-loader-overlay.mjs.map +1 -0
  596. package/fesm2015/ptsecurity-mosaic-modal.mjs +833 -824
  597. package/fesm2015/ptsecurity-mosaic-modal.mjs.map +1 -1
  598. package/fesm2015/ptsecurity-mosaic-navbar.mjs +996 -994
  599. package/fesm2015/ptsecurity-mosaic-navbar.mjs.map +1 -1
  600. package/fesm2015/ptsecurity-mosaic-popover.mjs +364 -364
  601. package/fesm2015/ptsecurity-mosaic-popover.mjs.map +1 -1
  602. package/fesm2015/ptsecurity-mosaic-progress-bar.mjs +61 -61
  603. package/fesm2015/ptsecurity-mosaic-progress-bar.mjs.map +1 -1
  604. package/fesm2015/ptsecurity-mosaic-progress-spinner.mjs +65 -65
  605. package/fesm2015/ptsecurity-mosaic-progress-spinner.mjs.map +1 -1
  606. package/fesm2015/ptsecurity-mosaic-radio.mjs +464 -464
  607. package/fesm2015/ptsecurity-mosaic-radio.mjs.map +1 -1
  608. package/fesm2015/ptsecurity-mosaic-select.mjs +1213 -1213
  609. package/fesm2015/ptsecurity-mosaic-select.mjs.map +1 -1
  610. package/fesm2015/ptsecurity-mosaic-sidebar.mjs +185 -185
  611. package/fesm2015/ptsecurity-mosaic-sidebar.mjs.map +1 -1
  612. package/fesm2015/ptsecurity-mosaic-sidepanel.mjs +555 -555
  613. package/fesm2015/ptsecurity-mosaic-sidepanel.mjs.map +1 -1
  614. package/fesm2015/ptsecurity-mosaic-splitter.mjs +511 -511
  615. package/fesm2015/ptsecurity-mosaic-splitter.mjs.map +1 -1
  616. package/fesm2015/ptsecurity-mosaic-table.mjs +36 -36
  617. package/fesm2015/ptsecurity-mosaic-table.mjs.map +1 -1
  618. package/fesm2015/ptsecurity-mosaic-tabs.mjs +1460 -1460
  619. package/fesm2015/ptsecurity-mosaic-tabs.mjs.map +1 -1
  620. package/fesm2015/ptsecurity-mosaic-tags.mjs +1342 -1342
  621. package/fesm2015/ptsecurity-mosaic-tags.mjs.map +1 -1
  622. package/fesm2015/ptsecurity-mosaic-textarea.mjs +274 -274
  623. package/fesm2015/ptsecurity-mosaic-textarea.mjs.map +1 -1
  624. package/fesm2015/ptsecurity-mosaic-timepicker.mjs +703 -703
  625. package/fesm2015/ptsecurity-mosaic-timepicker.mjs.map +1 -1
  626. package/fesm2015/ptsecurity-mosaic-toggle.mjs +163 -163
  627. package/fesm2015/ptsecurity-mosaic-toggle.mjs.map +1 -1
  628. package/fesm2015/ptsecurity-mosaic-tooltip.mjs +344 -344
  629. package/fesm2015/ptsecurity-mosaic-tooltip.mjs.map +1 -1
  630. package/fesm2015/ptsecurity-mosaic-tree-select.mjs +954 -954
  631. package/fesm2015/ptsecurity-mosaic-tree-select.mjs.map +1 -1
  632. package/fesm2015/ptsecurity-mosaic-tree.mjs +1689 -1688
  633. package/fesm2015/ptsecurity-mosaic-tree.mjs.map +1 -1
  634. package/fesm2015/ptsecurity-mosaic.mjs +2 -2
  635. package/fesm2020/ptsecurity-mosaic-autocomplete.mjs +722 -722
  636. package/fesm2020/ptsecurity-mosaic-autocomplete.mjs.map +1 -1
  637. package/fesm2020/ptsecurity-mosaic-button-toggle.mjs +365 -365
  638. package/fesm2020/ptsecurity-mosaic-button-toggle.mjs.map +1 -1
  639. package/fesm2020/ptsecurity-mosaic-button.mjs +160 -160
  640. package/fesm2020/ptsecurity-mosaic-button.mjs.map +1 -1
  641. package/fesm2020/ptsecurity-mosaic-card.mjs +96 -96
  642. package/fesm2020/ptsecurity-mosaic-card.mjs.map +1 -1
  643. package/fesm2020/ptsecurity-mosaic-checkbox.mjs +346 -346
  644. package/fesm2020/ptsecurity-mosaic-checkbox.mjs.map +1 -1
  645. package/fesm2020/ptsecurity-mosaic-core.mjs +2681 -2681
  646. package/fesm2020/ptsecurity-mosaic-core.mjs.map +1 -1
  647. package/fesm2020/ptsecurity-mosaic-datepicker.mjs +2667 -2667
  648. package/fesm2020/ptsecurity-mosaic-datepicker.mjs.map +1 -1
  649. package/fesm2020/ptsecurity-mosaic-design-tokens.mjs +2432 -2345
  650. package/fesm2020/ptsecurity-mosaic-design-tokens.mjs.map +1 -1
  651. package/fesm2020/ptsecurity-mosaic-divider.mjs +48 -48
  652. package/fesm2020/ptsecurity-mosaic-divider.mjs.map +1 -1
  653. package/fesm2020/ptsecurity-mosaic-dl.mjs +108 -108
  654. package/fesm2020/ptsecurity-mosaic-dl.mjs.map +1 -1
  655. package/fesm2020/ptsecurity-mosaic-dropdown.mjs +1056 -1056
  656. package/fesm2020/ptsecurity-mosaic-dropdown.mjs.map +1 -1
  657. package/fesm2020/ptsecurity-mosaic-form-field.mjs +507 -497
  658. package/fesm2020/ptsecurity-mosaic-form-field.mjs.map +1 -1
  659. package/fesm2020/ptsecurity-mosaic-icon.mjs +71 -71
  660. package/fesm2020/ptsecurity-mosaic-icon.mjs.map +1 -1
  661. package/fesm2020/ptsecurity-mosaic-input.mjs +968 -968
  662. package/fesm2020/ptsecurity-mosaic-input.mjs.map +1 -1
  663. package/fesm2020/ptsecurity-mosaic-link.mjs +120 -120
  664. package/fesm2020/ptsecurity-mosaic-link.mjs.map +1 -1
  665. package/fesm2020/ptsecurity-mosaic-list.mjs +758 -755
  666. package/fesm2020/ptsecurity-mosaic-list.mjs.map +1 -1
  667. package/fesm2020/ptsecurity-mosaic-loader-overlay.mjs +153 -0
  668. package/fesm2020/ptsecurity-mosaic-loader-overlay.mjs.map +1 -0
  669. package/fesm2020/ptsecurity-mosaic-modal.mjs +828 -820
  670. package/fesm2020/ptsecurity-mosaic-modal.mjs.map +1 -1
  671. package/fesm2020/ptsecurity-mosaic-navbar.mjs +980 -978
  672. package/fesm2020/ptsecurity-mosaic-navbar.mjs.map +1 -1
  673. package/fesm2020/ptsecurity-mosaic-popover.mjs +360 -360
  674. package/fesm2020/ptsecurity-mosaic-popover.mjs.map +1 -1
  675. package/fesm2020/ptsecurity-mosaic-progress-bar.mjs +61 -61
  676. package/fesm2020/ptsecurity-mosaic-progress-bar.mjs.map +1 -1
  677. package/fesm2020/ptsecurity-mosaic-progress-spinner.mjs +65 -65
  678. package/fesm2020/ptsecurity-mosaic-progress-spinner.mjs.map +1 -1
  679. package/fesm2020/ptsecurity-mosaic-radio.mjs +462 -462
  680. package/fesm2020/ptsecurity-mosaic-radio.mjs.map +1 -1
  681. package/fesm2020/ptsecurity-mosaic-select.mjs +1208 -1208
  682. package/fesm2020/ptsecurity-mosaic-select.mjs.map +1 -1
  683. package/fesm2020/ptsecurity-mosaic-sidebar.mjs +185 -185
  684. package/fesm2020/ptsecurity-mosaic-sidebar.mjs.map +1 -1
  685. package/fesm2020/ptsecurity-mosaic-sidepanel.mjs +552 -552
  686. package/fesm2020/ptsecurity-mosaic-sidepanel.mjs.map +1 -1
  687. package/fesm2020/ptsecurity-mosaic-splitter.mjs +511 -511
  688. package/fesm2020/ptsecurity-mosaic-splitter.mjs.map +1 -1
  689. package/fesm2020/ptsecurity-mosaic-table.mjs +36 -36
  690. package/fesm2020/ptsecurity-mosaic-table.mjs.map +1 -1
  691. package/fesm2020/ptsecurity-mosaic-tabs.mjs +1445 -1445
  692. package/fesm2020/ptsecurity-mosaic-tabs.mjs.map +1 -1
  693. package/fesm2020/ptsecurity-mosaic-tags.mjs +1335 -1335
  694. package/fesm2020/ptsecurity-mosaic-tags.mjs.map +1 -1
  695. package/fesm2020/ptsecurity-mosaic-textarea.mjs +272 -272
  696. package/fesm2020/ptsecurity-mosaic-textarea.mjs.map +1 -1
  697. package/fesm2020/ptsecurity-mosaic-timepicker.mjs +700 -700
  698. package/fesm2020/ptsecurity-mosaic-timepicker.mjs.map +1 -1
  699. package/fesm2020/ptsecurity-mosaic-toggle.mjs +163 -163
  700. package/fesm2020/ptsecurity-mosaic-toggle.mjs.map +1 -1
  701. package/fesm2020/ptsecurity-mosaic-tooltip.mjs +336 -336
  702. package/fesm2020/ptsecurity-mosaic-tooltip.mjs.map +1 -1
  703. package/fesm2020/ptsecurity-mosaic-tree-select.mjs +951 -951
  704. package/fesm2020/ptsecurity-mosaic-tree-select.mjs.map +1 -1
  705. package/fesm2020/ptsecurity-mosaic-tree.mjs +1676 -1675
  706. package/fesm2020/ptsecurity-mosaic-tree.mjs.map +1 -1
  707. package/fesm2020/ptsecurity-mosaic.mjs +2 -2
  708. package/form-field/cleaner.d.ts +7 -7
  709. package/form-field/form-field-control.d.ts +37 -37
  710. package/form-field/form-field-errors.d.ts +2 -2
  711. package/form-field/form-field.d.ts +69 -69
  712. package/form-field/form-field.module.d.ts +15 -15
  713. package/form-field/hint.d.ts +14 -6
  714. package/form-field/index.d.ts +1 -1
  715. package/form-field/password-hint.d.ts +40 -40
  716. package/form-field/prefix.d.ts +5 -5
  717. package/form-field/ptsecurity-mosaic-form-field.d.ts +5 -5
  718. package/form-field/public-api.d.ts +10 -10
  719. package/form-field/stepper.d.ts +11 -11
  720. package/form-field/suffix.d.ts +5 -5
  721. package/icon/icon.component.d.ts +18 -18
  722. package/icon/icon.module.d.ts +10 -10
  723. package/icon/index.d.ts +1 -1
  724. package/icon/ptsecurity-mosaic-icon.d.ts +5 -5
  725. package/icon/public-api.d.ts +2 -2
  726. package/index.d.ts +1 -1
  727. package/input/index.d.ts +1 -1
  728. package/input/input-errors.d.ts +1 -1
  729. package/input/input-number-validators.d.ts +39 -39
  730. package/input/input-number.d.ts +33 -33
  731. package/input/input-password.d.ts +123 -123
  732. package/input/input-value-accessor.d.ts +4 -4
  733. package/input/input.d.ts +116 -116
  734. package/input/input.module.d.ts +14 -14
  735. package/input/ptsecurity-mosaic-input.d.ts +5 -5
  736. package/input/public-api.d.ts +6 -6
  737. package/link/index.d.ts +1 -1
  738. package/link/link.component.d.ts +38 -38
  739. package/link/link.module.d.ts +9 -9
  740. package/link/ptsecurity-mosaic-link.d.ts +5 -5
  741. package/link/public-api.d.ts +2 -2
  742. package/list/index.d.ts +1 -1
  743. package/list/list-selection.component.d.ts +168 -168
  744. package/list/list.component.d.ts +18 -18
  745. package/list/list.module.d.ts +11 -11
  746. package/list/ptsecurity-mosaic-list.d.ts +5 -5
  747. package/list/public-api.d.ts +3 -3
  748. package/{toggle → loader-overlay}/README.md +0 -0
  749. package/loader-overlay/index.d.ts +1 -0
  750. package/loader-overlay/loader-overlay.component.d.ts +33 -0
  751. package/loader-overlay/loader-overlay.module.d.ts +11 -0
  752. package/loader-overlay/package.json +10 -0
  753. package/loader-overlay/ptsecurity-mosaic-loader-overlay.d.ts +5 -0
  754. package/loader-overlay/public-api.d.ts +2 -0
  755. package/modal/README.md +33 -33
  756. package/modal/css-unit.pipe.d.ts +7 -7
  757. package/modal/index.d.ts +1 -1
  758. package/modal/modal-control.service.d.ts +20 -20
  759. package/modal/modal-ref.class.d.ts +36 -36
  760. package/modal/modal-util.d.ts +12 -12
  761. package/modal/modal.component.d.ts +128 -126
  762. package/modal/modal.directive.d.ts +17 -17
  763. package/modal/modal.module.d.ts +14 -14
  764. package/modal/modal.service.d.ts +33 -33
  765. package/modal/modal.type.d.ts +60 -59
  766. package/modal/ptsecurity-mosaic-modal.d.ts +5 -5
  767. package/modal/public-api.d.ts +6 -6
  768. package/navbar/README.md +41 -41
  769. package/navbar/index.d.ts +1 -1
  770. package/navbar/navbar-item.component.d.ts +161 -161
  771. package/navbar/navbar.component.d.ts +58 -58
  772. package/navbar/navbar.module.d.ts +14 -14
  773. package/navbar/ptsecurity-mosaic-navbar.d.ts +5 -5
  774. package/navbar/public-api.d.ts +4 -4
  775. package/navbar/vertical-navbar.animation.d.ts +2 -2
  776. package/navbar/vertical-navbar.component.d.ts +23 -23
  777. package/package.json +12 -4
  778. package/popover/README.md +32 -32
  779. package/popover/index.d.ts +1 -1
  780. package/popover/popover-animations.d.ts +4 -4
  781. package/popover/popover-confirm.component.d.ts +33 -33
  782. package/popover/popover.component.d.ts +74 -74
  783. package/popover/popover.module.d.ts +12 -12
  784. package/popover/ptsecurity-mosaic-popover.d.ts +5 -5
  785. package/popover/public-api.d.ts +4 -4
  786. package/prebuilt-themes/dark-theme.css +1 -1
  787. package/prebuilt-themes/default-theme.css +1 -1
  788. package/progress-bar/index.d.ts +1 -1
  789. package/progress-bar/progress-bar.component.d.ts +18 -18
  790. package/progress-bar/progress-bar.module.d.ts +9 -9
  791. package/progress-bar/ptsecurity-mosaic-progress-bar.d.ts +5 -5
  792. package/progress-bar/public-api.d.ts +2 -2
  793. package/progress-spinner/index.d.ts +1 -1
  794. package/progress-spinner/progress-spinner.component.d.ts +19 -19
  795. package/progress-spinner/progress-spinner.module.d.ts +9 -9
  796. package/progress-spinner/ptsecurity-mosaic-progress-spinner.d.ts +5 -5
  797. package/progress-spinner/public-api.d.ts +2 -2
  798. package/ptsecurity-mosaic.d.ts +5 -5
  799. package/public-api.d.ts +1 -1
  800. package/radio/index.d.ts +1 -1
  801. package/radio/ptsecurity-mosaic-radio.d.ts +5 -5
  802. package/radio/public-api.d.ts +2 -2
  803. package/radio/radio.component.d.ts +207 -207
  804. package/radio/radio.module.d.ts +10 -10
  805. package/schematics/README.md +35 -35
  806. package/select/index.d.ts +1 -1
  807. package/select/ptsecurity-mosaic-select.d.ts +5 -5
  808. package/select/public-api.d.ts +3 -3
  809. package/select/select-option.directive.d.ts +20 -20
  810. package/select/select.component.d.ts +310 -310
  811. package/select/select.module.d.ts +15 -15
  812. package/sidebar/index.d.ts +1 -1
  813. package/sidebar/ptsecurity-mosaic-sidebar.d.ts +5 -5
  814. package/sidebar/public-api.d.ts +2 -2
  815. package/sidebar/sidebar-animations.d.ts +8 -8
  816. package/sidebar/sidebar.component.d.ts +53 -53
  817. package/sidebar/sidebar.module.d.ts +8 -8
  818. package/sidepanel/index.d.ts +1 -1
  819. package/sidepanel/ptsecurity-mosaic-sidepanel.d.ts +5 -5
  820. package/sidepanel/public-api.d.ts +6 -6
  821. package/sidepanel/sidepanel-animations.d.ts +14 -14
  822. package/sidepanel/sidepanel-config.d.ts +25 -25
  823. package/sidepanel/sidepanel-container.component.d.ts +45 -45
  824. package/sidepanel/sidepanel-directives.d.ts +50 -50
  825. package/sidepanel/sidepanel-ref.d.ts +24 -24
  826. package/sidepanel/sidepanel.module.d.ts +15 -15
  827. package/sidepanel/sidepanel.service.d.ts +57 -57
  828. package/splitter/index.d.ts +1 -1
  829. package/splitter/ptsecurity-mosaic-splitter.d.ts +5 -5
  830. package/splitter/public-api.d.ts +2 -2
  831. package/splitter/splitter.component.d.ts +130 -130
  832. package/splitter/splitter.module.d.ts +9 -9
  833. package/table/index.d.ts +1 -1
  834. package/table/ptsecurity-mosaic-table.d.ts +5 -5
  835. package/table/public-api.d.ts +2 -2
  836. package/table/table.component.d.ts +5 -5
  837. package/table/table.module.d.ts +10 -10
  838. package/tabs/index.d.ts +1 -1
  839. package/tabs/paginated-tab-header.d.ts +179 -179
  840. package/tabs/ptsecurity-mosaic-tabs.d.ts +5 -5
  841. package/tabs/public-api.d.ts +10 -10
  842. package/tabs/tab-body.component.d.ts +95 -95
  843. package/tabs/tab-content.directive.d.ts +9 -9
  844. package/tabs/tab-group.component.d.ts +133 -133
  845. package/tabs/tab-header.component.d.ts +35 -35
  846. package/tabs/tab-label-wrapper.directive.d.ts +30 -30
  847. package/tabs/tab-label.directive.d.ts +9 -9
  848. package/tabs/tab-nav-bar/index.d.ts +1 -1
  849. package/tabs/tab-nav-bar/tab-nav-bar.d.ts +38 -38
  850. package/tabs/tab.component.d.ts +66 -66
  851. package/tabs/tabs-animations.d.ts +4 -4
  852. package/tabs/tabs.module.d.ts +20 -20
  853. package/tags/index.d.ts +1 -1
  854. package/tags/ptsecurity-mosaic-tags.d.ts +5 -5
  855. package/tags/public-api.d.ts +5 -5
  856. package/tags/tag-default-options.d.ts +8 -8
  857. package/tags/tag-input.d.ts +77 -77
  858. package/tags/tag-list.component.d.ts +240 -240
  859. package/tags/tag-text-control.d.ts +10 -10
  860. package/tags/tag.component.d.ts +135 -135
  861. package/tags/tag.module.d.ts +11 -11
  862. package/textarea/index.d.ts +1 -1
  863. package/textarea/ptsecurity-mosaic-textarea.d.ts +5 -5
  864. package/textarea/public-api.d.ts +2 -2
  865. package/textarea/textarea.component.d.ts +111 -111
  866. package/textarea/textarea.module.d.ts +11 -11
  867. package/timepicker/index.d.ts +1 -1
  868. package/timepicker/ptsecurity-mosaic-timepicker.d.ts +5 -5
  869. package/timepicker/public-api.d.ts +3 -3
  870. package/timepicker/timepicker.constants.d.ts +20 -20
  871. package/timepicker/timepicker.directive.d.ts +146 -146
  872. package/timepicker/timepicker.module.d.ts +11 -11
  873. package/toggle/index.d.ts +1 -1
  874. package/toggle/ptsecurity-mosaic-toggle.d.ts +5 -5
  875. package/toggle/public-api.d.ts +2 -2
  876. package/toggle/toggle.component.d.ts +54 -54
  877. package/toggle/toggle.module.d.ts +10 -10
  878. package/tooltip/index.d.ts +1 -1
  879. package/tooltip/ptsecurity-mosaic-tooltip.d.ts +5 -5
  880. package/tooltip/public-api.d.ts +2 -2
  881. package/tooltip/tooltip.animations.d.ts +8 -8
  882. package/tooltip/tooltip.component.d.ts +91 -91
  883. package/tooltip/tooltip.module.d.ts +9 -9
  884. package/tree/control/base-tree-control.d.ts +40 -40
  885. package/tree/control/flat-tree-control.d.ts +52 -52
  886. package/tree/control/nested-tree-control.d.ts +19 -19
  887. package/tree/control/tree-control.d.ts +44 -44
  888. package/tree/data-source/flat-data-source.d.ts +80 -80
  889. package/tree/data-source/nested-data-source.d.ts +15 -15
  890. package/tree/index.d.ts +1 -1
  891. package/tree/node.d.ts +34 -34
  892. package/tree/outlet.d.ts +9 -9
  893. package/tree/padding.directive.d.ts +47 -47
  894. package/tree/ptsecurity-mosaic-tree.d.ts +5 -5
  895. package/tree/public-api.d.ts +15 -15
  896. package/tree/toggle.d.ts +28 -28
  897. package/tree/tree-base.d.ts +97 -97
  898. package/tree/tree-errors.d.ts +25 -25
  899. package/tree/tree-option.component.d.ts +72 -72
  900. package/tree/tree-selection.component.d.ts +132 -132
  901. package/tree/tree.d.ts +6 -6
  902. package/tree/tree.module.d.ts +16 -16
  903. package/tree-select/index.d.ts +1 -1
  904. package/tree-select/ptsecurity-mosaic-tree-select.d.ts +5 -5
  905. package/tree-select/public-api.d.ts +2 -2
  906. package/tree-select/tree-select.component.d.ts +277 -277
  907. package/tree-select/tree-select.module.d.ts +14 -14
@@ -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.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>\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.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>\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.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
- }]
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.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']
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.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
- }]
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 };