@ng-formworks/core 16.6.5 → 16.6.7

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (28) hide show
  1. package/esm2022/lib/json-schema-form.component.mjs +1 -1
  2. package/esm2022/lib/json-schema-form.service.mjs +25 -17
  3. package/esm2022/lib/shared/form-group.functions.mjs +52 -3
  4. package/esm2022/lib/shared/layout.functions.mjs +32 -9
  5. package/esm2022/lib/widget-library/add-reference.component.mjs +13 -6
  6. package/esm2022/lib/widget-library/button.component.mjs +9 -4
  7. package/esm2022/lib/widget-library/checkbox.component.mjs +2 -1
  8. package/esm2022/lib/widget-library/index.mjs +2 -1
  9. package/esm2022/lib/widget-library/input.component.mjs +9 -4
  10. package/esm2022/lib/widget-library/number.component.mjs +9 -6
  11. package/esm2022/lib/widget-library/root.component.mjs +169 -122
  12. package/esm2022/lib/widget-library/section.component.mjs +2 -2
  13. package/esm2022/lib/widget-library/select-framework.component.mjs +7 -4
  14. package/esm2022/lib/widget-library/select-widget.component.mjs +5 -4
  15. package/esm2022/lib/widget-library/stop-propagation.directive.mjs +42 -0
  16. package/esm2022/lib/widget-library/submit.component.mjs +9 -4
  17. package/esm2022/lib/widget-library/tab.component.mjs +1 -1
  18. package/esm2022/lib/widget-library/widget-library.module.mjs +9 -32
  19. package/fesm2022/ng-formworks-core.mjs +503 -334
  20. package/fesm2022/ng-formworks-core.mjs.map +1 -1
  21. package/lib/json-schema-form.service.d.ts +0 -3
  22. package/lib/widget-library/index.d.ts +1 -0
  23. package/lib/widget-library/root.component.d.ts +25 -7
  24. package/lib/widget-library/select-framework.component.d.ts +1 -1
  25. package/lib/widget-library/select-widget.component.d.ts +2 -2
  26. package/lib/widget-library/stop-propagation.directive.d.ts +13 -0
  27. package/lib/widget-library/widget-library.module.d.ts +5 -4
  28. package/package.json +3 -4
@@ -1,111 +1,92 @@
1
- import { Component, Input } from '@angular/core';
1
+ import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
2
+ import { memoize } from 'lodash';
2
3
  import * as i0 from "@angular/core";
3
4
  import * as i1 from "../json-schema-form.service";
4
5
  import * as i2 from "@angular/common";
5
- import * as i3 from "nxt-sortablejs";
6
+ import * as i3 from "@angular/cdk/drag-drop";
6
7
  import * as i4 from "./select-framework.component";
7
- import * as i5 from "./orderable.directive";
8
8
  export class RootComponent {
9
9
  constructor(jsf) {
10
10
  this.jsf = jsf;
11
11
  this.isFlexItem = false;
12
- this.sortableConfig = {
13
- filter: ".sortable-filter",
14
- preventOnFilter: false,
15
- onEnd: (/**Event*/ evt) => {
16
- evt.newIndex; // most likely why this event is used is to get the dragging element's current index
17
- // same properties as onEnd
18
- //console.log(`sortablejs event:${evt}`);
19
- let srcInd = evt.oldIndex;
20
- let trgInd = evt.newIndex;
21
- let layoutItem = this.layout[trgInd];
22
- let dataInd = layoutItem?.arrayItem ? (this.dataIndex || []).concat(trgInd) : (this.dataIndex || []);
23
- let layoutInd = (this.layoutIndex || []).concat(trgInd);
24
- let itemCtx = {
25
- dataIndex: dataInd,
26
- layoutIndex: layoutInd,
27
- layoutNode: layoutItem,
28
- };
29
- //must set moveLayout to false as nxtSortable already moves it
30
- this.jsf.moveArrayItem(itemCtx, evt.oldIndex, evt.newIndex, false);
31
- },
32
- onMove: function (/**Event*/ evt, /**Event*/ originalEvent) {
33
- if (evt.related.classList.contains("sortable-fixed")) {
34
- //console.log(evt.related);
35
- return false;
36
- }
37
- }
12
+ this.memoizationEnabled = true;
13
+ /**
14
+ * Predicate function that disallows '$ref' item sorts
15
+ * NB declared as a var instead of a function
16
+ * like sortPredicate(index: number, item: CdkDrag<number>){..}
17
+ * since 'this' is bound to the draglist and doesn't reference the
18
+ * FlexLayoutRootComponent instance
19
+ */
20
+ //TODO also need to think of other types such as button which can be
21
+ //created by an arbitrary layout
22
+ //might not be needed added condition to [cdkDragDisabled]
23
+ this.sortPredicate = (index, item) => {
24
+ let layoutItem = this.layout[index];
25
+ let result = this.isDraggable(layoutItem);
26
+ //layoutItem.type != '$ref';
27
+ return result;
38
28
  };
39
- }
40
- sortableInit(sortable) {
41
- this.sortableObj = sortable;
42
- //Sortable.utils.on(this.sortableObj.el,"nulling",(s)=>{console.log("event nulling sortablejs")})
43
- ///NB issue caused by sortablejs when it its destroyed
44
- //this mainly affects checkboxes coupled with conditions
45
- //-the value is rechecked
46
- //-see https://github.com/SortableJS/Sortable/issues/1052#issuecomment-369613072
47
- /* attempt to monkey patch sortable js
48
- const originalMethod = sortable._nulling;
49
- let zone=this.zone;
50
- sortable._nulling=function() {
51
- console.log(`pluginEvent 2 ${pluginEvent}`)
52
- zone.runOutsideAngular(() => {
53
- console.log(`pluginEvent3 ${pluginEvent}`)
54
- pluginEvent('nulling', this);
55
-
56
- rootEl =
57
- dragEl =
58
- parentEl =
59
- ghostEl =
60
- nextEl =
61
- cloneEl =
62
- lastDownEl =
63
- cloneHidden =
64
-
65
- tapEvt =
66
- touchEvt =
29
+ //private selectframeworkInputCache = new Map<string, { dataIndex: any[], layoutIndex: any[], layoutNode: any }>();
30
+ //TODO review caching-if form field values change, the changes are not propagated
31
+ /*
32
+ getSelectFrameworkInputs(layoutItem: any, i: number) {
33
+ // Create a unique key based on the layoutItem and index
34
+ const cacheKey = `${layoutItem._id}-${i}`;
35
+
36
+ // If the result is already in the cache, return it
37
+ if(this.enableCaching){
38
+ if (this.selectframeworkInputCache.has(cacheKey)) {
39
+ return this.selectframeworkInputCache.get(cacheKey);
40
+ }
41
+ }
67
42
 
68
- moved =
69
- newIndex =
70
- newDraggableIndex =
71
- oldIndex =
72
- oldDraggableIndex =
73
43
 
74
- lastTarget =
75
- lastDirection =
44
+ // If not cached, calculate the values (assuming dataIndex() and layoutIndex() are functions)
45
+ const dataIndex = layoutItem?.arrayItem ? (this.dataIndex() || []).concat(i) : (this.dataIndex() || []);
46
+ const layoutIndex = (this.layoutIndex() || []).concat(i);
76
47
 
77
- putSortable =
78
- activeGroup =
79
- Sortable.dragged =
80
- Sortable.ghost =
81
- Sortable.clone =
82
- Sortable.active = null;
48
+ // Save the result in the cache
49
+ const result = { dataIndex, layoutIndex, layoutNode: layoutItem };
50
+ if(this.enableCaching){
51
+ this.selectframeworkInputCache.set(cacheKey, result);
52
+ }
83
53
 
84
-
85
- let el = this.el;
86
- savedInputChecked.forEach(function (checkEl) {
87
- if (el.contains(checkEl)) {
88
- checkEl.checked = true;
89
- }
90
- });
91
-
92
- savedInputChecked.length =
93
- lastDx =
94
- lastDy = 0;
95
-
96
- })
97
-
98
- }.bind(sortable)
99
- */
54
+ return result;
55
+ }
56
+ */
57
+ this._getSelectFrameworkInputsRaw = (layoutItem, i) => {
58
+ const dataIndexValue = this.dataIndex || [];
59
+ const layoutIndexValue = this.layoutIndex || [];
60
+ return {
61
+ layoutNode: layoutItem,
62
+ layoutIndex: [...layoutIndexValue, i],
63
+ dataIndex: layoutItem?.arrayItem ? [...dataIndexValue, i] : dataIndexValue,
64
+ };
65
+ };
66
+ // Define a separate function to hold the memoized version
67
+ this._getSelectFrameworkInputsMemoized = memoize(this._getSelectFrameworkInputsRaw, (layoutItem, i) => {
68
+ const layoutItemKey = layoutItem?.id ?? JSON.stringify(layoutItem);
69
+ return `${layoutItemKey}-${i}`;
70
+ });
71
+ }
72
+ drop(event) {
73
+ // most likely why this event is used is to get the dragging element's current index
74
+ let srcInd = event.previousIndex;
75
+ let trgInd = event.currentIndex;
76
+ let layoutItem = this.layout[trgInd];
77
+ let dataInd = layoutItem?.arrayItem ? (this.dataIndex || []).concat(trgInd) : (this.dataIndex || []);
78
+ let layoutInd = (this.layoutIndex || []).concat(trgInd);
79
+ let itemCtx = {
80
+ dataIndex: dataInd,
81
+ layoutIndex: layoutInd,
82
+ layoutNode: layoutItem
83
+ };
84
+ this.jsf.moveArrayItem(itemCtx, srcInd, trgInd, true);
100
85
  }
101
86
  isDraggable(node) {
102
87
  let result = node.arrayItem && node.type !== '$ref' &&
103
- node.arrayItemType === 'list' && this.isOrderable !== false;
104
- if (this.sortableObj) {
105
- //this.sortableObj.option("disabled",true);
106
- //this.sortableObj.option("sort",false);
107
- //this.sortableObj.option("disabled",!result);
108
- }
88
+ node.arrayItemType === 'list' && this.isOrderable !== false
89
+ && node.type !== 'submit';
109
90
  return result;
110
91
  }
111
92
  //TODO also need to think of other types such as button which can be
@@ -121,93 +102,157 @@ export class RootComponent {
121
102
  return ((node.options || {}).flex || '').split(/\s+/)[index] ||
122
103
  (node.options || {})[attribute] || ['1', '1', 'auto'][index];
123
104
  }
105
+ // This is the public function that the template calls
106
+ getSelectFrameworkInputs(layoutItem, i) {
107
+ if (this.memoizationEnabled) {
108
+ return this._getSelectFrameworkInputsMemoized(layoutItem, i);
109
+ }
110
+ else {
111
+ return this._getSelectFrameworkInputsRaw(layoutItem, i);
112
+ }
113
+ }
114
+ trackByFn(index, item) {
115
+ return item._id ?? index;
116
+ }
117
+ /*
118
+ ngOnChanges(changes: SimpleChanges): void {
119
+ // If any of the input properties change, clear the cache
120
+ if (changes.dataIndex || changes.layoutIndex || changes.layout) {
121
+ this.selectframeworkInputCache?.clear(); // Clear the entire cache
122
+ }
123
+ }
124
+ */
125
+ ngOnChanges(changes) {
126
+ if (changes['layout'] || changes['dataIndex'] || changes['layoutIndex']) {
127
+ // Clear the entire cache of the memoized function
128
+ this._getSelectFrameworkInputsMemoized.cache.clear();
129
+ }
130
+ }
124
131
  showWidget(layoutNode) {
125
132
  return this.jsf.evaluateCondition(layoutNode, this.dataIndex);
126
133
  }
127
134
  ngOnInit() {
128
- // Subscribe to the draggable state
129
- this.sortableOptionsSubscription = this.jsf.sortableOptions$.subscribe((optsValue) => {
130
- if (this.sortableObj) {
131
- Object.keys(optsValue).forEach(opt => {
132
- let optVal = optsValue[opt];
133
- this.sortableObj.option(opt, optVal);
134
- });
135
- //this.sortableObj.option("disabled",true);
136
- //this.sortableObj.option("sort",false);
137
- }
138
- });
135
+ if (this.memoizationEnabled) {
136
+ this.jsf.dataChanges.subscribe((val) => {
137
+ //this.selectframeworkInputCache?.clear();
138
+ this._getSelectFrameworkInputsMemoized.cache.clear();
139
+ });
140
+ }
139
141
  }
140
142
  ngOnDestroy() {
141
- if (this.sortableOptionsSubscription) {
142
- this.sortableOptionsSubscription.unsubscribe();
143
- }
143
+ //this.selectframeworkInputCache?.clear()
144
+ //this.selectframeworkInputCache=null;
145
+ this._getSelectFrameworkInputsMemoized.cache.clear();
146
+ this.dataChangesSubs?.unsubscribe();
144
147
  }
145
148
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: RootComponent, deps: [{ token: i1.JsonSchemaFormService }], target: i0.ɵɵFactoryTarget.Component }); }
146
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: RootComponent, selector: "root-widget", inputs: { dataIndex: "dataIndex", layoutIndex: "layoutIndex", layout: "layout", isOrderable: "isOrderable", isFlexItem: "isFlexItem" }, ngImport: i0, template: `
147
- <div [class.flex-inherit]="true" #sortableContainter [nxtSortablejs]="layout" [config]="sortableConfig" (init)="sortableInit($event)">
148
- <div *ngFor="let layoutItem of layout; let i = index"
149
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: RootComponent, selector: "root-widget", inputs: { dataIndex: "dataIndex", layoutIndex: "layoutIndex", layout: "layout", isOrderable: "isOrderable", isFlexItem: "isFlexItem", memoizationEnabled: "memoizationEnabled" }, usesOnChanges: true, ngImport: i0, template: `
150
+ <div cdkDropList (cdkDropListDropped)="drop($event)"
151
+ [class.flex-inherit]="true"
152
+ [cdkDropListSortPredicate]="sortPredicate"
153
+ >
154
+ <!-- -for now left out
155
+ cdkDragHandle directive, by itself, does not disable the
156
+ default drag behavior of its parent cdkDrag element.
157
+ You must explicitly disable dragging on the main element
158
+ and re-enable it only when using the handle.
159
+ -->
160
+ <div *ngFor="let layoutItem of layout; let i = index;trackBy: trackByFn"
161
+ cdkDrag [cdkDragStartDelay]="{touch:1000,mouse:0}"
162
+ [cdkDragDisabled]="!isDraggable(layoutItem)"
149
163
  [class.form-flex-item]="isFlexItem"
150
164
  [style.align-self]="(layoutItem.options || {})['align-self']"
151
165
  [style.flex-basis]="getFlexAttribute(layoutItem, 'flex-basis')"
152
166
  [style.flex-grow]="getFlexAttribute(layoutItem, 'flex-grow')"
153
167
  [style.flex-shrink]="getFlexAttribute(layoutItem, 'flex-shrink')"
154
168
  [style.order]="(layoutItem.options || {}).order"
155
- [class.sortable-filter]="!isDraggable(layoutItem)"
156
- [class.sortable-fixed]="isFixed(layoutItem)"
157
169
  >
170
+
171
+ <!-- workaround to disbale dragging of input fields -->
172
+ <!--
173
+ <div *ngIf="layoutItem?.dataType !='object'" cdkDragHandle>
174
+ <p>Drag Handle {{layoutItem?.dataType}}</p>
175
+ </div>
176
+ -->
158
177
  <!--NB orderable directive is not used but has been left in for now and set to false
159
178
  otherwise the compiler won't recognize dataIndex and other dependent attributes
160
179
  -->
180
+ <!--
161
181
  <div
162
182
  [dataIndex]="layoutItem?.arrayItem ? (dataIndex || []).concat(i) : (dataIndex || [])"
163
183
  [layoutIndex]="(layoutIndex || []).concat(i)"
164
184
  [layoutNode]="layoutItem"
165
185
  [orderable]="false"
166
- [class.sortable-filter]="!isDraggable(layoutItem)"
167
- [class.sortable-fixed]="isFixed(layoutItem)"
168
186
  >
169
187
  <select-framework-widget *ngIf="showWidget(layoutItem)"
170
188
  [dataIndex]="layoutItem?.arrayItem ? (dataIndex || []).concat(i) : (dataIndex || [])"
171
189
  [layoutIndex]="(layoutIndex || []).concat(i)"
172
190
  [layoutNode]="layoutItem"></select-framework-widget>
173
191
  </div>
192
+ -->
193
+ <select-framework-widget *ngIf="showWidget(layoutItem)"
194
+ [dataIndex]="getSelectFrameworkInputs(layoutItem,i).dataIndex"
195
+ [layoutIndex]="getSelectFrameworkInputs(layoutItem,i).layoutIndex"
196
+ [layoutNode]="getSelectFrameworkInputs(layoutItem,i).layoutNode">
197
+ </select-framework-widget>
174
198
  </div>
175
199
  </div>
176
- `, isInline: true, styles: ["[draggable=true]{transition:all .15s cubic-bezier(.4,0,.2,1)}[draggable=true]:hover{cursor:move;box-shadow:2px 2px 4px #0003;position:relative;z-index:10;margin:-1px 1px 1px -1px}[draggable=true].drag-target-top{box-shadow:0 -2px #000;position:relative;z-index:20}[draggable=true].drag-target-bottom{box-shadow:0 2px #000;position:relative;z-index:20}.flex-inherit{display:inherit;flex-flow:inherit;flex-wrap:inherit;flex-direction:inherit;width:100%}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.SortablejsDirective, selector: "[nxtSortablejs]", inputs: ["nxtSortablejs", "sortablejsContainer", "config", "cloneFunction"], outputs: ["init"] }, { kind: "component", type: i4.SelectFrameworkComponent, selector: "select-framework-widget", inputs: ["layoutNode", "layoutIndex", "dataIndex"] }, { kind: "directive", type: i5.OrderableDirective, selector: "[orderable]", inputs: ["orderable", "layoutNode", "layoutIndex", "dataIndex"] }] }); }
200
+ `, isInline: true, styles: ["[draggable=true]{transition:all .15s cubic-bezier(.4,0,.2,1)}[draggable=true]:hover{cursor:move;box-shadow:2px 2px 4px #0003;position:relative;z-index:10;margin:-1px 1px 1px -1px}[draggable=true].drag-target-top{box-shadow:0 -2px #000;position:relative;z-index:20}[draggable=true].drag-target-bottom{box-shadow:0 2px #000;position:relative;z-index:20}.flex-inherit{display:inherit;flex-flow:inherit;flex-wrap:inherit;flex-direction:inherit;width:100%}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.CdkDropList, selector: "[cdkDropList], cdk-drop-list", inputs: ["cdkDropListConnectedTo", "cdkDropListData", "cdkDropListOrientation", "id", "cdkDropListLockAxis", "cdkDropListDisabled", "cdkDropListSortingDisabled", "cdkDropListEnterPredicate", "cdkDropListSortPredicate", "cdkDropListAutoScrollDisabled", "cdkDropListAutoScrollStep"], outputs: ["cdkDropListDropped", "cdkDropListEntered", "cdkDropListExited", "cdkDropListSorted"], exportAs: ["cdkDropList"] }, { kind: "directive", type: i3.CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }, { kind: "component", type: i4.SelectFrameworkComponent, selector: "select-framework-widget", inputs: ["layoutNode", "layoutIndex", "dataIndex"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
177
201
  }
178
202
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: RootComponent, decorators: [{
179
203
  type: Component,
180
204
  args: [{ selector: 'root-widget', template: `
181
- <div [class.flex-inherit]="true" #sortableContainter [nxtSortablejs]="layout" [config]="sortableConfig" (init)="sortableInit($event)">
182
- <div *ngFor="let layoutItem of layout; let i = index"
205
+ <div cdkDropList (cdkDropListDropped)="drop($event)"
206
+ [class.flex-inherit]="true"
207
+ [cdkDropListSortPredicate]="sortPredicate"
208
+ >
209
+ <!-- -for now left out
210
+ cdkDragHandle directive, by itself, does not disable the
211
+ default drag behavior of its parent cdkDrag element.
212
+ You must explicitly disable dragging on the main element
213
+ and re-enable it only when using the handle.
214
+ -->
215
+ <div *ngFor="let layoutItem of layout; let i = index;trackBy: trackByFn"
216
+ cdkDrag [cdkDragStartDelay]="{touch:1000,mouse:0}"
217
+ [cdkDragDisabled]="!isDraggable(layoutItem)"
183
218
  [class.form-flex-item]="isFlexItem"
184
219
  [style.align-self]="(layoutItem.options || {})['align-self']"
185
220
  [style.flex-basis]="getFlexAttribute(layoutItem, 'flex-basis')"
186
221
  [style.flex-grow]="getFlexAttribute(layoutItem, 'flex-grow')"
187
222
  [style.flex-shrink]="getFlexAttribute(layoutItem, 'flex-shrink')"
188
223
  [style.order]="(layoutItem.options || {}).order"
189
- [class.sortable-filter]="!isDraggable(layoutItem)"
190
- [class.sortable-fixed]="isFixed(layoutItem)"
191
224
  >
225
+
226
+ <!-- workaround to disbale dragging of input fields -->
227
+ <!--
228
+ <div *ngIf="layoutItem?.dataType !='object'" cdkDragHandle>
229
+ <p>Drag Handle {{layoutItem?.dataType}}</p>
230
+ </div>
231
+ -->
192
232
  <!--NB orderable directive is not used but has been left in for now and set to false
193
233
  otherwise the compiler won't recognize dataIndex and other dependent attributes
194
234
  -->
235
+ <!--
195
236
  <div
196
237
  [dataIndex]="layoutItem?.arrayItem ? (dataIndex || []).concat(i) : (dataIndex || [])"
197
238
  [layoutIndex]="(layoutIndex || []).concat(i)"
198
239
  [layoutNode]="layoutItem"
199
240
  [orderable]="false"
200
- [class.sortable-filter]="!isDraggable(layoutItem)"
201
- [class.sortable-fixed]="isFixed(layoutItem)"
202
241
  >
203
242
  <select-framework-widget *ngIf="showWidget(layoutItem)"
204
243
  [dataIndex]="layoutItem?.arrayItem ? (dataIndex || []).concat(i) : (dataIndex || [])"
205
244
  [layoutIndex]="(layoutIndex || []).concat(i)"
206
245
  [layoutNode]="layoutItem"></select-framework-widget>
207
246
  </div>
247
+ -->
248
+ <select-framework-widget *ngIf="showWidget(layoutItem)"
249
+ [dataIndex]="getSelectFrameworkInputs(layoutItem,i).dataIndex"
250
+ [layoutIndex]="getSelectFrameworkInputs(layoutItem,i).layoutIndex"
251
+ [layoutNode]="getSelectFrameworkInputs(layoutItem,i).layoutNode">
252
+ </select-framework-widget>
208
253
  </div>
209
254
  </div>
210
- `, standalone: false, styles: ["[draggable=true]{transition:all .15s cubic-bezier(.4,0,.2,1)}[draggable=true]:hover{cursor:move;box-shadow:2px 2px 4px #0003;position:relative;z-index:10;margin:-1px 1px 1px -1px}[draggable=true].drag-target-top{box-shadow:0 -2px #000;position:relative;z-index:20}[draggable=true].drag-target-bottom{box-shadow:0 2px #000;position:relative;z-index:20}.flex-inherit{display:inherit;flex-flow:inherit;flex-wrap:inherit;flex-direction:inherit;width:100%}\n"] }]
255
+ `, changeDetection: ChangeDetectionStrategy.OnPush, standalone: false, styles: ["[draggable=true]{transition:all .15s cubic-bezier(.4,0,.2,1)}[draggable=true]:hover{cursor:move;box-shadow:2px 2px 4px #0003;position:relative;z-index:10;margin:-1px 1px 1px -1px}[draggable=true].drag-target-top{box-shadow:0 -2px #000;position:relative;z-index:20}[draggable=true].drag-target-bottom{box-shadow:0 2px #000;position:relative;z-index:20}.flex-inherit{display:inherit;flex-flow:inherit;flex-wrap:inherit;flex-direction:inherit;width:100%}\n"] }]
211
256
  }], ctorParameters: function () { return [{ type: i1.JsonSchemaFormService }]; }, propDecorators: { dataIndex: [{
212
257
  type: Input
213
258
  }], layoutIndex: [{
@@ -218,5 +263,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
218
263
  type: Input
219
264
  }], isFlexItem: [{
220
265
  type: Input
266
+ }], memoizationEnabled: [{
267
+ type: Input
221
268
  }] } });
222
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"root.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-formworks-core/src/lib/widget-library/root.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnDestroy, OnInit } from '@angular/core';\r\nimport { Subscription } from 'rxjs';\r\nimport { JsonSchemaFormService } from '../json-schema-form.service';\r\n@Component({\r\n  // tslint:disable-next-line:component-selector\r\n  selector: 'root-widget',\r\n  template: `\r\n    <div [class.flex-inherit]=\"true\" #sortableContainter [nxtSortablejs]=\"layout\" [config]=\"sortableConfig\" (init)=\"sortableInit($event)\">\r\n      <div *ngFor=\"let layoutItem of layout; let i = index\"\r\n        [class.form-flex-item]=\"isFlexItem\"\r\n        [style.align-self]=\"(layoutItem.options || {})['align-self']\"\r\n        [style.flex-basis]=\"getFlexAttribute(layoutItem, 'flex-basis')\"\r\n        [style.flex-grow]=\"getFlexAttribute(layoutItem, 'flex-grow')\"\r\n        [style.flex-shrink]=\"getFlexAttribute(layoutItem, 'flex-shrink')\"\r\n        [style.order]=\"(layoutItem.options || {}).order\"\r\n        [class.sortable-filter]=\"!isDraggable(layoutItem)\"\r\n        [class.sortable-fixed]=\"isFixed(layoutItem)\"\r\n        >\r\n        <!--NB orderable directive is not used but has been left in for now and set to false\r\n          otherwise the compiler won't recognize dataIndex and other dependent attributes\r\n        -->\r\n        <div \r\n          [dataIndex]=\"layoutItem?.arrayItem ? (dataIndex || []).concat(i) : (dataIndex || [])\"\r\n          [layoutIndex]=\"(layoutIndex || []).concat(i)\"\r\n          [layoutNode]=\"layoutItem\"\r\n          [orderable]=\"false\"\r\n          [class.sortable-filter]=\"!isDraggable(layoutItem)\"\r\n          [class.sortable-fixed]=\"isFixed(layoutItem)\"\r\n          >\r\n          <select-framework-widget *ngIf=\"showWidget(layoutItem)\"\r\n            [dataIndex]=\"layoutItem?.arrayItem ? (dataIndex || []).concat(i) : (dataIndex || [])\"\r\n            [layoutIndex]=\"(layoutIndex || []).concat(i)\"\r\n            [layoutNode]=\"layoutItem\"></select-framework-widget>\r\n        </div>\r\n      </div>\r\n    </div>\r\n    `,\r\n  styles: [`\r\n    [draggable=true] {\r\n      transition: all 150ms cubic-bezier(.4, 0, .2, 1);\r\n    }\r\n    [draggable=true]:hover {\r\n      cursor: move;\r\n      box-shadow: 2px 2px 4px rgba(0, 0, 0, 0.2);\r\n      position: relative; z-index: 10;\r\n      margin-top: -1px;\r\n      margin-left: -1px;\r\n      margin-right: 1px;\r\n      margin-bottom: 1px;\r\n    }\r\n    [draggable=true].drag-target-top {\r\n      box-shadow: 0 -2px 0 #000;\r\n      position: relative; z-index: 20;\r\n    }\r\n    [draggable=true].drag-target-bottom {\r\n      box-shadow: 0 2px 0 #000;\r\n      position: relative; z-index: 20;\r\n    }\r\n    .flex-inherit{\r\n      display:inherit;\r\n      flex-flow:inherit;\r\n      flex-wrap:inherit;\r\n      flex-direction:inherit;\r\n      width:100%\r\n    }\r\n  `],\r\n  standalone: false\r\n})\r\n\r\n\r\nexport class RootComponent implements OnInit, OnDestroy{\r\n  options: any;\r\n  @Input() dataIndex: number[];\r\n  @Input() layoutIndex: number[];\r\n  @Input() layout: any[];\r\n  @Input() isOrderable: boolean;\r\n  @Input() isFlexItem = false;\r\n\r\n  constructor(\r\n    private jsf: JsonSchemaFormService\r\n  ) { }\r\n  // @ViewChild('sortableContainter', {})\r\n  // sortableContainterElt: ElementRef;\r\n\r\n  sortableObj: any;\r\n  sortableConfig:any={\r\n    filter:\".sortable-filter\",//needed to disable dragging on input range elements, class needs to be added to the element or its parent\r\n    preventOnFilter: false,//needed for input range elements slider do still work\r\n    onEnd: (/**Event*/evt)=> {\r\n      evt.newIndex // most likely why this event is used is to get the dragging element's current index\r\n      // same properties as onEnd\r\n      //console.log(`sortablejs event:${evt}`);\r\n      let srcInd=evt.oldIndex;\r\n      let trgInd=evt.newIndex;\r\n      let layoutItem=this.layout[trgInd];\r\n      let dataInd=layoutItem?.arrayItem ? (this.dataIndex || []).concat(trgInd) : (this.dataIndex || []);\r\n      let layoutInd=(this.layoutIndex || []).concat(trgInd)\r\n      let itemCtx:any={\r\n        dataIndex:dataInd,\r\n        layoutIndex:layoutInd,\r\n        layoutNode:layoutItem,\r\n      }\r\n      //must set moveLayout to false as nxtSortable already moves it\r\n      this.jsf.moveArrayItem(itemCtx, evt.oldIndex, evt.newIndex,false);\r\n      \r\n    },\r\n    onMove: function (/**Event*/evt, /**Event*/originalEvent) {\r\n      if(evt.related.classList.contains(\"sortable-fixed\")){\r\n       //console.log(evt.related);\r\n       return false;\r\n     }\r\n   }\r\n  }\r\n  private sortableOptionsSubscription: Subscription;\r\n  sortableInit(sortable) {\r\n    this.sortableObj = sortable;\r\n    //Sortable.utils.on(this.sortableObj.el,\"nulling\",(s)=>{console.log(\"event nulling sortablejs\")})\r\n    ///NB issue caused by sortablejs when it its destroyed\r\n    //this mainly affects checkboxes coupled with conditions\r\n    //-the value is rechecked\r\n    //-see https://github.com/SortableJS/Sortable/issues/1052#issuecomment-369613072\r\n    /* attempt to monkey patch sortable js \r\n    const originalMethod = sortable._nulling;\r\n    let zone=this.zone;\r\n    sortable._nulling=function() {\r\n      console.log(`pluginEvent 2 ${pluginEvent}`)\r\n            zone.runOutsideAngular(() => {\r\n              console.log(`pluginEvent3 ${pluginEvent}`)\r\n      pluginEvent('nulling', this);\r\n  \r\n      rootEl =\r\n      dragEl =\r\n      parentEl =\r\n      ghostEl =\r\n      nextEl =\r\n      cloneEl =\r\n      lastDownEl =\r\n      cloneHidden =\r\n  \r\n      tapEvt =\r\n      touchEvt =\r\n  \r\n      moved =\r\n      newIndex =\r\n      newDraggableIndex =\r\n      oldIndex =\r\n      oldDraggableIndex =\r\n  \r\n      lastTarget =\r\n      lastDirection =\r\n  \r\n      putSortable =\r\n      activeGroup =\r\n      Sortable.dragged =\r\n      Sortable.ghost =\r\n      Sortable.clone =\r\n      Sortable.active = null;\r\n  \r\n    \r\n        let el = this.el;\r\n        savedInputChecked.forEach(function (checkEl) {\r\n          if (el.contains(checkEl)) {\r\n            checkEl.checked = true;\r\n          }\r\n        });\r\n    \r\n        savedInputChecked.length =\r\n        lastDx =\r\n        lastDy = 0;\r\n\r\n      })\r\n\r\n    }.bind(sortable)\r\n    */\r\n  }\r\n\r\n  isDraggable(node: any): boolean {\r\n    let result=node.arrayItem && node.type !== '$ref' &&\r\n    node.arrayItemType === 'list' && this.isOrderable !== false;\r\n    if (this.sortableObj) {\r\n      //this.sortableObj.option(\"disabled\",true);\r\n      //this.sortableObj.option(\"sort\",false);\r\n      //this.sortableObj.option(\"disabled\",!result);\r\n    }\r\n\r\n    return result;\r\n  }\r\n\r\n  //TODO also need to think of other types such as button which can be\r\n  //created by an arbitrary layout\r\n  isFixed(node: any): boolean {\r\n    let result=node.type == '$ref';\r\n    return result;\r\n  }\r\n\r\n  // Set attributes for flexbox child\r\n  // (container attributes are set in section.component)\r\n  getFlexAttribute(node: any, attribute: string) {\r\n    const index = ['flex-grow', 'flex-shrink', 'flex-basis'].indexOf(attribute);\r\n    return ((node.options || {}).flex || '').split(/\\s+/)[index] ||\r\n      (node.options || {})[attribute] || ['1', '1', 'auto'][index];\r\n  }\r\n\r\n  showWidget(layoutNode: any): boolean {\r\n    return this.jsf.evaluateCondition(layoutNode, this.dataIndex);\r\n  }\r\n  ngOnInit(): void {\r\n    // Subscribe to the draggable state\r\n    this.sortableOptionsSubscription = this.jsf.sortableOptions$.subscribe(\r\n      (optsValue) => {\r\n        if (this.sortableObj) {\r\n          Object.keys(optsValue).forEach(opt=>{\r\n            let optVal=optsValue[opt];\r\n            this.sortableObj.option(opt,optVal);\r\n          })\r\n          //this.sortableObj.option(\"disabled\",true);\r\n          //this.sortableObj.option(\"sort\",false);\r\n        }\r\n      }\r\n    );\r\n  }\r\n  ngOnDestroy(): void {\r\n    if (this.sortableOptionsSubscription) {\r\n      this.sortableOptionsSubscription.unsubscribe();\r\n    }\r\n  }\r\n}\r\n"]}
269
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"root.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-formworks-core/src/lib/widget-library/root.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { CdkDrag, CdkDragDrop } from '@angular/cdk/drag-drop';\r\nimport { ChangeDetectionStrategy, Component, Input, OnChanges, OnDestroy, OnInit, SimpleChanges } from '@angular/core';\r\nimport { memoize } from 'lodash';\r\nimport { Subscription } from 'rxjs';\r\nimport { JsonSchemaFormService } from '../json-schema-form.service';\r\n@Component({\r\n  // tslint:disable-next-line:component-selector\r\n  selector: 'root-widget',\r\n  template: `\r\n    <div cdkDropList (cdkDropListDropped)=\"drop($event)\" \r\n      [class.flex-inherit]=\"true\"\r\n      [cdkDropListSortPredicate]=\"sortPredicate\"\r\n    >\r\n      <!-- -for now left out\r\n      cdkDragHandle directive, by itself, does not disable the \r\n      default drag behavior of its parent cdkDrag element. \r\n      You must explicitly disable dragging on the main element \r\n      and re-enable it only when using the handle.\r\n      -->\r\n      <div *ngFor=\"let layoutItem of layout; let i = index;trackBy: trackByFn\"\r\n         cdkDrag  [cdkDragStartDelay]=\"{touch:1000,mouse:0}\"\r\n        [cdkDragDisabled]=\"!isDraggable(layoutItem)\"\r\n        [class.form-flex-item]=\"isFlexItem\"\r\n        [style.align-self]=\"(layoutItem.options || {})['align-self']\"\r\n        [style.flex-basis]=\"getFlexAttribute(layoutItem, 'flex-basis')\"\r\n        [style.flex-grow]=\"getFlexAttribute(layoutItem, 'flex-grow')\"\r\n        [style.flex-shrink]=\"getFlexAttribute(layoutItem, 'flex-shrink')\"\r\n        [style.order]=\"(layoutItem.options || {}).order\"\r\n        >\r\n\r\n        <!-- workaround to disbale dragging of input fields -->\r\n        <!--\r\n        <div *ngIf=\"layoutItem?.dataType !='object'\"  cdkDragHandle>\r\n         <p>Drag Handle {{layoutItem?.dataType}}</p>\r\n        </div>\r\n        -->\r\n        <!--NB orderable directive is not used but has been left in for now and set to false\r\n          otherwise the compiler won't recognize dataIndex and other dependent attributes\r\n        -->\r\n        <!--\r\n        <div \r\n          [dataIndex]=\"layoutItem?.arrayItem ? (dataIndex || []).concat(i) : (dataIndex || [])\"\r\n          [layoutIndex]=\"(layoutIndex || []).concat(i)\"\r\n          [layoutNode]=\"layoutItem\"\r\n          [orderable]=\"false\"\r\n          >\r\n          <select-framework-widget *ngIf=\"showWidget(layoutItem)\"\r\n            [dataIndex]=\"layoutItem?.arrayItem ? (dataIndex || []).concat(i) : (dataIndex || [])\"\r\n            [layoutIndex]=\"(layoutIndex || []).concat(i)\"\r\n            [layoutNode]=\"layoutItem\"></select-framework-widget>\r\n        </div>\r\n        -->\r\n      <select-framework-widget *ngIf=\"showWidget(layoutItem)\"\r\n            [dataIndex]=\"getSelectFrameworkInputs(layoutItem,i).dataIndex\"\r\n            [layoutIndex]=\"getSelectFrameworkInputs(layoutItem,i).layoutIndex\"\r\n            [layoutNode]=\"getSelectFrameworkInputs(layoutItem,i).layoutNode\">\r\n\t\t  </select-framework-widget>\r\n      </div>\r\n    </div>\r\n    `,\r\n  styles: [`\r\n    [draggable=true] {\r\n      transition: all 150ms cubic-bezier(.4, 0, .2, 1);\r\n    }\r\n    [draggable=true]:hover {\r\n      cursor: move;\r\n      box-shadow: 2px 2px 4px rgba(0, 0, 0, 0.2);\r\n      position: relative; z-index: 10;\r\n      margin-top: -1px;\r\n      margin-left: -1px;\r\n      margin-right: 1px;\r\n      margin-bottom: 1px;\r\n    }\r\n    [draggable=true].drag-target-top {\r\n      box-shadow: 0 -2px 0 #000;\r\n      position: relative; z-index: 20;\r\n    }\r\n    [draggable=true].drag-target-bottom {\r\n      box-shadow: 0 2px 0 #000;\r\n      position: relative; z-index: 20;\r\n    }\r\n    .flex-inherit{\r\n      display:inherit;\r\n      flex-flow:inherit;\r\n      flex-wrap:inherit;\r\n      flex-direction:inherit;\r\n      width:100%\r\n    }\r\n  `],\r\n  changeDetection:ChangeDetectionStrategy.OnPush,\r\n  standalone: false\r\n})\r\n\r\n\r\nexport class RootComponent implements OnInit, OnDestroy,OnChanges{\r\n  options: any;\r\n  @Input() dataIndex: number[];\r\n  @Input() layoutIndex: number[];\r\n  @Input() layout: any[];\r\n  @Input() isOrderable: boolean;\r\n  @Input() isFlexItem = false;\r\n  @Input() memoizationEnabled= true;\r\n\r\n  dataChangesSubs:Subscription;\r\n  constructor(\r\n    private jsf: JsonSchemaFormService\r\n  ) { }\r\n\r\n\r\n  drop(event: CdkDragDrop<string[]>) {\r\n    // most likely why this event is used is to get the dragging element's current index\r\n    let srcInd=event.previousIndex;\r\n    let trgInd=event.currentIndex;\r\n    let layoutItem=this.layout[trgInd];\r\n    let dataInd=layoutItem?.arrayItem ? (this.dataIndex || []).concat(trgInd) : (this.dataIndex || []);\r\n    let layoutInd=(this.layoutIndex || []).concat(trgInd)\r\n    let itemCtx:any={\r\n      dataIndex:dataInd,\r\n      layoutIndex: layoutInd,\r\n      layoutNode: layoutItem\r\n    }\r\n    this.jsf.moveArrayItem(itemCtx, srcInd, trgInd,true);\r\n  }\r\n\r\n  isDraggable(node: any): boolean {\r\n    let result=node.arrayItem && node.type !== '$ref' &&\r\n    node.arrayItemType === 'list' && this.isOrderable !== false\r\n    && node.type !=='submit'\r\n    return result;\r\n  }\r\n\r\n  //TODO also need to think of other types such as button which can be\r\n  //created by an arbitrary layout\r\n  isFixed(node: any): boolean {\r\n    let result=node.type == '$ref';\r\n    return result;\r\n  }\r\n\r\n  /**\r\n   * Predicate function that disallows '$ref' item sorts\r\n   * NB declared as a var instead of a function \r\n   * like sortPredicate(index: number, item: CdkDrag<number>){..}\r\n   * since 'this' is bound to the draglist and doesn't reference the\r\n   * FlexLayoutRootComponent instance\r\n   */\r\n    //TODO also need to think of other types such as button which can be\r\n    //created by an arbitrary layout\r\n    //might not be needed added condition to [cdkDragDisabled]\r\n    sortPredicate=(index: number, item: CdkDrag<number>)=> {\r\n      let layoutItem=this.layout[index];\r\n      let result=this.isDraggable(layoutItem);\r\n      //layoutItem.type != '$ref';\r\n      return result;\r\n    }\r\n\r\n  // Set attributes for flexbox child\r\n  // (container attributes are set in section.component)\r\n  getFlexAttribute(node: any, attribute: string) {\r\n    const index = ['flex-grow', 'flex-shrink', 'flex-basis'].indexOf(attribute);\r\n    return ((node.options || {}).flex || '').split(/\\s+/)[index] ||\r\n      (node.options || {})[attribute] || ['1', '1', 'auto'][index];\r\n  }\r\n\r\n  //private selectframeworkInputCache = new Map<string, { dataIndex: any[], layoutIndex: any[], layoutNode: any }>();\r\n\r\n  //TODO review caching-if form field values change, the changes are not propagated\r\n\r\n  /*\r\n  getSelectFrameworkInputs(layoutItem: any, i: number) {\r\n    // Create a unique key based on the layoutItem and index\r\n    const cacheKey = `${layoutItem._id}-${i}`;\r\n  \r\n    // If the result is already in the cache, return it\r\n    if(this.enableCaching){\r\n      if (this.selectframeworkInputCache.has(cacheKey)) {\r\n        return this.selectframeworkInputCache.get(cacheKey);\r\n      }\r\n    }\r\n\r\n\r\n    // If not cached, calculate the values (assuming dataIndex() and layoutIndex() are functions)\r\n    const dataIndex = layoutItem?.arrayItem ? (this.dataIndex() || []).concat(i) : (this.dataIndex() || []);\r\n    const layoutIndex = (this.layoutIndex() || []).concat(i);\r\n\r\n    // Save the result in the cache\r\n    const result = { dataIndex, layoutIndex, layoutNode: layoutItem };\r\n    if(this.enableCaching){\r\n      this.selectframeworkInputCache.set(cacheKey, result);\r\n    }\r\n\r\n    return result;\r\n  }\r\n    */\r\n\r\n  private _getSelectFrameworkInputsRaw = (layoutItem: any, i: number) => {\r\n    const dataIndexValue = this.dataIndex || [];\r\n    const layoutIndexValue = this.layoutIndex || [];\r\n\r\n    return {\r\n      layoutNode: layoutItem,\r\n      layoutIndex: [...layoutIndexValue, i],\r\n      dataIndex: layoutItem?.arrayItem ? [...dataIndexValue, i] : dataIndexValue,\r\n    };\r\n  };\r\n\r\n  // Define a separate function to hold the memoized version\r\n  private _getSelectFrameworkInputsMemoized = memoize(\r\n    this._getSelectFrameworkInputsRaw,\r\n    (layoutItem: any, i: number) => {\r\n      const layoutItemKey = layoutItem?.id ?? JSON.stringify(layoutItem);\r\n      return `${layoutItemKey}-${i}`;\r\n    }\r\n  );\r\n\r\n  // This is the public function that the template calls\r\n  getSelectFrameworkInputs(layoutItem: any, i: number) {\r\n    if (this.memoizationEnabled) {\r\n      return this._getSelectFrameworkInputsMemoized(layoutItem, i);\r\n    } else {\r\n      return this._getSelectFrameworkInputsRaw(layoutItem, i);\r\n    }\r\n  }\r\n  trackByFn(index: number, item: any): any {\r\n    return item._id ?? index;\r\n  }\r\n\r\n  \r\n\r\n  /*\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    // If any of the input properties change, clear the cache\r\n    if (changes.dataIndex || changes.layoutIndex || changes.layout) {\r\n      this.selectframeworkInputCache?.clear(); // Clear the entire cache\r\n    }\r\n  }\r\n  */\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes['layout'] || changes['dataIndex'] || changes['layoutIndex']) {\r\n      // Clear the entire cache of the memoized function\r\n      this._getSelectFrameworkInputsMemoized.cache.clear();\r\n    }\r\n  }\r\n\r\n\r\n  showWidget(layoutNode: any): boolean {\r\n    return this.jsf.evaluateCondition(layoutNode, this.dataIndex);\r\n  }\r\n  ngOnInit(): void {\r\n      if(this.memoizationEnabled){\r\n        this.jsf.dataChanges.subscribe((val)=>{\r\n          //this.selectframeworkInputCache?.clear();\r\n          this._getSelectFrameworkInputsMemoized.cache.clear();\r\n        })\r\n      }\r\n\r\n  }\r\n  ngOnDestroy(): void {\r\n      //this.selectframeworkInputCache?.clear()\r\n      //this.selectframeworkInputCache=null;\r\n      this._getSelectFrameworkInputsMemoized.cache.clear();\r\n      this.dataChangesSubs?.unsubscribe();\r\n  }\r\n  \r\n\r\n}\r\n"]}
@@ -123,7 +123,7 @@ export class SectionComponent {
123
123
  [class]="options?.labelHelpBlockClass || ''"
124
124
  [innerHTML]="options?.description"></p>
125
125
  </div>
126
- </fieldset>`, isInline: true, styles: [".legend{font-weight:700}.expandable>legend:before,.expandable>label:before{content:\"\\25b6\";padding-right:.3em;font-family:auto}.expanded>legend:before,.expanded>label:before{content:\"\\25bc\";padding-right:.2em}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.RootComponent, selector: "root-widget", inputs: ["dataIndex", "layoutIndex", "layout", "isOrderable", "isFlexItem"] }] }); }
126
+ </fieldset>`, isInline: true, styles: [".legend{font-weight:700}.expandable>legend:before,.expandable>label:before{content:\"\\25b6\";padding-right:.3em;font-family:auto}.expanded>legend:before,.expanded>label:before{content:\"\\25bc\";padding-right:.2em}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.RootComponent, selector: "root-widget", inputs: ["dataIndex", "layoutIndex", "layout", "isOrderable", "isFlexItem", "memoizationEnabled"] }] }); }
127
127
  }
128
128
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SectionComponent, decorators: [{
129
129
  type: Component,
@@ -196,4 +196,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
196
196
  }], dataIndex: [{
197
197
  type: Input
198
198
  }] } });
199
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"section.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-formworks-core/src/lib/widget-library/section.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit } from '@angular/core';\r\nimport { JsonSchemaFormService } from '../json-schema-form.service';\r\n\r\n\r\n@Component({\r\n  // tslint:disable-next-line:component-selector\r\n  selector: '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\"\r\n        [class]=\"options?.labelHtmlClass || ''\"\r\n        [innerHTML]=\"sectionTitle\"\r\n        (click)=\"toggleExpanded()\"></label>\r\n      <root-widget \r\n        [dataIndex]=\"dataIndex\"\r\n        [layout]=\"layoutNode.items\"\r\n        [layoutIndex]=\"layoutIndex\"\r\n        [isFlexItem]=\"getFlexAttribute('is-flex')\"\r\n        [isOrderable]=\"options?.orderable\"\r\n        [class.form-flex-column]=\"getFlexAttribute('flex-direction') === 'column'\"\r\n        [class.form-flex-row]=\"getFlexAttribute('flex-direction') === 'row'\"\r\n        [style.align-content]=\"getFlexAttribute('align-content')\"\r\n        [style.align-items]=\"getFlexAttribute('align-items')\"\r\n        [style.display]=\"!expanded?'none':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')\"></root-widget>\r\n    </div>\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\"\r\n        [class]=\"options?.labelHtmlClass || ''\"\r\n        [innerHTML]=\"sectionTitle\"\r\n        (click)=\"toggleExpanded()\"></legend>\r\n      <div *ngIf=\"options?.messageLocation !== 'bottom'\">\r\n        <p *ngIf=\"options?.description\"\r\n        class=\"help-block\"\r\n        [class]=\"options?.labelHelpBlockClass || ''\"\r\n        [innerHTML]=\"options?.description\"></p>\r\n      </div>\r\n      <root-widget \r\n        [dataIndex]=\"dataIndex\"\r\n        [layout]=\"layoutNode.items\"\r\n        [layoutIndex]=\"layoutIndex\"\r\n        [isFlexItem]=\"getFlexAttribute('is-flex')\"\r\n        [isOrderable]=\"options?.orderable\"\r\n        [class.form-flex-column]=\"getFlexAttribute('flex-direction') === 'column'\"\r\n        [class.form-flex-row]=\"getFlexAttribute('flex-direction') === 'row'\"\r\n        [style.align-content]=\"getFlexAttribute('align-content')\"\r\n        [style.align-items]=\"getFlexAttribute('align-items')\"\r\n        [style.display]=\"!expanded?'none':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')\"></root-widget>\r\n      <div *ngIf=\"options?.messageLocation === 'bottom'\">\r\n        <p *ngIf=\"options?.description\"\r\n        class=\"help-block\"\r\n        [class]=\"options?.labelHelpBlockClass || ''\"\r\n        [innerHTML]=\"options?.description\"></p>\r\n      </div>\r\n    </fieldset>`,\r\n  styles: [`\r\n    .legend { font-weight: bold; }\r\n    .expandable > legend:before, .expandable > label:before  { content: '▶'; padding-right: .3em; font-family:auto }\r\n    .expanded > legend:before, .expanded > label:before  { content: '▼'; padding-right: .2em; }\r\n  `],\r\n})\r\nexport class SectionComponent implements OnInit {\r\n  options: any;\r\n  expanded = true;\r\n  containerType: string;\r\n  @Input() layoutNode: any;\r\n  @Input() layoutIndex: number[];\r\n  @Input() dataIndex: number[];\r\n\r\n  constructor(\r\n    private jsf: JsonSchemaFormService\r\n  ) { }\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 'fieldset': case 'array': case 'tab': case 'advancedfieldset':\r\n      case 'authfieldset': case 'optionfieldset': case 'selectfieldset':\r\n        this.containerType = 'fieldset';\r\n      break;\r\n      default: // 'div', 'flex', 'section', 'conditional', 'actions', 'tagsinput'\r\n        this.containerType = 'div';\r\n      break;\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 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    }\r\n  }\r\n}\r\n"]}
199
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"section.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-formworks-core/src/lib/widget-library/section.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit } from '@angular/core';\r\nimport { JsonSchemaFormService } from '../json-schema-form.service';\r\n\r\n\r\n@Component({\r\n  // tslint:disable-next-line:component-selector\r\n  selector: '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\"\r\n        [class]=\"options?.labelHtmlClass || ''\"\r\n        [innerHTML]=\"sectionTitle\"\r\n        (click)=\"toggleExpanded()\"></label>\r\n      <root-widget \r\n        [dataIndex]=\"dataIndex\"\r\n        [layout]=\"layoutNode.items\"\r\n        [layoutIndex]=\"layoutIndex\"\r\n        [isFlexItem]=\"getFlexAttribute('is-flex')\"\r\n        [isOrderable]=\"options?.orderable\"\r\n        [class.form-flex-column]=\"getFlexAttribute('flex-direction') === 'column'\"\r\n        [class.form-flex-row]=\"getFlexAttribute('flex-direction') === 'row'\"\r\n        [style.align-content]=\"getFlexAttribute('align-content')\"\r\n        [style.align-items]=\"getFlexAttribute('align-items')\"\r\n        [style.display]=\"!expanded?'none':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')\"></root-widget>\r\n    </div>\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\"\r\n        [class]=\"options?.labelHtmlClass || ''\"\r\n        [innerHTML]=\"sectionTitle\"\r\n        (click)=\"toggleExpanded()\"></legend>\r\n      <div *ngIf=\"options?.messageLocation !== 'bottom'\">\r\n        <p *ngIf=\"options?.description\"\r\n        class=\"help-block\"\r\n        [class]=\"options?.labelHelpBlockClass || ''\"\r\n        [innerHTML]=\"options?.description\"></p>\r\n      </div>\r\n      <root-widget \r\n        [dataIndex]=\"dataIndex\"\r\n        [layout]=\"layoutNode.items\"\r\n        [layoutIndex]=\"layoutIndex\"\r\n        [isFlexItem]=\"getFlexAttribute('is-flex')\"\r\n        [isOrderable]=\"options?.orderable\"\r\n        [class.form-flex-column]=\"getFlexAttribute('flex-direction') === 'column'\"\r\n        [class.form-flex-row]=\"getFlexAttribute('flex-direction') === 'row'\"\r\n        [style.align-content]=\"getFlexAttribute('align-content')\"\r\n        [style.align-items]=\"getFlexAttribute('align-items')\"\r\n        [style.display]=\"!expanded?'none':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')\"></root-widget>\r\n      <div *ngIf=\"options?.messageLocation === 'bottom'\">\r\n        <p *ngIf=\"options?.description\"\r\n        class=\"help-block\"\r\n        [class]=\"options?.labelHelpBlockClass || ''\"\r\n        [innerHTML]=\"options?.description\"></p>\r\n      </div>\r\n    </fieldset>`,\r\n  styles: [`\r\n    .legend { font-weight: bold; }\r\n    .expandable > legend:before, .expandable > label:before  { content: '▶'; padding-right: .3em; font-family:auto }\r\n    .expanded > legend:before, .expanded > label:before  { content: '▼'; padding-right: .2em; }\r\n  `],\r\n})\r\nexport class SectionComponent implements OnInit {\r\n  options: any;\r\n  expanded = true;\r\n  containerType: string;\r\n  @Input() layoutNode: any;\r\n  @Input() layoutIndex: number[];\r\n  @Input() dataIndex: number[];\r\n\r\n  constructor(\r\n    private jsf: JsonSchemaFormService\r\n  ) { }\r\n\r\n  get sectionTitle() {\r\n    return this.options.notitle ? null : this.jsf.setItemTitle(this);\r\n  }\r\n\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 'fieldset': case 'array': case 'tab': case 'advancedfieldset':\r\n      case 'authfieldset': case 'optionfieldset': case 'selectfieldset':\r\n        this.containerType = 'fieldset';\r\n      break;\r\n      default: // 'div', 'flex', 'section', 'conditional', 'actions', 'tagsinput'\r\n        this.containerType = 'div';\r\n      break;\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 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    }\r\n  }\r\n}\r\n"]}
@@ -9,7 +9,7 @@ export class SelectFrameworkComponent {
9
9
  ngOnInit() {
10
10
  this.updateComponent();
11
11
  }
12
- ngOnChanges() {
12
+ ngOnChanges(changes) {
13
13
  this.updateComponent();
14
14
  }
15
15
  updateComponent() {
@@ -20,9 +20,12 @@ export class SelectFrameworkComponent {
20
20
  //this.widgetContainer.createComponent<any>(this.jsf.framework)
21
21
  }
22
22
  if (this.newComponent) {
23
- for (const input of ['layoutNode', 'layoutIndex', 'dataIndex']) {
24
- this.newComponent.instance[input] = this[input];
23
+ for (const inp of ['layoutNode', 'layoutIndex', 'dataIndex']) {
24
+ //this.newComponent.instance[inp] = this[inp];
25
+ this.newComponent.setInput(inp, this[inp]);
25
26
  }
27
+ // Manually trigger change detection after updating inputs
28
+ //this.changeDetectorRef.detectChanges();
26
29
  }
27
30
  }
28
31
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SelectFrameworkComponent, deps: [{ token: i1.JsonSchemaFormService }], target: i0.ɵɵFactoryTarget.Component }); }
@@ -48,4 +51,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
48
51
  static: true
49
52
  }]
50
53
  }] } });
51
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0LWZyYW1ld29yay5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy1mb3Jtd29ya3MtY29yZS9zcmMvbGliL3dpZGdldC1saWJyYXJ5L3NlbGVjdC1mcmFtZXdvcmsuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCxTQUFTLEVBQ0ssS0FBSyxFQUNBLFNBQVMsRUFBRSxnQkFBZ0IsRUFDL0MsTUFBTSxlQUFlLENBQUM7OztBQVN2QixNQUFNLE9BQU8sd0JBQXdCO0lBVW5DLFlBQ1UsR0FBMEI7UUFBMUIsUUFBRyxHQUFILEdBQUcsQ0FBdUI7UUFWcEMsaUJBQVksR0FBc0IsSUFBSSxDQUFDO0lBV25DLENBQUM7SUFFTCxRQUFRO1FBQ04sSUFBSSxDQUFDLGVBQWUsRUFBRSxDQUFDO0lBQ3pCLENBQUM7SUFFRCxXQUFXO1FBQ1QsSUFBSSxDQUFDLGVBQWUsRUFBRSxDQUFDO0lBQ3pCLENBQUM7SUFFRCxlQUFlO1FBQ2IsTUFBTSxlQUFlLEdBQUcsSUFBSSxDQUFDLGVBQWUsQ0FBQztRQUM3QyxJQUFJLGVBQWUsSUFBSSxDQUFDLElBQUksQ0FBQyxZQUFZLElBQUksSUFBSSxDQUFDLEdBQUcsQ0FBQyxTQUFTLEVBQUU7WUFDL0QsSUFBSSxDQUFDLFlBQVksR0FBRyxlQUFlLENBQUMsZUFBZSxDQUFDLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxTQUFTLENBQUMsQ0FDdkUsQ0FBQztZQUNGLHlDQUF5QztZQUN6QywrREFBK0Q7U0FDaEU7UUFDRCxJQUFJLElBQUksQ0FBQyxZQUFZLEVBQUU7WUFDckIsS0FBSyxNQUFNLEtBQUssSUFBSSxDQUFDLFlBQVksRUFBRSxhQUFhLEVBQUUsV0FBVyxDQUFDLEVBQUU7Z0JBQzlELElBQUksQ0FBQyxZQUFZLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQzthQUNqRDtTQUNGO0lBQ0gsQ0FBQzsrR0FuQ1Usd0JBQXdCO21HQUF4Qix3QkFBd0Isd1BBTXpCLGdCQUFnQixnRUFSaEIsOEJBQThCOzs0RkFFN0Isd0JBQXdCO2tCQUxwQyxTQUFTO21CQUFDO29CQUNULDhDQUE4QztvQkFDOUMsUUFBUSxFQUFFLHlCQUF5QjtvQkFDbkMsUUFBUSxFQUFFLDhCQUE4QjtpQkFDekM7NEdBR1UsVUFBVTtzQkFBbEIsS0FBSztnQkFDRyxXQUFXO3NCQUFuQixLQUFLO2dCQUNHLFNBQVM7c0JBQWpCLEtBQUs7Z0JBSUosZUFBZTtzQkFIaEIsU0FBUzt1QkFBQyxpQkFBaUIsRUFBRTt3QkFDMUIsSUFBSSxFQUFFLGdCQUFnQjt3QkFDdEIsTUFBTSxFQUFFLElBQUk7cUJBQUUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xyXG4gIENvbXBvbmVudCxcclxuICBDb21wb25lbnRSZWYsIElucHV0LFxyXG4gIE9uQ2hhbmdlcywgT25Jbml0LCBWaWV3Q2hpbGQsIFZpZXdDb250YWluZXJSZWZcclxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbmltcG9ydCB7IEpzb25TY2hlbWFGb3JtU2VydmljZSB9IGZyb20gJy4uL2pzb24tc2NoZW1hLWZvcm0uc2VydmljZSc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICAvLyB0c2xpbnQ6ZGlzYWJsZS1uZXh0LWxpbmU6Y29tcG9uZW50LXNlbGVjdG9yXHJcbiAgc2VsZWN0b3I6ICdzZWxlY3QtZnJhbWV3b3JrLXdpZGdldCcsXHJcbiAgdGVtcGxhdGU6IGA8ZGl2ICN3aWRnZXRDb250YWluZXI+PC9kaXY+YCxcclxufSlcclxuZXhwb3J0IGNsYXNzIFNlbGVjdEZyYW1ld29ya0NvbXBvbmVudCBpbXBsZW1lbnRzIE9uQ2hhbmdlcywgT25Jbml0IHtcclxuICBuZXdDb21wb25lbnQ6IENvbXBvbmVudFJlZjxhbnk+ID0gbnVsbDtcclxuICBASW5wdXQoKSBsYXlvdXROb2RlOiBhbnk7XHJcbiAgQElucHV0KCkgbGF5b3V0SW5kZXg6IG51bWJlcltdO1xyXG4gIEBJbnB1dCgpIGRhdGFJbmRleDogbnVtYmVyW107XHJcbiAgQFZpZXdDaGlsZCgnd2lkZ2V0Q29udGFpbmVyJywge1xyXG4gICAgICByZWFkOiBWaWV3Q29udGFpbmVyUmVmLFxyXG4gICAgICBzdGF0aWM6IHRydWUgfSlcclxuICAgIHdpZGdldENvbnRhaW5lcjogVmlld0NvbnRhaW5lclJlZjtcclxuXHJcbiAgY29uc3RydWN0b3IoXHJcbiAgICBwcml2YXRlIGpzZjogSnNvblNjaGVtYUZvcm1TZXJ2aWNlXHJcbiAgKSB7IH1cclxuXHJcbiAgbmdPbkluaXQoKSB7XHJcbiAgICB0aGlzLnVwZGF0ZUNvbXBvbmVudCgpO1xyXG4gIH1cclxuXHJcbiAgbmdPbkNoYW5nZXMoKSB7XHJcbiAgICB0aGlzLnVwZGF0ZUNvbXBvbmVudCgpO1xyXG4gIH1cclxuXHJcbiAgdXBkYXRlQ29tcG9uZW50KCkge1xyXG4gICAgY29uc3Qgd2lkZ2V0Q29udGFpbmVyID0gdGhpcy53aWRnZXRDb250YWluZXI7XHJcbiAgICBpZiAod2lkZ2V0Q29udGFpbmVyICYmICF0aGlzLm5ld0NvbXBvbmVudCAmJiB0aGlzLmpzZi5mcmFtZXdvcmspIHtcclxuICAgICAgdGhpcy5uZXdDb21wb25lbnQgPSB3aWRnZXRDb250YWluZXIuY3JlYXRlQ29tcG9uZW50KCh0aGlzLmpzZi5mcmFtZXdvcmspXHJcbiAgICAgICk7XHJcbiAgICAgIC8vVE9ETyBmaXggYWxsIGRlcHJlY2F0ZWQgY2FsbHMgYW5kIHRlc3QgXHJcbiAgICAgIC8vdGhpcy53aWRnZXRDb250YWluZXIuY3JlYXRlQ29tcG9uZW50PGFueT4odGhpcy5qc2YuZnJhbWV3b3JrKVxyXG4gICAgfVxyXG4gICAgaWYgKHRoaXMubmV3Q29tcG9uZW50KSB7XHJcbiAgICAgIGZvciAoY29uc3QgaW5wdXQgb2YgWydsYXlvdXROb2RlJywgJ2xheW91dEluZGV4JywgJ2RhdGFJbmRleCddKSB7XHJcbiAgICAgICAgdGhpcy5uZXdDb21wb25lbnQuaW5zdGFuY2VbaW5wdXRdID0gdGhpc1tpbnB1dF07XHJcbiAgICAgIH1cclxuICAgIH1cclxuICB9XHJcbn1cclxuIl19
54
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0LWZyYW1ld29yay5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy1mb3Jtd29ya3MtY29yZS9zcmMvbGliL3dpZGdldC1saWJyYXJ5L3NlbGVjdC1mcmFtZXdvcmsuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCxTQUFTLEVBQ0ssS0FBSyxFQUNBLFNBQVMsRUFBRSxnQkFBZ0IsRUFDL0MsTUFBTSxlQUFlLENBQUM7OztBQVN2QixNQUFNLE9BQU8sd0JBQXdCO0lBWW5DLFlBQ1UsR0FBMEI7UUFBMUIsUUFBRyxHQUFILEdBQUcsQ0FBdUI7UUFWcEMsaUJBQVksR0FBc0IsSUFBSSxDQUFDO0lBV25DLENBQUM7SUFFTCxRQUFRO1FBQ04sSUFBSSxDQUFDLGVBQWUsRUFBRSxDQUFDO0lBQ3pCLENBQUM7SUFFRCxXQUFXLENBQUMsT0FBTztRQUNqQixJQUFJLENBQUMsZUFBZSxFQUFFLENBQUM7SUFDekIsQ0FBQztJQUVELGVBQWU7UUFDYixNQUFNLGVBQWUsR0FBRyxJQUFJLENBQUMsZUFBZSxDQUFDO1FBQzdDLElBQUksZUFBZSxJQUFJLENBQUMsSUFBSSxDQUFDLFlBQVksSUFBSSxJQUFJLENBQUMsR0FBRyxDQUFDLFNBQVMsRUFBRTtZQUMvRCxJQUFJLENBQUMsWUFBWSxHQUFHLGVBQWUsQ0FBQyxlQUFlLENBQUMsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLFNBQVMsQ0FBQyxDQUN2RSxDQUFDO1lBQ0YseUNBQXlDO1lBQ3pDLCtEQUErRDtTQUNoRTtRQUNELElBQUksSUFBSSxDQUFDLFlBQVksRUFBRTtZQUNyQixLQUFLLE1BQU0sR0FBRyxJQUFJLENBQUMsWUFBWSxFQUFFLGFBQWEsRUFBRSxXQUFXLENBQUMsRUFBRTtnQkFDNUQsOENBQThDO2dCQUM5QyxJQUFJLENBQUMsWUFBWSxDQUFDLFFBQVEsQ0FBQyxHQUFHLEVBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUM7YUFDM0M7WUFDRCwwREFBMEQ7WUFDMUQseUNBQXlDO1NBQzFDO0lBQ0gsQ0FBQzsrR0F4Q1Usd0JBQXdCO21HQUF4Qix3QkFBd0Isd1BBUXpCLGdCQUFnQixnRUFWaEIsOEJBQThCOzs0RkFFN0Isd0JBQXdCO2tCQUxwQyxTQUFTO21CQUFDO29CQUNULDhDQUE4QztvQkFDOUMsUUFBUSxFQUFFLHlCQUF5QjtvQkFDbkMsUUFBUSxFQUFFLDhCQUE4QjtpQkFDekM7NEdBS1UsVUFBVTtzQkFBbEIsS0FBSztnQkFDRyxXQUFXO3NCQUFuQixLQUFLO2dCQUNHLFNBQVM7c0JBQWpCLEtBQUs7Z0JBSUosZUFBZTtzQkFIaEIsU0FBUzt1QkFBQyxpQkFBaUIsRUFBRTt3QkFDMUIsSUFBSSxFQUFFLGdCQUFnQjt3QkFDdEIsTUFBTSxFQUFFLElBQUk7cUJBQUUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xyXG4gIENvbXBvbmVudCxcclxuICBDb21wb25lbnRSZWYsIElucHV0LFxyXG4gIE9uQ2hhbmdlcywgT25Jbml0LCBWaWV3Q2hpbGQsIFZpZXdDb250YWluZXJSZWZcclxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbmltcG9ydCB7IEpzb25TY2hlbWFGb3JtU2VydmljZSB9IGZyb20gJy4uL2pzb24tc2NoZW1hLWZvcm0uc2VydmljZSc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICAvLyB0c2xpbnQ6ZGlzYWJsZS1uZXh0LWxpbmU6Y29tcG9uZW50LXNlbGVjdG9yXHJcbiAgc2VsZWN0b3I6ICdzZWxlY3QtZnJhbWV3b3JrLXdpZGdldCcsXHJcbiAgdGVtcGxhdGU6IGA8ZGl2ICN3aWRnZXRDb250YWluZXI+PC9kaXY+YCxcclxufSlcclxuZXhwb3J0IGNsYXNzIFNlbGVjdEZyYW1ld29ya0NvbXBvbmVudCBpbXBsZW1lbnRzIE9uQ2hhbmdlcywgT25Jbml0IHtcclxuXHJcblxyXG4gIG5ld0NvbXBvbmVudDogQ29tcG9uZW50UmVmPGFueT4gPSBudWxsO1xyXG4gIEBJbnB1dCgpIGxheW91dE5vZGU6IGFueTtcclxuICBASW5wdXQoKSBsYXlvdXRJbmRleDogbnVtYmVyW107XHJcbiAgQElucHV0KCkgZGF0YUluZGV4OiBudW1iZXJbXTtcclxuICBAVmlld0NoaWxkKCd3aWRnZXRDb250YWluZXInLCB7XHJcbiAgICAgIHJlYWQ6IFZpZXdDb250YWluZXJSZWYsXHJcbiAgICAgIHN0YXRpYzogdHJ1ZSB9KVxyXG4gICAgd2lkZ2V0Q29udGFpbmVyOiBWaWV3Q29udGFpbmVyUmVmO1xyXG5cclxuICBjb25zdHJ1Y3RvcihcclxuICAgIHByaXZhdGUganNmOiBKc29uU2NoZW1hRm9ybVNlcnZpY2VcclxuICApIHsgfVxyXG5cclxuICBuZ09uSW5pdCgpIHtcclxuICAgIHRoaXMudXBkYXRlQ29tcG9uZW50KCk7XHJcbiAgfVxyXG5cclxuICBuZ09uQ2hhbmdlcyhjaGFuZ2VzKSB7XHJcbiAgICB0aGlzLnVwZGF0ZUNvbXBvbmVudCgpO1xyXG4gIH1cclxuXHJcbiAgdXBkYXRlQ29tcG9uZW50KCkge1xyXG4gICAgY29uc3Qgd2lkZ2V0Q29udGFpbmVyID0gdGhpcy53aWRnZXRDb250YWluZXI7XHJcbiAgICBpZiAod2lkZ2V0Q29udGFpbmVyICYmICF0aGlzLm5ld0NvbXBvbmVudCAmJiB0aGlzLmpzZi5mcmFtZXdvcmspIHtcclxuICAgICAgdGhpcy5uZXdDb21wb25lbnQgPSB3aWRnZXRDb250YWluZXIuY3JlYXRlQ29tcG9uZW50KCh0aGlzLmpzZi5mcmFtZXdvcmspXHJcbiAgICAgICk7XHJcbiAgICAgIC8vVE9ETyBmaXggYWxsIGRlcHJlY2F0ZWQgY2FsbHMgYW5kIHRlc3QgXHJcbiAgICAgIC8vdGhpcy53aWRnZXRDb250YWluZXIuY3JlYXRlQ29tcG9uZW50PGFueT4odGhpcy5qc2YuZnJhbWV3b3JrKVxyXG4gICAgfVxyXG4gICAgaWYgKHRoaXMubmV3Q29tcG9uZW50KSB7XHJcbiAgICAgIGZvciAoY29uc3QgaW5wIG9mIFsnbGF5b3V0Tm9kZScsICdsYXlvdXRJbmRleCcsICdkYXRhSW5kZXgnXSkge1xyXG4gICAgICAgIC8vdGhpcy5uZXdDb21wb25lbnQuaW5zdGFuY2VbaW5wXSA9IHRoaXNbaW5wXTtcclxuICAgICAgICB0aGlzLm5ld0NvbXBvbmVudC5zZXRJbnB1dChpbnAsdGhpc1tpbnBdKTtcclxuICAgICAgfVxyXG4gICAgICAvLyBNYW51YWxseSB0cmlnZ2VyIGNoYW5nZSBkZXRlY3Rpb24gYWZ0ZXIgdXBkYXRpbmcgaW5wdXRzXHJcbiAgICAgIC8vdGhpcy5jaGFuZ2VEZXRlY3RvclJlZi5kZXRlY3RDaGFuZ2VzKCk7XHJcbiAgICB9XHJcbiAgfVxyXG59XHJcbiJdfQ==
@@ -9,7 +9,7 @@ export class SelectWidgetComponent {
9
9
  ngOnInit() {
10
10
  this.updateComponent();
11
11
  }
12
- ngOnChanges() {
12
+ ngOnChanges(changes) {
13
13
  this.updateComponent();
14
14
  }
15
15
  updateComponent() {
@@ -18,8 +18,9 @@ export class SelectWidgetComponent {
18
18
  this.newComponent = widgetContainer.createComponent((this.layoutNode.widget));
19
19
  }
20
20
  if (this.newComponent) {
21
- for (const input of ['layoutNode', 'layoutIndex', 'dataIndex']) {
22
- this.newComponent.instance[input] = this[input];
21
+ for (const inp of ['layoutNode', 'layoutIndex', 'dataIndex']) {
22
+ //this.newComponent.instance[inp] = this[inp];
23
+ this.newComponent.setInput(inp, this[inp]);
23
24
  }
24
25
  }
25
26
  }
@@ -43,4 +44,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
43
44
  type: ViewChild,
44
45
  args: ['widgetContainer', { read: ViewContainerRef, static: true }]
45
46
  }] } });
46
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0LXdpZGdldC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy1mb3Jtd29ya3MtY29yZS9zcmMvbGliL3dpZGdldC1saWJyYXJ5L3NlbGVjdC13aWRnZXQuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCxTQUFTLEVBQ0ssS0FBSyxFQUNBLFNBQVMsRUFBRSxnQkFBZ0IsRUFDL0MsTUFBTSxlQUFlLENBQUM7OztBQVN2QixNQUFNLE9BQU8scUJBQXFCO0lBUWhDLFlBQ1UsR0FBMEI7UUFBMUIsUUFBRyxHQUFILEdBQUcsQ0FBdUI7UUFScEMsaUJBQVksR0FBc0IsSUFBSSxDQUFDO0lBU25DLENBQUM7SUFFTCxRQUFRO1FBQ04sSUFBSSxDQUFDLGVBQWUsRUFBRSxDQUFDO0lBQ3pCLENBQUM7SUFFRCxXQUFXO1FBQ1QsSUFBSSxDQUFDLGVBQWUsRUFBRSxDQUFDO0lBQ3pCLENBQUM7SUFFRCxlQUFlO1FBQ2IsTUFBTSxlQUFlLEdBQUcsSUFBSSxDQUFDLGVBQWUsQ0FBQztRQUM3QyxJQUFJLGVBQWUsSUFBSSxDQUFDLElBQUksQ0FBQyxZQUFZLElBQUksQ0FBQyxJQUFJLENBQUMsVUFBVSxJQUFJLEVBQUUsQ0FBQyxDQUFDLE1BQU0sRUFBRTtZQUMzRSxJQUFJLENBQUMsWUFBWSxHQUFHLGVBQWUsQ0FBQyxlQUFlLENBQUMsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLE1BQU0sQ0FBQyxDQUMzRSxDQUFDO1NBQ0g7UUFDRCxJQUFJLElBQUksQ0FBQyxZQUFZLEVBQUU7WUFDckIsS0FBSyxNQUFNLEtBQUssSUFBSSxDQUFDLFlBQVksRUFBRSxhQUFhLEVBQUUsV0FBVyxDQUFDLEVBQUU7Z0JBQzlELElBQUksQ0FBQyxZQUFZLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQzthQUNqRDtTQUNGO0lBQ0gsQ0FBQzsrR0EvQlUscUJBQXFCO21HQUFyQixxQkFBcUIscVBBS00sZ0JBQWdCLGdFQVA1Qyw4QkFBOEI7OzRGQUU3QixxQkFBcUI7a0JBTGpDLFNBQVM7bUJBQUM7b0JBQ1QsOENBQThDO29CQUM5QyxRQUFRLEVBQUUsc0JBQXNCO29CQUNoQyxRQUFRLEVBQUUsOEJBQThCO2lCQUN6Qzs0R0FHVSxVQUFVO3NCQUFsQixLQUFLO2dCQUNHLFdBQVc7c0JBQW5CLEtBQUs7Z0JBQ0csU0FBUztzQkFBakIsS0FBSztnQkFFSixlQUFlO3NCQURoQixTQUFTO3VCQUFDLGlCQUFpQixFQUFFLEVBQUUsSUFBSSxFQUFFLGdCQUFnQixFQUFFLE1BQU0sRUFBRSxJQUFJLEVBQUUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xyXG4gIENvbXBvbmVudCxcclxuICBDb21wb25lbnRSZWYsIElucHV0LFxyXG4gIE9uQ2hhbmdlcywgT25Jbml0LCBWaWV3Q2hpbGQsIFZpZXdDb250YWluZXJSZWZcclxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbmltcG9ydCB7IEpzb25TY2hlbWFGb3JtU2VydmljZSB9IGZyb20gJy4uL2pzb24tc2NoZW1hLWZvcm0uc2VydmljZSc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICAvLyB0c2xpbnQ6ZGlzYWJsZS1uZXh0LWxpbmU6Y29tcG9uZW50LXNlbGVjdG9yXHJcbiAgc2VsZWN0b3I6ICdzZWxlY3Qtd2lkZ2V0LXdpZGdldCcsXHJcbiAgdGVtcGxhdGU6IGA8ZGl2ICN3aWRnZXRDb250YWluZXI+PC9kaXY+YCxcclxufSlcclxuZXhwb3J0IGNsYXNzIFNlbGVjdFdpZGdldENvbXBvbmVudCBpbXBsZW1lbnRzIE9uQ2hhbmdlcywgT25Jbml0IHtcclxuICBuZXdDb21wb25lbnQ6IENvbXBvbmVudFJlZjxhbnk+ID0gbnVsbDtcclxuICBASW5wdXQoKSBsYXlvdXROb2RlOiBhbnk7XHJcbiAgQElucHV0KCkgbGF5b3V0SW5kZXg6IG51bWJlcltdO1xyXG4gIEBJbnB1dCgpIGRhdGFJbmRleDogbnVtYmVyW107XHJcbiAgQFZpZXdDaGlsZCgnd2lkZ2V0Q29udGFpbmVyJywgeyByZWFkOiBWaWV3Q29udGFpbmVyUmVmLCBzdGF0aWM6IHRydWUgfSlcclxuICAgIHdpZGdldENvbnRhaW5lcjogVmlld0NvbnRhaW5lclJlZjtcclxuXHJcbiAgY29uc3RydWN0b3IoXHJcbiAgICBwcml2YXRlIGpzZjogSnNvblNjaGVtYUZvcm1TZXJ2aWNlXHJcbiAgKSB7IH1cclxuXHJcbiAgbmdPbkluaXQoKSB7XHJcbiAgICB0aGlzLnVwZGF0ZUNvbXBvbmVudCgpO1xyXG4gIH1cclxuXHJcbiAgbmdPbkNoYW5nZXMoKSB7XHJcbiAgICB0aGlzLnVwZGF0ZUNvbXBvbmVudCgpO1xyXG4gIH1cclxuXHJcbiAgdXBkYXRlQ29tcG9uZW50KCkge1xyXG4gICAgY29uc3Qgd2lkZ2V0Q29udGFpbmVyID0gdGhpcy53aWRnZXRDb250YWluZXI7XHJcbiAgICBpZiAod2lkZ2V0Q29udGFpbmVyICYmICF0aGlzLm5ld0NvbXBvbmVudCAmJiAodGhpcy5sYXlvdXROb2RlIHx8IHt9KS53aWRnZXQpIHtcclxuICAgICAgdGhpcy5uZXdDb21wb25lbnQgPSB3aWRnZXRDb250YWluZXIuY3JlYXRlQ29tcG9uZW50KCh0aGlzLmxheW91dE5vZGUud2lkZ2V0KVxyXG4gICAgICApO1xyXG4gICAgfVxyXG4gICAgaWYgKHRoaXMubmV3Q29tcG9uZW50KSB7XHJcbiAgICAgIGZvciAoY29uc3QgaW5wdXQgb2YgWydsYXlvdXROb2RlJywgJ2xheW91dEluZGV4JywgJ2RhdGFJbmRleCddKSB7XHJcbiAgICAgICAgdGhpcy5uZXdDb21wb25lbnQuaW5zdGFuY2VbaW5wdXRdID0gdGhpc1tpbnB1dF07XHJcbiAgICAgIH1cclxuICAgIH1cclxuICB9XHJcbn1cclxuIl19
47
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0LXdpZGdldC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy1mb3Jtd29ya3MtY29yZS9zcmMvbGliL3dpZGdldC1saWJyYXJ5L3NlbGVjdC13aWRnZXQuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCxTQUFTLEVBQ0ssS0FBSyxFQUduQixTQUFTLEVBQ1QsZ0JBQWdCLEVBQ2pCLE1BQU0sZUFBZSxDQUFDOzs7QUFTdkIsTUFBTSxPQUFPLHFCQUFxQjtJQVFoQyxZQUNVLEdBQTBCO1FBQTFCLFFBQUcsR0FBSCxHQUFHLENBQXVCO1FBUnBDLGlCQUFZLEdBQXNCLElBQUksQ0FBQztJQVNuQyxDQUFDO0lBRUwsUUFBUTtRQUNOLElBQUksQ0FBQyxlQUFlLEVBQUUsQ0FBQztJQUN6QixDQUFDO0lBRUQsV0FBVyxDQUFDLE9BQXFCO1FBQy9CLElBQUksQ0FBQyxlQUFlLEVBQUUsQ0FBQztJQUN6QixDQUFDO0lBRUQsZUFBZTtRQUNiLE1BQU0sZUFBZSxHQUFHLElBQUksQ0FBQyxlQUFlLENBQUM7UUFDN0MsSUFBSSxlQUFlLElBQUksQ0FBQyxJQUFJLENBQUMsWUFBWSxJQUFJLENBQUMsSUFBSSxDQUFDLFVBQVUsSUFBSSxFQUFFLENBQUMsQ0FBQyxNQUFNLEVBQUU7WUFDM0UsSUFBSSxDQUFDLFlBQVksR0FBRyxlQUFlLENBQUMsZUFBZSxDQUFDLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxNQUFNLENBQUMsQ0FDM0UsQ0FBQztTQUNIO1FBQ0QsSUFBSSxJQUFJLENBQUMsWUFBWSxFQUFFO1lBQ3JCLEtBQUssTUFBTSxHQUFHLElBQUksQ0FBQyxZQUFZLEVBQUUsYUFBYSxFQUFFLFdBQVcsQ0FBQyxFQUFFO2dCQUM1RCw4Q0FBOEM7Z0JBQzlDLElBQUksQ0FBQyxZQUFZLENBQUMsUUFBUSxDQUFDLEdBQUcsRUFBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQzthQUMzQztTQUNGO0lBQ0gsQ0FBQzsrR0FoQ1UscUJBQXFCO21HQUFyQixxQkFBcUIscVBBS00sZ0JBQWdCLGdFQVA1Qyw4QkFBOEI7OzRGQUU3QixxQkFBcUI7a0JBTGpDLFNBQVM7bUJBQUM7b0JBQ1QsOENBQThDO29CQUM5QyxRQUFRLEVBQUUsc0JBQXNCO29CQUNoQyxRQUFRLEVBQUUsOEJBQThCO2lCQUN6Qzs0R0FHVSxVQUFVO3NCQUFsQixLQUFLO2dCQUNHLFdBQVc7c0JBQW5CLEtBQUs7Z0JBQ0csU0FBUztzQkFBakIsS0FBSztnQkFFSixlQUFlO3NCQURoQixTQUFTO3VCQUFDLGlCQUFpQixFQUFFLEVBQUUsSUFBSSxFQUFFLGdCQUFnQixFQUFFLE1BQU0sRUFBRSxJQUFJLEVBQUUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xyXG4gIENvbXBvbmVudCxcclxuICBDb21wb25lbnRSZWYsIElucHV0LFxyXG4gIE9uQ2hhbmdlcywgT25Jbml0LFxyXG4gIFNpbXBsZUNoYW5nZXMsXHJcbiAgVmlld0NoaWxkLFxyXG4gIFZpZXdDb250YWluZXJSZWZcclxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbmltcG9ydCB7IEpzb25TY2hlbWFGb3JtU2VydmljZSB9IGZyb20gJy4uL2pzb24tc2NoZW1hLWZvcm0uc2VydmljZSc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICAvLyB0c2xpbnQ6ZGlzYWJsZS1uZXh0LWxpbmU6Y29tcG9uZW50LXNlbGVjdG9yXHJcbiAgc2VsZWN0b3I6ICdzZWxlY3Qtd2lkZ2V0LXdpZGdldCcsXHJcbiAgdGVtcGxhdGU6IGA8ZGl2ICN3aWRnZXRDb250YWluZXI+PC9kaXY+YCxcclxufSlcclxuZXhwb3J0IGNsYXNzIFNlbGVjdFdpZGdldENvbXBvbmVudCBpbXBsZW1lbnRzIE9uQ2hhbmdlcywgT25Jbml0IHtcclxuICBuZXdDb21wb25lbnQ6IENvbXBvbmVudFJlZjxhbnk+ID0gbnVsbDtcclxuICBASW5wdXQoKSBsYXlvdXROb2RlOiBhbnk7XHJcbiAgQElucHV0KCkgbGF5b3V0SW5kZXg6IG51bWJlcltdO1xyXG4gIEBJbnB1dCgpIGRhdGFJbmRleDogbnVtYmVyW107XHJcbiAgQFZpZXdDaGlsZCgnd2lkZ2V0Q29udGFpbmVyJywgeyByZWFkOiBWaWV3Q29udGFpbmVyUmVmLCBzdGF0aWM6IHRydWUgfSlcclxuICAgIHdpZGdldENvbnRhaW5lcjogVmlld0NvbnRhaW5lclJlZjtcclxuXHJcbiAgY29uc3RydWN0b3IoXHJcbiAgICBwcml2YXRlIGpzZjogSnNvblNjaGVtYUZvcm1TZXJ2aWNlXHJcbiAgKSB7IH1cclxuXHJcbiAgbmdPbkluaXQoKSB7XHJcbiAgICB0aGlzLnVwZGF0ZUNvbXBvbmVudCgpO1xyXG4gIH1cclxuXHJcbiAgbmdPbkNoYW5nZXMoY2hhbmdlczpTaW1wbGVDaGFuZ2VzKSB7XHJcbiAgICB0aGlzLnVwZGF0ZUNvbXBvbmVudCgpO1xyXG4gIH1cclxuXHJcbiAgdXBkYXRlQ29tcG9uZW50KCkge1xyXG4gICAgY29uc3Qgd2lkZ2V0Q29udGFpbmVyID0gdGhpcy53aWRnZXRDb250YWluZXI7XHJcbiAgICBpZiAod2lkZ2V0Q29udGFpbmVyICYmICF0aGlzLm5ld0NvbXBvbmVudCAmJiAodGhpcy5sYXlvdXROb2RlIHx8IHt9KS53aWRnZXQpIHtcclxuICAgICAgdGhpcy5uZXdDb21wb25lbnQgPSB3aWRnZXRDb250YWluZXIuY3JlYXRlQ29tcG9uZW50KCh0aGlzLmxheW91dE5vZGUud2lkZ2V0KVxyXG4gICAgICApO1xyXG4gICAgfVxyXG4gICAgaWYgKHRoaXMubmV3Q29tcG9uZW50KSB7XHJcbiAgICAgIGZvciAoY29uc3QgaW5wIG9mIFsnbGF5b3V0Tm9kZScsICdsYXlvdXRJbmRleCcsICdkYXRhSW5kZXgnXSkge1xyXG4gICAgICAgIC8vdGhpcy5uZXdDb21wb25lbnQuaW5zdGFuY2VbaW5wXSA9IHRoaXNbaW5wXTtcclxuICAgICAgICB0aGlzLm5ld0NvbXBvbmVudC5zZXRJbnB1dChpbnAsdGhpc1tpbnBdKTtcclxuICAgICAgfVxyXG4gICAgfVxyXG4gIH1cclxufVxyXG4iXX0=