UNPKG

@netgrif/components-core

Version:

Netgrif Application engine frontend core Angular library

135 lines 22.7 kB
import { AbstractPanelWithHeaderBindingComponent } from './panel-with-header-binding'; import { toMoment } from '../../resources/types/nae-date-type'; import { DATE_FORMAT_STRING, DATE_TIME_FORMAT_STRING } from '../../moment/time-formats'; import { Component, Optional } from '@angular/core'; import * as i0 from "@angular/core"; import * as i1 from "@ngx-translate/core"; import * as i2 from "@angular/common"; import * as i3 from "../../header/services/overflow.service"; export class AbstractPanelWithImmediateDataComponent extends AbstractPanelWithHeaderBindingComponent { _translate; _currencyPipe; _overflowService; constructor(_translate, _currencyPipe, _overflowService) { super(_overflowService); this._translate = _translate; this._currencyPipe = _currencyPipe; this._overflowService = _overflowService; } ngOnDestroy() { super.ngOnDestroy(); } parseImmediateValue(immediate) { if (immediate && immediate.value !== undefined || immediate && immediate.type === 'button') { switch (immediate.type) { case 'date': return { value: toMoment(immediate.value).format(DATE_FORMAT_STRING), icon: 'event', type: immediate.type }; case 'dateTime': return { value: toMoment(immediate.value).format(DATE_TIME_FORMAT_STRING), icon: 'event', type: immediate.type }; case 'enumeration': return { value: this.getTranslation(immediate.value), icon: undefined, type: immediate.type }; case 'multichoice': return { value: immediate.value.map(it => this.getTranslation(it)).join(', '), icon: undefined, type: immediate.type }; case 'enumeration_map': return { value: this.getTranslation(immediate.options[immediate.value]), icon: undefined, type: immediate.type }; case 'multichoice_map': return { value: immediate.value.map(it => this.getTranslation(immediate.options[it])).join(', '), icon: undefined, type: immediate.type }; case 'file': return { value: immediate.value?.name, icon: 'insert_drive_file', type: immediate.type }; case 'fileList': return { value: immediate.value?.namesPaths.map(obj => obj.name).join(', '), icon: 'file_copy', type: immediate.type }; case 'userList': return { value: immediate.value?.userValues.map(obj => obj.fullName).join(', '), icon: 'account_circle', type: immediate.type }; case 'user': return { value: immediate.value.fullName, icon: 'account_circle', type: immediate.type }; case 'boolean': return { value: this._translate.instant('dataField.values.boolean.' + immediate.value), icon: undefined, type: immediate.type }; case 'button': let buttonValue; if (immediate.placeholder?.defaultValue !== undefined) { buttonValue = this.getTranslation(immediate.placeholder); } else if (immediate.name?.defaultValue !== undefined) { buttonValue = this.getTranslation(immediate.name); } else { buttonValue = this._translate.instant('dialog.submit'); } return { value: buttonValue, icon: undefined, type: immediate.type }; case 'filter': return { value: undefined, icon: undefined, type: immediate.type, filterMetadata: { filterMetadata: immediate.filterMetadata, allowedNets: immediate.allowedNets } }; case 'number': if (immediate.format !== undefined) { return this.formatCurrencyPipe(immediate.value, immediate.format.code, immediate.format.fractionSize, immediate.format.locale, immediate.type); } else if (immediate.component?.name === 'currency') { return this.formatCurrencyPipe(immediate.value, immediate.component.properties['code'], immediate.component.properties['fractionSize'], immediate.component.properties['locale'], immediate.type); } return { value: immediate.value, icon: undefined, type: immediate.type }; default: return { value: immediate.value, icon: undefined, type: immediate.type }; } } else { return { value: '', icon: '', type: '' }; } } getTranslation(i18n) { const locale = this._translate.currentLang; return (i18n && i18n.translations && locale in i18n.translations) ? i18n.translations[locale] : (i18n?.defaultValue ?? ''); } formatCurrencyPipe(value, code, fraction, locale, type) { return { value: this._currencyPipe.transform(parseFloat(value), code, 'symbol', '1.' + fraction + '-' + fraction, locale), icon: undefined, type }; } static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AbstractPanelWithImmediateDataComponent, deps: [{ token: i1.TranslateService }, { token: i2.CurrencyPipe }, { token: i3.OverflowService, optional: true }], target: i0.ɵɵFactoryTarget.Component }); static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: AbstractPanelWithImmediateDataComponent, selector: "ncc-abstract-panel-with-immediate", usesInheritance: true, ngImport: i0, template: '', isInline: true }); } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AbstractPanelWithImmediateDataComponent, decorators: [{ type: Component, args: [{ selector: 'ncc-abstract-panel-with-immediate', template: '' }] }], ctorParameters: () => [{ type: i1.TranslateService }, { type: i2.CurrencyPipe }, { type: i3.OverflowService, decorators: [{ type: Optional }] }] }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"panel-with-immediate-data.js","sourceRoot":"","sources":["../../../../../../projects/netgrif-components-core/src/lib/panel/abstract/panel-with-immediate-data.ts"],"names":[],"mappings":"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","sourcesContent":["import {AbstractPanelWithHeaderBindingComponent} from './panel-with-header-binding';\nimport {NaeDate, toMoment} from '../../resources/types/nae-date-type';\nimport {DATE_FORMAT_STRING, DATE_TIME_FORMAT_STRING} from '../../moment/time-formats';\nimport {TranslateService} from '@ngx-translate/core';\nimport {Component, OnDestroy, Optional} from '@angular/core';\nimport {FeaturedValue} from './featured-value';\nimport {CurrencyPipe} from '@angular/common';\nimport {ImmediateData} from '../../resources/interface/immediate-data';\nimport {OverflowService} from '../../header/services/overflow.service';\nimport {I18nFieldValue} from \"../../data-fields/i18n-field/models/i18n-field-value\";\n\n@Component({\n    selector: 'ncc-abstract-panel-with-immediate',\n    template: ''\n})\nexport abstract class AbstractPanelWithImmediateDataComponent extends AbstractPanelWithHeaderBindingComponent implements OnDestroy {\n    protected constructor(protected _translate: TranslateService,\n                          protected _currencyPipe: CurrencyPipe,\n                          @Optional() protected _overflowService: OverflowService) {\n        super(_overflowService);\n    }\n\n    ngOnDestroy(): void {\n        super.ngOnDestroy();\n    }\n\n    protected parseImmediateValue(immediate: ImmediateData): FeaturedValue {\n        if (immediate && immediate.value !== undefined || immediate && immediate.type === 'button') {\n            switch (immediate.type) {\n                case 'date':\n                    return {\n                        value: toMoment(immediate.value as NaeDate).format(DATE_FORMAT_STRING),\n                        icon: 'event',\n                        type: immediate.type\n                    };\n                case 'dateTime':\n                    return {\n                        value: toMoment(immediate.value as NaeDate).format(DATE_TIME_FORMAT_STRING),\n                        icon: 'event',\n                        type: immediate.type\n                    };\n                case 'enumeration':\n                    return {value: this.getTranslation(immediate.value), icon: undefined, type: immediate.type};\n                case 'multichoice':\n                    return {\n                        value: immediate.value.map(it => this.getTranslation(it)).join(', '),\n                        icon: undefined,\n                        type: immediate.type\n                    };\n                case 'enumeration_map':\n                    return {\n                        value: this.getTranslation(immediate.options[immediate.value]),\n                        icon: undefined,\n                        type: immediate.type\n                    };\n                case 'multichoice_map':\n                    return {\n                        value: immediate.value.map(it =>\n                            this.getTranslation(immediate.options[it])).join(', '),\n                        icon: undefined,\n                        type: immediate.type\n                    };\n                case 'file':\n                    return {value: immediate.value?.name, icon: 'insert_drive_file', type: immediate.type};\n                case 'fileList':\n                    return {\n                        value: immediate.value?.namesPaths.map(obj => obj.name).join(', '),\n                        icon: 'file_copy',\n                        type: immediate.type\n                    };\n                case 'userList':\n                    return {value: immediate.value?.userValues.map(obj => obj.fullName).join(', '), icon: 'account_circle', type: immediate.type};\n                case 'user':\n                    return {value: immediate.value.fullName, icon: 'account_circle', type: immediate.type};\n                case 'boolean':\n                    return {\n                        value: this._translate.instant('dataField.values.boolean.' + immediate.value),\n                        icon: undefined, type: immediate.type\n                    };\n                case 'button':\n                    let buttonValue: string;\n                    if ((immediate as any).placeholder?.defaultValue !== undefined) {\n                        buttonValue = this.getTranslation((immediate as any).placeholder);\n                    } else if (immediate.name?.defaultValue !== undefined) {\n                        buttonValue = this.getTranslation(immediate.name);\n                    } else {\n                        buttonValue = this._translate.instant('dialog.submit');\n                    }\n                    return {\n                        value: buttonValue,\n                        icon: undefined,\n                        type: immediate.type\n                    };\n                case 'filter':\n                    return {\n                        value: undefined, icon: undefined, type: immediate.type,\n                        filterMetadata: {filterMetadata: immediate.filterMetadata, allowedNets: immediate.allowedNets}\n                    };\n                case 'number':\n                    if (immediate.format !== undefined) {\n                        return this.formatCurrencyPipe(immediate.value, immediate.format.code, immediate.format.fractionSize,\n                            immediate.format.locale, immediate.type);\n                    } else if (immediate.component?.name === 'currency') {\n                        return this.formatCurrencyPipe(immediate.value, immediate.component.properties['code'],\n                            immediate.component.properties['fractionSize'], immediate.component.properties['locale'], immediate.type);\n                    }\n                    return {value: immediate.value, icon: undefined, type: immediate.type};\n                default:\n                    return {value: immediate.value, icon: undefined, type: immediate.type};\n            }\n        } else {\n            return {value: '', icon: '', type: ''};\n        }\n    }\n\n    protected getTranslation(i18n: I18nFieldValue | undefined): string {\n        const locale = this._translate.currentLang;\n        return (i18n && i18n.translations && locale in i18n.translations)\n            ? i18n.translations[locale]\n            : (i18n?.defaultValue ?? '');\n    }\n\n    protected formatCurrencyPipe(value: any, code: string, fraction: number, locale: string, type: string) {\n        return {\n            value:\n                this._currencyPipe.transform(\n                    parseFloat(value),\n                    code,\n                    'symbol',\n                    '1.' + fraction + '-' + fraction,\n                    locale),\n            icon: undefined, type\n        };\n    }\n}\n"]}