com.phloxui
Version:
PhloxUI Ng2+ Framework
356 lines (355 loc) • 34 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
import * as tslib_1 from "tslib";
import { Component, ElementRef } from '@angular/core';
import { DialogService } from '../../../service/DialogService.service';
import { AbstractComponentDataLangSelector } from '../../dataview/AbstractComponentDataLangSelector';
import { LanguageButtonModel } from '../../model/LanguageButtonModel';
import { PhloxAppInfo } from '../../../component/model/PhloxAppInfo';
var /** @type {?} */ TYPE_NAME = "phx-data-lang-selector";
var /** @type {?} */ LANG_BTN_CLICK = 'languageBtnClicked';
var DataLangSelectorPane = /** @class */ (function (_super) {
tslib_1.__extends(DataLangSelectorPane, _super);
function DataLangSelectorPane(elementRef, dialogService) {
var _this = _super.call(this, elementRef, dialogService) || this;
_this.LANGUAGE_FIELD_NAME = PhloxAppInfo.DEFAULT_LANGUAGE_FIELD_NAME;
_this.OBJECT_ID_FIELD_NAME = PhloxAppInfo.DEFAULT_OBJECT_ID_FIELD_NAME;
return _this;
}
/**
* @return {?}
*/
DataLangSelectorPane.prototype.ngOnInit = /**
* @return {?}
*/
function () {
_super.prototype.ngOnInit.call(this);
};
/**
* @return {?}
*/
DataLangSelectorPane.prototype.getEditor = /**
* @return {?}
*/
function () {
if (this.data !== null && typeof this.data !== 'undefined') {
if (this.data.editor !== null && typeof this.data.editor !== 'undefined') {
return this.data.editor;
}
}
return null;
};
/**
* @param {?} dataObject
* @return {?}
*/
DataLangSelectorPane.prototype.getWrapDataObject = /**
* @param {?} dataObject
* @return {?}
*/
function (dataObject) {
var /** @type {?} */ editor = this.getEditor();
var /** @type {?} */ data = {
editor: editor,
objects: dataObject
};
return data;
};
/**
* @return {?} any as one object.
*/
DataLangSelectorPane.prototype.getDefaultData = /**
* @return {?} any as one object.
*/
function () {
var /** @type {?} */ objects = null;
if (this.data !== null && typeof this.data !== 'undefined') {
objects = this.data.objects;
}
if (objects === null || typeof objects === 'undefined') {
return null;
}
var /** @type {?} */ editor = this.getEditor();
var /** @type {?} */ langFieldName = null;
if (editor !== null) {
langFieldName = editor.getLanguageField();
}
var /** @type {?} */ oneObj = null;
if (Array.isArray(objects)) {
var /** @type {?} */ moreThanOneDef = false;
var /** @type {?} */ defObj = null;
try {
for (var objects_1 = tslib_1.__values(objects), objects_1_1 = objects_1.next(); !objects_1_1.done; objects_1_1 = objects_1.next()) {
var obj = objects_1_1.value;
var /** @type {?} */ lang = obj[langFieldName];
if (lang === null || typeof lang === 'undefined') {
if (defObj === null) {
defObj = obj;
}
else {
moreThanOneDef = true;
break;
}
}
}
}
catch (e_1_1) { e_1 = { error: e_1_1 }; }
finally {
try {
if (objects_1_1 && !objects_1_1.done && (_a = objects_1.return)) _a.call(objects_1);
}
finally { if (e_1) throw e_1.error; }
}
if (!moreThanOneDef && defObj !== null && typeof defObj !== 'undefined') {
oneObj = defObj;
}
}
else {
if (objects[langFieldName] === null || typeof objects[langFieldName] === 'undefined') {
oneObj = objects;
}
}
return oneObj;
var e_1, _a;
};
/**
* @return {?}
*/
DataLangSelectorPane.prototype.getDataObjects = /**
* @return {?}
*/
function () {
var /** @type {?} */ objects = null;
if (this.data !== null && typeof this.data !== 'undefined') {
objects = this.data.objects;
}
if (objects === null || typeof objects === 'undefined') {
return null;
}
return objects;
};
/**
* @return {?}
*/
DataLangSelectorPane.prototype.hasModel = /**
* @return {?}
*/
function () {
if (this.model !== null && typeof this.model !== 'undefined') {
return true;
}
return false;
};
/**
* @return {?}
*/
DataLangSelectorPane.prototype.getModel = /**
* @return {?}
*/
function () {
return this.model;
};
/**
* @param {?} model
* @return {?}
*/
DataLangSelectorPane.prototype.setModel = /**
* @param {?} model
* @return {?}
*/
function (model) {
this.model = model;
};
/**
* @return {?}
*/
DataLangSelectorPane.prototype.getLanguageFieldName = /**
* @return {?}
*/
function () {
var /** @type {?} */ editor = this.getEditor();
var /** @type {?} */ langFieldName = (editor === null) ? null : editor.getLanguageField();
if (langFieldName !== null && typeof langFieldName !== 'undefined') {
return langFieldName;
}
return this.LANGUAGE_FIELD_NAME;
};
/**
* @return {?}
*/
DataLangSelectorPane.prototype.getObjectIdFieldName = /**
* @return {?}
*/
function () {
var /** @type {?} */ editor = this.getEditor();
var /** @type {?} */ objIdFieldName = (editor === null) ? null : editor.getObjectIdField();
if (objIdFieldName !== null && typeof objIdFieldName !== 'undefined') {
return objIdFieldName;
}
return this.OBJECT_ID_FIELD_NAME;
};
/**
* @param {?} data
* @return {?}
*/
DataLangSelectorPane.prototype.getInstanceDefaultData = /**
* @param {?} data
* @return {?}
*/
function (data) {
return this.getWrapDataObject([data]);
};
/**
* @param {?} data
* @return {?}
*/
DataLangSelectorPane.prototype.getInstanceDataLanguage = /**
* @param {?} data
* @return {?}
*/
function (data) {
return this.getWrapDataObject([data]);
};
/**
* @return {?} any as object in pattern {iconURL: string, code: string, label: string}
*/
DataLangSelectorPane.prototype.getLanguageList = /**
* @return {?} any as object in pattern {iconURL: string, code: string, label: string}
*/
function () {
var /** @type {?} */ editor = this.getEditor();
var /** @type {?} */ languageList = [];
if (editor !== null) {
var /** @type {?} */ setting = editor.getAppSetting();
if (setting !== null && typeof setting !== 'undefined') {
var /** @type {?} */ defaultLangs = setting.DEFAULT_DATA_LANGUAGES;
if (defaultLangs !== null && typeof defaultLangs !== 'undefined' && Array.isArray(defaultLangs)) {
try {
for (var defaultLangs_1 = tslib_1.__values(defaultLangs), defaultLangs_1_1 = defaultLangs_1.next(); !defaultLangs_1_1.done; defaultLangs_1_1 = defaultLangs_1.next()) {
var lang = defaultLangs_1_1.value;
languageList.push(lang.code);
}
}
catch (e_2_1) { e_2 = { error: e_2_1 }; }
finally {
try {
if (defaultLangs_1_1 && !defaultLangs_1_1.done && (_a = defaultLangs_1.return)) _a.call(defaultLangs_1);
}
finally { if (e_2) throw e_2.error; }
}
}
}
}
return languageList;
var e_2, _a;
};
/**
* @param {?} defaultData
* @return {?}
*/
DataLangSelectorPane.prototype.loadDataLanguageList = /**
* @param {?} defaultData
* @return {?}
*/
function (defaultData) {
var _this = this;
return new Promise(function (resolve, reject) {
var /** @type {?} */ editor = _this.getEditor();
if (editor !== null) {
var /** @type {?} */ langProm = editor.getLanguageList(defaultData);
if (langProm !== null && typeof langProm !== 'undefined') {
langProm.then(function (result) {
var /** @type {?} */ tempArray = [];
if (result !== null && typeof result !== 'undefined') {
if (Array.isArray(result)) {
tempArray = result;
}
else {
tempArray.push(result);
}
}
resolve(tempArray);
});
}
}
else {
resolve([]);
}
});
};
/**
* when new language was created this method will be called
* @param {?} newLangData as any
* @return {?}
*/
DataLangSelectorPane.prototype.onLanguageAdded = /**
* when new language was created this method will be called
* @param {?} newLangData as any
* @return {?}
*/
function (newLangData) {
if (newLangData !== null && typeof newLangData !== 'undefined') {
// do sth here
}
// this.data.objects.push(newLangData);
};
/**
* when language was removed this method will be called
* @param {?} deletedData as any
* @return {?}
*/
DataLangSelectorPane.prototype.onLanguageRemoved = /**
* when language was removed this method will be called
* @param {?} deletedData as any
* @return {?}
*/
function (deletedData) {
// do sth
};
/**
* @param {?} langCode
* @return {?}
*/
DataLangSelectorPane.prototype.parseLanguageButtonModel = /**
* @param {?} langCode
* @return {?}
*/
function (langCode) {
return new LanguageButtonModel('', langCode, 'label');
};
DataLangSelectorPane.TYPE_NAME = TYPE_NAME;
DataLangSelectorPane.decorators = [
{ type: Component, args: [{
moduleId: module.id,
selector: TYPE_NAME,
template: "<div class=\"phx-data-lang-selector\">\n\t<div class=\"wrapper left\" [class.expand]=\"!hasLanguage()\">\n\t\t<div class=\"component-pane\">\n\t\t\t<!-- default -->\n\t\t\t<div class=\"component-wrapper\" [class.show]=\"_isSelectedLanguageByIndex(null)\">\n\t\t\t\t<phx-component-wrapper *ngIf=\"hasModel()\" [type]=\"getModel().tabComponentType\" [model]=\"getModel().tabComponentModel\"\n\t\t\t\t\t[handler]=\"getDefaultComponentHandler()\" [data]=\"getDefaultData()\" [dataParent]=\"this\"></phx-component-wrapper>\n\t\t\t</div>\n\t\t\t<!-- by lang -->\n\t\t\t<ng-template ngFor let-item [ngForOf]=\"_getDataLangList()\" let-i=\"index\">\n\t\t\t\t<div class=\"component-wrapper\" [class.show]=\"_isSelectedLanguageByIndex(i)\">\n\t\t\t\t\t<ng-template [ngIf]=\"item !== null && item !== undefined\">\n\t\t\t\t\t\t<phx-component-wrapper *ngIf=\"hasModel()\" [type]=\"getModel().tabComponentType\" [model]=\"getModel().tabComponentModel\"\n\t\t\t\t\t\t\t[handler]=\"getComponentHandler()\" [setting]=\"getComponentSetting(i)\" [data]=\"item\" [dataParent]=\"this\"></phx-component-wrapper>\n\t\t\t\t\t</ng-template>\n\t\t\t\t</div>\n\t\t\t</ng-template>\n\t\t</div>\n\t</div>\n\t<div class=\"wrapper right\" [class.hide]=\"!hasLanguage()\">\n\t\t<div class=\"lang-pane\">\n\t\t\t<div class=\"language-btn default data\" [class.selected]=\"isSelectedLanguage(null)\" [class.dirty]=\"_isDataDirtyByIndex(null)\"\n\t\t\t\t(click)=\"onActionBtnClicked($event, null, undefined)\">\n\t\t\t\t<div class=\"table-wrapper fluid\">\n\t\t\t\t\t<div class=\"table-cell-wrapper middle\">\n\t\t\t\t\t\tDefault\n\t\t\t\t\t</div>\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t\t<div *ngFor=\"let item of getMergedLanguageList(); let i = index\" class=\"language-btn\" [class.data]=\"_langHasDataByIndex(i)\"\n\t\t\t\t[class.dirty]=\"_isDataDirtyByIndex(i)\"\n\t\t\t\t[class.selected]=\"isSelectedLanguage(item)\" (click)=\"onActionBtnClicked($event, item, i)\">\n\t\t\t\t<div class=\"table-wrapper fluid\">\n\t\t\t\t\t<div class=\"table-cell-wrapper middle\">\n\t\t\t\t\t\t<div *ngIf=\"!_hasButtonIcon(item)\">{{item.code}}</div>\n\t\t\t\t\t\t<div *ngIf=\"_hasButtonIcon(item)\">\n\t\t\t\t\t\t\t<img src=\"{{item.iconURL}}\">\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\t<div class=\"mocking-btn\"></div>\n\t\t</div>\n\t</div>\n</div>\n"
},] },
];
/** @nocollapse */
DataLangSelectorPane.ctorParameters = function () { return [
{ type: ElementRef, },
{ type: DialogService, },
]; };
return DataLangSelectorPane;
}(AbstractComponentDataLangSelector));
export { DataLangSelectorPane };
function DataLangSelectorPane_tsickle_Closure_declarations() {
/** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */
DataLangSelectorPane.decorators;
/**
* @nocollapse
* @type {function(): !Array<(null|{type: ?, decorators: (undefined|!Array<{type: !Function, args: (undefined|!Array<?>)}>)})>}
*/
DataLangSelectorPane.ctorParameters;
/** @type {?} */
DataLangSelectorPane.TYPE_NAME;
/** @type {?} */
DataLangSelectorPane.prototype.LANGUAGE_FIELD_NAME;
/** @type {?} */
DataLangSelectorPane.prototype.OBJECT_ID_FIELD_NAME;
/** @type {?} */
DataLangSelectorPane.prototype.model;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"DataLangSelectorPane.component.js","sourceRoot":"ng://com.phloxui/","sources":["lib/component/editor/editor.internal/DataLangSelectorPane.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, OnInit, ElementRef } from '@angular/core';\nimport { DialogService } from '../../../service/DialogService.service';\nimport { AbstractDataEditor } from '../AbstractDataEditor';\nimport { AbstractComponentDataLangSelector } from '../../dataview/AbstractComponentDataLangSelector';\n\nimport { IHasModel } from '../../IHasModel';\nimport { DataLangSelectorModel } from '../../model/DataLangSelectorModel';\nimport { LanguageButtonModel } from '../../model/LanguageButtonModel';\nimport { PhloxAppInfo } from '../../../component/model/PhloxAppInfo';\n\ndeclare var $: any;\n\nconst TYPE_NAME: string = \"phx-data-lang-selector\";\n\nconst LANG_BTN_CLICK: string = 'languageBtnClicked';\n\n// use material DataLangSelectorPane instade ?? (Should we delete this component)\n// try to find if no component use\n@Component({\n  moduleId: module.id,\n  selector: TYPE_NAME,\n  template: `<div class=\"phx-data-lang-selector\">\n\t<div class=\"wrapper left\" [class.expand]=\"!hasLanguage()\">\n\t\t<div class=\"component-pane\">\n\t\t\t<!-- default -->\n\t\t\t<div class=\"component-wrapper\" [class.show]=\"_isSelectedLanguageByIndex(null)\">\n\t\t\t\t<phx-component-wrapper *ngIf=\"hasModel()\" [type]=\"getModel().tabComponentType\" [model]=\"getModel().tabComponentModel\"\n\t\t\t\t\t[handler]=\"getDefaultComponentHandler()\" [data]=\"getDefaultData()\" [dataParent]=\"this\"></phx-component-wrapper>\n\t\t\t</div>\n\t\t\t<!-- by lang -->\n\t\t\t<ng-template ngFor let-item [ngForOf]=\"_getDataLangList()\" let-i=\"index\">\n\t\t\t\t<div class=\"component-wrapper\" [class.show]=\"_isSelectedLanguageByIndex(i)\">\n\t\t\t\t\t<ng-template [ngIf]=\"item !== null && item !== undefined\">\n\t\t\t\t\t\t<phx-component-wrapper *ngIf=\"hasModel()\" [type]=\"getModel().tabComponentType\" [model]=\"getModel().tabComponentModel\"\n\t\t\t\t\t\t\t[handler]=\"getComponentHandler()\" [setting]=\"getComponentSetting(i)\" [data]=\"item\" [dataParent]=\"this\"></phx-component-wrapper>\n\t\t\t\t\t</ng-template>\n\t\t\t\t</div>\n\t\t\t</ng-template>\n\t\t</div>\n\t</div>\n\t<div class=\"wrapper right\" [class.hide]=\"!hasLanguage()\">\n\t\t<div class=\"lang-pane\">\n\t\t\t<div class=\"language-btn default data\" [class.selected]=\"isSelectedLanguage(null)\" [class.dirty]=\"_isDataDirtyByIndex(null)\"\n\t\t\t\t(click)=\"onActionBtnClicked($event, null, undefined)\">\n\t\t\t\t<div class=\"table-wrapper fluid\">\n\t\t\t\t\t<div class=\"table-cell-wrapper middle\">\n\t\t\t\t\t\tDefault\n\t\t\t\t\t</div>\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t\t<div *ngFor=\"let item of getMergedLanguageList(); let i = index\" class=\"language-btn\" [class.data]=\"_langHasDataByIndex(i)\"\n\t\t\t\t[class.dirty]=\"_isDataDirtyByIndex(i)\"\n\t\t\t\t[class.selected]=\"isSelectedLanguage(item)\" (click)=\"onActionBtnClicked($event, item, i)\">\n\t\t\t\t<div class=\"table-wrapper fluid\">\n\t\t\t\t\t<div class=\"table-cell-wrapper middle\">\n\t\t\t\t\t\t<div *ngIf=\"!_hasButtonIcon(item)\">{{item.code}}</div>\n\t\t\t\t\t\t<div *ngIf=\"_hasButtonIcon(item)\">\n\t\t\t\t\t\t\t<img src=\"{{item.iconURL}}\">\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\t<div class=\"mocking-btn\"></div>\n\t\t</div>\n\t</div>\n</div>\n`\n})\nexport class DataLangSelectorPane extends AbstractComponentDataLangSelector implements OnInit, IHasModel {\n\n  public static readonly TYPE_NAME: string = TYPE_NAME;\n\n  private LANGUAGE_FIELD_NAME: string = PhloxAppInfo.DEFAULT_LANGUAGE_FIELD_NAME;\n  private OBJECT_ID_FIELD_NAME: string = PhloxAppInfo.DEFAULT_OBJECT_ID_FIELD_NAME;\n  private model: DataLangSelectorModel;\n\n  constructor(elementRef: ElementRef, dialogService: DialogService) {\n    super(elementRef, dialogService);\n  }\n\n  public ngOnInit(): void {\n    super.ngOnInit();\n  }\n\n  private getEditor(): AbstractDataEditor {\n    if (this.data !== null && typeof this.data !== 'undefined') {\n      if (this.data.editor !== null && typeof this.data.editor !== 'undefined') {\n        return this.data.editor;\n      }\n    }\n    return null;\n  }\n\n  private getWrapDataObject(dataObject: any[]): any {\n    let editor = this.getEditor();\n    let data = {\n      editor: editor,\n      objects: dataObject\n    };\n\n    return data;\n  }\n\n  /**\n   * @param data as any\n   * @return any as one object.\n   */\n  public getDefaultData(): any {\n    let objects = null;\n\n    if (this.data !== null && typeof this.data !== 'undefined') {\n      objects = this.data.objects;\n    }\n\n    if (objects === null || typeof objects === 'undefined') {\n      return null;\n    }\n\n    let editor = this.getEditor();\n    let langFieldName = null;\n    if (editor !== null) {\n      langFieldName = editor.getLanguageField();\n    }\n    let oneObj = null;\n    if (Array.isArray(objects)) {\n      let moreThanOneDef: boolean = false;\n      let defObj = null;\n      for (let obj of objects) {\n        let lang = obj[langFieldName];\n        if (lang === null || typeof lang === 'undefined') {\n          if (defObj === null) {\n            defObj = obj;\n          } else {\n            moreThanOneDef = true;\n            break;\n          }\n        }\n      }\n\n      if (!moreThanOneDef && defObj !== null && typeof defObj !== 'undefined') {\n        oneObj = defObj;\n      }\n    } else {\n      if (objects[langFieldName] === null || typeof objects[langFieldName] === 'undefined') {\n        oneObj = objects;\n      }\n    }\n\n    return oneObj;\n  }\n\n  public getDataObjects(): any[] {\n    let objects = null;\n\n    if (this.data !== null && typeof this.data !== 'undefined') {\n      objects = this.data.objects;\n    }\n\n    if (objects === null || typeof objects === 'undefined') {\n      return null;\n    }\n\n    return objects;\n  }\n\n  public hasModel(): boolean {\n    if (this.model !== null && typeof this.model !== 'undefined') {\n      return true;\n    }\n    return false;\n  }\n\n  public getModel(): any {\n    return this.model;\n  }\n\n  public setModel(model: any): void {\n    this.model = model;\n  }\n\n  public getLanguageFieldName(): string {\n    let editor = this.getEditor();\n    let langFieldName = (editor === null) ? null : editor.getLanguageField();\n\n    if (langFieldName !== null && typeof langFieldName !== 'undefined') {\n      return langFieldName;\n    }\n\n    return this.LANGUAGE_FIELD_NAME;\n  }\n\n  public getObjectIdFieldName(): string {\n    let editor = this.getEditor();\n    let objIdFieldName = (editor === null) ? null : editor.getObjectIdField();\n    if (objIdFieldName !== null && typeof objIdFieldName !== 'undefined') {\n      return objIdFieldName;\n    }\n\n    return this.OBJECT_ID_FIELD_NAME;\n  }\n\n  public getInstanceDefaultData(data: any): any {\n    return this.getWrapDataObject([data]);\n  }\n\n  public getInstanceDataLanguage(data: any): any {\n    return this.getWrapDataObject([data]);\n  }\n\n  /**\n   * @param data as any\n   * @return any as object in pattern {iconURL: string, code: string, label: string}\n   */\n  public getLanguageList(): string[] {\n    let editor = this.getEditor();\n\n    let languageList: string[] = [];\n    if (editor !== null) {\n      let setting = editor.getAppSetting();\n\n      if (setting !== null && typeof setting !== 'undefined') {\n        let defaultLangs = setting.DEFAULT_DATA_LANGUAGES;\n        if (defaultLangs !== null && typeof defaultLangs !== 'undefined' && Array.isArray(defaultLangs)) {\n          for (let lang of defaultLangs) {\n            languageList.push(lang.code);\n          }\n        }\n      }\n    }\n\n    return languageList;\n  }\n\n  public loadDataLanguageList(defaultData: any): Promise<any[]> {\n    return new Promise((resolve, reject) => {\n      let editor = this.getEditor();\n      if (editor !== null) {\n        let langProm = editor.getLanguageList(defaultData);\n        if (langProm !== null && typeof langProm !== 'undefined') {\n          langProm.then((result) => {\n            let tempArray = [];\n            if (result !== null && typeof result !== 'undefined') {\n              if (Array.isArray(result)) {\n                tempArray = result;\n              } else {\n                tempArray.push(result);\n              }\n            }\n            resolve(tempArray);\n          });\n        }\n      } else {\n        resolve([]);\n      }\n    });\n  }\n\n  /**\n   * when new language was created this method will be called\n   * @param newLangData as any\n   */\n  public onLanguageAdded(newLangData: any): void {\n    if (newLangData !== null && typeof newLangData !== 'undefined') {\n      // do sth here\n    }\n    //        this.data.objects.push(newLangData);\n  }\n\n  /**\n  * when language was removed this method will be called\n  * @param deletedData as any\n  */\n  public onLanguageRemoved(deletedData: any): void {\n    // do sth\n  }\n\n  public parseLanguageButtonModel(langCode: string): LanguageButtonModel {\n    return new LanguageButtonModel('', langCode, 'label');\n  }\n}\n"]}