igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
695 lines • 55.7 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { useAnimation } from '@angular/animations';
import { CommonModule } from '@angular/common';
import { Component, ElementRef, EventEmitter, HostBinding, Input, NgModule, Optional, Output, ViewChild } from '@angular/core';
import { Subject } from 'rxjs';
import { takeUntil } from 'rxjs/operators';
import { IgxNavigationService } from '../core/navigation';
import { IgxButtonModule } from '../directives/button/button.directive';
import { IgxRippleModule } from '../directives/ripple/ripple.directive';
import { IgxDialogActionsDirective, IgxDialogTitleDirective } from './dialog.directives';
import { IgxToggleModule, IgxToggleDirective } from '../directives/toggle/toggle.directive';
import { GlobalPositionStrategy, NoOpScrollStrategy } from '../services';
import { slideInBottom, slideOutTop } from '../animations/slide/index';
import { IgxFocusModule } from '../directives/focus/focus.directive';
/** @type {?} */
let DIALOG_ID = 0;
/**
* **Ignite UI for Angular Dialog Window** -
* [Documentation](https://www.infragistics.com/products/ignite-ui-angular/angular/components/dialog.html)
*
* The Ignite UI Dialog Window presents a dialog window to the user which can simply display messages or display
* more complicated visuals such as a user sign-in form. It also provides a right and left button
* which can be used for custom actions.
*
* Example:
* ```html
* <button (click)="form.open()">Show Dialog</button>
* <igx-dialog #form title="Sign In" rightButtonLabel="OK">
* <div>
* <input type="text" igxInput/>
* <label igxLabel>Username</label>
* </div>
* <div>
* <input type="password" igxInput/>
* <label igxLabel>Password</label>
* </div>
* </igx-dialog>
* ```
*/
export class IgxDialogComponent {
/**
* @param {?} elementRef
* @param {?} navService
*/
constructor(elementRef, navService) {
this.elementRef = elementRef;
this.navService = navService;
/**
* An \@Input property that sets the value of the `id` attribute. If not provided it will be automatically generated.
* ```html
* <igx-dialog [id]="'igx-dialog-56'" #alert title="Notification" leftButtonLabel="OK" (onLeftButtonSelect)="alert.close()"></igx-dialog>
* ```
*/
this.id = `igx-dialog-${DIALOG_ID++}`;
/**
* An \@Input property controlling the `title` of the dialog.
* ```html
* <igx-dialog title="Notification" #alert leftButtonLabel="OK" (onLeftButtonSelect)="alert.close()"></igx-dialog>
* ```
*/
this.title = '';
/**
* An \@Input property controlling the `message` of the dialog.
* ```html
* <igx-dialog message="Your email was sent!" #alert leftButtonLabel="OK" (onLeftButtonSelect)="alert.close()"></igx-dialog>
* ```
*/
this.message = '';
/**
* An \@Input property to set the `label` of the left button of the dialog.
* ```html
* <igx-dialog leftButtonLabel="OKAY" #alert title="Notification" (onLeftButtonSelect)="alert.close()"></igx-dialog>
* ```
*/
this.leftButtonLabel = '';
/**
* An \@Input property to set the left button `type`. The types are `flat`, `raised` and `fab`.
* The `flat` type button is a rectangle and doesn't have a shadow. <br>
* The `raised` type button is also a rectangle but has a shadow. <br>
* The `fab` type button is a circle with a shadow. <br>
* The default value is `flat`.
* ```html
* <igx-dialog leftButtonType="raised" leftButtonLabel="OKAY" #alert (onLeftButtonSelect)="alert.close()"></igx-dialog>
* ```
*/
this.leftButtonType = 'flat';
/**
* An \@Input property to set the left button color. The property accepts all valid CSS color property values.
* ```html
* <igx-dialog leftButtonColor="yellow" leftButtonLabel="OKAY" #alert (onLeftButtonSelect)="alert.close()"></igx-dialog>
* ```
*/
this.leftButtonColor = '';
/**
* An \@Input property to set the left button `background-color`. The property accepts all valid CSS color property values.
* ```html
* <igx-dialog leftButtonBackgroundColor="black" leftButtonLabel="OKAY" #alert (onLeftButtonSelect)="alert.close()"></igx-dialog>
* ```
*/
this.leftButtonBackgroundColor = '';
/**
* An \@Input property to set the left button `ripple`. The `ripple` animates a click/tap to a component as a series of fading waves.
* The property accepts all valid CSS color property values.
* ```html
* <igx-dialog leftButtonRipple="green" leftButtonLabel="OKAY" #alert (onLeftButtonSelect)="alert.close()"></igx-dialog>
* ```
*/
this.leftButtonRipple = '';
/**
* An \@Input property to set the `label` of the right button of the dialog.
* ```html
* <igx-dialog rightButtonLabel="OKAY" #alert title="Notification" (onLeftButtonSelect)="alert.close()"></igx-dialog>
* ```
*/
this.rightButtonLabel = '';
/**
* An \@Input property to set the right button `type`. The types are `flat`, `raised` and `fab`.
* The `flat` type button is a rectangle and doesn't have a shadow. <br>
* The `raised` type button is also a rectangle but has a shadow. <br>
* The `fab` type button is a circle with a shadow. <br>
* The default value is `flat`.
* ```html
* <igx-dialog rightButtonType="fab" rightButtonLabel="OKAY" #alert (onLeftButtonSelect)="alert.close()"></igx-dialog>
* ```
*/
this.rightButtonType = 'flat';
/**
* An \@Input property to set the right button `color`. The property accepts all valid CSS color property values.
* ```html
* <igx-dialog rightButtonColor="yellow" rightButtonLabel="OKAY" #alert (onLeftButtonSelect)="alert.close()"></igx-dialog>
* ```
*/
this.rightButtonColor = '';
/**
* An \@Input property to set the right button `background-color`. The property accepts all valid CSS color property values.
* ```html
* <igx-dialog rightButtonBackgroundColor="black" rightButtonLabel="OKAY" #alert (onLeftButtonSelect)="alert.close()"></igx-dialog>
* ```
*/
this.rightButtonBackgroundColor = '';
/**
* An \@Input property to set the right button `ripple`.
* ```html
* <igx-dialog rightButtonRipple="green" rightButtonLabel="OKAY" #alert (onLeftButtonSelect)="alert.close()"></igx-dialog>
* ```
*/
this.rightButtonRipple = '';
/**
* An event that is emitted when the dialog is opened.
* ```html
* <igx-dialog (onOpen)="onDialogOpenHandler($event)" (onLeftButtonSelect)="dialog.close()" rightButtonLabel="OK">
* </igx-dialog>
* ```
*/
this.onOpen = new EventEmitter();
/**
* An event that is emitted when the dialog is closed.
* ```html
* <igx-dialog (onClose)="onDialogCloseHandler($event)" title="Confirmation" leftButtonLabel="Cancel" rightButtonLabel="OK">
* </igx-dialog>
* ```
*/
this.onClose = new EventEmitter();
/**
* An event that is emitted when the left button is clicked.
* ```html
* <igx-dialog (onLeftButtonSelect)="onDialogOKSelected($event)" #dialog leftButtonLabel="OK" rightButtonLabel="Cancel">
* </igx-dialog>
* ```
*/
this.onLeftButtonSelect = new EventEmitter();
/**
* An event that is emitted when the right button is clicked.
* ```html
* <igx-dialog (onRightButtonSelect)="onDialogOKSelected($event)"
* #dialog title="Confirmation" (onLeftButtonSelect)="dialog.close()" rightButtonLabel="OK"
* rightButtonRipple="#4CAF50" closeOnOutsideSelect="true">
* </igx-dialog>
* ```
*/
this.onRightButtonSelect = new EventEmitter();
this._animaitonSettings = {
openAnimation: useAnimation(slideInBottom, { params: { fromPosition: 'translateY(100%)' } }),
closeAnimation: useAnimation(slideOutTop, { params: { toPosition: 'translateY(-100%)' } })
};
this._closeOnOutsideSelect = false;
this._isModal = true;
this.destroy$ = new Subject();
/**
* The default `tabindex` attribute for the component
*
* @hidden
*/
this.tabindex = -1;
this._titleId = IgxDialogComponent.NEXT_ID++ + '_title';
this._overlayDefaultSettings = {
positionStrategy: new GlobalPositionStrategy(this._animaitonSettings),
scrollStrategy: new NoOpScrollStrategy(),
modal: this.isModal,
closeOnOutsideClick: this.closeOnOutsideSelect
};
}
/**
* @return {?}
*/
get isModal() {
return this._isModal;
}
/**
* @param {?} val
* @return {?}
*/
set isModal(val) {
this._overlayDefaultSettings.modal = val;
this._isModal = val;
}
/**
* An \@Input property that allows you to enable the "close on click outside the dialog". By default it's disabled.
* ```html
* <igx-dialog closeOnOutsideSelect="true" leftButtonLabel="Cancel" (onLeftButtonSelect)="dialog.close()"
* rightButtonLabel="OK" rightButtonRipple="#4CAF50" (onRightButtonSelect)="onDialogOKSelected($event)">
* </igx-dialog>
* ```
* @return {?}
*/
get closeOnOutsideSelect() {
return this._closeOnOutsideSelect;
}
/**
* @param {?} val
* @return {?}
*/
set closeOnOutsideSelect(val) {
this._overlayDefaultSettings.closeOnOutsideClick = val;
this._closeOnOutsideSelect = val;
}
/**
* @hidden
* @return {?}
*/
get element() {
return this.elementRef.nativeElement;
}
/**
* Returns the value of state. Possible state values are "open" or "close".
* ```typescript
* \@ViewChild("MyDialog")
* public dialog: IgxDialogComponent;
* ngAfterViewInit() {
* let dialogState = this.dialog.state;
* }
* ```
* @return {?}
*/
get state() {
return this.isOpen ? 'open' : 'close';
}
/**
* Returns whether the dialog is visible to the end user.
* ```typescript
* \@ViewChild("MyDialog")
* public dialog: IgxDialogComponent;
* ngAfterViewInit() {
* let dialogOpen = this.dialog.isOpen;
* }
* ```
* @return {?}
*/
get isOpen() {
return !this.toggleRef.collapsed;
}
/**
* @return {?}
*/
get isCollapsed() {
return this.toggleRef.collapsed;
}
/**
* Returns the value of the role of the dialog. The valid values are `dialog`, `alertdialog`, `alert`.
* ```typescript
* \@ViewChild("MyDialog")
* public dialog: IgxDialogComponent;
* ngAfterViewInit() {
* let dialogRole = this.dialog.role;
* }
* ```
* @return {?}
*/
get role() {
if (this.leftButtonLabel !== '' && this.rightButtonLabel !== '') {
return 'dialog';
}
else if (this.leftButtonLabel !== '' ||
this.rightButtonLabel !== '') {
return 'alertdialog';
}
else {
return 'alert';
}
}
/**
* Returns the value of the title id.
* ```typescript
* \@ViewChild("MyDialog")
* public dialog: IgxDialogComponent;
* ngAfterViewInit() {
* let dialogTitle = this.dialog.titleId;
* }
* ```
* @return {?}
*/
get titleId() {
return this._titleId;
}
/**
* @return {?}
*/
ngAfterContentInit() {
this.toggleRef.onClosing.pipe(takeUntil(this.destroy$)).subscribe(() => this.emitCloseFromDialog());
}
/**
* @private
* @return {?}
*/
emitCloseFromDialog() {
this.onClose.emit({ dialog: this, event: null });
}
/**
* A method that opens the dialog.
* \@memberOf {\@link IgxDialogComponent}
* ```html
* <button (click)="dialog.open() igxButton="raised" igxButtonColor="white" igxRipple="white">Trigger Dialog</button>
* <igx-dialog #dialog></igx-dialog>
* ```
* @param {?=} overlaySettings
* @return {?}
*/
open(overlaySettings = this._overlayDefaultSettings) {
this.toggleRef.open(overlaySettings);
this.onOpen.emit({ dialog: this, event: null });
if (!this.leftButtonLabel && !this.rightButtonLabel) {
this.toggleRef.element.focus();
}
}
/**
* A method that that closes the dialog.
* \@memberOf {\@link IgxDialogComponent}
* ```html
* <button (click)="dialog.close() igxButton="raised" igxButtonColor="white" igxRipple="white">Trigger Dialog</button>
* <igx-dialog #dialog></igx-dialog>
* ```
* @return {?}
*/
close() {
// `onClose` will emit from `toggleRef.onClosing` subscription
this.toggleRef.close();
}
/**
* A method that opens/closes the dialog.
* \@memberOf {\@link IgxDialogComponent}
* ```html
* <button (click)="dialog.toggle() igxButton="raised" igxButtonColor="white" igxRipple="white">Trigger Dialog</button>
* <igx-dialog #dialog></igx-dialog>
* ```
* @return {?}
*/
toggle() {
this.isOpen ? this.close() : this.open();
}
/**
* @hidden
* @param {?} event
* @return {?}
*/
onDialogSelected(event) {
event.stopPropagation();
if (this.isOpen &&
this.closeOnOutsideSelect &&
event.target.classList.contains(IgxDialogComponent.DIALOG_CLASS)) {
this.close();
}
}
/**
* @hidden
* @param {?} event
* @return {?}
*/
onInternalLeftButtonSelect(event) {
this.onLeftButtonSelect.emit({ dialog: this, event });
}
/**
* @hidden
* @param {?} event
* @return {?}
*/
onInternalRightButtonSelect(event) {
this.onRightButtonSelect.emit({ dialog: this, event });
}
/**
* @hidden
* @return {?}
*/
ngOnInit() {
if (this.navService && this.id) {
this.navService.add(this.id, this);
}
}
/**
* @hidden
* @return {?}
*/
ngOnDestroy() {
if (this.navService && this.id) {
this.navService.remove(this.id);
}
}
}
IgxDialogComponent.NEXT_ID = 1;
IgxDialogComponent.DIALOG_CLASS = 'igx-dialog';
IgxDialogComponent.decorators = [
{ type: Component, args: [{
selector: 'igx-dialog',
template: "<div tabindex=\"0\" #dialog class=\"igx-dialog\" igxToggle (click)=\"onDialogSelected($event)\">\n <div #dialogWindow class=\"igx-dialog__window\" [attr.role]=\"role\" [attr.aria-labelledby]=\"titleId\">\n\n <div *ngIf=\"title\" [attr.id]=\"titleId\" class=\"igx-dialog__window-title\">\n {{ title }}\n </div>\n <ng-content *ngIf=\"!title\" select=\"igx-dialog-title,[igxDialogTitle]\"></ng-content>\n\n <div class=\"igx-dialog__window-content\" *ngIf=\"message\">{{ message }}</div>\n <ng-content *ngIf=\"!message\"></ng-content>\n\n <div *ngIf=\"leftButtonLabel || rightButtonLabel\" class=\"igx-dialog__window-actions\">\n <button *ngIf=\"leftButtonLabel\" type=\"button\" [igxFocus]=\"isOpen\" igxButton=\"{{ leftButtonType }}\" igxButtonColor=\"{{ leftButtonColor }}\" igxButtonBackground=\"{{ leftButtonBackgroundColor }}\"\n igxRipple=\"{{ leftButtonRipple }}\" (click)=\"onInternalLeftButtonSelect($event)\">\n {{ leftButtonLabel }}\n </button>\n <button *ngIf=\"rightButtonLabel\" type=\"button\" [igxFocus]=\"isOpen\" igxButton=\"{{ rightButtonType }}\" igxButtonColor=\"{{ rightButtonColor }}\" igxButtonBackground=\"{{ rightButtonBackgroundColor }}\"\n igxRipple=\"{{ rightButtonRipple }}\" (click)=\"onInternalRightButtonSelect($event)\">\n {{ rightButtonLabel }}\n </button>\n </div>\n <ng-content *ngIf=\"!leftButtonLabel && !rightButtonLabel\" select=\"igx-dialog-actions,[igxDialogActions]\"></ng-content>\n\n </div>\n</div>\n"
}] }
];
/** @nocollapse */
IgxDialogComponent.ctorParameters = () => [
{ type: ElementRef },
{ type: IgxNavigationService, decorators: [{ type: Optional }] }
];
IgxDialogComponent.propDecorators = {
toggleRef: [{ type: ViewChild, args: [IgxToggleDirective,] }],
id: [{ type: HostBinding, args: ['attr.id',] }, { type: Input }],
isModal: [{ type: Input }],
title: [{ type: Input }],
message: [{ type: Input }],
leftButtonLabel: [{ type: Input }],
leftButtonType: [{ type: Input }],
leftButtonColor: [{ type: Input }],
leftButtonBackgroundColor: [{ type: Input }],
leftButtonRipple: [{ type: Input }],
rightButtonLabel: [{ type: Input }],
rightButtonType: [{ type: Input }],
rightButtonColor: [{ type: Input }],
rightButtonBackgroundColor: [{ type: Input }],
rightButtonRipple: [{ type: Input }],
closeOnOutsideSelect: [{ type: Input }],
onOpen: [{ type: Output }],
onClose: [{ type: Output }],
onLeftButtonSelect: [{ type: Output }],
onRightButtonSelect: [{ type: Output }],
tabindex: [{ type: HostBinding, args: ['attr.tabindex',] }],
isOpen: [{ type: Input }],
isCollapsed: [{ type: HostBinding, args: ['class.igx-dialog--hidden',] }],
role: [{ type: Input }],
titleId: [{ type: Input }]
};
if (false) {
/**
* @type {?}
* @private
*/
IgxDialogComponent.NEXT_ID;
/**
* @type {?}
* @private
*/
IgxDialogComponent.DIALOG_CLASS;
/** @type {?} */
IgxDialogComponent.prototype.toggleRef;
/**
* An \@Input property that sets the value of the `id` attribute. If not provided it will be automatically generated.
* ```html
* <igx-dialog [id]="'igx-dialog-56'" #alert title="Notification" leftButtonLabel="OK" (onLeftButtonSelect)="alert.close()"></igx-dialog>
* ```
* @type {?}
*/
IgxDialogComponent.prototype.id;
/**
* An \@Input property controlling the `title` of the dialog.
* ```html
* <igx-dialog title="Notification" #alert leftButtonLabel="OK" (onLeftButtonSelect)="alert.close()"></igx-dialog>
* ```
* @type {?}
*/
IgxDialogComponent.prototype.title;
/**
* An \@Input property controlling the `message` of the dialog.
* ```html
* <igx-dialog message="Your email was sent!" #alert leftButtonLabel="OK" (onLeftButtonSelect)="alert.close()"></igx-dialog>
* ```
* @type {?}
*/
IgxDialogComponent.prototype.message;
/**
* An \@Input property to set the `label` of the left button of the dialog.
* ```html
* <igx-dialog leftButtonLabel="OKAY" #alert title="Notification" (onLeftButtonSelect)="alert.close()"></igx-dialog>
* ```
* @type {?}
*/
IgxDialogComponent.prototype.leftButtonLabel;
/**
* An \@Input property to set the left button `type`. The types are `flat`, `raised` and `fab`.
* The `flat` type button is a rectangle and doesn't have a shadow. <br>
* The `raised` type button is also a rectangle but has a shadow. <br>
* The `fab` type button is a circle with a shadow. <br>
* The default value is `flat`.
* ```html
* <igx-dialog leftButtonType="raised" leftButtonLabel="OKAY" #alert (onLeftButtonSelect)="alert.close()"></igx-dialog>
* ```
* @type {?}
*/
IgxDialogComponent.prototype.leftButtonType;
/**
* An \@Input property to set the left button color. The property accepts all valid CSS color property values.
* ```html
* <igx-dialog leftButtonColor="yellow" leftButtonLabel="OKAY" #alert (onLeftButtonSelect)="alert.close()"></igx-dialog>
* ```
* @type {?}
*/
IgxDialogComponent.prototype.leftButtonColor;
/**
* An \@Input property to set the left button `background-color`. The property accepts all valid CSS color property values.
* ```html
* <igx-dialog leftButtonBackgroundColor="black" leftButtonLabel="OKAY" #alert (onLeftButtonSelect)="alert.close()"></igx-dialog>
* ```
* @type {?}
*/
IgxDialogComponent.prototype.leftButtonBackgroundColor;
/**
* An \@Input property to set the left button `ripple`. The `ripple` animates a click/tap to a component as a series of fading waves.
* The property accepts all valid CSS color property values.
* ```html
* <igx-dialog leftButtonRipple="green" leftButtonLabel="OKAY" #alert (onLeftButtonSelect)="alert.close()"></igx-dialog>
* ```
* @type {?}
*/
IgxDialogComponent.prototype.leftButtonRipple;
/**
* An \@Input property to set the `label` of the right button of the dialog.
* ```html
* <igx-dialog rightButtonLabel="OKAY" #alert title="Notification" (onLeftButtonSelect)="alert.close()"></igx-dialog>
* ```
* @type {?}
*/
IgxDialogComponent.prototype.rightButtonLabel;
/**
* An \@Input property to set the right button `type`. The types are `flat`, `raised` and `fab`.
* The `flat` type button is a rectangle and doesn't have a shadow. <br>
* The `raised` type button is also a rectangle but has a shadow. <br>
* The `fab` type button is a circle with a shadow. <br>
* The default value is `flat`.
* ```html
* <igx-dialog rightButtonType="fab" rightButtonLabel="OKAY" #alert (onLeftButtonSelect)="alert.close()"></igx-dialog>
* ```
* @type {?}
*/
IgxDialogComponent.prototype.rightButtonType;
/**
* An \@Input property to set the right button `color`. The property accepts all valid CSS color property values.
* ```html
* <igx-dialog rightButtonColor="yellow" rightButtonLabel="OKAY" #alert (onLeftButtonSelect)="alert.close()"></igx-dialog>
* ```
* @type {?}
*/
IgxDialogComponent.prototype.rightButtonColor;
/**
* An \@Input property to set the right button `background-color`. The property accepts all valid CSS color property values.
* ```html
* <igx-dialog rightButtonBackgroundColor="black" rightButtonLabel="OKAY" #alert (onLeftButtonSelect)="alert.close()"></igx-dialog>
* ```
* @type {?}
*/
IgxDialogComponent.prototype.rightButtonBackgroundColor;
/**
* An \@Input property to set the right button `ripple`.
* ```html
* <igx-dialog rightButtonRipple="green" rightButtonLabel="OKAY" #alert (onLeftButtonSelect)="alert.close()"></igx-dialog>
* ```
* @type {?}
*/
IgxDialogComponent.prototype.rightButtonRipple;
/**
* An event that is emitted when the dialog is opened.
* ```html
* <igx-dialog (onOpen)="onDialogOpenHandler($event)" (onLeftButtonSelect)="dialog.close()" rightButtonLabel="OK">
* </igx-dialog>
* ```
* @type {?}
*/
IgxDialogComponent.prototype.onOpen;
/**
* An event that is emitted when the dialog is closed.
* ```html
* <igx-dialog (onClose)="onDialogCloseHandler($event)" title="Confirmation" leftButtonLabel="Cancel" rightButtonLabel="OK">
* </igx-dialog>
* ```
* @type {?}
*/
IgxDialogComponent.prototype.onClose;
/**
* An event that is emitted when the left button is clicked.
* ```html
* <igx-dialog (onLeftButtonSelect)="onDialogOKSelected($event)" #dialog leftButtonLabel="OK" rightButtonLabel="Cancel">
* </igx-dialog>
* ```
* @type {?}
*/
IgxDialogComponent.prototype.onLeftButtonSelect;
/**
* An event that is emitted when the right button is clicked.
* ```html
* <igx-dialog (onRightButtonSelect)="onDialogOKSelected($event)"
* #dialog title="Confirmation" (onLeftButtonSelect)="dialog.close()" rightButtonLabel="OK"
* rightButtonRipple="#4CAF50" closeOnOutsideSelect="true">
* </igx-dialog>
* ```
* @type {?}
*/
IgxDialogComponent.prototype.onRightButtonSelect;
/**
* @type {?}
* @private
*/
IgxDialogComponent.prototype._animaitonSettings;
/**
* @type {?}
* @private
*/
IgxDialogComponent.prototype._overlayDefaultSettings;
/**
* @type {?}
* @private
*/
IgxDialogComponent.prototype._closeOnOutsideSelect;
/**
* @type {?}
* @private
*/
IgxDialogComponent.prototype._isModal;
/**
* @type {?}
* @protected
*/
IgxDialogComponent.prototype.destroy$;
/**
* The default `tabindex` attribute for the component
*
* @hidden
* @type {?}
*/
IgxDialogComponent.prototype.tabindex;
/**
* @type {?}
* @private
*/
IgxDialogComponent.prototype._titleId;
/**
* @type {?}
* @private
*/
IgxDialogComponent.prototype.elementRef;
/**
* @type {?}
* @private
*/
IgxDialogComponent.prototype.navService;
}
/**
* @record
*/
export function IDialogEventArgs() { }
if (false) {
/** @type {?} */
IDialogEventArgs.prototype.dialog;
/** @type {?} */
IDialogEventArgs.prototype.event;
}
/**
* @hidden
*/
export class IgxDialogModule {
}
IgxDialogModule.decorators = [
{ type: NgModule, args: [{
declarations: [IgxDialogComponent, IgxDialogTitleDirective, IgxDialogActionsDirective],
exports: [IgxDialogComponent, IgxDialogTitleDirective, IgxDialogActionsDirective],
imports: [CommonModule, IgxToggleModule, IgxButtonModule, IgxRippleModule, IgxFocusModule]
},] }
];
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog.component.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/dialog/dialog.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { useAnimation } from '@angular/animations';\nimport { CommonModule } from '@angular/common';\nimport {\n    Component,\n    ContentChild,\n    ElementRef,\n    EventEmitter,\n    forwardRef,\n    HostBinding,\n    Input,\n    NgModule,\n    OnDestroy,\n    OnInit,\n    Optional,\n    Output,\n    ViewChild,\n    AfterContentInit\n} from '@angular/core';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { IgxNavigationService, IToggleView } from '../core/navigation';\nimport { IgxButtonModule } from '../directives/button/button.directive';\nimport { IgxRippleModule } from '../directives/ripple/ripple.directive';\nimport { IgxDialogActionsDirective, IgxDialogTitleDirective } from './dialog.directives';\nimport { IgxToggleModule, IgxToggleDirective } from '../directives/toggle/toggle.directive';\nimport { OverlaySettings, GlobalPositionStrategy, NoOpScrollStrategy, PositionSettings } from '../services';\nimport { slideInBottom, slideOutTop } from '../animations/slide/index';\nimport { IgxFocusModule } from '../directives/focus/focus.directive';\n\nlet DIALOG_ID = 0;\n/**\n * **Ignite UI for Angular Dialog Window** -\n * [Documentation](https://www.infragistics.com/products/ignite-ui-angular/angular/components/dialog.html)\n *\n * The Ignite UI Dialog Window presents a dialog window to the user which can simply display messages or display\n * more complicated visuals such as a user sign-in form.  It also provides a right and left button\n * which can be used for custom actions.\n *\n * Example:\n * ```html\n * <button (click)=\"form.open()\">Show Dialog</button>\n * <igx-dialog #form title=\"Sign In\" rightButtonLabel=\"OK\">\n *   <div>\n *     <input type=\"text\" igxInput/>\n *     <label igxLabel>Username</label>\n *   </div>\n *   <div>\n *     <input type=\"password\" igxInput/>\n *     <label igxLabel>Password</label>\n *   </div>\n * </igx-dialog>\n * ```\n */\n@Component({\n    selector: 'igx-dialog',\n    templateUrl: 'dialog-content.component.html'\n})\nexport class IgxDialogComponent implements IToggleView, OnInit, OnDestroy, AfterContentInit {\n    private static NEXT_ID = 1;\n    private static readonly DIALOG_CLASS = 'igx-dialog';\n\n    @ViewChild(IgxToggleDirective)\n    public toggleRef: IgxToggleDirective;\n\n    /**\n    * An @Input property that sets the value of the `id` attribute. If not provided it will be automatically generated.\n    *```html\n    *<igx-dialog [id]=\"'igx-dialog-56'\" #alert title=\"Notification\" leftButtonLabel=\"OK\" (onLeftButtonSelect)=\"alert.close()\"></igx-dialog>\n    *```\n    */\n    @HostBinding('attr.id')\n    @Input()\n    public id = `igx-dialog-${DIALOG_ID++}`;\n\n    @Input()\n    get isModal() {\n        return this._isModal;\n    }\n\n    set isModal(val: boolean) {\n        this._overlayDefaultSettings.modal = val;\n        this._isModal = val;\n    }\n\n    /**\n    * An @Input property controlling the `title` of the dialog.\n    *```html\n    *<igx-dialog title=\"Notification\" #alert leftButtonLabel=\"OK\" (onLeftButtonSelect)=\"alert.close()\"></igx-dialog>\n    *```\n    */\n    @Input()\n    public title = '';\n\n    /**\n     *  An @Input property controlling the `message` of the dialog.\n     *```html\n     *<igx-dialog message=\"Your email was sent!\" #alert leftButtonLabel=\"OK\" (onLeftButtonSelect)=\"alert.close()\"></igx-dialog>\n     *```\n     */\n    @Input()\n    public message = '';\n\n    /**\n     * An @Input property to set the `label` of the left button of the dialog.\n     *```html\n     *<igx-dialog leftButtonLabel=\"OKAY\" #alert title=\"Notification\"  (onLeftButtonSelect)=\"alert.close()\"></igx-dialog>\n     *```\n     */\n    @Input()\n    public leftButtonLabel = '';\n\n    /**\n     * An @Input property to set the left button `type`. The types are `flat`, `raised` and `fab`.\n     * The `flat` type button is a rectangle and doesn't have a shadow. <br>\n     * The `raised` type button is also a rectangle but has a shadow. <br>\n     * The `fab` type button is a circle with a shadow. <br>\n     * The default value is `flat`.\n     *```html\n     *<igx-dialog leftButtonType=\"raised\" leftButtonLabel=\"OKAY\" #alert (onLeftButtonSelect)=\"alert.close()\"></igx-dialog>\n     *```\n     */\n    @Input()\n    public leftButtonType = 'flat';\n    /**\n     * An @Input property to set the left button color. The property accepts all valid CSS color property values.\n     *```html\n     *<igx-dialog leftButtonColor=\"yellow\" leftButtonLabel=\"OKAY\" #alert (onLeftButtonSelect)=\"alert.close()\"></igx-dialog>\n     *```\n     */\n    @Input()\n    public leftButtonColor = '';\n\n    /**\n     * An @Input property to set the left button `background-color`. The property accepts all valid CSS color property values.\n     *```html\n     *<igx-dialog leftButtonBackgroundColor=\"black\" leftButtonLabel=\"OKAY\" #alert (onLeftButtonSelect)=\"alert.close()\"></igx-dialog>\n     *```\n     */\n    @Input()\n    public leftButtonBackgroundColor = '';\n\n    /**\n     * An @Input property to set the left button `ripple`. The `ripple` animates a click/tap to a component as a series of fading waves.\n     * The property accepts all valid CSS color property values.\n     *```html\n     *<igx-dialog leftButtonRipple=\"green\" leftButtonLabel=\"OKAY\" #alert (onLeftButtonSelect)=\"alert.close()\"></igx-dialog>\n     *```\n     */\n    @Input()\n    public leftButtonRipple = '';\n\n    /**\n     * An @Input property to set the `label` of the right button of the dialog.\n     *```html\n     *<igx-dialog rightButtonLabel=\"OKAY\" #alert title=\"Notification\"  (onLeftButtonSelect)=\"alert.close()\"></igx-dialog>\n     *```\n     */\n    @Input()\n    public rightButtonLabel = '';\n\n    /**\n     * An @Input property to set the right button `type`. The types are `flat`, `raised` and `fab`.\n     * The `flat` type button is a rectangle and doesn't have a shadow. <br>\n     * The `raised` type button is also a rectangle but has a shadow. <br>\n     * The `fab` type button is a circle with a shadow. <br>\n     * The default value is `flat`.\n     *```html\n     *<igx-dialog rightButtonType=\"fab\" rightButtonLabel=\"OKAY\" #alert (onLeftButtonSelect)=\"alert.close()\"></igx-dialog>\n     *```\n     */\n    @Input()\n    public rightButtonType = 'flat';\n\n    /**\n     * An @Input property to set the right button `color`. The property accepts all valid CSS color property values.\n     *```html\n     *<igx-dialog rightButtonColor=\"yellow\" rightButtonLabel=\"OKAY\" #alert (onLeftButtonSelect)=\"alert.close()\"></igx-dialog>\n     *```\n     */\n    @Input()\n    public rightButtonColor = '';\n\n    /**\n     * An @Input property to set the right button `background-color`. The property accepts all valid CSS color property values.\n     *```html\n     *<igx-dialog rightButtonBackgroundColor=\"black\" rightButtonLabel=\"OKAY\" #alert (onLeftButtonSelect)=\"alert.close()\"></igx-dialog>\n     *```\n     */\n    @Input()\n    public rightButtonBackgroundColor = '';\n\n    /**\n     * An @Input property to set the right button `ripple`.\n     *```html\n     *<igx-dialog rightButtonRipple=\"green\" rightButtonLabel=\"OKAY\" #alert (onLeftButtonSelect)=\"alert.close()\"></igx-dialog>\n     *```\n     */\n    @Input()\n    public rightButtonRipple = '';\n\n    /**\n     * An @Input property that allows you to enable the \"close on click outside the dialog\". By default it's disabled.\n     *```html\n     *<igx-dialog closeOnOutsideSelect=\"true\" leftButtonLabel=\"Cancel\" (onLeftButtonSelect)=\"dialog.close()\"\n     *rightButtonLabel=\"OK\" rightButtonRipple=\"#4CAF50\" (onRightButtonSelect)=\"onDialogOKSelected($event)\">\n     *</igx-dialog>\n     *```\n     */\n    @Input()\n    get closeOnOutsideSelect() {\n        return this._closeOnOutsideSelect;\n    }\n\n    set closeOnOutsideSelect(val: boolean) {\n        this._overlayDefaultSettings.closeOnOutsideClick = val;\n        this._closeOnOutsideSelect = val;\n    }\n\n    /**\n     * An event that is emitted when the dialog is opened.\n     *```html\n     *<igx-dialog (onOpen)=\"onDialogOpenHandler($event)\" (onLeftButtonSelect)=\"dialog.close()\" rightButtonLabel=\"OK\">\n     *</igx-dialog>\n     *```\n     */\n    @Output()\n    public onOpen = new EventEmitter<IDialogEventArgs>();\n\n    /**\n     * An event that is emitted when the dialog is closed.\n     *```html\n     *<igx-dialog (onClose)=\"onDialogCloseHandler($event)\" title=\"Confirmation\" leftButtonLabel=\"Cancel\" rightButtonLabel=\"OK\">\n     *</igx-dialog>\n     *```\n     */\n    @Output()\n    public onClose = new EventEmitter<IDialogEventArgs>();\n\n    /**\n     * An event that is emitted when the left button is clicked.\n     *```html\n     *<igx-dialog (onLeftButtonSelect)=\"onDialogOKSelected($event)\" #dialog leftButtonLabel=\"OK\" rightButtonLabel=\"Cancel\">\n     *</igx-dialog>\n     *```\n     */\n    @Output()\n    public onLeftButtonSelect = new EventEmitter<IDialogEventArgs>();\n\n    /**\n     * An event that is emitted when the right button is clicked.\n     * ```html\n     *<igx-dialog (onRightButtonSelect)=\"onDialogOKSelected($event)\"\n     *#dialog title=\"Confirmation\" (onLeftButtonSelect)=\"dialog.close()\" rightButtonLabel=\"OK\"\n     *rightButtonRipple=\"#4CAF50\" closeOnOutsideSelect=\"true\">\n     *</igx-dialog>\n     *```\n     */\n    @Output()\n    public onRightButtonSelect = new EventEmitter<IDialogEventArgs>();\n\n    private _animaitonSettings: PositionSettings = {\n        openAnimation: useAnimation(slideInBottom, { params: { fromPosition: 'translateY(100%)' } }),\n        closeAnimation: useAnimation(slideOutTop, { params: { toPosition: 'translateY(-100%)' } })\n    };\n\n    private _overlayDefaultSettings: OverlaySettings;\n    private _closeOnOutsideSelect = false;\n    private _isModal = true;\n    protected destroy$ = new Subject<boolean>();\n\n    /**\n     * @hidden\n     */\n    public get element() {\n        return this.elementRef.nativeElement;\n    }\n\n    /**\n     * The default `tabindex` attribute for the component\n     *\n     * @hidden\n     */\n    @HostBinding('attr.tabindex')\n    public tabindex = -1;\n\n    private _titleId: string;\n\n    /**\n     * Returns the value of state. Possible state values are \"open\" or \"close\".\n     *```typescript\n     *@ViewChild(\"MyDialog\")\n     *public dialog: IgxDialogComponent;\n     *ngAfterViewInit() {\n     *    let dialogState = this.dialog.state;\n     *}\n     *```\n     */\n    get state(): string {\n        return this.isOpen ? 'open' : 'close';\n    }\n\n    /**\n     * Returns whether the dialog is visible to the end user.\n     *```typescript\n     *@ViewChild(\"MyDialog\")\n     *public dialog: IgxDialogComponent;\n     *ngAfterViewInit() {\n     *    let dialogOpen = this.dialog.isOpen;\n     *}\n     * ```\n     */\n    @Input()\n    get isOpen() {\n        return !this.toggleRef.collapsed;\n    }\n\n    @HostBinding('class.igx-dialog--hidden')\n    get isCollapsed() {\n        return this.toggleRef.collapsed;\n    }\n\n    /**\n     *Returns the value of the role of the dialog. The valid values are `dialog`, `alertdialog`, `alert`.\n     *```typescript\n     *@ViewChild(\"MyDialog\")\n     *public dialog: IgxDialogComponent;\n     *ngAfterViewInit() {\n     *    let dialogRole = this.dialog.role;\n     *}\n     * ```\n     */\n    @Input()\n    get role() {\n        if (this.leftButtonLabel !== ''