@olafvv/ngx-dynamic-form 0.2.0 → 0.3.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.
Files changed (38) hide show
  1. package/README.md +326 -3
  2. package/esm2022/lib/components/dynamic-form/dynamic-form.component.mjs +6 -15
  3. package/esm2022/lib/components/dynamic-form-field/dynamic-form-field.component.mjs +5 -5
  4. package/esm2022/lib/controls/button/dynamic-button.component.mjs +5 -5
  5. package/esm2022/lib/controls/button/dynamic-button.model.mjs +2 -3
  6. package/esm2022/lib/controls/button-toggles/dynamic-button-toggles.component.mjs +6 -6
  7. package/esm2022/lib/controls/checkbox/dynamic-checkbox.component.mjs +3 -3
  8. package/esm2022/lib/controls/input/dynamic-input.component.mjs +6 -6
  9. package/esm2022/lib/controls/input/dynamic-input.model.mjs +2 -1
  10. package/esm2022/lib/controls/radio-group/dynamic-radio-group.component.mjs +6 -6
  11. package/esm2022/lib/controls/readonly/dynamic-readonly.component.mjs +3 -3
  12. package/esm2022/lib/controls/select/dynamic-select.component.mjs +6 -9
  13. package/esm2022/lib/controls/textarea/dynamic-textarea.component.mjs +6 -6
  14. package/esm2022/lib/controls/textarea/dynamic-textarea.model.mjs +2 -1
  15. package/esm2022/lib/models/classes/dynamic-form-field-base.mjs +1 -1
  16. package/esm2022/lib/models/classes/dynamic-form-field-model.mjs +9 -2
  17. package/esm2022/lib/models/classes/dynamic-form-field-option-model.mjs +1 -1
  18. package/esm2022/lib/models/classes/dynamic-form-validators.mjs +21 -21
  19. package/esm2022/lib/models/constants/dynamic-relations.const.mjs +1 -1
  20. package/esm2022/lib/models/interfaces/dynamic-form-field-config.interface.mjs +1 -1
  21. package/esm2022/lib/models/interfaces/dynamic-form-field-relation.interface.mjs +1 -1
  22. package/esm2022/lib/services/dynamic-form-relations.service.mjs +13 -9
  23. package/esm2022/lib/services/dynamic-form.service.mjs +5 -5
  24. package/esm2022/lib/services/dynamic-validations.service.mjs +4 -4
  25. package/fesm2022/olafvv-ngx-dynamic-form.mjs +90 -91
  26. package/fesm2022/olafvv-ngx-dynamic-form.mjs.map +1 -1
  27. package/lib/components/dynamic-form/dynamic-form.component.d.ts +0 -7
  28. package/lib/components/dynamic-form-field/dynamic-form-field.component.d.ts +2 -2
  29. package/lib/controls/button/dynamic-button.model.d.ts +2 -4
  30. package/lib/controls/input/dynamic-input.model.d.ts +2 -0
  31. package/lib/controls/select/dynamic-select.component.d.ts +0 -2
  32. package/lib/controls/textarea/dynamic-textarea.model.d.ts +2 -0
  33. package/lib/models/classes/dynamic-form-field-model.d.ts +3 -1
  34. package/lib/models/classes/dynamic-form-validators.d.ts +12 -12
  35. package/lib/models/constants/dynamic-relations.const.d.ts +9 -1
  36. package/lib/models/interfaces/dynamic-form-field-config.interface.d.ts +7 -2
  37. package/lib/models/interfaces/dynamic-form-field-relation.interface.d.ts +9 -10
  38. package/package.json +1 -1
package/README.md CHANGED
@@ -1,6 +1,329 @@
1
1
  # NgxDynamicForm
2
2
 
3
- ## Create a custom Form Control
3
+ This library is to create a form based on a JSON model. The forms is based on the `ReactiveFormsModule` from Angular and contains a set of pre-built form controls using the Angular Material library. Using the built-in form controls is optional, you can use your own components to use as form controls inside the dynamic form. See [Custom Form Controls](#custom-form-controls) form more information.
4
+
5
+ ## Table of contents
6
+
7
+ - [Getting Started](#getting-started)
8
+ - [Usage](#usage)
9
+ - [Validators](#validators)
10
+ - [Built-in validators](#built-in-validators)
11
+ - [Custom validators](#custom-validators)
12
+ - [Relations](#relations)
13
+ - [Action type](#action-type)
14
+ - [Conditions](#conditions)
15
+ - [Operator](#operator)
16
+ - [Custom Form Controls](#custom-form-controls)
17
+
18
+ ## Getting started
19
+
20
+ ##### 1. Make sure to install and configure [Angular Material](https://material.angular.io/guide/getting-started) if you want to use the built-in form controls
21
+
22
+ ##### 2. Install the library using npm:
23
+
24
+ ```
25
+ npm i --save @olafvv/ngx-dynamic-form
26
+ ```
27
+
28
+ ## Usage
29
+
30
+ ##### 1. Import the (standalone) component
31
+
32
+ ```ts
33
+ import { DynamicFormComponent } from 'olafvv/ngx-dynamic-form';
34
+
35
+ @NgModule({
36
+ //...
37
+ imports: [DynamicFormComponent]
38
+ //...
39
+ })
40
+ export class AppModule {}
41
+ ```
42
+
43
+ **Or when using a standalone application/components:**
44
+
45
+ ```ts
46
+ import { DynamicFormComponent } from '@olafvv/ngx-dynamic-form';
47
+
48
+ @Component({
49
+ standalone: true,
50
+ imports: [DynamicFormComponent]
51
+ //...
52
+ })
53
+ export class AppComponent {
54
+ //...
55
+ }
56
+ ```
57
+
58
+ ##### 2. Define your form configuration
59
+
60
+ Create the JSON configuration for the form. This is a two-dimensional array where each array is a row in the form. So if you want multiple fields next to each other, define them in a single array. See [Form layout](#form-layout) for more information.
61
+
62
+ ```ts
63
+ import { DynamicInput, DynamicTextarea, DynamicFormValidators } from '@olafvv/ngx-dynamic-form';
64
+
65
+ export const SAMPLE_FORM: DynamicFormConfig = [
66
+ [
67
+ new DynamicInput({
68
+ name: 'name',
69
+ inputType: 'text',
70
+ label: 'Name'
71
+ })
72
+ ],
73
+ [
74
+ new DynamicInput({
75
+ name: 'email',
76
+ inputType: 'email',
77
+ label: 'Email address'
78
+ })
79
+ ],
80
+ [
81
+ new DynamicTextarea({
82
+ name: 'message',
83
+ label: 'Your message',
84
+ maxLength: 200,
85
+ rows: 5
86
+ })
87
+ ]
88
+ ];
89
+ ```
90
+
91
+ ##### 3. Create a FormGroup
92
+
93
+ This library provides the service `DynamicFormService` which you can use to create a FormGroup based on the created form configuration.
94
+
95
+ ```ts
96
+ import { SAMPLE_FORM } from './sample-form.ts';
97
+ import { DynamicFormService } from '@olafvv/ngx-dynamic-form;
98
+
99
+ @Component({
100
+ //...
101
+ })
102
+ export class AppComponent {
103
+ sampleFormConfig: DynamicFormConfig = SAMPLE_FORM;
104
+ sampleFormGroup: FormGroup<SampleFormModel> = this.dynamicFormService.createFormGroup(this.sampleFormConfig);
105
+
106
+ constructor(private dynamicFormService: DynamicFormService) {}
107
+ }
108
+ ```
109
+
110
+ ##### 4. Add the `dynamic-form` inside the template
111
+
112
+ To add the form to your template, you have to use the selector `<dynamic-form></dynamic-form>` and pass the FormGroup and configuration as inputs:
113
+
114
+ ```html
115
+ <form [formGroup]="sampleFormGroup">
116
+ <dynamic-form [group]="sampleFormGroup" [formConfig]="sampleFormConfig">
117
+ </form>
118
+ ```
119
+
120
+ ## Validators
121
+
122
+ This library comes with a set of built-in validators, based on the [Angular Validators](https://angular.dev/api/forms/Validators). All provided validators are static methods inside the class `DynamicFormValidators`, each returning a `DynamicFormValidator` (e.g. `DynamicFormValidators.required()`).
123
+
124
+ To use the validators, pass them inside the validators array of the field configuration:
125
+
126
+ ```ts
127
+ import { DynamicFormValidators } from '@olafvv/ngx-dynamic-form';
128
+
129
+ export const SAMPLE_FORM = [
130
+ [
131
+ new DynamicFormInput({
132
+ //..
133
+ validators: [DynamicFormValidators.required('Custom error message')]
134
+ })
135
+ ]
136
+ ];
137
+ ```
138
+
139
+ #### Built-in validators
140
+
141
+ Each validator has at least the optional parameter for a custom error message. If you don't provided one, the library will place a generic error message (e.g. for required: 'This field is required').
142
+
143
+ ```ts
144
+ class DynamicFormValidators {
145
+ // Validator that requires the control's value to be less than or equal to the provided number.
146
+ static email(errorMessage?: string): DynamicFormValidator;
147
+ // Validator that requires the control's value to be greater than or equal to the provided number.
148
+ static min(min: number, errorMessage?: string): DynamicFormValidator;
149
+ // Validator that requires the control's value to be less than or equal to the provided number.
150
+ static max(max: number, errorMessage?: string): DynamicFormValidator;
151
+ // Validator that requires the length of control's value to be greater than or equal to the provided number.
152
+ static minLength(min: number, errorMessage?: string): DynamicFormValidator;
153
+ // Validator that requires the length of control's value to be less than or equal to the provided number.
154
+ static maxLength(max: number, errorMessage?: string): DynamicFormValidator;
155
+ // Validator that requires the control's value to match the provided pattern.
156
+ static pattern(pattern: string | RexExp, errorMessage?: string): DynamicFormValidator;
157
+ // Validator that requires the control to have a non-empty value.
158
+ static required(errorMessage?: string): DynamicFormValidator;
159
+ // Validator that requires the control's value to be true.
160
+ static requiredTrue(errorMessage?: string): DynamicFormValidator;
161
+ }
162
+ ```
163
+
164
+ #### Custom Validators
165
+
166
+ Adding a custom validator is quite straightforward. All you have to do is to provide an object of the type `DynamicFormValidator` to the validators array of a field with a (unique) name, validatorFn and errorMessage.
167
+
168
+ Read more about creating custom Angular validators on the following page:
169
+
170
+ > https://blog.angular-university.io/angular-custom-validators/
171
+
172
+ E.g. a validator to require a minimum time:
173
+
174
+ ```ts
175
+ function minTimeValidatorFn(minTime: string): ValidatorFn {
176
+ return (control: AbstractControl): ValidationErrors | null => {
177
+ const inputTime = control.value as string;
178
+
179
+ if (!inputTime) return null;
180
+
181
+ const minTimeObj = new Date(`2000-01-01T${minTime}`);
182
+ const inputTimeObj = new Date(`2000-01-01T${inputTime}`);
183
+
184
+ return inputTimeObj >= minTimeObj ? null : { minTime: true };
185
+ };
186
+ }
187
+
188
+ export const minTimeValidator: (minTime: string, msg?: string) => DynamicFormValidator = (minTime: string, msg?: string) => ({
189
+ name: 'minTime',
190
+ validator: minTimeValidatorFn(minTime),
191
+ message: msg ?? `Minimale tijd is ${minTime}`
192
+ });
193
+ ```
194
+
195
+ ```ts
196
+ import { minTimeValidator } from './min-time-validator.ts';
197
+
198
+ //..
199
+
200
+ const formConfig: DynamicFormConfig = [
201
+ [
202
+ new DynamicInput({
203
+ name: 'time',
204
+ inputType: 'time',
205
+ validators: [minTimeValidator('11:00')]
206
+ })
207
+ ]
208
+ ];
209
+ ```
210
+
211
+ ## Relations
212
+
213
+ Sometimes you want to create certain connections between fields in a form to control their state, based on the value of the other field. This library provides a way to configure these connections,called relations.
214
+
215
+ Each relation is defined on the field that requires a specific state based on one or more conditions. Each relation, a `DynamicFormFieldRelation`, contains an actionType, one or more condition(s) and optionally an operator.
216
+
217
+ ```ts
218
+ interface DynamicFormFieldRelation {
219
+ actionType: RelationActionType;
220
+ conditions: RelationCondition[];
221
+ operator?: RelationOperator;
222
+ }
223
+ ```
224
+
225
+ ##### Action type
226
+
227
+ The action type is the type of state the field should be when the conditions are met. Right now the library contains three different action types:
228
+
229
+ - Disable/Enable
230
+ - Visible/Hidden
231
+ - Required/Optional
232
+
233
+ To set the type you have to use one of the provided enums:
234
+
235
+ ```ts
236
+ enum RelationActionType {
237
+ DISABLED = 'DISABLED',
238
+ ENABLED = 'ENABLED',
239
+ HIDDEN = 'HIDDEN',
240
+ VISIBLE = 'VISIBLE',
241
+ REQUIRED = 'REQUIRED',
242
+ OPTIONAL = 'OPTIONAL'
243
+ }
244
+ ```
245
+
246
+ ##### Conditions
247
+
248
+ The conditions is an array of `RelationCondition` objects. Each condition contains the name of the field the related field is depended on and a value when the condition is met:
249
+
250
+ ```ts
251
+ interface RelationCondition {
252
+ // The name of the field this field is related to
253
+ fieldName: string;
254
+ // A method which has to return a boolean. Returning true means the condition is met
255
+ value: (val: any) => boolean;
256
+ }
257
+ ```
258
+
259
+ ##### Operator
260
+
261
+ The operator is an optional property and determines if all or any one of the conditions have to return true to trigger the required state of the field. By default the value of this property is `RelationOperator.AND` and is only used when there are more than 1 conditions.
262
+
263
+ ```ts
264
+ enum RelationOperator {
265
+ // All conditions have to equal true
266
+ AND = 'AND',
267
+ // On of the conditions have to equal true
268
+ OR = 'OR'
269
+ }
270
+ ```
271
+
272
+ ##### Example
273
+
274
+ Here is an example of a field called 'passportNumber' which has to be visible when the value of the field named 'documentType' equals to 'passport':
275
+
276
+ ```ts
277
+ const formConfig = [
278
+ [
279
+ new DynamicSelect({
280
+ name: 'documentType',
281
+ label: 'Document type',
282
+ options: [
283
+ { label: 'Passport', value: 'passport' }
284
+ //..
285
+ ]
286
+ })
287
+ ][
288
+ new DymamicInput({
289
+ name: 'passportNumber',
290
+ label: 'Passport number',
291
+ relations: [
292
+ {
293
+ actionType: RelationActionType.VISIBLE,
294
+ conditions: [
295
+ {
296
+ fieldName: 'documentType',
297
+ value: (val: string) => val === 'passport'
298
+ }
299
+ ]
300
+ }
301
+ ]
302
+ })
303
+ ]
304
+ ];
305
+ ```
306
+
307
+ ## Built-in form controls
308
+
309
+ The library comes with a set of built-in form controls, using the Angular Material library. To make use of these you have to make sure to install and configure [Angular Material](https://material.angular.io).
310
+
311
+ The library comes with the following form controls:
312
+
313
+ | Form control name | Description |
314
+ | :---------------- | :------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ |
315
+ | Button | Shows a button inside the form. Can be provided with a label and/or icon. You also provide a callback method for what happens when the button is clicked |
316
+ | Button toggle | Based on the Angular Material component which shows a row of buttons, each holding a value (can be compared to radio buttons). It is possible to select one or multiple options |
317
+ | Checkbox | Shows a checkbox, indicating a true or false value |
318
+ | Input | Text based input using the HTML5 input element with Angular Material styling and animations. |
319
+ | Radio group | Uses the `mat-radio-group` of Angular Material to show a group of radio buttons to select a single option |
320
+ | Readonly | Shows the value of the control without the possibility to interact with it. |
321
+ | Select | Uses the `mat-select` of Angular Material to show a list of options inside a dropdown. |
322
+ | Textarea | The HTML5 `<textarea>` element with enchanced Angular Material styling and animations. |
323
+
324
+ Each control has a basic set of properties (see `DynamicFormFieldConfig`) that can be passed to the control's model. They also have a specific set of properties that only apply to the selected control.
325
+
326
+ ## Custom Form Controls
4
327
 
5
328
  Other than the build-in form controls, it is possible to plug in you own custom controls. Start out with creating a custom form control component:
6
329
 
@@ -8,14 +331,14 @@ Other than the build-in form controls, it is possible to plug in you own custom
8
331
 
9
332
  After that follow the following steps.
10
333
 
11
- ### Create a model
334
+ #### 1. Create a model
12
335
 
13
336
  First step is to create a model and interface for the custom control containing the control specific properties for the configuration definitions, extending the base interface/model from the library.
14
337
  Also, you need to create an (unique) name for the type of the model/.
15
338
 
16
339
  For example if you're creating a control with a slider to select a value between 0 and 10:
17
340
 
18
- #### Interface:
341
+ ##### Interface:
19
342
 
20
343
  The interface extends the base interface `DynamicFormFieldValueConfig` and expects a generic type describing the possible value(s) of the field. In this case that would be a number or null value.
21
344
 
@@ -1,4 +1,4 @@
1
- import { NgClass, NgFor } from '@angular/common';
1
+ import { NgClass } from '@angular/common';
2
2
  import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from '@angular/core';
3
3
  import { ReactiveFormsModule } from '@angular/forms';
4
4
  import { DynamicFormService } from '../../services/dynamic-form.service';
@@ -14,15 +14,6 @@ export class DynamicFormComponent {
14
14
  get flatFormConfig() {
15
15
  return this.formConfig.reduce((acc, curr) => acc.concat(curr), []);
16
16
  }
17
- /**
18
- * TrackBy Function for performance optimization
19
- * @param _index
20
- * @param field
21
- * @returns
22
- */
23
- trackByFn(_index, field) {
24
- return field.id;
25
- }
26
17
  /**
27
18
  * Get the current value of the form.
28
19
  * @param includeDisabledFields Include the disabled fields of the form, is enabled by default
@@ -47,12 +38,12 @@ export class DynamicFormComponent {
47
38
  onChange(event) {
48
39
  this.change.emit(event);
49
40
  }
50
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DynamicFormComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
51
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DynamicFormComponent, isStandalone: true, selector: "dynamic-form", inputs: { group: "group", formConfig: "formConfig" }, outputs: { change: "change" }, providers: [DynamicFormService], ngImport: i0, template: "<div *ngFor=\"let row of formConfig\"\n class=\"dynamic-form-row\">\n <dynamic-form-field *ngFor=\"let field of row; trackBy: trackByFn\"\n class=\"dynamic-form-field\"\n [id]=\"field.id\"\n [hidden]=\"field.hidden\"\n [ngClass]=\"[field.type, 'form-field-width-' + field.width]\"\n [group]=\"group\"\n [model]=\"field\"\n (change)=\"onChange($event)\">\n </dynamic-form-field>\n</div>", styles: [".dynamic-form-row{display:flex}.dynamic-form-row .dynamic-form-field{width:100%;margin:4px 0}.dynamic-form-row .dynamic-form-field:not(:last-of-type){margin-right:12px}.dynamic-form-row .dynamic-form-field.button{flex:0}.dynamic-form-row .form-field-width-1{width:1%}.dynamic-form-row .form-field-width-2{width:2%}.dynamic-form-row .form-field-width-3{width:3%}.dynamic-form-row .form-field-width-4{width:4%}.dynamic-form-row .form-field-width-5{width:5%}.dynamic-form-row .form-field-width-6{width:6%}.dynamic-form-row .form-field-width-7{width:7%}.dynamic-form-row .form-field-width-8{width:8%}.dynamic-form-row .form-field-width-9{width:9%}.dynamic-form-row .form-field-width-10{width:10%}.dynamic-form-row .form-field-width-11{width:11%}.dynamic-form-row .form-field-width-12{width:12%}.dynamic-form-row .form-field-width-13{width:13%}.dynamic-form-row .form-field-width-14{width:14%}.dynamic-form-row .form-field-width-15{width:15%}.dynamic-form-row .form-field-width-16{width:16%}.dynamic-form-row .form-field-width-17{width:17%}.dynamic-form-row .form-field-width-18{width:18%}.dynamic-form-row .form-field-width-19{width:19%}.dynamic-form-row .form-field-width-20{width:20%}.dynamic-form-row .form-field-width-21{width:21%}.dynamic-form-row .form-field-width-22{width:22%}.dynamic-form-row .form-field-width-23{width:23%}.dynamic-form-row .form-field-width-24{width:24%}.dynamic-form-row .form-field-width-25{width:25%}.dynamic-form-row .form-field-width-26{width:26%}.dynamic-form-row .form-field-width-27{width:27%}.dynamic-form-row .form-field-width-28{width:28%}.dynamic-form-row .form-field-width-29{width:29%}.dynamic-form-row .form-field-width-30{width:30%}.dynamic-form-row .form-field-width-31{width:31%}.dynamic-form-row .form-field-width-32{width:32%}.dynamic-form-row .form-field-width-33{width:33%}.dynamic-form-row .form-field-width-34{width:34%}.dynamic-form-row .form-field-width-35{width:35%}.dynamic-form-row .form-field-width-36{width:36%}.dynamic-form-row .form-field-width-37{width:37%}.dynamic-form-row .form-field-width-38{width:38%}.dynamic-form-row .form-field-width-39{width:39%}.dynamic-form-row .form-field-width-40{width:40%}.dynamic-form-row .form-field-width-41{width:41%}.dynamic-form-row .form-field-width-42{width:42%}.dynamic-form-row .form-field-width-43{width:43%}.dynamic-form-row .form-field-width-44{width:44%}.dynamic-form-row .form-field-width-45{width:45%}.dynamic-form-row .form-field-width-46{width:46%}.dynamic-form-row .form-field-width-47{width:47%}.dynamic-form-row .form-field-width-48{width:48%}.dynamic-form-row .form-field-width-49{width:49%}.dynamic-form-row .form-field-width-50{width:50%}.dynamic-form-row .form-field-width-51{width:51%}.dynamic-form-row .form-field-width-52{width:52%}.dynamic-form-row .form-field-width-53{width:53%}.dynamic-form-row .form-field-width-54{width:54%}.dynamic-form-row .form-field-width-55{width:55%}.dynamic-form-row .form-field-width-56{width:56%}.dynamic-form-row .form-field-width-57{width:57%}.dynamic-form-row .form-field-width-58{width:58%}.dynamic-form-row .form-field-width-59{width:59%}.dynamic-form-row .form-field-width-60{width:60%}.dynamic-form-row .form-field-width-61{width:61%}.dynamic-form-row .form-field-width-62{width:62%}.dynamic-form-row .form-field-width-63{width:63%}.dynamic-form-row .form-field-width-64{width:64%}.dynamic-form-row .form-field-width-65{width:65%}.dynamic-form-row .form-field-width-66{width:66%}.dynamic-form-row .form-field-width-67{width:67%}.dynamic-form-row .form-field-width-68{width:68%}.dynamic-form-row .form-field-width-69{width:69%}.dynamic-form-row .form-field-width-70{width:70%}.dynamic-form-row .form-field-width-71{width:71%}.dynamic-form-row .form-field-width-72{width:72%}.dynamic-form-row .form-field-width-73{width:73%}.dynamic-form-row .form-field-width-74{width:74%}.dynamic-form-row .form-field-width-75{width:75%}.dynamic-form-row .form-field-width-76{width:76%}.dynamic-form-row .form-field-width-77{width:77%}.dynamic-form-row .form-field-width-78{width:78%}.dynamic-form-row .form-field-width-79{width:79%}.dynamic-form-row .form-field-width-80{width:80%}.dynamic-form-row .form-field-width-81{width:81%}.dynamic-form-row .form-field-width-82{width:82%}.dynamic-form-row .form-field-width-83{width:83%}.dynamic-form-row .form-field-width-84{width:84%}.dynamic-form-row .form-field-width-85{width:85%}.dynamic-form-row .form-field-width-86{width:86%}.dynamic-form-row .form-field-width-87{width:87%}.dynamic-form-row .form-field-width-88{width:88%}.dynamic-form-row .form-field-width-89{width:89%}.dynamic-form-row .form-field-width-90{width:90%}.dynamic-form-row .form-field-width-91{width:91%}.dynamic-form-row .form-field-width-92{width:92%}.dynamic-form-row .form-field-width-93{width:93%}.dynamic-form-row .form-field-width-94{width:94%}.dynamic-form-row .form-field-width-95{width:95%}.dynamic-form-row .form-field-width-96{width:96%}.dynamic-form-row .form-field-width-97{width:97%}.dynamic-form-row .form-field-width-98{width:98%}.dynamic-form-row .form-field-width-99{width:99%}.dynamic-form-row .form-field-width-100{width:100%}\n"], dependencies: [{ kind: "directive", type: NgFor, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: DynamicFormFieldComponent, selector: "dynamic-form-field", inputs: ["model", "group"], outputs: ["change"] }, { kind: "ngmodule", type: ReactiveFormsModule }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
41
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DynamicFormComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
42
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: DynamicFormComponent, isStandalone: true, selector: "dynamic-form", inputs: { group: "group", formConfig: "formConfig" }, outputs: { change: "change" }, providers: [DynamicFormService], ngImport: i0, template: "@for(row of formConfig; track $index) {\n<div class=\"dynamic-form-row\">\n @for(field of row; track field.id) {\n <dynamic-form-field class=\"dynamic-form-field\"\n [id]=\"field.id\"\n [hidden]=\"field.hidden\"\n [ngClass]=\"[field.type, 'form-field-width-' + field.width]\"\n [group]=\"group\"\n [model]=\"field\"\n (change)=\"onChange($event)\">\n </dynamic-form-field>\n }\n</div>\n}", styles: [".dynamic-form-row{display:flex}.dynamic-form-row .dynamic-form-field{width:100%;margin:4px 0}.dynamic-form-row .dynamic-form-field:not(:last-of-type){margin-right:12px}.dynamic-form-row .dynamic-form-field.button{flex:0}.dynamic-form-row .form-field-width-1{width:1%}.dynamic-form-row .form-field-width-2{width:2%}.dynamic-form-row .form-field-width-3{width:3%}.dynamic-form-row .form-field-width-4{width:4%}.dynamic-form-row .form-field-width-5{width:5%}.dynamic-form-row .form-field-width-6{width:6%}.dynamic-form-row .form-field-width-7{width:7%}.dynamic-form-row .form-field-width-8{width:8%}.dynamic-form-row .form-field-width-9{width:9%}.dynamic-form-row .form-field-width-10{width:10%}.dynamic-form-row .form-field-width-11{width:11%}.dynamic-form-row .form-field-width-12{width:12%}.dynamic-form-row .form-field-width-13{width:13%}.dynamic-form-row .form-field-width-14{width:14%}.dynamic-form-row .form-field-width-15{width:15%}.dynamic-form-row .form-field-width-16{width:16%}.dynamic-form-row .form-field-width-17{width:17%}.dynamic-form-row .form-field-width-18{width:18%}.dynamic-form-row .form-field-width-19{width:19%}.dynamic-form-row .form-field-width-20{width:20%}.dynamic-form-row .form-field-width-21{width:21%}.dynamic-form-row .form-field-width-22{width:22%}.dynamic-form-row .form-field-width-23{width:23%}.dynamic-form-row .form-field-width-24{width:24%}.dynamic-form-row .form-field-width-25{width:25%}.dynamic-form-row .form-field-width-26{width:26%}.dynamic-form-row .form-field-width-27{width:27%}.dynamic-form-row .form-field-width-28{width:28%}.dynamic-form-row .form-field-width-29{width:29%}.dynamic-form-row .form-field-width-30{width:30%}.dynamic-form-row .form-field-width-31{width:31%}.dynamic-form-row .form-field-width-32{width:32%}.dynamic-form-row .form-field-width-33{width:33%}.dynamic-form-row .form-field-width-34{width:34%}.dynamic-form-row .form-field-width-35{width:35%}.dynamic-form-row .form-field-width-36{width:36%}.dynamic-form-row .form-field-width-37{width:37%}.dynamic-form-row .form-field-width-38{width:38%}.dynamic-form-row .form-field-width-39{width:39%}.dynamic-form-row .form-field-width-40{width:40%}.dynamic-form-row .form-field-width-41{width:41%}.dynamic-form-row .form-field-width-42{width:42%}.dynamic-form-row .form-field-width-43{width:43%}.dynamic-form-row .form-field-width-44{width:44%}.dynamic-form-row .form-field-width-45{width:45%}.dynamic-form-row .form-field-width-46{width:46%}.dynamic-form-row .form-field-width-47{width:47%}.dynamic-form-row .form-field-width-48{width:48%}.dynamic-form-row .form-field-width-49{width:49%}.dynamic-form-row .form-field-width-50{width:50%}.dynamic-form-row .form-field-width-51{width:51%}.dynamic-form-row .form-field-width-52{width:52%}.dynamic-form-row .form-field-width-53{width:53%}.dynamic-form-row .form-field-width-54{width:54%}.dynamic-form-row .form-field-width-55{width:55%}.dynamic-form-row .form-field-width-56{width:56%}.dynamic-form-row .form-field-width-57{width:57%}.dynamic-form-row .form-field-width-58{width:58%}.dynamic-form-row .form-field-width-59{width:59%}.dynamic-form-row .form-field-width-60{width:60%}.dynamic-form-row .form-field-width-61{width:61%}.dynamic-form-row .form-field-width-62{width:62%}.dynamic-form-row .form-field-width-63{width:63%}.dynamic-form-row .form-field-width-64{width:64%}.dynamic-form-row .form-field-width-65{width:65%}.dynamic-form-row .form-field-width-66{width:66%}.dynamic-form-row .form-field-width-67{width:67%}.dynamic-form-row .form-field-width-68{width:68%}.dynamic-form-row .form-field-width-69{width:69%}.dynamic-form-row .form-field-width-70{width:70%}.dynamic-form-row .form-field-width-71{width:71%}.dynamic-form-row .form-field-width-72{width:72%}.dynamic-form-row .form-field-width-73{width:73%}.dynamic-form-row .form-field-width-74{width:74%}.dynamic-form-row .form-field-width-75{width:75%}.dynamic-form-row .form-field-width-76{width:76%}.dynamic-form-row .form-field-width-77{width:77%}.dynamic-form-row .form-field-width-78{width:78%}.dynamic-form-row .form-field-width-79{width:79%}.dynamic-form-row .form-field-width-80{width:80%}.dynamic-form-row .form-field-width-81{width:81%}.dynamic-form-row .form-field-width-82{width:82%}.dynamic-form-row .form-field-width-83{width:83%}.dynamic-form-row .form-field-width-84{width:84%}.dynamic-form-row .form-field-width-85{width:85%}.dynamic-form-row .form-field-width-86{width:86%}.dynamic-form-row .form-field-width-87{width:87%}.dynamic-form-row .form-field-width-88{width:88%}.dynamic-form-row .form-field-width-89{width:89%}.dynamic-form-row .form-field-width-90{width:90%}.dynamic-form-row .form-field-width-91{width:91%}.dynamic-form-row .form-field-width-92{width:92%}.dynamic-form-row .form-field-width-93{width:93%}.dynamic-form-row .form-field-width-94{width:94%}.dynamic-form-row .form-field-width-95{width:95%}.dynamic-form-row .form-field-width-96{width:96%}.dynamic-form-row .form-field-width-97{width:97%}.dynamic-form-row .form-field-width-98{width:98%}.dynamic-form-row .form-field-width-99{width:99%}.dynamic-form-row .form-field-width-100{width:100%}\n"], dependencies: [{ kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: DynamicFormFieldComponent, selector: "dynamic-form-field", inputs: ["model", "group"], outputs: ["change"] }, { kind: "ngmodule", type: ReactiveFormsModule }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
52
43
  }
53
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DynamicFormComponent, decorators: [{
44
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DynamicFormComponent, decorators: [{
54
45
  type: Component,
55
- args: [{ standalone: true, imports: [NgFor, NgClass, DynamicFormFieldComponent, ReactiveFormsModule], selector: 'dynamic-form', providers: [DynamicFormService], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div *ngFor=\"let row of formConfig\"\n class=\"dynamic-form-row\">\n <dynamic-form-field *ngFor=\"let field of row; trackBy: trackByFn\"\n class=\"dynamic-form-field\"\n [id]=\"field.id\"\n [hidden]=\"field.hidden\"\n [ngClass]=\"[field.type, 'form-field-width-' + field.width]\"\n [group]=\"group\"\n [model]=\"field\"\n (change)=\"onChange($event)\">\n </dynamic-form-field>\n</div>", styles: [".dynamic-form-row{display:flex}.dynamic-form-row .dynamic-form-field{width:100%;margin:4px 0}.dynamic-form-row .dynamic-form-field:not(:last-of-type){margin-right:12px}.dynamic-form-row .dynamic-form-field.button{flex:0}.dynamic-form-row .form-field-width-1{width:1%}.dynamic-form-row .form-field-width-2{width:2%}.dynamic-form-row .form-field-width-3{width:3%}.dynamic-form-row .form-field-width-4{width:4%}.dynamic-form-row .form-field-width-5{width:5%}.dynamic-form-row .form-field-width-6{width:6%}.dynamic-form-row .form-field-width-7{width:7%}.dynamic-form-row .form-field-width-8{width:8%}.dynamic-form-row .form-field-width-9{width:9%}.dynamic-form-row .form-field-width-10{width:10%}.dynamic-form-row .form-field-width-11{width:11%}.dynamic-form-row .form-field-width-12{width:12%}.dynamic-form-row .form-field-width-13{width:13%}.dynamic-form-row .form-field-width-14{width:14%}.dynamic-form-row .form-field-width-15{width:15%}.dynamic-form-row .form-field-width-16{width:16%}.dynamic-form-row .form-field-width-17{width:17%}.dynamic-form-row .form-field-width-18{width:18%}.dynamic-form-row .form-field-width-19{width:19%}.dynamic-form-row .form-field-width-20{width:20%}.dynamic-form-row .form-field-width-21{width:21%}.dynamic-form-row .form-field-width-22{width:22%}.dynamic-form-row .form-field-width-23{width:23%}.dynamic-form-row .form-field-width-24{width:24%}.dynamic-form-row .form-field-width-25{width:25%}.dynamic-form-row .form-field-width-26{width:26%}.dynamic-form-row .form-field-width-27{width:27%}.dynamic-form-row .form-field-width-28{width:28%}.dynamic-form-row .form-field-width-29{width:29%}.dynamic-form-row .form-field-width-30{width:30%}.dynamic-form-row .form-field-width-31{width:31%}.dynamic-form-row .form-field-width-32{width:32%}.dynamic-form-row .form-field-width-33{width:33%}.dynamic-form-row .form-field-width-34{width:34%}.dynamic-form-row .form-field-width-35{width:35%}.dynamic-form-row .form-field-width-36{width:36%}.dynamic-form-row .form-field-width-37{width:37%}.dynamic-form-row .form-field-width-38{width:38%}.dynamic-form-row .form-field-width-39{width:39%}.dynamic-form-row .form-field-width-40{width:40%}.dynamic-form-row .form-field-width-41{width:41%}.dynamic-form-row .form-field-width-42{width:42%}.dynamic-form-row .form-field-width-43{width:43%}.dynamic-form-row .form-field-width-44{width:44%}.dynamic-form-row .form-field-width-45{width:45%}.dynamic-form-row .form-field-width-46{width:46%}.dynamic-form-row .form-field-width-47{width:47%}.dynamic-form-row .form-field-width-48{width:48%}.dynamic-form-row .form-field-width-49{width:49%}.dynamic-form-row .form-field-width-50{width:50%}.dynamic-form-row .form-field-width-51{width:51%}.dynamic-form-row .form-field-width-52{width:52%}.dynamic-form-row .form-field-width-53{width:53%}.dynamic-form-row .form-field-width-54{width:54%}.dynamic-form-row .form-field-width-55{width:55%}.dynamic-form-row .form-field-width-56{width:56%}.dynamic-form-row .form-field-width-57{width:57%}.dynamic-form-row .form-field-width-58{width:58%}.dynamic-form-row .form-field-width-59{width:59%}.dynamic-form-row .form-field-width-60{width:60%}.dynamic-form-row .form-field-width-61{width:61%}.dynamic-form-row .form-field-width-62{width:62%}.dynamic-form-row .form-field-width-63{width:63%}.dynamic-form-row .form-field-width-64{width:64%}.dynamic-form-row .form-field-width-65{width:65%}.dynamic-form-row .form-field-width-66{width:66%}.dynamic-form-row .form-field-width-67{width:67%}.dynamic-form-row .form-field-width-68{width:68%}.dynamic-form-row .form-field-width-69{width:69%}.dynamic-form-row .form-field-width-70{width:70%}.dynamic-form-row .form-field-width-71{width:71%}.dynamic-form-row .form-field-width-72{width:72%}.dynamic-form-row .form-field-width-73{width:73%}.dynamic-form-row .form-field-width-74{width:74%}.dynamic-form-row .form-field-width-75{width:75%}.dynamic-form-row .form-field-width-76{width:76%}.dynamic-form-row .form-field-width-77{width:77%}.dynamic-form-row .form-field-width-78{width:78%}.dynamic-form-row .form-field-width-79{width:79%}.dynamic-form-row .form-field-width-80{width:80%}.dynamic-form-row .form-field-width-81{width:81%}.dynamic-form-row .form-field-width-82{width:82%}.dynamic-form-row .form-field-width-83{width:83%}.dynamic-form-row .form-field-width-84{width:84%}.dynamic-form-row .form-field-width-85{width:85%}.dynamic-form-row .form-field-width-86{width:86%}.dynamic-form-row .form-field-width-87{width:87%}.dynamic-form-row .form-field-width-88{width:88%}.dynamic-form-row .form-field-width-89{width:89%}.dynamic-form-row .form-field-width-90{width:90%}.dynamic-form-row .form-field-width-91{width:91%}.dynamic-form-row .form-field-width-92{width:92%}.dynamic-form-row .form-field-width-93{width:93%}.dynamic-form-row .form-field-width-94{width:94%}.dynamic-form-row .form-field-width-95{width:95%}.dynamic-form-row .form-field-width-96{width:96%}.dynamic-form-row .form-field-width-97{width:97%}.dynamic-form-row .form-field-width-98{width:98%}.dynamic-form-row .form-field-width-99{width:99%}.dynamic-form-row .form-field-width-100{width:100%}\n"] }]
46
+ args: [{ standalone: true, imports: [NgClass, DynamicFormFieldComponent, ReactiveFormsModule], selector: 'dynamic-form', providers: [DynamicFormService], changeDetection: ChangeDetectionStrategy.OnPush, template: "@for(row of formConfig; track $index) {\n<div class=\"dynamic-form-row\">\n @for(field of row; track field.id) {\n <dynamic-form-field class=\"dynamic-form-field\"\n [id]=\"field.id\"\n [hidden]=\"field.hidden\"\n [ngClass]=\"[field.type, 'form-field-width-' + field.width]\"\n [group]=\"group\"\n [model]=\"field\"\n (change)=\"onChange($event)\">\n </dynamic-form-field>\n }\n</div>\n}", styles: [".dynamic-form-row{display:flex}.dynamic-form-row .dynamic-form-field{width:100%;margin:4px 0}.dynamic-form-row .dynamic-form-field:not(:last-of-type){margin-right:12px}.dynamic-form-row .dynamic-form-field.button{flex:0}.dynamic-form-row .form-field-width-1{width:1%}.dynamic-form-row .form-field-width-2{width:2%}.dynamic-form-row .form-field-width-3{width:3%}.dynamic-form-row .form-field-width-4{width:4%}.dynamic-form-row .form-field-width-5{width:5%}.dynamic-form-row .form-field-width-6{width:6%}.dynamic-form-row .form-field-width-7{width:7%}.dynamic-form-row .form-field-width-8{width:8%}.dynamic-form-row .form-field-width-9{width:9%}.dynamic-form-row .form-field-width-10{width:10%}.dynamic-form-row .form-field-width-11{width:11%}.dynamic-form-row .form-field-width-12{width:12%}.dynamic-form-row .form-field-width-13{width:13%}.dynamic-form-row .form-field-width-14{width:14%}.dynamic-form-row .form-field-width-15{width:15%}.dynamic-form-row .form-field-width-16{width:16%}.dynamic-form-row .form-field-width-17{width:17%}.dynamic-form-row .form-field-width-18{width:18%}.dynamic-form-row .form-field-width-19{width:19%}.dynamic-form-row .form-field-width-20{width:20%}.dynamic-form-row .form-field-width-21{width:21%}.dynamic-form-row .form-field-width-22{width:22%}.dynamic-form-row .form-field-width-23{width:23%}.dynamic-form-row .form-field-width-24{width:24%}.dynamic-form-row .form-field-width-25{width:25%}.dynamic-form-row .form-field-width-26{width:26%}.dynamic-form-row .form-field-width-27{width:27%}.dynamic-form-row .form-field-width-28{width:28%}.dynamic-form-row .form-field-width-29{width:29%}.dynamic-form-row .form-field-width-30{width:30%}.dynamic-form-row .form-field-width-31{width:31%}.dynamic-form-row .form-field-width-32{width:32%}.dynamic-form-row .form-field-width-33{width:33%}.dynamic-form-row .form-field-width-34{width:34%}.dynamic-form-row .form-field-width-35{width:35%}.dynamic-form-row .form-field-width-36{width:36%}.dynamic-form-row .form-field-width-37{width:37%}.dynamic-form-row .form-field-width-38{width:38%}.dynamic-form-row .form-field-width-39{width:39%}.dynamic-form-row .form-field-width-40{width:40%}.dynamic-form-row .form-field-width-41{width:41%}.dynamic-form-row .form-field-width-42{width:42%}.dynamic-form-row .form-field-width-43{width:43%}.dynamic-form-row .form-field-width-44{width:44%}.dynamic-form-row .form-field-width-45{width:45%}.dynamic-form-row .form-field-width-46{width:46%}.dynamic-form-row .form-field-width-47{width:47%}.dynamic-form-row .form-field-width-48{width:48%}.dynamic-form-row .form-field-width-49{width:49%}.dynamic-form-row .form-field-width-50{width:50%}.dynamic-form-row .form-field-width-51{width:51%}.dynamic-form-row .form-field-width-52{width:52%}.dynamic-form-row .form-field-width-53{width:53%}.dynamic-form-row .form-field-width-54{width:54%}.dynamic-form-row .form-field-width-55{width:55%}.dynamic-form-row .form-field-width-56{width:56%}.dynamic-form-row .form-field-width-57{width:57%}.dynamic-form-row .form-field-width-58{width:58%}.dynamic-form-row .form-field-width-59{width:59%}.dynamic-form-row .form-field-width-60{width:60%}.dynamic-form-row .form-field-width-61{width:61%}.dynamic-form-row .form-field-width-62{width:62%}.dynamic-form-row .form-field-width-63{width:63%}.dynamic-form-row .form-field-width-64{width:64%}.dynamic-form-row .form-field-width-65{width:65%}.dynamic-form-row .form-field-width-66{width:66%}.dynamic-form-row .form-field-width-67{width:67%}.dynamic-form-row .form-field-width-68{width:68%}.dynamic-form-row .form-field-width-69{width:69%}.dynamic-form-row .form-field-width-70{width:70%}.dynamic-form-row .form-field-width-71{width:71%}.dynamic-form-row .form-field-width-72{width:72%}.dynamic-form-row .form-field-width-73{width:73%}.dynamic-form-row .form-field-width-74{width:74%}.dynamic-form-row .form-field-width-75{width:75%}.dynamic-form-row .form-field-width-76{width:76%}.dynamic-form-row .form-field-width-77{width:77%}.dynamic-form-row .form-field-width-78{width:78%}.dynamic-form-row .form-field-width-79{width:79%}.dynamic-form-row .form-field-width-80{width:80%}.dynamic-form-row .form-field-width-81{width:81%}.dynamic-form-row .form-field-width-82{width:82%}.dynamic-form-row .form-field-width-83{width:83%}.dynamic-form-row .form-field-width-84{width:84%}.dynamic-form-row .form-field-width-85{width:85%}.dynamic-form-row .form-field-width-86{width:86%}.dynamic-form-row .form-field-width-87{width:87%}.dynamic-form-row .form-field-width-88{width:88%}.dynamic-form-row .form-field-width-89{width:89%}.dynamic-form-row .form-field-width-90{width:90%}.dynamic-form-row .form-field-width-91{width:91%}.dynamic-form-row .form-field-width-92{width:92%}.dynamic-form-row .form-field-width-93{width:93%}.dynamic-form-row .form-field-width-94{width:94%}.dynamic-form-row .form-field-width-95{width:95%}.dynamic-form-row .form-field-width-96{width:96%}.dynamic-form-row .form-field-width-97{width:97%}.dynamic-form-row .form-field-width-98{width:98%}.dynamic-form-row .form-field-width-99{width:99%}.dynamic-form-row .form-field-width-100{width:100%}\n"] }]
56
47
  }], propDecorators: { group: [{
57
48
  type: Input,
58
49
  args: [{ required: true }]
@@ -62,4 +53,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
62
53
  }], change: [{
63
54
  type: Output
64
55
  }] } });
65
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHluYW1pYy1mb3JtLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1keW5hbWljLWZvcm0vc3JjL2xpYi9jb21wb25lbnRzL2R5bmFtaWMtZm9ybS9keW5hbWljLWZvcm0uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LWR5bmFtaWMtZm9ybS9zcmMvbGliL2NvbXBvbmVudHMvZHluYW1pYy1mb3JtL2R5bmFtaWMtZm9ybS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsT0FBTyxFQUFFLEtBQUssRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQ2pELE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDaEcsT0FBTyxFQUFFLG1CQUFtQixFQUFvQixNQUFNLGdCQUFnQixDQUFDO0FBS3ZFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHFDQUFxQyxDQUFDO0FBQ3pFLE9BQU8sRUFBRSx5QkFBeUIsRUFBRSxNQUFNLG9EQUFvRCxDQUFDOztBQVcvRixNQUFNLE9BQU8sb0JBQW9CO0lBVGpDO1FBYVksV0FBTSxHQUF3QyxJQUFJLFlBQVksRUFBRSxDQUFDO0tBZ0Q1RTtJQTlDQzs7T0FFRztJQUNILElBQVcsY0FBYztRQUN2QixPQUFPLElBQUksQ0FBQyxVQUFVLENBQUMsTUFBTSxDQUFDLENBQUMsR0FBRyxFQUFFLElBQUksRUFBRSxFQUFFLENBQUMsR0FBRyxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQztJQUNyRSxDQUFDO0lBRUQ7Ozs7O09BS0c7SUFDSSxTQUFTLENBQUMsTUFBYyxFQUFFLEtBQTRCO1FBQzNELE9BQU8sS0FBSyxDQUFDLEVBQUUsQ0FBQztJQUNsQixDQUFDO0lBRUQ7OztPQUdHO0lBQ0ksWUFBWSxDQUFjLHFCQUFxQixHQUFHLElBQUk7UUFDM0QsTUFBTSxTQUFTLEdBQUcscUJBQXFCLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsV0FBVyxFQUFFLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDO1FBRXRGLE9BQU8sU0FBUyxDQUFDO0lBQ25CLENBQUM7SUFFRDs7Ozs7T0FLRztJQUNJLGVBQWUsQ0FBQyxJQUFZO1FBQ2pDLE1BQU0sS0FBSyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxDQUFDO1FBRW5DLElBQUksQ0FBQyxLQUFLLEVBQUU7WUFDVixNQUFNLElBQUksS0FBSyxDQUFDLHFDQUFxQyxJQUFJLG1CQUFtQixDQUFDLENBQUM7U0FDL0U7UUFFRCxPQUFPLEtBQUssQ0FBQyxZQUFZLENBQUM7SUFDNUIsQ0FBQztJQUVNLFFBQVEsQ0FBQyxLQUE0QjtRQUMxQyxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUMxQixDQUFDOytHQW5EVSxvQkFBb0I7bUdBQXBCLG9CQUFvQixnSkFIcEIsQ0FBQyxrQkFBa0IsQ0FBQywwQkNoQmpDLDJaQVdNLDRpS0RDTSxLQUFLLG1IQUFFLE9BQU8sb0ZBQUUseUJBQXlCLCtHQUFFLG1CQUFtQjs7NEZBTzdELG9CQUFvQjtrQkFUaEMsU0FBUztpQ0FDSSxJQUFJLFdBQ1AsQ0FBQyxLQUFLLEVBQUUsT0FBTyxFQUFFLHlCQUF5QixFQUFFLG1CQUFtQixDQUFDLFlBQy9ELGNBQWMsYUFHYixDQUFDLGtCQUFrQixDQUFDLG1CQUNkLHVCQUF1QixDQUFDLE1BQU07OEJBR3BCLEtBQUs7c0JBQS9CLEtBQUs7dUJBQUMsRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFO2dCQUNFLFVBQVU7c0JBQXBDLEtBQUs7dUJBQUMsRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFO2dCQUVmLE1BQU07c0JBQWYsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nQ2xhc3MsIE5nRm9yIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgUmVhY3RpdmVGb3Jtc01vZHVsZSwgVW50eXBlZEZvcm1Hcm91cCB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7IE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IER5bmFtaWNGb3JtRmllbGRNb2RlbCB9IGZyb20gJy4uLy4uL21vZGVscy9jbGFzc2VzL2R5bmFtaWMtZm9ybS1maWVsZC1tb2RlbCc7XG5pbXBvcnQgeyBEeW5hbWljRm9ybUZpZWxkRXZlbnQgfSBmcm9tICcuLi8uLi9tb2RlbHMvaW50ZXJmYWNlcy9keW5hbWljLWZvcm0tZmllbGQtZXZlbnQuaW50ZXJmYWNlJztcbmltcG9ydCB7IER5bmFtaWNGb3JtQ29uZmlnIH0gZnJvbSAnLi4vLi4vbW9kZWxzL3R5cGVzL2R5bmFtaWMtZm9ybS1jb25maWcudHlwZSc7XG5pbXBvcnQgeyBEeW5hbWljRm9ybVNlcnZpY2UgfSBmcm9tICcuLi8uLi9zZXJ2aWNlcy9keW5hbWljLWZvcm0uc2VydmljZSc7XG5pbXBvcnQgeyBEeW5hbWljRm9ybUZpZWxkQ29tcG9uZW50IH0gZnJvbSAnLi4vZHluYW1pYy1mb3JtLWZpZWxkL2R5bmFtaWMtZm9ybS1maWVsZC5jb21wb25lbnQnO1xuXG5AQ29tcG9uZW50KHtcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW05nRm9yLCBOZ0NsYXNzLCBEeW5hbWljRm9ybUZpZWxkQ29tcG9uZW50LCBSZWFjdGl2ZUZvcm1zTW9kdWxlXSxcbiAgc2VsZWN0b3I6ICdkeW5hbWljLWZvcm0nLFxuICB0ZW1wbGF0ZVVybDogJ2R5bmFtaWMtZm9ybS5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2R5bmFtaWMtZm9ybS5jb21wb25lbnQuc2NzcyddLFxuICBwcm92aWRlcnM6IFtEeW5hbWljRm9ybVNlcnZpY2VdLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxufSlcbmV4cG9ydCBjbGFzcyBEeW5hbWljRm9ybUNvbXBvbmVudCB7XG4gIEBJbnB1dCh7IHJlcXVpcmVkOiB0cnVlIH0pIGdyb3VwITogVW50eXBlZEZvcm1Hcm91cDtcbiAgQElucHV0KHsgcmVxdWlyZWQ6IHRydWUgfSkgZm9ybUNvbmZpZyE6IER5bmFtaWNGb3JtQ29uZmlnO1xuXG4gIEBPdXRwdXQoKSBjaGFuZ2U6IEV2ZW50RW1pdHRlcjxEeW5hbWljRm9ybUZpZWxkRXZlbnQ+ID0gbmV3IEV2ZW50RW1pdHRlcigpO1xuXG4gIC8qKlxuICAgKiBHZXQgdGhlIGZvcm1Db25maWcgYXMgZmxhdCBhcnJheS5cbiAgICovXG4gIHB1YmxpYyBnZXQgZmxhdEZvcm1Db25maWcoKTogRHluYW1pY0Zvcm1GaWVsZE1vZGVsW10ge1xuICAgIHJldHVybiB0aGlzLmZvcm1Db25maWcucmVkdWNlKChhY2MsIGN1cnIpID0+IGFjYy5jb25jYXQoY3VyciksIFtdKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBUcmFja0J5IEZ1bmN0aW9uIGZvciBwZXJmb3JtYW5jZSBvcHRpbWl6YXRpb25cbiAgICogQHBhcmFtIF9pbmRleFxuICAgKiBAcGFyYW0gZmllbGRcbiAgICogQHJldHVybnNcbiAgICovXG4gIHB1YmxpYyB0cmFja0J5Rm4oX2luZGV4OiBudW1iZXIsIGZpZWxkOiBEeW5hbWljRm9ybUZpZWxkTW9kZWwpOiBzdHJpbmcge1xuICAgIHJldHVybiBmaWVsZC5pZDtcbiAgfVxuXG4gIC8qKlxuICAgKiBHZXQgdGhlIGN1cnJlbnQgdmFsdWUgb2YgdGhlIGZvcm0uXG4gICAqIEBwYXJhbSBpbmNsdWRlRGlzYWJsZWRGaWVsZHMgSW5jbHVkZSB0aGUgZGlzYWJsZWQgZmllbGRzIG9mIHRoZSBmb3JtLCBpcyBlbmFibGVkIGJ5IGRlZmF1bHRcbiAgICovXG4gIHB1YmxpYyBnZXRGb3JtVmFsdWU8VCA9IHVua25vd24+KGluY2x1ZGVEaXNhYmxlZEZpZWxkcyA9IHRydWUpOiBUIHtcbiAgICBjb25zdCBmb3JtVmFsdWUgPSBpbmNsdWRlRGlzYWJsZWRGaWVsZHMgPyB0aGlzLmdyb3VwLmdldFJhd1ZhbHVlKCkgOiB0aGlzLmdyb3VwLnZhbHVlO1xuXG4gICAgcmV0dXJuIGZvcm1WYWx1ZTtcbiAgfVxuXG4gIC8qKlxuICAgKiBQcm92aWRlcyBhbiBPYnNlcnZhYmxlIHRvIGxpc3RlbiB0byBjaGFuZ2VzIG9mIGEgc3BlY2lmaWMgZmllbGQgaW4gdGhlIGZvcm0uXG4gICAqXG4gICAqIEBwYXJhbSBuYW1lIE5hbWUgb2YgdGhlIGZpZWxkXG4gICAqIEByZXR1cm5zIE9ic2VydmFibGU8dW5rbm93bj5cbiAgICovXG4gIHB1YmxpYyBvbkNvbnRyb2xDaGFuZ2UobmFtZTogc3RyaW5nKTogT2JzZXJ2YWJsZTx1bmtub3duPiB7XG4gICAgY29uc3QgZmllbGQgPSB0aGlzLmdyb3VwLmdldChuYW1lKTtcblxuICAgIGlmICghZmllbGQpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcihgQ2Fubm90IGZpbmQgYSBmaWVsZCB3aXRoIHRoZSBuYW1lICR7bmFtZX0gaW4gdGhlIEZvcm1Hcm91cGApO1xuICAgIH1cblxuICAgIHJldHVybiBmaWVsZC52YWx1ZUNoYW5nZXM7XG4gIH1cblxuICBwdWJsaWMgb25DaGFuZ2UoZXZlbnQ6IER5bmFtaWNGb3JtRmllbGRFdmVudCkge1xuICAgIHRoaXMuY2hhbmdlLmVtaXQoZXZlbnQpO1xuICB9XG59XG4iLCI8ZGl2ICpuZ0Zvcj1cImxldCByb3cgb2YgZm9ybUNvbmZpZ1wiXG4gIGNsYXNzPVwiZHluYW1pYy1mb3JtLXJvd1wiPlxuICA8ZHluYW1pYy1mb3JtLWZpZWxkICpuZ0Zvcj1cImxldCBmaWVsZCBvZiByb3c7IHRyYWNrQnk6IHRyYWNrQnlGblwiXG4gICAgY2xhc3M9XCJkeW5hbWljLWZvcm0tZmllbGRcIlxuICAgIFtpZF09XCJmaWVsZC5pZFwiXG4gICAgW2hpZGRlbl09XCJmaWVsZC5oaWRkZW5cIlxuICAgIFtuZ0NsYXNzXT1cIltmaWVsZC50eXBlLCAnZm9ybS1maWVsZC13aWR0aC0nICsgZmllbGQud2lkdGhdXCJcbiAgICBbZ3JvdXBdPVwiZ3JvdXBcIlxuICAgIFttb2RlbF09XCJmaWVsZFwiXG4gICAgKGNoYW5nZSk9XCJvbkNoYW5nZSgkZXZlbnQpXCI+XG4gIDwvZHluYW1pYy1mb3JtLWZpZWxkPlxuPC9kaXY+Il19
56
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHluYW1pYy1mb3JtLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1keW5hbWljLWZvcm0vc3JjL2xpYi9jb21wb25lbnRzL2R5bmFtaWMtZm9ybS9keW5hbWljLWZvcm0uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LWR5bmFtaWMtZm9ybS9zcmMvbGliL2NvbXBvbmVudHMvZHluYW1pYy1mb3JtL2R5bmFtaWMtZm9ybS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDMUMsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNoRyxPQUFPLEVBQUUsbUJBQW1CLEVBQW9CLE1BQU0sZ0JBQWdCLENBQUM7QUFLdkUsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0scUNBQXFDLENBQUM7QUFDekUsT0FBTyxFQUFFLHlCQUF5QixFQUFFLE1BQU0sb0RBQW9ELENBQUM7O0FBVy9GLE1BQU0sT0FBTyxvQkFBb0I7SUFUakM7UUFhWSxXQUFNLEdBQXdDLElBQUksWUFBWSxFQUFFLENBQUM7S0FzQzVFO0lBcENDOztPQUVHO0lBQ0gsSUFBVyxjQUFjO1FBQ3ZCLE9BQU8sSUFBSSxDQUFDLFVBQVUsQ0FBQyxNQUFNLENBQUMsQ0FBQyxHQUFHLEVBQUUsSUFBSSxFQUFFLEVBQUUsQ0FBQyxHQUFHLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDO0lBQ3JFLENBQUM7SUFFRDs7O09BR0c7SUFDSSxZQUFZLENBQWMscUJBQXFCLEdBQUcsSUFBSTtRQUMzRCxNQUFNLFNBQVMsR0FBRyxxQkFBcUIsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxXQUFXLEVBQUUsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUM7UUFFdEYsT0FBTyxTQUFTLENBQUM7SUFDbkIsQ0FBQztJQUVEOzs7OztPQUtHO0lBQ0ksZUFBZSxDQUFDLElBQVk7UUFDakMsTUFBTSxLQUFLLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLENBQUM7UUFFbkMsSUFBSSxDQUFDLEtBQUssRUFBRSxDQUFDO1lBQ1gsTUFBTSxJQUFJLEtBQUssQ0FBQyxxQ0FBcUMsSUFBSSxtQkFBbUIsQ0FBQyxDQUFDO1FBQ2hGLENBQUM7UUFFRCxPQUFPLEtBQUssQ0FBQyxZQUFZLENBQUM7SUFDNUIsQ0FBQztJQUVNLFFBQVEsQ0FBQyxLQUE0QjtRQUMxQyxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUMxQixDQUFDOytHQXpDVSxvQkFBb0I7bUdBQXBCLG9CQUFvQixnSkFIcEIsQ0FBQyxrQkFBa0IsQ0FBQywwQkNoQmpDLDJaQWFDLDRpS0REVyxPQUFPLG9GQUFFLHlCQUF5QiwrR0FBRSxtQkFBbUI7OzRGQU90RCxvQkFBb0I7a0JBVGhDLFNBQVM7aUNBQ0ksSUFBSSxXQUNQLENBQUMsT0FBTyxFQUFFLHlCQUF5QixFQUFFLG1CQUFtQixDQUFDLFlBQ3hELGNBQWMsYUFHYixDQUFDLGtCQUFrQixDQUFDLG1CQUNkLHVCQUF1QixDQUFDLE1BQU07OEJBR3BCLEtBQUs7c0JBQS9CLEtBQUs7dUJBQUMsRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFO2dCQUNFLFVBQVU7c0JBQXBDLEtBQUs7dUJBQUMsRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFO2dCQUVmLE1BQU07c0JBQWYsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nQ2xhc3MgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBSZWFjdGl2ZUZvcm1zTW9kdWxlLCBVbnR5cGVkRm9ybUdyb3VwIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgT2JzZXJ2YWJsZSB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgRHluYW1pY0Zvcm1GaWVsZE1vZGVsIH0gZnJvbSAnLi4vLi4vbW9kZWxzL2NsYXNzZXMvZHluYW1pYy1mb3JtLWZpZWxkLW1vZGVsJztcbmltcG9ydCB7IER5bmFtaWNGb3JtRmllbGRFdmVudCB9IGZyb20gJy4uLy4uL21vZGVscy9pbnRlcmZhY2VzL2R5bmFtaWMtZm9ybS1maWVsZC1ldmVudC5pbnRlcmZhY2UnO1xuaW1wb3J0IHsgRHluYW1pY0Zvcm1Db25maWcgfSBmcm9tICcuLi8uLi9tb2RlbHMvdHlwZXMvZHluYW1pYy1mb3JtLWNvbmZpZy50eXBlJztcbmltcG9ydCB7IER5bmFtaWNGb3JtU2VydmljZSB9IGZyb20gJy4uLy4uL3NlcnZpY2VzL2R5bmFtaWMtZm9ybS5zZXJ2aWNlJztcbmltcG9ydCB7IER5bmFtaWNGb3JtRmllbGRDb21wb25lbnQgfSBmcm9tICcuLi9keW5hbWljLWZvcm0tZmllbGQvZHluYW1pYy1mb3JtLWZpZWxkLmNvbXBvbmVudCc7XG5cbkBDb21wb25lbnQoe1xuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbTmdDbGFzcywgRHluYW1pY0Zvcm1GaWVsZENvbXBvbmVudCwgUmVhY3RpdmVGb3Jtc01vZHVsZV0sXG4gIHNlbGVjdG9yOiAnZHluYW1pYy1mb3JtJyxcbiAgdGVtcGxhdGVVcmw6ICdkeW5hbWljLWZvcm0uY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9keW5hbWljLWZvcm0uY29tcG9uZW50LnNjc3MnXSxcbiAgcHJvdmlkZXJzOiBbRHluYW1pY0Zvcm1TZXJ2aWNlXSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcbn0pXG5leHBvcnQgY2xhc3MgRHluYW1pY0Zvcm1Db21wb25lbnQge1xuICBASW5wdXQoeyByZXF1aXJlZDogdHJ1ZSB9KSBncm91cCE6IFVudHlwZWRGb3JtR3JvdXA7XG4gIEBJbnB1dCh7IHJlcXVpcmVkOiB0cnVlIH0pIGZvcm1Db25maWchOiBEeW5hbWljRm9ybUNvbmZpZztcblxuICBAT3V0cHV0KCkgY2hhbmdlOiBFdmVudEVtaXR0ZXI8RHluYW1pY0Zvcm1GaWVsZEV2ZW50PiA9IG5ldyBFdmVudEVtaXR0ZXIoKTtcblxuICAvKipcbiAgICogR2V0IHRoZSBmb3JtQ29uZmlnIGFzIGZsYXQgYXJyYXkuXG4gICAqL1xuICBwdWJsaWMgZ2V0IGZsYXRGb3JtQ29uZmlnKCk6IER5bmFtaWNGb3JtRmllbGRNb2RlbFtdIHtcbiAgICByZXR1cm4gdGhpcy5mb3JtQ29uZmlnLnJlZHVjZSgoYWNjLCBjdXJyKSA9PiBhY2MuY29uY2F0KGN1cnIpLCBbXSk7XG4gIH1cblxuICAvKipcbiAgICogR2V0IHRoZSBjdXJyZW50IHZhbHVlIG9mIHRoZSBmb3JtLlxuICAgKiBAcGFyYW0gaW5jbHVkZURpc2FibGVkRmllbGRzIEluY2x1ZGUgdGhlIGRpc2FibGVkIGZpZWxkcyBvZiB0aGUgZm9ybSwgaXMgZW5hYmxlZCBieSBkZWZhdWx0XG4gICAqL1xuICBwdWJsaWMgZ2V0Rm9ybVZhbHVlPFQgPSB1bmtub3duPihpbmNsdWRlRGlzYWJsZWRGaWVsZHMgPSB0cnVlKTogVCB7XG4gICAgY29uc3QgZm9ybVZhbHVlID0gaW5jbHVkZURpc2FibGVkRmllbGRzID8gdGhpcy5ncm91cC5nZXRSYXdWYWx1ZSgpIDogdGhpcy5ncm91cC52YWx1ZTtcblxuICAgIHJldHVybiBmb3JtVmFsdWU7XG4gIH1cblxuICAvKipcbiAgICogUHJvdmlkZXMgYW4gT2JzZXJ2YWJsZSB0byBsaXN0ZW4gdG8gY2hhbmdlcyBvZiBhIHNwZWNpZmljIGZpZWxkIGluIHRoZSBmb3JtLlxuICAgKlxuICAgKiBAcGFyYW0gbmFtZSBOYW1lIG9mIHRoZSBmaWVsZFxuICAgKiBAcmV0dXJucyBPYnNlcnZhYmxlPHVua25vd24+XG4gICAqL1xuICBwdWJsaWMgb25Db250cm9sQ2hhbmdlKG5hbWU6IHN0cmluZyk6IE9ic2VydmFibGU8dW5rbm93bj4ge1xuICAgIGNvbnN0IGZpZWxkID0gdGhpcy5ncm91cC5nZXQobmFtZSk7XG5cbiAgICBpZiAoIWZpZWxkKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoYENhbm5vdCBmaW5kIGEgZmllbGQgd2l0aCB0aGUgbmFtZSAke25hbWV9IGluIHRoZSBGb3JtR3JvdXBgKTtcbiAgICB9XG5cbiAgICByZXR1cm4gZmllbGQudmFsdWVDaGFuZ2VzO1xuICB9XG5cbiAgcHVibGljIG9uQ2hhbmdlKGV2ZW50OiBEeW5hbWljRm9ybUZpZWxkRXZlbnQpIHtcbiAgICB0aGlzLmNoYW5nZS5lbWl0KGV2ZW50KTtcbiAgfVxufVxuIiwiQGZvcihyb3cgb2YgZm9ybUNvbmZpZzsgdHJhY2sgJGluZGV4KSB7XG48ZGl2IGNsYXNzPVwiZHluYW1pYy1mb3JtLXJvd1wiPlxuICBAZm9yKGZpZWxkIG9mIHJvdzsgdHJhY2sgZmllbGQuaWQpIHtcbiAgPGR5bmFtaWMtZm9ybS1maWVsZCBjbGFzcz1cImR5bmFtaWMtZm9ybS1maWVsZFwiXG4gICAgW2lkXT1cImZpZWxkLmlkXCJcbiAgICBbaGlkZGVuXT1cImZpZWxkLmhpZGRlblwiXG4gICAgW25nQ2xhc3NdPVwiW2ZpZWxkLnR5cGUsICdmb3JtLWZpZWxkLXdpZHRoLScgKyBmaWVsZC53aWR0aF1cIlxuICAgIFtncm91cF09XCJncm91cFwiXG4gICAgW21vZGVsXT1cImZpZWxkXCJcbiAgICAoY2hhbmdlKT1cIm9uQ2hhbmdlKCRldmVudClcIj5cbiAgPC9keW5hbWljLWZvcm0tZmllbGQ+XG4gIH1cbjwvZGl2PlxufSJdfQ==
@@ -26,9 +26,9 @@ import * as i1 from "@angular/forms";
26
26
  export class DynamicFormFieldComponent {
27
27
  constructor() {
28
28
  this.change = new EventEmitter();
29
- this._subs = new Subscription();
30
29
  this.dynamicFormService = inject(DynamicFormService);
31
30
  this.relationService = inject(DynamicFormRelationsService);
31
+ this._subs = new Subscription();
32
32
  }
33
33
  /** Get the instance of a control component using the injected custom method or local method */
34
34
  get componentType() {
@@ -128,10 +128,10 @@ export class DynamicFormFieldComponent {
128
128
  createDynamicFormEvent(event, type) {
129
129
  return { event, type, control: this._control, form: this.group, model: this.model };
130
130
  }
131
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DynamicFormFieldComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
132
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DynamicFormFieldComponent, isStandalone: true, selector: "dynamic-form-field", inputs: { model: "model", group: "group" }, outputs: { change: "change" }, viewQueries: [{ propertyName: "componentViewContainer", first: true, predicate: ["componentViewContainer"], descendants: true, read: ViewContainerRef, static: true }], ngImport: i0, template: "<div [formGroup]=\"group\"\n [ngClass]=\"['dynamic-form-field-container', 'dynamic-form-field-' + model.type]\">\n <ng-container #componentViewContainer></ng-container>\n</div>", dependencies: [{ kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
131
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DynamicFormFieldComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
132
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: DynamicFormFieldComponent, isStandalone: true, selector: "dynamic-form-field", inputs: { model: "model", group: "group" }, outputs: { change: "change" }, viewQueries: [{ propertyName: "componentViewContainer", first: true, predicate: ["componentViewContainer"], descendants: true, read: ViewContainerRef, static: true }], ngImport: i0, template: "<div [formGroup]=\"group\"\n [ngClass]=\"['dynamic-form-field-container', 'dynamic-form-field-' + model.type]\">\n <ng-container #componentViewContainer></ng-container>\n</div>", dependencies: [{ kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
133
133
  }
134
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DynamicFormFieldComponent, decorators: [{
134
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DynamicFormFieldComponent, decorators: [{
135
135
  type: Component,
136
136
  args: [{ standalone: true, imports: [NgClass, ReactiveFormsModule], selector: 'dynamic-form-field', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div [formGroup]=\"group\"\n [ngClass]=\"['dynamic-form-field-container', 'dynamic-form-field-' + model.type]\">\n <ng-container #componentViewContainer></ng-container>\n</div>" }]
137
137
  }], propDecorators: { componentViewContainer: [{
@@ -144,4 +144,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
144
144
  }], change: [{
145
145
  type: Output
146
146
  }] } });
147
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-form-field.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-dynamic-form/src/lib/components/dynamic-form-field/dynamic-form-field.component.ts","../../../../../../projects/ngx-dynamic-form/src/lib/components/dynamic-form-field/dynamic-form-field.component.html"],"names":[],"mappings":"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","sourcesContent":["import { NgClass } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  inject,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  Type,\n  ViewChild,\n  ViewContainerRef\n} from '@angular/core';\nimport { ReactiveFormsModule, UntypedFormControl, UntypedFormGroup } from '@angular/forms';\nimport { Subscription } from 'rxjs';\nimport { DynamicButtonTogglesComponent } from '../../controls/button-toggles/dynamic-button-toggles.component';\nimport { DYNAMIC_FORM_FIELD_BUTTON_TOGGLES } from '../../controls/button-toggles/dynamic-button-toggles.model';\nimport { DynamicButtonComponent } from '../../controls/button/dynamic-button.component';\nimport { DYNAMIC_FORM_FIELD_BUTTON } from '../../controls/button/dynamic-button.model';\nimport { DynamicCheckboxComponent } from '../../controls/checkbox/dynamic-checkbox.component';\nimport { DYNAMIC_FORM_FIELD_CHECKBOX } from '../../controls/checkbox/dynamic-checkbox.model';\nimport { DynamicInputComponent } from '../../controls/input/dynamic-input.component';\nimport { DYNAMIC_FORM_FIELD_INPUT } from '../../controls/input/dynamic-input.model';\nimport { DymamicRadioGroupComponent } from '../../controls/radio-group/dynamic-radio-group.component';\nimport { DYNAMIC_FORM_FIELD_RADIO_GROUP } from '../../controls/radio-group/dynamic-radio-group.model';\nimport { DynamicReadonlyComponent } from '../../controls/readonly/dynamic-readonly.component';\nimport { DYNAMIC_FORM_FIELD_READONLY } from '../../controls/readonly/dynamic-readonly.model';\nimport { DynamicSelectComponent } from '../../controls/select/dynamic-select.component';\nimport { DYNAMIC_FORM_FIELD_SELECT } from '../../controls/select/dynamic-select.model';\nimport { DynamicTextareaComponent } from '../../controls/textarea/dynamic-textarea.component';\nimport { DYNAMIC_FORM_FIELD_TEXTAREA } from '../../controls/textarea/dynamic-textarea.model';\nimport { DynamicFormField } from '../../models/classes/dynamic-form-field-base';\nimport { DynamicFormFieldModel } from '../../models/classes/dynamic-form-field-model';\nimport { DynamicFormFieldValueModel } from '../../models/classes/dynamic-form-field-value-model';\nimport { DynamicFormFieldEvent, DynamicFormFieldEventType } from '../../models/interfaces/dynamic-form-field-event.interface';\nimport { RelatedFormControls } from '../../models/types/related-form-controls.type';\nimport { DynamicFormRelationsService } from '../../services/dynamic-form-relations.service';\nimport { DynamicFormService } from '../../services/dynamic-form.service';\n\n@Component({\n  standalone: true,\n  imports: [NgClass, ReactiveFormsModule],\n  selector: 'dynamic-form-field',\n  templateUrl: 'dynamic-form-field.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class DynamicFormFieldComponent implements OnInit, OnDestroy {\n  @ViewChild('componentViewContainer', { read: ViewContainerRef, static: true }) componentViewContainer!: ViewContainerRef;\n\n  @Input() model!: DynamicFormFieldModel;\n  @Input() group!: UntypedFormGroup;\n\n  @Output() change = new EventEmitter<DynamicFormFieldEvent>();\n\n  private _control!: UntypedFormControl;\n  private _subs = new Subscription();\n\n  private dynamicFormService = inject(DynamicFormService);\n  private relationService = inject(DynamicFormRelationsService);\n\n  /** Get the instance of a control component using the injected custom method or local method */\n  private get componentType(): Type<DynamicFormField> | null {\n    return this.dynamicFormService.getCustomControlComponentType(this.model) || this.getControlComponentType();\n  }\n\n  ngOnInit(): void {\n    if (this.group) {\n      this._control = this.group.get(this.model.name) as UntypedFormControl;\n\n      this.createFormControlComponent();\n      this.setSubscriptions();\n    }\n  }\n\n  ngOnDestroy(): void {\n    this._subs.unsubscribe();\n  }\n\n  /**\n   * Finds the instance of a control component by type\n   * @returns\n   */\n  private getControlComponentType(): Type<DynamicFormField> | null {\n    switch (this.model.type) {\n      case DYNAMIC_FORM_FIELD_CHECKBOX:\n        return DynamicCheckboxComponent;\n      case DYNAMIC_FORM_FIELD_INPUT:\n        return DynamicInputComponent;\n      case DYNAMIC_FORM_FIELD_TEXTAREA:\n        return DynamicTextareaComponent;\n      case DYNAMIC_FORM_FIELD_READONLY:\n        return DynamicReadonlyComponent;\n      case DYNAMIC_FORM_FIELD_SELECT:\n        return DynamicSelectComponent;\n      case DYNAMIC_FORM_FIELD_BUTTON:\n        return DynamicButtonComponent;\n      case DYNAMIC_FORM_FIELD_BUTTON_TOGGLES:\n        return DynamicButtonTogglesComponent;\n      case DYNAMIC_FORM_FIELD_RADIO_GROUP:\n        return DymamicRadioGroupComponent;\n      default:\n        console.warn(\n          `Model of type 'dynamic-${this.model.type}' is not implemented yet. Add this type to dynamic-form-field.component.ts to add support`\n        );\n        return null;\n    }\n  }\n\n  private createFormControlComponent(): void {\n    const component = this.componentType;\n\n    if (component != null) {\n      let componentRef = this.componentViewContainer.createComponent(component);\n\n      const componentInstance = componentRef.instance;\n\n      this._subs.add(componentInstance.change?.subscribe((event) => this.onChange(event)));\n\n      componentInstance.group = this.group;\n      componentInstance.model = this.model;\n    }\n  }\n\n  /**\n   * Setup all necessary subscriptions of the FormControl\n   */\n  private setSubscriptions(): void {\n    const model = this.model as DynamicFormFieldValueModel<unknown>;\n\n    // Subscribe to the value change inside the control to change the value inside the model as well\n    this._subs.add(this._control.valueChanges.subscribe((value) => this.onValueChange(value)));\n\n    // Subscribe to the disabled change inside the model to change the disabled state of the FormControl\n    this._subs.add(model.disabledChange.subscribe((disabled) => this.onDisabledChange(disabled)));\n\n    // Setup subscriptions for any possible relation\n    if (this.model.relations?.length) {\n      this.setUpRelations();\n    }\n  }\n\n  /**\n   * Set up all relations of the current model\n   */\n  private setUpRelations(): void {\n    // Array of all FormControls the current model has a relation to\n    const relatedFormControls: RelatedFormControls = this.relationService.findRelatedFormField(this.model, this.group);\n    const subs = this.relationService.getRelationSubscriptions(relatedFormControls, this.model, this._control);\n\n    // Add all relations as subscription to the main Subscription object\n    subs.forEach((sub) => this._subs.add(sub));\n  }\n\n  /**\n   * Fired when the value changes of the control and updates the value inside the model\n   * @param value\n   */\n  private onValueChange(value: unknown): void {\n    if (this.model instanceof DynamicFormFieldValueModel && this.model.value !== value) {\n      this.model.value = value;\n    }\n  }\n\n  /**\n   * Enables/disabled the control based on the provided parameter.\n   * Is fired when disabled state is changed inside the model and should not be directly used outside this component.\n   * @param disabled\n   */\n  private onDisabledChange(disabled: boolean): void {\n    disabled ? this._control.disable() : this._control.enable();\n  }\n\n  private onChange(ev: unknown): void {\n    this.change.emit(this.createDynamicFormEvent(ev, 'change'));\n  }\n\n  private createDynamicFormEvent(event: unknown, type: DynamicFormFieldEventType): DynamicFormFieldEvent {\n    return { event, type, control: this._control, form: this.group, model: this.model };\n  }\n}\n","<div [formGroup]=\"group\"\n  [ngClass]=\"['dynamic-form-field-container', 'dynamic-form-field-' + model.type]\">\n  <ng-container #componentViewContainer></ng-container>\n</div>"]}
147
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-form-field.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-dynamic-form/src/lib/components/dynamic-form-field/dynamic-form-field.component.ts","../../../../../../projects/ngx-dynamic-form/src/lib/components/dynamic-form-field/dynamic-form-field.component.html"],"names":[],"mappings":"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","sourcesContent":["import { NgClass } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  inject,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  Type,\n  ViewChild,\n  ViewContainerRef\n} from '@angular/core';\nimport { ReactiveFormsModule, UntypedFormControl, UntypedFormGroup } from '@angular/forms';\nimport { Subscription } from 'rxjs';\nimport { DynamicButtonTogglesComponent } from '../../controls/button-toggles/dynamic-button-toggles.component';\nimport { DYNAMIC_FORM_FIELD_BUTTON_TOGGLES } from '../../controls/button-toggles/dynamic-button-toggles.model';\nimport { DynamicButtonComponent } from '../../controls/button/dynamic-button.component';\nimport { DYNAMIC_FORM_FIELD_BUTTON } from '../../controls/button/dynamic-button.model';\nimport { DynamicCheckboxComponent } from '../../controls/checkbox/dynamic-checkbox.component';\nimport { DYNAMIC_FORM_FIELD_CHECKBOX } from '../../controls/checkbox/dynamic-checkbox.model';\nimport { DynamicInputComponent } from '../../controls/input/dynamic-input.component';\nimport { DYNAMIC_FORM_FIELD_INPUT } from '../../controls/input/dynamic-input.model';\nimport { DymamicRadioGroupComponent } from '../../controls/radio-group/dynamic-radio-group.component';\nimport { DYNAMIC_FORM_FIELD_RADIO_GROUP } from '../../controls/radio-group/dynamic-radio-group.model';\nimport { DynamicReadonlyComponent } from '../../controls/readonly/dynamic-readonly.component';\nimport { DYNAMIC_FORM_FIELD_READONLY } from '../../controls/readonly/dynamic-readonly.model';\nimport { DynamicSelectComponent } from '../../controls/select/dynamic-select.component';\nimport { DYNAMIC_FORM_FIELD_SELECT } from '../../controls/select/dynamic-select.model';\nimport { DynamicTextareaComponent } from '../../controls/textarea/dynamic-textarea.component';\nimport { DYNAMIC_FORM_FIELD_TEXTAREA } from '../../controls/textarea/dynamic-textarea.model';\nimport { DynamicFormField } from '../../models/classes/dynamic-form-field-base';\nimport { DynamicFormFieldModel } from '../../models/classes/dynamic-form-field-model';\nimport { DynamicFormFieldValueModel } from '../../models/classes/dynamic-form-field-value-model';\nimport { DynamicFormFieldEvent, DynamicFormFieldEventType } from '../../models/interfaces/dynamic-form-field-event.interface';\nimport { RelatedFormControls } from '../../models/types/related-form-controls.type';\nimport { DynamicFormRelationsService } from '../../services/dynamic-form-relations.service';\nimport { DynamicFormService } from '../../services/dynamic-form.service';\n\n@Component({\n  standalone: true,\n  imports: [NgClass, ReactiveFormsModule],\n  selector: 'dynamic-form-field',\n  templateUrl: 'dynamic-form-field.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class DynamicFormFieldComponent implements OnInit, OnDestroy {\n  @ViewChild('componentViewContainer', { read: ViewContainerRef, static: true }) componentViewContainer!: ViewContainerRef;\n\n  @Input() model!: DynamicFormFieldModel;\n  @Input() group!: UntypedFormGroup;\n\n  @Output() change = new EventEmitter<DynamicFormFieldEvent>();\n\n  private readonly dynamicFormService = inject(DynamicFormService);\n  private readonly relationService = inject(DynamicFormRelationsService);\n\n  private _control!: UntypedFormControl;\n  private _subs = new Subscription();\n\n  /** Get the instance of a control component using the injected custom method or local method */\n  private get componentType(): Type<DynamicFormField> | null {\n    return this.dynamicFormService.getCustomControlComponentType(this.model) || this.getControlComponentType();\n  }\n\n  ngOnInit(): void {\n    if (this.group) {\n      this._control = this.group.get(this.model.name) as UntypedFormControl;\n\n      this.createFormControlComponent();\n      this.setSubscriptions();\n    }\n  }\n\n  ngOnDestroy(): void {\n    this._subs.unsubscribe();\n  }\n\n  /**\n   * Finds the instance of a control component by type\n   * @returns\n   */\n  private getControlComponentType(): Type<DynamicFormField> | null {\n    switch (this.model.type) {\n      case DYNAMIC_FORM_FIELD_CHECKBOX:\n        return DynamicCheckboxComponent;\n      case DYNAMIC_FORM_FIELD_INPUT:\n        return DynamicInputComponent;\n      case DYNAMIC_FORM_FIELD_TEXTAREA:\n        return DynamicTextareaComponent;\n      case DYNAMIC_FORM_FIELD_READONLY:\n        return DynamicReadonlyComponent;\n      case DYNAMIC_FORM_FIELD_SELECT:\n        return DynamicSelectComponent;\n      case DYNAMIC_FORM_FIELD_BUTTON:\n        return DynamicButtonComponent;\n      case DYNAMIC_FORM_FIELD_BUTTON_TOGGLES:\n        return DynamicButtonTogglesComponent;\n      case DYNAMIC_FORM_FIELD_RADIO_GROUP:\n        return DymamicRadioGroupComponent;\n      default:\n        console.warn(\n          `Model of type 'dynamic-${this.model.type}' is not implemented yet. Add this type to dynamic-form-field.component.ts to add support`\n        );\n        return null;\n    }\n  }\n\n  private createFormControlComponent(): void {\n    const component = this.componentType;\n\n    if (component != null) {\n      let componentRef = this.componentViewContainer.createComponent(component);\n\n      const componentInstance = componentRef.instance;\n\n      this._subs.add(componentInstance.change?.subscribe((event) => this.onChange(event)));\n\n      componentInstance.group = this.group;\n      componentInstance.model = this.model;\n    }\n  }\n\n  /**\n   * Setup all necessary subscriptions of the FormControl\n   */\n  private setSubscriptions(): void {\n    const model = this.model as DynamicFormFieldValueModel<unknown>;\n\n    // Subscribe to the value change inside the control to change the value inside the model as well\n    this._subs.add(this._control.valueChanges.subscribe((value) => this.onValueChange(value)));\n\n    // Subscribe to the disabled change inside the model to change the disabled state of the FormControl\n    this._subs.add(model.disabledChange.subscribe((disabled) => this.onDisabledChange(disabled)));\n\n    // Setup subscriptions for any possible relation\n    if (this.model.relations?.length) {\n      this.setUpRelations();\n    }\n  }\n\n  /**\n   * Set up all relations of the current model\n   */\n  private setUpRelations(): void {\n    // Array of all FormControls the current model has a relation to\n    const relatedFormControls: RelatedFormControls = this.relationService.findRelatedFormField(this.model, this.group);\n\n    const subs = this.relationService.getRelationSubscriptions(relatedFormControls, this.model, this._control);\n\n    // Add all relations as subscription to the main Subscription object\n    subs.forEach((sub) => this._subs.add(sub));\n  }\n\n  /**\n   * Fired when the value changes of the control and updates the value inside the model\n   * @param value\n   */\n  private onValueChange(value: unknown): void {\n    if (this.model instanceof DynamicFormFieldValueModel && this.model.value !== value) {\n      this.model.value = value;\n    }\n  }\n\n  /**\n   * Enables/disabled the control based on the provided parameter.\n   * Is fired when disabled state is changed inside the model and should not be directly used outside this component.\n   * @param disabled\n   */\n  private onDisabledChange(disabled: boolean): void {\n    disabled ? this._control.disable() : this._control.enable();\n  }\n\n  private onChange(ev: unknown): void {\n    this.change.emit(this.createDynamicFormEvent(ev, 'change'));\n  }\n\n  private createDynamicFormEvent(event: unknown, type: DynamicFormFieldEventType): DynamicFormFieldEvent {\n    return { event, type, control: this._control, form: this.group, model: this.model };\n  }\n}\n","<div [formGroup]=\"group\"\n  [ngClass]=\"['dynamic-form-field-container', 'dynamic-form-field-' + model.type]\">\n  <ng-container #componentViewContainer></ng-container>\n</div>"]}
@@ -8,15 +8,15 @@ export class DynamicButtonComponent extends DynamicFormFieldBase {
8
8
  onClick() {
9
9
  this.model.onClick();
10
10
  }
11
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DynamicButtonComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
12
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DynamicButtonComponent, isStandalone: true, selector: "dynamic-button", inputs: { model: "model", group: "group" }, usesInheritance: true, ngImport: i0, template: "<ng-container *ngIf=\"model.raised else stroked\">\n <button mat-raised-button\n color=\"primary\"\n [id]=\"id\"\n (click)=\"onClick()\">\n <span>{{model.text}}</span>\n </button>\n</ng-container>\n\n<ng-template #stroked>\n <button mat-stroked-button\n color=\"primary\"\n [id]=\"id\"\n (click)=\"onClick()\">\n <span>{{model.text}}</span>\n </button>\n</ng-template>", dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i1.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }] }); }
11
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DynamicButtonComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
12
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: DynamicButtonComponent, isStandalone: true, selector: "dynamic-button", inputs: { model: "model", group: "group" }, usesInheritance: true, ngImport: i0, template: "<button mat-button\n [id]=\"id\"\n (click)=\"onClick()\">\n <span>{{model.label}}</span>\n</button>", dependencies: [{ kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i1.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }] }); }
13
13
  }
14
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DynamicButtonComponent, decorators: [{
14
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DynamicButtonComponent, decorators: [{
15
15
  type: Component,
16
- args: [{ standalone: true, imports: [NgIf, MatButtonModule], selector: 'dynamic-button', template: "<ng-container *ngIf=\"model.raised else stroked\">\n <button mat-raised-button\n color=\"primary\"\n [id]=\"id\"\n (click)=\"onClick()\">\n <span>{{model.text}}</span>\n </button>\n</ng-container>\n\n<ng-template #stroked>\n <button mat-stroked-button\n color=\"primary\"\n [id]=\"id\"\n (click)=\"onClick()\">\n <span>{{model.text}}</span>\n </button>\n</ng-template>" }]
16
+ args: [{ standalone: true, imports: [NgIf, MatButtonModule], selector: 'dynamic-button', template: "<button mat-button\n [id]=\"id\"\n (click)=\"onClick()\">\n <span>{{model.label}}</span>\n</button>" }]
17
17
  }], propDecorators: { model: [{
18
18
  type: Input
19
19
  }], group: [{
20
20
  type: Input
21
21
  }] } });
22
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHluYW1pYy1idXR0b24uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LWR5bmFtaWMtZm9ybS9zcmMvbGliL2NvbnRyb2xzL2J1dHRvbi9keW5hbWljLWJ1dHRvbi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtZHluYW1pYy1mb3JtL3NyYy9saWIvY29udHJvbHMvYnV0dG9uL2R5bmFtaWMtYnV0dG9uLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxJQUFJLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUN2QyxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUVqRCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDM0QsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sOENBQThDLENBQUM7OztBQVNwRixNQUFNLE9BQU8sc0JBQXVCLFNBQVEsb0JBQW9CO0lBSXZELE9BQU87UUFDWixJQUFJLENBQUMsS0FBSyxDQUFDLE9BQU8sRUFBRSxDQUFDO0lBQ3ZCLENBQUM7K0dBTlUsc0JBQXNCO21HQUF0QixzQkFBc0IsNklDYm5DLDhZQWdCYyw0Q0RQRixJQUFJLDRGQUFFLGVBQWU7OzRGQUlwQixzQkFBc0I7a0JBTmxDLFNBQVM7aUNBQ0ksSUFBSSxXQUNQLENBQUMsSUFBSSxFQUFFLGVBQWUsQ0FBQyxZQUN0QixnQkFBZ0I7OEJBSWpCLEtBQUs7c0JBQWIsS0FBSztnQkFDRyxLQUFLO3NCQUFiLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ0lmIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFVudHlwZWRGb3JtR3JvdXAgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBNYXRCdXR0b25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9idXR0b24nO1xuaW1wb3J0IHsgRHluYW1pY0Zvcm1GaWVsZEJhc2UgfSBmcm9tICcuLi8uLi9tb2RlbHMvY2xhc3Nlcy9keW5hbWljLWZvcm0tZmllbGQtYmFzZSc7XG5pbXBvcnQgeyBEeW5hbWljQnV0dG9uIH0gZnJvbSAnLi9keW5hbWljLWJ1dHRvbi5tb2RlbCc7XG5cbkBDb21wb25lbnQoe1xuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbTmdJZiwgTWF0QnV0dG9uTW9kdWxlXSxcbiAgc2VsZWN0b3I6ICdkeW5hbWljLWJ1dHRvbicsXG4gIHRlbXBsYXRlVXJsOiAnLi9keW5hbWljLWJ1dHRvbi5jb21wb25lbnQuaHRtbCdcbn0pXG5leHBvcnQgY2xhc3MgRHluYW1pY0J1dHRvbkNvbXBvbmVudCBleHRlbmRzIER5bmFtaWNGb3JtRmllbGRCYXNlIHtcbiAgQElucHV0KCkgbW9kZWwhOiBEeW5hbWljQnV0dG9uO1xuICBASW5wdXQoKSBncm91cCE6IFVudHlwZWRGb3JtR3JvdXA7XG5cbiAgcHVibGljIG9uQ2xpY2soKSB7XG4gICAgdGhpcy5tb2RlbC5vbkNsaWNrKCk7XG4gIH1cbn1cbiIsIjxuZy1jb250YWluZXIgKm5nSWY9XCJtb2RlbC5yYWlzZWQgZWxzZSBzdHJva2VkXCI+XG4gIDxidXR0b24gbWF0LXJhaXNlZC1idXR0b25cbiAgICBjb2xvcj1cInByaW1hcnlcIlxuICAgIFtpZF09XCJpZFwiXG4gICAgKGNsaWNrKT1cIm9uQ2xpY2soKVwiPlxuICAgIDxzcGFuPnt7bW9kZWwudGV4dH19PC9zcGFuPlxuICA8L2J1dHRvbj5cbjwvbmctY29udGFpbmVyPlxuXG48bmctdGVtcGxhdGUgI3N0cm9rZWQ+XG4gIDxidXR0b24gbWF0LXN0cm9rZWQtYnV0dG9uXG4gICAgY29sb3I9XCJwcmltYXJ5XCJcbiAgICBbaWRdPVwiaWRcIlxuICAgIChjbGljayk9XCJvbkNsaWNrKClcIj5cbiAgICA8c3Bhbj57e21vZGVsLnRleHR9fTwvc3Bhbj5cbiAgPC9idXR0b24+XG48L25nLXRlbXBsYXRlPiJdfQ==
22
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHluYW1pYy1idXR0b24uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LWR5bmFtaWMtZm9ybS9zcmMvbGliL2NvbnRyb2xzL2J1dHRvbi9keW5hbWljLWJ1dHRvbi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtZHluYW1pYy1mb3JtL3NyYy9saWIvY29udHJvbHMvYnV0dG9uL2R5bmFtaWMtYnV0dG9uLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxJQUFJLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUN2QyxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUVqRCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDM0QsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sOENBQThDLENBQUM7OztBQVNwRixNQUFNLE9BQU8sc0JBQXVCLFNBQVEsb0JBQW9CO0lBSXZELE9BQU87UUFDWixJQUFJLENBQUMsS0FBSyxDQUFDLE9BQU8sRUFBRSxDQUFDO0lBQ3ZCLENBQUM7K0dBTlUsc0JBQXNCO21HQUF0QixzQkFBc0IsNklDYm5DLHdHQUlTLDJDREtTLGVBQWU7OzRGQUlwQixzQkFBc0I7a0JBTmxDLFNBQVM7aUNBQ0ksSUFBSSxXQUNQLENBQUMsSUFBSSxFQUFFLGVBQWUsQ0FBQyxZQUN0QixnQkFBZ0I7OEJBSWpCLEtBQUs7c0JBQWIsS0FBSztnQkFDRyxLQUFLO3NCQUFiLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ0lmIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFVudHlwZWRGb3JtR3JvdXAgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBNYXRCdXR0b25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9idXR0b24nO1xuaW1wb3J0IHsgRHluYW1pY0Zvcm1GaWVsZEJhc2UgfSBmcm9tICcuLi8uLi9tb2RlbHMvY2xhc3Nlcy9keW5hbWljLWZvcm0tZmllbGQtYmFzZSc7XG5pbXBvcnQgeyBEeW5hbWljQnV0dG9uIH0gZnJvbSAnLi9keW5hbWljLWJ1dHRvbi5tb2RlbCc7XG5cbkBDb21wb25lbnQoe1xuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbTmdJZiwgTWF0QnV0dG9uTW9kdWxlXSxcbiAgc2VsZWN0b3I6ICdkeW5hbWljLWJ1dHRvbicsXG4gIHRlbXBsYXRlVXJsOiAnLi9keW5hbWljLWJ1dHRvbi5jb21wb25lbnQuaHRtbCdcbn0pXG5leHBvcnQgY2xhc3MgRHluYW1pY0J1dHRvbkNvbXBvbmVudCBleHRlbmRzIER5bmFtaWNGb3JtRmllbGRCYXNlIHtcbiAgQElucHV0KCkgbW9kZWwhOiBEeW5hbWljQnV0dG9uO1xuICBASW5wdXQoKSBncm91cCE6IFVudHlwZWRGb3JtR3JvdXA7XG5cbiAgcHVibGljIG9uQ2xpY2soKSB7XG4gICAgdGhpcy5tb2RlbC5vbkNsaWNrKCk7XG4gIH1cbn1cbiIsIjxidXR0b24gbWF0LWJ1dHRvblxuICBbaWRdPVwiaWRcIlxuICAoY2xpY2spPVwib25DbGljaygpXCI+XG4gIDxzcGFuPnt7bW9kZWwubGFiZWx9fTwvc3Bhbj5cbjwvYnV0dG9uPiJdfQ==
@@ -4,9 +4,8 @@ export class DynamicButton extends DynamicFormFieldModel {
4
4
  constructor(config) {
5
5
  super(config);
6
6
  this.type = DYNAMIC_FORM_FIELD_BUTTON;
7
- this.text = config.text ?? null;
8
- this.raised = config.raised ?? false;
7
+ this.label = config.label ?? null;
9
8
  this.onClick = config.onClick;
10
9
  }
11
10
  }
12
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHluYW1pYy1idXR0b24ubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtZHluYW1pYy1mb3JtL3NyYy9saWIvY29udHJvbHMvYnV0dG9uL2R5bmFtaWMtYnV0dG9uLm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLCtDQUErQyxDQUFDO0FBR3RGLE1BQU0sQ0FBQyxNQUFNLHlCQUF5QixHQUFHLFFBQVEsQ0FBQztBQVFsRCxNQUFNLE9BQU8sYUFBYyxTQUFRLHFCQUFxQjtJQU90RCxZQUFZLE1BQTJCO1FBQ3JDLEtBQUssQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUhBLFNBQUksR0FBRyx5QkFBeUIsQ0FBQztRQUsvQyxJQUFJLENBQUMsSUFBSSxHQUFHLE1BQU0sQ0FBQyxJQUFJLElBQUksSUFBSSxDQUFDO1FBQ2hDLElBQUksQ0FBQyxNQUFNLEdBQUcsTUFBTSxDQUFDLE1BQU0sSUFBSSxLQUFLLENBQUM7UUFDckMsSUFBSSxDQUFDLE9BQU8sR0FBRyxNQUFNLENBQUMsT0FBTyxDQUFDO0lBQ2hDLENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IER5bmFtaWNGb3JtRmllbGRNb2RlbCB9IGZyb20gJy4uLy4uL21vZGVscy9jbGFzc2VzL2R5bmFtaWMtZm9ybS1maWVsZC1tb2RlbCc7XG5pbXBvcnQgeyBEeW5hbWljRm9ybUZpZWxkQ29uZmlnIH0gZnJvbSAnLi4vLi4vbW9kZWxzL2ludGVyZmFjZXMvZHluYW1pYy1mb3JtLWZpZWxkLWNvbmZpZy5pbnRlcmZhY2UnO1xuXG5leHBvcnQgY29uc3QgRFlOQU1JQ19GT1JNX0ZJRUxEX0JVVFRPTiA9ICdidXR0b24nO1xuXG5leHBvcnQgaW50ZXJmYWNlIER5bmFtaWNCdXR0b25Db25maWcgZXh0ZW5kcyBEeW5hbWljRm9ybUZpZWxkQ29uZmlnIHtcbiAgdGV4dDogc3RyaW5nO1xuICByYWlzZWQ/OiBib29sZWFuO1xuICBvbkNsaWNrOiAoKSA9PiBhbnk7XG59XG5cbmV4cG9ydCBjbGFzcyBEeW5hbWljQnV0dG9uIGV4dGVuZHMgRHluYW1pY0Zvcm1GaWVsZE1vZGVsIHtcbiAgcHVibGljIHRleHQ6IHN0cmluZyB8IG51bGw7XG4gIHB1YmxpYyByYWlzZWQ6IGJvb2xlYW47XG4gIHB1YmxpYyBvbkNsaWNrOiAoKSA9PiBhbnk7XG5cbiAgcHVibGljIHJlYWRvbmx5IHR5cGUgPSBEWU5BTUlDX0ZPUk1fRklFTERfQlVUVE9OO1xuXG4gIGNvbnN0cnVjdG9yKGNvbmZpZzogRHluYW1pY0J1dHRvbkNvbmZpZykge1xuICAgIHN1cGVyKGNvbmZpZyk7XG5cbiAgICB0aGlzLnRleHQgPSBjb25maWcudGV4dCA/PyBudWxsO1xuICAgIHRoaXMucmFpc2VkID0gY29uZmlnLnJhaXNlZCA/PyBmYWxzZTtcbiAgICB0aGlzLm9uQ2xpY2sgPSBjb25maWcub25DbGljaztcbiAgfVxufVxuIl19
11
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHluYW1pYy1idXR0b24ubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtZHluYW1pYy1mb3JtL3NyYy9saWIvY29udHJvbHMvYnV0dG9uL2R5bmFtaWMtYnV0dG9uLm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLCtDQUErQyxDQUFDO0FBR3RGLE1BQU0sQ0FBQyxNQUFNLHlCQUF5QixHQUFHLFFBQVEsQ0FBQztBQU9sRCxNQUFNLE9BQU8sYUFBYyxTQUFRLHFCQUFxQjtJQU10RCxZQUFZLE1BQTJCO1FBQ3JDLEtBQUssQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUhBLFNBQUksR0FBRyx5QkFBeUIsQ0FBQztRQUsvQyxJQUFJLENBQUMsS0FBSyxHQUFHLE1BQU0sQ0FBQyxLQUFLLElBQUksSUFBSSxDQUFDO1FBQ2xDLElBQUksQ0FBQyxPQUFPLEdBQUcsTUFBTSxDQUFDLE9BQU8sQ0FBQztJQUNoQyxDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEeW5hbWljRm9ybUZpZWxkTW9kZWwgfSBmcm9tICcuLi8uLi9tb2RlbHMvY2xhc3Nlcy9keW5hbWljLWZvcm0tZmllbGQtbW9kZWwnO1xuaW1wb3J0IHsgRHluYW1pY0Zvcm1GaWVsZENvbmZpZyB9IGZyb20gJy4uLy4uL21vZGVscy9pbnRlcmZhY2VzL2R5bmFtaWMtZm9ybS1maWVsZC1jb25maWcuaW50ZXJmYWNlJztcblxuZXhwb3J0IGNvbnN0IERZTkFNSUNfRk9STV9GSUVMRF9CVVRUT04gPSAnYnV0dG9uJztcblxuZXhwb3J0IGludGVyZmFjZSBEeW5hbWljQnV0dG9uQ29uZmlnIGV4dGVuZHMgRHluYW1pY0Zvcm1GaWVsZENvbmZpZyB7XG4gIGxhYmVsOiBzdHJpbmc7XG4gIG9uQ2xpY2s6ICgpID0+IGFueTtcbn1cblxuZXhwb3J0IGNsYXNzIER5bmFtaWNCdXR0b24gZXh0ZW5kcyBEeW5hbWljRm9ybUZpZWxkTW9kZWwge1xuICBwdWJsaWMgbGFiZWw6IHN0cmluZyB8IG51bGw7XG4gIHB1YmxpYyBvbkNsaWNrOiAoKSA9PiBhbnk7XG5cbiAgcHVibGljIHJlYWRvbmx5IHR5cGUgPSBEWU5BTUlDX0ZPUk1fRklFTERfQlVUVE9OO1xuXG4gIGNvbnN0cnVjdG9yKGNvbmZpZzogRHluYW1pY0J1dHRvbkNvbmZpZykge1xuICAgIHN1cGVyKGNvbmZpZyk7XG5cbiAgICB0aGlzLmxhYmVsID0gY29uZmlnLmxhYmVsID8/IG51bGw7XG4gICAgdGhpcy5vbkNsaWNrID0gY29uZmlnLm9uQ2xpY2s7XG4gIH1cbn1cbiJdfQ==