@uex/web-extensions
Version:
Uex extensions for Angular 6+ web projects
211 lines • 17.9 kB
JavaScript
/**
* @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"]}