@ptsecurity/mosaic 13.4.0 → 13.6.1

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