@gnggln/ng-ui-system 1.0.0-alpha.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/gnggln-ng-ui-system.mjs +5 -0
- package/esm2022/lib/components/accordion/accordion.component.mjs +353 -0
- package/esm2022/lib/components/accordion/accordion.types.mjs +6 -0
- package/esm2022/lib/components/accordion/index.mjs +2 -0
- package/esm2022/lib/components/base-layout/base-layout.component.mjs +218 -0
- package/esm2022/lib/components/base-layout/base-layout.types.mjs +6 -0
- package/esm2022/lib/components/base-layout/index.mjs +14 -0
- package/esm2022/lib/components/button/button-area.component.mjs +196 -0
- package/esm2022/lib/components/button/button.component.mjs +164 -0
- package/esm2022/lib/components/button/button.types.mjs +6 -0
- package/esm2022/lib/components/button/index.mjs +16 -0
- package/esm2022/lib/components/crud-table/crud-table.component.mjs +789 -0
- package/esm2022/lib/components/crud-table/crud-table.types.mjs +6 -0
- package/esm2022/lib/components/crud-table/index.mjs +16 -0
- package/esm2022/lib/components/form-builder/adapters/it-date-adapter.mjs +82 -0
- package/esm2022/lib/components/form-builder/directives/currency-input.directive.mjs +184 -0
- package/esm2022/lib/components/form-builder/form-builder.component.mjs +824 -0
- package/esm2022/lib/components/form-builder/form-wizard.component.mjs +510 -0
- package/esm2022/lib/components/form-builder/index.mjs +19 -0
- package/esm2022/lib/components/form-builder/services/form-condition.service.mjs +132 -0
- package/esm2022/lib/components/form-builder/services/form-validation.service.mjs +381 -0
- package/esm2022/lib/components/form-builder/services/location.service.mjs +140 -0
- package/esm2022/lib/components/form-builder/services/wizard-sync.service.mjs +84 -0
- package/esm2022/lib/components/form-builder/sub-components/error-summary/form-error-summary.component.mjs +161 -0
- package/esm2022/lib/components/form-builder/sub-components/file-input/file-input.component.mjs +310 -0
- package/esm2022/lib/components/form-builder/sub-components/specifica-territoriale/specifica-territoriale.component.mjs +648 -0
- package/esm2022/lib/components/form-builder/sub-components/table-territoriale/table-territoriale.component.mjs +432 -0
- package/esm2022/lib/components/form-builder/types/condition.types.mjs +6 -0
- package/esm2022/lib/components/form-builder/types/field.types.mjs +6 -0
- package/esm2022/lib/components/form-builder/types/index.mjs +2 -0
- package/esm2022/lib/components/form-builder/types/schema.types.mjs +6 -0
- package/esm2022/lib/components/form-builder/types/territoriale.types.mjs +6 -0
- package/esm2022/lib/components/form-builder/types/validation.types.mjs +6 -0
- package/esm2022/lib/components/form-builder-editor/form-builder-editor.component.mjs +730 -0
- package/esm2022/lib/components/form-builder-editor/form-builder-editor.service.mjs +56 -0
- package/esm2022/lib/components/form-builder-editor/index.mjs +21 -0
- package/esm2022/lib/components/form-builder-editor/services/editor-persistence.service.mjs +190 -0
- package/esm2022/lib/components/form-builder-editor/services/editor-state.service.mjs +324 -0
- package/esm2022/lib/components/form-builder-editor/services/field-factory.service.mjs +188 -0
- package/esm2022/lib/components/form-builder-editor/sub-components/condition-editor/condition-editor.component.mjs +667 -0
- package/esm2022/lib/components/form-builder-editor/sub-components/editor-toolbar/editor-toolbar.component.mjs +317 -0
- package/esm2022/lib/components/form-builder-editor/sub-components/field-config-panel/field-config-panel.component.mjs +611 -0
- package/esm2022/lib/components/form-builder-editor/sub-components/field-palette/field-palette.component.mjs +267 -0
- package/esm2022/lib/components/form-builder-editor/sub-components/form-values-panel/form-values-panel.component.mjs +276 -0
- package/esm2022/lib/components/form-builder-editor/sub-components/options-editor/options-editor.component.mjs +323 -0
- package/esm2022/lib/components/form-builder-editor/sub-components/preview-container/preview-container.component.mjs +238 -0
- package/esm2022/lib/components/form-builder-editor/sub-components/section-editor/section-editor.component.mjs +472 -0
- package/esm2022/lib/components/form-builder-editor/sub-components/validation-editor/validation-editor.component.mjs +473 -0
- package/esm2022/lib/components/form-builder-editor/types/editor.types.mjs +6 -0
- package/esm2022/lib/components/layout-builder/index.mjs +18 -0
- package/esm2022/lib/components/layout-builder/layout-builder.component.mjs +1730 -0
- package/esm2022/lib/components/layout-builder/layout-builder.types.mjs +9 -0
- package/esm2022/lib/components/layout-builder/layout.service.mjs +239 -0
- package/esm2022/lib/components/modal/confirm-dialog.component.mjs +151 -0
- package/esm2022/lib/components/modal/index.mjs +4 -0
- package/esm2022/lib/components/modal/modal.component.mjs +139 -0
- package/esm2022/lib/components/modal/modal.service.mjs +194 -0
- package/esm2022/lib/components/modal/modal.types.mjs +6 -0
- package/esm2022/lib/components/page-header/breadcrumb.service.mjs +242 -0
- package/esm2022/lib/components/page-header/index.mjs +20 -0
- package/esm2022/lib/components/page-header/page-header.component.mjs +243 -0
- package/esm2022/lib/components/page-header/page-header.types.mjs +21 -0
- package/esm2022/lib/components/table/index.mjs +2 -0
- package/esm2022/lib/components/table/paginated-table.component.mjs +407 -0
- package/esm2022/lib/components/table/table.types.mjs +6 -0
- package/esm2022/lib/core/types/index.mjs +6 -0
- package/esm2022/lib/core/utils/index.mjs +53 -0
- package/esm2022/lib/sources/location-data.opt.json +8942 -0
- package/esm2022/lib/sources/nazioni.opt.json +215 -0
- package/esm2022/public-api.mjs +34 -0
- package/fesm2022/gnggln-ng-ui-system.mjs +55752 -0
- package/fesm2022/gnggln-ng-ui-system.mjs.map +1 -0
- package/index.d.ts +5 -0
- package/lib/components/accordion/accordion.component.d.ts +118 -0
- package/lib/components/accordion/accordion.types.d.ts +62 -0
- package/lib/components/accordion/index.d.ts +2 -0
- package/lib/components/base-layout/base-layout.component.d.ts +83 -0
- package/lib/components/base-layout/base-layout.types.d.ts +26 -0
- package/lib/components/base-layout/index.d.ts +13 -0
- package/lib/components/button/button-area.component.d.ts +88 -0
- package/lib/components/button/button.component.d.ts +55 -0
- package/lib/components/button/button.types.d.ts +70 -0
- package/lib/components/button/index.d.ts +15 -0
- package/lib/components/crud-table/crud-table.component.d.ts +143 -0
- package/lib/components/crud-table/crud-table.types.d.ts +207 -0
- package/lib/components/crud-table/index.d.ts +15 -0
- package/lib/components/form-builder/adapters/it-date-adapter.d.ts +32 -0
- package/lib/components/form-builder/directives/currency-input.directive.d.ts +48 -0
- package/lib/components/form-builder/form-builder.component.d.ts +183 -0
- package/lib/components/form-builder/form-wizard.component.d.ts +87 -0
- package/lib/components/form-builder/index.d.ts +13 -0
- package/lib/components/form-builder/services/form-condition.service.d.ts +46 -0
- package/lib/components/form-builder/services/form-validation.service.d.ts +63 -0
- package/lib/components/form-builder/services/location.service.d.ts +83 -0
- package/lib/components/form-builder/services/wizard-sync.service.d.ts +63 -0
- package/lib/components/form-builder/sub-components/error-summary/form-error-summary.component.d.ts +28 -0
- package/lib/components/form-builder/sub-components/file-input/file-input.component.d.ts +41 -0
- package/lib/components/form-builder/sub-components/specifica-territoriale/specifica-territoriale.component.d.ts +145 -0
- package/lib/components/form-builder/sub-components/table-territoriale/table-territoriale.component.d.ts +108 -0
- package/lib/components/form-builder/types/condition.types.d.ts +51 -0
- package/lib/components/form-builder/types/field.types.d.ts +288 -0
- package/lib/components/form-builder/types/index.d.ts +5 -0
- package/lib/components/form-builder/types/schema.types.d.ts +227 -0
- package/lib/components/form-builder/types/territoriale.types.d.ts +170 -0
- package/lib/components/form-builder/types/validation.types.d.ts +174 -0
- package/lib/components/form-builder-editor/form-builder-editor.component.d.ts +117 -0
- package/lib/components/form-builder-editor/form-builder-editor.service.d.ts +38 -0
- package/lib/components/form-builder-editor/index.d.ts +15 -0
- package/lib/components/form-builder-editor/services/editor-persistence.service.d.ts +42 -0
- package/lib/components/form-builder-editor/services/editor-state.service.d.ts +66 -0
- package/lib/components/form-builder-editor/services/field-factory.service.d.ts +28 -0
- package/lib/components/form-builder-editor/sub-components/condition-editor/condition-editor.component.d.ts +139 -0
- package/lib/components/form-builder-editor/sub-components/editor-toolbar/editor-toolbar.component.d.ts +43 -0
- package/lib/components/form-builder-editor/sub-components/field-config-panel/field-config-panel.component.d.ts +83 -0
- package/lib/components/form-builder-editor/sub-components/field-palette/field-palette.component.d.ts +40 -0
- package/lib/components/form-builder-editor/sub-components/form-values-panel/form-values-panel.component.d.ts +51 -0
- package/lib/components/form-builder-editor/sub-components/options-editor/options-editor.component.d.ts +63 -0
- package/lib/components/form-builder-editor/sub-components/preview-container/preview-container.component.d.ts +68 -0
- package/lib/components/form-builder-editor/sub-components/section-editor/section-editor.component.d.ts +82 -0
- package/lib/components/form-builder-editor/sub-components/validation-editor/validation-editor.component.d.ts +112 -0
- package/lib/components/form-builder-editor/types/editor.types.d.ts +124 -0
- package/lib/components/layout-builder/index.d.ts +16 -0
- package/lib/components/layout-builder/layout-builder.component.d.ts +85 -0
- package/lib/components/layout-builder/layout-builder.types.d.ts +436 -0
- package/lib/components/layout-builder/layout.service.d.ts +100 -0
- package/lib/components/modal/confirm-dialog.component.d.ts +46 -0
- package/lib/components/modal/index.d.ts +4 -0
- package/lib/components/modal/modal.component.d.ts +44 -0
- package/lib/components/modal/modal.service.d.ts +93 -0
- package/lib/components/modal/modal.types.d.ts +110 -0
- package/lib/components/page-header/breadcrumb.service.d.ts +96 -0
- package/lib/components/page-header/index.d.ts +16 -0
- package/lib/components/page-header/page-header.component.d.ts +59 -0
- package/lib/components/page-header/page-header.types.d.ts +96 -0
- package/lib/components/table/index.d.ts +2 -0
- package/lib/components/table/paginated-table.component.d.ts +85 -0
- package/lib/components/table/table.types.d.ts +81 -0
- package/lib/core/types/index.d.ts +57 -0
- package/lib/core/utils/index.d.ts +29 -0
- package/package.json +44 -0
- package/public-api.d.ts +22 -0
|
@@ -0,0 +1,267 @@
|
|
|
1
|
+
import { Component, ChangeDetectionStrategy } from '@angular/core';
|
|
2
|
+
import { MatExpansionModule } from '@angular/material/expansion';
|
|
3
|
+
import { CdkDrag, CdkDragPlaceholder, CdkDropList } from '@angular/cdk/drag-drop';
|
|
4
|
+
import { LucideAngularModule } from 'lucide-angular';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "@angular/material/expansion";
|
|
7
|
+
import * as i2 from "lucide-angular";
|
|
8
|
+
/**
|
|
9
|
+
* Palette laterale dei tipi di campo disponibili.
|
|
10
|
+
*
|
|
11
|
+
* Mostra i campi raggruppati per categoria tramite pannelli espandibili.
|
|
12
|
+
* Ogni elemento e trascinabile (CDK drag-drop) verso le sezioni del form.
|
|
13
|
+
*
|
|
14
|
+
* @selector ui-field-palette
|
|
15
|
+
*/
|
|
16
|
+
export class UiFieldPaletteComponent {
|
|
17
|
+
constructor() {
|
|
18
|
+
/**
|
|
19
|
+
* Predicato che impedisce il drop di elementi dentro la palette.
|
|
20
|
+
* La palette e solo una sorgente di drag, non una destinazione.
|
|
21
|
+
*/
|
|
22
|
+
this.noDrop = () => false;
|
|
23
|
+
/**
|
|
24
|
+
* Catalogo completo degli elementi della palette,
|
|
25
|
+
* organizzato per categorie con i rispettivi metadati.
|
|
26
|
+
*/
|
|
27
|
+
this.categories = [
|
|
28
|
+
{
|
|
29
|
+
key: 'basic',
|
|
30
|
+
label: 'Campi base',
|
|
31
|
+
icon: 'type',
|
|
32
|
+
items: [
|
|
33
|
+
{ type: 'text', label: 'Testo', icon: 'type', description: 'Campo di testo singola riga', category: 'basic' },
|
|
34
|
+
{ type: 'email', label: 'Email', icon: 'mail', description: 'Campo email con validazione', category: 'basic' },
|
|
35
|
+
{
|
|
36
|
+
type: 'password',
|
|
37
|
+
label: 'Password',
|
|
38
|
+
icon: 'lock',
|
|
39
|
+
description: 'Campo password mascherato',
|
|
40
|
+
category: 'basic',
|
|
41
|
+
},
|
|
42
|
+
{ type: 'number', label: 'Numero', icon: 'hash', description: 'Campo numerico', category: 'basic' },
|
|
43
|
+
{
|
|
44
|
+
type: 'textarea',
|
|
45
|
+
label: 'Area testo',
|
|
46
|
+
icon: 'text',
|
|
47
|
+
description: 'Campo di testo multilinea',
|
|
48
|
+
category: 'basic',
|
|
49
|
+
},
|
|
50
|
+
],
|
|
51
|
+
},
|
|
52
|
+
{
|
|
53
|
+
key: 'choice',
|
|
54
|
+
label: 'Campi scelta',
|
|
55
|
+
icon: 'list',
|
|
56
|
+
items: [
|
|
57
|
+
{
|
|
58
|
+
type: 'select',
|
|
59
|
+
label: 'Select',
|
|
60
|
+
icon: 'chevron-down',
|
|
61
|
+
description: 'Menu a tendina singola scelta',
|
|
62
|
+
category: 'choice',
|
|
63
|
+
},
|
|
64
|
+
{
|
|
65
|
+
type: 'multiselect',
|
|
66
|
+
label: 'Multiselect',
|
|
67
|
+
icon: 'list',
|
|
68
|
+
description: 'Selezione multipla',
|
|
69
|
+
category: 'choice',
|
|
70
|
+
},
|
|
71
|
+
{
|
|
72
|
+
type: 'freemultiselect',
|
|
73
|
+
label: 'Multiselect libera',
|
|
74
|
+
icon: 'list-plus',
|
|
75
|
+
description: 'Selezione multipla con valori liberi',
|
|
76
|
+
category: 'choice',
|
|
77
|
+
},
|
|
78
|
+
{
|
|
79
|
+
type: 'radio',
|
|
80
|
+
label: 'Radio',
|
|
81
|
+
icon: 'circle-dot',
|
|
82
|
+
description: 'Gruppo di opzioni radio',
|
|
83
|
+
category: 'choice',
|
|
84
|
+
},
|
|
85
|
+
{
|
|
86
|
+
type: 'checkbox',
|
|
87
|
+
label: 'Checkbox',
|
|
88
|
+
icon: 'check-square',
|
|
89
|
+
description: 'Casella di spunta',
|
|
90
|
+
category: 'choice',
|
|
91
|
+
},
|
|
92
|
+
{
|
|
93
|
+
type: 'switch',
|
|
94
|
+
label: 'Switch',
|
|
95
|
+
icon: 'toggle-left',
|
|
96
|
+
description: 'Interruttore on/off',
|
|
97
|
+
category: 'choice',
|
|
98
|
+
},
|
|
99
|
+
],
|
|
100
|
+
},
|
|
101
|
+
{
|
|
102
|
+
key: 'datetime',
|
|
103
|
+
label: 'Data e ora',
|
|
104
|
+
icon: 'calendar',
|
|
105
|
+
items: [
|
|
106
|
+
{ type: 'date', label: 'Data', icon: 'calendar', description: 'Selettore di data', category: 'datetime' },
|
|
107
|
+
{
|
|
108
|
+
type: 'datetime',
|
|
109
|
+
label: 'Data e ora',
|
|
110
|
+
icon: 'clock',
|
|
111
|
+
description: 'Selettore data e ora',
|
|
112
|
+
category: 'datetime',
|
|
113
|
+
},
|
|
114
|
+
],
|
|
115
|
+
},
|
|
116
|
+
{
|
|
117
|
+
key: 'advanced',
|
|
118
|
+
label: 'Avanzati',
|
|
119
|
+
icon: 'settings',
|
|
120
|
+
items: [
|
|
121
|
+
{ type: 'file', label: 'File', icon: 'upload', description: 'Caricamento file', category: 'advanced' },
|
|
122
|
+
{ type: 'flag', label: 'Flag', icon: 'flag', description: 'Campo flag booleano', category: 'advanced' },
|
|
123
|
+
],
|
|
124
|
+
},
|
|
125
|
+
{
|
|
126
|
+
key: 'custom',
|
|
127
|
+
label: 'Personalizzati',
|
|
128
|
+
icon: 'settings',
|
|
129
|
+
items: [
|
|
130
|
+
{
|
|
131
|
+
type: 'custom',
|
|
132
|
+
label: 'Custom',
|
|
133
|
+
icon: 'settings',
|
|
134
|
+
description: 'Componente personalizzato',
|
|
135
|
+
category: 'custom',
|
|
136
|
+
},
|
|
137
|
+
{ type: 'divider', label: 'Separatore', icon: 'minus', description: 'Divisore visuale', category: 'custom' },
|
|
138
|
+
],
|
|
139
|
+
},
|
|
140
|
+
];
|
|
141
|
+
}
|
|
142
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: UiFieldPaletteComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
143
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: UiFieldPaletteComponent, isStandalone: true, selector: "ui-field-palette", ngImport: i0, template: `
|
|
144
|
+
<div class="field-palette">
|
|
145
|
+
<h3 class="field-palette__header">Campi disponibili</h3>
|
|
146
|
+
|
|
147
|
+
<mat-accordion multi>
|
|
148
|
+
@for (category of categories; track category.key) {
|
|
149
|
+
<mat-expansion-panel [expanded]="category.key === 'basic'">
|
|
150
|
+
<mat-expansion-panel-header>
|
|
151
|
+
<mat-panel-title>
|
|
152
|
+
<lucide-icon [name]="category.icon" [size]="16" aria-hidden="true" />
|
|
153
|
+
<span>{{ category.label }}</span>
|
|
154
|
+
</mat-panel-title>
|
|
155
|
+
</mat-expansion-panel-header>
|
|
156
|
+
|
|
157
|
+
<div
|
|
158
|
+
cdkDropList
|
|
159
|
+
[id]="'palette-' + category.key"
|
|
160
|
+
[cdkDropListData]="category.items"
|
|
161
|
+
[cdkDropListSortingDisabled]="true"
|
|
162
|
+
[cdkDropListEnterPredicate]="noDrop"
|
|
163
|
+
class="field-palette__list"
|
|
164
|
+
>
|
|
165
|
+
@for (item of category.items; track item.type) {
|
|
166
|
+
<div
|
|
167
|
+
cdkDrag
|
|
168
|
+
[cdkDragData]="item"
|
|
169
|
+
class="field-palette__item"
|
|
170
|
+
>
|
|
171
|
+
<!-- Placeholder visualizzato nella lista di destinazione durante il drag -->
|
|
172
|
+
<div class="field-palette__drag-placeholder" *cdkDragPlaceholder></div>
|
|
173
|
+
|
|
174
|
+
<!-- Icona handle di trascinamento (decorativa, l'intero elemento e draggabile) -->
|
|
175
|
+
<lucide-icon
|
|
176
|
+
name="grip-vertical"
|
|
177
|
+
[size]="14"
|
|
178
|
+
class="field-palette__drag-handle"
|
|
179
|
+
aria-hidden="true"
|
|
180
|
+
/>
|
|
181
|
+
|
|
182
|
+
<!-- Icona del tipo di campo -->
|
|
183
|
+
<lucide-icon
|
|
184
|
+
[name]="item.icon"
|
|
185
|
+
[size]="18"
|
|
186
|
+
class="field-palette__item-icon"
|
|
187
|
+
aria-hidden="true"
|
|
188
|
+
/>
|
|
189
|
+
|
|
190
|
+
<!-- Informazioni sul campo -->
|
|
191
|
+
<div class="field-palette__item-info">
|
|
192
|
+
<span class="field-palette__item-label">{{ item.label }}</span>
|
|
193
|
+
<span class="field-palette__item-desc">{{ item.description }}</span>
|
|
194
|
+
</div>
|
|
195
|
+
</div>
|
|
196
|
+
}
|
|
197
|
+
</div>
|
|
198
|
+
</mat-expansion-panel>
|
|
199
|
+
}
|
|
200
|
+
</mat-accordion>
|
|
201
|
+
</div>
|
|
202
|
+
`, isInline: true, styles: [".field-palette{padding:var(--ui-spacing-3, 12px);height:100%;overflow-y:auto;background:var(--ui-color-surface, #fff)}.field-palette__header{margin:0 0 var(--ui-spacing-3, 12px);font-size:var(--ui-font-size-md, 1rem);font-weight:600;color:var(--ui-color-text, #212121)}mat-panel-title{display:flex;align-items:center;gap:var(--ui-spacing-2, 8px);font-size:var(--ui-font-size-sm, .875rem);font-weight:500}.field-palette__list{display:flex;flex-direction:column;gap:var(--ui-spacing-1, 4px);min-height:24px}.field-palette__item{display:flex;align-items:center;gap:var(--ui-spacing-2, 8px);padding:var(--ui-spacing-2, 8px);border:1px solid var(--ui-color-border, #e0e0e0);border-radius:var(--ui-radius-sm, 4px);background:var(--ui-color-surface, #fff);cursor:grab;transition:box-shadow var(--ui-transition-fast, .15s),border-color var(--ui-transition-fast, .15s);-webkit-user-select:none;user-select:none}.field-palette__item:hover{border-color:var(--ui-color-primary, #3f51b5);box-shadow:var(--ui-shadow-sm, 0 1px 3px rgba(0,0,0,.1))}.field-palette__drag-handle{color:var(--ui-color-text-muted, #9e9e9e);flex-shrink:0;cursor:grab}.field-palette__item-icon{color:var(--ui-color-primary, #3f51b5);flex-shrink:0}.field-palette__item-info{display:flex;flex-direction:column;min-width:0}.field-palette__item-label{font-size:var(--ui-font-size-sm, .875rem);font-weight:500;color:var(--ui-color-text, #212121);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.field-palette__item-desc{font-size:var(--ui-font-size-xs, .75rem);color:var(--ui-color-text-secondary, #616161);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.field-palette__drag-placeholder{height:40px;border:2px dashed var(--ui-color-primary, #3f51b5);border-radius:var(--ui-radius-sm, 4px);background:var(--ui-color-primary-bg, rgba(63, 81, 181, .08));transition:transform var(--ui-transition-fast, .15s)}.cdk-drag-preview{box-shadow:var(--ui-shadow-md, 0 4px 12px rgba(0,0,0,.15));border-radius:var(--ui-radius-sm, 4px);background:var(--ui-color-surface, #fff);padding:var(--ui-spacing-2, 8px);display:flex;align-items:center;gap:var(--ui-spacing-2, 8px)}.cdk-drag-animating{transition:transform var(--ui-transition-normal, .25s) cubic-bezier(0,0,.2,1)}mat-expansion-panel{margin-bottom:var(--ui-spacing-1, 4px)!important;box-shadow:none!important;border:1px solid var(--ui-color-border, #e0e0e0);border-radius:var(--ui-radius-sm, 4px)!important}\n"], dependencies: [{ kind: "ngmodule", type: MatExpansionModule }, { kind: "directive", type: i1.MatAccordion, selector: "mat-accordion", inputs: ["hideToggle", "displayMode", "togglePosition"], exportAs: ["matAccordion"] }, { kind: "component", type: i1.MatExpansionPanel, selector: "mat-expansion-panel", inputs: ["hideToggle", "togglePosition"], outputs: ["afterExpand", "afterCollapse"], exportAs: ["matExpansionPanel"] }, { kind: "component", type: i1.MatExpansionPanelHeader, selector: "mat-expansion-panel-header", inputs: ["expandedHeight", "collapsedHeight", "tabIndex"] }, { kind: "directive", type: i1.MatExpansionPanelTitle, selector: "mat-panel-title" }, { kind: "directive", type: CdkDropList, selector: "[cdkDropList], cdk-drop-list", inputs: ["cdkDropListConnectedTo", "cdkDropListData", "cdkDropListOrientation", "id", "cdkDropListLockAxis", "cdkDropListDisabled", "cdkDropListSortingDisabled", "cdkDropListEnterPredicate", "cdkDropListSortPredicate", "cdkDropListAutoScrollDisabled", "cdkDropListAutoScrollStep", "cdkDropListElementContainer"], outputs: ["cdkDropListDropped", "cdkDropListEntered", "cdkDropListExited", "cdkDropListSorted"], exportAs: ["cdkDropList"] }, { kind: "directive", type: CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer", "cdkDragScale"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }, { kind: "directive", type: CdkDragPlaceholder, selector: "ng-template[cdkDragPlaceholder]", inputs: ["data"] }, { kind: "ngmodule", type: LucideAngularModule }, { kind: "component", type: i2.LucideAngularComponent, selector: "lucide-angular, lucide-icon, i-lucide, span-lucide", inputs: ["class", "name", "img", "color", "absoluteStrokeWidth", "size", "strokeWidth"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
203
|
+
}
|
|
204
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: UiFieldPaletteComponent, decorators: [{
|
|
205
|
+
type: Component,
|
|
206
|
+
args: [{ selector: 'ui-field-palette', standalone: true, imports: [MatExpansionModule, CdkDropList, CdkDrag, CdkDragPlaceholder, LucideAngularModule], changeDetection: ChangeDetectionStrategy.OnPush, template: `
|
|
207
|
+
<div class="field-palette">
|
|
208
|
+
<h3 class="field-palette__header">Campi disponibili</h3>
|
|
209
|
+
|
|
210
|
+
<mat-accordion multi>
|
|
211
|
+
@for (category of categories; track category.key) {
|
|
212
|
+
<mat-expansion-panel [expanded]="category.key === 'basic'">
|
|
213
|
+
<mat-expansion-panel-header>
|
|
214
|
+
<mat-panel-title>
|
|
215
|
+
<lucide-icon [name]="category.icon" [size]="16" aria-hidden="true" />
|
|
216
|
+
<span>{{ category.label }}</span>
|
|
217
|
+
</mat-panel-title>
|
|
218
|
+
</mat-expansion-panel-header>
|
|
219
|
+
|
|
220
|
+
<div
|
|
221
|
+
cdkDropList
|
|
222
|
+
[id]="'palette-' + category.key"
|
|
223
|
+
[cdkDropListData]="category.items"
|
|
224
|
+
[cdkDropListSortingDisabled]="true"
|
|
225
|
+
[cdkDropListEnterPredicate]="noDrop"
|
|
226
|
+
class="field-palette__list"
|
|
227
|
+
>
|
|
228
|
+
@for (item of category.items; track item.type) {
|
|
229
|
+
<div
|
|
230
|
+
cdkDrag
|
|
231
|
+
[cdkDragData]="item"
|
|
232
|
+
class="field-palette__item"
|
|
233
|
+
>
|
|
234
|
+
<!-- Placeholder visualizzato nella lista di destinazione durante il drag -->
|
|
235
|
+
<div class="field-palette__drag-placeholder" *cdkDragPlaceholder></div>
|
|
236
|
+
|
|
237
|
+
<!-- Icona handle di trascinamento (decorativa, l'intero elemento e draggabile) -->
|
|
238
|
+
<lucide-icon
|
|
239
|
+
name="grip-vertical"
|
|
240
|
+
[size]="14"
|
|
241
|
+
class="field-palette__drag-handle"
|
|
242
|
+
aria-hidden="true"
|
|
243
|
+
/>
|
|
244
|
+
|
|
245
|
+
<!-- Icona del tipo di campo -->
|
|
246
|
+
<lucide-icon
|
|
247
|
+
[name]="item.icon"
|
|
248
|
+
[size]="18"
|
|
249
|
+
class="field-palette__item-icon"
|
|
250
|
+
aria-hidden="true"
|
|
251
|
+
/>
|
|
252
|
+
|
|
253
|
+
<!-- Informazioni sul campo -->
|
|
254
|
+
<div class="field-palette__item-info">
|
|
255
|
+
<span class="field-palette__item-label">{{ item.label }}</span>
|
|
256
|
+
<span class="field-palette__item-desc">{{ item.description }}</span>
|
|
257
|
+
</div>
|
|
258
|
+
</div>
|
|
259
|
+
}
|
|
260
|
+
</div>
|
|
261
|
+
</mat-expansion-panel>
|
|
262
|
+
}
|
|
263
|
+
</mat-accordion>
|
|
264
|
+
</div>
|
|
265
|
+
`, styles: [".field-palette{padding:var(--ui-spacing-3, 12px);height:100%;overflow-y:auto;background:var(--ui-color-surface, #fff)}.field-palette__header{margin:0 0 var(--ui-spacing-3, 12px);font-size:var(--ui-font-size-md, 1rem);font-weight:600;color:var(--ui-color-text, #212121)}mat-panel-title{display:flex;align-items:center;gap:var(--ui-spacing-2, 8px);font-size:var(--ui-font-size-sm, .875rem);font-weight:500}.field-palette__list{display:flex;flex-direction:column;gap:var(--ui-spacing-1, 4px);min-height:24px}.field-palette__item{display:flex;align-items:center;gap:var(--ui-spacing-2, 8px);padding:var(--ui-spacing-2, 8px);border:1px solid var(--ui-color-border, #e0e0e0);border-radius:var(--ui-radius-sm, 4px);background:var(--ui-color-surface, #fff);cursor:grab;transition:box-shadow var(--ui-transition-fast, .15s),border-color var(--ui-transition-fast, .15s);-webkit-user-select:none;user-select:none}.field-palette__item:hover{border-color:var(--ui-color-primary, #3f51b5);box-shadow:var(--ui-shadow-sm, 0 1px 3px rgba(0,0,0,.1))}.field-palette__drag-handle{color:var(--ui-color-text-muted, #9e9e9e);flex-shrink:0;cursor:grab}.field-palette__item-icon{color:var(--ui-color-primary, #3f51b5);flex-shrink:0}.field-palette__item-info{display:flex;flex-direction:column;min-width:0}.field-palette__item-label{font-size:var(--ui-font-size-sm, .875rem);font-weight:500;color:var(--ui-color-text, #212121);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.field-palette__item-desc{font-size:var(--ui-font-size-xs, .75rem);color:var(--ui-color-text-secondary, #616161);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.field-palette__drag-placeholder{height:40px;border:2px dashed var(--ui-color-primary, #3f51b5);border-radius:var(--ui-radius-sm, 4px);background:var(--ui-color-primary-bg, rgba(63, 81, 181, .08));transition:transform var(--ui-transition-fast, .15s)}.cdk-drag-preview{box-shadow:var(--ui-shadow-md, 0 4px 12px rgba(0,0,0,.15));border-radius:var(--ui-radius-sm, 4px);background:var(--ui-color-surface, #fff);padding:var(--ui-spacing-2, 8px);display:flex;align-items:center;gap:var(--ui-spacing-2, 8px)}.cdk-drag-animating{transition:transform var(--ui-transition-normal, .25s) cubic-bezier(0,0,.2,1)}mat-expansion-panel{margin-bottom:var(--ui-spacing-1, 4px)!important;box-shadow:none!important;border:1px solid var(--ui-color-border, #e0e0e0);border-radius:var(--ui-radius-sm, 4px)!important}\n"] }]
|
|
266
|
+
}] });
|
|
267
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmllbGQtcGFsZXR0ZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9uZy11aS1zeXN0ZW0vc3JjL2xpYi9jb21wb25lbnRzL2Zvcm0tYnVpbGRlci1lZGl0b3Ivc3ViLWNvbXBvbmVudHMvZmllbGQtcGFsZXR0ZS9maWVsZC1wYWxldHRlLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLHVCQUF1QixFQUFTLE1BQU0sZUFBZSxDQUFDO0FBQzFFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBQ2pFLE9BQU8sRUFBRSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsV0FBVyxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDbEYsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7Ozs7QUFxQnJEOzs7Ozs7O0dBT0c7QUFpTUgsTUFBTSxPQUFPLHVCQUF1QjtJQWhNcEM7UUFpTUU7OztXQUdHO1FBQ0gsV0FBTSxHQUFHLEdBQVksRUFBRSxDQUFDLEtBQUssQ0FBQztRQUU5Qjs7O1dBR0c7UUFDTSxlQUFVLEdBQXNCO1lBQ3ZDO2dCQUNFLEdBQUcsRUFBRSxPQUFPO2dCQUNaLEtBQUssRUFBRSxZQUFZO2dCQUNuQixJQUFJLEVBQUUsTUFBTTtnQkFDWixLQUFLLEVBQUU7b0JBQ0wsRUFBRSxJQUFJLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxPQUFPLEVBQUUsSUFBSSxFQUFFLE1BQU0sRUFBRSxXQUFXLEVBQUUsNkJBQTZCLEVBQUUsUUFBUSxFQUFFLE9BQU8sRUFBRTtvQkFDN0csRUFBRSxJQUFJLEVBQUUsT0FBTyxFQUFFLEtBQUssRUFBRSxPQUFPLEVBQUUsSUFBSSxFQUFFLE1BQU0sRUFBRSxXQUFXLEVBQUUsNkJBQTZCLEVBQUUsUUFBUSxFQUFFLE9BQU8sRUFBRTtvQkFD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TUFBTSxFQUFFLFdBQVcsRUFBRSxxQkFBcUIsRUFBRSxRQUFRLEVBQUUsVUFBVSxFQUFFO2lCQUN4RzthQUNGO1lBQ0Q7Z0JBQ0UsR0FBRyxFQUFFLFFBQVE7Z0JBQ2IsS0FBSyxFQUFFLGdCQUFnQjtnQkFDdkIsSUFBSSxFQUFFLFVBQVU7Z0JBQ2hCLEtBQUssRUFBRTtvQkFDTDt3QkFDRSxJQUFJLEVBQUUsUUFBUTt3QkFDZCxLQUFLLEVBQUUsUUFBUTt3QkFDZixJQUFJLEVBQUUsVUFBVTt3QkFDaEIsV0FBVyxFQUFFLDJCQUEyQjt3QkFDeEMsUUFBUSxFQUFFLFFBQVE7cUJBQ25CO29CQUNELEVBQUUsSUFBSSxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsWUFBWSxFQUFFLElBQUksRUFBRSxPQUFPLEVBQUUsV0FBVyxFQUFFLGtCQUFrQixFQUFFLFFBQVEsRUFBRSxRQUFRLEVBQUU7aUJBQzdHO2FBQ0Y7U0FDRixDQUFDO0tBQ0g7K0dBN0hZLHVCQUF1QjttR0FBdkIsdUJBQXVCLDRFQTNMeEI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBMkRULGk4RUE3RFMsa0JBQWtCLHduQkFBRSxXQUFXLDhmQUFFLE9BQU8sd2NBQUUsa0JBQWtCLDZGQUFFLG1CQUFtQjs7NEZBNkxoRix1QkFBdUI7a0JBaE1uQyxTQUFTOytCQUNFLGtCQUFrQixjQUNoQixJQUFJLFdBQ1AsQ0FBQyxrQkFBa0IsRUFBRSxXQUFXLEVBQUUsT0FBTyxFQUFFLGtCQUFrQixFQUFFLG1CQUFtQixDQUFDLG1CQUMzRSx1QkFBdUIsQ0FBQyxNQUFNLFlBQ3JDOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQTJEVCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IE1hdEV4cGFuc2lvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2V4cGFuc2lvbic7XHJcbmltcG9ydCB7IENka0RyYWcsIENka0RyYWdQbGFjZWhvbGRlciwgQ2RrRHJvcExpc3QgfSBmcm9tICdAYW5ndWxhci9jZGsvZHJhZy1kcm9wJztcclxuaW1wb3J0IHsgTHVjaWRlQW5ndWxhck1vZHVsZSB9IGZyb20gJ2x1Y2lkZS1hbmd1bGFyJztcclxuXHJcbmltcG9ydCB7IFVpRWRpdG9yRmllbGRQYWxldHRlSXRlbSwgVWlFZGl0b3JGaWVsZENhdGVnb3J5IH0gZnJvbSAnLi4vLi4vdHlwZXMvZWRpdG9yLnR5cGVzJztcclxuaW1wb3J0IHsgVWlGaWVsZFR5cGUgfSBmcm9tICcuLi8uLi8uLi9mb3JtLWJ1aWxkZXIvdHlwZXMvaW5kZXgnO1xyXG5pbXBvcnQgeyBVaUljb25OYW1lIH0gZnJvbSAnLi4vLi4vLi4vLi4vY29yZS90eXBlcyc7XHJcblxyXG4vKipcclxuICogSW50ZXJmYWNjaWEgaW50ZXJuYSBwZXIgdW5hIGNhdGVnb3JpYSBkZWxsYSBwYWxldHRlLlxyXG4gKiBSYWdncnVwcGEgdW4gaW5zaWVtZSBkaSBlbGVtZW50aSBzb3R0byB1bidldGljaGV0dGEgY29tdW5lLlxyXG4gKi9cclxuaW50ZXJmYWNlIFBhbGV0dGVDYXRlZ29yeSB7XHJcbiAgLyoqIElkZW50aWZpY2F0aXZvIGRlbGxhIGNhdGVnb3JpYS4gKi9cclxuICBrZXk6IFVpRWRpdG9yRmllbGRDYXRlZ29yeTtcclxuICAvKiogRXRpY2hldHRhIHZpc3VhbGl6emF0YSBuZWxsJ2ludGVzdGF6aW9uZSBkZWxsJ2FjY29yZGlvbi4gKi9cclxuICBsYWJlbDogc3RyaW5nO1xyXG4gIC8qKiBJY29uYSBMdWNpZGUgZGVsbGEgY2F0ZWdvcmlhLiAqL1xyXG4gIGljb246IFVpSWNvbk5hbWU7XHJcbiAgLyoqIEVsZW1lbnRpIHRyYXNjaW5hYmlsaSBhcHBhcnRlbmVudGkgYWxsYSBjYXRlZ29yaWEuICovXHJcbiAgaXRlbXM6IFVpRWRpdG9yRmllbGRQYWxldHRlSXRlbVtdO1xyXG59XHJcblxyXG4vKipcclxuICogUGFsZXR0ZSBsYXRlcmFsZSBkZWkgdGlwaSBkaSBjYW1wbyBkaXNwb25pYmlsaS5cclxuICpcclxuICogTW9zdHJhIGkgY2FtcGkgcmFnZ3J1cHBhdGkgcGVyIGNhdGVnb3JpYSB0cmFtaXRlIHBhbm5lbGxpIGVzcGFuZGliaWxpLlxyXG4gKiBPZ25pIGVsZW1lbnRvIGUgdHJhc2NpbmFiaWxlIChDREsgZHJhZy1kcm9wKSB2ZXJzbyBsZSBzZXppb25pIGRlbCBmb3JtLlxyXG4gKlxyXG4gKiBAc2VsZWN0b3IgdWktZmllbGQtcGFsZXR0ZVxyXG4gKi9cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICd1aS1maWVsZC1wYWxldHRlJyxcclxuICBzdGFuZGFsb25lOiB0cnVlLFxyXG4gIGltcG9ydHM6IFtNYXRFeHBhbnNpb25Nb2R1bGUsIENka0Ryb3BMaXN0LCBDZGtEcmFnLCBDZGtEcmFnUGxhY2Vob2xkZXIsIEx1Y2lkZUFuZ3VsYXJNb2R1bGVdLFxyXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxyXG4gIHRlbXBsYXRlOiBgXHJcbiAgICA8ZGl2IGNsYXNzPVwiZmllbGQtcGFsZXR0ZVwiPlxyXG4gICAgICA8aDMgY2xhc3M9XCJmaWVsZC1wYWxldHRlX19oZWFkZXJcIj5DYW1waSBkaXNwb25pYmlsaTwvaDM+XHJcblxyXG4gICAgICA8bWF0LWFjY29yZGlvbiBtdWx0aT5cclxuICAgICAgICBAZm9yIChjYXRlZ29yeSBvZiBjYXRlZ29yaWVzOyB0cmFjayBjYXRlZ29yeS5rZXkpIHtcclxuICAgICAgICAgIDxtYXQtZXhwYW5zaW9uLXBhbmVsIFtleHBhbmRlZF09XCJjYXRlZ29yeS5rZXkgPT09ICdiYXNpYydcIj5cclxuICAgICAgICAgICAgPG1hdC1leHBhbnNpb24tcGFuZWwtaGVhZGVyPlxyXG4gICAgICAgICAgICAgIDxtYXQtcGFuZWwtdGl0bGU+XHJcbiAgICAgICAgICAgICAgICA8bHVjaWRlLWljb24gW25hbWVdPVwiY2F0ZWdvcnkuaWNvblwiIFtzaXplXT1cIjE2XCIgYXJpYS1oaWRkZW49XCJ0cnVlXCIgLz5cclxuICAgICAgICAgICAgICAgIDxzcGFuPnt7IGNhdGVnb3J5LmxhYmVsIH19PC9zcGFuPlxyXG4gICAgICAgICAgICAgIDwvbWF0LXBhbmVsLXRpdGxlPlxyXG4gICAgICAgICAgICA8L21hdC1leHBhbnNpb24tcGFuZWwtaGVhZGVyPlxyXG5cclxuICAgICAgICAgICAgPGRpdlxyXG4gICAgICAgICAgICAgIGNka0Ryb3BMaXN0XHJcbiAgICAgICAgICAgICAgW2lkXT1cIidwYWxldHRlLScgKyBjYXRlZ29yeS5rZXlcIlxyXG4gICAgICAgICAgICAgIFtjZGtEcm9wTGlzdERhdGFdPVwiY2F0ZWdvcnkuaXRlbXNcIlxyXG4gICAgICAgICAgICAgIFtjZGtEcm9wTGlzdFNvcnRpbmdEaXNhYmxlZF09XCJ0cnVlXCJcclxuICAgICAgICAgICAgICBbY2RrRHJvcExpc3RFbnRlclByZWRpY2F0ZV09XCJub0Ryb3BcIlxyXG4gICAgICAgICAgICAgIGNsYXNzPVwiZmllbGQtcGFsZXR0ZV9fbGlzdFwiXHJcbiAgICAgICAgICAgID5cclxuICAgICAgICAgICAgICBAZm9yIChpdGVtIG9mIGNhdGVnb3J5Lml0ZW1zOyB0cmFjayBpdGVtLnR5cGUpIHtcclxuICAgICAgICAgICAgICAgIDxkaXZcclxuICAgICAgICAgICAgICAgICAgY2RrRHJhZ1xyXG4gICAgICAgICAgICAgICAgICBbY2RrRHJhZ0RhdGFdPVwiaXRlbVwiXHJcbiAgICAgICAgICAgICAgICAgIGNsYXNzPVwiZmllbGQtcGFsZXR0ZV9faXRlbVwiXHJcbiAgICAgICAgICAgICAgICA+XHJcbiAgICAgICAgICAgICAgICAgIDwhLS0gUGxhY2Vob2xkZXIgdmlzdWFsaXp6YXRvIG5lbGxhIGxpc3RhIGRpIGRlc3RpbmF6aW9uZSBkdXJhbnRlIGlsIGRyYWcgLS0+XHJcbiAgICAgICAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJmaWVsZC1wYWxldHRlX19kcmFnLXBsYWNlaG9sZGVyXCIgKmNka0RyYWdQbGFjZWhvbGRlcj48L2Rpdj5cclxuXHJcbiAgICAgICAgICAgICAgICAgIDwhLS0gSWNvbmEgaGFuZGxlIGRpIHRyYXNjaW5hbWVudG8gKGRlY29yYXRpdmEsIGwnaW50ZXJvIGVsZW1lbnRvIGUgZHJhZ2dhYmlsZSkgLS0+XHJcbiAgICAgICAgICAgICAgICAgIDxsdWNpZGUtaWNvblxyXG4gICAgICAgICAgICAgICAgICAgIG5hbWU9XCJncmlwLXZlcnRpY2FsXCJcclxuICAgICAgICAgICAgICAgICAgICBbc2l6ZV09XCIxNFwiXHJcbiAgICAgICAgICAgICAgICAgICAgY2xhc3M9XCJmaWVsZC1wYWxldHRlX19kcmFnLWhhbmRsZVwiXHJcbiAgICAgICAgICAgICAgICAgICAgYXJpYS1oaWRkZW49XCJ0cnVlXCJcclxuICAgICAgICAgICAgICAgICAgLz5cclxuXHJcbiAgICAgICAgICAgICAgICAgIDwhLS0gSWNvbmEgZGVsIHRpcG8gZGkgY2FtcG8gLS0+XHJcbiAgICAgICAgICAgICAgICAgIDxsdWNpZGUtaWNvblxyXG4gICAgICAgICAgICAgICAgICAgIFtuYW1lXT1cIml0ZW0uaWNvblwiXHJcbiAgICAgICAgICAgICAgICAgICAgW3NpemVdPVwiMThcIlxyXG4gICAgICAgICAgICAgICAgICAgIGNsYXNzPVwiZmllbGQtcGFsZXR0ZV9faXRlbS1pY29uXCJcclxuICAgICAgICAgICAgICAgICAgICBhcmlhLWhpZGRlbj1cInRydWVcIlxyXG4gICAgICAgICAgICAgICAgICAvPlxyXG5cclxuICAgICAgICAgICAgICAgICAgPCEtLSBJbmZvcm1hemlvbmkgc3VsIGNhbXBvIC0tPlxyXG4gICAgICAgICAgICAgICAgICA8ZGl2IGNsYXNzPVwiZmllbGQtcGFsZXR0ZV9faXRlbS1pbmZvXCI+XHJcbiAgICAgICAgICAgICAgICAgICAgPHNwYW4gY2xhc3M9XCJmaWVsZC1wYWxldHRlX19pdGVtLWxhYmVsXCI+e3sgaXRlbS5sYWJlbCB9fTwvc3Bhbj5cclxuICAgICAgICAgICAgICAgICAgICA8c3BhbiBjbGFzcz1cImZpZWxkLXBhbGV0dGVfX2l0ZW0tZGVzY1wiPnt7IGl0ZW0uZGVzY3JpcHRpb24gfX08L3NwYW4+XHJcbiAgICAgICAgICAgICAgICAgIDwvZGl2PlxyXG4gICAgICAgICAgICAgICAgPC9kaXY+XHJcbiAgICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICA8L2Rpdj5cclxuICAgICAgICAgIDwvbWF0LWV4cGFuc2lvbi1wYW5lbD5cclxuICAgICAgICB9XHJcbiAgICAgIDwvbWF0LWFjY29yZGlvbj5cclxuICAgIDwvZGl2PlxyXG4gIGAsXHJcbiAgc3R5bGVzOiBbXHJcbiAgICBgXHJcbiAgICAvKiBDb250ZW5pdG9yZSBwcmluY2lwYWxlIGRlbGxhIHBhbGV0dGUgKi9cclxuICAgIC5maWVsZC1wYWxldHRlIHtcclxuICAgICAgcGFkZGluZzogdmFyKC0tdWktc3BhY2luZy0zLCAxMnB4KTtcclxuICAgICAgaGVpZ2h0OiAxMDAlO1xyXG4gICAgICBvdmVyZmxvdy15OiBhdXRvO1xyXG4gICAgICBiYWNrZ3JvdW5kOiB2YXIoLS11aS1jb2xvci1zdXJmYWNlLCAjZmZmKTtcclxuICAgIH1cclxuXHJcbiAgICAvKiBJbnRlc3RhemlvbmUgZGVsbGEgcGFsZXR0ZSAqL1xyXG4gICAgLmZpZWxkLXBhbGV0dGVfX2hlYWRlciB7XHJcbiAgICAgIG1hcmdpbjogMCAwIHZhcigtLXVpLXNwYWNpbmctMywgMTJweCk7XHJcbiAgICAgIGZvbnQtc2l6ZTogdmFyKC0tdWktZm9udC1zaXplLW1kLCAxcmVtKTtcclxuICAgICAgZm9udC13ZWlnaHQ6IDYwMDtcclxuICAgICAgY29sb3I6IHZhcigtLXVpLWNvbG9yLXRleHQsICMyMTIxMjEpO1xyXG4gICAgfVxyXG5cclxuICAgIC8qIFRpdG9sbyBkZWwgcGFubmVsbG86IGljb25hICsgdGVzdG8gKi9cclxuICAgIG1hdC1wYW5lbC10aXRsZSB7XHJcbiAgICAgIGRpc3BsYXk6IGZsZXg7XHJcbiAgICAgIGFsaWduLWl0ZW1zOiBjZW50ZXI7XHJcbiAgICAgIGdhcDogdmFyKC0tdWktc3BhY2luZy0yLCA4cHgpO1xyXG4gICAgICBmb250LXNpemU6IHZhcigtLXVpLWZvbnQtc2l6ZS1zbSwgMC44NzVyZW0pO1xyXG4gICAgICBmb250LXdlaWdodDogNTAwO1xyXG4gICAgfVxyXG5cclxuICAgIC8qIExpc3RhIGRpIGNhbXBpIGFsbCdpbnRlcm5vIGRlbCBwYW5uZWxsbyAqL1xyXG4gICAgLmZpZWxkLXBhbGV0dGVfX2xpc3Qge1xyXG4gICAgICBkaXNwbGF5OiBmbGV4O1xyXG4gICAgICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xyXG4gICAgICBnYXA6IHZhcigtLXVpLXNwYWNpbmctMSwgNHB4KTtcclxuICAgICAgbWluLWhlaWdodDogMjRweDtcclxuICAgIH1cclxuXHJcbiAgICAvKiBTaW5nb2xvIGVsZW1lbnRvIHRyYXNjaW5hYmlsZSAqL1xyXG4gICAgLmZpZWxkLXBhbGV0dGVfX2l0ZW0ge1xyXG4gICAgICBkaXNwbGF5OiBmbGV4O1xyXG4gICAgICBhbGlnbi1pdGVtczogY2VudGVyO1xyXG4gICAgICBnYXA6IHZhcigtLXVpLXNwYWNpbmctMiwgOHB4KTtcclxuICAgICAgcGFkZGluZzogdmFyKC0tdWktc3BhY2luZy0yLCA4cHgpO1xyXG4gICAgICBib3JkZXI6IDFweCBzb2xpZCB2YXIoLS11aS1jb2xvci1ib3JkZXIsICNlMGUwZTApO1xyXG4gICAgICBib3JkZXItcmFkaXVzOiB2YXIoLS11aS1yYWRpdXMtc20sIDRweCk7XHJcbiAgICAgIGJhY2tncm91bmQ6IHZhcigtLXVpLWNvbG9yLXN1cmZhY2UsICNmZmYpO1xyXG4gICAgICBjdXJzb3I6IGdyYWI7XHJcbiAgICAgIHRyYW5zaXRpb246IGJveC1zaGFkb3cgdmFyKC0tdWktdHJhbnNpdGlvbi1mYXN0LCAxNTBtcyksXHJcbiAgICAgICAgICAgICAgICAgIGJvcmRlci1jb2xvciB2YXIoLS11aS10cmFuc2l0aW9uLWZhc3QsIDE1MG1zKTtcclxuICAgICAgdXNlci1zZWxlY3Q6IG5vbmU7XHJcbiAgICB9XHJcblxyXG4gICAgLmZpZWxkLXBhbGV0dGVfX2l0ZW06aG92ZXIge1xyXG4gICAgICBib3JkZXItY29sb3I6IHZhcigtLXVpLWNvbG9yLXByaW1hcnksICMzZjUxYjUpO1xyXG4gICAgICBib3gtc2hhZG93OiB2YXIoLS11aS1zaGFkb3ctc20sIDAgMXB4IDNweCByZ2JhKDAsMCwwLC4xKSk7XHJcbiAgICB9XHJcblxyXG4gICAgLyogSGFuZGxlIGRpIHRyYXNjaW5hbWVudG8gKi9cclxuICAgIC5maWVsZC1wYWxldHRlX19kcmFnLWhhbmRsZSB7XHJcbiAgICAgIGNvbG9yOiB2YXIoLS11aS1jb2xvci10ZXh0LW11dGVkLCAjOWU5ZTllKTtcclxuICAgICAgZmxleC1zaHJpbms6IDA7XHJcbiAgICAgIGN1cnNvcjogZ3JhYjtcclxuICAgIH1cclxuXHJcbiAgICAvKiBJY29uYSB0aXBvIGNhbXBvICovXHJcbiAgICAuZmllbGQtcGFsZXR0ZV9faXRlbS1pY29uIHtcclxuICAgICAgY29sb3I6IHZhcigtLXVpLWNvbG9yLXByaW1hcnksICMzZjUxYjUpO1xyXG4gICAgICBmbGV4LXNocmluazogMDtcclxuICAgIH1cclxuXHJcbiAgICAvKiBCbG9jY28gaW5mbyAobGFiZWwgKyBkZXNjcml6aW9uZSkgKi9cclxuICAgIC5maWVsZC1wYWxldHRlX19pdGVtLWluZm8ge1xyXG4gICAgICBkaXNwbGF5OiBmbGV4O1xyXG4gICAgICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xyXG4gICAgICBtaW4td2lkdGg6IDA7XHJcbiAgICB9XHJcblxyXG4gICAgLmZpZWxkLXBhbGV0dGVfX2l0ZW0tbGFiZWwge1xyXG4gICAgICBmb250LXNpemU6IHZhcigtLXVpLWZvbnQtc2l6ZS1zbSwgMC44NzVyZW0pO1xyXG4gICAgICBmb250LXdlaWdodDogNTAwO1xyXG4gICAgICBjb2xvcjogdmFyKC0tdWktY29sb3ItdGV4dCwgIzIxMjEyMSk7XHJcbiAgICAgIHdoaXRlLXNwYWNlOiBub3dyYXA7XHJcbiAgICAgIG92ZXJmbG93OiBoaWRkZW47XHJcbiAgICAgIHRleHQtb3ZlcmZsb3c6IGVsbGlwc2lzO1xyXG4gICAgfVxyXG5cclxuICAgIC5maWVsZC1wYWxldHRlX19pdGVtLWRlc2Mge1xyXG4gICAgICBmb250LXNpemU6IHZhcigtLXVpLWZvbnQtc2l6ZS14cywgMC43NXJlbSk7XHJcbiAgICAgIGNvbG9yOiB2YXIoLS11aS1jb2xvci10ZXh0LXNlY29uZGFyeSwgIzYxNjE2MSk7XHJcbiAgICAgIHdoaXRlLXNwYWNlOiBub3dyYXA7XHJcbiAgICAgIG92ZXJmbG93OiBoaWRkZW47XHJcbiAgICAgIHRleHQtb3ZlcmZsb3c6IGVsbGlwc2lzO1xyXG4gICAgfVxyXG5cclxuICAgIC8qIFBsYWNlaG9sZGVyIG1vc3RyYXRvIG5lbGxhIHpvbmEgZGkgZGVzdGluYXppb25lICovXHJcbiAgICAuZmllbGQtcGFsZXR0ZV9fZHJhZy1wbGFjZWhvbGRlciB7XHJcbiAgICAgIGhlaWdodDogNDBweDtcclxuICAgICAgYm9yZGVyOiAycHggZGFzaGVkIHZhcigtLXVpLWNvbG9yLXByaW1hcnksICMzZjUxYjUpO1xyXG4gICAgICBib3JkZXItcmFkaXVzOiB2YXIoLS11aS1yYWRpdXMtc20sIDRweCk7XHJcbiAgICAgIGJhY2tncm91bmQ6IHZhcigtLXVpLWNvbG9yLXByaW1hcnktYmcsIHJnYmEoNjMsIDgxLCAxODEsIDAuMDgpKTtcclxuICAgICAgdHJhbnNpdGlvbjogdHJhbnNmb3JtIHZhcigtLXVpLXRyYW5zaXRpb24tZmFzdCwgMTUwbXMpO1xyXG4gICAgfVxyXG5cclxuICAgIC8qIFN0aWxlIGRlbGwnZWxlbWVudG8gZHVyYW50ZSBpbCB0cmFzY2luYW1lbnRvIChDREspICovXHJcbiAgICAuY2RrLWRyYWctcHJldmlldyB7XHJcbiAgICAgIGJveC1zaGFkb3c6IHZhcigtLXVpLXNoYWRvdy1tZCwgMCA0cHggMTJweCByZ2JhKDAsMCwwLC4xNSkpO1xyXG4gICAgICBib3JkZXItcmFkaXVzOiB2YXIoLS11aS1yYWRpdXMtc20sIDRweCk7XHJcbiAgICAgIGJhY2tncm91bmQ6IHZhcigtLXVpLWNvbG9yLXN1cmZhY2UsICNmZmYpO1xyXG4gICAgICBwYWRkaW5nOiB2YXIoLS11aS1zcGFjaW5nLTIsIDhweCk7XHJcbiAgICAgIGRpc3BsYXk6IGZsZXg7XHJcbiAgICAgIGFsaWduLWl0ZW1zOiBjZW50ZXI7XHJcbiAgICAgIGdhcDogdmFyKC0tdWktc3BhY2luZy0yLCA4cHgpO1xyXG4gICAgfVxyXG5cclxuICAgIC8qIEFuaW1hemlvbmUgZGkgc3Bvc3RhbWVudG8gZGVnbGkgZWxlbWVudGkgQ0RLICovXHJcbiAgICAuY2RrLWRyYWctYW5pbWF0aW5nIHtcclxuICAgICAgdHJhbnNpdGlvbjogdHJhbnNmb3JtIHZhcigtLXVpLXRyYW5zaXRpb24tbm9ybWFsLCAyNTBtcykgY3ViaWMtYmV6aWVyKDAsIDAsIDAuMiwgMSk7XHJcbiAgICB9XHJcblxyXG4gICAgLyogUGFubmVsbGkgZXNwYW5kaWJpbGk6IHNwYXppYXR1cmEgKi9cclxuICAgIG1hdC1leHBhbnNpb24tcGFuZWwge1xyXG4gICAgICBtYXJnaW4tYm90dG9tOiB2YXIoLS11aS1zcGFjaW5nLTEsIDRweCkgIWltcG9ydGFudDtcclxuICAgICAgYm94LXNoYWRvdzogbm9uZSAhaW1wb3J0YW50O1xyXG4gICAgICBib3JkZXI6IDFweCBzb2xpZCB2YXIoLS11aS1jb2xvci1ib3JkZXIsICNlMGUwZTApO1xyXG4gICAgICBib3JkZXItcmFkaXVzOiB2YXIoLS11aS1yYWRpdXMtc20sIDRweCkgIWltcG9ydGFudDtcclxuICAgIH1cclxuICBgLFxyXG4gIF0sXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBVaUZpZWxkUGFsZXR0ZUNvbXBvbmVudCB7XHJcbiAgLyoqXHJcbiAgICogUHJlZGljYXRvIGNoZSBpbXBlZGlzY2UgaWwgZHJvcCBkaSBlbGVtZW50aSBkZW50cm8gbGEgcGFsZXR0ZS5cclxuICAgKiBMYSBwYWxldHRlIGUgc29sbyB1bmEgc29yZ2VudGUgZGkgZHJhZywgbm9uIHVuYSBkZXN0aW5hemlvbmUuXHJcbiAgICovXHJcbiAgbm9Ecm9wID0gKCk6IGJvb2xlYW4gPT4gZmFsc2U7XHJcblxyXG4gIC8qKlxyXG4gICAqIENhdGFsb2dvIGNvbXBsZXRvIGRlZ2xpIGVsZW1lbnRpIGRlbGxhIHBhbGV0dGUsXHJcbiAgICogb3JnYW5penphdG8gcGVyIGNhdGVnb3JpZSBjb24gaSByaXNwZXR0aXZpIG1ldGFkYXRpLlxyXG4gICAqL1xyXG4gIHJlYWRvbmx5IGNhdGVnb3JpZXM6IFBhbGV0dGVDYXRlZ29yeVtdID0gW1xyXG4gICAge1xyXG4gICAgICBrZXk6ICdiYXNpYycsXHJcbiAgICAgIGxhYmVsOiAnQ2FtcGkgYmFzZScsXHJcbiAgICAgIGljb246ICd0eXBlJyxcclxuICAgICAgaXRlbXM6IFtcclxuICAgICAgICB7IHR5cGU6ICd0ZXh0JywgbGFiZWw6ICdUZXN0bycsIGljb246ICd0eXBlJywgZGVzY3JpcHRpb246ICdDYW1wbyBkaSB0ZXN0byBzaW5nb2xhIHJpZ2EnLCBjYXRlZ29yeTogJ2Jhc2ljJyB9LFxyXG4gICAgICAgIHsgdHlwZTogJ2VtYWlsJywgbGFiZWw6ICdFbWFpbCcsIGljb246ICdtYWlsJywgZGVzY3JpcHRpb246ICdDYW1wbyBlbWFpbCBjb24gdmFsaWRhemlvbmUnLCBjYXRlZ29yeTogJ2Jhc2ljJyB9LFxyXG4gICAgICAgIHtcclxuICAgICAgICAgIHR5cGU6ICdwYXNzd29yZCcsXHJcbiAgICAgICAgICBsYWJlbDogJ1Bhc3N3b3JkJyxcclxuICAgICAgICAgIGljb246ICdsb2NrJyxcclxuICAgICAgICAgIGRlc2NyaXB0aW9uOiAnQ2FtcG8gcGFzc3dvcmQgbWFzY2hlcmF0bycsXHJcbiAgICAgICAgICBjYXRlZ29yeTogJ2Jhc2ljJyxcclxuICAgICAgICB9LFxyXG4gICAgICAgIHsgdHlwZTogJ251bWJlcicsIGxhYmVsOiAnTnVtZXJvJywgaWNvbjogJ2hhc2gnLCBkZXNjcmlwdGlvbjogJ0NhbXBvIG51bWVyaWNvJywgY2F0ZWdvcnk6ICdiYXNpYycgfSxcclxuICAgICAgICB7XHJcbiAgICAgICAgICB0eXBlOiAndGV4dGFyZWEnLFxyXG4gICAgICAgICAgbGFiZWw6ICdBcmVhIHRlc3RvJyxcclxuICAgICAgICAgIGljb246ICd0ZXh0JyxcclxuICAgICAgICAgIGRlc2NyaXB0aW9uOiAnQ2FtcG8gZGkgdGVzdG8gbXVsdGlsaW5lYScsXHJcbiAgICAgICAgICBjYXRlZ29yeTogJ2Jhc2ljJyxcclxuICAgICAgICB9LFxyXG4gICAgICBdLFxyXG4gICAgfSxcclxuICAgIHtcclxuICAgICAga2V5OiAnY2hvaWNlJyxcclxuICAgICAgbGFiZWw6ICdDYW1waSBzY2VsdGEnLFxyXG4gICAgICBpY29uOiAnbGlzdCcsXHJcbiAgICAgIGl0ZW1zOiBbXHJcbiAgICAgICAge1xyXG4gICAgICAgICAgdHlwZTogJ3NlbGVjdCcsXHJcbiAgICAgICAgICBsYWJlbDogJ1NlbGVjdCcsXHJcbiAgICAgICAgICBpY29uOiAnY2hldnJvbi1kb3duJyxcclxuICAgICAgICAgIGRlc2NyaXB0aW9uOiAnTWVudSBhIHRlbmRpbmEgc2luZ29sYSBzY2VsdGEnLFxyXG4gICAgICAgICAgY2F0ZWdvcnk6ICdjaG9pY2UnLFxyXG4gICAgICAgIH0sXHJcbiAgICAgICAge1xyXG4gICAgICAgICAgdHlwZTogJ211bHRpc2VsZWN0JyxcclxuICAgICAgICAgIGxhYmVsOiAnTXVsdGlzZWxlY3QnLFxyXG4gICAgICAgICAgaWNvbjogJ2xpc3QnLFxyXG4gICAgICAgICAgZGVzY3JpcHRpb246ICdTZWxlemlvbmUgbXVsdGlwbGEnLFxyXG4gICAgICAgICAgY2F0ZWdvcnk6ICdjaG9pY2UnLFxyXG4gICAgICAgIH0sXHJcbiAgICAgICAge1xyXG4gICAgICAgICAgdHlwZTogJ2ZyZWVtdWx0aXNlbGVjdCcsXHJcbiAgICAgICAgICBsYWJlbDogJ011bHRpc2VsZWN0IGxpYmVyYScsXHJcbiAgICAgICAgICBpY29uOiAnbGlzdC1wbHVzJyxcclxuICAgICAgICAgIGRlc2NyaXB0aW9uOiAnU2VsZXppb25lIG11bHRpcGxhIGNvbiB2YWxvcmkgbGliZXJpJyxcclxuICAgICAgICAgIGNhdGVnb3J5OiAnY2hvaWNlJyxcclxuICAgICAgICB9LFxyXG4gICAgICAgIHtcclxuICAgICAgICAgIHR5cGU6ICdyYWRpbycsXHJcbiAgICAgICAgICBsYWJlbDogJ1JhZGlvJyxcclxuICAgICAgICAgIGljb246ICdjaXJjbGUtZG90JyxcclxuICAgICAgICAgIGRlc2NyaXB0aW9uOiAnR3J1cHBvIGRpIG9wemlvbmkgcmFkaW8nLFxyXG4gICAgICAgICAgY2F0ZWdvcnk6ICdjaG9pY2UnLFxyXG4gICAgICAgIH0sXHJcbiAgICAgICAge1xyXG4gICAgICAgICAgdHlwZTogJ2NoZWNrYm94JyxcclxuICAgICAgICAgIGxhYmVsOiAnQ2hlY2tib3gnLFxyXG4gICAgICAgICAgaWNvbjogJ2NoZWNrLXNxdWFyZScsXHJcbiAgICAgICAgICBkZXNjcmlwdGlvbjogJ0Nhc2VsbGEgZGkgc3B1bnRhJyxcclxuICAgICAgICAgIGNhdGVnb3J5OiAnY2hvaWNlJyxcclxuICAgICAgICB9LFxyXG4gICAgICAgIHtcclxuICAgICAgICAgIHR5cGU6ICdzd2l0Y2gnLFxyXG4gICAgICAgICAgbGFiZWw6ICdTd2l0Y2gnLFxyXG4gICAgICAgICAgaWNvbjogJ3RvZ2dsZS1sZWZ0JyxcclxuICAgICAgICAgIGRlc2NyaXB0aW9uOiAnSW50ZXJydXR0b3JlIG9uL29mZicsXHJcbiAgICAgICAgICBjYXRlZ29yeTogJ2Nob2ljZScsXHJcbiAgICAgICAgfSxcclxuICAgICAgXSxcclxuICAgIH0sXHJcbiAgICB7XHJcbiAgICAgIGtleTogJ2RhdGV0aW1lJyxcclxuICAgICAgbGFiZWw6ICdEYXRhIGUgb3JhJyxcclxuICAgICAgaWNvbjogJ2NhbGVuZGFyJyxcclxuICAgICAgaXRlbXM6IFtcclxuICAgICAgICB7IHR5cGU6ICdkYXRlJywgbGFiZWw6ICdEYXRhJywgaWNvbjogJ2NhbGVuZGFyJywgZGVzY3JpcHRpb246ICdTZWxldHRvcmUgZGkgZGF0YScsIGNhdGVnb3J5OiAnZGF0ZXRpbWUnIH0sXHJcbiAgICAgICAge1xyXG4gICAgICAgICAgdHlwZTogJ2RhdGV0aW1lJyxcclxuICAgICAgICAgIGxhYmVsOiAnRGF0YSBlIG9yYScsXHJcbiAgICAgICAgICBpY29uOiAnY2xvY2snLFxyXG4gICAgICAgICAgZGVzY3JpcHRpb246ICdTZWxldHRvcmUgZGF0YSBlIG9yYScsXHJcbiAgICAgICAgICBjYXRlZ29yeTogJ2RhdGV0aW1lJyxcclxuICAgICAgICB9LFxyXG4gICAgICBdLFxyXG4gICAgfSxcclxuICAgIHtcclxuICAgICAga2V5OiAnYWR2YW5jZWQnLFxyXG4gICAgICBsYWJlbDogJ0F2YW56YXRpJyxcclxuICAgICAgaWNvbjogJ3NldHRpbmdzJyxcclxuICAgICAgaXRlbXM6IFtcclxuICAgICAgICB7IHR5cGU6ICdmaWxlJywgbGFiZWw6ICdGaWxlJywgaWNvbjogJ3VwbG9hZCcsIGRlc2NyaXB0aW9uOiAnQ2FyaWNhbWVudG8gZmlsZScsIGNhdGVnb3J5OiAnYWR2YW5jZWQnIH0sXHJcbiAgICAgICAgeyB0eXBlOiAnZmxhZycsIGxhYmVsOiAnRmxhZycsIGljb246ICdmbGFnJywgZGVzY3JpcHRpb246ICdDYW1wbyBmbGFnIGJvb2xlYW5vJywgY2F0ZWdvcnk6ICdhZHZhbmNlZCcgfSxcclxuICAgICAgXSxcclxuICAgIH0sXHJcbiAgICB7XHJcbiAgICAgIGtleTogJ2N1c3RvbScsXHJcbiAgICAgIGxhYmVsOiAnUGVyc29uYWxpenphdGknLFxyXG4gICAgICBpY29uOiAnc2V0dGluZ3MnLFxyXG4gICAgICBpdGVtczogW1xyXG4gICAgICAgIHtcclxuICAgICAgICAgIHR5cGU6ICdjdXN0b20nLFxyXG4gICAgICAgICAgbGFiZWw6ICdDdXN0b20nLFxyXG4gICAgICAgICAgaWNvbjogJ3NldHRpbmdzJyxcclxuICAgICAgICAgIGRlc2NyaXB0aW9uOiAnQ29tcG9uZW50ZSBwZXJzb25hbGl6emF0bycsXHJcbiAgICAgICAgICBjYXRlZ29yeTogJ2N1c3RvbScsXHJcbiAgICAgICAgfSxcclxuICAgICAgICB7IHR5cGU6ICdkaXZpZGVyJywgbGFiZWw6ICdTZXBhcmF0b3JlJywgaWNvbjogJ21pbnVzJywgZGVzY3JpcHRpb246ICdEaXZpc29yZSB2aXN1YWxlJywgY2F0ZWdvcnk6ICdjdXN0b20nIH0sXHJcbiAgICAgIF0sXHJcbiAgICB9LFxyXG4gIF07XHJcbn1cclxuIl19
|
|
@@ -0,0 +1,276 @@
|
|
|
1
|
+
import { Component, ChangeDetectionStrategy, Input, Output, EventEmitter } from '@angular/core';
|
|
2
|
+
import { FormsModule } from '@angular/forms';
|
|
3
|
+
import { MatFormFieldModule } from '@angular/material/form-field';
|
|
4
|
+
import { MatInputModule } from '@angular/material/input';
|
|
5
|
+
import { LucideAngularModule } from 'lucide-angular';
|
|
6
|
+
import { UiButtonComponent } from '../../../button/index';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
import * as i1 from "@angular/forms";
|
|
9
|
+
import * as i2 from "@angular/material/form-field";
|
|
10
|
+
import * as i3 from "@angular/material/input";
|
|
11
|
+
import * as i4 from "lucide-angular";
|
|
12
|
+
/**
|
|
13
|
+
* Pannello overlay in basso nell'anteprima che mostra i valori correnti
|
|
14
|
+
* del form in formato JSON modificabile.
|
|
15
|
+
*
|
|
16
|
+
* Permette di visualizzare, modificare, formattare e resettare i valori
|
|
17
|
+
* del form durante la fase di anteprima nell'editor.
|
|
18
|
+
*
|
|
19
|
+
* @selector ui-editor-form-values-panel
|
|
20
|
+
*/
|
|
21
|
+
export class UiEditorFormValuesPanelComponent {
|
|
22
|
+
constructor() {
|
|
23
|
+
/** Stato di apertura/chiusura del pannello. */
|
|
24
|
+
this.isOpen = false;
|
|
25
|
+
/** Emesso quando i valori vengono modificati dall'utente via JSON. */
|
|
26
|
+
this.valuesChange = new EventEmitter();
|
|
27
|
+
/** Emesso alla richiesta di aggiornamento dei valori. */
|
|
28
|
+
this.refreshValues = new EventEmitter();
|
|
29
|
+
/** Emesso alla richiesta di apertura/chiusura del pannello. */
|
|
30
|
+
this.toggle = new EventEmitter();
|
|
31
|
+
/** Testo JSON visualizzato nella textarea. */
|
|
32
|
+
this.jsonText = '{}';
|
|
33
|
+
/** Messaggio di errore per JSON non valido. */
|
|
34
|
+
this.jsonError = null;
|
|
35
|
+
/** @internal Valori interni del form. */
|
|
36
|
+
this._formValues = {};
|
|
37
|
+
}
|
|
38
|
+
/** Valori correnti del form da visualizzare. */
|
|
39
|
+
set formValues(value) {
|
|
40
|
+
this._formValues = value;
|
|
41
|
+
this.updateJsonText();
|
|
42
|
+
}
|
|
43
|
+
get formValues() {
|
|
44
|
+
return this._formValues;
|
|
45
|
+
}
|
|
46
|
+
/**
|
|
47
|
+
* Gestisce l'input dell'utente nella textarea JSON.
|
|
48
|
+
* Prova a parsare il JSON e aggiorna i valori se valido.
|
|
49
|
+
* @param text - Testo JSON inserito dall'utente
|
|
50
|
+
*/
|
|
51
|
+
onJsonInput(text) {
|
|
52
|
+
this.jsonText = text;
|
|
53
|
+
try {
|
|
54
|
+
const parsed = JSON.parse(text);
|
|
55
|
+
this.jsonError = null;
|
|
56
|
+
this.valuesChange.emit(parsed);
|
|
57
|
+
}
|
|
58
|
+
catch (e) {
|
|
59
|
+
this.jsonError = 'JSON non valido: controlla la sintassi';
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
/**
|
|
63
|
+
* Pulisce i valori del form resettando a oggetto vuoto.
|
|
64
|
+
*/
|
|
65
|
+
clearValues() {
|
|
66
|
+
this._formValues = {};
|
|
67
|
+
this.jsonText = '{}';
|
|
68
|
+
this.jsonError = null;
|
|
69
|
+
this.valuesChange.emit({});
|
|
70
|
+
}
|
|
71
|
+
/**
|
|
72
|
+
* Formatta il JSON con indentazione per una migliore leggibilita.
|
|
73
|
+
*/
|
|
74
|
+
formatJson() {
|
|
75
|
+
try {
|
|
76
|
+
const parsed = JSON.parse(this.jsonText);
|
|
77
|
+
this.jsonText = JSON.stringify(parsed, null, 2);
|
|
78
|
+
this.jsonError = null;
|
|
79
|
+
}
|
|
80
|
+
catch (e) {
|
|
81
|
+
this.jsonError = 'Impossibile formattare: JSON non valido';
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
/**
|
|
85
|
+
* @internal
|
|
86
|
+
* Aggiorna il testo JSON dalla rappresentazione interna dei valori.
|
|
87
|
+
*/
|
|
88
|
+
updateJsonText() {
|
|
89
|
+
try {
|
|
90
|
+
this.jsonText = JSON.stringify(this._formValues, null, 2);
|
|
91
|
+
this.jsonError = null;
|
|
92
|
+
}
|
|
93
|
+
catch {
|
|
94
|
+
this.jsonText = '{}';
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: UiEditorFormValuesPanelComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
98
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: UiEditorFormValuesPanelComponent, isStandalone: true, selector: "ui-editor-form-values-panel", inputs: { formValues: "formValues", isOpen: "isOpen" }, outputs: { valuesChange: "valuesChange", refreshValues: "refreshValues", toggle: "toggle" }, ngImport: i0, template: `
|
|
99
|
+
<div
|
|
100
|
+
class="form-values-panel"
|
|
101
|
+
[class.form-values-panel--open]="isOpen"
|
|
102
|
+
>
|
|
103
|
+
<!-- Intestazione con toggle e azioni -->
|
|
104
|
+
<div class="form-values-panel__header" (click)="toggle.emit()">
|
|
105
|
+
<div class="form-values-panel__header-left">
|
|
106
|
+
<lucide-icon name="code" [size]="16" aria-hidden="true" />
|
|
107
|
+
<span class="form-values-panel__title">Valori Form</span>
|
|
108
|
+
</div>
|
|
109
|
+
|
|
110
|
+
<div class="form-values-panel__header-actions" (click)="$event.stopPropagation()">
|
|
111
|
+
<!-- Aggiorna valori -->
|
|
112
|
+
<ui-button
|
|
113
|
+
icon="refresh-cw"
|
|
114
|
+
variant="ghost"
|
|
115
|
+
size="xs"
|
|
116
|
+
tooltip="Aggiorna valori"
|
|
117
|
+
ariaLabel="Aggiorna valori"
|
|
118
|
+
(click)="refreshValues.emit()"
|
|
119
|
+
/>
|
|
120
|
+
|
|
121
|
+
<!-- Pulisci valori -->
|
|
122
|
+
<ui-button
|
|
123
|
+
icon="trash-2"
|
|
124
|
+
variant="ghost"
|
|
125
|
+
size="xs"
|
|
126
|
+
tooltip="Pulisci valori"
|
|
127
|
+
ariaLabel="Pulisci valori"
|
|
128
|
+
(click)="clearValues()"
|
|
129
|
+
/>
|
|
130
|
+
|
|
131
|
+
<!-- Formatta JSON -->
|
|
132
|
+
<ui-button
|
|
133
|
+
icon="align-left"
|
|
134
|
+
variant="ghost"
|
|
135
|
+
size="xs"
|
|
136
|
+
tooltip="Formatta JSON"
|
|
137
|
+
ariaLabel="Formatta JSON"
|
|
138
|
+
(click)="formatJson()"
|
|
139
|
+
/>
|
|
140
|
+
|
|
141
|
+
<!-- Freccia toggle apertura/chiusura -->
|
|
142
|
+
<ui-button
|
|
143
|
+
[icon]="isOpen ? 'chevron-down' : 'chevron-up'"
|
|
144
|
+
variant="ghost"
|
|
145
|
+
size="xs"
|
|
146
|
+
tooltip="Chiudi pannello"
|
|
147
|
+
ariaLabel="Chiudi pannello"
|
|
148
|
+
(click)="toggle.emit()"
|
|
149
|
+
/>
|
|
150
|
+
</div>
|
|
151
|
+
</div>
|
|
152
|
+
|
|
153
|
+
<!-- Corpo del pannello (visibile solo quando aperto) -->
|
|
154
|
+
@if (isOpen) {
|
|
155
|
+
<div class="form-values-panel__body">
|
|
156
|
+
<mat-form-field appearance="outline" class="form-values-panel__textarea-wrapper">
|
|
157
|
+
<mat-label>JSON</mat-label>
|
|
158
|
+
<textarea
|
|
159
|
+
matInput
|
|
160
|
+
class="form-values-panel__textarea"
|
|
161
|
+
[ngModel]="jsonText"
|
|
162
|
+
(ngModelChange)="onJsonInput($event)"
|
|
163
|
+
rows="8"
|
|
164
|
+
spellcheck="false"
|
|
165
|
+
placeholder='{ "chiave": "valore" }'
|
|
166
|
+
></textarea>
|
|
167
|
+
</mat-form-field>
|
|
168
|
+
|
|
169
|
+
<!-- Indicatore di errore di parsing -->
|
|
170
|
+
@if (jsonError) {
|
|
171
|
+
<div class="form-values-panel__error">
|
|
172
|
+
<lucide-icon name="alert-triangle" [size]="14" aria-hidden="true" />
|
|
173
|
+
<span>{{ jsonError }}</span>
|
|
174
|
+
</div>
|
|
175
|
+
}
|
|
176
|
+
</div>
|
|
177
|
+
}
|
|
178
|
+
</div>
|
|
179
|
+
`, isInline: true, styles: [".form-values-panel{border-top:1px solid var(--ui-color-border, #e0e0e0);background:var(--ui-color-surface, #fff);transition:max-height .2s ease-in-out;overflow:hidden}.form-values-panel__header{display:flex;align-items:center;justify-content:space-between;padding:var(--ui-spacing-2, 8px) var(--ui-spacing-3, 12px);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .15s}.form-values-panel__header:hover{background:var(--ui-color-bg-subtle, #fafafa)}.form-values-panel__header-left{display:flex;align-items:center;gap:var(--ui-spacing-2, 8px)}.form-values-panel__title{font-weight:600;font-size:var(--ui-font-size-xs, .75rem);color:var(--ui-color-text-secondary, #616161);text-transform:uppercase;letter-spacing:.5px}.form-values-panel__header-actions{display:flex;align-items:center;gap:var(--ui-spacing-1, 4px)}.form-values-panel__body{padding:0 var(--ui-spacing-3, 12px) var(--ui-spacing-3, 12px)}.form-values-panel__textarea-wrapper{width:100%}.form-values-panel__textarea{font-family:Fira Code,Consolas,Monaco,monospace;font-size:var(--ui-font-size-xs, .75rem);line-height:1.5;resize:vertical}.form-values-panel__error{display:flex;align-items:center;gap:var(--ui-spacing-1, 4px);padding:var(--ui-spacing-1, 4px) var(--ui-spacing-2, 8px);margin-top:var(--ui-spacing-1, 4px);border-radius:var(--ui-radius-sm, 4px);background:color-mix(in srgb,var(--ui-color-warn, #f44336) 10%,transparent);color:var(--ui-color-warn, #f44336);font-size:var(--ui-font-size-xs, .75rem)}\n"], dependencies: [{ kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: MatFormFieldModule }, { kind: "component", type: i2.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i2.MatLabel, selector: "mat-label" }, { kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i3.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "ngmodule", type: LucideAngularModule }, { kind: "component", type: i4.LucideAngularComponent, selector: "lucide-angular, lucide-icon, i-lucide, span-lucide", inputs: ["class", "name", "img", "color", "absoluteStrokeWidth", "size", "strokeWidth"] }, { kind: "component", type: UiButtonComponent, selector: "ui-button", inputs: ["label", "tooltip", "variant", "size", "icon", "iconPosition", "loading", "disabled", "fullWidth", "type", "ariaLabel", "customClass"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
180
|
+
}
|
|
181
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: UiEditorFormValuesPanelComponent, decorators: [{
|
|
182
|
+
type: Component,
|
|
183
|
+
args: [{ selector: 'ui-editor-form-values-panel', standalone: true, imports: [FormsModule, MatFormFieldModule, MatInputModule, LucideAngularModule, UiButtonComponent], changeDetection: ChangeDetectionStrategy.OnPush, template: `
|
|
184
|
+
<div
|
|
185
|
+
class="form-values-panel"
|
|
186
|
+
[class.form-values-panel--open]="isOpen"
|
|
187
|
+
>
|
|
188
|
+
<!-- Intestazione con toggle e azioni -->
|
|
189
|
+
<div class="form-values-panel__header" (click)="toggle.emit()">
|
|
190
|
+
<div class="form-values-panel__header-left">
|
|
191
|
+
<lucide-icon name="code" [size]="16" aria-hidden="true" />
|
|
192
|
+
<span class="form-values-panel__title">Valori Form</span>
|
|
193
|
+
</div>
|
|
194
|
+
|
|
195
|
+
<div class="form-values-panel__header-actions" (click)="$event.stopPropagation()">
|
|
196
|
+
<!-- Aggiorna valori -->
|
|
197
|
+
<ui-button
|
|
198
|
+
icon="refresh-cw"
|
|
199
|
+
variant="ghost"
|
|
200
|
+
size="xs"
|
|
201
|
+
tooltip="Aggiorna valori"
|
|
202
|
+
ariaLabel="Aggiorna valori"
|
|
203
|
+
(click)="refreshValues.emit()"
|
|
204
|
+
/>
|
|
205
|
+
|
|
206
|
+
<!-- Pulisci valori -->
|
|
207
|
+
<ui-button
|
|
208
|
+
icon="trash-2"
|
|
209
|
+
variant="ghost"
|
|
210
|
+
size="xs"
|
|
211
|
+
tooltip="Pulisci valori"
|
|
212
|
+
ariaLabel="Pulisci valori"
|
|
213
|
+
(click)="clearValues()"
|
|
214
|
+
/>
|
|
215
|
+
|
|
216
|
+
<!-- Formatta JSON -->
|
|
217
|
+
<ui-button
|
|
218
|
+
icon="align-left"
|
|
219
|
+
variant="ghost"
|
|
220
|
+
size="xs"
|
|
221
|
+
tooltip="Formatta JSON"
|
|
222
|
+
ariaLabel="Formatta JSON"
|
|
223
|
+
(click)="formatJson()"
|
|
224
|
+
/>
|
|
225
|
+
|
|
226
|
+
<!-- Freccia toggle apertura/chiusura -->
|
|
227
|
+
<ui-button
|
|
228
|
+
[icon]="isOpen ? 'chevron-down' : 'chevron-up'"
|
|
229
|
+
variant="ghost"
|
|
230
|
+
size="xs"
|
|
231
|
+
tooltip="Chiudi pannello"
|
|
232
|
+
ariaLabel="Chiudi pannello"
|
|
233
|
+
(click)="toggle.emit()"
|
|
234
|
+
/>
|
|
235
|
+
</div>
|
|
236
|
+
</div>
|
|
237
|
+
|
|
238
|
+
<!-- Corpo del pannello (visibile solo quando aperto) -->
|
|
239
|
+
@if (isOpen) {
|
|
240
|
+
<div class="form-values-panel__body">
|
|
241
|
+
<mat-form-field appearance="outline" class="form-values-panel__textarea-wrapper">
|
|
242
|
+
<mat-label>JSON</mat-label>
|
|
243
|
+
<textarea
|
|
244
|
+
matInput
|
|
245
|
+
class="form-values-panel__textarea"
|
|
246
|
+
[ngModel]="jsonText"
|
|
247
|
+
(ngModelChange)="onJsonInput($event)"
|
|
248
|
+
rows="8"
|
|
249
|
+
spellcheck="false"
|
|
250
|
+
placeholder='{ "chiave": "valore" }'
|
|
251
|
+
></textarea>
|
|
252
|
+
</mat-form-field>
|
|
253
|
+
|
|
254
|
+
<!-- Indicatore di errore di parsing -->
|
|
255
|
+
@if (jsonError) {
|
|
256
|
+
<div class="form-values-panel__error">
|
|
257
|
+
<lucide-icon name="alert-triangle" [size]="14" aria-hidden="true" />
|
|
258
|
+
<span>{{ jsonError }}</span>
|
|
259
|
+
</div>
|
|
260
|
+
}
|
|
261
|
+
</div>
|
|
262
|
+
}
|
|
263
|
+
</div>
|
|
264
|
+
`, styles: [".form-values-panel{border-top:1px solid var(--ui-color-border, #e0e0e0);background:var(--ui-color-surface, #fff);transition:max-height .2s ease-in-out;overflow:hidden}.form-values-panel__header{display:flex;align-items:center;justify-content:space-between;padding:var(--ui-spacing-2, 8px) var(--ui-spacing-3, 12px);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .15s}.form-values-panel__header:hover{background:var(--ui-color-bg-subtle, #fafafa)}.form-values-panel__header-left{display:flex;align-items:center;gap:var(--ui-spacing-2, 8px)}.form-values-panel__title{font-weight:600;font-size:var(--ui-font-size-xs, .75rem);color:var(--ui-color-text-secondary, #616161);text-transform:uppercase;letter-spacing:.5px}.form-values-panel__header-actions{display:flex;align-items:center;gap:var(--ui-spacing-1, 4px)}.form-values-panel__body{padding:0 var(--ui-spacing-3, 12px) var(--ui-spacing-3, 12px)}.form-values-panel__textarea-wrapper{width:100%}.form-values-panel__textarea{font-family:Fira Code,Consolas,Monaco,monospace;font-size:var(--ui-font-size-xs, .75rem);line-height:1.5;resize:vertical}.form-values-panel__error{display:flex;align-items:center;gap:var(--ui-spacing-1, 4px);padding:var(--ui-spacing-1, 4px) var(--ui-spacing-2, 8px);margin-top:var(--ui-spacing-1, 4px);border-radius:var(--ui-radius-sm, 4px);background:color-mix(in srgb,var(--ui-color-warn, #f44336) 10%,transparent);color:var(--ui-color-warn, #f44336);font-size:var(--ui-font-size-xs, .75rem)}\n"] }]
|
|
265
|
+
}], propDecorators: { formValues: [{
|
|
266
|
+
type: Input
|
|
267
|
+
}], isOpen: [{
|
|
268
|
+
type: Input
|
|
269
|
+
}], valuesChange: [{
|
|
270
|
+
type: Output
|
|
271
|
+
}], refreshValues: [{
|
|
272
|
+
type: Output
|
|
273
|
+
}], toggle: [{
|
|
274
|
+
type: Output
|
|
275
|
+
}] } });
|
|
276
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS12YWx1ZXMtcGFuZWwuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvbmctdWktc3lzdGVtL3NyYy9saWIvY29tcG9uZW50cy9mb3JtLWJ1aWxkZXItZWRpdG9yL3N1Yi1jb21wb25lbnRzL2Zvcm0tdmFsdWVzLXBhbmVsL2Zvcm0tdmFsdWVzLXBhbmVsLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLHVCQUF1QixFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsWUFBWSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2hHLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUM3QyxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQztBQUNsRSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDekQsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDckQsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sdUJBQXVCLENBQUM7Ozs7OztBQUUxRDs7Ozs7Ozs7R0FRRztBQXNLSCxNQUFNLE9BQU8sZ0NBQWdDO0lBcks3QztRQWdMRSwrQ0FBK0M7UUFDdEMsV0FBTSxHQUFHLEtBQUssQ0FBQztRQUV4QixzRUFBc0U7UUFDNUQsaUJBQVksR0FBRyxJQUFJLFlBQVksRUFBTyxDQUFDO1FBRWpELHlEQUF5RDtRQUMvQyxrQkFBYSxHQUFHLElBQUksWUFBWSxFQUFRLENBQUM7UUFFbkQsK0RBQStEO1FBQ3JELFdBQU0sR0FBRyxJQUFJLFlBQVksRUFBUSxDQUFDO1FBRTVDLDhDQUE4QztRQUM5QyxhQUFRLEdBQUcsSUFBSSxDQUFDO1FBRWhCLCtDQUErQztRQUMvQyxjQUFTLEdBQWtCLElBQUksQ0FBQztRQUVoQyx5Q0FBeUM7UUFDakMsZ0JB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TSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIElucHV0LCBPdXRwdXQsIEV2ZW50RW1pdHRlciB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcclxuaW1wb3J0IHsgTWF0Rm9ybUZpZWxkTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvZm9ybS1maWVsZCc7XHJcbmltcG9ydCB7IE1hdElucHV0TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaW5wdXQnO1xyXG5pbXBvcnQgeyBMdWNpZGVBbmd1bGFyTW9kdWxlIH0gZnJvbSAnbHVjaWRlLWFuZ3VsYXInO1xyXG5pbXBvcnQgeyBVaUJ1dHRvbkNvbXBvbmVudCB9IGZyb20gJy4uLy4uLy4uL2J1dHRvbi9pbmRleCc7XHJcblxyXG4vKipcclxuICogUGFubmVsbG8gb3ZlcmxheSBpbiBiYXNzbyBuZWxsJ2FudGVwcmltYSBjaGUgbW9zdHJhIGkgdmFsb3JpIGNvcnJlbnRpXHJcbiAqIGRlbCBmb3JtIGluIGZvcm1hdG8gSlNPTiBtb2RpZmljYWJpbGUuXHJcbiAqXHJcbiAqIFBlcm1ldHRlIGRpIHZpc3VhbGl6emFyZSwgbW9kaWZpY2FyZSwgZm9ybWF0dGFyZSBlIHJlc2V0dGFyZSBpIHZhbG9yaVxyXG4gKiBkZWwgZm9ybSBkdXJhbnRlIGxhIGZhc2UgZGkgYW50ZXByaW1hIG5lbGwnZWRpdG9yLlxyXG4gKlxyXG4gKiBAc2VsZWN0b3IgdWktZWRpdG9yLWZvcm0tdmFsdWVzLXBhbmVsXHJcbiAqL1xyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ3VpLWVkaXRvci1mb3JtLXZhbHVlcy1wYW5lbCcsXHJcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcclxuICBpbXBvcnRzOiBbRm9ybXNNb2R1bGUsIE1hdEZvcm1GaWVsZE1vZHVsZSwgTWF0SW5wdXRNb2R1bGUsIEx1Y2lkZUFuZ3VsYXJNb2R1bGUsIFVpQnV0dG9uQ29tcG9uZW50XSxcclxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcclxuICB0ZW1wbGF0ZTogYFxyXG4gICAgPGRpdlxyXG4gICAgICBjbGFzcz1cImZvcm0tdmFsdWVzLXBhbmVsXCJcclxuICAgICAgW2NsYXNzLmZvcm0tdmFsdWVzLXBhbmVsLS1vcGVuXT1cImlzT3BlblwiXHJcbiAgICA+XHJcbiAgICAgIDwhLS0gSW50ZXN0YXppb25lIGNvbiB0b2dnbGUgZSBhemlvbmkgLS0+XHJcbiAgICAgIDxkaXYgY2xhc3M9XCJmb3JtLXZhbHVlcy1wYW5lbF9faGVhZGVyXCIgKGNsaWNrKT1cInRvZ2dsZS5lbWl0KClcIj5cclxuICAgICAgICA8ZGl2IGNsYXNzPVwiZm9ybS12YWx1ZXMtcGFuZWxfX2hlYWRlci1sZWZ0XCI+XHJcbiAgICAgICAgICA8bHVjaWRlLWljb24gbmFtZT1cImNvZGVcIiBbc2l6ZV09XCIxNlwiIGFyaWEtaGlkZGVuPVwidHJ1ZVwiIC8+XHJcbiAgICAgICAgICA8c3BhbiBjbGFzcz1cImZvcm0tdmFsdWVzLXBhbmVsX190aXRsZVwiPlZhbG9yaSBGb3JtPC9zcGFuPlxyXG4gICAgICAgIDwvZGl2PlxyXG5cclxuICAgICAgICA8ZGl2IGNsYXNzPVwiZm9ybS12YWx1ZXMtcGFuZWxfX2hlYWRlci1hY3Rpb25zXCIgKGNsaWNrKT1cIiRldmVudC5zdG9wUHJvcGFnYXRpb24oKVwiPlxyXG4gICAgICAgICAgPCEtLSBBZ2dpb3JuYSB2YWxvcmkgLS0+XHJcbiAgICAgICAgICA8dWktYnV0dG9uXHJcbiAgICAgICAgICAgIGljb249XCJyZWZyZXNoLWN3XCJcclxuICAgICAgICAgICAgdmFyaWFudD1cImdob3N0XCJcclxuICAgICAgICAgICAgc2l6ZT1cInhzXCJcclxuICAgICAgICAgICAgdG9vbHRpcD1cIkFnZ2lvcm5hIHZhbG9yaVwiXHJcbiAgICAgICAgICAgIGFyaWFMYWJlbD1cIkFnZ2lvcm5hIHZhbG9yaVwiXHJcbiAgICAgICAgICAgIChjbGljayk9XCJyZWZyZXNoVmFsdWVzLmVtaXQoKVwiXHJcbiAgICAgICAgICAvPlxyXG5cclxuICAgICAgICAgIDwhLS0gUHVsaXNjaSB2YWxvcmkgLS0+XHJcbiAgICAgICAgICA8dWktYnV0dG9uXHJcbiAgICAgICAgICAgIGljb249XCJ0cmFzaC0yXCJcclxuICAgICAgICAgICAgdmFyaWFudD1cImdob3N0XCJcclxuICAgICAgICAgICAgc2l6ZT1cInhzXCJcclxuICAgICAgICAgICAgdG9vbHRpcD1cIlB1bGlzY2kgdmFsb3JpXCJcclxuICAgICAgICAgICAgYXJpYUxhYmVsPVwiUHVsaXNjaSB2YWxvcmlcIlxyXG4gICAgICAgICAgICAoY2xpY2spPVwiY2xlYXJWYWx1ZXMoKVwiXHJcbiAgICAgICAgICAvPlxyXG5cclxuICAgICAgICAgIDwhLS0gRm9ybWF0dGEgSlNPTiAtLT5cclxuICAgICAgICAgIDx1aS1idXR0b25cclxuICAgICAgICAgICAgaWNvbj1cImFsaWduLWxlZnRcIlxyXG4gICAgICAgICAgICB2YXJpYW50PVwiZ2hvc3RcIlxyXG4gICAgICAgICAgICBzaXplPVwieHNcIlxyXG4gICAgICAgICAgICB0b29sdGlwPVwiRm9ybWF0dGEgSlNPTlwiXHJcbiAgICAgICAgICAgIGFyaWFMYWJlbD1cIkZvcm1hdHRhIEpTT05cIlxyXG4gICAgICAgICAgICAoY2xpY2spPVwiZm9ybWF0SnNvbigpXCJcclxuICAgICAgICAgIC8+XHJcblxyXG4gICAgICAgICAgPCEtLSBGcmVjY2lhIHRvZ2dsZSBhcGVydHVyYS9jaGl1c3VyYSAtLT5cclxuICAgICAgICAgIDx1aS1idXR0b25cclxuICAgICAgICAgICAgW2ljb25dPVwiaXNPcGVuID8gJ2NoZXZyb24tZG93bicgOiAnY2hldnJvbi11cCdcIlxyXG4gICAgICAgICAgICB2YXJpYW50PVwiZ2hvc3RcIlxyXG4gICAgICAgICAgICBzaXplPVwieHNcIlxyXG4gICAgICAgICAgICB0b29sdGlwPVwiQ2hpdWRpIHBhbm5lbGxvXCJcclxuICAgICAgICAgICAgYXJpYUxhYmVsPVwiQ2hpdWRpIHBhbm5lbGxvXCJcclxuICAgICAgICAgICAgKGNsaWNrKT1cInRvZ2dsZS5lbWl0KClcIlxyXG4gICAgICAgICAgLz5cclxuICAgICAgICA8L2Rpdj5cclxuICAgICAgPC9kaXY+XHJcblxyXG4gICAgICA8IS0tIENvcnBvIGRlbCBwYW5uZWxsbyAodmlzaWJpbGUgc29sbyBxdWFuZG8gYXBlcnRvKSAtLT5cclxuICAgICAgQGlmIChpc09wZW4pIHtcclxuICAgICAgICA8ZGl2IGNsYXNzPVwiZm9ybS12YWx1ZXMtcGFuZWxfX2JvZHlcIj5cclxuICAgICAgICAgIDxtYXQtZm9ybS1maWVsZCBhcHBlYXJhbmNlPVwib3V0bGluZVwiIGNsYXNzPVwiZm9ybS12YWx1ZXMtcGFuZWxfX3RleHRhcmVhLXdyYXBwZXJcIj5cclxuICAgICAgICAgICAgPG1hdC1sYWJlbD5KU09OPC9tYXQtbGFiZWw+XHJcbiAgICAgICAgICAgIDx0ZXh0YXJlYVxyXG4gICAgICAgICAgICAgIG1hdElucHV0XHJcbiAgICAgICAgICAgICAgY2xhc3M9XCJmb3JtLXZhbHVlcy1wYW5lbF9fdGV4dGFyZWFcIlxyXG4gICAgICAgICAgICAgIFtuZ01vZGVsXT1cImpzb25UZXh0XCJcclxuICAgICAgICAgICAgICAobmdNb2RlbENoYW5nZSk9XCJvbkpzb25JbnB1dCgkZXZlbnQpXCJcclxuICAgICAgICAgICAgICByb3dzPVwiOFwiXHJcbiAgICAgICAgICAgICAgc3BlbGxjaGVjaz1cImZhbHNlXCJcclxuICAgICAgICAgICAgICBwbGFjZWhvbGRlcj0neyBcImNoaWF2ZVwiOiBcInZhbG9yZVwiIH0nXHJcbiAgICAgICAgICAgID48L3RleHRhcmVhPlxyXG4gICAgICAgICAgPC9tYXQtZm9ybS1maWVsZD5cclxuXHJcbiAgICAgICAgICA8IS0tIEluZGljYXRvcmUgZGkgZXJyb3JlIGRpIHBhcnNpbmcgLS0+XHJcbiAgICAgICAgICBAaWYgKGpzb25FcnJvcikge1xyXG4gICAgICAgICAgICA8ZGl2IGNsYXNzPVwiZm9ybS12YWx1ZXMtcGFuZWxfX2Vycm9yXCI+XHJcbiAgICAgICAgICAgICAgPGx1Y2lkZS1pY29uIG5hbWU9XCJhbGVydC10cmlhbmdsZVwiIFtzaXplXT1cIjE0XCIgYXJpYS1oaWRkZW49XCJ0cnVlXCIgLz5cclxuICAgICAgICAgICAgICA8c3Bhbj57eyBqc29uRXJyb3IgfX08L3NwYW4+XHJcbiAgICAgICAgICAgIDwvZGl2PlxyXG4gICAgICAgICAgfVxyXG4gICAgICAgIDwvZGl2PlxyXG4gICAgICB9XHJcbiAgICA8L2Rpdj5cclxuICBgLFxyXG4gIHN0eWxlczogW1xyXG4gICAgYFxyXG4gICAgLyogQ29udGVuaXRvcmUgcHJpbmNpcGFsZSBkZWwgcGFubmVsbG8gdmFsb3JpICovXHJcbiAgICAuZm9ybS12YWx1ZXMtcGFuZWwge1xyXG4gICAgICBib3JkZXItdG9wOiAxcHggc29saWQgdmFyKC0tdWktY29sb3ItYm9yZGVyLCAjZTBlMGUwKTtcclxuICAgICAgYmFja2dyb3VuZDogdmFyKC0tdWktY29sb3Itc3VyZmFjZSwgI2ZmZik7XHJcbiAgICAgIHRyYW5zaXRpb246IG1heC1oZWlnaHQgMjAwbXMgZWFzZS1pbi1vdXQ7XHJcbiAgICAgIG92ZXJmbG93OiBoaWRkZW47XHJcbiAgICB9XHJcblxyXG4gICAgLyogSW50ZXN0YXppb25lIGNsaWNjYWJpbGUgcGVyIHRvZ2dsZSAqL1xyXG4gICAgLmZvcm0tdmFsdWVzLXBhbmVsX19oZWFkZXIge1xyXG4gICAgICBkaXNwbGF5OiBmbGV4O1xyXG4gICAgICBhbGlnbi1pdGVtczogY2VudGVyO1xyXG4gICAgICBqdXN0aWZ5LWNvbnRlbnQ6IHNwYWNlLWJldHdlZW47XHJcbiAgICAgIHBhZGRpbmc6IHZhcigtLXVpLXNwYWNpbmctMiwgOHB4KSB2YXIoLS11aS1zcGFjaW5nLTMsIDEycHgpO1xyXG4gICAgICBjdXJzb3I6IHBvaW50ZXI7XHJcbiAgICAgIHVzZXItc2VsZWN0OiBub25lO1xyXG4gICAgICB0cmFuc2l0aW9uOiBiYWNrZ3JvdW5kLWNvbG9yIDE1MG1zO1xyXG4gICAgfVxyXG5cclxuICAgIC5mb3JtLXZhbHVlcy1wYW5lbF9faGVhZGVyOmhvdmVyIHtcclxuICAgICAgYmFja2dyb3VuZDogdmFyKC0tdWktY29sb3ItYmctc3VidGxlLCAjZmFmYWZhKTtcclxuICAgIH1cclxuXHJcbiAgICAuZm9ybS12YWx1ZXMtcGFuZWxfX2hlYWRlci1sZWZ0IHtcclxuICAgICAgZGlzcGxheTogZmxleDtcclxuICAgICAgYWxpZ24taXRlbXM6IGNlbnRlcjtcclxuICAgICAgZ2FwOiB2YXIoLS11aS1zcGFjaW5nLTIsIDhweCk7XHJcbiAgICB9XHJcblxyXG4gICAgLmZvcm0tdmFsdWVzLXBhbmVsX190aXRsZSB7XHJcbiAgICAgIGZvbnQtd2VpZ2h0OiA2MDA7XHJcbiAgICAgIGZvbnQtc2l6ZTogdmFyKC0tdWktZm9udC1zaXplLXhzLCAwLjc1cmVtKTtcclxuICAgICAgY29sb3I6IHZhcigtLXVpLWNvbG9yLXRleHQtc2Vjb25kYXJ5LCAjNjE2MTYxKTtcclxuICAgICAgdGV4dC10cmFuc2Zvcm06IHVwcGVyY2FzZTtcclxuICAgICAgbGV0dGVyLXNwYWNpbmc6IDAuNXB4O1xyXG4gICAgfVxyXG5cclxuICAgIC5mb3JtLXZhbHVlcy1wYW5lbF9faGVhZGVyLWFjdGlvbnMge1xyXG4gICAgICBkaXNwbGF5OiBmbGV4O1xyXG4gICAgICBhbGlnbi1pdGVtczogY2VudGVyO1xyXG4gICAgICBnYXA6IHZhcigtLXVpLXNwYWNpbmctMSwgNHB4KTtcclxuICAgIH1cclxuXHJcbiAgICAvKiBDb3JwbyBkZWwgcGFubmVsbG8gY29uIHRleHRhcmVhICovXHJcbiAgICAuZm9ybS12YWx1ZXMtcGFuZWxfX2JvZHkge1xyXG4gICAgICBwYWRkaW5nOiAwIHZhcigtLXVpLXNwYWNpbmctMywgMTJweCkgdmFyKC0tdWktc3BhY2luZy0zLCAxMnB4KTtcclxuICAgIH1cclxuXHJcbiAgICAvKiBXcmFwcGVyIGRlbGxhIHRleHRhcmVhICovXHJcbiAgICAuZm9ybS12YWx1ZXMtcGFuZWxfX3RleHRhcmVhLXdyYXBwZXIge1xyXG4gICAgICB3aWR0aDogMTAwJTtcclxuICAgIH1cclxuXHJcbiAgICAvKiBUZXh0YXJlYSBwZXIgaWwgSlNPTiAqL1xyXG4gICAgLmZvcm0tdmFsdWVzLXBhbmVsX190ZXh0YXJlYSB7XHJcbiAgICAgIGZvbnQtZmFtaWx5OiAnRmlyYSBDb2RlJywgJ0NvbnNvbGFzJywgJ01vbmFjbycsIG1vbm9zcGFjZTtcclxuICAgICAgZm9udC1zaXplOiB2YXIoLS11aS1mb250LXNpemUteHMsIDAuNzVyZW0pO1xyXG4gICAgICBsaW5lLWhlaWdodDogMS41O1xyXG4gICAgICByZXNpemU6IHZlcnRpY2FsO1xyXG4gICAgfVxyXG5cclxuICAgIC8qIE1lc3NhZ2dpbyBkaSBlcnJvcmUgSlNPTiAqL1xyXG4gICAgLmZvcm0tdmFsdWVzLXBhbmVsX19lcnJvciB7XHJcbiAgICAgIGRpc3BsYXk6IGZsZXg7XHJcbiAgICAgIGFsaWduLWl0ZW1zOiBjZW50ZXI7XHJcbiAgICAgIGdhcDogdmFyKC0tdWktc3BhY2luZy0xLCA0cHgpO1xyXG4gICAgICBwYWRkaW5nOiB2YXIoLS11aS1zcGFjaW5nLTEsIDRweCkgdmFyKC0tdWktc3BhY2luZy0yLCA4cHgpO1xyXG4gICAgICBtYXJnaW4tdG9wOiB2YXIoLS11aS1zcGFjaW5nLTEsIDRweCk7XHJcbiAgICAgIGJvcmRlci1yYWRpdXM6IHZhcigtLXVpLXJhZGl1cy1zbSwgNHB4KTtcclxuICAgICAgYmFja2dyb3VuZDogY29sb3ItbWl4KGluIHNyZ2IsIHZhcigtLXVpLWNvbG9yLXdhcm4sICNmNDQzMzYpIDEwJSwgdHJhbnNwYXJlbnQpO1xyXG4gICAgICBjb2xvcjogdmFyKC0tdWktY29sb3Itd2FybiwgI2Y0NDMzNik7XHJcbiAgICAgIGZvbnQtc2l6ZTogdmFyKC0tdWktZm9udC1zaXplLXhzLCAwLjc1cmVtKTtcclxuICAgIH1cclxuICBgLFxyXG4gIF0sXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBVaUVkaXRvckZvcm1WYWx1ZXNQYW5lbENvbXBvbmVudCB7XHJcbiAgLyoqIFZhbG9yaSBjb3JyZW50aSBkZWwgZm9ybSBkYSB2aXN1YWxpenphcmUuICovXHJcbiAgQElucHV0KClcclxuICBzZXQgZm9ybVZhbHVlcyh2YWx1ZTogYW55KSB7XHJcbiAgICB0aGlzLl9mb3JtVmFsdWVzID0gdmFsdWU7XHJcbiAgICB0aGlzLnVwZGF0ZUpzb25UZXh0KCk7XHJcbiAgfVxyXG4gIGdldCBmb3JtVmFsdWVzKCk6IGFueSB7XHJcbiAgICByZXR1cm4gdGhpcy5fZm9ybVZhbHVlcztcclxuICB9XHJcblxyXG4gIC8qKiBTdGF0byBkaSBhcGVydHVyYS9jaGl1c3VyYSBkZWwgcGFubmVsbG8uICovXHJcbiAgQElucHV0KCkgaXNPcGVuID0gZmFsc2U7XHJcblxyXG4gIC8qKiBFbWVzc28gcXVhbmRvIGkgdmFsb3JpIHZlbmdvbm8gbW9kaWZpY2F0aSBkYWxsJ3V0ZW50ZSB2aWEgSlNPTi4gKi9cclxuICBAT3V0cHV0KCkgdmFsdWVzQ2hhbmdlID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XHJcblxyXG4gIC8qKiBFbWVzc28gYWxsYSByaWNoaWVzdGEgZGkgYWdnaW9ybmFtZW50byBkZWkgdmFsb3JpLiAqL1xyXG4gIEBPdXRwdXQoKSByZWZyZXNoVmFsdWVzID0gbmV3IEV2ZW50RW1pdHRlcjx2b2lkPigpO1xyXG5cclxuICAvKiogRW1lc3NvIGFsbGEgcmljaGllc3RhIGRpIGFwZXJ0dXJhL2NoaXVzdXJhIGRlbCBwYW5uZWxsby4gKi9cclxuICBAT3V0cHV0KCkgdG9nZ2xlID0gbmV3IEV2ZW50RW1pdHRlcjx2b2lkPigpO1xyXG5cclxuICAvKiogVGVzdG8gSlNPTiB2aXN1YWxpenphdG8gbmVsbGEgdGV4dGFyZWEuICovXHJcbiAganNvblRleHQgPSAne30nO1xyXG5cclxuICAvKiogTWVzc2FnZ2lvIGRpIGVycm9yZSBwZXIgSlNPTiBub24gdmFsaWRvLiAqL1xyXG4gIGpzb25FcnJvcjogc3RyaW5nIHwgbnVsbCA9IG51bGw7XHJcblxyXG4gIC8qKiBAaW50ZXJuYWwgVmFsb3JpIGludGVybmkgZGVsIGZvcm0uICovXHJcbiAgcHJpdmF0ZSBfZm9ybVZhbHVlczogYW55ID0ge307XHJcblxyXG4gIC8qKlxyXG4gICAqIEdlc3Rpc2NlIGwnaW5wdXQgZGVsbCd1dGVudGUgbmVsbGEgdGV4dGFyZWEgSlNPTi5cclxuICAgKiBQcm92YSBhIHBhcnNhcmUgaWwgSlNPTiBlIGFnZ2lvcm5hIGkgdmFsb3JpIHNlIHZhbGlkby5cclxuICAgKiBAcGFyYW0gdGV4dCAtIFRlc3RvIEpTT04gaW5zZXJpdG8gZGFsbCd1dGVudGVcclxuICAgKi9cclxuICBvbkpzb25JbnB1dCh0ZXh0OiBzdHJpbmcpOiB2b2lkIHtcclxuICAgIHRoaXMuanNvblRleHQgPSB0ZXh0O1xyXG4gICAgdHJ5IHtcclxuICAgICAgY29uc3QgcGFyc2VkID0gSlNPTi5wYXJzZSh0ZXh0KTtcclxuICAgICAgdGhpcy5qc29uRXJyb3IgPSBudWxsO1xyXG4gICAgICB0aGlzLnZhbHVlc0NoYW5nZS5lbWl0KHBhcnNlZCk7XHJcbiAgICB9IGNhdGNoIChlKSB7XHJcbiAgICAgIHRoaXMuanNvbkVycm9yID0gJ0pTT04gbm9uIHZhbGlkbzogY29udHJvbGxhIGxhIHNpbnRhc3NpJztcclxuICAgIH1cclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIFB1bGlzY2UgaSB2YWxvcmkgZGVsIGZvcm0gcmVzZXR0YW5kbyBhIG9nZ2V0dG8gdnVvdG8uXHJcbiAgICovXHJcbiAgY2xlYXJWYWx1ZXMoKTogdm9pZCB7XHJcbiAgICB0aGlzLl9mb3JtVmFsdWVzID0ge307XHJcbiAgICB0aGlzLmpzb25UZXh0ID0gJ3t9JztcclxuICAgIHRoaXMuanNvbkVycm9yID0gbnVsbDtcclxuICAgIHRoaXMudmFsdWVzQ2hhbmdlLmVtaXQoe30pO1xyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogRm9ybWF0dGEgaWwgSlNPTiBjb24gaW5kZW50YXppb25lIHBlciB1bmEgbWlnbGlvcmUgbGVnZ2liaWxpdGEuXHJcbiAgICovXHJcbiAgZm9ybWF0SnNvbigpOiB2b2lkIHtcclxuICAgIHRyeSB7XHJcbiAgICAgIGNvbnN0IHBhcnNlZCA9IEpTT04ucGFyc2UodGhpcy5qc29uVGV4dCk7XHJcbiAgICAgIHRoaXMuanNvblRleHQgPSBKU09OLnN0cmluZ2lmeShwYXJzZWQsIG51bGwsIDIpO1xyXG4gICAgICB0aGlzLmpzb25FcnJvciA9IG51bGw7XHJcbiAgICB9IGNhdGNoIChlKSB7XHJcbiAgICAgIHRoaXMuanNvbkVycm9yID0gJ0ltcG9zc2liaWxlIGZvcm1hdHRhcmU6IEpTT04gbm9uIHZhbGlkbyc7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICAvKipcclxuICAgKiBAaW50ZXJuYWxcclxuICAgKiBBZ2dpb3JuYSBpbCB0ZXN0byBKU09OIGRhbGxhIHJhcHByZXNlbnRhemlvbmUgaW50ZXJuYSBkZWkgdmFsb3JpLlxyXG4gICAqL1xyXG4gIHByaXZhdGUgdXBkYXRlSnNvblRleHQoKTogdm9pZCB7XHJcbiAgICB0cnkge1xyXG4gICAgICB0aGlzLmpzb25UZXh0ID0gSlNPTi5zdHJpbmdpZnkodGhpcy5fZm9ybVZhbHVlcywgbnVsbCwgMik7XHJcbiAgICAgIHRoaXMuanNvbkVycm9yID0gbnVsbDtcclxuICAgIH0gY2F0Y2gge1xyXG4gICAgICB0aGlzLmpzb25UZXh0ID0gJ3t9JztcclxuICAgIH1cclxuICB9XHJcbn1cclxuIl19
|