@uex/web-extensions
Version:
Uex extensions for Angular 6+ web projects
163 lines • 13.2 kB
JavaScript
/**
* @fileoverview added by tsickle
* Generated from: lib/modules/dialog/dialog.base.service.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Injectable, EventEmitter } from "@angular/core";
import * as _ from "lodash";
import { Dialog } from "./dialog.base";
/**
* @ignore
*/
export class DialogBaseService {
/**
* @ignore
*/
constructor() {
this.dialogs = [];
this.onShow = new EventEmitter();
this.onHide = new EventEmitter();
this._current_index = 0;
this._zindex = 10010;
this._content_zindex = 10020;
this._backdrop_zindex = 10000;
document.addEventListener("keydown", (/**
* @param {?} event
* @return {?}
*/
event => {
/** @type {?} */
const keyCode = event.which || event.keyCode;
if ([
13,
27 // Escape
].indexOf(keyCode) > -1) {
/** @type {?} */
const visible_dialogs = this.dialogs.filter((/**
* @param {?} dialog
* @return {?}
*/
dialog => dialog.visible));
if (visible_dialogs.length > 0) {
// const is_escape = keyCode == 27;
// const is_return = keyCode == 13;
/** @type {?} */
const last_visible_dialogs = _.last(visible_dialogs);
/** @type {?} */
let handler = null;
if (!last_visible_dialogs.settings.keyboard)
return;
switch (keyCode) {
case 13:
handler = last_visible_dialogs.settings.keyboard.onReturn;
break;
case 27:
handler = last_visible_dialogs.settings.keyboard.onEscape;
break;
}
if (_.isFunction(handler)) {
handler();
}
else {
switch (handler) {
case "close":
event.preventDefault();
last_visible_dialogs.close();
break;
case "dismiss":
event.preventDefault();
last_visible_dialogs.dismiss();
break;
default:
return;
}
}
}
}
}), true);
}
/**
* @return {?}
*/
get visibleDialogs() {
return this.dialogs.filter((/**
* @param {?} dialog
* @return {?}
*/
dialog => dialog.visible));
}
/**
* @param {?} component
* @param {?=} params
* @param {?=} settings
* @return {?}
*/
create(component, params, settings) {
if (!(params && _.isPlainObject(params)))
params = {};
/** @type {?} */
let data = {
component: component,
params: params,
settings: settings,
zindex: this._zindex,
content_zindex: this._content_zindex,
backdrop_zindex: this._backdrop_zindex
};
this._zindex += 100;
this._content_zindex += 100;
this._backdrop_zindex += 100;
/** @type {?} */
const dialog_instance = new Dialog(this, data, this._current_index);
this._current_index++;
return dialog_instance;
}
/**
* @param {?} component
* @param {?=} params
* @param {?=} settings
* @return {?}
*/
open(component, params, settings) {
if (!(params && _.isPlainObject(params)))
params = {};
/** @type {?} */
let instance = this.create(component, params, settings);
instance.open();
return instance;
}
}
DialogBaseService.decorators = [
{ type: Injectable }
];
/** @nocollapse */
DialogBaseService.ctorParameters = () => [];
if (false) {
/** @type {?} */
DialogBaseService.prototype.dialogs;
/** @type {?} */
DialogBaseService.prototype.onShow;
/** @type {?} */
DialogBaseService.prototype.onHide;
/**
* @type {?}
* @private
*/
DialogBaseService.prototype._current_index;
/**
* @type {?}
* @private
*/
DialogBaseService.prototype._zindex;
/**
* @type {?}
* @private
*/
DialogBaseService.prototype._content_zindex;
/**
* @type {?}
* @private
*/
DialogBaseService.prototype._backdrop_zindex;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog.base.service.js","sourceRoot":"ng://@uex/web-extensions/","sources":["lib/modules/dialog/dialog.base.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, EventEmitter } from \"@angular/core\";\r\n\r\nimport * as _ from \"lodash\";\r\n\r\nimport { DialogSettings } from \"./dialog.base\";\r\nimport { Dialog } from \"./dialog.base\";\r\n\r\n/**\r\n * @ignore\r\n */\r\n@Injectable()\r\nexport class DialogBaseService {\r\n  /**\r\n   * @ignore\r\n   */\r\n  constructor() {\r\n    document.addEventListener(\r\n      \"keydown\",\r\n      event => {\r\n        const keyCode = event.which || event.keyCode;\r\n        if (\r\n          [\r\n            13, // Return\r\n            27 // Escape\r\n          ].indexOf(keyCode) > -1\r\n        ) {\r\n          const visible_dialogs = this.dialogs.filter(dialog => dialog.visible);\r\n          if (visible_dialogs.length > 0) {\r\n            // const is_escape = keyCode == 27;\r\n            // const is_return = keyCode == 13;\r\n            const last_visible_dialogs = _.last(visible_dialogs);\r\n            let handler = null;\r\n            if (!last_visible_dialogs.settings.keyboard) return;\r\n            switch (keyCode) {\r\n              case 13:\r\n                handler = last_visible_dialogs.settings.keyboard.onReturn;\r\n                break;\r\n              case 27:\r\n                handler = last_visible_dialogs.settings.keyboard.onEscape;\r\n                break;\r\n            }\r\n            if (_.isFunction(handler)) {\r\n              handler();\r\n            } else {\r\n              switch (handler) {\r\n                case \"close\":\r\n                  event.preventDefault();\r\n                  last_visible_dialogs.close();\r\n                  break;\r\n                case \"dismiss\":\r\n                  event.preventDefault();\r\n                  last_visible_dialogs.dismiss();\r\n                  break;\r\n                default:\r\n                  return;\r\n              }\r\n            }\r\n          }\r\n        }\r\n      },\r\n      true\r\n    );\r\n  }\r\n\r\n  public dialogs: Array<Dialog> = [];\r\n\r\n  public onShow: EventEmitter<Dialog> = new EventEmitter();\r\n  public onHide: EventEmitter<Dialog> = new EventEmitter();\r\n\r\n  private _current_index: number = 0;\r\n\r\n  private _zindex: number = 10010;\r\n  private _content_zindex: number = 10020;\r\n  private _backdrop_zindex: number = 10000;\r\n\r\n  public get visibleDialogs(): Array<Dialog> {\r\n    return this.dialogs.filter(dialog => dialog.visible);\r\n  }\r\n\r\n  public create(\r\n    component: any,\r\n    params?: any,\r\n    settings?: DialogSettings\r\n  ): Dialog {\r\n    if (!(params && _.isPlainObject(params))) params = {};\r\n    let data = {\r\n      component: component,\r\n      params: params,\r\n      settings: settings,\r\n      zindex: this._zindex,\r\n      content_zindex: this._content_zindex,\r\n      backdrop_zindex: this._backdrop_zindex\r\n    };\r\n\r\n    this._zindex += 100;\r\n    this._content_zindex += 100;\r\n    this._backdrop_zindex += 100;\r\n\r\n    const dialog_instance = new Dialog(this, data, this._current_index);\r\n\r\n    this._current_index++;\r\n\r\n    return dialog_instance;\r\n  }\r\n\r\n  public open(component: any, params?: any, settings?: DialogSettings): Dialog {\r\n    if (!(params && _.isPlainObject(params))) params = {};\r\n    let instance = this.create(component, params, settings);\r\n    instance.open();\r\n    return instance;\r\n  }\r\n}\r\n"]}