blob: 5cfcf367340f4f26e2077c0da84ad60a8ba6b9b2 [file] [log] [blame]
/**
* @fileoverview added by tsickle
* Generated from: expansion-panel-group.component.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Component, Renderer2, ElementRef, QueryList, ContentChildren, Input, } from '@angular/core';
import { TdExpansionPanelComponent } from './expansion-panel.component';
import { coerceBooleanProperty } from '@angular/cdk/coercion';
import { takeUntil } from 'rxjs/operators';
import { Subject } from 'rxjs';
export class TdExpansionPanelGroupComponent {
/**
* @param {?} _renderer
* @param {?} _elementRef
*/
constructor(_renderer, _elementRef) {
this._renderer = _renderer;
this._elementRef = _elementRef;
this._multi = false;
this._lastOpenedPanels = [];
this._destroyed = new Subject();
this._stopWatchingPanels = new Subject();
this._renderer.addClass(this._elementRef.nativeElement, 'td-expansion-panel-group');
}
/**
* multi?: boolean
* Sets whether multiple panels can be opened at a given time.
* Set to false for accordion mode.
* Defaults to false.
* @param {?} multi
* @return {?}
*/
set multi(multi) {
this._multi = coerceBooleanProperty(multi);
if (this._multi === false && this._lastOpenedPanels.length > 0) {
this._closeAllExcept(this._lastOpenedPanels[this._lastOpenedPanels.length - 1]);
}
}
/**
* @return {?}
*/
ngOnDestroy() {
this._destroyed.next(true);
this._destroyed.unsubscribe();
this._stopWatchingPanels.next(true);
this._stopWatchingPanels.unsubscribe();
}
/**
* @return {?}
*/
ngAfterContentInit() {
if (!this._multi) {
/** @type {?} */
const openedPanels = this.expansionPanels.filter((/**
* @param {?} expansionPanel
* @return {?}
*/
(expansionPanel) => expansionPanel.expand));
/** @type {?} */
const numOpenedPanels = openedPanels.length;
if (numOpenedPanels > 1) {
this._closeAllExcept(openedPanels[numOpenedPanels - 1]);
}
}
this._attachListeners(this.expansionPanels);
this.expansionPanels.changes
.pipe(takeUntil(this._destroyed))
.subscribe((/**
* @param {?} expansionPanels
* @return {?}
*/
(expansionPanels) => {
this._stopWatchingPanels.next(true);
this._stopWatchingPanels.unsubscribe();
this._stopWatchingPanels = new Subject();
this._attachListeners(expansionPanels);
}));
}
/**
* Opens all expansion panels, only if multi set set to true.
* @return {?}
*/
openAll() {
if (this._multi) {
this.expansionPanels.forEach((/**
* @param {?} expansionPanel
* @return {?}
*/
(expansionPanel) => {
expansionPanel.open();
}));
}
}
/**
* Closes all expansion panels
* @return {?}
*/
closeAll() {
this.expansionPanels.forEach((/**
* @param {?} expansionPanel
* @return {?}
*/
(expansionPanel) => {
expansionPanel.close();
}));
}
/**
* @private
* @param {?} expansionPanels
* @return {?}
*/
_attachListeners(expansionPanels) {
this._lastOpenedPanels = [];
expansionPanels.forEach((/**
* @param {?} expansionPanel
* @return {?}
*/
(expansionPanel) => {
expansionPanel.expanded.pipe(takeUntil(this._stopWatchingPanels)).subscribe((/**
* @return {?}
*/
() => {
/** @type {?} */
const indexOfPanel = this._lastOpenedPanels.indexOf(expansionPanel);
if (indexOfPanel !== -1) {
this._lastOpenedPanels.splice(indexOfPanel, 1);
}
this._lastOpenedPanels.push(expansionPanel);
if (!this._multi) {
this._closeAllExcept(expansionPanel);
}
}));
expansionPanel.collapsed.pipe(takeUntil(this._stopWatchingPanels)).subscribe((/**
* @return {?}
*/
() => {
/** @type {?} */
const indexOfPanel = this._lastOpenedPanels.indexOf(expansionPanel);
if (indexOfPanel !== -1) {
this._lastOpenedPanels.splice(indexOfPanel, 1);
}
}));
}));
}
/**
* @private
* @param {?} expansionPanel
* @return {?}
*/
_closeAllExcept(expansionPanel) {
this.expansionPanels.forEach((/**
* @param {?} panel
* @return {?}
*/
(panel) => {
if (panel !== expansionPanel) {
panel.close();
}
}));
}
}
TdExpansionPanelGroupComponent.decorators = [
{ type: Component, args: [{
selector: 'td-expansion-panel-group',
template: "<ng-content></ng-content>\n",
styles: [""]
}] }
];
/** @nocollapse */
TdExpansionPanelGroupComponent.ctorParameters = () => [
{ type: Renderer2 },
{ type: ElementRef }
];
TdExpansionPanelGroupComponent.propDecorators = {
multi: [{ type: Input, args: ['multi',] }],
expansionPanels: [{ type: ContentChildren, args: [TdExpansionPanelComponent, { descendants: true },] }]
};
if (false) {
/**
* @type {?}
* @private
*/
TdExpansionPanelGroupComponent.prototype._multi;
/**
* @type {?}
* @private
*/
TdExpansionPanelGroupComponent.prototype._lastOpenedPanels;
/**
* @type {?}
* @private
*/
TdExpansionPanelGroupComponent.prototype._destroyed;
/**
* @type {?}
* @private
*/
TdExpansionPanelGroupComponent.prototype._stopWatchingPanels;
/** @type {?} */
TdExpansionPanelGroupComponent.prototype.expansionPanels;
/**
* @type {?}
* @private
*/
TdExpansionPanelGroupComponent.prototype._renderer;
/**
* @type {?}
* @private
*/
TdExpansionPanelGroupComponent.prototype._elementRef;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"expansion-panel-group.component.js","sourceRoot":"../../../../../src/platform/core/expansion-panel/","sources":["expansion-panel-group.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Renderer2,\n  ElementRef,\n  QueryList,\n  ContentChildren,\n  AfterContentInit,\n  Input,\n  OnDestroy,\n} from '@angular/core';\nimport { TdExpansionPanelComponent } from './expansion-panel.component';\nimport { coerceBooleanProperty } from '@angular/cdk/coercion';\nimport { takeUntil } from 'rxjs/operators';\nimport { Subject } from 'rxjs';\n\n@Component({\n  selector: 'td-expansion-panel-group',\n  styleUrls: ['./expansion-panel-group.component.scss'],\n  templateUrl: './expansion-panel-group.component.html',\n})\nexport class TdExpansionPanelGroupComponent implements AfterContentInit, OnDestroy {\n  private _multi: boolean = false;\n\n  private _lastOpenedPanels: TdExpansionPanelComponent[] = [];\n\n  private _destroyed: Subject<boolean> = new Subject<boolean>();\n  private _stopWatchingPanels: Subject<boolean> = new Subject<boolean>();\n\n  /**\n   * multi?: boolean\n   * Sets whether multiple panels can be opened at a given time.\n   * Set to false for accordion mode.\n   * Defaults to false.\n   */\n  @Input('multi')\n  set multi(multi: boolean) {\n    this._multi = coerceBooleanProperty(multi);\n    if (this._multi === false && this._lastOpenedPanels.length > 0) {\n      this._closeAllExcept(this._lastOpenedPanels[this._lastOpenedPanels.length - 1]);\n    }\n  }\n\n  @ContentChildren(TdExpansionPanelComponent, { descendants: true })\n  expansionPanels: QueryList<TdExpansionPanelComponent>;\n\n  constructor(private _renderer: Renderer2, private _elementRef: ElementRef) {\n    this._renderer.addClass(this._elementRef.nativeElement, 'td-expansion-panel-group');\n  }\n\n  ngOnDestroy(): void {\n    this._destroyed.next(true);\n    this._destroyed.unsubscribe();\n    this._stopWatchingPanels.next(true);\n    this._stopWatchingPanels.unsubscribe();\n  }\n\n  public ngAfterContentInit(): void {\n    if (!this._multi) {\n      const openedPanels: TdExpansionPanelComponent[] = this.expansionPanels.filter(\n        (expansionPanel: TdExpansionPanelComponent) => expansionPanel.expand,\n      );\n      const numOpenedPanels: number = openedPanels.length;\n      if (numOpenedPanels > 1) {\n        this._closeAllExcept(openedPanels[numOpenedPanels - 1]);\n      }\n    }\n\n    this._attachListeners(this.expansionPanels);\n\n    this.expansionPanels.changes\n      .pipe(takeUntil(this._destroyed))\n      .subscribe((expansionPanels: QueryList<TdExpansionPanelComponent>) => {\n        this._stopWatchingPanels.next(true);\n        this._stopWatchingPanels.unsubscribe();\n        this._stopWatchingPanels = new Subject<boolean>();\n        this._attachListeners(expansionPanels);\n      });\n  }\n\n  /**\n   * Opens all expansion panels, only if multi set set to true.\n   */\n  public openAll(): void {\n    if (this._multi) {\n      this.expansionPanels.forEach((expansionPanel: TdExpansionPanelComponent) => {\n        expansionPanel.open();\n      });\n    }\n  }\n\n  /**\n   * Closes all expansion panels\n   */\n  public closeAll(): void {\n    this.expansionPanels.forEach((expansionPanel: TdExpansionPanelComponent) => {\n      expansionPanel.close();\n    });\n  }\n\n  private _attachListeners(expansionPanels: QueryList<TdExpansionPanelComponent>): void {\n    this._lastOpenedPanels = [];\n    expansionPanels.forEach((expansionPanel: TdExpansionPanelComponent) => {\n      expansionPanel.expanded.pipe(takeUntil(this._stopWatchingPanels)).subscribe(() => {\n        const indexOfPanel: number = this._lastOpenedPanels.indexOf(expansionPanel);\n        if (indexOfPanel !== -1) {\n          this._lastOpenedPanels.splice(indexOfPanel, 1);\n        }\n        this._lastOpenedPanels.push(expansionPanel);\n\n        if (!this._multi) {\n          this._closeAllExcept(expansionPanel);\n        }\n      });\n\n      expansionPanel.collapsed.pipe(takeUntil(this._stopWatchingPanels)).subscribe(() => {\n        const indexOfPanel: number = this._lastOpenedPanels.indexOf(expansionPanel);\n        if (indexOfPanel !== -1) {\n          this._lastOpenedPanels.splice(indexOfPanel, 1);\n        }\n      });\n    });\n  }\n\n  private _closeAllExcept(expansionPanel: TdExpansionPanelComponent): void {\n    this.expansionPanels.forEach((panel: TdExpansionPanelComponent) => {\n      if (panel !== expansionPanel) {\n        panel.close();\n      }\n    });\n  }\n}\n"]}