| /** |
| * @fileoverview added by tsickle |
| * @suppress {checkTypes,extraRequire,missingReturn,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'; |
| var TdExpansionPanelGroupComponent = /** @class */ (function () { |
| function TdExpansionPanelGroupComponent(_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'); |
| } |
| Object.defineProperty(TdExpansionPanelGroupComponent.prototype, "multi", { |
| /** |
| * multi?: boolean |
| * Sets whether multiple panels can be opened at a given time. |
| * Set to false for accordion mode. |
| * Defaults to false. |
| */ |
| set: /** |
| * 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 {?} |
| */ |
| function (multi) { |
| this._multi = coerceBooleanProperty(multi); |
| if (this._multi === false && this._lastOpenedPanels.length > 0) { |
| this._closeAllExcept(this._lastOpenedPanels[this._lastOpenedPanels.length - 1]); |
| } |
| }, |
| enumerable: true, |
| configurable: true |
| }); |
| /** |
| * @return {?} |
| */ |
| TdExpansionPanelGroupComponent.prototype.ngOnDestroy = /** |
| * @return {?} |
| */ |
| function () { |
| this._destroyed.next(true); |
| this._destroyed.unsubscribe(); |
| this._stopWatchingPanels.next(true); |
| this._stopWatchingPanels.unsubscribe(); |
| }; |
| /** |
| * @return {?} |
| */ |
| TdExpansionPanelGroupComponent.prototype.ngAfterContentInit = /** |
| * @return {?} |
| */ |
| function () { |
| var _this = this; |
| if (!this._multi) { |
| /** @type {?} */ |
| var openedPanels = this.expansionPanels.filter(function (expansionPanel) { return expansionPanel.expand; }); |
| /** @type {?} */ |
| var numOpenedPanels = openedPanels.length; |
| if (numOpenedPanels > 1) { |
| this._closeAllExcept(openedPanels[numOpenedPanels - 1]); |
| } |
| } |
| this._attachListeners(this.expansionPanels); |
| this.expansionPanels.changes |
| .pipe(takeUntil(this._destroyed)) |
| .subscribe(function (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. |
| */ |
| /** |
| * Opens all expansion panels, only if multi set set to true. |
| * @return {?} |
| */ |
| TdExpansionPanelGroupComponent.prototype.openAll = /** |
| * Opens all expansion panels, only if multi set set to true. |
| * @return {?} |
| */ |
| function () { |
| if (this._multi) { |
| this.expansionPanels.forEach(function (expansionPanel) { |
| expansionPanel.open(); |
| }); |
| } |
| }; |
| /** |
| * Closes all expansion panels |
| */ |
| /** |
| * Closes all expansion panels |
| * @return {?} |
| */ |
| TdExpansionPanelGroupComponent.prototype.closeAll = /** |
| * Closes all expansion panels |
| * @return {?} |
| */ |
| function () { |
| this.expansionPanels.forEach(function (expansionPanel) { |
| expansionPanel.close(); |
| }); |
| }; |
| /** |
| * @param {?} expansionPanels |
| * @return {?} |
| */ |
| TdExpansionPanelGroupComponent.prototype._attachListeners = /** |
| * @param {?} expansionPanels |
| * @return {?} |
| */ |
| function (expansionPanels) { |
| var _this = this; |
| this._lastOpenedPanels = []; |
| expansionPanels.forEach(function (expansionPanel) { |
| expansionPanel.expanded |
| .pipe(takeUntil(_this._stopWatchingPanels)) |
| .subscribe(function () { |
| /** @type {?} */ |
| var 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(function () { |
| /** @type {?} */ |
| var indexOfPanel = _this._lastOpenedPanels.indexOf(expansionPanel); |
| if (indexOfPanel !== -1) { |
| _this._lastOpenedPanels.splice(indexOfPanel, 1); |
| } |
| }); |
| }); |
| }; |
| /** |
| * @param {?} expansionPanel |
| * @return {?} |
| */ |
| TdExpansionPanelGroupComponent.prototype._closeAllExcept = /** |
| * @param {?} expansionPanel |
| * @return {?} |
| */ |
| function (expansionPanel) { |
| this.expansionPanels.forEach(function (panel) { |
| if (panel !== expansionPanel) { |
| panel.close(); |
| } |
| }); |
| }; |
| TdExpansionPanelGroupComponent.decorators = [ |
| { type: Component, args: [{ |
| selector: 'td-expansion-panel-group', |
| template: "<ng-content></ng-content>", |
| styles: [""] |
| }] } |
| ]; |
| /** @nocollapse */ |
| TdExpansionPanelGroupComponent.ctorParameters = function () { return [ |
| { type: Renderer2 }, |
| { type: ElementRef } |
| ]; }; |
| TdExpansionPanelGroupComponent.propDecorators = { |
| multi: [{ type: Input, args: ['multi',] }], |
| expansionPanels: [{ type: ContentChildren, args: [TdExpansionPanelComponent,] }] |
| }; |
| return TdExpansionPanelGroupComponent; |
| }()); |
| export { TdExpansionPanelGroupComponent }; |
| if (false) { |
| /** @type {?} */ |
| TdExpansionPanelGroupComponent.prototype._multi; |
| /** @type {?} */ |
| TdExpansionPanelGroupComponent.prototype._lastOpenedPanels; |
| /** @type {?} */ |
| TdExpansionPanelGroupComponent.prototype._destroyed; |
| /** @type {?} */ |
| TdExpansionPanelGroupComponent.prototype._stopWatchingPanels; |
| /** @type {?} */ |
| TdExpansionPanelGroupComponent.prototype.expansionPanels; |
| /** @type {?} */ |
| TdExpansionPanelGroupComponent.prototype._renderer; |
| /** @type {?} */ |
| TdExpansionPanelGroupComponent.prototype._elementRef; |
| } |
| //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"expansion-panel-group.component.js","sourceRoot":"ng://@covalent/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\n  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(\n        this._lastOpenedPanels[this._lastOpenedPanels.length - 1],\n      );\n    }\n  }\n\n  @ContentChildren(TdExpansionPanelComponent) expansionPanels: QueryList<\n    TdExpansionPanelComponent\n  >;\n\n  constructor(private _renderer: Renderer2, private _elementRef: ElementRef) {\n    this._renderer.addClass(\n      this._elementRef.nativeElement,\n      'td-expansion-panel-group',\n    );\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(\n        (expansionPanel: TdExpansionPanelComponent) => {\n          expansionPanel.open();\n        },\n      );\n    }\n  }\n\n  /**\n   * Closes all expansion panels\n   */\n  public closeAll(): void {\n    this.expansionPanels.forEach(\n      (expansionPanel: TdExpansionPanelComponent) => {\n        expansionPanel.close();\n      },\n    );\n  }\n\n  private _attachListeners(\n    expansionPanels: QueryList<TdExpansionPanelComponent>,\n  ): void {\n    this._lastOpenedPanels = [];\n    expansionPanels.forEach((expansionPanel: TdExpansionPanelComponent) => {\n      expansionPanel.expanded\n        .pipe(takeUntil(this._stopWatchingPanels))\n        .subscribe(() => {\n          const indexOfPanel: number = this._lastOpenedPanels.indexOf(\n            expansionPanel,\n          );\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\n        .pipe(takeUntil(this._stopWatchingPanels))\n        .subscribe(() => {\n          const indexOfPanel: number = this._lastOpenedPanels.indexOf(\n            expansionPanel,\n          );\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"]} |