angular-bootstrap-md
Version:
Bootstrap 4 & Angular 15 UI KIT - 700+ components, MIT license, simple installation.
115 lines • 13.8 kB
JavaScript
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"]}