@ng-formworks/material 18.5.1 → 19.5.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/assets/material-design-themes.scss +10 -5
- package/fesm2022/ng-formworks-material.mjs +94 -88
- package/fesm2022/ng-formworks-material.mjs.map +1 -1
- package/lib/widgets/public_api.d.ts +1 -1
- package/package.json +3 -5
- package/esm2022/lib/material-design-cssframework.mjs +0 -23
- package/esm2022/lib/material-design-framework.component.mjs +0 -119
- package/esm2022/lib/material-design-framework.module.mjs +0 -117
- package/esm2022/lib/material-design.framework.mjs +0 -62
- package/esm2022/lib/widgets/flex-layout-root.component.mjs +0 -71
- package/esm2022/lib/widgets/flex-layout-section.component.mjs +0 -344
- package/esm2022/lib/widgets/material-add-reference.component.mjs +0 -63
- package/esm2022/lib/widgets/material-button-group.component.mjs +0 -86
- package/esm2022/lib/widgets/material-button.component.mjs +0 -76
- package/esm2022/lib/widgets/material-checkbox.component.mjs +0 -164
- package/esm2022/lib/widgets/material-checkboxes.component.mjs +0 -126
- package/esm2022/lib/widgets/material-chip-list.component.mjs +0 -32
- package/esm2022/lib/widgets/material-datepicker.component.mjs +0 -133
- package/esm2022/lib/widgets/material-file.component.mjs +0 -32
- package/esm2022/lib/widgets/material-input.component.mjs +0 -146
- package/esm2022/lib/widgets/material-number.component.mjs +0 -137
- package/esm2022/lib/widgets/material-one-of.component.mjs +0 -32
- package/esm2022/lib/widgets/material-radios.component.mjs +0 -118
- package/esm2022/lib/widgets/material-select.component.mjs +0 -177
- package/esm2022/lib/widgets/material-slider.component.mjs +0 -88
- package/esm2022/lib/widgets/material-stepper.component.mjs +0 -32
- package/esm2022/lib/widgets/material-tabs.component.mjs +0 -91
- package/esm2022/lib/widgets/material-textarea.component.mjs +0 -126
- package/esm2022/lib/widgets/public_api.mjs +0 -52
- package/esm2022/ng-formworks-material.mjs +0 -5
- package/esm2022/public_api.mjs +0 -8
|
@@ -1,344 +0,0 @@
|
|
|
1
|
-
import { Component, inject, input } from '@angular/core';
|
|
2
|
-
import { JsonSchemaFormService } from '@ng-formworks/core';
|
|
3
|
-
import * as i0 from "@angular/core";
|
|
4
|
-
import * as i1 from "@angular/common";
|
|
5
|
-
import * as i2 from "@angular/material/card";
|
|
6
|
-
import * as i3 from "@angular/material/expansion";
|
|
7
|
-
import * as i4 from "@angular/material/form-field";
|
|
8
|
-
import * as i5 from "./flex-layout-root.component";
|
|
9
|
-
export class FlexLayoutSectionComponent {
|
|
10
|
-
constructor() {
|
|
11
|
-
this.jsf = inject(JsonSchemaFormService);
|
|
12
|
-
this.controlDisabled = false;
|
|
13
|
-
this.boundControl = false;
|
|
14
|
-
this.expanded = true;
|
|
15
|
-
this.containerType = 'div';
|
|
16
|
-
this.layoutNode = input(undefined);
|
|
17
|
-
this.layoutIndex = input(undefined);
|
|
18
|
-
this.dataIndex = input(undefined);
|
|
19
|
-
}
|
|
20
|
-
get sectionTitle() {
|
|
21
|
-
return this.options.notitle ? null : this.jsf.setItemTitle(this);
|
|
22
|
-
}
|
|
23
|
-
ngOnInit() {
|
|
24
|
-
this.jsf.initializeControl(this);
|
|
25
|
-
this.options = this.layoutNode().options || {};
|
|
26
|
-
this.expanded = typeof this.options.expanded === 'boolean' ?
|
|
27
|
-
this.options.expanded : !this.options.expandable;
|
|
28
|
-
switch (this.layoutNode().type) {
|
|
29
|
-
case 'section':
|
|
30
|
-
case 'array':
|
|
31
|
-
case 'fieldset':
|
|
32
|
-
case 'advancedfieldset':
|
|
33
|
-
case 'authfieldset':
|
|
34
|
-
case 'optionfieldset':
|
|
35
|
-
case 'selectfieldset':
|
|
36
|
-
this.containerType = 'fieldset';
|
|
37
|
-
break;
|
|
38
|
-
case 'card':
|
|
39
|
-
this.containerType = 'card';
|
|
40
|
-
break;
|
|
41
|
-
case 'expansion-panel':
|
|
42
|
-
this.containerType = 'expansion-panel';
|
|
43
|
-
break;
|
|
44
|
-
default: // 'div', 'flex', 'tab', 'conditional', 'actions'
|
|
45
|
-
this.containerType = 'div';
|
|
46
|
-
}
|
|
47
|
-
}
|
|
48
|
-
toggleExpanded() {
|
|
49
|
-
if (this.options.expandable) {
|
|
50
|
-
this.expanded = !this.expanded;
|
|
51
|
-
}
|
|
52
|
-
}
|
|
53
|
-
// Set attributes for flexbox container
|
|
54
|
-
// (child attributes are set in flex-layout-root.component)
|
|
55
|
-
getFlexAttribute(attribute) {
|
|
56
|
-
const flexActive = this.layoutNode().type === 'flex' ||
|
|
57
|
-
!!this.options.displayFlex ||
|
|
58
|
-
this.options.display === 'flex';
|
|
59
|
-
// if (attribute !== 'flex' && !flexActive) { return null; }
|
|
60
|
-
switch (attribute) {
|
|
61
|
-
case 'is-flex':
|
|
62
|
-
return flexActive;
|
|
63
|
-
case 'display':
|
|
64
|
-
return flexActive ? 'flex' : 'initial';
|
|
65
|
-
case 'flex-direction':
|
|
66
|
-
case 'flex-wrap':
|
|
67
|
-
const index = ['flex-direction', 'flex-wrap'].indexOf(attribute);
|
|
68
|
-
return (this.options['flex-flow'] || '').split(/\s+/)[index] ||
|
|
69
|
-
this.options[attribute] || ['column', 'nowrap'][index];
|
|
70
|
-
case 'justify-content':
|
|
71
|
-
case 'align-items':
|
|
72
|
-
case 'align-content':
|
|
73
|
-
return this.options[attribute];
|
|
74
|
-
case 'layout':
|
|
75
|
-
return (this.options.fxLayout || 'row') +
|
|
76
|
-
this.options.fxLayoutWrap ? ' ' + this.options.fxLayoutWrap : '';
|
|
77
|
-
}
|
|
78
|
-
}
|
|
79
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FlexLayoutSectionComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
80
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.13", type: FlexLayoutSectionComponent, selector: "flex-layout-section-widget", inputs: { layoutNode: { classPropertyName: "layoutNode", publicName: "layoutNode", isSignal: true, isRequired: false, transformFunction: null }, layoutIndex: { classPropertyName: "layoutIndex", publicName: "layoutIndex", isSignal: true, isRequired: false, transformFunction: null }, dataIndex: { classPropertyName: "dataIndex", publicName: "dataIndex", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: `
|
|
81
|
-
<div *ngIf="containerType === 'div'"
|
|
82
|
-
[class]="options?.htmlClass || ''"
|
|
83
|
-
[class.expandable]="options?.expandable && !expanded"
|
|
84
|
-
[class.expanded]="options?.expandable && expanded">
|
|
85
|
-
<label *ngIf="sectionTitle"
|
|
86
|
-
[class]="'legend ' + (options?.labelHtmlClass || '')"
|
|
87
|
-
[innerHTML]="sectionTitle"
|
|
88
|
-
(click)="toggleExpanded()"></label>
|
|
89
|
-
<flex-layout-root-widget *ngIf="expanded"
|
|
90
|
-
[layout]="layoutNode().items"
|
|
91
|
-
[dataIndex]="dataIndex()"
|
|
92
|
-
[layoutIndex]="layoutIndex()"
|
|
93
|
-
[isFlexItem]="getFlexAttribute('is-flex')"
|
|
94
|
-
[class.form-flex-column]="getFlexAttribute('flex-direction') === 'column'"
|
|
95
|
-
[class.form-flex-row]="getFlexAttribute('flex-direction') === 'row'"
|
|
96
|
-
[style.display]="getFlexAttribute('display')"
|
|
97
|
-
[style.flex-direction]="getFlexAttribute('flex-direction')"
|
|
98
|
-
[style.flex-wrap]="getFlexAttribute('flex-wrap')"
|
|
99
|
-
[style.justify-content]="getFlexAttribute('justify-content')"
|
|
100
|
-
[style.align-items]="getFlexAttribute('align-items')"
|
|
101
|
-
[style.align-content]="getFlexAttribute('align-content')"
|
|
102
|
-
[attr.fxLayout]="getFlexAttribute('layout')"
|
|
103
|
-
[attr.fxLayoutGap]="options?.fxLayoutGap"
|
|
104
|
-
[attr.fxLayoutAlign]="options?.fxLayoutAlign"
|
|
105
|
-
[attr.fxFlexFill]="options?.fxLayoutAlign"></flex-layout-root-widget>
|
|
106
|
-
<mat-error *ngIf="options?.showErrors && options?.errorMessage"
|
|
107
|
-
[innerHTML]="options?.errorMessage"></mat-error>
|
|
108
|
-
</div>
|
|
109
|
-
|
|
110
|
-
<fieldset *ngIf="containerType === 'fieldset'"
|
|
111
|
-
[class]="options?.htmlClass || ''"
|
|
112
|
-
[class.expandable]="options?.expandable && !expanded"
|
|
113
|
-
[class.expanded]="options?.expandable && expanded"
|
|
114
|
-
[disabled]="options?.readonly">
|
|
115
|
-
<legend *ngIf="sectionTitle"
|
|
116
|
-
[class]="'legend ' + (options?.labelHtmlClass || '')"
|
|
117
|
-
[innerHTML]="sectionTitle"
|
|
118
|
-
(click)="toggleExpanded()"></legend>
|
|
119
|
-
<flex-layout-root-widget *ngIf="expanded"
|
|
120
|
-
[layout]="layoutNode().items"
|
|
121
|
-
[dataIndex]="dataIndex()"
|
|
122
|
-
[layoutIndex]="layoutIndex()"
|
|
123
|
-
[isFlexItem]="getFlexAttribute('is-flex')"
|
|
124
|
-
[class.form-flex-column]="getFlexAttribute('flex-direction') === 'column'"
|
|
125
|
-
[class.form-flex-row]="getFlexAttribute('flex-direction') === 'row'"
|
|
126
|
-
[style.display]="getFlexAttribute('display')"
|
|
127
|
-
[style.flex-direction]="getFlexAttribute('flex-direction')"
|
|
128
|
-
[style.flex-wrap]="getFlexAttribute('flex-wrap')"
|
|
129
|
-
[style.justify-content]="getFlexAttribute('justify-content')"
|
|
130
|
-
[style.align-items]="getFlexAttribute('align-items')"
|
|
131
|
-
[style.align-content]="getFlexAttribute('align-content')"
|
|
132
|
-
[attr.fxLayout]="getFlexAttribute('layout')"
|
|
133
|
-
[attr.fxLayoutGap]="options?.fxLayoutGap"
|
|
134
|
-
[attr.fxLayoutAlign]="options?.fxLayoutAlign"
|
|
135
|
-
[attr.attr.fxFlexFill]="options?.fxLayoutAlign"></flex-layout-root-widget>
|
|
136
|
-
<mat-error *ngIf="options?.showErrors && options?.errorMessage"
|
|
137
|
-
[innerHTML]="options?.errorMessage"></mat-error>
|
|
138
|
-
</fieldset>
|
|
139
|
-
|
|
140
|
-
<mat-card appearance="outlined" *ngIf="containerType === 'card'"
|
|
141
|
-
[ngClass]="options?.htmlClass || ''"
|
|
142
|
-
[class.expandable]="options?.expandable && !expanded"
|
|
143
|
-
[class.expanded]="options?.expandable && expanded">
|
|
144
|
-
<mat-card-header *ngIf="sectionTitle">
|
|
145
|
-
<legend
|
|
146
|
-
[class]="'legend ' + (options?.labelHtmlClass || '')"
|
|
147
|
-
[innerHTML]="sectionTitle"
|
|
148
|
-
(click)="toggleExpanded()"></legend>
|
|
149
|
-
</mat-card-header>
|
|
150
|
-
<mat-card-content *ngIf="expanded">
|
|
151
|
-
<fieldset [disabled]="options?.readonly">
|
|
152
|
-
<flex-layout-root-widget *ngIf="expanded"
|
|
153
|
-
[layout]="layoutNode().items"
|
|
154
|
-
[dataIndex]="dataIndex()"
|
|
155
|
-
[layoutIndex]="layoutIndex()"
|
|
156
|
-
[isFlexItem]="getFlexAttribute('is-flex')"
|
|
157
|
-
[class.form-flex-column]="getFlexAttribute('flex-direction') === 'column'"
|
|
158
|
-
[class.form-flex-row]="getFlexAttribute('flex-direction') === 'row'"
|
|
159
|
-
[style.display]="getFlexAttribute('display')"
|
|
160
|
-
[style.flex-direction]="getFlexAttribute('flex-direction')"
|
|
161
|
-
[style.flex-wrap]="getFlexAttribute('flex-wrap')"
|
|
162
|
-
[style.justify-content]="getFlexAttribute('justify-content')"
|
|
163
|
-
[style.align-items]="getFlexAttribute('align-items')"
|
|
164
|
-
[style.align-content]="getFlexAttribute('align-content')"
|
|
165
|
-
[attr.fxLayout]="getFlexAttribute('layout')"
|
|
166
|
-
[attr.fxLayoutGap]="options?.fxLayoutGap"
|
|
167
|
-
[attr.fxLayoutAlign]="options?.fxLayoutAlign"
|
|
168
|
-
[attr.fxFlexFill]="options?.fxLayoutAlign"></flex-layout-root-widget>
|
|
169
|
-
</fieldset>
|
|
170
|
-
</mat-card-content>
|
|
171
|
-
<mat-card-footer>
|
|
172
|
-
<mat-error *ngIf="options?.showErrors && options?.errorMessage"
|
|
173
|
-
[innerHTML]="options?.errorMessage"></mat-error>
|
|
174
|
-
</mat-card-footer>
|
|
175
|
-
</mat-card>
|
|
176
|
-
|
|
177
|
-
<mat-expansion-panel *ngIf="containerType === 'expansion-panel'"
|
|
178
|
-
[expanded]="expanded"
|
|
179
|
-
[hideToggle]="!options?.expandable">
|
|
180
|
-
<mat-expansion-panel-header>
|
|
181
|
-
<mat-panel-title>
|
|
182
|
-
<legend *ngIf="sectionTitle"
|
|
183
|
-
[class]="options?.labelHtmlClass"
|
|
184
|
-
[innerHTML]="sectionTitle"
|
|
185
|
-
(click)="toggleExpanded()"></legend>
|
|
186
|
-
</mat-panel-title>
|
|
187
|
-
</mat-expansion-panel-header>
|
|
188
|
-
<fieldset [disabled]="options?.readonly">
|
|
189
|
-
<flex-layout-root-widget *ngIf="expanded"
|
|
190
|
-
[layout]="layoutNode().items"
|
|
191
|
-
[dataIndex]="dataIndex()"
|
|
192
|
-
[layoutIndex]="layoutIndex()"
|
|
193
|
-
[isFlexItem]="getFlexAttribute('is-flex')"
|
|
194
|
-
[class.form-flex-column]="getFlexAttribute('flex-direction') === 'column'"
|
|
195
|
-
[class.form-flex-row]="getFlexAttribute('flex-direction') === 'row'"
|
|
196
|
-
[style.display]="getFlexAttribute('display')"
|
|
197
|
-
[style.flex-direction]="getFlexAttribute('flex-direction')"
|
|
198
|
-
[style.flex-wrap]="getFlexAttribute('flex-wrap')"
|
|
199
|
-
[style.justify-content]="getFlexAttribute('justify-content')"
|
|
200
|
-
[style.align-items]="getFlexAttribute('align-items')"
|
|
201
|
-
[style.align-content]="getFlexAttribute('align-content')"
|
|
202
|
-
[attr.fxLayout]="getFlexAttribute('layout')"
|
|
203
|
-
[attr.fxLayoutGap]="options?.fxLayoutGap"
|
|
204
|
-
[attr.fxLayoutAlign]="options?.fxLayoutAlign"
|
|
205
|
-
[attr.fxFlexFill]="options?.fxLayoutAlign"></flex-layout-root-widget>
|
|
206
|
-
</fieldset>
|
|
207
|
-
<mat-error *ngIf="options?.showErrors && options?.errorMessage"
|
|
208
|
-
[innerHTML]="options?.errorMessage"></mat-error>
|
|
209
|
-
</mat-expansion-panel>`, isInline: true, styles: ["fieldset{border:0;margin:0;padding:0}.legend{font-weight:700}.expandable>.legend:before{content:\"\\25b6\";padding-right:.3em;font-family:auto}.expanded>.legend:before{content:\"\\25bc\";padding-right:.2em}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.MatCard, selector: "mat-card", inputs: ["appearance"], exportAs: ["matCard"] }, { kind: "directive", type: i2.MatCardContent, selector: "mat-card-content" }, { kind: "directive", type: i2.MatCardFooter, selector: "mat-card-footer" }, { kind: "component", type: i2.MatCardHeader, selector: "mat-card-header" }, { kind: "component", type: i3.MatExpansionPanel, selector: "mat-expansion-panel", inputs: ["hideToggle", "togglePosition"], outputs: ["afterExpand", "afterCollapse"], exportAs: ["matExpansionPanel"] }, { kind: "component", type: i3.MatExpansionPanelHeader, selector: "mat-expansion-panel-header", inputs: ["expandedHeight", "collapsedHeight", "tabIndex"] }, { kind: "directive", type: i3.MatExpansionPanelTitle, selector: "mat-panel-title" }, { kind: "directive", type: i4.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "component", type: i5.FlexLayoutRootComponent, selector: "flex-layout-root-widget", inputs: ["dataIndex", "layoutIndex", "layout", "isFlexItem"] }] }); }
|
|
210
|
-
}
|
|
211
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FlexLayoutSectionComponent, decorators: [{
|
|
212
|
-
type: Component,
|
|
213
|
-
args: [{ selector: 'flex-layout-section-widget', template: `
|
|
214
|
-
<div *ngIf="containerType === 'div'"
|
|
215
|
-
[class]="options?.htmlClass || ''"
|
|
216
|
-
[class.expandable]="options?.expandable && !expanded"
|
|
217
|
-
[class.expanded]="options?.expandable && expanded">
|
|
218
|
-
<label *ngIf="sectionTitle"
|
|
219
|
-
[class]="'legend ' + (options?.labelHtmlClass || '')"
|
|
220
|
-
[innerHTML]="sectionTitle"
|
|
221
|
-
(click)="toggleExpanded()"></label>
|
|
222
|
-
<flex-layout-root-widget *ngIf="expanded"
|
|
223
|
-
[layout]="layoutNode().items"
|
|
224
|
-
[dataIndex]="dataIndex()"
|
|
225
|
-
[layoutIndex]="layoutIndex()"
|
|
226
|
-
[isFlexItem]="getFlexAttribute('is-flex')"
|
|
227
|
-
[class.form-flex-column]="getFlexAttribute('flex-direction') === 'column'"
|
|
228
|
-
[class.form-flex-row]="getFlexAttribute('flex-direction') === 'row'"
|
|
229
|
-
[style.display]="getFlexAttribute('display')"
|
|
230
|
-
[style.flex-direction]="getFlexAttribute('flex-direction')"
|
|
231
|
-
[style.flex-wrap]="getFlexAttribute('flex-wrap')"
|
|
232
|
-
[style.justify-content]="getFlexAttribute('justify-content')"
|
|
233
|
-
[style.align-items]="getFlexAttribute('align-items')"
|
|
234
|
-
[style.align-content]="getFlexAttribute('align-content')"
|
|
235
|
-
[attr.fxLayout]="getFlexAttribute('layout')"
|
|
236
|
-
[attr.fxLayoutGap]="options?.fxLayoutGap"
|
|
237
|
-
[attr.fxLayoutAlign]="options?.fxLayoutAlign"
|
|
238
|
-
[attr.fxFlexFill]="options?.fxLayoutAlign"></flex-layout-root-widget>
|
|
239
|
-
<mat-error *ngIf="options?.showErrors && options?.errorMessage"
|
|
240
|
-
[innerHTML]="options?.errorMessage"></mat-error>
|
|
241
|
-
</div>
|
|
242
|
-
|
|
243
|
-
<fieldset *ngIf="containerType === 'fieldset'"
|
|
244
|
-
[class]="options?.htmlClass || ''"
|
|
245
|
-
[class.expandable]="options?.expandable && !expanded"
|
|
246
|
-
[class.expanded]="options?.expandable && expanded"
|
|
247
|
-
[disabled]="options?.readonly">
|
|
248
|
-
<legend *ngIf="sectionTitle"
|
|
249
|
-
[class]="'legend ' + (options?.labelHtmlClass || '')"
|
|
250
|
-
[innerHTML]="sectionTitle"
|
|
251
|
-
(click)="toggleExpanded()"></legend>
|
|
252
|
-
<flex-layout-root-widget *ngIf="expanded"
|
|
253
|
-
[layout]="layoutNode().items"
|
|
254
|
-
[dataIndex]="dataIndex()"
|
|
255
|
-
[layoutIndex]="layoutIndex()"
|
|
256
|
-
[isFlexItem]="getFlexAttribute('is-flex')"
|
|
257
|
-
[class.form-flex-column]="getFlexAttribute('flex-direction') === 'column'"
|
|
258
|
-
[class.form-flex-row]="getFlexAttribute('flex-direction') === 'row'"
|
|
259
|
-
[style.display]="getFlexAttribute('display')"
|
|
260
|
-
[style.flex-direction]="getFlexAttribute('flex-direction')"
|
|
261
|
-
[style.flex-wrap]="getFlexAttribute('flex-wrap')"
|
|
262
|
-
[style.justify-content]="getFlexAttribute('justify-content')"
|
|
263
|
-
[style.align-items]="getFlexAttribute('align-items')"
|
|
264
|
-
[style.align-content]="getFlexAttribute('align-content')"
|
|
265
|
-
[attr.fxLayout]="getFlexAttribute('layout')"
|
|
266
|
-
[attr.fxLayoutGap]="options?.fxLayoutGap"
|
|
267
|
-
[attr.fxLayoutAlign]="options?.fxLayoutAlign"
|
|
268
|
-
[attr.attr.fxFlexFill]="options?.fxLayoutAlign"></flex-layout-root-widget>
|
|
269
|
-
<mat-error *ngIf="options?.showErrors && options?.errorMessage"
|
|
270
|
-
[innerHTML]="options?.errorMessage"></mat-error>
|
|
271
|
-
</fieldset>
|
|
272
|
-
|
|
273
|
-
<mat-card appearance="outlined" *ngIf="containerType === 'card'"
|
|
274
|
-
[ngClass]="options?.htmlClass || ''"
|
|
275
|
-
[class.expandable]="options?.expandable && !expanded"
|
|
276
|
-
[class.expanded]="options?.expandable && expanded">
|
|
277
|
-
<mat-card-header *ngIf="sectionTitle">
|
|
278
|
-
<legend
|
|
279
|
-
[class]="'legend ' + (options?.labelHtmlClass || '')"
|
|
280
|
-
[innerHTML]="sectionTitle"
|
|
281
|
-
(click)="toggleExpanded()"></legend>
|
|
282
|
-
</mat-card-header>
|
|
283
|
-
<mat-card-content *ngIf="expanded">
|
|
284
|
-
<fieldset [disabled]="options?.readonly">
|
|
285
|
-
<flex-layout-root-widget *ngIf="expanded"
|
|
286
|
-
[layout]="layoutNode().items"
|
|
287
|
-
[dataIndex]="dataIndex()"
|
|
288
|
-
[layoutIndex]="layoutIndex()"
|
|
289
|
-
[isFlexItem]="getFlexAttribute('is-flex')"
|
|
290
|
-
[class.form-flex-column]="getFlexAttribute('flex-direction') === 'column'"
|
|
291
|
-
[class.form-flex-row]="getFlexAttribute('flex-direction') === 'row'"
|
|
292
|
-
[style.display]="getFlexAttribute('display')"
|
|
293
|
-
[style.flex-direction]="getFlexAttribute('flex-direction')"
|
|
294
|
-
[style.flex-wrap]="getFlexAttribute('flex-wrap')"
|
|
295
|
-
[style.justify-content]="getFlexAttribute('justify-content')"
|
|
296
|
-
[style.align-items]="getFlexAttribute('align-items')"
|
|
297
|
-
[style.align-content]="getFlexAttribute('align-content')"
|
|
298
|
-
[attr.fxLayout]="getFlexAttribute('layout')"
|
|
299
|
-
[attr.fxLayoutGap]="options?.fxLayoutGap"
|
|
300
|
-
[attr.fxLayoutAlign]="options?.fxLayoutAlign"
|
|
301
|
-
[attr.fxFlexFill]="options?.fxLayoutAlign"></flex-layout-root-widget>
|
|
302
|
-
</fieldset>
|
|
303
|
-
</mat-card-content>
|
|
304
|
-
<mat-card-footer>
|
|
305
|
-
<mat-error *ngIf="options?.showErrors && options?.errorMessage"
|
|
306
|
-
[innerHTML]="options?.errorMessage"></mat-error>
|
|
307
|
-
</mat-card-footer>
|
|
308
|
-
</mat-card>
|
|
309
|
-
|
|
310
|
-
<mat-expansion-panel *ngIf="containerType === 'expansion-panel'"
|
|
311
|
-
[expanded]="expanded"
|
|
312
|
-
[hideToggle]="!options?.expandable">
|
|
313
|
-
<mat-expansion-panel-header>
|
|
314
|
-
<mat-panel-title>
|
|
315
|
-
<legend *ngIf="sectionTitle"
|
|
316
|
-
[class]="options?.labelHtmlClass"
|
|
317
|
-
[innerHTML]="sectionTitle"
|
|
318
|
-
(click)="toggleExpanded()"></legend>
|
|
319
|
-
</mat-panel-title>
|
|
320
|
-
</mat-expansion-panel-header>
|
|
321
|
-
<fieldset [disabled]="options?.readonly">
|
|
322
|
-
<flex-layout-root-widget *ngIf="expanded"
|
|
323
|
-
[layout]="layoutNode().items"
|
|
324
|
-
[dataIndex]="dataIndex()"
|
|
325
|
-
[layoutIndex]="layoutIndex()"
|
|
326
|
-
[isFlexItem]="getFlexAttribute('is-flex')"
|
|
327
|
-
[class.form-flex-column]="getFlexAttribute('flex-direction') === 'column'"
|
|
328
|
-
[class.form-flex-row]="getFlexAttribute('flex-direction') === 'row'"
|
|
329
|
-
[style.display]="getFlexAttribute('display')"
|
|
330
|
-
[style.flex-direction]="getFlexAttribute('flex-direction')"
|
|
331
|
-
[style.flex-wrap]="getFlexAttribute('flex-wrap')"
|
|
332
|
-
[style.justify-content]="getFlexAttribute('justify-content')"
|
|
333
|
-
[style.align-items]="getFlexAttribute('align-items')"
|
|
334
|
-
[style.align-content]="getFlexAttribute('align-content')"
|
|
335
|
-
[attr.fxLayout]="getFlexAttribute('layout')"
|
|
336
|
-
[attr.fxLayoutGap]="options?.fxLayoutGap"
|
|
337
|
-
[attr.fxLayoutAlign]="options?.fxLayoutAlign"
|
|
338
|
-
[attr.fxFlexFill]="options?.fxLayoutAlign"></flex-layout-root-widget>
|
|
339
|
-
</fieldset>
|
|
340
|
-
<mat-error *ngIf="options?.showErrors && options?.errorMessage"
|
|
341
|
-
[innerHTML]="options?.errorMessage"></mat-error>
|
|
342
|
-
</mat-expansion-panel>`, styles: ["fieldset{border:0;margin:0;padding:0}.legend{font-weight:700}.expandable>.legend:before{content:\"\\25b6\";padding-right:.3em;font-family:auto}.expanded>.legend:before{content:\"\\25bc\";padding-right:.2em}\n"] }]
|
|
343
|
-
}] });
|
|
344
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"flex-layout-section.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-formworks-material/src/lib/widgets/flex-layout-section.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, inject, input } from '@angular/core';\r\nimport { AbstractControl } from '@angular/forms';\r\nimport { JsonSchemaFormService } from '@ng-formworks/core';\r\n\r\n@Component({\r\n  // tslint:disable-next-line:component-selector\r\n  selector: 'flex-layout-section-widget',\r\n  template: `\r\n    <div *ngIf=\"containerType === 'div'\"\r\n      [class]=\"options?.htmlClass || ''\"\r\n      [class.expandable]=\"options?.expandable && !expanded\"\r\n      [class.expanded]=\"options?.expandable && expanded\">\r\n      <label *ngIf=\"sectionTitle\"\r\n        [class]=\"'legend ' + (options?.labelHtmlClass || '')\"\r\n        [innerHTML]=\"sectionTitle\"\r\n        (click)=\"toggleExpanded()\"></label>\r\n      <flex-layout-root-widget *ngIf=\"expanded\"\r\n        [layout]=\"layoutNode().items\"\r\n        [dataIndex]=\"dataIndex()\"\r\n        [layoutIndex]=\"layoutIndex()\"\r\n        [isFlexItem]=\"getFlexAttribute('is-flex')\"\r\n        [class.form-flex-column]=\"getFlexAttribute('flex-direction') === 'column'\"\r\n        [class.form-flex-row]=\"getFlexAttribute('flex-direction') === 'row'\"\r\n        [style.display]=\"getFlexAttribute('display')\"\r\n        [style.flex-direction]=\"getFlexAttribute('flex-direction')\"\r\n        [style.flex-wrap]=\"getFlexAttribute('flex-wrap')\"\r\n        [style.justify-content]=\"getFlexAttribute('justify-content')\"\r\n        [style.align-items]=\"getFlexAttribute('align-items')\"\r\n        [style.align-content]=\"getFlexAttribute('align-content')\"\r\n        [attr.fxLayout]=\"getFlexAttribute('layout')\"\r\n        [attr.fxLayoutGap]=\"options?.fxLayoutGap\"\r\n        [attr.fxLayoutAlign]=\"options?.fxLayoutAlign\"\r\n        [attr.fxFlexFill]=\"options?.fxLayoutAlign\"></flex-layout-root-widget>\r\n      <mat-error *ngIf=\"options?.showErrors && options?.errorMessage\"\r\n        [innerHTML]=\"options?.errorMessage\"></mat-error>\r\n    </div>\r\n\r\n    <fieldset *ngIf=\"containerType === 'fieldset'\"\r\n      [class]=\"options?.htmlClass || ''\"\r\n      [class.expandable]=\"options?.expandable && !expanded\"\r\n      [class.expanded]=\"options?.expandable && expanded\"\r\n      [disabled]=\"options?.readonly\">\r\n      <legend *ngIf=\"sectionTitle\"\r\n        [class]=\"'legend ' + (options?.labelHtmlClass || '')\"\r\n        [innerHTML]=\"sectionTitle\"\r\n        (click)=\"toggleExpanded()\"></legend>\r\n      <flex-layout-root-widget *ngIf=\"expanded\"\r\n        [layout]=\"layoutNode().items\"\r\n        [dataIndex]=\"dataIndex()\"\r\n        [layoutIndex]=\"layoutIndex()\"\r\n        [isFlexItem]=\"getFlexAttribute('is-flex')\"\r\n        [class.form-flex-column]=\"getFlexAttribute('flex-direction') === 'column'\"\r\n        [class.form-flex-row]=\"getFlexAttribute('flex-direction') === 'row'\"\r\n        [style.display]=\"getFlexAttribute('display')\"\r\n        [style.flex-direction]=\"getFlexAttribute('flex-direction')\"\r\n        [style.flex-wrap]=\"getFlexAttribute('flex-wrap')\"\r\n        [style.justify-content]=\"getFlexAttribute('justify-content')\"\r\n        [style.align-items]=\"getFlexAttribute('align-items')\"\r\n        [style.align-content]=\"getFlexAttribute('align-content')\"\r\n        [attr.fxLayout]=\"getFlexAttribute('layout')\"\r\n        [attr.fxLayoutGap]=\"options?.fxLayoutGap\"\r\n        [attr.fxLayoutAlign]=\"options?.fxLayoutAlign\"\r\n        [attr.attr.fxFlexFill]=\"options?.fxLayoutAlign\"></flex-layout-root-widget>\r\n      <mat-error *ngIf=\"options?.showErrors && options?.errorMessage\"\r\n        [innerHTML]=\"options?.errorMessage\"></mat-error>\r\n    </fieldset>\r\n\r\n    <mat-card appearance=\"outlined\" *ngIf=\"containerType === 'card'\"\r\n      [ngClass]=\"options?.htmlClass || ''\"\r\n      [class.expandable]=\"options?.expandable && !expanded\"\r\n      [class.expanded]=\"options?.expandable && expanded\">\r\n      <mat-card-header *ngIf=\"sectionTitle\">\r\n        <legend\r\n          [class]=\"'legend ' + (options?.labelHtmlClass || '')\"\r\n          [innerHTML]=\"sectionTitle\"\r\n          (click)=\"toggleExpanded()\"></legend>\r\n      </mat-card-header>\r\n      <mat-card-content *ngIf=\"expanded\">\r\n        <fieldset [disabled]=\"options?.readonly\">\r\n          <flex-layout-root-widget *ngIf=\"expanded\"\r\n            [layout]=\"layoutNode().items\"\r\n            [dataIndex]=\"dataIndex()\"\r\n            [layoutIndex]=\"layoutIndex()\"\r\n            [isFlexItem]=\"getFlexAttribute('is-flex')\"\r\n            [class.form-flex-column]=\"getFlexAttribute('flex-direction') === 'column'\"\r\n            [class.form-flex-row]=\"getFlexAttribute('flex-direction') === 'row'\"\r\n            [style.display]=\"getFlexAttribute('display')\"\r\n            [style.flex-direction]=\"getFlexAttribute('flex-direction')\"\r\n            [style.flex-wrap]=\"getFlexAttribute('flex-wrap')\"\r\n            [style.justify-content]=\"getFlexAttribute('justify-content')\"\r\n            [style.align-items]=\"getFlexAttribute('align-items')\"\r\n            [style.align-content]=\"getFlexAttribute('align-content')\"\r\n            [attr.fxLayout]=\"getFlexAttribute('layout')\"\r\n            [attr.fxLayoutGap]=\"options?.fxLayoutGap\"\r\n            [attr.fxLayoutAlign]=\"options?.fxLayoutAlign\"\r\n            [attr.fxFlexFill]=\"options?.fxLayoutAlign\"></flex-layout-root-widget>\r\n          </fieldset>\r\n      </mat-card-content>\r\n      <mat-card-footer>\r\n        <mat-error *ngIf=\"options?.showErrors && options?.errorMessage\"\r\n          [innerHTML]=\"options?.errorMessage\"></mat-error>\r\n      </mat-card-footer>\r\n    </mat-card>\r\n\r\n    <mat-expansion-panel *ngIf=\"containerType === 'expansion-panel'\"\r\n      [expanded]=\"expanded\"\r\n      [hideToggle]=\"!options?.expandable\">\r\n      <mat-expansion-panel-header>\r\n        <mat-panel-title>\r\n          <legend *ngIf=\"sectionTitle\"\r\n            [class]=\"options?.labelHtmlClass\"\r\n            [innerHTML]=\"sectionTitle\"\r\n            (click)=\"toggleExpanded()\"></legend>\r\n        </mat-panel-title>\r\n      </mat-expansion-panel-header>\r\n      <fieldset [disabled]=\"options?.readonly\">\r\n        <flex-layout-root-widget *ngIf=\"expanded\"\r\n          [layout]=\"layoutNode().items\"\r\n          [dataIndex]=\"dataIndex()\"\r\n          [layoutIndex]=\"layoutIndex()\"\r\n          [isFlexItem]=\"getFlexAttribute('is-flex')\"\r\n          [class.form-flex-column]=\"getFlexAttribute('flex-direction') === 'column'\"\r\n          [class.form-flex-row]=\"getFlexAttribute('flex-direction') === 'row'\"\r\n          [style.display]=\"getFlexAttribute('display')\"\r\n          [style.flex-direction]=\"getFlexAttribute('flex-direction')\"\r\n          [style.flex-wrap]=\"getFlexAttribute('flex-wrap')\"\r\n          [style.justify-content]=\"getFlexAttribute('justify-content')\"\r\n          [style.align-items]=\"getFlexAttribute('align-items')\"\r\n          [style.align-content]=\"getFlexAttribute('align-content')\"\r\n          [attr.fxLayout]=\"getFlexAttribute('layout')\"\r\n          [attr.fxLayoutGap]=\"options?.fxLayoutGap\"\r\n          [attr.fxLayoutAlign]=\"options?.fxLayoutAlign\"\r\n          [attr.fxFlexFill]=\"options?.fxLayoutAlign\"></flex-layout-root-widget>\r\n      </fieldset>\r\n      <mat-error *ngIf=\"options?.showErrors && options?.errorMessage\"\r\n        [innerHTML]=\"options?.errorMessage\"></mat-error>\r\n    </mat-expansion-panel>`,\r\n  styles: [`\r\n    fieldset { border: 0; margin: 0; padding: 0; }\r\n    .legend { font-weight: bold; }\r\n    .expandable > .legend:before { content: '▶'; padding-right: .3em; font-family:auto }\r\n    .expanded > .legend:before { content: '▼'; padding-right: .2em; }\r\n  `],\r\n})\r\nexport class FlexLayoutSectionComponent implements OnInit {\r\n  private jsf = inject(JsonSchemaFormService);\r\n\r\n  formControl: AbstractControl;\r\n  controlName: string;\r\n  controlValue: any;\r\n  controlDisabled = false;\r\n  boundControl = false;\r\n  options: any;\r\n  expanded = true;\r\n  containerType = 'div';\r\n  readonly layoutNode = input<any>(undefined);\r\n  readonly layoutIndex = input<number[]>(undefined);\r\n  readonly dataIndex = input<number[]>(undefined);\r\n\r\n  get sectionTitle() {\r\n    return this.options.notitle ? null : this.jsf.setItemTitle(this);\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.jsf.initializeControl(this);\r\n    this.options = this.layoutNode().options || {};\r\n    this.expanded = typeof this.options.expanded === 'boolean' ?\r\n      this.options.expanded : !this.options.expandable;\r\n    switch (this.layoutNode().type) {\r\n      case 'section': case 'array': case 'fieldset': case 'advancedfieldset':\r\n      case 'authfieldset': case 'optionfieldset': case 'selectfieldset':\r\n        this.containerType = 'fieldset';\r\n        break;\r\n      case 'card':\r\n        this.containerType = 'card';\r\n        break;\r\n      case 'expansion-panel':\r\n        this.containerType = 'expansion-panel';\r\n        break;\r\n      default: // 'div', 'flex', 'tab', 'conditional', 'actions'\r\n        this.containerType = 'div';\r\n    }\r\n  }\r\n\r\n  toggleExpanded() {\r\n    if (this.options.expandable) { this.expanded = !this.expanded; }\r\n  }\r\n\r\n  // Set attributes for flexbox container\r\n  // (child attributes are set in flex-layout-root.component)\r\n  getFlexAttribute(attribute: string) {\r\n    const flexActive: boolean =\r\n      this.layoutNode().type === 'flex' ||\r\n      !!this.options.displayFlex ||\r\n      this.options.display === 'flex';\r\n    // if (attribute !== 'flex' && !flexActive) { return null; }\r\n    switch (attribute) {\r\n      case 'is-flex':\r\n        return flexActive;\r\n      case 'display':\r\n        return flexActive ? 'flex' : 'initial';\r\n      case 'flex-direction': case 'flex-wrap':\r\n        const index = ['flex-direction', 'flex-wrap'].indexOf(attribute);\r\n        return (this.options['flex-flow'] || '').split(/\\s+/)[index] ||\r\n          this.options[attribute] || ['column', 'nowrap'][index];\r\n      case 'justify-content': case 'align-items': case 'align-content':\r\n        return this.options[attribute];\r\n      case 'layout':\r\n        return (this.options.fxLayout || 'row') +\r\n          this.options.fxLayoutWrap ? ' ' + this.options.fxLayoutWrap : '';\r\n\r\n    }\r\n  }\r\n}\r\n"]}
|
|
@@ -1,63 +0,0 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component, input, inject } from '@angular/core';
|
|
2
|
-
import { JsonSchemaFormService } from '@ng-formworks/core';
|
|
3
|
-
import * as i0 from "@angular/core";
|
|
4
|
-
import * as i1 from "@angular/common";
|
|
5
|
-
import * as i2 from "@angular/material/button";
|
|
6
|
-
export class MaterialAddReferenceComponent {
|
|
7
|
-
constructor() {
|
|
8
|
-
this.jsf = inject(JsonSchemaFormService);
|
|
9
|
-
this.layoutNode = input(undefined);
|
|
10
|
-
this.layoutIndex = input(undefined);
|
|
11
|
-
this.dataIndex = input(undefined);
|
|
12
|
-
}
|
|
13
|
-
ngOnInit() {
|
|
14
|
-
this.options = this.layoutNode().options || {};
|
|
15
|
-
}
|
|
16
|
-
get showAddButton() {
|
|
17
|
-
return !this.layoutNode().arrayItem ||
|
|
18
|
-
this.layoutIndex()[this.layoutIndex().length - 1] < this.options.maxItems;
|
|
19
|
-
}
|
|
20
|
-
addItem(event) {
|
|
21
|
-
event.preventDefault();
|
|
22
|
-
this.jsf.addItem(this);
|
|
23
|
-
}
|
|
24
|
-
get buttonText() {
|
|
25
|
-
const parent = {
|
|
26
|
-
dataIndex: this.dataIndex().slice(0, -1),
|
|
27
|
-
layoutIndex: this.layoutIndex().slice(0, -1),
|
|
28
|
-
layoutNode: this.jsf.getParentNode(this),
|
|
29
|
-
};
|
|
30
|
-
return parent.layoutNode.add ||
|
|
31
|
-
this.jsf.setArrayItemTitle(parent, this.layoutNode(), this.itemCount);
|
|
32
|
-
}
|
|
33
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MaterialAddReferenceComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
34
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.13", type: MaterialAddReferenceComponent, selector: "material-add-reference-widget", inputs: { layoutNode: { classPropertyName: "layoutNode", publicName: "layoutNode", isSignal: true, isRequired: false, transformFunction: null }, layoutIndex: { classPropertyName: "layoutIndex", publicName: "layoutIndex", isSignal: true, isRequired: false, transformFunction: null }, dataIndex: { classPropertyName: "dataIndex", publicName: "dataIndex", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: `
|
|
35
|
-
<section [class]="options?.htmlClass || ''" align="end">
|
|
36
|
-
<button mat-raised-button *ngIf="showAddButton"
|
|
37
|
-
[color]="options?.color || 'accent'"
|
|
38
|
-
[disabled]="options?.readonly"
|
|
39
|
-
(click)="addItem($event)">
|
|
40
|
-
<span *ngIf="options?.icon" [class]="options?.icon"></span>
|
|
41
|
-
<span *ngIf="options?.title" [innerHTML]="buttonText"></span>
|
|
42
|
-
</button>
|
|
43
|
-
</section>`, isInline: true, dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }], changeDetection: i0.ChangeDetectionStrategy.Default }); }
|
|
44
|
-
}
|
|
45
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MaterialAddReferenceComponent, decorators: [{
|
|
46
|
-
type: Component,
|
|
47
|
-
args: [{
|
|
48
|
-
// tslint:disable-next-line:component-selector
|
|
49
|
-
selector: 'material-add-reference-widget',
|
|
50
|
-
template: `
|
|
51
|
-
<section [class]="options?.htmlClass || ''" align="end">
|
|
52
|
-
<button mat-raised-button *ngIf="showAddButton"
|
|
53
|
-
[color]="options?.color || 'accent'"
|
|
54
|
-
[disabled]="options?.readonly"
|
|
55
|
-
(click)="addItem($event)">
|
|
56
|
-
<span *ngIf="options?.icon" [class]="options?.icon"></span>
|
|
57
|
-
<span *ngIf="options?.title" [innerHTML]="buttonText"></span>
|
|
58
|
-
</button>
|
|
59
|
-
</section>`,
|
|
60
|
-
changeDetection: ChangeDetectionStrategy.Default,
|
|
61
|
-
}]
|
|
62
|
-
}] });
|
|
63
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWF0ZXJpYWwtYWRkLXJlZmVyZW5jZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy1mb3Jtd29ya3MtbWF0ZXJpYWwvc3JjL2xpYi93aWRnZXRzL21hdGVyaWFsLWFkZC1yZWZlcmVuY2UuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQVUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMxRixPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQzs7OztBQWtCM0QsTUFBTSxPQUFPLDZCQUE2QjtJQWYxQztRQWdCVSxRQUFHLEdBQUcsTUFBTSxDQUFDLHFCQUFxQixDQUFDLENBQUM7UUFNbkMsZUFBVSxHQUFHLEtBQUssQ0FBTSxTQUFTLENBQUMsQ0FBQztRQUNuQyxnQkFBVyxHQUFHLEtBQUssQ0FBVyxTQUFTLENBQUMsQ0FBQztRQUN6QyxjQUFTLEdBQUcsS0FBSyxDQUFXLFNBQVMsQ0FBQyxDQUFDO0tBeUJqRDtJQXZCQyxRQUFRO1FBQ04sSUFBSSxDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUMsVUFBVSxFQUFFLENBQUMsT0FBTyxJQUFJLEVBQUUsQ0FBQztJQUNqRCxDQUFDO0lBRUQsSUFBSSxhQUFhO1FBQ2YsT0FBTyxDQUFDLElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQyxTQUFTO1lBQ2pDLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQyxJQUFJLENBQUMsV0FBVyxFQUFFLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQyxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDO0lBQzlFLENBQUM7SUFFRCxPQUFPLENBQUMsS0FBSztRQUNYLEtBQUssQ0FBQyxjQUFjLEVBQUUsQ0FBQztRQUN2QixJQUFJLENBQUMsR0FBRyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUN6QixDQUFDO0lBRUQsSUFBSSxVQUFVO1FBQ1osTUFBTSxNQUFNLEdBQVE7WUFDbEIsU0FBUyxFQUFFLElBQUksQ0FBQyxTQUFTLEVBQUUsQ0FBQyxLQUFLLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDO1lBQ3hDLFdBQVcsRUFBRSxJQUFJLENBQUMsV0FBVyxFQUFFLENBQUMsS0FBSyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQztZQUM1QyxVQUFVLEVBQUUsSUFBSSxDQUFDLEdBQUcsQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDO1NBQ3pDLENBQUM7UUFDRixPQUFPLE1BQU0sQ0FBQyxVQUFVLENBQUMsR0FBRztZQUMxQixJQUFJLENBQUMsR0FBRyxDQUFDLGlCQUFpQixDQUFDLE1BQU0sRUFBRSxJQUFJLENBQUMsVUFBVSxFQUFFLEVBQUUsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDO0lBQzFFLENBQUM7K0dBakNVLDZCQUE2QjttR0FBN0IsNkJBQTZCLHNlQVo5Qjs7Ozs7Ozs7O2VBU0c7OzRGQUdGLDZCQUE2QjtrQkFmekMsU0FBUzttQkFBQztvQkFDVCw4Q0FBOEM7b0JBQzlDLFFBQVEsRUFBRSwrQkFBK0I7b0JBQ3pDLFFBQVEsRUFBRTs7Ozs7Ozs7O2VBU0c7b0JBQ2IsZUFBZSxFQUFFLHVCQUF1QixDQUFDLE9BQU87aUJBQ2pEIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgT25Jbml0LCBpbnB1dCwgaW5qZWN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IEpzb25TY2hlbWFGb3JtU2VydmljZSB9IGZyb20gJ0BuZy1mb3Jtd29ya3MvY29yZSc7XHJcblxyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgLy8gdHNsaW50OmRpc2FibGUtbmV4dC1saW5lOmNvbXBvbmVudC1zZWxlY3RvclxyXG4gIHNlbGVjdG9yOiAnbWF0ZXJpYWwtYWRkLXJlZmVyZW5jZS13aWRnZXQnLFxyXG4gIHRlbXBsYXRlOiBgXHJcbiAgICA8c2VjdGlvbiBbY2xhc3NdPVwib3B0aW9ucz8uaHRtbENsYXNzIHx8ICcnXCIgYWxpZ249XCJlbmRcIj5cclxuICAgICAgPGJ1dHRvbiBtYXQtcmFpc2VkLWJ1dHRvbiAqbmdJZj1cInNob3dBZGRCdXR0b25cIlxyXG4gICAgICAgIFtjb2xvcl09XCJvcHRpb25zPy5jb2xvciB8fCAnYWNjZW50J1wiXHJcbiAgICAgICAgW2Rpc2FibGVkXT1cIm9wdGlvbnM/LnJlYWRvbmx5XCJcclxuICAgICAgICAoY2xpY2spPVwiYWRkSXRlbSgkZXZlbnQpXCI+XHJcbiAgICAgICAgPHNwYW4gKm5nSWY9XCJvcHRpb25zPy5pY29uXCIgW2NsYXNzXT1cIm9wdGlvbnM/Lmljb25cIj48L3NwYW4+XHJcbiAgICAgICAgPHNwYW4gKm5nSWY9XCJvcHRpb25zPy50aXRsZVwiIFtpbm5lckhUTUxdPVwiYnV0dG9uVGV4dFwiPjwvc3Bhbj5cclxuICAgICAgPC9idXR0b24+XHJcbiAgICA8L3NlY3Rpb24+YCxcclxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LkRlZmF1bHQsXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBNYXRlcmlhbEFkZFJlZmVyZW5jZUNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XHJcbiAgcHJpdmF0ZSBqc2YgPSBpbmplY3QoSnNvblNjaGVtYUZvcm1TZXJ2aWNlKTtcclxuXHJcbiAgb3B0aW9uczogYW55O1xyXG4gIGl0ZW1Db3VudDogbnVtYmVyO1xyXG4gIHByZXZpb3VzTGF5b3V0SW5kZXg6IG51bWJlcltdO1xyXG4gIHByZXZpb3VzRGF0YUluZGV4OiBudW1iZXJbXTtcclxuICByZWFkb25seSBsYXlvdXROb2RlID0gaW5wdXQ8YW55Pih1bmRlZmluZWQpO1xyXG4gIHJlYWRvbmx5IGxheW91dEluZGV4ID0gaW5wdXQ8bnVtYmVyW10+KHVuZGVmaW5lZCk7XHJcbiAgcmVhZG9ubHkgZGF0YUluZGV4ID0gaW5wdXQ8bnVtYmVyW10+KHVuZGVmaW5lZCk7XHJcblxyXG4gIG5nT25Jbml0KCkge1xyXG4gICAgdGhpcy5vcHRpb25zID0gdGhpcy5sYXlvdXROb2RlKCkub3B0aW9ucyB8fCB7fTtcclxuICB9XHJcblxyXG4gIGdldCBzaG93QWRkQnV0dG9uKCk6IGJvb2xlYW4ge1xyXG4gICAgcmV0dXJuICF0aGlzLmxheW91dE5vZGUoKS5hcnJheUl0ZW0gfHxcclxuICAgICAgdGhpcy5sYXlvdXRJbmRleCgpW3RoaXMubGF5b3V0SW5kZXgoKS5sZW5ndGggLSAxXSA8IHRoaXMub3B0aW9ucy5tYXhJdGVtcztcclxuICB9XHJcblxyXG4gIGFkZEl0ZW0oZXZlbnQpIHtcclxuICAgIGV2ZW50LnByZXZlbnREZWZhdWx0KCk7XHJcbiAgICB0aGlzLmpzZi5hZGRJdGVtKHRoaXMpO1xyXG4gIH1cclxuXHJcbiAgZ2V0IGJ1dHRvblRleHQoKTogc3RyaW5nIHtcclxuICAgIGNvbnN0IHBhcmVudDogYW55ID0ge1xyXG4gICAgICBkYXRhSW5kZXg6IHRoaXMuZGF0YUluZGV4KCkuc2xpY2UoMCwgLTEpLFxyXG4gICAgICBsYXlvdXRJbmRleDogdGhpcy5sYXlvdXRJbmRleCgpLnNsaWNlKDAsIC0xKSxcclxuICAgICAgbGF5b3V0Tm9kZTogdGhpcy5qc2YuZ2V0UGFyZW50Tm9kZSh0aGlzKSxcclxuICAgIH07XHJcbiAgICByZXR1cm4gcGFyZW50LmxheW91dE5vZGUuYWRkIHx8XHJcbiAgICAgIHRoaXMuanNmLnNldEFycmF5SXRlbVRpdGxlKHBhcmVudCwgdGhpcy5sYXlvdXROb2RlKCksIHRoaXMuaXRlbUNvdW50KTtcclxuICB9XHJcbn1cclxuIl19
|
|
@@ -1,86 +0,0 @@
|
|
|
1
|
-
import { Component, input, inject } from '@angular/core';
|
|
2
|
-
import { JsonSchemaFormService, buildTitleMap } from '@ng-formworks/core';
|
|
3
|
-
import * as i0 from "@angular/core";
|
|
4
|
-
import * as i1 from "@angular/common";
|
|
5
|
-
import * as i2 from "@angular/material/button-toggle";
|
|
6
|
-
import * as i3 from "@angular/material/form-field";
|
|
7
|
-
export class MaterialButtonGroupComponent {
|
|
8
|
-
constructor() {
|
|
9
|
-
this.jsf = inject(JsonSchemaFormService);
|
|
10
|
-
this.controlDisabled = false;
|
|
11
|
-
this.boundControl = false;
|
|
12
|
-
this.radiosList = [];
|
|
13
|
-
this.vertical = false;
|
|
14
|
-
this.layoutNode = input(undefined);
|
|
15
|
-
this.layoutIndex = input(undefined);
|
|
16
|
-
this.dataIndex = input(undefined);
|
|
17
|
-
}
|
|
18
|
-
ngOnInit() {
|
|
19
|
-
this.options = this.layoutNode().options || {};
|
|
20
|
-
this.radiosList = buildTitleMap(this.options.titleMap || this.options.enumNames, this.options.enum, true);
|
|
21
|
-
this.jsf.initializeControl(this);
|
|
22
|
-
}
|
|
23
|
-
updateValue(value) {
|
|
24
|
-
this.options.showErrors = true;
|
|
25
|
-
this.jsf.updateValue(this, value);
|
|
26
|
-
}
|
|
27
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MaterialButtonGroupComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
28
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.13", type: MaterialButtonGroupComponent, selector: "material-button-group-widget", inputs: { layoutNode: { classPropertyName: "layoutNode", publicName: "layoutNode", isSignal: true, isRequired: false, transformFunction: null }, layoutIndex: { classPropertyName: "layoutIndex", publicName: "layoutIndex", isSignal: true, isRequired: false, transformFunction: null }, dataIndex: { classPropertyName: "dataIndex", publicName: "dataIndex", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: `
|
|
29
|
-
<div>
|
|
30
|
-
<div *ngIf="options?.title">
|
|
31
|
-
<label
|
|
32
|
-
[attr.for]="'control' + layoutNode()?._id"
|
|
33
|
-
[class]="options?.labelHtmlClass || ''"
|
|
34
|
-
[style.display]="options?.notitle ? 'none' : ''"
|
|
35
|
-
[innerHTML]="options?.title"></label>
|
|
36
|
-
</div>
|
|
37
|
-
<mat-button-toggle-group
|
|
38
|
-
[attr.aria-describedby]="'control' + layoutNode()?._id + 'Status'"
|
|
39
|
-
[attr.readonly]="options?.readonly ? 'readonly' : null"
|
|
40
|
-
[attr.required]="options?.required"
|
|
41
|
-
[disabled]="controlDisabled || options?.readonly"
|
|
42
|
-
[name]="controlName"
|
|
43
|
-
[value]="controlValue"
|
|
44
|
-
[vertical]="!!options.vertical">
|
|
45
|
-
<mat-button-toggle *ngFor="let radioItem of radiosList"
|
|
46
|
-
[id]="'control' + layoutNode()?._id + '/' + radioItem?.name"
|
|
47
|
-
[value]="radioItem?.value"
|
|
48
|
-
(click)="updateValue(radioItem?.value)">
|
|
49
|
-
<span [innerHTML]="radioItem?.name"></span>
|
|
50
|
-
</mat-button-toggle>
|
|
51
|
-
</mat-button-toggle-group>
|
|
52
|
-
<mat-error *ngIf="options?.showErrors && options?.errorMessage"
|
|
53
|
-
[innerHTML]="options?.errorMessage"></mat-error>
|
|
54
|
-
</div>`, isInline: true, styles: ["mat-error{font-size:75%}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.MatButtonToggleGroup, selector: "mat-button-toggle-group", inputs: ["appearance", "name", "vertical", "value", "multiple", "disabled", "disabledInteractive", "hideSingleSelectionIndicator", "hideMultipleSelectionIndicator"], outputs: ["valueChange", "change"], exportAs: ["matButtonToggleGroup"] }, { kind: "component", type: i2.MatButtonToggle, selector: "mat-button-toggle", inputs: ["aria-label", "aria-labelledby", "id", "name", "value", "tabIndex", "disableRipple", "appearance", "checked", "disabled", "disabledInteractive"], outputs: ["change"], exportAs: ["matButtonToggle"] }, { kind: "directive", type: i3.MatError, selector: "mat-error, [matError]", inputs: ["id"] }] }); }
|
|
55
|
-
}
|
|
56
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MaterialButtonGroupComponent, decorators: [{
|
|
57
|
-
type: Component,
|
|
58
|
-
args: [{ selector: 'material-button-group-widget', template: `
|
|
59
|
-
<div>
|
|
60
|
-
<div *ngIf="options?.title">
|
|
61
|
-
<label
|
|
62
|
-
[attr.for]="'control' + layoutNode()?._id"
|
|
63
|
-
[class]="options?.labelHtmlClass || ''"
|
|
64
|
-
[style.display]="options?.notitle ? 'none' : ''"
|
|
65
|
-
[innerHTML]="options?.title"></label>
|
|
66
|
-
</div>
|
|
67
|
-
<mat-button-toggle-group
|
|
68
|
-
[attr.aria-describedby]="'control' + layoutNode()?._id + 'Status'"
|
|
69
|
-
[attr.readonly]="options?.readonly ? 'readonly' : null"
|
|
70
|
-
[attr.required]="options?.required"
|
|
71
|
-
[disabled]="controlDisabled || options?.readonly"
|
|
72
|
-
[name]="controlName"
|
|
73
|
-
[value]="controlValue"
|
|
74
|
-
[vertical]="!!options.vertical">
|
|
75
|
-
<mat-button-toggle *ngFor="let radioItem of radiosList"
|
|
76
|
-
[id]="'control' + layoutNode()?._id + '/' + radioItem?.name"
|
|
77
|
-
[value]="radioItem?.value"
|
|
78
|
-
(click)="updateValue(radioItem?.value)">
|
|
79
|
-
<span [innerHTML]="radioItem?.name"></span>
|
|
80
|
-
</mat-button-toggle>
|
|
81
|
-
</mat-button-toggle-group>
|
|
82
|
-
<mat-error *ngIf="options?.showErrors && options?.errorMessage"
|
|
83
|
-
[innerHTML]="options?.errorMessage"></mat-error>
|
|
84
|
-
</div>`, styles: ["mat-error{font-size:75%}\n"] }]
|
|
85
|
-
}] });
|
|
86
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWF0ZXJpYWwtYnV0dG9uLWdyb3VwLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLWZvcm13b3Jrcy1tYXRlcmlhbC9zcmMvbGliL3dpZGdldHMvbWF0ZXJpYWwtYnV0dG9uLWdyb3VwLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFVLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFakUsT0FBTyxFQUFFLHFCQUFxQixFQUFFLGFBQWEsRUFBRSxNQUFNLG9CQUFvQixDQUFDOzs7OztBQW1DMUUsTUFBTSxPQUFPLDRCQUE0QjtJQWhDekM7UUFpQ1UsUUFBRyxHQUFHLE1BQU0sQ0FBQyxxQkFBcUIsQ0FBQyxDQUFDO1FBSzVDLG9CQUFlLEdBQUcsS0FBSyxDQUFDO1FBQ3hCLGlCQUFZLEdBQUcsS0FBSyxDQUFDO1FBRXJCLGVBQVUsR0FBVSxFQUFFLENBQUM7UUFDdkIsYUFBUSxHQUFHLEtBQUssQ0FBQztRQUNSLGVBQVUsR0FBRyxLQUFLLENBQU0sU0FBUyxDQUFDLENBQUM7UUFDbkMsZ0JBQVcsR0FBRyxLQUFLLENBQVcsU0FBUyxDQUFDLENBQUM7UUFDekMsY0FBUyxHQUFHLEtBQUssQ0FBVyxTQUFTLENBQUMsQ0FBQztLQWVqRDtJQWJDLFFBQVE7UUFDTixJQUFJLENBQUMsT0FBTyxHQUFHLElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQyxPQUFPLElBQUksRUFBRSxDQUFDO1FBQy9DLElBQUksQ0FBQyxVQUFVLEdBQUcsYUFBYSxDQUM3QixJQUFJLENBQUMsT0FBTyxDQUFDLFFBQVEsSUFBSSxJQUFJLENBQUMsT0FBTyxDQUFDLFNBQVMsRUFDL0MsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLEVBQUUsSUFBSSxDQUN4QixDQUFDO1FBQ0YsSUFBSSxDQUFDLEdBQUcsQ0FBQyxpQkFBaUIsQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUNuQyxDQUFDO0lBRUQsV0FBVyxDQUFDLEtBQUs7UUFDZixJQUFJLENBQUMsT0FBTyxDQUFDLFVBQVUsR0FBRyxJQUFJLENBQUM7UUFDL0IsSUFBSSxDQUFDLEdBQUcsQ0FBQyxXQUFXLENBQUMsSUFBSSxFQUFFLEtBQUssQ0FBQyxDQUFDO0lBQ3BDLENBQUM7K0dBM0JVLDRCQUE0QjttR0FBNUIsNEJBQTRCLHFlQTdCN0I7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O1dBMEJEOzs0RkFHRSw0QkFBNEI7a0JBaEN4QyxTQUFTOytCQUVFLDhCQUE4QixZQUM5Qjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7V0EwQkQiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIE9uSW5pdCwgaW5wdXQsIGluamVjdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBBYnN0cmFjdENvbnRyb2wgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XHJcbmltcG9ydCB7IEpzb25TY2hlbWFGb3JtU2VydmljZSwgYnVpbGRUaXRsZU1hcCB9IGZyb20gJ0BuZy1mb3Jtd29ya3MvY29yZSc7XHJcblxyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgLy8gdHNsaW50OmRpc2FibGUtbmV4dC1saW5lOmNvbXBvbmVudC1zZWxlY3RvclxyXG4gIHNlbGVjdG9yOiAnbWF0ZXJpYWwtYnV0dG9uLWdyb3VwLXdpZGdldCcsXHJcbiAgdGVtcGxhdGU6IGBcclxuICAgIDxkaXY+XHJcbiAgICAgIDxkaXYgKm5nSWY9XCJvcHRpb25zPy50aXRsZVwiPlxyXG4gICAgICAgIDxsYWJlbFxyXG4gICAgICAgICAgW2F0dHIuZm9yXT1cIidjb250cm9sJyArIGxheW91dE5vZGUoKT8uX2lkXCJcclxuICAgICAgICAgIFtjbGFzc109XCJvcHRpb25zPy5sYWJlbEh0bWxDbGFzcyB8fCAnJ1wiXHJcbiAgICAgICAgICBbc3R5bGUuZGlzcGxheV09XCJvcHRpb25zPy5ub3RpdGxlID8gJ25vbmUnIDogJydcIlxyXG4gICAgICAgICAgW2lubmVySFRNTF09XCJvcHRpb25zPy50aXRsZVwiPjwvbGFiZWw+XHJcbiAgICAgIDwvZGl2PlxyXG4gICAgICA8bWF0LWJ1dHRvbi10b2dnbGUtZ3JvdXBcclxuICAgICAgICBbYXR0ci5hcmlhLWRlc2NyaWJlZGJ5XT1cIidjb250cm9sJyArIGxheW91dE5vZGUoKT8uX2lkICsgJ1N0YXR1cydcIlxyXG4gICAgICAgIFthdHRyLnJlYWRvbmx5XT1cIm9wdGlvbnM/LnJlYWRvbmx5ID8gJ3JlYWRvbmx5JyA6IG51bGxcIlxyXG4gICAgICAgIFthdHRyLnJlcXVpcmVkXT1cIm9wdGlvbnM/LnJlcXVpcmVkXCJcclxuICAgICAgICBbZGlzYWJsZWRdPVwiY29udHJvbERpc2FibGVkIHx8IG9wdGlvbnM/LnJlYWRvbmx5XCJcclxuICAgICAgICBbbmFtZV09XCJjb250cm9sTmFtZVwiXHJcbiAgICAgICAgW3ZhbHVlXT1cImNvbnRyb2xWYWx1ZVwiXHJcbiAgICAgICAgW3ZlcnRpY2FsXT1cIiEhb3B0aW9ucy52ZXJ0aWNhbFwiPlxyXG4gICAgICAgIDxtYXQtYnV0dG9uLXRvZ2dsZSAqbmdGb3I9XCJsZXQgcmFkaW9JdGVtIG9mIHJhZGlvc0xpc3RcIlxyXG4gICAgICAgICAgW2lkXT1cIidjb250cm9sJyArIGxheW91dE5vZGUoKT8uX2lkICsgJy8nICsgcmFkaW9JdGVtPy5uYW1lXCJcclxuICAgICAgICAgIFt2YWx1ZV09XCJyYWRpb0l0ZW0/LnZhbHVlXCJcclxuICAgICAgICAgIChjbGljayk9XCJ1cGRhdGVWYWx1ZShyYWRpb0l0ZW0/LnZhbHVlKVwiPlxyXG4gICAgICAgICAgPHNwYW4gW2lubmVySFRNTF09XCJyYWRpb0l0ZW0/Lm5hbWVcIj48L3NwYW4+XHJcbiAgICAgICAgPC9tYXQtYnV0dG9uLXRvZ2dsZT5cclxuICAgICAgPC9tYXQtYnV0dG9uLXRvZ2dsZS1ncm91cD5cclxuICAgICAgPG1hdC1lcnJvciAqbmdJZj1cIm9wdGlvbnM/LnNob3dFcnJvcnMgJiYgb3B0aW9ucz8uZXJyb3JNZXNzYWdlXCJcclxuICAgICAgICBbaW5uZXJIVE1MXT1cIm9wdGlvbnM/LmVycm9yTWVzc2FnZVwiPjwvbWF0LWVycm9yPlxyXG4gICAgPC9kaXY+YCxcclxuICAgIHN0eWxlczogW2AgbWF0LWVycm9yIHsgZm9udC1zaXplOiA3NSU7IH0gYF0sXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBNYXRlcmlhbEJ1dHRvbkdyb3VwQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcclxuICBwcml2YXRlIGpzZiA9IGluamVjdChKc29uU2NoZW1hRm9ybVNlcnZpY2UpO1xyXG5cclxuICBmb3JtQ29udHJvbDogQWJzdHJhY3RDb250cm9sO1xyXG4gIGNvbnRyb2xOYW1lOiBzdHJpbmc7XHJcbiAgY29udHJvbFZhbHVlOiBhbnk7XHJcbiAgY29udHJvbERpc2FibGVkID0gZmFsc2U7XHJcbiAgYm91bmRDb250cm9sID0gZmFsc2U7XHJcbiAgb3B0aW9uczogYW55O1xyXG4gIHJhZGlvc0xpc3Q6IGFueVtdID0gW107XHJcbiAgdmVydGljYWwgPSBmYWxzZTtcclxuICByZWFkb25seSBsYXlvdXROb2RlID0gaW5wdXQ8YW55Pih1bmRlZmluZWQpO1xyXG4gIHJlYWRvbmx5IGxheW91dEluZGV4ID0gaW5wdXQ8bnVtYmVyW10+KHVuZGVmaW5lZCk7XHJcbiAgcmVhZG9ubHkgZGF0YUluZGV4ID0gaW5wdXQ8bnVtYmVyW10+KHVuZGVmaW5lZCk7XHJcblxyXG4gIG5nT25Jbml0KCkge1xyXG4gICAgdGhpcy5vcHRpb25zID0gdGhpcy5sYXlvdXROb2RlKCkub3B0aW9ucyB8fCB7fTtcclxuICAgIHRoaXMucmFkaW9zTGlzdCA9IGJ1aWxkVGl0bGVNYXAoXHJcbiAgICAgIHRoaXMub3B0aW9ucy50aXRsZU1hcCB8fCB0aGlzLm9wdGlvbnMuZW51bU5hbWVzLFxyXG4gICAgICB0aGlzLm9wdGlvbnMuZW51bSwgdHJ1ZVxyXG4gICAgKTtcclxuICAgIHRoaXMuanNmLmluaXRpYWxpemVDb250cm9sKHRoaXMpO1xyXG4gIH1cclxuXHJcbiAgdXBkYXRlVmFsdWUodmFsdWUpIHtcclxuICAgIHRoaXMub3B0aW9ucy5zaG93RXJyb3JzID0gdHJ1ZTtcclxuICAgIHRoaXMuanNmLnVwZGF0ZVZhbHVlKHRoaXMsIHZhbHVlKTtcclxuICB9XHJcbn1cclxuIl19
|