UNPKG

@angular/material

Version:
790 lines (786 loc) 48.9 kB
import { FocusMonitor, _IdGenerator } from '@angular/cdk/a11y'; import { Directionality, BidiModule } from '@angular/cdk/bidi'; import { SelectionModel } from '@angular/cdk/collections'; import { hasModifierKey, RIGHT_ARROW, DOWN_ARROW, LEFT_ARROW, UP_ARROW, ENTER, SPACE } from '@angular/cdk/keycodes'; import { _CdkPrivateStyleLoader } from '@angular/cdk/private'; import * as i0 from '@angular/core'; import { InjectionToken, forwardRef, inject, ChangeDetectorRef, ElementRef, EventEmitter, HostAttributeToken, signal, booleanAttribute, Input, Output, ContentChildren, Directive, ViewChild, ChangeDetectionStrategy, ViewEncapsulation, Component, NgModule } from '@angular/core'; import { NG_VALUE_ACCESSOR } from '@angular/forms'; import { MatRipple } from './_ripple-chunk.mjs'; import { MatPseudoCheckbox } from './_pseudo-checkbox-chunk.mjs'; import { _animationsDisabled } from './_animation-chunk.mjs'; import { _StructuralStylesLoader } from './_structural-styles-chunk.mjs'; import { MatRippleModule } from './_ripple-module-chunk.mjs'; import '@angular/cdk/platform'; import '@angular/cdk/coercion'; import '@angular/cdk/layout'; const MAT_BUTTON_TOGGLE_DEFAULT_OPTIONS = new InjectionToken('MAT_BUTTON_TOGGLE_DEFAULT_OPTIONS', { providedIn: 'root', factory: () => ({ hideSingleSelectionIndicator: false, hideMultipleSelectionIndicator: false, disabledInteractive: false }) }); const MAT_BUTTON_TOGGLE_GROUP = new InjectionToken('MatButtonToggleGroup'); const MAT_BUTTON_TOGGLE_GROUP_VALUE_ACCESSOR = { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => MatButtonToggleGroup), multi: true }; class MatButtonToggleChange { source; value; constructor(source, value) { this.source = source; this.value = value; } } class MatButtonToggleGroup { _changeDetector = inject(ChangeDetectorRef); _dir = inject(Directionality, { optional: true }); _multiple = false; _disabled = false; _disabledInteractive = false; _selectionModel; _rawValue; _controlValueAccessorChangeFn = () => {}; _onTouched = () => {}; _buttonToggles; appearance; get name() { return this._name; } set name(value) { this._name = value; this._markButtonsForCheck(); } _name = inject(_IdGenerator).getId('mat-button-toggle-group-'); vertical = false; get value() { const selected = this._selectionModel ? this._selectionModel.selected : []; if (this.multiple) { return selected.map(toggle => toggle.value); } return selected[0] ? selected[0].value : undefined; } set value(newValue) { this._setSelectionByValue(newValue); this.valueChange.emit(this.value); } valueChange = new EventEmitter(); get selected() { const selected = this._selectionModel ? this._selectionModel.selected : []; return this.multiple ? selected : selected[0] || null; } get multiple() { return this._multiple; } set multiple(value) { this._multiple = value; this._markButtonsForCheck(); } get disabled() { return this._disabled; } set disabled(value) { this._disabled = value; this._markButtonsForCheck(); } get disabledInteractive() { return this._disabledInteractive; } set disabledInteractive(value) { this._disabledInteractive = value; this._markButtonsForCheck(); } get dir() { return this._dir && this._dir.value === 'rtl' ? 'rtl' : 'ltr'; } change = new EventEmitter(); get hideSingleSelectionIndicator() { return this._hideSingleSelectionIndicator; } set hideSingleSelectionIndicator(value) { this._hideSingleSelectionIndicator = value; this._markButtonsForCheck(); } _hideSingleSelectionIndicator; get hideMultipleSelectionIndicator() { return this._hideMultipleSelectionIndicator; } set hideMultipleSelectionIndicator(value) { this._hideMultipleSelectionIndicator = value; this._markButtonsForCheck(); } _hideMultipleSelectionIndicator; constructor() { const defaultOptions = inject(MAT_BUTTON_TOGGLE_DEFAULT_OPTIONS, { optional: true }); this.appearance = defaultOptions && defaultOptions.appearance ? defaultOptions.appearance : 'standard'; this._hideSingleSelectionIndicator = defaultOptions?.hideSingleSelectionIndicator ?? false; this._hideMultipleSelectionIndicator = defaultOptions?.hideMultipleSelectionIndicator ?? false; } ngOnInit() { this._selectionModel = new SelectionModel(this.multiple, undefined, false); } ngAfterContentInit() { this._selectionModel.select(...this._buttonToggles.filter(toggle => toggle.checked)); if (!this.multiple) { this._initializeTabIndex(); } } writeValue(value) { this.value = value; this._changeDetector.markForCheck(); } registerOnChange(fn) { this._controlValueAccessorChangeFn = fn; } registerOnTouched(fn) { this._onTouched = fn; } setDisabledState(isDisabled) { this.disabled = isDisabled; } _keydown(event) { if (this.multiple || this.disabled || hasModifierKey(event)) { return; } const target = event.target; const buttonId = target.id; const index = this._buttonToggles.toArray().findIndex(toggle => { return toggle.buttonId === buttonId; }); let nextButton = null; switch (event.keyCode) { case SPACE: case ENTER: nextButton = this._buttonToggles.get(index) || null; break; case UP_ARROW: nextButton = this._getNextButton(index, -1); break; case LEFT_ARROW: nextButton = this._getNextButton(index, this.dir === 'ltr' ? -1 : 1); break; case DOWN_ARROW: nextButton = this._getNextButton(index, 1); break; case RIGHT_ARROW: nextButton = this._getNextButton(index, this.dir === 'ltr' ? 1 : -1); break; default: return; } if (nextButton) { event.preventDefault(); nextButton._onButtonClick(); nextButton.focus(); } } _emitChangeEvent(toggle) { const event = new MatButtonToggleChange(toggle, this.value); this._rawValue = event.value; this._controlValueAccessorChangeFn(event.value); this.change.emit(event); } _syncButtonToggle(toggle, select, isUserInput = false, deferEvents = false) { if (!this.multiple && this.selected && !toggle.checked) { this.selected.checked = false; } if (this._selectionModel) { if (select) { this._selectionModel.select(toggle); } else { this._selectionModel.deselect(toggle); } } else { deferEvents = true; } if (deferEvents) { Promise.resolve().then(() => this._updateModelValue(toggle, isUserInput)); } else { this._updateModelValue(toggle, isUserInput); } } _isSelected(toggle) { return this._selectionModel && this._selectionModel.isSelected(toggle); } _isPrechecked(toggle) { if (typeof this._rawValue === 'undefined') { return false; } if (this.multiple && Array.isArray(this._rawValue)) { return this._rawValue.some(value => toggle.value != null && value === toggle.value); } return toggle.value === this._rawValue; } _initializeTabIndex() { this._buttonToggles.forEach(toggle => { toggle.tabIndex = -1; }); if (this.selected) { this.selected.tabIndex = 0; } else { for (let i = 0; i < this._buttonToggles.length; i++) { const toggle = this._buttonToggles.get(i); if (!toggle.disabled) { toggle.tabIndex = 0; break; } } } } _getNextButton(startIndex, offset) { const items = this._buttonToggles; for (let i = 1; i <= items.length; i++) { const index = (startIndex + offset * i + items.length) % items.length; const item = items.get(index); if (item && !item.disabled) { return item; } } return null; } _setSelectionByValue(value) { this._rawValue = value; if (!this._buttonToggles) { return; } const toggles = this._buttonToggles.toArray(); if (this.multiple && value) { if (!Array.isArray(value) && (typeof ngDevMode === 'undefined' || ngDevMode)) { throw Error('Value must be an array in multiple-selection mode.'); } this._clearSelection(); value.forEach(currentValue => this._selectValue(currentValue, toggles)); } else { this._clearSelection(); this._selectValue(value, toggles); } if (!this.multiple && toggles.every(toggle => toggle.tabIndex === -1)) { for (const toggle of toggles) { if (!toggle.disabled) { toggle.tabIndex = 0; break; } } } } _clearSelection() { this._selectionModel.clear(); this._buttonToggles.forEach(toggle => { toggle.checked = false; if (!this.multiple) { toggle.tabIndex = -1; } }); } _selectValue(value, toggles) { for (const toggle of toggles) { if (toggle.value === value) { toggle.checked = true; this._selectionModel.select(toggle); if (!this.multiple) { toggle.tabIndex = 0; } break; } } } _updateModelValue(toggle, isUserInput) { if (isUserInput) { this._emitChangeEvent(toggle); } this.valueChange.emit(this.value); } _markButtonsForCheck() { this._buttonToggles?.forEach(toggle => toggle._markForCheck()); } static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "22.0.0-next.5", ngImport: i0, type: MatButtonToggleGroup, deps: [], target: i0.ɵɵFactoryTarget.Directive }); static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "22.0.0-next.5", type: MatButtonToggleGroup, isStandalone: true, selector: "mat-button-toggle-group", inputs: { appearance: "appearance", name: "name", vertical: ["vertical", "vertical", booleanAttribute], value: "value", multiple: ["multiple", "multiple", booleanAttribute], disabled: ["disabled", "disabled", booleanAttribute], disabledInteractive: ["disabledInteractive", "disabledInteractive", booleanAttribute], hideSingleSelectionIndicator: ["hideSingleSelectionIndicator", "hideSingleSelectionIndicator", booleanAttribute], hideMultipleSelectionIndicator: ["hideMultipleSelectionIndicator", "hideMultipleSelectionIndicator", booleanAttribute] }, outputs: { valueChange: "valueChange", change: "change" }, host: { listeners: { "keydown": "_keydown($event)" }, properties: { "attr.role": "multiple ? 'group' : 'radiogroup'", "attr.aria-disabled": "disabled", "class.mat-button-toggle-vertical": "vertical", "class.mat-button-toggle-group-appearance-standard": "appearance === \"standard\"" }, classAttribute: "mat-button-toggle-group" }, providers: [MAT_BUTTON_TOGGLE_GROUP_VALUE_ACCESSOR, { provide: MAT_BUTTON_TOGGLE_GROUP, useExisting: MatButtonToggleGroup }], queries: [{ propertyName: "_buttonToggles", predicate: i0.forwardRef(() => MatButtonToggle), descendants: true }], exportAs: ["matButtonToggleGroup"], ngImport: i0 }); } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "22.0.0-next.5", ngImport: i0, type: MatButtonToggleGroup, decorators: [{ type: Directive, args: [{ selector: 'mat-button-toggle-group', providers: [MAT_BUTTON_TOGGLE_GROUP_VALUE_ACCESSOR, { provide: MAT_BUTTON_TOGGLE_GROUP, useExisting: MatButtonToggleGroup }], host: { 'class': 'mat-button-toggle-group', '(keydown)': '_keydown($event)', '[attr.role]': "multiple ? 'group' : 'radiogroup'", '[attr.aria-disabled]': 'disabled', '[class.mat-button-toggle-vertical]': 'vertical', '[class.mat-button-toggle-group-appearance-standard]': 'appearance === "standard"' }, exportAs: 'matButtonToggleGroup' }] }], ctorParameters: () => [], propDecorators: { _buttonToggles: [{ type: ContentChildren, args: [forwardRef(() => MatButtonToggle), { descendants: true }] }], appearance: [{ type: Input }], name: [{ type: Input }], vertical: [{ type: Input, args: [{ transform: booleanAttribute }] }], value: [{ type: Input }], valueChange: [{ type: Output }], multiple: [{ type: Input, args: [{ transform: booleanAttribute }] }], disabled: [{ type: Input, args: [{ transform: booleanAttribute }] }], disabledInteractive: [{ type: Input, args: [{ transform: booleanAttribute }] }], change: [{ type: Output }], hideSingleSelectionIndicator: [{ type: Input, args: [{ transform: booleanAttribute }] }], hideMultipleSelectionIndicator: [{ type: Input, args: [{ transform: booleanAttribute }] }] } }); class MatButtonToggle { _changeDetectorRef = inject(ChangeDetectorRef); _elementRef = inject(ElementRef); _focusMonitor = inject(FocusMonitor); _idGenerator = inject(_IdGenerator); _animationDisabled = _animationsDisabled(); _checked = false; ariaLabel; ariaLabelledby = null; _buttonElement; buttonToggleGroup; get buttonId() { return `${this.id}-button`; } id; name; value; get tabIndex() { return this._tabIndex(); } set tabIndex(value) { this._tabIndex.set(value); } _tabIndex; disableRipple = false; get appearance() { return this.buttonToggleGroup ? this.buttonToggleGroup.appearance : this._appearance; } set appearance(value) { this._appearance = value; } _appearance; get checked() { return this.buttonToggleGroup ? this.buttonToggleGroup._isSelected(this) : this._checked; } set checked(value) { if (value !== this._checked) { this._checked = value; if (this.buttonToggleGroup) { this.buttonToggleGroup._syncButtonToggle(this, this._checked); } this._changeDetectorRef.markForCheck(); } } get disabled() { return this._disabled || this.buttonToggleGroup && this.buttonToggleGroup.disabled; } set disabled(value) { this._disabled = value; } _disabled = false; get disabledInteractive() { return this._disabledInteractive || this.buttonToggleGroup !== null && this.buttonToggleGroup.disabledInteractive; } set disabledInteractive(value) { this._disabledInteractive = value; } _disabledInteractive; change = new EventEmitter(); constructor() { inject(_CdkPrivateStyleLoader).load(_StructuralStylesLoader); const toggleGroup = inject(MAT_BUTTON_TOGGLE_GROUP, { optional: true }); const defaultTabIndex = inject(new HostAttributeToken('tabindex'), { optional: true }) || ''; const defaultOptions = inject(MAT_BUTTON_TOGGLE_DEFAULT_OPTIONS, { optional: true }); this._tabIndex = signal(parseInt(defaultTabIndex) || 0, ...(ngDevMode ? [{ debugName: "_tabIndex" }] : [])); this.buttonToggleGroup = toggleGroup; this._appearance = defaultOptions && defaultOptions.appearance ? defaultOptions.appearance : 'standard'; this._disabledInteractive = defaultOptions?.disabledInteractive ?? false; } ngOnInit() { const group = this.buttonToggleGroup; this.id = this.id || this._idGenerator.getId('mat-button-toggle-'); if (group) { if (group._isPrechecked(this)) { this.checked = true; } else if (group._isSelected(this) !== this._checked) { group._syncButtonToggle(this, this._checked); } } } ngAfterViewInit() { if (!this._animationDisabled) { this._elementRef.nativeElement.classList.add('mat-button-toggle-animations-enabled'); } this._focusMonitor.monitor(this._elementRef, true); } ngOnDestroy() { const group = this.buttonToggleGroup; this._focusMonitor.stopMonitoring(this._elementRef); if (group && group._isSelected(this)) { group._syncButtonToggle(this, false, false, true); } } focus(options) { this._buttonElement.nativeElement.focus(options); } _onButtonClick() { if (this.disabled) { return; } const newChecked = this.isSingleSelector() ? true : !this._checked; if (newChecked !== this._checked) { this._checked = newChecked; if (this.buttonToggleGroup) { this.buttonToggleGroup._syncButtonToggle(this, this._checked, true); this.buttonToggleGroup._onTouched(); } } if (this.isSingleSelector()) { const focusable = this.buttonToggleGroup._buttonToggles.find(toggle => { return toggle.tabIndex === 0; }); if (focusable) { focusable.tabIndex = -1; } this.tabIndex = 0; } this.change.emit(new MatButtonToggleChange(this, this.value)); } _markForCheck() { this._changeDetectorRef.markForCheck(); } _getButtonName() { if (this.isSingleSelector()) { return this.buttonToggleGroup.name; } return this.name || null; } isSingleSelector() { return this.buttonToggleGroup && !this.buttonToggleGroup.multiple; } static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "22.0.0-next.5", ngImport: i0, type: MatButtonToggle, deps: [], target: i0.ɵɵFactoryTarget.Component }); static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "22.0.0-next.5", type: MatButtonToggle, isStandalone: true, selector: "mat-button-toggle", inputs: { ariaLabel: ["aria-label", "ariaLabel"], ariaLabelledby: ["aria-labelledby", "ariaLabelledby"], id: "id", name: "name", value: "value", tabIndex: "tabIndex", disableRipple: ["disableRipple", "disableRipple", booleanAttribute], appearance: "appearance", checked: ["checked", "checked", booleanAttribute], disabled: ["disabled", "disabled", booleanAttribute], disabledInteractive: ["disabledInteractive", "disabledInteractive", booleanAttribute] }, outputs: { change: "change" }, host: { attributes: { "role": "presentation" }, listeners: { "focus": "focus()" }, properties: { "class.mat-button-toggle-standalone": "!buttonToggleGroup", "class.mat-button-toggle-checked": "checked", "class.mat-button-toggle-disabled": "disabled", "class.mat-button-toggle-disabled-interactive": "disabledInteractive", "class.mat-button-toggle-appearance-standard": "appearance === \"standard\"", "attr.aria-label": "null", "attr.aria-labelledby": "null", "attr.id": "id", "attr.name": "null" }, classAttribute: "mat-button-toggle" }, viewQueries: [{ propertyName: "_buttonElement", first: true, predicate: ["button"], descendants: true }], exportAs: ["matButtonToggle"], ngImport: i0, template: "<button #button class=\"mat-button-toggle-button mat-focus-indicator\"\n type=\"button\"\n [id]=\"buttonId\"\n [attr.role]=\"isSingleSelector() ? 'radio' : 'button'\"\n [attr.tabindex]=\"disabled && !disabledInteractive ? -1 : tabIndex\"\n [attr.aria-pressed]=\"!isSingleSelector() ? checked : null\"\n [attr.aria-checked]=\"isSingleSelector() ? checked : null\"\n [disabled]=\"(disabled && !disabledInteractive) || null\"\n [attr.name]=\"_getButtonName()\"\n [attr.aria-label]=\"ariaLabel\"\n [attr.aria-labelledby]=\"ariaLabelledby\"\n [attr.aria-disabled]=\"disabled && disabledInteractive ? 'true' : null\"\n (click)=\"_onButtonClick()\">\n @if (buttonToggleGroup && (\n !buttonToggleGroup.multiple && !buttonToggleGroup.hideSingleSelectionIndicator ||\n buttonToggleGroup.multiple && !buttonToggleGroup.hideMultipleSelectionIndicator)\n ) {\n <div class=\"mat-button-toggle-checkbox-wrapper\">\n <mat-pseudo-checkbox\n [disabled]=\"disabled\"\n state=\"checked\"\n aria-hidden=\"true\"\n appearance=\"minimal\"/>\n </div>\n }\n\n <span class=\"mat-button-toggle-label-content\">\n <ng-content></ng-content>\n </span>\n</button>\n\n<span class=\"mat-button-toggle-focus-overlay\"></span>\n<span class=\"mat-button-toggle-ripple\" matRipple\n [matRippleTrigger]=\"button\"\n [matRippleDisabled]=\"disableRipple || disabled\">\n</span>\n", styles: [".mat-button-toggle-standalone,\n.mat-button-toggle-group {\n position: relative;\n display: inline-flex;\n flex-direction: row;\n white-space: nowrap;\n overflow: hidden;\n -webkit-tap-highlight-color: transparent;\n border-radius: var(--mat-button-toggle-legacy-shape);\n transform: translateZ(0);\n}\n.mat-button-toggle-standalone:not([class*=mat-elevation-z]),\n.mat-button-toggle-group:not([class*=mat-elevation-z]) {\n box-shadow: 0px 3px 1px -2px rgba(0, 0, 0, 0.2), 0px 2px 2px 0px rgba(0, 0, 0, 0.14), 0px 1px 5px 0px rgba(0, 0, 0, 0.12);\n}\n@media (forced-colors: active) {\n .mat-button-toggle-standalone,\n .mat-button-toggle-group {\n outline: solid 1px;\n }\n}\n\n.mat-button-toggle-standalone.mat-button-toggle-appearance-standard,\n.mat-button-toggle-group-appearance-standard {\n border-radius: var(--mat-button-toggle-shape, var(--mat-sys-corner-extra-large));\n border: solid 1px var(--mat-button-toggle-divider-color, var(--mat-sys-outline));\n}\n.mat-button-toggle-standalone.mat-button-toggle-appearance-standard .mat-pseudo-checkbox,\n.mat-button-toggle-group-appearance-standard .mat-pseudo-checkbox {\n --mat-pseudo-checkbox-minimal-selected-checkmark-color: var(--mat-button-toggle-selected-state-text-color, var(--mat-sys-on-secondary-container));\n}\n.mat-button-toggle-standalone.mat-button-toggle-appearance-standard:not([class*=mat-elevation-z]),\n.mat-button-toggle-group-appearance-standard:not([class*=mat-elevation-z]) {\n box-shadow: none;\n}\n@media (forced-colors: active) {\n .mat-button-toggle-standalone.mat-button-toggle-appearance-standard,\n .mat-button-toggle-group-appearance-standard {\n outline: 0;\n }\n}\n\n.mat-button-toggle-vertical {\n flex-direction: column;\n}\n.mat-button-toggle-vertical .mat-button-toggle-label-content {\n display: block;\n}\n\n.mat-button-toggle {\n white-space: nowrap;\n position: relative;\n color: var(--mat-button-toggle-legacy-text-color);\n font-family: var(--mat-button-toggle-legacy-label-text-font);\n font-size: var(--mat-button-toggle-legacy-label-text-size);\n line-height: var(--mat-button-toggle-legacy-label-text-line-height);\n font-weight: var(--mat-button-toggle-legacy-label-text-weight);\n letter-spacing: var(--mat-button-toggle-legacy-label-text-tracking);\n --mat-pseudo-checkbox-minimal-selected-checkmark-color: var(--mat-button-toggle-legacy-selected-state-text-color);\n}\n.mat-button-toggle.cdk-keyboard-focused .mat-button-toggle-focus-overlay {\n opacity: var(--mat-button-toggle-legacy-focus-state-layer-opacity);\n}\n.mat-button-toggle .mat-icon svg {\n vertical-align: top;\n}\n\n.mat-button-toggle-checkbox-wrapper {\n display: inline-block;\n justify-content: flex-start;\n align-items: center;\n width: 0;\n height: 18px;\n line-height: 18px;\n overflow: hidden;\n box-sizing: border-box;\n position: absolute;\n top: 50%;\n left: 16px;\n transform: translate3d(0, -50%, 0);\n}\n[dir=rtl] .mat-button-toggle-checkbox-wrapper {\n left: auto;\n right: 16px;\n}\n.mat-button-toggle-appearance-standard .mat-button-toggle-checkbox-wrapper {\n left: 12px;\n}\n[dir=rtl] .mat-button-toggle-appearance-standard .mat-button-toggle-checkbox-wrapper {\n left: auto;\n right: 12px;\n}\n.mat-button-toggle-checked .mat-button-toggle-checkbox-wrapper {\n width: 18px;\n}\n.mat-button-toggle-animations-enabled .mat-button-toggle-checkbox-wrapper {\n transition: width 150ms 45ms cubic-bezier(0.4, 0, 0.2, 1);\n}\n.mat-button-toggle-vertical .mat-button-toggle-checkbox-wrapper {\n transition: none;\n}\n\n.mat-button-toggle-checked {\n color: var(--mat-button-toggle-legacy-selected-state-text-color);\n background-color: var(--mat-button-toggle-legacy-selected-state-background-color);\n}\n\n.mat-button-toggle-disabled {\n pointer-events: none;\n color: var(--mat-button-toggle-legacy-disabled-state-text-color);\n background-color: var(--mat-button-toggle-legacy-disabled-state-background-color);\n --mat-pseudo-checkbox-minimal-disabled-selected-checkmark-color: var(--mat-button-toggle-legacy-disabled-state-text-color);\n}\n.mat-button-toggle-disabled.mat-button-toggle-checked {\n background-color: var(--mat-button-toggle-legacy-disabled-selected-state-background-color);\n}\n\n.mat-button-toggle-disabled-interactive {\n pointer-events: auto;\n}\n\n.mat-button-toggle-appearance-standard {\n color: var(--mat-button-toggle-text-color, var(--mat-sys-on-surface));\n background-color: var(--mat-button-toggle-background-color, transparent);\n font-family: var(--mat-button-toggle-label-text-font, var(--mat-sys-label-large-font));\n font-size: var(--mat-button-toggle-label-text-size, var(--mat-sys-label-large-size));\n line-height: var(--mat-button-toggle-label-text-line-height, var(--mat-sys-label-large-line-height));\n font-weight: var(--mat-button-toggle-label-text-weight, var(--mat-sys-label-large-weight));\n letter-spacing: var(--mat-button-toggle-label-text-tracking, var(--mat-sys-label-large-tracking));\n}\n.mat-button-toggle-group-appearance-standard .mat-button-toggle-appearance-standard + .mat-button-toggle-appearance-standard {\n border-left: solid 1px var(--mat-button-toggle-divider-color, var(--mat-sys-outline));\n}\n[dir=rtl] .mat-button-toggle-group-appearance-standard .mat-button-toggle-appearance-standard + .mat-button-toggle-appearance-standard {\n border-left: none;\n border-right: solid 1px var(--mat-button-toggle-divider-color, var(--mat-sys-outline));\n}\n.mat-button-toggle-group-appearance-standard.mat-button-toggle-vertical .mat-button-toggle-appearance-standard + .mat-button-toggle-appearance-standard {\n border-left: none;\n border-right: none;\n border-top: solid 1px var(--mat-button-toggle-divider-color, var(--mat-sys-outline));\n}\n.mat-button-toggle-appearance-standard.mat-button-toggle-checked {\n color: var(--mat-button-toggle-selected-state-text-color, var(--mat-sys-on-secondary-container));\n background-color: var(--mat-button-toggle-selected-state-background-color, var(--mat-sys-secondary-container));\n}\n.mat-button-toggle-appearance-standard.mat-button-toggle-disabled {\n color: var(--mat-button-toggle-disabled-state-text-color, color-mix(in srgb, var(--mat-sys-on-surface) 38%, transparent));\n background-color: var(--mat-button-toggle-disabled-state-background-color, transparent);\n}\n.mat-button-toggle-appearance-standard.mat-button-toggle-disabled .mat-pseudo-checkbox {\n --mat-pseudo-checkbox-minimal-disabled-selected-checkmark-color: var(--mat-button-toggle-disabled-selected-state-text-color, color-mix(in srgb, var(--mat-sys-on-surface) 38%, transparent));\n}\n.mat-button-toggle-appearance-standard.mat-button-toggle-disabled.mat-button-toggle-checked {\n color: var(--mat-button-toggle-disabled-selected-state-text-color, color-mix(in srgb, var(--mat-sys-on-surface) 38%, transparent));\n background-color: var(--mat-button-toggle-disabled-selected-state-background-color, color-mix(in srgb, var(--mat-sys-on-surface) 12%, transparent));\n}\n.mat-button-toggle-appearance-standard .mat-button-toggle-focus-overlay {\n background-color: var(--mat-button-toggle-state-layer-color, var(--mat-sys-on-surface));\n}\n.mat-button-toggle-appearance-standard:hover .mat-button-toggle-focus-overlay {\n opacity: var(--mat-button-toggle-hover-state-layer-opacity, var(--mat-sys-hover-state-layer-opacity));\n}\n.mat-button-toggle-appearance-standard.cdk-keyboard-focused .mat-button-toggle-focus-overlay {\n opacity: var(--mat-button-toggle-focus-state-layer-opacity, var(--mat-sys-focus-state-layer-opacity));\n}\n@media (hover: none) {\n .mat-button-toggle-appearance-standard:hover .mat-button-toggle-focus-overlay {\n display: none;\n }\n}\n\n.mat-button-toggle-label-content {\n -webkit-user-select: none;\n user-select: none;\n display: inline-block;\n padding: 0 16px;\n line-height: var(--mat-button-toggle-legacy-height);\n position: relative;\n}\n.mat-button-toggle-appearance-standard .mat-button-toggle-label-content {\n padding: 0 12px;\n line-height: var(--mat-button-toggle-height, 40px);\n}\n\n.mat-button-toggle-label-content > * {\n vertical-align: middle;\n}\n\n.mat-button-toggle-focus-overlay {\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n position: absolute;\n border-radius: inherit;\n pointer-events: none;\n opacity: 0;\n background-color: var(--mat-button-toggle-legacy-state-layer-color);\n}\n\n@media (forced-colors: active) {\n .mat-button-toggle-checked .mat-button-toggle-focus-overlay {\n border-bottom: solid 500px;\n opacity: 0.5;\n height: 0;\n }\n .mat-button-toggle-checked:hover .mat-button-toggle-focus-overlay {\n opacity: 0.6;\n }\n .mat-button-toggle-checked.mat-button-toggle-appearance-standard .mat-button-toggle-focus-overlay {\n border-bottom: solid 500px;\n }\n}\n.mat-button-toggle .mat-button-toggle-ripple {\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n position: absolute;\n pointer-events: none;\n}\n\n.mat-button-toggle-button {\n border: 0;\n background: none;\n color: inherit;\n padding: 0;\n margin: 0;\n font: inherit;\n outline: none;\n width: 100%;\n cursor: pointer;\n}\n.mat-button-toggle-animations-enabled .mat-button-toggle-button {\n transition: padding 150ms 45ms cubic-bezier(0.4, 0, 0.2, 1);\n}\n.mat-button-toggle-vertical .mat-button-toggle-button {\n transition: none;\n}\n.mat-button-toggle-disabled .mat-button-toggle-button {\n cursor: default;\n}\n.mat-button-toggle-button::-moz-focus-inner {\n border: 0;\n}\n.mat-button-toggle-checked .mat-button-toggle-button:has(.mat-button-toggle-checkbox-wrapper) {\n padding-left: 30px;\n}\n[dir=rtl] .mat-button-toggle-checked .mat-button-toggle-button:has(.mat-button-toggle-checkbox-wrapper) {\n padding-left: 0;\n padding-right: 30px;\n}\n\n.mat-button-toggle-standalone.mat-button-toggle-appearance-standard {\n --mat-focus-indicator-border-radius: var(--mat-button-toggle-shape, var(--mat-sys-corner-extra-large));\n}\n\n.mat-button-toggle-group-appearance-standard:not(.mat-button-toggle-vertical) .mat-button-toggle:last-of-type .mat-button-toggle-button::before {\n border-top-right-radius: var(--mat-button-toggle-shape, var(--mat-sys-corner-extra-large));\n border-bottom-right-radius: var(--mat-button-toggle-shape, var(--mat-sys-corner-extra-large));\n}\n.mat-button-toggle-group-appearance-standard:not(.mat-button-toggle-vertical) .mat-button-toggle:first-of-type .mat-button-toggle-button::before {\n border-top-left-radius: var(--mat-button-toggle-shape, var(--mat-sys-corner-extra-large));\n border-bottom-left-radius: var(--mat-button-toggle-shape, var(--mat-sys-corner-extra-large));\n}\n\n.mat-button-toggle-group-appearance-standard.mat-button-toggle-vertical .mat-button-toggle:last-of-type .mat-button-toggle-button::before {\n border-bottom-right-radius: var(--mat-button-toggle-shape, var(--mat-sys-corner-extra-large));\n border-bottom-left-radius: var(--mat-button-toggle-shape, var(--mat-sys-corner-extra-large));\n}\n.mat-button-toggle-group-appearance-standard.mat-button-toggle-vertical .mat-button-toggle:first-of-type .mat-button-toggle-button::before {\n border-top-right-radius: var(--mat-button-toggle-shape, var(--mat-sys-corner-extra-large));\n border-top-left-radius: var(--mat-button-toggle-shape, var(--mat-sys-corner-extra-large));\n}\n"], dependencies: [{ kind: "directive", type: MatRipple, selector: "[mat-ripple], [matRipple]", inputs: ["matRippleColor", "matRippleUnbounded", "matRippleCentered", "matRippleRadius", "matRippleAnimation", "matRippleDisabled", "matRippleTrigger"], exportAs: ["matRipple"] }, { kind: "component", type: MatPseudoCheckbox, selector: "mat-pseudo-checkbox", inputs: ["state", "disabled", "appearance"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "22.0.0-next.5", ngImport: i0, type: MatButtonToggle, decorators: [{ type: Component, args: [{ selector: 'mat-button-toggle', encapsulation: ViewEncapsulation.None, exportAs: 'matButtonToggle', changeDetection: ChangeDetectionStrategy.OnPush, host: { '[class.mat-button-toggle-standalone]': '!buttonToggleGroup', '[class.mat-button-toggle-checked]': 'checked', '[class.mat-button-toggle-disabled]': 'disabled', '[class.mat-button-toggle-disabled-interactive]': 'disabledInteractive', '[class.mat-button-toggle-appearance-standard]': 'appearance === "standard"', 'class': 'mat-button-toggle', '[attr.aria-label]': 'null', '[attr.aria-labelledby]': 'null', '[attr.id]': 'id', '[attr.name]': 'null', '(focus)': 'focus()', 'role': 'presentation' }, imports: [MatRipple, MatPseudoCheckbox], template: "<button #button class=\"mat-button-toggle-button mat-focus-indicator\"\n type=\"button\"\n [id]=\"buttonId\"\n [attr.role]=\"isSingleSelector() ? 'radio' : 'button'\"\n [attr.tabindex]=\"disabled && !disabledInteractive ? -1 : tabIndex\"\n [attr.aria-pressed]=\"!isSingleSelector() ? checked : null\"\n [attr.aria-checked]=\"isSingleSelector() ? checked : null\"\n [disabled]=\"(disabled && !disabledInteractive) || null\"\n [attr.name]=\"_getButtonName()\"\n [attr.aria-label]=\"ariaLabel\"\n [attr.aria-labelledby]=\"ariaLabelledby\"\n [attr.aria-disabled]=\"disabled && disabledInteractive ? 'true' : null\"\n (click)=\"_onButtonClick()\">\n @if (buttonToggleGroup && (\n !buttonToggleGroup.multiple && !buttonToggleGroup.hideSingleSelectionIndicator ||\n buttonToggleGroup.multiple && !buttonToggleGroup.hideMultipleSelectionIndicator)\n ) {\n <div class=\"mat-button-toggle-checkbox-wrapper\">\n <mat-pseudo-checkbox\n [disabled]=\"disabled\"\n state=\"checked\"\n aria-hidden=\"true\"\n appearance=\"minimal\"/>\n </div>\n }\n\n <span class=\"mat-button-toggle-label-content\">\n <ng-content></ng-content>\n </span>\n</button>\n\n<span class=\"mat-button-toggle-focus-overlay\"></span>\n<span class=\"mat-button-toggle-ripple\" matRipple\n [matRippleTrigger]=\"button\"\n [matRippleDisabled]=\"disableRipple || disabled\">\n</span>\n", styles: [".mat-button-toggle-standalone,\n.mat-button-toggle-group {\n position: relative;\n display: inline-flex;\n flex-direction: row;\n white-space: nowrap;\n overflow: hidden;\n -webkit-tap-highlight-color: transparent;\n border-radius: var(--mat-button-toggle-legacy-shape);\n transform: translateZ(0);\n}\n.mat-button-toggle-standalone:not([class*=mat-elevation-z]),\n.mat-button-toggle-group:not([class*=mat-elevation-z]) {\n box-shadow: 0px 3px 1px -2px rgba(0, 0, 0, 0.2), 0px 2px 2px 0px rgba(0, 0, 0, 0.14), 0px 1px 5px 0px rgba(0, 0, 0, 0.12);\n}\n@media (forced-colors: active) {\n .mat-button-toggle-standalone,\n .mat-button-toggle-group {\n outline: solid 1px;\n }\n}\n\n.mat-button-toggle-standalone.mat-button-toggle-appearance-standard,\n.mat-button-toggle-group-appearance-standard {\n border-radius: var(--mat-button-toggle-shape, var(--mat-sys-corner-extra-large));\n border: solid 1px var(--mat-button-toggle-divider-color, var(--mat-sys-outline));\n}\n.mat-button-toggle-standalone.mat-button-toggle-appearance-standard .mat-pseudo-checkbox,\n.mat-button-toggle-group-appearance-standard .mat-pseudo-checkbox {\n --mat-pseudo-checkbox-minimal-selected-checkmark-color: var(--mat-button-toggle-selected-state-text-color, var(--mat-sys-on-secondary-container));\n}\n.mat-button-toggle-standalone.mat-button-toggle-appearance-standard:not([class*=mat-elevation-z]),\n.mat-button-toggle-group-appearance-standard:not([class*=mat-elevation-z]) {\n box-shadow: none;\n}\n@media (forced-colors: active) {\n .mat-button-toggle-standalone.mat-button-toggle-appearance-standard,\n .mat-button-toggle-group-appearance-standard {\n outline: 0;\n }\n}\n\n.mat-button-toggle-vertical {\n flex-direction: column;\n}\n.mat-button-toggle-vertical .mat-button-toggle-label-content {\n display: block;\n}\n\n.mat-button-toggle {\n white-space: nowrap;\n position: relative;\n color: var(--mat-button-toggle-legacy-text-color);\n font-family: var(--mat-button-toggle-legacy-label-text-font);\n font-size: var(--mat-button-toggle-legacy-label-text-size);\n line-height: var(--mat-button-toggle-legacy-label-text-line-height);\n font-weight: var(--mat-button-toggle-legacy-label-text-weight);\n letter-spacing: var(--mat-button-toggle-legacy-label-text-tracking);\n --mat-pseudo-checkbox-minimal-selected-checkmark-color: var(--mat-button-toggle-legacy-selected-state-text-color);\n}\n.mat-button-toggle.cdk-keyboard-focused .mat-button-toggle-focus-overlay {\n opacity: var(--mat-button-toggle-legacy-focus-state-layer-opacity);\n}\n.mat-button-toggle .mat-icon svg {\n vertical-align: top;\n}\n\n.mat-button-toggle-checkbox-wrapper {\n display: inline-block;\n justify-content: flex-start;\n align-items: center;\n width: 0;\n height: 18px;\n line-height: 18px;\n overflow: hidden;\n box-sizing: border-box;\n position: absolute;\n top: 50%;\n left: 16px;\n transform: translate3d(0, -50%, 0);\n}\n[dir=rtl] .mat-button-toggle-checkbox-wrapper {\n left: auto;\n right: 16px;\n}\n.mat-button-toggle-appearance-standard .mat-button-toggle-checkbox-wrapper {\n left: 12px;\n}\n[dir=rtl] .mat-button-toggle-appearance-standard .mat-button-toggle-checkbox-wrapper {\n left: auto;\n right: 12px;\n}\n.mat-button-toggle-checked .mat-button-toggle-checkbox-wrapper {\n width: 18px;\n}\n.mat-button-toggle-animations-enabled .mat-button-toggle-checkbox-wrapper {\n transition: width 150ms 45ms cubic-bezier(0.4, 0, 0.2, 1);\n}\n.mat-button-toggle-vertical .mat-button-toggle-checkbox-wrapper {\n transition: none;\n}\n\n.mat-button-toggle-checked {\n color: var(--mat-button-toggle-legacy-selected-state-text-color);\n background-color: var(--mat-button-toggle-legacy-selected-state-background-color);\n}\n\n.mat-button-toggle-disabled {\n pointer-events: none;\n color: var(--mat-button-toggle-legacy-disabled-state-text-color);\n background-color: var(--mat-button-toggle-legacy-disabled-state-background-color);\n --mat-pseudo-checkbox-minimal-disabled-selected-checkmark-color: var(--mat-button-toggle-legacy-disabled-state-text-color);\n}\n.mat-button-toggle-disabled.mat-button-toggle-checked {\n background-color: var(--mat-button-toggle-legacy-disabled-selected-state-background-color);\n}\n\n.mat-button-toggle-disabled-interactive {\n pointer-events: auto;\n}\n\n.mat-button-toggle-appearance-standard {\n color: var(--mat-button-toggle-text-color, var(--mat-sys-on-surface));\n background-color: var(--mat-button-toggle-background-color, transparent);\n font-family: var(--mat-button-toggle-label-text-font, var(--mat-sys-label-large-font));\n font-size: var(--mat-button-toggle-label-text-size, var(--mat-sys-label-large-size));\n line-height: var(--mat-button-toggle-label-text-line-height, var(--mat-sys-label-large-line-height));\n font-weight: var(--mat-button-toggle-label-text-weight, var(--mat-sys-label-large-weight));\n letter-spacing: var(--mat-button-toggle-label-text-tracking, var(--mat-sys-label-large-tracking));\n}\n.mat-button-toggle-group-appearance-standard .mat-button-toggle-appearance-standard + .mat-button-toggle-appearance-standard {\n border-left: solid 1px var(--mat-button-toggle-divider-color, var(--mat-sys-outline));\n}\n[dir=rtl] .mat-button-toggle-group-appearance-standard .mat-button-toggle-appearance-standard + .mat-button-toggle-appearance-standard {\n border-left: none;\n border-right: solid 1px var(--mat-button-toggle-divider-color, var(--mat-sys-outline));\n}\n.mat-button-toggle-group-appearance-standard.mat-button-toggle-vertical .mat-button-toggle-appearance-standard + .mat-button-toggle-appearance-standard {\n border-left: none;\n border-right: none;\n border-top: solid 1px var(--mat-button-toggle-divider-color, var(--mat-sys-outline));\n}\n.mat-button-toggle-appearance-standard.mat-button-toggle-checked {\n color: var(--mat-button-toggle-selected-state-text-color, var(--mat-sys-on-secondary-container));\n background-color: var(--mat-button-toggle-selected-state-background-color, var(--mat-sys-secondary-container));\n}\n.mat-button-toggle-appearance-standard.mat-button-toggle-disabled {\n color: var(--mat-button-toggle-disabled-state-text-color, color-mix(in srgb, var(--mat-sys-on-surface) 38%, transparent));\n background-color: var(--mat-button-toggle-disabled-state-background-color, transparent);\n}\n.mat-button-toggle-appearance-standard.mat-button-toggle-disabled .mat-pseudo-checkbox {\n --mat-pseudo-checkbox-minimal-disabled-selected-checkmark-color: var(--mat-button-toggle-disabled-selected-state-text-color, color-mix(in srgb, var(--mat-sys-on-surface) 38%, transparent));\n}\n.mat-button-toggle-appearance-standard.mat-button-toggle-disabled.mat-button-toggle-checked {\n color: var(--mat-button-toggle-disabled-selected-state-text-color, color-mix(in srgb, var(--mat-sys-on-surface) 38%, transparent));\n background-color: var(--mat-button-toggle-disabled-selected-state-background-color, color-mix(in srgb, var(--mat-sys-on-surface) 12%, transparent));\n}\n.mat-button-toggle-appearance-standard .mat-button-toggle-focus-overlay {\n background-color: var(--mat-button-toggle-state-layer-color, var(--mat-sys-on-surface));\n}\n.mat-button-toggle-appearance-standard:hover .mat-button-toggle-focus-overlay {\n opacity: var(--mat-button-toggle-hover-state-layer-opacity, var(--mat-sys-hover-state-layer-opacity));\n}\n.mat-button-toggle-appearance-standard.cdk-keyboard-focused .mat-button-toggle-focus-overlay {\n opacity: var(--mat-button-toggle-focus-state-layer-opacity, var(--mat-sys-focus-state-layer-opacity));\n}\n@media (hover: none) {\n .mat-button-toggle-appearance-standard:hover .mat-button-toggle-focus-overlay {\n display: none;\n }\n}\n\n.mat-button-toggle-label-content {\n -webkit-user-select: none;\n user-select: none;\n display: inline-block;\n padding: 0 16px;\n line-height: var(--mat-button-toggle-legacy-height);\n position: relative;\n}\n.mat-button-toggle-appearance-standard .mat-button-toggle-label-content {\n padding: 0 12px;\n line-height: var(--mat-button-toggle-height, 40px);\n}\n\n.mat-button-toggle-label-content > * {\n vertical-align: middle;\n}\n\n.mat-button-toggle-focus-overlay {\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n position: absolute;\n border-radius: inherit;\n pointer-events: none;\n opacity: 0;\n background-color: var(--mat-button-toggle-legacy-state-layer-color);\n}\n\n@media (forced-colors: active) {\n .mat-button-toggle-checked .mat-button-toggle-focus-overlay {\n border-bottom: solid 500px;\n opacity: 0.5;\n height: 0;\n }\n .mat-button-toggle-checked:hover .mat-button-toggle-focus-overlay {\n opacity: 0.6;\n }\n .mat-button-toggle-checked.mat-button-toggle-appearance-standard .mat-button-toggle-focus-overlay {\n border-bottom: solid 500px;\n }\n}\n.mat-button-toggle .mat-button-toggle-ripple {\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n position: absolute;\n pointer-events: none;\n}\n\n.mat-button-toggle-button {\n border: 0;\n background: none;\n color: inherit;\n padding: 0;\n margin: 0;\n font: inherit;\n outline: none;\n width: 100%;\n cursor: pointer;\n}\n.mat-button-toggle-animations-enabled .mat-button-toggle-button {\n transition: padding 150ms 45ms cubic-bezier(0.4, 0, 0.2, 1);\n}\n.mat-button-toggle-vertical .mat-button-toggle-button {\n transition: none;\n}\n.mat-button-toggle-disabled .mat-button-toggle-button {\n cursor: default;\n}\n.mat-button-toggle-button::-moz-focus-inner {\n border: 0;\n}\n.mat-button-toggle-checked .mat-button-toggle-button:has(.mat-button-toggle-checkbox-wrapper) {\n padding-left: 30px;\n}\n[dir=rtl] .mat-button-toggle-checked .mat-button-toggle-button:has(.mat-button-toggle-checkbox-wrapper) {\n padding-left: 0;\n padding-right: 30px;\n}\n\n.mat-button-toggle-standalone.mat-button-toggle-appearance-standard {\n --mat-focus-indicator-border-radius: var(--mat-button-toggle-shape, var(--mat-sys-corner-extra-large));\n}\n\n.mat-button-toggle-group-appearance-standard:not(.mat-button-toggle-vertical) .mat-button-toggle:last-of-type .mat-button-toggle-button::before {\n border-top-right-radius: var(--mat-button-toggle-shape, var(--mat-sys-corner-extra-large));\n border-bottom-right-radius: var(--mat-button-toggle-shape, var(--mat-sys-corner-extra-large));\n}\n.mat-button-toggle-group-appearance-standard:not(.mat-button-toggle-vertical) .mat-button-toggle:first-of-type .mat-button-toggle-button::before {\n border-top-left-radius: var(--mat-button-toggle-shape, var(--mat-sys-corner-extra-large));\n border-bottom-left-radius: var(--mat-button-toggle-shape, var(--mat-sys-corner-extra-large));\n}\n\n.mat-button-toggle-group-appearance-standard.mat-button-toggle-vertical .mat-button-toggle:last-of-type .mat-button-toggle-button::before {\n border-bottom-right-radius: var(--mat-button-toggle-shape, var(--mat-sys-corner-extra-large));\n border-bottom-left-radius: var(--mat-button-toggle-shape, var(--mat-sys-corner-extra-large));\n}\n.mat-button-toggle-group-appearance-standard.mat-button-toggle-vertical .mat-button-toggle:first-of-type .mat-button-toggle-button::before {\n border-top-right-radius: var(--mat-button-toggle-shape, var(--mat-sys-corner-extra-large));\n border-top-left-radius: var(--mat-button-toggle-shape, var(--mat-sys-corner-extra-large));\n}\n"] }] }], ctorParameters: () => [], propDecorators: { ariaLabel: [{ type: Input, args: ['aria-label'] }], ariaLabelledby: [{ type: Input, args: ['aria-labelledby'] }], _buttonElement: [{ type: ViewChild, args: ['button'] }], id: [{ type: Input }], name: [{ type: Input }], value: [{ type: Input }], tabIndex: [{ type: Input }], disableRipple: [{ type: Input, args: [{ transform: booleanAttribute }] }], appearance: [{ type: Input }], checked: [{ type: Input, args: [{ transform: booleanAttribute }] }], disabled: [{ type: Input, args: [{ transform: booleanAttribute }] }], disabledInteractive: [{ type: Input, args: [{ transform: booleanAttribute }] }], change: [{ type: Output }] } }); class MatButtonToggleModule { static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "22.0.0-next.5", ngImport: i0, type: MatButtonToggleModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "22.0.0-next.5", ngImport: i0, type: MatButtonToggleModule, imports: [MatRippleModule, MatButtonToggleGroup, MatButtonToggle], exports: [BidiModule, MatButtonToggleGroup, MatButtonToggle] }); static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "22.0.0-next.5", ngImport: i0, type: MatButtonToggleModule, imports: [MatRippleModule, MatButtonToggle, BidiModule] }); } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "22.0.0-next.5", ngImport: i0, type: MatButtonToggleModule, decorators: [{ type: NgModule, args: [{ imports: [MatRippleModule, MatButtonToggleGroup, MatButtonToggle], exports: [BidiModule, MatButtonToggleGroup, MatButtonToggle] }] }] }); export { MAT_BUTTON_TOGGLE_DEFAULT_OPTIONS, MAT_BUTTON_TOGGLE_GROUP, MAT_BUTTON_TOGGLE_GROUP_VALUE_ACCESSOR, MatButtonToggle, MatButtonToggleChange, MatButtonToggleGroup, MatButtonToggleModule }; //# sourceMappingURL=button-toggle.mjs.map