UNPKG

@uex/web-extensions

Version:

Uex extensions for Angular 6+ web projects

163 lines 13.2 kB
/** * @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":";;;;;AAAA,OAAO,EAAE,UAAU,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAEzD,OAAO,KAAK,CAAC,MAAM,QAAQ,CAAC;AAG5B,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;;;;AAMvC,MAAM,OAAO,iBAAiB;;;;IAI5B;QAiDO,YAAO,GAAkB,EAAE,CAAC;QAE5B,WAAM,GAAyB,IAAI,YAAY,EAAE,CAAC;QAClD,WAAM,GAAyB,IAAI,YAAY,EAAE,CAAC;QAEjD,mBAAc,GAAW,CAAC,CAAC;QAE3B,YAAO,GAAW,KAAK,CAAC;QACxB,oBAAe,GAAW,KAAK,CAAC;QAChC,qBAAgB,GAAW,KAAK,CAAC;QAzDvC,QAAQ,CAAC,gBAAgB,CACvB,SAAS;;;;QACT,KAAK,CAAC,EAAE;;kBACA,OAAO,GAAG,KAAK,CAAC,KAAK,IAAI,KAAK,CAAC,OAAO;YAC5C,IACE;gBACE,EAAE;gBACF,EAAE,CAAC,SAAS;aACb,CAAC,OAAO,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,EACvB;;sBACM,eAAe,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM;;;;gBAAC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,OAAO,EAAC;gBACrE,IAAI,eAAe,CAAC,MAAM,GAAG,CAAC,EAAE;;;;0BAGxB,oBAAoB,GAAG,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC;;wBAChD,OAAO,GAAG,IAAI;oBAClB,IAAI,CAAC,oBAAoB,CAAC,QAAQ,CAAC,QAAQ;wBAAE,OAAO;oBACpD,QAAQ,OAAO,EAAE;wBACf,KAAK,EAAE;4BACL,OAAO,GAAG,oBAAoB,CAAC,QAAQ,CAAC,QAAQ,CAAC,QAAQ,CAAC;4BAC1D,MAAM;wBACR,KAAK,EAAE;4BACL,OAAO,GAAG,oBAAoB,CAAC,QAAQ,CAAC,QAAQ,CAAC,QAAQ,CAAC;4BAC1D,MAAM;qBACT;oBACD,IAAI,CAAC,CAAC,UAAU,CAAC,OAAO,CAAC,EAAE;wBACzB,OAAO,EAAE,CAAC;qBACX;yBAAM;wBACL,QAAQ,OAAO,EAAE;4BACf,KAAK,OAAO;gCACV,KAAK,CAAC,cAAc,EAAE,CAAC;gCACvB,oBAAoB,CAAC,KAAK,EAAE,CAAC;gCAC7B,MAAM;4BACR,KAAK,SAAS;gCACZ,KAAK,CAAC,cAAc,EAAE,CAAC;gCACvB,oBAAoB,CAAC,OAAO,EAAE,CAAC;gCAC/B,MAAM;4BACR;gCACE,OAAO;yBACV;qBACF;iBACF;aACF;QACH,CAAC,GACD,IAAI,CACL,CAAC;IACJ,CAAC;;;;IAaD,IAAW,cAAc;QACvB,OAAO,IAAI,CAAC,OAAO,CAAC,MAAM;;;;QAAC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,OAAO,EAAC,CAAC;IACvD,CAAC;;;;;;;IAEM,MAAM,CACX,SAAc,EACd,MAAY,EACZ,QAAyB;QAEzB,IAAI,CAAC,CAAC,MAAM,IAAI,CAAC,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;YAAE,MAAM,GAAG,EAAE,CAAC;;YAClD,IAAI,GAAG;YACT,SAAS,EAAE,SAAS;YACpB,MAAM,EAAE,MAAM;YACd,QAAQ,EAAE,QAAQ;YAClB,MAAM,EAAE,IAAI,CAAC,OAAO;YACpB,cAAc,EAAE,IAAI,CAAC,eAAe;YACpC,eAAe,EAAE,IAAI,CAAC,gBAAgB;SACvC;QAED,IAAI,CAAC,OAAO,IAAI,GAAG,CAAC;QACpB,IAAI,CAAC,eAAe,IAAI,GAAG,CAAC;QAC5B,IAAI,CAAC,gBAAgB,IAAI,GAAG,CAAC;;cAEvB,eAAe,GAAG,IAAI,MAAM,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,cAAc,CAAC;QAEnE,IAAI,CAAC,cAAc,EAAE,CAAC;QAEtB,OAAO,eAAe,CAAC;IACzB,CAAC;;;;;;;IAEM,IAAI,CAAC,SAAc,EAAE,MAAY,EAAE,QAAyB;QACjE,IAAI,CAAC,CAAC,MAAM,IAAI,CAAC,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;YAAE,MAAM,GAAG,EAAE,CAAC;;YAClD,QAAQ,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,EAAE,MAAM,EAAE,QAAQ,CAAC;QACvD,QAAQ,CAAC,IAAI,EAAE,CAAC;QAChB,OAAO,QAAQ,CAAC;IAClB,CAAC;;;YApGF,UAAU;;;;;;IAsDT,oCAAmC;;IAEnC,mCAAyD;;IACzD,mCAAyD;;;;;IAEzD,2CAAmC;;;;;IAEnC,oCAAgC;;;;;IAChC,4CAAwC;;;;;IACxC,6CAAyC","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"]}