@netgrif/components-core
Version:
Netgrif Application engine frontend core Angular library
75 lines • 13 kB
JavaScript
import { Component, Inject, Optional } from '@angular/core';
import { getCurrencySymbol } from '@angular/common';
import { AbstractNumberErrorsComponent } from '../abstract-number-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 "@angular/common";
import * as i2 from "@ngx-translate/core";
export class AbstractCurrencyNumberFieldComponent extends AbstractNumberErrorsComponent {
_currencyPipe;
transformedValue;
fieldType;
NUMBER_TYPE = 'number';
TEXT_TYPE = 'text';
WHITESPACE = ' ';
constructor(_currencyPipe, translateService, dataFieldPortalData) {
super(translateService, dataFieldPortalData);
this._currencyPipe = _currencyPipe;
}
ngAfterViewInit() {
setTimeout(() => {
this.fieldType = this.TEXT_TYPE;
this.transformedValue = this.transformCurrency(this.dataField.value?.toString());
this.dataField.valueChanges().subscribe(value => {
if (value !== undefined && value !== null) {
if (this.fieldType === this.TEXT_TYPE) {
this.transformedValue = this.transformCurrency(value.toString()) + this.WHITESPACE;
}
}
else {
this.transformedValue = '';
}
});
});
}
transformToText(event) {
const target = event.target;
this.fieldType = this.TEXT_TYPE;
this.transformedValue = this.transformCurrency(target.value);
}
transformToNumber() {
this.fieldType = this.NUMBER_TYPE;
this.transformedValue = !!this.dataField.value ? this.dataField.value.toString() : '0';
}
getCurrencySymbol() {
if (this.dataField._formatFilter === undefined) {
return getCurrencySymbol(this.dataField.component.properties['code'], 'wide', this.dataField.component.properties['locale']);
}
return getCurrencySymbol(this.dataField._formatFilter.code, 'wide', this.dataField._formatFilter.locale);
}
isNumberType() {
return this.fieldType === this.NUMBER_TYPE;
}
transformCurrency(value) {
value = !!value ? value : '0';
if (this.dataField._formatFilter === undefined) {
return this._currencyPipe.transform(parseFloat(value), this.dataField.component.properties['code'], 'symbol', '1.' + this.dataField.component.properties['fractionSize'] + '-' + this.dataField.component.properties['fractionSize'], this.dataField.component.properties['locale']);
}
return this._currencyPipe.transform(parseFloat(value), this.dataField._formatFilter.code, 'symbol', '1.' + this.dataField._formatFilter.fractionSize + '-' + this.dataField._formatFilter.fractionSize, this.dataField._formatFilter.locale);
}
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AbstractCurrencyNumberFieldComponent, deps: [{ token: i1.CurrencyPipe }, { token: i2.TranslateService }, { token: DATA_FIELD_PORTAL_DATA, optional: true }], target: i0.ɵɵFactoryTarget.Component });
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: AbstractCurrencyNumberFieldComponent, selector: "ncc-abstract-currency-field", usesInheritance: true, ngImport: i0, template: '', isInline: true });
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AbstractCurrencyNumberFieldComponent, decorators: [{
type: Component,
args: [{
selector: 'ncc-abstract-currency-field',
template: ''
}]
}], ctorParameters: () => [{ type: i1.CurrencyPipe }, { type: i2.TranslateService }, { type: undefined, decorators: [{
type: Optional
}, {
type: Inject,
args: [DATA_FIELD_PORTAL_DATA]
}] }] });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstract-currency-number-field.component.js","sourceRoot":"","sources":["../../../../../../../projects/netgrif-components-core/src/lib/data-fields/number-field/currency-number-field/abstract-currency-number-field.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {AfterViewInit, Component, Inject, Optional} from '@angular/core';\nimport {TranslateService} from '@ngx-translate/core';\nimport {CurrencyPipe, getCurrencySymbol} from '@angular/common';\nimport {AbstractNumberErrorsComponent} from '../abstract-number-errors.component';\nimport {DATA_FIELD_PORTAL_DATA, DataFieldPortalData} from \"../../models/data-field-portal-data-injection-token\";\nimport {NumberField} from \"../models/number-field\";\n\n@Component({\n    selector: 'ncc-abstract-currency-field',\n    template: ''\n})\nexport abstract class AbstractCurrencyNumberFieldComponent extends AbstractNumberErrorsComponent implements AfterViewInit {\n\n    transformedValue: string;\n    fieldType: string;\n    public readonly NUMBER_TYPE = 'number';\n    public readonly TEXT_TYPE = 'text';\n    public readonly WHITESPACE = ' ';\n\n    protected constructor(protected _currencyPipe: CurrencyPipe, translateService: TranslateService,\n                          @Optional() @Inject(DATA_FIELD_PORTAL_DATA) dataFieldPortalData: DataFieldPortalData<NumberField>) {\n        super(translateService, dataFieldPortalData);\n    }\n\n    ngAfterViewInit() {\n        setTimeout(() => {\n            this.fieldType = this.TEXT_TYPE;\n            this.transformedValue = this.transformCurrency(this.dataField.value?.toString());\n            this.dataField.valueChanges().subscribe(value => {\n                if (value !== undefined && value !== null) {\n                    if (this.fieldType === this.TEXT_TYPE) {\n                        this.transformedValue = this.transformCurrency(value.toString()) + this.WHITESPACE;\n                    }\n                } else {\n                    this.transformedValue = '';\n                }\n            });\n        })\n    }\n\n    transformToText(event: Event) {\n        const target = (event.target as HTMLInputElement);\n        this.fieldType = this.TEXT_TYPE;\n        this.transformedValue = this.transformCurrency(target.value);\n    }\n\n    transformToNumber() {\n        this.fieldType = this.NUMBER_TYPE;\n        this.transformedValue = !!this.dataField.value ? this.dataField.value.toString() : '0';\n    }\n\n    getCurrencySymbol(): string {\n        if (this.dataField._formatFilter === undefined) {\n            return getCurrencySymbol(this.dataField.component.properties['code'],\n                'wide', this.dataField.component.properties['locale']);\n        }\n        return getCurrencySymbol(this.dataField._formatFilter.code, 'wide', this.dataField._formatFilter.locale);\n    }\n\n    isNumberType(): boolean {\n        return this.fieldType === this.NUMBER_TYPE;\n    }\n\n    private transformCurrency(value: string | undefined): string {\n        value = !!value ? value : '0';\n        if (this.dataField._formatFilter === undefined) {\n            return this._currencyPipe.transform(\n                parseFloat(value),\n                this.dataField.component.properties['code'],\n                'symbol',\n                '1.' + this.dataField.component.properties['fractionSize'] + '-' + this.dataField.component.properties['fractionSize'],\n                this.dataField.component.properties['locale']);\n        }\n        return this._currencyPipe.transform(\n            parseFloat(value),\n            this.dataField._formatFilter.code,\n            'symbol',\n            '1.' + this.dataField._formatFilter.fractionSize + '-' + this.dataField._formatFilter.fractionSize,\n            this.dataField._formatFilter.locale);\n    }\n}\n"]}