@coreui/angular
Version:
CoreUI Components Library for Angular
173 lines • 21.1 kB
JavaScript
import { booleanAttribute, Component, ContentChildren, EventEmitter, HostBinding, HostListener, Input, Output } from '@angular/core';
import { NgTemplateOutlet } from '@angular/common';
import { animate, state, style, transition, trigger } from '@angular/animations';
import { TemplateIdDirective } from '../shared';
import { ButtonCloseDirective } from '../button';
import * as i0 from "@angular/core";
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';
/**
* Default role for alert. [docs]
* @type string
* @default 'alert'
*/
this.role = 'alert';
/**
* 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
* @default false
*/
this.dismissible = false;
/**
* Adds animation for dismissible alert.
* @type boolean
*/
this.fade = false;
this.#visible = true;
}
/**
* Toggle the visibility of alert component.
* @type boolean
*/
set visible(value) {
if (this.#visible !== value) {
this.#visible = value;
this.visibleChange.emit(value);
}
}
;
get visible() {
return this.#visible;
}
#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;
}
}
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: AlertComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.12", type: AlertComponent, isStandalone: true, selector: "c-alert", inputs: { color: "color", role: "role", variant: "variant", dismissible: ["dismissible", "dismissible", booleanAttribute], fade: ["fade", "fade", booleanAttribute], visible: ["visible", "visible", booleanAttribute] }, 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: "@if (visible || !hide) {\n @if (dismissible) {\n <ng-container *ngTemplateOutlet=\"templates?.alertButtonCloseTemplate || defaultAlertButtonCloseTemplate\" />\n }\n <ng-content />\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: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: 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: "18.2.12", ngImport: i0, type: AlertComponent, decorators: [{
type: Component,
args: [{ selector: 'c-alert', exportAs: 'cAlert', standalone: true, imports: [NgTemplateOutlet, ButtonCloseDirective], 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: "@if (visible || !hide) {\n @if (dismissible) {\n <ng-container *ngTemplateOutlet=\"templates?.alertButtonCloseTemplate || defaultAlertButtonCloseTemplate\" />\n }\n <ng-content />\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
}], role: [{
type: HostBinding,
args: ['attr.role']
}, {
type: Input
}], variant: [{
type: Input
}], visibleChange: [{
type: Output
}], contentTemplates: [{
type: ContentChildren,
args: [TemplateIdDirective, { descendants: true }]
}], dismissible: [{
type: Input,
args: [{ transform: booleanAttribute }]
}], fade: [{
type: Input,
args: [{ transform: booleanAttribute }]
}], visible: [{
type: Input,
args: [{ transform: booleanAttribute }]
}], 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 {\n  AfterContentInit,\n  booleanAttribute,\n  Component,\n  ContentChildren,\n  EventEmitter,\n  HostBinding,\n  HostListener,\n  Input,\n  Output,\n  QueryList\n} from '@angular/core';\nimport { NgTemplateOutlet } from '@angular/common';\nimport { animate, AnimationEvent, state, style, transition, trigger } from '@angular/animations';\n\nimport { Colors } from '../coreui.types';\nimport { TemplateIdDirective } from '../shared';\nimport { ButtonCloseDirective } from '../button';\n\ntype AnimateType = ('hide' | 'show');\n\n@Component({\n  selector: 'c-alert',\n  templateUrl: './alert.component.html',\n  styleUrls: ['./alert.component.scss'],\n  exportAs: 'cAlert',\n  standalone: true,\n  imports: [NgTemplateOutlet, ButtonCloseDirective],\n  animations: [\n    trigger('fadeInOut', [\n      state('show', style({ opacity: 1, height: '*', padding: '*', border: '*', margin: '*' })),\n      state('hide', style({ opacity: 0, height: 0, padding: 0, border: 0, margin: 0 })),\n      state('void', style({ opacity: 0, height: 0, padding: 0, border: 0, margin: 0 })),\n      transition('show => hide', [\n        animate('.3s ease-out')\n      ]),\n      transition('hide => show', [\n        animate('.3s ease-in')\n      ]),\n      transition('show => void', [\n        animate('.3s ease-out')\n      ]),\n      transition('void => show', [\n        animate('.3s ease-in')\n      ])\n    ])\n  ]\n})\nexport class AlertComponent implements AfterContentInit {\n\n  hide!: boolean;\n  /**\n   * Sets the color context of the component to one of CoreUI’s themed colors.\n   *\n   * @type Colors\n   * @default 'primary'\n   */\n  @Input() color: Colors = 'primary';\n  /**\n   * Default role for alert. [docs]\n   * @type string\n   * @default 'alert'\n   */\n  @HostBinding('attr.role')\n  @Input() role = 'alert';\n  /**\n   * Set the alert variant to a solid.\n   * @type string\n   */\n  @Input() variant?: 'solid' | string;\n  /**\n   * Event triggered on the alert dismiss.\n   */\n  @Output() visibleChange: EventEmitter<boolean> = new EventEmitter();\n  templates: any = {};\n  @ContentChildren(TemplateIdDirective, { descendants: true }) contentTemplates!: QueryList<TemplateIdDirective>;\n\n  /**\n   * Optionally adds a close button to alert and allow it to self dismiss.\n   * @type boolean\n   * @default false\n   */\n  @Input({ transform: booleanAttribute }) dismissible: boolean = false;\n\n  /**\n   * Adds animation for dismissible alert.\n   * @type boolean\n   */\n  @Input({ transform: booleanAttribute }) fade: boolean = false;\n\n  /**\n   * Toggle the visibility of alert component.\n   * @type boolean\n   */\n  @Input({ transform: booleanAttribute })\n  set visible(value: boolean) {\n    if (this.#visible !== value) {\n      this.#visible = value;\n      this.visibleChange.emit(value);\n    }\n  };\n\n  get visible() {\n    return this.#visible;\n  }\n\n  #visible: boolean = true;\n\n  @HostBinding('@.disabled')\n  get animationDisabled(): boolean {\n    return !this.fade;\n  }\n\n  @HostBinding('@fadeInOut')\n  get animateType(): AnimateType {\n    return this.visible ? 'show' : 'hide';\n  }\n\n  @HostBinding('class')\n  get hostClasses(): any {\n    return {\n      alert: true,\n      'alert-dismissible': this.dismissible,\n      fade: this.fade,\n      show: !this.hide,\n      [`alert-${this.color}`]: !!this.color && this.variant !== 'solid',\n      [`bg-${this.color}`]: !!this.color && this.variant === 'solid',\n      'text-white': !!this.color && this.variant === 'solid'\n    };\n  }\n\n  @HostListener('@fadeInOut.start', ['$event'])\n  onAnimationStart($event: AnimationEvent): void {\n    this.onAnimationEvent($event);\n  }\n\n  @HostListener('@fadeInOut.done', ['$event'])\n  onAnimationDone($event: AnimationEvent): void {\n    this.onAnimationEvent($event);\n  }\n\n  ngAfterContentInit(): void {\n    this.contentTemplates.forEach((child: TemplateIdDirective) => {\n      this.templates[child.id] = child.templateRef;\n    });\n  }\n\n  onAnimationEvent(event: AnimationEvent): void {\n    this.hide = event.phaseName === 'start' && event.toState === 'show';\n    if (event.phaseName === 'done') {\n      this.hide = (event.toState === 'hide' || event.toState === 'void');\n      if (event.toState === 'show') {\n        this.hide = false;\n      }\n    }\n  }\n}\n","@if (visible || !hide) {\n  @if (dismissible) {\n    <ng-container *ngTemplateOutlet=\"templates?.alertButtonCloseTemplate || defaultAlertButtonCloseTemplate\" />\n  }\n  <ng-content />\n}\n<ng-template #defaultAlertButtonCloseTemplate>\n  <button (click)=\"visible=false\" aria-label=\"Close\" cButtonClose></button>\n</ng-template>\n"]}