@ptsecurity/mosaic 13.6.0 → 13.7.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -21
- package/README.md +6 -6
- package/_theming.scss +7238 -7128
- package/_visual.scss +2724 -2694
- package/autocomplete/autocomplete-origin.directive.d.ts +12 -12
- package/autocomplete/autocomplete-trigger.directive.d.ts +167 -167
- package/autocomplete/autocomplete.component.d.ts +73 -73
- package/autocomplete/autocomplete.module.d.ts +12 -12
- package/autocomplete/index.d.ts +1 -1
- package/autocomplete/ptsecurity-mosaic-autocomplete.d.ts +5 -5
- package/autocomplete/public-api.d.ts +4 -4
- package/button/button.component.d.ts +40 -40
- package/button/button.module.d.ts +10 -10
- package/button/index.d.ts +1 -1
- package/button/ptsecurity-mosaic-button.d.ts +5 -5
- package/button/public-api.d.ts +2 -2
- package/button-toggle/button-toggle.component.d.ts +141 -141
- package/button-toggle/button-toggle.module.d.ts +9 -9
- package/button-toggle/index.d.ts +1 -1
- package/button-toggle/ptsecurity-mosaic-button-toggle.d.ts +5 -5
- package/button-toggle/public-api.d.ts +2 -2
- package/card/card.component.d.ts +26 -26
- package/card/card.module.d.ts +10 -10
- package/card/index.d.ts +1 -1
- package/card/ptsecurity-mosaic-card.d.ts +5 -5
- package/card/public-api.d.ts +2 -2
- package/checkbox/README.md +1 -1
- package/checkbox/checkbox-config.d.ts +13 -13
- package/checkbox/checkbox-module.d.ts +9 -9
- package/checkbox/checkbox-required-validator.d.ts +13 -13
- package/checkbox/checkbox.d.ts +140 -140
- package/checkbox/index.d.ts +1 -1
- package/checkbox/ptsecurity-mosaic-checkbox.d.ts +5 -5
- package/checkbox/public-api.d.ts +4 -4
- package/core/animation/animation.d.ts +6 -6
- package/core/animation/fade-animations.d.ts +2 -2
- package/core/animation/index.d.ts +3 -3
- package/core/animation/select-animations.d.ts +12 -12
- package/core/common-behaviors/color.d.ts +19 -19
- package/core/common-behaviors/common-module.d.ts +25 -25
- package/core/common-behaviors/constructor.d.ts +9 -9
- package/core/common-behaviors/disabled.d.ts +8 -8
- package/core/common-behaviors/error-state.d.ts +25 -25
- package/core/common-behaviors/index.d.ts +5 -5
- package/core/common-behaviors/tabindex.d.ts +8 -8
- package/core/error/error-options.d.ts +14 -14
- package/core/formatters/date/formatter.d.ts +203 -203
- package/core/formatters/date/templates/en-US.d.ts +74 -74
- package/core/formatters/date/templates/ru-RU.d.ts +74 -74
- package/core/formatters/index.d.ts +9 -9
- package/core/formatters/number/formatter.d.ts +27 -27
- package/core/forms/forms-module.d.ts +7 -7
- package/core/forms/forms.directive.d.ts +22 -22
- package/core/forms/index.d.ts +2 -2
- package/core/highlight/highlight.pipe.d.ts +7 -7
- package/core/highlight/index.d.ts +9 -9
- package/core/index.d.ts +1 -1
- package/core/label/label-options.d.ts +13 -13
- package/core/line/line.d.ts +28 -28
- package/core/option/action.d.ts +42 -42
- package/core/option/index.d.ts +4 -4
- package/core/option/optgroup.d.ts +16 -16
- package/core/option/option-module.d.ts +11 -11
- package/core/option/option.d.ts +115 -115
- package/core/overlay/overlay-position-map.d.ts +34 -34
- package/core/pop-up/constants.d.ts +29 -29
- package/core/pop-up/index.d.ts +3 -3
- package/core/pop-up/pop-up-trigger.d.ts +70 -70
- package/core/pop-up/pop-up.d.ts +36 -36
- package/core/ptsecurity-mosaic-core.d.ts +5 -5
- package/core/public-api.d.ts +17 -17
- package/core/select/constants.d.ts +23 -23
- package/core/select/errors.d.ts +19 -19
- package/core/select/events.d.ts +1 -1
- package/core/select/index.d.ts +3 -3
- package/core/selection/constants.d.ts +4 -4
- package/core/selection/index.d.ts +3 -3
- package/core/selection/pseudo-checkbox/pseudo-checkbox.d.ts +30 -30
- package/core/selection/pseudo-checkbox/pseudo-checkbox.module.d.ts +8 -8
- package/core/services/measure-scrollbar.service.d.ts +11 -11
- package/core/utils/index.d.ts +1 -1
- package/core/utils/public-api.d.ts +1 -1
- package/core/utils/utils.d.ts +2 -2
- package/core/validation/index.d.ts +1 -1
- package/core/validation/validation.d.ts +18 -18
- package/core/version.d.ts +2 -2
- package/datepicker/calendar-body.component.d.ts +63 -63
- package/datepicker/calendar.component.d.ts +151 -151
- package/datepicker/datepicker-animations.d.ts +9 -9
- package/datepicker/datepicker-errors.d.ts +2 -2
- package/datepicker/datepicker-input.directive.d.ts +178 -178
- package/datepicker/datepicker-intl.d.ts +32 -32
- package/datepicker/datepicker-module.d.ts +20 -20
- package/datepicker/datepicker-toggle.component.d.ts +35 -35
- package/datepicker/datepicker.component.d.ts +158 -158
- package/datepicker/index.d.ts +1 -1
- package/datepicker/month-view.component.d.ts +93 -93
- package/datepicker/multi-year-view.component.d.ts +72 -72
- package/datepicker/ptsecurity-mosaic-datepicker.d.ts +5 -5
- package/datepicker/public-api.d.ts +11 -11
- package/datepicker/year-view.component.d.ts +90 -90
- package/design-tokens/index.d.ts +1 -1
- package/design-tokens/legacy-2017/tokens/components/alert.json5 +83 -83
- package/design-tokens/legacy-2017/tokens/components/autocomplete.json5 +11 -11
- package/design-tokens/legacy-2017/tokens/components/badge.json5 +174 -174
- package/design-tokens/legacy-2017/tokens/components/button-toggle.json5 +10 -10
- package/design-tokens/legacy-2017/tokens/components/button.json5 +142 -142
- package/design-tokens/legacy-2017/tokens/components/card.json5 +51 -51
- package/design-tokens/legacy-2017/tokens/components/checkbox.json5 +97 -97
- package/design-tokens/legacy-2017/tokens/components/datepicker.json5 +64 -64
- package/design-tokens/legacy-2017/tokens/components/divider.json5 +14 -14
- package/design-tokens/legacy-2017/tokens/components/dl.json5 +38 -38
- package/design-tokens/legacy-2017/tokens/components/dropdown.json5 +48 -48
- package/design-tokens/legacy-2017/tokens/components/form-field.json5 +92 -92
- package/design-tokens/legacy-2017/tokens/components/forms.json5 +52 -52
- package/design-tokens/legacy-2017/tokens/components/icon.json5 +104 -104
- package/design-tokens/legacy-2017/tokens/components/input.json5 +12 -12
- package/design-tokens/legacy-2017/tokens/components/link.json5 +50 -50
- package/design-tokens/legacy-2017/tokens/components/list.json5 +13 -13
- package/design-tokens/legacy-2017/tokens/components/loader-overlay.json5 +23 -0
- package/design-tokens/legacy-2017/tokens/components/modal.json5 +81 -81
- package/design-tokens/legacy-2017/tokens/components/navbar.json5 +70 -70
- package/design-tokens/legacy-2017/tokens/components/optgroup.json5 +10 -10
- package/design-tokens/legacy-2017/tokens/components/option.json5 +12 -12
- package/design-tokens/legacy-2017/tokens/components/popover.json5 +68 -68
- package/design-tokens/legacy-2017/tokens/components/popup.json5 +16 -16
- package/design-tokens/legacy-2017/tokens/components/progress-bar.json5 +13 -13
- package/design-tokens/legacy-2017/tokens/components/progress-spinner.json5 +7 -7
- package/design-tokens/legacy-2017/tokens/components/radio.json5 +45 -44
- package/design-tokens/legacy-2017/tokens/components/select.json5 +24 -24
- package/design-tokens/legacy-2017/tokens/components/sidepanel.json5 +44 -44
- package/design-tokens/legacy-2017/tokens/components/table.json5 +15 -15
- package/design-tokens/legacy-2017/tokens/components/tabs.json5 +101 -101
- package/design-tokens/legacy-2017/tokens/components/tags.json5 +134 -134
- package/design-tokens/legacy-2017/tokens/components/textarea.json5 +12 -12
- package/design-tokens/legacy-2017/tokens/components/timepicker.json5 +7 -7
- package/design-tokens/legacy-2017/tokens/components/toggle.json5 +79 -79
- package/design-tokens/legacy-2017/tokens/components/tooltip.json5 +83 -83
- package/design-tokens/legacy-2017/tokens/components/tree.json5 +15 -15
- package/design-tokens/legacy-2017/tokens/properties/aliases.json5 +3 -3
- package/design-tokens/legacy-2017/tokens/properties/colors.json5 +119 -118
- package/design-tokens/legacy-2017/tokens/properties/font.json5 +12 -12
- package/design-tokens/legacy-2017/tokens/properties/globals.json5 +49 -49
- package/design-tokens/legacy-2017/tokens/properties/padding.json5 +3 -3
- package/design-tokens/legacy-2017/tokens/properties/palette.json5 +163 -163
- package/design-tokens/legacy-2017/tokens/properties/typography.json5 +175 -175
- package/design-tokens/legacy-2017/tokens.d.ts +7873 -7843
- package/design-tokens/pt-2022/tokens/components/alert.json5 +83 -83
- package/design-tokens/pt-2022/tokens/components/autocomplete.json5 +11 -11
- package/design-tokens/pt-2022/tokens/components/badge.json5 +174 -174
- package/design-tokens/pt-2022/tokens/components/button-toggle.json5 +10 -10
- package/design-tokens/pt-2022/tokens/components/button.json5 +142 -142
- package/design-tokens/pt-2022/tokens/components/card.json5 +51 -51
- package/design-tokens/pt-2022/tokens/components/checkbox.json5 +97 -97
- package/design-tokens/pt-2022/tokens/components/datepicker.json5 +64 -64
- package/design-tokens/pt-2022/tokens/components/divider.json5 +14 -14
- package/design-tokens/pt-2022/tokens/components/dl.json5 +38 -38
- package/design-tokens/pt-2022/tokens/components/dropdown.json5 +48 -48
- package/design-tokens/pt-2022/tokens/components/form-field.json5 +92 -92
- package/design-tokens/pt-2022/tokens/components/forms.json5 +52 -52
- package/design-tokens/pt-2022/tokens/components/icon.json5 +104 -104
- package/design-tokens/pt-2022/tokens/components/input.json5 +12 -12
- package/design-tokens/pt-2022/tokens/components/link.json5 +50 -50
- package/design-tokens/pt-2022/tokens/components/list.json5 +13 -13
- package/design-tokens/pt-2022/tokens/components/loader-overlay.json5 +23 -0
- package/design-tokens/pt-2022/tokens/components/modal.json5 +81 -81
- package/design-tokens/pt-2022/tokens/components/navbar.json5 +70 -70
- package/design-tokens/pt-2022/tokens/components/optgroup.json5 +10 -10
- package/design-tokens/pt-2022/tokens/components/option.json5 +12 -12
- package/design-tokens/pt-2022/tokens/components/popover.json5 +68 -68
- package/design-tokens/pt-2022/tokens/components/popup.json5 +16 -16
- package/design-tokens/pt-2022/tokens/components/progress-bar.json5 +13 -13
- package/design-tokens/pt-2022/tokens/components/progress-spinner.json5 +7 -7
- package/design-tokens/pt-2022/tokens/components/radio.json5 +45 -44
- package/design-tokens/pt-2022/tokens/components/select.json5 +24 -24
- package/design-tokens/pt-2022/tokens/components/sidepanel.json5 +44 -44
- package/design-tokens/pt-2022/tokens/components/table.json5 +15 -15
- package/design-tokens/pt-2022/tokens/components/tabs.json5 +101 -101
- package/design-tokens/pt-2022/tokens/components/tags.json5 +137 -137
- package/design-tokens/pt-2022/tokens/components/textarea.json5 +12 -12
- package/design-tokens/pt-2022/tokens/components/timepicker.json5 +7 -7
- package/design-tokens/pt-2022/tokens/components/toggle.json5 +79 -79
- package/design-tokens/pt-2022/tokens/components/tooltip.json5 +83 -83
- package/design-tokens/pt-2022/tokens/components/tree.json5 +15 -15
- package/design-tokens/pt-2022/tokens/properties/aliases.json5 +3 -3
- package/design-tokens/pt-2022/tokens/properties/colors.json5 +122 -120
- package/design-tokens/pt-2022/tokens/properties/font.json5 +15 -15
- package/design-tokens/pt-2022/tokens/properties/globals.json5 +49 -49
- package/design-tokens/pt-2022/tokens/properties/padding.json5 +3 -3
- package/design-tokens/pt-2022/tokens/properties/palette.json5 +232 -232
- package/design-tokens/pt-2022/tokens/properties/typography.json5 +175 -175
- package/design-tokens/pt-2022/tokens.d.ts +9205 -9175
- package/design-tokens/ptsecurity-mosaic-design-tokens.d.ts +5 -5
- package/design-tokens/public-api.d.ts +3 -3
- package/design-tokens/style-dictionary/build.js +76 -63
- package/design-tokens/style-dictionary/configs/css.js +13 -13
- package/design-tokens/style-dictionary/configs/figma.js +11 -0
- package/design-tokens/style-dictionary/configs/index.js +48 -48
- package/design-tokens/style-dictionary/configs/js.js +9 -9
- package/design-tokens/style-dictionary/configs/scss.js +23 -23
- package/design-tokens/style-dictionary/filters/color.js +7 -7
- package/design-tokens/style-dictionary/filters/palette.js +7 -7
- package/design-tokens/style-dictionary/filters/size.js +7 -7
- package/design-tokens/style-dictionary/filters/typography.js +7 -7
- package/design-tokens/style-dictionary/formats/figma.js +104 -0
- package/design-tokens/style-dictionary/formats/palette.js +25 -25
- package/design-tokens/style-dictionary/formats/typography.js +52 -52
- package/design-tokens/style-dictionary/transformGroups/css.js +13 -13
- package/design-tokens/style-dictionary/transformGroups/figma.js +21 -0
- package/design-tokens/style-dictionary/transformGroups/scss.js +12 -12
- package/design-tokens/style-dictionary/transformGroups/ts.js +11 -11
- package/design-tokens/style-dictionary/transforms/attribute/figma-border.js +18 -0
- package/design-tokens/style-dictionary/transforms/attribute/figma-color.js +25 -0
- package/design-tokens/style-dictionary/transforms/attribute/figma-default.js +10 -0
- package/design-tokens/style-dictionary/transforms/attribute/figma-font.js +31 -0
- package/design-tokens/style-dictionary/transforms/attribute/figma-group.js +17 -0
- package/design-tokens/style-dictionary/transforms/attribute/figma-opacity.js +10 -0
- package/design-tokens/style-dictionary/transforms/attribute/figma-shadow.js +66 -0
- package/design-tokens/style-dictionary/transforms/attribute/figma-sizing.js +16 -0
- package/design-tokens/style-dictionary/transforms/attribute/figma-spacing.js +15 -0
- package/design-tokens/style-dictionary/transforms/attribute/figma-typography.js +24 -0
- package/design-tokens/style-dictionary/transforms/attribute/palette.js +9 -9
- package/design-tokens/style-dictionary/transforms/attribute/prefix.js +11 -11
- package/design-tokens/style-dictionary/transforms/attribute/size.js +8 -8
- package/design-tokens/style-dictionary/transforms/attribute/typography.js +9 -9
- package/design-tokens/style-dictionary/transforms/value/figma-values.js +7 -0
- package/divider/divider.component.d.ts +11 -11
- package/divider/divider.module.d.ts +8 -8
- package/divider/index.d.ts +1 -1
- package/divider/ptsecurity-mosaic-divider.d.ts +5 -5
- package/divider/public-api.d.ts +2 -2
- package/dl/dl.component.d.ts +26 -26
- package/dl/dl.module.d.ts +10 -10
- package/dl/index.d.ts +1 -1
- package/dl/ptsecurity-mosaic-dl.d.ts +5 -5
- package/dl/public-api.d.ts +2 -2
- package/dropdown/dropdown-animations.d.ts +11 -11
- package/dropdown/dropdown-content.directive.d.ts +32 -32
- package/dropdown/dropdown-errors.d.ts +17 -17
- package/dropdown/dropdown-item.component.d.ts +50 -50
- package/dropdown/dropdown-trigger.directive.d.ts +136 -136
- package/dropdown/dropdown.component.d.ts +121 -121
- package/dropdown/dropdown.module.d.ts +13 -13
- package/dropdown/dropdown.types.d.ts +53 -53
- package/dropdown/index.d.ts +1 -1
- package/dropdown/ptsecurity-mosaic-dropdown.d.ts +5 -5
- package/dropdown/public-api.d.ts +8 -8
- package/esm2020/autocomplete/autocomplete-origin.directive.mjs +21 -21
- package/esm2020/autocomplete/autocomplete-trigger.directive.mjs +555 -555
- package/esm2020/autocomplete/autocomplete.component.mjs +154 -154
- package/esm2020/autocomplete/autocomplete.module.mjs +34 -34
- package/esm2020/autocomplete/index.mjs +2 -2
- package/esm2020/autocomplete/ptsecurity-mosaic-autocomplete.mjs +4 -4
- package/esm2020/autocomplete/public-api.mjs +5 -5
- package/esm2020/button/button.component.mjs +137 -137
- package/esm2020/button/button.module.mjs +38 -38
- package/esm2020/button/index.mjs +2 -2
- package/esm2020/button/ptsecurity-mosaic-button.mjs +4 -4
- package/esm2020/button/public-api.mjs +3 -3
- package/esm2020/button-toggle/button-toggle.component.mjs +362 -362
- package/esm2020/button-toggle/button-toggle.module.mjs +19 -19
- package/esm2020/button-toggle/index.mjs +2 -2
- package/esm2020/button-toggle/ptsecurity-mosaic-button-toggle.mjs +4 -4
- package/esm2020/button-toggle/public-api.mjs +3 -3
- package/esm2020/card/card.component.mjs +80 -80
- package/esm2020/card/card.module.mjs +30 -30
- package/esm2020/card/index.mjs +2 -2
- package/esm2020/card/ptsecurity-mosaic-card.mjs +4 -4
- package/esm2020/card/public-api.mjs +3 -3
- package/esm2020/checkbox/checkbox-config.mjs +6 -6
- package/esm2020/checkbox/checkbox-module.mjs +19 -19
- package/esm2020/checkbox/checkbox-required-validator.mjs +27 -27
- package/esm2020/checkbox/checkbox.mjs +316 -316
- package/esm2020/checkbox/index.mjs +2 -2
- package/esm2020/checkbox/ptsecurity-mosaic-checkbox.mjs +4 -4
- package/esm2020/checkbox/public-api.mjs +5 -5
- package/esm2020/core/animation/animation.mjs +8 -8
- package/esm2020/core/animation/fade-animations.mjs +9 -9
- package/esm2020/core/animation/index.mjs +4 -4
- package/esm2020/core/animation/select-animations.mjs +45 -45
- package/esm2020/core/common-behaviors/color.mjs +30 -30
- package/esm2020/core/common-behaviors/common-module.mjs +83 -83
- package/esm2020/core/common-behaviors/constructor.mjs +2 -2
- package/esm2020/core/common-behaviors/disabled.mjs +17 -17
- package/esm2020/core/common-behaviors/error-state.mjs +31 -31
- package/esm2020/core/common-behaviors/index.mjs +6 -6
- package/esm2020/core/common-behaviors/tabindex.mjs +18 -18
- package/esm2020/core/error/error-options.mjs +26 -26
- package/esm2020/core/formatters/date/formatter.mjs +359 -359
- package/esm2020/core/formatters/date/templates/en-US.mjs +281 -281
- package/esm2020/core/formatters/date/templates/ru-RU.mjs +281 -281
- package/esm2020/core/formatters/index.mjs +20 -20
- package/esm2020/core/formatters/number/formatter.mjs +105 -105
- package/esm2020/core/forms/forms-module.mjs +24 -24
- package/esm2020/core/forms/forms.directive.mjs +66 -66
- package/esm2020/core/forms/index.mjs +3 -3
- package/esm2020/core/highlight/highlight.pipe.mjs +17 -17
- package/esm2020/core/highlight/index.mjs +19 -19
- package/esm2020/core/index.mjs +2 -2
- package/esm2020/core/label/label-options.mjs +4 -4
- package/esm2020/core/line/line.mjs +70 -70
- package/esm2020/core/option/action.mjs +121 -121
- package/esm2020/core/option/index.mjs +5 -5
- package/esm2020/core/option/optgroup.mjs +31 -31
- package/esm2020/core/option/option-module.mjs +21 -21
- package/esm2020/core/option/option.mjs +257 -257
- package/esm2020/core/overlay/overlay-position-map.mjs +244 -244
- package/esm2020/core/pop-up/constants.mjs +34 -34
- package/esm2020/core/pop-up/index.mjs +4 -4
- package/esm2020/core/pop-up/pop-up-trigger.mjs +239 -239
- package/esm2020/core/pop-up/pop-up.mjs +94 -94
- package/esm2020/core/ptsecurity-mosaic-core.mjs +4 -4
- package/esm2020/core/public-api.mjs +18 -18
- package/esm2020/core/select/constants.mjs +27 -27
- package/esm2020/core/select/errors.mjs +26 -26
- package/esm2020/core/select/events.mjs +2 -2
- package/esm2020/core/select/index.mjs +4 -4
- package/esm2020/core/selection/constants.mjs +6 -6
- package/esm2020/core/selection/index.mjs +4 -4
- package/esm2020/core/selection/pseudo-checkbox/pseudo-checkbox.mjs +49 -49
- package/esm2020/core/selection/pseudo-checkbox/pseudo-checkbox.module.mjs +18 -18
- package/esm2020/core/services/measure-scrollbar.service.mjs +48 -48
- package/esm2020/core/utils/index.mjs +2 -2
- package/esm2020/core/utils/public-api.mjs +2 -2
- package/esm2020/core/utils/utils.mjs +5 -5
- package/esm2020/core/validation/index.mjs +2 -2
- package/esm2020/core/validation/validation.mjs +118 -118
- package/esm2020/core/version.mjs +3 -3
- package/esm2020/datepicker/calendar-body.component.mjs +106 -106
- package/esm2020/datepicker/calendar.component.mjs +362 -362
- package/esm2020/datepicker/datepicker-animations.mjs +32 -32
- package/esm2020/datepicker/datepicker-errors.mjs +6 -6
- package/esm2020/datepicker/datepicker-input.directive.mjs +938 -936
- package/esm2020/datepicker/datepicker-intl.mjs +40 -40
- package/esm2020/datepicker/datepicker-module.mjs +107 -107
- package/esm2020/datepicker/datepicker-toggle.component.mjs +86 -86
- package/esm2020/datepicker/datepicker.component.mjs +404 -408
- package/esm2020/datepicker/index.mjs +2 -2
- package/esm2020/datepicker/month-view.component.mjs +257 -257
- package/esm2020/datepicker/multi-year-view.component.mjs +218 -218
- package/esm2020/datepicker/ptsecurity-mosaic-datepicker.mjs +4 -4
- package/esm2020/datepicker/public-api.mjs +12 -12
- package/esm2020/datepicker/year-view.component.mjs +253 -253
- package/esm2020/design-tokens/index.mjs +2 -2
- package/esm2020/design-tokens/legacy-2017/tokens.mjs +1167 -1137
- package/esm2020/design-tokens/pt-2022/tokens.mjs +1237 -1207
- package/esm2020/design-tokens/ptsecurity-mosaic-design-tokens.mjs +4 -4
- package/esm2020/design-tokens/public-api.mjs +4 -4
- package/esm2020/divider/divider.component.mjs +39 -39
- package/esm2020/divider/divider.module.mjs +18 -18
- package/esm2020/divider/index.mjs +2 -2
- package/esm2020/divider/ptsecurity-mosaic-divider.mjs +4 -4
- package/esm2020/divider/public-api.mjs +3 -3
- package/esm2020/dl/dl.component.mjs +78 -78
- package/esm2020/dl/dl.module.mjs +42 -42
- package/esm2020/dl/index.mjs +2 -2
- package/esm2020/dl/ptsecurity-mosaic-dl.mjs +4 -4
- package/esm2020/dl/public-api.mjs +3 -3
- package/esm2020/dropdown/dropdown-animations.mjs +41 -41
- package/esm2020/dropdown/dropdown-content.directive.mjs +64 -64
- package/esm2020/dropdown/dropdown-errors.mjs +29 -29
- package/esm2020/dropdown/dropdown-item.component.mjs +139 -139
- package/esm2020/dropdown/dropdown-trigger.directive.mjs +489 -489
- package/esm2020/dropdown/dropdown.component.mjs +292 -292
- package/esm2020/dropdown/dropdown.module.mjs +50 -50
- package/esm2020/dropdown/dropdown.types.mjs +24 -24
- package/esm2020/dropdown/index.mjs +2 -2
- package/esm2020/dropdown/ptsecurity-mosaic-dropdown.mjs +4 -4
- package/esm2020/dropdown/public-api.mjs +9 -9
- package/esm2020/form-field/cleaner.mjs +23 -23
- package/esm2020/form-field/form-field-control.mjs +5 -5
- package/esm2020/form-field/form-field-errors.mjs +7 -7
- package/esm2020/form-field/form-field.mjs +225 -225
- package/esm2020/form-field/form-field.module.mjs +57 -57
- package/esm2020/form-field/hint.mjs +34 -23
- package/esm2020/form-field/index.mjs +2 -2
- package/esm2020/form-field/password-hint.mjs +139 -139
- package/esm2020/form-field/prefix.mjs +13 -13
- package/esm2020/form-field/ptsecurity-mosaic-form-field.mjs +4 -4
- package/esm2020/form-field/public-api.mjs +11 -11
- package/esm2020/form-field/stepper.mjs +55 -55
- package/esm2020/form-field/suffix.mjs +13 -13
- package/esm2020/icon/icon.component.mjs +44 -44
- package/esm2020/icon/icon.module.mjs +38 -38
- package/esm2020/icon/index.mjs +2 -2
- package/esm2020/icon/ptsecurity-mosaic-icon.mjs +4 -4
- package/esm2020/icon/public-api.mjs +3 -3
- package/esm2020/index.mjs +2 -2
- package/esm2020/input/index.mjs +2 -2
- package/esm2020/input/input-errors.mjs +4 -4
- package/esm2020/input/input-number-validators.mjs +92 -92
- package/esm2020/input/input-number.mjs +163 -163
- package/esm2020/input/input-password.mjs +372 -372
- package/esm2020/input/input-value-accessor.mjs +3 -3
- package/esm2020/input/input.mjs +334 -334
- package/esm2020/input/input.module.mjs +65 -65
- package/esm2020/input/ptsecurity-mosaic-input.mjs +4 -4
- package/esm2020/input/public-api.mjs +7 -7
- package/esm2020/link/index.mjs +2 -2
- package/esm2020/link/link.component.mjs +107 -107
- package/esm2020/link/link.module.mjs +26 -26
- package/esm2020/link/ptsecurity-mosaic-link.mjs +4 -4
- package/esm2020/link/public-api.mjs +3 -3
- package/esm2020/list/index.mjs +2 -2
- package/esm2020/list/list-selection.component.mjs +689 -686
- package/esm2020/list/list.component.mjs +44 -44
- package/esm2020/list/list.module.mjs +55 -55
- package/esm2020/list/ptsecurity-mosaic-list.mjs +4 -4
- package/esm2020/list/public-api.mjs +4 -4
- package/esm2020/loader-overlay/index.mjs +2 -0
- package/esm2020/loader-overlay/loader-overlay.component.mjs +99 -0
- package/esm2020/loader-overlay/loader-overlay.module.mjs +50 -0
- package/esm2020/loader-overlay/ptsecurity-mosaic-loader-overlay.mjs +5 -0
- package/esm2020/loader-overlay/public-api.mjs +3 -0
- package/esm2020/modal/css-unit.pipe.mjs +17 -17
- package/esm2020/modal/index.mjs +2 -2
- package/esm2020/modal/modal-control.service.mjs +85 -85
- package/esm2020/modal/modal-ref.class.mjs +8 -8
- package/esm2020/modal/modal-util.mjs +17 -17
- package/esm2020/modal/modal.component.mjs +509 -501
- package/esm2020/modal/modal.directive.mjs +52 -52
- package/esm2020/modal/modal.module.mjs +72 -72
- package/esm2020/modal/modal.service.mjs +124 -124
- package/esm2020/modal/modal.type.mjs +7 -7
- package/esm2020/modal/ptsecurity-mosaic-modal.mjs +4 -4
- package/esm2020/modal/public-api.mjs +7 -7
- package/esm2020/navbar/index.mjs +2 -2
- package/esm2020/navbar/navbar-item.component.mjs +582 -582
- package/esm2020/navbar/navbar.component.mjs +239 -237
- package/esm2020/navbar/navbar.module.mjs +92 -92
- package/esm2020/navbar/ptsecurity-mosaic-navbar.mjs +4 -4
- package/esm2020/navbar/public-api.mjs +5 -5
- package/esm2020/navbar/vertical-navbar.animation.mjs +10 -10
- package/esm2020/navbar/vertical-navbar.component.mjs +114 -114
- package/esm2020/popover/index.mjs +2 -2
- package/esm2020/popover/popover-animations.mjs +16 -16
- package/esm2020/popover/popover-confirm.component.mjs +108 -108
- package/esm2020/popover/popover.component.mjs +253 -253
- package/esm2020/popover/popover.module.mjs +24 -24
- package/esm2020/popover/ptsecurity-mosaic-popover.mjs +4 -4
- package/esm2020/popover/public-api.mjs +5 -5
- package/esm2020/progress-bar/index.mjs +2 -2
- package/esm2020/progress-bar/progress-bar.component.mjs +42 -42
- package/esm2020/progress-bar/progress-bar.module.mjs +30 -30
- package/esm2020/progress-bar/ptsecurity-mosaic-progress-bar.mjs +4 -4
- package/esm2020/progress-bar/public-api.mjs +3 -3
- package/esm2020/progress-spinner/index.mjs +2 -2
- package/esm2020/progress-spinner/progress-spinner.component.mjs +46 -46
- package/esm2020/progress-spinner/progress-spinner.module.mjs +30 -30
- package/esm2020/progress-spinner/ptsecurity-mosaic-progress-spinner.mjs +4 -4
- package/esm2020/progress-spinner/public-api.mjs +3 -3
- package/esm2020/ptsecurity-mosaic.mjs +4 -4
- package/esm2020/public-api.mjs +2 -2
- package/esm2020/radio/index.mjs +2 -2
- package/esm2020/radio/ptsecurity-mosaic-radio.mjs +4 -4
- package/esm2020/radio/public-api.mjs +3 -3
- package/esm2020/radio/radio.component.mjs +458 -458
- package/esm2020/radio/radio.module.mjs +20 -20
- package/esm2020/select/index.mjs +2 -2
- package/esm2020/select/ptsecurity-mosaic-select.mjs +4 -4
- package/esm2020/select/public-api.mjs +4 -4
- package/esm2020/select/select-option.directive.mjs +65 -65
- package/esm2020/select/select.component.mjs +1117 -1107
- package/esm2020/select/select.module.mjs +73 -73
- package/esm2020/sidebar/index.mjs +2 -2
- package/esm2020/sidebar/ptsecurity-mosaic-sidebar.mjs +4 -4
- package/esm2020/sidebar/public-api.mjs +3 -3
- package/esm2020/sidebar/sidebar-animations.mjs +23 -23
- package/esm2020/sidebar/sidebar.component.mjs +146 -146
- package/esm2020/sidebar/sidebar.module.mjs +30 -30
- package/esm2020/sidepanel/index.mjs +2 -2
- package/esm2020/sidepanel/ptsecurity-mosaic-sidepanel.mjs +4 -4
- package/esm2020/sidepanel/public-api.mjs +7 -7
- package/esm2020/sidepanel/sidepanel-animations.mjs +26 -26
- package/esm2020/sidepanel/sidepanel-config.mjs +26 -26
- package/esm2020/sidepanel/sidepanel-container.component.mjs +106 -106
- package/esm2020/sidepanel/sidepanel-directives.mjs +159 -159
- package/esm2020/sidepanel/sidepanel-ref.mjs +53 -53
- package/esm2020/sidepanel/sidepanel.module.mjs +74 -74
- package/esm2020/sidepanel/sidepanel.service.mjs +167 -167
- package/esm2020/splitter/index.mjs +2 -2
- package/esm2020/splitter/ptsecurity-mosaic-splitter.mjs +4 -4
- package/esm2020/splitter/public-api.mjs +3 -3
- package/esm2020/splitter/splitter.component.mjs +482 -482
- package/esm2020/splitter/splitter.module.mjs +40 -40
- package/esm2020/table/index.mjs +2 -2
- package/esm2020/table/ptsecurity-mosaic-table.mjs +4 -4
- package/esm2020/table/public-api.mjs +3 -3
- package/esm2020/table/table.component.mjs +16 -16
- package/esm2020/table/table.module.mjs +30 -30
- package/esm2020/tabs/index.mjs +2 -2
- package/esm2020/tabs/paginated-tab-header.mjs +479 -479
- package/esm2020/tabs/ptsecurity-mosaic-tabs.mjs +4 -4
- package/esm2020/tabs/public-api.mjs +11 -11
- package/esm2020/tabs/tab-body.component.mjs +178 -178
- package/esm2020/tabs/tab-content.directive.mjs +15 -15
- package/esm2020/tabs/tab-group.component.mjs +350 -350
- package/esm2020/tabs/tab-header.component.mjs +67 -67
- package/esm2020/tabs/tab-label-wrapper.directive.mjs +78 -78
- package/esm2020/tabs/tab-label.directive.mjs +17 -17
- package/esm2020/tabs/tab-nav-bar/index.mjs +2 -2
- package/esm2020/tabs/tab-nav-bar/tab-nav-bar.mjs +110 -110
- package/esm2020/tabs/tab.component.mjs +133 -133
- package/esm2020/tabs/tabs-animations.mjs +24 -24
- package/esm2020/tabs/tabs.module.mjs +104 -104
- package/esm2020/tags/index.mjs +2 -2
- package/esm2020/tags/ptsecurity-mosaic-tags.mjs +4 -4
- package/esm2020/tags/public-api.mjs +6 -6
- package/esm2020/tags/tag-default-options.mjs +4 -4
- package/esm2020/tags/tag-input.mjs +229 -229
- package/esm2020/tags/tag-list.component.mjs +722 -722
- package/esm2020/tags/tag-text-control.mjs +2 -2
- package/esm2020/tags/tag.component.mjs +375 -375
- package/esm2020/tags/tag.module.mjs +56 -56
- package/esm2020/textarea/index.mjs +2 -2
- package/esm2020/textarea/ptsecurity-mosaic-textarea.mjs +4 -4
- package/esm2020/textarea/public-api.mjs +3 -3
- package/esm2020/textarea/textarea.component.mjs +269 -269
- package/esm2020/textarea/textarea.module.mjs +21 -21
- package/esm2020/timepicker/index.mjs +2 -2
- package/esm2020/timepicker/ptsecurity-mosaic-timepicker.mjs +4 -4
- package/esm2020/timepicker/public-api.mjs +4 -4
- package/esm2020/timepicker/timepicker.constants.mjs +25 -25
- package/esm2020/timepicker/timepicker.directive.mjs +665 -676
- package/esm2020/timepicker/timepicker.module.mjs +34 -34
- package/esm2020/toggle/index.mjs +2 -2
- package/esm2020/toggle/ptsecurity-mosaic-toggle.mjs +4 -4
- package/esm2020/toggle/public-api.mjs +3 -3
- package/esm2020/toggle/toggle.component.mjs +158 -158
- package/esm2020/toggle/toggle.module.mjs +20 -20
- package/esm2020/tooltip/index.mjs +2 -2
- package/esm2020/tooltip/ptsecurity-mosaic-tooltip.mjs +4 -4
- package/esm2020/tooltip/public-api.mjs +3 -3
- package/esm2020/tooltip/tooltip.animations.mjs +19 -19
- package/esm2020/tooltip/tooltip.component.mjs +295 -295
- package/esm2020/tooltip/tooltip.module.mjs +43 -43
- package/esm2020/tree/control/base-tree-control.mjs +60 -60
- package/esm2020/tree/control/flat-tree-control.mjs +126 -126
- package/esm2020/tree/control/nested-tree-control.mjs +41 -41
- package/esm2020/tree/control/tree-control.mjs +2 -2
- package/esm2020/tree/data-source/flat-data-source.mjs +162 -162
- package/esm2020/tree/data-source/nested-data-source.mjs +30 -30
- package/esm2020/tree/index.mjs +2 -2
- package/esm2020/tree/node.mjs +31 -31
- package/esm2020/tree/outlet.mjs +15 -15
- package/esm2020/tree/padding.directive.mjs +113 -110
- package/esm2020/tree/ptsecurity-mosaic-tree.mjs +4 -4
- package/esm2020/tree/public-api.mjs +16 -16
- package/esm2020/tree/toggle.mjs +80 -80
- package/esm2020/tree/tree-base.mjs +243 -243
- package/esm2020/tree/tree-errors.mjs +36 -36
- package/esm2020/tree/tree-option.component.mjs +248 -236
- package/esm2020/tree/tree-selection.component.mjs +541 -540
- package/esm2020/tree/tree.mjs +15 -15
- package/esm2020/tree/tree.module.mjs +57 -57
- package/esm2020/tree-select/index.mjs +2 -2
- package/esm2020/tree-select/ptsecurity-mosaic-tree-select.mjs +4 -4
- package/esm2020/tree-select/public-api.mjs +3 -3
- package/esm2020/tree-select/tree-select.component.mjs +939 -929
- package/esm2020/tree-select/tree-select.module.mjs +47 -47
- package/fesm2015/ptsecurity-mosaic-autocomplete.mjs +726 -726
- package/fesm2015/ptsecurity-mosaic-autocomplete.mjs.map +1 -1
- package/fesm2015/ptsecurity-mosaic-button-toggle.mjs +367 -367
- package/fesm2015/ptsecurity-mosaic-button-toggle.mjs.map +1 -1
- package/fesm2015/ptsecurity-mosaic-button.mjs +160 -160
- package/fesm2015/ptsecurity-mosaic-button.mjs.map +1 -1
- package/fesm2015/ptsecurity-mosaic-card.mjs +96 -96
- package/fesm2015/ptsecurity-mosaic-card.mjs.map +1 -1
- package/fesm2015/ptsecurity-mosaic-checkbox.mjs +348 -348
- package/fesm2015/ptsecurity-mosaic-checkbox.mjs.map +1 -1
- package/fesm2015/ptsecurity-mosaic-core.mjs +2652 -2652
- package/fesm2015/ptsecurity-mosaic-core.mjs.map +1 -1
- package/fesm2015/ptsecurity-mosaic-datepicker.mjs +2682 -2684
- package/fesm2015/ptsecurity-mosaic-datepicker.mjs.map +1 -1
- package/fesm2015/ptsecurity-mosaic-design-tokens.mjs +2433 -2343
- package/fesm2015/ptsecurity-mosaic-design-tokens.mjs.map +1 -1
- package/fesm2015/ptsecurity-mosaic-divider.mjs +48 -48
- package/fesm2015/ptsecurity-mosaic-divider.mjs.map +1 -1
- package/fesm2015/ptsecurity-mosaic-dl.mjs +108 -108
- package/fesm2015/ptsecurity-mosaic-dl.mjs.map +1 -1
- package/fesm2015/ptsecurity-mosaic-dropdown.mjs +1069 -1069
- package/fesm2015/ptsecurity-mosaic-dropdown.mjs.map +1 -1
- package/fesm2015/ptsecurity-mosaic-form-field.mjs +522 -512
- package/fesm2015/ptsecurity-mosaic-form-field.mjs.map +1 -1
- package/fesm2015/ptsecurity-mosaic-icon.mjs +73 -73
- package/fesm2015/ptsecurity-mosaic-icon.mjs.map +1 -1
- package/fesm2015/ptsecurity-mosaic-input.mjs +979 -979
- package/fesm2015/ptsecurity-mosaic-input.mjs.map +1 -1
- package/fesm2015/ptsecurity-mosaic-link.mjs +121 -121
- package/fesm2015/ptsecurity-mosaic-link.mjs.map +1 -1
- package/fesm2015/ptsecurity-mosaic-list.mjs +765 -762
- package/fesm2015/ptsecurity-mosaic-list.mjs.map +1 -1
- package/fesm2015/ptsecurity-mosaic-loader-overlay.mjs +155 -0
- package/fesm2015/ptsecurity-mosaic-loader-overlay.mjs.map +1 -0
- package/fesm2015/ptsecurity-mosaic-modal.mjs +833 -824
- package/fesm2015/ptsecurity-mosaic-modal.mjs.map +1 -1
- package/fesm2015/ptsecurity-mosaic-navbar.mjs +996 -994
- package/fesm2015/ptsecurity-mosaic-navbar.mjs.map +1 -1
- package/fesm2015/ptsecurity-mosaic-popover.mjs +364 -364
- package/fesm2015/ptsecurity-mosaic-popover.mjs.map +1 -1
- package/fesm2015/ptsecurity-mosaic-progress-bar.mjs +61 -61
- package/fesm2015/ptsecurity-mosaic-progress-bar.mjs.map +1 -1
- package/fesm2015/ptsecurity-mosaic-progress-spinner.mjs +65 -65
- package/fesm2015/ptsecurity-mosaic-progress-spinner.mjs.map +1 -1
- package/fesm2015/ptsecurity-mosaic-radio.mjs +464 -464
- package/fesm2015/ptsecurity-mosaic-radio.mjs.map +1 -1
- package/fesm2015/ptsecurity-mosaic-select.mjs +1213 -1203
- package/fesm2015/ptsecurity-mosaic-select.mjs.map +1 -1
- package/fesm2015/ptsecurity-mosaic-sidebar.mjs +185 -185
- package/fesm2015/ptsecurity-mosaic-sidebar.mjs.map +1 -1
- package/fesm2015/ptsecurity-mosaic-sidepanel.mjs +555 -555
- package/fesm2015/ptsecurity-mosaic-sidepanel.mjs.map +1 -1
- package/fesm2015/ptsecurity-mosaic-splitter.mjs +511 -511
- package/fesm2015/ptsecurity-mosaic-splitter.mjs.map +1 -1
- package/fesm2015/ptsecurity-mosaic-table.mjs +36 -36
- package/fesm2015/ptsecurity-mosaic-table.mjs.map +1 -1
- package/fesm2015/ptsecurity-mosaic-tabs.mjs +1460 -1460
- package/fesm2015/ptsecurity-mosaic-tabs.mjs.map +1 -1
- package/fesm2015/ptsecurity-mosaic-tags.mjs +1342 -1342
- package/fesm2015/ptsecurity-mosaic-tags.mjs.map +1 -1
- package/fesm2015/ptsecurity-mosaic-textarea.mjs +274 -274
- package/fesm2015/ptsecurity-mosaic-textarea.mjs.map +1 -1
- package/fesm2015/ptsecurity-mosaic-timepicker.mjs +703 -714
- package/fesm2015/ptsecurity-mosaic-timepicker.mjs.map +1 -1
- package/fesm2015/ptsecurity-mosaic-toggle.mjs +163 -163
- package/fesm2015/ptsecurity-mosaic-toggle.mjs.map +1 -1
- package/fesm2015/ptsecurity-mosaic-tooltip.mjs +344 -344
- package/fesm2015/ptsecurity-mosaic-tooltip.mjs.map +1 -1
- package/fesm2015/ptsecurity-mosaic-tree-select.mjs +954 -944
- package/fesm2015/ptsecurity-mosaic-tree-select.mjs.map +1 -1
- package/fesm2015/ptsecurity-mosaic-tree.mjs +1696 -1682
- package/fesm2015/ptsecurity-mosaic-tree.mjs.map +1 -1
- package/fesm2015/ptsecurity-mosaic.mjs +2 -2
- package/fesm2020/ptsecurity-mosaic-autocomplete.mjs +722 -722
- package/fesm2020/ptsecurity-mosaic-autocomplete.mjs.map +1 -1
- package/fesm2020/ptsecurity-mosaic-button-toggle.mjs +365 -365
- package/fesm2020/ptsecurity-mosaic-button-toggle.mjs.map +1 -1
- package/fesm2020/ptsecurity-mosaic-button.mjs +160 -160
- package/fesm2020/ptsecurity-mosaic-button.mjs.map +1 -1
- package/fesm2020/ptsecurity-mosaic-card.mjs +96 -96
- package/fesm2020/ptsecurity-mosaic-card.mjs.map +1 -1
- package/fesm2020/ptsecurity-mosaic-checkbox.mjs +346 -346
- package/fesm2020/ptsecurity-mosaic-checkbox.mjs.map +1 -1
- package/fesm2020/ptsecurity-mosaic-core.mjs +2681 -2681
- package/fesm2020/ptsecurity-mosaic-core.mjs.map +1 -1
- package/fesm2020/ptsecurity-mosaic-datepicker.mjs +2667 -2669
- package/fesm2020/ptsecurity-mosaic-datepicker.mjs.map +1 -1
- package/fesm2020/ptsecurity-mosaic-design-tokens.mjs +2433 -2343
- package/fesm2020/ptsecurity-mosaic-design-tokens.mjs.map +1 -1
- package/fesm2020/ptsecurity-mosaic-divider.mjs +48 -48
- package/fesm2020/ptsecurity-mosaic-divider.mjs.map +1 -1
- package/fesm2020/ptsecurity-mosaic-dl.mjs +108 -108
- package/fesm2020/ptsecurity-mosaic-dl.mjs.map +1 -1
- package/fesm2020/ptsecurity-mosaic-dropdown.mjs +1056 -1056
- package/fesm2020/ptsecurity-mosaic-dropdown.mjs.map +1 -1
- package/fesm2020/ptsecurity-mosaic-form-field.mjs +507 -497
- package/fesm2020/ptsecurity-mosaic-form-field.mjs.map +1 -1
- package/fesm2020/ptsecurity-mosaic-icon.mjs +71 -71
- package/fesm2020/ptsecurity-mosaic-icon.mjs.map +1 -1
- package/fesm2020/ptsecurity-mosaic-input.mjs +968 -968
- package/fesm2020/ptsecurity-mosaic-input.mjs.map +1 -1
- package/fesm2020/ptsecurity-mosaic-link.mjs +120 -120
- package/fesm2020/ptsecurity-mosaic-link.mjs.map +1 -1
- package/fesm2020/ptsecurity-mosaic-list.mjs +758 -755
- package/fesm2020/ptsecurity-mosaic-list.mjs.map +1 -1
- package/fesm2020/ptsecurity-mosaic-loader-overlay.mjs +153 -0
- package/fesm2020/ptsecurity-mosaic-loader-overlay.mjs.map +1 -0
- package/fesm2020/ptsecurity-mosaic-modal.mjs +828 -820
- package/fesm2020/ptsecurity-mosaic-modal.mjs.map +1 -1
- package/fesm2020/ptsecurity-mosaic-navbar.mjs +980 -978
- package/fesm2020/ptsecurity-mosaic-navbar.mjs.map +1 -1
- package/fesm2020/ptsecurity-mosaic-popover.mjs +360 -360
- package/fesm2020/ptsecurity-mosaic-popover.mjs.map +1 -1
- package/fesm2020/ptsecurity-mosaic-progress-bar.mjs +61 -61
- package/fesm2020/ptsecurity-mosaic-progress-bar.mjs.map +1 -1
- package/fesm2020/ptsecurity-mosaic-progress-spinner.mjs +65 -65
- package/fesm2020/ptsecurity-mosaic-progress-spinner.mjs.map +1 -1
- package/fesm2020/ptsecurity-mosaic-radio.mjs +462 -462
- package/fesm2020/ptsecurity-mosaic-radio.mjs.map +1 -1
- package/fesm2020/ptsecurity-mosaic-select.mjs +1208 -1198
- package/fesm2020/ptsecurity-mosaic-select.mjs.map +1 -1
- package/fesm2020/ptsecurity-mosaic-sidebar.mjs +185 -185
- package/fesm2020/ptsecurity-mosaic-sidebar.mjs.map +1 -1
- package/fesm2020/ptsecurity-mosaic-sidepanel.mjs +552 -552
- package/fesm2020/ptsecurity-mosaic-sidepanel.mjs.map +1 -1
- package/fesm2020/ptsecurity-mosaic-splitter.mjs +511 -511
- package/fesm2020/ptsecurity-mosaic-splitter.mjs.map +1 -1
- package/fesm2020/ptsecurity-mosaic-table.mjs +36 -36
- package/fesm2020/ptsecurity-mosaic-table.mjs.map +1 -1
- package/fesm2020/ptsecurity-mosaic-tabs.mjs +1445 -1445
- package/fesm2020/ptsecurity-mosaic-tabs.mjs.map +1 -1
- package/fesm2020/ptsecurity-mosaic-tags.mjs +1335 -1335
- package/fesm2020/ptsecurity-mosaic-tags.mjs.map +1 -1
- package/fesm2020/ptsecurity-mosaic-textarea.mjs +272 -272
- package/fesm2020/ptsecurity-mosaic-textarea.mjs.map +1 -1
- package/fesm2020/ptsecurity-mosaic-timepicker.mjs +700 -711
- package/fesm2020/ptsecurity-mosaic-timepicker.mjs.map +1 -1
- package/fesm2020/ptsecurity-mosaic-toggle.mjs +163 -163
- package/fesm2020/ptsecurity-mosaic-toggle.mjs.map +1 -1
- package/fesm2020/ptsecurity-mosaic-tooltip.mjs +336 -336
- package/fesm2020/ptsecurity-mosaic-tooltip.mjs.map +1 -1
- package/fesm2020/ptsecurity-mosaic-tree-select.mjs +951 -941
- package/fesm2020/ptsecurity-mosaic-tree-select.mjs.map +1 -1
- package/fesm2020/ptsecurity-mosaic-tree.mjs +1683 -1669
- package/fesm2020/ptsecurity-mosaic-tree.mjs.map +1 -1
- package/fesm2020/ptsecurity-mosaic.mjs +2 -2
- package/form-field/cleaner.d.ts +7 -7
- package/form-field/form-field-control.d.ts +37 -37
- package/form-field/form-field-errors.d.ts +2 -2
- package/form-field/form-field.d.ts +69 -69
- package/form-field/form-field.module.d.ts +15 -15
- package/form-field/hint.d.ts +14 -6
- package/form-field/index.d.ts +1 -1
- package/form-field/password-hint.d.ts +40 -40
- package/form-field/prefix.d.ts +5 -5
- package/form-field/ptsecurity-mosaic-form-field.d.ts +5 -5
- package/form-field/public-api.d.ts +10 -10
- package/form-field/stepper.d.ts +11 -11
- package/form-field/suffix.d.ts +5 -5
- package/icon/icon.component.d.ts +18 -18
- package/icon/icon.module.d.ts +10 -10
- package/icon/index.d.ts +1 -1
- package/icon/ptsecurity-mosaic-icon.d.ts +5 -5
- package/icon/public-api.d.ts +2 -2
- package/index.d.ts +1 -1
- package/input/index.d.ts +1 -1
- package/input/input-errors.d.ts +1 -1
- package/input/input-number-validators.d.ts +39 -39
- package/input/input-number.d.ts +33 -33
- package/input/input-password.d.ts +123 -123
- package/input/input-value-accessor.d.ts +4 -4
- package/input/input.d.ts +116 -116
- package/input/input.module.d.ts +14 -14
- package/input/ptsecurity-mosaic-input.d.ts +5 -5
- package/input/public-api.d.ts +6 -6
- package/link/index.d.ts +1 -1
- package/link/link.component.d.ts +38 -38
- package/link/link.module.d.ts +9 -9
- package/link/ptsecurity-mosaic-link.d.ts +5 -5
- package/link/public-api.d.ts +2 -2
- package/list/index.d.ts +1 -1
- package/list/list-selection.component.d.ts +168 -168
- package/list/list.component.d.ts +18 -18
- package/list/list.module.d.ts +11 -11
- package/list/ptsecurity-mosaic-list.d.ts +5 -5
- package/list/public-api.d.ts +3 -3
- package/{toggle → loader-overlay}/README.md +0 -0
- package/loader-overlay/index.d.ts +1 -0
- package/loader-overlay/loader-overlay.component.d.ts +33 -0
- package/loader-overlay/loader-overlay.module.d.ts +11 -0
- package/loader-overlay/package.json +10 -0
- package/loader-overlay/ptsecurity-mosaic-loader-overlay.d.ts +5 -0
- package/loader-overlay/public-api.d.ts +2 -0
- package/modal/README.md +33 -33
- package/modal/css-unit.pipe.d.ts +7 -7
- package/modal/index.d.ts +1 -1
- package/modal/modal-control.service.d.ts +20 -20
- package/modal/modal-ref.class.d.ts +36 -36
- package/modal/modal-util.d.ts +12 -12
- package/modal/modal.component.d.ts +128 -126
- package/modal/modal.directive.d.ts +17 -17
- package/modal/modal.module.d.ts +14 -14
- package/modal/modal.service.d.ts +33 -33
- package/modal/modal.type.d.ts +60 -59
- package/modal/ptsecurity-mosaic-modal.d.ts +5 -5
- package/modal/public-api.d.ts +6 -6
- package/navbar/README.md +41 -41
- package/navbar/index.d.ts +1 -1
- package/navbar/navbar-item.component.d.ts +161 -161
- package/navbar/navbar.component.d.ts +58 -58
- package/navbar/navbar.module.d.ts +14 -14
- package/navbar/ptsecurity-mosaic-navbar.d.ts +5 -5
- package/navbar/public-api.d.ts +4 -4
- package/navbar/vertical-navbar.animation.d.ts +2 -2
- package/navbar/vertical-navbar.component.d.ts +23 -23
- package/package.json +12 -4
- package/popover/README.md +32 -32
- package/popover/index.d.ts +1 -1
- package/popover/popover-animations.d.ts +4 -4
- package/popover/popover-confirm.component.d.ts +33 -33
- package/popover/popover.component.d.ts +74 -74
- package/popover/popover.module.d.ts +12 -12
- package/popover/ptsecurity-mosaic-popover.d.ts +5 -5
- package/popover/public-api.d.ts +4 -4
- package/prebuilt-themes/dark-theme.css +1 -1
- package/prebuilt-themes/default-theme.css +1 -1
- package/progress-bar/index.d.ts +1 -1
- package/progress-bar/progress-bar.component.d.ts +18 -18
- package/progress-bar/progress-bar.module.d.ts +9 -9
- package/progress-bar/ptsecurity-mosaic-progress-bar.d.ts +5 -5
- package/progress-bar/public-api.d.ts +2 -2
- package/progress-spinner/index.d.ts +1 -1
- package/progress-spinner/progress-spinner.component.d.ts +19 -19
- package/progress-spinner/progress-spinner.module.d.ts +9 -9
- package/progress-spinner/ptsecurity-mosaic-progress-spinner.d.ts +5 -5
- package/progress-spinner/public-api.d.ts +2 -2
- package/ptsecurity-mosaic.d.ts +5 -5
- package/public-api.d.ts +1 -1
- package/radio/index.d.ts +1 -1
- package/radio/ptsecurity-mosaic-radio.d.ts +5 -5
- package/radio/public-api.d.ts +2 -2
- package/radio/radio.component.d.ts +207 -207
- package/radio/radio.module.d.ts +10 -10
- package/schematics/README.md +35 -35
- package/select/index.d.ts +1 -1
- package/select/ptsecurity-mosaic-select.d.ts +5 -5
- package/select/public-api.d.ts +3 -3
- package/select/select-option.directive.d.ts +20 -20
- package/select/select.component.d.ts +310 -307
- package/select/select.module.d.ts +15 -15
- package/sidebar/index.d.ts +1 -1
- package/sidebar/ptsecurity-mosaic-sidebar.d.ts +5 -5
- package/sidebar/public-api.d.ts +2 -2
- package/sidebar/sidebar-animations.d.ts +8 -8
- package/sidebar/sidebar.component.d.ts +53 -53
- package/sidebar/sidebar.module.d.ts +8 -8
- package/sidepanel/index.d.ts +1 -1
- package/sidepanel/ptsecurity-mosaic-sidepanel.d.ts +5 -5
- package/sidepanel/public-api.d.ts +6 -6
- package/sidepanel/sidepanel-animations.d.ts +14 -14
- package/sidepanel/sidepanel-config.d.ts +25 -25
- package/sidepanel/sidepanel-container.component.d.ts +45 -45
- package/sidepanel/sidepanel-directives.d.ts +50 -50
- package/sidepanel/sidepanel-ref.d.ts +24 -24
- package/sidepanel/sidepanel.module.d.ts +15 -15
- package/sidepanel/sidepanel.service.d.ts +57 -57
- package/splitter/index.d.ts +1 -1
- package/splitter/ptsecurity-mosaic-splitter.d.ts +5 -5
- package/splitter/public-api.d.ts +2 -2
- package/splitter/splitter.component.d.ts +130 -130
- package/splitter/splitter.module.d.ts +9 -9
- package/table/index.d.ts +1 -1
- package/table/ptsecurity-mosaic-table.d.ts +5 -5
- package/table/public-api.d.ts +2 -2
- package/table/table.component.d.ts +5 -5
- package/table/table.module.d.ts +10 -10
- package/tabs/index.d.ts +1 -1
- package/tabs/paginated-tab-header.d.ts +179 -179
- package/tabs/ptsecurity-mosaic-tabs.d.ts +5 -5
- package/tabs/public-api.d.ts +10 -10
- package/tabs/tab-body.component.d.ts +95 -95
- package/tabs/tab-content.directive.d.ts +9 -9
- package/tabs/tab-group.component.d.ts +133 -133
- package/tabs/tab-header.component.d.ts +35 -35
- package/tabs/tab-label-wrapper.directive.d.ts +30 -30
- package/tabs/tab-label.directive.d.ts +9 -9
- package/tabs/tab-nav-bar/index.d.ts +1 -1
- package/tabs/tab-nav-bar/tab-nav-bar.d.ts +38 -38
- package/tabs/tab.component.d.ts +66 -66
- package/tabs/tabs-animations.d.ts +4 -4
- package/tabs/tabs.module.d.ts +20 -20
- package/tags/index.d.ts +1 -1
- package/tags/ptsecurity-mosaic-tags.d.ts +5 -5
- package/tags/public-api.d.ts +5 -5
- package/tags/tag-default-options.d.ts +8 -8
- package/tags/tag-input.d.ts +77 -77
- package/tags/tag-list.component.d.ts +240 -240
- package/tags/tag-text-control.d.ts +10 -10
- package/tags/tag.component.d.ts +135 -135
- package/tags/tag.module.d.ts +11 -11
- package/textarea/index.d.ts +1 -1
- package/textarea/ptsecurity-mosaic-textarea.d.ts +5 -5
- package/textarea/public-api.d.ts +2 -2
- package/textarea/textarea.component.d.ts +111 -111
- package/textarea/textarea.module.d.ts +11 -11
- package/timepicker/index.d.ts +1 -1
- package/timepicker/ptsecurity-mosaic-timepicker.d.ts +5 -5
- package/timepicker/public-api.d.ts +3 -3
- package/timepicker/timepicker.constants.d.ts +20 -20
- package/timepicker/timepicker.directive.d.ts +146 -147
- package/timepicker/timepicker.module.d.ts +11 -11
- package/toggle/index.d.ts +1 -1
- package/toggle/ptsecurity-mosaic-toggle.d.ts +5 -5
- package/toggle/public-api.d.ts +2 -2
- package/toggle/toggle.component.d.ts +54 -54
- package/toggle/toggle.module.d.ts +10 -10
- package/tooltip/index.d.ts +1 -1
- package/tooltip/ptsecurity-mosaic-tooltip.d.ts +5 -5
- package/tooltip/public-api.d.ts +2 -2
- package/tooltip/tooltip.animations.d.ts +8 -8
- package/tooltip/tooltip.component.d.ts +91 -91
- package/tooltip/tooltip.module.d.ts +9 -9
- package/tree/control/base-tree-control.d.ts +40 -40
- package/tree/control/flat-tree-control.d.ts +52 -52
- package/tree/control/nested-tree-control.d.ts +19 -19
- package/tree/control/tree-control.d.ts +44 -44
- package/tree/data-source/flat-data-source.d.ts +80 -80
- package/tree/data-source/nested-data-source.d.ts +15 -15
- package/tree/index.d.ts +1 -1
- package/tree/node.d.ts +34 -34
- package/tree/outlet.d.ts +9 -9
- package/tree/padding.directive.d.ts +47 -45
- package/tree/ptsecurity-mosaic-tree.d.ts +5 -5
- package/tree/public-api.d.ts +15 -15
- package/tree/toggle.d.ts +28 -28
- package/tree/tree-base.d.ts +97 -97
- package/tree/tree-errors.d.ts +25 -25
- package/tree/tree-option.component.d.ts +72 -68
- package/tree/tree-selection.component.d.ts +132 -132
- package/tree/tree.d.ts +6 -6
- package/tree/tree.module.d.ts +16 -16
- package/tree-select/index.d.ts +1 -1
- package/tree-select/ptsecurity-mosaic-tree-select.d.ts +5 -5
- package/tree-select/public-api.d.ts +2 -2
- package/tree-select/tree-select.component.d.ts +277 -274
- package/tree-select/tree-select.module.d.ts +14 -14
@@ -24,1210 +24,1220 @@ import { McInput } from '@ptsecurity/mosaic/input';
|
|
24
24
|
import { Subscription, Subject, defer, merge } from 'rxjs';
|
25
25
|
import { take, switchMap, filter, map, distinctUntilChanged, takeUntil, startWith } from 'rxjs/operators';
|
26
26
|
|
27
|
-
class McOptionTooltip extends McTooltipTrigger {
|
28
|
-
constructor(option, overlay, elementRef, ngZone, scrollDispatcher, hostView, scrollStrategy, direction) {
|
29
|
-
super(overlay, elementRef, ngZone, scrollDispatcher, hostView, scrollStrategy, direction);
|
30
|
-
this.option = option;
|
31
|
-
}
|
32
|
-
get textElement() {
|
33
|
-
return this.option.textElement.nativeElement;
|
34
|
-
}
|
35
|
-
get isOverflown() {
|
36
|
-
return this.textElement.clientWidth < this.textElement.scrollWidth;
|
37
|
-
}
|
38
|
-
ngAfterViewInit() {
|
39
|
-
this.content = this.option.viewValue;
|
40
|
-
this.resizeObserver = new ResizeObserver(() => this.disabled = !this.isOverflown);
|
41
|
-
this.mutationObserver = new MutationObserver(() => this.content = this.option.viewValue);
|
42
|
-
this.mutationObserver.observe(this.textElement, {
|
43
|
-
characterData: true, attributes: false, childList: true, subtree: true
|
44
|
-
});
|
45
|
-
}
|
46
|
-
ngOnDestroy() {
|
47
|
-
super.ngOnDestroy();
|
48
|
-
if (this.resizeObserver) {
|
49
|
-
this.resizeObserver.unobserve(this.textElement);
|
50
|
-
this.resizeObserver.disconnect();
|
51
|
-
}
|
52
|
-
if (this.mutationObserver) {
|
53
|
-
this.mutationObserver.disconnect();
|
54
|
-
}
|
55
|
-
}
|
56
|
-
onMouseEnter() {
|
57
|
-
this.resizeObserver.observe(this.textElement);
|
58
|
-
this.disabled = !this.isOverflown;
|
59
|
-
}
|
60
|
-
onMouseLeave() {
|
61
|
-
this.resizeObserver.unobserve(this.textElement);
|
62
|
-
this.disabled = true;
|
63
|
-
}
|
64
|
-
}
|
65
|
-
/** @nocollapse */ /** @nocollapse */ McOptionTooltip.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.
|
66
|
-
/** @nocollapse */ /** @nocollapse */ McOptionTooltip.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.
|
67
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.
|
68
|
-
type: Directive,
|
69
|
-
args: [{
|
70
|
-
selector: 'mc-option',
|
71
|
-
host: {
|
72
|
-
'(mouseenter)': 'onMouseEnter()',
|
73
|
-
'(mouseleave)': 'onMouseLeave()'
|
74
|
-
}
|
75
|
-
}]
|
76
|
-
}], ctorParameters: function () { return [{ type: i1.McOption }, { type: i2.Overlay }, { type: i0.ElementRef }, { type: i0.NgZone }, { type: i2.ScrollDispatcher }, { type: i0.ViewContainerRef }, { type: undefined, decorators: [{
|
77
|
-
type: Inject,
|
78
|
-
args: [MC_TOOLTIP_SCROLL_STRATEGY]
|
79
|
-
}] }, { type: i3.Directionality, decorators: [{
|
80
|
-
type: Optional
|
27
|
+
class McOptionTooltip extends McTooltipTrigger {
|
28
|
+
constructor(option, overlay, elementRef, ngZone, scrollDispatcher, hostView, scrollStrategy, direction) {
|
29
|
+
super(overlay, elementRef, ngZone, scrollDispatcher, hostView, scrollStrategy, direction);
|
30
|
+
this.option = option;
|
31
|
+
}
|
32
|
+
get textElement() {
|
33
|
+
return this.option.textElement.nativeElement;
|
34
|
+
}
|
35
|
+
get isOverflown() {
|
36
|
+
return this.textElement.clientWidth < this.textElement.scrollWidth;
|
37
|
+
}
|
38
|
+
ngAfterViewInit() {
|
39
|
+
this.content = this.option.viewValue;
|
40
|
+
this.resizeObserver = new ResizeObserver(() => this.disabled = !this.isOverflown);
|
41
|
+
this.mutationObserver = new MutationObserver(() => this.content = this.option.viewValue);
|
42
|
+
this.mutationObserver.observe(this.textElement, {
|
43
|
+
characterData: true, attributes: false, childList: true, subtree: true
|
44
|
+
});
|
45
|
+
}
|
46
|
+
ngOnDestroy() {
|
47
|
+
super.ngOnDestroy();
|
48
|
+
if (this.resizeObserver) {
|
49
|
+
this.resizeObserver.unobserve(this.textElement);
|
50
|
+
this.resizeObserver.disconnect();
|
51
|
+
}
|
52
|
+
if (this.mutationObserver) {
|
53
|
+
this.mutationObserver.disconnect();
|
54
|
+
}
|
55
|
+
}
|
56
|
+
onMouseEnter() {
|
57
|
+
this.resizeObserver.observe(this.textElement);
|
58
|
+
this.disabled = !this.isOverflown;
|
59
|
+
}
|
60
|
+
onMouseLeave() {
|
61
|
+
this.resizeObserver.unobserve(this.textElement);
|
62
|
+
this.disabled = true;
|
63
|
+
}
|
64
|
+
}
|
65
|
+
/** @nocollapse */ /** @nocollapse */ McOptionTooltip.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: McOptionTooltip, deps: [{ token: i1.McOption }, { token: i2.Overlay }, { token: i0.ElementRef }, { token: i0.NgZone }, { token: i2.ScrollDispatcher }, { token: i0.ViewContainerRef }, { token: MC_TOOLTIP_SCROLL_STRATEGY }, { token: i3.Directionality, optional: true }], target: i0.ɵɵFactoryTarget.Directive });
|
66
|
+
/** @nocollapse */ /** @nocollapse */ McOptionTooltip.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.11", type: McOptionTooltip, selector: "mc-option", host: { listeners: { "mouseenter": "onMouseEnter()", "mouseleave": "onMouseLeave()" } }, usesInheritance: true, ngImport: i0 });
|
67
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: McOptionTooltip, decorators: [{
|
68
|
+
type: Directive,
|
69
|
+
args: [{
|
70
|
+
selector: 'mc-option',
|
71
|
+
host: {
|
72
|
+
'(mouseenter)': 'onMouseEnter()',
|
73
|
+
'(mouseleave)': 'onMouseLeave()'
|
74
|
+
}
|
75
|
+
}]
|
76
|
+
}], ctorParameters: function () { return [{ type: i1.McOption }, { type: i2.Overlay }, { type: i0.ElementRef }, { type: i0.NgZone }, { type: i2.ScrollDispatcher }, { type: i0.ViewContainerRef }, { type: undefined, decorators: [{
|
77
|
+
type: Inject,
|
78
|
+
args: [MC_TOOLTIP_SCROLL_STRATEGY]
|
79
|
+
}] }, { type: i3.Directionality, decorators: [{
|
80
|
+
type: Optional
|
81
81
|
}] }]; } });
|
82
82
|
|
83
|
-
/* tslint:disable:no-empty */
|
84
|
-
let nextUniqueId = 0;
|
85
|
-
/** Change event object that is emitted when the select value has changed. */
|
86
|
-
class McSelectChange {
|
87
|
-
constructor(source, value) {
|
88
|
-
this.source = source;
|
89
|
-
this.value = value;
|
90
|
-
}
|
91
|
-
}
|
92
|
-
class McSelectSearch {
|
93
|
-
constructor(formField) {
|
94
|
-
this.searchChangesSubscription = new Subscription();
|
95
|
-
this.isSearchChanged = false;
|
96
|
-
formField.canCleanerClearByEsc = false;
|
97
|
-
}
|
98
|
-
focus() {
|
99
|
-
this.input.focus();
|
100
|
-
}
|
101
|
-
reset() {
|
102
|
-
this.input.ngControl.reset();
|
103
|
-
}
|
104
|
-
ngAfterContentInit() {
|
105
|
-
if (!this.input) {
|
106
|
-
throw Error('McSelectSearch does not work without mcInput');
|
107
|
-
}
|
108
|
-
if (!this.input.ngControl) {
|
109
|
-
throw Error('McSelectSearch does not work without ngControl');
|
110
|
-
}
|
111
|
-
Promise.resolve().then(() => {
|
112
|
-
this.searchChangesSubscription = this.input.ngControl.valueChanges.subscribe(() => {
|
113
|
-
this.isSearchChanged = true;
|
114
|
-
});
|
115
|
-
});
|
116
|
-
}
|
117
|
-
ngOnDestroy() {
|
118
|
-
this.searchChangesSubscription.unsubscribe();
|
119
|
-
}
|
120
|
-
handleKeydown(event) {
|
121
|
-
// tslint:disable-next-line:deprecation
|
122
|
-
if (event.keyCode === ESCAPE) {
|
123
|
-
if (this.input.value) {
|
124
|
-
this.reset();
|
125
|
-
event.stopPropagation();
|
126
|
-
}
|
127
|
-
}
|
128
|
-
// tslint:disable-next-line:deprecation
|
129
|
-
if ([SPACE, HOME, END].includes(event.keyCode)) {
|
130
|
-
event.stopPropagation();
|
131
|
-
}
|
132
|
-
}
|
133
|
-
}
|
134
|
-
/** @nocollapse */ /** @nocollapse */ McSelectSearch.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.
|
135
|
-
/** @nocollapse */ /** @nocollapse */ McSelectSearch.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.
|
136
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.
|
137
|
-
type: Directive,
|
138
|
-
args: [{
|
139
|
-
selector: '[mcSelectSearch]',
|
140
|
-
exportAs: 'mcSelectSearch',
|
141
|
-
host: {
|
142
|
-
'(keydown)': 'handleKeydown($event)'
|
143
|
-
}
|
144
|
-
}]
|
145
|
-
}], ctorParameters: function () { return [{ type: i1$1.McFormField }]; }, propDecorators: { input: [{
|
146
|
-
type: ContentChild,
|
147
|
-
args: [McInput, { static: false }]
|
148
|
-
}] } });
|
149
|
-
class McSelectSearchEmptyResult {
|
150
|
-
}
|
151
|
-
/** @nocollapse */ /** @nocollapse */ McSelectSearchEmptyResult.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.
|
152
|
-
/** @nocollapse */ /** @nocollapse */ McSelectSearchEmptyResult.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.
|
153
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.
|
154
|
-
type: Directive,
|
155
|
-
args: [{
|
156
|
-
selector: '[mc-select-search-empty-result]',
|
157
|
-
exportAs: 'mcSelectSearchEmptyResult'
|
158
|
-
}]
|
159
|
-
}] });
|
160
|
-
class McSelectTrigger {
|
161
|
-
}
|
162
|
-
/** @nocollapse */ /** @nocollapse */ McSelectTrigger.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.
|
163
|
-
/** @nocollapse */ /** @nocollapse */ McSelectTrigger.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.
|
164
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.
|
165
|
-
type: Directive,
|
166
|
-
args: [{ selector: 'mc-select-trigger' }]
|
167
|
-
}] });
|
168
|
-
class McSelectBase {
|
169
|
-
constructor(elementRef, defaultErrorStateMatcher, parentForm, parentFormGroup, ngControl) {
|
170
|
-
this.elementRef = elementRef;
|
171
|
-
this.defaultErrorStateMatcher = defaultErrorStateMatcher;
|
172
|
-
this.parentForm = parentForm;
|
173
|
-
this.parentFormGroup = parentFormGroup;
|
174
|
-
this.ngControl = ngControl;
|
175
|
-
}
|
176
|
-
}
|
177
|
-
// tslint:disable-next-line:naming-convention
|
178
|
-
const McSelectMixinBase = mixinTabIndex(mixinDisabled(mixinErrorState(McSelectBase)));
|
179
|
-
class McSelect extends McSelectMixinBase {
|
180
|
-
constructor(_changeDetectorRef, _ngZone, _renderer, defaultErrorStateMatcher, elementRef, rawValidators, _dir, parentForm, parentFormGroup, _parentFormField, ngControl, ngModel, formControlName, _scrollStrategyFactory, mcValidation) {
|
181
|
-
super(elementRef, defaultErrorStateMatcher, parentForm, parentFormGroup, ngControl);
|
182
|
-
this._changeDetectorRef = _changeDetectorRef;
|
183
|
-
this._ngZone = _ngZone;
|
184
|
-
this._renderer = _renderer;
|
185
|
-
this.rawValidators = rawValidators;
|
186
|
-
this._dir = _dir;
|
187
|
-
this._parentFormField = _parentFormField;
|
188
|
-
this.ngModel = ngModel;
|
189
|
-
this.formControlName = formControlName;
|
190
|
-
this._scrollStrategyFactory = _scrollStrategyFactory;
|
191
|
-
this.mcValidation = mcValidation;
|
192
|
-
/** A name for this control that can be used by `mc-form-field`. */
|
193
|
-
this.controlType = 'select';
|
194
|
-
this.hiddenItems = 0;
|
195
|
-
/** The cached font-size of the trigger element. */
|
196
|
-
this.triggerFontSize = 0;
|
197
|
-
this.previousSelectionModelSelected = [];
|
198
|
-
/** The value of the select panel's transform-origin property. */
|
199
|
-
this.transformOrigin = 'top';
|
200
|
-
/** Emits when the panel element is finished transforming in. */
|
201
|
-
this.panelDoneAnimatingStream = new Subject();
|
202
|
-
/** Strategy that will be used to handle scrolling while the select panel is open. */
|
203
|
-
this.scrollStrategy = this._scrollStrategyFactory();
|
204
|
-
/**
|
205
|
-
* The y-offset of the overlay panel in relation to the trigger's top start corner.
|
206
|
-
* This must be adjusted to align the selected option text over the trigger text.
|
207
|
-
* when the panel opens. Will change based on the y-position of the selected option.
|
208
|
-
*/
|
209
|
-
this.offsetY = 0;
|
210
|
-
/**
|
211
|
-
* This position config ensures that the top "start" corner of the overlay
|
212
|
-
* is aligned with with the top "start" of the origin by default (overlapping
|
213
|
-
* the trigger completely). If the panel cannot fit below the trigger, it
|
214
|
-
* will fall back to a position above the trigger.
|
215
|
-
*/
|
216
|
-
this.positions = [
|
217
|
-
{
|
218
|
-
originX: 'start',
|
219
|
-
originY: 'bottom',
|
220
|
-
overlayX: 'start',
|
221
|
-
overlayY: 'top'
|
222
|
-
},
|
223
|
-
{
|
224
|
-
originX: 'start',
|
225
|
-
originY: 'top',
|
226
|
-
overlayX: 'start',
|
227
|
-
overlayY: 'bottom'
|
228
|
-
}
|
229
|
-
];
|
230
|
-
this.hiddenItemsText = '...ещё';
|
231
|
-
this.backdropClass = 'cdk-overlay-transparent-backdrop';
|
232
|
-
/** Combined stream of all of the child options' change events. */
|
233
|
-
this.optionSelectionChanges = defer(() => {
|
234
|
-
if (this.options) {
|
235
|
-
return merge(...this.options.map((option) => option.onSelectionChange), ...this.selectionModel.selected.map((option) => option.onSelectionChange));
|
236
|
-
}
|
237
|
-
return this._ngZone.onStable
|
238
|
-
.asObservable()
|
239
|
-
.pipe(take(1), switchMap(() => this.optionSelectionChanges));
|
240
|
-
});
|
241
|
-
/** Event emitted when the select panel has been toggled. */
|
242
|
-
this.openedChange = new EventEmitter();
|
243
|
-
/** Event emitted when the select has been opened. */
|
244
|
-
this.openedStream = this.openedChange.pipe(filter((o) => o), map(() => { }));
|
245
|
-
/** Event emitted when the select has been closed. */
|
246
|
-
this.closedStream = this.openedChange.pipe(filter((o) => !o), map(() => { }));
|
247
|
-
/** Event emitted when the selected value has been changed by the user. */
|
248
|
-
this.selectionChange = new EventEmitter();
|
249
|
-
/**
|
250
|
-
* Event that emits whenever the raw value of the select changes. This is here primarily
|
251
|
-
* to facilitate the two-way binding for the `value` input.
|
252
|
-
* @docs-private
|
253
|
-
*/
|
254
|
-
this.valueChange = new EventEmitter();
|
255
|
-
this._hasBackdrop = false;
|
256
|
-
this._required = false;
|
257
|
-
this._multiple = false;
|
258
|
-
this.
|
259
|
-
this.
|
260
|
-
this.
|
261
|
-
|
262
|
-
|
263
|
-
|
264
|
-
this.
|
265
|
-
|
266
|
-
|
267
|
-
|
268
|
-
|
269
|
-
|
270
|
-
|
271
|
-
|
272
|
-
|
273
|
-
|
274
|
-
|
275
|
-
//
|
276
|
-
|
277
|
-
|
278
|
-
|
279
|
-
|
280
|
-
|
281
|
-
|
282
|
-
|
283
|
-
|
284
|
-
|
285
|
-
|
286
|
-
|
287
|
-
|
288
|
-
|
289
|
-
|
290
|
-
|
291
|
-
|
292
|
-
this.
|
293
|
-
|
294
|
-
|
295
|
-
|
296
|
-
|
297
|
-
|
298
|
-
|
299
|
-
this.
|
300
|
-
|
301
|
-
|
302
|
-
|
303
|
-
|
304
|
-
|
305
|
-
|
306
|
-
|
307
|
-
|
308
|
-
|
309
|
-
|
310
|
-
|
311
|
-
|
312
|
-
*
|
313
|
-
*
|
314
|
-
|
315
|
-
|
316
|
-
|
317
|
-
|
318
|
-
|
319
|
-
|
320
|
-
|
321
|
-
|
322
|
-
|
323
|
-
|
324
|
-
|
325
|
-
|
326
|
-
|
327
|
-
|
328
|
-
|
329
|
-
|
330
|
-
|
331
|
-
|
332
|
-
|
333
|
-
|
334
|
-
|
335
|
-
|
336
|
-
this.
|
337
|
-
|
338
|
-
|
339
|
-
|
340
|
-
|
341
|
-
|
342
|
-
|
343
|
-
|
344
|
-
this.
|
345
|
-
|
346
|
-
|
347
|
-
get
|
348
|
-
return this.
|
349
|
-
}
|
350
|
-
set
|
351
|
-
this.
|
352
|
-
|
353
|
-
|
354
|
-
|
355
|
-
}
|
356
|
-
|
357
|
-
|
358
|
-
|
359
|
-
|
360
|
-
|
361
|
-
|
362
|
-
|
363
|
-
|
364
|
-
|
365
|
-
|
366
|
-
|
367
|
-
|
368
|
-
|
369
|
-
|
370
|
-
|
371
|
-
|
372
|
-
|
373
|
-
if (this.
|
374
|
-
|
375
|
-
}
|
376
|
-
return
|
377
|
-
}
|
378
|
-
get
|
379
|
-
|
380
|
-
|
381
|
-
|
382
|
-
|
383
|
-
this.
|
384
|
-
|
385
|
-
|
386
|
-
|
387
|
-
|
388
|
-
|
389
|
-
|
390
|
-
|
391
|
-
|
392
|
-
|
393
|
-
|
394
|
-
|
395
|
-
|
396
|
-
|
397
|
-
|
398
|
-
|
399
|
-
|
400
|
-
|
401
|
-
|
402
|
-
|
403
|
-
|
404
|
-
|
405
|
-
|
406
|
-
|
407
|
-
|
408
|
-
|
409
|
-
|
410
|
-
|
411
|
-
|
412
|
-
|
413
|
-
|
414
|
-
this.
|
415
|
-
|
416
|
-
|
417
|
-
|
418
|
-
|
419
|
-
|
420
|
-
|
421
|
-
|
422
|
-
|
423
|
-
|
424
|
-
|
425
|
-
|
426
|
-
|
427
|
-
|
428
|
-
|
429
|
-
|
430
|
-
|
431
|
-
|
432
|
-
|
433
|
-
|
434
|
-
|
435
|
-
|
436
|
-
|
437
|
-
|
438
|
-
|
439
|
-
|
440
|
-
|
441
|
-
|
442
|
-
|
443
|
-
|
444
|
-
|
445
|
-
|
446
|
-
|
447
|
-
|
448
|
-
|
449
|
-
|
450
|
-
this.
|
451
|
-
this.
|
452
|
-
this.
|
453
|
-
|
454
|
-
|
455
|
-
|
456
|
-
|
457
|
-
|
458
|
-
|
459
|
-
|
460
|
-
|
461
|
-
|
462
|
-
|
463
|
-
|
464
|
-
|
465
|
-
|
466
|
-
|
467
|
-
|
468
|
-
|
469
|
-
|
470
|
-
|
471
|
-
|
472
|
-
|
473
|
-
|
474
|
-
|
475
|
-
|
476
|
-
open
|
477
|
-
|
478
|
-
|
479
|
-
|
480
|
-
|
481
|
-
|
482
|
-
|
483
|
-
|
484
|
-
|
485
|
-
|
486
|
-
|
487
|
-
this.
|
488
|
-
|
489
|
-
|
490
|
-
|
491
|
-
|
492
|
-
|
493
|
-
|
494
|
-
|
495
|
-
|
496
|
-
|
497
|
-
|
498
|
-
|
499
|
-
|
500
|
-
|
501
|
-
|
502
|
-
|
503
|
-
|
504
|
-
|
505
|
-
|
506
|
-
|
507
|
-
|
508
|
-
|
509
|
-
|
510
|
-
|
511
|
-
|
512
|
-
|
513
|
-
|
514
|
-
|
515
|
-
|
516
|
-
|
517
|
-
|
518
|
-
|
519
|
-
|
520
|
-
|
521
|
-
|
522
|
-
*
|
523
|
-
*
|
524
|
-
*
|
525
|
-
|
526
|
-
|
527
|
-
|
528
|
-
|
529
|
-
|
530
|
-
}
|
531
|
-
/**
|
532
|
-
* Saves a callback function to be invoked when the select
|
533
|
-
*
|
534
|
-
* to integrate with Angular's core forms API.
|
535
|
-
*
|
536
|
-
* @param fn Callback to be triggered when the
|
537
|
-
*/
|
538
|
-
|
539
|
-
this.
|
540
|
-
}
|
541
|
-
/**
|
542
|
-
*
|
543
|
-
*
|
544
|
-
*
|
545
|
-
*
|
546
|
-
|
547
|
-
|
548
|
-
|
549
|
-
this.
|
550
|
-
|
551
|
-
|
552
|
-
|
553
|
-
|
554
|
-
|
555
|
-
|
556
|
-
|
557
|
-
|
558
|
-
|
559
|
-
|
560
|
-
|
561
|
-
|
562
|
-
|
563
|
-
|
564
|
-
|
565
|
-
|
566
|
-
|
567
|
-
|
568
|
-
|
569
|
-
|
570
|
-
|
571
|
-
|
572
|
-
|
573
|
-
|
574
|
-
|
575
|
-
|
576
|
-
|
577
|
-
this.
|
578
|
-
|
579
|
-
this.
|
580
|
-
|
581
|
-
|
582
|
-
|
583
|
-
|
584
|
-
|
585
|
-
|
586
|
-
|
587
|
-
|
588
|
-
this.
|
589
|
-
.
|
590
|
-
.
|
591
|
-
this.
|
592
|
-
|
593
|
-
|
594
|
-
|
595
|
-
|
596
|
-
|
597
|
-
|
598
|
-
|
599
|
-
|
600
|
-
|
601
|
-
|
602
|
-
|
603
|
-
|
604
|
-
|
605
|
-
|
606
|
-
|
607
|
-
|
608
|
-
|
609
|
-
|
610
|
-
|
611
|
-
|
612
|
-
|
613
|
-
|
614
|
-
|
615
|
-
|
616
|
-
|
617
|
-
|
618
|
-
|
619
|
-
|
620
|
-
|
621
|
-
|
622
|
-
|
623
|
-
|
624
|
-
|
625
|
-
|
626
|
-
|
627
|
-
|
628
|
-
|
629
|
-
|
630
|
-
|
631
|
-
|
632
|
-
|
633
|
-
|
634
|
-
|
635
|
-
|
636
|
-
|
637
|
-
|
638
|
-
|
639
|
-
|
640
|
-
|
641
|
-
|
642
|
-
|
643
|
-
|
644
|
-
|
645
|
-
|
646
|
-
|
647
|
-
|
648
|
-
|
649
|
-
|
650
|
-
|
651
|
-
|
652
|
-
|
653
|
-
|
654
|
-
|
655
|
-
|
656
|
-
|
657
|
-
|
658
|
-
|
659
|
-
|
660
|
-
|
661
|
-
|
662
|
-
|
663
|
-
|
664
|
-
}
|
665
|
-
|
666
|
-
|
667
|
-
|
668
|
-
|
669
|
-
|
670
|
-
|
671
|
-
|
672
|
-
|
673
|
-
|
674
|
-
|
675
|
-
|
676
|
-
this.
|
677
|
-
|
678
|
-
|
679
|
-
|
680
|
-
|
681
|
-
|
682
|
-
|
683
|
-
triggerClone.remove();
|
684
|
-
|
685
|
-
|
686
|
-
|
687
|
-
|
688
|
-
|
689
|
-
|
690
|
-
|
691
|
-
|
692
|
-
|
693
|
-
|
694
|
-
|
695
|
-
|
696
|
-
|
697
|
-
const
|
698
|
-
const
|
699
|
-
|
700
|
-
|
701
|
-
|
702
|
-
|
703
|
-
|
704
|
-
|
705
|
-
|
706
|
-
|
707
|
-
|
708
|
-
|
709
|
-
|
710
|
-
|
711
|
-
|
712
|
-
|
713
|
-
|
714
|
-
|
715
|
-
|
716
|
-
|
717
|
-
|
718
|
-
|
719
|
-
|
720
|
-
|
721
|
-
|
722
|
-
|
723
|
-
|
724
|
-
|
725
|
-
|
726
|
-
|
727
|
-
|
728
|
-
|
729
|
-
|
730
|
-
|
731
|
-
|
732
|
-
|
733
|
-
|
734
|
-
|
735
|
-
|
736
|
-
|
737
|
-
|
738
|
-
|
739
|
-
|
740
|
-
|
741
|
-
|
742
|
-
|
743
|
-
|
744
|
-
|
745
|
-
|
746
|
-
|
747
|
-
|
748
|
-
|
749
|
-
|
750
|
-
|
751
|
-
|
752
|
-
|
753
|
-
|
754
|
-
|
755
|
-
|
756
|
-
|
757
|
-
|
758
|
-
|
759
|
-
|
760
|
-
|
761
|
-
|
762
|
-
|
763
|
-
|
764
|
-
|
765
|
-
|
766
|
-
|
767
|
-
|
768
|
-
|
769
|
-
|
770
|
-
|
771
|
-
|
772
|
-
|
773
|
-
|
774
|
-
|
775
|
-
|
776
|
-
|
777
|
-
|
778
|
-
|
779
|
-
|
780
|
-
|
781
|
-
|
782
|
-
|
783
|
-
|
784
|
-
|
785
|
-
|
786
|
-
|
787
|
-
|
788
|
-
|
789
|
-
|
790
|
-
|
791
|
-
|
792
|
-
|
793
|
-
|
794
|
-
|
795
|
-
|
796
|
-
|
797
|
-
|
798
|
-
|
799
|
-
|
800
|
-
|
801
|
-
|
802
|
-
|
803
|
-
|
804
|
-
|
805
|
-
|
806
|
-
|
807
|
-
|
808
|
-
|
809
|
-
|
810
|
-
|
811
|
-
|
812
|
-
|
813
|
-
|
814
|
-
|
815
|
-
|
816
|
-
|
817
|
-
|
818
|
-
|
819
|
-
|
820
|
-
}
|
821
|
-
|
822
|
-
|
823
|
-
|
824
|
-
|
825
|
-
|
826
|
-
|
827
|
-
|
828
|
-
|
829
|
-
|
830
|
-
|
831
|
-
|
832
|
-
|
833
|
-
|
834
|
-
|
835
|
-
|
836
|
-
|
837
|
-
|
838
|
-
|
839
|
-
.
|
840
|
-
|
841
|
-
|
842
|
-
|
843
|
-
|
844
|
-
|
845
|
-
|
846
|
-
|
847
|
-
});
|
848
|
-
|
849
|
-
|
850
|
-
|
851
|
-
|
852
|
-
|
853
|
-
|
854
|
-
.
|
855
|
-
|
856
|
-
|
857
|
-
|
858
|
-
|
859
|
-
|
860
|
-
|
861
|
-
|
862
|
-
|
863
|
-
|
864
|
-
|
865
|
-
|
866
|
-
|
867
|
-
|
868
|
-
|
869
|
-
|
870
|
-
this.
|
871
|
-
|
872
|
-
|
873
|
-
|
874
|
-
|
875
|
-
|
876
|
-
|
877
|
-
|
878
|
-
|
879
|
-
|
880
|
-
this.
|
881
|
-
|
882
|
-
|
883
|
-
|
884
|
-
|
885
|
-
|
886
|
-
|
887
|
-
|
888
|
-
|
889
|
-
|
890
|
-
|
891
|
-
|
892
|
-
|
893
|
-
|
894
|
-
|
895
|
-
|
896
|
-
|
897
|
-
|
898
|
-
|
899
|
-
|
900
|
-
|
901
|
-
|
902
|
-
|
903
|
-
|
904
|
-
|
905
|
-
|
906
|
-
|
907
|
-
|
908
|
-
|
909
|
-
|
910
|
-
|
911
|
-
|
912
|
-
|
913
|
-
|
914
|
-
|
915
|
-
|
916
|
-
|
917
|
-
|
918
|
-
|
919
|
-
|
920
|
-
|
921
|
-
|
922
|
-
|
923
|
-
|
924
|
-
|
925
|
-
|
926
|
-
|
927
|
-
|
928
|
-
|
929
|
-
|
930
|
-
|
931
|
-
|
932
|
-
|
933
|
-
}
|
934
|
-
|
935
|
-
|
936
|
-
|
937
|
-
|
938
|
-
this.
|
939
|
-
|
940
|
-
|
941
|
-
|
942
|
-
|
943
|
-
|
944
|
-
|
945
|
-
|
946
|
-
|
947
|
-
|
948
|
-
|
949
|
-
|
950
|
-
|
951
|
-
|
952
|
-
|
953
|
-
|
954
|
-
|
955
|
-
|
956
|
-
|
957
|
-
|
958
|
-
|
959
|
-
|
960
|
-
|
961
|
-
|
962
|
-
|
963
|
-
|
964
|
-
|
965
|
-
|
966
|
-
this.
|
967
|
-
|
968
|
-
|
969
|
-
|
970
|
-
|
971
|
-
|
972
|
-
|
973
|
-
|
974
|
-
|
975
|
-
|
976
|
-
|
977
|
-
|
978
|
-
|
979
|
-
|
980
|
-
|
981
|
-
|
982
|
-
const
|
983
|
-
|
984
|
-
|
985
|
-
|
986
|
-
|
987
|
-
|
988
|
-
|
989
|
-
|
990
|
-
|
991
|
-
//
|
992
|
-
|
993
|
-
|
994
|
-
|
995
|
-
|
996
|
-
|
997
|
-
|
998
|
-
|
999
|
-
|
1000
|
-
//
|
1001
|
-
|
1002
|
-
|
1003
|
-
|
1004
|
-
|
1005
|
-
|
1006
|
-
|
1007
|
-
|
1008
|
-
|
1009
|
-
|
1010
|
-
|
1011
|
-
|
1012
|
-
|
1013
|
-
|
1014
|
-
|
1015
|
-
|
1016
|
-
|
1017
|
-
|
1018
|
-
|
1019
|
-
|
1020
|
-
|
1021
|
-
|
1022
|
-
|
1023
|
-
|
1024
|
-
|
1025
|
-
|
1026
|
-
|
1027
|
-
|
1028
|
-
|
1029
|
-
|
1030
|
-
|
1031
|
-
|
1032
|
-
|
1033
|
-
|
1034
|
-
|
1035
|
-
|
1036
|
-
|
1037
|
-
|
1038
|
-
|
1039
|
-
|
1040
|
-
], queries: [{ propertyName: "customTrigger", first: true, predicate: McSelectTrigger, descendants: true }, { propertyName: "cleaner", first: true, predicate: ["mcSelectCleaner"], descendants: true, static: true }, { propertyName: "search", first: true, predicate: McSelectSearch, descendants: true }, { propertyName: "options", predicate: McOption, descendants: true }, { propertyName: "optionGroups", predicate: McOptgroup }], viewQueries: [{ propertyName: "trigger", first: true, predicate: ["trigger"], descendants: true }, { propertyName: "panel", first: true, predicate: ["panel"], descendants: true }, { propertyName: "optionsContainer", first: true, predicate: ["optionsContainer"], descendants: true }, { propertyName: "overlayDir", first: true, predicate: CdkConnectedOverlay, descendants: true }, { propertyName: "tags", predicate: McTag, descendants: true }], exportAs: ["mcSelect"], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div cdk-overlay-origin\r\n class=\"mc-select__trigger\"\r\n (click)=\"toggle()\"\r\n [class.mc-select__trigger_multiple]=\"multiple\"\r\n #origin=\"cdkOverlayOrigin\"\r\n #trigger>\r\n <div class=\"mc-select__matcher\" [ngSwitch]=\"empty\">\r\n <span class=\"mc-select__placeholder\" *ngSwitchCase=\"true\">{{ placeholder || '\\u00A0' }}</span>\r\n <span *ngSwitchCase=\"false\" [ngSwitch]=\"!!customTrigger\">\r\n <div *ngSwitchDefault [ngSwitch]=\"multiple\" class=\"mc-select__match-container\">\r\n <span *ngSwitchCase=\"false\" class=\"mc-select__matcher-text\">{{ triggerValue }}</span>\r\n <div *ngSwitchCase=\"true\" class=\"mc-select__match-list\">\r\n <mc-tag *ngFor=\"let option of triggerValues\"\r\n [disabled]=\"option.disabled || disabled\"\r\n [selectable]=\"false\"\r\n [class.mc-error]=\"errorState\">\r\n {{ option.viewValue }}\r\n <i mc-icon=\"mc-close-S_16\"\r\n *ngIf=\"!option.disabled && !disabled\"\r\n (click)=\"onRemoveMatcherItem(option, $event)\">\r\n </i>\r\n </mc-tag>\r\n </div>\r\n <div class=\"mc-select__match-hidden-text\" [style.display]=\"hiddenItems > 0 ? 'block' : 'none'\">\r\n {{ hiddenItemsTextFormatter(hiddenItemsText, hiddenItems) }}\r\n </div>\r\n </div>\r\n <ng-content select=\"mc-select-trigger\" *ngSwitchCase=\"true\"></ng-content>\r\n </span>\r\n </div>\r\n\r\n <div class=\"mc-select__cleaner\" *ngIf=\"canShowCleaner\" (click)=\"clearValue($event)\">\r\n <ng-content select=\"mc-cleaner\"></ng-content>\r\n </div>\r\n\r\n <div class=\"mc-select__arrow-wrapper\">\r\n <i class=\"mc-select__arrow\" mc-icon=\"mc-angle-down-S_16\"></i>\r\n </div>\r\n</div>\r\n\r\n<ng-template\r\n cdk-connected-overlay\r\n cdkConnectedOverlayLockPosition\r\n [cdkConnectedOverlayHasBackdrop]=\"hasBackdrop\"\r\n [cdkConnectedOverlayBackdropClass]=\"backdropClass\"\r\n [cdkConnectedOverlayScrollStrategy]=\"scrollStrategy\"\r\n [cdkConnectedOverlayOrigin]=\"origin\"\r\n [cdkConnectedOverlayOpen]=\"panelOpen\"\r\n [cdkConnectedOverlayPositions]=\"positions\"\r\n [cdkConnectedOverlayMinWidth]=\"triggerRect?.width!\"\r\n [cdkConnectedOverlayOffsetY]=\"offsetY\"\r\n (backdropClick)=\"close()\"\r\n (attach)=\"onAttached()\"\r\n (detach)=\"close()\">\r\n <div\r\n #panel\r\n class=\"mc-select__panel {{ getPanelTheme() }}\"\r\n [ngClass]=\"panelClass\"\r\n [style.transformOrigin]=\"transformOrigin\"\r\n [style.font-size.px]=\"triggerFontSize\"\r\n (keydown)=\"handleKeydown($event)\">\r\n\r\n <div *ngIf=\"search\" class=\"mc-select__search-container\">\r\n <ng-content select=\"[mcSelectSearch]\"></ng-content>\r\n </div>\r\n\r\n <div #optionsContainer\r\n class=\"mc-select__content\"\r\n [@fadeInContent]=\"'showing'\"\r\n (@fadeInContent.done)=\"panelDoneAnimatingStream.next($event.toState)\">\r\n\r\n <div *ngIf=\"isEmptySearchResult\" class=\"mc-select__no-options-message\">\r\n <ng-content select=\"[mc-select-search-empty-result]\"></ng-content>\r\n </div>\r\n <ng-content></ng-content>\r\n </div>\r\n </div>\r\n</ng-template>\r\n", styles: [".mc-option{display:flex;flex-direction:row;align-items:center;box-sizing:border-box;position:relative;max-width:100%;height:var(--mc-option-size-height, 32px);border:var(--mc-option-size-border-width, 2px) solid transparent;cursor:pointer;outline:none;padding-left:var(--mc-option-size-horizontal-padding, 12px);padding-right:var(--mc-option-size-horizontal-padding, 12px);-webkit-tap-highlight-color:transparent}.mc-option.mc-disabled{cursor:default}.mc-option .mc-pseudo-checkbox{margin-right:8px}.mc-option .mc-option-overlay{position:absolute;top:calc(-1 * var(--mc-option-size-border-width, 2px));left:calc(-1 * var(--mc-option-size-border-width, 2px));right:calc(-1 * var(--mc-option-size-border-width, 2px));bottom:calc(-1 * var(--mc-option-size-border-width, 2px));pointer-events:none;border-radius:inherit}.mc-option-text{display:inline-block;flex-grow:1;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.mc-select{box-sizing:border-box;display:inline-block;width:100%;outline:none}.mc-select .mc-select__trigger{display:flex;box-sizing:border-box;position:relative;height:calc(var(--mc-form-field-size-height, 32px) - var(--mc-form-field-size-border-width, 1px) * 2);cursor:pointer;padding-left:calc(var(--mc-select-size-left-padding, 12px) - var(--mc-form-field-size-border-width, 1px));padding-right:calc(var(--mc-select-size-right-padding, 6px) - var(--mc-form-field-size-border-width, 1px))}.mc-select .mc-select__trigger.mc-select__trigger_multiple{padding-left:calc(var(--mc-select-size-left-padding-multiple, 12px) - var(--mc-form-field-size-border-width, 1px))}.mc-select .mc-select__trigger.mc-select__trigger_multiple .mc-tag.mc-disabled .mc-tag__text{margin-right:7px}.mc-select.mc-disabled .mc-select__trigger{-webkit-user-select:none;user-select:none;cursor:default}.mc-select__no-options-message{display:flex;flex-direction:row;align-items:center;box-sizing:border-box;position:relative;max-width:100%;height:var(--mc-option-size-height, 32px);cursor:default;outline:none;padding-left:var(--mc-option-size-horizontal-padding, 12px);padding-right:var(--mc-option-size-horizontal-padding, 12px)}.mc-select__matcher{display:flex;align-items:center;width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mc-select__matcher>span{width:100%}.mc-select__match-list{display:flex;flex-wrap:wrap;overflow:hidden;max-height:calc(var(--mc-form-field-size-height, 32px) - var(--mc-form-field-size-border-width, 1px) * 2)}.mc-select__match-list .mc-tag{margin-right:4px}.mc-select__match-container{display:flex;flex-direction:row;justify-content:space-between;width:100%}.mc-select__match-container .mc-select__match-hidden-text{flex:0 0 70px;align-self:center;padding:0 8px;text-align:right}.mc-select__arrow-wrapper{align-self:center}.mc-form-field-appearance-fill .mc-select__arrow-wrapper,.mc-form-field-appearance-standard .mc-select__arrow-wrapper{transform:translateY(-50%)}.mc-form-field-appearance-outline .mc-select__arrow-wrapper{transform:translateY(-25%)}.mc-select__panel{min-width:100%;max-width:var(--mc-select-panel-size-max-width, 640px);overflow:hidden;border-width:var(--mc-select-panel-size-border-width, 1px);border-style:solid;border-bottom-left-radius:var(--mc-select-panel-size-border-radius, 4px);border-bottom-right-radius:var(--mc-select-panel-size-border-radius, 4px)}.mc-select__panel .mc-optgroup-label,.mc-select__panel .mc-option{font-size:inherit;line-height:var(--mc-option-size-height, 32px);height:var(--mc-option-size-height, 32px)}.mc-select__content{max-height:var(--mc-select-panel-size-max-height, 232px);padding:var(--mc-select-panel-size-vertical-padding, 4px) 0;overflow:auto}.mc-select__content .cdk-virtual-scroll-viewport{min-height:var(--mc-select-panel-size-max-height, 232px)-8px;max-height:var(--mc-select-panel-size-max-height, 232px)-8px}.mc-form-field-type-select:not(.mc-disabled) .mc-form-field-flex{cursor:pointer}.mc-select__search-container{border-bottom-width:1px;border-bottom-style:solid}\n"], components: [{ type: i5.McTag, selector: "mc-tag, [mc-tag], mc-basic-tag, [mc-basic-tag]", inputs: ["color", "selected", "value", "selectable", "removable", "disabled"], outputs: ["selectionChange", "destroyed", "removed"], exportAs: ["mcTag"] }, { type: i6.McIcon, selector: "[mc-icon]", inputs: ["color"] }], directives: [{ type: i2.CdkOverlayOrigin, selector: "[cdk-overlay-origin], [overlay-origin], [cdkOverlayOrigin]", exportAs: ["cdkOverlayOrigin"] }, { type: i8.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i8.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { type: i8.NgSwitchDefault, selector: "[ngSwitchDefault]" }, { type: i8.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i8.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i6.McIconCSSStyler, selector: "[mc-icon]" }, { type: i2.CdkConnectedOverlay, selector: "[cdk-connected-overlay], [connected-overlay], [cdkConnectedOverlay]", inputs: ["cdkConnectedOverlayOrigin", "cdkConnectedOverlayPositions", "cdkConnectedOverlayPositionStrategy", "cdkConnectedOverlayOffsetX", "cdkConnectedOverlayOffsetY", "cdkConnectedOverlayWidth", "cdkConnectedOverlayHeight", "cdkConnectedOverlayMinWidth", "cdkConnectedOverlayMinHeight", "cdkConnectedOverlayBackdropClass", "cdkConnectedOverlayPanelClass", "cdkConnectedOverlayViewportMargin", "cdkConnectedOverlayScrollStrategy", "cdkConnectedOverlayOpen", "cdkConnectedOverlayDisableClose", "cdkConnectedOverlayTransformOriginOn", "cdkConnectedOverlayHasBackdrop", "cdkConnectedOverlayLockPosition", "cdkConnectedOverlayFlexibleDimensions", "cdkConnectedOverlayGrowAfterOpen", "cdkConnectedOverlayPush"], outputs: ["backdropClick", "positionChange", "attach", "detach", "overlayKeydown", "overlayOutsideClick"], exportAs: ["cdkConnectedOverlay"] }, { type: i8.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], animations: [
|
1041
|
-
|
1042
|
-
|
1043
|
-
|
1044
|
-
|
1045
|
-
|
1046
|
-
|
1047
|
-
|
1048
|
-
|
1049
|
-
|
1050
|
-
class: 'mc-select',
|
1051
|
-
|
1052
|
-
|
1053
|
-
|
1054
|
-
|
1055
|
-
|
1056
|
-
|
1057
|
-
|
1058
|
-
|
1059
|
-
|
1060
|
-
|
1061
|
-
|
1062
|
-
|
1063
|
-
|
1064
|
-
|
1065
|
-
|
1066
|
-
|
1067
|
-
|
1068
|
-
|
1069
|
-
|
1070
|
-
|
1071
|
-
|
1072
|
-
|
1073
|
-
}] },
|
1074
|
-
|
1075
|
-
|
1076
|
-
|
1077
|
-
|
1078
|
-
|
1079
|
-
}, {
|
1080
|
-
type: Optional
|
1081
|
-
}] }, { type: i4.
|
1082
|
-
type: Optional
|
1083
|
-
}, {
|
1084
|
-
type:
|
1085
|
-
}] }, { type:
|
1086
|
-
type: Optional
|
1087
|
-
}, {
|
1088
|
-
type: Self
|
1089
|
-
}
|
1090
|
-
type:
|
1091
|
-
|
1092
|
-
|
1093
|
-
|
1094
|
-
|
1095
|
-
|
1096
|
-
|
1097
|
-
}
|
1098
|
-
|
1099
|
-
|
1100
|
-
|
1101
|
-
|
1102
|
-
|
1103
|
-
|
1104
|
-
|
1105
|
-
|
1106
|
-
|
1107
|
-
|
1108
|
-
|
1109
|
-
|
1110
|
-
|
1111
|
-
|
1112
|
-
|
1113
|
-
|
1114
|
-
|
1115
|
-
|
1116
|
-
|
1117
|
-
|
1118
|
-
|
1119
|
-
|
1120
|
-
|
1121
|
-
|
1122
|
-
|
1123
|
-
|
1124
|
-
|
1125
|
-
|
1126
|
-
|
1127
|
-
|
1128
|
-
|
1129
|
-
|
1130
|
-
|
1131
|
-
}],
|
1132
|
-
type:
|
1133
|
-
|
1134
|
-
|
1135
|
-
|
1136
|
-
|
1137
|
-
}],
|
1138
|
-
type:
|
1139
|
-
}],
|
1140
|
-
type:
|
1141
|
-
|
1142
|
-
|
1143
|
-
|
1144
|
-
|
1145
|
-
}],
|
1146
|
-
type:
|
1147
|
-
}],
|
1148
|
-
type: Output
|
1149
|
-
}],
|
1150
|
-
type:
|
1151
|
-
|
1152
|
-
|
1153
|
-
|
1154
|
-
|
1155
|
-
}],
|
1156
|
-
type:
|
1157
|
-
}],
|
1158
|
-
type:
|
1159
|
-
}],
|
1160
|
-
type: Input
|
1161
|
-
}],
|
1162
|
-
type: Input
|
1163
|
-
}],
|
1164
|
-
type: Input
|
83
|
+
/* tslint:disable:no-empty */
|
84
|
+
let nextUniqueId = 0;
|
85
|
+
/** Change event object that is emitted when the select value has changed. */
|
86
|
+
class McSelectChange {
|
87
|
+
constructor(source, value) {
|
88
|
+
this.source = source;
|
89
|
+
this.value = value;
|
90
|
+
}
|
91
|
+
}
|
92
|
+
class McSelectSearch {
|
93
|
+
constructor(formField) {
|
94
|
+
this.searchChangesSubscription = new Subscription();
|
95
|
+
this.isSearchChanged = false;
|
96
|
+
formField.canCleanerClearByEsc = false;
|
97
|
+
}
|
98
|
+
focus() {
|
99
|
+
this.input.focus();
|
100
|
+
}
|
101
|
+
reset() {
|
102
|
+
this.input.ngControl.reset();
|
103
|
+
}
|
104
|
+
ngAfterContentInit() {
|
105
|
+
if (!this.input) {
|
106
|
+
throw Error('McSelectSearch does not work without mcInput');
|
107
|
+
}
|
108
|
+
if (!this.input.ngControl) {
|
109
|
+
throw Error('McSelectSearch does not work without ngControl');
|
110
|
+
}
|
111
|
+
Promise.resolve().then(() => {
|
112
|
+
this.searchChangesSubscription = this.input.ngControl.valueChanges.subscribe(() => {
|
113
|
+
this.isSearchChanged = true;
|
114
|
+
});
|
115
|
+
});
|
116
|
+
}
|
117
|
+
ngOnDestroy() {
|
118
|
+
this.searchChangesSubscription.unsubscribe();
|
119
|
+
}
|
120
|
+
handleKeydown(event) {
|
121
|
+
// tslint:disable-next-line:deprecation
|
122
|
+
if (event.keyCode === ESCAPE) {
|
123
|
+
if (this.input.value) {
|
124
|
+
this.reset();
|
125
|
+
event.stopPropagation();
|
126
|
+
}
|
127
|
+
}
|
128
|
+
// tslint:disable-next-line:deprecation
|
129
|
+
if ([SPACE, HOME, END].includes(event.keyCode)) {
|
130
|
+
event.stopPropagation();
|
131
|
+
}
|
132
|
+
}
|
133
|
+
}
|
134
|
+
/** @nocollapse */ /** @nocollapse */ McSelectSearch.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: McSelectSearch, deps: [{ token: i1$1.McFormField }], target: i0.ɵɵFactoryTarget.Directive });
|
135
|
+
/** @nocollapse */ /** @nocollapse */ McSelectSearch.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.11", type: McSelectSearch, selector: "[mcSelectSearch]", host: { listeners: { "keydown": "handleKeydown($event)" } }, queries: [{ propertyName: "input", first: true, predicate: McInput, descendants: true }], exportAs: ["mcSelectSearch"], ngImport: i0 });
|
136
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: McSelectSearch, decorators: [{
|
137
|
+
type: Directive,
|
138
|
+
args: [{
|
139
|
+
selector: '[mcSelectSearch]',
|
140
|
+
exportAs: 'mcSelectSearch',
|
141
|
+
host: {
|
142
|
+
'(keydown)': 'handleKeydown($event)'
|
143
|
+
}
|
144
|
+
}]
|
145
|
+
}], ctorParameters: function () { return [{ type: i1$1.McFormField }]; }, propDecorators: { input: [{
|
146
|
+
type: ContentChild,
|
147
|
+
args: [McInput, { static: false }]
|
148
|
+
}] } });
|
149
|
+
class McSelectSearchEmptyResult {
|
150
|
+
}
|
151
|
+
/** @nocollapse */ /** @nocollapse */ McSelectSearchEmptyResult.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: McSelectSearchEmptyResult, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
152
|
+
/** @nocollapse */ /** @nocollapse */ McSelectSearchEmptyResult.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.11", type: McSelectSearchEmptyResult, selector: "[mc-select-search-empty-result]", exportAs: ["mcSelectSearchEmptyResult"], ngImport: i0 });
|
153
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: McSelectSearchEmptyResult, decorators: [{
|
154
|
+
type: Directive,
|
155
|
+
args: [{
|
156
|
+
selector: '[mc-select-search-empty-result]',
|
157
|
+
exportAs: 'mcSelectSearchEmptyResult'
|
158
|
+
}]
|
159
|
+
}] });
|
160
|
+
class McSelectTrigger {
|
161
|
+
}
|
162
|
+
/** @nocollapse */ /** @nocollapse */ McSelectTrigger.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: McSelectTrigger, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
163
|
+
/** @nocollapse */ /** @nocollapse */ McSelectTrigger.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.11", type: McSelectTrigger, selector: "mc-select-trigger", ngImport: i0 });
|
164
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: McSelectTrigger, decorators: [{
|
165
|
+
type: Directive,
|
166
|
+
args: [{ selector: 'mc-select-trigger' }]
|
167
|
+
}] });
|
168
|
+
class McSelectBase {
|
169
|
+
constructor(elementRef, defaultErrorStateMatcher, parentForm, parentFormGroup, ngControl) {
|
170
|
+
this.elementRef = elementRef;
|
171
|
+
this.defaultErrorStateMatcher = defaultErrorStateMatcher;
|
172
|
+
this.parentForm = parentForm;
|
173
|
+
this.parentFormGroup = parentFormGroup;
|
174
|
+
this.ngControl = ngControl;
|
175
|
+
}
|
176
|
+
}
|
177
|
+
// tslint:disable-next-line:naming-convention
|
178
|
+
const McSelectMixinBase = mixinTabIndex(mixinDisabled(mixinErrorState(McSelectBase)));
|
179
|
+
class McSelect extends McSelectMixinBase {
|
180
|
+
constructor(_changeDetectorRef, _ngZone, _renderer, defaultErrorStateMatcher, elementRef, rawValidators, _dir, parentForm, parentFormGroup, _parentFormField, ngControl, ngModel, formControlName, _scrollStrategyFactory, mcValidation) {
|
181
|
+
super(elementRef, defaultErrorStateMatcher, parentForm, parentFormGroup, ngControl);
|
182
|
+
this._changeDetectorRef = _changeDetectorRef;
|
183
|
+
this._ngZone = _ngZone;
|
184
|
+
this._renderer = _renderer;
|
185
|
+
this.rawValidators = rawValidators;
|
186
|
+
this._dir = _dir;
|
187
|
+
this._parentFormField = _parentFormField;
|
188
|
+
this.ngModel = ngModel;
|
189
|
+
this.formControlName = formControlName;
|
190
|
+
this._scrollStrategyFactory = _scrollStrategyFactory;
|
191
|
+
this.mcValidation = mcValidation;
|
192
|
+
/** A name for this control that can be used by `mc-form-field`. */
|
193
|
+
this.controlType = 'select';
|
194
|
+
this.hiddenItems = 0;
|
195
|
+
/** The cached font-size of the trigger element. */
|
196
|
+
this.triggerFontSize = 0;
|
197
|
+
this.previousSelectionModelSelected = [];
|
198
|
+
/** The value of the select panel's transform-origin property. */
|
199
|
+
this.transformOrigin = 'top';
|
200
|
+
/** Emits when the panel element is finished transforming in. */
|
201
|
+
this.panelDoneAnimatingStream = new Subject();
|
202
|
+
/** Strategy that will be used to handle scrolling while the select panel is open. */
|
203
|
+
this.scrollStrategy = this._scrollStrategyFactory();
|
204
|
+
/**
|
205
|
+
* The y-offset of the overlay panel in relation to the trigger's top start corner.
|
206
|
+
* This must be adjusted to align the selected option text over the trigger text.
|
207
|
+
* when the panel opens. Will change based on the y-position of the selected option.
|
208
|
+
*/
|
209
|
+
this.offsetY = 0;
|
210
|
+
/**
|
211
|
+
* This position config ensures that the top "start" corner of the overlay
|
212
|
+
* is aligned with with the top "start" of the origin by default (overlapping
|
213
|
+
* the trigger completely). If the panel cannot fit below the trigger, it
|
214
|
+
* will fall back to a position above the trigger.
|
215
|
+
*/
|
216
|
+
this.positions = [
|
217
|
+
{
|
218
|
+
originX: 'start',
|
219
|
+
originY: 'bottom',
|
220
|
+
overlayX: 'start',
|
221
|
+
overlayY: 'top'
|
222
|
+
},
|
223
|
+
{
|
224
|
+
originX: 'start',
|
225
|
+
originY: 'top',
|
226
|
+
overlayX: 'start',
|
227
|
+
overlayY: 'bottom'
|
228
|
+
}
|
229
|
+
];
|
230
|
+
this.hiddenItemsText = '...ещё';
|
231
|
+
this.backdropClass = 'cdk-overlay-transparent-backdrop';
|
232
|
+
/** Combined stream of all of the child options' change events. */
|
233
|
+
this.optionSelectionChanges = defer(() => {
|
234
|
+
if (this.options) {
|
235
|
+
return merge(...this.options.map((option) => option.onSelectionChange), ...this.selectionModel.selected.map((option) => option.onSelectionChange));
|
236
|
+
}
|
237
|
+
return this._ngZone.onStable
|
238
|
+
.asObservable()
|
239
|
+
.pipe(take(1), switchMap(() => this.optionSelectionChanges));
|
240
|
+
});
|
241
|
+
/** Event emitted when the select panel has been toggled. */
|
242
|
+
this.openedChange = new EventEmitter();
|
243
|
+
/** Event emitted when the select has been opened. */
|
244
|
+
this.openedStream = this.openedChange.pipe(filter((o) => o), map(() => { }));
|
245
|
+
/** Event emitted when the select has been closed. */
|
246
|
+
this.closedStream = this.openedChange.pipe(filter((o) => !o), map(() => { }));
|
247
|
+
/** Event emitted when the selected value has been changed by the user. */
|
248
|
+
this.selectionChange = new EventEmitter();
|
249
|
+
/**
|
250
|
+
* Event that emits whenever the raw value of the select changes. This is here primarily
|
251
|
+
* to facilitate the two-way binding for the `value` input.
|
252
|
+
* @docs-private
|
253
|
+
*/
|
254
|
+
this.valueChange = new EventEmitter();
|
255
|
+
this._hasBackdrop = false;
|
256
|
+
this._required = false;
|
257
|
+
this._multiple = false;
|
258
|
+
this._disabled = false;
|
259
|
+
this._focused = false;
|
260
|
+
this.panelOpen = false;
|
261
|
+
this.closeSubscription = Subscription.EMPTY;
|
262
|
+
/** The scroll position of the overlay panel, calculated to center the selected option. */
|
263
|
+
this.scrollTop = 0;
|
264
|
+
/** Unique id for this input. */
|
265
|
+
this.uid = `mc-select-${nextUniqueId++}`;
|
266
|
+
/** Emits whenever the component is destroyed. */
|
267
|
+
this.destroy = new Subject();
|
268
|
+
/** `View -> model callback called when value changes` */
|
269
|
+
this.onChange = () => { };
|
270
|
+
/** `View -> model callback called when select has been touched` */
|
271
|
+
this.onTouched = () => { };
|
272
|
+
/** Comparison function to specify which option is displayed. Defaults to object equality. */
|
273
|
+
this._compareWith = (o1, o2) => o1 === o2;
|
274
|
+
if (this.ngControl) {
|
275
|
+
// Note: we provide the value accessor through here, instead of
|
276
|
+
// the `providers` to avoid running into a circular import.
|
277
|
+
this.ngControl.valueAccessor = this;
|
278
|
+
}
|
279
|
+
// Force setter to be called in case id was not specified.
|
280
|
+
this.id = this.id;
|
281
|
+
}
|
282
|
+
get hasBackdrop() {
|
283
|
+
return this._hasBackdrop;
|
284
|
+
}
|
285
|
+
set hasBackdrop(value) {
|
286
|
+
this._hasBackdrop = coerceBooleanProperty(value);
|
287
|
+
}
|
288
|
+
get placeholder() {
|
289
|
+
return this._placeholder;
|
290
|
+
}
|
291
|
+
set placeholder(value) {
|
292
|
+
this._placeholder = value;
|
293
|
+
this.stateChanges.next();
|
294
|
+
}
|
295
|
+
get required() {
|
296
|
+
return this._required;
|
297
|
+
}
|
298
|
+
set required(value) {
|
299
|
+
this._required = coerceBooleanProperty(value);
|
300
|
+
this.stateChanges.next();
|
301
|
+
}
|
302
|
+
get multiple() {
|
303
|
+
return this._multiple;
|
304
|
+
}
|
305
|
+
set multiple(value) {
|
306
|
+
if (this.selectionModel) {
|
307
|
+
throw getMcSelectDynamicMultipleError();
|
308
|
+
}
|
309
|
+
this._multiple = coerceBooleanProperty(value);
|
310
|
+
}
|
311
|
+
/**
|
312
|
+
* Function to compare the option values with the selected values. The first argument
|
313
|
+
* is a value from an option. The second is a value from the selection. A boolean
|
314
|
+
* should be returned.
|
315
|
+
*/
|
316
|
+
get compareWith() {
|
317
|
+
return this._compareWith;
|
318
|
+
}
|
319
|
+
set compareWith(fn) {
|
320
|
+
/* tslint:disable-next-line:strict-type-predicates */
|
321
|
+
if (typeof fn !== 'function') {
|
322
|
+
throw getMcSelectNonFunctionValueError();
|
323
|
+
}
|
324
|
+
this._compareWith = fn;
|
325
|
+
if (this.selectionModel) {
|
326
|
+
// A different comparator means the selection could change.
|
327
|
+
this.initializeSelection();
|
328
|
+
}
|
329
|
+
}
|
330
|
+
/** Value of the select control. */
|
331
|
+
get value() {
|
332
|
+
return this._value;
|
333
|
+
}
|
334
|
+
set value(newValue) {
|
335
|
+
if (newValue !== this._value) {
|
336
|
+
this.writeValue(newValue);
|
337
|
+
this._value = newValue;
|
338
|
+
}
|
339
|
+
}
|
340
|
+
get id() {
|
341
|
+
return this._id;
|
342
|
+
}
|
343
|
+
set id(value) {
|
344
|
+
this._id = value || this.uid;
|
345
|
+
this.stateChanges.next();
|
346
|
+
}
|
347
|
+
get disabled() {
|
348
|
+
return this._disabled;
|
349
|
+
}
|
350
|
+
set disabled(value) {
|
351
|
+
this._disabled = coerceBooleanProperty(value);
|
352
|
+
if (this._parentFormField) {
|
353
|
+
this._disabled ? this._parentFormField.stopFocusMonitor() : this._parentFormField.runFocusMonitor();
|
354
|
+
}
|
355
|
+
}
|
356
|
+
/** Whether the select is focused. */
|
357
|
+
get focused() {
|
358
|
+
return this._focused || this.panelOpen;
|
359
|
+
}
|
360
|
+
set focused(value) {
|
361
|
+
this._focused = value;
|
362
|
+
}
|
363
|
+
get isEmptySearchResult() {
|
364
|
+
return this.search && this.options.length === 0 && !!this.search.input.value;
|
365
|
+
}
|
366
|
+
get canShowCleaner() {
|
367
|
+
return !this.disabled && this.cleaner && this.selectionModel.hasValue();
|
368
|
+
}
|
369
|
+
get selected() {
|
370
|
+
return this.multiple ? this.selectionModel.selected : this.selectionModel.selected[0];
|
371
|
+
}
|
372
|
+
get triggerValue() {
|
373
|
+
if (this.empty) {
|
374
|
+
return '';
|
375
|
+
}
|
376
|
+
return this.selectionModel.selected[0].viewValue;
|
377
|
+
}
|
378
|
+
get triggerValues() {
|
379
|
+
if (this.empty) {
|
380
|
+
return [];
|
381
|
+
}
|
382
|
+
const selectedOptions = this.selectionModel.selected;
|
383
|
+
if (this.isRtl()) {
|
384
|
+
selectedOptions.reverse();
|
385
|
+
}
|
386
|
+
return selectedOptions;
|
387
|
+
}
|
388
|
+
get empty() {
|
389
|
+
return !this.selectionModel || this.selectionModel.isEmpty();
|
390
|
+
}
|
391
|
+
ngOnInit() {
|
392
|
+
this.selectionModel = new SelectionModel(this.multiple);
|
393
|
+
this.stateChanges.next();
|
394
|
+
// We need `distinctUntilChanged` here, because some browsers will
|
395
|
+
// fire the animation end event twice for the same animation. See:
|
396
|
+
// https://github.com/angular/angular/issues/24084
|
397
|
+
this.panelDoneAnimatingStream
|
398
|
+
.pipe(distinctUntilChanged(), takeUntil(this.destroy))
|
399
|
+
.subscribe(() => {
|
400
|
+
if (this.panelOpen) {
|
401
|
+
this.scrollTop = 0;
|
402
|
+
if (this.search) {
|
403
|
+
this.search.focus();
|
404
|
+
}
|
405
|
+
this.openedChange.emit(true);
|
406
|
+
}
|
407
|
+
else {
|
408
|
+
this.openedChange.emit(false);
|
409
|
+
this._changeDetectorRef.markForCheck();
|
410
|
+
}
|
411
|
+
});
|
412
|
+
}
|
413
|
+
ngAfterContentInit() {
|
414
|
+
if (this.mcValidation.useValidation) {
|
415
|
+
setMosaicValidation(this, this._changeDetectorRef);
|
416
|
+
}
|
417
|
+
this.initKeyManager();
|
418
|
+
this.selectionModel.changed
|
419
|
+
.pipe(takeUntil(this.destroy))
|
420
|
+
.subscribe((event) => {
|
421
|
+
event.added.forEach((option) => option.select());
|
422
|
+
event.removed.forEach((option) => option.deselect());
|
423
|
+
});
|
424
|
+
this.options.changes
|
425
|
+
.pipe(startWith(null), takeUntil(this.destroy))
|
426
|
+
.subscribe(() => {
|
427
|
+
this.resetOptions();
|
428
|
+
this.initializeSelection();
|
429
|
+
});
|
430
|
+
}
|
431
|
+
ngAfterViewInit() {
|
432
|
+
this.tags.changes
|
433
|
+
.subscribe(() => {
|
434
|
+
setTimeout(() => this.calculateHiddenItems(), 0);
|
435
|
+
});
|
436
|
+
}
|
437
|
+
ngDoCheck() {
|
438
|
+
if (this.ngControl) {
|
439
|
+
this.updateErrorState();
|
440
|
+
}
|
441
|
+
}
|
442
|
+
ngOnChanges(changes) {
|
443
|
+
// Updating the disabled state is handled by `mixinDisabled`, but we need to additionally let
|
444
|
+
// the parent form field know to run change detection when the disabled state changes.
|
445
|
+
if (changes.disabled) {
|
446
|
+
this.stateChanges.next();
|
447
|
+
}
|
448
|
+
}
|
449
|
+
ngOnDestroy() {
|
450
|
+
this.destroy.next();
|
451
|
+
this.destroy.complete();
|
452
|
+
this.stateChanges.complete();
|
453
|
+
this.closeSubscription.unsubscribe();
|
454
|
+
}
|
455
|
+
hiddenItemsTextFormatter(hiddenItemsText, hiddenItems) {
|
456
|
+
return `${hiddenItemsText} ${hiddenItems}`;
|
457
|
+
}
|
458
|
+
clearValue($event) {
|
459
|
+
$event.stopPropagation();
|
460
|
+
this.selectionModel.clear();
|
461
|
+
this.keyManager.setActiveItem(-1);
|
462
|
+
this.propagateChanges();
|
463
|
+
}
|
464
|
+
resetSearch() {
|
465
|
+
if (!this.search) {
|
466
|
+
return;
|
467
|
+
}
|
468
|
+
this.search.reset();
|
469
|
+
/*
|
470
|
+
todo the incorrect behaviour of keyManager is possible here
|
471
|
+
to avoid first item selection (to provide correct options flipping on closed select)
|
472
|
+
we should process options update like it is the first options appearance
|
473
|
+
*/
|
474
|
+
this.search.isSearchChanged = false;
|
475
|
+
}
|
476
|
+
/** Toggles the overlay panel open or closed. */
|
477
|
+
toggle() {
|
478
|
+
if (this.panelOpen) {
|
479
|
+
this.close();
|
480
|
+
}
|
481
|
+
else {
|
482
|
+
this.open();
|
483
|
+
}
|
484
|
+
}
|
485
|
+
/** Opens the overlay panel. */
|
486
|
+
open() {
|
487
|
+
if (this.disabled || !this.options?.length || this.panelOpen) {
|
488
|
+
return;
|
489
|
+
}
|
490
|
+
this.triggerRect = this.trigger.nativeElement.getBoundingClientRect();
|
491
|
+
// Note: The computed font-size will be a string pixel value (e.g. "16px").
|
492
|
+
// `parseInt` ignores the trailing 'px' and converts this to a number.
|
493
|
+
this.triggerFontSize = parseInt(getComputedStyle(this.trigger.nativeElement)['font-size']);
|
494
|
+
this.panelOpen = true;
|
495
|
+
this.keyManager.withHorizontalOrientation(null);
|
496
|
+
this.highlightCorrectOption();
|
497
|
+
this._changeDetectorRef.markForCheck();
|
498
|
+
// Set the font size on the panel element once it exists.
|
499
|
+
this._ngZone.onStable.asObservable()
|
500
|
+
.pipe(take(1))
|
501
|
+
.subscribe(() => {
|
502
|
+
this.scrollActiveOptionIntoView();
|
503
|
+
if (this.triggerFontSize && this.overlayDir.overlayRef && this.overlayDir.overlayRef.overlayElement) {
|
504
|
+
this.overlayDir.overlayRef.overlayElement.style.fontSize = `${this.triggerFontSize}px`;
|
505
|
+
}
|
506
|
+
});
|
507
|
+
}
|
508
|
+
/** Closes the overlay panel and focuses the host element. */
|
509
|
+
close() {
|
510
|
+
if (!this.panelOpen) {
|
511
|
+
return;
|
512
|
+
}
|
513
|
+
// the order of calls is important
|
514
|
+
this.resetSearch();
|
515
|
+
this.panelOpen = false;
|
516
|
+
this.keyManager.withHorizontalOrientation(this.isRtl() ? 'rtl' : 'ltr');
|
517
|
+
this._changeDetectorRef.markForCheck();
|
518
|
+
this.onTouched();
|
519
|
+
}
|
520
|
+
/**
|
521
|
+
* Sets the select's value. Part of the ControlValueAccessor interface
|
522
|
+
* required to integrate with Angular's core forms API.
|
523
|
+
*
|
524
|
+
* @param value New value to be written to the model.
|
525
|
+
*/
|
526
|
+
writeValue(value) {
|
527
|
+
if (this.options) {
|
528
|
+
this.setSelectionByValue(value);
|
529
|
+
}
|
530
|
+
}
|
531
|
+
/**
|
532
|
+
* Saves a callback function to be invoked when the select's value
|
533
|
+
* changes from user input. Part of the ControlValueAccessor interface
|
534
|
+
* required to integrate with Angular's core forms API.
|
535
|
+
*
|
536
|
+
* @param fn Callback to be triggered when the value changes.
|
537
|
+
*/
|
538
|
+
registerOnChange(fn) {
|
539
|
+
this.onChange = fn;
|
540
|
+
}
|
541
|
+
/**
|
542
|
+
* Saves a callback function to be invoked when the select is blurred
|
543
|
+
* by the user. Part of the ControlValueAccessor interface required
|
544
|
+
* to integrate with Angular's core forms API.
|
545
|
+
*
|
546
|
+
* @param fn Callback to be triggered when the component has been touched.
|
547
|
+
*/
|
548
|
+
registerOnTouched(fn) {
|
549
|
+
this.onTouched = fn;
|
550
|
+
}
|
551
|
+
/**
|
552
|
+
* Disables the select. Part of the ControlValueAccessor interface required
|
553
|
+
* to integrate with Angular's core forms API.
|
554
|
+
*
|
555
|
+
* @param isDisabled Sets whether the component is disabled.
|
556
|
+
*/
|
557
|
+
setDisabledState(isDisabled) {
|
558
|
+
this.disabled = isDisabled;
|
559
|
+
this._changeDetectorRef.markForCheck();
|
560
|
+
this.stateChanges.next();
|
561
|
+
}
|
562
|
+
isRtl() {
|
563
|
+
return this._dir ? this._dir.value === 'rtl' : false;
|
564
|
+
}
|
565
|
+
handleKeydown(event) {
|
566
|
+
if (this.disabled) {
|
567
|
+
return;
|
568
|
+
}
|
569
|
+
if (this.panelOpen) {
|
570
|
+
this.handleOpenKeydown(event);
|
571
|
+
}
|
572
|
+
else {
|
573
|
+
this.handleClosedKeydown(event);
|
574
|
+
}
|
575
|
+
}
|
576
|
+
onFocus() {
|
577
|
+
if (!this.disabled) {
|
578
|
+
this._focused = true;
|
579
|
+
this.stateChanges.next();
|
580
|
+
}
|
581
|
+
}
|
582
|
+
/**
|
583
|
+
* Calls the touched callback only if the panel is closed. Otherwise, the trigger will
|
584
|
+
* "blur" to the panel when it opens, causing a false positive.
|
585
|
+
*/
|
586
|
+
onBlur() {
|
587
|
+
this._focused = false;
|
588
|
+
if (!this.disabled && !this.panelOpen) {
|
589
|
+
this.onTouched();
|
590
|
+
this._changeDetectorRef.markForCheck();
|
591
|
+
this.stateChanges.next();
|
592
|
+
}
|
593
|
+
}
|
594
|
+
/**
|
595
|
+
* Callback that is invoked when the overlay panel has been attached.
|
596
|
+
*/
|
597
|
+
onAttached() {
|
598
|
+
this.overlayDir.positionChange
|
599
|
+
.pipe(take(1))
|
600
|
+
.subscribe(() => {
|
601
|
+
this._changeDetectorRef.detectChanges();
|
602
|
+
this.setOverlayPosition();
|
603
|
+
this.optionsContainer.nativeElement.scrollTop = this.scrollTop;
|
604
|
+
this.updateScrollSize();
|
605
|
+
});
|
606
|
+
this.closeSubscription = this.closingActions()
|
607
|
+
.subscribe(() => this.close());
|
608
|
+
}
|
609
|
+
/** Returns the theme to be used on the panel. */
|
610
|
+
getPanelTheme() {
|
611
|
+
return this._parentFormField ? `mc-${this._parentFormField.color}` : '';
|
612
|
+
}
|
613
|
+
/** Focuses the select element. */
|
614
|
+
focus() {
|
615
|
+
this.elementRef.nativeElement.focus();
|
616
|
+
}
|
617
|
+
/**
|
618
|
+
* Implemented as part of McFormFieldControl.
|
619
|
+
* @docs-private
|
620
|
+
*/
|
621
|
+
onContainerClick() {
|
622
|
+
this.focus();
|
623
|
+
}
|
624
|
+
/** Invoked when an option is clicked. */
|
625
|
+
onRemoveMatcherItem(option, $event) {
|
626
|
+
$event.stopPropagation();
|
627
|
+
option.deselect();
|
628
|
+
}
|
629
|
+
calculateHiddenItems() {
|
630
|
+
if (this.customTrigger || this.empty || !this.multiple) {
|
631
|
+
return;
|
632
|
+
}
|
633
|
+
let visibleItems = 0;
|
634
|
+
const totalItemsWidth = this.getTotalItemsWidthInMatcher();
|
635
|
+
let totalVisibleItemsWidth = 0;
|
636
|
+
this.tags.forEach((tag) => {
|
637
|
+
if (tag.nativeElement.offsetTop < tag.nativeElement.offsetHeight) {
|
638
|
+
totalVisibleItemsWidth += this.getItemWidth(tag.nativeElement);
|
639
|
+
visibleItems++;
|
640
|
+
}
|
641
|
+
});
|
642
|
+
this.hiddenItems = this.selected.length - visibleItems;
|
643
|
+
if (this.hiddenItems) {
|
644
|
+
const itemsCounter = this.trigger.nativeElement.querySelector('.mc-select__match-hidden-text');
|
645
|
+
const matcherList = this.trigger.nativeElement.querySelector('.mc-select__match-list');
|
646
|
+
const itemsCounterShowed = itemsCounter.offsetTop < itemsCounter.offsetHeight;
|
647
|
+
// const itemsCounterWidth: number = itemsCounter.getBoundingClientRect().width;
|
648
|
+
const itemsCounterWidth = 86;
|
649
|
+
const matcherListWidth = Math.floor(matcherList.getBoundingClientRect().width);
|
650
|
+
const matcherWidth = matcherListWidth + (itemsCounterShowed ? itemsCounterWidth : 0);
|
651
|
+
if (itemsCounterShowed && (totalItemsWidth < matcherWidth)) {
|
652
|
+
this.hiddenItems = 0;
|
653
|
+
}
|
654
|
+
if (totalVisibleItemsWidth === matcherListWidth ||
|
655
|
+
(totalVisibleItemsWidth + itemsCounterWidth) < matcherListWidth) {
|
656
|
+
this._changeDetectorRef.markForCheck();
|
657
|
+
return;
|
658
|
+
}
|
659
|
+
else if (!itemsCounterShowed && (totalItemsWidth + itemsCounterWidth) > matcherWidth) {
|
660
|
+
this.hiddenItems++;
|
661
|
+
}
|
662
|
+
}
|
663
|
+
this._changeDetectorRef.markForCheck();
|
664
|
+
}
|
665
|
+
getItemHeight() {
|
666
|
+
return this.options.first ? this.options.first.getHeight() : 0;
|
667
|
+
}
|
668
|
+
closingActions() {
|
669
|
+
return merge(this.overlayDir.overlayRef.outsidePointerEvents()
|
670
|
+
.pipe(filter((event) => !this.elementRef.nativeElement.contains(event.target))), this.overlayDir.overlayRef.detachments());
|
671
|
+
}
|
672
|
+
getHeightOfOptionsContainer() {
|
673
|
+
return this.optionsContainer.nativeElement.getClientRects()[0].height;
|
674
|
+
}
|
675
|
+
updateScrollSize() {
|
676
|
+
if (!this.options.first) {
|
677
|
+
return;
|
678
|
+
}
|
679
|
+
this.keyManager.withScrollSize(Math.floor(this.getHeightOfOptionsContainer() / this.options.first.getHeight()));
|
680
|
+
}
|
681
|
+
getTotalItemsWidthInMatcher() {
|
682
|
+
const triggerClone = this.trigger.nativeElement.cloneNode(true);
|
683
|
+
triggerClone.querySelector('.mc-select__match-hidden-text').remove();
|
684
|
+
this._renderer.setStyle(triggerClone, 'position', 'absolute');
|
685
|
+
this._renderer.setStyle(triggerClone, 'visibility', 'hidden');
|
686
|
+
this._renderer.setStyle(triggerClone, 'top', '-100%');
|
687
|
+
this._renderer.setStyle(triggerClone, 'left', '0');
|
688
|
+
this._renderer.appendChild(this.trigger.nativeElement, triggerClone);
|
689
|
+
let totalItemsWidth = 0;
|
690
|
+
triggerClone.querySelectorAll('mc-tag').forEach((item) => {
|
691
|
+
totalItemsWidth += this.getItemWidth(item);
|
692
|
+
});
|
693
|
+
triggerClone.remove();
|
694
|
+
return totalItemsWidth;
|
695
|
+
}
|
696
|
+
getItemWidth(element) {
|
697
|
+
const computedStyle = window.getComputedStyle(element);
|
698
|
+
const width = parseInt(computedStyle.width);
|
699
|
+
const marginLeft = parseInt(computedStyle.marginLeft);
|
700
|
+
const marginRight = parseInt(computedStyle.marginRight);
|
701
|
+
return width + marginLeft + marginRight;
|
702
|
+
}
|
703
|
+
/** Handles keyboard events while the select is closed. */
|
704
|
+
handleClosedKeydown(event) {
|
705
|
+
/* tslint:disable-next-line */
|
706
|
+
const keyCode = event.keyCode;
|
707
|
+
const isArrowKey = [DOWN_ARROW, UP_ARROW, LEFT_ARROW, RIGHT_ARROW].includes(keyCode);
|
708
|
+
const isOpenKey = [ENTER, SPACE].includes(keyCode);
|
709
|
+
// Open the select on ALT + arrow key to match the native <select>
|
710
|
+
if (isOpenKey || ((this.multiple || event.altKey) && isArrowKey)) {
|
711
|
+
event.preventDefault(); // prevents the page from scrolling down when pressing space
|
712
|
+
this.open();
|
713
|
+
}
|
714
|
+
else if (!this.multiple) {
|
715
|
+
this.keyManager.onKeydown(event);
|
716
|
+
}
|
717
|
+
}
|
718
|
+
/** Handles keyboard events when the selected is open. */
|
719
|
+
handleOpenKeydown(event) {
|
720
|
+
/* tslint:disable-next-line */
|
721
|
+
const keyCode = event.keyCode;
|
722
|
+
const isArrowKey = keyCode === DOWN_ARROW || keyCode === UP_ARROW;
|
723
|
+
if (isArrowKey && event.altKey) {
|
724
|
+
// Close the select on ALT + arrow key to match the native <select>
|
725
|
+
event.preventDefault();
|
726
|
+
this.close();
|
727
|
+
}
|
728
|
+
else if (keyCode === HOME) {
|
729
|
+
event.preventDefault();
|
730
|
+
this.keyManager.setFirstItemActive();
|
731
|
+
}
|
732
|
+
else if (keyCode === END) {
|
733
|
+
event.preventDefault();
|
734
|
+
this.keyManager.setLastItemActive();
|
735
|
+
}
|
736
|
+
else if (keyCode === PAGE_UP) {
|
737
|
+
event.preventDefault();
|
738
|
+
this.keyManager.setPreviousPageItemActive();
|
739
|
+
}
|
740
|
+
else if (keyCode === PAGE_DOWN) {
|
741
|
+
event.preventDefault();
|
742
|
+
this.keyManager.setNextPageItemActive();
|
743
|
+
}
|
744
|
+
else if ((keyCode === ENTER || keyCode === SPACE) && this.keyManager.activeItem) {
|
745
|
+
event.preventDefault();
|
746
|
+
this.keyManager.activeItem.selectViaInteraction();
|
747
|
+
}
|
748
|
+
else if (this._multiple && keyCode === A && event.ctrlKey) {
|
749
|
+
event.preventDefault();
|
750
|
+
const hasDeselectedOptions = this.options.some((option) => !option.selected);
|
751
|
+
this.options.forEach((option) => {
|
752
|
+
if (hasDeselectedOptions && !option.disabled) {
|
753
|
+
option.select();
|
754
|
+
}
|
755
|
+
else {
|
756
|
+
option.deselect();
|
757
|
+
}
|
758
|
+
});
|
759
|
+
}
|
760
|
+
else {
|
761
|
+
const previouslyFocusedIndex = this.keyManager.activeItemIndex;
|
762
|
+
this.keyManager.onKeydown(event);
|
763
|
+
if (this._multiple && isArrowKey && event.shiftKey && this.keyManager.activeItem &&
|
764
|
+
this.keyManager.activeItemIndex !== previouslyFocusedIndex) {
|
765
|
+
this.keyManager.activeItem.selectViaInteraction();
|
766
|
+
}
|
767
|
+
if (this.search) {
|
768
|
+
this.search.focus();
|
769
|
+
}
|
770
|
+
}
|
771
|
+
}
|
772
|
+
initializeSelection() {
|
773
|
+
// Defer setting the value in order to avoid the "Expression
|
774
|
+
// has changed after it was checked" errors from Angular.
|
775
|
+
Promise.resolve().then(() => {
|
776
|
+
this.setSelectionByValue(this.ngControl ? this.ngControl.value : this._value);
|
777
|
+
});
|
778
|
+
}
|
779
|
+
/**
|
780
|
+
* Sets the selected option based on a value. If no option can be
|
781
|
+
* found with the designated value, the select trigger is cleared.
|
782
|
+
*/
|
783
|
+
setSelectionByValue(value) {
|
784
|
+
this.previousSelectionModelSelected = this.selectionModel.selected;
|
785
|
+
if (this.multiple && value) {
|
786
|
+
if (!Array.isArray(value)) {
|
787
|
+
throw getMcSelectNonArrayValueError();
|
788
|
+
}
|
789
|
+
this.selectionModel.clear();
|
790
|
+
value.forEach((currentValue) => this.selectValue(currentValue));
|
791
|
+
this.sortValues();
|
792
|
+
}
|
793
|
+
else {
|
794
|
+
this.selectionModel.clear();
|
795
|
+
const correspondingOption = this.selectValue(value);
|
796
|
+
// Shift focus to the active item. Note that we shouldn't do this in multiple
|
797
|
+
// mode, because we don't know what option the user interacted with last.
|
798
|
+
if (correspondingOption) {
|
799
|
+
this.keyManager.setActiveItem(correspondingOption);
|
800
|
+
}
|
801
|
+
}
|
802
|
+
this._changeDetectorRef.markForCheck();
|
803
|
+
}
|
804
|
+
getCorrespondOption(value) {
|
805
|
+
return [
|
806
|
+
...this.options.toArray(),
|
807
|
+
...this.previousSelectionModelSelected
|
808
|
+
].find((option) => {
|
809
|
+
try {
|
810
|
+
// Treat null as a special reset value.
|
811
|
+
return option.value != null && this.compareWith(option.value, value);
|
812
|
+
}
|
813
|
+
catch (error) {
|
814
|
+
if (isDevMode()) {
|
815
|
+
// Notify developers of errors in their comparator.
|
816
|
+
console.warn(error);
|
817
|
+
}
|
818
|
+
return false;
|
819
|
+
}
|
820
|
+
});
|
821
|
+
}
|
822
|
+
/**
|
823
|
+
* Finds and selects and option based on its value.
|
824
|
+
* @returns Option that has the corresponding value.
|
825
|
+
*/
|
826
|
+
selectValue(value) {
|
827
|
+
const correspondingOption = this.getCorrespondOption(value);
|
828
|
+
if (correspondingOption) {
|
829
|
+
this.selectionModel.select(correspondingOption);
|
830
|
+
}
|
831
|
+
return correspondingOption;
|
832
|
+
}
|
833
|
+
/** Sets up a key manager to listen to keyboard events on the overlay panel. */
|
834
|
+
initKeyManager() {
|
835
|
+
const typeAheadDebounce = 200;
|
836
|
+
this.keyManager = new ActiveDescendantKeyManager(this.options)
|
837
|
+
.withTypeAhead(typeAheadDebounce, this.search ? -1 : 0)
|
838
|
+
.withVerticalOrientation()
|
839
|
+
.withHorizontalOrientation(this.isRtl() ? 'rtl' : 'ltr');
|
840
|
+
this.keyManager.tabOut
|
841
|
+
.pipe(takeUntil(this.destroy))
|
842
|
+
.subscribe(() => {
|
843
|
+
// Restore focus to the trigger before closing. Ensures that the focus
|
844
|
+
// position won't be lost if the user got focus into the overlay.
|
845
|
+
this.focus();
|
846
|
+
this.close();
|
847
|
+
});
|
848
|
+
this.keyManager.change
|
849
|
+
.pipe(takeUntil(this.destroy))
|
850
|
+
.subscribe(() => {
|
851
|
+
if (this.panelOpen && this.panel) {
|
852
|
+
this.scrollActiveOptionIntoView();
|
853
|
+
}
|
854
|
+
else if (!this.panelOpen && !this.multiple && this.keyManager.activeItem) {
|
855
|
+
this.keyManager.activeItem.selectViaInteraction();
|
856
|
+
}
|
857
|
+
});
|
858
|
+
}
|
859
|
+
/** Drops current option subscriptions and IDs and resets from scratch. */
|
860
|
+
resetOptions() {
|
861
|
+
const changedOrDestroyed = merge(this.options.changes, this.destroy);
|
862
|
+
this.optionSelectionChanges
|
863
|
+
.pipe(takeUntil(changedOrDestroyed))
|
864
|
+
.subscribe((event) => {
|
865
|
+
this.onSelect(event.source, event.isUserInput);
|
866
|
+
if (this.search && this.search.isSearchChanged) {
|
867
|
+
Promise.resolve().then(() => this.keyManager.updateActiveItem(0));
|
868
|
+
this.search.isSearchChanged = false;
|
869
|
+
}
|
870
|
+
if (event.isUserInput && !this.multiple && this.panelOpen) {
|
871
|
+
this.close();
|
872
|
+
this.focus();
|
873
|
+
}
|
874
|
+
});
|
875
|
+
// Listen to changes in the internal state of the options and react accordingly.
|
876
|
+
// Handles cases like the labels of the selected options changing.
|
877
|
+
merge(...this.options.map((option) => option.stateChanges))
|
878
|
+
.pipe(takeUntil(changedOrDestroyed))
|
879
|
+
.subscribe(() => {
|
880
|
+
this._changeDetectorRef.markForCheck();
|
881
|
+
this.stateChanges.next();
|
882
|
+
});
|
883
|
+
}
|
884
|
+
/** Invoked when an option is clicked. */
|
885
|
+
onSelect(option, isUserInput) {
|
886
|
+
const wasSelected = this.selectionModel.isSelected(option);
|
887
|
+
if (option.value == null && !this._multiple) {
|
888
|
+
option.deselect();
|
889
|
+
this.selectionModel.clear();
|
890
|
+
this.propagateChanges(option.value);
|
891
|
+
}
|
892
|
+
else {
|
893
|
+
if (option.selected) {
|
894
|
+
this.selectionModel.select(option);
|
895
|
+
}
|
896
|
+
else {
|
897
|
+
this.selectionModel.deselect(option);
|
898
|
+
}
|
899
|
+
if (isUserInput) {
|
900
|
+
this.keyManager.setActiveItem(option);
|
901
|
+
}
|
902
|
+
if (this.multiple) {
|
903
|
+
this.sortValues();
|
904
|
+
if (isUserInput) {
|
905
|
+
// In case the user selected the option with their mouse, we
|
906
|
+
// want to restore focus back to the trigger, in order to
|
907
|
+
// prevent the select keyboard controls from clashing with
|
908
|
+
// the ones from `mc-option`.
|
909
|
+
// If search is avaliable then we focus search again.
|
910
|
+
if (this.search) {
|
911
|
+
this.search.focus();
|
912
|
+
}
|
913
|
+
else {
|
914
|
+
this.focus();
|
915
|
+
}
|
916
|
+
}
|
917
|
+
}
|
918
|
+
}
|
919
|
+
if (wasSelected !== this.selectionModel.isSelected(option)) {
|
920
|
+
this.propagateChanges();
|
921
|
+
}
|
922
|
+
this.stateChanges.next();
|
923
|
+
}
|
924
|
+
/** Sorts the selected values in the selected based on their order in the panel. */
|
925
|
+
sortValues() {
|
926
|
+
if (this.multiple) {
|
927
|
+
const options = this.options.toArray();
|
928
|
+
this.selectionModel.sort((a, b) => {
|
929
|
+
return this.sortComparator ? this.sortComparator(a, b, options) :
|
930
|
+
options.indexOf(a) - options.indexOf(b);
|
931
|
+
});
|
932
|
+
this.stateChanges.next();
|
933
|
+
}
|
934
|
+
}
|
935
|
+
/** Emits change event to set the model value. */
|
936
|
+
propagateChanges(fallbackValue) {
|
937
|
+
let valueToEmit = null;
|
938
|
+
if (this.multiple) {
|
939
|
+
valueToEmit = this.selected.map((option) => option.value);
|
940
|
+
}
|
941
|
+
else {
|
942
|
+
valueToEmit = this.selected ? this.selected.value : fallbackValue;
|
943
|
+
}
|
944
|
+
this._value = valueToEmit;
|
945
|
+
this.valueChange.emit(valueToEmit);
|
946
|
+
this.onChange(valueToEmit);
|
947
|
+
this.selectionChange.emit(new McSelectChange(this, valueToEmit));
|
948
|
+
this._changeDetectorRef.markForCheck();
|
949
|
+
}
|
950
|
+
/**
|
951
|
+
* Highlights the selected item. If no option is selected, it will highlight
|
952
|
+
* the first item instead.
|
953
|
+
*/
|
954
|
+
highlightCorrectOption() {
|
955
|
+
if (this.keyManager) {
|
956
|
+
if (this.empty) {
|
957
|
+
this.keyManager.setFirstItemActive();
|
958
|
+
}
|
959
|
+
else {
|
960
|
+
this.keyManager.setActiveItem(this.selectionModel.selected[0]);
|
961
|
+
}
|
962
|
+
}
|
963
|
+
}
|
964
|
+
/** Scrolls the active option into view. */
|
965
|
+
scrollActiveOptionIntoView() {
|
966
|
+
this.keyManager.activeItem?.focus();
|
967
|
+
}
|
968
|
+
/**
|
969
|
+
* Sets the x-offset of the overlay panel in relation to the trigger's top start corner.
|
970
|
+
* This must be adjusted to align the selected option text over the trigger text when
|
971
|
+
* the panel opens. Will change based on LTR or RTL text direction. Note that the offset
|
972
|
+
* can't be calculated until the panel has been attached, because we need to know the
|
973
|
+
* content width in order to constrain the panel within the viewport.
|
974
|
+
*/
|
975
|
+
setOverlayPosition() {
|
976
|
+
this.resetOverlay();
|
977
|
+
const overlayRect = this.getOverlayRect();
|
978
|
+
// Window width without scrollbar
|
979
|
+
const windowWidth = this.getOverlayWidth();
|
980
|
+
const isRtl = this.isRtl();
|
981
|
+
/* tslint:disable-next-line:no-magic-numbers */
|
982
|
+
const paddingWidth = SELECT_PANEL_PADDING_X * 2;
|
983
|
+
let offsetX;
|
984
|
+
let overlayMaxWidth;
|
985
|
+
const selected = this.selectionModel.selected[0] || this.options.first;
|
986
|
+
offsetX = selected && selected.group ? SELECT_PANEL_INDENT_PADDING_X : SELECT_PANEL_PADDING_X;
|
987
|
+
// Invert the offset in LTR.
|
988
|
+
if (!isRtl) {
|
989
|
+
offsetX *= -1;
|
990
|
+
}
|
991
|
+
// Determine if select overflows on either side.
|
992
|
+
const leftOverflow = 0 - (overlayRect.left + offsetX - (isRtl ? paddingWidth : 0));
|
993
|
+
const rightOverflow = overlayRect.right + offsetX - windowWidth
|
994
|
+
+ (isRtl ? 0 : paddingWidth);
|
995
|
+
// If the element overflows on either side, reduce the offset to allow it to fit.
|
996
|
+
if (leftOverflow > 0 || rightOverflow > 0) {
|
997
|
+
[offsetX, overlayMaxWidth] = this.calculateOverlayXPosition(overlayRect, windowWidth, offsetX);
|
998
|
+
this.overlayDir.overlayRef.overlayElement.style.maxWidth = `${overlayMaxWidth}px`;
|
999
|
+
}
|
1000
|
+
// Set the offset directly in order to avoid having to go through change detection and
|
1001
|
+
// potentially triggering "changed after it was checked" errors. Round the value to avoid
|
1002
|
+
// blurry content in some browsers.
|
1003
|
+
this.overlayDir.offsetX = Math.round(offsetX);
|
1004
|
+
this.overlayDir.overlayRef.updatePosition();
|
1005
|
+
}
|
1006
|
+
calculateOverlayXPosition(overlayRect, windowWidth, basicOffsetX) {
|
1007
|
+
let offsetX = basicOffsetX;
|
1008
|
+
const leftIndent = this.triggerRect.left;
|
1009
|
+
const rightIndent = windowWidth - this.triggerRect.right;
|
1010
|
+
// Setting direction of dropdown expansion
|
1011
|
+
const isRightDirection = leftIndent <= rightIndent;
|
1012
|
+
let maxDropdownWidth;
|
1013
|
+
let overlayMaxWidth;
|
1014
|
+
const triggerWidth = this.triggerRect.width + SELECT_PANEL_INDENT_PADDING_X;
|
1015
|
+
if (isRightDirection) {
|
1016
|
+
maxDropdownWidth = rightIndent + triggerWidth - SELECT_PANEL_VIEWPORT_PADDING;
|
1017
|
+
overlayMaxWidth = overlayRect.width < maxDropdownWidth ? overlayRect.width : maxDropdownWidth;
|
1018
|
+
}
|
1019
|
+
else {
|
1020
|
+
let leftOffset;
|
1021
|
+
maxDropdownWidth = leftIndent + triggerWidth - SELECT_PANEL_VIEWPORT_PADDING;
|
1022
|
+
if (overlayRect.width < maxDropdownWidth) {
|
1023
|
+
overlayMaxWidth = overlayRect.width;
|
1024
|
+
leftOffset = this.triggerRect.right - overlayMaxWidth;
|
1025
|
+
}
|
1026
|
+
else {
|
1027
|
+
overlayMaxWidth = maxDropdownWidth;
|
1028
|
+
leftOffset = this.triggerRect.right - (overlayMaxWidth - SELECT_PANEL_INDENT_PADDING_X);
|
1029
|
+
}
|
1030
|
+
offsetX -= this.triggerRect.left - leftOffset;
|
1031
|
+
}
|
1032
|
+
return [offsetX, overlayMaxWidth];
|
1033
|
+
}
|
1034
|
+
resetOverlay() {
|
1035
|
+
this.overlayDir.offsetX = 0;
|
1036
|
+
this.overlayDir.overlayRef.overlayElement.style.maxWidth = 'unset';
|
1037
|
+
this.overlayDir.overlayRef.updatePosition();
|
1038
|
+
}
|
1039
|
+
getOverlayRect() {
|
1040
|
+
return this.overlayDir.overlayRef.overlayElement.getBoundingClientRect();
|
1041
|
+
}
|
1042
|
+
getOverlayWidth() {
|
1043
|
+
return this.scrollStrategy._overlayRef.hostElement.clientWidth;
|
1044
|
+
}
|
1045
|
+
}
|
1046
|
+
/** @nocollapse */ /** @nocollapse */ McSelect.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: McSelect, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.NgZone }, { token: i0.Renderer2 }, { token: i1.ErrorStateMatcher }, { token: i0.ElementRef }, { token: NG_VALIDATORS, optional: true }, { token: i3.Directionality, optional: true }, { token: i4.NgForm, optional: true }, { token: i4.FormGroupDirective, optional: true }, { token: i1$1.McFormField, optional: true }, { token: i4.NgControl, optional: true, self: true }, { token: i4.NgModel, optional: true, self: true }, { token: i4.FormControlName, optional: true, self: true }, { token: MC_SELECT_SCROLL_STRATEGY }, { token: MC_VALIDATION, optional: true }], target: i0.ɵɵFactoryTarget.Component });
|
1047
|
+
/** @nocollapse */ /** @nocollapse */ McSelect.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: McSelect, selector: "mc-select", inputs: { disabled: "disabled", tabIndex: "tabIndex", hiddenItemsText: "hiddenItemsText", panelClass: "panelClass", backdropClass: "backdropClass", errorStateMatcher: "errorStateMatcher", sortComparator: "sortComparator", hasBackdrop: "hasBackdrop", placeholder: "placeholder", required: "required", multiple: "multiple", compareWith: "compareWith", value: "value", id: "id", hiddenItemsTextFormatter: "hiddenItemsTextFormatter" }, outputs: { openedChange: "openedChange", openedStream: "opened", closedStream: "closed", selectionChange: "selectionChange", valueChange: "valueChange" }, host: { listeners: { "keydown": "handleKeydown($event)", "focus": "onFocus()", "blur": "onBlur()", "window:resize": "calculateHiddenItems()" }, properties: { "attr.id": "id", "attr.tabindex": "tabIndex", "attr.disabled": "disabled || null", "class.mc-disabled": "disabled", "class.mc-invalid": "errorState" }, classAttribute: "mc-select" }, providers: [
|
1048
|
+
{ provide: McFormFieldControl, useExisting: McSelect },
|
1049
|
+
{ provide: MC_OPTION_PARENT_COMPONENT, useExisting: McSelect }
|
1050
|
+
], queries: [{ propertyName: "customTrigger", first: true, predicate: McSelectTrigger, descendants: true }, { propertyName: "cleaner", first: true, predicate: ["mcSelectCleaner"], descendants: true, static: true }, { propertyName: "search", first: true, predicate: McSelectSearch, descendants: true }, { propertyName: "options", predicate: McOption, descendants: true }, { propertyName: "optionGroups", predicate: McOptgroup }], viewQueries: [{ propertyName: "trigger", first: true, predicate: ["trigger"], descendants: true }, { propertyName: "panel", first: true, predicate: ["panel"], descendants: true }, { propertyName: "optionsContainer", first: true, predicate: ["optionsContainer"], descendants: true }, { propertyName: "overlayDir", first: true, predicate: CdkConnectedOverlay, descendants: true }, { propertyName: "tags", predicate: McTag, descendants: true }], exportAs: ["mcSelect"], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div cdk-overlay-origin\n class=\"mc-select__trigger\"\n (click)=\"toggle()\"\n [class.mc-select__trigger_multiple]=\"multiple\"\n #origin=\"cdkOverlayOrigin\"\n #trigger>\n <div class=\"mc-select__matcher\" [ngSwitch]=\"empty\">\n <span class=\"mc-select__placeholder\" *ngSwitchCase=\"true\">{{ placeholder || '\\u00A0' }}</span>\n <span *ngSwitchCase=\"false\" [ngSwitch]=\"!!customTrigger\">\n <div *ngSwitchDefault [ngSwitch]=\"multiple\" class=\"mc-select__match-container\">\n <span *ngSwitchCase=\"false\" class=\"mc-select__matcher-text\">{{ triggerValue }}</span>\n <div *ngSwitchCase=\"true\" class=\"mc-select__match-list\">\n <mc-tag *ngFor=\"let option of triggerValues\"\n [disabled]=\"option.disabled || disabled\"\n [selectable]=\"false\"\n [class.mc-error]=\"errorState\">\n {{ option.viewValue }}\n <i mc-icon=\"mc-close-S_16\" mcTagRemove\n *ngIf=\"!option.disabled && !disabled\"\n (click)=\"onRemoveMatcherItem(option, $event)\">\n </i>\n </mc-tag>\n </div>\n <div class=\"mc-select__match-hidden-text\" [style.display]=\"hiddenItems > 0 ? 'block' : 'none'\">\n {{ hiddenItemsTextFormatter(hiddenItemsText, hiddenItems) }}\n </div>\n </div>\n <ng-content select=\"mc-select-trigger\" *ngSwitchCase=\"true\"></ng-content>\n </span>\n </div>\n\n <div class=\"mc-select__cleaner\" *ngIf=\"canShowCleaner\" (click)=\"clearValue($event)\">\n <ng-content select=\"mc-cleaner\"></ng-content>\n </div>\n\n <div class=\"mc-select__arrow-wrapper\">\n <i class=\"mc-select__arrow\" mc-icon=\"mc-angle-down-S_16\"></i>\n </div>\n</div>\n\n<ng-template\n cdk-connected-overlay\n cdkConnectedOverlayLockPosition\n [cdkConnectedOverlayHasBackdrop]=\"hasBackdrop\"\n [cdkConnectedOverlayBackdropClass]=\"backdropClass\"\n [cdkConnectedOverlayScrollStrategy]=\"scrollStrategy\"\n [cdkConnectedOverlayOrigin]=\"origin\"\n [cdkConnectedOverlayOpen]=\"panelOpen\"\n [cdkConnectedOverlayPositions]=\"positions\"\n [cdkConnectedOverlayMinWidth]=\"triggerRect?.width!\"\n [cdkConnectedOverlayOffsetY]=\"offsetY\"\n (backdropClick)=\"close()\"\n (attach)=\"onAttached()\"\n (detach)=\"close()\">\n <div\n #panel\n class=\"mc-select__panel {{ getPanelTheme() }}\"\n [ngClass]=\"panelClass\"\n [style.transformOrigin]=\"transformOrigin\"\n [style.font-size.px]=\"triggerFontSize\"\n (keydown)=\"handleKeydown($event)\">\n\n <div *ngIf=\"search\" class=\"mc-select__search-container\">\n <ng-content select=\"[mcSelectSearch]\"></ng-content>\n </div>\n\n <div #optionsContainer\n class=\"mc-select__content\"\n [@fadeInContent]=\"'showing'\"\n (@fadeInContent.done)=\"panelDoneAnimatingStream.next($event.toState)\">\n\n <div *ngIf=\"isEmptySearchResult\" class=\"mc-select__no-options-message\">\n <ng-content select=\"[mc-select-search-empty-result]\"></ng-content>\n </div>\n <ng-content></ng-content>\n </div>\n </div>\n</ng-template>\n", styles: [".mc-option{display:flex;flex-direction:row;align-items:center;box-sizing:border-box;position:relative;max-width:100%;height:var(--mc-option-size-height, 32px);border:var(--mc-option-size-border-width, 2px) solid transparent;cursor:pointer;outline:none;padding-left:var(--mc-option-size-horizontal-padding, 12px);padding-right:var(--mc-option-size-horizontal-padding, 12px);-webkit-tap-highlight-color:transparent}.mc-option.mc-disabled{cursor:default}.mc-option .mc-pseudo-checkbox{margin-right:8px}.mc-option .mc-option-overlay{position:absolute;top:calc(-1 * var(--mc-option-size-border-width, 2px));left:calc(-1 * var(--mc-option-size-border-width, 2px));right:calc(-1 * var(--mc-option-size-border-width, 2px));bottom:calc(-1 * var(--mc-option-size-border-width, 2px));pointer-events:none;border-radius:inherit}.mc-option-text{display:inline-block;flex-grow:1;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.mc-select{box-sizing:border-box;display:inline-block;width:100%;outline:none}.mc-select .mc-select__trigger{display:flex;box-sizing:border-box;position:relative;height:calc(var(--mc-form-field-size-height, 32px) - var(--mc-form-field-size-border-width, 1px) * 2);cursor:pointer;padding-left:calc(var(--mc-select-size-left-padding, 12px) - var(--mc-form-field-size-border-width, 1px));padding-right:calc(var(--mc-select-size-right-padding, 6px) - var(--mc-form-field-size-border-width, 1px))}.mc-select .mc-select__trigger.mc-select__trigger_multiple{padding-left:calc(var(--mc-select-size-left-padding-multiple, 12px) - var(--mc-form-field-size-border-width, 1px))}.mc-select .mc-select__trigger.mc-select__trigger_multiple .mc-tag.mc-disabled .mc-tag__text{margin-right:7px}.mc-select.mc-disabled .mc-select__trigger{-webkit-user-select:none;user-select:none;cursor:default}.mc-select__no-options-message{display:flex;flex-direction:row;align-items:center;box-sizing:border-box;position:relative;max-width:100%;height:var(--mc-option-size-height, 32px);cursor:default;outline:none;padding-left:var(--mc-option-size-horizontal-padding, 12px);padding-right:var(--mc-option-size-horizontal-padding, 12px)}.mc-select__matcher{display:flex;align-items:center;width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mc-select__matcher>span{width:100%}.mc-select__match-list{display:flex;flex-wrap:wrap;overflow:hidden;max-height:calc(var(--mc-form-field-size-height, 32px) - var(--mc-form-field-size-border-width, 1px) * 2)}.mc-select__match-list .mc-tag{margin-right:4px}.mc-select__match-container{display:flex;flex-direction:row;justify-content:space-between;width:100%}.mc-select__match-container .mc-select__match-hidden-text{flex:0 0 70px;align-self:center;padding:0 8px;text-align:right}.mc-select__arrow-wrapper{align-self:center}.mc-form-field-appearance-fill .mc-select__arrow-wrapper,.mc-form-field-appearance-standard .mc-select__arrow-wrapper{transform:translateY(-50%)}.mc-form-field-appearance-outline .mc-select__arrow-wrapper{transform:translateY(-25%)}.mc-select__panel{min-width:100%;max-width:var(--mc-select-panel-size-max-width, 640px);overflow:hidden;border-width:var(--mc-select-panel-size-border-width, 1px);border-style:solid;border-bottom-left-radius:var(--mc-select-panel-size-border-radius, 4px);border-bottom-right-radius:var(--mc-select-panel-size-border-radius, 4px)}.mc-select__panel .mc-optgroup-label,.mc-select__panel .mc-option{font-size:inherit;line-height:var(--mc-option-size-height, 32px);height:var(--mc-option-size-height, 32px)}.mc-select__content{max-height:var(--mc-select-panel-size-max-height, 232px);padding:var(--mc-select-panel-size-vertical-padding, 4px) 0;overflow:auto}.mc-select__content .cdk-virtual-scroll-viewport{min-height:var(--mc-select-panel-size-max-height, 232px)-8px;max-height:var(--mc-select-panel-size-max-height, 232px)-8px}.mc-form-field-type-select:not(.mc-disabled) .mc-form-field-flex{cursor:pointer}.mc-select__search-container{border-bottom-width:1px;border-bottom-style:solid}\n"], components: [{ type: i5.McTag, selector: "mc-tag, [mc-tag], mc-basic-tag, [mc-basic-tag]", inputs: ["color", "selected", "value", "selectable", "removable", "disabled"], outputs: ["selectionChange", "destroyed", "removed"], exportAs: ["mcTag"] }, { type: i6.McIcon, selector: "[mc-icon]", inputs: ["color"] }], directives: [{ type: i2.CdkOverlayOrigin, selector: "[cdk-overlay-origin], [overlay-origin], [cdkOverlayOrigin]", exportAs: ["cdkOverlayOrigin"] }, { type: i8.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i8.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { type: i8.NgSwitchDefault, selector: "[ngSwitchDefault]" }, { type: i8.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i8.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i6.McIconCSSStyler, selector: "[mc-icon]" }, { type: i5.McTagRemove, selector: "[mcTagRemove]" }, { type: i2.CdkConnectedOverlay, selector: "[cdk-connected-overlay], [connected-overlay], [cdkConnectedOverlay]", inputs: ["cdkConnectedOverlayOrigin", "cdkConnectedOverlayPositions", "cdkConnectedOverlayPositionStrategy", "cdkConnectedOverlayOffsetX", "cdkConnectedOverlayOffsetY", "cdkConnectedOverlayWidth", "cdkConnectedOverlayHeight", "cdkConnectedOverlayMinWidth", "cdkConnectedOverlayMinHeight", "cdkConnectedOverlayBackdropClass", "cdkConnectedOverlayPanelClass", "cdkConnectedOverlayViewportMargin", "cdkConnectedOverlayScrollStrategy", "cdkConnectedOverlayOpen", "cdkConnectedOverlayDisableClose", "cdkConnectedOverlayTransformOriginOn", "cdkConnectedOverlayHasBackdrop", "cdkConnectedOverlayLockPosition", "cdkConnectedOverlayFlexibleDimensions", "cdkConnectedOverlayGrowAfterOpen", "cdkConnectedOverlayPush"], outputs: ["backdropClick", "positionChange", "attach", "detach", "overlayKeydown", "overlayOutsideClick"], exportAs: ["cdkConnectedOverlay"] }, { type: i8.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], animations: [
|
1051
|
+
mcSelectAnimations.transformPanel,
|
1052
|
+
mcSelectAnimations.fadeInContent
|
1053
|
+
], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
1054
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: McSelect, decorators: [{
|
1055
|
+
type: Component,
|
1056
|
+
args: [{ selector: 'mc-select', exportAs: 'mcSelect', inputs: ['disabled', 'tabIndex'], encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, host: {
|
1057
|
+
'[attr.id]': 'id',
|
1058
|
+
'[attr.tabindex]': 'tabIndex',
|
1059
|
+
'[attr.disabled]': 'disabled || null',
|
1060
|
+
class: 'mc-select',
|
1061
|
+
'[class.mc-disabled]': 'disabled',
|
1062
|
+
'[class.mc-invalid]': 'errorState',
|
1063
|
+
'(keydown)': 'handleKeydown($event)',
|
1064
|
+
'(focus)': 'onFocus()',
|
1065
|
+
'(blur)': 'onBlur()',
|
1066
|
+
'(window:resize)': 'calculateHiddenItems()'
|
1067
|
+
}, animations: [
|
1068
|
+
mcSelectAnimations.transformPanel,
|
1069
|
+
mcSelectAnimations.fadeInContent
|
1070
|
+
], providers: [
|
1071
|
+
{ provide: McFormFieldControl, useExisting: McSelect },
|
1072
|
+
{ provide: MC_OPTION_PARENT_COMPONENT, useExisting: McSelect }
|
1073
|
+
], template: "<div cdk-overlay-origin\n class=\"mc-select__trigger\"\n (click)=\"toggle()\"\n [class.mc-select__trigger_multiple]=\"multiple\"\n #origin=\"cdkOverlayOrigin\"\n #trigger>\n <div class=\"mc-select__matcher\" [ngSwitch]=\"empty\">\n <span class=\"mc-select__placeholder\" *ngSwitchCase=\"true\">{{ placeholder || '\\u00A0' }}</span>\n <span *ngSwitchCase=\"false\" [ngSwitch]=\"!!customTrigger\">\n <div *ngSwitchDefault [ngSwitch]=\"multiple\" class=\"mc-select__match-container\">\n <span *ngSwitchCase=\"false\" class=\"mc-select__matcher-text\">{{ triggerValue }}</span>\n <div *ngSwitchCase=\"true\" class=\"mc-select__match-list\">\n <mc-tag *ngFor=\"let option of triggerValues\"\n [disabled]=\"option.disabled || disabled\"\n [selectable]=\"false\"\n [class.mc-error]=\"errorState\">\n {{ option.viewValue }}\n <i mc-icon=\"mc-close-S_16\" mcTagRemove\n *ngIf=\"!option.disabled && !disabled\"\n (click)=\"onRemoveMatcherItem(option, $event)\">\n </i>\n </mc-tag>\n </div>\n <div class=\"mc-select__match-hidden-text\" [style.display]=\"hiddenItems > 0 ? 'block' : 'none'\">\n {{ hiddenItemsTextFormatter(hiddenItemsText, hiddenItems) }}\n </div>\n </div>\n <ng-content select=\"mc-select-trigger\" *ngSwitchCase=\"true\"></ng-content>\n </span>\n </div>\n\n <div class=\"mc-select__cleaner\" *ngIf=\"canShowCleaner\" (click)=\"clearValue($event)\">\n <ng-content select=\"mc-cleaner\"></ng-content>\n </div>\n\n <div class=\"mc-select__arrow-wrapper\">\n <i class=\"mc-select__arrow\" mc-icon=\"mc-angle-down-S_16\"></i>\n </div>\n</div>\n\n<ng-template\n cdk-connected-overlay\n cdkConnectedOverlayLockPosition\n [cdkConnectedOverlayHasBackdrop]=\"hasBackdrop\"\n [cdkConnectedOverlayBackdropClass]=\"backdropClass\"\n [cdkConnectedOverlayScrollStrategy]=\"scrollStrategy\"\n [cdkConnectedOverlayOrigin]=\"origin\"\n [cdkConnectedOverlayOpen]=\"panelOpen\"\n [cdkConnectedOverlayPositions]=\"positions\"\n [cdkConnectedOverlayMinWidth]=\"triggerRect?.width!\"\n [cdkConnectedOverlayOffsetY]=\"offsetY\"\n (backdropClick)=\"close()\"\n (attach)=\"onAttached()\"\n (detach)=\"close()\">\n <div\n #panel\n class=\"mc-select__panel {{ getPanelTheme() }}\"\n [ngClass]=\"panelClass\"\n [style.transformOrigin]=\"transformOrigin\"\n [style.font-size.px]=\"triggerFontSize\"\n (keydown)=\"handleKeydown($event)\">\n\n <div *ngIf=\"search\" class=\"mc-select__search-container\">\n <ng-content select=\"[mcSelectSearch]\"></ng-content>\n </div>\n\n <div #optionsContainer\n class=\"mc-select__content\"\n [@fadeInContent]=\"'showing'\"\n (@fadeInContent.done)=\"panelDoneAnimatingStream.next($event.toState)\">\n\n <div *ngIf=\"isEmptySearchResult\" class=\"mc-select__no-options-message\">\n <ng-content select=\"[mc-select-search-empty-result]\"></ng-content>\n </div>\n <ng-content></ng-content>\n </div>\n </div>\n</ng-template>\n", styles: [".mc-option{display:flex;flex-direction:row;align-items:center;box-sizing:border-box;position:relative;max-width:100%;height:var(--mc-option-size-height, 32px);border:var(--mc-option-size-border-width, 2px) solid transparent;cursor:pointer;outline:none;padding-left:var(--mc-option-size-horizontal-padding, 12px);padding-right:var(--mc-option-size-horizontal-padding, 12px);-webkit-tap-highlight-color:transparent}.mc-option.mc-disabled{cursor:default}.mc-option .mc-pseudo-checkbox{margin-right:8px}.mc-option .mc-option-overlay{position:absolute;top:calc(-1 * var(--mc-option-size-border-width, 2px));left:calc(-1 * var(--mc-option-size-border-width, 2px));right:calc(-1 * var(--mc-option-size-border-width, 2px));bottom:calc(-1 * var(--mc-option-size-border-width, 2px));pointer-events:none;border-radius:inherit}.mc-option-text{display:inline-block;flex-grow:1;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.mc-select{box-sizing:border-box;display:inline-block;width:100%;outline:none}.mc-select .mc-select__trigger{display:flex;box-sizing:border-box;position:relative;height:calc(var(--mc-form-field-size-height, 32px) - var(--mc-form-field-size-border-width, 1px) * 2);cursor:pointer;padding-left:calc(var(--mc-select-size-left-padding, 12px) - var(--mc-form-field-size-border-width, 1px));padding-right:calc(var(--mc-select-size-right-padding, 6px) - var(--mc-form-field-size-border-width, 1px))}.mc-select .mc-select__trigger.mc-select__trigger_multiple{padding-left:calc(var(--mc-select-size-left-padding-multiple, 12px) - var(--mc-form-field-size-border-width, 1px))}.mc-select .mc-select__trigger.mc-select__trigger_multiple .mc-tag.mc-disabled .mc-tag__text{margin-right:7px}.mc-select.mc-disabled .mc-select__trigger{-webkit-user-select:none;user-select:none;cursor:default}.mc-select__no-options-message{display:flex;flex-direction:row;align-items:center;box-sizing:border-box;position:relative;max-width:100%;height:var(--mc-option-size-height, 32px);cursor:default;outline:none;padding-left:var(--mc-option-size-horizontal-padding, 12px);padding-right:var(--mc-option-size-horizontal-padding, 12px)}.mc-select__matcher{display:flex;align-items:center;width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mc-select__matcher>span{width:100%}.mc-select__match-list{display:flex;flex-wrap:wrap;overflow:hidden;max-height:calc(var(--mc-form-field-size-height, 32px) - var(--mc-form-field-size-border-width, 1px) * 2)}.mc-select__match-list .mc-tag{margin-right:4px}.mc-select__match-container{display:flex;flex-direction:row;justify-content:space-between;width:100%}.mc-select__match-container .mc-select__match-hidden-text{flex:0 0 70px;align-self:center;padding:0 8px;text-align:right}.mc-select__arrow-wrapper{align-self:center}.mc-form-field-appearance-fill .mc-select__arrow-wrapper,.mc-form-field-appearance-standard .mc-select__arrow-wrapper{transform:translateY(-50%)}.mc-form-field-appearance-outline .mc-select__arrow-wrapper{transform:translateY(-25%)}.mc-select__panel{min-width:100%;max-width:var(--mc-select-panel-size-max-width, 640px);overflow:hidden;border-width:var(--mc-select-panel-size-border-width, 1px);border-style:solid;border-bottom-left-radius:var(--mc-select-panel-size-border-radius, 4px);border-bottom-right-radius:var(--mc-select-panel-size-border-radius, 4px)}.mc-select__panel .mc-optgroup-label,.mc-select__panel .mc-option{font-size:inherit;line-height:var(--mc-option-size-height, 32px);height:var(--mc-option-size-height, 32px)}.mc-select__content{max-height:var(--mc-select-panel-size-max-height, 232px);padding:var(--mc-select-panel-size-vertical-padding, 4px) 0;overflow:auto}.mc-select__content .cdk-virtual-scroll-viewport{min-height:var(--mc-select-panel-size-max-height, 232px)-8px;max-height:var(--mc-select-panel-size-max-height, 232px)-8px}.mc-form-field-type-select:not(.mc-disabled) .mc-form-field-flex{cursor:pointer}.mc-select__search-container{border-bottom-width:1px;border-bottom-style:solid}\n"] }]
|
1074
|
+
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i0.NgZone }, { type: i0.Renderer2 }, { type: i1.ErrorStateMatcher }, { type: i0.ElementRef }, { type: undefined, decorators: [{
|
1075
|
+
type: Optional
|
1076
|
+
}, {
|
1077
|
+
type: Inject,
|
1078
|
+
args: [NG_VALIDATORS]
|
1079
|
+
}] }, { type: i3.Directionality, decorators: [{
|
1080
|
+
type: Optional
|
1081
|
+
}] }, { type: i4.NgForm, decorators: [{
|
1082
|
+
type: Optional
|
1083
|
+
}] }, { type: i4.FormGroupDirective, decorators: [{
|
1084
|
+
type: Optional
|
1085
|
+
}] }, { type: i1$1.McFormField, decorators: [{
|
1086
|
+
type: Optional
|
1087
|
+
}] }, { type: i4.NgControl, decorators: [{
|
1088
|
+
type: Self
|
1089
|
+
}, {
|
1090
|
+
type: Optional
|
1091
|
+
}] }, { type: i4.NgModel, decorators: [{
|
1092
|
+
type: Optional
|
1093
|
+
}, {
|
1094
|
+
type: Self
|
1095
|
+
}] }, { type: i4.FormControlName, decorators: [{
|
1096
|
+
type: Optional
|
1097
|
+
}, {
|
1098
|
+
type: Self
|
1099
|
+
}] }, { type: undefined, decorators: [{
|
1100
|
+
type: Inject,
|
1101
|
+
args: [MC_SELECT_SCROLL_STRATEGY]
|
1102
|
+
}] }, { type: undefined, decorators: [{
|
1103
|
+
type: Optional
|
1104
|
+
}, {
|
1105
|
+
type: Inject,
|
1106
|
+
args: [MC_VALIDATION]
|
1107
|
+
}] }]; }, propDecorators: { trigger: [{
|
1108
|
+
type: ViewChild,
|
1109
|
+
args: ['trigger', { static: false }]
|
1110
|
+
}], panel: [{
|
1111
|
+
type: ViewChild,
|
1112
|
+
args: ['panel', { static: false }]
|
1113
|
+
}], optionsContainer: [{
|
1114
|
+
type: ViewChild,
|
1115
|
+
args: ['optionsContainer', { static: false }]
|
1116
|
+
}], overlayDir: [{
|
1117
|
+
type: ViewChild,
|
1118
|
+
args: [CdkConnectedOverlay, { static: false }]
|
1119
|
+
}], tags: [{
|
1120
|
+
type: ViewChildren,
|
1121
|
+
args: [McTag]
|
1122
|
+
}], customTrigger: [{
|
1123
|
+
type: ContentChild,
|
1124
|
+
args: [McSelectTrigger, { static: false }]
|
1125
|
+
}], cleaner: [{
|
1126
|
+
type: ContentChild,
|
1127
|
+
args: ['mcSelectCleaner', { static: true }]
|
1128
|
+
}], options: [{
|
1129
|
+
type: ContentChildren,
|
1130
|
+
args: [McOption, { descendants: true }]
|
1131
|
+
}], optionGroups: [{
|
1132
|
+
type: ContentChildren,
|
1133
|
+
args: [McOptgroup]
|
1134
|
+
}], search: [{
|
1135
|
+
type: ContentChild,
|
1136
|
+
args: [McSelectSearch, { static: false }]
|
1137
|
+
}], hiddenItemsText: [{
|
1138
|
+
type: Input
|
1139
|
+
}], panelClass: [{
|
1140
|
+
type: Input
|
1141
|
+
}], backdropClass: [{
|
1142
|
+
type: Input
|
1143
|
+
}], errorStateMatcher: [{
|
1144
|
+
type: Input
|
1145
|
+
}], sortComparator: [{
|
1146
|
+
type: Input
|
1147
|
+
}], openedChange: [{
|
1148
|
+
type: Output
|
1149
|
+
}], openedStream: [{
|
1150
|
+
type: Output,
|
1151
|
+
args: ['opened']
|
1152
|
+
}], closedStream: [{
|
1153
|
+
type: Output,
|
1154
|
+
args: ['closed']
|
1155
|
+
}], selectionChange: [{
|
1156
|
+
type: Output
|
1157
|
+
}], valueChange: [{
|
1158
|
+
type: Output
|
1159
|
+
}], hasBackdrop: [{
|
1160
|
+
type: Input
|
1161
|
+
}], placeholder: [{
|
1162
|
+
type: Input
|
1163
|
+
}], required: [{
|
1164
|
+
type: Input
|
1165
|
+
}], multiple: [{
|
1166
|
+
type: Input
|
1167
|
+
}], compareWith: [{
|
1168
|
+
type: Input
|
1169
|
+
}], value: [{
|
1170
|
+
type: Input
|
1171
|
+
}], id: [{
|
1172
|
+
type: Input
|
1173
|
+
}], hiddenItemsTextFormatter: [{
|
1174
|
+
type: Input
|
1165
1175
|
}] } });
|
1166
1176
|
|
1167
|
-
class McSelectModule {
|
1168
|
-
}
|
1169
|
-
/** @nocollapse */ /** @nocollapse */ McSelectModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.
|
1170
|
-
/** @nocollapse */ /** @nocollapse */ McSelectModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.3.
|
1171
|
-
McSelectSearch,
|
1172
|
-
McSelectSearchEmptyResult,
|
1173
|
-
McSelectTrigger,
|
1174
|
-
McOptionTooltip], imports: [CommonModule,
|
1175
|
-
OverlayModule,
|
1176
|
-
McOptionModule,
|
1177
|
-
McIconModule,
|
1178
|
-
McTagsModule,
|
1179
|
-
McToolTipModule], exports: [McFormFieldModule,
|
1180
|
-
McSelect,
|
1181
|
-
McSelectSearch,
|
1182
|
-
McSelectSearchEmptyResult,
|
1183
|
-
McSelectTrigger,
|
1184
|
-
McOptionTooltip,
|
1185
|
-
McOptionModule,
|
1186
|
-
CommonModule] });
|
1187
|
-
/** @nocollapse */ /** @nocollapse */ McSelectModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.3.
|
1188
|
-
CommonModule,
|
1189
|
-
OverlayModule,
|
1190
|
-
McOptionModule,
|
1191
|
-
McIconModule,
|
1192
|
-
McTagsModule,
|
1193
|
-
McToolTipModule
|
1194
|
-
], McFormFieldModule,
|
1195
|
-
McOptionModule,
|
1196
|
-
CommonModule] });
|
1197
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.
|
1198
|
-
type: NgModule,
|
1199
|
-
args: [{
|
1200
|
-
imports: [
|
1201
|
-
CommonModule,
|
1202
|
-
OverlayModule,
|
1203
|
-
McOptionModule,
|
1204
|
-
McIconModule,
|
1205
|
-
McTagsModule,
|
1206
|
-
McToolTipModule
|
1207
|
-
],
|
1208
|
-
exports: [
|
1209
|
-
McFormFieldModule,
|
1210
|
-
McSelect,
|
1211
|
-
McSelectSearch,
|
1212
|
-
McSelectSearchEmptyResult,
|
1213
|
-
McSelectTrigger,
|
1214
|
-
McOptionTooltip,
|
1215
|
-
McOptionModule,
|
1216
|
-
CommonModule
|
1217
|
-
],
|
1218
|
-
declarations: [
|
1219
|
-
McSelect,
|
1220
|
-
McSelectSearch,
|
1221
|
-
McSelectSearchEmptyResult,
|
1222
|
-
McSelectTrigger,
|
1223
|
-
McOptionTooltip
|
1224
|
-
],
|
1225
|
-
providers: [MC_SELECT_SCROLL_STRATEGY_PROVIDER]
|
1226
|
-
}]
|
1177
|
+
class McSelectModule {
|
1178
|
+
}
|
1179
|
+
/** @nocollapse */ /** @nocollapse */ McSelectModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: McSelectModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
1180
|
+
/** @nocollapse */ /** @nocollapse */ McSelectModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: McSelectModule, declarations: [McSelect,
|
1181
|
+
McSelectSearch,
|
1182
|
+
McSelectSearchEmptyResult,
|
1183
|
+
McSelectTrigger,
|
1184
|
+
McOptionTooltip], imports: [CommonModule,
|
1185
|
+
OverlayModule,
|
1186
|
+
McOptionModule,
|
1187
|
+
McIconModule,
|
1188
|
+
McTagsModule,
|
1189
|
+
McToolTipModule], exports: [McFormFieldModule,
|
1190
|
+
McSelect,
|
1191
|
+
McSelectSearch,
|
1192
|
+
McSelectSearchEmptyResult,
|
1193
|
+
McSelectTrigger,
|
1194
|
+
McOptionTooltip,
|
1195
|
+
McOptionModule,
|
1196
|
+
CommonModule] });
|
1197
|
+
/** @nocollapse */ /** @nocollapse */ McSelectModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: McSelectModule, providers: [MC_SELECT_SCROLL_STRATEGY_PROVIDER], imports: [[
|
1198
|
+
CommonModule,
|
1199
|
+
OverlayModule,
|
1200
|
+
McOptionModule,
|
1201
|
+
McIconModule,
|
1202
|
+
McTagsModule,
|
1203
|
+
McToolTipModule
|
1204
|
+
], McFormFieldModule,
|
1205
|
+
McOptionModule,
|
1206
|
+
CommonModule] });
|
1207
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: McSelectModule, decorators: [{
|
1208
|
+
type: NgModule,
|
1209
|
+
args: [{
|
1210
|
+
imports: [
|
1211
|
+
CommonModule,
|
1212
|
+
OverlayModule,
|
1213
|
+
McOptionModule,
|
1214
|
+
McIconModule,
|
1215
|
+
McTagsModule,
|
1216
|
+
McToolTipModule
|
1217
|
+
],
|
1218
|
+
exports: [
|
1219
|
+
McFormFieldModule,
|
1220
|
+
McSelect,
|
1221
|
+
McSelectSearch,
|
1222
|
+
McSelectSearchEmptyResult,
|
1223
|
+
McSelectTrigger,
|
1224
|
+
McOptionTooltip,
|
1225
|
+
McOptionModule,
|
1226
|
+
CommonModule
|
1227
|
+
],
|
1228
|
+
declarations: [
|
1229
|
+
McSelect,
|
1230
|
+
McSelectSearch,
|
1231
|
+
McSelectSearchEmptyResult,
|
1232
|
+
McSelectTrigger,
|
1233
|
+
McOptionTooltip
|
1234
|
+
],
|
1235
|
+
providers: [MC_SELECT_SCROLL_STRATEGY_PROVIDER]
|
1236
|
+
}]
|
1227
1237
|
}] });
|
1228
1238
|
|
1229
|
-
/**
|
1230
|
-
* Generated bundle index. Do not edit.
|
1239
|
+
/**
|
1240
|
+
* Generated bundle index. Do not edit.
|
1231
1241
|
*/
|
1232
1242
|
|
1233
1243
|
export { McOptionTooltip, McSelect, McSelectBase, McSelectChange, McSelectModule, McSelectSearch, McSelectSearchEmptyResult, McSelectTrigger };
|