UNPKG

@coreui/angular

Version:

CoreUI Components Library for Angular

173 lines 21.1 kB
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"]}