@catull/igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
378 lines • 31.1 kB
JavaScript
import { __decorate, __metadata, __param } from "tslib";
import { animate, state, style, transition, trigger } from '@angular/animations';
import { CommonModule } from '@angular/common';
import { Component, ElementRef, EventEmitter, HostBinding, Input, NgModule, OnDestroy, OnInit, Optional, Output } from '@angular/core';
import { IgxNavigationService, IToggleView } from '../core/navigation';
var NEXT_ID = 0;
/**
* **Ignite UI for Angular Toast** -
* [Documentation](https://www.infragistics.com/products/ignite-ui-angular/angular/components/toast.html)
*
* The Ignite UI Toast provides information and warning messages that are non-interactive and cannot
* be dismissed by the user. Toasts can be displayed at the bottom, middle, or top of the page.
*
* Example:
* ```html
* <button (click)="toast.show()">Show notification</button>
* <igx-toast #toast
* message="Notification displayed"
* displayTime="1000">
* </igx-toast>
* ```
*/
var IgxToastComponent = /** @class */ (function () {
function IgxToastComponent(elementRef, navService) {
this.elementRef = elementRef;
this.navService = navService;
this._isVisible = false;
/**
* Returns a list of available CSS classes.
* ```typescript
* let toastClasses = this.toast.CSS_CLASSES;
* ```
* @memberof IgxToastComponent
*/
this.CSS_CLASSES = {
IGX_TOAST_BOTTOM: 'igx-toast--bottom',
IGX_TOAST_MIDDLE: 'igx-toast--middle',
IGX_TOAST_TOP: 'igx-toast--top'
};
/**
* Sets/gets the `id` of the toast.
* If not set, the `id` will have value `"igx-toast-0"`.
* ```html
* <igx-toast id = "my-first-toast"></igx-toast>
* ```
* ```typescript
* let toastId = this.toast.id;
* ```
*/
this.id = "igx-toast-" + NEXT_ID++;
/**
* Emits an event prior the toast is shown.
* Provides reference to the `IgxToastComponent` as event argument.
* ```html
* <igx-toast (onShowing) = "onShowing($event)"></igx-toast>
* ```
* @memberof IgxToastComponent
*/
this.onShowing = new EventEmitter();
/**
* Emits an event when the toast is shown.
* Provides reference to the `IgxToastComponent` as event argument.
* ```html
* <igx-toast (onShown) = "onShown($event)"></igx-toast>
* ```
* @memberof IgxToastComponent
*/
this.onShown = new EventEmitter();
/**
* Emits an event prior the toast is hidden.
* Provides reference to the `IgxToastComponent` as event argument.
* ```html
* <igx-toast (onHiding) = "onHiding($event)"></igx-toast>
* ```
* @memberof IgxToastComponent
*/
this.onHiding = new EventEmitter();
/**
* Emits an event when the toast is hidden.
* Provides reference to the `IgxToastComponent` as event argument.
* ```html
* <igx-toast (onHidden) = "onHidden($event)"></igx-toast>
* ```
* @memberof IgxToastComponent
*/
this.onHidden = new EventEmitter();
/**
* Sets/gets the `role` attribute.
* If not set, `role` will have value `"alert"`.
* ```html
* <igx-toast [role] = "'notify'"></igx-toast>
* ```
* ```typescript
* let toastRole = this.toast.role;
* ```
* @memberof IgxToastComponent
*/
this.role = 'alert';
/**
* Sets/gets whether the toast will be hidden after the `displayTime` is over.
* Default value is `true`.
* ```html
* <igx-toast [autoHide] = "false"></igx-toast>
* ```
* ```typescript
* let autoHide = this.toast.autoHide;
* ```
* @memberof IgxToastComponent
*/
this.autoHide = true;
/**
* Sets/gets the duration of time span(in milliseconds) which the toast will be visible
* after it is being shown.
* Default value is `4000`.
* ```html
* <igx-toast [displayTime] = "2500"></igx-toast>
* ```
* ```typescript
* let displayTime = this.toast.displayTime;
* ```
* @memberof IgxToastComponent
*/
this.displayTime = 4000;
/**
*@hidden
*/
this.isVisibleChange = new EventEmitter();
/**
* Sets/gets the position of the toast.
* If not set, the `position` attribute will have value `IgxToastPosition.Bottom`.
* ```html
* <igx-toast [position] = "top"></igx-toast>
* ```
* ```typescript
* let toastPosition = this.toast.position;
* ```
* @memberof IgxToastComponent
*/
this.position = IgxToastPosition.Bottom;
}
Object.defineProperty(IgxToastComponent.prototype, "isVisible", {
/**
* Enables/Disables the visibility of the toast.
* If not set, the `isVisible` attribute will have value `false`.
* ```html
* <igx-toast [isVisible] = "true"></igx-toast>
* ```
* ```typescript
* let isVisible = this.toast.isVisible;
* ```
*
* Two-way data binding.
* ```html
* <igx-toast [(isVisible)] = "model.isVisible"></igx-toast>
* ```
* @memberof IgxToastComponent
*/
get: function () {
return this._isVisible;
},
set: function (value) {
this._isVisible = value;
this.isVisibleChange.emit(this._isVisible);
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxToastComponent.prototype, "element", {
/**
* Gets the nativeElement of the toast.
* ```typescript
* let nativeElement = this.toast.element;
* ```
* @memberof IgxToastComponent
*/
get: function () {
return this.elementRef.nativeElement;
},
enumerable: true,
configurable: true
});
/**
* Shows the toast.
* If `autoHide` is enabled, the toast will hide after `displayTime` is over.
* ```typescript
* this.toast.show();
* ```
* @memberof IgxToastComponent
*/
IgxToastComponent.prototype.show = function () {
var _this = this;
clearInterval(this.timeoutId);
this.onShowing.emit(this);
this.isVisible = true;
if (this.autoHide) {
this.timeoutId = setTimeout(function () {
_this.hide();
}, this.displayTime);
}
this.onShown.emit(this);
};
/**
* Hides the toast.
* ```typescript
* this.toast.hide();
* ```
* @memberof IgxToastComponent
*/
IgxToastComponent.prototype.hide = function () {
this.onHiding.emit(this);
this.isVisible = false;
this.onHidden.emit(this);
clearInterval(this.timeoutId);
};
/**
* Wraps @show() method due @IToggleView interface implementation.
* @hidden
*/
IgxToastComponent.prototype.open = function () {
this.show();
};
/**
* Wraps @hide() method due @IToggleView interface implementation.
* @hidden
*/
IgxToastComponent.prototype.close = function () {
this.hide();
};
/**
* Toggles the visible state of the toast.
* ```typescript
* this.toast.toggle();
* ```
* @memberof IgxToastComponent
*/
IgxToastComponent.prototype.toggle = function () {
this.isVisible ? this.close() : this.open();
};
/**
* Sets/gets the class name of the toast based on the `position` value.
* ```typescript
* let className = this.toast.mapPositionToClassName();
* ```
* @memberof IgxToastComponent
*/
IgxToastComponent.prototype.mapPositionToClassName = function () {
if (this.position === IgxToastPosition.Top) {
return this.CSS_CLASSES.IGX_TOAST_TOP;
}
if (this.position === IgxToastPosition.Middle) {
return this.CSS_CLASSES.IGX_TOAST_MIDDLE;
}
if (this.position === IgxToastPosition.Bottom) {
return this.CSS_CLASSES.IGX_TOAST_BOTTOM;
}
};
/**
*@hidden
*/
IgxToastComponent.prototype.ngOnInit = function () {
if (this.navService && this.id) {
this.navService.add(this.id, this);
}
};
/**
*@hidden
*/
IgxToastComponent.prototype.ngOnDestroy = function () {
if (this.navService && this.id) {
this.navService.remove(this.id);
}
};
IgxToastComponent.ctorParameters = function () { return [
{ type: ElementRef },
{ type: IgxNavigationService, decorators: [{ type: Optional }] }
]; };
__decorate([
HostBinding('attr.id'),
Input(),
__metadata("design:type", Object)
], IgxToastComponent.prototype, "id", void 0);
__decorate([
Output(),
__metadata("design:type", Object)
], IgxToastComponent.prototype, "onShowing", void 0);
__decorate([
Output(),
__metadata("design:type", Object)
], IgxToastComponent.prototype, "onShown", void 0);
__decorate([
Output(),
__metadata("design:type", Object)
], IgxToastComponent.prototype, "onHiding", void 0);
__decorate([
Output(),
__metadata("design:type", Object)
], IgxToastComponent.prototype, "onHidden", void 0);
__decorate([
Input(),
__metadata("design:type", Object)
], IgxToastComponent.prototype, "role", void 0);
__decorate([
Input(),
__metadata("design:type", Object)
], IgxToastComponent.prototype, "autoHide", void 0);
__decorate([
Input(),
__metadata("design:type", Object)
], IgxToastComponent.prototype, "displayTime", void 0);
__decorate([
Input(),
__metadata("design:type", Object),
__metadata("design:paramtypes", [Object])
], IgxToastComponent.prototype, "isVisible", null);
__decorate([
Output(),
__metadata("design:type", Object)
], IgxToastComponent.prototype, "isVisibleChange", void 0);
__decorate([
Input(),
__metadata("design:type", String)
], IgxToastComponent.prototype, "message", void 0);
__decorate([
Input(),
__metadata("design:type", Number)
], IgxToastComponent.prototype, "position", void 0);
IgxToastComponent = __decorate([
Component({
animations: [
trigger('animate', [
state('show', style({
opacity: 1
})),
transition('* => show', animate('.20s ease')),
transition('show => *', animate('.40s ease-out'))
])
],
selector: 'igx-toast',
template: "<div [ngClass]=\"mapPositionToClassName()\" *ngIf=\"this.isVisible\" [@animate]=\"'show'\">\n {{ message }}\n</div>\n",
styles: ["\n :host {\n display: block;\n }\n "]
}),
__param(1, Optional()),
__metadata("design:paramtypes", [ElementRef,
IgxNavigationService])
], IgxToastComponent);
return IgxToastComponent;
}());
export { IgxToastComponent };
/**
* Enumeration for toast position
* Can be:
* Bottom
* Middle
* Top
*/
export var IgxToastPosition;
(function (IgxToastPosition) {
IgxToastPosition[IgxToastPosition["Bottom"] = 0] = "Bottom";
IgxToastPosition[IgxToastPosition["Middle"] = 1] = "Middle";
IgxToastPosition[IgxToastPosition["Top"] = 2] = "Top";
})(IgxToastPosition || (IgxToastPosition = {}));
/**
* @hidden
*/
var IgxToastModule = /** @class */ (function () {
function IgxToastModule() {
}
IgxToastModule = __decorate([
NgModule({
declarations: [IgxToastComponent],
exports: [IgxToastComponent],
imports: [CommonModule]
})
], IgxToastModule);
return IgxToastModule;
}());
export { IgxToastModule };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toast.component.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/toast/toast.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { animate, state, style, transition, trigger } from '@angular/animations';\nimport { CommonModule } from '@angular/common';\nimport {\n    Component,\n    ElementRef,\n    EventEmitter,\n    HostBinding,\n    Input,\n    NgModule,\n    OnDestroy,\n    OnInit,\n    Optional,\n    Output\n} from '@angular/core';\nimport { IgxNavigationService, IToggleView } from '../core/navigation';\n\nlet NEXT_ID = 0;\n/**\n * **Ignite UI for Angular Toast** -\n * [Documentation](https://www.infragistics.com/products/ignite-ui-angular/angular/components/toast.html)\n *\n * The Ignite UI Toast provides information and warning messages that are non-interactive and cannot\n * be dismissed by the user. Toasts can be displayed at the bottom, middle, or top of the page.\n *\n * Example:\n * ```html\n * <button (click)=\"toast.show()\">Show notification</button>\n * <igx-toast #toast\n *           message=\"Notification displayed\"\n *           displayTime=\"1000\">\n * </igx-toast>\n * ```\n */\n@Component({\n    animations: [\n        trigger('animate', [\n            state('show', style({\n                opacity: 1\n            })),\n            transition('* => show', animate('.20s ease')),\n            transition('show => *', animate('.40s ease-out'))\n        ])\n    ],\n    selector: 'igx-toast',\n    templateUrl: 'toast.component.html',\n    styles: [`\n        :host {\n            display: block;\n        }\n    `]\n})\nexport class IgxToastComponent implements IToggleView, OnInit, OnDestroy {\n    private _isVisible = false;\n    /**\n     * Returns a list of available CSS classes.\n     * ```typescript\n     * let toastClasses =  this.toast.CSS_CLASSES;\n     * ```\n     * @memberof IgxToastComponent\n     */\n    public readonly CSS_CLASSES = {\n        IGX_TOAST_BOTTOM: 'igx-toast--bottom',\n        IGX_TOAST_MIDDLE: 'igx-toast--middle',\n        IGX_TOAST_TOP: 'igx-toast--top'\n    };\n\n    /**\n     * Sets/gets the `id` of the toast.\n     * If not set, the `id` will have value `\"igx-toast-0\"`.\n     * ```html\n     * <igx-toast id = \"my-first-toast\"></igx-toast>\n     * ```\n     * ```typescript\n     * let toastId = this.toast.id;\n     * ```\n     */\n    @HostBinding('attr.id')\n    @Input()\n    public id = `igx-toast-${NEXT_ID++}`;\n\n    /**\n     * Emits an event prior the toast is shown.\n     * Provides reference to the `IgxToastComponent` as event argument.\n     * ```html\n     * <igx-toast (onShowing) = \"onShowing($event)\"></igx-toast>\n     * ```\n     * @memberof IgxToastComponent\n     */\n    @Output()\n    public onShowing = new EventEmitter<IgxToastComponent>();\n\n    /**\n     * Emits an event when the toast is shown.\n     * Provides reference to the `IgxToastComponent` as event argument.\n     * ```html\n     * <igx-toast (onShown) = \"onShown($event)\"></igx-toast>\n     * ```\n     * @memberof IgxToastComponent\n     */\n    @Output()\n    public onShown = new EventEmitter<IgxToastComponent>();\n\n    /**\n     * Emits an event prior the toast is hidden.\n     * Provides reference to the `IgxToastComponent` as event argument.\n     * ```html\n     * <igx-toast (onHiding) = \"onHiding($event)\"></igx-toast>\n     * ```\n     * @memberof IgxToastComponent\n     */\n    @Output()\n    public onHiding = new EventEmitter<IgxToastComponent>();\n\n    /**\n     *  Emits an event when the toast is hidden.\n     *  Provides reference to the `IgxToastComponent` as event argument.\n     * ```html\n     * <igx-toast (onHidden) = \"onHidden($event)\"></igx-toast>\n     * ```\n     * @memberof IgxToastComponent\n     */\n    @Output()\n    public onHidden = new EventEmitter<IgxToastComponent>();\n    /**\n     * Sets/gets the `role` attribute.\n     * If not set, `role` will have value `\"alert\"`.\n     * ```html\n     * <igx-toast [role] = \"'notify'\"></igx-toast>\n     * ```\n     * ```typescript\n     * let toastRole = this.toast.role;\n     * ```\n     * @memberof IgxToastComponent\n     */\n    @Input()\n    public role = 'alert';\n    /**\n     * Sets/gets whether the toast will be hidden after the `displayTime` is over.\n     * Default value is `true`.\n     * ```html\n     * <igx-toast [autoHide] = \"false\"></igx-toast>\n     * ```\n     * ```typescript\n     * let autoHide = this.toast.autoHide;\n     * ```\n     * @memberof IgxToastComponent\n     */\n    @Input()\n    public autoHide = true;\n\n    /**\n     * Sets/gets the duration of time span(in milliseconds) which the toast will be visible\n     * after it is being shown.\n     * Default value is `4000`.\n     * ```html\n     * <igx-toast [displayTime] = \"2500\"></igx-toast>\n     * ```\n     * ```typescript\n     * let displayTime = this.toast.displayTime;\n     * ```\n     * @memberof IgxToastComponent\n     */\n    @Input()\n    public displayTime = 4000;\n\n    /**\n     * Enables/Disables the visibility of the toast.\n     * If not set, the `isVisible` attribute will have value `false`.\n     * ```html\n     * <igx-toast [isVisible] = \"true\"></igx-toast>\n     * ```\n     * ```typescript\n     * let isVisible = this.toast.isVisible;\n     * ```\n     *\n     * Two-way data binding.\n     * ```html\n     * <igx-toast [(isVisible)] = \"model.isVisible\"></igx-toast>\n     * ```\n     * @memberof IgxToastComponent\n     */\n    @Input()\n    public get isVisible() {\n        return this._isVisible;\n    }\n    public set isVisible(value) {\n        this._isVisible = value;\n        this.isVisibleChange.emit(this._isVisible);\n\n    }\n\n    /**\n     *@hidden\n     */\n    @Output()\n    public isVisibleChange = new EventEmitter<boolean>();\n\n    /**\n     * Sets/gets the message that will be shown by the toast.\n     * ```html\n     * <igx-toast [message] = \"Notification\"></igx-toast>\n     * ```\n     * ```typescript\n     * let toastMessage = this.toast.message;\n     * ```\n     * @memberof IgxToastComponent\n     */\n    @Input()\n    public message: string;\n\n    /**\n     * Sets/gets the position of the toast.\n     * If not set, the `position` attribute will have value `IgxToastPosition.Bottom`.\n     * ```html\n     * <igx-toast [position] = \"top\"></igx-toast>\n     * ```\n     * ```typescript\n     * let toastPosition = this.toast.position;\n     * ```\n     * @memberof IgxToastComponent\n     */\n    @Input()\n    public position: IgxToastPosition = IgxToastPosition.Bottom;\n\n    /**\n     * Gets the nativeElement of the toast.\n     * ```typescript\n     * let nativeElement = this.toast.element;\n     * ```\n     * @memberof IgxToastComponent\n     */\n    public get element() {\n        return this.elementRef.nativeElement;\n    }\n    /**\n     *@hidden\n     */\n    private timeoutId;\n\n    constructor(\n        private elementRef: ElementRef,\n        @Optional() private navService: IgxNavigationService) { }\n\n    /**\n     * Shows the toast.\n     * If `autoHide` is enabled, the toast will hide after `displayTime` is over.\n     * ```typescript\n     * this.toast.show();\n     * ```\n     * @memberof IgxToastComponent\n     */\n    public show(): void {\n        clearInterval(this.timeoutId);\n        this.onShowing.emit(this);\n        this.isVisible = true;\n\n        if (this.autoHide) {\n            this.timeoutId = setTimeout(() => {\n                this.hide();\n            }, this.displayTime);\n        }\n\n        this.onShown.emit(this);\n    }\n\n    /**\n     * Hides the toast.\n     * ```typescript\n     * this.toast.hide();\n     * ```\n     * @memberof IgxToastComponent\n     */\n    public hide(): void {\n        this.onHiding.emit(this);\n        this.isVisible = false;\n        this.onHidden.emit(this);\n\n        clearInterval(this.timeoutId);\n    }\n\n    /**\n     * Wraps @show() method due @IToggleView interface implementation.\n     * @hidden\n     */\n    public open() {\n        this.show();\n    }\n\n    /**\n     * Wraps @hide() method due @IToggleView interface implementation.\n     * @hidden\n     */\n    public close() {\n        this.hide();\n    }\n\n    /**\n     * Toggles the visible state of the toast.\n     * ```typescript\n     * this.toast.toggle();\n     * ```\n     * @memberof IgxToastComponent\n     */\n    public toggle() {\n        this.isVisible ? this.close() : this.open();\n    }\n    /**\n     * Sets/gets the class name of the toast based on the `position` value.\n     * ```typescript\n     * let className =  this.toast.mapPositionToClassName();\n     * ```\n     * @memberof IgxToastComponent\n     */\n    public mapPositionToClassName(): any {\n        if (this.position === IgxToastPosition.Top) {\n            return this.CSS_CLASSES.IGX_TOAST_TOP;\n        }\n\n        if (this.position === IgxToastPosition.Middle) {\n            return this.CSS_CLASSES.IGX_TOAST_MIDDLE;\n        }\n\n        if (this.position === IgxToastPosition.Bottom) {\n            return this.CSS_CLASSES.IGX_TOAST_BOTTOM;\n        }\n    }\n    /**\n     *@hidden\n     */\n    public ngOnInit() {\n        if (this.navService && this.id) {\n            this.navService.add(this.id, this);\n        }\n    }\n    /**\n     *@hidden\n     */\n    public ngOnDestroy() {\n        if (this.navService && this.id) {\n            this.navService.remove(this.id);\n        }\n    }\n}\n\n/**\n * Enumeration for toast position\n * Can be:\n * Bottom\n * Middle\n * Top\n */\nexport enum IgxToastPosition {\n    Bottom,\n    Middle,\n    Top\n}\n\n/**\n * @hidden\n */\n@NgModule({\n    declarations: [IgxToastComponent],\n    exports: [IgxToastComponent],\n    imports: [CommonModule]\n})\nexport class IgxToastModule { }\n"]}