com.phloxui
Version:
PhloxUI Ng2+ Framework
310 lines (309 loc) • 28.3 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
import * as tslib_1 from "tslib";
import { Component, Input, ElementRef } from '@angular/core';
import { ComponentDialogModel } from '.././model/ComponentDialogModel';
import { PhloxAppInfoService } from '../../service/PhloxAppInfoService.service';
import { AbstractDialogController } from '../AbstractDialogController';
var /** @type {?} */ TYPE_NAME = "phx-component-dialog";
/**
* <p style="text-indent: 2em;">
* A <code>child-view</code> component class of [[PhloxDialog]] handling logic of <code>component dialog</code>. This class should be
* <b>internally used by the framework</b>. If you just want to show a <code>component dialog</code>. Please see [[DialogService.showComponentDialog]]
* for more info.
* </p>
*
* @author shiorin, tee4cute
* @see [[PhloxDialog]]
* @see [[DialogService]]
*/
var ComponentDialog = /** @class */ (function (_super) {
tslib_1.__extends(ComponentDialog, _super);
function ComponentDialog(elementRef, phloxAppService) {
var _this = _super.call(this, elementRef) || this;
_this.componentInstance = null;
if (phloxAppService != null) {
phloxAppService.getAppInfo().then(function (result) {
_this.phloxAppInfo = result;
});
}
_this.componentHandler = function (result) {
_this.componentInstance = result.instance;
if (typeof _this.componentInstance.getButtonsChangeEvent === 'function') {
var /** @type {?} */ btnChangeEV = _this.componentInstance.getButtonsChangeEvent();
if (btnChangeEV !== null && typeof btnChangeEV !== 'undefined') {
btnChangeEV.subscribe(function (event) {
_this.refreshActionButtons();
});
}
}
_this.refreshActionButtons();
};
return _this;
}
/**
* @return {?}
*/
ComponentDialog.prototype.ngOnInit = /**
* @return {?}
*/
function () {
this.refreshActionButtons();
};
/**
* @param {?} changes
* @return {?}
*/
ComponentDialog.prototype.ngOnChanges = /**
* @param {?} changes
* @return {?}
*/
function (changes) {
if (changes['model'] !== null && typeof changes['model'] !== 'undefined') {
this.refreshActionButtons();
}
};
/**
* @return {?}
*/
ComponentDialog.prototype.getResultFromComponentWrapper = /**
* @return {?}
*/
function () {
if (this.componentInstance !== null && typeof this.componentInstance !== 'undefined') {
if (typeof this.componentInstance.getDialogResult === 'function') {
return this.componentInstance.getDialogResult();
}
}
return null;
};
/**
* @return {?}
*/
ComponentDialog.prototype.refreshActionButtons = /**
* @return {?}
*/
function () {
var _this = this;
var /** @type {?} */ dialogButtons = [];
if (this.componentInstance !== null && typeof this.componentInstance !== 'undefined') {
if (typeof this.componentInstance.getDialogButtons === 'function') {
var /** @type {?} */ actionBths = this.componentInstance.getDialogButtons();
if (actionBths !== null && typeof actionBths !== 'undefined' && Array.isArray(actionBths)) {
try {
for (var actionBths_1 = tslib_1.__values(actionBths), actionBths_1_1 = actionBths_1.next(); !actionBths_1_1.done; actionBths_1_1 = actionBths_1.next()) {
var btn = actionBths_1_1.value;
dialogButtons.push(btn);
}
}
catch (e_1_1) { e_1 = { error: e_1_1 }; }
finally {
try {
if (actionBths_1_1 && !actionBths_1_1.done && (_a = actionBths_1.return)) _a.call(actionBths_1);
}
finally { if (e_1) throw e_1.error; }
}
}
}
}
if (dialogButtons.length <= 0) {
if (this.model !== null && typeof this.model !== 'undefined') {
if (this.model.buttonModels !== null && typeof this.model.buttonModels !== 'undefined') {
try {
for (var _b = tslib_1.__values(this.model.buttonModels), _c = _b.next(); !_c.done; _c = _b.next()) {
var btn = _c.value;
dialogButtons.push(btn);
}
}
catch (e_2_1) { e_2 = { error: e_2_1 }; }
finally {
try {
if (_c && !_c.done && (_d = _b.return)) _d.call(_b);
}
finally { if (e_2) throw e_2.error; }
}
}
}
}
// auto add btn
if (dialogButtons.length <= 0) {
var /** @type {?} */ cancelHandler = function () {
var /** @type {?} */ result = -1;
if (_this.dialog !== null && typeof _this.dialog !== 'undefined') {
_this.dialog.hideDialog();
}
};
dialogButtons.push(new ComponentDialogModel.ButtonModel(this.getI18NMessage('CANCEL'), null, cancelHandler, ['dialog-btn', 'cancel']));
}
this.dialogButtons = dialogButtons;
var e_1, _a, e_2, _d;
};
/**
* @param {?} key
* @return {?}
*/
ComponentDialog.prototype.getI18NMessage = /**
* @param {?} key
* @return {?}
*/
function (key) {
if (this.phloxAppInfo != null && this.phloxAppInfo.i18n != null) {
if (this.phloxAppInfo.i18n[key] !== null && typeof this.phloxAppInfo.i18n[key] !== 'undefined') {
return this.phloxAppInfo.i18n[key];
}
}
return key;
};
/**
* @param {?} $event
* @return {?}
*/
ComponentDialog.prototype._onXBtnClicked = /**
* @param {?} $event
* @return {?}
*/
function ($event) {
if (this.model !== null && typeof this.model !== 'undefined') {
if (this.model.closeHandler !== null && typeof this.model.closeHandler !== 'undefined') {
if (typeof this.model.closeHandler === 'function') {
this.model.closeHandler.call(null, $event);
}
}
}
};
/**
* @return {?}
*/
ComponentDialog.prototype._isShowXBtn = /**
* @return {?}
*/
function () {
if (this.model !== null && typeof this.model !== 'undefined') {
if (this.model.closeHandler !== null && typeof this.model.closeHandler !== 'undefined') {
if (typeof this.model.closeHandler === 'function') {
return true;
}
}
}
return false;
};
/**
* @return {?}
*/
ComponentDialog.prototype._getComponentHandler = /**
* @return {?}
*/
function () {
return this.componentHandler;
};
/**
* @param {?} styleClass
* @return {?}
*/
ComponentDialog.prototype._getDefaultItemStyleClass = /**
* @param {?} styleClass
* @return {?}
*/
function (styleClass) {
var /** @type {?} */ defStyleClass = ["dialog-btn"];
if (styleClass !== null && styleClass !== undefined && styleClass.length > 0) {
return styleClass;
}
return defStyleClass;
};
/**
* @return {?}
*/
ComponentDialog.prototype.showDialog = /**
* @return {?}
*/
function () {
this.show = true;
};
/**
* @return {?}
*/
ComponentDialog.prototype.hideDialog = /**
* @return {?}
*/
function () {
this.show = false;
};
/**
* @return {?}
*/
ComponentDialog.prototype.isShow = /**
* @return {?}
*/
function () {
return this.show;
};
/**
* @return {?}
*/
ComponentDialog.prototype.getModel = /**
* @return {?}
*/
function () {
return this.model;
};
/**
* @param {?} model
* @return {?}
*/
ComponentDialog.prototype.setModel = /**
* @param {?} model
* @return {?}
*/
function (model) {
this.model = model;
this.refreshActionButtons();
};
ComponentDialog.TYPE_NAME = TYPE_NAME;
ComponentDialog.decorators = [
{ type: Component, args: [{
moduleId: module.id,
selector: TYPE_NAME,
template: "<div class=\"phx-component-dialog\" [class.show]=\"isShow()\">\n\t<ng-template [ngIf]=\"getModel() != null\">\n\t\t<div class=\"dialog-header\" [ngClass]=\"getModel().headerStyleClass\">\n\t\t\t<div class=\"wrapper\">\n\t\t\t\t<div>\n\t\t\t\t\t{{getModel() != null ? getModel().title : ''}}\n\t\t\t\t</div>\n\t\t\t\t<div>\n\t\t\t\t\t<div class=\"table-wrapper fluid\">\n\t\t\t\t\t\t<div class=\"table-cell-wrapper middle\">\n\t\t\t\t\t\t\t<h4 class=\"x-btn\" *ngIf=\"_isShowXBtn()\" (click)=\"_onXBtnClicked($event)\">X</h4>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t</div>\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t</div>\n\n\t\t<div class=\"dialog-body\" [ngClass]=\"getModel().bodyStyleClass\">\n\t\t\t<div>\n\t\t\t\t<phx-component-wrapper #componentWrapper [type]=\"getModel().componentType\" [model]=\"getModel().model\" [handler]=\"_getComponentHandler()\"\n\t\t\t\t\t[data]=\"getModel().data\"></phx-component-wrapper>\n\t\t\t</div>\n\t\t</div>\n\n\t\t<div class=\"dialog-footer\" [ngClass]=\"getModel().footerStyleClass\">\n\t\t\t<div class=\"wrapper\">\n\t\t\t\t<div>\n\t\t\t\t\t<ng-template [ngIf]=\"getModel() != null\">\n\t\t\t\t\t<div *ngFor=\"let item of getDialogButtons(); let j = index\"\n\t\t\t\t\t\t[ngClass]=\"_getDefaultItemStyleClass(item.styleClass)\" (click)=\"item.handler()\">{{item.label}}</div>\n\t\t\t\t\t</ng-template>\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t</div>\n\t</ng-template>\n</div>\n"
},] },
];
/** @nocollapse */
ComponentDialog.ctorParameters = function () { return [
{ type: ElementRef, },
{ type: PhloxAppInfoService, },
]; };
ComponentDialog.propDecorators = {
"model": [{ type: Input },],
"dialog": [{ type: Input },],
};
return ComponentDialog;
}(AbstractDialogController));
export { ComponentDialog };
function ComponentDialog_tsickle_Closure_declarations() {
/** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */
ComponentDialog.decorators;
/**
* @nocollapse
* @type {function(): !Array<(null|{type: ?, decorators: (undefined|!Array<{type: !Function, args: (undefined|!Array<?>)}>)})>}
*/
ComponentDialog.ctorParameters;
/** @type {!Object<string,!Array<{type: !Function, args: (undefined|!Array<?>)}>>} */
ComponentDialog.propDecorators;
/** @type {?} */
ComponentDialog.TYPE_NAME;
/** @type {?} */
ComponentDialog.prototype.model;
/** @type {?} */
ComponentDialog.prototype.dialog;
/** @type {?} */
ComponentDialog.prototype.componentInstance;
/** @type {?} */
ComponentDialog.prototype.show;
/** @type {?} */
ComponentDialog.prototype.phloxAppInfo;
/** @type {?} */
ComponentDialog.prototype.componentHandler;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ComponentDialog.component.js","sourceRoot":"ng://com.phloxui/","sources":["lib/component/dialog.internal/ComponentDialog.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit, OnChanges, ViewChild, EventEmitter, ElementRef } from '@angular/core';\nimport { ComponentDialogModel, ButtonModel } from '.././model/ComponentDialogModel';\nimport { DialogModel } from '.././model/DialogModel';\nimport { IDialog } from './IDialog';\nimport { PhloxAppInfo } from '../../component/model/PhloxAppInfo';\nimport { PhloxAppInfoService } from '../../service/PhloxAppInfoService.service';\nimport { AbstractDialogController } from '../AbstractDialogController';\n\nconst TYPE_NAME: string = \"phx-component-dialog\";\n\n/**\n * <p style=\"text-indent: 2em;\">\n * A <code>child-view</code> component class of [[PhloxDialog]] handling logic of <code>component dialog</code>. This class should be\n * <b>internally used by the framework</b>. If you just want to show a <code>component dialog</code>. Please see [[DialogService.showComponentDialog]]\n * for more info.\n * </p>\n *\n * @author shiorin, tee4cute\n * @see [[PhloxDialog]]\n * @see [[DialogService]]\n */\n@Component({\n  moduleId: module.id,\n  selector: TYPE_NAME,\n  template: `<div class=\"phx-component-dialog\" [class.show]=\"isShow()\">\n\t<ng-template [ngIf]=\"getModel() != null\">\n\t\t<div class=\"dialog-header\" [ngClass]=\"getModel().headerStyleClass\">\n\t\t\t<div class=\"wrapper\">\n\t\t\t\t<div>\n\t\t\t\t\t{{getModel() != null ? getModel().title : ''}}\n\t\t\t\t</div>\n\t\t\t\t<div>\n\t\t\t\t\t<div class=\"table-wrapper fluid\">\n\t\t\t\t\t\t<div class=\"table-cell-wrapper middle\">\n\t\t\t\t\t\t\t<h4 class=\"x-btn\" *ngIf=\"_isShowXBtn()\" (click)=\"_onXBtnClicked($event)\">X</h4>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t</div>\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t</div>\n\n\t\t<div class=\"dialog-body\" [ngClass]=\"getModel().bodyStyleClass\">\n\t\t\t<div>\n\t\t\t\t<phx-component-wrapper #componentWrapper [type]=\"getModel().componentType\" [model]=\"getModel().model\" [handler]=\"_getComponentHandler()\"\n\t\t\t\t\t[data]=\"getModel().data\"></phx-component-wrapper>\n\t\t\t</div>\n\t\t</div>\n\n\t\t<div class=\"dialog-footer\" [ngClass]=\"getModel().footerStyleClass\">\n\t\t\t<div class=\"wrapper\">\n\t\t\t\t<div>\n\t\t\t\t\t<ng-template [ngIf]=\"getModel() != null\">\n\t\t\t\t\t<div *ngFor=\"let item of getDialogButtons(); let j = index\"\n\t\t\t\t\t\t[ngClass]=\"_getDefaultItemStyleClass(item.styleClass)\" (click)=\"item.handler()\">{{item.label}}</div>\n\t\t\t\t\t</ng-template>\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t</div>\n\t</ng-template>\n</div>\n`\n})\nexport class ComponentDialog extends AbstractDialogController implements IDialog, OnInit, OnChanges {\n\n  public static readonly TYPE_NAME: string = TYPE_NAME;\n\n  @Input()\n  private model: ComponentDialogModel;\n  @Input()\n  private dialog: any;\n  private componentInstance: any;\n  private show: boolean;\n  private phloxAppInfo: PhloxAppInfo;\n  private componentHandler: Function;\n\n  constructor(elementRef: ElementRef, phloxAppService: PhloxAppInfoService) {\n    super(elementRef);\n\n    this.componentInstance = null;\n\n    if (phloxAppService != null) {\n      phloxAppService.getAppInfo().then((result) => {\n        this.phloxAppInfo = result;\n      });\n    }\n\n    this.componentHandler = (result: any) => {\n      this.componentInstance = result.instance;\n      if (typeof this.componentInstance.getButtonsChangeEvent === 'function') {\n        let btnChangeEV = this.componentInstance.getButtonsChangeEvent();\n        if (btnChangeEV !== null && typeof btnChangeEV !== 'undefined') {\n          btnChangeEV.subscribe((event: any) => {\n            this.refreshActionButtons();\n          });\n        }\n      }\n\n      this.refreshActionButtons();\n    }\n  }\n\n  public ngOnInit(): void {\n    this.refreshActionButtons();\n  }\n\n  public ngOnChanges(changes: any) {\n    if (changes['model'] !== null && typeof changes['model'] !== 'undefined') {\n      this.refreshActionButtons();\n    }\n  }\n\n  private getResultFromComponentWrapper(): any {\n    if (this.componentInstance !== null && typeof this.componentInstance !== 'undefined') {\n      if (typeof this.componentInstance.getDialogResult === 'function') {\n        return this.componentInstance.getDialogResult();\n      }\n    }\n    return null;\n  }\n\n  private refreshActionButtons(): void {\n    let dialogButtons = [];\n\n    if (this.componentInstance !== null && typeof this.componentInstance !== 'undefined') {\n      if (typeof this.componentInstance.getDialogButtons === 'function') {\n        let actionBths = this.componentInstance.getDialogButtons();\n\n        if (actionBths !== null && typeof actionBths !== 'undefined' && Array.isArray(actionBths)) {\n          for (let btn of actionBths) {\n            dialogButtons.push(btn);\n          }\n        }\n      }\n    }\n\n    if (dialogButtons.length <= 0) {\n      if (this.model !== null && typeof this.model !== 'undefined') {\n        if (this.model.buttonModels !== null && typeof this.model.buttonModels !== 'undefined') {\n          for (let btn of this.model.buttonModels) {\n            dialogButtons.push(btn);\n          }\n        }\n      }\n    }\n\n    // auto add btn\n    if (dialogButtons.length <= 0) {\n      let cancelHandler: Function = () => {\n        let result = -1;\n        if (this.dialog !== null && typeof this.dialog !== 'undefined') {\n          this.dialog.hideDialog();\n        }\n      };\n      dialogButtons.push(new ComponentDialogModel.ButtonModel(this.getI18NMessage('CANCEL'), null, cancelHandler, ['dialog-btn', 'cancel']));\n    }\n\n    this.dialogButtons = dialogButtons;\n  }\n\n  private getI18NMessage(key: string): string {\n    if (this.phloxAppInfo != null && this.phloxAppInfo.i18n != null) {\n      if (this.phloxAppInfo.i18n[key] !== null && typeof this.phloxAppInfo.i18n[key] !== 'undefined') {\n        return this.phloxAppInfo.i18n[key];\n      }\n    }\n    return key;\n  }\n\n  public _onXBtnClicked($event: Event): void {\n    if (this.model !== null && typeof this.model !== 'undefined') {\n      if (this.model.closeHandler !== null && typeof this.model.closeHandler !== 'undefined') {\n        if (typeof this.model.closeHandler === 'function') {\n          this.model.closeHandler.call(null, $event);\n        }\n      }\n    }\n  }\n\n  public _isShowXBtn(): boolean {\n    if (this.model !== null && typeof this.model !== 'undefined') {\n      if (this.model.closeHandler !== null && typeof this.model.closeHandler !== 'undefined') {\n        if (typeof this.model.closeHandler === 'function') {\n          return true;\n        }\n      }\n    }\n\n    return false;\n  }\n\n  public _getComponentHandler(): Function {\n    return this.componentHandler;\n  }\n\n  public _getDefaultItemStyleClass(styleClass: String[]): String[]{\n    let defStyleClass = [\"dialog-btn\"];\n\n    if(styleClass !== null && styleClass !== undefined && styleClass.length > 0){\n      return styleClass;\n    }\n\n    return defStyleClass;\n  }\n\n  public showDialog(): void {\n    this.show = true;\n  }\n\n  public hideDialog(): void {\n    this.show = false;\n  }\n\n  public isShow(): boolean {\n    return this.show;\n  }\n\n  public getModel(): any {\n    return this.model;\n  }\n\n  public setModel(model: any): void {\n    this.model = model;\n\n    this.refreshActionButtons();\n  }\n}\n"]}