@angular/material 15.0.0-rc.0 → 15.0.0-rc.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/_index.scss +1 -1
- package/checkbox/_checkbox-private.scss +1 -1
- package/chips/_chips-theme.scss +11 -19
- package/chips/index.d.ts +0 -2
- package/core/density/private/_all-density.scss +5 -9
- package/core/theming/_all-theme.scss +14 -18
- package/core/typography/_all-typography.scss +15 -19
- package/core/typography/_typography-deprecated.scss +1 -1
- package/core/typography/_typography.scss +130 -0
- package/esm2020/autocomplete/autocomplete-origin.mjs +6 -6
- package/esm2020/autocomplete/autocomplete-trigger.mjs +6 -6
- package/esm2020/autocomplete/autocomplete.mjs +6 -6
- package/esm2020/autocomplete/module.mjs +4 -4
- package/esm2020/badge/badge-module.mjs +4 -4
- package/esm2020/badge/badge.mjs +3 -3
- package/esm2020/bottom-sheet/bottom-sheet-container.mjs +3 -3
- package/esm2020/bottom-sheet/bottom-sheet-module.mjs +4 -4
- package/esm2020/bottom-sheet/bottom-sheet.mjs +3 -3
- package/esm2020/button/button-base.mjs +6 -6
- package/esm2020/button/button.mjs +8 -8
- package/esm2020/button/fab.mjs +16 -16
- package/esm2020/button/icon-button.mjs +6 -6
- package/esm2020/button/module.mjs +4 -4
- package/esm2020/button-toggle/button-toggle-module.mjs +4 -4
- package/esm2020/button-toggle/button-toggle.mjs +6 -6
- package/esm2020/card/card.mjs +42 -42
- package/esm2020/card/module.mjs +4 -4
- package/esm2020/checkbox/checkbox-required-validator.mjs +3 -3
- package/esm2020/checkbox/checkbox.mjs +6 -6
- package/esm2020/checkbox/module.mjs +8 -8
- package/esm2020/chips/chip-action.mjs +3 -3
- package/esm2020/chips/chip-edit-input.mjs +3 -3
- package/esm2020/chips/chip-grid.mjs +3 -3
- package/esm2020/chips/chip-icons.mjs +9 -9
- package/esm2020/chips/chip-input.mjs +3 -3
- package/esm2020/chips/chip-listbox.mjs +3 -3
- package/esm2020/chips/chip-option.mjs +7 -13
- package/esm2020/chips/chip-row.mjs +5 -5
- package/esm2020/chips/chip-set.mjs +3 -3
- package/esm2020/chips/chip.mjs +4 -4
- package/esm2020/chips/module.mjs +4 -4
- package/esm2020/core/common-behaviors/common-module.mjs +4 -4
- package/esm2020/core/datetime/index.mjs +8 -8
- package/esm2020/core/datetime/native-date-adapter.mjs +3 -3
- package/esm2020/core/error/error-options.mjs +6 -6
- package/esm2020/core/line/line.mjs +7 -7
- package/esm2020/core/option/index.mjs +4 -4
- package/esm2020/core/option/optgroup.mjs +6 -6
- package/esm2020/core/option/option.mjs +6 -6
- package/esm2020/core/ripple/index.mjs +4 -4
- package/esm2020/core/ripple/ripple.mjs +3 -3
- package/esm2020/core/selection/pseudo-checkbox/pseudo-checkbox-module.mjs +4 -4
- package/esm2020/core/selection/pseudo-checkbox/pseudo-checkbox.mjs +3 -3
- package/esm2020/core/version.mjs +1 -1
- package/esm2020/datepicker/calendar-body.mjs +3 -3
- package/esm2020/datepicker/calendar.mjs +6 -6
- package/esm2020/datepicker/date-range-input-parts.mjs +12 -12
- package/esm2020/datepicker/date-range-input.mjs +3 -3
- package/esm2020/datepicker/date-range-picker.mjs +3 -3
- package/esm2020/datepicker/date-range-selection-strategy.mjs +3 -3
- package/esm2020/datepicker/date-selection-model.mjs +9 -9
- package/esm2020/datepicker/datepicker-actions.mjs +9 -9
- package/esm2020/datepicker/datepicker-base.mjs +6 -6
- package/esm2020/datepicker/datepicker-input-base.mjs +3 -3
- package/esm2020/datepicker/datepicker-input.mjs +3 -3
- package/esm2020/datepicker/datepicker-intl.mjs +3 -3
- package/esm2020/datepicker/datepicker-module.mjs +4 -4
- package/esm2020/datepicker/datepicker-toggle.mjs +6 -6
- package/esm2020/datepicker/datepicker.mjs +3 -3
- package/esm2020/datepicker/month-view.mjs +3 -3
- package/esm2020/datepicker/multi-year-view.mjs +3 -3
- package/esm2020/datepicker/year-view.mjs +3 -3
- package/esm2020/dialog/dialog-container.mjs +7 -7
- package/esm2020/dialog/dialog-content-directives.mjs +12 -12
- package/esm2020/dialog/dialog.mjs +6 -6
- package/esm2020/dialog/module.mjs +4 -4
- package/esm2020/divider/divider-module.mjs +4 -4
- package/esm2020/divider/divider.mjs +3 -3
- package/esm2020/expansion/accordion.mjs +3 -3
- package/esm2020/expansion/expansion-module.mjs +4 -4
- package/esm2020/expansion/expansion-panel-content.mjs +3 -3
- package/esm2020/expansion/expansion-panel-header.mjs +9 -9
- package/esm2020/expansion/expansion-panel.mjs +6 -6
- package/esm2020/form-field/directives/error.mjs +3 -3
- package/esm2020/form-field/directives/floating-label.mjs +3 -3
- package/esm2020/form-field/directives/hint.mjs +3 -3
- package/esm2020/form-field/directives/label.mjs +3 -3
- package/esm2020/form-field/directives/line-ripple.mjs +3 -3
- package/esm2020/form-field/directives/notched-outline.mjs +3 -3
- package/esm2020/form-field/directives/prefix.mjs +3 -3
- package/esm2020/form-field/directives/suffix.mjs +3 -3
- package/esm2020/form-field/form-field-control.mjs +3 -3
- package/esm2020/form-field/form-field.mjs +3 -3
- package/esm2020/form-field/module.mjs +4 -4
- package/esm2020/grid-list/grid-list-module.mjs +4 -4
- package/esm2020/grid-list/grid-list.mjs +3 -3
- package/esm2020/grid-list/grid-tile.mjs +15 -15
- package/esm2020/icon/icon-module.mjs +4 -4
- package/esm2020/icon/icon-registry.mjs +3 -3
- package/esm2020/icon/icon.mjs +3 -3
- package/esm2020/icon/testing/fake-icon-registry.mjs +7 -7
- package/esm2020/input/input.mjs +3 -3
- package/esm2020/input/module.mjs +4 -4
- package/esm2020/legacy-autocomplete/autocomplete-module.mjs +4 -4
- package/esm2020/legacy-autocomplete/autocomplete-origin.mjs +3 -3
- package/esm2020/legacy-autocomplete/autocomplete-trigger.mjs +3 -3
- package/esm2020/legacy-autocomplete/autocomplete.mjs +3 -3
- package/esm2020/legacy-button/button-module.mjs +4 -4
- package/esm2020/legacy-button/button.mjs +6 -6
- package/esm2020/legacy-card/card-module.mjs +4 -4
- package/esm2020/legacy-card/card.mjs +42 -42
- package/esm2020/legacy-checkbox/checkbox-module.mjs +4 -4
- package/esm2020/legacy-checkbox/checkbox.mjs +3 -3
- package/esm2020/legacy-chips/chip-input.mjs +3 -3
- package/esm2020/legacy-chips/chip-list.mjs +3 -3
- package/esm2020/legacy-chips/chip.mjs +12 -12
- package/esm2020/legacy-chips/chips-module.mjs +4 -4
- package/esm2020/legacy-core/option/index.mjs +4 -4
- package/esm2020/legacy-core/option/optgroup.mjs +3 -3
- package/esm2020/legacy-core/option/option.mjs +3 -3
- package/esm2020/legacy-dialog/dialog-container.mjs +3 -3
- package/esm2020/legacy-dialog/dialog-content-directives.mjs +12 -12
- package/esm2020/legacy-dialog/dialog-module.mjs +4 -4
- package/esm2020/legacy-dialog/dialog.mjs +3 -3
- package/esm2020/legacy-form-field/error.mjs +3 -3
- package/esm2020/legacy-form-field/form-field-module.mjs +4 -4
- package/esm2020/legacy-form-field/form-field.mjs +3 -3
- package/esm2020/legacy-form-field/hint.mjs +3 -3
- package/esm2020/legacy-form-field/label.mjs +3 -3
- package/esm2020/legacy-form-field/placeholder.mjs +3 -3
- package/esm2020/legacy-form-field/prefix.mjs +3 -3
- package/esm2020/legacy-form-field/suffix.mjs +3 -3
- package/esm2020/legacy-input/input-module.mjs +4 -4
- package/esm2020/legacy-input/input.mjs +3 -3
- package/esm2020/legacy-list/list-module.mjs +4 -4
- package/esm2020/legacy-list/list.mjs +18 -18
- package/esm2020/legacy-list/selection-list.mjs +6 -6
- package/esm2020/legacy-menu/menu-content.mjs +3 -3
- package/esm2020/legacy-menu/menu-item.mjs +3 -3
- package/esm2020/legacy-menu/menu-module.mjs +4 -4
- package/esm2020/legacy-menu/menu-trigger.mjs +3 -3
- package/esm2020/legacy-menu/menu.mjs +3 -3
- package/esm2020/legacy-paginator/paginator-module.mjs +4 -4
- package/esm2020/legacy-paginator/paginator.mjs +3 -3
- package/esm2020/legacy-progress-bar/progress-bar-module.mjs +4 -4
- package/esm2020/legacy-progress-bar/progress-bar.mjs +3 -3
- package/esm2020/legacy-progress-spinner/progress-spinner-module.mjs +4 -4
- package/esm2020/legacy-progress-spinner/progress-spinner.mjs +3 -3
- package/esm2020/legacy-radio/radio-module.mjs +4 -4
- package/esm2020/legacy-radio/radio.mjs +6 -6
- package/esm2020/legacy-select/select-module.mjs +4 -4
- package/esm2020/legacy-select/select.mjs +6 -6
- package/esm2020/legacy-slide-toggle/slide-toggle-module.mjs +4 -4
- package/esm2020/legacy-slide-toggle/slide-toggle.mjs +3 -3
- package/esm2020/legacy-slider/slider-module.mjs +4 -4
- package/esm2020/legacy-slider/slider.mjs +3 -3
- package/esm2020/legacy-snack-bar/simple-snack-bar.mjs +3 -3
- package/esm2020/legacy-snack-bar/snack-bar-container.mjs +3 -3
- package/esm2020/legacy-snack-bar/snack-bar-module.mjs +4 -4
- package/esm2020/legacy-snack-bar/snack-bar.mjs +3 -3
- package/esm2020/legacy-table/cell.mjs +21 -21
- package/esm2020/legacy-table/row.mjs +21 -21
- package/esm2020/legacy-table/table-module.mjs +4 -4
- package/esm2020/legacy-table/table.mjs +6 -6
- package/esm2020/legacy-table/text-column.mjs +3 -3
- package/esm2020/legacy-tabs/ink-bar.mjs +3 -3
- package/esm2020/legacy-tabs/tab-body.mjs +6 -6
- package/esm2020/legacy-tabs/tab-content.mjs +3 -3
- package/esm2020/legacy-tabs/tab-group.mjs +3 -3
- package/esm2020/legacy-tabs/tab-header.mjs +3 -3
- package/esm2020/legacy-tabs/tab-label-wrapper.mjs +3 -3
- package/esm2020/legacy-tabs/tab-label.mjs +3 -3
- package/esm2020/legacy-tabs/tab-nav-bar/tab-nav-bar.mjs +9 -9
- package/esm2020/legacy-tabs/tab.mjs +3 -3
- package/esm2020/legacy-tabs/tabs-module.mjs +4 -4
- package/esm2020/legacy-tooltip/tooltip-module.mjs +4 -4
- package/esm2020/legacy-tooltip/tooltip.mjs +6 -6
- package/esm2020/list/action-list.mjs +3 -3
- package/esm2020/list/list-base.mjs +6 -6
- package/esm2020/list/list-item-sections.mjs +18 -18
- package/esm2020/list/list-module.mjs +4 -4
- package/esm2020/list/list-option.mjs +3 -3
- package/esm2020/list/list.mjs +6 -6
- package/esm2020/list/nav-list.mjs +3 -3
- package/esm2020/list/selection-list.mjs +16 -6
- package/esm2020/list/subheader.mjs +3 -3
- package/esm2020/menu/menu-content.mjs +6 -6
- package/esm2020/menu/menu-item.mjs +3 -3
- package/esm2020/menu/menu-trigger.mjs +6 -6
- package/esm2020/menu/menu.mjs +6 -6
- package/esm2020/menu/module.mjs +4 -4
- package/esm2020/paginator/module.mjs +4 -4
- package/esm2020/paginator/paginator-intl.mjs +3 -3
- package/esm2020/paginator/paginator.mjs +6 -6
- package/esm2020/progress-bar/module.mjs +4 -4
- package/esm2020/progress-bar/progress-bar.mjs +3 -3
- package/esm2020/progress-spinner/module.mjs +4 -4
- package/esm2020/progress-spinner/progress-spinner.mjs +3 -3
- package/esm2020/radio/module.mjs +4 -4
- package/esm2020/radio/radio.mjs +12 -12
- package/esm2020/select/module.mjs +4 -4
- package/esm2020/select/select.mjs +9 -9
- package/esm2020/sidenav/drawer.mjs +9 -9
- package/esm2020/sidenav/sidenav-module.mjs +4 -4
- package/esm2020/sidenav/sidenav.mjs +9 -9
- package/esm2020/slide-toggle/module.mjs +8 -8
- package/esm2020/slide-toggle/slide-toggle-required-validator.mjs +3 -3
- package/esm2020/slide-toggle/slide-toggle.mjs +7 -7
- package/esm2020/slider/module.mjs +10 -8
- package/esm2020/slider/public-api.mjs +4 -2
- package/esm2020/slider/slider-input.mjs +611 -0
- package/esm2020/slider/slider-interface.mjs +34 -0
- package/esm2020/slider/slider-thumb.mjs +229 -0
- package/esm2020/slider/slider.mjs +523 -925
- package/esm2020/snack-bar/module.mjs +4 -4
- package/esm2020/snack-bar/simple-snack-bar.mjs +3 -3
- package/esm2020/snack-bar/snack-bar-container.mjs +8 -8
- package/esm2020/snack-bar/snack-bar-content.mjs +9 -9
- package/esm2020/snack-bar/snack-bar.mjs +6 -6
- package/esm2020/sort/sort-header-intl.mjs +3 -3
- package/esm2020/sort/sort-header.mjs +3 -3
- package/esm2020/sort/sort-module.mjs +4 -4
- package/esm2020/sort/sort.mjs +3 -3
- package/esm2020/stepper/step-content.mjs +3 -3
- package/esm2020/stepper/step-header.mjs +4 -4
- package/esm2020/stepper/step-label.mjs +3 -3
- package/esm2020/stepper/stepper-button.mjs +6 -6
- package/esm2020/stepper/stepper-icon.mjs +3 -3
- package/esm2020/stepper/stepper-intl.mjs +3 -3
- package/esm2020/stepper/stepper-module.mjs +4 -4
- package/esm2020/stepper/stepper.mjs +8 -8
- package/esm2020/table/cell.mjs +21 -21
- package/esm2020/table/module.mjs +4 -4
- package/esm2020/table/row.mjs +21 -21
- package/esm2020/table/table.mjs +8 -8
- package/esm2020/table/text-column.mjs +3 -3
- package/esm2020/tabs/module.mjs +4 -4
- package/esm2020/tabs/paginated-tab-header.mjs +3 -3
- package/esm2020/tabs/tab-body.mjs +9 -9
- package/esm2020/tabs/tab-content.mjs +3 -3
- package/esm2020/tabs/tab-group.mjs +6 -6
- package/esm2020/tabs/tab-header.mjs +7 -7
- package/esm2020/tabs/tab-label-wrapper.mjs +6 -6
- package/esm2020/tabs/tab-label.mjs +3 -3
- package/esm2020/tabs/tab-nav-bar/tab-nav-bar.mjs +106 -106
- package/esm2020/tabs/tab.mjs +6 -6
- package/esm2020/toolbar/toolbar-module.mjs +4 -4
- package/esm2020/toolbar/toolbar.mjs +6 -6
- package/esm2020/tooltip/module.mjs +4 -4
- package/esm2020/tooltip/tooltip.mjs +12 -12
- package/esm2020/tree/node.mjs +9 -9
- package/esm2020/tree/outlet.mjs +3 -3
- package/esm2020/tree/padding.mjs +3 -3
- package/esm2020/tree/toggle.mjs +3 -3
- package/esm2020/tree/tree-module.mjs +4 -4
- package/esm2020/tree/tree.mjs +3 -3
- package/fesm2015/autocomplete.mjs +22 -22
- package/fesm2015/badge.mjs +7 -7
- package/fesm2015/bottom-sheet.mjs +10 -10
- package/fesm2015/button-toggle.mjs +10 -10
- package/fesm2015/button.mjs +40 -40
- package/fesm2015/button.mjs.map +1 -1
- package/fesm2015/card.mjs +46 -46
- package/fesm2015/checkbox.mjs +17 -17
- package/fesm2015/chips.mjs +46 -52
- package/fesm2015/chips.mjs.map +1 -1
- package/fesm2015/core.mjs +59 -59
- package/fesm2015/core.mjs.map +1 -1
- package/fesm2015/datepicker.mjs +84 -84
- package/fesm2015/datepicker.mjs.map +1 -1
- package/fesm2015/dialog.mjs +29 -29
- package/fesm2015/dialog.mjs.map +1 -1
- package/fesm2015/divider.mjs +7 -7
- package/fesm2015/expansion.mjs +25 -25
- package/fesm2015/form-field.mjs +34 -34
- package/fesm2015/grid-list.mjs +22 -22
- package/fesm2015/icon/testing.mjs +7 -7
- package/fesm2015/icon.mjs +10 -10
- package/fesm2015/input.mjs +7 -7
- package/fesm2015/legacy-autocomplete.mjs +13 -13
- package/fesm2015/legacy-button.mjs +10 -10
- package/fesm2015/legacy-card.mjs +46 -46
- package/fesm2015/legacy-checkbox.mjs +7 -7
- package/fesm2015/legacy-chips.mjs +22 -22
- package/fesm2015/legacy-core.mjs +10 -10
- package/fesm2015/legacy-dialog.mjs +22 -22
- package/fesm2015/legacy-form-field.mjs +25 -25
- package/fesm2015/legacy-input.mjs +7 -7
- package/fesm2015/legacy-list.mjs +28 -28
- package/fesm2015/legacy-menu.mjs +16 -16
- package/fesm2015/legacy-paginator.mjs +7 -7
- package/fesm2015/legacy-progress-bar.mjs +7 -7
- package/fesm2015/legacy-progress-spinner.mjs +7 -7
- package/fesm2015/legacy-radio.mjs +10 -10
- package/fesm2015/legacy-select.mjs +10 -10
- package/fesm2015/legacy-slide-toggle.mjs +7 -7
- package/fesm2015/legacy-slider.mjs +7 -7
- package/fesm2015/legacy-snack-bar.mjs +13 -13
- package/fesm2015/legacy-table.mjs +55 -55
- package/fesm2015/legacy-tabs.mjs +40 -40
- package/fesm2015/legacy-tooltip.mjs +10 -10
- package/fesm2015/list.mjs +61 -51
- package/fesm2015/list.mjs.map +1 -1
- package/fesm2015/menu.mjs +25 -25
- package/fesm2015/paginator.mjs +13 -13
- package/fesm2015/progress-bar.mjs +7 -7
- package/fesm2015/progress-spinner.mjs +7 -7
- package/fesm2015/radio.mjs +16 -16
- package/fesm2015/select.mjs +13 -13
- package/fesm2015/sidenav.mjs +22 -22
- package/fesm2015/slide-toggle.mjs +18 -18
- package/fesm2015/slide-toggle.mjs.map +1 -1
- package/fesm2015/slider.mjs +1300 -902
- package/fesm2015/slider.mjs.map +1 -1
- package/fesm2015/snack-bar.mjs +29 -29
- package/fesm2015/snack-bar.mjs.map +1 -1
- package/fesm2015/sort.mjs +13 -13
- package/fesm2015/stepper.mjs +33 -33
- package/fesm2015/stepper.mjs.map +1 -1
- package/fesm2015/table.mjs +57 -57
- package/fesm2015/table.mjs.map +1 -1
- package/fesm2015/tabs.mjs +161 -161
- package/fesm2015/tabs.mjs.map +1 -1
- package/fesm2015/toolbar.mjs +10 -10
- package/fesm2015/tooltip.mjs +16 -16
- package/fesm2015/tree.mjs +25 -25
- package/fesm2020/autocomplete.mjs +22 -22
- package/fesm2020/badge.mjs +7 -7
- package/fesm2020/bottom-sheet.mjs +10 -10
- package/fesm2020/button-toggle.mjs +10 -10
- package/fesm2020/button.mjs +40 -40
- package/fesm2020/button.mjs.map +1 -1
- package/fesm2020/card.mjs +46 -46
- package/fesm2020/checkbox.mjs +17 -17
- package/fesm2020/chips.mjs +46 -52
- package/fesm2020/chips.mjs.map +1 -1
- package/fesm2020/core.mjs +59 -59
- package/fesm2020/core.mjs.map +1 -1
- package/fesm2020/datepicker.mjs +84 -84
- package/fesm2020/datepicker.mjs.map +1 -1
- package/fesm2020/dialog.mjs +29 -29
- package/fesm2020/dialog.mjs.map +1 -1
- package/fesm2020/divider.mjs +7 -7
- package/fesm2020/expansion.mjs +25 -25
- package/fesm2020/form-field.mjs +34 -34
- package/fesm2020/grid-list.mjs +22 -22
- package/fesm2020/icon/testing.mjs +7 -7
- package/fesm2020/icon.mjs +10 -10
- package/fesm2020/input.mjs +7 -7
- package/fesm2020/legacy-autocomplete.mjs +13 -13
- package/fesm2020/legacy-button.mjs +10 -10
- package/fesm2020/legacy-card.mjs +46 -46
- package/fesm2020/legacy-checkbox.mjs +7 -7
- package/fesm2020/legacy-chips.mjs +22 -22
- package/fesm2020/legacy-core.mjs +10 -10
- package/fesm2020/legacy-dialog.mjs +22 -22
- package/fesm2020/legacy-form-field.mjs +25 -25
- package/fesm2020/legacy-input.mjs +7 -7
- package/fesm2020/legacy-list.mjs +28 -28
- package/fesm2020/legacy-menu.mjs +16 -16
- package/fesm2020/legacy-paginator.mjs +7 -7
- package/fesm2020/legacy-progress-bar.mjs +7 -7
- package/fesm2020/legacy-progress-spinner.mjs +7 -7
- package/fesm2020/legacy-radio.mjs +10 -10
- package/fesm2020/legacy-select.mjs +10 -10
- package/fesm2020/legacy-slide-toggle.mjs +7 -7
- package/fesm2020/legacy-slider.mjs +7 -7
- package/fesm2020/legacy-snack-bar.mjs +13 -13
- package/fesm2020/legacy-table.mjs +55 -55
- package/fesm2020/legacy-tabs.mjs +40 -40
- package/fesm2020/legacy-tooltip.mjs +10 -10
- package/fesm2020/list.mjs +61 -51
- package/fesm2020/list.mjs.map +1 -1
- package/fesm2020/menu.mjs +25 -25
- package/fesm2020/paginator.mjs +13 -13
- package/fesm2020/progress-bar.mjs +7 -7
- package/fesm2020/progress-spinner.mjs +7 -7
- package/fesm2020/radio.mjs +16 -16
- package/fesm2020/select.mjs +13 -13
- package/fesm2020/sidenav.mjs +22 -22
- package/fesm2020/slide-toggle.mjs +18 -18
- package/fesm2020/slide-toggle.mjs.map +1 -1
- package/fesm2020/slider.mjs +1289 -882
- package/fesm2020/slider.mjs.map +1 -1
- package/fesm2020/snack-bar.mjs +29 -29
- package/fesm2020/snack-bar.mjs.map +1 -1
- package/fesm2020/sort.mjs +13 -13
- package/fesm2020/stepper.mjs +33 -33
- package/fesm2020/stepper.mjs.map +1 -1
- package/fesm2020/table.mjs +57 -57
- package/fesm2020/table.mjs.map +1 -1
- package/fesm2020/tabs.mjs +159 -159
- package/fesm2020/tabs.mjs.map +1 -1
- package/fesm2020/toolbar.mjs +10 -10
- package/fesm2020/tooltip.mjs +16 -16
- package/fesm2020/tree.mjs +25 -25
- package/legacy-core/density/private/_all-density.scss +10 -2
- package/legacy-core/theming/_all-theme.scss +29 -2
- package/legacy-core/typography/_all-typography.scss +31 -2
- package/legacy-prebuilt-themes/legacy-deeppurple-amber.css +1 -1
- package/legacy-prebuilt-themes/legacy-indigo-pink.css +1 -1
- package/legacy-prebuilt-themes/legacy-pink-bluegrey.css +1 -1
- package/legacy-prebuilt-themes/legacy-purple-green.css +1 -1
- package/list/index.d.ts +4 -1
- package/package.json +49 -49
- package/prebuilt-themes/deeppurple-amber.css +1 -1
- package/prebuilt-themes/indigo-pink.css +1 -1
- package/prebuilt-themes/pink-bluegrey.css +1 -1
- package/prebuilt-themes/purple-green.css +1 -1
- package/radio/_radio-theme.scss +1 -1
- package/schematics/ng-add/index.js +1 -1
- package/schematics/ng-add/index.mjs +1 -1
- package/schematics/ng-generate/mdc-migration/index_bundled.js +320 -47
- package/schematics/ng-generate/mdc-migration/index_bundled.js.map +3 -3
- package/schematics/ng-generate/mdc-migration/mdc_migration_bundle_metadata.json +1 -1
- package/schematics/ng-update/index_bundled.js +2 -1
- package/schematics/ng-update/index_bundled.js.map +2 -2
- package/schematics/ng-update/ng_update_index_metadata.json +1 -1
- package/slider/index.d.ts +443 -235
- package/tabs/index.d.ts +1 -1
- package/esm2020/slider/global-change-and-input-listener.mjs +0 -59
|
@@ -0,0 +1,611 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright Google LLC All Rights Reserved.
|
|
4
|
+
*
|
|
5
|
+
* Use of this source code is governed by an MIT-style license that can be
|
|
6
|
+
* found in the LICENSE file at https://angular.io/license
|
|
7
|
+
*/
|
|
8
|
+
import { coerceBooleanProperty, coerceNumberProperty, } from '@angular/cdk/coercion';
|
|
9
|
+
import { ChangeDetectorRef, Directive, ElementRef, EventEmitter, forwardRef, Inject, Input, NgZone, Output, } from '@angular/core';
|
|
10
|
+
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
11
|
+
import { Subject } from 'rxjs';
|
|
12
|
+
import { MAT_SLIDER_RANGE_THUMB, MAT_SLIDER_THUMB, MAT_SLIDER, } from './slider-interface';
|
|
13
|
+
import * as i0 from "@angular/core";
|
|
14
|
+
/**
|
|
15
|
+
* Provider that allows the slider thumb to register as a ControlValueAccessor.
|
|
16
|
+
* @docs-private
|
|
17
|
+
*/
|
|
18
|
+
export const MAT_SLIDER_THUMB_VALUE_ACCESSOR = {
|
|
19
|
+
provide: NG_VALUE_ACCESSOR,
|
|
20
|
+
useExisting: forwardRef(() => MatSliderThumb),
|
|
21
|
+
multi: true,
|
|
22
|
+
};
|
|
23
|
+
/**
|
|
24
|
+
* Provider that allows the range slider thumb to register as a ControlValueAccessor.
|
|
25
|
+
* @docs-private
|
|
26
|
+
*/
|
|
27
|
+
export const MAT_SLIDER_RANGE_THUMB_VALUE_ACCESSOR = {
|
|
28
|
+
provide: NG_VALUE_ACCESSOR,
|
|
29
|
+
useExisting: forwardRef(() => MatSliderRangeThumb),
|
|
30
|
+
multi: true,
|
|
31
|
+
};
|
|
32
|
+
/**
|
|
33
|
+
* Directive that adds slider-specific behaviors to an input element inside `<mat-slider>`.
|
|
34
|
+
* Up to two may be placed inside of a `<mat-slider>`.
|
|
35
|
+
*
|
|
36
|
+
* If one is used, the selector `matSliderThumb` must be used, and the outcome will be a normal
|
|
37
|
+
* slider. If two are used, the selectors `matSliderStartThumb` and `matSliderEndThumb` must be
|
|
38
|
+
* used, and the outcome will be a range slider with two slider thumbs.
|
|
39
|
+
*/
|
|
40
|
+
export class MatSliderThumb {
|
|
41
|
+
constructor(_ngZone, _elementRef, _cdr, _slider) {
|
|
42
|
+
this._ngZone = _ngZone;
|
|
43
|
+
this._elementRef = _elementRef;
|
|
44
|
+
this._cdr = _cdr;
|
|
45
|
+
this._slider = _slider;
|
|
46
|
+
this.valueChange = new EventEmitter();
|
|
47
|
+
/** Event emitted when the slider thumb starts being dragged. */
|
|
48
|
+
this.dragStart = new EventEmitter();
|
|
49
|
+
/** Event emitted when the slider thumb stops being dragged. */
|
|
50
|
+
this.dragEnd = new EventEmitter();
|
|
51
|
+
/** Indicates whether this thumb is the start or end thumb. */
|
|
52
|
+
this.thumbPosition = 2 /* _MatThumb.END */;
|
|
53
|
+
/** The radius of a native html slider's knob. */
|
|
54
|
+
this._knobRadius = 8;
|
|
55
|
+
/** Whether user's cursor is currently in a mouse down state on the input. */
|
|
56
|
+
this._isActive = false;
|
|
57
|
+
/** Whether the input is currently focused (either by tab or after clicking). */
|
|
58
|
+
this._isFocused = false;
|
|
59
|
+
/**
|
|
60
|
+
* Whether the initial value has been set.
|
|
61
|
+
* This exists because the initial value cannot be immediately set because the min and max
|
|
62
|
+
* must first be relayed from the parent MatSlider component, which can only happen later
|
|
63
|
+
* in the component lifecycle.
|
|
64
|
+
*/
|
|
65
|
+
this._hasSetInitialValue = false;
|
|
66
|
+
/** Emits when the component is destroyed. */
|
|
67
|
+
this._destroyed = new Subject();
|
|
68
|
+
/**
|
|
69
|
+
* Indicates whether UI updates should be skipped.
|
|
70
|
+
*
|
|
71
|
+
* This flag is used to avoid flickering
|
|
72
|
+
* when correcting values on pointer up/down.
|
|
73
|
+
*/
|
|
74
|
+
this._skipUIUpdate = false;
|
|
75
|
+
/** Callback called when the slider input value changes. */
|
|
76
|
+
this._onChangeFn = () => { };
|
|
77
|
+
/** Callback called when the slider input has been touched. */
|
|
78
|
+
this._onTouchedFn = () => { };
|
|
79
|
+
this._hostElement = _elementRef.nativeElement;
|
|
80
|
+
this._ngZone.runOutsideAngular(() => {
|
|
81
|
+
this._hostElement.addEventListener('pointerdown', this._onPointerDown.bind(this));
|
|
82
|
+
this._hostElement.addEventListener('pointermove', this._onPointerMove.bind(this));
|
|
83
|
+
this._hostElement.addEventListener('pointerup', this._onPointerUp.bind(this));
|
|
84
|
+
});
|
|
85
|
+
}
|
|
86
|
+
get value() {
|
|
87
|
+
return coerceNumberProperty(this._hostElement.value);
|
|
88
|
+
}
|
|
89
|
+
set value(v) {
|
|
90
|
+
const val = coerceNumberProperty(v).toString();
|
|
91
|
+
if (!this._hasSetInitialValue) {
|
|
92
|
+
this._initialValue = val;
|
|
93
|
+
return;
|
|
94
|
+
}
|
|
95
|
+
if (this._isActive) {
|
|
96
|
+
return;
|
|
97
|
+
}
|
|
98
|
+
this._hostElement.value = val;
|
|
99
|
+
this._updateThumbUIByValue();
|
|
100
|
+
this._slider._onValueChange(this);
|
|
101
|
+
this._cdr.detectChanges();
|
|
102
|
+
}
|
|
103
|
+
/** The current translateX in px of the slider visual thumb. */
|
|
104
|
+
get translateX() {
|
|
105
|
+
if (this._slider.min >= this._slider.max) {
|
|
106
|
+
this._translateX = 0;
|
|
107
|
+
return this._translateX;
|
|
108
|
+
}
|
|
109
|
+
if (this._translateX === undefined) {
|
|
110
|
+
this._translateX = this._calcTranslateXByValue();
|
|
111
|
+
}
|
|
112
|
+
return this._translateX;
|
|
113
|
+
}
|
|
114
|
+
set translateX(v) {
|
|
115
|
+
this._translateX = v;
|
|
116
|
+
}
|
|
117
|
+
get min() {
|
|
118
|
+
return coerceNumberProperty(this._hostElement.min);
|
|
119
|
+
}
|
|
120
|
+
set min(v) {
|
|
121
|
+
this._hostElement.min = coerceNumberProperty(v).toString();
|
|
122
|
+
this._cdr.detectChanges();
|
|
123
|
+
}
|
|
124
|
+
get max() {
|
|
125
|
+
return coerceNumberProperty(this._hostElement.max);
|
|
126
|
+
}
|
|
127
|
+
set max(v) {
|
|
128
|
+
this._hostElement.max = coerceNumberProperty(v).toString();
|
|
129
|
+
this._cdr.detectChanges();
|
|
130
|
+
}
|
|
131
|
+
get step() {
|
|
132
|
+
return coerceNumberProperty(this._hostElement.step);
|
|
133
|
+
}
|
|
134
|
+
set step(v) {
|
|
135
|
+
this._hostElement.step = coerceNumberProperty(v).toString();
|
|
136
|
+
this._cdr.detectChanges();
|
|
137
|
+
}
|
|
138
|
+
get disabled() {
|
|
139
|
+
return coerceBooleanProperty(this._hostElement.disabled);
|
|
140
|
+
}
|
|
141
|
+
set disabled(v) {
|
|
142
|
+
this._hostElement.disabled = coerceBooleanProperty(v);
|
|
143
|
+
this._cdr.detectChanges();
|
|
144
|
+
if (this._slider.disabled !== this.disabled) {
|
|
145
|
+
this._slider.disabled = this.disabled;
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
get percentage() {
|
|
149
|
+
if (this._slider.min >= this._slider.max) {
|
|
150
|
+
return this._slider._isRtl ? 1 : 0;
|
|
151
|
+
}
|
|
152
|
+
return (this.value - this._slider.min) / (this._slider.max - this._slider.min);
|
|
153
|
+
}
|
|
154
|
+
get fillPercentage() {
|
|
155
|
+
if (!this._slider._cachedWidth) {
|
|
156
|
+
return this._slider._isRtl ? 1 : 0;
|
|
157
|
+
}
|
|
158
|
+
if (this._translateX === 0) {
|
|
159
|
+
return 0;
|
|
160
|
+
}
|
|
161
|
+
return this.translateX / this._slider._cachedWidth;
|
|
162
|
+
}
|
|
163
|
+
/** Used to relay updates to _isFocused to the slider visual thumbs. */
|
|
164
|
+
_setIsFocused(v) {
|
|
165
|
+
this._isFocused = v;
|
|
166
|
+
}
|
|
167
|
+
ngOnDestroy() {
|
|
168
|
+
this._hostElement.removeEventListener('pointerdown', this._onPointerDown);
|
|
169
|
+
this._hostElement.removeEventListener('pointermove', this._onPointerMove);
|
|
170
|
+
this._hostElement.removeEventListener('pointerup', this._onPointerUp);
|
|
171
|
+
this._destroyed.next();
|
|
172
|
+
this._destroyed.complete();
|
|
173
|
+
this.dragStart.complete();
|
|
174
|
+
this.dragEnd.complete();
|
|
175
|
+
}
|
|
176
|
+
initProps() {
|
|
177
|
+
this._updateWidthInactive();
|
|
178
|
+
this.disabled = this._slider.disabled;
|
|
179
|
+
this.step = this._slider.step;
|
|
180
|
+
this.min = this._slider.min;
|
|
181
|
+
this.max = this._slider.max;
|
|
182
|
+
this._initValue();
|
|
183
|
+
}
|
|
184
|
+
initUI() {
|
|
185
|
+
this._updateThumbUIByValue();
|
|
186
|
+
}
|
|
187
|
+
_initValue() {
|
|
188
|
+
this._hasSetInitialValue = true;
|
|
189
|
+
if (this._initialValue === undefined) {
|
|
190
|
+
this.value = this._getDefaultValue();
|
|
191
|
+
}
|
|
192
|
+
else {
|
|
193
|
+
this._hostElement.value = this._initialValue;
|
|
194
|
+
this._updateThumbUIByValue();
|
|
195
|
+
this._slider._onValueChange(this);
|
|
196
|
+
this._cdr.detectChanges();
|
|
197
|
+
}
|
|
198
|
+
}
|
|
199
|
+
_getDefaultValue() {
|
|
200
|
+
return this.min;
|
|
201
|
+
}
|
|
202
|
+
_onBlur() {
|
|
203
|
+
this._setIsFocused(false);
|
|
204
|
+
this._onTouchedFn();
|
|
205
|
+
}
|
|
206
|
+
_onFocus() {
|
|
207
|
+
this._setIsFocused(true);
|
|
208
|
+
}
|
|
209
|
+
_onChange() {
|
|
210
|
+
// only used to handle the edge case where user
|
|
211
|
+
// mousedown on the slider then uses arrow keys.
|
|
212
|
+
if (this._isActive) {
|
|
213
|
+
this._updateThumbUIByValue({ withAnimation: true });
|
|
214
|
+
}
|
|
215
|
+
}
|
|
216
|
+
_onInput() {
|
|
217
|
+
this.valueChange.emit(this.value);
|
|
218
|
+
this._onChangeFn(this.value);
|
|
219
|
+
// handles arrowing and updating the value when
|
|
220
|
+
// a step is defined.
|
|
221
|
+
if (this._slider.step || !this._isActive) {
|
|
222
|
+
this._updateThumbUIByValue({ withAnimation: true });
|
|
223
|
+
}
|
|
224
|
+
this._slider._onValueChange(this);
|
|
225
|
+
}
|
|
226
|
+
_onNgControlValueChange() {
|
|
227
|
+
// only used to handle when the value change
|
|
228
|
+
// originates outside of the slider.
|
|
229
|
+
if (!this._isActive || !this._isFocused) {
|
|
230
|
+
this._slider._onValueChange(this);
|
|
231
|
+
this._updateThumbUIByValue();
|
|
232
|
+
}
|
|
233
|
+
this._slider.disabled = this._formControl.disabled;
|
|
234
|
+
}
|
|
235
|
+
_onPointerDown(event) {
|
|
236
|
+
if (this.disabled || event.button !== 0) {
|
|
237
|
+
return;
|
|
238
|
+
}
|
|
239
|
+
this._isActive = true;
|
|
240
|
+
this._setIsFocused(true);
|
|
241
|
+
this._updateWidthActive();
|
|
242
|
+
this._slider._updateDimensions();
|
|
243
|
+
// Does nothing if a step is defined because we
|
|
244
|
+
// want the value to snap to the values on input.
|
|
245
|
+
if (!this._slider.step) {
|
|
246
|
+
this._updateThumbUIByPointerEvent(event, { withAnimation: true });
|
|
247
|
+
}
|
|
248
|
+
if (!this.disabled) {
|
|
249
|
+
this._handleValueCorrection(event);
|
|
250
|
+
}
|
|
251
|
+
}
|
|
252
|
+
/**
|
|
253
|
+
* Corrects the value of the slider on pointer up/down.
|
|
254
|
+
*
|
|
255
|
+
* Called on pointer down and up because the value is set based
|
|
256
|
+
* on the inactive width instead of the active width.
|
|
257
|
+
*/
|
|
258
|
+
_handleValueCorrection(event) {
|
|
259
|
+
// Don't update the UI with the current value! The value on pointerdown
|
|
260
|
+
// and pointerup is calculated in the split second before the input(s)
|
|
261
|
+
// resize. See _updateWidthInactive() and _updateWidthActive() for more
|
|
262
|
+
// details.
|
|
263
|
+
this._skipUIUpdate = true;
|
|
264
|
+
// Note that this function gets triggered before the actual value of the
|
|
265
|
+
// slider is updated. This means if we were to set the value here, it
|
|
266
|
+
// would immediately be overwritten. Using setTimeout ensures the setting
|
|
267
|
+
// of the value happens after the value has been updated by the
|
|
268
|
+
// pointerdown event.
|
|
269
|
+
setTimeout(() => {
|
|
270
|
+
this._skipUIUpdate = false;
|
|
271
|
+
this._fixValue(event);
|
|
272
|
+
}, 0);
|
|
273
|
+
}
|
|
274
|
+
/** Corrects the value of the slider based on the pointer event's position. */
|
|
275
|
+
_fixValue(event) {
|
|
276
|
+
const xPos = event.clientX - this._slider._cachedLeft;
|
|
277
|
+
const width = this._slider._cachedWidth;
|
|
278
|
+
const step = this._slider.step === 0 ? 1 : this._slider.step;
|
|
279
|
+
const numSteps = Math.floor((this._slider.max - this._slider.min) / step);
|
|
280
|
+
const percentage = this._slider._isRtl ? 1 - xPos / width : xPos / width;
|
|
281
|
+
// To ensure the percentage is rounded to the necessary number of decimals.
|
|
282
|
+
const fixedPercentage = Math.round(percentage * numSteps) / numSteps;
|
|
283
|
+
const impreciseValue = fixedPercentage * (this._slider.max - this._slider.min) + this._slider.min;
|
|
284
|
+
const value = Math.round(impreciseValue / step) * step;
|
|
285
|
+
const prevValue = this.value;
|
|
286
|
+
const dragEvent = { source: this, parent: this._slider, value: value };
|
|
287
|
+
this._isActive ? this.dragStart.emit(dragEvent) : this.dragEnd.emit(dragEvent);
|
|
288
|
+
if (value === prevValue) {
|
|
289
|
+
// Because we prevented UI updates, if it turns out that the race
|
|
290
|
+
// condition didn't happen and the value is already correct, we
|
|
291
|
+
// have to apply the ui updates now.
|
|
292
|
+
this._slider._onValueChange(this);
|
|
293
|
+
this._slider.step > 0
|
|
294
|
+
? this._updateThumbUIByValue()
|
|
295
|
+
: this._updateThumbUIByPointerEvent(event, { withAnimation: this._slider._hasAnimation });
|
|
296
|
+
return;
|
|
297
|
+
}
|
|
298
|
+
this.value = value;
|
|
299
|
+
this.valueChange.emit(this.value);
|
|
300
|
+
this._onChangeFn(this.value);
|
|
301
|
+
this._slider._onValueChange(this);
|
|
302
|
+
this._slider.step > 0
|
|
303
|
+
? this._updateThumbUIByValue()
|
|
304
|
+
: this._updateThumbUIByPointerEvent(event, { withAnimation: this._slider._hasAnimation });
|
|
305
|
+
}
|
|
306
|
+
_onPointerMove(event) {
|
|
307
|
+
// Again, does nothing if a step is defined because
|
|
308
|
+
// we want the value to snap to the values on input.
|
|
309
|
+
if (!this._slider.step && this._isActive) {
|
|
310
|
+
this._updateThumbUIByPointerEvent(event);
|
|
311
|
+
}
|
|
312
|
+
}
|
|
313
|
+
_onPointerUp(event) {
|
|
314
|
+
this._isActive = false;
|
|
315
|
+
this._updateWidthInactive();
|
|
316
|
+
if (!this.disabled) {
|
|
317
|
+
this._handleValueCorrection(event);
|
|
318
|
+
}
|
|
319
|
+
}
|
|
320
|
+
_clamp(v) {
|
|
321
|
+
return Math.max(Math.min(v, this._slider._cachedWidth), 0);
|
|
322
|
+
}
|
|
323
|
+
_calcTranslateXByValue() {
|
|
324
|
+
if (this._slider._isRtl) {
|
|
325
|
+
return (1 - this.percentage) * this._slider._cachedWidth;
|
|
326
|
+
}
|
|
327
|
+
return this.percentage * this._slider._cachedWidth;
|
|
328
|
+
}
|
|
329
|
+
_calcTranslateXByPointerEvent(event) {
|
|
330
|
+
return event.clientX - this._slider._cachedLeft;
|
|
331
|
+
}
|
|
332
|
+
/**
|
|
333
|
+
* Used to set the slider width to the correct
|
|
334
|
+
* dimensions while the user is dragging.
|
|
335
|
+
*/
|
|
336
|
+
_updateWidthActive() {
|
|
337
|
+
this._hostElement.style.padding = `0 ${this._slider._inputPadding}px`;
|
|
338
|
+
this._hostElement.style.width = `calc(100% + ${this._slider._inputPadding}px)`;
|
|
339
|
+
}
|
|
340
|
+
/**
|
|
341
|
+
* Sets the slider input to disproportionate dimensions to allow for touch
|
|
342
|
+
* events to be captured on touch devices.
|
|
343
|
+
*/
|
|
344
|
+
_updateWidthInactive() {
|
|
345
|
+
this._hostElement.style.padding = '0px';
|
|
346
|
+
this._hostElement.style.width = 'calc(100% + 48px)';
|
|
347
|
+
this._hostElement.style.left = '-24px';
|
|
348
|
+
}
|
|
349
|
+
_updateThumbUIByValue(options) {
|
|
350
|
+
this.translateX = this._clamp(this._calcTranslateXByValue());
|
|
351
|
+
this._updateThumbUI(options);
|
|
352
|
+
}
|
|
353
|
+
_updateThumbUIByPointerEvent(event, options) {
|
|
354
|
+
this.translateX = this._clamp(this._calcTranslateXByPointerEvent(event));
|
|
355
|
+
this._updateThumbUI(options);
|
|
356
|
+
}
|
|
357
|
+
_updateThumbUI(options) {
|
|
358
|
+
this._slider._setTransition(!!options?.withAnimation);
|
|
359
|
+
this._slider._onTranslateXChange(this);
|
|
360
|
+
}
|
|
361
|
+
/**
|
|
362
|
+
* Sets the input's value.
|
|
363
|
+
* @param value The new value of the input
|
|
364
|
+
* @docs-private
|
|
365
|
+
*/
|
|
366
|
+
writeValue(value) {
|
|
367
|
+
this.value = value;
|
|
368
|
+
}
|
|
369
|
+
/**
|
|
370
|
+
* Registers a callback to be invoked when the input's value changes from user input.
|
|
371
|
+
* @param fn The callback to register
|
|
372
|
+
* @docs-private
|
|
373
|
+
*/
|
|
374
|
+
registerOnChange(fn) {
|
|
375
|
+
this._onChangeFn = fn;
|
|
376
|
+
}
|
|
377
|
+
/**
|
|
378
|
+
* Registers a callback to be invoked when the input is blurred by the user.
|
|
379
|
+
* @param fn The callback to register
|
|
380
|
+
* @docs-private
|
|
381
|
+
*/
|
|
382
|
+
registerOnTouched(fn) {
|
|
383
|
+
this._onTouchedFn = fn;
|
|
384
|
+
}
|
|
385
|
+
/**
|
|
386
|
+
* Sets the disabled state of the slider.
|
|
387
|
+
* @param isDisabled The new disabled state
|
|
388
|
+
* @docs-private
|
|
389
|
+
*/
|
|
390
|
+
setDisabledState(isDisabled) {
|
|
391
|
+
this.disabled = isDisabled;
|
|
392
|
+
}
|
|
393
|
+
focus() {
|
|
394
|
+
this._hostElement.focus();
|
|
395
|
+
}
|
|
396
|
+
blur() {
|
|
397
|
+
this._hostElement.blur();
|
|
398
|
+
}
|
|
399
|
+
}
|
|
400
|
+
MatSliderThumb.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.0-rc.1", ngImport: i0, type: MatSliderThumb, deps: [{ token: i0.NgZone }, { token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: MAT_SLIDER }], target: i0.ɵɵFactoryTarget.Directive });
|
|
401
|
+
MatSliderThumb.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.0.0-rc.1", type: MatSliderThumb, selector: "input[matSliderThumb]", inputs: { value: "value" }, outputs: { valueChange: "valueChange", dragStart: "dragStart", dragEnd: "dragEnd" }, host: { attributes: { "type": "range" }, listeners: { "change": "_onChange()", "input": "_onInput()", "blur": "_onBlur()", "focus": "_onFocus()" }, properties: { "attr.aria-valuetext": "_valuetext" }, classAttribute: "mdc-slider__input" }, providers: [
|
|
402
|
+
MAT_SLIDER_THUMB_VALUE_ACCESSOR,
|
|
403
|
+
{ provide: MAT_SLIDER_THUMB, useExisting: MatSliderThumb },
|
|
404
|
+
], exportAs: ["matSliderThumb"], ngImport: i0 });
|
|
405
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.0-rc.1", ngImport: i0, type: MatSliderThumb, decorators: [{
|
|
406
|
+
type: Directive,
|
|
407
|
+
args: [{
|
|
408
|
+
selector: 'input[matSliderThumb]',
|
|
409
|
+
exportAs: 'matSliderThumb',
|
|
410
|
+
host: {
|
|
411
|
+
'class': 'mdc-slider__input',
|
|
412
|
+
'type': 'range',
|
|
413
|
+
'[attr.aria-valuetext]': '_valuetext',
|
|
414
|
+
'(change)': '_onChange()',
|
|
415
|
+
'(input)': '_onInput()',
|
|
416
|
+
// TODO(wagnermaciel): Consider using a global event listener instead.
|
|
417
|
+
// Reason: I have found a semi-consistent way to mouse up without triggering this event.
|
|
418
|
+
'(blur)': '_onBlur()',
|
|
419
|
+
'(focus)': '_onFocus()',
|
|
420
|
+
},
|
|
421
|
+
providers: [
|
|
422
|
+
MAT_SLIDER_THUMB_VALUE_ACCESSOR,
|
|
423
|
+
{ provide: MAT_SLIDER_THUMB, useExisting: MatSliderThumb },
|
|
424
|
+
],
|
|
425
|
+
}]
|
|
426
|
+
}], ctorParameters: function () { return [{ type: i0.NgZone }, { type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: undefined, decorators: [{
|
|
427
|
+
type: Inject,
|
|
428
|
+
args: [MAT_SLIDER]
|
|
429
|
+
}] }]; }, propDecorators: { value: [{
|
|
430
|
+
type: Input
|
|
431
|
+
}], valueChange: [{
|
|
432
|
+
type: Output
|
|
433
|
+
}], dragStart: [{
|
|
434
|
+
type: Output
|
|
435
|
+
}], dragEnd: [{
|
|
436
|
+
type: Output
|
|
437
|
+
}] } });
|
|
438
|
+
export class MatSliderRangeThumb extends MatSliderThumb {
|
|
439
|
+
constructor(_ngZone, _slider, _elementRef, _cdr) {
|
|
440
|
+
super(_ngZone, _elementRef, _cdr, _slider);
|
|
441
|
+
this._cdr = _cdr;
|
|
442
|
+
this._isEndThumb = this._hostElement.hasAttribute('matSliderEndThumb');
|
|
443
|
+
this._setIsLeftThumb();
|
|
444
|
+
this.thumbPosition = this._isEndThumb ? 2 /* _MatThumb.END */ : 1 /* _MatThumb.START */;
|
|
445
|
+
}
|
|
446
|
+
getSibling() {
|
|
447
|
+
if (!this._sibling) {
|
|
448
|
+
this._sibling = this._slider._getInput(this._isEndThumb ? 1 /* _MatThumb.START */ : 2 /* _MatThumb.END */);
|
|
449
|
+
}
|
|
450
|
+
return this._sibling;
|
|
451
|
+
}
|
|
452
|
+
/** Returns the minimum translateX position allowed for this slider input's visual thumb. */
|
|
453
|
+
getMinPos() {
|
|
454
|
+
const sibling = this.getSibling();
|
|
455
|
+
if (!this._isLeftThumb && sibling) {
|
|
456
|
+
return sibling.translateX;
|
|
457
|
+
}
|
|
458
|
+
return 0;
|
|
459
|
+
}
|
|
460
|
+
/** Returns the maximum translateX position allowed for this slider input's visual thumb. */
|
|
461
|
+
getMaxPos() {
|
|
462
|
+
const sibling = this.getSibling();
|
|
463
|
+
if (this._isLeftThumb && sibling) {
|
|
464
|
+
return sibling.translateX;
|
|
465
|
+
}
|
|
466
|
+
return this._slider._cachedWidth;
|
|
467
|
+
}
|
|
468
|
+
_setIsLeftThumb() {
|
|
469
|
+
this._isLeftThumb =
|
|
470
|
+
(this._isEndThumb && this._slider._isRtl) || (!this._isEndThumb && !this._slider._isRtl);
|
|
471
|
+
}
|
|
472
|
+
_getDefaultValue() {
|
|
473
|
+
return this._isEndThumb && this._slider._isRange ? this.max : this.min;
|
|
474
|
+
}
|
|
475
|
+
_onInput() {
|
|
476
|
+
super._onInput();
|
|
477
|
+
this._updateSibling();
|
|
478
|
+
if (!this._isActive) {
|
|
479
|
+
this._updateWidthInactive();
|
|
480
|
+
}
|
|
481
|
+
}
|
|
482
|
+
_onNgControlValueChange() {
|
|
483
|
+
super._onNgControlValueChange();
|
|
484
|
+
this.getSibling()?._updateMinMax();
|
|
485
|
+
}
|
|
486
|
+
_onPointerDown(event) {
|
|
487
|
+
if (this.disabled) {
|
|
488
|
+
return;
|
|
489
|
+
}
|
|
490
|
+
if (this._sibling) {
|
|
491
|
+
this._sibling._updateWidthActive();
|
|
492
|
+
this._sibling._hostElement.classList.add('mat-mdc-slider-input-no-pointer-events');
|
|
493
|
+
}
|
|
494
|
+
super._onPointerDown(event);
|
|
495
|
+
}
|
|
496
|
+
_onPointerUp(event) {
|
|
497
|
+
super._onPointerUp(event);
|
|
498
|
+
if (this._sibling) {
|
|
499
|
+
this._sibling._updateWidthInactive();
|
|
500
|
+
this._sibling._hostElement.classList.remove('mat-mdc-slider-input-no-pointer-events');
|
|
501
|
+
}
|
|
502
|
+
}
|
|
503
|
+
_onPointerMove(event) {
|
|
504
|
+
super._onPointerMove(event);
|
|
505
|
+
if (!this._slider.step && this._isActive) {
|
|
506
|
+
this._updateSibling();
|
|
507
|
+
}
|
|
508
|
+
}
|
|
509
|
+
_fixValue(event) {
|
|
510
|
+
super._fixValue(event);
|
|
511
|
+
this._sibling?._updateMinMax();
|
|
512
|
+
}
|
|
513
|
+
_clamp(v) {
|
|
514
|
+
return Math.max(Math.min(v, this.getMaxPos()), this.getMinPos());
|
|
515
|
+
}
|
|
516
|
+
_updateMinMax() {
|
|
517
|
+
const sibling = this.getSibling();
|
|
518
|
+
if (!sibling) {
|
|
519
|
+
return;
|
|
520
|
+
}
|
|
521
|
+
if (this._isEndThumb) {
|
|
522
|
+
this.min = Math.max(this._slider.min, sibling.value);
|
|
523
|
+
this.max = this._slider.max;
|
|
524
|
+
}
|
|
525
|
+
else {
|
|
526
|
+
this.min = this._slider.min;
|
|
527
|
+
this.max = Math.min(this._slider.max, sibling.value);
|
|
528
|
+
}
|
|
529
|
+
}
|
|
530
|
+
_updateWidthActive() {
|
|
531
|
+
const minWidth = this._slider._rippleRadius * 2 - this._slider._inputPadding * 2;
|
|
532
|
+
const maxWidth = this._slider._cachedWidth + this._slider._inputPadding - minWidth;
|
|
533
|
+
const percentage = this._slider.min < this._slider.max
|
|
534
|
+
? (this.max - this.min) / (this._slider.max - this._slider.min)
|
|
535
|
+
: 1;
|
|
536
|
+
const width = maxWidth * percentage + minWidth;
|
|
537
|
+
this._hostElement.style.width = `${width}px`;
|
|
538
|
+
this._hostElement.style.padding = `0 ${this._slider._inputPadding}px`;
|
|
539
|
+
}
|
|
540
|
+
_updateWidthInactive() {
|
|
541
|
+
const sibling = this.getSibling();
|
|
542
|
+
if (!sibling) {
|
|
543
|
+
return;
|
|
544
|
+
}
|
|
545
|
+
const maxWidth = this._slider._cachedWidth;
|
|
546
|
+
const midValue = this._isEndThumb
|
|
547
|
+
? this.value - (this.value - sibling.value) / 2
|
|
548
|
+
: this.value + (sibling.value - this.value) / 2;
|
|
549
|
+
const _percentage = this._isEndThumb
|
|
550
|
+
? (this.max - midValue) / (this._slider.max - this._slider.min)
|
|
551
|
+
: (midValue - this.min) / (this._slider.max - this._slider.min);
|
|
552
|
+
const percentage = this._slider.min < this._slider.max ? _percentage : 1;
|
|
553
|
+
const width = maxWidth * percentage + 24;
|
|
554
|
+
this._hostElement.style.width = `${width}px`;
|
|
555
|
+
this._hostElement.style.padding = '0px';
|
|
556
|
+
if (this._isLeftThumb) {
|
|
557
|
+
this._hostElement.style.left = '-24px';
|
|
558
|
+
this._hostElement.style.right = 'auto';
|
|
559
|
+
}
|
|
560
|
+
else {
|
|
561
|
+
this._hostElement.style.left = 'auto';
|
|
562
|
+
this._hostElement.style.right = '-24px';
|
|
563
|
+
}
|
|
564
|
+
}
|
|
565
|
+
_updateStaticStyles() {
|
|
566
|
+
this._hostElement.classList.toggle('mat-slider__right-input', !this._isLeftThumb);
|
|
567
|
+
}
|
|
568
|
+
_updateSibling() {
|
|
569
|
+
const sibling = this.getSibling();
|
|
570
|
+
if (!sibling) {
|
|
571
|
+
return;
|
|
572
|
+
}
|
|
573
|
+
sibling._updateMinMax();
|
|
574
|
+
if (this._isActive) {
|
|
575
|
+
sibling._updateWidthActive();
|
|
576
|
+
}
|
|
577
|
+
else {
|
|
578
|
+
sibling._updateWidthInactive();
|
|
579
|
+
}
|
|
580
|
+
}
|
|
581
|
+
/**
|
|
582
|
+
* Sets the input's value.
|
|
583
|
+
* @param value The new value of the input
|
|
584
|
+
* @docs-private
|
|
585
|
+
*/
|
|
586
|
+
writeValue(value) {
|
|
587
|
+
this.value = value;
|
|
588
|
+
this._updateWidthInactive();
|
|
589
|
+
this._updateSibling();
|
|
590
|
+
}
|
|
591
|
+
}
|
|
592
|
+
MatSliderRangeThumb.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.0-rc.1", ngImport: i0, type: MatSliderRangeThumb, deps: [{ token: i0.NgZone }, { token: MAT_SLIDER }, { token: i0.ElementRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
593
|
+
MatSliderRangeThumb.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.0.0-rc.1", type: MatSliderRangeThumb, selector: "input[matSliderStartThumb], input[matSliderEndThumb]", providers: [
|
|
594
|
+
MAT_SLIDER_RANGE_THUMB_VALUE_ACCESSOR,
|
|
595
|
+
{ provide: MAT_SLIDER_RANGE_THUMB, useExisting: MatSliderRangeThumb },
|
|
596
|
+
], exportAs: ["matSliderRangeThumb"], usesInheritance: true, ngImport: i0 });
|
|
597
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.0-rc.1", ngImport: i0, type: MatSliderRangeThumb, decorators: [{
|
|
598
|
+
type: Directive,
|
|
599
|
+
args: [{
|
|
600
|
+
selector: 'input[matSliderStartThumb], input[matSliderEndThumb]',
|
|
601
|
+
exportAs: 'matSliderRangeThumb',
|
|
602
|
+
providers: [
|
|
603
|
+
MAT_SLIDER_RANGE_THUMB_VALUE_ACCESSOR,
|
|
604
|
+
{ provide: MAT_SLIDER_RANGE_THUMB, useExisting: MatSliderRangeThumb },
|
|
605
|
+
],
|
|
606
|
+
}]
|
|
607
|
+
}], ctorParameters: function () { return [{ type: i0.NgZone }, { type: undefined, decorators: [{
|
|
608
|
+
type: Inject,
|
|
609
|
+
args: [MAT_SLIDER]
|
|
610
|
+
}] }, { type: i0.ElementRef }, { type: i0.ChangeDetectorRef }]; } });
|
|
611
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"slider-input.js","sourceRoot":"","sources":["../../../../../../src/material/slider/slider-input.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,EAEL,qBAAqB,EACrB,oBAAoB,GAErB,MAAM,uBAAuB,CAAC;AAC/B,OAAO,EACL,iBAAiB,EACjB,SAAS,EACT,UAAU,EACV,YAAY,EACZ,UAAU,EACV,MAAM,EACN,KAAK,EACL,MAAM,EAEN,MAAM,GACP,MAAM,eAAe,CAAC;AACvB,OAAO,EAAoC,iBAAiB,EAAC,MAAM,gBAAgB,CAAC;AACpF,OAAO,EAAC,OAAO,EAAC,MAAM,MAAM,CAAC;AAC7B,OAAO,EAML,sBAAsB,EACtB,gBAAgB,EAChB,UAAU,GACX,MAAM,oBAAoB,CAAC;;AAE5B;;;GAGG;AACH,MAAM,CAAC,MAAM,+BAA+B,GAAQ;IAClD,OAAO,EAAE,iBAAiB;IAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,cAAc,CAAC;IAC7C,KAAK,EAAE,IAAI;CACZ,CAAC;AAEF;;;GAGG;AACH,MAAM,CAAC,MAAM,qCAAqC,GAAQ;IACxD,OAAO,EAAE,iBAAiB;IAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,mBAAmB,CAAC;IAClD,KAAK,EAAE,IAAI;CACZ,CAAC;AAEF;;;;;;;GAOG;AAoBH,MAAM,OAAO,cAAc;IAwJzB,YACW,OAAe,EACf,WAAyC,EACzC,IAAuB,EACF,OAAmB;QAHxC,YAAO,GAAP,OAAO,CAAQ;QACf,gBAAW,GAAX,WAAW,CAA8B;QACzC,SAAI,GAAJ,IAAI,CAAmB;QACF,YAAO,GAAP,OAAO,CAAY;QAzIhC,gBAAW,GAAyB,IAAI,YAAY,EAAU,CAAC;QAElF,gEAAgE;QAC7C,cAAS,GAC1B,IAAI,YAAY,EAAsB,CAAC;QAEzC,+DAA+D;QAC5C,YAAO,GACxB,IAAI,YAAY,EAAsB,CAAC;QAkBzC,8DAA8D;QAC9D,kBAAa,yBAA4B;QA6DzC,iDAAiD;QACjD,gBAAW,GAAW,CAAC,CAAC;QAExB,6EAA6E;QAC7E,cAAS,GAAY,KAAK,CAAC;QAE3B,gFAAgF;QAChF,eAAU,GAAY,KAAK,CAAC;QAO5B;;;;;WAKG;QACK,wBAAmB,GAAY,KAAK,CAAC;QAQ7C,6CAA6C;QAC1B,eAAU,GAAG,IAAI,OAAO,EAAQ,CAAC;QAEpD;;;;;WAKG;QACH,kBAAa,GAAY,KAAK,CAAC;QAE/B,2DAA2D;QACnD,gBAAW,GAAyB,GAAG,EAAE,GAAE,CAAC,CAAC;QAErD,8DAA8D;QACtD,iBAAY,GAAe,GAAG,EAAE,GAAE,CAAC,CAAC;QAQ1C,IAAI,CAAC,YAAY,GAAG,WAAW,CAAC,aAAa,CAAC;QAC9C,IAAI,CAAC,OAAO,CAAC,iBAAiB,CAAC,GAAG,EAAE;YAClC,IAAI,CAAC,YAAY,CAAC,gBAAgB,CAAC,aAAa,EAAE,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;YAClF,IAAI,CAAC,YAAY,CAAC,gBAAgB,CAAC,aAAa,EAAE,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;YAClF,IAAI,CAAC,YAAY,CAAC,gBAAgB,CAAC,WAAW,EAAE,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;QAChF,CAAC,CAAC,CAAC;IACL,CAAC;IAnKD,IACI,KAAK;QACP,OAAO,oBAAoB,CAAC,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;IACvD,CAAC;IACD,IAAI,KAAK,CAAC,CAAc;QACtB,MAAM,GAAG,GAAG,oBAAoB,CAAC,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC;QAC/C,IAAI,CAAC,IAAI,CAAC,mBAAmB,EAAE;YAC7B,IAAI,CAAC,aAAa,GAAG,GAAG,CAAC;YACzB,OAAO;SACR;QACD,IAAI,IAAI,CAAC,SAAS,EAAE;YAClB,OAAO;SACR;QACD,IAAI,CAAC,YAAY,CAAC,KAAK,GAAG,GAAG,CAAC;QAC9B,IAAI,CAAC,qBAAqB,EAAE,CAAC;QAC7B,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;QAClC,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC;IAC5B,CAAC;IAWD,+DAA+D;IAC/D,IAAI,UAAU;QACZ,IAAI,IAAI,CAAC,OAAO,CAAC,GAAG,IAAI,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE;YACxC,IAAI,CAAC,WAAW,GAAG,CAAC,CAAC;YACrB,OAAO,IAAI,CAAC,WAAW,CAAC;SACzB;QACD,IAAI,IAAI,CAAC,WAAW,KAAK,SAAS,EAAE;YAClC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,sBAAsB,EAAE,CAAC;SAClD;QACD,OAAO,IAAI,CAAC,WAAW,CAAC;IAC1B,CAAC;IACD,IAAI,UAAU,CAAC,CAAS;QACtB,IAAI,CAAC,WAAW,GAAG,CAAC,CAAC;IACvB,CAAC;IAMD,IAAI,GAAG;QACL,OAAO,oBAAoB,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC;IACrD,CAAC;IACD,IAAI,GAAG,CAAC,CAAc;QACpB,IAAI,CAAC,YAAY,CAAC,GAAG,GAAG,oBAAoB,CAAC,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC;QAC3D,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC;IAC5B,CAAC;IAED,IAAI,GAAG;QACL,OAAO,oBAAoB,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC;IACrD,CAAC;IACD,IAAI,GAAG,CAAC,CAAc;QACpB,IAAI,CAAC,YAAY,CAAC,GAAG,GAAG,oBAAoB,CAAC,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC;QAC3D,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC;IAC5B,CAAC;IAED,IAAI,IAAI;QACN,OAAO,oBAAoB,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;IACtD,CAAC;IACD,IAAI,IAAI,CAAC,CAAc;QACrB,IAAI,CAAC,YAAY,CAAC,IAAI,GAAG,oBAAoB,CAAC,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC;QAC5D,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC;IAC5B,CAAC;IAED,IAAI,QAAQ;QACV,OAAO,qBAAqB,CAAC,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;IAC3D,CAAC;IACD,IAAI,QAAQ,CAAC,CAAe;QAC1B,IAAI,CAAC,YAAY,CAAC,QAAQ,GAAG,qBAAqB,CAAC,CAAC,CAAC,CAAC;QACtD,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC;QAE1B,IAAI,IAAI,CAAC,OAAO,CAAC,QAAQ,KAAK,IAAI,CAAC,QAAQ,EAAE;YAC3C,IAAI,CAAC,OAAO,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC;SACvC;IACH,CAAC;IAED,IAAI,UAAU;QACZ,IAAI,IAAI,CAAC,OAAO,CAAC,GAAG,IAAI,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE;YACxC,OAAO,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;SACpC;QACD,OAAO,CAAC,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;IACjF,CAAC;IAED,IAAI,cAAc;QAChB,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,YAAY,EAAE;YAC9B,OAAO,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;SACpC;QACD,IAAI,IAAI,CAAC,WAAW,KAAK,CAAC,EAAE;YAC1B,OAAO,CAAC,CAAC;SACV;QACD,OAAO,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC;IACrD,CAAC;IAiBD,uEAAuE;IAC/D,aAAa,CAAC,CAAU;QAC9B,IAAI,CAAC,UAAU,GAAG,CAAC,CAAC;IACtB,CAAC;IA+CD,WAAW;QACT,IAAI,CAAC,YAAY,CAAC,mBAAmB,CAAC,aAAa,EAAE,IAAI,CAAC,cAAc,CAAC,CAAC;QAC1E,IAAI,CAAC,YAAY,CAAC,mBAAmB,CAAC,aAAa,EAAE,IAAI,CAAC,cAAc,CAAC,CAAC;QAC1E,IAAI,CAAC,YAAY,CAAC,mBAAmB,CAAC,WAAW,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;QACtE,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;QACvB,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE,CAAC;QAC3B,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC;QAC1B,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC;IAC1B,CAAC;IAED,SAAS;QACP,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC5B,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC;QACtC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC;QAC9B,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC;QAC5B,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC;QAC5B,IAAI,CAAC,UAAU,EAAE,CAAC;IACpB,CAAC;IAED,MAAM;QACJ,IAAI,CAAC,qBAAqB,EAAE,CAAC;IAC/B,CAAC;IAED,UAAU;QACR,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC;QAChC,IAAI,IAAI,CAAC,aAAa,KAAK,SAAS,EAAE;YACpC,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC;SACtC;aAAM;YACL,IAAI,CAAC,YAAY,CAAC,KAAK,GAAG,IAAI,CAAC,aAAa,CAAC;YAC7C,IAAI,CAAC,qBAAqB,EAAE,CAAC;YAC7B,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;YAClC,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC;SAC3B;IACH,CAAC;IAED,gBAAgB;QACd,OAAO,IAAI,CAAC,GAAG,CAAC;IAClB,CAAC;IAED,OAAO;QACL,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QAC1B,IAAI,CAAC,YAAY,EAAE,CAAC;IACtB,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;IAC3B,CAAC;IAED,SAAS;QACP,+CAA+C;QAC/C,gDAAgD;QAChD,IAAI,IAAI,CAAC,SAAS,EAAE;YAClB,IAAI,CAAC,qBAAqB,CAAC,EAAC,aAAa,EAAE,IAAI,EAAC,CAAC,CAAC;SACnD;IACH,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAClC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC7B,+CAA+C;QAC/C,qBAAqB;QACrB,IAAI,IAAI,CAAC,OAAO,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE;YACxC,IAAI,CAAC,qBAAqB,CAAC,EAAC,aAAa,EAAE,IAAI,EAAC,CAAC,CAAC;SACnD;QACD,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;IACpC,CAAC;IAED,uBAAuB;QACrB,4CAA4C;QAC5C,oCAAoC;QACpC,IAAI,CAAC,IAAI,CAAC,SAAS,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE;YACvC,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;YAClC,IAAI,CAAC,qBAAqB,EAAE,CAAC;SAC9B;QACD,IAAI,CAAC,OAAO,CAAC,QAAQ,GAAG,IAAI,CAAC,YAAa,CAAC,QAAQ,CAAC;IACtD,CAAC;IAED,cAAc,CAAC,KAAmB;QAChC,IAAI,IAAI,CAAC,QAAQ,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE;YACvC,OAAO;SACR;QAED,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QACtB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;QACzB,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAC1B,IAAI,CAAC,OAAO,CAAC,iBAAiB,EAAE,CAAC;QAEjC,+CAA+C;QAC/C,iDAAiD;QACjD,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE;YACtB,IAAI,CAAC,4BAA4B,CAAC,KAAK,EAAE,EAAC,aAAa,EAAE,IAAI,EAAC,CAAC,CAAC;SACjE;QAED,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAClB,IAAI,CAAC,sBAAsB,CAAC,KAAK,CAAC,CAAC;SACpC;IACH,CAAC;IAED;;;;;OAKG;IACK,sBAAsB,CAAC,KAAmB;QAChD,uEAAuE;QACvE,sEAAsE;QACtE,uEAAuE;QACvE,WAAW;QACX,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;QAE1B,wEAAwE;QACxE,qEAAqE;QACrE,yEAAyE;QACzE,+DAA+D;QAC/D,qBAAqB;QACrB,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;YAC3B,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;QACxB,CAAC,EAAE,CAAC,CAAC,CAAC;IACR,CAAC;IAED,8EAA8E;IAC9E,SAAS,CAAC,KAAmB;QAC3B,MAAM,IAAI,GAAG,KAAK,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC;QACtD,MAAM,KAAK,GAAG,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC;QACxC,MAAM,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC;QAC7D,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,CAAC;QAC1E,MAAM,UAAU,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,GAAG,KAAK,CAAC,CAAC,CAAC,IAAI,GAAG,KAAK,CAAC;QAEzE,2EAA2E;QAC3E,MAAM,eAAe,GAAG,IAAI,CAAC,KAAK,CAAC,UAAU,GAAG,QAAQ,CAAC,GAAG,QAAQ,CAAC;QAErE,MAAM,cAAc,GAClB,eAAe,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC;QAC7E,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,cAAc,GAAG,IAAI,CAAC,GAAG,IAAI,CAAC;QAEvD,MAAM,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC;QAC7B,MAAM,SAAS,GAAG,EAAC,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,CAAC,OAAO,EAAE,KAAK,EAAE,KAAK,EAAC,CAAC;QACrE,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAE/E,IAAI,KAAK,KAAK,SAAS,EAAE;YACvB,iEAAiE;YACjE,+DAA+D;YAC/D,oCAAoC;YACpC,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;YAClC,IAAI,CAAC,OAAO,CAAC,IAAI,GAAG,CAAC;gBACnB,CAAC,CAAC,IAAI,CAAC,qBAAqB,EAAE;gBAC9B,CAAC,CAAC,IAAI,CAAC,4BAA4B,CAAC,KAAK,EAAE,EAAC,aAAa,EAAE,IAAI,CAAC,OAAO,CAAC,aAAa,EAAC,CAAC,CAAC;YAC1F,OAAO;SACR;QAED,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAClC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC7B,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;QAClC,IAAI,CAAC,OAAO,CAAC,IAAI,GAAG,CAAC;YACnB,CAAC,CAAC,IAAI,CAAC,qBAAqB,EAAE;YAC9B,CAAC,CAAC,IAAI,CAAC,4BAA4B,CAAC,KAAK,EAAE,EAAC,aAAa,EAAE,IAAI,CAAC,OAAO,CAAC,aAAa,EAAC,CAAC,CAAC;IAC5F,CAAC;IAED,cAAc,CAAC,KAAmB;QAChC,mDAAmD;QACnD,oDAAoD;QACpD,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,IAAI,IAAI,CAAC,SAAS,EAAE;YACxC,IAAI,CAAC,4BAA4B,CAAC,KAAK,CAAC,CAAC;SAC1C;IACH,CAAC;IAED,YAAY,CAAC,KAAmB;QAC9B,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QACvB,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC5B,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAClB,IAAI,CAAC,sBAAsB,CAAC,KAAK,CAAC,CAAC;SACpC;IACH,CAAC;IAED,MAAM,CAAC,CAAS;QACd,OAAO,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,EAAE,CAAC,CAAC,CAAC;IAC7D,CAAC;IAED,sBAAsB;QACpB,IAAI,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE;YACvB,OAAO,CAAC,CAAC,GAAG,IAAI,CAAC,UAAU,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC;SAC1D;QACD,OAAO,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC;IACrD,CAAC;IAED,6BAA6B,CAAC,KAAmB;QAC/C,OAAO,KAAK,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC;IAClD,CAAC;IAED;;;OAGG;IACH,kBAAkB;QAChB,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,OAAO,GAAG,KAAK,IAAI,CAAC,OAAO,CAAC,aAAa,IAAI,CAAC;QACtE,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,KAAK,GAAG,eAAe,IAAI,CAAC,OAAO,CAAC,aAAa,KAAK,CAAC;IACjF,CAAC;IAED;;;OAGG;IACH,oBAAoB;QAClB,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,OAAO,GAAG,KAAK,CAAC;QACxC,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,KAAK,GAAG,mBAAmB,CAAC;QACpD,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,IAAI,GAAG,OAAO,CAAC;IACzC,CAAC;IAED,qBAAqB,CAAC,OAAkC;QACtD,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,sBAAsB,EAAE,CAAC,CAAC;QAC7D,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC;IAC/B,CAAC;IAED,4BAA4B,CAAC,KAAmB,EAAE,OAAkC;QAClF,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,6BAA6B,CAAC,KAAK,CAAC,CAAC,CAAC;QACzE,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC;IAC/B,CAAC;IAED,cAAc,CAAC,OAAkC;QAC/C,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC,CAAC,OAAO,EAAE,aAAa,CAAC,CAAC;QACtD,IAAI,CAAC,OAAO,CAAC,mBAAmB,CAAC,IAAI,CAAC,CAAC;IACzC,CAAC;IAED;;;;OAIG;IACH,UAAU,CAAC,KAAU;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;IACrB,CAAC;IAED;;;;OAIG;IACH,gBAAgB,CAAC,EAAO;QACtB,IAAI,CAAC,WAAW,GAAG,EAAE,CAAC;IACxB,CAAC;IAED;;;;OAIG;IACH,iBAAiB,CAAC,EAAO;QACvB,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;IACzB,CAAC;IAED;;;;OAIG;IACH,gBAAgB,CAAC,UAAmB;QAClC,IAAI,CAAC,QAAQ,GAAG,UAAU,CAAC;IAC7B,CAAC;IAED,KAAK;QACH,IAAI,CAAC,YAAY,CAAC,KAAK,EAAE,CAAC;IAC5B,CAAC;IAED,IAAI;QACF,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;IAC3B,CAAC;;gHAlbU,cAAc,mGA4Jf,UAAU;oGA5JT,cAAc,iZALd;QACT,+BAA+B;QAC/B,EAAC,OAAO,EAAE,gBAAgB,EAAE,WAAW,EAAE,cAAc,EAAC;KACzD;gGAEU,cAAc;kBAnB1B,SAAS;mBAAC;oBACT,QAAQ,EAAE,uBAAuB;oBACjC,QAAQ,EAAE,gBAAgB;oBAC1B,IAAI,EAAE;wBACJ,OAAO,EAAE,mBAAmB;wBAC5B,MAAM,EAAE,OAAO;wBACf,uBAAuB,EAAE,YAAY;wBACrC,UAAU,EAAE,aAAa;wBACzB,SAAS,EAAE,YAAY;wBACvB,sEAAsE;wBACtE,wFAAwF;wBACxF,QAAQ,EAAE,WAAW;wBACrB,SAAS,EAAE,YAAY;qBACxB;oBACD,SAAS,EAAE;wBACT,+BAA+B;wBAC/B,EAAC,OAAO,EAAE,gBAAgB,EAAE,WAAW,gBAAgB,EAAC;qBACzD;iBACF;;0BA6JI,MAAM;2BAAC,UAAU;4CA1JhB,KAAK;sBADR,KAAK;gBAkBa,WAAW;sBAA7B,MAAM;gBAGY,SAAS;sBAA3B,MAAM;gBAIY,OAAO;sBAAzB,MAAM;;AAmaT,MAAM,OAAO,mBAAoB,SAAQ,cAAc;IAwCrD,YACE,OAAe,EACK,OAAmB,EACvC,WAAyC,EACvB,IAAuB;QAEzC,KAAK,CAAC,OAAO,EAAE,WAAW,EAAE,IAAI,EAAE,OAAO,CAAC,CAAC;QAFzB,SAAI,GAAJ,IAAI,CAAmB;QAGzC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,YAAY,CAAC,YAAY,CAAC,mBAAmB,CAAC,CAAC;QACvE,IAAI,CAAC,eAAe,EAAE,CAAC;QACvB,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,WAAW,CAAC,CAAC,uBAAe,CAAC,wBAAgB,CAAC;IAC1E,CAAC;IAjDD,UAAU;QACR,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAClB,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,yBAAiB,CAAC,sBAAc,CAE5E,CAAC;SACf;QACD,OAAO,IAAI,CAAC,QAAQ,CAAC;IACvB,CAAC;IAGD,4FAA4F;IAC5F,SAAS;QACP,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;QAClC,IAAI,CAAC,IAAI,CAAC,YAAY,IAAI,OAAO,EAAE;YACjC,OAAO,OAAO,CAAC,UAAU,CAAC;SAC3B;QACD,OAAO,CAAC,CAAC;IACX,CAAC;IAED,4FAA4F;IAC5F,SAAS;QACP,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;QAClC,IAAI,IAAI,CAAC,YAAY,IAAI,OAAO,EAAE;YAChC,OAAO,OAAO,CAAC,UAAU,CAAC;SAC3B;QACD,OAAO,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC;IACnC,CAAC;IAED,eAAe;QACb,IAAI,CAAC,YAAY;YACf,CAAC,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,WAAW,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;IAC7F,CAAC;IAoBQ,gBAAgB;QACvB,OAAO,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC;IACzE,CAAC;IAEQ,QAAQ;QACf,KAAK,CAAC,QAAQ,EAAE,CAAC;QACjB,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE;YACnB,IAAI,CAAC,oBAAoB,EAAE,CAAC;SAC7B;IACH,CAAC;IAEQ,uBAAuB;QAC9B,KAAK,CAAC,uBAAuB,EAAE,CAAC;QAChC,IAAI,CAAC,UAAU,EAAE,EAAE,aAAa,EAAE,CAAC;IACrC,CAAC;IAEQ,cAAc,CAAC,KAAmB;QACzC,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,OAAO;SACR;QACD,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,IAAI,CAAC,QAAQ,CAAC,kBAAkB,EAAE,CAAC;YACnC,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,SAAS,CAAC,GAAG,CAAC,wCAAwC,CAAC,CAAC;SACpF;QACD,KAAK,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;IAC9B,CAAC;IAEQ,YAAY,CAAC,KAAmB;QACvC,KAAK,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;QAC1B,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,IAAI,CAAC,QAAQ,CAAC,oBAAoB,EAAE,CAAC;YACrC,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,SAAS,CAAC,MAAM,CAAC,wCAAwC,CAAC,CAAC;SACvF;IACH,CAAC;IAEQ,cAAc,CAAC,KAAmB;QACzC,KAAK,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;QAC5B,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,IAAI,IAAI,CAAC,SAAS,EAAE;YACxC,IAAI,CAAC,cAAc,EAAE,CAAC;SACvB;IACH,CAAC;IAEQ,SAAS,CAAC,KAAmB;QACpC,KAAK,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;QACvB,IAAI,CAAC,QAAQ,EAAE,aAAa,EAAE,CAAC;IACjC,CAAC;IAEQ,MAAM,CAAC,CAAS;QACvB,OAAO,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,SAAS,EAAE,CAAC,EAAE,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC;IACnE,CAAC;IAED,aAAa;QACX,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;QAClC,IAAI,CAAC,OAAO,EAAE;YACZ,OAAO;SACR;QACD,IAAI,IAAI,CAAC,WAAW,EAAE;YACpB,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,OAAO,CAAC,KAAK,CAAC,CAAC;YACrD,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC;SAC7B;aAAM;YACL,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC;YAC5B,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,OAAO,CAAC,KAAK,CAAC,CAAC;SACtD;IACH,CAAC;IAEQ,kBAAkB;QACzB,MAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,aAAa,GAAG,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,aAAa,GAAG,CAAC,CAAC;QACjF,MAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,YAAY,GAAG,IAAI,CAAC,OAAO,CAAC,aAAa,GAAG,QAAQ,CAAC;QACnF,MAAM,UAAU,GACd,IAAI,CAAC,OAAO,CAAC,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG;YACjC,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC;YAC/D,CAAC,CAAC,CAAC,CAAC;QACR,MAAM,KAAK,GAAG,QAAQ,GAAG,UAAU,GAAG,QAAQ,CAAC;QAC/C,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,KAAK,GAAG,GAAG,KAAK,IAAI,CAAC;QAC7C,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,OAAO,GAAG,KAAK,IAAI,CAAC,OAAO,CAAC,aAAa,IAAI,CAAC;IACxE,CAAC;IAEQ,oBAAoB;QAC3B,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;QAClC,IAAI,CAAC,OAAO,EAAE;YACZ,OAAO;SACR;QACD,MAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC;QAC3C,MAAM,QAAQ,GAAG,IAAI,CAAC,WAAW;YAC/B,CAAC,CAAC,IAAI,CAAC,KAAK,GAAG,CAAC,IAAI,CAAC,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC;YAC/C,CAAC,CAAC,IAAI,CAAC,KAAK,GAAG,CAAC,OAAO,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QAElD,MAAM,WAAW,GAAG,IAAI,CAAC,WAAW;YAClC,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,GAAG,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC;YAC/D,CAAC,CAAC,CAAC,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;QAElE,MAAM,UAAU,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC;QAEzE,MAAM,KAAK,GAAG,QAAQ,GAAG,UAAU,GAAG,EAAE,CAAC;QACzC,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,KAAK,GAAG,GAAG,KAAK,IAAI,CAAC;QAC7C,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,OAAO,GAAG,KAAK,CAAC;QAExC,IAAI,IAAI,CAAC,YAAY,EAAE;YACrB,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,IAAI,GAAG,OAAO,CAAC;YACvC,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,KAAK,GAAG,MAAM,CAAC;SACxC;aAAM;YACL,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,IAAI,GAAG,MAAM,CAAC;YACtC,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,KAAK,GAAG,OAAO,CAAC;SACzC;IACH,CAAC;IAED,mBAAmB;QACjB,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,MAAM,CAAC,yBAAyB,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IACpF,CAAC;IAEO,cAAc;QACpB,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;QAClC,IAAI,CAAC,OAAO,EAAE;YACZ,OAAO;SACR;QACD,OAAO,CAAC,aAAa,EAAE,CAAC;QACxB,IAAI,IAAI,CAAC,SAAS,EAAE;YAClB,OAAO,CAAC,kBAAkB,EAAE,CAAC;SAC9B;aAAM;YACL,OAAO,CAAC,oBAAoB,EAAE,CAAC;SAChC;IACH,CAAC;IAED;;;;OAIG;IACM,UAAU,CAAC,KAAU;QAC5B,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC5B,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;;qHAzLU,mBAAmB,wCA0CpB,UAAU;yGA1CT,mBAAmB,+EALnB;QACT,qCAAqC;QACrC,EAAC,OAAO,EAAE,sBAAsB,EAAE,WAAW,EAAE,mBAAmB,EAAC;KACpE;gGAEU,mBAAmB;kBAR/B,SAAS;mBAAC;oBACT,QAAQ,EAAE,sDAAsD;oBAChE,QAAQ,EAAE,qBAAqB;oBAC/B,SAAS,EAAE;wBACT,qCAAqC;wBACrC,EAAC,OAAO,EAAE,sBAAsB,EAAE,WAAW,qBAAqB,EAAC;qBACpE;iBACF;;0BA2CI,MAAM;2BAAC,UAAU","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {\n  BooleanInput,\n  coerceBooleanProperty,\n  coerceNumberProperty,\n  NumberInput,\n} from '@angular/cdk/coercion';\nimport {\n  ChangeDetectorRef,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  forwardRef,\n  Inject,\n  Input,\n  NgZone,\n  OnDestroy,\n  Output,\n} from '@angular/core';\nimport {ControlValueAccessor, FormControl, NG_VALUE_ACCESSOR} from '@angular/forms';\nimport {Subject} from 'rxjs';\nimport {\n  _MatThumb,\n  MatSliderDragEvent,\n  _MatSlider,\n  _MatSliderRangeThumb,\n  _MatSliderThumb,\n  MAT_SLIDER_RANGE_THUMB,\n  MAT_SLIDER_THUMB,\n  MAT_SLIDER,\n} from './slider-interface';\n\n/**\n * Provider that allows the slider thumb to register as a ControlValueAccessor.\n * @docs-private\n */\nexport const MAT_SLIDER_THUMB_VALUE_ACCESSOR: any = {\n  provide: NG_VALUE_ACCESSOR,\n  useExisting: forwardRef(() => MatSliderThumb),\n  multi: true,\n};\n\n/**\n * Provider that allows the range slider thumb to register as a ControlValueAccessor.\n * @docs-private\n */\nexport const MAT_SLIDER_RANGE_THUMB_VALUE_ACCESSOR: any = {\n  provide: NG_VALUE_ACCESSOR,\n  useExisting: forwardRef(() => MatSliderRangeThumb),\n  multi: true,\n};\n\n/**\n * Directive that adds slider-specific behaviors to an input element inside `<mat-slider>`.\n * Up to two may be placed inside of a `<mat-slider>`.\n *\n * If one is used, the selector `matSliderThumb` must be used, and the outcome will be a normal\n * slider. If two are used, the selectors `matSliderStartThumb` and `matSliderEndThumb` must be\n * used, and the outcome will be a range slider with two slider thumbs.\n */\n@Directive({\n  selector: 'input[matSliderThumb]',\n  exportAs: 'matSliderThumb',\n  host: {\n    'class': 'mdc-slider__input',\n    'type': 'range',\n    '[attr.aria-valuetext]': '_valuetext',\n    '(change)': '_onChange()',\n    '(input)': '_onInput()',\n    // TODO(wagnermaciel): Consider using a global event listener instead.\n    // Reason: I have found a semi-consistent way to mouse up without triggering this event.\n    '(blur)': '_onBlur()',\n    '(focus)': '_onFocus()',\n  },\n  providers: [\n    MAT_SLIDER_THUMB_VALUE_ACCESSOR,\n    {provide: MAT_SLIDER_THUMB, useExisting: MatSliderThumb},\n  ],\n})\nexport class MatSliderThumb implements _MatSliderThumb, OnDestroy, ControlValueAccessor {\n  @Input()\n  get value(): number {\n    return coerceNumberProperty(this._hostElement.value);\n  }\n  set value(v: NumberInput) {\n    const val = coerceNumberProperty(v).toString();\n    if (!this._hasSetInitialValue) {\n      this._initialValue = val;\n      return;\n    }\n    if (this._isActive) {\n      return;\n    }\n    this._hostElement.value = val;\n    this._updateThumbUIByValue();\n    this._slider._onValueChange(this);\n    this._cdr.detectChanges();\n  }\n  @Output() readonly valueChange: EventEmitter<number> = new EventEmitter<number>();\n\n  /** Event emitted when the slider thumb starts being dragged. */\n  @Output() readonly dragStart: EventEmitter<MatSliderDragEvent> =\n    new EventEmitter<MatSliderDragEvent>();\n\n  /** Event emitted when the slider thumb stops being dragged. */\n  @Output() readonly dragEnd: EventEmitter<MatSliderDragEvent> =\n    new EventEmitter<MatSliderDragEvent>();\n\n  /** The current translateX in px of the slider visual thumb. */\n  get translateX(): number {\n    if (this._slider.min >= this._slider.max) {\n      this._translateX = 0;\n      return this._translateX;\n    }\n    if (this._translateX === undefined) {\n      this._translateX = this._calcTranslateXByValue();\n    }\n    return this._translateX;\n  }\n  set translateX(v: number) {\n    this._translateX = v;\n  }\n  private _translateX: number | undefined;\n\n  /** Indicates whether this thumb is the start or end thumb. */\n  thumbPosition: _MatThumb = _MatThumb.END;\n\n  get min(): number {\n    return coerceNumberProperty(this._hostElement.min);\n  }\n  set min(v: NumberInput) {\n    this._hostElement.min = coerceNumberProperty(v).toString();\n    this._cdr.detectChanges();\n  }\n\n  get max(): number {\n    return coerceNumberProperty(this._hostElement.max);\n  }\n  set max(v: NumberInput) {\n    this._hostElement.max = coerceNumberProperty(v).toString();\n    this._cdr.detectChanges();\n  }\n\n  get step(): number {\n    return coerceNumberProperty(this._hostElement.step);\n  }\n  set step(v: NumberInput) {\n    this._hostElement.step = coerceNumberProperty(v).toString();\n    this._cdr.detectChanges();\n  }\n\n  get disabled(): boolean {\n    return coerceBooleanProperty(this._hostElement.disabled);\n  }\n  set disabled(v: BooleanInput) {\n    this._hostElement.disabled = coerceBooleanProperty(v);\n    this._cdr.detectChanges();\n\n    if (this._slider.disabled !== this.disabled) {\n      this._slider.disabled = this.disabled;\n    }\n  }\n\n  get percentage(): number {\n    if (this._slider.min >= this._slider.max) {\n      return this._slider._isRtl ? 1 : 0;\n    }\n    return (this.value - this._slider.min) / (this._slider.max - this._slider.min);\n  }\n\n  get fillPercentage(): number {\n    if (!this._slider._cachedWidth) {\n      return this._slider._isRtl ? 1 : 0;\n    }\n    if (this._translateX === 0) {\n      return 0;\n    }\n    return this.translateX / this._slider._cachedWidth;\n  }\n\n  /** The host native HTML input element. */\n  _hostElement: HTMLInputElement;\n\n  /** The aria-valuetext string representation of the input's value. */\n  _valuetext: string;\n\n  /** The radius of a native html slider's knob. */\n  _knobRadius: number = 8;\n\n  /** Whether user's cursor is currently in a mouse down state on the input. */\n  _isActive: boolean = false;\n\n  /** Whether the input is currently focused (either by tab or after clicking). */\n  _isFocused: boolean = false;\n\n  /** Used to relay updates to _isFocused to the slider visual thumbs. */\n  private _setIsFocused(v: boolean): void {\n    this._isFocused = v;\n  }\n\n  /**\n   * Whether the initial value has been set.\n   * This exists because the initial value cannot be immediately set because the min and max\n   * must first be relayed from the parent MatSlider component, which can only happen later\n   * in the component lifecycle.\n   */\n  private _hasSetInitialValue: boolean = false;\n\n  /** The stored initial value. */\n  _initialValue: string | undefined;\n\n  /** Defined when a user is using a form control to manage slider value & validation. */\n  private _formControl: FormControl | undefined;\n\n  /** Emits when the component is destroyed. */\n  protected readonly _destroyed = new Subject<void>();\n\n  /**\n   * Indicates whether UI updates should be skipped.\n   *\n   * This flag is used to avoid flickering\n   * when correcting values on pointer up/down.\n   */\n  _skipUIUpdate: boolean = false;\n\n  /** Callback called when the slider input value changes. */\n  private _onChangeFn: (value: any) => void = () => {};\n\n  /** Callback called when the slider input has been touched. */\n  private _onTouchedFn: () => void = () => {};\n\n  constructor(\n    readonly _ngZone: NgZone,\n    readonly _elementRef: ElementRef<HTMLInputElement>,\n    readonly _cdr: ChangeDetectorRef,\n    @Inject(MAT_SLIDER) protected _slider: _MatSlider,\n  ) {\n    this._hostElement = _elementRef.nativeElement;\n    this._ngZone.runOutsideAngular(() => {\n      this._hostElement.addEventListener('pointerdown', this._onPointerDown.bind(this));\n      this._hostElement.addEventListener('pointermove', this._onPointerMove.bind(this));\n      this._hostElement.addEventListener('pointerup', this._onPointerUp.bind(this));\n    });\n  }\n\n  ngOnDestroy(): void {\n    this._hostElement.removeEventListener('pointerdown', this._onPointerDown);\n    this._hostElement.removeEventListener('pointermove', this._onPointerMove);\n    this._hostElement.removeEventListener('pointerup', this._onPointerUp);\n    this._destroyed.next();\n    this._destroyed.complete();\n    this.dragStart.complete();\n    this.dragEnd.complete();\n  }\n\n  initProps(): void {\n    this._updateWidthInactive();\n    this.disabled = this._slider.disabled;\n    this.step = this._slider.step;\n    this.min = this._slider.min;\n    this.max = this._slider.max;\n    this._initValue();\n  }\n\n  initUI(): void {\n    this._updateThumbUIByValue();\n  }\n\n  _initValue(): void {\n    this._hasSetInitialValue = true;\n    if (this._initialValue === undefined) {\n      this.value = this._getDefaultValue();\n    } else {\n      this._hostElement.value = this._initialValue;\n      this._updateThumbUIByValue();\n      this._slider._onValueChange(this);\n      this._cdr.detectChanges();\n    }\n  }\n\n  _getDefaultValue(): number {\n    return this.min;\n  }\n\n  _onBlur(): void {\n    this._setIsFocused(false);\n    this._onTouchedFn();\n  }\n\n  _onFocus(): void {\n    this._setIsFocused(true);\n  }\n\n  _onChange(): void {\n    // only used to handle the edge case where user\n    // mousedown on the slider then uses arrow keys.\n    if (this._isActive) {\n      this._updateThumbUIByValue({withAnimation: true});\n    }\n  }\n\n  _onInput(): void {\n    this.valueChange.emit(this.value);\n    this._onChangeFn(this.value);\n    // handles arrowing and updating the value when\n    // a step is defined.\n    if (this._slider.step || !this._isActive) {\n      this._updateThumbUIByValue({withAnimation: true});\n    }\n    this._slider._onValueChange(this);\n  }\n\n  _onNgControlValueChange(): void {\n    // only used to handle when the value change\n    // originates outside of the slider.\n    if (!this._isActive || !this._isFocused) {\n      this._slider._onValueChange(this);\n      this._updateThumbUIByValue();\n    }\n    this._slider.disabled = this._formControl!.disabled;\n  }\n\n  _onPointerDown(event: PointerEvent): void {\n    if (this.disabled || event.button !== 0) {\n      return;\n    }\n\n    this._isActive = true;\n    this._setIsFocused(true);\n    this._updateWidthActive();\n    this._slider._updateDimensions();\n\n    // Does nothing if a step is defined because we\n    // want the value to snap to the values on input.\n    if (!this._slider.step) {\n      this._updateThumbUIByPointerEvent(event, {withAnimation: true});\n    }\n\n    if (!this.disabled) {\n      this._handleValueCorrection(event);\n    }\n  }\n\n  /**\n   * Corrects the value of the slider on pointer up/down.\n   *\n   * Called on pointer down and up because the value is set based\n   * on the inactive width instead of the active width.\n   */\n  private _handleValueCorrection(event: PointerEvent): void {\n    // Don't update the UI with the current value! The value on pointerdown\n    // and pointerup is calculated in the split second before the input(s)\n    // resize. See _updateWidthInactive() and _updateWidthActive() for more\n    // details.\n    this._skipUIUpdate = true;\n\n    // Note that this function gets triggered before the actual value of the\n    // slider is updated. This means if we were to set the value here, it\n    // would immediately be overwritten. Using setTimeout ensures the setting\n    // of the value happens after the value has been updated by the\n    // pointerdown event.\n    setTimeout(() => {\n      this._skipUIUpdate = false;\n      this._fixValue(event);\n    }, 0);\n  }\n\n  /** Corrects the value of the slider based on the pointer event's position. */\n  _fixValue(event: PointerEvent): void {\n    const xPos = event.clientX - this._slider._cachedLeft;\n    const width = this._slider._cachedWidth;\n    const step = this._slider.step === 0 ? 1 : this._slider.step;\n    const numSteps = Math.floor((this._slider.max - this._slider.min) / step);\n    const percentage = this._slider._isRtl ? 1 - xPos / width : xPos / width;\n\n    // To ensure the percentage is rounded to the necessary number of decimals.\n    const fixedPercentage = Math.round(percentage * numSteps) / numSteps;\n\n    const impreciseValue =\n      fixedPercentage * (this._slider.max - this._slider.min) + this._slider.min;\n    const value = Math.round(impreciseValue / step) * step;\n\n    const prevValue = this.value;\n    const dragEvent = {source: this, parent: this._slider, value: value};\n    this._isActive ? this.dragStart.emit(dragEvent) : this.dragEnd.emit(dragEvent);\n\n    if (value === prevValue) {\n      // Because we prevented UI updates, if it turns out that the race\n      // condition didn't happen and the value is already correct, we\n      // have to apply the ui updates now.\n      this._slider._onValueChange(this);\n      this._slider.step > 0\n        ? this._updateThumbUIByValue()\n        : this._updateThumbUIByPointerEvent(event, {withAnimation: this._slider._hasAnimation});\n      return;\n    }\n\n    this.value = value;\n    this.valueChange.emit(this.value);\n    this._onChangeFn(this.value);\n    this._slider._onValueChange(this);\n    this._slider.step > 0\n      ? this._updateThumbUIByValue()\n      : this._updateThumbUIByPointerEvent(event, {withAnimation: this._slider._hasAnimation});\n  }\n\n  _onPointerMove(event: PointerEvent): void {\n    // Again, does nothing if a step is defined because\n    // we want the value to snap to the values on input.\n    if (!this._slider.step && this._isActive) {\n      this._updateThumbUIByPointerEvent(event);\n    }\n  }\n\n  _onPointerUp(event: PointerEvent): void {\n    this._isActive = false;\n    this._updateWidthInactive();\n    if (!this.disabled) {\n      this._handleValueCorrection(event);\n    }\n  }\n\n  _clamp(v: number): number {\n    return Math.max(Math.min(v, this._slider._cachedWidth), 0);\n  }\n\n  _calcTranslateXByValue(): number {\n    if (this._slider._isRtl) {\n      return (1 - this.percentage) * this._slider._cachedWidth;\n    }\n    return this.percentage * this._slider._cachedWidth;\n  }\n\n  _calcTranslateXByPointerEvent(event: PointerEvent): number {\n    return event.clientX - this._slider._cachedLeft;\n  }\n\n  /**\n   * Used to set the slider width to the correct\n   * dimensions while the user is dragging.\n   */\n  _updateWidthActive(): void {\n    this._hostElement.style.padding = `0 ${this._slider._inputPadding}px`;\n    this._hostElement.style.width = `calc(100% + ${this._slider._inputPadding}px)`;\n  }\n\n  /**\n   * Sets the slider input to disproportionate dimensions to allow for touch\n   * events to be captured on touch devices.\n   */\n  _updateWidthInactive(): void {\n    this._hostElement.style.padding = '0px';\n    this._hostElement.style.width = 'calc(100% + 48px)';\n    this._hostElement.style.left = '-24px';\n  }\n\n  _updateThumbUIByValue(options?: {withAnimation: boolean}): void {\n    this.translateX = this._clamp(this._calcTranslateXByValue());\n    this._updateThumbUI(options);\n  }\n\n  _updateThumbUIByPointerEvent(event: PointerEvent, options?: {withAnimation: boolean}): void {\n    this.translateX = this._clamp(this._calcTranslateXByPointerEvent(event));\n    this._updateThumbUI(options);\n  }\n\n  _updateThumbUI(options?: {withAnimation: boolean}) {\n    this._slider._setTransition(!!options?.withAnimation);\n    this._slider._onTranslateXChange(this);\n  }\n\n  /**\n   * Sets the input's value.\n   * @param value The new value of the input\n   * @docs-private\n   */\n  writeValue(value: any): void {\n    this.value = value;\n  }\n\n  /**\n   * Registers a callback to be invoked when the input's value changes from user input.\n   * @param fn The callback to register\n   * @docs-private\n   */\n  registerOnChange(fn: any): void {\n    this._onChangeFn = fn;\n  }\n\n  /**\n   * Registers a callback to be invoked when the input is blurred by the user.\n   * @param fn The callback to register\n   * @docs-private\n   */\n  registerOnTouched(fn: any): void {\n    this._onTouchedFn = fn;\n  }\n\n  /**\n   * Sets the disabled state of the slider.\n   * @param isDisabled The new disabled state\n   * @docs-private\n   */\n  setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n  }\n\n  focus(): void {\n    this._hostElement.focus();\n  }\n\n  blur(): void {\n    this._hostElement.blur();\n  }\n}\n\n@Directive({\n  selector: 'input[matSliderStartThumb], input[matSliderEndThumb]',\n  exportAs: 'matSliderRangeThumb',\n  providers: [\n    MAT_SLIDER_RANGE_THUMB_VALUE_ACCESSOR,\n    {provide: MAT_SLIDER_RANGE_THUMB, useExisting: MatSliderRangeThumb},\n  ],\n})\nexport class MatSliderRangeThumb extends MatSliderThumb implements _MatSliderRangeThumb {\n  getSibling(): _MatSliderRangeThumb | undefined {\n    if (!this._sibling) {\n      this._sibling = this._slider._getInput(this._isEndThumb ? _MatThumb.START : _MatThumb.END) as\n        | MatSliderRangeThumb\n        | undefined;\n    }\n    return this._sibling;\n  }\n  private _sibling: MatSliderRangeThumb | undefined;\n\n  /** Returns the minimum translateX position allowed for this slider input's visual thumb. */\n  getMinPos(): number {\n    const sibling = this.getSibling();\n    if (!this._isLeftThumb && sibling) {\n      return sibling.translateX;\n    }\n    return 0;\n  }\n\n  /** Returns the maximum translateX position allowed for this slider input's visual thumb. */\n  getMaxPos(): number {\n    const sibling = this.getSibling();\n    if (this._isLeftThumb && sibling) {\n      return sibling.translateX;\n    }\n    return this._slider._cachedWidth;\n  }\n\n  _setIsLeftThumb(): void {\n    this._isLeftThumb =\n      (this._isEndThumb && this._slider._isRtl) || (!this._isEndThumb && !this._slider._isRtl);\n  }\n\n  /** Whether this slider corresponds to the input on the left hand side. */\n  _isLeftThumb: boolean;\n\n  /** Whether this slider corresponds to the input with greater value. */\n  _isEndThumb: boolean;\n\n  constructor(\n    _ngZone: NgZone,\n    @Inject(MAT_SLIDER) _slider: _MatSlider,\n    _elementRef: ElementRef<HTMLInputElement>,\n    override readonly _cdr: ChangeDetectorRef,\n  ) {\n    super(_ngZone, _elementRef, _cdr, _slider);\n    this._isEndThumb = this._hostElement.hasAttribute('matSliderEndThumb');\n    this._setIsLeftThumb();\n    this.thumbPosition = this._isEndThumb ? _MatThumb.END : _MatThumb.START;\n  }\n\n  override _getDefaultValue(): number {\n    return this._isEndThumb && this._slider._isRange ? this.max : this.min;\n  }\n\n  override _onInput(): void {\n    super._onInput();\n    this._updateSibling();\n    if (!this._isActive) {\n      this._updateWidthInactive();\n    }\n  }\n\n  override _onNgControlValueChange(): void {\n    super._onNgControlValueChange();\n    this.getSibling()?._updateMinMax();\n  }\n\n  override _onPointerDown(event: PointerEvent): void {\n    if (this.disabled) {\n      return;\n    }\n    if (this._sibling) {\n      this._sibling._updateWidthActive();\n      this._sibling._hostElement.classList.add('mat-mdc-slider-input-no-pointer-events');\n    }\n    super._onPointerDown(event);\n  }\n\n  override _onPointerUp(event: PointerEvent): void {\n    super._onPointerUp(event);\n    if (this._sibling) {\n      this._sibling._updateWidthInactive();\n      this._sibling._hostElement.classList.remove('mat-mdc-slider-input-no-pointer-events');\n    }\n  }\n\n  override _onPointerMove(event: PointerEvent): void {\n    super._onPointerMove(event);\n    if (!this._slider.step && this._isActive) {\n      this._updateSibling();\n    }\n  }\n\n  override _fixValue(event: PointerEvent): void {\n    super._fixValue(event);\n    this._sibling?._updateMinMax();\n  }\n\n  override _clamp(v: number): number {\n    return Math.max(Math.min(v, this.getMaxPos()), this.getMinPos());\n  }\n\n  _updateMinMax(): void {\n    const sibling = this.getSibling();\n    if (!sibling) {\n      return;\n    }\n    if (this._isEndThumb) {\n      this.min = Math.max(this._slider.min, sibling.value);\n      this.max = this._slider.max;\n    } else {\n      this.min = this._slider.min;\n      this.max = Math.min(this._slider.max, sibling.value);\n    }\n  }\n\n  override _updateWidthActive(): void {\n    const minWidth = this._slider._rippleRadius * 2 - this._slider._inputPadding * 2;\n    const maxWidth = this._slider._cachedWidth + this._slider._inputPadding - minWidth;\n    const percentage =\n      this._slider.min < this._slider.max\n        ? (this.max - this.min) / (this._slider.max - this._slider.min)\n        : 1;\n    const width = maxWidth * percentage + minWidth;\n    this._hostElement.style.width = `${width}px`;\n    this._hostElement.style.padding = `0 ${this._slider._inputPadding}px`;\n  }\n\n  override _updateWidthInactive(): void {\n    const sibling = this.getSibling();\n    if (!sibling) {\n      return;\n    }\n    const maxWidth = this._slider._cachedWidth;\n    const midValue = this._isEndThumb\n      ? this.value - (this.value - sibling.value) / 2\n      : this.value + (sibling.value - this.value) / 2;\n\n    const _percentage = this._isEndThumb\n      ? (this.max - midValue) / (this._slider.max - this._slider.min)\n      : (midValue - this.min) / (this._slider.max - this._slider.min);\n\n    const percentage = this._slider.min < this._slider.max ? _percentage : 1;\n\n    const width = maxWidth * percentage + 24;\n    this._hostElement.style.width = `${width}px`;\n    this._hostElement.style.padding = '0px';\n\n    if (this._isLeftThumb) {\n      this._hostElement.style.left = '-24px';\n      this._hostElement.style.right = 'auto';\n    } else {\n      this._hostElement.style.left = 'auto';\n      this._hostElement.style.right = '-24px';\n    }\n  }\n\n  _updateStaticStyles(): void {\n    this._hostElement.classList.toggle('mat-slider__right-input', !this._isLeftThumb);\n  }\n\n  private _updateSibling(): void {\n    const sibling = this.getSibling();\n    if (!sibling) {\n      return;\n    }\n    sibling._updateMinMax();\n    if (this._isActive) {\n      sibling._updateWidthActive();\n    } else {\n      sibling._updateWidthInactive();\n    }\n  }\n\n  /**\n   * Sets the input's value.\n   * @param value The new value of the input\n   * @docs-private\n   */\n  override writeValue(value: any): void {\n    this.value = value;\n    this._updateWidthInactive();\n    this._updateSibling();\n  }\n}\n"]}
|