@yuuvis/client-framework 0.7.4 → 0.9.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/actions/lib/actions/delete-action/delete-action.d.ts +1 -0
- package/common/index.d.ts +1 -0
- package/common/lib/services/error-messages/error-messages.service.d.ts +7 -0
- package/common/lib/services/index.d.ts +1 -0
- package/esm2022/actions/lib/actions/delete-action/delete-action.mjs +4 -10
- package/esm2022/actions/lib/components/contextmenu/contextmenu.component.mjs +2 -2
- package/esm2022/common/index.mjs +2 -1
- package/esm2022/common/lib/directives/drag-select.directive.mjs +2 -2
- package/esm2022/common/lib/services/error-messages/error-messages.service.mjs +68 -0
- package/esm2022/common/lib/services/index.mjs +2 -0
- package/esm2022/forms/index.mjs +13 -8
- package/esm2022/forms/lib/elements/data-grid/data-grid/data-grid.component.mjs +172 -0
- package/esm2022/forms/lib/elements/data-grid/edit-table-data/edit-data.component.mjs +95 -0
- package/esm2022/forms/lib/elements/data-grid/model/data-grid.interface.mjs +9 -0
- package/esm2022/forms/lib/elements/datetime-range/datetime-range.component.mjs +32 -32
- package/esm2022/forms/lib/elements/index.mjs +11 -0
- package/esm2022/forms/lib/elements/number/number.component.mjs +3 -3
- package/esm2022/forms/lib/elements/number-range/number-range.component.mjs +3 -3
- package/esm2022/forms/lib/elements/organization/organization.component.mjs +47 -29
- package/esm2022/forms/lib/elements/range-select-date/date-range-picker/date-range-picker.component.mjs +38 -0
- package/esm2022/forms/lib/elements/range-select-date/range-select-date.component.mjs +181 -0
- package/esm2022/forms/lib/elements/range-select-date/range-select-date.interface.mjs +2 -0
- package/esm2022/forms/lib/elements/range-select-filesize/range-select-filesize.component.mjs +98 -0
- package/esm2022/forms/lib/elements/range-select-filesize/range-select-filesize.interface.mjs +2 -0
- package/esm2022/forms/lib/elements/string/string.component.mjs +10 -3
- package/esm2022/icons/lib/icons.mjs +3 -2
- package/esm2022/list/lib/list.component.mjs +6 -4
- package/esm2022/metadata-form/lib/metadata-default-templates/metadata-default-templates.component.mjs +5 -4
- package/esm2022/metadata-form/lib/metadata-form-element-registry.service.mjs +1 -1
- package/esm2022/metadata-form/lib/metadata-form-field/metadata-form-field.component.mjs +9 -52
- package/esm2022/object-details/index.mjs +2 -1
- package/esm2022/object-details/lib/object-audit/object-audit.component.mjs +3 -3
- package/esm2022/object-details/lib/object-metadata/object-metadata.component.mjs +5 -4
- package/esm2022/object-details/lib/retention-badge/retention-badge.component.mjs +27 -0
- package/esm2022/object-flavor/lib/object-flavor/object-flavor.component.mjs +2 -2
- package/esm2022/object-flavor/lib/object-flavor-picker/object-flavor-picker.component.mjs +2 -2
- package/esm2022/object-form/index.mjs +1 -1
- package/esm2022/object-form/lib/object-form.component.mjs +2 -1
- package/esm2022/object-form/lib/object-form.service.mjs +5 -2
- package/esm2022/object-summary/lib/object-summary/object-summary.component.mjs +15 -13
- package/esm2022/pagination/lib/pagination.component.mjs +4 -6
- package/esm2022/sequence-list/index.mjs +1 -3
- package/esm2022/sequence-list/lib/sequence-list.component.mjs +11 -16
- package/esm2022/sequence-list/lib/sequence-list.interface.mjs +1 -1
- package/esm2022/tile-list/lib/tile/tile.component.mjs +3 -3
- package/esm2022/tile-list/lib/tile-config/tile-config.component.mjs +2 -2
- package/esm2022/tile-list/lib/tile-extension/extensions/email.extension.mjs +1 -1
- package/fesm2022/yuuvis-client-framework-actions.mjs +4 -10
- package/fesm2022/yuuvis-client-framework-actions.mjs.map +1 -1
- package/fesm2022/yuuvis-client-framework-common.mjs +69 -4
- package/fesm2022/yuuvis-client-framework-common.mjs.map +1 -1
- package/fesm2022/yuuvis-client-framework-forms.mjs +1335 -755
- package/fesm2022/yuuvis-client-framework-forms.mjs.map +1 -1
- package/fesm2022/yuuvis-client-framework-icons.mjs +2 -1
- package/fesm2022/yuuvis-client-framework-icons.mjs.map +1 -1
- package/fesm2022/yuuvis-client-framework-list.mjs +5 -3
- package/fesm2022/yuuvis-client-framework-list.mjs.map +1 -1
- package/fesm2022/yuuvis-client-framework-metadata-form.mjs +12 -55
- package/fesm2022/yuuvis-client-framework-metadata-form.mjs.map +1 -1
- package/fesm2022/yuuvis-client-framework-object-details.mjs +28 -7
- package/fesm2022/yuuvis-client-framework-object-details.mjs.map +1 -1
- package/fesm2022/yuuvis-client-framework-object-flavor.mjs +2 -2
- package/fesm2022/yuuvis-client-framework-object-flavor.mjs.map +1 -1
- package/fesm2022/yuuvis-client-framework-object-form.mjs +5 -1
- package/fesm2022/yuuvis-client-framework-object-form.mjs.map +1 -1
- package/fesm2022/yuuvis-client-framework-object-summary.mjs +14 -12
- package/fesm2022/yuuvis-client-framework-object-summary.mjs.map +1 -1
- package/fesm2022/yuuvis-client-framework-pagination.mjs +3 -5
- package/fesm2022/yuuvis-client-framework-pagination.mjs.map +1 -1
- package/fesm2022/yuuvis-client-framework-sequence-list.mjs +17 -296
- package/fesm2022/yuuvis-client-framework-sequence-list.mjs.map +1 -1
- package/fesm2022/yuuvis-client-framework-tile-list.mjs +3 -3
- package/fesm2022/yuuvis-client-framework-tile-list.mjs.map +1 -1
- package/forms/index.d.ts +5 -7
- package/forms/lib/elements/data-grid/data-grid/data-grid.component.d.ts +38 -0
- package/forms/lib/elements/data-grid/edit-table-data/edit-data.component.d.ts +21 -0
- package/forms/lib/elements/data-grid/model/data-grid.interface.d.ts +14 -0
- package/forms/lib/elements/datetime-range/datetime-range.component.d.ts +2 -1
- package/forms/lib/elements/index.d.ts +10 -0
- package/forms/lib/elements/organization/organization.component.d.ts +13 -4
- package/forms/lib/elements/range-select-date/date-range-picker/date-range-picker.component.d.ts +13 -0
- package/forms/lib/elements/range-select-date/range-select-date.component.d.ts +33 -0
- package/forms/lib/elements/range-select-date/range-select-date.interface.d.ts +5 -0
- package/forms/lib/elements/range-select-filesize/range-select-filesize.component.d.ts +28 -0
- package/forms/lib/elements/range-select-filesize/range-select-filesize.interface.d.ts +5 -0
- package/list/lib/list.component.d.ts +2 -1
- package/metadata-form/lib/metadata-form-field/metadata-form-field.component.d.ts +1 -1
- package/object-details/index.d.ts +1 -0
- package/object-details/lib/retention-badge/retention-badge.component.d.ts +12 -0
- package/package.json +10 -10
- package/sequence-list/index.d.ts +0 -2
- package/sequence-list/lib/sequence-list.component.d.ts +2 -2
- package/sequence-list/lib/sequence-list.interface.d.ts +5 -4
- package/styles/client-framework.scss +55 -18
- package/esm2022/sequence-list/lib/sequence-list-template-manage/sequence-list-template-manage.component.mjs +0 -183
- package/esm2022/sequence-list/lib/sequence-list-templates/sequence-list-templates.component.mjs +0 -114
- package/sequence-list/lib/sequence-list-template-manage/sequence-list-template-manage.component.d.ts +0 -52
- package/sequence-list/lib/sequence-list-templates/sequence-list-templates.component.d.ts +0 -36
|
@@ -0,0 +1,95 @@
|
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
|
2
|
+
import { ChangeDetectionStrategy, Component, forwardRef, inject, input, signal } from '@angular/core';
|
|
3
|
+
import { FormBuilder, NG_VALUE_ACCESSOR, ReactiveFormsModule, Validators } from '@angular/forms';
|
|
4
|
+
import { Situation, TranslateModule } from '@yuuvis/client-core';
|
|
5
|
+
import { YvcOverlayRef } from '@yuuvis/components/overlay';
|
|
6
|
+
import { FormInputComponent } from '../../../form-input/form-input.component';
|
|
7
|
+
import { NumberComponent } from '../../number/number.component';
|
|
8
|
+
import { StringComponent } from '../../string/string.component';
|
|
9
|
+
import { ErrorMessagesService } from '@yuuvis/client-framework/common';
|
|
10
|
+
import * as i0 from "@angular/core";
|
|
11
|
+
import * as i1 from "@angular/forms";
|
|
12
|
+
import * as i2 from "@yuuvis/client-core";
|
|
13
|
+
export class EditTableDataComponent {
|
|
14
|
+
constructor() {
|
|
15
|
+
this.#oRef = inject((YvcOverlayRef));
|
|
16
|
+
this.#fb = inject(FormBuilder);
|
|
17
|
+
this.#errorMassge = inject(ErrorMessagesService);
|
|
18
|
+
this.errorMassage = signal(null);
|
|
19
|
+
this.tableForm = this.#fb.group({});
|
|
20
|
+
this.isInnerTableForm = input(true);
|
|
21
|
+
this.formElement = this.#oRef.data?.formElement || {};
|
|
22
|
+
this.#elementData = this.#oRef.data?.elementData || {};
|
|
23
|
+
this.situation = this.#oRef.data?.situation || Situation.EDIT;
|
|
24
|
+
this.header = this.#oRef.data?.label || '';
|
|
25
|
+
this.adding = this.#oRef.data?.adding;
|
|
26
|
+
}
|
|
27
|
+
#oRef;
|
|
28
|
+
#fb;
|
|
29
|
+
#errorMassge;
|
|
30
|
+
#elementData;
|
|
31
|
+
cancel() {
|
|
32
|
+
if (this.#oRef)
|
|
33
|
+
this.#oRef.close();
|
|
34
|
+
}
|
|
35
|
+
submit() {
|
|
36
|
+
if (this.tableForm.valid && this.#oRef)
|
|
37
|
+
this.#oRef.close(this.tableForm.getRawValue());
|
|
38
|
+
}
|
|
39
|
+
ngOnInit() {
|
|
40
|
+
Object.values(this.formElement['elements']).forEach((element) => {
|
|
41
|
+
return this.tableForm.addControl(element.name, this.#fb.control({ value: '', disabled: element.readonly }, element.required ? Validators.required : null));
|
|
42
|
+
});
|
|
43
|
+
this.tableForm.setValidators(this.#globalErrorValidator());
|
|
44
|
+
this.#elementData && this.tableForm.patchValue(this.#elementData);
|
|
45
|
+
this.tableForm.valueChanges.subscribe((v) => {
|
|
46
|
+
this.errorMassage.set(this.tableForm.errors
|
|
47
|
+
? Object.keys(this.tableForm.errors).map((key) => this.tableForm.errors && this.tableForm.errors[key]
|
|
48
|
+
? Object.keys(this.tableForm.errors[key]).map((k) => ({ [key]: this.#errorMassge.getErrorLabel(k, key) }))
|
|
49
|
+
: null)
|
|
50
|
+
: null);
|
|
51
|
+
});
|
|
52
|
+
}
|
|
53
|
+
#globalErrorValidator() {
|
|
54
|
+
return (control) => {
|
|
55
|
+
const formGroup = control;
|
|
56
|
+
const errors = {};
|
|
57
|
+
Object.keys(formGroup.controls).forEach((key) => {
|
|
58
|
+
const control = formGroup.get(key);
|
|
59
|
+
if (control && control.invalid && control.dirty) {
|
|
60
|
+
const controlErrors = control.errors;
|
|
61
|
+
if (controlErrors) {
|
|
62
|
+
// Ignore 'required' error if there are more errors
|
|
63
|
+
if (Object.keys(controlErrors).length > 1 && controlErrors['required']) {
|
|
64
|
+
const { required, ...otherErrors } = controlErrors;
|
|
65
|
+
errors[key] = otherErrors;
|
|
66
|
+
}
|
|
67
|
+
else {
|
|
68
|
+
errors[key] = controlErrors;
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
});
|
|
73
|
+
return Object.keys(errors).length ? errors : null;
|
|
74
|
+
};
|
|
75
|
+
}
|
|
76
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: EditTableDataComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
77
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: EditTableDataComponent, isStandalone: true, selector: "yuv-edit-table-data", inputs: { isInnerTableForm: { classPropertyName: "isInnerTableForm", publicName: "isInnerTableForm", isSignal: true, isRequired: false, transformFunction: null } }, providers: [
|
|
78
|
+
{
|
|
79
|
+
provide: NG_VALUE_ACCESSOR,
|
|
80
|
+
useExisting: forwardRef(() => EditTableDataComponent),
|
|
81
|
+
multi: true
|
|
82
|
+
}
|
|
83
|
+
], ngImport: i0, template: "<header>\n <h2>{{ 'yuv.form.element.data.grid.edit.headline' | translate: { headline: header } }}</h2>\n</header>\n\n<div [formGroup]=\"tableForm\">\n @for (element of formElement['elements']; track $index) {\n <div [attr.data-name]=\"element.name\" class=\"form-field\">\n <yuv-form-input\n [label]=\"element.label\"\n [required]=\"element.required\"\n [invalid]=\"false\"\n [disabled]=\"element.readonly\"\n [invalid]=\"!tableForm.get(element.label)?.valid && tableForm.get(element.label)?.dirty\"\n >\n @switch (element.type) {\n @case ('string') {\n <yuv-string\n [situation]=\"situation\"\n [formControlName]=\"element.name\"\n [attr.data-name]=\"element.name\"\n [multiselect]=\"element.cardinality === 'multi' || situation === 'SEARCH'\"\n [rows]=\"element.rows\"\n [classifications]=\"element.classifications\"\n [regex]=\"element.regex\"\n [readonly]=\"element.readonly\"\n [minLength]=\"element.minLength\"\n [maxLength]=\"element.maxLength\"\n >\n </yuv-string>\n }\n @case ('decimal') {\n <yuv-number\n [readonly]=\"element.readonly\"\n [precision]=\"element.precision\"\n [scale]=\"element.scale\"\n [pattern]=\"element.pattern\"\n [grouping]=\"element.grouping\"\n [minValue]=\"element.minValue\"\n [maxValue]=\"element.maxValue\"\n [formControlName]=\"element.name\"\n [attr.data-name]=\"element.name\"\n ></yuv-number>\n }\n @default {\n <input [type]=\"element.type\" [id]=\"element.name\" [name]=\"element.name\" [readonly]=\"element.readonly\" [required]=\"element.required\" />\n }\n }\n <!-- <input [type]=\"element.type\" [id]=\"element.name\" [name]=\"element.name\" [readonly]=\"element.readonly\" [required]=\"element.required\" /> -->\n </yuv-form-input>\n @let errorsGroup = errorMassage();\n @if (errorsGroup && tableForm.errors) {\n <div class=\"err-msg\">\n @for (errors of errorsGroup; track $index) {\n @for (error of errors; track $index) {\n {{ error[element.label] }}\n }\n }\n </div>\n }\n </div>\n }\n <footer>\n <button (click)=\"cancel()\">{{ 'yuv.form.element.data.grid.edit.cancel' | translate }}</button>\n <button class=\"primary\" (click)=\"submit()\" [disabled]=\"!tableForm.dirty && !tableForm.valid\">\n @if (adding) {\n {{ 'yuv.form.element.data.grid.edit.add' | translate }}\n } @else {\n {{ 'yuv.form.element.data.grid.edit' | translate }}\n }\n </button>\n </footer>\n</div>\n", styles: [":host{display:flex;flex-direction:column;padding:var(--app-pane-padding)}:host header h2{padding:0;font-weight:400;font-size:var(--font-headline);margin:0 0 var(--app-pane-padding) 0}:host .err-msg{font-size:var(--font-hint);color:var(--color-error);padding:calc(var(--app-pane-padding) / 4) 0;border:0}:host footer{display:flex;justify-content:end;gap:var(--app-pane-padding);margin-block-start:var(--app-pane-padding)}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.PatternValidator, selector: "[pattern][formControlName],[pattern][formControl],[pattern][ngModel]", inputs: ["pattern"] }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "component", type: FormInputComponent, selector: "yuv-form-input", inputs: ["label", "tag", "description", "invalid", "disabled", "required"] }, { kind: "component", type: StringComponent, selector: "yuv-string", inputs: ["multiselect", "rows", "readonly", "autofocus", "classifications", "situation", "regex", "minLength", "maxLength"] }, { kind: "component", type: NumberComponent, selector: "yuv-number", inputs: ["scale", "precision", "grouping", "groupPattern", "readonly", "minValue", "maxValue", "classifications"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
84
|
+
}
|
|
85
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: EditTableDataComponent, decorators: [{
|
|
86
|
+
type: Component,
|
|
87
|
+
args: [{ selector: 'yuv-edit-table-data', standalone: true, imports: [CommonModule, ReactiveFormsModule, FormInputComponent, StringComponent, NumberComponent, TranslateModule], changeDetection: ChangeDetectionStrategy.OnPush, providers: [
|
|
88
|
+
{
|
|
89
|
+
provide: NG_VALUE_ACCESSOR,
|
|
90
|
+
useExisting: forwardRef(() => EditTableDataComponent),
|
|
91
|
+
multi: true
|
|
92
|
+
}
|
|
93
|
+
], template: "<header>\n <h2>{{ 'yuv.form.element.data.grid.edit.headline' | translate: { headline: header } }}</h2>\n</header>\n\n<div [formGroup]=\"tableForm\">\n @for (element of formElement['elements']; track $index) {\n <div [attr.data-name]=\"element.name\" class=\"form-field\">\n <yuv-form-input\n [label]=\"element.label\"\n [required]=\"element.required\"\n [invalid]=\"false\"\n [disabled]=\"element.readonly\"\n [invalid]=\"!tableForm.get(element.label)?.valid && tableForm.get(element.label)?.dirty\"\n >\n @switch (element.type) {\n @case ('string') {\n <yuv-string\n [situation]=\"situation\"\n [formControlName]=\"element.name\"\n [attr.data-name]=\"element.name\"\n [multiselect]=\"element.cardinality === 'multi' || situation === 'SEARCH'\"\n [rows]=\"element.rows\"\n [classifications]=\"element.classifications\"\n [regex]=\"element.regex\"\n [readonly]=\"element.readonly\"\n [minLength]=\"element.minLength\"\n [maxLength]=\"element.maxLength\"\n >\n </yuv-string>\n }\n @case ('decimal') {\n <yuv-number\n [readonly]=\"element.readonly\"\n [precision]=\"element.precision\"\n [scale]=\"element.scale\"\n [pattern]=\"element.pattern\"\n [grouping]=\"element.grouping\"\n [minValue]=\"element.minValue\"\n [maxValue]=\"element.maxValue\"\n [formControlName]=\"element.name\"\n [attr.data-name]=\"element.name\"\n ></yuv-number>\n }\n @default {\n <input [type]=\"element.type\" [id]=\"element.name\" [name]=\"element.name\" [readonly]=\"element.readonly\" [required]=\"element.required\" />\n }\n }\n <!-- <input [type]=\"element.type\" [id]=\"element.name\" [name]=\"element.name\" [readonly]=\"element.readonly\" [required]=\"element.required\" /> -->\n </yuv-form-input>\n @let errorsGroup = errorMassage();\n @if (errorsGroup && tableForm.errors) {\n <div class=\"err-msg\">\n @for (errors of errorsGroup; track $index) {\n @for (error of errors; track $index) {\n {{ error[element.label] }}\n }\n }\n </div>\n }\n </div>\n }\n <footer>\n <button (click)=\"cancel()\">{{ 'yuv.form.element.data.grid.edit.cancel' | translate }}</button>\n <button class=\"primary\" (click)=\"submit()\" [disabled]=\"!tableForm.dirty && !tableForm.valid\">\n @if (adding) {\n {{ 'yuv.form.element.data.grid.edit.add' | translate }}\n } @else {\n {{ 'yuv.form.element.data.grid.edit' | translate }}\n }\n </button>\n </footer>\n</div>\n", styles: [":host{display:flex;flex-direction:column;padding:var(--app-pane-padding)}:host header h2{padding:0;font-weight:400;font-size:var(--font-headline);margin:0 0 var(--app-pane-padding) 0}:host .err-msg{font-size:var(--font-hint);color:var(--color-error);padding:calc(var(--app-pane-padding) / 4) 0;border:0}:host footer{display:flex;justify-content:end;gap:var(--app-pane-padding);margin-block-start:var(--app-pane-padding)}\n"] }]
|
|
94
|
+
}] });
|
|
95
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"edit-data.component.js","sourceRoot":"","sources":["../../../../../../../../../../libs/yuuvis/client-framework/forms/src/lib/elements/data-grid/edit-table-data/edit-data.component.ts","../../../../../../../../../../libs/yuuvis/client-framework/forms/src/lib/elements/data-grid/edit-table-data/edit-data.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { ChangeDetectionStrategy, Component, forwardRef, inject, input, OnInit, signal } from '@angular/core';\nimport { AbstractControl, FormBuilder, FormGroup, NG_VALUE_ACCESSOR, ReactiveFormsModule, ValidationErrors, Validators } from '@angular/forms';\nimport { Situation, TranslateModule } from '@yuuvis/client-core';\nimport { YvcOverlayRef } from '@yuuvis/components/overlay';\nimport { FormInputComponent } from '../../../form-input/form-input.component';\nimport { NumberComponent } from '../../number/number.component';\nimport { StringComponent } from '../../string/string.component';\nimport { ErrorMessagesService } from '@yuuvis/client-framework/common';\n\n@Component({\n  selector: 'yuv-edit-table-data',\n  standalone: true,\n  imports: [CommonModule, ReactiveFormsModule, FormInputComponent, StringComponent, NumberComponent, TranslateModule],\n  templateUrl: './edit-data.component.html',\n  styleUrl: './edit-data.component.scss',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => EditTableDataComponent),\n      multi: true\n    }\n  ]\n})\nexport class EditTableDataComponent<T = any> implements OnInit {\n  readonly #oRef = inject(YvcOverlayRef<T, { adding: boolean; formElement: { [key: string]: any }; elementData: T; situation: Situation; label: string }>);\n  readonly #fb = inject(FormBuilder);\n  readonly #errorMassge = inject(ErrorMessagesService);\n\n  errorMassage = signal<any[] | null>(null);\n  tableForm: FormGroup = this.#fb.group({});\n\n  isInnerTableForm = input(true);\n\n  formElement: { [key: string]: any } = this.#oRef.data?.formElement || {};\n  #elementData: T = this.#oRef.data?.elementData || ({} as T);\n  situation: Situation = this.#oRef.data?.situation || Situation.EDIT;\n  header = this.#oRef.data?.label || '';\n  adding = this.#oRef.data?.adding;\n\n  cancel() {\n    if (this.#oRef) this.#oRef.close();\n  }\n\n  submit() {\n    if (this.tableForm.valid && this.#oRef) this.#oRef.close(this.tableForm.getRawValue());\n  }\n\n  ngOnInit() {\n    Object.values(this.formElement['elements']).forEach((element: any) => {\n      return this.tableForm.addControl(\n        element.name,\n        this.#fb.control({ value: '', disabled: element.readonly }, element.required ? Validators.required : null)\n      );\n    });\n    this.tableForm.setValidators(this.#globalErrorValidator());\n    this.#elementData && this.tableForm.patchValue(this.#elementData);\n\n    this.tableForm.valueChanges.subscribe((v) => {\n      this.errorMassage.set(\n        this.tableForm.errors\n          ? Object.keys(this.tableForm.errors).map((key) =>\n              this.tableForm.errors && this.tableForm.errors[key]\n                ? Object.keys(this.tableForm.errors[key]).map((k) => ({ [key]: this.#errorMassge.getErrorLabel(k, key) }))\n                : null\n            )\n          : null\n      );\n    });\n  }\n\n  #globalErrorValidator() {\n    return (control: AbstractControl): ValidationErrors | null => {\n      const formGroup = control as FormGroup;\n      const errors: ValidationErrors = {};\n\n      Object.keys(formGroup.controls).forEach((key) => {\n        const control = formGroup.get(key);\n        if (control && control.invalid && control.dirty) {\n          const controlErrors = control.errors;\n          if (controlErrors) {\n            // Ignore 'required' error if there are more errors\n            if (Object.keys(controlErrors).length > 1 && controlErrors['required']) {\n              const { required, ...otherErrors } = controlErrors;\n              errors[key] = otherErrors;\n            } else {\n              errors[key] = controlErrors;\n            }\n          }\n        }\n      });\n\n      return Object.keys(errors).length ? errors : null;\n    };\n  }\n}\n","<header>\n  <h2>{{ 'yuv.form.element.data.grid.edit.headline' | translate: { headline: header } }}</h2>\n</header>\n\n<div [formGroup]=\"tableForm\">\n  @for (element of formElement['elements']; track $index) {\n    <div [attr.data-name]=\"element.name\" class=\"form-field\">\n      <yuv-form-input\n        [label]=\"element.label\"\n        [required]=\"element.required\"\n        [invalid]=\"false\"\n        [disabled]=\"element.readonly\"\n        [invalid]=\"!tableForm.get(element.label)?.valid && tableForm.get(element.label)?.dirty\"\n      >\n        @switch (element.type) {\n          @case ('string') {\n            <yuv-string\n              [situation]=\"situation\"\n              [formControlName]=\"element.name\"\n              [attr.data-name]=\"element.name\"\n              [multiselect]=\"element.cardinality === 'multi' || situation === 'SEARCH'\"\n              [rows]=\"element.rows\"\n              [classifications]=\"element.classifications\"\n              [regex]=\"element.regex\"\n              [readonly]=\"element.readonly\"\n              [minLength]=\"element.minLength\"\n              [maxLength]=\"element.maxLength\"\n            >\n            </yuv-string>\n          }\n          @case ('decimal') {\n            <yuv-number\n              [readonly]=\"element.readonly\"\n              [precision]=\"element.precision\"\n              [scale]=\"element.scale\"\n              [pattern]=\"element.pattern\"\n              [grouping]=\"element.grouping\"\n              [minValue]=\"element.minValue\"\n              [maxValue]=\"element.maxValue\"\n              [formControlName]=\"element.name\"\n              [attr.data-name]=\"element.name\"\n            ></yuv-number>\n          }\n          @default {\n            <input [type]=\"element.type\" [id]=\"element.name\" [name]=\"element.name\" [readonly]=\"element.readonly\" [required]=\"element.required\" />\n          }\n        }\n        <!-- <input [type]=\"element.type\" [id]=\"element.name\" [name]=\"element.name\" [readonly]=\"element.readonly\" [required]=\"element.required\" /> -->\n      </yuv-form-input>\n      @let errorsGroup = errorMassage();\n      @if (errorsGroup && tableForm.errors) {\n        <div class=\"err-msg\">\n          @for (errors of errorsGroup; track $index) {\n            @for (error of errors; track $index) {\n              {{ error[element.label] }}\n            }\n          }\n        </div>\n      }\n    </div>\n  }\n  <footer>\n    <button (click)=\"cancel()\">{{ 'yuv.form.element.data.grid.edit.cancel' | translate }}</button>\n    <button class=\"primary\" (click)=\"submit()\" [disabled]=\"!tableForm.dirty && !tableForm.valid\">\n      @if (adding) {\n        {{ 'yuv.form.element.data.grid.edit.add' | translate }}\n      } @else {\n        {{ 'yuv.form.element.data.grid.edit' | translate }}\n      }\n    </button>\n  </footer>\n</div>\n"]}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
export var DataGridSizeType;
|
|
2
|
+
(function (DataGridSizeType) {
|
|
3
|
+
DataGridSizeType["SMALL"] = "small";
|
|
4
|
+
DataGridSizeType["MEDIUM"] = "medium";
|
|
5
|
+
DataGridSizeType["LARGE"] = "large";
|
|
6
|
+
DataGridSizeType["XLARGE"] = "extra-large";
|
|
7
|
+
DataGridSizeType["AUTO"] = "auto";
|
|
8
|
+
})(DataGridSizeType || (DataGridSizeType = {}));
|
|
9
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YS1ncmlkLmludGVyZmFjZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMveXV1dmlzL2NsaWVudC1mcmFtZXdvcmsvZm9ybXMvc3JjL2xpYi9lbGVtZW50cy9kYXRhLWdyaWQvbW9kZWwvZGF0YS1ncmlkLmludGVyZmFjZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQU4sSUFBWSxnQkFNWDtBQU5ELFdBQVksZ0JBQWdCO0lBQzFCLG1DQUFlLENBQUE7SUFDZixxQ0FBaUIsQ0FBQTtJQUNqQixtQ0FBZSxDQUFBO0lBQ2YsMENBQXNCLENBQUE7SUFDdEIsaUNBQWEsQ0FBQTtBQUNmLENBQUMsRUFOVyxnQkFBZ0IsS0FBaEIsZ0JBQWdCLFFBTTNCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGVudW0gRGF0YUdyaWRTaXplVHlwZSB7XG4gIFNNQUxMID0gJ3NtYWxsJyxcbiAgTUVESVVNID0gJ21lZGl1bScsXG4gIExBUkdFID0gJ2xhcmdlJyxcbiAgWExBUkdFID0gJ2V4dHJhLWxhcmdlJyxcbiAgQVVUTyA9ICdhdXRvJ1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIERhdGFHcmlkU2l6ZSB7XG4gIGV4dHJhbGFyZ2U6IERhdGFHcmlkU2l6ZVR5cGUuWExBUkdFO1xuICBsYXJnZTogRGF0YUdyaWRTaXplVHlwZS5MQVJHRTtcbiAgbWVkaXVtOiBEYXRhR3JpZFNpemVUeXBlLk1FRElVTTtcbiAgc21hbGw6IERhdGFHcmlkU2l6ZVR5cGUuU01BTEw7XG4gIGF1dG86IERhdGFHcmlkU2l6ZVR5cGUuQVVUTztcbn1cbiJdfQ==
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { Component, Input, forwardRef, inject } from '@angular/core';
|
|
2
2
|
import { FormBuilder, FormsModule, NG_VALIDATORS, NG_VALUE_ACCESSOR, ReactiveFormsModule, Validators } from '@angular/forms';
|
|
3
|
-
import { Operator, OperatorLabel } from '@yuuvis/client-core';
|
|
3
|
+
import { Operator, OperatorLabel, Situation } from '@yuuvis/client-core';
|
|
4
4
|
import { YvcDropdownModule } from '@yuuvis/components/dropdown';
|
|
5
5
|
import { DatetimeComponent } from '../datetime/datetime.component';
|
|
6
6
|
import { CommonModule } from '@angular/common';
|
|
@@ -63,36 +63,34 @@ export class DatetimeRangeComponent {
|
|
|
63
63
|
const dateValueFrom = this.rangeForm.value.dateValueFrom || undefined;
|
|
64
64
|
if (dateValueFrom || dateValue) {
|
|
65
65
|
this._isValid = this.rangeForm.valid && !!dateValueFrom && !!dateValue;
|
|
66
|
-
this.value = !this._isValid
|
|
67
|
-
// {
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
:
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
};
|
|
66
|
+
this.value = !this._isValid
|
|
67
|
+
? // {
|
|
68
|
+
// operator: this.searchOption,
|
|
69
|
+
// firstValue: undefined,
|
|
70
|
+
// secondValue: undefined
|
|
71
|
+
// }
|
|
72
|
+
undefined
|
|
73
|
+
: {
|
|
74
|
+
operator: this.searchOption,
|
|
75
|
+
firstValue: dateValueFrom,
|
|
76
|
+
secondValue: dateValue
|
|
77
|
+
};
|
|
79
78
|
}
|
|
80
79
|
}
|
|
81
80
|
else {
|
|
82
81
|
this._isValid = this.rangeForm.valid;
|
|
83
|
-
this.value = !this._isValid
|
|
84
|
-
// {
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
:
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
};
|
|
82
|
+
this.value = !this._isValid
|
|
83
|
+
? // {
|
|
84
|
+
// operator: this.searchOption,
|
|
85
|
+
// firstValue: undefined,
|
|
86
|
+
// secondValue: undefined
|
|
87
|
+
// }
|
|
88
|
+
undefined
|
|
89
|
+
: {
|
|
90
|
+
operator: this.searchOption,
|
|
91
|
+
firstValue: dateValue,
|
|
92
|
+
secondValue: undefined
|
|
93
|
+
};
|
|
96
94
|
}
|
|
97
95
|
this.propagateChange(this.value);
|
|
98
96
|
}
|
|
@@ -123,13 +121,13 @@ export class DatetimeRangeComponent {
|
|
|
123
121
|
};
|
|
124
122
|
}
|
|
125
123
|
}
|
|
126
|
-
return this._isValid ? null : err;
|
|
124
|
+
return this.situation === Situation.SEARCH || this._isValid ? null : err;
|
|
127
125
|
}
|
|
128
126
|
ngOnInit() {
|
|
129
127
|
this.rangeForm.valueChanges.subscribe(() => this.onValueChange());
|
|
130
128
|
}
|
|
131
129
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DatetimeRangeComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
132
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: DatetimeRangeComponent, isStandalone: true, selector: "yuv-datetime-range", inputs: { withTime: "withTime", readonly: "readonly", operator: "operator" }, providers: [
|
|
130
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: DatetimeRangeComponent, isStandalone: true, selector: "yuv-datetime-range", inputs: { withTime: "withTime", readonly: "readonly", operator: "operator", situation: "situation" }, providers: [
|
|
133
131
|
{
|
|
134
132
|
provide: NG_VALUE_ACCESSOR,
|
|
135
133
|
useExisting: forwardRef(() => DatetimeRangeComponent),
|
|
@@ -140,7 +138,7 @@ export class DatetimeRangeComponent {
|
|
|
140
138
|
useExisting: forwardRef(() => DatetimeRangeComponent),
|
|
141
139
|
multi: true
|
|
142
140
|
}
|
|
143
|
-
], ngImport: i0, template: "<form class=\"eo-datetime-range\" [formGroup]=\"rangeForm\">\n @if (searchOption === 'gtelte') {\n <yuv-datetime [withTime]=\"withTime\" formControlName=\"dateValueFrom\"></yuv-datetime>\n }\n <yvc-dropdown\n [disableClearButton]=\"true\"\n [(ngModel)]=\"searchOption\"\n (ngModelChange)=\"onValueChange()\"\n [ngModelOptions]=\"{ standalone: true }\"\n [options]=\"availableSearchOptions\"\n ></yvc-dropdown>\n\n <yuv-datetime [withTime]=\"withTime\" formControlName=\"dateValue\"></yuv-datetime>\n</form>\n", styles: [":host form{display:flex;flex-flow:row nowrap;
|
|
141
|
+
], ngImport: i0, template: "<form class=\"eo-datetime-range\" [formGroup]=\"rangeForm\">\n @if (searchOption === 'gtelte') {\n <yuv-datetime [withTime]=\"withTime\" formControlName=\"dateValueFrom\"></yuv-datetime>\n }\n <yvc-dropdown\n [disableClearButton]=\"true\"\n [(ngModel)]=\"searchOption\"\n (ngModelChange)=\"onValueChange()\"\n [ngModelOptions]=\"{ standalone: true }\"\n [options]=\"availableSearchOptions\"\n ></yvc-dropdown>\n\n <yuv-datetime [withTime]=\"withTime\" formControlName=\"dateValue\"></yuv-datetime>\n</form>\n", styles: [":host form{display:flex;flex-flow:row nowrap;gap:3px}:host form yuv-datetime{flex:1 1 auto}:host form yvc-dropdown{--yvc-form-element-border-color: var(--text-color-hint);--yvc-form-element-focus-border-color: var(--color-accent);padding:0;min-width:auto;border-radius:2px;background-color:var(--list-item-hover-background)}:host form yvc-dropdown:hover{background-color:var(--list-item-selected-background)}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: YvcDropdownModule }, { kind: "component", type: i2.Dropdown, selector: "yvc-dropdown", inputs: ["options", "filter", "disabled", "multiple", "disableClearButton"], outputs: ["onDropdownOptionsClose"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "component", type: DatetimeComponent, selector: "yuv-datetime", inputs: ["onlyFutureDates", "readonly", "withTime"] }] }); }
|
|
144
142
|
}
|
|
145
143
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DatetimeRangeComponent, decorators: [{
|
|
146
144
|
type: Component,
|
|
@@ -155,12 +153,14 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
155
153
|
useExisting: forwardRef(() => DatetimeRangeComponent),
|
|
156
154
|
multi: true
|
|
157
155
|
}
|
|
158
|
-
], template: "<form class=\"eo-datetime-range\" [formGroup]=\"rangeForm\">\n @if (searchOption === 'gtelte') {\n <yuv-datetime [withTime]=\"withTime\" formControlName=\"dateValueFrom\"></yuv-datetime>\n }\n <yvc-dropdown\n [disableClearButton]=\"true\"\n [(ngModel)]=\"searchOption\"\n (ngModelChange)=\"onValueChange()\"\n [ngModelOptions]=\"{ standalone: true }\"\n [options]=\"availableSearchOptions\"\n ></yvc-dropdown>\n\n <yuv-datetime [withTime]=\"withTime\" formControlName=\"dateValue\"></yuv-datetime>\n</form>\n", styles: [":host form{display:flex;flex-flow:row nowrap;
|
|
156
|
+
], template: "<form class=\"eo-datetime-range\" [formGroup]=\"rangeForm\">\n @if (searchOption === 'gtelte') {\n <yuv-datetime [withTime]=\"withTime\" formControlName=\"dateValueFrom\"></yuv-datetime>\n }\n <yvc-dropdown\n [disableClearButton]=\"true\"\n [(ngModel)]=\"searchOption\"\n (ngModelChange)=\"onValueChange()\"\n [ngModelOptions]=\"{ standalone: true }\"\n [options]=\"availableSearchOptions\"\n ></yvc-dropdown>\n\n <yuv-datetime [withTime]=\"withTime\" formControlName=\"dateValue\"></yuv-datetime>\n</form>\n", styles: [":host form{display:flex;flex-flow:row nowrap;gap:3px}:host form yuv-datetime{flex:1 1 auto}:host form yvc-dropdown{--yvc-form-element-border-color: var(--text-color-hint);--yvc-form-element-focus-border-color: var(--color-accent);padding:0;min-width:auto;border-radius:2px;background-color:var(--list-item-hover-background)}:host form yvc-dropdown:hover{background-color:var(--list-item-selected-background)}\n"] }]
|
|
159
157
|
}], propDecorators: { withTime: [{
|
|
160
158
|
type: Input
|
|
161
159
|
}], readonly: [{
|
|
162
160
|
type: Input
|
|
163
161
|
}], operator: [{
|
|
164
162
|
type: Input
|
|
163
|
+
}], situation: [{
|
|
164
|
+
type: Input
|
|
165
165
|
}] } });
|
|
166
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datetime-range.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/yuuvis/client-framework/forms/src/lib/elements/datetime-range/datetime-range.component.ts","../../../../../../../../../libs/yuuvis/client-framework/forms/src/lib/elements/datetime-range/datetime-range.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit, forwardRef, inject } from '@angular/core';\nimport { ControlValueAccessor, FormBuilder, FormGroup, FormsModule, NG_VALIDATORS, NG_VALUE_ACCESSOR, ReactiveFormsModule, Validator, Validators } from '@angular/forms';\nimport { Operator, OperatorLabel, RangeValue } from '@yuuvis/client-core';\nimport { YvcDropdownModule } from '@yuuvis/components/dropdown';\nimport { DatetimeComponent } from '../datetime/datetime.component';\nimport { CommonModule } from '@angular/common';\n\n@Component({\n  selector: 'yuv-datetime-range',\n  standalone: true,\n  imports: [CommonModule,  FormsModule, YvcDropdownModule, ReactiveFormsModule, DatetimeComponent],\n  templateUrl: './datetime-range.component.html',\n  styleUrl: './datetime-range.component.scss',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => DatetimeRangeComponent),\n      multi: true\n    },\n    {\n      provide: NG_VALIDATORS,\n      useExisting: forwardRef(() => DatetimeRangeComponent),\n      multi: true\n    }\n  ]\n})\nexport class DatetimeRangeComponent implements ControlValueAccessor, Validator, OnInit {\n  private fb = inject(FormBuilder);\n\n  /**\n   * Enables setting time as well (default: false)\n   */\n  @Input() withTime = false;\n  /**\n   * Will prevent the input from being changed (default: false)\n   */\n  @Input() readonly = false;\n  @Input() operator = 'eq';\n\n  rangeForm: FormGroup = this.fb.group({\n    dateValue: [undefined, Validators.required],\n    dateValueFrom: []\n  });\n  value?: RangeValue;\n\n  private _isValid = true;\n\n  // options for search situation\n  availableSearchOptions = [\n    { label: OperatorLabel.EQUAL, value: Operator.EQUAL },\n    { label: OperatorLabel.GREATER_OR_EQUAL, value: Operator.GREATER_OR_EQUAL },\n    { label: OperatorLabel.LESS_OR_EQUAL, value: Operator.LESS_OR_EQUAL },\n    { label: OperatorLabel.INTERVAL_INCLUDE_BOTH, value: Operator.INTERVAL_INCLUDE_BOTH }\n  ];\n  // the selected search option\n  searchOption = this.availableSearchOptions[1].value;\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars, @typescript-eslint/no-empty-function\n  propagateChange = (_: any) => {};\n\n  writeValue(value: RangeValue): void {\n    if (value && (value.firstValue || value.secondValue)) {\n      const match = this.availableSearchOptions.find((o) => o.value === value.operator);\n      this.searchOption = match ? match.value : this.availableSearchOptions[0].value;\n\n      this.value = value;\n      this.rangeForm.patchValue({\n        dateValueFrom: value.secondValue && value.firstValue,\n        dateValue: value.secondValue || value.firstValue\n      });\n    } else {\n      this.searchOption = this.availableSearchOptions[0].value;\n      this.value = undefined;\n      this.rangeForm.reset();\n    }\n  }\n\n  registerOnChange(fn: any): void {\n    this.propagateChange = fn;\n  }\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars, @typescript-eslint/no-empty-function\n  registerOnTouched(fn: any): void {}\n\n  onValueChange() {\n    const dateValue = this.rangeForm.value.dateValue || undefined;\n    if (this.searchOption === Operator.INTERVAL_INCLUDE_BOTH) {\n      const dateValueFrom = this.rangeForm.value.dateValueFrom || undefined;\n\n      if (dateValueFrom || dateValue) {\n        this._isValid = this.rangeForm.valid && !!dateValueFrom && !!dateValue;\n        this.value = !this._isValid ? \n        // {\n        //   operator: this.searchOption,\n        //   firstValue: undefined,\n        //   secondValue: undefined\n        // } \n        undefined\n        : \n        {\n          operator: this.searchOption,\n          firstValue: dateValueFrom,\n          secondValue: dateValue\n        };\n      }\n    } else {\n      this._isValid = this.rangeForm.valid;\n      this.value = !this._isValid ? \n      // {\n      //   operator: this.searchOption,\n      //   firstValue: undefined,\n      //   secondValue: undefined\n      // } \n      undefined\n      : \n      {\n        operator: this.searchOption,\n        firstValue: dateValue,\n        secondValue: undefined\n      }\n    }\n\n    this.propagateChange(this.value);\n  }\n\n  validate() {\n    let err;\n    if (this.searchOption === Operator.EQUAL) {\n      err = {\n        datecontrol: {\n          valid: false\n        }\n      };\n    } else {\n      // make sure that on ranges, the first value is earlier than the last\n      if (this.searchOption === Operator.INTERVAL_INCLUDE_BOTH && this.value && this.value.firstValue && this.value.secondValue) {\n        this._isValid = new Date(this.value.firstValue as Date).getTime() < new Date(this.value.secondValue as Date).getTime();\n        err = {\n          daterangeorder: {\n            valid: false\n          }\n        };\n      } else {\n        err = {\n          daterange: {\n            valid: false\n          }\n        };\n      }\n    }\n    return this._isValid ? null : err;\n  }\n\n  ngOnInit(): void {\n    this.rangeForm.valueChanges.subscribe(() => this.onValueChange());\n  }\n}\n","<form class=\"eo-datetime-range\" [formGroup]=\"rangeForm\">\n  @if (searchOption === 'gtelte') {\n    <yuv-datetime [withTime]=\"withTime\" formControlName=\"dateValueFrom\"></yuv-datetime>\n  }\n  <yvc-dropdown\n    [disableClearButton]=\"true\"\n    [(ngModel)]=\"searchOption\"\n    (ngModelChange)=\"onValueChange()\"\n    [ngModelOptions]=\"{ standalone: true }\"\n    [options]=\"availableSearchOptions\"\n  ></yvc-dropdown>\n\n  <yuv-datetime [withTime]=\"withTime\" formControlName=\"dateValue\"></yuv-datetime>\n</form>\n"]}
|
|
166
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datetime-range.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/yuuvis/client-framework/forms/src/lib/elements/datetime-range/datetime-range.component.ts","../../../../../../../../../libs/yuuvis/client-framework/forms/src/lib/elements/datetime-range/datetime-range.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit, forwardRef, inject } from '@angular/core';\nimport {\n  ControlValueAccessor,\n  FormBuilder,\n  FormGroup,\n  FormsModule,\n  NG_VALIDATORS,\n  NG_VALUE_ACCESSOR,\n  ReactiveFormsModule,\n  Validator,\n  Validators\n} from '@angular/forms';\nimport { Operator, OperatorLabel, RangeValue, Situation } from '@yuuvis/client-core';\nimport { YvcDropdownModule } from '@yuuvis/components/dropdown';\nimport { DatetimeComponent } from '../datetime/datetime.component';\nimport { CommonModule } from '@angular/common';\n\n@Component({\n  selector: 'yuv-datetime-range',\n  standalone: true,\n  imports: [CommonModule, FormsModule, YvcDropdownModule, ReactiveFormsModule, DatetimeComponent],\n  templateUrl: './datetime-range.component.html',\n  styleUrl: './datetime-range.component.scss',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => DatetimeRangeComponent),\n      multi: true\n    },\n    {\n      provide: NG_VALIDATORS,\n      useExisting: forwardRef(() => DatetimeRangeComponent),\n      multi: true\n    }\n  ]\n})\nexport class DatetimeRangeComponent implements ControlValueAccessor, Validator, OnInit {\n  private fb = inject(FormBuilder);\n\n  /**\n   * Enables setting time as well (default: false)\n   */\n  @Input() withTime = false;\n  /**\n   * Will prevent the input from being changed (default: false)\n   */\n  @Input() readonly = false;\n  @Input() operator = 'eq';\n  @Input() situation?: string;\n\n  rangeForm: FormGroup = this.fb.group({\n    dateValue: [undefined, Validators.required],\n    dateValueFrom: []\n  });\n  value?: RangeValue;\n\n  private _isValid = true;\n\n  // options for search situation\n  availableSearchOptions = [\n    { label: OperatorLabel.EQUAL, value: Operator.EQUAL },\n    { label: OperatorLabel.GREATER_OR_EQUAL, value: Operator.GREATER_OR_EQUAL },\n    { label: OperatorLabel.LESS_OR_EQUAL, value: Operator.LESS_OR_EQUAL },\n    { label: OperatorLabel.INTERVAL_INCLUDE_BOTH, value: Operator.INTERVAL_INCLUDE_BOTH }\n  ];\n  // the selected search option\n  searchOption = this.availableSearchOptions[1].value;\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars, @typescript-eslint/no-empty-function\n  propagateChange = (_: any) => {};\n\n  writeValue(value: RangeValue): void {\n    if (value && (value.firstValue || value.secondValue)) {\n      const match = this.availableSearchOptions.find((o) => o.value === value.operator);\n      this.searchOption = match ? match.value : this.availableSearchOptions[0].value;\n\n      this.value = value;\n      this.rangeForm.patchValue({\n        dateValueFrom: value.secondValue && value.firstValue,\n        dateValue: value.secondValue || value.firstValue\n      });\n    } else {\n      this.searchOption = this.availableSearchOptions[0].value;\n      this.value = undefined;\n      this.rangeForm.reset();\n    }\n  }\n\n  registerOnChange(fn: any): void {\n    this.propagateChange = fn;\n  }\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars, @typescript-eslint/no-empty-function\n  registerOnTouched(fn: any): void {}\n\n  onValueChange() {\n    const dateValue = this.rangeForm.value.dateValue || undefined;\n    if (this.searchOption === Operator.INTERVAL_INCLUDE_BOTH) {\n      const dateValueFrom = this.rangeForm.value.dateValueFrom || undefined;\n\n      if (dateValueFrom || dateValue) {\n        this._isValid = this.rangeForm.valid && !!dateValueFrom && !!dateValue;\n        this.value = !this._isValid\n          ? // {\n            //   operator: this.searchOption,\n            //   firstValue: undefined,\n            //   secondValue: undefined\n            // }\n            undefined\n          : {\n              operator: this.searchOption,\n              firstValue: dateValueFrom,\n              secondValue: dateValue\n            };\n      }\n    } else {\n      this._isValid = this.rangeForm.valid;\n      this.value = !this._isValid\n        ? // {\n          //   operator: this.searchOption,\n          //   firstValue: undefined,\n          //   secondValue: undefined\n          // }\n          undefined\n        : {\n            operator: this.searchOption,\n            firstValue: dateValue,\n            secondValue: undefined\n          };\n    }\n\n    this.propagateChange(this.value);\n  }\n\n  validate() {\n    let err;\n    if (this.searchOption === Operator.EQUAL) {\n      err = {\n        datecontrol: {\n          valid: false\n        }\n      };\n    } else {\n      // make sure that on ranges, the first value is earlier than the last\n      if (this.searchOption === Operator.INTERVAL_INCLUDE_BOTH && this.value && this.value.firstValue && this.value.secondValue) {\n        this._isValid = new Date(this.value.firstValue as Date).getTime() < new Date(this.value.secondValue as Date).getTime();\n        err = {\n          daterangeorder: {\n            valid: false\n          }\n        };\n      } else {\n        err = {\n          daterange: {\n            valid: false\n          }\n        };\n      }\n    }\n    return this.situation === Situation.SEARCH || this._isValid ? null : err;\n  }\n\n  ngOnInit(): void {\n    this.rangeForm.valueChanges.subscribe(() => this.onValueChange());\n  }\n}\n","<form class=\"eo-datetime-range\" [formGroup]=\"rangeForm\">\n  @if (searchOption === 'gtelte') {\n    <yuv-datetime [withTime]=\"withTime\" formControlName=\"dateValueFrom\"></yuv-datetime>\n  }\n  <yvc-dropdown\n    [disableClearButton]=\"true\"\n    [(ngModel)]=\"searchOption\"\n    (ngModelChange)=\"onValueChange()\"\n    [ngModelOptions]=\"{ standalone: true }\"\n    [options]=\"availableSearchOptions\"\n  ></yvc-dropdown>\n\n  <yuv-datetime [withTime]=\"withTime\" formControlName=\"dateValue\"></yuv-datetime>\n</form>\n"]}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export * from './catalog/catalog.component';
|
|
2
|
+
export * from './data-grid/data-grid/data-grid.component';
|
|
3
|
+
export * from './datetime/datetime.component';
|
|
4
|
+
export * from './datetime-range/datetime-range.component';
|
|
5
|
+
export * from './number/number.component';
|
|
6
|
+
export * from './number-range/number-range.component';
|
|
7
|
+
export * from './organization/organization.component';
|
|
8
|
+
export * from './range-select-date/range-select-date.component';
|
|
9
|
+
export * from './range-select-filesize/range-select-filesize.component';
|
|
10
|
+
export * from './string/string.component';
|
|
11
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL3l1dXZpcy9jbGllbnQtZnJhbWV3b3JrL2Zvcm1zL3NyYy9saWIvZWxlbWVudHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLDJDQUEyQyxDQUFDO0FBQzFELGNBQWMsK0JBQStCLENBQUM7QUFDOUMsY0FBYywyQ0FBMkMsQ0FBQztBQUMxRCxjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMsdUNBQXVDLENBQUM7QUFDdEQsY0FBYyx1Q0FBdUMsQ0FBQztBQUN0RCxjQUFjLGlEQUFpRCxDQUFDO0FBQ2hFLGNBQWMseURBQXlELENBQUM7QUFDeEUsY0FBYywyQkFBMkIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vY2F0YWxvZy9jYXRhbG9nLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2RhdGEtZ3JpZC9kYXRhLWdyaWQvZGF0YS1ncmlkLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2RhdGV0aW1lL2RhdGV0aW1lLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2RhdGV0aW1lLXJhbmdlL2RhdGV0aW1lLXJhbmdlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL251bWJlci9udW1iZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbnVtYmVyLXJhbmdlL251bWJlci1yYW5nZS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9vcmdhbml6YXRpb24vb3JnYW5pemF0aW9uLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3JhbmdlLXNlbGVjdC1kYXRlL3JhbmdlLXNlbGVjdC1kYXRlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3JhbmdlLXNlbGVjdC1maWxlc2l6ZS9yYW5nZS1zZWxlY3QtZmlsZXNpemUuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vc3RyaW5nL3N0cmluZy5jb21wb25lbnQnO1xuIl19
|
|
@@ -159,7 +159,7 @@ export class NumberComponent {
|
|
|
159
159
|
useExisting: forwardRef(() => NumberComponent),
|
|
160
160
|
multi: true
|
|
161
161
|
}
|
|
162
|
-
], ngImport: i0, template: "<input type=\"string\" [(ngModel)]=\"innerValue\" (focus)=\"unformat()\" (blur)=\"format()\" class=\"input-number\"\n [readonly]=\"readonly\" (ngModelChange)=\"onValueChange($event)\" />\n", styles: [":host{display:
|
|
162
|
+
], ngImport: i0, template: "<input type=\"string\" [(ngModel)]=\"innerValue\" (focus)=\"unformat()\" (blur)=\"format()\" class=\"input-number\"\n [readonly]=\"readonly\" (ngModelChange)=\"onValueChange($event)\" />\n", styles: [":host{display:flex}:host input{width:100%;border:0;background-color:transparent}\n"], dependencies: [{ kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] }); }
|
|
163
163
|
}
|
|
164
164
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: NumberComponent, decorators: [{
|
|
165
165
|
type: Component,
|
|
@@ -174,7 +174,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
174
174
|
useExisting: forwardRef(() => NumberComponent),
|
|
175
175
|
multi: true
|
|
176
176
|
}
|
|
177
|
-
], template: "<input type=\"string\" [(ngModel)]=\"innerValue\" (focus)=\"unformat()\" (blur)=\"format()\" class=\"input-number\"\n [readonly]=\"readonly\" (ngModelChange)=\"onValueChange($event)\" />\n", styles: [":host{display:
|
|
177
|
+
], template: "<input type=\"string\" [(ngModel)]=\"innerValue\" (focus)=\"unformat()\" (blur)=\"format()\" class=\"input-number\"\n [readonly]=\"readonly\" (ngModelChange)=\"onValueChange($event)\" />\n", styles: [":host{display:flex}:host input{width:100%;border:0;background-color:transparent}\n"] }]
|
|
178
178
|
}], ctorParameters: () => [{ type: i1.TranslateService }], propDecorators: { scale: [{
|
|
179
179
|
type: Input
|
|
180
180
|
}], precision: [{
|
|
@@ -192,4 +192,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
192
192
|
}], classifications: [{
|
|
193
193
|
type: Input
|
|
194
194
|
}] } });
|
|
195
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"number.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/yuuvis/client-framework/forms/src/lib/elements/number/number.component.ts","../../../../../../../../../libs/yuuvis/client-framework/forms/src/lib/elements/number/number.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, forwardRef, Input } from '@angular/core';\nimport { ControlValueAccessor, FormsModule, NG_VALIDATORS, NG_VALUE_ACCESSOR, ValidationErrors, Validator } from '@angular/forms';\nimport { Classification, TranslateService, Utils } from '@yuuvis/client-core';\nimport { FileSizePipe, LocaleNumberPipe } from '@yuuvis/client-core';\n\n/**\n * Creates form input for number values.\n *\n * Implements `ControlValueAccessor` so it can be used within Angular forms.\n *\n * @example\n * <yuv-number [scale]=\"2\"></yuv-number>\n *\n */\n@Component({\n  selector: 'yuv-number',\n  standalone: true,\n  imports: [FormsModule],\n  templateUrl: './number.component.html',\n  styleUrls: ['./number.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => NumberComponent),\n      multi: true\n    },\n    {\n      provide: NG_VALIDATORS,\n      useExisting: forwardRef(() => NumberComponent),\n      multi: true\n    }\n  ]\n})\nexport class NumberComponent implements ControlValueAccessor, Validator {\n  value?: number;\n  innerValue: string | null = null;\n  _scale?: number;\n  _precision?: number;\n  _pattern?: string;\n  _grouping = false;\n  validationErrors: ValidationErrors[] = [];\n  numberPipe: LocaleNumberPipe | FileSizePipe;\n\n  /**\n   * Number of decimal places\n   */\n  @Input()\n  set scale(val: number | undefined) {\n    this._scale = Math.min(val || 0, 30);\n  }\n  get scale(): number | undefined {\n    return this._scale;\n  }\n  /**\n   * Overall amount of digits allowed (including decimal places)\n   */\n  @Input()\n  set precision(val: number | undefined) {\n    this._precision = Math.min(val || 100, 100);\n  }\n  get precision(): number | undefined {\n    return this._precision;\n  }\n  /**\n   *  Set to true to group number by pattern\n   */\n  @Input()\n  set grouping(val: boolean) {\n    this._grouping = val ?? true;\n  }\n  get grouping(): boolean {\n    return this._grouping;\n  }\n  /**\n   * The pattern to group number value by\n   */\n  @Input()\n  set groupPattern(val: string | undefined) {\n    this._pattern = val;\n  }\n  get groupPattern(): string | undefined {\n    return this._pattern;\n  }\n  /**\n   * Will prevent the input from being changed (default: false)\n   */\n  @Input() readonly = false;\n\n  /**\n   * set minimum input value\n   */\n  @Input() minValue?: number;\n\n  /**\n   * set maximum input value\n   *\n   */\n  @Input() maxValue?: number;\n\n  /**\n   * classification property adds some semantics to the value of this component.\n   * If you provide a value of `filesize` numbers typed into the control will be\n   * handled like file sizes (calculates differnt units)\n   */\n  @Input() set classifications(classifications: string[]) {\n    this.numberPipe =\n      classifications && classifications.includes(Classification.NUMBER_FILESIZE) ? new FileSizePipe(this.translate) : new LocaleNumberPipe(this.translate);\n  }\n\n  static betweenTwoNumbers(val: number, minVal: number | undefined, maxVal: number | undefined) {\n    const min = !Utils.isEmpty(minVal) ? minVal : -Infinity;\n    const max = !Utils.isEmpty(maxVal) ? maxVal : Infinity;\n    return val >= (min as number) && val <= (max as number);\n  }\n\n  constructor(private translate: TranslateService) {\n    this.numberPipe = new LocaleNumberPipe(this.translate);\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars, @typescript-eslint/no-empty-function\n  propagateChange = (_: any) => {};\n\n  writeValue(value: any): void {\n    this.value = value != null ? value : null;\n    this.innerValue = value != null ? this.numberPipe.numberToString(value, this.grouping, this.groupPattern, this.scale) : null;\n  }\n\n  registerOnChange(fn: any): void {\n    this.propagateChange = fn;\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  registerOnTouched(): void {}\n\n  onValueChange(evt: any) {\n    this.validationErrors = [];\n\n    if (Utils.isEmpty(evt)) {\n      this.value = undefined;\n      this.propagateChange(this.value);\n      return;\n    }\n\n    // validate input\n    const val = this.numberPipe.stringToNumber(evt);\n    // general number validation\n    if (isNaN(val) || typeof val !== 'number') {\n      this.validationErrors.push({ key: 'number' });\n    } else {\n      const split = evt.replaceAll(this.numberPipe.separator, '').split(this.numberPipe.decimalSeparator);\n      // check precision\n      if (this.precision !== undefined) {\n        const prePointDigits = this.precision - (this.scale || 0);\n        if (split[0]?.length > prePointDigits) {\n          this.validationErrors.push({ key: 'precision', params: { prePointDigits } });\n        }\n      }\n      // check scale\n      if (this.scale && split[1]?.length > this.scale) {\n        this.validationErrors.push({ key: 'scale', params: { scale: this.scale } });\n      }\n\n      // min max\n      if (!NumberComponent.betweenTwoNumbers(val, this.minValue, this.maxValue)) {\n        if (Utils.isEmpty(this.minValue)) {\n          this.validationErrors.push({ key: 'maxvalue', params: { maxValue: this.maxValue } });\n        } else if (Utils.isEmpty(this.maxValue)) {\n          this.validationErrors.push({ key: 'minvalue', params: { minValue: this.minValue } });\n        } else {\n          this.validationErrors.push({ key: 'minmax', params: { minValue: this.minValue, maxValue: this.maxValue } });\n        }\n      }\n\n      if (!this.validationErrors.length) {\n        this.value = val;\n      }\n    }\n    this.propagateChange(this.value);\n  }\n\n  // called when the input looses focus\n  public format() {\n    if (!this.readonly && typeof this.value === 'number' && this.validationErrors.length === 0) {\n      this.innerValue = this.numberPipe.numberToString(this.value, this.grouping, this.groupPattern, this.scale);\n    }\n  }\n\n  // called when the input get focus\n  public unformat() {\n    if (!this.readonly && typeof this.value === 'number' && this.validationErrors.length === 0) {\n      this.innerValue = this.numberPipe.transform(this.value, false);\n    }\n  }\n\n  // returns null when valid else the validation object\n  public validate() {\n    return this.validationErrors.length ? Utils.arrayToObject(this.validationErrors, 'key', (err) => ({ valid: false, ...err })) : null;\n  }\n}\n","<input type=\"string\" [(ngModel)]=\"innerValue\" (focus)=\"unformat()\" (blur)=\"format()\" class=\"input-number\"\n  [readonly]=\"readonly\" (ngModelChange)=\"onValueChange($event)\" />\n"]}
|
|
195
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"number.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/yuuvis/client-framework/forms/src/lib/elements/number/number.component.ts","../../../../../../../../../libs/yuuvis/client-framework/forms/src/lib/elements/number/number.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, forwardRef, Input } from '@angular/core';\nimport { ControlValueAccessor, FormsModule, NG_VALIDATORS, NG_VALUE_ACCESSOR, ValidationErrors, Validator } from '@angular/forms';\nimport { Classification, TranslateService, Utils } from '@yuuvis/client-core';\nimport { FileSizePipe, LocaleNumberPipe } from '@yuuvis/client-core';\n\n/**\n * Creates form input for number values.\n *\n * Implements `ControlValueAccessor` so it can be used within Angular forms.\n *\n * @example\n * <yuv-number [scale]=\"2\"></yuv-number>\n *\n */\n@Component({\n  selector: 'yuv-number',\n  standalone: true,\n  imports: [FormsModule],\n  templateUrl: './number.component.html',\n  styleUrls: ['./number.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => NumberComponent),\n      multi: true\n    },\n    {\n      provide: NG_VALIDATORS,\n      useExisting: forwardRef(() => NumberComponent),\n      multi: true\n    }\n  ]\n})\nexport class NumberComponent implements ControlValueAccessor, Validator {\n  value?: number;\n  innerValue: string | null = null;\n  _scale?: number;\n  _precision?: number;\n  _pattern?: string;\n  _grouping = false;\n  validationErrors: ValidationErrors[] = [];\n  numberPipe: LocaleNumberPipe | FileSizePipe;\n\n  /**\n   * Number of decimal places\n   */\n  @Input()\n  set scale(val: number | undefined) {\n    this._scale = Math.min(val || 0, 30);\n  }\n  get scale(): number | undefined {\n    return this._scale;\n  }\n  /**\n   * Overall amount of digits allowed (including decimal places)\n   */\n  @Input()\n  set precision(val: number | undefined) {\n    this._precision = Math.min(val || 100, 100);\n  }\n  get precision(): number | undefined {\n    return this._precision;\n  }\n  /**\n   *  Set to true to group number by pattern\n   */\n  @Input()\n  set grouping(val: boolean) {\n    this._grouping = val ?? true;\n  }\n  get grouping(): boolean {\n    return this._grouping;\n  }\n  /**\n   * The pattern to group number value by\n   */\n  @Input()\n  set groupPattern(val: string | undefined) {\n    this._pattern = val;\n  }\n  get groupPattern(): string | undefined {\n    return this._pattern;\n  }\n  /**\n   * Will prevent the input from being changed (default: false)\n   */\n  @Input() readonly = false;\n\n  /**\n   * set minimum input value\n   */\n  @Input() minValue?: number;\n\n  /**\n   * set maximum input value\n   *\n   */\n  @Input() maxValue?: number;\n\n  /**\n   * classification property adds some semantics to the value of this component.\n   * If you provide a value of `filesize` numbers typed into the control will be\n   * handled like file sizes (calculates differnt units)\n   */\n  @Input() set classifications(classifications: string[]) {\n    this.numberPipe =\n      classifications && classifications.includes(Classification.NUMBER_FILESIZE) ? new FileSizePipe(this.translate) : new LocaleNumberPipe(this.translate);\n  }\n\n  static betweenTwoNumbers(val: number, minVal: number | undefined, maxVal: number | undefined) {\n    const min = !Utils.isEmpty(minVal) ? minVal : -Infinity;\n    const max = !Utils.isEmpty(maxVal) ? maxVal : Infinity;\n    return val >= (min as number) && val <= (max as number);\n  }\n\n  constructor(private translate: TranslateService) {\n    this.numberPipe = new LocaleNumberPipe(this.translate);\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars, @typescript-eslint/no-empty-function\n  propagateChange = (_: any) => {};\n\n  writeValue(value: any): void {\n    this.value = value != null ? value : null;\n    this.innerValue = value != null ? this.numberPipe.numberToString(value, this.grouping, this.groupPattern, this.scale) : null;\n  }\n\n  registerOnChange(fn: any): void {\n    this.propagateChange = fn;\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  registerOnTouched(): void {}\n\n  onValueChange(evt: any) {\n    this.validationErrors = [];\n\n    if (Utils.isEmpty(evt)) {\n      this.value = undefined;\n      this.propagateChange(this.value);\n      return;\n    }\n\n    // validate input\n    const val = this.numberPipe.stringToNumber(evt);\n    // general number validation\n    if (isNaN(val) || typeof val !== 'number') {\n      this.validationErrors.push({ key: 'number' });\n    } else {\n      const split = evt.replaceAll(this.numberPipe.separator, '').split(this.numberPipe.decimalSeparator);\n      // check precision\n      if (this.precision !== undefined) {\n        const prePointDigits = this.precision - (this.scale || 0);\n        if (split[0]?.length > prePointDigits) {\n          this.validationErrors.push({ key: 'precision', params: { prePointDigits } });\n        }\n      }\n      // check scale\n      if (this.scale && split[1]?.length > this.scale) {\n        this.validationErrors.push({ key: 'scale', params: { scale: this.scale } });\n      }\n\n      // min max\n      if (!NumberComponent.betweenTwoNumbers(val, this.minValue, this.maxValue)) {\n        if (Utils.isEmpty(this.minValue)) {\n          this.validationErrors.push({ key: 'maxvalue', params: { maxValue: this.maxValue } });\n        } else if (Utils.isEmpty(this.maxValue)) {\n          this.validationErrors.push({ key: 'minvalue', params: { minValue: this.minValue } });\n        } else {\n          this.validationErrors.push({ key: 'minmax', params: { minValue: this.minValue, maxValue: this.maxValue } });\n        }\n      }\n\n      if (!this.validationErrors.length) {\n        this.value = val;\n      }\n    }\n    this.propagateChange(this.value);\n  }\n\n  // called when the input looses focus\n  public format() {\n    if (!this.readonly && typeof this.value === 'number' && this.validationErrors.length === 0) {\n      this.innerValue = this.numberPipe.numberToString(this.value, this.grouping, this.groupPattern, this.scale);\n    }\n  }\n\n  // called when the input get focus\n  public unformat() {\n    if (!this.readonly && typeof this.value === 'number' && this.validationErrors.length === 0) {\n      this.innerValue = this.numberPipe.transform(this.value, false);\n    }\n  }\n\n  // returns null when valid else the validation object\n  public validate() {\n    return this.validationErrors.length ? Utils.arrayToObject(this.validationErrors, 'key', (err) => ({ valid: false, ...err })) : null;\n  }\n}\n","<input type=\"string\" [(ngModel)]=\"innerValue\" (focus)=\"unformat()\" (blur)=\"format()\" class=\"input-number\"\n  [readonly]=\"readonly\" (ngModelChange)=\"onValueChange($event)\" />\n"]}
|
|
@@ -140,7 +140,7 @@ export class NumberRangeComponent {
|
|
|
140
140
|
useExisting: forwardRef(() => NumberRangeComponent),
|
|
141
141
|
multi: true
|
|
142
142
|
}
|
|
143
|
-
], ngImport: i0, template: "<form class=\"yuv-number-range\" [formGroup]=\"rangeForm\">\n @if(searchOption === 'gtelte'){\n <yuv-number\n class=\"first\"\n [readonly]=\"readonly\"\n [scale]=\"scale\"\n [precision]=\"precision\"\n [grouping]=\"grouping\"\n [groupPattern]=\"pattern\"\n formControlName=\"numberValueFrom\"\n [classifications]=\"classifications\"\n [minValue]=\"minValue\"\n [maxValue]=\"maxValue\"\n ></yuv-number>}\n\n <yvc-dropdown\n class=\"no-trigger\"\n [(ngModel)]=\"searchOption\"\n (ngModelChange)=\"onValueChange()\"\n [disabled]=\"readonly\"\n [disableClearButton]=\"true\"\n [ngModelOptions]=\"{ standalone: true }\"\n [options]=\"availableSearchOptions\"\n ></yvc-dropdown>\n\n <yuv-number\n [scale]=\"scale\"\n [readonly]=\"readonly\"\n [precision]=\"precision\"\n [grouping]=\"grouping\"\n [groupPattern]=\"pattern\"\n formControlName=\"numberValue\"\n [classifications]=\"classifications\"\n [minValue]=\"minValue\"\n [maxValue]=\"maxValue\"\n >\n </yuv-number>\n</form>\n", styles: [":host
|
|
143
|
+
], ngImport: i0, template: "<form class=\"yuv-number-range\" [formGroup]=\"rangeForm\">\n @if(searchOption === 'gtelte'){\n <yuv-number\n class=\"first\"\n [readonly]=\"readonly\"\n [scale]=\"scale\"\n [precision]=\"precision\"\n [grouping]=\"grouping\"\n [groupPattern]=\"pattern\"\n formControlName=\"numberValueFrom\"\n [classifications]=\"classifications\"\n [minValue]=\"minValue\"\n [maxValue]=\"maxValue\"\n ></yuv-number>}\n\n <yvc-dropdown\n class=\"no-trigger\"\n [(ngModel)]=\"searchOption\"\n (ngModelChange)=\"onValueChange()\"\n [disabled]=\"readonly\"\n [disableClearButton]=\"true\"\n [ngModelOptions]=\"{ standalone: true }\"\n [options]=\"availableSearchOptions\"\n ></yvc-dropdown>\n\n <yuv-number\n [scale]=\"scale\"\n [readonly]=\"readonly\"\n [precision]=\"precision\"\n [grouping]=\"grouping\"\n [groupPattern]=\"pattern\"\n formControlName=\"numberValue\"\n [classifications]=\"classifications\"\n [minValue]=\"minValue\"\n [maxValue]=\"maxValue\"\n >\n </yuv-number>\n</form>\n", styles: [":host>form{display:flex;flex-flow:row nowrap;gap:3px}:host>form yuv-number{flex:1 1 auto}:host>form yvc-dropdown{--yvc-form-element-border-color: var(--text-color-hint);--yvc-form-element-focus-border-color: var(--color-accent);padding:0;min-width:auto;border-radius:2px;background-color:var(--list-item-hover-background)}:host>form yvc-dropdown:hover{background-color:var(--list-item-selected-background)}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "component", type: NumberComponent, selector: "yuv-number", inputs: ["scale", "precision", "grouping", "groupPattern", "readonly", "minValue", "maxValue", "classifications"] }, { kind: "ngmodule", type: YvcDropdownModule }, { kind: "component", type: i1.Dropdown, selector: "yvc-dropdown", inputs: ["options", "filter", "disabled", "multiple", "disableClearButton"], outputs: ["onDropdownOptionsClose"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i2.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }] }); }
|
|
144
144
|
}
|
|
145
145
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: NumberRangeComponent, decorators: [{
|
|
146
146
|
type: Component,
|
|
@@ -155,7 +155,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
155
155
|
useExisting: forwardRef(() => NumberRangeComponent),
|
|
156
156
|
multi: true
|
|
157
157
|
}
|
|
158
|
-
], template: "<form class=\"yuv-number-range\" [formGroup]=\"rangeForm\">\n @if(searchOption === 'gtelte'){\n <yuv-number\n class=\"first\"\n [readonly]=\"readonly\"\n [scale]=\"scale\"\n [precision]=\"precision\"\n [grouping]=\"grouping\"\n [groupPattern]=\"pattern\"\n formControlName=\"numberValueFrom\"\n [classifications]=\"classifications\"\n [minValue]=\"minValue\"\n [maxValue]=\"maxValue\"\n ></yuv-number>}\n\n <yvc-dropdown\n class=\"no-trigger\"\n [(ngModel)]=\"searchOption\"\n (ngModelChange)=\"onValueChange()\"\n [disabled]=\"readonly\"\n [disableClearButton]=\"true\"\n [ngModelOptions]=\"{ standalone: true }\"\n [options]=\"availableSearchOptions\"\n ></yvc-dropdown>\n\n <yuv-number\n [scale]=\"scale\"\n [readonly]=\"readonly\"\n [precision]=\"precision\"\n [grouping]=\"grouping\"\n [groupPattern]=\"pattern\"\n formControlName=\"numberValue\"\n [classifications]=\"classifications\"\n [minValue]=\"minValue\"\n [maxValue]=\"maxValue\"\n >\n </yuv-number>\n</form>\n", styles: [":host
|
|
158
|
+
], template: "<form class=\"yuv-number-range\" [formGroup]=\"rangeForm\">\n @if(searchOption === 'gtelte'){\n <yuv-number\n class=\"first\"\n [readonly]=\"readonly\"\n [scale]=\"scale\"\n [precision]=\"precision\"\n [grouping]=\"grouping\"\n [groupPattern]=\"pattern\"\n formControlName=\"numberValueFrom\"\n [classifications]=\"classifications\"\n [minValue]=\"minValue\"\n [maxValue]=\"maxValue\"\n ></yuv-number>}\n\n <yvc-dropdown\n class=\"no-trigger\"\n [(ngModel)]=\"searchOption\"\n (ngModelChange)=\"onValueChange()\"\n [disabled]=\"readonly\"\n [disableClearButton]=\"true\"\n [ngModelOptions]=\"{ standalone: true }\"\n [options]=\"availableSearchOptions\"\n ></yvc-dropdown>\n\n <yuv-number\n [scale]=\"scale\"\n [readonly]=\"readonly\"\n [precision]=\"precision\"\n [grouping]=\"grouping\"\n [groupPattern]=\"pattern\"\n formControlName=\"numberValue\"\n [classifications]=\"classifications\"\n [minValue]=\"minValue\"\n [maxValue]=\"maxValue\"\n >\n </yuv-number>\n</form>\n", styles: [":host>form{display:flex;flex-flow:row nowrap;gap:3px}:host>form yuv-number{flex:1 1 auto}:host>form yvc-dropdown{--yvc-form-element-border-color: var(--text-color-hint);--yvc-form-element-focus-border-color: var(--color-accent);padding:0;min-width:auto;border-radius:2px;background-color:var(--list-item-hover-background)}:host>form yvc-dropdown:hover{background-color:var(--list-item-selected-background)}\n"] }]
|
|
159
159
|
}], ctorParameters: () => [], propDecorators: { scale: [{
|
|
160
160
|
type: Input
|
|
161
161
|
}], precision: [{
|
|
@@ -173,4 +173,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
173
173
|
}], maxValue: [{
|
|
174
174
|
type: Input
|
|
175
175
|
}] } });
|
|
176
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"number-range.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/yuuvis/client-framework/forms/src/lib/elements/number-range/number-range.component.ts","../../../../../../../../../libs/yuuvis/client-framework/forms/src/lib/elements/number-range/number-range.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { Component, forwardRef, Input } from '@angular/core';\nimport {\n  ControlValueAccessor,\n  FormsModule,\n  NG_VALIDATORS,\n  NG_VALUE_ACCESSOR,\n  ReactiveFormsModule,\n  UntypedFormControl,\n  UntypedFormGroup,\n  Validator\n} from '@angular/forms';\nimport { Operator, OperatorLabel, RangeValue } from '@yuuvis/client-core';\nimport { YvcDropdownModule } from '@yuuvis/components/dropdown';\nimport { NumberComponent } from '../number/number.component';\n\n/**\n * Creates form input for ranges of numeric values.\n *\n * Implements `ControlValueAccessor` so it can be used within Angular forms.\n *\n * @example\n * <yuv-number-range [scale]=\"2\"></yuv-number-range>\n *\n */\n@Component({\n  selector: 'yuv-number-range',\n  standalone: true,\n  imports: [CommonModule, NumberComponent, YvcDropdownModule, FormsModule, ReactiveFormsModule],\n  templateUrl: './number-range.component.html',\n  styleUrls: ['./number-range.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => NumberRangeComponent),\n      multi: true\n    },\n    {\n      provide: NG_VALIDATORS,\n      useExisting: forwardRef(() => NumberRangeComponent),\n      multi: true\n    }\n  ]\n})\nexport class NumberRangeComponent implements ControlValueAccessor, Validator {\n  /**\n   * Number of decimal places\n   */\n  @Input() scale?: number;\n  /**\n   * Overall amount of digits allowed (including decimal places)\n   */\n  @Input() precision?: number;\n  /**\n   *  Set to true to group number by pattern\n   */\n  @Input() grouping = false;\n  /**\n   * The pattern to group number value by\n   */\n  @Input() pattern?: string;\n  /**\n   * Will prevent the input from being changed (default: false)\n   */\n  @Input() readonly = false;\n\n  /**\n   * classification property adds some semantics to the value of this component.\n   * If you provide a value of `filesize` numbers typed into the control will be\n   * handled like file sizes (calculates differnt units)\n   */\n  @Input() classifications: string[] = [];\n  /**\n   * set minimum input value\n   */\n  @Input() minValue?: number;\n  /**\n   * set maximum input value\n   *\n   */\n  @Input() maxValue?: number;\n\n  public rangeForm = new UntypedFormGroup({\n    numberValue: new UntypedFormControl(),\n    numberValueFrom: new UntypedFormControl()\n  });\n\n  value?: RangeValue;\n  private isValid = true;\n\n  // options for search situation\n  public availableSearchOptions = [\n    { label: OperatorLabel.EQUAL, value: Operator.EQUAL },\n    { label: OperatorLabel.GREATER_OR_EQUAL, value: Operator.GREATER_OR_EQUAL },\n    { label: OperatorLabel.LESS_OR_EQUAL, value: Operator.LESS_OR_EQUAL },\n    { label: OperatorLabel.INTERVAL_INCLUDE_BOTH, value: Operator.INTERVAL_INCLUDE_BOTH }\n  ];\n  // the selected search option\n  public searchOption = this.availableSearchOptions[1].value;\n\n  constructor() {\n    this.rangeForm.valueChanges.forEach(() => {\n      this.onValueChange();\n    });\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars, @typescript-eslint/no-empty-function\n  propagateChange = (_: any) => {};\n\n  writeValue(value: RangeValue): void {\n    if (value && (value.firstValue != null || value.secondValue != null)) {\n      const match = this.availableSearchOptions.find((o) => o.value === value.operator);\n      this.searchOption = match ? match.value : this.availableSearchOptions[0].value;\n\n      this.value = value;\n      if (value.secondValue == null) {\n        this.rangeForm.setValue({\n          numberValueFrom: null,\n          numberValue: value.firstValue != null ? value.firstValue : null\n        });\n      } else {\n        this.rangeForm.setValue({\n          numberValueFrom: value.firstValue != null ? value.firstValue : null,\n          numberValue: value.secondValue\n        });\n      }\n    } else {\n      this.searchOption = this.availableSearchOptions[0].value;\n      this.value = undefined;\n      this.rangeForm.reset();\n    }\n  }\n\n  registerOnChange(fn: any): void {\n    this.propagateChange = fn;\n  }\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars, @typescript-eslint/no-empty-function\n  registerOnTouched(fn: any): void {}\n\n  onValueChange() {\n    this.isValid = this.rangeForm.valid;\n    if (this.searchOption === Operator.INTERVAL_INCLUDE_BOTH) {\n      this.isValid = this.rangeForm.valid && this.rangeForm.value.numberValueFrom != null && this.rangeForm.value.numberValue != null;\n      this.value = !this.isValid\n        ? {\n            operator: this.searchOption,\n            firstValue: undefined,\n            secondValue: undefined\n          }\n        : {\n            operator: this.searchOption,\n            firstValue: this.rangeForm.value.numberValueFrom,\n            secondValue: this.rangeForm.value.numberValue\n          };\n    } else {\n      this.value = !this.isValid\n        ? {\n            operator: this.searchOption,\n            firstValue: undefined,\n            secondValue: undefined\n          }\n        : {\n            operator: this.searchOption,\n            firstValue: this.rangeForm.value.numberValue,\n            secondValue: undefined\n          };\n    }\n    this.propagateChange(this.value);\n  }\n\n  // returns null when valid else the validation object\n  public validate() {\n    let err: any;\n    if (this.searchOption === Operator.EQUAL) {\n      err = { number: { valid: false } };\n    } else if (this.searchOption === Operator.INTERVAL_INCLUDE_BOTH && this.value?.firstValue && this.value?.secondValue) {\n      // make sure that on ranges, the first value is earlier than the last\n      this.isValid = this.value!.firstValue < this.value!.secondValue;\n      err = { numberrangeorder: { valid: false } };\n    } else {\n      err = { numberrange: { valid: false } };\n    }\n    return this.isValid ? null : err;\n  }\n}\n","<form class=\"yuv-number-range\" [formGroup]=\"rangeForm\">\n  @if(searchOption === 'gtelte'){\n  <yuv-number\n    class=\"first\"\n    [readonly]=\"readonly\"\n    [scale]=\"scale\"\n    [precision]=\"precision\"\n    [grouping]=\"grouping\"\n    [groupPattern]=\"pattern\"\n    formControlName=\"numberValueFrom\"\n    [classifications]=\"classifications\"\n    [minValue]=\"minValue\"\n    [maxValue]=\"maxValue\"\n  ></yuv-number>}\n\n  <yvc-dropdown\n    class=\"no-trigger\"\n    [(ngModel)]=\"searchOption\"\n    (ngModelChange)=\"onValueChange()\"\n    [disabled]=\"readonly\"\n    [disableClearButton]=\"true\"\n    [ngModelOptions]=\"{ standalone: true }\"\n    [options]=\"availableSearchOptions\"\n  ></yvc-dropdown>\n\n  <yuv-number\n    [scale]=\"scale\"\n    [readonly]=\"readonly\"\n    [precision]=\"precision\"\n    [grouping]=\"grouping\"\n    [groupPattern]=\"pattern\"\n    formControlName=\"numberValue\"\n    [classifications]=\"classifications\"\n    [minValue]=\"minValue\"\n    [maxValue]=\"maxValue\"\n  >\n  </yuv-number>\n</form>\n"]}
|
|
176
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"number-range.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/yuuvis/client-framework/forms/src/lib/elements/number-range/number-range.component.ts","../../../../../../../../../libs/yuuvis/client-framework/forms/src/lib/elements/number-range/number-range.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { Component, forwardRef, Input } from '@angular/core';\nimport {\n  ControlValueAccessor,\n  FormsModule,\n  NG_VALIDATORS,\n  NG_VALUE_ACCESSOR,\n  ReactiveFormsModule,\n  UntypedFormControl,\n  UntypedFormGroup,\n  Validator\n} from '@angular/forms';\nimport { Operator, OperatorLabel, RangeValue } from '@yuuvis/client-core';\nimport { YvcDropdownModule } from '@yuuvis/components/dropdown';\nimport { NumberComponent } from '../number/number.component';\n\n/**\n * Creates form input for ranges of numeric values.\n *\n * Implements `ControlValueAccessor` so it can be used within Angular forms.\n *\n * @example\n * <yuv-number-range [scale]=\"2\"></yuv-number-range>\n *\n */\n@Component({\n  selector: 'yuv-number-range',\n  standalone: true,\n  imports: [CommonModule, NumberComponent, YvcDropdownModule, FormsModule, ReactiveFormsModule],\n  templateUrl: './number-range.component.html',\n  styleUrls: ['./number-range.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => NumberRangeComponent),\n      multi: true\n    },\n    {\n      provide: NG_VALIDATORS,\n      useExisting: forwardRef(() => NumberRangeComponent),\n      multi: true\n    }\n  ]\n})\nexport class NumberRangeComponent implements ControlValueAccessor, Validator {\n  /**\n   * Number of decimal places\n   */\n  @Input() scale?: number;\n  /**\n   * Overall amount of digits allowed (including decimal places)\n   */\n  @Input() precision?: number;\n  /**\n   *  Set to true to group number by pattern\n   */\n  @Input() grouping = false;\n  /**\n   * The pattern to group number value by\n   */\n  @Input() pattern?: string;\n  /**\n   * Will prevent the input from being changed (default: false)\n   */\n  @Input() readonly = false;\n\n  /**\n   * classification property adds some semantics to the value of this component.\n   * If you provide a value of `filesize` numbers typed into the control will be\n   * handled like file sizes (calculates differnt units)\n   */\n  @Input() classifications: string[] = [];\n  /**\n   * set minimum input value\n   */\n  @Input() minValue?: number;\n  /**\n   * set maximum input value\n   *\n   */\n  @Input() maxValue?: number;\n\n  public rangeForm = new UntypedFormGroup({\n    numberValue: new UntypedFormControl(),\n    numberValueFrom: new UntypedFormControl()\n  });\n\n  value?: RangeValue;\n  private isValid = true;\n\n  // options for search situation\n  public availableSearchOptions = [\n    { label: OperatorLabel.EQUAL, value: Operator.EQUAL },\n    { label: OperatorLabel.GREATER_OR_EQUAL, value: Operator.GREATER_OR_EQUAL },\n    { label: OperatorLabel.LESS_OR_EQUAL, value: Operator.LESS_OR_EQUAL },\n    { label: OperatorLabel.INTERVAL_INCLUDE_BOTH, value: Operator.INTERVAL_INCLUDE_BOTH }\n  ];\n  // the selected search option\n  public searchOption = this.availableSearchOptions[1].value;\n\n  constructor() {\n    this.rangeForm.valueChanges.forEach(() => {\n      this.onValueChange();\n    });\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars, @typescript-eslint/no-empty-function\n  propagateChange = (_: any) => {};\n\n  writeValue(value: RangeValue): void {\n    if (value && (value.firstValue != null || value.secondValue != null)) {\n      const match = this.availableSearchOptions.find((o) => o.value === value.operator);\n      this.searchOption = match ? match.value : this.availableSearchOptions[0].value;\n\n      this.value = value;\n      if (value.secondValue == null) {\n        this.rangeForm.setValue({\n          numberValueFrom: null,\n          numberValue: value.firstValue != null ? value.firstValue : null\n        });\n      } else {\n        this.rangeForm.setValue({\n          numberValueFrom: value.firstValue != null ? value.firstValue : null,\n          numberValue: value.secondValue\n        });\n      }\n    } else {\n      this.searchOption = this.availableSearchOptions[0].value;\n      this.value = undefined;\n      this.rangeForm.reset();\n    }\n  }\n\n  registerOnChange(fn: any): void {\n    this.propagateChange = fn;\n  }\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars, @typescript-eslint/no-empty-function\n  registerOnTouched(fn: any): void {}\n\n  onValueChange() {\n    this.isValid = this.rangeForm.valid;\n    if (this.searchOption === Operator.INTERVAL_INCLUDE_BOTH) {\n      this.isValid = this.rangeForm.valid && this.rangeForm.value.numberValueFrom != null && this.rangeForm.value.numberValue != null;\n      this.value = !this.isValid\n        ? {\n            operator: this.searchOption,\n            firstValue: undefined,\n            secondValue: undefined\n          }\n        : {\n            operator: this.searchOption,\n            firstValue: this.rangeForm.value.numberValueFrom,\n            secondValue: this.rangeForm.value.numberValue\n          };\n    } else {\n      this.value = !this.isValid\n        ? {\n            operator: this.searchOption,\n            firstValue: undefined,\n            secondValue: undefined\n          }\n        : {\n            operator: this.searchOption,\n            firstValue: this.rangeForm.value.numberValue,\n            secondValue: undefined\n          };\n    }\n    this.propagateChange(this.value);\n  }\n\n  // returns null when valid else the validation object\n  public validate() {\n    let err: any;\n    if (this.searchOption === Operator.EQUAL) {\n      err = { number: { valid: false } };\n    } else if (this.searchOption === Operator.INTERVAL_INCLUDE_BOTH && this.value?.firstValue && this.value?.secondValue) {\n      // make sure that on ranges, the first value is earlier than the last\n      this.isValid = this.value!.firstValue < this.value!.secondValue;\n      err = { numberrangeorder: { valid: false } };\n    } else {\n      err = { numberrange: { valid: false } };\n    }\n    return this.isValid ? null : err;\n  }\n}\n","<form class=\"yuv-number-range\" [formGroup]=\"rangeForm\">\n  @if(searchOption === 'gtelte'){\n  <yuv-number\n    class=\"first\"\n    [readonly]=\"readonly\"\n    [scale]=\"scale\"\n    [precision]=\"precision\"\n    [grouping]=\"grouping\"\n    [groupPattern]=\"pattern\"\n    formControlName=\"numberValueFrom\"\n    [classifications]=\"classifications\"\n    [minValue]=\"minValue\"\n    [maxValue]=\"maxValue\"\n  ></yuv-number>}\n\n  <yvc-dropdown\n    class=\"no-trigger\"\n    [(ngModel)]=\"searchOption\"\n    (ngModelChange)=\"onValueChange()\"\n    [disabled]=\"readonly\"\n    [disableClearButton]=\"true\"\n    [ngModelOptions]=\"{ standalone: true }\"\n    [options]=\"availableSearchOptions\"\n  ></yvc-dropdown>\n\n  <yuv-number\n    [scale]=\"scale\"\n    [readonly]=\"readonly\"\n    [precision]=\"precision\"\n    [grouping]=\"grouping\"\n    [groupPattern]=\"pattern\"\n    formControlName=\"numberValue\"\n    [classifications]=\"classifications\"\n    [minValue]=\"minValue\"\n    [maxValue]=\"maxValue\"\n  >\n  </yuv-number>\n</form>\n"]}
|