igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
403 lines • 27.6 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { transition, trigger, useAnimation } from '@angular/animations';
import { CommonModule } from '@angular/common';
import { Component, EventEmitter, HostBinding, Input, NgModule, NgZone, Output } from '@angular/core';
import { fadeIn, fadeOut, slideInBottom, slideOutBottom } from '../animations/main';
/** @type {?} */
var NEXT_ID = 0;
/**
* **Ignite UI for Angular Snackbar** -
* [Documentation](https://www.infragistics.com/products/ignite-ui-angular/angular/components/snackbar.html)
*
* The Ignite UI Snack Bar provides feedback about an operation with a single-line message, which can
* include a link to an action such as Undo.
*
* Example:
* ```html
* <button (click)="snackbar.show()">Send message</button>
* <div>
* <igx-snackbar #snackbar message="Message sent">
* </igx-snackbar>
* </div>
* ```
*/
var IgxSnackbarComponent = /** @class */ (function () {
function IgxSnackbarComponent(zone) {
this.zone = zone;
/**
* Sets/gets the `id` of the snackbar.
* If not set, the `id` of the first snackbar component will be `"igx-snackbar-0"`;
* ```html
* <igx-snackbar id = "Snackbar1"></igx-snackbar>
* ```
* ```typescript
* let snackbarId = this.snackbar.id;
* ```
* \@memberof IgxSnackbarComponent
*/
this.id = "igx-snackbar-" + NEXT_ID++;
/**
* Enables/Disables the visibility of the snackbar.
* If not set, the `isVisible` attribute will have value `false`.
* ```html
* <igx-snackbar [isVisible] = "true"></igx-snackbar>
* ```
* ```typescript
* let isVisible = this.snackbar.isVisible;
* ```
*/
this.isVisible = false;
/**
* Sets/gets if the snackbar will be automatically hidden after the `displayTime` is over.
* Default value is `true`.
* ```html
* <igx-snackbar [autoHide] = "false"></igx-snackbar>
* ```
* ```typescript
* let autoHide = this.snackbar.autoHide;
* ```
*/
this.autoHide = true;
/**
* Sets/gets the duration of time(in milliseconds) in which the snackbar will be visible after it is being shown.
* Default value is 4000.
* ```html
* <igx-snackbar [displayTime] = "2000"></igx-snackbar>
* ```
* ```typescript
* let displayTime = this.snackbar.displayTime;
* ```
*/
this.displayTime = 4000;
/**
* An event that will be emitted when the action is executed.
* Provides reference to the `IgxSnackbarComponent` as an argument.
* ```html
* <igx-snackbar (onAction) = "onAction($event)"></igx-snackbar>
* ```
*/
this.onAction = new EventEmitter();
/**
* An event that will be emitted when the snackbar animation starts.
* Provides reference to the `AnimationEvent` interface as an argument.
* ```html
* <igx-snackbar (animationStarted) = "animationStarted($event)"></igx-snackbar>
* ```
*/
this.animationStarted = new EventEmitter();
/**
* An event that will be emitted when the snackbar animation ends.
* Provides reference to the `AnimationEvent` interface as an argument.
* ```html
* <igx-snackbar (animationDone) = "animationDone($event)"></igx-snackbar>
* ```
*/
this.animationDone = new EventEmitter();
}
/**
* Shows the snackbar and hides it after the `displayTime` is over if `autoHide` is set to `true`.
* ```typescript
* this.snackbar.show();
* ```
*/
/**
* Shows the snackbar and hides it after the `displayTime` is over if `autoHide` is set to `true`.
* ```typescript
* this.snackbar.show();
* ```
* @return {?}
*/
IgxSnackbarComponent.prototype.show = /**
* Shows the snackbar and hides it after the `displayTime` is over if `autoHide` is set to `true`.
* ```typescript
* this.snackbar.show();
* ```
* @return {?}
*/
function () {
var _this = this;
clearTimeout(this.timeoutId);
setTimeout(this.timeoutId);
this.isVisible = true;
if (this.autoHide) {
this.timeoutId = setTimeout(function () {
_this.hide();
}, this.displayTime);
}
};
/**
* Hides the snackbar.
* ```typescript
* this.snackbar.hide();
* ```
*/
/**
* Hides the snackbar.
* ```typescript
* this.snackbar.hide();
* ```
* @return {?}
*/
IgxSnackbarComponent.prototype.hide = /**
* Hides the snackbar.
* ```typescript
* this.snackbar.hide();
* ```
* @return {?}
*/
function () {
this.isVisible = false;
clearTimeout(this.timeoutId);
};
/**
*@hidden
*/
/**
* @hidden
* @return {?}
*/
IgxSnackbarComponent.prototype.triggerAction = /**
* @hidden
* @return {?}
*/
function () {
this.onAction.emit(this);
};
/**
*@hidden
* @memberof IgxSnackbarComponent
*/
/**
* @hidden
* \@memberof IgxSnackbarComponent
* @param {?} evt
* @return {?}
*/
IgxSnackbarComponent.prototype.snackbarAnimationStarted = /**
* @hidden
* \@memberof IgxSnackbarComponent
* @param {?} evt
* @return {?}
*/
function (evt) {
if (evt.fromState === 'void') {
this.animationStarted.emit(evt);
}
};
/**
*@hidden
* @memberof IgxSnackbarComponent
*/
/**
* @hidden
* \@memberof IgxSnackbarComponent
* @param {?} evt
* @return {?}
*/
IgxSnackbarComponent.prototype.snackbarAnimationDone = /**
* @hidden
* \@memberof IgxSnackbarComponent
* @param {?} evt
* @return {?}
*/
function (evt) {
if (evt.fromState === 'show') {
this.animationDone.emit(evt);
}
};
IgxSnackbarComponent.decorators = [
{ type: Component, args: [{
animations: [
trigger('slideInOut', [
transition('void => *', [
useAnimation(slideInBottom, {
params: {
duration: '.35s',
easing: 'cubic-bezier(0.0, 0.0, 0.2, 1)',
fromPosition: 'translateY(100%)',
toPosition: 'translateY(0)'
}
})
]),
transition('* => void', [
useAnimation(slideOutBottom, {
params: {
duration: '.2s',
easing: 'cubic-bezier(0.4, 0.0, 1, 1)',
fromPosition: 'translateY(0)',
toOpacity: 1,
toPosition: 'translateY(100%)'
}
})
])
]),
trigger('fadeInOut', [
transition('void => *', [
useAnimation(fadeIn, {
params: {
duration: '.35s',
easing: 'ease-out'
}
})
]),
transition('* => void', [
useAnimation(fadeOut, {
params: {
duration: '.2s',
easing: 'ease-out'
}
})
])
])
],
selector: 'igx-snackbar',
template: "<div class=\"igx-snackbar\" *ngIf=\"isVisible\" (@slideInOut.start)=\"snackbarAnimationStarted($event)\" (@slideInOut.done)=\"snackbarAnimationDone($event)\"\n [@slideInOut]=\"isVisible\">\n <div class=\"igx-snackbar__message\" [@fadeInOut]=\"isVisible\">\n {{ message }}\n <ng-content></ng-content>\n </div>\n <button class=\"igx-snackbar__button\" igxRipple=\"white\" *ngIf=\"actionText\" [@fadeInOut] (click)=\"triggerAction()\">\n {{ actionText }}\n </button>\n</div>\n",
styles: ["\n :host {\n display: block;\n }\n "]
}] }
];
/** @nocollapse */
IgxSnackbarComponent.ctorParameters = function () { return [
{ type: NgZone }
]; };
IgxSnackbarComponent.propDecorators = {
id: [{ type: HostBinding, args: ['attr.id',] }, { type: Input }],
message: [{ type: Input }],
isVisible: [{ type: Input }],
autoHide: [{ type: Input }],
displayTime: [{ type: Input }],
actionText: [{ type: Input }],
onAction: [{ type: Output }],
animationStarted: [{ type: Output }],
animationDone: [{ type: Output }]
};
return IgxSnackbarComponent;
}());
export { IgxSnackbarComponent };
if (false) {
/**
* Sets/gets the `id` of the snackbar.
* If not set, the `id` of the first snackbar component will be `"igx-snackbar-0"`;
* ```html
* <igx-snackbar id = "Snackbar1"></igx-snackbar>
* ```
* ```typescript
* let snackbarId = this.snackbar.id;
* ```
* \@memberof IgxSnackbarComponent
* @type {?}
*/
IgxSnackbarComponent.prototype.id;
/**
* Sets/gets the `message` attribute.
* ```html
* <igx-snackbar [message] = "'Snackbar Component'"></igx-snackbar>
* ```
* ```typescript
* let message = this.snackbar.message;
* ```
* @type {?}
*/
IgxSnackbarComponent.prototype.message;
/**
* Enables/Disables the visibility of the snackbar.
* If not set, the `isVisible` attribute will have value `false`.
* ```html
* <igx-snackbar [isVisible] = "true"></igx-snackbar>
* ```
* ```typescript
* let isVisible = this.snackbar.isVisible;
* ```
* @type {?}
*/
IgxSnackbarComponent.prototype.isVisible;
/**
* Sets/gets if the snackbar will be automatically hidden after the `displayTime` is over.
* Default value is `true`.
* ```html
* <igx-snackbar [autoHide] = "false"></igx-snackbar>
* ```
* ```typescript
* let autoHide = this.snackbar.autoHide;
* ```
* @type {?}
*/
IgxSnackbarComponent.prototype.autoHide;
/**
* Sets/gets the duration of time(in milliseconds) in which the snackbar will be visible after it is being shown.
* Default value is 4000.
* ```html
* <igx-snackbar [displayTime] = "2000"></igx-snackbar>
* ```
* ```typescript
* let displayTime = this.snackbar.displayTime;
* ```
* @type {?}
*/
IgxSnackbarComponent.prototype.displayTime;
/**
* Sets/gets the `actionText` attribute.
* ```html
* <igx-snackbar [actionText] = "'Action Text'"></igx-snackbar>
* ```
* @type {?}
*/
IgxSnackbarComponent.prototype.actionText;
/**
* An event that will be emitted when the action is executed.
* Provides reference to the `IgxSnackbarComponent` as an argument.
* ```html
* <igx-snackbar (onAction) = "onAction($event)"></igx-snackbar>
* ```
* @type {?}
*/
IgxSnackbarComponent.prototype.onAction;
/**
* An event that will be emitted when the snackbar animation starts.
* Provides reference to the `AnimationEvent` interface as an argument.
* ```html
* <igx-snackbar (animationStarted) = "animationStarted($event)"></igx-snackbar>
* ```
* @type {?}
*/
IgxSnackbarComponent.prototype.animationStarted;
/**
* An event that will be emitted when the snackbar animation ends.
* Provides reference to the `AnimationEvent` interface as an argument.
* ```html
* <igx-snackbar (animationDone) = "animationDone($event)"></igx-snackbar>
* ```
* @type {?}
*/
IgxSnackbarComponent.prototype.animationDone;
/**
* @hidden
* @type {?}
* @private
*/
IgxSnackbarComponent.prototype.timeoutId;
/**
* @type {?}
* @private
*/
IgxSnackbarComponent.prototype.zone;
}
/**
* @hidden
*/
var IgxSnackbarModule = /** @class */ (function () {
function IgxSnackbarModule() {
}
IgxSnackbarModule.decorators = [
{ type: NgModule, args: [{
declarations: [IgxSnackbarComponent],
exports: [IgxSnackbarComponent],
imports: [CommonModule]
},] }
];
return IgxSnackbarModule;
}());
export { IgxSnackbarModule };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"snackbar.component.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/snackbar/snackbar.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    animate,\n    AnimationEvent,\n    state,\n    style,\n    transition,\n    trigger,\n    useAnimation\n} from '@angular/animations';\nimport { CommonModule } from '@angular/common';\nimport {\n    Component,\n    EventEmitter,\n    HostBinding,\n    Input,\n    NgModule,\n    NgZone,\n    Output\n} from '@angular/core';\nimport { fadeIn, fadeOut, slideInBottom, slideOutBottom } from '../animations/main';\n\nlet NEXT_ID = 0;\n/**\n * **Ignite UI for Angular Snackbar** -\n * [Documentation](https://www.infragistics.com/products/ignite-ui-angular/angular/components/snackbar.html)\n *\n * The Ignite UI Snack Bar provides feedback about an operation with a single-line message, which can\n * include a link to an action such as Undo.\n *\n * Example:\n * ```html\n * <button (click)=\"snackbar.show()\">Send message</button>\n * <div>\n *   <igx-snackbar #snackbar message=\"Message sent\">\n *   </igx-snackbar>\n * </div>\n * ```\n */\n@Component({\n    animations: [\n        trigger('slideInOut', [\n            transition('void => *', [\n                useAnimation(slideInBottom, {\n                    params: {\n                        duration: '.35s',\n                        easing: 'cubic-bezier(0.0, 0.0, 0.2, 1)',\n                        fromPosition: 'translateY(100%)',\n                        toPosition: 'translateY(0)'\n                    }\n                })\n            ]),\n            transition('* => void', [\n                useAnimation(slideOutBottom, {\n                    params: {\n                        duration: '.2s',\n                        easing: 'cubic-bezier(0.4, 0.0, 1, 1)',\n                        fromPosition: 'translateY(0)',\n                        toOpacity: 1,\n                        toPosition: 'translateY(100%)'\n                    }\n                })\n            ])\n        ]),\n        trigger('fadeInOut', [\n            transition('void => *', [\n                useAnimation(fadeIn, {\n                    params: {\n                        duration: '.35s',\n                        easing: 'ease-out'\n                    }\n                })\n            ]),\n            transition('* => void', [\n                useAnimation(fadeOut, {\n                    params: {\n                        duration: '.2s',\n                        easing: 'ease-out'\n                    }\n                })\n            ])\n        ])\n    ],\n    selector: 'igx-snackbar',\n    templateUrl: 'snackbar.component.html',\n    styles: [`\n        :host {\n            display: block;\n        }\n    `]\n})\nexport class IgxSnackbarComponent {\n\n    /**\n     * Sets/gets the `id` of the snackbar.\n     * If not set, the `id` of the first snackbar component  will be `\"igx-snackbar-0\"`;\n     * ```html\n     * <igx-snackbar id = \"Snackbar1\"></igx-snackbar>\n     * ```\n     * ```typescript\n     * let snackbarId = this.snackbar.id;\n     * ```\n     * @memberof IgxSnackbarComponent\n     */\n    @HostBinding('attr.id')\n    @Input()\n    public id = `igx-snackbar-${NEXT_ID++}`;\n    /**\n     * Sets/gets the `message` attribute.\n     * ```html\n     * <igx-snackbar [message] = \"'Snackbar Component'\"></igx-snackbar>\n     * ```\n     * ```typescript\n     * let message =  this.snackbar.message;\n     * ```\n     */\n    @Input() public message: string;\n\n    /**\n     * Enables/Disables the visibility of the snackbar.\n     * If not set, the `isVisible` attribute will have value `false`.\n     * ```html\n     * <igx-snackbar [isVisible] = \"true\"></igx-snackbar>\n     * ```\n     * ```typescript\n     * let isVisible =  this.snackbar.isVisible;\n     * ```\n     */\n    @Input() public isVisible = false;\n\n    /**\n     * Sets/gets if the snackbar will be automatically hidden after the `displayTime` is over.\n     * Default value is `true`.\n     * ```html\n     * <igx-snackbar [autoHide] = \"false\"></igx-snackbar>\n     * ```\n     * ```typescript\n     * let autoHide =  this.snackbar.autoHide;\n     * ```\n     */\n    @Input() public autoHide = true;\n\n    /**\n     * Sets/gets the duration of time(in milliseconds) in which the snackbar will be visible after it is being shown.\n     * Default value is 4000.\n     * ```html\n     * <igx-snackbar [displayTime] = \"2000\"></igx-snackbar>\n     * ```\n     * ```typescript\n     * let displayTime = this.snackbar.displayTime;\n     * ```\n     */\n    @Input() public displayTime = 4000;\n\n    /**\n     * Sets/gets the `actionText` attribute.\n     * ```html\n     * <igx-snackbar [actionText] = \"'Action Text'\"></igx-snackbar>\n     * ```\n     */\n    @Input() public actionText?: string;\n\n    /**\n     * An event that will be emitted when the action is executed.\n     * Provides reference to the `IgxSnackbarComponent` as an argument.\n     * ```html\n     * <igx-snackbar (onAction) = \"onAction($event)\"></igx-snackbar>\n     * ```\n     */\n    @Output() public onAction = new EventEmitter<IgxSnackbarComponent>();\n\n    /**\n     * An event that will be emitted when the snackbar animation starts.\n     * Provides reference to the `AnimationEvent` interface as an argument.\n     * ```html\n     * <igx-snackbar (animationStarted) = \"animationStarted($event)\"></igx-snackbar>\n     * ```\n     */\n    @Output() public animationStarted = new EventEmitter<AnimationEvent>();\n\n    /**\n     * An event that will be emitted when the snackbar animation ends.\n     * Provides reference to the `AnimationEvent` interface as an argument.\n     * ```html\n     * <igx-snackbar (animationDone) = \"animationDone($event)\"></igx-snackbar>\n     * ```\n     */\n    @Output() public animationDone = new EventEmitter<AnimationEvent>();\n    /**\n     *@hidden\n     */\n    private timeoutId;\n\n    constructor(private zone: NgZone) { }\n\n    /**\n     * Shows the snackbar and hides it after the `displayTime` is over if `autoHide` is set to `true`.\n     * ```typescript\n     * this.snackbar.show();\n     * ```\n     */\n    public show(): void {\n        clearTimeout(this.timeoutId);\n        setTimeout(this.timeoutId);\n        this.isVisible = true;\n\n        if (this.autoHide) {\n            this.timeoutId = setTimeout(() => {\n                this.hide();\n            }, this.displayTime);\n        }\n    }\n\n    /**\n     * Hides the snackbar.\n     * ```typescript\n     * this.snackbar.hide();\n     * ```\n     */\n    public hide(): void {\n        this.isVisible = false;\n        clearTimeout(this.timeoutId);\n    }\n    /**\n     *@hidden\n     */\n    public triggerAction(): void {\n        this.onAction.emit(this);\n    }\n    /**\n     *@hidden\n     * @memberof IgxSnackbarComponent\n     */\n    public snackbarAnimationStarted(evt: AnimationEvent): void {\n        if (evt.fromState === 'void') {\n            this.animationStarted.emit(evt);\n        }\n    }\n    /**\n     *@hidden\n     * @memberof IgxSnackbarComponent\n     */\n    public snackbarAnimationDone(evt: AnimationEvent): void {\n        if (evt.fromState === 'show') {\n            this.animationDone.emit(evt);\n        }\n    }\n}\n\n/**\n * @hidden\n */\n@NgModule({\n    declarations: [IgxSnackbarComponent],\n    exports: [IgxSnackbarComponent],\n    imports: [CommonModule]\n})\nexport class IgxSnackbarModule { }\n"]}