import { Attribute, Component, ContentChild, Directive, EventEmitter, Input, Output, TemplateRef, ViewEncapsulation, } from '@angular/core';
import { take } from 'rxjs/operators';
import { ngbRunTransition } from '../util/transition/ngbTransition';
import { ngbToastFadeInTransition, ngbToastFadeOutTransition } from './toast-transition';
import * as i0 from "@angular/core";
import * as i1 from "./toast-config";
import * as i2 from "@angular/common";
/**
* This directive allows the usage of HTML markup or other directives
* inside of the toast's header.
*
* @since 5.0.0
*/
export class NgbToastHeader {
}
NgbToastHeader.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.6", ngImport: i0, type: NgbToastHeader, deps: [], target: i0.ɵɵFactoryTarget.Directive });
NgbToastHeader.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.6", type: NgbToastHeader, selector: "[ngbToastHeader]", ngImport: i0 });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.6", ngImport: i0, type: NgbToastHeader, decorators: [{
type: Directive,
args: [{ selector: '[ngbToastHeader]' }]
}] });
/**
* Toasts provide feedback messages as notifications to the user.
* Goal is to mimic the push notifications available both on mobile and desktop operating systems.
*
* @since 5.0.0
*/
export class NgbToast {
constructor(ariaLive, config, _zone, _element) {
this.ariaLive = ariaLive;
this._zone = _zone;
this._element = _element;
/**
* A template like `` can be
* used in the projected content to allow markup usage.
*/
this.contentHeaderTpl = null;
/**
* An event fired after the animation triggered by calling `.show()` method has finished.
*
* @since 8.0.0
*/
this.shown = new EventEmitter();
/**
* An event fired after the animation triggered by calling `.hide()` method has finished.
*
* It can only occur in 2 different scenarios:
* - `autohide` timeout fires
* - user clicks on a closing cross
*
* Additionally this output is purely informative. The toast won't be removed from DOM automatically, it's up
* to the user to take care of that.
*
* @since 8.0.0
*/
this.hidden = new EventEmitter();
if (this.ariaLive == null) {
this.ariaLive = config.ariaLive;
}
this.delay = config.delay;
this.autohide = config.autohide;
this.animation = config.animation;
}
ngAfterContentInit() {
this._zone.onStable
.asObservable()
.pipe(take(1))
.subscribe(() => {
this._init();
this.show();
});
}
ngOnChanges(changes) {
if ('autohide' in changes) {
this._clearTimeout();
this._init();
}
}
/**
* Triggers toast closing programmatically.
*
* The returned observable will emit and be completed once the closing transition has finished.
* If the animations are turned off this happens synchronously.
*
* Alternatively you could listen or subscribe to the `(hidden)` output
*
* @since 8.0.0
*/
hide() {
this._clearTimeout();
const transition = ngbRunTransition(this._zone, this._element.nativeElement, ngbToastFadeOutTransition, {
animation: this.animation,
runningTransition: 'stop',
});
transition.subscribe(() => {
this.hidden.emit();
});
return transition;
}
/**
* Triggers toast opening programmatically.
*
* The returned observable will emit and be completed once the opening transition has finished.
* If the animations are turned off this happens synchronously.
*
* Alternatively you could listen or subscribe to the `(shown)` output
*
* @since 8.0.0
*/
show() {
const transition = ngbRunTransition(this._zone, this._element.nativeElement, ngbToastFadeInTransition, {
animation: this.animation,
runningTransition: 'continue',
});
transition.subscribe(() => {
this.shown.emit();
});
return transition;
}
_init() {
if (this.autohide && !this._timeoutID) {
this._timeoutID = setTimeout(() => this.hide(), this.delay);
}
}
_clearTimeout() {
if (this._timeoutID) {
clearTimeout(this._timeoutID);
this._timeoutID = null;
}
}
}
NgbToast.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.6", ngImport: i0, type: NgbToast, deps: [{ token: 'aria-live', attribute: true }, { token: i1.NgbToastConfig }, { token: i0.NgZone }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
NgbToast.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.6", type: NgbToast, selector: "ngb-toast", inputs: { animation: "animation", delay: "delay", autohide: "autohide", header: "header" }, outputs: { shown: "shown", hidden: "hidden" }, host: { attributes: { "role": "alert", "aria-atomic": "true" }, properties: { "attr.aria-live": "ariaLive", "class.fade": "animation" }, classAttribute: "toast" }, queries: [{ propertyName: "contentHeaderTpl", first: true, predicate: NgbToastHeader, descendants: true, read: TemplateRef, static: true }], exportAs: ["ngbToast"], usesOnChanges: true, ngImport: i0, template: `
{{ header }}
`, isInline: true, styles: ["ngb-toast{display:block}ngb-toast .toast-header .close{margin-left:auto;margin-bottom:.25rem}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], encapsulation: i0.ViewEncapsulation.None });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.6", ngImport: i0, type: NgbToast, decorators: [{
type: Component,
args: [{ selector: 'ngb-toast', exportAs: 'ngbToast', encapsulation: ViewEncapsulation.None, host: {
role: 'alert',
'[attr.aria-live]': 'ariaLive',
'aria-atomic': 'true',
class: 'toast',
'[class.fade]': 'animation',
}, template: `
{{ header }}
`, styles: ["ngb-toast{display:block}ngb-toast .toast-header .close{margin-left:auto;margin-bottom:.25rem}\n"] }]
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
type: Attribute,
args: ['aria-live']
}] }, { type: i1.NgbToastConfig }, { type: i0.NgZone }, { type: i0.ElementRef }]; }, propDecorators: { animation: [{
type: Input
}], delay: [{
type: Input
}], autohide: [{
type: Input
}], header: [{
type: Input
}], contentHeaderTpl: [{
type: ContentChild,
args: [NgbToastHeader, { read: TemplateRef, static: true }]
}], shown: [{
type: Output
}], hidden: [{
type: Output
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toast.js","sourceRoot":"","sources":["../../../../src/toast/toast.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n\tAfterContentInit,\n\tAttribute,\n\tComponent,\n\tContentChild,\n\tDirective,\n\tEventEmitter,\n\tInput,\n\tOnChanges,\n\tOutput,\n\tSimpleChanges,\n\tTemplateRef,\n\tViewEncapsulation,\n\tElementRef,\n\tNgZone,\n} from '@angular/core';\n\nimport { Observable } from 'rxjs';\nimport { take } from 'rxjs/operators';\n\nimport { NgbToastConfig } from './toast-config';\nimport { ngbRunTransition } from '../util/transition/ngbTransition';\nimport { ngbToastFadeInTransition, ngbToastFadeOutTransition } from './toast-transition';\n\n/**\n * This directive allows the usage of HTML markup or other directives\n * inside of the toast's header.\n *\n * @since 5.0.0\n */\n@Directive({ selector: '[ngbToastHeader]' })\nexport class NgbToastHeader {}\n\n/**\n * Toasts provide feedback messages as notifications to the user.\n * Goal is to mimic the push notifications available both on mobile and desktop operating systems.\n *\n * @since 5.0.0\n */\n@Component({\n\tselector: 'ngb-toast',\n\texportAs: 'ngbToast',\n\tencapsulation: ViewEncapsulation.None,\n\thost: {\n\t\trole: 'alert',\n\t\t'[attr.aria-live]': 'ariaLive',\n\t\t'aria-atomic': 'true',\n\t\tclass: 'toast',\n\t\t'[class.fade]': 'animation',\n\t},\n\ttemplate: `\n\t\t<ng-template #headerTpl>\n\t\t\t<strong class=\"me-auto\">{{ header }}</strong>\n\t\t</ng-template>\n\t\t<ng-template [ngIf]=\"contentHeaderTpl || header\">\n\t\t\t<div class=\"toast-header\">\n\t\t\t\t<ng-template [ngTemplateOutlet]=\"contentHeaderTpl || headerTpl\"></ng-template>\n\t\t\t\t<button\n\t\t\t\t\ttype=\"button\"\n\t\t\t\t\tclass=\"btn-close\"\n\t\t\t\t\taria-label=\"Close\"\n\t\t\t\t\ti18n-aria-label=\"@@ngb.toast.close-aria\"\n\t\t\t\t\t(click)=\"hide()\"\n\t\t\t\t>\n\t\t\t\t</button>\n\t\t\t</div>\n\t\t</ng-template>\n\t\t<div class=\"toast-body\">\n\t\t\t<ng-content></ng-content>\n\t\t</div>\n\t`,\n\tstyleUrls: ['./toast.scss'],\n})\nexport class NgbToast implements AfterContentInit, OnChanges {\n\t/**\n\t * If `true`, toast opening and closing will be animated.\n\t *\n\t * Animation is triggered only when the `.hide()` or `.show()` functions are called\n\t *\n\t * @since 8.0.0\n\t */\n\t@Input() animation: boolean;\n\n\tprivate _timeoutID;\n\n\t/**\n\t * Delay after which the toast will hide (ms).\n\t * default: `500` (ms) (inherited from NgbToastConfig)\n\t */\n\t@Input() delay: number;\n\n\t/**\n\t * Auto hide the toast after a delay in ms.\n\t * default: `true` (inherited from NgbToastConfig)\n\t */\n\t@Input() autohide: boolean;\n\n\t/**\n\t * Text to be used as toast's header.\n\t * Ignored if a ContentChild template is specified at the same time.\n\t */\n\t@Input() header: string;\n\n\t/**\n\t * A template like `<ng-template ngbToastHeader></ng-template>` can be\n\t * used in the projected content to allow markup usage.\n\t */\n\t@ContentChild(NgbToastHeader, { read: TemplateRef, static: true }) contentHeaderTpl: TemplateRef<any> | null = null;\n\n\t/**\n\t * An event fired after the animation triggered by calling `.show()` method has finished.\n\t *\n\t * @since 8.0.0\n\t */\n\t@Output() shown = new EventEmitter<void>();\n\n\t/**\n\t * An event fired after the animation triggered by calling `.hide()` method has finished.\n\t *\n\t * It can only occur in 2 different scenarios:\n\t * - `autohide` timeout fires\n\t * - user clicks on a closing cross\n\t *\n\t * Additionally this output is purely informative. The toast won't be removed from DOM automatically, it's up\n\t * to the user to take care of that.\n\t *\n\t * @since 8.0.0\n\t */\n\t@Output() hidden = new EventEmitter<void>();\n\n\tconstructor(\n\t\t@Attribute('aria-live') public ariaLive: string,\n\t\tconfig: NgbToastConfig,\n\t\tprivate _zone: NgZone,\n\t\tprivate _element: ElementRef,\n\t) {\n\t\tif (this.ariaLive == null) {\n\t\t\tthis.ariaLive = config.ariaLive;\n\t\t}\n\t\tthis.delay = config.delay;\n\t\tthis.autohide = config.autohide;\n\t\tthis.animation = config.animation;\n\t}\n\n\tngAfterContentInit() {\n\t\tthis._zone.onStable\n\t\t\t.asObservable()\n\t\t\t.pipe(take(1))\n\t\t\t.subscribe(() => {\n\t\t\t\tthis._init();\n\t\t\t\tthis.show();\n\t\t\t});\n\t}\n\n\tngOnChanges(changes: SimpleChanges) {\n\t\tif ('autohide' in changes) {\n\t\t\tthis._clearTimeout();\n\t\t\tthis._init();\n\t\t}\n\t}\n\n\t/**\n\t * Triggers toast closing programmatically.\n\t *\n\t * The returned observable will emit and be completed once the closing transition has finished.\n\t * If the animations are turned off this happens synchronously.\n\t *\n\t * Alternatively you could listen or subscribe to the `(hidden)` output\n\t *\n\t * @since 8.0.0\n\t */\n\thide(): Observable<void> {\n\t\tthis._clearTimeout();\n\t\tconst transition = ngbRunTransition(this._zone, this._element.nativeElement, ngbToastFadeOutTransition, {\n\t\t\tanimation: this.animation,\n\t\t\trunningTransition: 'stop',\n\t\t});\n\t\ttransition.subscribe(() => {\n\t\t\tthis.hidden.emit();\n\t\t});\n\t\treturn transition;\n\t}\n\n\t/**\n\t * Triggers toast opening programmatically.\n\t *\n\t * The returned observable will emit and be completed once the opening transition has finished.\n\t * If the animations are turned off this happens synchronously.\n\t *\n\t * Alternatively you could listen or subscribe to the `(shown)` output\n\t *\n\t * @since 8.0.0\n\t */\n\tshow(): Observable<void> {\n\t\tconst transition = ngbRunTransition(this._zone, this._element.nativeElement, ngbToastFadeInTransition, {\n\t\t\tanimation: this.animation,\n\t\t\trunningTransition: 'continue',\n\t\t});\n\t\ttransition.subscribe(() => {\n\t\t\tthis.shown.emit();\n\t\t});\n\t\treturn transition;\n\t}\n\n\tprivate _init() {\n\t\tif (this.autohide && !this._timeoutID) {\n\t\t\tthis._timeoutID = setTimeout(() => this.hide(), this.delay);\n\t\t}\n\t}\n\n\tprivate _clearTimeout() {\n\t\tif (this._timeoutID) {\n\t\t\tclearTimeout(this._timeoutID);\n\t\t\tthis._timeoutID = null;\n\t\t}\n\t}\n}\n"]}