@cause-911/devextreme
Version:
Run `npm install @cause-911/devextreme --save` to add this library to your project
195 lines • 15.5 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Component, EventEmitter, Input, Output } from '@angular/core';
import { TranslateService, CoreService } from '@cause-911/core';
export class CauseTextBoxMultipleLangueComponent {
/**
* @param {?} coreService
* @param {?} translate
*/
constructor(coreService, translate) {
this.translate = translate;
this.valueChange = new EventEmitter();
this.isValid = true;
this.isValidLang = {};
this.tabs = [];
this.selectedIndex = 0;
this.values = [];
this.validation = {
isRequired: false
};
this.config = coreService.getConfig();
}
/**
* @return {?}
*/
get isRequired() {
return this.validation.isRequired;
}
/**
* @param {?} value
* @return {?}
*/
set isRequired(value) {
this.validation.isRequired = value;
this.validate();
}
/**
* @return {?}
*/
get value() {
return this.values;
}
/**
* @param {?} value
* @return {?}
*/
set value(value) {
if (typeof (value) === 'string' || typeof (value) === 'undefined') {
for (const i of this.config.languages) {
/** @type {?} */
const valueLang = {};
valueLang['languageCode'] = i;
valueLang[this.localizationField] = value || '';
this.values.push(valueLang);
}
}
else if (typeof (value) === 'object') {
this.values = value;
}
}
/**
* @return {?}
*/
ngOnInit() {
this.translate.get(this.config.languages).subscribe((/**
* @param {?} labels
* @return {?}
*/
labels => {
for (const i in labels) {
if (labels[i]) {
this.isValidLang[i] = true;
this.tabs.push({
languageCode: i,
text: labels[i],
});
}
}
}));
}
/**
* @param {?} languageCode
* @return {?}
*/
getLocalizationIndex(languageCode) {
/** @type {?} */
const index = this.values.findIndex((/**
* @param {?} l
* @return {?}
*/
l => l.languageCode === languageCode));
if (index === -1) {
/** @type {?} */
const value = {};
value['languageCode'] = languageCode;
value[this.localizationField] = '';
this.values.push(value);
return this.values.length - 1;
}
return index;
}
/**
* @return {?}
*/
validate() {
/** @type {?} */
let isValid = true;
this.config.languages.forEach((/**
* @param {?} lang
* @return {?}
*/
lang => {
/** @type {?} */
const index = this.values.findIndex((/**
* @param {?} l
* @return {?}
*/
l => l.languageCode === lang));
if (this.validation.isRequired && (index === -1 || !this.values[index][this.localizationField])) {
isValid = false;
this.isValidLang[lang] = false;
}
else {
this.isValidLang[lang] = true;
}
}));
this.isValid = isValid;
}
/**
* @param {?} e
* @return {?}
*/
onTagChanged(e) {
this.validate();
}
/**
* @return {?}
*/
onValueChanged() {
this.validate();
this.valueChange.emit(this.values);
}
}
CauseTextBoxMultipleLangueComponent.decorators = [
{ type: Component, args: [{
selector: 'cause-dx-text-box-multiple-langue',
template: "<dx-tab-panel\n [dataSource]=\"tabs\"\n [selectedIndex]=\"selectedIndex\"\n (onSelectionChanged)=\"onTagChanged($event)\">\n <div *dxTemplate=\"let lang of 'title'\">\n <span [class]=\"isValidLang[lang.languageCode] ? '' : 'text-error'\">{{lang.text}}</span>\n <span *ngIf=\"!isValidLang[lang.languageCode]\" class=\"icon-error\">\n <i class=\"dx-icon-info\"></i>\n </span>\n </div>\n <div *dxTemplate=\"let lang of 'item'\">\n <div *ngIf=\"localizationField\">\n <dx-text-box\n [placeholder]=\"lang.text\"\n [(value)]=\"value[getLocalizationIndex(lang.languageCode)][localizationField]\"\n valueChangeEvent=\"keyup\"\n (onValueChanged)=\"onValueChanged()\">\n </dx-text-box>\n </div>\n <div *ngIf=\"!localizationField\">\n <dx-text-box\n [placeholder]=\"lang.text\"\n [(value)]=\"value[lang.languageCode]\"\n valueChangeEvent=\"keyup\"\n (onValueChanged)=\"onValueChanged()\">\n </dx-text-box>\n </div>\n </div>\n</dx-tab-panel>\n",
styles: [".text-error{color:#d9534f}.icon-error{color:#fff;border-radius:50%;margin-left:.5em;background-color:#d9534f}"]
}] }
];
/** @nocollapse */
CauseTextBoxMultipleLangueComponent.ctorParameters = () => [
{ type: CoreService },
{ type: TranslateService }
];
CauseTextBoxMultipleLangueComponent.propDecorators = {
valueChange: [{ type: Output }],
localizationField: [{ type: Input }],
isRequired: [{ type: Input, args: ['isRequired',] }],
value: [{ type: Input, args: ['value',] }]
};
if (false) {
/** @type {?} */
CauseTextBoxMultipleLangueComponent.prototype.valueChange;
/** @type {?} */
CauseTextBoxMultipleLangueComponent.prototype.localizationField;
/** @type {?} */
CauseTextBoxMultipleLangueComponent.prototype.isValid;
/** @type {?} */
CauseTextBoxMultipleLangueComponent.prototype.isValidLang;
/** @type {?} */
CauseTextBoxMultipleLangueComponent.prototype.config;
/** @type {?} */
CauseTextBoxMultipleLangueComponent.prototype.tabs;
/** @type {?} */
CauseTextBoxMultipleLangueComponent.prototype.selectedIndex;
/**
* @type {?}
* @private
*/
CauseTextBoxMultipleLangueComponent.prototype.values;
/**
* @type {?}
* @private
*/
CauseTextBoxMultipleLangueComponent.prototype.validation;
/**
* @type {?}
* @private
*/
CauseTextBoxMultipleLangueComponent.prototype.translate;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cause-text-box-multiple-langue.component.js","sourceRoot":"ng://@cause-911/devextreme/","sources":["lib/cause-text-box-multiple-langue/cause-text-box-multiple-langue.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, Input, OnInit, Output} from '@angular/core';\nimport {TranslateService, Configuration, CoreService} from '@cause-911/core';\n\n@Component({\n    selector: 'cause-dx-text-box-multiple-langue',\n    templateUrl: './cause-text-box-multiple-langue.component.html',\n    styleUrls: ['./cause-text-box-multiple-langue.component.scss']\n})\nexport class CauseTextBoxMultipleLangueComponent implements OnInit {\n    @Output() valueChange = new EventEmitter();\n    @Input() localizationField: string;\n    @Input('isRequired')\n    get isRequired(): boolean {\n        return this.validation.isRequired;\n    }\n    set isRequired(value: boolean) {\n        this.validation.isRequired = value;\n        this.validate();\n    }\n\n    @Input('value')\n    get value(): {} {\n        return this.values;\n    }\n    set value(value: {}) {\n        if (typeof(value) === 'string' || typeof(value) === 'undefined') {\n            for (const i of this.config.languages) {\n                const valueLang = {};\n                valueLang['languageCode'] = i;\n                valueLang[this.localizationField] = value || '';\n\n                this.values.push(valueLang);\n            }\n        } else if (typeof(value) === 'object') {\n            this.values = value;\n        }\n    }\n\n    isValid = true;\n    isValidLang: any = {};\n    config: Configuration;\n    tabs: {\n        languageCode: string,\n        text: string,\n    }[] = [];\n    selectedIndex = 0;\n\n    private values: any = [];\n    private validation = {\n        isRequired: false\n    };\n\n    constructor(\n        coreService: CoreService,\n        private translate: TranslateService,\n    ) {\n        this.config = coreService.getConfig();\n    }\n\n    ngOnInit() {\n        this.translate.get(this.config.languages).subscribe(labels => {\n            for (const i in labels) {\n                if (labels[i]) {\n                    this.isValidLang[i] = true;\n                    this.tabs.push({\n                        languageCode: i,\n                        text: labels[i],\n                    });\n                }\n            }\n        });\n    }\n\n    getLocalizationIndex(languageCode: string) {\n        const index = this.values.findIndex(l => l.languageCode === languageCode);\n\n        if (index === -1) {\n            const value = {};\n            value['languageCode'] = languageCode;\n            value[this.localizationField] = '';\n\n            this.values.push(value);\n            return this.values.length - 1;\n        }\n\n        return index;\n    }\n\n    validate() {\n        let isValid = true;\n\n        this.config.languages.forEach(lang => {\n            const index = this.values.findIndex(l => l.languageCode === lang);\n\n            if (this.validation.isRequired && (index === -1 || !this.values[index][this.localizationField])) {\n                isValid = false;\n                this.isValidLang[lang] = false;\n            } else {\n                this.isValidLang[lang] = true;\n            }\n        });\n\n        this.isValid = isValid;\n    }\n\n    onTagChanged(e) {\n        this.validate();\n    }\n\n    onValueChanged() {\n        this.validate();\n        this.valueChange.emit(this.values);\n    }\n}\n"]}