UNPKG

@netgrif/components-core

Version:

Netgrif Application engine frontend core Angular library

157 lines 22.5 kB
import { Component, Inject, Optional } from '@angular/core'; import { DEFAULT_LANGUAGE_CODE, I18nField } from '../models/i18n-field'; import { AbstractI18nErrorsComponent } from '../abstract-i18n-errors.component'; import { DATA_FIELD_PORTAL_DATA } from "../../models/data-field-portal-data-injection-token"; import * as i0 from "@angular/core"; import * as i1 from "../language-icons.service"; import * as i2 from "@ngx-translate/core"; import * as i3 from "@angular/platform-browser"; export class AbstractI18nTextFieldComponent extends AbstractI18nErrorsComponent { languageIconsService; _translateService; _domSanitizer; fieldValueChangesSubscription; fieldUpdateSubscription; languageKeys; initializedLanguage = false; selectedLanguage; filledShown = false; labelWidth; cutProperty; currentValue = {}; filledKeys; constructor(languageIconsService, _translateService, _domSanitizer, dataFieldPortalData) { super(languageIconsService, _translateService, dataFieldPortalData); this.languageIconsService = languageIconsService; this._translateService = _translateService; this._domSanitizer = _domSanitizer; this.selectedLanguage = this._translateService.currentLang; this.languageKeys = Object.keys(this.languageIconsService.languageIcons); } ngOnInit() { this.currentValue = I18nField.toObject(this.dataField.value); this.fieldUpdateSubscription = this.dataField.updated.subscribe(() => { this.refreshCurrentValue(); }); this.fieldValueChangesSubscription = this.dataField.valueChanges().subscribe(newValue => { this.refreshCurrentValue(newValue); }); } ngOnDestroy() { this.fieldUpdateSubscription.unsubscribe(); this.fieldValueChangesSubscription.unsubscribe(); } refreshCurrentValue(newValue = this.dataField.value) { if (this.dataField.disabled) { this.selectedLanguage = this._translateService.currentLang; this.filledShown = false; this.initializedLanguage = false; return; } if (!this.initializedLanguage) { if (!(this.selectedLanguage in newValue.translations)) { this.selectedLanguage = DEFAULT_LANGUAGE_CODE; } this.initializedLanguage = true; } this.currentValue = I18nField.toObject(newValue); this.refreshFilledMap(); } getLanguageIcons() { return this.languageIconsService.languageIcons; } isDefaultValue(chosenLanguage) { return chosenLanguage === DEFAULT_LANGUAGE_CODE; } selectLanguage(newLanguage) { this.selectedLanguage = newLanguage; this.refreshFilledMap(); } setSelectedValue() { if (!this.isDefaultValue(this.selectedLanguage) && this.currentValue[this.selectedLanguage] === '') { delete this.currentValue[this.selectedLanguage]; } this.dataField.value = I18nField.fromObject(this.currentValue, this.dataField.value?.key ?? DEFAULT_LANGUAGE_CODE); this.formControlRef.markAsTouched(); } refreshFilledMap() { this.filledKeys = []; for (const k in this.currentValue) { if (this.selectedLanguage === k) { continue; } this.filledKeys.push(k); } this.filledKeys.sort((a, b) => { return this.languageKeys.indexOf(a) - this.languageKeys.indexOf(b); }); } removeTranslation(key) { delete this.currentValue[key]; this.dataField.value = I18nField.fromObject(this.currentValue, this.dataField.value?.key ?? DEFAULT_LANGUAGE_CODE); this.formControlRef.markAsTouched(); this.refreshFilledMap(); } toggleFilled() { this.filledShown = !this.filledShown; } getCutProperty(i18nLabel) { if (this.labelWidth !== i18nLabel.offsetWidth) { this.labelWidth = i18nLabel.offsetWidth; const calculatedWidth = 'calc(0.5em + ' + i18nLabel.offsetWidth / 4 * 3 + 'px)'; this.cutProperty = `polygon(0 0, 0 100%, 100% 100%, 100% 0%, ${calculatedWidth} 0, ${calculatedWidth} 6%, 0.5em 6%, 0.5em 0)`; } return this.cutProperty; } hasHint() { return this.dataField.description !== undefined && this.dataField.description !== ''; } getTranslation() { const locale = this._translateService.currentLang; return locale in this.dataField.value.translations ? this.dataField.value.translations[locale] : this.dataField.value.defaultValue; } getDefaultLanguageCode() { return DEFAULT_LANGUAGE_CODE; } isPlainText() { if (this.checkPropertyInComponent('plainText')) { return this.dataField.component.properties.plainText === 'true'; } } isBoldText() { if (this.textPropertyEnabled('boldText')) { return this.dataField.component.properties.boldText === 'true'; } } getTextColor() { if (this.checkPropertyInComponent('textColor')) { return this.dataField.component.properties.textColor; } } getTextFontSize() { if (this.checkPropertyInComponent('fontSize')) { return this.dataField.component.properties.fontSize + 'px'; } } textPropertyEnabled(property) { return !!this.dataField?.component?.properties && property in this.dataField.component.properties; } static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AbstractI18nTextFieldComponent, deps: [{ token: i1.LanguageIconsService }, { token: i2.TranslateService }, { token: i3.DomSanitizer }, { token: DATA_FIELD_PORTAL_DATA, optional: true }], target: i0.ɵɵFactoryTarget.Component }); static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: AbstractI18nTextFieldComponent, selector: "ncc-abstract-i18n-text-field", usesInheritance: true, ngImport: i0, template: '', isInline: true }); } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AbstractI18nTextFieldComponent, decorators: [{ type: Component, args: [{ selector: 'ncc-abstract-i18n-text-field', template: '' }] }], ctorParameters: () => [{ type: i1.LanguageIconsService }, { type: i2.TranslateService }, { type: i3.DomSanitizer }, { type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [DATA_FIELD_PORTAL_DATA] }] }] }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstract-i18n-text-field.component.js","sourceRoot":"","sources":["../../../../../../../projects/netgrif-components-core/src/lib/data-fields/i18n-field/i18n-text-field/abstract-i18n-text-field.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, Inject, OnDestroy, OnInit, Optional} from '@angular/core';\nimport {DEFAULT_LANGUAGE_CODE, I18nField} from '../models/i18n-field';\nimport {TranslateService} from '@ngx-translate/core';\nimport {DomSanitizer} from '@angular/platform-browser';\nimport {LanguageIconsService} from '../language-icons.service';\nimport {Subscription} from 'rxjs';\nimport {AbstractI18nErrorsComponent} from '../abstract-i18n-errors.component';\nimport {LanguageIcons} from '../models/language-icons';\nimport {I18nFieldTranslations} from '../models/i18n-field-value';\nimport {DATA_FIELD_PORTAL_DATA, DataFieldPortalData} from \"../../models/data-field-portal-data-injection-token\";\n\n@Component({\n    selector: 'ncc-abstract-i18n-text-field',\n    template: ''\n})\nexport abstract class AbstractI18nTextFieldComponent extends AbstractI18nErrorsComponent implements OnInit, OnDestroy {\n\n    private fieldValueChangesSubscription: Subscription;\n    private fieldUpdateSubscription: Subscription;\n\n    public languageKeys: Array<string>;\n\n    protected initializedLanguage = false;\n\n    public selectedLanguage: string;\n    public filledShown = false;\n\n    private labelWidth: number;\n    public cutProperty: string;\n\n    public currentValue: I18nFieldTranslations = {};\n    public filledKeys: Array<string>;\n\n    protected constructor(protected languageIconsService: LanguageIconsService,\n                          protected _translateService: TranslateService,\n                          protected _domSanitizer: DomSanitizer,\n                          @Optional() @Inject(DATA_FIELD_PORTAL_DATA) dataFieldPortalData: DataFieldPortalData<I18nField>) {\n        super(languageIconsService, _translateService, dataFieldPortalData);\n        this.selectedLanguage = this._translateService.currentLang;\n        this.languageKeys = Object.keys(this.languageIconsService.languageIcons);\n    }\n\n    ngOnInit(): void {\n        this.currentValue = I18nField.toObject(this.dataField.value);\n        this.fieldUpdateSubscription = this.dataField.updated.subscribe(() => {\n            this.refreshCurrentValue();\n        });\n        this.fieldValueChangesSubscription = this.dataField.valueChanges().subscribe(newValue => {\n            this.refreshCurrentValue(newValue);\n        });\n    }\n\n    ngOnDestroy(): void {\n        this.fieldUpdateSubscription.unsubscribe();\n        this.fieldValueChangesSubscription.unsubscribe();\n    }\n\n    protected refreshCurrentValue(newValue = this.dataField.value): void {\n        if (this.dataField.disabled) {\n            this.selectedLanguage = this._translateService.currentLang;\n            this.filledShown = false;\n            this.initializedLanguage = false;\n            return;\n        }\n        if (!this.initializedLanguage) {\n            if (!(this.selectedLanguage in newValue.translations)) {\n                this.selectedLanguage = DEFAULT_LANGUAGE_CODE;\n            }\n            this.initializedLanguage = true;\n        }\n        this.currentValue = I18nField.toObject(newValue);\n        this.refreshFilledMap();\n    }\n\n    public getLanguageIcons(): LanguageIcons {\n        return this.languageIconsService.languageIcons;\n    }\n\n    public isDefaultValue(chosenLanguage: string): boolean {\n        return chosenLanguage === DEFAULT_LANGUAGE_CODE;\n    }\n\n    public selectLanguage(newLanguage: string): void {\n        this.selectedLanguage = newLanguage;\n        this.refreshFilledMap();\n    }\n\n    public setSelectedValue(): void {\n        if (!this.isDefaultValue(this.selectedLanguage) && this.currentValue[this.selectedLanguage] === '') {\n            delete this.currentValue[this.selectedLanguage];\n        }\n        this.dataField.value = I18nField.fromObject(this.currentValue, this.dataField.value?.key ?? DEFAULT_LANGUAGE_CODE);\n        this.formControlRef.markAsTouched();\n    }\n\n    public refreshFilledMap(): void {\n        this.filledKeys = [];\n        for (const k in this.currentValue) {\n            if (this.selectedLanguage === k) {\n                continue;\n            }\n            this.filledKeys.push(k);\n        }\n        this.filledKeys.sort((a, b) => {\n            return this.languageKeys.indexOf(a) - this.languageKeys.indexOf(b);\n        });\n    }\n\n    public removeTranslation(key: string): void {\n        delete this.currentValue[key];\n        this.dataField.value = I18nField.fromObject(this.currentValue, this.dataField.value?.key ?? DEFAULT_LANGUAGE_CODE);\n        this.formControlRef.markAsTouched();\n        this.refreshFilledMap();\n    }\n\n    public toggleFilled(): void {\n        this.filledShown = !this.filledShown;\n    }\n\n    public getCutProperty(i18nLabel): string {\n        if (this.labelWidth !== i18nLabel.offsetWidth) {\n            this.labelWidth = i18nLabel.offsetWidth;\n            const calculatedWidth = 'calc(0.5em + ' + i18nLabel.offsetWidth / 4 * 3 + 'px)';\n            this.cutProperty = `polygon(0 0, 0 100%, 100% 100%, 100% 0%, ${calculatedWidth} 0, ${calculatedWidth} 6%, 0.5em 6%, 0.5em 0)`;\n        }\n        return this.cutProperty;\n    }\n\n    public hasHint(): boolean {\n        return this.dataField.description !== undefined && this.dataField.description !== '';\n    }\n\n\n    public getTranslation(): string {\n        const locale = this._translateService.currentLang;\n        return locale in this.dataField.value.translations\n            ? this.dataField.value.translations[locale]\n            : this.dataField.value.defaultValue;\n    }\n\n    public getDefaultLanguageCode(): string {\n        return DEFAULT_LANGUAGE_CODE;\n    }\n\n    public isPlainText(): boolean {\n        if (this.checkPropertyInComponent('plainText')) {\n            return this.dataField.component.properties.plainText === 'true';\n        }\n    }\n\n    public isBoldText(): boolean {\n        if (this.textPropertyEnabled('boldText')) {\n            return this.dataField.component.properties.boldText === 'true';\n        }\n    }\n\n    public getTextColor(): string {\n        if (this.checkPropertyInComponent('textColor')) {\n            return this.dataField.component.properties.textColor;\n        }\n    }\n\n    public getTextFontSize(): string {\n        if (this.checkPropertyInComponent('fontSize')) {\n            return this.dataField.component.properties.fontSize + 'px';\n        }\n    }\n\n    public textPropertyEnabled(property: string): boolean {\n        return !!this.dataField?.component?.properties\n            && property in this.dataField.component.properties;\n    }\n}\n"]}