@wemake4u/form-player-se 1.0.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/README.md +17 -0
- package/esm2022/lib/controls/accordion.mjs +7 -0
- package/esm2022/lib/controls/button.mjs +7 -0
- package/esm2022/lib/controls/checkbox.mjs +7 -0
- package/esm2022/lib/controls/checklist.mjs +7 -0
- package/esm2022/lib/controls/chipchecklist.mjs +7 -0
- package/esm2022/lib/controls/chipradio.mjs +7 -0
- package/esm2022/lib/controls/control.mjs +65 -0
- package/esm2022/lib/controls/date.mjs +7 -0
- package/esm2022/lib/controls/dynamiclist.mjs +4 -0
- package/esm2022/lib/controls/factory.mjs +106 -0
- package/esm2022/lib/controls/filepicker.mjs +7 -0
- package/esm2022/lib/controls/form.mjs +4 -0
- package/esm2022/lib/controls/group.mjs +4 -0
- package/esm2022/lib/controls/html.mjs +4 -0
- package/esm2022/lib/controls/iframe.mjs +4 -0
- package/esm2022/lib/controls/image.mjs +4 -0
- package/esm2022/lib/controls/number.mjs +7 -0
- package/esm2022/lib/controls/radio.mjs +7 -0
- package/esm2022/lib/controls/select.mjs +7 -0
- package/esm2022/lib/controls/separator.mjs +4 -0
- package/esm2022/lib/controls/spacer.mjs +4 -0
- package/esm2022/lib/controls/tab.mjs +7 -0
- package/esm2022/lib/controls/table.mjs +13 -0
- package/esm2022/lib/controls/taglist.mjs +7 -0
- package/esm2022/lib/controls/text.mjs +4 -0
- package/esm2022/lib/controls/textarea.mjs +7 -0
- package/esm2022/lib/controls/textfield.mjs +18 -0
- package/esm2022/lib/controls/time.mjs +7 -0
- package/esm2022/lib/controls/toggle.mjs +7 -0
- package/esm2022/lib/dataSources/interfaces.mjs +2 -0
- package/esm2022/lib/dataSources/odata.mjs +131 -0
- package/esm2022/lib/dataSources/rest.mjs +48 -0
- package/esm2022/lib/directives/accordion.directive.mjs +52 -0
- package/esm2022/lib/directives/adorner.directive.mjs +130 -0
- package/esm2022/lib/directives/disable.directive.mjs +38 -0
- package/esm2022/lib/directives/display.directive.mjs +46 -0
- package/esm2022/lib/directives/dropdown.directive.mjs +233 -0
- package/esm2022/lib/directives/frame-security.directive.mjs +66 -0
- package/esm2022/lib/directives/grid.directive.mjs +68 -0
- package/esm2022/lib/directives/register.directive.mjs +86 -0
- package/esm2022/lib/directives/repeat.directive.mjs +38 -0
- package/esm2022/lib/directives/tab.directive.mjs +49 -0
- package/esm2022/lib/directives/updateblur.directive.mjs +32 -0
- package/esm2022/lib/dynamic-fields/dynamic-fields.component.mjs +493 -0
- package/esm2022/lib/dynamic-form/dynamic-form.component.mjs +395 -0
- package/esm2022/lib/locale/locale-it.mjs +13 -0
- package/esm2022/lib/services/data.service.mjs +29 -0
- package/esm2022/lib/services/event.service.mjs +19 -0
- package/esm2022/lib/services/feel.service.mjs +73 -0
- package/esm2022/lib/services/formatter.service.mjs +60 -0
- package/esm2022/lib/services/markdown.service.mjs +24 -0
- package/esm2022/lib/services/mime.service.mjs +32 -0
- package/esm2022/lib/services/programmability.service.mjs +221 -0
- package/esm2022/lib/services/proxy.service.mjs +131 -0
- package/esm2022/lib/services/register.service.mjs +60 -0
- package/esm2022/lib/services/sanitize.service.mjs +38 -0
- package/esm2022/lib/services/scope.service.mjs +46 -0
- package/esm2022/lib/services/toast.service.mjs +37 -0
- package/esm2022/lib/services/weak.service.mjs +60 -0
- package/esm2022/lib/utils/extractFiles.mjs +30 -0
- package/esm2022/lib/utils/gridCells.mjs +49 -0
- package/esm2022/lib/utils/groupByRow.mjs +30 -0
- package/esm2022/lib/utils/patchForm.mjs +55 -0
- package/esm2022/lib/utils/toFormData.mjs +11 -0
- package/esm2022/public-api.mjs +8 -0
- package/esm2022/wemake4u-form-player-se.mjs +5 -0
- package/fesm2022/wemake4u-form-player-se.mjs +3101 -0
- package/fesm2022/wemake4u-form-player-se.mjs.map +1 -0
- package/index.d.ts +5 -0
- package/lib/controls/accordion.d.ts +4 -0
- package/lib/controls/button.d.ts +4 -0
- package/lib/controls/checkbox.d.ts +4 -0
- package/lib/controls/checklist.d.ts +4 -0
- package/lib/controls/chipchecklist.d.ts +4 -0
- package/lib/controls/chipradio.d.ts +4 -0
- package/lib/controls/control.d.ts +24 -0
- package/lib/controls/date.d.ts +4 -0
- package/lib/controls/dynamiclist.d.ts +3 -0
- package/lib/controls/factory.d.ts +4 -0
- package/lib/controls/filepicker.d.ts +4 -0
- package/lib/controls/form.d.ts +3 -0
- package/lib/controls/group.d.ts +3 -0
- package/lib/controls/html.d.ts +3 -0
- package/lib/controls/iframe.d.ts +3 -0
- package/lib/controls/image.d.ts +3 -0
- package/lib/controls/number.d.ts +4 -0
- package/lib/controls/radio.d.ts +4 -0
- package/lib/controls/select.d.ts +4 -0
- package/lib/controls/separator.d.ts +3 -0
- package/lib/controls/spacer.d.ts +3 -0
- package/lib/controls/tab.d.ts +4 -0
- package/lib/controls/table.d.ts +6 -0
- package/lib/controls/taglist.d.ts +4 -0
- package/lib/controls/text.d.ts +3 -0
- package/lib/controls/textarea.d.ts +4 -0
- package/lib/controls/textfield.d.ts +6 -0
- package/lib/controls/time.d.ts +4 -0
- package/lib/controls/toggle.d.ts +4 -0
- package/lib/dataSources/interfaces.d.ts +8 -0
- package/lib/dataSources/odata.d.ts +16 -0
- package/lib/dataSources/rest.d.ts +16 -0
- package/lib/directives/accordion.directive.d.ts +11 -0
- package/lib/directives/adorner.directive.d.ts +22 -0
- package/lib/directives/disable.directive.d.ts +12 -0
- package/lib/directives/display.directive.d.ts +12 -0
- package/lib/directives/dropdown.directive.d.ts +26 -0
- package/lib/directives/frame-security.directive.d.ts +14 -0
- package/lib/directives/grid.directive.d.ts +17 -0
- package/lib/directives/register.directive.d.ts +24 -0
- package/lib/directives/repeat.directive.d.ts +12 -0
- package/lib/directives/tab.directive.d.ts +11 -0
- package/lib/directives/updateblur.directive.d.ts +10 -0
- package/lib/dynamic-fields/dynamic-fields.component.d.ts +84 -0
- package/lib/dynamic-form/dynamic-form.component.d.ts +76 -0
- package/lib/locale/locale-it.d.ts +12 -0
- package/lib/services/data.service.d.ts +15 -0
- package/lib/services/event.service.d.ts +15 -0
- package/lib/services/feel.service.d.ts +10 -0
- package/lib/services/formatter.service.d.ts +10 -0
- package/lib/services/markdown.service.d.ts +7 -0
- package/lib/services/mime.service.d.ts +8 -0
- package/lib/services/programmability.service.d.ts +39 -0
- package/lib/services/proxy.service.d.ts +31 -0
- package/lib/services/register.service.d.ts +18 -0
- package/lib/services/sanitize.service.d.ts +12 -0
- package/lib/services/scope.service.d.ts +13 -0
- package/lib/services/toast.service.d.ts +13 -0
- package/lib/services/weak.service.d.ts +10 -0
- package/lib/utils/extractFiles.d.ts +4 -0
- package/lib/utils/gridCells.d.ts +19 -0
- package/lib/utils/groupByRow.d.ts +38 -0
- package/lib/utils/patchForm.d.ts +8 -0
- package/lib/utils/toFormData.d.ts +1 -0
- package/package.json +42 -0
- package/public-api.d.ts +4 -0
|
@@ -0,0 +1,493 @@
|
|
|
1
|
+
import { Component, Input, ViewEncapsulation } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { FormGroup, FormArray } from '@angular/forms';
|
|
4
|
+
import { ReactiveFormsModule } from '@angular/forms';
|
|
5
|
+
import { Datepicker } from 'vanillajs-datepicker';
|
|
6
|
+
import { ProgrammabilityService } from '../services/programmability.service';
|
|
7
|
+
import { RegisterService } from '../services/register.service';
|
|
8
|
+
import { AdornerDirective } from '../directives/adorner.directive';
|
|
9
|
+
import { DisableDirective } from '../directives/disable.directive';
|
|
10
|
+
import { DisplayDirective } from '../directives/display.directive';
|
|
11
|
+
import { RepeatDirective } from '../directives/repeat.directive';
|
|
12
|
+
import { FrameSecurityDirective } from '../directives/frame-security.directive';
|
|
13
|
+
import { DropdownDirective } from '../directives/dropdown.directive';
|
|
14
|
+
import { TabDirective } from '../directives/tab.directive';
|
|
15
|
+
import { AccordionDirective } from '../directives/accordion.directive';
|
|
16
|
+
import { GridDirective } from '../directives/grid.directive';
|
|
17
|
+
import { RegisterDirective } from '../directives/register.directive';
|
|
18
|
+
import { UpdateBlurDirective } from '../directives/updateblur.directive';
|
|
19
|
+
import { ObjectURLRendererComponent, DeleteRowCellRenderer } from '../utils/gridCells';
|
|
20
|
+
import { isObservable, of } from 'rxjs';
|
|
21
|
+
import { SirioInputComponent, SirioValidationDirective, SirioSelectComponent, SirioSelectOptionComponent, SirioSelectPanelComponent, SirioCheckboxGroupComponent, SirioCheckboxComponent, SirioDatepickerComponent, SirioTimepickerComponent, SirioRadioGroupComponent, SirioRadioButtonComponent, SirioTabComponent, SirioTabItemComponent, SirioAccordionComponent, SirioAccordionPanelComponent, SirioAccordionHeaderComponent, SirioAccordionBodyComponent, SirioButtonComponent, SirioFileUploadComponent, SirioToggleComponent, SirioChipCheckboxGroupComponent, SirioChipRadioGroupComponent, SirioInputChipComponent, SirioTableModule, SirioTableComponent, SirioPaginatorComponent, SirioAlertComponent, SirioAlertMessageComponent, SirioSliderComponent, SirioNotifyComponent, SirioNotifyBodyComponent, SirioNotifyActionComponent, SirioNotifyLinkComponent } from 'ngx-sirio-lib';
|
|
22
|
+
import { AgGridAngular } from 'ag-grid-angular';
|
|
23
|
+
import { PaginationModule, ClientSideRowModelModule, InfiniteRowModelModule, LocaleModule, CellStyleModule, TextFilterModule, NumberFilterModule, DateFilterModule, themeQuartz, iconSetAlpine, ClientSideRowModelApiModule } from 'ag-grid-community';
|
|
24
|
+
import { AG_GRID_LOCALE_IT } from '@ag-grid-community/locale';
|
|
25
|
+
import { Texts } from '../locale/locale-it';
|
|
26
|
+
import * as i0 from "@angular/core";
|
|
27
|
+
import * as i1 from "../services/sanitize.service";
|
|
28
|
+
import * as i2 from "../services/markdown.service";
|
|
29
|
+
import * as i3 from "../services/mime.service";
|
|
30
|
+
import * as i4 from "../services/programmability.service";
|
|
31
|
+
import * as i5 from "../services/event.service";
|
|
32
|
+
import * as i6 from "../services/formatter.service";
|
|
33
|
+
import * as i7 from "../services/weak.service";
|
|
34
|
+
import * as i8 from "../services/register.service";
|
|
35
|
+
import * as i9 from "@angular/common";
|
|
36
|
+
import * as i10 from "@angular/forms";
|
|
37
|
+
export class DynamicFieldsComponent {
|
|
38
|
+
sanitizer;
|
|
39
|
+
markdown;
|
|
40
|
+
mime;
|
|
41
|
+
programmability;
|
|
42
|
+
events;
|
|
43
|
+
formatter;
|
|
44
|
+
weak;
|
|
45
|
+
register;
|
|
46
|
+
el;
|
|
47
|
+
rows;
|
|
48
|
+
formGroup;
|
|
49
|
+
Texts = Texts;
|
|
50
|
+
constructor(sanitizer, markdown, mime, programmability, events, formatter, weak, register, el) {
|
|
51
|
+
this.sanitizer = sanitizer;
|
|
52
|
+
this.markdown = markdown;
|
|
53
|
+
this.mime = mime;
|
|
54
|
+
this.programmability = programmability;
|
|
55
|
+
this.events = events;
|
|
56
|
+
this.formatter = formatter;
|
|
57
|
+
this.weak = weak;
|
|
58
|
+
this.register = register;
|
|
59
|
+
this.el = el;
|
|
60
|
+
}
|
|
61
|
+
ngOnInit() {
|
|
62
|
+
this.configureDatepicker();
|
|
63
|
+
}
|
|
64
|
+
ngAfterViewInit() {
|
|
65
|
+
setTimeout(() => {
|
|
66
|
+
this.focusFirst();
|
|
67
|
+
});
|
|
68
|
+
}
|
|
69
|
+
getRegister() {
|
|
70
|
+
return this.register;
|
|
71
|
+
}
|
|
72
|
+
getClass(component) {
|
|
73
|
+
if (component.layout?.columns) {
|
|
74
|
+
return "col-md-" + component.layout?.columns;
|
|
75
|
+
}
|
|
76
|
+
else {
|
|
77
|
+
return "col";
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
getTextFeedback(component) {
|
|
81
|
+
const control = this.formGroup.get(component.key);
|
|
82
|
+
return control.valid || !control.errors
|
|
83
|
+
? ''
|
|
84
|
+
: control.errors['message'];
|
|
85
|
+
}
|
|
86
|
+
isWarning(component) {
|
|
87
|
+
const control = this.formGroup.get(component.key);
|
|
88
|
+
return (control.errors && control.errors['warning']) || false;
|
|
89
|
+
}
|
|
90
|
+
evaluateString(value) {
|
|
91
|
+
return this.programmability.evaluateString(this.formGroup, value);
|
|
92
|
+
}
|
|
93
|
+
evaluateBoolean(value) {
|
|
94
|
+
return this.programmability.evaluateBoolean(this.formGroup, value);
|
|
95
|
+
}
|
|
96
|
+
evaluateNumber(value) {
|
|
97
|
+
return this.programmability.evaluateNumber(this.formGroup, value);
|
|
98
|
+
}
|
|
99
|
+
evaluateUrl(value) {
|
|
100
|
+
const url = this.programmability.evaluateString(this.formGroup, value);
|
|
101
|
+
const watchKey = `:safeUrl(${url})`;
|
|
102
|
+
return this.weak.call(this.formGroup, watchKey, () => {
|
|
103
|
+
return this.sanitizer.sanitizeSafeUrl(url);
|
|
104
|
+
});
|
|
105
|
+
}
|
|
106
|
+
evaluateTemplate(value) {
|
|
107
|
+
return this.programmability.evaluateTemplate(this.formGroup, value);
|
|
108
|
+
}
|
|
109
|
+
evaluate(text, cacheable = true) {
|
|
110
|
+
return this.programmability.evaluate(this.formGroup, text, cacheable);
|
|
111
|
+
}
|
|
112
|
+
evaluateColor(value) {
|
|
113
|
+
const color = this.evaluateString(value);
|
|
114
|
+
const watchKey = `:buttonColor(${color})`;
|
|
115
|
+
return this.weak.call(this.formGroup, watchKey, () => {
|
|
116
|
+
if (color === "ghost")
|
|
117
|
+
return null;
|
|
118
|
+
const validColors = ['primary', 'secondary', 'tertiary', 'tertiary-light', 'danger'];
|
|
119
|
+
return validColors.includes(color) ? color : 'primary';
|
|
120
|
+
});
|
|
121
|
+
}
|
|
122
|
+
getFormGroup(control) {
|
|
123
|
+
if (!(control instanceof FormGroup)) {
|
|
124
|
+
throw new Error('Control is not a FormGroup');
|
|
125
|
+
}
|
|
126
|
+
return control;
|
|
127
|
+
}
|
|
128
|
+
getFormArray(control) {
|
|
129
|
+
if (!(control instanceof FormArray)) {
|
|
130
|
+
throw new Error('Control is not a FormArray');
|
|
131
|
+
}
|
|
132
|
+
return control;
|
|
133
|
+
}
|
|
134
|
+
getControlFromPath(path) {
|
|
135
|
+
return path
|
|
136
|
+
? this.formGroup.get(path)
|
|
137
|
+
: this.formGroup;
|
|
138
|
+
}
|
|
139
|
+
toHTML(text) {
|
|
140
|
+
let html = this.markdown.toHtml(text);
|
|
141
|
+
return this.sanitizer.sanitizeSafeHtml(html);
|
|
142
|
+
}
|
|
143
|
+
;
|
|
144
|
+
sanitize(html) {
|
|
145
|
+
return this.sanitizer.sanitizeSafeHtml(html);
|
|
146
|
+
}
|
|
147
|
+
;
|
|
148
|
+
getMimeTypes(extensions) {
|
|
149
|
+
return this.mime.getMimeTypes(extensions);
|
|
150
|
+
}
|
|
151
|
+
;
|
|
152
|
+
clickButton(component, event) {
|
|
153
|
+
if (component.click) {
|
|
154
|
+
this.evaluate(component.click, false);
|
|
155
|
+
}
|
|
156
|
+
if (component.command) {
|
|
157
|
+
const command = {
|
|
158
|
+
name: this.evaluateString(component.command),
|
|
159
|
+
component: component,
|
|
160
|
+
formGroup: this.formGroup,
|
|
161
|
+
event: event
|
|
162
|
+
};
|
|
163
|
+
this.events.emitCommand(command);
|
|
164
|
+
}
|
|
165
|
+
}
|
|
166
|
+
getValues(component) {
|
|
167
|
+
if (component.values) {
|
|
168
|
+
// Static
|
|
169
|
+
return of(component.values);
|
|
170
|
+
}
|
|
171
|
+
else if (component.valuesKey) {
|
|
172
|
+
// Field value
|
|
173
|
+
const result = this.evaluate(component.valuesKey);
|
|
174
|
+
return this.getAsObservable(result);
|
|
175
|
+
}
|
|
176
|
+
else if (component.valuesExpression) {
|
|
177
|
+
// Expression
|
|
178
|
+
const result = this.evaluate(component.valuesExpression);
|
|
179
|
+
return this.getAsObservable(result);
|
|
180
|
+
}
|
|
181
|
+
else {
|
|
182
|
+
// Nothing
|
|
183
|
+
return of([]);
|
|
184
|
+
}
|
|
185
|
+
}
|
|
186
|
+
getGridOptions(component) {
|
|
187
|
+
return this.weak.call(component, 'getGridOptions', () => {
|
|
188
|
+
return {
|
|
189
|
+
defaultColDef: {
|
|
190
|
+
floatingFilter: (component.floatingFilter === true),
|
|
191
|
+
headerClass: (component.floatingFilter === true)
|
|
192
|
+
? 'show-filter' : 'hide-filter'
|
|
193
|
+
},
|
|
194
|
+
columnDefs: this.getGridColumns(component),
|
|
195
|
+
pagination: this.getGridPaginable(component),
|
|
196
|
+
paginationPageSize: this.getGridPageSize(component),
|
|
197
|
+
paginationPageSizeSelector: [5, 10, 20, 50],
|
|
198
|
+
localeText: this.getGridTexts(),
|
|
199
|
+
theme: this.getGridTheme(),
|
|
200
|
+
};
|
|
201
|
+
});
|
|
202
|
+
}
|
|
203
|
+
getGridModules(component) {
|
|
204
|
+
return this.weak.call(component, 'getGridModules', () => {
|
|
205
|
+
return [
|
|
206
|
+
ClientSideRowModelModule,
|
|
207
|
+
InfiniteRowModelModule,
|
|
208
|
+
PaginationModule,
|
|
209
|
+
LocaleModule,
|
|
210
|
+
CellStyleModule,
|
|
211
|
+
ClientSideRowModelApiModule,
|
|
212
|
+
TextFilterModule,
|
|
213
|
+
NumberFilterModule,
|
|
214
|
+
DateFilterModule
|
|
215
|
+
];
|
|
216
|
+
});
|
|
217
|
+
}
|
|
218
|
+
getGridData(component) {
|
|
219
|
+
if (component.dataSource) {
|
|
220
|
+
// Expression
|
|
221
|
+
const result = this.evaluate(component.dataSource);
|
|
222
|
+
return this.getAsObservable(result);
|
|
223
|
+
}
|
|
224
|
+
else {
|
|
225
|
+
// Nothing
|
|
226
|
+
return of([]);
|
|
227
|
+
}
|
|
228
|
+
}
|
|
229
|
+
addNewItem(component) {
|
|
230
|
+
const formArray = this.getFormArray(this.getControlFromPath(component.path));
|
|
231
|
+
formArray.addNewItem();
|
|
232
|
+
}
|
|
233
|
+
removeItem(component, index) {
|
|
234
|
+
const formArray = this.getFormArray(this.getControlFromPath(component.path));
|
|
235
|
+
formArray.removeAt(index);
|
|
236
|
+
}
|
|
237
|
+
createUploadTables(component) {
|
|
238
|
+
return this.weak.call(component, 'createUploadTables', () => {
|
|
239
|
+
return [
|
|
240
|
+
{
|
|
241
|
+
components: [
|
|
242
|
+
{
|
|
243
|
+
"type": "table",
|
|
244
|
+
"layout": {
|
|
245
|
+
"columns": null
|
|
246
|
+
},
|
|
247
|
+
"columns": [
|
|
248
|
+
{
|
|
249
|
+
"label": "Name",
|
|
250
|
+
"key": "name",
|
|
251
|
+
"flex": 1
|
|
252
|
+
},
|
|
253
|
+
{
|
|
254
|
+
"label": "Size",
|
|
255
|
+
"key": "size",
|
|
256
|
+
"format": "integer",
|
|
257
|
+
"align": "right"
|
|
258
|
+
},
|
|
259
|
+
{
|
|
260
|
+
"key": "type",
|
|
261
|
+
"label": "Type"
|
|
262
|
+
},
|
|
263
|
+
{
|
|
264
|
+
"key": "url",
|
|
265
|
+
"label": "",
|
|
266
|
+
"width": 50,
|
|
267
|
+
"align": "center",
|
|
268
|
+
"format": "objectURL"
|
|
269
|
+
},
|
|
270
|
+
{
|
|
271
|
+
"label": "",
|
|
272
|
+
"width": 50,
|
|
273
|
+
"align": "center",
|
|
274
|
+
"format": "deleteRow"
|
|
275
|
+
}
|
|
276
|
+
],
|
|
277
|
+
"dataSource": "=" + component.key,
|
|
278
|
+
"height": 200,
|
|
279
|
+
"conditional": component.conditional,
|
|
280
|
+
"disabled": component.disabled
|
|
281
|
+
}
|
|
282
|
+
]
|
|
283
|
+
}
|
|
284
|
+
];
|
|
285
|
+
});
|
|
286
|
+
}
|
|
287
|
+
fileUploaded($event) {
|
|
288
|
+
const removeFile = (file) => {
|
|
289
|
+
if ($event.component.control) {
|
|
290
|
+
const newFiles = $event.component.fileList.filter(f => f !== file);
|
|
291
|
+
$event.component.control.setValue(newFiles);
|
|
292
|
+
addRemove(newFiles);
|
|
293
|
+
return newFiles;
|
|
294
|
+
}
|
|
295
|
+
return [];
|
|
296
|
+
};
|
|
297
|
+
const addRemove = (files) => {
|
|
298
|
+
files.forEach(file => {
|
|
299
|
+
if (!('remove' in file)) {
|
|
300
|
+
Object.defineProperty(file, 'remove', {
|
|
301
|
+
value: function () {
|
|
302
|
+
removeFile(this);
|
|
303
|
+
},
|
|
304
|
+
writable: false,
|
|
305
|
+
enumerable: false
|
|
306
|
+
});
|
|
307
|
+
}
|
|
308
|
+
});
|
|
309
|
+
};
|
|
310
|
+
addRemove($event.component.fileList);
|
|
311
|
+
}
|
|
312
|
+
focusFirst() {
|
|
313
|
+
const focusableElements = this.el.nativeElement.querySelectorAll('button, [href], input, select, textarea, [tabindex]:not([tabindex="-1"])');
|
|
314
|
+
for (let el of focusableElements) {
|
|
315
|
+
if (!el.hasAttribute('disabled')) {
|
|
316
|
+
el.focus();
|
|
317
|
+
break;
|
|
318
|
+
}
|
|
319
|
+
}
|
|
320
|
+
}
|
|
321
|
+
gridTexts = {
|
|
322
|
+
...AG_GRID_LOCALE_IT,
|
|
323
|
+
"pageSizeSelectorLabel": "Elementi per pagina:",
|
|
324
|
+
"to": "-",
|
|
325
|
+
};
|
|
326
|
+
gridTheme = themeQuartz
|
|
327
|
+
.withPart(iconSetAlpine)
|
|
328
|
+
.withParams({
|
|
329
|
+
backgroundColor: "#FAFAFA",
|
|
330
|
+
borderColor: "#D9E4F7",
|
|
331
|
+
browserColorScheme: "light",
|
|
332
|
+
cellTextColor: "#00121A",
|
|
333
|
+
columnBorder: true,
|
|
334
|
+
fontFamily: "inherit",
|
|
335
|
+
fontSize: 16,
|
|
336
|
+
headerBackgroundColor: "#002460",
|
|
337
|
+
headerColumnBorder: true,
|
|
338
|
+
headerColumnResizeHandleColor: "#F2F6FC",
|
|
339
|
+
headerColumnResizeHandleWidth: 2,
|
|
340
|
+
headerFontSize: 16,
|
|
341
|
+
headerFontWeight: 600,
|
|
342
|
+
headerRowBorder: false,
|
|
343
|
+
headerTextColor: "#F2F6FC",
|
|
344
|
+
rowBorder: true
|
|
345
|
+
});
|
|
346
|
+
getGridColumns(component) {
|
|
347
|
+
if (Array.isArray(component.columns)) {
|
|
348
|
+
return component.columns.map((column) => ({
|
|
349
|
+
field: column.key,
|
|
350
|
+
headerName: column.label,
|
|
351
|
+
resizable: column.resize === true,
|
|
352
|
+
sortable: column.sort === true,
|
|
353
|
+
filter: column.filter === true,
|
|
354
|
+
suppressMovable: !(column.move === true),
|
|
355
|
+
...(column.flex === true && { flex: 1 }),
|
|
356
|
+
...(column.align === "left" && { cellStyle: { textAlign: 'left' } }),
|
|
357
|
+
...(column.align === "center" && { cellStyle: { textAlign: 'center' } }),
|
|
358
|
+
...(column.align === "right" && { cellStyle: { textAlign: 'right' } }),
|
|
359
|
+
...(typeof column.pinned === "string" && { pinned: column.pinned }),
|
|
360
|
+
...(typeof column.flex === "number" && { flex: column.flex }),
|
|
361
|
+
...(typeof column.width === "number" && { width: column.width }),
|
|
362
|
+
...(typeof column.minWidth === "number" && { minWidth: column.minWidth }),
|
|
363
|
+
...(typeof column.maxWidth === "number" && { maxWidth: column.maxWidth }),
|
|
364
|
+
valueFormatter: this.getGridFormatter(column),
|
|
365
|
+
cellRenderer: this.getGridRenderer(column)
|
|
366
|
+
}));
|
|
367
|
+
}
|
|
368
|
+
else {
|
|
369
|
+
return [];
|
|
370
|
+
}
|
|
371
|
+
}
|
|
372
|
+
getGridPaginable(component) {
|
|
373
|
+
return (typeof component.rowCount === 'number' && component.rowCount > 0);
|
|
374
|
+
}
|
|
375
|
+
getGridPageSize(component) {
|
|
376
|
+
if (typeof component.rowCount === 'number') {
|
|
377
|
+
return component.rowCount;
|
|
378
|
+
}
|
|
379
|
+
}
|
|
380
|
+
getGridTexts() {
|
|
381
|
+
return this.gridTexts;
|
|
382
|
+
}
|
|
383
|
+
getGridTheme() {
|
|
384
|
+
return this.gridTheme;
|
|
385
|
+
}
|
|
386
|
+
getGridFormatter(column) {
|
|
387
|
+
if (column.format) {
|
|
388
|
+
switch (column.format) {
|
|
389
|
+
case 'integer':
|
|
390
|
+
return params => this.formatter.formatInteger(params.value);
|
|
391
|
+
case 'currency':
|
|
392
|
+
return params => this.formatter.formatCurrency(params.value);
|
|
393
|
+
case 'date':
|
|
394
|
+
return params => this.formatter.formatDate(params.value);
|
|
395
|
+
}
|
|
396
|
+
}
|
|
397
|
+
return undefined;
|
|
398
|
+
}
|
|
399
|
+
getGridRenderer(column) {
|
|
400
|
+
if (column.format) {
|
|
401
|
+
switch (column.format) {
|
|
402
|
+
case 'objectURL':
|
|
403
|
+
return ObjectURLRendererComponent;
|
|
404
|
+
case "deleteRow":
|
|
405
|
+
return DeleteRowCellRenderer;
|
|
406
|
+
}
|
|
407
|
+
}
|
|
408
|
+
return undefined;
|
|
409
|
+
}
|
|
410
|
+
getAsObservable(value) {
|
|
411
|
+
if (isObservable(value))
|
|
412
|
+
return value;
|
|
413
|
+
return of(value);
|
|
414
|
+
}
|
|
415
|
+
configureDatepicker() {
|
|
416
|
+
Datepicker.locales['it'] = {
|
|
417
|
+
days: [
|
|
418
|
+
'Domenica',
|
|
419
|
+
'Lunedì',
|
|
420
|
+
'Martedì',
|
|
421
|
+
'Mercoledì',
|
|
422
|
+
'Giovedì',
|
|
423
|
+
'Venerdì',
|
|
424
|
+
'Sabato',
|
|
425
|
+
],
|
|
426
|
+
daysMin: ['Dom', 'Lun', 'Mar', 'Mer', 'Gio', 'Ven', 'Sab'],
|
|
427
|
+
months: [
|
|
428
|
+
'Gennaio',
|
|
429
|
+
'Febbraio',
|
|
430
|
+
'Marzo',
|
|
431
|
+
'Aprile',
|
|
432
|
+
'Maggio',
|
|
433
|
+
'Giugno',
|
|
434
|
+
'Luglio',
|
|
435
|
+
'Agosto',
|
|
436
|
+
'Settembre',
|
|
437
|
+
'Ottobre',
|
|
438
|
+
'Novembre',
|
|
439
|
+
'Dicembre',
|
|
440
|
+
],
|
|
441
|
+
monthsShort: [
|
|
442
|
+
'Gen',
|
|
443
|
+
'Feb',
|
|
444
|
+
'Mar',
|
|
445
|
+
'Apr',
|
|
446
|
+
'Mag',
|
|
447
|
+
'Giu',
|
|
448
|
+
'Lug',
|
|
449
|
+
'Ago',
|
|
450
|
+
'Set',
|
|
451
|
+
'Ott',
|
|
452
|
+
'Nov',
|
|
453
|
+
'Dic',
|
|
454
|
+
],
|
|
455
|
+
today: 'Oggi',
|
|
456
|
+
clear: 'Pulisci',
|
|
457
|
+
format: 'dd/mm/yyyy',
|
|
458
|
+
weekStart: 1,
|
|
459
|
+
};
|
|
460
|
+
}
|
|
461
|
+
;
|
|
462
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DynamicFieldsComponent, deps: [{ token: i1.SanitizeService }, { token: i2.MarkdownService }, { token: i3.MimeService }, { token: i4.ProgrammabilityService }, { token: i5.EventService }, { token: i6.FormatterService }, { token: i7.WeakService }, { token: i8.RegisterService }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
463
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: DynamicFieldsComponent, isStandalone: true, selector: "app-dynamic-fields", inputs: { rows: "rows", formGroup: "formGroup" }, providers: [
|
|
464
|
+
RegisterService,
|
|
465
|
+
ProgrammabilityService
|
|
466
|
+
], ngImport: i0, template: "<ng-container *ngFor=\"let row of rows\" [formGroup]=\"formGroup\">\r\n <div class=\"row field-set\">\r\n <ng-container *ngFor=\"let component of row.components\">\r\n <ng-container [ngSwitch]=\"component.type\">\r\n <div [formGroup]=\"formGroup\" [class]=\"getClass(component)\">\r\n <!-- #region textfield -->\r\n <ng-container *ngSwitchCase=\"'textfield'\">\r\n <ngx-sirio-input type=\"text\"\r\n ariaLabel=\"input\"\r\n [label]=\"evaluateString(component.label)\"\r\n [labelPopover]=\"evaluateString(component.tooltip)\"\r\n [placeholder]=\"component.placeholder || ''\"\r\n [textHelp]=\"evaluateString(component.description)\"\r\n [textFeedback]=\"getTextFeedback(component)\"\r\n [prefixAdorner]=\"evaluateString(component.appearance?.prefixAdorner)\"\r\n [suffixAdorner]=\"evaluateString(component.appearance?.suffixAdorner)\"\r\n [readonly]=\"evaluateBoolean(component.readonly)\"\r\n [disableControl]=\"evaluateBoolean(component.disabled)\"\r\n [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n [formControlName]=\"component.key\"\r\n updateBlur\r\n validation\r\n [canValidate]=\"true\"\r\n [isWarning]=\"isWarning(component)\"\r\n [showWhenValid]=\"false\"\r\n #textfield\r\n [register]=\"component\"\r\n [componentRef]=\"textfield\">\r\n </ngx-sirio-input>\r\n </ng-container>\r\n <!-- #endregion -->\r\n <!-- #region select -->\r\n <ng-container *ngSwitchCase=\"'select'\">\r\n <ngx-sirio-select ariaLabel=\"select\"\r\n [label]=\"evaluateString(component.label)\"\r\n [labelPopover]=\"evaluateString(component.tooltip)\"\r\n [placeholder]=\"component.placeholder || ''\"\r\n [textHelp]=\"evaluateString(component.description)\"\r\n [textFeedback]=\"getTextFeedback(component)\"\r\n [readonly]=\"evaluateBoolean(component.readonly)\"\r\n [disableControl]=\"evaluateBoolean(component.disabled)\"\r\n [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n [formControlName]=\"component.key\"\r\n validation\r\n [canValidate]=\"true\"\r\n [isWarning]=\"isWarning(component)\"\r\n [showWhenValid]=\"false\"\r\n dropdown\r\n #select\r\n [register]=\"component\"\r\n [componentRef]=\"select\">\r\n <ngx-sirio-select-panel ariaLabel=\"items\">\r\n <ngx-sirio-input *ngIf=\"component.searchable\" class=\"searchable\" type=\"text\" [placeholder]=\"Texts.TypeToSearch\"></ngx-sirio-input>\r\n <ngx-sirio-select-option *ngFor=\"let option of (getValues(component) | async) || []\" [value]=\"option.value\">{{ option.label }}</ngx-sirio-select-option>\r\n </ngx-sirio-select-panel>\r\n </ngx-sirio-select>\r\n </ng-container>\r\n <!-- #endregion -->\r\n <!-- #region taglist -->\r\n <ng-container *ngSwitchCase=\"'taglist'\">\r\n <ngx-sirio-select ariaLabel=\"select\"\r\n [label]=\"evaluateString(component.label)\"\r\n [labelPopover]=\"evaluateString(component.tooltip)\"\r\n [placeholder]=\"component.placeholder || ''\"\r\n [textHelp]=\"evaluateString(component.description)\"\r\n [textFeedback]=\"getTextFeedback(component)\"\r\n [readonly]=\"evaluateBoolean(component.readonly)\"\r\n [disableControl]=\"evaluateBoolean(component.disabled)\"\r\n [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n [isMultiple]=\"true\"\r\n [formControlName]=\"component.key\"\r\n validation\r\n [canValidate]=\"true\"\r\n [isWarning]=\"isWarning(component)\"\r\n [showWhenValid]=\"false\"\r\n #taglist\r\n [register]=\"component\"\r\n [componentRef]=\"taglist\">\r\n <ngx-sirio-select-panel ariaLabel=\"items\">\r\n <ngx-sirio-select-option *ngFor=\"let option of (getValues(component) | async) || []\" [value]=\"option.value\">{{ option.label }}</ngx-sirio-select-option>\r\n </ngx-sirio-select-panel>\r\n </ngx-sirio-select>\r\n </ng-container>\r\n <!-- #endregion -->\r\n <!-- #region number -->\r\n <ng-container *ngSwitchCase=\"'number'\">\r\n <ngx-sirio-input type=\"number\"\r\n ariaLabel=\"input\"\r\n [label]=\"evaluateString(component.label)\"\r\n [labelPopover]=\"evaluateString(component.tooltip)\"\r\n [placeholder]=\"component.placeholder || ''\"\r\n [textHelp]=\"evaluateString(component.description)\"\r\n [textFeedback]=\"getTextFeedback(component)\"\r\n [prefixAdorner]=\"evaluateString(component.appearance?.prefixAdorner)\"\r\n [suffixAdorner]=\"evaluateString(component.appearance?.suffixAdorner)\"\r\n [readonly]=\"evaluateBoolean(component.readonly)\"\r\n [disableControl]=\"evaluateBoolean(component.disabled)\"\r\n [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n [formControlName]=\"component.key\"\r\n updateBlur\r\n validation\r\n [canValidate]=\"true\"\r\n [isWarning]=\"isWarning(component)\"\r\n [showWhenValid]=\"false\"\r\n #number\r\n [register]=\"component\"\r\n [componentRef]=\"number\">\r\n </ngx-sirio-input>\r\n </ng-container>\r\n <!-- #endregion -->\r\n <!-- #region datetime -->\r\n <ng-container *ngSwitchCase=\"'datetime'\">\r\n <ng-container [ngSwitch]=\"component.subtype\">\r\n <!-- #region date -->\r\n <ng-container *ngSwitchCase=\"'date'\">\r\n <ngx-sirio-datepicker ariaLabel=\"date\"\r\n [label]=\"evaluateString(component.dateLabel)\"\r\n [labelPopover]=\"evaluateString(component.tooltip)\"\r\n [placeholder]=\"component.placeholder || ''\"\r\n [textHelp]=\"evaluateString(component.description)\"\r\n [textFeedback]=\"getTextFeedback(component)\"\r\n [readonly]=\"evaluateBoolean(component.readonly)\"\r\n [disableControl]=\"evaluateBoolean(component.disabled)\"\r\n [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n [formControlName]=\"component.key\"\r\n validation\r\n [canValidate]=\"true\"\r\n [isWarning]=\"isWarning(component)\"\r\n [showWhenValid]=\"false\"\r\n #date\r\n [register]=\"component\"\r\n [componentRef]=\"date\">\r\n </ngx-sirio-datepicker>\r\n </ng-container>\r\n <!-- #endregion -->\r\n <!-- #region time -->\r\n <ng-container *ngSwitchCase=\"'time'\">\r\n <ngx-sirio-timepicker ariaLabel=\"time\"\r\n [label]=\"evaluateString(component.timeLabel)\"\r\n [labelPopover]=\"evaluateString(component.tooltip)\"\r\n [placeholder]=\"component.placeholder || ''\"\r\n [textHelp]=\"evaluateString(component.description)\"\r\n [textFeedback]=\"getTextFeedback(component)\"\r\n [readonly]=\"evaluateBoolean(component.readonly)\"\r\n [disableControl]=\"evaluateBoolean(component.disabled)\"\r\n [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n [formControlName]=\"component.key\"\r\n validation\r\n [canValidate]=\"true\"\r\n [isWarning]=\"isWarning(component)\"\r\n [showWhenValid]=\"false\"\r\n #time\r\n [register]=\"component\"\r\n [componentRef]=\"time\">\r\n </ngx-sirio-timepicker>\r\n </ng-container>\r\n <!-- #endregion -->\r\n </ng-container>\r\n </ng-container>\r\n <!-- #endregion -->\r\n <!-- #region checkbox -->\r\n <ng-container *ngSwitchCase=\"'checkbox'\">\r\n <ng-container [ngSwitch]=\"component.subtype\">\r\n <!-- #region toggle -->\r\n <ng-container *ngSwitchCase=\"'toggle'\">\r\n <ngx-sirio-toggle ariaLabel=\"checkbox\"\r\n [textHelp]=\"evaluateString(component.description)\"\r\n [textFeedback]=\"getTextFeedback(component)\"\r\n [readonly]=\"evaluateBoolean(component.readonly)\"\r\n [disableControl]=\"evaluateBoolean(component.disabled)\"\r\n [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n [formControlName]=\"component.key\"\r\n validation\r\n [canValidate]=\"true\"\r\n [isWarning]=\"isWarning(component)\"\r\n [showWhenValid]=\"false\"\r\n #toggle\r\n [register]=\"component\"\r\n [componentRef]=\"toggle\">\r\n {{ evaluateString(component.label) }}\r\n </ngx-sirio-toggle>\r\n </ng-container>\r\n <!-- #endregion -->\r\n <!-- #region default -->\r\n <ng-container *ngSwitchDefault>\r\n <ngx-sirio-checkbox ariaLabel=\"checkbox\"\r\n [textHelp]=\"evaluateString(component.description)\"\r\n [textFeedback]=\"getTextFeedback(component)\"\r\n [readonly]=\"evaluateBoolean(component.readonly)\"\r\n [disableControl]=\"evaluateBoolean(component.disabled)\"\r\n [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n [formControlName]=\"component.key\"\r\n validation\r\n [canValidate]=\"true\"\r\n [isWarning]=\"isWarning(component)\"\r\n [showWhenValid]=\"false\"\r\n #checkbox\r\n [register]=\"component\"\r\n [componentRef]=\"checkbox\">\r\n {{ evaluateString(component.label) }}\r\n </ngx-sirio-checkbox>\r\n </ng-container>\r\n <!-- #endregion -->\r\n </ng-container>\r\n </ng-container>\r\n <!-- #endregion -->\r\n <!-- #region radio -->\r\n <ng-container *ngSwitchCase=\"'radio'\">\r\n <ng-container [ngSwitch]=\"component.subtype\">\r\n <!-- #region chip -->\r\n <ng-container *ngSwitchCase=\"'chip'\">\r\n <ngx-sirio-chip-radio-group ariaLabel=\"radio\"\r\n [label]=\"evaluateString(component.label)\"\r\n [labelPopover]=\"evaluateString(component.tooltip)\"\r\n [textHelp]=\"evaluateString(component.description)\"\r\n [textFeedback]=\"getTextFeedback(component)\"\r\n [readonly]=\"evaluateBoolean(component.readonly)\"\r\n [disableControl]=\"evaluateBoolean(component.disabled)\"\r\n [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n [formControlName]=\"component.key\"\r\n validation\r\n [canValidate]=\"true\"\r\n [isWarning]=\"isWarning(component)\"\r\n [showWhenValid]=\"false\"\r\n #chipradio\r\n [register]=\"component\"\r\n [componentRef]=\"chipradio\">\r\n <ngx-sirio-input-chip *ngFor=\"let option of (getValues(component) | async) || []\"\r\n type=\"radio\"\r\n [value]=\"option.value\">\r\n {{ option.label }}\r\n </ngx-sirio-input-chip>\r\n </ngx-sirio-chip-radio-group>\r\n </ng-container>\r\n <!-- #endregion -->\r\n <!-- #region default -->\r\n <ng-container *ngSwitchDefault>\r\n <ngx-sirio-radio-group ariaLabel=\"radio\"\r\n [label]=\"evaluateString(component.label)\"\r\n [labelPopover]=\"evaluateString(component.tooltip)\"\r\n [textHelp]=\"evaluateString(component.description)\"\r\n [textFeedback]=\"getTextFeedback(component)\"\r\n [readonly]=\"evaluateBoolean(component.readonly)\"\r\n [disableControl]=\"evaluateBoolean(component.disabled)\"\r\n [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n [formControlName]=\"component.key\"\r\n validation\r\n [canValidate]=\"true\"\r\n [isWarning]=\"isWarning(component)\"\r\n [showWhenValid]=\"false\"\r\n #radio\r\n [register]=\"component\"\r\n [componentRef]=\"radio\">\r\n <ngx-sirio-radio-button *ngFor=\"let option of (getValues(component) | async) || []\" [value]=\"option.value\">\r\n {{ option.label }}\r\n </ngx-sirio-radio-button>\r\n </ngx-sirio-radio-group>\r\n </ng-container>\r\n <!-- #endregion -->\r\n </ng-container>\r\n </ng-container>\r\n <!-- #endregion -->\r\n <!-- #region checklist -->\r\n <ng-container *ngSwitchCase=\"'checklist'\">\r\n <ng-container [ngSwitch]=\"component.subtype\">\r\n <!-- #region chip -->\r\n <ng-container *ngSwitchCase=\"'chip'\">\r\n <ngx-sirio-chip-checkbox-group ariaLabel=\"checklist\"\r\n [label]=\"evaluateString(component.label)\"\r\n [labelPopover]=\"evaluateString(component.tooltip)\"\r\n [textHelp]=\"evaluateString(component.description)\"\r\n [textFeedback]=\"getTextFeedback(component)\"\r\n [readonly]=\"evaluateBoolean(component.readonly)\"\r\n [disableControl]=\"evaluateBoolean(component.disabled)\"\r\n [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n [formControlName]=\"component.key\"\r\n validation\r\n [canValidate]=\"true\"\r\n [isWarning]=\"isWarning(component)\"\r\n [showWhenValid]=\"false\"\r\n #chipcheckbox\r\n [register]=\"component\"\r\n [componentRef]=\"chipcheckbox\">\r\n <ngx-sirio-input-chip *ngFor=\"let option of (getValues(component) | async) || []\"\r\n type=\"checkbox\"\r\n [value]=\"option.value\">\r\n {{ option.label }}\r\n </ngx-sirio-input-chip>\r\n </ngx-sirio-chip-checkbox-group>\r\n </ng-container>\r\n <!-- #endregion -->\r\n <!-- #region default -->\r\n <ng-container *ngSwitchDefault>\r\n <ngx-sirio-checkbox-group ariaLabel=\"checklist\"\r\n [label]=\"evaluateString(component.label)\"\r\n [labelPopover]=\"evaluateString(component.tooltip)\"\r\n [textHelp]=\"evaluateString(component.description)\"\r\n [textFeedback]=\"getTextFeedback(component)\"\r\n [readonly]=\"evaluateBoolean(component.readonly)\"\r\n [disableControl]=\"evaluateBoolean(component.disabled)\"\r\n [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n [formControlName]=\"component.key\"\r\n validation\r\n [canValidate]=\"true\"\r\n [isWarning]=\"isWarning(component)\"\r\n [showWhenValid]=\"false\"\r\n #checkbox\r\n [register]=\"component\"\r\n [componentRef]=\"checkbox\">\r\n <ngx-sirio-checkbox *ngFor=\"let option of (getValues(component) | async) || []\" [value]=\"option.value\">\r\n {{ option.label }}\r\n </ngx-sirio-checkbox>\r\n </ngx-sirio-checkbox-group>\r\n </ng-container>\r\n <!-- #endregion -->\r\n </ng-container>\r\n </ng-container>\r\n <!-- #endregion -->\r\n <!-- #region textarea -->\r\n <ng-container *ngSwitchCase=\"'textarea'\">\r\n <ngx-sirio-input type=\"textarea\"\r\n ariaLabel=\"textarea\"\r\n [label]=\"evaluateString(component.label)\"\r\n [labelPopover]=\"evaluateString(component.tooltip)\"\r\n [placeholder]=\"component.placeholder || ''\"\r\n [readonly]=\"evaluateBoolean(component.readonly)\"\r\n [disableControl]=\"evaluateBoolean(component.disabled)\"\r\n [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n [textHelp]=\"evaluateString(component.description)\"\r\n [textFeedback]=\"getTextFeedback(component)\"\r\n [formControlName]=\"component.key\"\r\n updateBlur\r\n validation\r\n [canValidate]=\"true\"\r\n [isWarning]=\"isWarning(component)\"\r\n [showWhenValid]=\"false\"\r\n #textarea\r\n [register]=\"component\"\r\n [componentRef]=\"textarea\">\r\n </ngx-sirio-input>\r\n </ng-container>\r\n <!-- #endregion -->\r\n <!-- #region filepicker -->\r\n <ng-container *ngSwitchCase=\"'filepicker'\">\r\n <ngx-sirio-file-upload ariaLabel=\"filepicker\"\r\n [label]=\"evaluateString(component.label)\"\r\n [labelPopover]=\"evaluateString(component.tooltip)\"\r\n [accept]=\"getMimeTypes(component.accept)\"\r\n [multiple]=\"evaluateBoolean(component.multiple)\"\r\n (fileUploadedEvent)=\"fileUploaded($event)\"\r\n [showFilelist]=\"!component.showDetails\"\r\n [textHelp]=\"evaluateString(component.description)\"\r\n [textFeedback]=\"getTextFeedback(component)\"\r\n [readonly]=\"evaluateBoolean(component.readonly)\"\r\n [disableControl]=\"evaluateBoolean(component.disabled)\"\r\n [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n [formControlName]=\"component.key\"\r\n validation\r\n [canValidate]=\"true\"\r\n [isWarning]=\"isWarning(component)\"\r\n [showWhenValid]=\"false\"\r\n #filepicker\r\n [register]=\"component\"\r\n [componentRef]=\"filepicker\">\r\n <span class=\"fas fa-arrow-up\" aria-hidden=\"true\"></span>\r\n {{ Texts.Upload }}\r\n </ngx-sirio-file-upload>\r\n <ng-container *ngIf=\"component.showDetails\">\r\n <app-dynamic-fields [formGroup]=\"formGroup\" [rows]=\"createUploadTables(component)\"></app-dynamic-fields>\r\n </ng-container>\r\n </ng-container>\r\n <!-- #endregion -->\r\n <!-- #region text -->\r\n <ng-container *ngSwitchCase=\"'text'\">\r\n <div class=\"text-paragraph\"\r\n [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n [innerHTML]=\"toHTML(evaluateTemplate(component.text))\"\r\n #text\r\n [register]=\"component\"\r\n [componentRef]=\"text\">\r\n </div>\r\n </ng-container>\r\n <!-- #endregion -->\r\n <!-- #region html -->\r\n <ng-container *ngSwitchCase=\"'html'\">\r\n <div class=\"html-paragraph\"\r\n [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n [innerHTML]=\"sanitize(evaluateTemplate(component.content))\"\r\n #html\r\n [register]=\"component\"\r\n [componentRef]=\"html\">\r\n </div>\r\n </ng-container>\r\n <!-- #endregion -->\r\n <!-- #region image -->\r\n <ng-container *ngSwitchCase=\"'image'\">\r\n <img [src]=\"evaluateString(component.source)\"\r\n [alt]=\"evaluateString(component.alt)\"\r\n [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n style=\"width: 100%;height: 100%;\"\r\n #image\r\n [register]=\"component\"\r\n [componentRef]=\"image\">\r\n </ng-container>\r\n <!-- #endregion -->\r\n <!-- #region dynamiclist -->\r\n <ng-container *ngSwitchCase=\"'dynamiclist'\">\r\n <ng-container [formArrayName]=\"component.path\" [repeat]=\"evaluateNumber(component.repetitions)\">\r\n <ng-container [ngSwitch]=\"component.subtype\">\r\n <ng-container *ngIf=\"getFormArray(formGroup.get(component.path)).controls.length > 0\">\r\n <!-- #region tab -->\r\n <ng-container *ngSwitchCase=\"'tab'\">\r\n <div [register]=\"component\"\r\n [componentRef]=\"dynamiclisttab\">\r\n <ngx-sirio-tab [leftArrowLabel]=\"Texts.ScrollLeft\"\r\n [rightArrowLabel]=\"Texts.ScrollRight\"\r\n [tabCount]=\"getFormArray(formGroup.get(component.path)).controls.length\"\r\n #dynamiclisttab>\r\n <ng-container *ngFor=\"let item of getFormArray(formGroup.get(component.path)).controls; let i = index;\" [formGroupName]=\"i\">\r\n <ngx-sirio-tab-item [label]=\"component.label + ' ' + (i + 1)\">\r\n <!--<ng-container *ngTemplateOutlet=\"itemTemplate; context: { item: item, index: i }\"></ng-container>-->\r\n <div [ngClass]=\"{\r\n 'group-top': component.verticalAlignment === 'start',\r\n 'group-center': component.verticalAlignment === 'center',\r\n 'group-bottom': component.verticalAlignment === 'end'}\">\r\n <div>\r\n <app-dynamic-fields [formGroup]=\"getFormGroup(item)\" [rows]=\"component.rows\"></app-dynamic-fields>\r\n </div>\r\n <ng-container *ngIf=\"component.allowAddRemove\">\r\n <div style=\"text-align:right\">\r\n <ngx-sirio-button (click)=\"removeItem(component, i)\" class=\"remove-item\" [color]=\"null\" icon=\"fas fa-trash\">{{ Texts.RemoveItem }}</ngx-sirio-button>\r\n </div>\r\n </ng-container>\r\n </div>\r\n </ngx-sirio-tab-item>\r\n </ng-container>\r\n </ngx-sirio-tab>\r\n </div>\r\n </ng-container>\r\n <!-- #endregion -->\r\n <!-- #region accordion -->\r\n <ng-container *ngSwitchCase=\"'accordion'\">\r\n <div [register]=\"component\"\r\n [componentRef]=\"dynamiclistaccordion\">\r\n <ngx-sirio-accordion [accordionCount]=\"getFormArray(formGroup.get(component.path)).controls.length\"\r\n #dynamiclistaccordion>\r\n <ng-container *ngFor=\"let item of getFormArray(formGroup.get(component.path)).controls; let i = index;\" [formGroupName]=\"i\">\r\n <ngx-sirio-accordion-panel>\r\n <ngx-sirio-accordion-header>\r\n <span [innerText]=\"component.label + ' ' + (i + 1)\"></span>\r\n </ngx-sirio-accordion-header>\r\n <ngx-sirio-accordion-body>\r\n <!--<ng-container *ngTemplateOutlet=\"itemTemplate; context: { item: item, index: i }\"></ng-container>-->\r\n <div [ngClass]=\"{\r\n 'group-top': component.verticalAlignment === 'start',\r\n 'group-center': component.verticalAlignment === 'center',\r\n 'group-bottom': component.verticalAlignment === 'end'}\">\r\n <div>\r\n <app-dynamic-fields [formGroup]=\"getFormGroup(item)\" [rows]=\"component.rows\"></app-dynamic-fields>\r\n </div>\r\n <ng-container *ngIf=\"component.allowAddRemove\">\r\n <div style=\"text-align:right\">\r\n <ngx-sirio-button (click)=\"removeItem(component, i)\" class=\"remove-item\" [color]=\"null\" icon=\"fas fa-trash\">{{ Texts.RemoveItem }}</ngx-sirio-button>\r\n </div>\r\n </ng-container>\r\n </div>\r\n </ngx-sirio-accordion-body>\r\n </ngx-sirio-accordion-panel>\r\n </ng-container>\r\n </ngx-sirio-accordion>\r\n </div>\r\n </ng-container>\r\n <!-- #endregion -->\r\n <!-- #region default -->\r\n <ng-container *ngSwitchDefault>\r\n <div [ngClass]=\"{'group-outline': component.showOutline === true}\"\r\n #dynamiclist\r\n [register]=\"component\"\r\n [componentRef]=\"dynamiclist\">\r\n <label>{{ evaluateString(component.label) }}</label>\r\n <ng-container *ngFor=\"let item of getFormArray(formGroup.get(component.path)).controls; let i = index;\" [formGroupName]=\"i\">\r\n <div [ngClass]=\"{\r\n 'group-top': component.verticalAlignment === 'start',\r\n 'group-center': component.verticalAlignment === 'center',\r\n 'group-bottom': component.verticalAlignment === 'end'}\">\r\n <div>\r\n <app-dynamic-fields [formGroup]=\"getFormGroup(item)\" [rows]=\"component.rows\"></app-dynamic-fields>\r\n </div>\r\n <ng-container *ngIf=\"component.allowAddRemove\">\r\n <div style=\"text-align:right\">\r\n <ngx-sirio-button (click)=\"removeItem(component, i)\" class=\"remove-item\" [color]=\"null\" icon=\"fas fa-trash\">{{ Texts.RemoveItem }}</ngx-sirio-button>\r\n </div>\r\n </ng-container>\r\n </div>\r\n </ng-container>\r\n </div>\r\n </ng-container>\r\n <!-- #endregion -->\r\n </ng-container> \r\n <ng-container *ngIf=\"component.allowAddRemove\">\r\n <ngx-sirio-button (click)=\"addNewItem(component)\" class=\"add-item\" [color]=\"null\" icon=\"fas fa-plus\">{{ Texts.AddItem }}</ngx-sirio-button>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n <!-- #endregion -->\r\n <!-- #region group -->\r\n <ng-container *ngSwitchCase=\"'group'\">\r\n <div [ngClass]=\"{\r\n 'group-outline': component.showOutline === true,\r\n 'group-top': component.verticalAlignment === 'start',\r\n 'group-center': component.verticalAlignment === 'center',\r\n 'group-bottom': component.verticalAlignment === 'end'}\"\r\n [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n [show]=\"evaluateBoolean(component.conditional?.show)\">\r\n <label>{{ evaluateString(component.label) }}</label>\r\n <div #group\r\n [register]=\"component\"\r\n [componentRef]=\"group\">\r\n <app-dynamic-fields [formGroup]=\"getFormGroup(getControlFromPath(component.path))\"\r\n [rows]=\"component.rows\"></app-dynamic-fields>\r\n </div>\r\n </div>\r\n </ng-container>\r\n <!-- #endregion -->\r\n <!-- #region table -->\r\n <ng-container *ngSwitchCase=\"'table'\">\r\n <ag-grid-angular [modules]=\"getGridModules(component)\"\r\n [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n [gridOptions]=\"getGridOptions(component)\"\r\n [rowSource]=\"(getGridData(component) | async) || []\"\r\n [style.height.px]=\"component.height\"\r\n #table\r\n [register]=\"component\"\r\n [componentRef]=\"table\" />\r\n </ng-container>\r\n <!-- #endregion -->\r\n <!-- #region button -->\r\n <ng-container *ngSwitchCase=\"'button'\">\r\n <ngx-sirio-button (clickEvent)=\"clickButton(component, $event)\"\r\n [color]=\"evaluateColor(component.color)\"\r\n [icon]=\"evaluateString(component.icon)\"\r\n [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n [disabled]=\"evaluateBoolean(component.disabled)\"\r\n #button\r\n [register]=\"component\"\r\n [componentRef]=\"button\">\r\n {{ evaluateString(component.label) }}\r\n </ngx-sirio-button>\r\n </ng-container>\r\n <!-- #endregion -->\r\n <!-- #region separator -->\r\n <ng-container *ngSwitchCase=\"'separator'\">\r\n <div class=\"separator\"\r\n [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n #separator\r\n [register]=\"component\"\r\n [componentRef]=\"separator\">\r\n </div>\r\n </ng-container>\r\n <!-- #endregion -->\r\n <!-- #region spacer -->\r\n <ng-container *ngSwitchCase=\"'spacer'\">\r\n <div style=\"width: 100%\"\r\n [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n [style.height.px]=\"component.height\"\r\n #spacer\r\n [register]=\"component\"\r\n [componentRef]=\"spacer\">\r\n </div>\r\n </ng-container>\r\n <!-- #endregion -->\r\n <!-- #region iframe -->\r\n <ng-container *ngSwitchCase=\"'iframe'\">\r\n <div [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n [show]=\"evaluateBoolean(component.conditional?.show)\">\r\n <label [for]=\"component.id\">{{ evaluateString(component.label) }}</label>\r\n <iframe [src]=\"evaluateUrl(component.url)\"\r\n [title]=\"evaluateString(component.label)\"\r\n [style.width]=\"'100%'\"\r\n [style.height.px]=\"component.height\"\r\n [frameSecurity]=\"component.security\"\r\n #iframe\r\n [register]=\"component\"\r\n [componentRef]=\"iframe\">\r\n </iframe>\r\n </div>\r\n </ng-container>\r\n <!-- #endregion -->\r\n <!-- #region alert -->\r\n <ng-container *ngSwitchCase=\"'alert'\">\r\n <ngx-sirio-alert [type]=\"component.role\"\r\n [labelClose]=\"Texts.Close\"\r\n [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n #alert\r\n [register]=\"component\"\r\n [componentRef]=\"alert\">\r\n <ngx-sirio-alert-message>\r\n <div class=\"text-paragraph\"\r\n [innerHTML]=\"toHTML(evaluateTemplate(component.text))\">\r\n </div>\r\n </ngx-sirio-alert-message>\r\n </ngx-sirio-alert>\r\n </ng-container>\r\n <!-- #endregion -->\r\n <!-- #region notice -->\r\n <ng-container *ngSwitchCase=\"'notice'\">\r\n <ngx-sirio-notify\r\n [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n #notice\r\n [register]=\"component\"\r\n [componentRef]=\"notice\">\r\n <ngx-sirio-notify-body [title]=\"evaluateString(component.title)\">\r\n <div class=\"text-paragraph\"\r\n [innerHTML]=\"toHTML(evaluateTemplate(component.text))\">\r\n </div>\r\n </ngx-sirio-notify-body>\r\n </ngx-sirio-notify>\r\n </ng-container>\r\n <!-- #endregion -->\r\n <!-- #region range -->\r\n <ng-container *ngSwitchCase=\"'range'\">\r\n <ngx-sirio-slider [label]=\"evaluateString(component.label)\"\r\n [labelPopover]=\"evaluateString(component.tooltip)\"\r\n [textHelp]=\"evaluateString(component.description)\"\r\n [textFeedback]=\"getTextFeedback(component)\"\r\n [readonly]=\"evaluateBoolean(component.readonly)\"\r\n [disableControl]=\"evaluateBoolean(component.disabled)\"\r\n [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n [formControlName]=\"component.key\"\r\n validation\r\n [canValidate]=\"true\"\r\n [isWarning]=\"isWarning(component)\"\r\n [showWhenValid]=\"false\"\r\n [min]=\"evaluateNumber(component.range?.min) ?? 0\"\r\n [max]=\"evaluateNumber(component.range?.max) ?? 0\"\r\n #range\r\n [register]=\"component\"\r\n [componentRef]=\"range\">\r\n </ngx-sirio-slider>\r\n </ng-container>\r\n <!-- #endregion -->\r\n </div>\r\n </ng-container>\r\n </ng-container>\r\n </div>\r\n</ng-container>\r\n", styles: [".field-set{align-items:center}.field-set>div{margin-top:10px;margin-bottom:10px}.separator{border-bottom:2px solid #d9e4f7;width:100%;margin:10px 0}.group-outline{border:1px solid #d9e4f7;padding:15px;margin-top:2px;margin-bottom:2px}.group-top .row{align-items:baseline}.group-center .row{align-items:center}.group-bottom .row{align-items:end}.text-paragraph p{margin-bottom:0!important}.sirio-control.ng-invalid .sirio-form-feedback{color:#aa224f;display:inline-block}.sirio-control.ng-invalid .sirio-input-group-text{color:#aa224f;border-color:#aa224f}.sirio-form-check.sirio-is-invalid input[type=checkbox]~label,.sirio-form-check.sirio-is-invalid input[type=checkbox]:checked~label{color:#aa224f}.sirio-form-check.sirio-is-invalid input[type=checkbox]~label:before,.sirio-form-check.sirio-is-invalid input[type=checkbox]:checked~label:before{border-color:#aa224f}.sirio-form-check.sirio-is-invalid input[type=checkbox]:checked~label:after{background-image:url(\"data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='512' height='512' viewBox='0 0 512 512'%3e%3cpath fill='%23AA224F' d='M173.898 439.404l-166.4-166.4c-9.997-9.997-9.997-26.206 0-36.204l36.203-36.204c9.997-9.998 26.207-9.998 36.204 0L192 312.69 432.095 72.596c9.997-9.997 26.207-9.997 36.204 0l36.203 36.204c9.997 9.997 9.997 26.206 0 36.204l-294.4 294.401c-9.998 9.997-26.207 9.997-36.204-.001z'/%3e%3c/svg%3e\");background-size:12px}.sirio-form-check.sirio-form-toggle input[type=checkbox].sirio-is-invalid~label,.sirio-form-check.sirio-form-toggle input[type=checkbox].sirio-is-invalid:checked~label{color:#aa224f}.sirio-form-check.sirio-form-toggle input[type=checkbox].sirio-is-invalid~label:before,.sirio-form-check.sirio-form-toggle input[type=checkbox].sirio-is-invalid:checked~label:before{border-color:#aa224f}.sirio-form-check.sirio-form-toggle input[type=checkbox].sirio-is-invalid~label:after,.sirio-form-check.sirio-form-toggle input[type=checkbox].sirio-is-invalid:checked~label:after{background-color:#aa224f}.sirio-control.sirio-is-invalid fieldset .sirio-form-check input[type=checkbox]~label,.sirio-control.sirio-is-invalid fieldset .sirio-form-check input[type=checkbox]:checked~label{color:#aa224f}.sirio-control.sirio-is-invalid fieldset .sirio-form-check input[type=checkbox]~label:before,.sirio-control.sirio-is-invalid fieldset .sirio-form-check input[type=checkbox]:checked~label:before{border-color:#aa224f}.sirio-control.sirio-is-invalid fieldset .sirio-form-check input[type=checkbox]:checked~label:after{background-image:url(\"data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='512' height='512' viewBox='0 0 512 512'%3e%3cpath fill='%23AA224F' d='M173.898 439.404l-166.4-166.4c-9.997-9.997-9.997-26.206 0-36.204l36.203-36.204c9.997-9.998 26.207-9.998 36.204 0L192 312.69 432.095 72.596c9.997-9.997 26.207-9.997 36.204 0l36.203 36.204c9.997 9.997 9.997 26.206 0 36.204l-294.4 294.401c-9.998 9.997-26.207 9.997-36.204-.001z'/%3e%3c/svg%3e\");background-size:12px}.sirio-control.sirio-is-invalid fieldset .sirio-chip-selection input[type=checkbox]+label{color:#aa224f;border-color:#aa224f}.sirio-control.sirio-is-invalid fieldset .sirio-chip-selection input[type=checkbox]:checked+label{color:#fff;background-color:#aa224f;border-color:#aa224f}.sirio-control.sirio-is-invalid fieldset .sirio-form-check input[type=radio]~label,.sirio-control.sirio-is-invalid fieldset .sirio-form-check input[type=radio]:checked~label{color:#aa224f}.sirio-control.sirio-is-invalid fieldset .sirio-form-check input[type=radio]~label:before,.sirio-control.sirio-is-invalid fieldset .sirio-form-check input[type=radio]:checked~label:before{border-color:#aa224f}.sirio-control.sirio-is-invalid fieldset .sirio-form-check input[type=radio]:checked~label:after{background-image:url(\"data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='512' height='512' viewBox='0 0 512 512'%3e%3cpath fill='%23AA224F' d='M173.898 439.404l-166.4-166.4c-9.997-9.997-9.997-26.206 0-36.204l36.203-36.204c9.997-9.998 26.207-9.998 36.204 0L192 312.69 432.095 72.596c9.997-9.997 26.207-9.997 36.204 0l36.203 36.204c9.997 9.997 9.997 26.206 0 36.204l-294.4 294.401c-9.998 9.997-26.207 9.997-36.204-.001z'/%3e%3c/svg%3e\");background-size:12px}.sirio-control.sirio-is-invalid fieldset .sirio-chip-selection input[type=radio]+label{color:#aa224f;border-color:#aa224f}.sirio-control.sirio-is-invalid fieldset .sirio-chip-selection input[type=radio]:checked+label{color:#fff;background-color:#aa224f;border-color:#aa224f}.sirio-upload.sirio-is-invalid button{background-color:#aa224f;border-color:#aa224f}.sirio-accordion .sirio-accordion-body .sirio-accordion-content{padding:16px}.ag-cell-value button.sirio-btn.sirio-btn-icon{padding:0}.sirio-tab.sirio-tab-scroll{display:block}.sirio-dropdown .searchable{position:absolute;width:100%;display:none;left:0}.ag-header-cell.hide-filter .ag-header-cell-filter-button{display:none}\n"], dependencies: [{ kind: "component", type: DynamicFieldsComponent, selector: "app-dynamic-fields", inputs: ["rows", "formGroup"] }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i9.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i9.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i9.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i9.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i9.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i9.NgSwitchDefault, selector: "[ngSwitchDefault]" }, { kind: "pipe", type: i9.AsyncPipe, name: "async" }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i10.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i10.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i10.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i10.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: i10.FormGroupName, selector: "[formGroupName]", inputs: ["formGroupName"] }, { kind: "directive", type: i10.FormArrayName, selector: "[formArrayName]", inputs: ["formArrayName"] }, { kind: "directive", type: AdornerDirective, selector: "[prefixAdorner], [suffixAdorner]", inputs: ["prefixAdorner", "suffixAdorner"] }, { kind: "directive", type: DisableDirective, selector: "[disableControl], [readonly]", inputs: ["disableControl", "readonly"] }, { kind: "directive", type: DisplayDirective, selector: "[hide], [show]", inputs: ["hide", "show"] }, { kind: "directive", type: FrameSecurityDirective, selector: "[frameSecurity]", inputs: ["frameSecurity"] }, { kind: "directive", type: DropdownDirective, selector: "[dropdown]" }, { kind: "directive", type: UpdateBlurDirective, selector: "[updateBlur]" }, { kind: "directive", type: RepeatDirective, selector: "[repeat]", inputs: ["repeat"] }, { kind: "directive", type: TabDirective, selector: "[tabCount]", inputs: ["tabCount"] }, { kind: "directive", type: GridDirective, selector: "[rowSource]", inputs: ["rowSource"] }, { kind: "directive", type: RegisterDirective, selector: "[register]", inputs: ["register", "componentRef"] }, { kind: "directive", type: AccordionDirective, selector: "[accordionCount]", inputs: ["accordionCount"] }, { kind: "component", type: SirioInputComponent, selector: "ngx-sirio-input", inputs: ["disabledState", "value", "label", "labelPopover", "ariaLabelPopoverButton", "type", "name", "placeholder", "textHelp", "textFeedback", "rows", "cols", "ariaLabel", "ariaAutocomplete", "ariaInvalid", "ariaDescribedBy", "role"], outputs: ["focusEvent", "inputEvent", "blurEvent", "keyupEvent", "keydownEvent"] }, { kind: "directive", type: SirioValidationDirective, selector: "[validation]", inputs: ["canValidate", "isWarning", "showWhenValid"] }, { kind: "component", type: SirioSelectComponent, selector: "ngx-sirio-select", inputs: ["placeholder", "disabledState", "value", "label", "labelPopover", "ariaLabelPopoverButton", "isMultiple", "textHelp", "textFeedback", "ariaLabel", "ariaInvalid", "ariaDescribedBy"], outputs: ["focusEvent", "blurEvent", "keydownEvent"] }, { kind: "component", type: SirioSelectOptionComponent, selector: "ngx-sirio-select-option", inputs: ["value"], outputs: ["optionSelected", "blurEvent"] }, { kind: "component", type: SirioSelectPanelComponent, selector: "ngx-sirio-select-panel", outputs: ["optionSelected", "panelOpened", "panelClosed"] }, { kind: "component", type: SirioCheckboxGroupComponent, selector: "ngx-sirio-checkbox-group", inputs: ["textHelp", "textFeedback", "label", "labelPopover", "ariaLabelPopoverButton", "ariaLabel", "ariaInvalid", "ariaDescribedBy", "disabledState", "value"], outputs: ["focusEvent", "blurEvent", "changeEvent"] }, { kind: "component", type: SirioCheckboxComponent, selector: "ngx-sirio-checkbox", inputs: ["disabled", "name", "textHelp", "textFeedback", "value", "ariaInvalid", "ariaDescribedBy", "disabledState", "checked"], outputs: ["focusEvent", "blurEvent", "changeEvent"] }, { kind: "component", type: SirioDatepickerComponent, selector: "ngx-sirio-datepicker", inputs: ["name", "placeholder", "textHelp", "textFeedback", "label", "labelPopover", "ariaLabelPopoverButton", "ariaLabel", "ariaAutocomplete", "ariaInvalid", "ariaDescribedBy", "value", "disabledState"], outputs: ["focusEvent", "inputEvent", "blurEvent", "keyupEvent", "keydownEvent", "datechangeEvent"] }, { kind: "component", type: SirioTimepickerComponent, selector: "ngx-sirio-timepicker", inputs: ["name", "label", "labelPopover", "ariaLabelPopoverButton", "placeholder", "textHelp", "textFeedback", "ariaLabel", "ariaAutocomplete", "ariaInvalid", "ariaDescribedBy", "disabledState", "value"], outputs: ["focusEvent", "inputEvent", "blurEvent", "keyupEvent", "keydownEvent"] }, { kind: "component", type: SirioRadioGroupComponent, selector: "ngx-sirio-radio-group", inputs: ["label", "labelPopover", "ariaLabelPopoverButton", "textHelp", "textFeedback", "items", "ariaLabel", "ariaInvalid", "ariaDescribedBy", "disabledState", "value"], outputs: ["focusEvent", "blurEvent", "changeEvent"] }, { kind: "component", type: SirioRadioButtonComponent, selector: "ngx-sirio-radio-button", inputs: ["disabledState", "label", "name", "textHelp", "textFeedback", "ariaInvalid", "ariaDescribedBy", "value", "checked"], outputs: ["focusEvent", "blurEvent", "changeEvent"] }, { kind: "component", type: SirioTabComponent, selector: "ngx-sirio-tab", inputs: ["isVertical", "isNavLine", "leftArrowLabel", "rightArrowLabel", "tabActive"], outputs: ["tabChange"] }, { kind: "component", type: SirioTabItemComponent, selector: "ngx-sirio-tab-item", inputs: ["label", "disabled", "icon"] }, { kind: "component", type: SirioAccordionComponent, selector: "ngx-sirio-accordion", inputs: ["dark"] }, { kind: "component", type: SirioAccordionPanelComponent, selector: "ngx-sirio-accordion-panel", inputs: ["active", "disabled"], outputs: ["opened", "closed"] }, { kind: "component", type: SirioAccordionHeaderComponent, selector: "ngx-sirio-accordion-header" }, { kind: "component", type: SirioAccordionBodyComponent, selector: "ngx-sirio-accordion-body" }, { kind: "component", type: SirioButtonComponent, selector: "ngx-sirio-button", inputs: ["ariaExpanded", "ariaControls", "ariaActivedescendant", "ariaHaspopup", "ariaLabel", "ariaRequired", "ariaInvalid", "ariaDescribedby", "icon", "title", "role", "color", "isFloating", "isExtended", "isLight", "isSmall", "disabled", "isDropdown", "type", "dismissType", "isBtnBlock"], outputs: ["clickEvent", "focusEvent", "blurEvent"] }, { kind: "component", type: SirioFileUploadComponent, selector: "ngx-sirio-file-upload", inputs: ["multiple", "color", "accept", "maxFiles", "showFilelist", "label", "labelPopover", "ariaLabelPopoverButton", "name", "textHelp", "textFeedback", "ariaLabel", "ariaLabelDeleteFileButton", "ariaInvalid", "ariaDescribedBy", "disabledState", "value"], outputs: ["focusEvent", "fileUploadedEvent", "fileDeletedEvent", "uploadErrorEvent", "blurEvent"] }, { kind: "component", type: SirioToggleComponent, selector: "ngx-sirio-toggle", inputs: ["name", "textHelp", "textFeedback", "ariaLabel", "ariaInvalid", "ariaDescribedBy", "disabledState", "value", "checked"], outputs: ["focusEvent", "blurEvent", "changeEvent"] }, { kind: "component", type: SirioChipCheckboxGroupComponent, selector: "ngx-sirio-chip-checkbox-group", inputs: ["label", "labelPopover", "ariaLabelPopoverButton", "textHelp", "textFeedback", "items", "ariaLabel", "ariaInvalid", "ariaDescribedBy", "disabledState", "value"], outputs: ["focusEvent", "blurEvent", "changeEvent"] }, { kind: "component", type: SirioChipRadioGroupComponent, selector: "ngx-sirio-chip-radio-group", inputs: ["label", "labelPopover", "ariaLabelPopoverButton", "textHelp", "textFeedback", "items", "ariaLabel", "ariaInvalid", "ariaDescribedBy", "disabledState", "value"], outputs: ["focusEvent", "blurEvent", "changeEvent"] }, { kind: "component", type: SirioInputChipComponent, selector: "ngx-sirio-input-chip", inputs: ["disabledState", "name", "textHelp", "textFeedback", "value", "ariaInvalid", "ariaDescribedBy", "type", "checked"], outputs: ["focusEvent", "blurEvent", "changeEvent"] }, { kind: "ngmodule", type: SirioTableModule }, { kind: "component", type: SirioAlertComponent, selector: "ngx-sirio-alert", inputs: ["type", "labelClose", "isVisible"], outputs: ["closeEvent"] }, { kind: "component", type: SirioAlertMessageComponent, selector: "ngx-sirio-alert-message" }, { kind: "component", type: SirioSliderComponent, selector: "ngx-sirio-slider", inputs: ["disabledState", "value", "label", "labelPopover", "ariaLabelPopoverButton", "description", "min", "max", "ariaInvalid", "ariaDescribedBy", "textHelp", "textFeedback"], outputs: ["focusEvent", "inputEvent", "blurEvent", "keyupEvent", "keydownEvent"] }, { kind: "component", type: SirioNotifyComponent, selector: "ngx-sirio-notify", inputs: ["isDark"] }, { kind: "component", type: SirioNotifyBodyComponent, selector: "ngx-sirio-notify-body", inputs: ["title"] }, { kind: "component", type: AgGridAngular, selector: "ag-grid-angular", inputs: ["gridOptions", "modules", "statusBar", "sideBar", "suppressContextMenu", "preventDefaultOnContextMenu", "allowContextMenuWithControlKey", "columnMenu", "suppressMenuHide", "enableBrowserTooltips", "tooltipTrigger", "tooltipShowDelay", "tooltipHideDelay", "tooltipMouseTrack", "tooltipShowMode", "tooltipInteraction", "popupParent", "copyHeadersToClipboard", "copyGroupHeadersToClipboard", "clipboardDelimiter", "suppressCopyRowsToClipboard", "suppressCopySingleCellRanges", "suppressLastEmptyLineOnPaste", "suppressClipboardPaste", "suppressClipboardApi", "suppressCutToClipboard", "columnDefs", "defaultColDef", "defaultColGroupDef", "columnTypes", "dataTypeDefinitions", "maintainColumnOrder", "enableStrictPivotColumnOrder", "suppressFieldDotNotation", "headerHeight", "groupHeaderHeight", "floatingFiltersHeight", "pivotHeaderHeight", "pivotGroupHeaderHeight", "allowDragFromColumnsToolPanel", "suppressMovableColumns", "suppressColumnMoveAnimation", "suppressMoveWhenColumnDragging", "suppressDragLeaveHidesColumns", "suppressGroupChangesColumnVisibility", "suppressMakeColumnVisibleAfterUnGroup", "suppressRowGroupHidesColumns", "colResizeDefault", "suppressAutoSize", "autoSizePadding", "skipHeaderOnAutoSize", "autoSizeStrategy", "components", "editType", "singleClickEdit", "suppressClickEdit", "readOnlyEdit", "stopEditingWhenCellsLoseFocus", "enterNavigatesVertically", "enterNavigatesVerticallyAfterEdit", "enableCellEditingOnBackspace", "undoRedoCellEditing", "undoRedoCellEditingLimit", "defaultCsvExportParams", "suppressCsvExport", "defaultExcelExportParams", "suppressExcelExport", "excelStyles", "quickFilterText", "cacheQuickFilter", "includeHiddenColumnsInQuickFilter", "quickFilterParser", "quickFilterMatcher", "applyQuickFilterBeforePivotOrAgg", "excludeChildrenWhenTreeDataFiltering", "enableAdvancedFilter", "alwaysPassFilter", "includeHiddenColumnsInAdvancedFilter", "advancedFilterParent", "advancedFilterBuilderParams", "suppressAdvancedFilterEval", "suppressSetFilterByDefault", "enableCharts", "chartThemes", "customChartThemes", "chartThemeOverrides", "chartToolPanelsDef", "chartMenuItems", "loadingCellRenderer", "loadingCellRendererParams", "loadingCellRendererSelector", "localeText", "masterDetail", "keepDetailRows", "keepDetailRowsCount", "detailCellRenderer", "detailCellRendererParams", "detailRowHeight", "detailRowAutoHeight", "context", "dragAndDropImageComponent", "dragAndDropImageComponentParams", "alignedGrids", "tabIndex", "rowBuffer", "valueCache", "valueCacheNeverExpires", "enableCellExpressions", "suppressTouch", "suppressFocusAfterRefresh", "suppressBrowserResizeObserver", "suppressPropertyNamesCheck", "suppressChangeDetection", "debug", "loading", "overlayLoadingTemplate", "loadingOverlayComponent", "loadingOverlayComponentParams", "suppressLoadingOverlay", "overlayNoRowsTemplate", "noRowsOverlayComponent", "noRowsOverlayComponentParams", "suppressNoRowsOverlay", "pagination", "paginationPageSize", "paginationPageSizeSelector", "paginationAutoPageSize", "paginateChildRows", "suppressPaginationPanel", "pivotMode", "pivotPanelShow", "pivotMaxGeneratedColumns", "pivotDefaultExpanded", "pivotColumnGroupTotals", "pivotRowTotals", "pivotSuppressAutoColumn", "suppressExpandablePivotGroups", "functionsReadOnly", "aggFuncs", "suppressAggFuncInHeader", "alwaysAggregateAtRootLevel", "aggregateOnlyChangedColumns", "suppressAggFilteredOnly", "removePivotHeaderRowWhenSingleValueColumn", "animateRows", "cellFlashDuration", "cellFadeDuration", "allowShowChangeAfterFilter", "domLayout", "ensureDomOrder", "enableRtl", "suppressColumnVirtualisation", "suppressMaxRenderedRowRestriction", "suppressRowVirtualisation", "rowDragManaged", "suppressRowDrag", "suppressMoveWhenRowDragging", "rowDragEntireRow", "rowDragMultiRow", "rowDragText", "fullWidthCellRenderer", "fullWidthCellRendererParams", "embedFullWidthRows", "groupDisplayType", "groupDefaultExpanded", "autoGroupColumnDef", "groupMaintainOrder", "groupSelectsChildren", "groupLockGroupColumns", "groupAggFiltering", "groupTotalRow", "grandTotalRow", "suppressStickyTotalRow", "groupSuppressBlankHeader", "groupSelectsFiltered", "showOpenedGroup", "groupHideParentOfSingleChild", "groupRemoveSingleChildren", "groupRemoveLowestSingleChildren", "groupHideOpenParents", "groupAllowUnbalanced", "rowGroupPanelShow", "groupRowRenderer", "groupRowRendererParams", "treeData", "rowGroupPanelSuppressSort", "suppressGroupRowsSticky", "pinnedTopRowData", "pinnedBottomRowData", "rowModelType", "rowData", "asyncTransactionWaitMillis", "suppressModelUpdateAfterUpdateTransaction", "datasource", "cacheOverflowSize", "infiniteInitialRowCount", "serverSideInitialRowCount", "suppressServerSideFullWidthLoadingRow", "cacheBlockSize", "maxBlocksInCache", "maxConcurrentDatasourceRequests", "blockLoadDebounceMillis", "purgeClosedRowNodes", "serverSideDatasource", "serverSideSortAllLevels", "serverSideEnableClientSideSort", "serverSideOnlyRefreshFilteredGroups", "serverSidePivotResultFieldSeparator", "viewportDatasource", "viewportRowModelPageSize", "viewportRowModelBufferSize", "alwaysShowHorizontalScroll", "alwaysShowVerticalScroll", "debounceVerticalScrollbar", "suppressHorizontalScroll", "suppressScrollOnNewData", "suppressScrollWhenPopupsAreOpen", "suppressAnimationFrame", "suppressMiddleClickScrolls", "suppressPreventDefaultOnMouseWheel", "scrollbarWidth", "rowSelection", "cellSelection", "rowMultiSelectWithClick", "suppressRowDeselection", "suppressRowClickSelection", "suppressCellFocus", "suppressHeaderFocus", "selectionColumnDef", "suppressMultiRangeSelection", "enableCellTextSelection", "enableRangeSelection", "enableRangeHandle", "enableFillHandle", "fillHandleDirection", "suppressClearOnFillReduction", "sortingOrder", "accentedSort", "unSortIcon", "suppressMultiSort", "alwaysMultiSort", "multiSortKey", "suppressMaintainUnsortedOrder", "icons", "rowHeight", "rowStyle", "rowClass", "rowClassRules", "suppressRowHoverHighlight", "suppressRowTransform", "columnHoverHighlight", "gridId", "deltaSort", "treeDataDisplayType", "enableGroupEdit", "initialState", "theme", "loadThemeGoogleFonts", "getContextMenuItems", "getMainMenuItems", "postProcessPopup", "processUnpinnedColumns", "processCellForClipboard", "processHeaderForClipboard", "processGroupHeaderForClipboard", "processCellFromClipboard", "sendToClipboard", "processDataFromClipboard", "isExternalFilterPresent", "doesExternalFilterPass", "getChartToolbarItems", "createChartContainer", "focusGridInnerElement", "navigateToNextHeader", "tabToNextHeader", "navigateToNextCell", "tabToNextCell", "getLocaleText", "getDocument", "paginationNumberFormatter", "getGroupRowAgg", "isGroupOpenByDefault", "initialGroupOrderComparator", "processPivotResultColDef", "processPivotResultColGroupDef", "getDataPath", "getChildCount", "getServerSideGroupLevelParams", "isServerSideGroupOpenByDefault", "isApplyServerSideTransaction", "isServerSideGroup", "getServerSideGroupKey", "getBusinessKeyForNode", "getRowId", "resetRowDataOnUpdate", "processRowPostCreate", "isRowSelectable", "isRowMaster", "fillOperation", "postSortRows", "getRowStyle", "getRowClass", "getRowHeight", "isFullWidthRow"], outputs: ["toolPanelVisibleChanged", "toolPanelSizeChanged", "columnMenuVisibleChanged", "contextMenuVisibleChanged", "cutStart", "cutEnd", "pasteStart", "pasteEnd", "columnVisible", "columnPinned", "columnResized", "columnMoved", "columnValueChanged", "columnPivotModeChanged", "columnPivotChanged", "columnGroupOpened", "newColumnsLoaded", "gridColumnsChanged", "displayedColumnsChanged", "virtualColumnsChanged", "columnEverythingChanged", "columnHeaderMouseOver", "columnHeaderMouseLeave", "columnHeaderClicked", "columnHeaderContextMenu", "componentStateChanged", "cellValueChanged", "cellEditRequest", "rowValueChanged", "cellEditingStarted", "cellEditingStopped", "rowEditingStarted", "rowEditingStopped", "undoStarted", "undoEnded", "redoStarted", "redoEnded", "cellSelectionDeleteStart", "cellSelectionDeleteEnd", "rangeDeleteStart", "rangeDeleteEnd", "fillStart", "fillEnd", "filterOpened", "filterChanged", "filterModified", "advancedFilterBuilderVisibleChanged", "chartCreated", "chartRangeSelectionChanged", "chartOptionsChanged", "chartDestroyed", "cellKeyDown", "gridReady", "firstDataRendered", "gridSizeChanged", "modelUpdated", "virtualRowRemoved", "viewportChanged", "bodyScroll", "bodyScrollEnd", "dragStarted", "dragStopped", "dragCancelled", "stateUpdated", "paginationChanged", "rowDragEnter", "rowDragMove", "rowDragLeave", "rowDragEnd", "rowDragCancel", "columnRowGroupChanged", "rowGroupOpened", "expandOrCollapseAll", "pivotMaxColumnsExceeded", "pinnedRowDataChanged", "rowDataUpdated", "asyncTransactionsFlushed", "storeRefreshed", "headerFocused", "cellClicked", "cellDoubleClicked", "cellFocused", "cellMouseOver", "cellMouseOut", "cellMouseDown", "rowClicked", "rowDoubleClicked", "rowSelected", "selectionChanged", "cellContextMenu", "rangeSelectionChanged", "cellSelectionChanged", "tooltipShow", "tooltipHide", "sortChanged"] }], encapsulation: i0.ViewEncapsulation.None });
|
|
467
|
+
}
|
|
468
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DynamicFieldsComponent, decorators: [{
|
|
469
|
+
type: Component,
|
|
470
|
+
args: [{ selector: 'app-dynamic-fields', standalone: true, imports: [CommonModule, ReactiveFormsModule,
|
|
471
|
+
AdornerDirective, DisableDirective, DisplayDirective, FrameSecurityDirective,
|
|
472
|
+
DropdownDirective, UpdateBlurDirective, RepeatDirective, TabDirective, GridDirective,
|
|
473
|
+
RegisterDirective, AccordionDirective,
|
|
474
|
+
SirioInputComponent, SirioValidationDirective,
|
|
475
|
+
SirioSelectComponent, SirioSelectOptionComponent, SirioSelectPanelComponent,
|
|
476
|
+
SirioCheckboxGroupComponent, SirioCheckboxComponent, SirioDatepickerComponent, SirioTimepickerComponent,
|
|
477
|
+
SirioRadioGroupComponent, SirioRadioButtonComponent, SirioTabComponent, SirioTabItemComponent,
|
|
478
|
+
SirioAccordionComponent, SirioAccordionPanelComponent, SirioAccordionHeaderComponent, SirioAccordionBodyComponent,
|
|
479
|
+
SirioButtonComponent, SirioFileUploadComponent,
|
|
480
|
+
SirioToggleComponent, SirioChipCheckboxGroupComponent, SirioChipRadioGroupComponent, SirioInputChipComponent,
|
|
481
|
+
SirioTableModule, SirioTableComponent, SirioPaginatorComponent,
|
|
482
|
+
SirioAlertComponent, SirioAlertMessageComponent, SirioSliderComponent,
|
|
483
|
+
SirioNotifyComponent, SirioNotifyBodyComponent, SirioNotifyActionComponent, SirioNotifyLinkComponent,
|
|
484
|
+
AgGridAngular], providers: [
|
|
485
|
+
RegisterService,
|
|
486
|
+
ProgrammabilityService
|
|
487
|
+
], encapsulation: ViewEncapsulation.None, template: "<ng-container *ngFor=\"let row of rows\" [formGroup]=\"formGroup\">\r\n <div class=\"row field-set\">\r\n <ng-container *ngFor=\"let component of row.components\">\r\n <ng-container [ngSwitch]=\"component.type\">\r\n <div [formGroup]=\"formGroup\" [class]=\"getClass(component)\">\r\n <!-- #region textfield -->\r\n <ng-container *ngSwitchCase=\"'textfield'\">\r\n <ngx-sirio-input type=\"text\"\r\n ariaLabel=\"input\"\r\n [label]=\"evaluateString(component.label)\"\r\n [labelPopover]=\"evaluateString(component.tooltip)\"\r\n [placeholder]=\"component.placeholder || ''\"\r\n [textHelp]=\"evaluateString(component.description)\"\r\n [textFeedback]=\"getTextFeedback(component)\"\r\n [prefixAdorner]=\"evaluateString(component.appearance?.prefixAdorner)\"\r\n [suffixAdorner]=\"evaluateString(component.appearance?.suffixAdorner)\"\r\n [readonly]=\"evaluateBoolean(component.readonly)\"\r\n [disableControl]=\"evaluateBoolean(component.disabled)\"\r\n [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n [formControlName]=\"component.key\"\r\n updateBlur\r\n validation\r\n [canValidate]=\"true\"\r\n [isWarning]=\"isWarning(component)\"\r\n [showWhenValid]=\"false\"\r\n #textfield\r\n [register]=\"component\"\r\n [componentRef]=\"textfield\">\r\n </ngx-sirio-input>\r\n </ng-container>\r\n <!-- #endregion -->\r\n <!-- #region select -->\r\n <ng-container *ngSwitchCase=\"'select'\">\r\n <ngx-sirio-select ariaLabel=\"select\"\r\n [label]=\"evaluateString(component.label)\"\r\n [labelPopover]=\"evaluateString(component.tooltip)\"\r\n [placeholder]=\"component.placeholder || ''\"\r\n [textHelp]=\"evaluateString(component.description)\"\r\n [textFeedback]=\"getTextFeedback(component)\"\r\n [readonly]=\"evaluateBoolean(component.readonly)\"\r\n [disableControl]=\"evaluateBoolean(component.disabled)\"\r\n [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n [formControlName]=\"component.key\"\r\n validation\r\n [canValidate]=\"true\"\r\n [isWarning]=\"isWarning(component)\"\r\n [showWhenValid]=\"false\"\r\n dropdown\r\n #select\r\n [register]=\"component\"\r\n [componentRef]=\"select\">\r\n <ngx-sirio-select-panel ariaLabel=\"items\">\r\n <ngx-sirio-input *ngIf=\"component.searchable\" class=\"searchable\" type=\"text\" [placeholder]=\"Texts.TypeToSearch\"></ngx-sirio-input>\r\n <ngx-sirio-select-option *ngFor=\"let option of (getValues(component) | async) || []\" [value]=\"option.value\">{{ option.label }}</ngx-sirio-select-option>\r\n </ngx-sirio-select-panel>\r\n </ngx-sirio-select>\r\n </ng-container>\r\n <!-- #endregion -->\r\n <!-- #region taglist -->\r\n <ng-container *ngSwitchCase=\"'taglist'\">\r\n <ngx-sirio-select ariaLabel=\"select\"\r\n [label]=\"evaluateString(component.label)\"\r\n [labelPopover]=\"evaluateString(component.tooltip)\"\r\n [placeholder]=\"component.placeholder || ''\"\r\n [textHelp]=\"evaluateString(component.description)\"\r\n [textFeedback]=\"getTextFeedback(component)\"\r\n [readonly]=\"evaluateBoolean(component.readonly)\"\r\n [disableControl]=\"evaluateBoolean(component.disabled)\"\r\n [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n [isMultiple]=\"true\"\r\n [formControlName]=\"component.key\"\r\n validation\r\n [canValidate]=\"true\"\r\n [isWarning]=\"isWarning(component)\"\r\n [showWhenValid]=\"false\"\r\n #taglist\r\n [register]=\"component\"\r\n [componentRef]=\"taglist\">\r\n <ngx-sirio-select-panel ariaLabel=\"items\">\r\n <ngx-sirio-select-option *ngFor=\"let option of (getValues(component) | async) || []\" [value]=\"option.value\">{{ option.label }}</ngx-sirio-select-option>\r\n </ngx-sirio-select-panel>\r\n </ngx-sirio-select>\r\n </ng-container>\r\n <!-- #endregion -->\r\n <!-- #region number -->\r\n <ng-container *ngSwitchCase=\"'number'\">\r\n <ngx-sirio-input type=\"number\"\r\n ariaLabel=\"input\"\r\n [label]=\"evaluateString(component.label)\"\r\n [labelPopover]=\"evaluateString(component.tooltip)\"\r\n [placeholder]=\"component.placeholder || ''\"\r\n [textHelp]=\"evaluateString(component.description)\"\r\n [textFeedback]=\"getTextFeedback(component)\"\r\n [prefixAdorner]=\"evaluateString(component.appearance?.prefixAdorner)\"\r\n [suffixAdorner]=\"evaluateString(component.appearance?.suffixAdorner)\"\r\n [readonly]=\"evaluateBoolean(component.readonly)\"\r\n [disableControl]=\"evaluateBoolean(component.disabled)\"\r\n [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n [formControlName]=\"component.key\"\r\n updateBlur\r\n validation\r\n [canValidate]=\"true\"\r\n [isWarning]=\"isWarning(component)\"\r\n [showWhenValid]=\"false\"\r\n #number\r\n [register]=\"component\"\r\n [componentRef]=\"number\">\r\n </ngx-sirio-input>\r\n </ng-container>\r\n <!-- #endregion -->\r\n <!-- #region datetime -->\r\n <ng-container *ngSwitchCase=\"'datetime'\">\r\n <ng-container [ngSwitch]=\"component.subtype\">\r\n <!-- #region date -->\r\n <ng-container *ngSwitchCase=\"'date'\">\r\n <ngx-sirio-datepicker ariaLabel=\"date\"\r\n [label]=\"evaluateString(component.dateLabel)\"\r\n [labelPopover]=\"evaluateString(component.tooltip)\"\r\n [placeholder]=\"component.placeholder || ''\"\r\n [textHelp]=\"evaluateString(component.description)\"\r\n [textFeedback]=\"getTextFeedback(component)\"\r\n [readonly]=\"evaluateBoolean(component.readonly)\"\r\n [disableControl]=\"evaluateBoolean(component.disabled)\"\r\n [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n [formControlName]=\"component.key\"\r\n validation\r\n [canValidate]=\"true\"\r\n [isWarning]=\"isWarning(component)\"\r\n [showWhenValid]=\"false\"\r\n #date\r\n [register]=\"component\"\r\n [componentRef]=\"date\">\r\n </ngx-sirio-datepicker>\r\n </ng-container>\r\n <!-- #endregion -->\r\n <!-- #region time -->\r\n <ng-container *ngSwitchCase=\"'time'\">\r\n <ngx-sirio-timepicker ariaLabel=\"time\"\r\n [label]=\"evaluateString(component.timeLabel)\"\r\n [labelPopover]=\"evaluateString(component.tooltip)\"\r\n [placeholder]=\"component.placeholder || ''\"\r\n [textHelp]=\"evaluateString(component.description)\"\r\n [textFeedback]=\"getTextFeedback(component)\"\r\n [readonly]=\"evaluateBoolean(component.readonly)\"\r\n [disableControl]=\"evaluateBoolean(component.disabled)\"\r\n [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n [formControlName]=\"component.key\"\r\n validation\r\n [canValidate]=\"true\"\r\n [isWarning]=\"isWarning(component)\"\r\n [showWhenValid]=\"false\"\r\n #time\r\n [register]=\"component\"\r\n [componentRef]=\"time\">\r\n </ngx-sirio-timepicker>\r\n </ng-container>\r\n <!-- #endregion -->\r\n </ng-container>\r\n </ng-container>\r\n <!-- #endregion -->\r\n <!-- #region checkbox -->\r\n <ng-container *ngSwitchCase=\"'checkbox'\">\r\n <ng-container [ngSwitch]=\"component.subtype\">\r\n <!-- #region toggle -->\r\n <ng-container *ngSwitchCase=\"'toggle'\">\r\n <ngx-sirio-toggle ariaLabel=\"checkbox\"\r\n [textHelp]=\"evaluateString(component.description)\"\r\n [textFeedback]=\"getTextFeedback(component)\"\r\n [readonly]=\"evaluateBoolean(component.readonly)\"\r\n [disableControl]=\"evaluateBoolean(component.disabled)\"\r\n [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n [formControlName]=\"component.key\"\r\n validation\r\n [canValidate]=\"true\"\r\n [isWarning]=\"isWarning(component)\"\r\n [showWhenValid]=\"false\"\r\n #toggle\r\n [register]=\"component\"\r\n [componentRef]=\"toggle\">\r\n {{ evaluateString(component.label) }}\r\n </ngx-sirio-toggle>\r\n </ng-container>\r\n <!-- #endregion -->\r\n <!-- #region default -->\r\n <ng-container *ngSwitchDefault>\r\n <ngx-sirio-checkbox ariaLabel=\"checkbox\"\r\n [textHelp]=\"evaluateString(component.description)\"\r\n [textFeedback]=\"getTextFeedback(component)\"\r\n [readonly]=\"evaluateBoolean(component.readonly)\"\r\n [disableControl]=\"evaluateBoolean(component.disabled)\"\r\n [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n [formControlName]=\"component.key\"\r\n validation\r\n [canValidate]=\"true\"\r\n [isWarning]=\"isWarning(component)\"\r\n [showWhenValid]=\"false\"\r\n #checkbox\r\n [register]=\"component\"\r\n [componentRef]=\"checkbox\">\r\n {{ evaluateString(component.label) }}\r\n </ngx-sirio-checkbox>\r\n </ng-container>\r\n <!-- #endregion -->\r\n </ng-container>\r\n </ng-container>\r\n <!-- #endregion -->\r\n <!-- #region radio -->\r\n <ng-container *ngSwitchCase=\"'radio'\">\r\n <ng-container [ngSwitch]=\"component.subtype\">\r\n <!-- #region chip -->\r\n <ng-container *ngSwitchCase=\"'chip'\">\r\n <ngx-sirio-chip-radio-group ariaLabel=\"radio\"\r\n [label]=\"evaluateString(component.label)\"\r\n [labelPopover]=\"evaluateString(component.tooltip)\"\r\n [textHelp]=\"evaluateString(component.description)\"\r\n [textFeedback]=\"getTextFeedback(component)\"\r\n [readonly]=\"evaluateBoolean(component.readonly)\"\r\n [disableControl]=\"evaluateBoolean(component.disabled)\"\r\n [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n [formControlName]=\"component.key\"\r\n validation\r\n [canValidate]=\"true\"\r\n [isWarning]=\"isWarning(component)\"\r\n [showWhenValid]=\"false\"\r\n #chipradio\r\n [register]=\"component\"\r\n [componentRef]=\"chipradio\">\r\n <ngx-sirio-input-chip *ngFor=\"let option of (getValues(component) | async) || []\"\r\n type=\"radio\"\r\n [value]=\"option.value\">\r\n {{ option.label }}\r\n </ngx-sirio-input-chip>\r\n </ngx-sirio-chip-radio-group>\r\n </ng-container>\r\n <!-- #endregion -->\r\n <!-- #region default -->\r\n <ng-container *ngSwitchDefault>\r\n <ngx-sirio-radio-group ariaLabel=\"radio\"\r\n [label]=\"evaluateString(component.label)\"\r\n [labelPopover]=\"evaluateString(component.tooltip)\"\r\n [textHelp]=\"evaluateString(component.description)\"\r\n [textFeedback]=\"getTextFeedback(component)\"\r\n [readonly]=\"evaluateBoolean(component.readonly)\"\r\n [disableControl]=\"evaluateBoolean(component.disabled)\"\r\n [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n [formControlName]=\"component.key\"\r\n validation\r\n [canValidate]=\"true\"\r\n [isWarning]=\"isWarning(component)\"\r\n [showWhenValid]=\"false\"\r\n #radio\r\n [register]=\"component\"\r\n [componentRef]=\"radio\">\r\n <ngx-sirio-radio-button *ngFor=\"let option of (getValues(component) | async) || []\" [value]=\"option.value\">\r\n {{ option.label }}\r\n </ngx-sirio-radio-button>\r\n </ngx-sirio-radio-group>\r\n </ng-container>\r\n <!-- #endregion -->\r\n </ng-container>\r\n </ng-container>\r\n <!-- #endregion -->\r\n <!-- #region checklist -->\r\n <ng-container *ngSwitchCase=\"'checklist'\">\r\n <ng-container [ngSwitch]=\"component.subtype\">\r\n <!-- #region chip -->\r\n <ng-container *ngSwitchCase=\"'chip'\">\r\n <ngx-sirio-chip-checkbox-group ariaLabel=\"checklist\"\r\n [label]=\"evaluateString(component.label)\"\r\n [labelPopover]=\"evaluateString(component.tooltip)\"\r\n [textHelp]=\"evaluateString(component.description)\"\r\n [textFeedback]=\"getTextFeedback(component)\"\r\n [readonly]=\"evaluateBoolean(component.readonly)\"\r\n [disableControl]=\"evaluateBoolean(component.disabled)\"\r\n [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n [formControlName]=\"component.key\"\r\n validation\r\n [canValidate]=\"true\"\r\n [isWarning]=\"isWarning(component)\"\r\n [showWhenValid]=\"false\"\r\n #chipcheckbox\r\n [register]=\"component\"\r\n [componentRef]=\"chipcheckbox\">\r\n <ngx-sirio-input-chip *ngFor=\"let option of (getValues(component) | async) || []\"\r\n type=\"checkbox\"\r\n [value]=\"option.value\">\r\n {{ option.label }}\r\n </ngx-sirio-input-chip>\r\n </ngx-sirio-chip-checkbox-group>\r\n </ng-container>\r\n <!-- #endregion -->\r\n <!-- #region default -->\r\n <ng-container *ngSwitchDefault>\r\n <ngx-sirio-checkbox-group ariaLabel=\"checklist\"\r\n [label]=\"evaluateString(component.label)\"\r\n [labelPopover]=\"evaluateString(component.tooltip)\"\r\n [textHelp]=\"evaluateString(component.description)\"\r\n [textFeedback]=\"getTextFeedback(component)\"\r\n [readonly]=\"evaluateBoolean(component.readonly)\"\r\n [disableControl]=\"evaluateBoolean(component.disabled)\"\r\n [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n [formControlName]=\"component.key\"\r\n validation\r\n [canValidate]=\"true\"\r\n [isWarning]=\"isWarning(component)\"\r\n [showWhenValid]=\"false\"\r\n #checkbox\r\n [register]=\"component\"\r\n [componentRef]=\"checkbox\">\r\n <ngx-sirio-checkbox *ngFor=\"let option of (getValues(component) | async) || []\" [value]=\"option.value\">\r\n {{ option.label }}\r\n </ngx-sirio-checkbox>\r\n </ngx-sirio-checkbox-group>\r\n </ng-container>\r\n <!-- #endregion -->\r\n </ng-container>\r\n </ng-container>\r\n <!-- #endregion -->\r\n <!-- #region textarea -->\r\n <ng-container *ngSwitchCase=\"'textarea'\">\r\n <ngx-sirio-input type=\"textarea\"\r\n ariaLabel=\"textarea\"\r\n [label]=\"evaluateString(component.label)\"\r\n [labelPopover]=\"evaluateString(component.tooltip)\"\r\n [placeholder]=\"component.placeholder || ''\"\r\n [readonly]=\"evaluateBoolean(component.readonly)\"\r\n [disableControl]=\"evaluateBoolean(component.disabled)\"\r\n [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n [textHelp]=\"evaluateString(component.description)\"\r\n [textFeedback]=\"getTextFeedback(component)\"\r\n [formControlName]=\"component.key\"\r\n updateBlur\r\n validation\r\n [canValidate]=\"true\"\r\n [isWarning]=\"isWarning(component)\"\r\n [showWhenValid]=\"false\"\r\n #textarea\r\n [register]=\"component\"\r\n [componentRef]=\"textarea\">\r\n </ngx-sirio-input>\r\n </ng-container>\r\n <!-- #endregion -->\r\n <!-- #region filepicker -->\r\n <ng-container *ngSwitchCase=\"'filepicker'\">\r\n <ngx-sirio-file-upload ariaLabel=\"filepicker\"\r\n [label]=\"evaluateString(component.label)\"\r\n [labelPopover]=\"evaluateString(component.tooltip)\"\r\n [accept]=\"getMimeTypes(component.accept)\"\r\n [multiple]=\"evaluateBoolean(component.multiple)\"\r\n (fileUploadedEvent)=\"fileUploaded($event)\"\r\n [showFilelist]=\"!component.showDetails\"\r\n [textHelp]=\"evaluateString(component.description)\"\r\n [textFeedback]=\"getTextFeedback(component)\"\r\n [readonly]=\"evaluateBoolean(component.readonly)\"\r\n [disableControl]=\"evaluateBoolean(component.disabled)\"\r\n [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n [formControlName]=\"component.key\"\r\n validation\r\n [canValidate]=\"true\"\r\n [isWarning]=\"isWarning(component)\"\r\n [showWhenValid]=\"false\"\r\n #filepicker\r\n [register]=\"component\"\r\n [componentRef]=\"filepicker\">\r\n <span class=\"fas fa-arrow-up\" aria-hidden=\"true\"></span>\r\n {{ Texts.Upload }}\r\n </ngx-sirio-file-upload>\r\n <ng-container *ngIf=\"component.showDetails\">\r\n <app-dynamic-fields [formGroup]=\"formGroup\" [rows]=\"createUploadTables(component)\"></app-dynamic-fields>\r\n </ng-container>\r\n </ng-container>\r\n <!-- #endregion -->\r\n <!-- #region text -->\r\n <ng-container *ngSwitchCase=\"'text'\">\r\n <div class=\"text-paragraph\"\r\n [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n [innerHTML]=\"toHTML(evaluateTemplate(component.text))\"\r\n #text\r\n [register]=\"component\"\r\n [componentRef]=\"text\">\r\n </div>\r\n </ng-container>\r\n <!-- #endregion -->\r\n <!-- #region html -->\r\n <ng-container *ngSwitchCase=\"'html'\">\r\n <div class=\"html-paragraph\"\r\n [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n [innerHTML]=\"sanitize(evaluateTemplate(component.content))\"\r\n #html\r\n [register]=\"component\"\r\n [componentRef]=\"html\">\r\n </div>\r\n </ng-container>\r\n <!-- #endregion -->\r\n <!-- #region image -->\r\n <ng-container *ngSwitchCase=\"'image'\">\r\n <img [src]=\"evaluateString(component.source)\"\r\n [alt]=\"evaluateString(component.alt)\"\r\n [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n style=\"width: 100%;height: 100%;\"\r\n #image\r\n [register]=\"component\"\r\n [componentRef]=\"image\">\r\n </ng-container>\r\n <!-- #endregion -->\r\n <!-- #region dynamiclist -->\r\n <ng-container *ngSwitchCase=\"'dynamiclist'\">\r\n <ng-container [formArrayName]=\"component.path\" [repeat]=\"evaluateNumber(component.repetitions)\">\r\n <ng-container [ngSwitch]=\"component.subtype\">\r\n <ng-container *ngIf=\"getFormArray(formGroup.get(component.path)).controls.length > 0\">\r\n <!-- #region tab -->\r\n <ng-container *ngSwitchCase=\"'tab'\">\r\n <div [register]=\"component\"\r\n [componentRef]=\"dynamiclisttab\">\r\n <ngx-sirio-tab [leftArrowLabel]=\"Texts.ScrollLeft\"\r\n [rightArrowLabel]=\"Texts.ScrollRight\"\r\n [tabCount]=\"getFormArray(formGroup.get(component.path)).controls.length\"\r\n #dynamiclisttab>\r\n <ng-container *ngFor=\"let item of getFormArray(formGroup.get(component.path)).controls; let i = index;\" [formGroupName]=\"i\">\r\n <ngx-sirio-tab-item [label]=\"component.label + ' ' + (i + 1)\">\r\n <!--<ng-container *ngTemplateOutlet=\"itemTemplate; context: { item: item, index: i }\"></ng-container>-->\r\n <div [ngClass]=\"{\r\n 'group-top': component.verticalAlignment === 'start',\r\n 'group-center': component.verticalAlignment === 'center',\r\n 'group-bottom': component.verticalAlignment === 'end'}\">\r\n <div>\r\n <app-dynamic-fields [formGroup]=\"getFormGroup(item)\" [rows]=\"component.rows\"></app-dynamic-fields>\r\n </div>\r\n <ng-container *ngIf=\"component.allowAddRemove\">\r\n <div style=\"text-align:right\">\r\n <ngx-sirio-button (click)=\"removeItem(component, i)\" class=\"remove-item\" [color]=\"null\" icon=\"fas fa-trash\">{{ Texts.RemoveItem }}</ngx-sirio-button>\r\n </div>\r\n </ng-container>\r\n </div>\r\n </ngx-sirio-tab-item>\r\n </ng-container>\r\n </ngx-sirio-tab>\r\n </div>\r\n </ng-container>\r\n <!-- #endregion -->\r\n <!-- #region accordion -->\r\n <ng-container *ngSwitchCase=\"'accordion'\">\r\n <div [register]=\"component\"\r\n [componentRef]=\"dynamiclistaccordion\">\r\n <ngx-sirio-accordion [accordionCount]=\"getFormArray(formGroup.get(component.path)).controls.length\"\r\n #dynamiclistaccordion>\r\n <ng-container *ngFor=\"let item of getFormArray(formGroup.get(component.path)).controls; let i = index;\" [formGroupName]=\"i\">\r\n <ngx-sirio-accordion-panel>\r\n <ngx-sirio-accordion-header>\r\n <span [innerText]=\"component.label + ' ' + (i + 1)\"></span>\r\n </ngx-sirio-accordion-header>\r\n <ngx-sirio-accordion-body>\r\n <!--<ng-container *ngTemplateOutlet=\"itemTemplate; context: { item: item, index: i }\"></ng-container>-->\r\n <div [ngClass]=\"{\r\n 'group-top': component.verticalAlignment === 'start',\r\n 'group-center': component.verticalAlignment === 'center',\r\n 'group-bottom': component.verticalAlignment === 'end'}\">\r\n <div>\r\n <app-dynamic-fields [formGroup]=\"getFormGroup(item)\" [rows]=\"component.rows\"></app-dynamic-fields>\r\n </div>\r\n <ng-container *ngIf=\"component.allowAddRemove\">\r\n <div style=\"text-align:right\">\r\n <ngx-sirio-button (click)=\"removeItem(component, i)\" class=\"remove-item\" [color]=\"null\" icon=\"fas fa-trash\">{{ Texts.RemoveItem }}</ngx-sirio-button>\r\n </div>\r\n </ng-container>\r\n </div>\r\n </ngx-sirio-accordion-body>\r\n </ngx-sirio-accordion-panel>\r\n </ng-container>\r\n </ngx-sirio-accordion>\r\n </div>\r\n </ng-container>\r\n <!-- #endregion -->\r\n <!-- #region default -->\r\n <ng-container *ngSwitchDefault>\r\n <div [ngClass]=\"{'group-outline': component.showOutline === true}\"\r\n #dynamiclist\r\n [register]=\"component\"\r\n [componentRef]=\"dynamiclist\">\r\n <label>{{ evaluateString(component.label) }}</label>\r\n <ng-container *ngFor=\"let item of getFormArray(formGroup.get(component.path)).controls; let i = index;\" [formGroupName]=\"i\">\r\n <div [ngClass]=\"{\r\n 'group-top': component.verticalAlignment === 'start',\r\n 'group-center': component.verticalAlignment === 'center',\r\n 'group-bottom': component.verticalAlignment === 'end'}\">\r\n <div>\r\n <app-dynamic-fields [formGroup]=\"getFormGroup(item)\" [rows]=\"component.rows\"></app-dynamic-fields>\r\n </div>\r\n <ng-container *ngIf=\"component.allowAddRemove\">\r\n <div style=\"text-align:right\">\r\n <ngx-sirio-button (click)=\"removeItem(component, i)\" class=\"remove-item\" [color]=\"null\" icon=\"fas fa-trash\">{{ Texts.RemoveItem }}</ngx-sirio-button>\r\n </div>\r\n </ng-container>\r\n </div>\r\n </ng-container>\r\n </div>\r\n </ng-container>\r\n <!-- #endregion -->\r\n </ng-container> \r\n <ng-container *ngIf=\"component.allowAddRemove\">\r\n <ngx-sirio-button (click)=\"addNewItem(component)\" class=\"add-item\" [color]=\"null\" icon=\"fas fa-plus\">{{ Texts.AddItem }}</ngx-sirio-button>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n <!-- #endregion -->\r\n <!-- #region group -->\r\n <ng-container *ngSwitchCase=\"'group'\">\r\n <div [ngClass]=\"{\r\n 'group-outline': component.showOutline === true,\r\n 'group-top': component.verticalAlignment === 'start',\r\n 'group-center': component.verticalAlignment === 'center',\r\n 'group-bottom': component.verticalAlignment === 'end'}\"\r\n [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n [show]=\"evaluateBoolean(component.conditional?.show)\">\r\n <label>{{ evaluateString(component.label) }}</label>\r\n <div #group\r\n [register]=\"component\"\r\n [componentRef]=\"group\">\r\n <app-dynamic-fields [formGroup]=\"getFormGroup(getControlFromPath(component.path))\"\r\n [rows]=\"component.rows\"></app-dynamic-fields>\r\n </div>\r\n </div>\r\n </ng-container>\r\n <!-- #endregion -->\r\n <!-- #region table -->\r\n <ng-container *ngSwitchCase=\"'table'\">\r\n <ag-grid-angular [modules]=\"getGridModules(component)\"\r\n [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n [gridOptions]=\"getGridOptions(component)\"\r\n [rowSource]=\"(getGridData(component) | async) || []\"\r\n [style.height.px]=\"component.height\"\r\n #table\r\n [register]=\"component\"\r\n [componentRef]=\"table\" />\r\n </ng-container>\r\n <!-- #endregion -->\r\n <!-- #region button -->\r\n <ng-container *ngSwitchCase=\"'button'\">\r\n <ngx-sirio-button (clickEvent)=\"clickButton(component, $event)\"\r\n [color]=\"evaluateColor(component.color)\"\r\n [icon]=\"evaluateString(component.icon)\"\r\n [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n [disabled]=\"evaluateBoolean(component.disabled)\"\r\n #button\r\n [register]=\"component\"\r\n [componentRef]=\"button\">\r\n {{ evaluateString(component.label) }}\r\n </ngx-sirio-button>\r\n </ng-container>\r\n <!-- #endregion -->\r\n <!-- #region separator -->\r\n <ng-container *ngSwitchCase=\"'separator'\">\r\n <div class=\"separator\"\r\n [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n #separator\r\n [register]=\"component\"\r\n [componentRef]=\"separator\">\r\n </div>\r\n </ng-container>\r\n <!-- #endregion -->\r\n <!-- #region spacer -->\r\n <ng-container *ngSwitchCase=\"'spacer'\">\r\n <div style=\"width: 100%\"\r\n [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n [style.height.px]=\"component.height\"\r\n #spacer\r\n [register]=\"component\"\r\n [componentRef]=\"spacer\">\r\n </div>\r\n </ng-container>\r\n <!-- #endregion -->\r\n <!-- #region iframe -->\r\n <ng-container *ngSwitchCase=\"'iframe'\">\r\n <div [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n [show]=\"evaluateBoolean(component.conditional?.show)\">\r\n <label [for]=\"component.id\">{{ evaluateString(component.label) }}</label>\r\n <iframe [src]=\"evaluateUrl(component.url)\"\r\n [title]=\"evaluateString(component.label)\"\r\n [style.width]=\"'100%'\"\r\n [style.height.px]=\"component.height\"\r\n [frameSecurity]=\"component.security\"\r\n #iframe\r\n [register]=\"component\"\r\n [componentRef]=\"iframe\">\r\n </iframe>\r\n </div>\r\n </ng-container>\r\n <!-- #endregion -->\r\n <!-- #region alert -->\r\n <ng-container *ngSwitchCase=\"'alert'\">\r\n <ngx-sirio-alert [type]=\"component.role\"\r\n [labelClose]=\"Texts.Close\"\r\n [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n #alert\r\n [register]=\"component\"\r\n [componentRef]=\"alert\">\r\n <ngx-sirio-alert-message>\r\n <div class=\"text-paragraph\"\r\n [innerHTML]=\"toHTML(evaluateTemplate(component.text))\">\r\n </div>\r\n </ngx-sirio-alert-message>\r\n </ngx-sirio-alert>\r\n </ng-container>\r\n <!-- #endregion -->\r\n <!-- #region notice -->\r\n <ng-container *ngSwitchCase=\"'notice'\">\r\n <ngx-sirio-notify\r\n [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n #notice\r\n [register]=\"component\"\r\n [componentRef]=\"notice\">\r\n <ngx-sirio-notify-body [title]=\"evaluateString(component.title)\">\r\n <div class=\"text-paragraph\"\r\n [innerHTML]=\"toHTML(evaluateTemplate(component.text))\">\r\n </div>\r\n </ngx-sirio-notify-body>\r\n </ngx-sirio-notify>\r\n </ng-container>\r\n <!-- #endregion -->\r\n <!-- #region range -->\r\n <ng-container *ngSwitchCase=\"'range'\">\r\n <ngx-sirio-slider [label]=\"evaluateString(component.label)\"\r\n [labelPopover]=\"evaluateString(component.tooltip)\"\r\n [textHelp]=\"evaluateString(component.description)\"\r\n [textFeedback]=\"getTextFeedback(component)\"\r\n [readonly]=\"evaluateBoolean(component.readonly)\"\r\n [disableControl]=\"evaluateBoolean(component.disabled)\"\r\n [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n [formControlName]=\"component.key\"\r\n validation\r\n [canValidate]=\"true\"\r\n [isWarning]=\"isWarning(component)\"\r\n [showWhenValid]=\"false\"\r\n [min]=\"evaluateNumber(component.range?.min) ?? 0\"\r\n [max]=\"evaluateNumber(component.range?.max) ?? 0\"\r\n #range\r\n [register]=\"component\"\r\n [componentRef]=\"range\">\r\n </ngx-sirio-slider>\r\n </ng-container>\r\n <!-- #endregion -->\r\n </div>\r\n </ng-container>\r\n </ng-container>\r\n </div>\r\n</ng-container>\r\n", styles: [".field-set{align-items:center}.field-set>div{margin-top:10px;margin-bottom:10px}.separator{border-bottom:2px solid #d9e4f7;width:100%;margin:10px 0}.group-outline{border:1px solid #d9e4f7;padding:15px;margin-top:2px;margin-bottom:2px}.group-top .row{align-items:baseline}.group-center .row{align-items:center}.group-bottom .row{align-items:end}.text-paragraph p{margin-bottom:0!important}.sirio-control.ng-invalid .sirio-form-feedback{color:#aa224f;display:inline-block}.sirio-control.ng-invalid .sirio-input-group-text{color:#aa224f;border-color:#aa224f}.sirio-form-check.sirio-is-invalid input[type=checkbox]~label,.sirio-form-check.sirio-is-invalid input[type=checkbox]:checked~label{color:#aa224f}.sirio-form-check.sirio-is-invalid input[type=checkbox]~label:before,.sirio-form-check.sirio-is-invalid input[type=checkbox]:checked~label:before{border-color:#aa224f}.sirio-form-check.sirio-is-invalid input[type=checkbox]:checked~label:after{background-image:url(\"data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='512' height='512' viewBox='0 0 512 512'%3e%3cpath fill='%23AA224F' d='M173.898 439.404l-166.4-166.4c-9.997-9.997-9.997-26.206 0-36.204l36.203-36.204c9.997-9.998 26.207-9.998 36.204 0L192 312.69 432.095 72.596c9.997-9.997 26.207-9.997 36.204 0l36.203 36.204c9.997 9.997 9.997 26.206 0 36.204l-294.4 294.401c-9.998 9.997-26.207 9.997-36.204-.001z'/%3e%3c/svg%3e\");background-size:12px}.sirio-form-check.sirio-form-toggle input[type=checkbox].sirio-is-invalid~label,.sirio-form-check.sirio-form-toggle input[type=checkbox].sirio-is-invalid:checked~label{color:#aa224f}.sirio-form-check.sirio-form-toggle input[type=checkbox].sirio-is-invalid~label:before,.sirio-form-check.sirio-form-toggle input[type=checkbox].sirio-is-invalid:checked~label:before{border-color:#aa224f}.sirio-form-check.sirio-form-toggle input[type=checkbox].sirio-is-invalid~label:after,.sirio-form-check.sirio-form-toggle input[type=checkbox].sirio-is-invalid:checked~label:after{background-color:#aa224f}.sirio-control.sirio-is-invalid fieldset .sirio-form-check input[type=checkbox]~label,.sirio-control.sirio-is-invalid fieldset .sirio-form-check input[type=checkbox]:checked~label{color:#aa224f}.sirio-control.sirio-is-invalid fieldset .sirio-form-check input[type=checkbox]~label:before,.sirio-control.sirio-is-invalid fieldset .sirio-form-check input[type=checkbox]:checked~label:before{border-color:#aa224f}.sirio-control.sirio-is-invalid fieldset .sirio-form-check input[type=checkbox]:checked~label:after{background-image:url(\"data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='512' height='512' viewBox='0 0 512 512'%3e%3cpath fill='%23AA224F' d='M173.898 439.404l-166.4-166.4c-9.997-9.997-9.997-26.206 0-36.204l36.203-36.204c9.997-9.998 26.207-9.998 36.204 0L192 312.69 432.095 72.596c9.997-9.997 26.207-9.997 36.204 0l36.203 36.204c9.997 9.997 9.997 26.206 0 36.204l-294.4 294.401c-9.998 9.997-26.207 9.997-36.204-.001z'/%3e%3c/svg%3e\");background-size:12px}.sirio-control.sirio-is-invalid fieldset .sirio-chip-selection input[type=checkbox]+label{color:#aa224f;border-color:#aa224f}.sirio-control.sirio-is-invalid fieldset .sirio-chip-selection input[type=checkbox]:checked+label{color:#fff;background-color:#aa224f;border-color:#aa224f}.sirio-control.sirio-is-invalid fieldset .sirio-form-check input[type=radio]~label,.sirio-control.sirio-is-invalid fieldset .sirio-form-check input[type=radio]:checked~label{color:#aa224f}.sirio-control.sirio-is-invalid fieldset .sirio-form-check input[type=radio]~label:before,.sirio-control.sirio-is-invalid fieldset .sirio-form-check input[type=radio]:checked~label:before{border-color:#aa224f}.sirio-control.sirio-is-invalid fieldset .sirio-form-check input[type=radio]:checked~label:after{background-image:url(\"data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='512' height='512' viewBox='0 0 512 512'%3e%3cpath fill='%23AA224F' d='M173.898 439.404l-166.4-166.4c-9.997-9.997-9.997-26.206 0-36.204l36.203-36.204c9.997-9.998 26.207-9.998 36.204 0L192 312.69 432.095 72.596c9.997-9.997 26.207-9.997 36.204 0l36.203 36.204c9.997 9.997 9.997 26.206 0 36.204l-294.4 294.401c-9.998 9.997-26.207 9.997-36.204-.001z'/%3e%3c/svg%3e\");background-size:12px}.sirio-control.sirio-is-invalid fieldset .sirio-chip-selection input[type=radio]+label{color:#aa224f;border-color:#aa224f}.sirio-control.sirio-is-invalid fieldset .sirio-chip-selection input[type=radio]:checked+label{color:#fff;background-color:#aa224f;border-color:#aa224f}.sirio-upload.sirio-is-invalid button{background-color:#aa224f;border-color:#aa224f}.sirio-accordion .sirio-accordion-body .sirio-accordion-content{padding:16px}.ag-cell-value button.sirio-btn.sirio-btn-icon{padding:0}.sirio-tab.sirio-tab-scroll{display:block}.sirio-dropdown .searchable{position:absolute;width:100%;display:none;left:0}.ag-header-cell.hide-filter .ag-header-cell-filter-button{display:none}\n"] }]
|
|
488
|
+
}], ctorParameters: () => [{ type: i1.SanitizeService }, { type: i2.MarkdownService }, { type: i3.MimeService }, { type: i4.ProgrammabilityService }, { type: i5.EventService }, { type: i6.FormatterService }, { type: i7.WeakService }, { type: i8.RegisterService }, { type: i0.ElementRef }], propDecorators: { rows: [{
|
|
489
|
+
type: Input
|
|
490
|
+
}], formGroup: [{
|
|
491
|
+
type: Input
|
|
492
|
+
}] } });
|
|
493
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-fields.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-sirio/src/lib/dynamic-fields/dynamic-fields.component.ts","../../../../../projects/ngx-sirio/src/lib/dynamic-fields/dynamic-fields.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit, ViewEncapsulation, ViewChildren, QueryList, ElementRef, AfterViewInit } from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { FormGroup, FormControl, FormArray, AbstractControl } from '@angular/forms';\r\nimport { ReactiveFormsModule } from '@angular/forms';\r\nimport { SafeHtml, SafeResourceUrl } from '@angular/platform-browser';\r\nimport { Datepicker } from 'vanillajs-datepicker';\r\nimport { SanitizeService } from '../services/sanitize.service';\r\nimport { MarkdownService } from '../services/markdown.service';\r\nimport { MimeService } from '../services/mime.service';\r\nimport { ProgrammabilityService } from '../services/programmability.service';\r\nimport { EventService, CommandEvent } from '../services/event.service';\r\nimport { FormatterService } from '../services/formatter.service';\r\nimport { WeakService } from '../services/weak.service';\r\nimport { RegisterService } from '../services/register.service';\r\nimport { ButtonColors } from 'ngx-sirio-lib';\r\nimport { AdornerDirective } from '../directives/adorner.directive';\r\nimport { DisableDirective } from '../directives/disable.directive';\r\nimport { DisplayDirective } from '../directives/display.directive';\r\nimport { RepeatDirective } from '../directives/repeat.directive';\r\nimport { FrameSecurityDirective } from '../directives/frame-security.directive';\r\nimport { DropdownDirective } from '../directives/dropdown.directive';\r\nimport { TabDirective } from '../directives/tab.directive';\r\nimport { AccordionDirective } from '../directives/accordion.directive';\r\nimport { GridDirective } from '../directives/grid.directive';\r\nimport { RegisterDirective } from '../directives/register.directive';\r\nimport { UpdateBlurDirective } from '../directives/updateblur.directive';\r\nimport { ObjectURLRendererComponent, DeleteRowCellRenderer } from '../utils/gridCells';\r\nimport { isObservable, Observable, of } from 'rxjs';\r\n\r\nimport {\r\n  SirioInputComponent, SirioValidationDirective\r\n  , SirioSelectComponent, SirioSelectOptionComponent, SirioSelectPanelComponent\r\n  , SirioCheckboxGroupComponent, SirioCheckboxComponent, SirioDatepickerComponent, SirioTimepickerComponent\r\n  , SirioRadioGroupComponent, SirioRadioButtonComponent, SirioTabComponent, SirioTabItemComponent\r\n  , SirioAccordionComponent, SirioAccordionPanelComponent, SirioAccordionHeaderComponent, SirioAccordionBodyComponent\r\n  , SirioButtonComponent, SirioFileUploadComponent\r\n  , SirioToggleComponent, SirioChipCheckboxGroupComponent, SirioChipRadioGroupComponent, SirioInputChipComponent\r\n  , SirioTableModule, SirioTableComponent, SirioPaginatorComponent\r\n  , SirioAlertComponent, SirioAlertMessageComponent, SirioSliderComponent\r\n  , SirioNotifyComponent, SirioNotifyBodyComponent, SirioNotifyActionComponent, SirioNotifyLinkComponent\r\n  , NgxSirioEvent\r\n} from 'ngx-sirio-lib';\r\n\r\nimport { AgGridAngular } from 'ag-grid-angular';\r\nimport {\r\n  Module, PaginationModule, ClientSideRowModelModule, InfiniteRowModelModule\r\n  , LocaleModule, CellStyleModule\r\n  , TextFilterModule, NumberFilterModule, DateFilterModule\r\n  , ColDef, themeQuartz, iconSetAlpine, GridOptions, ValueFormatterParams\r\n  , ClientSideRowModelApiModule\r\n} from 'ag-grid-community';\r\nimport { AG_GRID_LOCALE_IT } from '@ag-grid-community/locale';\r\n\r\nimport { Texts } from '../locale/locale-it';\r\n\r\n@Component({\r\n  selector: 'app-dynamic-fields',\r\n  templateUrl: './dynamic-fields.component.html',\r\n  styleUrls: [\r\n    './dynamic-fields.component.css'],\r\n  standalone: true,\r\n  imports: [CommonModule, ReactiveFormsModule\r\n    , AdornerDirective, DisableDirective, DisplayDirective, FrameSecurityDirective\r\n    , DropdownDirective, UpdateBlurDirective, RepeatDirective, TabDirective, GridDirective\r\n    , RegisterDirective, AccordionDirective\r\n    , SirioInputComponent, SirioValidationDirective\r\n    , SirioSelectComponent, SirioSelectOptionComponent, SirioSelectPanelComponent\r\n    , SirioCheckboxGroupComponent, SirioCheckboxComponent, SirioDatepickerComponent, SirioTimepickerComponent\r\n    , SirioRadioGroupComponent, SirioRadioButtonComponent, SirioTabComponent, SirioTabItemComponent\r\n    , SirioAccordionComponent, SirioAccordionPanelComponent, SirioAccordionHeaderComponent, SirioAccordionBodyComponent\r\n    , SirioButtonComponent, SirioFileUploadComponent\r\n    , SirioToggleComponent, SirioChipCheckboxGroupComponent, SirioChipRadioGroupComponent, SirioInputChipComponent\r\n    , SirioTableModule, SirioTableComponent, SirioPaginatorComponent\r\n    , SirioAlertComponent, SirioAlertMessageComponent, SirioSliderComponent\r\n    , SirioNotifyComponent, SirioNotifyBodyComponent, SirioNotifyActionComponent, SirioNotifyLinkComponent\r\n    , AgGridAngular],\r\n  providers: [\r\n    RegisterService,\r\n    ProgrammabilityService\r\n  ],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class DynamicFieldsComponent implements OnInit, AfterViewInit {\r\n  @Input() rows: Array<any> | undefined;\r\n  @Input() formGroup!: FormGroup;\r\n\r\n  Texts = Texts;\r\n\r\n  constructor(private sanitizer: SanitizeService\r\n    , private markdown: MarkdownService\r\n    , private mime: MimeService\r\n    , private programmability: ProgrammabilityService\r\n    , private events: EventService\r\n    , private formatter: FormatterService\r\n    , private weak: WeakService\r\n    , private register: RegisterService\r\n    , private el: ElementRef\r\n  )\r\n  {\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.configureDatepicker();\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    setTimeout(() => {\r\n      this.focusFirst();\r\n    });\r\n  }\r\n\r\n  getRegister(): RegisterService {\r\n    return this.register;\r\n  }\r\n\r\n  getClass(component: any): string {\r\n    if (component.layout?.columns) {\r\n      return \"col-md-\" + component.layout?.columns;\r\n    }\r\n    else {\r\n      return \"col\";\r\n    }\r\n  }\r\n\r\n  getTextFeedback(component: any): string {\r\n    const control = this.formGroup.get(component.key) as FormControl;\r\n    return control.valid || !control.errors\r\n      ? ''\r\n      : control.errors['message'];\r\n  }\r\n\r\n  isWarning(component: any): boolean {\r\n    const control = this.formGroup.get(component.key) as FormControl;\r\n    return (control.errors && control.errors['warning']) || false\r\n  }\r\n\r\n  evaluateString(value: string | null): string {\r\n    return this.programmability.evaluateString(this.formGroup, value);    \r\n  }\r\n\r\n  evaluateBoolean(value: boolean | string | null): boolean | null {\r\n    return this.programmability.evaluateBoolean(this.formGroup, value);\r\n  }\r\n\r\n  evaluateNumber(value: number | null): number | null {\r\n    return this.programmability.evaluateNumber(this.formGroup, value);\r\n  }\r\n\r\n  evaluateUrl(value: string | null): SafeResourceUrl {\r\n    const url = this.programmability.evaluateString(this.formGroup, value);\r\n    const watchKey = `:safeUrl(${url})`;\r\n    return this.weak.call(this.formGroup, watchKey, () => {\r\n      return this.sanitizer.sanitizeSafeUrl(url);\r\n    });\r\n  }\r\n\r\n  evaluateTemplate(value: string | null): string {\r\n    return this.programmability.evaluateTemplate(this.formGroup, value);\r\n  }\r\n\r\n  evaluate(text: string | null, cacheable: boolean = true): any {\r\n    return this.programmability.evaluate(this.formGroup, text, cacheable);\r\n  }\r\n\r\n  evaluateColor(value: string | null): ButtonColors | null {\r\n    const color = this.evaluateString(value);\r\n    const watchKey = `:buttonColor(${color})`;\r\n    return this.weak.call(this.formGroup, watchKey, () => {\r\n      if (color === \"ghost\")\r\n        return null;\r\n      const validColors: ButtonColors[] = ['primary', 'secondary', 'tertiary', 'tertiary-light', 'danger'];\r\n      return validColors.includes(color as ButtonColors) ? (color as ButtonColors) : 'primary';\r\n    });\r\n  }\r\n\r\n  getFormGroup(control: AbstractControl | null): FormGroup {\r\n    if (!(control instanceof FormGroup)) {\r\n      throw new Error('Control is not a FormGroup');\r\n    }\r\n    return control;\r\n  }\r\n\r\n  getFormArray(control: AbstractControl | null): FormArray {\r\n    if (!(control instanceof FormArray)) {\r\n      throw new Error('Control is not a FormArray');\r\n    }\r\n    return control;\r\n  }\r\n\r\n  getControlFromPath(path: string | null): AbstractControl | null {\r\n    return path\r\n      ? this.formGroup.get(path)\r\n      : this.formGroup;\r\n  }\r\n\r\n  toHTML(text: string): SafeHtml {\r\n    let html = this.markdown.toHtml(text);\r\n    return this.sanitizer.sanitizeSafeHtml(html)\r\n  };\r\n\r\n  sanitize(html: string): SafeHtml {\r\n    return this.sanitizer.sanitizeSafeHtml(html);\r\n  };\r\n\r\n  getMimeTypes(extensions: string): string {\r\n    return this.mime.getMimeTypes(extensions);\r\n  };\r\n\r\n  clickButton(component: any, event: any) {\r\n    if (component.click) {\r\n      this.evaluate(component.click, false);\r\n    }\r\n    if (component.command) {\r\n      const command: CommandEvent = {\r\n        name: this.evaluateString(component.command),\r\n        component: component,\r\n        formGroup: this.formGroup,\r\n        event: event\r\n      };\r\n      this.events.emitCommand(command);\r\n    }    \r\n  }\r\n\r\n  getValues(component: any): Observable<any> {\r\n    if (component.values) {\r\n      // Static\r\n      return of(component.values);\r\n    }\r\n    else if (component.valuesKey) {\r\n      // Field value\r\n      const result = this.evaluate(component.valuesKey);\r\n      return this.getAsObservable(result);\r\n    }\r\n    else if (component.valuesExpression) {\r\n      // Expression\r\n      const result = this.evaluate(component.valuesExpression);\r\n      return this.getAsObservable(result);\r\n    }\r\n    else {\r\n      // Nothing\r\n      return of([]);\r\n    }    \r\n  }\r\n\r\n  getGridOptions(component: any): GridOptions {\r\n    return this.weak.call(component, 'getGridOptions', () => {\r\n      return {\r\n        defaultColDef: {\r\n          floatingFilter: (component.floatingFilter === true),\r\n          headerClass: (component.floatingFilter === true)\r\n            ? 'show-filter' : 'hide-filter'\r\n        },\r\n        columnDefs: this.getGridColumns(component),\r\n        pagination: this.getGridPaginable(component),\r\n        paginationPageSize: this.getGridPageSize(component),\r\n        paginationPageSizeSelector: [5, 10, 20, 50],\r\n        localeText: this.getGridTexts(),\r\n        theme: this.getGridTheme(),\r\n      };\r\n    });\r\n  }\r\n\r\n  getGridModules(component: any): Module[] {\r\n    return this.weak.call(component, 'getGridModules', () => {\r\n      return [\r\n        ClientSideRowModelModule\r\n        , InfiniteRowModelModule\r\n        , PaginationModule\r\n        , LocaleModule\r\n        , CellStyleModule\r\n        , ClientSideRowModelApiModule\r\n        , TextFilterModule\r\n        , NumberFilterModule\r\n        , DateFilterModule\r\n      ];\r\n    });\r\n  }\r\n\r\n  getGridData(component: any): Observable<any> {\r\n    if (component.dataSource) {\r\n      // Expression\r\n      const result = this.evaluate(component.dataSource);\r\n      return this.getAsObservable(result);\r\n    }\r\n    else {\r\n      // Nothing\r\n      return of([]);\r\n    }\r\n  }\r\n\r\n  addNewItem(component: any) {\r\n    const formArray = this.getFormArray(this.getControlFromPath(component.path));\r\n    (formArray as any).addNewItem();\r\n  }\r\n\r\n  removeItem(component: any, index: number) {\r\n    const formArray = this.getFormArray(this.getControlFromPath(component.path));\r\n    formArray.removeAt(index);\r\n  }\r\n\r\n  createUploadTables(component: any): any {\r\n    return this.weak.call(component, 'createUploadTables', () => {\r\n      return [\r\n        {\r\n          components: [\r\n            {\r\n              \"type\": \"table\",\r\n              \"layout\": {\r\n                \"columns\": null\r\n              },\r\n              \"columns\": [\r\n                {\r\n                  \"label\": \"Name\",\r\n                  \"key\": \"name\",\r\n                  \"flex\": 1\r\n                },\r\n                {\r\n                  \"label\": \"Size\",\r\n                  \"key\": \"size\",\r\n                  \"format\": \"integer\",\r\n                  \"align\": \"right\"\r\n                },\r\n                {\r\n                  \"key\": \"type\",\r\n                  \"label\": \"Type\"\r\n                },\r\n                {\r\n                  \"key\": \"url\",\r\n                  \"label\": \"\",\r\n                  \"width\": 50,\r\n                  \"align\": \"center\",\r\n                  \"format\": \"objectURL\"\r\n                },\r\n                {\r\n                  \"label\": \"\",\r\n                  \"width\": 50,\r\n                  \"align\": \"center\",\r\n                  \"format\": \"deleteRow\"\r\n                }\r\n              ],\r\n              \"dataSource\": \"=\" + component.key,\r\n              \"height\": 200,\r\n              \"conditional\": component.conditional,\r\n              \"disabled\": component.disabled\r\n            }\r\n          ]\r\n        }\r\n      ];\r\n    });\r\n  }\r\n\r\n  fileUploaded($event: NgxSirioEvent<SirioFileUploadComponent>) {\r\n    const removeFile = (file: File) => {\r\n      if ($event.component.control) {\r\n        const newFiles = $event.component.fileList.filter(f => f !== file);\r\n        $event.component.control.setValue(newFiles);\r\n        addRemove(newFiles);\r\n        return newFiles;\r\n      }\r\n      return [];\r\n    }\r\n\r\n    const addRemove = (files: File[]) => {\r\n      files.forEach(file => {\r\n        if (!('remove' in file)) {\r\n          Object.defineProperty(file, 'remove', {\r\n            value: function () {\r\n              removeFile(this);\r\n            },\r\n            writable: false,\r\n            enumerable: false\r\n          });\r\n        }        \r\n      }); \r\n    };\r\n\r\n    addRemove($event.component.fileList);\r\n  }\r\n\r\n  private focusFirst() {\r\n    const focusableElements = this.el.nativeElement.querySelectorAll(\r\n      'button, [href], input, select, textarea, [tabindex]:not([tabindex=\"-1\"])'\r\n    );\r\n\r\n    for (let el of focusableElements) {\r\n      if (!(el as HTMLElement).hasAttribute('disabled')) {\r\n        (el as HTMLElement).focus();\r\n        break;\r\n      }      \r\n    }\r\n  }\r\n\r\n  private gridTexts = {\r\n    ...AG_GRID_LOCALE_IT,\r\n    \"pageSizeSelectorLabel\": \"Elementi per pagina:\",\r\n    \"to\": \"-\",\r\n  };\r\n\r\n  private gridTheme = themeQuartz\r\n    .withPart(iconSetAlpine)\r\n    .withParams({\r\n      backgroundColor: \"#FAFAFA\",\r\n      borderColor: \"#D9E4F7\",\r\n      browserColorScheme: \"light\",\r\n      cellTextColor: \"#00121A\",\r\n      columnBorder: true,\r\n      fontFamily: \"inherit\",\r\n      fontSize: 16,\r\n      headerBackgroundColor: \"#002460\",\r\n      headerColumnBorder: true,\r\n      headerColumnResizeHandleColor: \"#F2F6FC\",\r\n      headerColumnResizeHandleWidth: 2,\r\n      headerFontSize: 16,\r\n      headerFontWeight: 600,\r\n      headerRowBorder: false,\r\n      headerTextColor: \"#F2F6FC\",\r\n      rowBorder: true\r\n    });\r\n\r\n  private getGridColumns(component: any): ColDef[] {\r\n    if (Array.isArray(component.columns)) {\r\n      return component.columns.map((column: any) => ({\r\n        field: column.key,\r\n        headerName: column.label,\r\n        resizable: column.resize === true,\r\n        sortable: column.sort === true,\r\n        filter: column.filter === true,\r\n        suppressMovable: !(column.move === true),\r\n        ...(column.flex === true && { flex: 1 }),\r\n        ...(column.align === \"left\" && { cellStyle: { textAlign: 'left' } }),\r\n        ...(column.align === \"center\" && { cellStyle: { textAlign: 'center' } }),\r\n        ...(column.align === \"right\" && { cellStyle: { textAlign: 'right' } }),\r\n        ...(typeof column.pinned === \"string\" && { pinned: column.pinned }),\r\n        ...(typeof column.flex === \"number\" && { flex: column.flex }),\r\n        ...(typeof column.width === \"number\" && { width: column.width }),\r\n        ...(typeof column.minWidth === \"number\" && { minWidth: column.minWidth }),\r\n        ...(typeof column.maxWidth === \"number\" && { maxWidth: column.maxWidth }),\r\n        valueFormatter: this.getGridFormatter(column),\r\n        cellRenderer: this.getGridRenderer(column)\r\n      }));\r\n    }\r\n    else {\r\n      return [];\r\n    }\r\n  }\r\n\r\n  private getGridPaginable(component: any): boolean {\r\n    return (typeof component.rowCount === 'number' && component.rowCount > 0);\r\n  }\r\n\r\n  private getGridPageSize(component: any) {\r\n    if (typeof component.rowCount === 'number') {\r\n      return component.rowCount;\r\n    }\r\n  }\r\n\r\n  private getGridTexts() {\r\n    return this.gridTexts;\r\n  }\r\n\r\n  private getGridTheme() {\r\n    return this.gridTheme;\r\n  }\r\n\r\n  private getGridFormatter(column: any): ((param: ValueFormatterParams) => string) | undefined {\r\n    if (column.format) {\r\n      switch (column.format) {\r\n        case 'integer':\r\n          return params => this.formatter.formatInteger(params.value);\r\n        case 'currency':\r\n          return params => this.formatter.formatCurrency(params.value);\r\n        case 'date':\r\n          return params => this.formatter.formatDate(params.value);\r\n      }\r\n    }\r\n    return undefined;\r\n  }\r\n\r\n  private getGridRenderer(column: any): any {\r\n    if (column.format) {\r\n      switch (column.format) {\r\n        case 'objectURL':\r\n          return ObjectURLRendererComponent;\r\n        case \"deleteRow\":\r\n          return DeleteRowCellRenderer;\r\n      }\r\n    }\r\n    return undefined;\r\n  }\r\n  \r\n  private getAsObservable(value: any): Observable<any> {\r\n    if (isObservable(value))\r\n      return value;\r\n    return of(value);\r\n  }\r\n\r\n  private configureDatepicker() {\r\n    (Datepicker.locales as any)['it'] = {\r\n      days: [\r\n        'Domenica',\r\n        'Lunedì',\r\n        'Martedì',\r\n        'Mercoledì',\r\n        'Giovedì',\r\n        'Venerdì',\r\n        'Sabato',\r\n      ],\r\n      daysMin: ['Dom', 'Lun', 'Mar', 'Mer', 'Gio', 'Ven', 'Sab'],\r\n      months: [\r\n        'Gennaio',\r\n        'Febbraio',\r\n        'Marzo',\r\n        'Aprile',\r\n        'Maggio',\r\n        'Giugno',\r\n        'Luglio',\r\n        'Agosto',\r\n        'Settembre',\r\n        'Ottobre',\r\n        'Novembre',\r\n        'Dicembre',\r\n      ],\r\n      monthsShort: [\r\n        'Gen',\r\n        'Feb',\r\n        'Mar',\r\n        'Apr',\r\n        'Mag',\r\n        'Giu',\r\n        'Lug',\r\n        'Ago',\r\n        'Set',\r\n        'Ott',\r\n        'Nov',\r\n        'Dic',\r\n      ],\r\n      today: 'Oggi',\r\n      clear: 'Pulisci',\r\n      format: 'dd/mm/yyyy',\r\n      weekStart: 1,\r\n    };\r\n  };\r\n}\r\n","<ng-container *ngFor=\"let row of rows\" [formGroup]=\"formGroup\">\r\n  <div class=\"row field-set\">\r\n    <ng-container *ngFor=\"let component of row.components\">\r\n      <ng-container [ngSwitch]=\"component.type\">\r\n        <div [formGroup]=\"formGroup\" [class]=\"getClass(component)\">\r\n          <!-- #region textfield -->\r\n          <ng-container *ngSwitchCase=\"'textfield'\">\r\n            <ngx-sirio-input type=\"text\"\r\n                             ariaLabel=\"input\"\r\n                             [label]=\"evaluateString(component.label)\"\r\n                             [labelPopover]=\"evaluateString(component.tooltip)\"\r\n                             [placeholder]=\"component.placeholder || ''\"\r\n                             [textHelp]=\"evaluateString(component.description)\"\r\n                             [textFeedback]=\"getTextFeedback(component)\"\r\n                             [prefixAdorner]=\"evaluateString(component.appearance?.prefixAdorner)\"\r\n                             [suffixAdorner]=\"evaluateString(component.appearance?.suffixAdorner)\"\r\n                             [readonly]=\"evaluateBoolean(component.readonly)\"\r\n                             [disableControl]=\"evaluateBoolean(component.disabled)\"\r\n                             [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n                             [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n                             [formControlName]=\"component.key\"\r\n                             updateBlur\r\n                             validation\r\n                             [canValidate]=\"true\"\r\n                             [isWarning]=\"isWarning(component)\"\r\n                             [showWhenValid]=\"false\"\r\n                             #textfield\r\n                             [register]=\"component\"\r\n                             [componentRef]=\"textfield\">\r\n            </ngx-sirio-input>\r\n          </ng-container>\r\n          <!-- #endregion -->\r\n          <!-- #region select -->\r\n          <ng-container *ngSwitchCase=\"'select'\">\r\n            <ngx-sirio-select ariaLabel=\"select\"\r\n                              [label]=\"evaluateString(component.label)\"\r\n                              [labelPopover]=\"evaluateString(component.tooltip)\"\r\n                              [placeholder]=\"component.placeholder || ''\"\r\n                              [textHelp]=\"evaluateString(component.description)\"\r\n                              [textFeedback]=\"getTextFeedback(component)\"\r\n                              [readonly]=\"evaluateBoolean(component.readonly)\"\r\n                              [disableControl]=\"evaluateBoolean(component.disabled)\"\r\n                              [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n                              [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n                              [formControlName]=\"component.key\"\r\n                              validation\r\n                              [canValidate]=\"true\"\r\n                              [isWarning]=\"isWarning(component)\"\r\n                              [showWhenValid]=\"false\"\r\n                              dropdown\r\n                              #select\r\n                              [register]=\"component\"\r\n                              [componentRef]=\"select\">\r\n              <ngx-sirio-select-panel ariaLabel=\"items\">\r\n                <ngx-sirio-input *ngIf=\"component.searchable\" class=\"searchable\" type=\"text\" [placeholder]=\"Texts.TypeToSearch\"></ngx-sirio-input>\r\n                <ngx-sirio-select-option *ngFor=\"let option of (getValues(component) | async) || []\" [value]=\"option.value\">{{ option.label }}</ngx-sirio-select-option>\r\n              </ngx-sirio-select-panel>\r\n            </ngx-sirio-select>\r\n          </ng-container>\r\n          <!-- #endregion -->\r\n          <!-- #region taglist -->\r\n          <ng-container *ngSwitchCase=\"'taglist'\">\r\n            <ngx-sirio-select ariaLabel=\"select\"\r\n                              [label]=\"evaluateString(component.label)\"\r\n                              [labelPopover]=\"evaluateString(component.tooltip)\"\r\n                              [placeholder]=\"component.placeholder || ''\"\r\n                              [textHelp]=\"evaluateString(component.description)\"\r\n                              [textFeedback]=\"getTextFeedback(component)\"\r\n                              [readonly]=\"evaluateBoolean(component.readonly)\"\r\n                              [disableControl]=\"evaluateBoolean(component.disabled)\"\r\n                              [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n                              [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n                              [isMultiple]=\"true\"\r\n                              [formControlName]=\"component.key\"\r\n                              validation\r\n                              [canValidate]=\"true\"\r\n                              [isWarning]=\"isWarning(component)\"\r\n                              [showWhenValid]=\"false\"\r\n                              #taglist\r\n                              [register]=\"component\"\r\n                              [componentRef]=\"taglist\">\r\n              <ngx-sirio-select-panel ariaLabel=\"items\">\r\n                <ngx-sirio-select-option *ngFor=\"let option of (getValues(component) | async) || []\" [value]=\"option.value\">{{ option.label }}</ngx-sirio-select-option>\r\n              </ngx-sirio-select-panel>\r\n            </ngx-sirio-select>\r\n          </ng-container>\r\n          <!-- #endregion -->\r\n          <!-- #region number -->\r\n          <ng-container *ngSwitchCase=\"'number'\">\r\n            <ngx-sirio-input type=\"number\"\r\n                             ariaLabel=\"input\"\r\n                             [label]=\"evaluateString(component.label)\"\r\n                             [labelPopover]=\"evaluateString(component.tooltip)\"\r\n                             [placeholder]=\"component.placeholder || ''\"\r\n                             [textHelp]=\"evaluateString(component.description)\"\r\n                             [textFeedback]=\"getTextFeedback(component)\"\r\n                             [prefixAdorner]=\"evaluateString(component.appearance?.prefixAdorner)\"\r\n                             [suffixAdorner]=\"evaluateString(component.appearance?.suffixAdorner)\"\r\n                             [readonly]=\"evaluateBoolean(component.readonly)\"\r\n                             [disableControl]=\"evaluateBoolean(component.disabled)\"\r\n                             [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n                             [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n                             [formControlName]=\"component.key\"\r\n                             updateBlur\r\n                             validation\r\n                             [canValidate]=\"true\"\r\n                             [isWarning]=\"isWarning(component)\"\r\n                             [showWhenValid]=\"false\"\r\n                             #number\r\n                             [register]=\"component\"\r\n                             [componentRef]=\"number\">\r\n            </ngx-sirio-input>\r\n          </ng-container>\r\n          <!-- #endregion -->\r\n          <!-- #region datetime -->\r\n          <ng-container *ngSwitchCase=\"'datetime'\">\r\n            <ng-container [ngSwitch]=\"component.subtype\">\r\n              <!-- #region date -->\r\n              <ng-container *ngSwitchCase=\"'date'\">\r\n                <ngx-sirio-datepicker ariaLabel=\"date\"\r\n                                      [label]=\"evaluateString(component.dateLabel)\"\r\n                                      [labelPopover]=\"evaluateString(component.tooltip)\"\r\n                                      [placeholder]=\"component.placeholder || ''\"\r\n                                      [textHelp]=\"evaluateString(component.description)\"\r\n                                      [textFeedback]=\"getTextFeedback(component)\"\r\n                                      [readonly]=\"evaluateBoolean(component.readonly)\"\r\n                                      [disableControl]=\"evaluateBoolean(component.disabled)\"\r\n                                      [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n                                      [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n                                      [formControlName]=\"component.key\"\r\n                                      validation\r\n                                      [canValidate]=\"true\"\r\n                                      [isWarning]=\"isWarning(component)\"\r\n                                      [showWhenValid]=\"false\"\r\n                                      #date\r\n                                      [register]=\"component\"\r\n                                      [componentRef]=\"date\">\r\n                </ngx-sirio-datepicker>\r\n              </ng-container>\r\n              <!-- #endregion -->\r\n              <!-- #region time -->\r\n              <ng-container *ngSwitchCase=\"'time'\">\r\n                <ngx-sirio-timepicker ariaLabel=\"time\"\r\n                                      [label]=\"evaluateString(component.timeLabel)\"\r\n                                      [labelPopover]=\"evaluateString(component.tooltip)\"\r\n                                      [placeholder]=\"component.placeholder || ''\"\r\n                                      [textHelp]=\"evaluateString(component.description)\"\r\n                                      [textFeedback]=\"getTextFeedback(component)\"\r\n                                      [readonly]=\"evaluateBoolean(component.readonly)\"\r\n                                      [disableControl]=\"evaluateBoolean(component.disabled)\"\r\n                                      [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n                                      [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n                                      [formControlName]=\"component.key\"\r\n                                      validation\r\n                                      [canValidate]=\"true\"\r\n                                      [isWarning]=\"isWarning(component)\"\r\n                                      [showWhenValid]=\"false\"\r\n                                      #time\r\n                                      [register]=\"component\"\r\n                                      [componentRef]=\"time\">\r\n                </ngx-sirio-timepicker>\r\n              </ng-container>\r\n              <!-- #endregion -->\r\n            </ng-container>\r\n          </ng-container>\r\n          <!-- #endregion -->\r\n          <!-- #region checkbox -->\r\n          <ng-container *ngSwitchCase=\"'checkbox'\">\r\n            <ng-container [ngSwitch]=\"component.subtype\">\r\n              <!-- #region toggle -->\r\n              <ng-container *ngSwitchCase=\"'toggle'\">\r\n                <ngx-sirio-toggle ariaLabel=\"checkbox\"\r\n                                  [textHelp]=\"evaluateString(component.description)\"\r\n                                  [textFeedback]=\"getTextFeedback(component)\"\r\n                                  [readonly]=\"evaluateBoolean(component.readonly)\"\r\n                                  [disableControl]=\"evaluateBoolean(component.disabled)\"\r\n                                  [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n                                  [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n                                  [formControlName]=\"component.key\"\r\n                                  validation\r\n                                  [canValidate]=\"true\"\r\n                                  [isWarning]=\"isWarning(component)\"\r\n                                  [showWhenValid]=\"false\"\r\n                                  #toggle\r\n                                  [register]=\"component\"\r\n                                  [componentRef]=\"toggle\">\r\n                  {{ evaluateString(component.label) }}\r\n                </ngx-sirio-toggle>\r\n              </ng-container>\r\n              <!-- #endregion -->\r\n              <!-- #region default -->\r\n              <ng-container *ngSwitchDefault>\r\n                <ngx-sirio-checkbox ariaLabel=\"checkbox\"\r\n                                    [textHelp]=\"evaluateString(component.description)\"\r\n                                    [textFeedback]=\"getTextFeedback(component)\"\r\n                                    [readonly]=\"evaluateBoolean(component.readonly)\"\r\n                                    [disableControl]=\"evaluateBoolean(component.disabled)\"\r\n                                    [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n                                    [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n                                    [formControlName]=\"component.key\"\r\n                                    validation\r\n                                    [canValidate]=\"true\"\r\n                                    [isWarning]=\"isWarning(component)\"\r\n                                    [showWhenValid]=\"false\"\r\n                                    #checkbox\r\n                                    [register]=\"component\"\r\n                                    [componentRef]=\"checkbox\">\r\n                  {{ evaluateString(component.label) }}\r\n                </ngx-sirio-checkbox>\r\n              </ng-container>\r\n              <!-- #endregion -->\r\n            </ng-container>\r\n          </ng-container>\r\n          <!-- #endregion -->\r\n          <!-- #region radio -->\r\n          <ng-container *ngSwitchCase=\"'radio'\">\r\n            <ng-container [ngSwitch]=\"component.subtype\">\r\n              <!-- #region chip -->\r\n              <ng-container *ngSwitchCase=\"'chip'\">\r\n                <ngx-sirio-chip-radio-group ariaLabel=\"radio\"\r\n                                            [label]=\"evaluateString(component.label)\"\r\n                                            [labelPopover]=\"evaluateString(component.tooltip)\"\r\n                                            [textHelp]=\"evaluateString(component.description)\"\r\n                                            [textFeedback]=\"getTextFeedback(component)\"\r\n                                            [readonly]=\"evaluateBoolean(component.readonly)\"\r\n                                            [disableControl]=\"evaluateBoolean(component.disabled)\"\r\n                                            [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n                                            [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n                                            [formControlName]=\"component.key\"\r\n                                            validation\r\n                                            [canValidate]=\"true\"\r\n                                            [isWarning]=\"isWarning(component)\"\r\n                                            [showWhenValid]=\"false\"\r\n                                            #chipradio\r\n                                            [register]=\"component\"\r\n                                            [componentRef]=\"chipradio\">\r\n                  <ngx-sirio-input-chip *ngFor=\"let option of (getValues(component) | async) || []\"\r\n                                        type=\"radio\"\r\n                                        [value]=\"option.value\">\r\n                    {{ option.label }}\r\n                  </ngx-sirio-input-chip>\r\n                </ngx-sirio-chip-radio-group>\r\n              </ng-container>\r\n              <!-- #endregion -->\r\n              <!-- #region default -->\r\n              <ng-container *ngSwitchDefault>\r\n                <ngx-sirio-radio-group ariaLabel=\"radio\"\r\n                                       [label]=\"evaluateString(component.label)\"\r\n                                       [labelPopover]=\"evaluateString(component.tooltip)\"\r\n                                       [textHelp]=\"evaluateString(component.description)\"\r\n                                       [textFeedback]=\"getTextFeedback(component)\"\r\n                                       [readonly]=\"evaluateBoolean(component.readonly)\"\r\n                                       [disableControl]=\"evaluateBoolean(component.disabled)\"\r\n                                       [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n                                       [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n                                       [formControlName]=\"component.key\"\r\n                                       validation\r\n                                       [canValidate]=\"true\"\r\n                                       [isWarning]=\"isWarning(component)\"\r\n                                       [showWhenValid]=\"false\"\r\n                                       #radio\r\n                                       [register]=\"component\"\r\n                                       [componentRef]=\"radio\">\r\n                  <ngx-sirio-radio-button *ngFor=\"let option of (getValues(component) | async) || []\" [value]=\"option.value\">\r\n                    {{ option.label }}\r\n                  </ngx-sirio-radio-button>\r\n                </ngx-sirio-radio-group>\r\n              </ng-container>\r\n              <!-- #endregion -->\r\n            </ng-container>\r\n          </ng-container>\r\n          <!-- #endregion -->\r\n          <!-- #region checklist -->\r\n          <ng-container *ngSwitchCase=\"'checklist'\">\r\n            <ng-container [ngSwitch]=\"component.subtype\">\r\n              <!-- #region chip -->\r\n              <ng-container *ngSwitchCase=\"'chip'\">\r\n                <ngx-sirio-chip-checkbox-group ariaLabel=\"checklist\"\r\n                                               [label]=\"evaluateString(component.label)\"\r\n                                               [labelPopover]=\"evaluateString(component.tooltip)\"\r\n                                               [textHelp]=\"evaluateString(component.description)\"\r\n                                               [textFeedback]=\"getTextFeedback(component)\"\r\n                                               [readonly]=\"evaluateBoolean(component.readonly)\"\r\n                                               [disableControl]=\"evaluateBoolean(component.disabled)\"\r\n                                               [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n                                               [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n                                               [formControlName]=\"component.key\"\r\n                                               validation\r\n                                               [canValidate]=\"true\"\r\n                                               [isWarning]=\"isWarning(component)\"\r\n                                               [showWhenValid]=\"false\"\r\n                                               #chipcheckbox\r\n                                               [register]=\"component\"\r\n                                               [componentRef]=\"chipcheckbox\">\r\n                  <ngx-sirio-input-chip *ngFor=\"let option of (getValues(component) | async) || []\"\r\n                                        type=\"checkbox\"\r\n                                        [value]=\"option.value\">\r\n                    {{ option.label }}\r\n                  </ngx-sirio-input-chip>\r\n                </ngx-sirio-chip-checkbox-group>\r\n              </ng-container>\r\n              <!-- #endregion -->\r\n              <!-- #region default -->\r\n              <ng-container *ngSwitchDefault>\r\n                <ngx-sirio-checkbox-group ariaLabel=\"checklist\"\r\n                                          [label]=\"evaluateString(component.label)\"\r\n                                          [labelPopover]=\"evaluateString(component.tooltip)\"\r\n                                          [textHelp]=\"evaluateString(component.description)\"\r\n                                          [textFeedback]=\"getTextFeedback(component)\"\r\n                                          [readonly]=\"evaluateBoolean(component.readonly)\"\r\n                                          [disableControl]=\"evaluateBoolean(component.disabled)\"\r\n                                          [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n                                          [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n                                          [formControlName]=\"component.key\"\r\n                                          validation\r\n                                          [canValidate]=\"true\"\r\n                                          [isWarning]=\"isWarning(component)\"\r\n                                          [showWhenValid]=\"false\"\r\n                                          #checkbox\r\n                                          [register]=\"component\"\r\n                                          [componentRef]=\"checkbox\">\r\n                  <ngx-sirio-checkbox *ngFor=\"let option of (getValues(component) | async) || []\" [value]=\"option.value\">\r\n                    {{ option.label }}\r\n                  </ngx-sirio-checkbox>\r\n                </ngx-sirio-checkbox-group>\r\n              </ng-container>\r\n              <!-- #endregion -->\r\n            </ng-container>\r\n          </ng-container>\r\n          <!-- #endregion -->\r\n          <!-- #region textarea -->\r\n          <ng-container *ngSwitchCase=\"'textarea'\">\r\n            <ngx-sirio-input type=\"textarea\"\r\n                             ariaLabel=\"textarea\"\r\n                             [label]=\"evaluateString(component.label)\"\r\n                             [labelPopover]=\"evaluateString(component.tooltip)\"\r\n                             [placeholder]=\"component.placeholder || ''\"\r\n                             [readonly]=\"evaluateBoolean(component.readonly)\"\r\n                             [disableControl]=\"evaluateBoolean(component.disabled)\"\r\n                             [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n                             [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n                             [textHelp]=\"evaluateString(component.description)\"\r\n                             [textFeedback]=\"getTextFeedback(component)\"\r\n                             [formControlName]=\"component.key\"\r\n                             updateBlur\r\n                             validation\r\n                             [canValidate]=\"true\"\r\n                             [isWarning]=\"isWarning(component)\"\r\n                             [showWhenValid]=\"false\"\r\n                             #textarea\r\n                             [register]=\"component\"\r\n                             [componentRef]=\"textarea\">\r\n            </ngx-sirio-input>\r\n          </ng-container>\r\n          <!-- #endregion -->\r\n          <!-- #region filepicker -->\r\n          <ng-container *ngSwitchCase=\"'filepicker'\">\r\n            <ngx-sirio-file-upload ariaLabel=\"filepicker\"\r\n                                   [label]=\"evaluateString(component.label)\"\r\n                                   [labelPopover]=\"evaluateString(component.tooltip)\"\r\n                                   [accept]=\"getMimeTypes(component.accept)\"\r\n                                   [multiple]=\"evaluateBoolean(component.multiple)\"\r\n                                   (fileUploadedEvent)=\"fileUploaded($event)\"\r\n                                   [showFilelist]=\"!component.showDetails\"\r\n                                   [textHelp]=\"evaluateString(component.description)\"\r\n                                   [textFeedback]=\"getTextFeedback(component)\"\r\n                                   [readonly]=\"evaluateBoolean(component.readonly)\"\r\n                                   [disableControl]=\"evaluateBoolean(component.disabled)\"\r\n                                   [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n                                   [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n                                   [formControlName]=\"component.key\"\r\n                                   validation\r\n                                   [canValidate]=\"true\"\r\n                                   [isWarning]=\"isWarning(component)\"\r\n                                   [showWhenValid]=\"false\"\r\n                                   #filepicker\r\n                                   [register]=\"component\"\r\n                                   [componentRef]=\"filepicker\">\r\n              <span class=\"fas fa-arrow-up\" aria-hidden=\"true\"></span>\r\n              {{ Texts.Upload }}\r\n            </ngx-sirio-file-upload>\r\n            <ng-container *ngIf=\"component.showDetails\">\r\n              <app-dynamic-fields [formGroup]=\"formGroup\" [rows]=\"createUploadTables(component)\"></app-dynamic-fields>\r\n            </ng-container>\r\n          </ng-container>\r\n          <!-- #endregion -->\r\n          <!-- #region text -->\r\n          <ng-container *ngSwitchCase=\"'text'\">\r\n            <div class=\"text-paragraph\"\r\n                 [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n                 [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n                 [innerHTML]=\"toHTML(evaluateTemplate(component.text))\"\r\n                 #text\r\n                 [register]=\"component\"\r\n                 [componentRef]=\"text\">\r\n            </div>\r\n          </ng-container>\r\n          <!-- #endregion -->\r\n          <!-- #region html -->\r\n          <ng-container *ngSwitchCase=\"'html'\">\r\n            <div class=\"html-paragraph\"\r\n                 [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n                 [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n                 [innerHTML]=\"sanitize(evaluateTemplate(component.content))\"\r\n                 #html\r\n                 [register]=\"component\"\r\n                 [componentRef]=\"html\">\r\n            </div>\r\n          </ng-container>\r\n          <!-- #endregion -->\r\n          <!-- #region image -->\r\n          <ng-container *ngSwitchCase=\"'image'\">\r\n            <img [src]=\"evaluateString(component.source)\"\r\n                 [alt]=\"evaluateString(component.alt)\"\r\n                 [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n                 [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n                 style=\"width: 100%;height: 100%;\"\r\n                 #image\r\n                 [register]=\"component\"\r\n                 [componentRef]=\"image\">\r\n          </ng-container>\r\n          <!-- #endregion -->\r\n          <!-- #region dynamiclist -->\r\n          <ng-container *ngSwitchCase=\"'dynamiclist'\">\r\n            <ng-container [formArrayName]=\"component.path\" [repeat]=\"evaluateNumber(component.repetitions)\">\r\n              <ng-container [ngSwitch]=\"component.subtype\">\r\n                <ng-container *ngIf=\"getFormArray(formGroup.get(component.path)).controls.length > 0\">\r\n                  <!-- #region tab -->\r\n                  <ng-container *ngSwitchCase=\"'tab'\">\r\n                    <div [register]=\"component\"\r\n                         [componentRef]=\"dynamiclisttab\">\r\n                      <ngx-sirio-tab [leftArrowLabel]=\"Texts.ScrollLeft\"\r\n                                     [rightArrowLabel]=\"Texts.ScrollRight\"\r\n                                     [tabCount]=\"getFormArray(formGroup.get(component.path)).controls.length\"\r\n                                     #dynamiclisttab>\r\n                        <ng-container *ngFor=\"let item of getFormArray(formGroup.get(component.path)).controls; let i = index;\" [formGroupName]=\"i\">\r\n                          <ngx-sirio-tab-item [label]=\"component.label + ' ' + (i + 1)\">\r\n                            <!--<ng-container *ngTemplateOutlet=\"itemTemplate; context: { item: item, index: i }\"></ng-container>-->\r\n                            <div [ngClass]=\"{\r\n            'group-top': component.verticalAlignment === 'start',\r\n            'group-center': component.verticalAlignment === 'center',\r\n            'group-bottom': component.verticalAlignment === 'end'}\">\r\n                              <div>\r\n                                <app-dynamic-fields [formGroup]=\"getFormGroup(item)\" [rows]=\"component.rows\"></app-dynamic-fields>\r\n                              </div>\r\n                              <ng-container *ngIf=\"component.allowAddRemove\">\r\n                                <div style=\"text-align:right\">\r\n                                  <ngx-sirio-button (click)=\"removeItem(component, i)\" class=\"remove-item\" [color]=\"null\" icon=\"fas fa-trash\">{{ Texts.RemoveItem }}</ngx-sirio-button>\r\n                                </div>\r\n                              </ng-container>\r\n                            </div>\r\n                          </ngx-sirio-tab-item>\r\n                        </ng-container>\r\n                      </ngx-sirio-tab>\r\n                    </div>\r\n                  </ng-container>\r\n                  <!-- #endregion -->\r\n                  <!-- #region accordion -->\r\n                  <ng-container *ngSwitchCase=\"'accordion'\">\r\n                    <div [register]=\"component\"\r\n                         [componentRef]=\"dynamiclistaccordion\">\r\n                      <ngx-sirio-accordion [accordionCount]=\"getFormArray(formGroup.get(component.path)).controls.length\"\r\n                                           #dynamiclistaccordion>\r\n                        <ng-container *ngFor=\"let item of getFormArray(formGroup.get(component.path)).controls; let i = index;\" [formGroupName]=\"i\">\r\n                          <ngx-sirio-accordion-panel>\r\n                            <ngx-sirio-accordion-header>\r\n                              <span [innerText]=\"component.label + ' ' + (i + 1)\"></span>\r\n                            </ngx-sirio-accordion-header>\r\n                            <ngx-sirio-accordion-body>\r\n                              <!--<ng-container *ngTemplateOutlet=\"itemTemplate; context: { item: item, index: i }\"></ng-container>-->\r\n                              <div [ngClass]=\"{\r\n              'group-top': component.verticalAlignment === 'start',\r\n              'group-center': component.verticalAlignment === 'center',\r\n              'group-bottom': component.verticalAlignment === 'end'}\">\r\n                                <div>\r\n                                  <app-dynamic-fields [formGroup]=\"getFormGroup(item)\" [rows]=\"component.rows\"></app-dynamic-fields>\r\n                                </div>\r\n                                <ng-container *ngIf=\"component.allowAddRemove\">\r\n                                  <div style=\"text-align:right\">\r\n                                    <ngx-sirio-button (click)=\"removeItem(component, i)\" class=\"remove-item\" [color]=\"null\" icon=\"fas fa-trash\">{{ Texts.RemoveItem }}</ngx-sirio-button>\r\n                                  </div>\r\n                                </ng-container>\r\n                              </div>\r\n                            </ngx-sirio-accordion-body>\r\n                          </ngx-sirio-accordion-panel>\r\n                        </ng-container>\r\n                      </ngx-sirio-accordion>\r\n                    </div>\r\n                  </ng-container>\r\n                  <!-- #endregion -->\r\n                  <!-- #region default -->\r\n                  <ng-container *ngSwitchDefault>\r\n                    <div [ngClass]=\"{'group-outline': component.showOutline === true}\"\r\n                         #dynamiclist\r\n                         [register]=\"component\"\r\n                         [componentRef]=\"dynamiclist\">\r\n                      <label>{{ evaluateString(component.label) }}</label>\r\n                      <ng-container *ngFor=\"let item of getFormArray(formGroup.get(component.path)).controls; let i = index;\" [formGroupName]=\"i\">\r\n                        <div [ngClass]=\"{\r\n        'group-top': component.verticalAlignment === 'start',\r\n        'group-center': component.verticalAlignment === 'center',\r\n        'group-bottom': component.verticalAlignment === 'end'}\">\r\n                          <div>\r\n                            <app-dynamic-fields [formGroup]=\"getFormGroup(item)\" [rows]=\"component.rows\"></app-dynamic-fields>\r\n                          </div>\r\n                          <ng-container *ngIf=\"component.allowAddRemove\">\r\n                            <div style=\"text-align:right\">\r\n                              <ngx-sirio-button (click)=\"removeItem(component, i)\" class=\"remove-item\" [color]=\"null\" icon=\"fas fa-trash\">{{ Texts.RemoveItem }}</ngx-sirio-button>\r\n                            </div>\r\n                          </ng-container>\r\n                        </div>\r\n                      </ng-container>\r\n                    </div>\r\n                  </ng-container>\r\n                  <!-- #endregion -->\r\n                </ng-container>                          \r\n                <ng-container *ngIf=\"component.allowAddRemove\">\r\n                  <ngx-sirio-button (click)=\"addNewItem(component)\" class=\"add-item\" [color]=\"null\" icon=\"fas fa-plus\">{{ Texts.AddItem }}</ngx-sirio-button>\r\n                </ng-container>\r\n              </ng-container>\r\n            </ng-container>\r\n          </ng-container>\r\n          <!-- #endregion -->\r\n          <!-- #region group -->\r\n          <ng-container *ngSwitchCase=\"'group'\">\r\n            <div [ngClass]=\"{\r\n                 'group-outline': component.showOutline === true,\r\n                 'group-top': component.verticalAlignment === 'start',\r\n                 'group-center': component.verticalAlignment === 'center',\r\n                 'group-bottom': component.verticalAlignment === 'end'}\"\r\n                 [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n                 [show]=\"evaluateBoolean(component.conditional?.show)\">\r\n              <label>{{ evaluateString(component.label) }}</label>\r\n              <div #group\r\n                   [register]=\"component\"\r\n                   [componentRef]=\"group\">\r\n                <app-dynamic-fields [formGroup]=\"getFormGroup(getControlFromPath(component.path))\"\r\n                                    [rows]=\"component.rows\"></app-dynamic-fields>\r\n              </div>\r\n            </div>\r\n          </ng-container>\r\n          <!-- #endregion -->\r\n          <!-- #region table -->\r\n          <ng-container *ngSwitchCase=\"'table'\">\r\n            <ag-grid-angular [modules]=\"getGridModules(component)\"\r\n                             [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n                             [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n                             [gridOptions]=\"getGridOptions(component)\"\r\n                             [rowSource]=\"(getGridData(component) | async) || []\"\r\n                             [style.height.px]=\"component.height\"\r\n                             #table\r\n                             [register]=\"component\"\r\n                             [componentRef]=\"table\" />\r\n          </ng-container>\r\n          <!-- #endregion -->\r\n          <!-- #region button -->\r\n          <ng-container *ngSwitchCase=\"'button'\">\r\n            <ngx-sirio-button (clickEvent)=\"clickButton(component, $event)\"\r\n                              [color]=\"evaluateColor(component.color)\"\r\n                              [icon]=\"evaluateString(component.icon)\"\r\n                              [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n                              [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n                              [disabled]=\"evaluateBoolean(component.disabled)\"\r\n                              #button\r\n                              [register]=\"component\"\r\n                              [componentRef]=\"button\">\r\n              {{ evaluateString(component.label) }}\r\n            </ngx-sirio-button>\r\n          </ng-container>\r\n          <!-- #endregion -->\r\n          <!-- #region separator -->\r\n          <ng-container *ngSwitchCase=\"'separator'\">\r\n            <div class=\"separator\"\r\n                 [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n                 [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n                 #separator\r\n                 [register]=\"component\"\r\n                 [componentRef]=\"separator\">\r\n            </div>\r\n          </ng-container>\r\n          <!-- #endregion -->\r\n          <!-- #region spacer -->\r\n          <ng-container *ngSwitchCase=\"'spacer'\">\r\n            <div style=\"width: 100%\"\r\n                 [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n                 [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n                 [style.height.px]=\"component.height\"\r\n                 #spacer\r\n                 [register]=\"component\"\r\n                 [componentRef]=\"spacer\">\r\n            </div>\r\n          </ng-container>\r\n          <!-- #endregion -->\r\n          <!-- #region iframe -->\r\n          <ng-container *ngSwitchCase=\"'iframe'\">\r\n            <div [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n                 [show]=\"evaluateBoolean(component.conditional?.show)\">\r\n              <label [for]=\"component.id\">{{ evaluateString(component.label) }}</label>\r\n              <iframe [src]=\"evaluateUrl(component.url)\"\r\n                      [title]=\"evaluateString(component.label)\"\r\n                      [style.width]=\"'100%'\"\r\n                      [style.height.px]=\"component.height\"\r\n                      [frameSecurity]=\"component.security\"\r\n                      #iframe\r\n                      [register]=\"component\"\r\n                      [componentRef]=\"iframe\">\r\n              </iframe>\r\n            </div>\r\n          </ng-container>\r\n          <!-- #endregion -->\r\n          <!-- #region alert -->\r\n          <ng-container *ngSwitchCase=\"'alert'\">\r\n            <ngx-sirio-alert [type]=\"component.role\"\r\n                             [labelClose]=\"Texts.Close\"\r\n                             [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n                             [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n                             #alert\r\n                             [register]=\"component\"\r\n                             [componentRef]=\"alert\">\r\n              <ngx-sirio-alert-message>\r\n                <div class=\"text-paragraph\"\r\n                     [innerHTML]=\"toHTML(evaluateTemplate(component.text))\">\r\n                </div>\r\n              </ngx-sirio-alert-message>\r\n            </ngx-sirio-alert>\r\n          </ng-container>\r\n          <!-- #endregion -->\r\n          <!-- #region notice -->\r\n          <ng-container *ngSwitchCase=\"'notice'\">\r\n            <ngx-sirio-notify\r\n                [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n                [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n                #notice\r\n                [register]=\"component\"\r\n                [componentRef]=\"notice\">\r\n              <ngx-sirio-notify-body [title]=\"evaluateString(component.title)\">\r\n                <div class=\"text-paragraph\"\r\n                     [innerHTML]=\"toHTML(evaluateTemplate(component.text))\">\r\n                </div>\r\n              </ngx-sirio-notify-body>\r\n            </ngx-sirio-notify>\r\n          </ng-container>\r\n          <!-- #endregion -->\r\n          <!-- #region range -->\r\n          <ng-container *ngSwitchCase=\"'range'\">\r\n            <ngx-sirio-slider [label]=\"evaluateString(component.label)\"\r\n                              [labelPopover]=\"evaluateString(component.tooltip)\"\r\n                              [textHelp]=\"evaluateString(component.description)\"\r\n                              [textFeedback]=\"getTextFeedback(component)\"\r\n                              [readonly]=\"evaluateBoolean(component.readonly)\"\r\n                              [disableControl]=\"evaluateBoolean(component.disabled)\"\r\n                              [hide]=\"evaluateBoolean(component.conditional?.hide)\"\r\n                              [show]=\"evaluateBoolean(component.conditional?.show)\"\r\n                              [formControlName]=\"component.key\"\r\n                              validation\r\n                              [canValidate]=\"true\"\r\n                              [isWarning]=\"isWarning(component)\"\r\n                              [showWhenValid]=\"false\"\r\n                              [min]=\"evaluateNumber(component.range?.min) ?? 0\"\r\n                              [max]=\"evaluateNumber(component.range?.max) ?? 0\"\r\n                              #range\r\n                              [register]=\"component\"\r\n                              [componentRef]=\"range\">\r\n            </ngx-sirio-slider>\r\n          </ng-container>\r\n          <!-- #endregion -->\r\n        </div>\r\n      </ng-container>\r\n    </ng-container>\r\n  </div>\r\n</ng-container>\r\n"]}
|