UNPKG

@uex/web-extensions

Version:

Uex extensions for Angular 6+ web projects

211 lines 17.9 kB
/** * @fileoverview added by tsickle * Generated from: lib/modules/dialog/dialog.service.ts * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Injectable } from "@angular/core"; import * as _ from "lodash"; import { DialogBaseService } from "./dialog.base.service"; import { DialogLoadingComponent } from "./components/loading/loading.component"; import { DialogAlertComponent } from "./components/alert/alert.component"; import { DialogConfirmComponent } from "./components/confirm/confirm.component"; import { DialogPromptComponent } from "./components/prompt/prompt.component"; import { DialogViewerComponent } from "./components/viewer/viewer.component"; /** * Serviço que inicializa e exibe um modal a partir de um componente * * Example * ```ts * private dialog: Dialog; * private openModal() { * if(!this.dialog) { * this.dialog = this.dialogService.create(TesteModal, { * // Dialog params (Opcional) * teste: { * 'its work?': true * } * }, { * // Dialog settings (Opcional) * backdrop: { // Backdrop settings (Opcional) * onClick: 'close' // Opcional: 'close', 'dismiss', 'none' (default: close) * }, * header: { // Header settings (Opcional) * title: 'Teste modal', // Obrigatório * subtitle: 'Isso é apenas um teste', // Opcional * closable: true, // Opcional (default: true) * closeClick: 'close' // Opcional: 'close', 'dismiss' (default: close) * } * }); * // Quando o modal é aberto * this.dialog.onOpen.subscribe(() => console.log("Modal opened")); * // Quando o dialog é ocultado * this.dialog.onDismiss.subscribe(() => console.log("Modal dismissed")); * // Quando o dialog é destruido * this.dialog.onClose.subscribe(() => console.log("Modal closed")); * // Quando o dialog retorna um valor * this.dialog.onReturnValue.subscribe((response) => console.log("Modal response:", response)); * } * this.dialog.open(); * } * ``` * */ export class DialogService { /** * @param {?} _baseService */ constructor(_baseService) { this._baseService = _baseService; } /** * @return {?} */ get onShow() { return this._baseService.onShow; } /** * @return {?} */ get onHide() { return this._baseService.onHide; } /** * @return {?} */ get visibleDialogs() { return this._baseService.visibleDialogs; } /** * @return {?} */ get dialogs() { return this._baseService.dialogs; } /** * @param {?} component * @param {?=} params * @param {?=} settings * @return {?} */ create(component, params, settings) { return this._baseService.create(component, params, settings); } /** * @param {?} component * @param {?=} params * @param {?=} settings * @return {?} */ open(component, params, settings) { return this._baseService.open(component, params, settings); } /** * @param {?} message * @return {?} */ loading(message) { return this.open(DialogLoadingComponent, { message }, { size: "xs", backdrop: { onClick: "none" } }); } /** * @param {?} params * @return {?} */ alert(params) { /** @type {?} */ let size = params.size ? params.size : "xs"; delete params.size; return this.open(DialogAlertComponent, params, { size }); } /** * @param {?} params * @param {?} callback * @return {?} */ confirm(params, callback) { /** @type {?} */ let size = params.size ? params.size : "xs"; delete params.size; /** @type {?} */ let dialog = this.open(DialogConfirmComponent, params, { size, backdrop: { onClick: "none" } }); /** @type {?} */ const subscription = dialog.onReturnValue.subscribe((/** * @param {?} response * @return {?} */ (response) => { subscription.unsubscribe(); callback(response); dialog.close(); })); return dialog; } /** * @param {?} params * @param {?} callback * @return {?} */ prompt(params, callback) { /** @type {?} */ let size = params.size ? params.size : "xs"; delete params.size; if (!_.isArray(params.schema)) params.schema = [(/** @type {?} */ (params.schema))]; /** @type {?} */ let dialog = this.open(DialogPromptComponent, params, { size, backdrop: { onClick: "none" } }); /** @type {?} */ const subscription = dialog.onReturnValue.subscribe((/** * @param {?} response * @return {?} */ (response) => { subscription.unsubscribe(); callback(response); dialog.close(); })); return dialog; } /** * @param {?} src * @param {?=} type * @return {?} */ openViewer(src, type = "image") { return this.open(DialogViewerComponent, { src, type }, { size: "responsive", keyboard: { onEscape: "close" }, fit_to_screen: false, wrapper_class: "uex-dialog-viewer-wrapper", dialog_class: "uex-dialog-viewer-dialog", content_class: "uex-dialog-viewer-content", backdrop_class: "uex-dialog-viewer-backdrop" }); } } DialogService.decorators = [ { type: Injectable } ]; /** @nocollapse */ DialogService.ctorParameters = () => [ { type: DialogBaseService } ]; if (false) { /** * @type {?} * @private */ DialogService.prototype._baseService; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog.service.js","sourceRoot":"ng://@uex/web-extensions/","sources":["lib/modules/dialog/dialog.service.ts"],"names":[],"mappings":";;;;;AAAA,OAAO,EAAE,UAAU,EAAgB,MAAM,eAAe,CAAC;AAEzD,OAAO,KAAK,CAAC,MAAM,QAAQ,CAAC;AAa5B,OAAO,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAC;AAG1D,OAAO,EAAE,sBAAsB,EAAE,MAAM,wCAAwC,CAAC;AAChF,OAAO,EAAE,oBAAoB,EAAE,MAAM,oCAAoC,CAAC;AAC1E,OAAO,EAAE,sBAAsB,EAAE,MAAM,wCAAwC,CAAC;AAChF,OAAO,EAAE,qBAAqB,EAAE,MAAM,sCAAsC,CAAC;AAC7E,OAAO,EAAE,qBAAqB,EAAE,MAAM,sCAAsC,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA4C7E,MAAM,OAAO,aAAa;;;;IACxB,YAAoB,YAA+B;QAA/B,iBAAY,GAAZ,YAAY,CAAmB;IAAG,CAAC;;;;IAEvD,IAAW,MAAM;QACf,OAAO,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC;IAClC,CAAC;;;;IACD,IAAW,MAAM;QACf,OAAO,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC;IAClC,CAAC;;;;IAED,IAAW,cAAc;QACvB,OAAO,IAAI,CAAC,YAAY,CAAC,cAAc,CAAC;IAC1C,CAAC;;;;IAED,IAAW,OAAO;QAChB,OAAO,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC;IACnC,CAAC;;;;;;;IAEM,MAAM,CACX,SAAc,EACd,MAAY,EACZ,QAAyB;QAEzB,OAAO,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,SAAS,EAAE,MAAM,EAAE,QAAQ,CAAC,CAAC;IAC/D,CAAC;;;;;;;IAEM,IAAI,CAAC,SAAc,EAAE,MAAY,EAAE,QAAyB;QACjE,OAAO,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,SAAS,EAAE,MAAM,EAAE,QAAQ,CAAC,CAAC;IAC7D,CAAC;;;;;IAEM,OAAO,CAAC,OAAsC;QACnD,OAAO,IAAI,CAAC,IAAI,CACd,sBAAsB,EACtB;YACE,OAAO;SACR,EACD;YACE,IAAI,EAAE,IAAI;YACV,QAAQ,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE;SAC9B,CACF,CAAC;IACJ,CAAC;;;;;IAEM,KAAK,CAAC,MAAyB;;YAChC,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI;QAC3C,OAAO,MAAM,CAAC,IAAI,CAAC;QACnB,OAAO,IAAI,CAAC,IAAI,CAAC,oBAAoB,EAAE,MAAM,EAAE,EAAE,IAAI,EAAE,CAAC,CAAC;IAC3D,CAAC;;;;;;IAEM,OAAO,CACZ,MAA2B,EAC3B,QAA+B;;YAE3B,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI;QAC3C,OAAO,MAAM,CAAC,IAAI,CAAC;;YACf,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,sBAAsB,EAAE,MAAM,EAAE;YACrD,IAAI;YACJ,QAAQ,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE;SAC9B,CAAC;;cACI,YAAY,GAAiB,MAAM,CAAC,aAAa,CAAC,SAAS;;;;QAC/D,CAAC,QAAiB,EAAE,EAAE;YACpB,YAAY,CAAC,WAAW,EAAE,CAAC;YAC3B,QAAQ,CAAC,QAAQ,CAAC,CAAC;YACnB,MAAM,CAAC,KAAK,EAAE,CAAC;QACjB,CAAC,EACF;QACD,OAAO,MAAM,CAAC;IAChB,CAAC;;;;;;IAEM,MAAM,CACX,MAA0B,EAC1B,QAA8B;;YAE1B,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI;QAC3C,OAAO,MAAM,CAAC,IAAI,CAAC;QACnB,IAAI,CAAC,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,MAAM,CAAC;YAC3B,MAAM,CAAC,MAAM,GAAG,CAAC,mBAAgB,MAAM,CAAC,MAAM,EAAA,CAAC,CAAC;;YAC9C,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,qBAAqB,EAAE,MAAM,EAAE;YACpD,IAAI;YACJ,QAAQ,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE;SAC9B,CAAC;;cACI,YAAY,GAAiB,MAAM,CAAC,aAAa,CAAC,SAAS;;;;QAC/D,CAAC,QAAoB,EAAE,EAAE;YACvB,YAAY,CAAC,WAAW,EAAE,CAAC;YAC3B,QAAQ,CAAC,QAAQ,CAAC,CAAC;YACnB,MAAM,CAAC,KAAK,EAAE,CAAC;QACjB,CAAC,EACF;QACD,OAAO,MAAM,CAAC;IAChB,CAAC;;;;;;IAEM,UAAU,CAAC,GAAW,EAAE,OAA0B,OAAO;QAC9D,OAAO,IAAI,CAAC,IAAI,CACd,qBAAqB,EACrB,EAAE,GAAG,EAAE,IAAI,EAAE,EACb;YACE,IAAI,EAAE,YAAY;YAClB,QAAQ,EAAE;gBACR,QAAQ,EAAE,OAAO;aAClB;YACD,aAAa,EAAE,KAAK;YACpB,aAAa,EAAE,2BAA2B;YAC1C,YAAY,EAAE,0BAA0B;YACxC,aAAa,EAAE,2BAA2B;YAC1C,cAAc,EAAE,4BAA4B;SAC7C,CACF,CAAC;IACJ,CAAC;;;YA5GF,UAAU;;;;YAlDF,iBAAiB;;;;;;;IAoDZ,qCAAuC","sourcesContent":["import { Injectable, EventEmitter } from \"@angular/core\";\r\n\r\nimport * as _ from \"lodash\";\r\nimport { Subscription } from \"rxjs\";\r\n\r\nimport {\r\n  Dialog,\r\n  DialogSettings,\r\n  DialogAlertParams,\r\n  DialogConfirmParams,\r\n  DialogConfirmCallback,\r\n  DialogPromptParams,\r\n  DialogPromptCallback,\r\n  DialogStringFunction\r\n} from \"./dialog.base\";\r\nimport { DialogBaseService } from \"./dialog.base.service\";\r\nimport { FormValues, FormSchemaData } from \"../form/form.interface\";\r\n\r\nimport { DialogLoadingComponent } from \"./components/loading/loading.component\";\r\nimport { DialogAlertComponent } from \"./components/alert/alert.component\";\r\nimport { DialogConfirmComponent } from \"./components/confirm/confirm.component\";\r\nimport { DialogPromptComponent } from \"./components/prompt/prompt.component\";\r\nimport { DialogViewerComponent } from \"./components/viewer/viewer.component\";\r\n\r\n/**\r\n * Serviço que inicializa e exibe um modal a partir de um componente\r\n *\r\n * Example\r\n\r\n```ts\r\nprivate dialog: Dialog;\r\nprivate openModal() {\r\n  if(!this.dialog) {\r\n    this.dialog = this.dialogService.create(TesteModal, {\r\n      // Dialog params (Opcional)\r\n      teste: {\r\n        'its work?': true\r\n      }\r\n    }, {\r\n      // Dialog settings (Opcional)\r\n      backdrop: {                             // Backdrop settings (Opcional)\r\n        onClick: 'close'                      // Opcional: 'close', 'dismiss', 'none' (default: close)\r\n      },\r\n      header: {                               // Header settings (Opcional)\r\n        title: 'Teste modal',                 // Obrigatório\r\n        subtitle: 'Isso é apenas um teste',   // Opcional\r\n        closable: true,                       // Opcional (default: true)\r\n        closeClick: 'close'                   // Opcional: 'close', 'dismiss' (default: close)\r\n      }\r\n    });\r\n    // Quando o modal é aberto\r\n    this.dialog.onOpen.subscribe(() => console.log(\"Modal opened\"));\r\n    // Quando o dialog é ocultado\r\n    this.dialog.onDismiss.subscribe(() => console.log(\"Modal dismissed\"));\r\n    // Quando o dialog é destruido\r\n    this.dialog.onClose.subscribe(() => console.log(\"Modal closed\"));\r\n    // Quando o dialog retorna um valor\r\n    this.dialog.onReturnValue.subscribe((response) => console.log(\"Modal response:\", response));\r\n  }\r\n  this.dialog.open();\r\n}\r\n```\r\n\r\n *\r\n */\r\n@Injectable()\r\nexport class DialogService {\r\n  constructor(private _baseService: DialogBaseService) {}\r\n\r\n  public get onShow(): EventEmitter<Dialog> {\r\n    return this._baseService.onShow;\r\n  }\r\n  public get onHide(): EventEmitter<Dialog> {\r\n    return this._baseService.onHide;\r\n  }\r\n\r\n  public get visibleDialogs(): Array<Dialog> {\r\n    return this._baseService.visibleDialogs;\r\n  }\r\n\r\n  public get dialogs(): Array<Dialog> {\r\n    return this._baseService.dialogs;\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    return this._baseService.create(component, params, settings);\r\n  }\r\n\r\n  public open(component: any, params?: any, settings?: DialogSettings): Dialog {\r\n    return this._baseService.open(component, params, settings);\r\n  }\r\n\r\n  public loading(message: DialogStringFunction | string): Dialog {\r\n    return this.open(\r\n      DialogLoadingComponent,\r\n      {\r\n        message\r\n      },\r\n      {\r\n        size: \"xs\",\r\n        backdrop: { onClick: \"none\" }\r\n      }\r\n    );\r\n  }\r\n\r\n  public alert(params: DialogAlertParams): Dialog {\r\n    let size = params.size ? params.size : \"xs\";\r\n    delete params.size;\r\n    return this.open(DialogAlertComponent, params, { size });\r\n  }\r\n\r\n  public confirm(\r\n    params: DialogConfirmParams,\r\n    callback: DialogConfirmCallback\r\n  ): Dialog {\r\n    let size = params.size ? params.size : \"xs\";\r\n    delete params.size;\r\n    let dialog = this.open(DialogConfirmComponent, params, {\r\n      size,\r\n      backdrop: { onClick: \"none\" }\r\n    });\r\n    const subscription: Subscription = dialog.onReturnValue.subscribe(\r\n      (response: boolean) => {\r\n        subscription.unsubscribe();\r\n        callback(response);\r\n        dialog.close();\r\n      }\r\n    );\r\n    return dialog;\r\n  }\r\n\r\n  public prompt(\r\n    params: DialogPromptParams,\r\n    callback: DialogPromptCallback\r\n  ): Dialog {\r\n    let size = params.size ? params.size : \"xs\";\r\n    delete params.size;\r\n    if (!_.isArray(params.schema))\r\n      params.schema = [<FormSchemaData>params.schema];\r\n    let dialog = this.open(DialogPromptComponent, params, {\r\n      size,\r\n      backdrop: { onClick: \"none\" }\r\n    });\r\n    const subscription: Subscription = dialog.onReturnValue.subscribe(\r\n      (response: FormValues) => {\r\n        subscription.unsubscribe();\r\n        callback(response);\r\n        dialog.close();\r\n      }\r\n    );\r\n    return dialog;\r\n  }\r\n\r\n  public openViewer(src: string, type: \"image\" | \"video\" = \"image\"): Dialog {\r\n    return this.open(\r\n      DialogViewerComponent,\r\n      { src, type },\r\n      {\r\n        size: \"responsive\",\r\n        keyboard: {\r\n          onEscape: \"close\"\r\n        },\r\n        fit_to_screen: false,\r\n        wrapper_class: \"uex-dialog-viewer-wrapper\",\r\n        dialog_class: \"uex-dialog-viewer-dialog\",\r\n        content_class: \"uex-dialog-viewer-content\",\r\n        backdrop_class: \"uex-dialog-viewer-backdrop\"\r\n      }\r\n    );\r\n  }\r\n}\r\n"]}