UNPKG

igniteui-angular

Version:

Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps

587 lines • 35.2 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { animate, state, style, transition, trigger } from '@angular/animations'; import { CommonModule } from '@angular/common'; import { Component, ElementRef, EventEmitter, HostBinding, Input, NgModule, Optional, Output } from '@angular/core'; import { IgxNavigationService } from '../core/navigation'; /** @type {?} */ 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; /** * 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; /** * 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; * ``` * \@memberof IgxToastComponent */ this.isVisible = false; /** * 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, "element", { /** * Gets the nativeElement of the toast. * ```typescript * let nativeElement = this.toast.element; * ``` * @memberof IgxToastComponent */ get: /** * Gets the nativeElement of the toast. * ```typescript * let nativeElement = this.toast.element; * ``` * \@memberof IgxToastComponent * @return {?} */ 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 */ /** * Shows the toast. * If `autoHide` is enabled, the toast will hide after `displayTime` is over. * ```typescript * this.toast.show(); * ``` * \@memberof IgxToastComponent * @return {?} */ IgxToastComponent.prototype.show = /** * Shows the toast. * If `autoHide` is enabled, the toast will hide after `displayTime` is over. * ```typescript * this.toast.show(); * ``` * \@memberof IgxToastComponent * @return {?} */ 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 */ /** * Hides the toast. * ```typescript * this.toast.hide(); * ``` * \@memberof IgxToastComponent * @return {?} */ IgxToastComponent.prototype.hide = /** * Hides the toast. * ```typescript * this.toast.hide(); * ``` * \@memberof IgxToastComponent * @return {?} */ function () { this.onHiding.emit(this); this.isVisible = false; this.onHidden.emit(this); clearInterval(this.timeoutId); }; /** * Wraps @show() method due @IToggleView interface implementation. * @hidden */ /** * Wraps \@show() method due \@IToggleView interface implementation. * @hidden * @return {?} */ IgxToastComponent.prototype.open = /** * Wraps \@show() method due \@IToggleView interface implementation. * @hidden * @return {?} */ function () { this.show(); }; /** * Wraps @hide() method due @IToggleView interface implementation. * @hidden */ /** * Wraps \@hide() method due \@IToggleView interface implementation. * @hidden * @return {?} */ IgxToastComponent.prototype.close = /** * Wraps \@hide() method due \@IToggleView interface implementation. * @hidden * @return {?} */ function () { this.hide(); }; /** * Toggles the visible state of the toast. * ```typescript * this.toast.toggle(); * ``` * @memberof IgxToastComponent */ /** * Toggles the visible state of the toast. * ```typescript * this.toast.toggle(); * ``` * \@memberof IgxToastComponent * @return {?} */ IgxToastComponent.prototype.toggle = /** * Toggles the visible state of the toast. * ```typescript * this.toast.toggle(); * ``` * \@memberof IgxToastComponent * @return {?} */ 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 */ /** * Sets/gets the class name of the toast based on the `position` value. * ```typescript * let className = this.toast.mapPositionToClassName(); * ``` * \@memberof IgxToastComponent * @return {?} */ IgxToastComponent.prototype.mapPositionToClassName = /** * Sets/gets the class name of the toast based on the `position` value. * ```typescript * let className = this.toast.mapPositionToClassName(); * ``` * \@memberof IgxToastComponent * @return {?} */ 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 */ /** * @hidden * @return {?} */ IgxToastComponent.prototype.ngOnInit = /** * @hidden * @return {?} */ function () { if (this.navService && this.id) { this.navService.add(this.id, this); } }; /** *@hidden */ /** * @hidden * @return {?} */ IgxToastComponent.prototype.ngOnDestroy = /** * @hidden * @return {?} */ function () { if (this.navService && this.id) { this.navService.remove(this.id); } }; IgxToastComponent.decorators = [ { type: Component, args: [{ 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 "] }] } ]; /** @nocollapse */ IgxToastComponent.ctorParameters = function () { return [ { type: ElementRef }, { type: IgxNavigationService, decorators: [{ type: Optional }] } ]; }; IgxToastComponent.propDecorators = { id: [{ type: HostBinding, args: ['attr.id',] }, { type: Input }], onShowing: [{ type: Output }], onShown: [{ type: Output }], onHiding: [{ type: Output }], onHidden: [{ type: Output }], role: [{ type: Input }], autoHide: [{ type: Input }], displayTime: [{ type: Input }], isVisible: [{ type: Input }], message: [{ type: Input }], position: [{ type: Input }] }; return IgxToastComponent; }()); export { IgxToastComponent }; if (false) { /** * Returns a list of available CSS classes. * ```typescript * let toastClasses = this.toast.CSS_CLASSES; * ``` * \@memberof IgxToastComponent * @type {?} */ IgxToastComponent.prototype.CSS_CLASSES; /** * 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; * ``` * @type {?} */ IgxToastComponent.prototype.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 * @type {?} */ IgxToastComponent.prototype.onShowing; /** * 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 * @type {?} */ IgxToastComponent.prototype.onShown; /** * 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 * @type {?} */ IgxToastComponent.prototype.onHiding; /** * 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 * @type {?} */ IgxToastComponent.prototype.onHidden; /** * 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 * @type {?} */ IgxToastComponent.prototype.role; /** * 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 * @type {?} */ IgxToastComponent.prototype.autoHide; /** * 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 * @type {?} */ IgxToastComponent.prototype.displayTime; /** * 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; * ``` * \@memberof IgxToastComponent * @type {?} */ IgxToastComponent.prototype.isVisible; /** * Sets/gets the message that will be shown by the toast. * ```html * <igx-toast [message] = "Notification"></igx-toast> * ``` * ```typescript * let toastMessage = this.toast.message; * ``` * \@memberof IgxToastComponent * @type {?} */ IgxToastComponent.prototype.message; /** * 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 * @type {?} */ IgxToastComponent.prototype.position; /** * @hidden * @type {?} * @private */ IgxToastComponent.prototype.timeoutId; /** * @type {?} * @private */ IgxToastComponent.prototype.elementRef; /** * @type {?} * @private */ IgxToastComponent.prototype.navService; } /** @enum {number} */ var IgxToastPosition = { Bottom: 0, Middle: 1, Top: 2, }; export { IgxToastPosition }; IgxToastPosition[IgxToastPosition.Bottom] = 'Bottom'; IgxToastPosition[IgxToastPosition.Middle] = 'Middle'; IgxToastPosition[IgxToastPosition.Top] = 'Top'; /** * @hidden */ var IgxToastModule = /** @class */ (function () { function IgxToastModule() { } IgxToastModule.decorators = [ { type: NgModule, args: [{ declarations: [IgxToastComponent], exports: [IgxToastComponent], imports: [CommonModule] },] } ]; 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    /**\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     * @memberof IgxToastComponent\n     */\n    @Input()\n    public isVisible = false;\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"]}