You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
275 lines
35 KiB
275 lines
35 KiB
/**
|
|
* @license
|
|
* Copyright Google LLC All Rights Reserved.
|
|
*
|
|
* Use of this source code is governed by an MIT-style license that can be
|
|
* found in the LICENSE file at https://angular.io/license
|
|
*/
|
|
import { FocusMonitor } from '@angular/cdk/a11y';
|
|
import { ENTER, hasModifierKey, SPACE } from '@angular/cdk/keycodes';
|
|
import { Attribute, ChangeDetectionStrategy, ChangeDetectorRef, Component, Directive, ElementRef, Host, Inject, Input, Optional, ViewEncapsulation, } from '@angular/core';
|
|
import { ANIMATION_MODULE_TYPE } from '@angular/platform-browser/animations';
|
|
import { mixinTabIndex } from '@angular/material/core';
|
|
import { EMPTY, merge, Subscription } from 'rxjs';
|
|
import { filter } from 'rxjs/operators';
|
|
import { matExpansionAnimations } from './expansion-animations';
|
|
import { MatExpansionPanel, MAT_EXPANSION_PANEL_DEFAULT_OPTIONS, } from './expansion-panel';
|
|
// Boilerplate for applying mixins to MatExpansionPanelHeader.
|
|
/** @docs-private */
|
|
import * as ɵngcc0 from '@angular/core';
|
|
import * as ɵngcc1 from './expansion-panel';
|
|
import * as ɵngcc2 from '@angular/cdk/a11y';
|
|
import * as ɵngcc3 from '@angular/common';
|
|
|
|
function MatExpansionPanelHeader_span_4_Template(rf, ctx) { if (rf & 1) {
|
|
ɵngcc0.ɵɵelement(0, "span", 2);
|
|
} if (rf & 2) {
|
|
const ctx_r0 = ɵngcc0.ɵɵnextContext();
|
|
ɵngcc0.ɵɵproperty("@indicatorRotate", ctx_r0._getExpandedState());
|
|
} }
|
|
const _c0 = [[["mat-panel-title"]], [["mat-panel-description"]], "*"];
|
|
const _c1 = ["mat-panel-title", "mat-panel-description", "*"];
|
|
class MatExpansionPanelHeaderBase {
|
|
}
|
|
const _MatExpansionPanelHeaderMixinBase = mixinTabIndex(MatExpansionPanelHeaderBase);
|
|
/**
|
|
* Header element of a `<mat-expansion-panel>`.
|
|
*/
|
|
export class MatExpansionPanelHeader extends _MatExpansionPanelHeaderMixinBase {
|
|
constructor(panel, _element, _focusMonitor, _changeDetectorRef, defaultOptions, _animationMode, tabIndex) {
|
|
super();
|
|
this.panel = panel;
|
|
this._element = _element;
|
|
this._focusMonitor = _focusMonitor;
|
|
this._changeDetectorRef = _changeDetectorRef;
|
|
this._animationMode = _animationMode;
|
|
this._parentChangeSubscription = Subscription.EMPTY;
|
|
const accordionHideToggleChange = panel.accordion ?
|
|
panel.accordion._stateChanges.pipe(filter(changes => !!(changes['hideToggle'] || changes['togglePosition']))) :
|
|
EMPTY;
|
|
this.tabIndex = parseInt(tabIndex || '') || 0;
|
|
// Since the toggle state depends on an @Input on the panel, we
|
|
// need to subscribe and trigger change detection manually.
|
|
this._parentChangeSubscription =
|
|
merge(panel.opened, panel.closed, accordionHideToggleChange, panel._inputChanges.pipe(filter(changes => {
|
|
return !!(changes['hideToggle'] ||
|
|
changes['disabled'] ||
|
|
changes['togglePosition']);
|
|
})))
|
|
.subscribe(() => this._changeDetectorRef.markForCheck());
|
|
// Avoids focus being lost if the panel contained the focused element and was closed.
|
|
panel.closed
|
|
.pipe(filter(() => panel._containsFocus()))
|
|
.subscribe(() => _focusMonitor.focusVia(_element, 'program'));
|
|
if (defaultOptions) {
|
|
this.expandedHeight = defaultOptions.expandedHeight;
|
|
this.collapsedHeight = defaultOptions.collapsedHeight;
|
|
}
|
|
}
|
|
/**
|
|
* Whether the associated panel is disabled. Implemented as a part of `FocusableOption`.
|
|
* @docs-private
|
|
*/
|
|
get disabled() {
|
|
return this.panel.disabled;
|
|
}
|
|
/** Toggles the expanded state of the panel. */
|
|
_toggle() {
|
|
if (!this.disabled) {
|
|
this.panel.toggle();
|
|
}
|
|
}
|
|
/** Gets whether the panel is expanded. */
|
|
_isExpanded() {
|
|
return this.panel.expanded;
|
|
}
|
|
/** Gets the expanded state string of the panel. */
|
|
_getExpandedState() {
|
|
return this.panel._getExpandedState();
|
|
}
|
|
/** Gets the panel id. */
|
|
_getPanelId() {
|
|
return this.panel.id;
|
|
}
|
|
/** Gets the toggle position for the header. */
|
|
_getTogglePosition() {
|
|
return this.panel.togglePosition;
|
|
}
|
|
/** Gets whether the expand indicator should be shown. */
|
|
_showToggle() {
|
|
return !this.panel.hideToggle && !this.panel.disabled;
|
|
}
|
|
/**
|
|
* Gets the current height of the header. Null if no custom height has been
|
|
* specified, and if the default height from the stylesheet should be used.
|
|
*/
|
|
_getHeaderHeight() {
|
|
const isExpanded = this._isExpanded();
|
|
if (isExpanded && this.expandedHeight) {
|
|
return this.expandedHeight;
|
|
}
|
|
else if (!isExpanded && this.collapsedHeight) {
|
|
return this.collapsedHeight;
|
|
}
|
|
return null;
|
|
}
|
|
/** Handle keydown event calling to toggle() if appropriate. */
|
|
_keydown(event) {
|
|
switch (event.keyCode) {
|
|
// Toggle for space and enter keys.
|
|
case SPACE:
|
|
case ENTER:
|
|
if (!hasModifierKey(event)) {
|
|
event.preventDefault();
|
|
this._toggle();
|
|
}
|
|
break;
|
|
default:
|
|
if (this.panel.accordion) {
|
|
this.panel.accordion._handleHeaderKeydown(event);
|
|
}
|
|
return;
|
|
}
|
|
}
|
|
/**
|
|
* Focuses the panel header. Implemented as a part of `FocusableOption`.
|
|
* @param origin Origin of the action that triggered the focus.
|
|
* @docs-private
|
|
*/
|
|
focus(origin, options) {
|
|
if (origin) {
|
|
this._focusMonitor.focusVia(this._element, origin, options);
|
|
}
|
|
else {
|
|
this._element.nativeElement.focus(options);
|
|
}
|
|
}
|
|
ngAfterViewInit() {
|
|
this._focusMonitor.monitor(this._element).subscribe(origin => {
|
|
if (origin && this.panel.accordion) {
|
|
this.panel.accordion._handleHeaderFocus(this);
|
|
}
|
|
});
|
|
}
|
|
ngOnDestroy() {
|
|
this._parentChangeSubscription.unsubscribe();
|
|
this._focusMonitor.stopMonitoring(this._element);
|
|
}
|
|
}
|
|
MatExpansionPanelHeader.ɵfac = function MatExpansionPanelHeader_Factory(t) { return new (t || MatExpansionPanelHeader)(ɵngcc0.ɵɵdirectiveInject(ɵngcc1.MatExpansionPanel, 1), ɵngcc0.ɵɵdirectiveInject(ɵngcc0.ElementRef), ɵngcc0.ɵɵdirectiveInject(ɵngcc2.FocusMonitor), ɵngcc0.ɵɵdirectiveInject(ɵngcc0.ChangeDetectorRef), ɵngcc0.ɵɵdirectiveInject(MAT_EXPANSION_PANEL_DEFAULT_OPTIONS, 8), ɵngcc0.ɵɵdirectiveInject(ANIMATION_MODULE_TYPE, 8), ɵngcc0.ɵɵinjectAttribute('tabindex')); };
|
|
MatExpansionPanelHeader.ɵcmp = /*@__PURE__*/ ɵngcc0.ɵɵdefineComponent({ type: MatExpansionPanelHeader, selectors: [["mat-expansion-panel-header"]], hostAttrs: ["role", "button", 1, "mat-expansion-panel-header", "mat-focus-indicator"], hostVars: 15, hostBindings: function MatExpansionPanelHeader_HostBindings(rf, ctx) { if (rf & 1) {
|
|
ɵngcc0.ɵɵlistener("click", function MatExpansionPanelHeader_click_HostBindingHandler() { return ctx._toggle(); })("keydown", function MatExpansionPanelHeader_keydown_HostBindingHandler($event) { return ctx._keydown($event); });
|
|
} if (rf & 2) {
|
|
ɵngcc0.ɵɵattribute("id", ctx.panel._headerId)("tabindex", ctx.tabIndex)("aria-controls", ctx._getPanelId())("aria-expanded", ctx._isExpanded())("aria-disabled", ctx.panel.disabled);
|
|
ɵngcc0.ɵɵstyleProp("height", ctx._getHeaderHeight());
|
|
ɵngcc0.ɵɵclassProp("mat-expanded", ctx._isExpanded())("mat-expansion-toggle-indicator-after", ctx._getTogglePosition() === "after")("mat-expansion-toggle-indicator-before", ctx._getTogglePosition() === "before")("_mat-animation-noopable", ctx._animationMode === "NoopAnimations");
|
|
} }, inputs: { tabIndex: "tabIndex", expandedHeight: "expandedHeight", collapsedHeight: "collapsedHeight" }, features: [ɵngcc0.ɵɵInheritDefinitionFeature], ngContentSelectors: _c1, decls: 5, vars: 1, consts: [[1, "mat-content"], ["class", "mat-expansion-indicator", 4, "ngIf"], [1, "mat-expansion-indicator"]], template: function MatExpansionPanelHeader_Template(rf, ctx) { if (rf & 1) {
|
|
ɵngcc0.ɵɵprojectionDef(_c0);
|
|
ɵngcc0.ɵɵelementStart(0, "span", 0);
|
|
ɵngcc0.ɵɵprojection(1);
|
|
ɵngcc0.ɵɵprojection(2, 1);
|
|
ɵngcc0.ɵɵprojection(3, 2);
|
|
ɵngcc0.ɵɵelementEnd();
|
|
ɵngcc0.ɵɵtemplate(4, MatExpansionPanelHeader_span_4_Template, 1, 1, "span", 1);
|
|
} if (rf & 2) {
|
|
ɵngcc0.ɵɵadvance(4);
|
|
ɵngcc0.ɵɵproperty("ngIf", ctx._showToggle());
|
|
} }, directives: [ɵngcc3.NgIf], styles: [".mat-expansion-panel-header{display:flex;flex-direction:row;align-items:center;padding:0 24px;border-radius:inherit;transition:height 225ms cubic-bezier(0.4, 0, 0.2, 1)}.mat-expansion-panel-header._mat-animation-noopable{transition:none}.mat-expansion-panel-header:focus,.mat-expansion-panel-header:hover{outline:none}.mat-expansion-panel-header.mat-expanded:focus,.mat-expansion-panel-header.mat-expanded:hover{background:inherit}.mat-expansion-panel-header:not([aria-disabled=true]){cursor:pointer}.mat-expansion-panel-header.mat-expansion-toggle-indicator-before{flex-direction:row-reverse}.mat-expansion-panel-header.mat-expansion-toggle-indicator-before .mat-expansion-indicator{margin:0 16px 0 0}[dir=rtl] .mat-expansion-panel-header.mat-expansion-toggle-indicator-before .mat-expansion-indicator{margin:0 0 0 16px}.mat-content{display:flex;flex:1;flex-direction:row;overflow:hidden}.mat-expansion-panel-header-title,.mat-expansion-panel-header-description{display:flex;flex-grow:1;margin-right:16px}[dir=rtl] .mat-expansion-panel-header-title,[dir=rtl] .mat-expansion-panel-header-description{margin-right:0;margin-left:16px}.mat-expansion-panel-header-description{flex-grow:2}.mat-expansion-indicator::after{border-style:solid;border-width:0 2px 2px 0;content:\"\";display:inline-block;padding:3px;transform:rotate(45deg);vertical-align:middle}.cdk-high-contrast-active .mat-expansion-panel .mat-expansion-panel-header.cdk-keyboard-focused:not([aria-disabled=true])::before,.cdk-high-contrast-active .mat-expansion-panel .mat-expansion-panel-header.cdk-program-focused:not([aria-disabled=true])::before,.cdk-high-contrast-active .mat-expansion-panel:not(.mat-expanded) .mat-expansion-panel-header:hover:not([aria-disabled=true])::before{top:0;left:0;right:0;bottom:0;position:absolute;box-sizing:border-box;pointer-events:none;border:3px solid;border-radius:4px;content:\"\"}.cdk-high-contrast-active .mat-expansion-panel-content{border-top:1px solid;border-top-left-radius:0;border-top-right-radius:0}\n"], encapsulation: 2, data: { animation: [
|
|
matExpansionAnimations.indicatorRotate,
|
|
] }, changeDetection: 0 });
|
|
MatExpansionPanelHeader.ctorParameters = () => [
|
|
{ type: MatExpansionPanel, decorators: [{ type: Host }] },
|
|
{ type: ElementRef },
|
|
{ type: FocusMonitor },
|
|
{ type: ChangeDetectorRef },
|
|
{ type: undefined, decorators: [{ type: Inject, args: [MAT_EXPANSION_PANEL_DEFAULT_OPTIONS,] }, { type: Optional }] },
|
|
{ type: String, decorators: [{ type: Optional }, { type: Inject, args: [ANIMATION_MODULE_TYPE,] }] },
|
|
{ type: String, decorators: [{ type: Attribute, args: ['tabindex',] }] }
|
|
];
|
|
MatExpansionPanelHeader.propDecorators = {
|
|
expandedHeight: [{ type: Input }],
|
|
collapsedHeight: [{ type: Input }]
|
|
};
|
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && ɵngcc0.ɵsetClassMetadata(MatExpansionPanelHeader, [{
|
|
type: Component,
|
|
args: [{
|
|
selector: 'mat-expansion-panel-header',
|
|
template: "<span class=\"mat-content\">\n <ng-content select=\"mat-panel-title\"></ng-content>\n <ng-content select=\"mat-panel-description\"></ng-content>\n <ng-content></ng-content>\n</span>\n<span [@indicatorRotate]=\"_getExpandedState()\" *ngIf=\"_showToggle()\"\n class=\"mat-expansion-indicator\"></span>\n",
|
|
encapsulation: ViewEncapsulation.None,
|
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
inputs: ['tabIndex'],
|
|
animations: [
|
|
matExpansionAnimations.indicatorRotate,
|
|
],
|
|
host: {
|
|
'class': 'mat-expansion-panel-header mat-focus-indicator',
|
|
'role': 'button',
|
|
'[attr.id]': 'panel._headerId',
|
|
'[attr.tabindex]': 'tabIndex',
|
|
'[attr.aria-controls]': '_getPanelId()',
|
|
'[attr.aria-expanded]': '_isExpanded()',
|
|
'[attr.aria-disabled]': 'panel.disabled',
|
|
'[class.mat-expanded]': '_isExpanded()',
|
|
'[class.mat-expansion-toggle-indicator-after]': `_getTogglePosition() === 'after'`,
|
|
'[class.mat-expansion-toggle-indicator-before]': `_getTogglePosition() === 'before'`,
|
|
'[class._mat-animation-noopable]': '_animationMode === "NoopAnimations"',
|
|
'[style.height]': '_getHeaderHeight()',
|
|
'(click)': '_toggle()',
|
|
'(keydown)': '_keydown($event)'
|
|
},
|
|
styles: [".mat-expansion-panel-header{display:flex;flex-direction:row;align-items:center;padding:0 24px;border-radius:inherit;transition:height 225ms cubic-bezier(0.4, 0, 0.2, 1)}.mat-expansion-panel-header._mat-animation-noopable{transition:none}.mat-expansion-panel-header:focus,.mat-expansion-panel-header:hover{outline:none}.mat-expansion-panel-header.mat-expanded:focus,.mat-expansion-panel-header.mat-expanded:hover{background:inherit}.mat-expansion-panel-header:not([aria-disabled=true]){cursor:pointer}.mat-expansion-panel-header.mat-expansion-toggle-indicator-before{flex-direction:row-reverse}.mat-expansion-panel-header.mat-expansion-toggle-indicator-before .mat-expansion-indicator{margin:0 16px 0 0}[dir=rtl] .mat-expansion-panel-header.mat-expansion-toggle-indicator-before .mat-expansion-indicator{margin:0 0 0 16px}.mat-content{display:flex;flex:1;flex-direction:row;overflow:hidden}.mat-expansion-panel-header-title,.mat-expansion-panel-header-description{display:flex;flex-grow:1;margin-right:16px}[dir=rtl] .mat-expansion-panel-header-title,[dir=rtl] .mat-expansion-panel-header-description{margin-right:0;margin-left:16px}.mat-expansion-panel-header-description{flex-grow:2}.mat-expansion-indicator::after{border-style:solid;border-width:0 2px 2px 0;content:\"\";display:inline-block;padding:3px;transform:rotate(45deg);vertical-align:middle}.cdk-high-contrast-active .mat-expansion-panel .mat-expansion-panel-header.cdk-keyboard-focused:not([aria-disabled=true])::before,.cdk-high-contrast-active .mat-expansion-panel .mat-expansion-panel-header.cdk-program-focused:not([aria-disabled=true])::before,.cdk-high-contrast-active .mat-expansion-panel:not(.mat-expanded) .mat-expansion-panel-header:hover:not([aria-disabled=true])::before{top:0;left:0;right:0;bottom:0;position:absolute;box-sizing:border-box;pointer-events:none;border:3px solid;border-radius:4px;content:\"\"}.cdk-high-contrast-active .mat-expansion-panel-content{border-top:1px solid;border-top-left-radius:0;border-top-right-radius:0}\n"]
|
|
}]
|
|
}], function () { return [{ type: ɵngcc1.MatExpansionPanel, decorators: [{
|
|
type: Host
|
|
}] }, { type: ɵngcc0.ElementRef }, { type: ɵngcc2.FocusMonitor }, { type: ɵngcc0.ChangeDetectorRef }, { type: undefined, decorators: [{
|
|
type: Inject,
|
|
args: [MAT_EXPANSION_PANEL_DEFAULT_OPTIONS]
|
|
}, {
|
|
type: Optional
|
|
}] }, { type: String, decorators: [{
|
|
type: Optional
|
|
}, {
|
|
type: Inject,
|
|
args: [ANIMATION_MODULE_TYPE]
|
|
}] }, { type: String, decorators: [{
|
|
type: Attribute,
|
|
args: ['tabindex']
|
|
}] }]; }, { expandedHeight: [{
|
|
type: Input
|
|
}], collapsedHeight: [{
|
|
type: Input
|
|
}] }); })();
|
|
/**
|
|
* Description element of a `<mat-expansion-panel-header>`.
|
|
*/
|
|
export class MatExpansionPanelDescription {
|
|
}
|
|
MatExpansionPanelDescription.ɵfac = function MatExpansionPanelDescription_Factory(t) { return new (t || MatExpansionPanelDescription)(); };
|
|
MatExpansionPanelDescription.ɵdir = /*@__PURE__*/ ɵngcc0.ɵɵdefineDirective({ type: MatExpansionPanelDescription, selectors: [["mat-panel-description"]], hostAttrs: [1, "mat-expansion-panel-header-description"] });
|
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && ɵngcc0.ɵsetClassMetadata(MatExpansionPanelDescription, [{
|
|
type: Directive,
|
|
args: [{
|
|
selector: 'mat-panel-description',
|
|
host: {
|
|
class: 'mat-expansion-panel-header-description'
|
|
}
|
|
}]
|
|
}], null, null); })();
|
|
/**
|
|
* Title element of a `<mat-expansion-panel-header>`.
|
|
*/
|
|
export class MatExpansionPanelTitle {
|
|
}
|
|
MatExpansionPanelTitle.ɵfac = function MatExpansionPanelTitle_Factory(t) { return new (t || MatExpansionPanelTitle)(); };
|
|
MatExpansionPanelTitle.ɵdir = /*@__PURE__*/ ɵngcc0.ɵɵdefineDirective({ type: MatExpansionPanelTitle, selectors: [["mat-panel-title"]], hostAttrs: [1, "mat-expansion-panel-header-title"] });
|
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && ɵngcc0.ɵsetClassMetadata(MatExpansionPanelTitle, [{
|
|
type: Directive,
|
|
args: [{
|
|
selector: 'mat-panel-title',
|
|
host: {
|
|
class: 'mat-expansion-panel-header-title'
|
|
}
|
|
}]
|
|
}], null, null); })();
|
|
|
|
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"expansion-panel-header.js","sources":["../../../../../../src/material/expansion/expansion-panel-header.ts"],"names":[],"mappings":"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","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 {FocusableOption, FocusMonitor, FocusOrigin} from '@angular/cdk/a11y';\nimport {ENTER, hasModifierKey, SPACE} from '@angular/cdk/keycodes';\nimport {\n  AfterViewInit,\n  Attribute,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  Directive,\n  ElementRef,\n  Host,\n  Inject,\n  Input,\n  OnDestroy,\n  Optional,\n  ViewEncapsulation,\n} from '@angular/core';\nimport {ANIMATION_MODULE_TYPE} from '@angular/platform-browser/animations';\nimport {HasTabIndex, mixinTabIndex} from '@angular/material/core';\nimport {NumberInput} from '@angular/cdk/coercion';\nimport {EMPTY, merge, Subscription} from 'rxjs';\nimport {filter} from 'rxjs/operators';\nimport {MatAccordionTogglePosition} from './accordion-base';\nimport {matExpansionAnimations} from './expansion-animations';\nimport {\n  MatExpansionPanel,\n  MatExpansionPanelDefaultOptions,\n  MAT_EXPANSION_PANEL_DEFAULT_OPTIONS,\n} from './expansion-panel';\n\n\n// Boilerplate for applying mixins to MatExpansionPanelHeader.\n/** @docs-private */\nabstract class MatExpansionPanelHeaderBase {\n  abstract readonly disabled: boolean;\n}\nconst _MatExpansionPanelHeaderMixinBase = mixinTabIndex(MatExpansionPanelHeaderBase);\n\n/**\n * Header element of a `<mat-expansion-panel>`.\n */\n@Component({\n  selector: 'mat-expansion-panel-header',\n  styleUrls: ['expansion-panel-header.css'],\n  templateUrl: 'expansion-panel-header.html',\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  inputs: ['tabIndex'],\n  animations: [\n    matExpansionAnimations.indicatorRotate,\n  ],\n  host: {\n    'class': 'mat-expansion-panel-header mat-focus-indicator',\n    'role': 'button',\n    '[attr.id]': 'panel._headerId',\n    '[attr.tabindex]': 'tabIndex',\n    '[attr.aria-controls]': '_getPanelId()',\n    '[attr.aria-expanded]': '_isExpanded()',\n    '[attr.aria-disabled]': 'panel.disabled',\n    '[class.mat-expanded]': '_isExpanded()',\n    '[class.mat-expansion-toggle-indicator-after]': `_getTogglePosition() === 'after'`,\n    '[class.mat-expansion-toggle-indicator-before]': `_getTogglePosition() === 'before'`,\n    '[class._mat-animation-noopable]': '_animationMode === \"NoopAnimations\"',\n    '[style.height]': '_getHeaderHeight()',\n    '(click)': '_toggle()',\n    '(keydown)': '_keydown($event)',\n  },\n})\nexport class MatExpansionPanelHeader extends _MatExpansionPanelHeaderMixinBase implements\n  AfterViewInit, OnDestroy, FocusableOption, HasTabIndex {\n  private _parentChangeSubscription = Subscription.EMPTY;\n\n  constructor(\n      @Host() public panel: MatExpansionPanel,\n      private _element: ElementRef,\n      private _focusMonitor: FocusMonitor,\n      private _changeDetectorRef: ChangeDetectorRef,\n      @Inject(MAT_EXPANSION_PANEL_DEFAULT_OPTIONS) @Optional()\n          defaultOptions?: MatExpansionPanelDefaultOptions,\n      @Optional() @Inject(ANIMATION_MODULE_TYPE) public _animationMode?: string,\n      @Attribute('tabindex') tabIndex?: string) {\n    super();\n    const accordionHideToggleChange = panel.accordion ?\n        panel.accordion._stateChanges.pipe(\n            filter(changes => !!(changes['hideToggle'] || changes['togglePosition']))) :\n        EMPTY;\n    this.tabIndex = parseInt(tabIndex || '') || 0;\n\n    // Since the toggle state depends on an @Input on the panel, we\n    // need to subscribe and trigger change detection manually.\n    this._parentChangeSubscription =\n        merge(\n            panel.opened, panel.closed, accordionHideToggleChange,\n            panel._inputChanges.pipe(filter(\n                changes => {\n                  return !!(\n                    changes['hideToggle'] ||\n                    changes['disabled'] ||\n                    changes['togglePosition']);\n                  })))\n    .subscribe(() => this._changeDetectorRef.markForCheck());\n\n    // Avoids focus being lost if the panel contained the focused element and was closed.\n    panel.closed\n      .pipe(filter(() => panel._containsFocus()))\n      .subscribe(() => _focusMonitor.focusVia(_element, 'program'));\n\n    if (defaultOptions) {\n      this.expandedHeight = defaultOptions.expandedHeight;\n      this.collapsedHeight = defaultOptions.collapsedHeight;\n    }\n  }\n\n  /** Height of the header while the panel is expanded. */\n  @Input() expandedHeight: string;\n\n  /** Height of the header while the panel is collapsed. */\n  @Input() collapsedHeight: string;\n\n  /**\n   * Whether the associated panel is disabled. Implemented as a part of `FocusableOption`.\n   * @docs-private\n   */\n  get disabled(): boolean {\n    return this.panel.disabled;\n  }\n\n  /** Toggles the expanded state of the panel. */\n  _toggle(): void {\n    if (!this.disabled) {\n      this.panel.toggle();\n    }\n  }\n\n  /** Gets whether the panel is expanded. */\n  _isExpanded(): boolean {\n    return this.panel.expanded;\n  }\n\n  /** Gets the expanded state string of the panel. */\n  _getExpandedState(): string {\n    return this.panel._getExpandedState();\n  }\n\n  /** Gets the panel id. */\n  _getPanelId(): string {\n    return this.panel.id;\n  }\n\n  /** Gets the toggle position for the header. */\n  _getTogglePosition(): MatAccordionTogglePosition {\n    return this.panel.togglePosition;\n  }\n\n  /** Gets whether the expand indicator should be shown. */\n  _showToggle(): boolean {\n    return !this.panel.hideToggle && !this.panel.disabled;\n  }\n\n  /**\n   * Gets the current height of the header. Null if no custom height has been\n   * specified, and if the default height from the stylesheet should be used.\n   */\n  _getHeaderHeight(): string|null {\n    const isExpanded = this._isExpanded();\n    if (isExpanded && this.expandedHeight) {\n      return this.expandedHeight;\n    } else if (!isExpanded && this.collapsedHeight) {\n      return this.collapsedHeight;\n    }\n    return null;\n  }\n\n  /** Handle keydown event calling to toggle() if appropriate. */\n  _keydown(event: KeyboardEvent) {\n    switch (event.keyCode) {\n      // Toggle for space and enter keys.\n      case SPACE:\n      case ENTER:\n        if (!hasModifierKey(event)) {\n          event.preventDefault();\n          this._toggle();\n        }\n\n        break;\n      default:\n        if (this.panel.accordion) {\n          this.panel.accordion._handleHeaderKeydown(event);\n        }\n\n        return;\n    }\n  }\n\n  /**\n   * Focuses the panel header. Implemented as a part of `FocusableOption`.\n   * @param origin Origin of the action that triggered the focus.\n   * @docs-private\n   */\n  focus(origin?: FocusOrigin, options?: FocusOptions) {\n    if (origin) {\n      this._focusMonitor.focusVia(this._element, origin, options);\n    } else {\n      this._element.nativeElement.focus(options);\n    }\n  }\n\n  ngAfterViewInit() {\n    this._focusMonitor.monitor(this._element).subscribe(origin => {\n      if (origin && this.panel.accordion) {\n        this.panel.accordion._handleHeaderFocus(this);\n      }\n    });\n  }\n\n  ngOnDestroy() {\n    this._parentChangeSubscription.unsubscribe();\n    this._focusMonitor.stopMonitoring(this._element);\n  }\n\n  static ngAcceptInputType_tabIndex: NumberInput;\n}\n\n/**\n * Description element of a `<mat-expansion-panel-header>`.\n */\n@Directive({\n  selector: 'mat-panel-description',\n  host: {\n    class: 'mat-expansion-panel-header-description'\n  }\n})\nexport class MatExpansionPanelDescription {}\n\n/**\n * Title element of a `<mat-expansion-panel-header>`.\n */\n@Directive({\n  selector: 'mat-panel-title',\n  host: {\n    class: 'mat-expansion-panel-header-title'\n  }\n})\nexport class MatExpansionPanelTitle {}\n"]}
|