@dynamic-field-kit/angular 1.0.2 → 1.2.1
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 +120 -61
- package/components/BaseInput.d.ts +22 -0
- package/components/DynamicInput.d.ts +28 -0
- package/components/FieldInput.d.ts +14 -0
- package/components/MultiFieldInput.d.ts +23 -0
- package/esm2020/components/BaseInput.mjs +46 -0
- package/esm2020/components/DynamicInput.mjs +146 -0
- package/esm2020/components/FieldInput.mjs +66 -0
- package/esm2020/components/MultiFieldInput.mjs +79 -0
- package/esm2020/dynamic-field-kit-angular.mjs +5 -0
- package/esm2020/layout/defaultLayouts.mjs +43 -0
- package/esm2020/layout/index.mjs +2 -0
- package/esm2020/lib/dynamic-field-kit.module.mjs +20 -0
- package/esm2020/public-api.mjs +14 -0
- package/esm2020/types/layout.mjs +2 -0
- package/fesm2015/dynamic-field-kit-angular.mjs +393 -0
- package/fesm2015/dynamic-field-kit-angular.mjs.map +1 -0
- package/fesm2020/dynamic-field-kit-angular.mjs +390 -0
- package/fesm2020/dynamic-field-kit-angular.mjs.map +1 -0
- package/index.d.ts +5 -0
- package/layout/defaultLayouts.d.ts +13 -0
- package/layout/index.d.ts +1 -0
- package/lib/dynamic-field-kit.module.d.ts +11 -0
- package/package.json +47 -42
- package/public-api.d.ts +9 -0
- package/types/layout.d.ts +1 -0
- package/dist/README.md +0 -65
- package/dist/fesm2022/dynamic-field-kit-angular.mjs +0 -266
- package/dist/fesm2022/dynamic-field-kit-angular.mjs.map +0 -1
- package/dist/types/dynamic-field-kit-angular.d.ts +0 -70
package/README.md
CHANGED
|
@@ -1,65 +1,124 @@
|
|
|
1
|
-
# @dynamic-field-kit/angular
|
|
2
|
-
|
|
3
|
-
Lightweight Angular adapters for `@dynamic-field-kit/core`.
|
|
4
|
-
|
|
5
|
-
This package
|
|
6
|
-
|
|
7
|
-
Quick overview
|
|
8
|
-
- Exports
|
|
9
|
-
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
1
|
+
# @dynamic-field-kit/angular
|
|
2
|
+
|
|
3
|
+
Lightweight Angular adapters for `@dynamic-field-kit/core`.
|
|
4
|
+
|
|
5
|
+
This package exposes Angular components and a convenience NgModule that integrate with the shared `fieldRegistry` from `@dynamic-field-kit/core`.
|
|
6
|
+
|
|
7
|
+
Quick overview
|
|
8
|
+
- Exports `DynamicInput`, `FieldInput`, `MultiFieldInput`, layout components, and `DynamicFieldKitModule`.
|
|
9
|
+
- Uses the shared `fieldRegistry` from `@dynamic-field-kit/core` to resolve Angular field renderers at runtime.
|
|
10
|
+
- Can be consumed as a packaged library, or linked locally from `packages/angular/dist` during development.
|
|
11
|
+
- `MultiFieldInput` currently supports `column`, `row`, and `grid` layout values.
|
|
12
|
+
|
|
13
|
+
Usage (consumer Angular app)
|
|
14
|
+
|
|
15
|
+
1. Install the packages:
|
|
16
|
+
|
|
17
|
+
```bash
|
|
18
|
+
npm install @dynamic-field-kit/core @dynamic-field-kit/angular
|
|
19
|
+
```
|
|
20
|
+
|
|
21
|
+
2. Import `DynamicFieldKitModule` in your Angular module:
|
|
22
|
+
|
|
23
|
+
```ts
|
|
24
|
+
import { DynamicFieldKitModule } from '@dynamic-field-kit/angular'
|
|
24
25
|
|
|
25
26
|
@NgModule({
|
|
26
27
|
imports: [BrowserModule, DynamicFieldKitModule],
|
|
27
28
|
})
|
|
28
|
-
export class AppModule {}
|
|
29
|
-
```
|
|
30
|
-
|
|
31
|
-
3. Register Angular
|
|
32
|
-
|
|
33
|
-
```ts
|
|
34
|
-
// src/main.ts
|
|
35
|
-
import '
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
29
|
+
export class AppModule {}
|
|
30
|
+
```
|
|
31
|
+
|
|
32
|
+
3. Register your Angular field components in the shared registry before bootstrap:
|
|
33
|
+
|
|
34
|
+
```ts
|
|
35
|
+
// src/main.ts
|
|
36
|
+
import 'zone.js'
|
|
37
|
+
import { platformBrowserDynamic } from '@angular/platform-browser-dynamic'
|
|
38
|
+
import { fieldRegistry } from '@dynamic-field-kit/angular'
|
|
39
|
+
import { AppModule } from './app/app.module'
|
|
40
|
+
import { TextFieldComponent } from './app/components/text-field.component'
|
|
41
|
+
import { NumberFieldComponent } from './app/components/number-field.component'
|
|
42
|
+
|
|
43
|
+
fieldRegistry.register('text', TextFieldComponent as any)
|
|
44
|
+
fieldRegistry.register('number', NumberFieldComponent as any)
|
|
45
|
+
|
|
46
|
+
platformBrowserDynamic()
|
|
47
|
+
.bootstrapModule(AppModule)
|
|
48
|
+
.catch((err) => console.error(err))
|
|
49
|
+
```
|
|
50
|
+
|
|
51
|
+
4. Render fields in a template:
|
|
52
|
+
|
|
53
|
+
```html
|
|
54
|
+
<dfk-multi-field-input
|
|
55
|
+
[fieldDescriptions]="fields"
|
|
56
|
+
[properties]="data"
|
|
57
|
+
(onChange)="onChange($event)"
|
|
58
|
+
></dfk-multi-field-input>
|
|
59
|
+
```
|
|
60
|
+
|
|
61
|
+
5. Example component state:
|
|
62
|
+
|
|
63
|
+
```ts
|
|
64
|
+
import { Component } from '@angular/core'
|
|
65
|
+
import { FieldDescription } from '@dynamic-field-kit/core'
|
|
66
|
+
|
|
67
|
+
@Component({
|
|
68
|
+
selector: 'app-root',
|
|
69
|
+
templateUrl: './app.component.html',
|
|
70
|
+
})
|
|
71
|
+
export class AppComponent {
|
|
72
|
+
fields: FieldDescription[] = [
|
|
73
|
+
{ name: 'name', type: 'text', label: 'Name' },
|
|
74
|
+
{ name: 'age', type: 'number', label: 'Age' },
|
|
75
|
+
]
|
|
76
|
+
|
|
77
|
+
data: any = {}
|
|
78
|
+
|
|
79
|
+
onChange(data: any) {
|
|
80
|
+
this.data = data
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
```
|
|
84
|
+
|
|
85
|
+
Local development
|
|
86
|
+
- During local development, point your Angular app at the built package output instead of importing from `src/`:
|
|
87
|
+
|
|
88
|
+
```json
|
|
89
|
+
{
|
|
90
|
+
"dependencies": {
|
|
91
|
+
"@dynamic-field-kit/core": "file:../../packages/core",
|
|
92
|
+
"@dynamic-field-kit/angular": "file:../../packages/angular/dist"
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
```
|
|
96
|
+
|
|
97
|
+
- When using a local `file:` dependency on Windows or via symlinked installs, set `preserveSymlinks: true` in the Angular builder options to avoid runtime issues with linked packages.
|
|
98
|
+
|
|
99
|
+
Build & publish
|
|
100
|
+
- Build locally with `ng-packagr`:
|
|
101
|
+
|
|
102
|
+
```bash
|
|
103
|
+
cd packages/angular
|
|
104
|
+
npm run build
|
|
105
|
+
```
|
|
106
|
+
|
|
107
|
+
- Publish to npm:
|
|
108
|
+
|
|
109
|
+
```bash
|
|
110
|
+
cd packages/angular
|
|
111
|
+
npm run build
|
|
112
|
+
npm run publish:dist
|
|
113
|
+
```
|
|
114
|
+
|
|
115
|
+
Notes & caveats
|
|
116
|
+
- Register Angular component classes in `fieldRegistry`. Do not register React or Vue renderers when using the Angular adapter.
|
|
117
|
+
- `DynamicFieldKitModule` is the recommended integration path for consumer apps.
|
|
118
|
+
- Standalone exports are still available for advanced composition, but most apps should start with the module.
|
|
119
|
+
- Text fields default to an empty string when no value is present, so empty controls render as blank instead of `undefined`.
|
|
120
|
+
- Supported `layout` values are `column`, `row`, and `grid`.
|
|
121
|
+
|
|
122
|
+
Examples & docs
|
|
123
|
+
- See `example/angular-instructions.md` for detailed wiring steps.
|
|
124
|
+
- Try the local scaffold at `example/angular-app/` for a hands-on demo.
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { EventEmitter, ChangeDetectorRef } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export declare abstract class BaseInputComponent {
|
|
4
|
+
protected cdr: ChangeDetectorRef;
|
|
5
|
+
value?: any;
|
|
6
|
+
label?: string;
|
|
7
|
+
placeholder?: string;
|
|
8
|
+
required?: boolean;
|
|
9
|
+
disabled?: boolean;
|
|
10
|
+
options?: any[];
|
|
11
|
+
className?: string;
|
|
12
|
+
description?: string;
|
|
13
|
+
errorMessage?: string;
|
|
14
|
+
acceptFile?: string;
|
|
15
|
+
maxLength?: number;
|
|
16
|
+
minNumber?: number;
|
|
17
|
+
maxNumber?: number;
|
|
18
|
+
valueChange: EventEmitter<any>;
|
|
19
|
+
constructor(cdr: ChangeDetectorRef);
|
|
20
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<BaseInputComponent, never>;
|
|
21
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<BaseInputComponent, "ng-component", never, { "value": "value"; "label": "label"; "placeholder": "placeholder"; "required": "required"; "disabled": "disabled"; "options": "options"; "className": "className"; "description": "description"; "errorMessage": "errorMessage"; "acceptFile": "acceptFile"; "maxLength": "maxLength"; "minNumber": "minNumber"; "maxNumber": "maxNumber"; }, { "valueChange": "valueChange"; }, never, never, false, never>;
|
|
22
|
+
}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { EventEmitter, ViewContainerRef, OnChanges, AfterViewInit, SimpleChanges } from "@angular/core";
|
|
2
|
+
import { FieldTypeKey } from "@dynamic-field-kit/core";
|
|
3
|
+
import { BaseInputComponent } from "./BaseInput";
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export declare class DynamicInput extends BaseInputComponent implements OnChanges, AfterViewInit {
|
|
6
|
+
type: FieldTypeKey;
|
|
7
|
+
value?: any;
|
|
8
|
+
label?: string;
|
|
9
|
+
placeholder?: string;
|
|
10
|
+
required?: boolean;
|
|
11
|
+
options?: any[];
|
|
12
|
+
className?: string;
|
|
13
|
+
description?: any;
|
|
14
|
+
valueChange: EventEmitter<any>;
|
|
15
|
+
onChange: EventEmitter<any>;
|
|
16
|
+
host: ViewContainerRef;
|
|
17
|
+
private compRef?;
|
|
18
|
+
private inputInstance?;
|
|
19
|
+
ngOnChanges(changes: SimpleChanges): void;
|
|
20
|
+
ngAfterViewInit(): void;
|
|
21
|
+
private render;
|
|
22
|
+
private applyKnownProps;
|
|
23
|
+
private bindOutput;
|
|
24
|
+
private emitValue;
|
|
25
|
+
private cleanupRenderedComponent;
|
|
26
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<DynamicInput, never>;
|
|
27
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<DynamicInput, "dfk-dynamic-input", never, { "type": "type"; "value": "value"; "label": "label"; "placeholder": "placeholder"; "required": "required"; "options": "options"; "className": "className"; "description": "description"; }, { "valueChange": "valueChange"; "onChange": "onChange"; }, never, never, true, never>;
|
|
28
|
+
}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { EventEmitter } from "@angular/core";
|
|
2
|
+
import { FieldDescription, Properties } from "@dynamic-field-kit/core";
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export declare class FieldInput {
|
|
5
|
+
fieldDescription?: FieldDescription;
|
|
6
|
+
renderInfos?: Properties;
|
|
7
|
+
onValueChangeField: EventEmitter<{
|
|
8
|
+
value: any;
|
|
9
|
+
key: string;
|
|
10
|
+
}>;
|
|
11
|
+
getFieldValue(): any;
|
|
12
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<FieldInput, never>;
|
|
13
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<FieldInput, "dfk-field-input", never, { "fieldDescription": "fieldDescription"; "renderInfos": "renderInfos"; }, { "onValueChangeField": "onValueChangeField"; }, never, never, true, never>;
|
|
14
|
+
}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { EventEmitter, OnChanges, OnInit, SimpleChanges } from "@angular/core";
|
|
2
|
+
import { FieldDescription, Properties } from "@dynamic-field-kit/core";
|
|
3
|
+
import { LayoutConfig } from "../types/layout";
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export declare class MultiFieldInput implements OnInit, OnChanges {
|
|
6
|
+
fieldDescriptions: FieldDescription[];
|
|
7
|
+
properties?: Properties;
|
|
8
|
+
onChange: EventEmitter<Properties>;
|
|
9
|
+
layout: LayoutConfig;
|
|
10
|
+
data: Properties;
|
|
11
|
+
visibleFields: FieldDescription[];
|
|
12
|
+
trackByFn(index: number, field: FieldDescription): string | number;
|
|
13
|
+
ngOnInit(): void;
|
|
14
|
+
ngOnChanges(_changes: SimpleChanges): void;
|
|
15
|
+
private init;
|
|
16
|
+
private updateVisibleFields;
|
|
17
|
+
onFieldChange(event: {
|
|
18
|
+
value: any;
|
|
19
|
+
key: string;
|
|
20
|
+
}): void;
|
|
21
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<MultiFieldInput, never>;
|
|
22
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<MultiFieldInput, "dfk-multi-field-input", never, { "fieldDescriptions": "fieldDescriptions"; "properties": "properties"; "layout": "layout"; }, { "onChange": "onChange"; }, never, never, true, never>;
|
|
23
|
+
}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import { Component, Input, Output, EventEmitter } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class BaseInputComponent {
|
|
4
|
+
constructor(cdr) {
|
|
5
|
+
this.cdr = cdr;
|
|
6
|
+
// Add more from mplis as needed
|
|
7
|
+
this.valueChange = new EventEmitter();
|
|
8
|
+
}
|
|
9
|
+
}
|
|
10
|
+
BaseInputComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: BaseInputComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
11
|
+
BaseInputComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: BaseInputComponent, selector: "ng-component", inputs: { value: "value", label: "label", placeholder: "placeholder", required: "required", disabled: "disabled", options: "options", className: "className", description: "description", errorMessage: "errorMessage", acceptFile: "acceptFile", maxLength: "maxLength", minNumber: "minNumber", maxNumber: "maxNumber" }, outputs: { valueChange: "valueChange" }, ngImport: i0, template: '', isInline: true });
|
|
12
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: BaseInputComponent, decorators: [{
|
|
13
|
+
type: Component,
|
|
14
|
+
args: [{
|
|
15
|
+
template: ''
|
|
16
|
+
}]
|
|
17
|
+
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { value: [{
|
|
18
|
+
type: Input
|
|
19
|
+
}], label: [{
|
|
20
|
+
type: Input
|
|
21
|
+
}], placeholder: [{
|
|
22
|
+
type: Input
|
|
23
|
+
}], required: [{
|
|
24
|
+
type: Input
|
|
25
|
+
}], disabled: [{
|
|
26
|
+
type: Input
|
|
27
|
+
}], options: [{
|
|
28
|
+
type: Input
|
|
29
|
+
}], className: [{
|
|
30
|
+
type: Input
|
|
31
|
+
}], description: [{
|
|
32
|
+
type: Input
|
|
33
|
+
}], errorMessage: [{
|
|
34
|
+
type: Input
|
|
35
|
+
}], acceptFile: [{
|
|
36
|
+
type: Input
|
|
37
|
+
}], maxLength: [{
|
|
38
|
+
type: Input
|
|
39
|
+
}], minNumber: [{
|
|
40
|
+
type: Input
|
|
41
|
+
}], maxNumber: [{
|
|
42
|
+
type: Input
|
|
43
|
+
}], valueChange: [{
|
|
44
|
+
type: Output
|
|
45
|
+
}] } });
|
|
46
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQmFzZUlucHV0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvQmFzZUlucHV0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxZQUFZLEVBQXFCLE1BQU0sZUFBZSxDQUFDOztBQU0xRixNQUFNLE9BQWdCLGtCQUFrQjtJQWtCdEMsWUFBc0IsR0FBc0I7UUFBdEIsUUFBRyxHQUFILEdBQUcsQ0FBbUI7UUFKNUMsZ0NBQWdDO1FBRXRCLGdCQUFXLEdBQUcsSUFBSSxZQUFZLEVBQU8sQ0FBQztJQUVELENBQUM7O2dIQWxCNUIsa0JBQWtCO29HQUFsQixrQkFBa0IseVpBRjVCLEVBQUU7NEZBRVEsa0JBQWtCO2tCQUh2QyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxFQUFFO2lCQUNiO3dHQUVVLEtBQUs7c0JBQWIsS0FBSztnQkFDRyxLQUFLO3NCQUFiLEtBQUs7Z0JBQ0csV0FBVztzQkFBbkIsS0FBSztnQkFDRyxRQUFRO3NCQUFoQixLQUFLO2dCQUNHLFFBQVE7c0JBQWhCLEtBQUs7Z0JBQ0csT0FBTztzQkFBZixLQUFLO2dCQUNHLFNBQVM7c0JBQWpCLEtBQUs7Z0JBQ0csV0FBVztzQkFBbkIsS0FBSztnQkFDRyxZQUFZO3NCQUFwQixLQUFLO2dCQUNHLFVBQVU7c0JBQWxCLEtBQUs7Z0JBQ0csU0FBUztzQkFBakIsS0FBSztnQkFDRyxTQUFTO3NCQUFqQixLQUFLO2dCQUNHLFNBQVM7c0JBQWpCLEtBQUs7Z0JBR0ksV0FBVztzQkFBcEIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQsIE91dHB1dCwgRXZlbnRFbWl0dGVyLCBDaGFuZ2VEZXRlY3RvclJlZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBGaWVsZFJlbmRlcmVyUHJvcHMgfSBmcm9tICdAZHluYW1pYy1maWVsZC1raXQvY29yZSc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICB0ZW1wbGF0ZTogJydcclxufSlcclxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIEJhc2VJbnB1dENvbXBvbmVudCB7XHJcbiAgQElucHV0KCkgdmFsdWU/OiBhbnk7XHJcbiAgQElucHV0KCkgbGFiZWw/OiBzdHJpbmc7XHJcbiAgQElucHV0KCkgcGxhY2Vob2xkZXI/OiBzdHJpbmc7XHJcbiAgQElucHV0KCkgcmVxdWlyZWQ/OiBib29sZWFuO1xyXG4gIEBJbnB1dCgpIGRpc2FibGVkPzogYm9vbGVhbjtcclxuICBASW5wdXQoKSBvcHRpb25zPzogYW55W107XHJcbiAgQElucHV0KCkgY2xhc3NOYW1lPzogc3RyaW5nO1xyXG4gIEBJbnB1dCgpIGRlc2NyaXB0aW9uPzogc3RyaW5nO1xyXG4gIEBJbnB1dCgpIGVycm9yTWVzc2FnZT86IHN0cmluZztcclxuICBASW5wdXQoKSBhY2NlcHRGaWxlPzogc3RyaW5nO1xyXG4gIEBJbnB1dCgpIG1heExlbmd0aD86IG51bWJlcjtcclxuICBASW5wdXQoKSBtaW5OdW1iZXI/OiBudW1iZXI7XHJcbiAgQElucHV0KCkgbWF4TnVtYmVyPzogbnVtYmVyO1xyXG4gIC8vIEFkZCBtb3JlIGZyb20gbXBsaXMgYXMgbmVlZGVkXHJcblxyXG4gIEBPdXRwdXQoKSB2YWx1ZUNoYW5nZSA9IG5ldyBFdmVudEVtaXR0ZXI8YW55PigpO1xyXG5cclxuICBjb25zdHJ1Y3Rvcihwcm90ZWN0ZWQgY2RyOiBDaGFuZ2VEZXRlY3RvclJlZikge31cclxufVxyXG5cclxuIl19
|
|
@@ -0,0 +1,146 @@
|
|
|
1
|
+
import { CommonModule } from "@angular/common";
|
|
2
|
+
import { Component, Input, Output, EventEmitter, ViewChild, ViewContainerRef, SimpleChange } from "@angular/core";
|
|
3
|
+
import { fieldRegistry } from "@dynamic-field-kit/core";
|
|
4
|
+
import { BaseInputComponent } from "./BaseInput";
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
export class DynamicInput extends BaseInputComponent {
|
|
7
|
+
constructor() {
|
|
8
|
+
super(...arguments);
|
|
9
|
+
this.valueChange = new EventEmitter();
|
|
10
|
+
this.onChange = new EventEmitter(); // backward compat
|
|
11
|
+
}
|
|
12
|
+
ngOnChanges(changes) {
|
|
13
|
+
if (changes["type"] && !changes["type"].firstChange && this.host) {
|
|
14
|
+
this.render();
|
|
15
|
+
return;
|
|
16
|
+
}
|
|
17
|
+
if (this.inputInstance) {
|
|
18
|
+
this.applyKnownProps(this.inputInstance);
|
|
19
|
+
const childChanges = {};
|
|
20
|
+
for (const prop in changes) {
|
|
21
|
+
childChanges[prop] = new SimpleChange(changes[prop].previousValue, changes[prop].currentValue, changes[prop].firstChange);
|
|
22
|
+
}
|
|
23
|
+
this.inputInstance.ngOnChanges?.(childChanges);
|
|
24
|
+
this.compRef?.changeDetectorRef.detectChanges();
|
|
25
|
+
}
|
|
26
|
+
else if (this.host) {
|
|
27
|
+
this.render();
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
ngAfterViewInit() {
|
|
31
|
+
this.render();
|
|
32
|
+
}
|
|
33
|
+
render() {
|
|
34
|
+
const Renderer = fieldRegistry.get(this.type);
|
|
35
|
+
this.cleanupRenderedComponent();
|
|
36
|
+
this.host.clear();
|
|
37
|
+
if (!Renderer) {
|
|
38
|
+
const el = document.createElement("div");
|
|
39
|
+
el.textContent = `Unknown field type: ${this.type}`;
|
|
40
|
+
this.host.element.nativeElement.appendChild(el);
|
|
41
|
+
return;
|
|
42
|
+
}
|
|
43
|
+
try {
|
|
44
|
+
const compType = Renderer;
|
|
45
|
+
const compRef = this.host.createComponent(compType);
|
|
46
|
+
const instance = compRef.instance;
|
|
47
|
+
if (!instance)
|
|
48
|
+
throw new Error(`Failed to create instance for ${this.type}`);
|
|
49
|
+
this.applyKnownProps(instance);
|
|
50
|
+
this.bindOutput(instance, "valueChange");
|
|
51
|
+
this.bindOutput(instance, "onValueChange");
|
|
52
|
+
instance.changeDetectorRef?.detectChanges();
|
|
53
|
+
this.compRef = compRef;
|
|
54
|
+
this.inputInstance = instance;
|
|
55
|
+
compRef.changeDetectorRef.detectChanges();
|
|
56
|
+
}
|
|
57
|
+
catch (err) {
|
|
58
|
+
// Fallback to function renderer
|
|
59
|
+
try {
|
|
60
|
+
const props = {
|
|
61
|
+
value: this.value,
|
|
62
|
+
onValueChange: (v) => this.emitValue(v),
|
|
63
|
+
label: this.label,
|
|
64
|
+
placeholder: this.placeholder,
|
|
65
|
+
required: this.required,
|
|
66
|
+
options: this.options,
|
|
67
|
+
className: this.className,
|
|
68
|
+
description: this.description,
|
|
69
|
+
disabled: this.disabled,
|
|
70
|
+
errorMessage: this.errorMessage,
|
|
71
|
+
};
|
|
72
|
+
const out = Renderer(props);
|
|
73
|
+
if (typeof out === 'string') {
|
|
74
|
+
const el = document.createElement('div');
|
|
75
|
+
el.innerHTML = out;
|
|
76
|
+
this.host.element.nativeElement.appendChild(el);
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
catch (e) {
|
|
80
|
+
const el = document.createElement('div');
|
|
81
|
+
el.textContent = `Failed to render field: ${this.type}`;
|
|
82
|
+
this.host.element.nativeElement.appendChild(el);
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
applyKnownProps(instance) {
|
|
87
|
+
const knownProps = ["value", "label", "placeholder", "required", "disabled", "options", "className", "description", "errorMessage"];
|
|
88
|
+
for (const prop of knownProps) {
|
|
89
|
+
if (prop in this && prop in instance) {
|
|
90
|
+
instance[prop] = this[prop];
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
bindOutput(instance, outputName) {
|
|
95
|
+
const output = instance?.[outputName];
|
|
96
|
+
if (!output || typeof output.subscribe !== "function")
|
|
97
|
+
return;
|
|
98
|
+
output.subscribe((value) => {
|
|
99
|
+
this.emitValue(value);
|
|
100
|
+
});
|
|
101
|
+
}
|
|
102
|
+
emitValue(value) {
|
|
103
|
+
this.valueChange.emit(value);
|
|
104
|
+
this.onChange.emit(value);
|
|
105
|
+
}
|
|
106
|
+
cleanupRenderedComponent() {
|
|
107
|
+
this.compRef?.destroy();
|
|
108
|
+
this.compRef = undefined;
|
|
109
|
+
this.inputInstance = undefined;
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
DynamicInput.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DynamicInput, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
113
|
+
DynamicInput.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: DynamicInput, isStandalone: true, selector: "dfk-dynamic-input", inputs: { type: "type", value: "value", label: "label", placeholder: "placeholder", required: "required", options: "options", className: "className", description: "description" }, outputs: { valueChange: "valueChange", onChange: "onChange" }, viewQueries: [{ propertyName: "host", first: true, predicate: ["host"], descendants: true, read: ViewContainerRef }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: `<div #host style="display: contents;"></div>`, isInline: true, dependencies: [{ kind: "ngmodule", type: CommonModule }] });
|
|
114
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DynamicInput, decorators: [{
|
|
115
|
+
type: Component,
|
|
116
|
+
args: [{
|
|
117
|
+
selector: "dfk-dynamic-input",
|
|
118
|
+
standalone: true,
|
|
119
|
+
imports: [CommonModule],
|
|
120
|
+
template: `<div #host style="display: contents;"></div>`,
|
|
121
|
+
}]
|
|
122
|
+
}], propDecorators: { type: [{
|
|
123
|
+
type: Input
|
|
124
|
+
}], value: [{
|
|
125
|
+
type: Input
|
|
126
|
+
}], label: [{
|
|
127
|
+
type: Input
|
|
128
|
+
}], placeholder: [{
|
|
129
|
+
type: Input
|
|
130
|
+
}], required: [{
|
|
131
|
+
type: Input
|
|
132
|
+
}], options: [{
|
|
133
|
+
type: Input
|
|
134
|
+
}], className: [{
|
|
135
|
+
type: Input
|
|
136
|
+
}], description: [{
|
|
137
|
+
type: Input
|
|
138
|
+
}], valueChange: [{
|
|
139
|
+
type: Output
|
|
140
|
+
}], onChange: [{
|
|
141
|
+
type: Output
|
|
142
|
+
}], host: [{
|
|
143
|
+
type: ViewChild,
|
|
144
|
+
args: ["host", { read: ViewContainerRef, static: false }]
|
|
145
|
+
}] } });
|
|
146
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"DynamicInput.js","sourceRoot":"","sources":["../../../src/components/DynamicInput.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from \"@angular/common\"\nimport { Component, ComponentRef, Input, Output, EventEmitter, ViewChild, ViewContainerRef, OnChanges, AfterViewInit, SimpleChanges, Type, SimpleChange } from \"@angular/core\"\nimport { fieldRegistry, FieldTypeKey } from \"@dynamic-field-kit/core\"\nimport { BaseInputComponent } from \"./BaseInput\"\n\n@Component({\n  selector: \"dfk-dynamic-input\",\n  standalone: true,\n  imports: [CommonModule],\n  template: `<div #host style=\"display: contents;\"></div>`,\n})\nexport class DynamicInput extends BaseInputComponent implements OnChanges, AfterViewInit {\n  @Input() type!: FieldTypeKey\n  @Input() value?: any\n  @Input() label?: string\r\n  @Input() placeholder?: string\r\n  @Input() required?: boolean\r\n  @Input() options?: any[]\n  @Input() className?: string\n  @Input() description?: any\n  @Output() override valueChange = new EventEmitter<any>()\n  @Output() onChange = new EventEmitter<any>() // backward compat\n\n  @ViewChild(\"host\", { read: ViewContainerRef, static: false }) host!: ViewContainerRef\n  private compRef?: ComponentRef<any>\n  private inputInstance?: any\n\r\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes[\"type\"] && !changes[\"type\"].firstChange && this.host) {\n      this.render()\n      return\n    }\n\n    if (this.inputInstance) {\n      this.applyKnownProps(this.inputInstance)\n\n      const childChanges: SimpleChanges = {}\n      for (const prop in changes) {\n        childChanges[prop] = new SimpleChange(\n          changes[prop].previousValue,\n          changes[prop].currentValue,\n          changes[prop].firstChange\n        )\n      }\n\n      this.inputInstance.ngOnChanges?.(childChanges)\n      this.compRef?.changeDetectorRef.detectChanges()\n    } else if (this.host) {\n      this.render()\n    }\n  }\n\r\n  ngAfterViewInit() {\r\n    this.render();\r\n  }\r\n\r\n  private render() {\n    const Renderer = fieldRegistry.get(this.type as FieldTypeKey)\n    this.cleanupRenderedComponent()\n    this.host.clear()\n    if (!Renderer) {\n      const el = document.createElement(\"div\")\n      el.textContent = `Unknown field type: ${this.type}`\n      this.host.element.nativeElement.appendChild(el)\n      return\n    }\n\n    try {\n      const compType = Renderer as unknown as Type<any>\n      const compRef = this.host.createComponent(compType)\n      const instance = compRef.instance\n      if (!instance) throw new Error(`Failed to create instance for ${this.type}`)\n\n      this.applyKnownProps(instance)\n\n      this.bindOutput(instance, \"valueChange\")\n      this.bindOutput(instance, \"onValueChange\")\n\n      instance.changeDetectorRef?.detectChanges()\n      this.compRef = compRef\n      this.inputInstance = instance\n      compRef.changeDetectorRef.detectChanges()\n    } catch (err) {\n      // Fallback to function renderer\n      try {\n        const props: any = {\n          value: this.value,\n          onValueChange: (v: any) => this.emitValue(v),\n          label: this.label,\n          placeholder: this.placeholder,\n          required: this.required,\n          options: this.options,\r\n          className: this.className,\r\n          description: this.description,\r\n          disabled: this.disabled,\r\n          errorMessage: this.errorMessage,\r\n        }\n        const out = (Renderer as Function)(props)\n        if (typeof out === 'string') {\n          const el = document.createElement('div')\n          el.innerHTML = out\n          this.host.element.nativeElement.appendChild(el)\n        }\n      } catch (e) {\n        const el = document.createElement('div')\n        el.textContent = `Failed to render field: ${this.type}`\n        this.host.element.nativeElement.appendChild(el)\n      }\n    }\n  }\n\n  private applyKnownProps(instance: any) {\n    const knownProps = [\"value\", \"label\", \"placeholder\", \"required\", \"disabled\", \"options\", \"className\", \"description\", \"errorMessage\"]\n    for (const prop of knownProps) {\n      if (prop in this && prop in instance) {\n        instance[prop] = (this as any)[prop]\n      }\n    }\n  }\n\n  private bindOutput(instance: any, outputName: \"valueChange\" | \"onValueChange\") {\n    const output = instance?.[outputName]\n    if (!output || typeof output.subscribe !== \"function\") return;\n\n    (output as EventEmitter<any>).subscribe((value) => {\n      this.emitValue(value)\n    })\n  }\n\n  private emitValue(value: any) {\n    this.valueChange.emit(value)\n    this.onChange.emit(value)\n  }\n\n  private cleanupRenderedComponent() {\n    this.compRef?.destroy()\n    this.compRef = undefined\n    this.inputInstance = undefined\n  }\n}\n"]}
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
import { NgIf } from "@angular/common";
|
|
2
|
+
import { Component, Input, Output, EventEmitter } from "@angular/core";
|
|
3
|
+
import { DynamicInput } from './DynamicInput';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export class FieldInput {
|
|
6
|
+
constructor() {
|
|
7
|
+
this.onValueChangeField = new EventEmitter();
|
|
8
|
+
}
|
|
9
|
+
getFieldValue() {
|
|
10
|
+
if (!this.fieldDescription || !this.renderInfos)
|
|
11
|
+
return undefined;
|
|
12
|
+
const value = this.renderInfos[this.fieldDescription.name];
|
|
13
|
+
if (value === undefined && this.fieldDescription.type === "text") {
|
|
14
|
+
return "";
|
|
15
|
+
}
|
|
16
|
+
return value;
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
FieldInput.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: FieldInput, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
20
|
+
FieldInput.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: FieldInput, isStandalone: true, selector: "dfk-field-input", inputs: { fieldDescription: "fieldDescription", renderInfos: "renderInfos" }, outputs: { onValueChangeField: "onValueChangeField" }, ngImport: i0, template: `
|
|
21
|
+
<dfk-dynamic-input
|
|
22
|
+
*ngIf="fieldDescription && renderInfos"
|
|
23
|
+
[type]="fieldDescription!.type"
|
|
24
|
+
[value]="getFieldValue()"
|
|
25
|
+
[label]="fieldDescription!.label"
|
|
26
|
+
[placeholder]="fieldDescription!.placeholder"
|
|
27
|
+
[required]="fieldDescription!.required"
|
|
28
|
+
[description]="fieldDescription!.description"
|
|
29
|
+
[options]="fieldDescription!.options"
|
|
30
|
+
[className]="fieldDescription!.className"
|
|
31
|
+
(valueChange)="onValueChangeField.emit({ value: $event, key: fieldDescription!.name })"
|
|
32
|
+
[disabled]="false"
|
|
33
|
+
[errorMessage]="''"
|
|
34
|
+
></dfk-dynamic-input>
|
|
35
|
+
`, isInline: true, dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: DynamicInput, selector: "dfk-dynamic-input", inputs: ["type", "value", "label", "placeholder", "required", "options", "className", "description"], outputs: ["valueChange", "onChange"] }] });
|
|
36
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: FieldInput, decorators: [{
|
|
37
|
+
type: Component,
|
|
38
|
+
args: [{
|
|
39
|
+
selector: "dfk-field-input",
|
|
40
|
+
standalone: true,
|
|
41
|
+
imports: [NgIf, DynamicInput],
|
|
42
|
+
template: `
|
|
43
|
+
<dfk-dynamic-input
|
|
44
|
+
*ngIf="fieldDescription && renderInfos"
|
|
45
|
+
[type]="fieldDescription!.type"
|
|
46
|
+
[value]="getFieldValue()"
|
|
47
|
+
[label]="fieldDescription!.label"
|
|
48
|
+
[placeholder]="fieldDescription!.placeholder"
|
|
49
|
+
[required]="fieldDescription!.required"
|
|
50
|
+
[description]="fieldDescription!.description"
|
|
51
|
+
[options]="fieldDescription!.options"
|
|
52
|
+
[className]="fieldDescription!.className"
|
|
53
|
+
(valueChange)="onValueChangeField.emit({ value: $event, key: fieldDescription!.name })"
|
|
54
|
+
[disabled]="false"
|
|
55
|
+
[errorMessage]="''"
|
|
56
|
+
></dfk-dynamic-input>
|
|
57
|
+
`,
|
|
58
|
+
}]
|
|
59
|
+
}], propDecorators: { fieldDescription: [{
|
|
60
|
+
type: Input
|
|
61
|
+
}], renderInfos: [{
|
|
62
|
+
type: Input
|
|
63
|
+
}], onValueChangeField: [{
|
|
64
|
+
type: Output
|
|
65
|
+
}] } });
|
|
66
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiRmllbGRJbnB1dC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0ZpZWxkSW5wdXQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLElBQUksRUFBRSxNQUFNLGlCQUFpQixDQUFBO0FBQ3RDLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxZQUFZLEVBQUUsTUFBTSxlQUFlLENBQUE7QUFDdEUsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGdCQUFnQixDQUFBOztBQXdCN0MsTUFBTSxPQUFPLFVBQVU7SUFyQnZCO1FBd0JZLHVCQUFrQixHQUFHLElBQUksWUFBWSxFQUE2QixDQUFBO0tBWTdFO0lBVkMsYUFBYTtRQUNYLElBQUksQ0FBQyxJQUFJLENBQUMsZ0JBQWdCLElBQUksQ0FBQyxJQUFJLENBQUMsV0FBVztZQUFFLE9BQU8sU0FBUyxDQUFBO1FBRWpFLE1BQU0sS0FBSyxHQUFHLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLGdCQUFnQixDQUFDLElBQUksQ0FBQyxDQUFBO1FBQzFELElBQUksS0FBSyxLQUFLLFNBQVMsSUFBSSxJQUFJLENBQUMsZ0JBQWdCLENBQUMsSUFBSSxLQUFLLE1BQU0sRUFBRTtZQUNoRSxPQUFPLEVBQUUsQ0FBQTtTQUNWO1FBRUQsT0FBTyxLQUFLLENBQUE7SUFDZCxDQUFDOzt3R0FkVSxVQUFVOzRGQUFWLFVBQVUsZ05BakJYOzs7Ozs7Ozs7Ozs7Ozs7R0FlVCw0REFoQlMsSUFBSSw2RkFBRSxZQUFZOzRGQWtCakIsVUFBVTtrQkFyQnRCLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLGlCQUFpQjtvQkFDM0IsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLE9BQU8sRUFBRSxDQUFDLElBQUksRUFBRSxZQUFZLENBQUM7b0JBQzdCLFFBQVEsRUFBRTs7Ozs7Ozs7Ozs7Ozs7O0dBZVQ7aUJBQ0Y7OEJBRVUsZ0JBQWdCO3NCQUF4QixLQUFLO2dCQUNHLFdBQVc7c0JBQW5CLEtBQUs7Z0JBQ0ksa0JBQWtCO3NCQUEzQixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdJZiB9IGZyb20gXCJAYW5ndWxhci9jb21tb25cIlxuaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCwgT3V0cHV0LCBFdmVudEVtaXR0ZXIgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiXG5pbXBvcnQgeyBEeW5hbWljSW5wdXQgfSBmcm9tICcuL0R5bmFtaWNJbnB1dCdcbmltcG9ydCB7IEZpZWxkRGVzY3JpcHRpb24sIFByb3BlcnRpZXMgfSBmcm9tIFwiQGR5bmFtaWMtZmllbGQta2l0L2NvcmVcIlxuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6IFwiZGZrLWZpZWxkLWlucHV0XCIsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtOZ0lmLCBEeW5hbWljSW5wdXRdLFxuICB0ZW1wbGF0ZTogYFxuICAgIDxkZmstZHluYW1pYy1pbnB1dFxuICAgICAgKm5nSWY9XCJmaWVsZERlc2NyaXB0aW9uICYmIHJlbmRlckluZm9zXCJcbiAgICAgIFt0eXBlXT1cImZpZWxkRGVzY3JpcHRpb24hLnR5cGVcIlxuICAgICAgW3ZhbHVlXT1cImdldEZpZWxkVmFsdWUoKVwiXG4gICAgICBbbGFiZWxdPVwiZmllbGREZXNjcmlwdGlvbiEubGFiZWxcIlxuICAgICAgW3BsYWNlaG9sZGVyXT1cImZpZWxkRGVzY3JpcHRpb24hLnBsYWNlaG9sZGVyXCJcbiAgICAgIFtyZXF1aXJlZF09XCJmaWVsZERlc2NyaXB0aW9uIS5yZXF1aXJlZFwiXG4gICAgICBbZGVzY3JpcHRpb25dPVwiZmllbGREZXNjcmlwdGlvbiEuZGVzY3JpcHRpb25cIlxyXG4gICAgICBbb3B0aW9uc109XCJmaWVsZERlc2NyaXB0aW9uIS5vcHRpb25zXCJcclxuICAgICAgW2NsYXNzTmFtZV09XCJmaWVsZERlc2NyaXB0aW9uIS5jbGFzc05hbWVcIlxyXG4gICAgICAodmFsdWVDaGFuZ2UpPVwib25WYWx1ZUNoYW5nZUZpZWxkLmVtaXQoeyB2YWx1ZTogJGV2ZW50LCBrZXk6IGZpZWxkRGVzY3JpcHRpb24hLm5hbWUgfSlcIlxyXG4gICAgICBbZGlzYWJsZWRdPVwiZmFsc2VcIlxyXG4gICAgICBbZXJyb3JNZXNzYWdlXT1cIicnXCJcclxuICAgID48L2Rmay1keW5hbWljLWlucHV0PlxyXG4gIGAsXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBGaWVsZElucHV0IHtcbiAgQElucHV0KCkgZmllbGREZXNjcmlwdGlvbj86IEZpZWxkRGVzY3JpcHRpb25cbiAgQElucHV0KCkgcmVuZGVySW5mb3M/OiBQcm9wZXJ0aWVzXG4gIEBPdXRwdXQoKSBvblZhbHVlQ2hhbmdlRmllbGQgPSBuZXcgRXZlbnRFbWl0dGVyPHt2YWx1ZTogYW55LCBrZXk6IHN0cmluZ30+KClcblxuICBnZXRGaWVsZFZhbHVlKCkge1xuICAgIGlmICghdGhpcy5maWVsZERlc2NyaXB0aW9uIHx8ICF0aGlzLnJlbmRlckluZm9zKSByZXR1cm4gdW5kZWZpbmVkXG5cbiAgICBjb25zdCB2YWx1ZSA9IHRoaXMucmVuZGVySW5mb3NbdGhpcy5maWVsZERlc2NyaXB0aW9uLm5hbWVdXG4gICAgaWYgKHZhbHVlID09PSB1bmRlZmluZWQgJiYgdGhpcy5maWVsZERlc2NyaXB0aW9uLnR5cGUgPT09IFwidGV4dFwiKSB7XG4gICAgICByZXR1cm4gXCJcIlxuICAgIH1cblxuICAgIHJldHVybiB2YWx1ZVxuICB9XG59XG4iXX0=
|