@coreui/angular
Version:
CoreUI for Angular UI components library
181 lines • 22.3 kB
JavaScript
import { Component, ContentChildren, EventEmitter, HostBinding, HostListener, Input, Output } from '@angular/core';
import { animate, state, style, transition, trigger } from '@angular/animations';
import { coerceBooleanProperty } from '@angular/cdk/coercion';
import { TemplateIdDirective } from '../shared';
import * as i0 from "@angular/core";
import * as i1 from "@angular/common";
import * as i2 from "../button/button-close.directive";
export class AlertComponent {
constructor() {
/**
* Sets the color context of the component to one of CoreUI’s themed colors.
*
* @type Colors
* @default 'primary'
*/
this.color = 'primary';
this._dismissible = false;
this._fade = false;
/**
* Default role for alert. [docs]
* @type string
* @default 'alert'
*/
this.role = 'alert';
this._visible = true;
/**
* Event triggered on the alert dismiss.
*/
this.visibleChange = new EventEmitter();
this.templates = {};
}
/**
* Optionally adds a close button to alert and allow it to self dismiss.
* @type boolean
*/
get dismissible() {
return this._dismissible;
}
set dismissible(value) {
this._dismissible = coerceBooleanProperty(value);
}
/**
* Adds animation for dismissible alert.
* @type boolean
*/
get fade() {
return this._fade;
}
set fade(value) {
this._fade = coerceBooleanProperty(value);
}
/**
* Toggle the visibility of alert component.
* @type boolean
*/
set visible(value) {
if (this._visible !== value) {
this._visible = coerceBooleanProperty(value);
this.visibleChange.emit(value);
}
}
;
get visible() {
return this._visible;
}
get animationDisabled() {
return !this.fade;
}
get animateType() {
return this.visible ? 'show' : 'hide';
}
get hostClasses() {
return {
alert: true,
'alert-dismissible': this.dismissible,
fade: this.fade,
show: !this.hide,
[`alert-${this.color}`]: !!this.color && this.variant !== 'solid',
[`bg-${this.color}`]: !!this.color && this.variant === 'solid',
'text-white': !!this.color && this.variant === 'solid'
};
}
onAnimationStart($event) {
this.onAnimationEvent($event);
}
onAnimationDone($event) {
this.onAnimationEvent($event);
}
ngAfterContentInit() {
this.contentTemplates.forEach((child) => {
this.templates[child.id] = child.templateRef;
});
}
onAnimationEvent(event) {
this.hide = event.phaseName === 'start' && event.toState === 'show';
if (event.phaseName === 'done') {
this.hide = (event.toState === 'hide' || event.toState === 'void');
if (event.toState === 'show') {
this.hide = false;
}
}
}
}
AlertComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: AlertComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
AlertComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: AlertComponent, selector: "c-alert", inputs: { color: "color", dismissible: "dismissible", fade: "fade", role: "role", variant: "variant", visible: "visible" }, outputs: { visibleChange: "visibleChange" }, host: { listeners: { "@fadeInOut.start": "onAnimationStart($event)", "@fadeInOut.done": "onAnimationDone($event)" }, properties: { "attr.role": "this.role", "@.disabled": "this.animationDisabled", "@fadeInOut": "this.animateType", "class": "this.hostClasses" } }, queries: [{ propertyName: "contentTemplates", predicate: TemplateIdDirective, descendants: true }], exportAs: ["cAlert"], ngImport: i0, template: "<ng-container *ngIf=\"visible || !hide\">\n <ng-template [ngIf]=\"dismissible\">\n <ng-container *ngTemplateOutlet=\"templates?.alertButtonCloseTemplate || defaultAlertButtonCloseTemplate\">\n </ng-container>\n </ng-template>\n <ng-content></ng-content>\n</ng-container>\n\n<ng-template #defaultAlertButtonCloseTemplate>\n <button (click)=\"visible=false\" aria-label=\"Close\" cButtonClose></button>\n</ng-template>\n", styles: [":host{display:block;overflow:hidden}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.ButtonCloseDirective, selector: "[cButtonClose]", inputs: ["white"] }], animations: [
trigger('fadeInOut', [
state('show', style({ opacity: 1, height: '*', padding: '*', border: '*', margin: '*' })),
state('hide', style({ opacity: 0, height: 0, padding: 0, border: 0, margin: 0 })),
state('void', style({ opacity: 0, height: 0, padding: 0, border: 0, margin: 0 })),
transition('show => hide', [
animate('.3s ease-out'),
]),
transition('hide => show', [
animate('.3s ease-in'),
]),
transition('show => void', [
animate('.3s ease-out'),
]),
transition('void => show', [
animate('.3s ease-in'),
]),
])
] });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: AlertComponent, decorators: [{
type: Component,
args: [{ selector: 'c-alert', exportAs: 'cAlert', animations: [
trigger('fadeInOut', [
state('show', style({ opacity: 1, height: '*', padding: '*', border: '*', margin: '*' })),
state('hide', style({ opacity: 0, height: 0, padding: 0, border: 0, margin: 0 })),
state('void', style({ opacity: 0, height: 0, padding: 0, border: 0, margin: 0 })),
transition('show => hide', [
animate('.3s ease-out'),
]),
transition('hide => show', [
animate('.3s ease-in'),
]),
transition('show => void', [
animate('.3s ease-out'),
]),
transition('void => show', [
animate('.3s ease-in'),
]),
])
], template: "<ng-container *ngIf=\"visible || !hide\">\n <ng-template [ngIf]=\"dismissible\">\n <ng-container *ngTemplateOutlet=\"templates?.alertButtonCloseTemplate || defaultAlertButtonCloseTemplate\">\n </ng-container>\n </ng-template>\n <ng-content></ng-content>\n</ng-container>\n\n<ng-template #defaultAlertButtonCloseTemplate>\n <button (click)=\"visible=false\" aria-label=\"Close\" cButtonClose></button>\n</ng-template>\n", styles: [":host{display:block;overflow:hidden}\n"] }]
}], propDecorators: { color: [{
type: Input
}], dismissible: [{
type: Input
}], fade: [{
type: Input
}], role: [{
type: HostBinding,
args: ['attr.role']
}, {
type: Input
}], variant: [{
type: Input
}], visible: [{
type: Input
}], visibleChange: [{
type: Output
}], contentTemplates: [{
type: ContentChildren,
args: [TemplateIdDirective, { descendants: true }]
}], animationDisabled: [{
type: HostBinding,
args: ['@.disabled']
}], animateType: [{
type: HostBinding,
args: ['@fadeInOut']
}], hostClasses: [{
type: HostBinding,
args: ['class']
}], onAnimationStart: [{
type: HostListener,
args: ['@fadeInOut.start', ['$event']]
}], onAnimationDone: [{
type: HostListener,
args: ['@fadeInOut.done', ['$event']]
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"alert.component.js","sourceRoot":"","sources":["../../../../../projects/coreui-angular/src/lib/alert/alert.component.ts","../../../../../projects/coreui-angular/src/lib/alert/alert.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterContentInit,\r\n  Component,\r\n  ContentChildren,\r\n  EventEmitter,\r\n  HostBinding,\r\n  HostListener,\r\n  Input,\r\n  Output,\r\n  QueryList\r\n} from '@angular/core';\r\nimport { animate, AnimationEvent, state, style, transition, trigger } from '@angular/animations';\r\nimport { BooleanInput, coerceBooleanProperty } from '@angular/cdk/coercion';\r\n\r\nimport { Colors } from '../coreui.types';\r\nimport { TemplateIdDirective } from '../shared';\r\n\r\ntype AnimateType = ('hide' | 'show');\r\n\r\n@Component({\r\n  selector: 'c-alert',\r\n  templateUrl: './alert.component.html',\r\n  styleUrls: ['./alert.component.scss'],\r\n  exportAs: 'cAlert',\r\n  animations: [\r\n    trigger('fadeInOut', [\r\n      state('show', style({opacity: 1, height: '*', padding: '*', border: '*', margin: '*'})),\r\n      state('hide', style({opacity: 0, height: 0, padding: 0, border: 0, margin: 0})),\r\n      state('void', style({opacity: 0, height: 0, padding: 0, border: 0, margin: 0})),\r\n      transition('show => hide', [\r\n        animate('.3s ease-out'),\r\n      ]),\r\n      transition('hide => show', [\r\n        animate('.3s ease-in'),\r\n      ]),\r\n      transition('show => void', [\r\n        animate('.3s ease-out'),\r\n      ]),\r\n      transition('void => show', [\r\n        animate('.3s ease-in'),\r\n      ]),\r\n    ])\r\n  ]\r\n})\r\nexport class AlertComponent implements AfterContentInit {\r\n\r\n  static ngAcceptInputType_dismissible: BooleanInput;\r\n  static ngAcceptInputType_fade: BooleanInput;\r\n  static ngAcceptInputType_visible: BooleanInput;\r\n\r\n  hide!: boolean;\r\n  /**\r\n   * Sets the color context of the component to one of CoreUI’s themed colors.\r\n   *\r\n   * @type Colors\r\n   * @default 'primary'\r\n   */\r\n  @Input() color: Colors = 'primary';\r\n\r\n  /**\r\n   * Optionally adds a close button to alert and allow it to self dismiss.\r\n   * @type boolean\r\n   */\r\n  @Input()\r\n  get dismissible(): boolean {\r\n    return this._dismissible;\r\n  }\r\n  set dismissible(value: boolean) {\r\n    this._dismissible = coerceBooleanProperty(value);\r\n  }\r\n  private _dismissible = false;\r\n\r\n  /**\r\n   * Adds animation for dismissible alert.\r\n   * @type boolean\r\n   */\r\n  @Input()\r\n  get fade(): boolean {\r\n    return this._fade;\r\n  }\r\n  set fade(value: boolean) {\r\n    this._fade = coerceBooleanProperty(value);\r\n  }\r\n  private _fade = false;\r\n\r\n  /**\r\n   * Default role for alert. [docs]\r\n   * @type string\r\n   * @default 'alert'\r\n   */\r\n  @HostBinding('attr.role')\r\n  @Input() role = 'alert';\r\n\r\n  /**\r\n   * Set the alert variant to a solid.\r\n   * @type string\r\n   */\r\n  @Input() variant?: 'solid' | string;\r\n\r\n  /**\r\n   * Toggle the visibility of alert component.\r\n   * @type boolean\r\n   */\r\n  @Input()\r\n  set visible(value: boolean) {\r\n    if (this._visible !== value) {\r\n      this._visible = coerceBooleanProperty(value);\r\n      this.visibleChange.emit(value);\r\n    }\r\n  };\r\n  get visible() {\r\n    return this._visible;\r\n  }\r\n  private _visible = true;\r\n\r\n  /**\r\n   * Event triggered on the alert dismiss.\r\n   */\r\n  @Output() visibleChange: EventEmitter<boolean> = new EventEmitter();\r\n\r\n  templates: any = {};\r\n  @ContentChildren(TemplateIdDirective, {descendants: true}) contentTemplates!: QueryList<TemplateIdDirective>;\r\n\r\n  @HostBinding('@.disabled')\r\n  get animationDisabled(): boolean {\r\n    return !this.fade;\r\n  }\r\n\r\n  @HostBinding('@fadeInOut')\r\n  get animateType(): AnimateType {\r\n    return this.visible ? 'show' : 'hide';\r\n  }\r\n\r\n  @HostBinding('class')\r\n  get hostClasses(): any {\r\n    return {\r\n      alert: true,\r\n      'alert-dismissible': this.dismissible,\r\n      fade: this.fade,\r\n      show: !this.hide,\r\n      [`alert-${this.color}`]: !!this.color && this.variant !== 'solid',\r\n      [`bg-${this.color}`]: !!this.color && this.variant === 'solid',\r\n      'text-white': !!this.color && this.variant === 'solid'\r\n    };\r\n  }\r\n\r\n  @HostListener('@fadeInOut.start', ['$event'])\r\n  onAnimationStart($event: AnimationEvent): void {\r\n    this.onAnimationEvent($event);\r\n  }\r\n\r\n  @HostListener('@fadeInOut.done', ['$event'])\r\n  onAnimationDone($event: AnimationEvent): void {\r\n    this.onAnimationEvent($event);\r\n  }\r\n\r\n  ngAfterContentInit(): void {\r\n    this.contentTemplates.forEach((child: TemplateIdDirective) => {\r\n      this.templates[child.id] = child.templateRef;\r\n    });\r\n  }\r\n\r\n  onAnimationEvent(event: AnimationEvent): void {\r\n    this.hide = event.phaseName === 'start' && event.toState === 'show';\r\n    if (event.phaseName === 'done') {\r\n      this.hide = (event.toState === 'hide' || event.toState === 'void');\r\n      if (event.toState === 'show') {\r\n        this.hide = false;\r\n      }\r\n    }\r\n  }\r\n}\r\n","<ng-container *ngIf=\"visible || !hide\">\n  <ng-template [ngIf]=\"dismissible\">\n    <ng-container *ngTemplateOutlet=\"templates?.alertButtonCloseTemplate || defaultAlertButtonCloseTemplate\">\n    </ng-container>\n  </ng-template>\n  <ng-content></ng-content>\n</ng-container>\n\n<ng-template #defaultAlertButtonCloseTemplate>\n  <button (click)=\"visible=false\" aria-label=\"Close\" cButtonClose></button>\n</ng-template>\n"]}