UNPKG

angular-bootstrap-md

Version:

Bootstrap 4 & Angular 15 UI KIT - 700+ components, MIT license, simple installation.

115 lines 13.8 kB
import { Component, HostBinding, Input, Output, EventEmitter, HostListener, ContentChildren, ChangeDetectionStrategy, } from '@angular/core'; import { state, style, trigger, transition, animate } from '@angular/animations'; import { FixedButtonCaptionDirective } from '../buttons/fixed-caption.directive'; import { coerceBooleanProperty } from '@angular/cdk/coercion'; import * as i0 from "@angular/core"; export class CollapseComponent { constructor(_cdRef) { this._cdRef = _cdRef; this._isCollapsed = true; this.showBsCollapse = new EventEmitter(); this.shownBsCollapse = new EventEmitter(); this.hideBsCollapse = new EventEmitter(); this.hiddenBsCollapse = new EventEmitter(); this.collapsed = new EventEmitter(); this.expanded = new EventEmitter(); this.overflow = 'hidden'; } get isCollapsed() { return this._isCollapsed; } set isCollapsed(value) { this._isCollapsed = coerceBooleanProperty(value); } onExpandBodyDone(event) { setTimeout(() => { if (event.toState === 'expanded') { this.isCollapsed = false; this.shownBsCollapse.emit(this); this.expanded.emit(this); this.overflow = 'visible'; this.showCaptions(); } else { this.isCollapsed = true; this.hiddenBsCollapse.emit(this); this.collapsed.emit(this); } }, 0); } showCaptions() { this.captions.forEach((caption) => caption.showCaption()); } toggle() { this.isCollapsed ? this.show() : this.hide(); } show() { this.expandAnimationState = 'expanded'; this.showBsCollapse.emit(this); this._cdRef.markForCheck(); } hide() { this.overflow = 'hidden'; this.expandAnimationState = 'collapsed'; this.hideBsCollapse.emit(this); this._cdRef.markForCheck(); } initializeCollapseState() { this.isCollapsed ? this.hide() : this.show(); } ngOnInit() { this.initializeCollapseState(); } } CollapseComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.1", ngImport: i0, type: CollapseComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); CollapseComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.1", type: CollapseComponent, selector: "[mdbCollapse]", inputs: { isCollapsed: "isCollapsed" }, outputs: { showBsCollapse: "showBsCollapse", shownBsCollapse: "shownBsCollapse", hideBsCollapse: "hideBsCollapse", hiddenBsCollapse: "hiddenBsCollapse", collapsed: "collapsed", expanded: "expanded" }, host: { listeners: { "@expandBody.done": "onExpandBodyDone($event)" }, properties: { "@expandBody": "this.expandAnimationState", "style.overflow": "this.overflow" } }, queries: [{ propertyName: "captions", predicate: FixedButtonCaptionDirective }], exportAs: ["bs-collapse"], ngImport: i0, template: '<ng-content></ng-content>', isInline: true, animations: [ trigger('expandBody', [ state('collapsed', style({ height: '0px' })), state('expanded', style({ height: '*' })), transition('expanded <=> collapsed', animate('500ms ease')), ]), ], changeDetection: i0.ChangeDetectionStrategy.OnPush }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.1", ngImport: i0, type: CollapseComponent, decorators: [{ type: Component, args: [{ // eslint-disable-next-line @angular-eslint/component-selector selector: '[mdbCollapse]', exportAs: 'bs-collapse', template: '<ng-content></ng-content>', animations: [ trigger('expandBody', [ state('collapsed', style({ height: '0px' })), state('expanded', style({ height: '*' })), transition('expanded <=> collapsed', animate('500ms ease')), ]), ], changeDetection: ChangeDetectionStrategy.OnPush, }] }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { captions: [{ type: ContentChildren, args: [FixedButtonCaptionDirective] }], isCollapsed: [{ type: Input }], showBsCollapse: [{ type: Output }], shownBsCollapse: [{ type: Output }], hideBsCollapse: [{ type: Output }], hiddenBsCollapse: [{ type: Output }], collapsed: [{ type: Output }], expanded: [{ type: Output }], expandAnimationState: [{ type: HostBinding, args: ['@expandBody'] }], overflow: [{ type: HostBinding, args: ['style.overflow'] }], onExpandBodyDone: [{ type: HostListener, args: ['@expandBody.done', ['$event']] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"collapse.component.js","sourceRoot":"","sources":["../../../../../../projects/angular-bootstrap-md/src/lib/free/collapse/collapse.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  OnInit,\n  HostBinding,\n  Input,\n  Output,\n  EventEmitter,\n  HostListener,\n  ContentChildren,\n  QueryList,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n} from '@angular/core';\nimport { state, style, trigger, transition, animate } from '@angular/animations';\nimport { FixedButtonCaptionDirective } from '../buttons/fixed-caption.directive';\nimport { BooleanInput, coerceBooleanProperty } from '@angular/cdk/coercion';\n\n@Component({\n  // eslint-disable-next-line @angular-eslint/component-selector\n  selector: '[mdbCollapse]',\n  exportAs: 'bs-collapse',\n  template: '<ng-content></ng-content>',\n  animations: [\n    trigger('expandBody', [\n      state('collapsed', style({ height: '0px' })),\n      state('expanded', style({ height: '*' })),\n      transition('expanded <=> collapsed', animate('500ms ease')),\n    ]),\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class CollapseComponent implements OnInit {\n  @ContentChildren(FixedButtonCaptionDirective) captions: QueryList<FixedButtonCaptionDirective>;\n\n  @Input()\n  get isCollapsed(): boolean {\n    return this._isCollapsed;\n  }\n  set isCollapsed(value: BooleanInput) {\n    this._isCollapsed = coerceBooleanProperty(value);\n  }\n  private _isCollapsed = true;\n\n  @Output() showBsCollapse: EventEmitter<any> = new EventEmitter();\n  @Output() shownBsCollapse: EventEmitter<any> = new EventEmitter();\n  @Output() hideBsCollapse: EventEmitter<any> = new EventEmitter();\n  @Output() hiddenBsCollapse: EventEmitter<any> = new EventEmitter();\n  @Output() collapsed: EventEmitter<any> = new EventEmitter();\n  @Output() expanded: EventEmitter<any> = new EventEmitter();\n\n  constructor(private _cdRef: ChangeDetectorRef) {}\n\n  @HostBinding('@expandBody') expandAnimationState: string;\n  @HostBinding('style.overflow') overflow = 'hidden';\n\n  @HostListener('@expandBody.done', ['$event'])\n  onExpandBodyDone(event: any) {\n    setTimeout(() => {\n      if (event.toState === 'expanded') {\n        this.isCollapsed = false;\n        this.shownBsCollapse.emit(this);\n        this.expanded.emit(this);\n        this.overflow = 'visible';\n        this.showCaptions();\n      } else {\n        this.isCollapsed = true;\n        this.hiddenBsCollapse.emit(this);\n        this.collapsed.emit(this);\n      }\n    }, 0);\n  }\n\n  showCaptions() {\n    this.captions.forEach((caption: FixedButtonCaptionDirective) => caption.showCaption());\n  }\n\n  toggle() {\n    this.isCollapsed ? this.show() : this.hide();\n  }\n\n  show() {\n    this.expandAnimationState = 'expanded';\n\n    this.showBsCollapse.emit(this);\n    this._cdRef.markForCheck();\n  }\n\n  hide() {\n    this.overflow = 'hidden';\n    this.expandAnimationState = 'collapsed';\n\n    this.hideBsCollapse.emit(this);\n    this._cdRef.markForCheck();\n  }\n\n  initializeCollapseState() {\n    this.isCollapsed ? this.hide() : this.show();\n  }\n\n  ngOnInit() {\n    this.initializeCollapseState();\n  }\n}\n"]}