@ng-formworks/material 17.6.6 → 17.6.8
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/material-design-framework.component.mjs +25 -18
- package/esm2022/lib/material-design-framework.module.mjs +4 -18
- package/esm2022/lib/widgets/flex-layout-root.component.mjs +113 -49
- package/esm2022/lib/widgets/flex-layout-section.component.mjs +1 -1
- package/esm2022/lib/widgets/material-add-reference.component.mjs +8 -5
- package/esm2022/lib/widgets/material-button-group.component.mjs +3 -3
- package/esm2022/lib/widgets/material-button.component.mjs +11 -6
- package/esm2022/lib/widgets/material-checkbox.component.mjs +9 -9
- package/esm2022/lib/widgets/material-checkboxes.component.mjs +3 -3
- package/esm2022/lib/widgets/material-datepicker.component.mjs +7 -7
- package/esm2022/lib/widgets/material-input.component.mjs +30 -30
- package/esm2022/lib/widgets/material-number.component.mjs +14 -26
- package/esm2022/lib/widgets/material-radios.component.mjs +3 -3
- package/esm2022/lib/widgets/material-select.component.mjs +11 -11
- package/esm2022/lib/widgets/material-slider.component.mjs +12 -28
- package/esm2022/lib/widgets/material-tabs.component.mjs +16 -7
- package/esm2022/lib/widgets/material-textarea.component.mjs +7 -7
- package/fesm2022/ng-formworks-material.mjs +278 -235
- package/fesm2022/ng-formworks-material.mjs.map +1 -1
- package/lib/material-design-framework.component.d.ts +2 -2
- package/lib/material-design-framework.module.d.ts +1 -2
- package/lib/widgets/flex-layout-root.component.d.ts +16 -6
- package/lib/widgets/material-input.component.d.ts +1 -2
- package/lib/widgets/material-number.component.d.ts +0 -2
- package/lib/widgets/material-slider.component.d.ts +0 -2
- package/lib/widgets/material-tabs.component.d.ts +5 -2
- package/package.json +3 -3
|
@@ -25,7 +25,6 @@ import { MatToolbarModule } from '@angular/material/toolbar';
|
|
|
25
25
|
import { MatTooltipModule } from '@angular/material/tooltip';
|
|
26
26
|
import { Framework, FrameworkLibraryService, JsonSchemaFormModule, JsonSchemaFormService, WidgetLibraryModule, WidgetLibraryService } from '@ng-formworks/core';
|
|
27
27
|
import { CssFrameworkModule } from '@ng-formworks/cssframework';
|
|
28
|
-
import { SortablejsModule } from 'nxt-sortablejs';
|
|
29
28
|
import { MaterialDesignFramework } from './material-design.framework';
|
|
30
29
|
import { MATERIAL_FRAMEWORK_COMPONENTS } from './widgets/public_api';
|
|
31
30
|
import * as i0 from "@angular/core";
|
|
@@ -49,7 +48,6 @@ import * as i17 from "./widgets/material-stepper.component";
|
|
|
49
48
|
import * as i18 from "./widgets/material-tabs.component";
|
|
50
49
|
import * as i19 from "./widgets/material-textarea.component";
|
|
51
50
|
import * as i20 from "./material-design-framework.component";
|
|
52
|
-
import * as i21 from "nxt-sortablejs";
|
|
53
51
|
/**
|
|
54
52
|
* unused @angular/material modules:
|
|
55
53
|
* MatDialogModule, MatGridListModule, MatListModule, MatMenuModule,
|
|
@@ -80,7 +78,7 @@ export class MaterialDesignFrameworkModule {
|
|
|
80
78
|
MatToolbarModule, MatMenuModule, MatToolbarModule,
|
|
81
79
|
DragDropModule, WidgetLibraryModule,
|
|
82
80
|
JsonSchemaFormModule,
|
|
83
|
-
CssFrameworkModule
|
|
81
|
+
CssFrameworkModule], exports: [JsonSchemaFormModule, i1.FlexLayoutRootComponent, i2.FlexLayoutSectionComponent, i3.MaterialAddReferenceComponent, i4.MaterialOneOfComponent, i5.MaterialButtonComponent, i6.MaterialButtonGroupComponent, i7.MaterialCheckboxComponent, i8.MaterialCheckboxesComponent, i9.MaterialChipListComponent, i10.MaterialDatepickerComponent, i11.MaterialFileComponent, i12.MaterialInputComponent, i13.MaterialNumberComponent, i14.MaterialRadiosComponent, i15.MaterialSelectComponent, i16.MaterialSliderComponent, i17.MaterialStepperComponent, i18.MaterialTabsComponent, i19.MaterialTextareaComponent, i20.MaterialDesignFrameworkComponent] }); }
|
|
84
82
|
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MaterialDesignFrameworkModule, providers: [
|
|
85
83
|
JsonSchemaFormService,
|
|
86
84
|
FrameworkLibraryService,
|
|
@@ -90,13 +88,7 @@ export class MaterialDesignFrameworkModule {
|
|
|
90
88
|
FormsModule,
|
|
91
89
|
ReactiveFormsModule, ANGULAR_MATERIAL_MODULES, WidgetLibraryModule,
|
|
92
90
|
JsonSchemaFormModule,
|
|
93
|
-
CssFrameworkModule,
|
|
94
|
-
SortablejsModule.forRoot({
|
|
95
|
-
//disabled:false,
|
|
96
|
-
//draggable:".draggableitem",//">:not(.nonsort)",//">.draggable-item",//":not(.nonsort)",//">*",//":not(.nonsort)",//":not(.non-draggable)",
|
|
97
|
-
filter: ".sortable-filter",
|
|
98
|
-
preventOnFilter: false //needed for input range elements slider do still work
|
|
99
|
-
}), JsonSchemaFormModule] }); }
|
|
91
|
+
CssFrameworkModule, JsonSchemaFormModule] }); }
|
|
100
92
|
}
|
|
101
93
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MaterialDesignFrameworkModule, decorators: [{
|
|
102
94
|
type: NgModule,
|
|
@@ -108,13 +100,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
108
100
|
...ANGULAR_MATERIAL_MODULES,
|
|
109
101
|
WidgetLibraryModule,
|
|
110
102
|
JsonSchemaFormModule,
|
|
111
|
-
CssFrameworkModule
|
|
112
|
-
SortablejsModule.forRoot({
|
|
113
|
-
//disabled:false,
|
|
114
|
-
//draggable:".draggableitem",//">:not(.nonsort)",//">.draggable-item",//":not(.nonsort)",//">*",//":not(.nonsort)",//":not(.non-draggable)",
|
|
115
|
-
filter: ".sortable-filter",
|
|
116
|
-
preventOnFilter: false //needed for input range elements slider do still work
|
|
117
|
-
})
|
|
103
|
+
CssFrameworkModule
|
|
118
104
|
],
|
|
119
105
|
declarations: [
|
|
120
106
|
...MATERIAL_FRAMEWORK_COMPONENTS,
|
|
@@ -131,4 +117,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
131
117
|
]
|
|
132
118
|
}]
|
|
133
119
|
}], ctorParameters: () => [] });
|
|
134
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
120
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"material-design-framework.module.js","sourceRoot":"","sources":["../../../../../projects/ng-formworks-material/src/lib/material-design-framework.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { DragDropModule } from '@angular/cdk/drag-drop';\r\nimport { CommonModule } from '@angular/common';\r\nimport { NgModule } from '@angular/core';\r\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\r\nimport { MatAutocompleteModule } from '@angular/material/autocomplete';\r\nimport { MatButtonModule } from '@angular/material/button';\r\nimport { MatButtonToggleModule } from '@angular/material/button-toggle';\r\nimport { MatCardModule } from '@angular/material/card';\r\nimport { MatCheckboxModule } from '@angular/material/checkbox';\r\nimport { MatChipsModule } from '@angular/material/chips';\r\nimport { MatNativeDateModule } from '@angular/material/core';\r\nimport { MatDatepickerModule } from '@angular/material/datepicker';\r\nimport { MatExpansionModule } from '@angular/material/expansion';\r\nimport { MatFormFieldModule } from '@angular/material/form-field';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { MatInputModule } from '@angular/material/input';\r\nimport { MatMenuModule } from '@angular/material/menu';\r\nimport { MatRadioModule } from '@angular/material/radio';\r\nimport { MatSelectModule } from '@angular/material/select';\r\nimport { MatSlideToggleModule } from '@angular/material/slide-toggle';\r\nimport { MatSliderModule } from '@angular/material/slider';\r\nimport { MatStepperModule } from '@angular/material/stepper';\r\nimport { MatTabsModule } from '@angular/material/tabs';\r\nimport { MatToolbarModule } from '@angular/material/toolbar';\r\nimport { MatTooltipModule } from '@angular/material/tooltip';\r\n\r\nimport {\r\n    Framework,\r\n    FrameworkLibraryService,\r\n    JsonSchemaFormModule,\r\n    JsonSchemaFormService,\r\n    WidgetLibraryModule, WidgetLibraryService\r\n} from '@ng-formworks/core';\r\nimport { CssFrameworkModule } from '@ng-formworks/cssframework';\r\nimport { MaterialDesignFramework } from './material-design.framework';\r\nimport { MATERIAL_FRAMEWORK_COMPONENTS } from './widgets/public_api';\r\n\r\n\r\n/**\r\n * unused @angular/material modules:\r\n * MatDialogModule, MatGridListModule, MatListModule, MatMenuModule,\r\n * MatPaginatorModule, MatProgressBarModule, MatProgressSpinnerModule,\r\n * MatSidenavModule, MatSnackBarModule, MatSortModule, MatTableModule,\r\n * ,\r\n */\r\nexport const ANGULAR_MATERIAL_MODULES = [\r\n  MatAutocompleteModule, MatButtonModule, MatButtonToggleModule, MatCardModule,\r\n  MatCheckboxModule, MatChipsModule, MatDatepickerModule, MatExpansionModule,\r\n  MatFormFieldModule, MatIconModule, MatInputModule, MatNativeDateModule,\r\n  MatRadioModule, MatSelectModule, MatSliderModule, MatSlideToggleModule,\r\n  MatStepperModule, MatTabsModule, MatTooltipModule,\r\n  MatToolbarModule, MatMenuModule, MatToolbarModule,\r\n  DragDropModule\r\n];\r\n\r\n@NgModule({\r\n    imports: [\r\n        CommonModule,\r\n        FormsModule,\r\n        ReactiveFormsModule,\r\n        ...ANGULAR_MATERIAL_MODULES,\r\n        WidgetLibraryModule,\r\n        JsonSchemaFormModule,\r\n        CssFrameworkModule\r\n    ],\r\n    declarations: [\r\n        ...MATERIAL_FRAMEWORK_COMPONENTS,\r\n    ],\r\n    exports: [\r\n        JsonSchemaFormModule,\r\n        ...MATERIAL_FRAMEWORK_COMPONENTS,\r\n    ],\r\n    providers: [\r\n        JsonSchemaFormService,\r\n        FrameworkLibraryService,\r\n        WidgetLibraryService,\r\n        { provide: Framework, useClass: MaterialDesignFramework, multi: true },\r\n    ]\r\n})\r\nexport class MaterialDesignFrameworkModule {\r\n  constructor() {\r\n\r\n  }\r\n}\r\n"]}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { ChangeDetectionStrategy, Component, inject, input } from '@angular/core';
|
|
2
2
|
import { JsonSchemaFormService } from '@ng-formworks/core';
|
|
3
|
+
import { memoize } from 'lodash';
|
|
3
4
|
import * as i0 from "@angular/core";
|
|
4
5
|
import * as i1 from "@angular/common";
|
|
5
6
|
import * as i2 from "@angular/cdk/drag-drop";
|
|
@@ -10,13 +11,9 @@ export class FlexLayoutRootComponent {
|
|
|
10
11
|
this.dataIndex = input(undefined);
|
|
11
12
|
this.layoutIndex = input(undefined);
|
|
12
13
|
this.layout = input(undefined);
|
|
14
|
+
this.isOrderable = input(undefined);
|
|
13
15
|
this.isFlexItem = input(false);
|
|
14
|
-
this.
|
|
15
|
-
filter: ".sortable-filter",
|
|
16
|
-
preventOnFilter: false,
|
|
17
|
-
onEnd: (/**Event*/ evt) => {
|
|
18
|
-
}
|
|
19
|
-
};
|
|
16
|
+
this.memoizationEnabled = input(true);
|
|
20
17
|
/**
|
|
21
18
|
* Predicate function that disallows '$ref' item sorts
|
|
22
19
|
* NB declared as a var instead of a function
|
|
@@ -28,22 +25,32 @@ export class FlexLayoutRootComponent {
|
|
|
28
25
|
//created by an arbitrary layout
|
|
29
26
|
this.sortPredicate = (index, item) => {
|
|
30
27
|
let layoutItem = this.layout()[index];
|
|
31
|
-
let result = layoutItem
|
|
28
|
+
let result = this.isDraggable(layoutItem);
|
|
29
|
+
//layoutItem.type != '$ref';
|
|
32
30
|
return result;
|
|
33
31
|
};
|
|
32
|
+
this._getSelectFrameworkInputsRaw = (layoutItem, i) => {
|
|
33
|
+
const dataIndexValue = this.dataIndex() || [];
|
|
34
|
+
const layoutIndexValue = this.layoutIndex() || [];
|
|
35
|
+
return {
|
|
36
|
+
layoutNode: layoutItem,
|
|
37
|
+
layoutIndex: [...layoutIndexValue, i],
|
|
38
|
+
dataIndex: layoutItem?.arrayItem ? [...dataIndexValue, i] : dataIndexValue,
|
|
39
|
+
};
|
|
40
|
+
};
|
|
41
|
+
// Define a separate function to hold the memoized version
|
|
42
|
+
this._getSelectFrameworkInputsMemoized = memoize(this._getSelectFrameworkInputsRaw, (layoutItem, i) => {
|
|
43
|
+
const layoutItemKey = layoutItem?.id ?? JSON.stringify(layoutItem);
|
|
44
|
+
return `${layoutItemKey}-${i}`;
|
|
45
|
+
});
|
|
34
46
|
}
|
|
35
47
|
ngOnInit() {
|
|
36
48
|
}
|
|
37
49
|
removeItem(item) {
|
|
38
50
|
this.jsf.removeItem(item);
|
|
39
51
|
}
|
|
40
|
-
sortableInit(sortable) {
|
|
41
|
-
this.sortableObj = sortable;
|
|
42
|
-
}
|
|
43
52
|
drop(event) {
|
|
44
53
|
// most likely why this event is used is to get the dragging element's current index
|
|
45
|
-
// same properties as onEnd
|
|
46
|
-
//console.log(`sortablejs event:${evt}`);
|
|
47
54
|
let srcInd = event.previousIndex;
|
|
48
55
|
let trgInd = event.currentIndex;
|
|
49
56
|
let layoutItem = this.layout()[trgInd];
|
|
@@ -54,9 +61,14 @@ export class FlexLayoutRootComponent {
|
|
|
54
61
|
layoutIndex: () => { return layoutInd; },
|
|
55
62
|
layoutNode: () => { return layoutItem; },
|
|
56
63
|
};
|
|
57
|
-
//must set moveLayout to false as nxtSortable already moves it
|
|
58
64
|
this.jsf.moveArrayItem(itemCtx, srcInd, trgInd, true);
|
|
59
65
|
}
|
|
66
|
+
isDraggable(node) {
|
|
67
|
+
let result = node.arrayItem && node.type !== '$ref' &&
|
|
68
|
+
node.arrayItemType === 'list' && this.isOrderable() !== false
|
|
69
|
+
&& node.type !== 'submit';
|
|
70
|
+
return result;
|
|
71
|
+
}
|
|
60
72
|
// Set attributes for flexbox child
|
|
61
73
|
// (container attributes are set in flex-layout-section.component)
|
|
62
74
|
getFlexAttribute(node, attribute) {
|
|
@@ -64,41 +76,79 @@ export class FlexLayoutRootComponent {
|
|
|
64
76
|
return ((node.options || {}).flex || '').split(/\s+/)[index] ||
|
|
65
77
|
(node.options || {})[attribute] || ['1', '1', 'auto'][index];
|
|
66
78
|
}
|
|
79
|
+
// This is the public function that the template calls
|
|
80
|
+
getSelectFrameworkInputs(layoutItem, i) {
|
|
81
|
+
if (this.memoizationEnabled) {
|
|
82
|
+
return this._getSelectFrameworkInputsMemoized(layoutItem, i);
|
|
83
|
+
}
|
|
84
|
+
else {
|
|
85
|
+
return this._getSelectFrameworkInputsRaw(layoutItem, i);
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
trackByFn(index, item) {
|
|
89
|
+
return item._id ?? index;
|
|
90
|
+
}
|
|
67
91
|
showWidget(layoutNode) {
|
|
68
92
|
return this.jsf.evaluateCondition(layoutNode, this.dataIndex());
|
|
69
93
|
}
|
|
94
|
+
ngOnChanges(changes) {
|
|
95
|
+
if (changes['layout'] || changes['dataIndex'] || changes['layoutIndex']) {
|
|
96
|
+
// Clear the entire cache of the memoized function
|
|
97
|
+
this._getSelectFrameworkInputsMemoized.cache.clear();
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
ngOnDestroy() {
|
|
101
|
+
//this.selectframeworkInputCache?.clear()
|
|
102
|
+
//this.selectframeworkInputCache=null;
|
|
103
|
+
this._getSelectFrameworkInputsMemoized.cache.clear();
|
|
104
|
+
//this.dataChangesSubs?.unsubscribe();
|
|
105
|
+
}
|
|
70
106
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FlexLayoutRootComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
71
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "17.3.12", type: FlexLayoutRootComponent, selector: "flex-layout-root-widget", inputs: { dataIndex: { classPropertyName: "dataIndex", publicName: "dataIndex", isSignal: true, isRequired: false, transformFunction: null }, layoutIndex: { classPropertyName: "layoutIndex", publicName: "layoutIndex", isSignal: true, isRequired: false, transformFunction: null }, layout: { classPropertyName: "layout", publicName: "layout", isSignal: true, isRequired: false, transformFunction: null }, isFlexItem: { classPropertyName: "isFlexItem", publicName: "isFlexItem", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: `
|
|
107
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "17.3.12", type: FlexLayoutRootComponent, selector: "flex-layout-root-widget", inputs: { dataIndex: { classPropertyName: "dataIndex", publicName: "dataIndex", isSignal: true, isRequired: false, transformFunction: null }, layoutIndex: { classPropertyName: "layoutIndex", publicName: "layoutIndex", isSignal: true, isRequired: false, transformFunction: null }, layout: { classPropertyName: "layout", publicName: "layout", isSignal: true, isRequired: false, transformFunction: null }, isOrderable: { classPropertyName: "isOrderable", publicName: "isOrderable", isSignal: true, isRequired: false, transformFunction: null }, isFlexItem: { classPropertyName: "isFlexItem", publicName: "isFlexItem", isSignal: true, isRequired: false, transformFunction: null }, memoizationEnabled: { classPropertyName: "memoizationEnabled", publicName: "memoizationEnabled", isSignal: true, isRequired: false, transformFunction: null } }, usesOnChanges: true, ngImport: i0, template: `
|
|
72
108
|
<div cdkDropList (cdkDropListDropped)="drop($event)"
|
|
73
109
|
[class.flex-inherit]="true"
|
|
74
110
|
[cdkDropListSortPredicate]="sortPredicate"
|
|
75
111
|
>
|
|
76
|
-
|
|
112
|
+
<!-- -for now left out
|
|
113
|
+
cdkDragHandle directive, by itself, does not disable the
|
|
114
|
+
default drag behavior of its parent cdkDrag element.
|
|
115
|
+
You must explicitly disable dragging on the main element
|
|
116
|
+
and re-enable it only when using the handle.
|
|
117
|
+
-->
|
|
118
|
+
<div *ngFor="let layoutItem of layout(); let i = index;trackBy: trackByFn"
|
|
77
119
|
cdkDrag [cdkDragStartDelay]="{touch:1000,mouse:0}"
|
|
78
|
-
|
|
120
|
+
[cdkDragDisabled]="!isDraggable(layoutItem)"
|
|
79
121
|
[class.form-flex-item]="isFlexItem()"
|
|
80
|
-
[style.flex-grow]="getFlexAttribute(
|
|
81
|
-
[style.flex-shrink]="getFlexAttribute(
|
|
82
|
-
[style.flex-basis]="getFlexAttribute(
|
|
83
|
-
[style.align-self]="(
|
|
84
|
-
[style.order]="
|
|
85
|
-
[attr.fxFlex]="
|
|
86
|
-
[attr.fxFlexOrder]="
|
|
87
|
-
[attr.fxFlexOffset]="
|
|
88
|
-
[attr.fxFlexAlign]="
|
|
122
|
+
[style.flex-grow]="getFlexAttribute(layoutItem, 'flex-grow')"
|
|
123
|
+
[style.flex-shrink]="getFlexAttribute(layoutItem, 'flex-shrink')"
|
|
124
|
+
[style.flex-basis]="getFlexAttribute(layoutItem, 'flex-basis')"
|
|
125
|
+
[style.align-self]="(layoutItem?.options || {})['align-self']"
|
|
126
|
+
[style.order]="layoutItem?.options?.order"
|
|
127
|
+
[attr.fxFlex]="layoutItem?.options?.fxFlex"
|
|
128
|
+
[attr.fxFlexOrder]="layoutItem?.options?.fxFlexOrder"
|
|
129
|
+
[attr.fxFlexOffset]="layoutItem?.options?.fxFlexOffset"
|
|
130
|
+
[attr.fxFlexAlign]="layoutItem?.options?.fxFlexAlign"
|
|
89
131
|
|
|
90
132
|
>
|
|
91
133
|
<!-- workaround to disbale dragging of input fields -->
|
|
92
|
-
|
|
134
|
+
<!--
|
|
135
|
+
<div *ngIf="layoutItem?.dataType !='object'" cdkDragHandle>
|
|
93
136
|
<p></p>
|
|
94
137
|
</div>
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
138
|
+
-->
|
|
139
|
+
<!--
|
|
140
|
+
<select-framework-widget *ngIf="showWidget(layoutItem)"
|
|
141
|
+
[dataIndex]="layoutItem?.arrayItem ? (dataIndex() || []).concat(i) : (dataIndex() || [])"
|
|
98
142
|
[layoutIndex]="(layoutIndex() || []).concat(i)"
|
|
99
|
-
[layoutNode]="
|
|
143
|
+
[layoutNode]="layoutItem"></select-framework-widget>
|
|
144
|
+
-->
|
|
145
|
+
<select-framework-widget *ngIf="showWidget(layoutItem)"
|
|
146
|
+
[dataIndex]="getSelectFrameworkInputs(layoutItem,i).dataIndex"
|
|
147
|
+
[layoutIndex]="getSelectFrameworkInputs(layoutItem,i).layoutIndex"
|
|
148
|
+
[layoutNode]="getSelectFrameworkInputs(layoutItem,i).layoutNode">
|
|
149
|
+
</select-framework-widget>
|
|
100
150
|
</div>
|
|
101
|
-
</div>`, isInline: true, styles: [".example-list{width:500px;max-width:100%;border:solid 1px #ccc;min-height:60px;display:block;background:#fff;border-radius:4px;overflow:hidden}.example-box{padding:20px 10px;border-bottom:solid 1px #ccc;color:#000000de;display:flex;flex-direction:row;align-items:center;justify-content:space-between;box-sizing:border-box;cursor:move;background:#fff;font-size:14px}.cdk-drag-preview{border:none;box-sizing:border-box;border-radius:4px;box-shadow:0 5px 5px -3px #0003,0 8px 10px 1px #00000024,0 3px 14px 2px #0000001f}.cdk-drag-placeholder{opacity:0}.cdk-drag-animating{transition:transform .25s cubic-bezier(0,0,.2,1)}.example-box:last-child{border:none}.example-list.cdk-drop-list-dragging .example-box:not(.cdk-drag-placeholder){transition:transform .25s cubic-bezier(0,0,.2,1)}.flex-inherit{display:inherit;flex-flow:inherit;flex-wrap:inherit;flex-direction:inherit;width:100%}\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.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: i2.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: "
|
|
151
|
+
</div>`, isInline: true, styles: [".example-list{width:500px;max-width:100%;border:solid 1px #ccc;min-height:60px;display:block;background:#fff;border-radius:4px;overflow:hidden}.example-box{padding:20px 10px;border-bottom:solid 1px #ccc;color:#000000de;display:flex;flex-direction:row;align-items:center;justify-content:space-between;box-sizing:border-box;cursor:move;background:#fff;font-size:14px}.cdk-drag-preview{border:none;box-sizing:border-box;border-radius:4px;box-shadow:0 5px 5px -3px #0003,0 8px 10px 1px #00000024,0 3px 14px 2px #0000001f}.cdk-drag-placeholder{opacity:0}.cdk-drag-animating{transition:transform .25s cubic-bezier(0,0,.2,1)}.example-box:last-child{border:none}.example-list.cdk-drop-list-dragging .example-box:not(.cdk-drag-placeholder){transition:transform .25s cubic-bezier(0,0,.2,1)}.flex-inherit{display:inherit;flex-flow:inherit;flex-wrap:inherit;flex-direction:inherit;width:100%}\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.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: i2.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: i3.SelectFrameworkComponent, selector: "select-framework-widget", inputs: ["layoutNode", "layoutIndex", "dataIndex"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
102
152
|
}
|
|
103
153
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FlexLayoutRootComponent, decorators: [{
|
|
104
154
|
type: Component,
|
|
@@ -107,31 +157,45 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
107
157
|
[class.flex-inherit]="true"
|
|
108
158
|
[cdkDropListSortPredicate]="sortPredicate"
|
|
109
159
|
>
|
|
110
|
-
|
|
160
|
+
<!-- -for now left out
|
|
161
|
+
cdkDragHandle directive, by itself, does not disable the
|
|
162
|
+
default drag behavior of its parent cdkDrag element.
|
|
163
|
+
You must explicitly disable dragging on the main element
|
|
164
|
+
and re-enable it only when using the handle.
|
|
165
|
+
-->
|
|
166
|
+
<div *ngFor="let layoutItem of layout(); let i = index;trackBy: trackByFn"
|
|
111
167
|
cdkDrag [cdkDragStartDelay]="{touch:1000,mouse:0}"
|
|
112
|
-
|
|
168
|
+
[cdkDragDisabled]="!isDraggable(layoutItem)"
|
|
113
169
|
[class.form-flex-item]="isFlexItem()"
|
|
114
|
-
[style.flex-grow]="getFlexAttribute(
|
|
115
|
-
[style.flex-shrink]="getFlexAttribute(
|
|
116
|
-
[style.flex-basis]="getFlexAttribute(
|
|
117
|
-
[style.align-self]="(
|
|
118
|
-
[style.order]="
|
|
119
|
-
[attr.fxFlex]="
|
|
120
|
-
[attr.fxFlexOrder]="
|
|
121
|
-
[attr.fxFlexOffset]="
|
|
122
|
-
[attr.fxFlexAlign]="
|
|
170
|
+
[style.flex-grow]="getFlexAttribute(layoutItem, 'flex-grow')"
|
|
171
|
+
[style.flex-shrink]="getFlexAttribute(layoutItem, 'flex-shrink')"
|
|
172
|
+
[style.flex-basis]="getFlexAttribute(layoutItem, 'flex-basis')"
|
|
173
|
+
[style.align-self]="(layoutItem?.options || {})['align-self']"
|
|
174
|
+
[style.order]="layoutItem?.options?.order"
|
|
175
|
+
[attr.fxFlex]="layoutItem?.options?.fxFlex"
|
|
176
|
+
[attr.fxFlexOrder]="layoutItem?.options?.fxFlexOrder"
|
|
177
|
+
[attr.fxFlexOffset]="layoutItem?.options?.fxFlexOffset"
|
|
178
|
+
[attr.fxFlexAlign]="layoutItem?.options?.fxFlexAlign"
|
|
123
179
|
|
|
124
180
|
>
|
|
125
181
|
<!-- workaround to disbale dragging of input fields -->
|
|
126
|
-
|
|
182
|
+
<!--
|
|
183
|
+
<div *ngIf="layoutItem?.dataType !='object'" cdkDragHandle>
|
|
127
184
|
<p></p>
|
|
128
185
|
</div>
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
186
|
+
-->
|
|
187
|
+
<!--
|
|
188
|
+
<select-framework-widget *ngIf="showWidget(layoutItem)"
|
|
189
|
+
[dataIndex]="layoutItem?.arrayItem ? (dataIndex() || []).concat(i) : (dataIndex() || [])"
|
|
132
190
|
[layoutIndex]="(layoutIndex() || []).concat(i)"
|
|
133
|
-
[layoutNode]="
|
|
191
|
+
[layoutNode]="layoutItem"></select-framework-widget>
|
|
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>
|
|
134
198
|
</div>
|
|
135
|
-
</div>`, changeDetection: ChangeDetectionStrategy.
|
|
199
|
+
</div>`, changeDetection: ChangeDetectionStrategy.OnPush, standalone: false, styles: [".example-list{width:500px;max-width:100%;border:solid 1px #ccc;min-height:60px;display:block;background:#fff;border-radius:4px;overflow:hidden}.example-box{padding:20px 10px;border-bottom:solid 1px #ccc;color:#000000de;display:flex;flex-direction:row;align-items:center;justify-content:space-between;box-sizing:border-box;cursor:move;background:#fff;font-size:14px}.cdk-drag-preview{border:none;box-sizing:border-box;border-radius:4px;box-shadow:0 5px 5px -3px #0003,0 8px 10px 1px #00000024,0 3px 14px 2px #0000001f}.cdk-drag-placeholder{opacity:0}.cdk-drag-animating{transition:transform .25s cubic-bezier(0,0,.2,1)}.example-box:last-child{border:none}.example-list.cdk-drop-list-dragging .example-box:not(.cdk-drag-placeholder){transition:transform .25s cubic-bezier(0,0,.2,1)}.flex-inherit{display:inherit;flex-flow:inherit;flex-wrap:inherit;flex-direction:inherit;width:100%}\n"] }]
|
|
136
200
|
}] });
|
|
137
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"flex-layout-root.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-formworks-material/src/lib/widgets/flex-layout-root.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { CdkDrag, CdkDragDrop } from '@angular/cdk/drag-drop';\r\nimport { ChangeDetectionStrategy, Component, inject, input, OnInit } from '@angular/core';\r\nimport { JsonSchemaFormService } from '@ng-formworks/core';\r\n\r\n\r\n@Component({\r\n    // tslint:disable-next-line:component-selector\r\n    selector: 'flex-layout-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      <div *ngFor=\"let layoutNode of layout(); let i = index\" \r\n       cdkDrag  [cdkDragStartDelay]=\"{touch:1000,mouse:0}\"\r\n       \r\n        [class.form-flex-item]=\"isFlexItem()\"\r\n        [style.flex-grow]=\"getFlexAttribute(layoutNode, 'flex-grow')\"\r\n        [style.flex-shrink]=\"getFlexAttribute(layoutNode, 'flex-shrink')\"\r\n        [style.flex-basis]=\"getFlexAttribute(layoutNode, 'flex-basis')\"\r\n        [style.align-self]=\"(layoutNode?.options || {})['align-self']\"\r\n        [style.order]=\"layoutNode?.options?.order\"\r\n        [attr.fxFlex]=\"layoutNode?.options?.fxFlex\"\r\n        [attr.fxFlexOrder]=\"layoutNode?.options?.fxFlexOrder\"\r\n        [attr.fxFlexOffset]=\"layoutNode?.options?.fxFlexOffset\"\r\n        [attr.fxFlexAlign]=\"layoutNode?.options?.fxFlexAlign\"\r\n\r\n        >\r\n        <!-- workaround to disbale dragging of input fields -->\r\n        <div *ngIf=\"layoutNode?.dataType !='object'\" cdkDragHandle>\r\n         <p></p>\r\n        </div>\r\n        <select-framework-widget *ngIf=\"showWidget(layoutNode)\"\r\n       \r\n          [dataIndex]=\"layoutNode?.arrayItem ? (dataIndex() || []).concat(i) : (dataIndex() || [])\"\r\n          [layoutIndex]=\"(layoutIndex() || []).concat(i)\"\r\n          [layoutNode]=\"layoutNode\"></select-framework-widget>\r\n      </div>\r\n    </div>`,\r\n    styles:`\r\n    .example-list {\r\n  width: 500px;\r\n  max-width: 100%;\r\n  border: solid 1px #ccc;\r\n  min-height: 60px;\r\n  display: block;\r\n  background: white;\r\n  border-radius: 4px;\r\n  overflow: hidden;\r\n}\r\n\r\n.example-box {\r\n  padding: 20px 10px;\r\n  border-bottom: solid 1px #ccc;\r\n  color: rgba(0, 0, 0, 0.87);\r\n  display: flex;\r\n  flex-direction: row;\r\n  align-items: center;\r\n  justify-content: space-between;\r\n  box-sizing: border-box;\r\n  cursor: move;\r\n  background: white;\r\n  font-size: 14px;\r\n}\r\n\r\n.cdk-drag-preview {\r\n  border: none;\r\n  box-sizing: border-box;\r\n  border-radius: 4px;\r\n  box-shadow: 0 5px 5px -3px rgba(0, 0, 0, 0.2),\r\n              0 8px 10px 1px rgba(0, 0, 0, 0.14),\r\n              0 3px 14px 2px rgba(0, 0, 0, 0.12);\r\n}\r\n\r\n.cdk-drag-placeholder {\r\n  opacity: 0;\r\n}\r\n\r\n.cdk-drag-animating {\r\n  transition: transform 250ms cubic-bezier(0, 0, 0.2, 1);\r\n}\r\n\r\n.example-box:last-child {\r\n  border: none;\r\n}\r\n\r\n.example-list.cdk-drop-list-dragging .example-box:not(.cdk-drag-placeholder) {\r\n  transition: transform 250ms cubic-bezier(0, 0, 0.2, 1);\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`,\r\n    changeDetection: ChangeDetectionStrategy.Default,\r\n    standalone: false\r\n})\r\nexport class FlexLayoutRootComponent implements OnInit {\r\n  private jsf = inject(JsonSchemaFormService);\r\n\r\n  readonly dataIndex = input<number[]>(undefined);\r\n  readonly layoutIndex = input<number[]>(undefined);\r\n  readonly layout = input<any[]>(undefined);\r\n  readonly isFlexItem = input(false);\r\n  ngOnInit() {\r\n\r\n  }\r\n  removeItem(item) {\r\n    this.jsf.removeItem(item);\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\r\n      \r\n    }\r\n  }\r\n  sortableInit(sortable) {\r\n    this.sortableObj = sortable;\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    // same properties as onEnd\r\n    //console.log(`sortablejs event:${evt}`);\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:()=>{return dataInd},\r\n      layoutIndex:()=>{return layoutInd},\r\n      layoutNode:()=>{return layoutItem},\r\n    }\r\n    //must set moveLayout to false as nxtSortable already moves it\r\n    this.jsf.moveArrayItem(itemCtx, srcInd, trgInd,true);\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    sortPredicate=(index: number, item: CdkDrag<number>)=> {\r\n      let layoutItem=this.layout()[index];\r\n      let result=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 flex-layout-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}\r\n"]}
|
|
201
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"flex-layout-root.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-formworks-material/src/lib/widgets/flex-layout-root.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { CdkDrag, CdkDragDrop } from '@angular/cdk/drag-drop';\r\nimport { ChangeDetectionStrategy, Component, inject, input, OnChanges, OnDestroy, OnInit, SimpleChanges } from '@angular/core';\r\nimport { JsonSchemaFormService } from '@ng-formworks/core';\r\nimport { memoize } from 'lodash';\r\n\r\n\r\n@Component({\r\n    // tslint:disable-next-line:component-selector\r\n    selector: 'flex-layout-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.flex-grow]=\"getFlexAttribute(layoutItem, 'flex-grow')\"\r\n        [style.flex-shrink]=\"getFlexAttribute(layoutItem, 'flex-shrink')\"\r\n        [style.flex-basis]=\"getFlexAttribute(layoutItem, 'flex-basis')\"\r\n        [style.align-self]=\"(layoutItem?.options || {})['align-self']\"\r\n        [style.order]=\"layoutItem?.options?.order\"\r\n        [attr.fxFlex]=\"layoutItem?.options?.fxFlex\"\r\n        [attr.fxFlexOrder]=\"layoutItem?.options?.fxFlexOrder\"\r\n        [attr.fxFlexOffset]=\"layoutItem?.options?.fxFlexOffset\"\r\n        [attr.fxFlexAlign]=\"layoutItem?.options?.fxFlexAlign\"\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></p>\r\n        </div>\r\n        -->\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        -->\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    styles:`\r\n    .example-list {\r\n  width: 500px;\r\n  max-width: 100%;\r\n  border: solid 1px #ccc;\r\n  min-height: 60px;\r\n  display: block;\r\n  background: white;\r\n  border-radius: 4px;\r\n  overflow: hidden;\r\n}\r\n\r\n.example-box {\r\n  padding: 20px 10px;\r\n  border-bottom: solid 1px #ccc;\r\n  color: rgba(0, 0, 0, 0.87);\r\n  display: flex;\r\n  flex-direction: row;\r\n  align-items: center;\r\n  justify-content: space-between;\r\n  box-sizing: border-box;\r\n  cursor: move;\r\n  background: white;\r\n  font-size: 14px;\r\n}\r\n\r\n.cdk-drag-preview {\r\n  border: none;\r\n  box-sizing: border-box;\r\n  border-radius: 4px;\r\n  box-shadow: 0 5px 5px -3px rgba(0, 0, 0, 0.2),\r\n              0 8px 10px 1px rgba(0, 0, 0, 0.14),\r\n              0 3px 14px 2px rgba(0, 0, 0, 0.12);\r\n}\r\n\r\n.cdk-drag-placeholder {\r\n  opacity: 0;\r\n}\r\n\r\n.cdk-drag-animating {\r\n  transition: transform 250ms cubic-bezier(0, 0, 0.2, 1);\r\n}\r\n\r\n.example-box:last-child {\r\n  border: none;\r\n}\r\n\r\n.example-list.cdk-drop-list-dragging .example-box:not(.cdk-drag-placeholder) {\r\n  transition: transform 250ms cubic-bezier(0, 0, 0.2, 1);\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`,\r\n    //changeDetection: ChangeDetectionStrategy.Default,\r\n    changeDetection:ChangeDetectionStrategy.OnPush,\r\n    standalone: false\r\n})\r\nexport class FlexLayoutRootComponent implements OnInit,OnDestroy,OnChanges {\r\n\r\n  private jsf = inject(JsonSchemaFormService);\r\n\r\n  readonly dataIndex = input<number[]>(undefined);\r\n  readonly layoutIndex = input<number[]>(undefined);\r\n  readonly layout = input<any[]>(undefined);\r\n  readonly isOrderable = input<boolean>(undefined);\r\n  readonly isFlexItem = input(false);\r\n  readonly memoizationEnabled= input<boolean>(true);\r\n  ngOnInit() {\r\n\r\n  }\r\n  removeItem(item) {\r\n    this.jsf.removeItem(item);\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:()=>{return dataInd},\r\n      layoutIndex:()=>{return layoutInd},\r\n      layoutNode:()=>{return 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\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    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 flex-layout-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 _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    \r\n    trackByFn(index: number, item: any): any {\r\n      return item._id ?? index;\r\n    }\r\n\r\n  showWidget(layoutNode: any): boolean {\r\n    return this.jsf.evaluateCondition(layoutNode, this.dataIndex());\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  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"]}
|
|
@@ -207,7 +207,7 @@ export class FlexLayoutSectionComponent {
|
|
|
207
207
|
</fieldset>
|
|
208
208
|
<mat-error *ngIf="options?.showErrors && options?.errorMessage"
|
|
209
209
|
[innerHTML]="options?.errorMessage"></mat-error>
|
|
210
|
-
</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
|
+
</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", "isOrderable", "isFlexItem", "memoizationEnabled"] }] }); }
|
|
211
211
|
}
|
|
212
212
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FlexLayoutSectionComponent, decorators: [{
|
|
213
213
|
type: Component,
|
|
@@ -1,8 +1,9 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component,
|
|
1
|
+
import { ChangeDetectionStrategy, Component, inject, input } from '@angular/core';
|
|
2
2
|
import { JsonSchemaFormService } from '@ng-formworks/core';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
import * as i1 from "@angular/common";
|
|
5
5
|
import * as i2 from "@angular/material/button";
|
|
6
|
+
import * as i3 from "@ng-formworks/core";
|
|
6
7
|
export class MaterialAddReferenceComponent {
|
|
7
8
|
constructor() {
|
|
8
9
|
this.jsf = inject(JsonSchemaFormService);
|
|
@@ -36,11 +37,12 @@ export class MaterialAddReferenceComponent {
|
|
|
36
37
|
<button mat-raised-button *ngIf="showAddButton"
|
|
37
38
|
[color]="options?.color || 'accent'"
|
|
38
39
|
[disabled]="options?.readonly"
|
|
39
|
-
(click)="addItem($event)"
|
|
40
|
+
(click)="addItem($event)"
|
|
41
|
+
[appStopPropagation]="['mousedown', 'touchstart']">
|
|
40
42
|
<span *ngIf="options?.icon" [class]="options?.icon"></span>
|
|
41
43
|
<span *ngIf="options?.title" [innerHTML]="buttonText"></span>
|
|
42
44
|
</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 }); }
|
|
45
|
+
</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"] }, { kind: "directive", type: i3.StopPropagationDirective, selector: "[appStopPropagation]", inputs: ["appStopPropagation"] }], changeDetection: i0.ChangeDetectionStrategy.Default }); }
|
|
44
46
|
}
|
|
45
47
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MaterialAddReferenceComponent, decorators: [{
|
|
46
48
|
type: Component,
|
|
@@ -52,7 +54,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
52
54
|
<button mat-raised-button *ngIf="showAddButton"
|
|
53
55
|
[color]="options?.color || 'accent'"
|
|
54
56
|
[disabled]="options?.readonly"
|
|
55
|
-
(click)="addItem($event)"
|
|
57
|
+
(click)="addItem($event)"
|
|
58
|
+
[appStopPropagation]="['mousedown', 'touchstart']">
|
|
56
59
|
<span *ngIf="options?.icon" [class]="options?.icon"></span>
|
|
57
60
|
<span *ngIf="options?.title" [innerHTML]="buttonText"></span>
|
|
58
61
|
</button>
|
|
@@ -60,4 +63,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
60
63
|
changeDetection: ChangeDetectionStrategy.Default,
|
|
61
64
|
}]
|
|
62
65
|
}] });
|
|
63
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
66
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWF0ZXJpYWwtYWRkLXJlZmVyZW5jZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy1mb3Jtd29ya3MtbWF0ZXJpYWwvc3JjL2xpYi93aWRnZXRzL21hdGVyaWFsLWFkZC1yZWZlcmVuY2UuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQVUsTUFBTSxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMxRixPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQzs7Ozs7QUFtQjNELE1BQU0sT0FBTyw2QkFBNkI7SUFoQjFDO1FBaUJVLFFBQUcsR0FBRyxNQUFNLENBQUMscUJBQXFCLENBQUMsQ0FBQztRQU1uQyxlQUFVLEdBQUcsS0FBSyxDQUFNLFNBQVMsQ0FBQyxDQUFDO1FBQ25DLGdCQUFXLEdBQUcsS0FBSyxDQUFXLFNBQVMsQ0FBQyxDQUFDO1FBQ3pDLGNBQVMsR0FBRyxLQUFLLENBQVcsU0FBUyxDQUFDLENBQUM7S0F5QmpEO0lBdkJDLFFBQVE7UUFDTixJQUFJLENBQUMsT0FBTyxHQUFHLElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQyxPQUFPLElBQUksRUFBRSxDQUFDO0lBQ2pELENBQUM7SUFFRCxJQUFJLGFBQWE7UUFDZixPQUFPLENBQUMsSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFDLFNBQVM7WUFDakMsSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxRQUFRLENBQUM7SUFDOUUsQ0FBQztJQUVELE9BQU8sQ0FBQyxLQUFLO1FBQ1gsS0FBSyxDQUFDLGNBQWMsRUFBRSxDQUFDO1FBQ3ZCLElBQUksQ0FBQyxHQUFHLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ3pCLENBQUM7SUFFRCxJQUFJLFVBQVU7UUFDWixNQUFNLE1BQU0sR0FBUTtZQUNsQixTQUFTLEVBQUUsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDLEtBQUssQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUM7WUFDeEMsV0FBVyxFQUFFLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQyxLQUFLLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDO1lBQzVDLFVBQVUsRUFBRSxJQUFJLENBQUMsR0FBRyxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUM7U0FDekMsQ0FBQztRQUNGLE9BQU8sTUFBTSxDQUFDLFVBQVUsQ0FBQyxHQUFHO1lBQzFCLElBQUksQ0FBQyxHQUFHLENBQUMsaUJBQWlCLENBQUMsTUFBTSxFQUFFLElBQUksQ0FBQyxVQUFVLEVBQUUsRUFBRSxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUM7SUFDMUUsQ0FBQzsrR0FqQ1UsNkJBQTZCO21HQUE3Qiw2QkFBNkIsc2VBYjlCOzs7Ozs7Ozs7O2VBVUc7OzRGQUdGLDZCQUE2QjtrQkFoQnpDLFNBQVM7bUJBQUM7b0JBQ1QsOENBQThDO29CQUM5QyxRQUFRLEVBQUUsK0JBQStCO29CQUN6QyxRQUFRLEVBQUU7Ozs7Ozs7Ozs7ZUFVRztvQkFDYixlQUFlLEVBQUUsdUJBQXVCLENBQUMsT0FBTztpQkFDakQiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBPbkluaXQsIGluamVjdCwgaW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgSnNvblNjaGVtYUZvcm1TZXJ2aWNlIH0gZnJvbSAnQG5nLWZvcm13b3Jrcy9jb3JlJztcclxuXHJcblxyXG5AQ29tcG9uZW50KHtcclxuICAvLyB0c2xpbnQ6ZGlzYWJsZS1uZXh0LWxpbmU6Y29tcG9uZW50LXNlbGVjdG9yXHJcbiAgc2VsZWN0b3I6ICdtYXRlcmlhbC1hZGQtcmVmZXJlbmNlLXdpZGdldCcsXHJcbiAgdGVtcGxhdGU6IGBcclxuICAgIDxzZWN0aW9uIFtjbGFzc109XCJvcHRpb25zPy5odG1sQ2xhc3MgfHwgJydcIiBhbGlnbj1cImVuZFwiPlxyXG4gICAgICA8YnV0dG9uIG1hdC1yYWlzZWQtYnV0dG9uICpuZ0lmPVwic2hvd0FkZEJ1dHRvblwiXHJcbiAgICAgICAgW2NvbG9yXT1cIm9wdGlvbnM/LmNvbG9yIHx8ICdhY2NlbnQnXCJcclxuICAgICAgICBbZGlzYWJsZWRdPVwib3B0aW9ucz8ucmVhZG9ubHlcIlxyXG4gICAgICAgIChjbGljayk9XCJhZGRJdGVtKCRldmVudClcIlxyXG4gICAgICAgIFthcHBTdG9wUHJvcGFnYXRpb25dPVwiWydtb3VzZWRvd24nLCAndG91Y2hzdGFydCddXCI+XHJcbiAgICAgICAgPHNwYW4gKm5nSWY9XCJvcHRpb25zPy5pY29uXCIgW2NsYXNzXT1cIm9wdGlvbnM/Lmljb25cIj48L3NwYW4+XHJcbiAgICAgICAgPHNwYW4gKm5nSWY9XCJvcHRpb25zPy50aXRsZVwiIFtpbm5lckhUTUxdPVwiYnV0dG9uVGV4dFwiPjwvc3Bhbj5cclxuICAgICAgPC9idXR0b24+XHJcbiAgICA8L3NlY3Rpb24+YCxcclxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LkRlZmF1bHQsXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBNYXRlcmlhbEFkZFJlZmVyZW5jZUNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XHJcbiAgcHJpdmF0ZSBqc2YgPSBpbmplY3QoSnNvblNjaGVtYUZvcm1TZXJ2aWNlKTtcclxuXHJcbiAgb3B0aW9uczogYW55O1xyXG4gIGl0ZW1Db3VudDogbnVtYmVyO1xyXG4gIHByZXZpb3VzTGF5b3V0SW5kZXg6IG51bWJlcltdO1xyXG4gIHByZXZpb3VzRGF0YUluZGV4OiBudW1iZXJbXTtcclxuICByZWFkb25seSBsYXlvdXROb2RlID0gaW5wdXQ8YW55Pih1bmRlZmluZWQpO1xyXG4gIHJlYWRvbmx5IGxheW91dEluZGV4ID0gaW5wdXQ8bnVtYmVyW10+KHVuZGVmaW5lZCk7XHJcbiAgcmVhZG9ubHkgZGF0YUluZGV4ID0gaW5wdXQ8bnVtYmVyW10+KHVuZGVmaW5lZCk7XHJcblxyXG4gIG5nT25Jbml0KCkge1xyXG4gICAgdGhpcy5vcHRpb25zID0gdGhpcy5sYXlvdXROb2RlKCkub3B0aW9ucyB8fCB7fTtcclxuICB9XHJcblxyXG4gIGdldCBzaG93QWRkQnV0dG9uKCk6IGJvb2xlYW4ge1xyXG4gICAgcmV0dXJuICF0aGlzLmxheW91dE5vZGUoKS5hcnJheUl0ZW0gfHxcclxuICAgICAgdGhpcy5sYXlvdXRJbmRleCgpW3RoaXMubGF5b3V0SW5kZXgoKS5sZW5ndGggLSAxXSA8IHRoaXMub3B0aW9ucy5tYXhJdGVtcztcclxuICB9XHJcblxyXG4gIGFkZEl0ZW0oZXZlbnQpIHtcclxuICAgIGV2ZW50LnByZXZlbnREZWZhdWx0KCk7XHJcbiAgICB0aGlzLmpzZi5hZGRJdGVtKHRoaXMpO1xyXG4gIH1cclxuXHJcbiAgZ2V0IGJ1dHRvblRleHQoKTogc3RyaW5nIHtcclxuICAgIGNvbnN0IHBhcmVudDogYW55ID0ge1xyXG4gICAgICBkYXRhSW5kZXg6IHRoaXMuZGF0YUluZGV4KCkuc2xpY2UoMCwgLTEpLFxyXG4gICAgICBsYXlvdXRJbmRleDogdGhpcy5sYXlvdXRJbmRleCgpLnNsaWNlKDAsIC0xKSxcclxuICAgICAgbGF5b3V0Tm9kZTogdGhpcy5qc2YuZ2V0UGFyZW50Tm9kZSh0aGlzKSxcclxuICAgIH07XHJcbiAgICByZXR1cm4gcGFyZW50LmxheW91dE5vZGUuYWRkIHx8XHJcbiAgICAgIHRoaXMuanNmLnNldEFycmF5SXRlbVRpdGxlKHBhcmVudCwgdGhpcy5sYXlvdXROb2RlKCksIHRoaXMuaXRlbUNvdW50KTtcclxuICB9XHJcbn1cclxuIl19
|
|
@@ -35,7 +35,7 @@ export class MaterialButtonGroupComponent {
|
|
|
35
35
|
[attr.for]="'control' + layoutNode()?._id"
|
|
36
36
|
[class]="options?.labelHtmlClass || ''"
|
|
37
37
|
[style.display]="options?.notitle ? 'none' : ''"
|
|
38
|
-
[innerHTML]="options?.title"></label>
|
|
38
|
+
[innerHTML]="layoutNode().options?.title"></label>
|
|
39
39
|
</div>
|
|
40
40
|
<mat-button-toggle-group
|
|
41
41
|
[attr.aria-describedby]="'control' + layoutNode()?._id + 'Status'"
|
|
@@ -65,7 +65,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
65
65
|
[attr.for]="'control' + layoutNode()?._id"
|
|
66
66
|
[class]="options?.labelHtmlClass || ''"
|
|
67
67
|
[style.display]="options?.notitle ? 'none' : ''"
|
|
68
|
-
[innerHTML]="options?.title"></label>
|
|
68
|
+
[innerHTML]="layoutNode().options?.title"></label>
|
|
69
69
|
</div>
|
|
70
70
|
<mat-button-toggle-group
|
|
71
71
|
[attr.aria-describedby]="'control' + layoutNode()?._id + 'Status'"
|
|
@@ -86,4 +86,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
86
86
|
[innerHTML]="options?.errorMessage"></mat-error>
|
|
87
87
|
</div>`, styles: ["mat-error{font-size:75%}\n"] }]
|
|
88
88
|
}] });
|
|
89
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWF0ZXJpYWwtYnV0dG9uLWdyb3VwLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLWZvcm13b3Jrcy1tYXRlcmlhbC9zcmMvbGliL3dpZGdldHMvbWF0ZXJpYWwtYnV0dG9uLWdyb3VwLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFxQixNQUFNLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRTVFLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxhQUFhLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQzs7Ozs7QUFtQzFFLE1BQU0sT0FBTyw0QkFBNEI7SUFoQ3pDO1FBaUNVLFFBQUcsR0FBRyxNQUFNLENBQUMscUJBQXFCLENBQUMsQ0FBQztRQUs1QyxvQkFBZSxHQUFHLEtBQUssQ0FBQztRQUN4QixpQkFBWSxHQUFHLEtBQUssQ0FBQztRQUVyQixlQUFVLEdBQVUsRUFBRSxDQUFDO1FBQ3ZCLGFBQVEsR0FBRyxLQUFLLENBQUM7UUFDUixlQUFVLEdBQUcsS0FBSyxDQUFNLFNBQVMsQ0FBQyxDQUFDO1FBQ25DLGdCQUFXLEdBQUcsS0FBSyxDQUFXLFNBQVMsQ0FBQyxDQUFDO1FBQ3pDLGNBQVMsR0FBRyxLQUFLLENBQVcsU0FBUyxDQUFDLENBQUM7S0FrQmpEO0lBaEJDLFFBQVE7UUFDTixJQUFJLENBQUMsT0FBTyxHQUFHLElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQyxPQUFPLElBQUksRUFBRSxDQUFDO1FBQy9DLElBQUksQ0FBQyxVQUFVLEdBQUcsYUFBYSxDQUM3QixJQUFJLENBQUMsT0FBTyxDQUFDLFFBQVEsSUFBSSxJQUFJLENBQUMsT0FBTyxDQUFDLFNBQVMsRUFDL0MsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLEVBQUUsSUFBSSxDQUN4QixDQUFDO1FBQ0YsSUFBSSxDQUFDLEdBQUcsQ0FBQyxpQkFBaUIsQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUNuQyxDQUFDO0lBRUQsV0FBVyxDQUFDLEtBQUs7UUFDZixJQUFJLENBQUMsT0FBTyxDQUFDLFVBQVUsR0FBRyxJQUFJLENBQUM7UUFDL0IsSUFBSSxDQUFDLEdBQUcsQ0FBQyxXQUFXLENBQUMsSUFBSSxFQUFFLEtBQUssQ0FBQyxDQUFDO0lBQ3BDLENBQUM7SUFDRCxXQUFXO1FBQ1QsSUFBSSxDQUFDLEdBQUcsQ0FBQyxXQUFXLENBQUMsSUFBSSxFQUFFLElBQUksQ0FBQyxDQUFDO0lBQ25DLENBQUM7K0dBOUJVLDRCQUE0QjttR0FBNUIsNEJBQTRCLHFlQTdCN0I7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O1dBMEJEOzs0RkFHRSw0QkFBNEI7a0JBaEN4QyxTQUFTOytCQUVFLDhCQUE4QixZQUM5Qjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7V0EwQkQiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIE9uRGVzdHJveSwgT25Jbml0LCBpbmplY3QsIGlucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IEFic3RyYWN0Q29udHJvbCB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcclxuaW1wb3J0IHsgSnNvblNjaGVtYUZvcm1TZXJ2aWNlLCBidWlsZFRpdGxlTWFwIH0gZnJvbSAnQG5nLWZvcm13b3Jrcy9jb3JlJztcclxuXHJcblxyXG5AQ29tcG9uZW50KHtcclxuICAvLyB0c2xpbnQ6ZGlzYWJsZS1uZXh0LWxpbmU6Y29tcG9uZW50LXNlbGVjdG9yXHJcbiAgc2VsZWN0b3I6ICdtYXRlcmlhbC1idXR0b24tZ3JvdXAtd2lkZ2V0JyxcclxuICB0ZW1wbGF0ZTogYFxyXG4gICAgPGRpdj5cclxuICAgICAgPGRpdiAqbmdJZj1cIm9wdGlvbnM/LnRpdGxlXCI+XHJcbiAgICAgICAgPGxhYmVsXHJcbiAgICAgICAgICBbYXR0ci5mb3JdPVwiJ2NvbnRyb2wnICsgbGF5b3V0Tm9kZSgpPy5faWRcIlxyXG4gICAgICAgICAgW2NsYXNzXT1cIm9wdGlvbnM/LmxhYmVsSHRtbENsYXNzIHx8ICcnXCJcclxuICAgICAgICAgIFtzdHlsZS5kaXNwbGF5XT1cIm9wdGlvbnM/
|
|
89
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWF0ZXJpYWwtYnV0dG9uLWdyb3VwLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLWZvcm13b3Jrcy1tYXRlcmlhbC9zcmMvbGliL3dpZGdldHMvbWF0ZXJpYWwtYnV0dG9uLWdyb3VwLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFxQixNQUFNLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRTVFLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxhQUFhLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQzs7Ozs7QUFtQzFFLE1BQU0sT0FBTyw0QkFBNEI7SUFoQ3pDO1FBaUNVLFFBQUcsR0FBRyxNQUFNLENBQUMscUJBQXFCLENBQUMsQ0FBQztRQUs1QyxvQkFBZSxHQUFHLEtBQUssQ0FBQztRQUN4QixpQkFBWSxHQUFHLEtBQUssQ0FBQztRQUVyQixlQUFVLEdBQVUsRUFBRSxDQUFDO1FBQ3ZCLGFBQVEsR0FBRyxLQUFLLENBQUM7UUFDUixlQUFVLEdBQUcsS0FBSyxDQUFNLFNBQVMsQ0FBQyxDQUFDO1FBQ25DLGdCQUFXLEdBQUcsS0FBSyxDQUFXLFNBQVMsQ0FBQyxDQUFDO1FBQ3pDLGNBQVMsR0FBRyxLQUFLLENBQVcsU0FBUyxDQUFDLENBQUM7S0FrQmpEO0lBaEJDLFFBQVE7UUFDTixJQUFJLENBQUMsT0FBTyxHQUFHLElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQyxPQUFPLElBQUksRUFBRSxDQUFDO1FBQy9DLElBQUksQ0FBQyxVQUFVLEdBQUcsYUFBYSxDQUM3QixJQUFJLENBQUMsT0FBTyxDQUFDLFFBQVEsSUFBSSxJQUFJLENBQUMsT0FBTyxDQUFDLFNBQVMsRUFDL0MsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLEVBQUUsSUFBSSxDQUN4QixDQUFDO1FBQ0YsSUFBSSxDQUFDLEdBQUcsQ0FBQyxpQkFBaUIsQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUNuQyxDQUFDO0lBRUQsV0FBVyxDQUFDLEtBQUs7UUFDZixJQUFJLENBQUMsT0FBTyxDQUFDLFVBQVUsR0FBRyxJQUFJLENBQUM7UUFDL0IsSUFBSSxDQUFDLEdBQUcsQ0FBQyxXQUFXLENBQUMsSUFBSSxFQUFFLEtBQUssQ0FBQyxDQUFDO0lBQ3BDLENBQUM7SUFDRCxXQUFXO1FBQ1QsSUFBSSxDQUFDLEdBQUcsQ0FBQyxXQUFXLENBQUMsSUFBSSxFQUFFLElBQUksQ0FBQyxDQUFDO0lBQ25DLENBQUM7K0dBOUJVLDRCQUE0QjttR0FBNUIsNEJBQTRCLHFlQTdCN0I7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O1dBMEJEOzs0RkFHRSw0QkFBNEI7a0JBaEN4QyxTQUFTOytCQUVFLDhCQUE4QixZQUM5Qjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7V0EwQkQiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIE9uRGVzdHJveSwgT25Jbml0LCBpbmplY3QsIGlucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IEFic3RyYWN0Q29udHJvbCB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcclxuaW1wb3J0IHsgSnNvblNjaGVtYUZvcm1TZXJ2aWNlLCBidWlsZFRpdGxlTWFwIH0gZnJvbSAnQG5nLWZvcm13b3Jrcy9jb3JlJztcclxuXHJcblxyXG5AQ29tcG9uZW50KHtcclxuICAvLyB0c2xpbnQ6ZGlzYWJsZS1uZXh0LWxpbmU6Y29tcG9uZW50LXNlbGVjdG9yXHJcbiAgc2VsZWN0b3I6ICdtYXRlcmlhbC1idXR0b24tZ3JvdXAtd2lkZ2V0JyxcclxuICB0ZW1wbGF0ZTogYFxyXG4gICAgPGRpdj5cclxuICAgICAgPGRpdiAqbmdJZj1cIm9wdGlvbnM/LnRpdGxlXCI+XHJcbiAgICAgICAgPGxhYmVsXHJcbiAgICAgICAgICBbYXR0ci5mb3JdPVwiJ2NvbnRyb2wnICsgbGF5b3V0Tm9kZSgpPy5faWRcIlxyXG4gICAgICAgICAgW2NsYXNzXT1cIm9wdGlvbnM/LmxhYmVsSHRtbENsYXNzIHx8ICcnXCJcclxuICAgICAgICAgIFtzdHlsZS5kaXNwbGF5XT1cIm9wdGlvbnM/Lm5vdGl0bGUgPyAnbm9uZScgOiAnJ1wiXHJcbiAgICAgICAgICBbaW5uZXJIVE1MXT1cImxheW91dE5vZGUoKS5vcHRpb25zPy50aXRsZVwiPjwvbGFiZWw+XHJcbiAgICAgIDwvZGl2PlxyXG4gICAgICA8bWF0LWJ1dHRvbi10b2dnbGUtZ3JvdXBcclxuICAgICAgICBbYXR0ci5hcmlhLWRlc2NyaWJlZGJ5XT1cIidjb250cm9sJyArIGxheW91dE5vZGUoKT8uX2lkICsgJ1N0YXR1cydcIlxyXG4gICAgICAgIFthdHRyLnJlYWRvbmx5XT1cIm9wdGlvbnM/LnJlYWRvbmx5ID8gJ3JlYWRvbmx5JyA6IG51bGxcIlxyXG4gICAgICAgIFthdHRyLnJlcXVpcmVkXT1cIm9wdGlvbnM/LnJlcXVpcmVkXCJcclxuICAgICAgICBbZGlzYWJsZWRdPVwiY29udHJvbERpc2FibGVkIHx8IG9wdGlvbnM/LnJlYWRvbmx5XCJcclxuICAgICAgICBbbmFtZV09XCJjb250cm9sTmFtZVwiXHJcbiAgICAgICAgW3ZhbHVlXT1cImNvbnRyb2xWYWx1ZVwiXHJcbiAgICAgICAgW3ZlcnRpY2FsXT1cIiEhb3B0aW9ucy52ZXJ0aWNhbFwiPlxyXG4gICAgICAgIDxtYXQtYnV0dG9uLXRvZ2dsZSAqbmdGb3I9XCJsZXQgcmFkaW9JdGVtIG9mIHJhZGlvc0xpc3RcIlxyXG4gICAgICAgICAgW2lkXT1cIidjb250cm9sJyArIGxheW91dE5vZGUoKT8uX2lkICsgJy8nICsgcmFkaW9JdGVtPy5uYW1lXCJcclxuICAgICAgICAgIFt2YWx1ZV09XCJyYWRpb0l0ZW0/LnZhbHVlXCJcclxuICAgICAgICAgIChjbGljayk9XCJ1cGRhdGVWYWx1ZShyYWRpb0l0ZW0/LnZhbHVlKVwiPlxyXG4gICAgICAgICAgPHNwYW4gW2lubmVySFRNTF09XCJyYWRpb0l0ZW0/Lm5hbWVcIj48L3NwYW4+XHJcbiAgICAgICAgPC9tYXQtYnV0dG9uLXRvZ2dsZT5cclxuICAgICAgPC9tYXQtYnV0dG9uLXRvZ2dsZS1ncm91cD5cclxuICAgICAgPG1hdC1lcnJvciAqbmdJZj1cIm9wdGlvbnM/LnNob3dFcnJvcnMgJiYgb3B0aW9ucz8uZXJyb3JNZXNzYWdlXCJcclxuICAgICAgICBbaW5uZXJIVE1MXT1cIm9wdGlvbnM/LmVycm9yTWVzc2FnZVwiPjwvbWF0LWVycm9yPlxyXG4gICAgPC9kaXY+YCxcclxuICAgIHN0eWxlczogW2AgbWF0LWVycm9yIHsgZm9udC1zaXplOiA3NSU7IH0gYF0sXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBNYXRlcmlhbEJ1dHRvbkdyb3VwQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0LE9uRGVzdHJveSB7XHJcbiAgcHJpdmF0ZSBqc2YgPSBpbmplY3QoSnNvblNjaGVtYUZvcm1TZXJ2aWNlKTtcclxuXHJcbiAgZm9ybUNvbnRyb2w6IEFic3RyYWN0Q29udHJvbDtcclxuICBjb250cm9sTmFtZTogc3RyaW5nO1xyXG4gIGNvbnRyb2xWYWx1ZTogYW55O1xyXG4gIGNvbnRyb2xEaXNhYmxlZCA9IGZhbHNlO1xyXG4gIGJvdW5kQ29udHJvbCA9IGZhbHNlO1xyXG4gIG9wdGlvbnM6IGFueTtcclxuICByYWRpb3NMaXN0OiBhbnlbXSA9IFtdO1xyXG4gIHZlcnRpY2FsID0gZmFsc2U7XHJcbiAgcmVhZG9ubHkgbGF5b3V0Tm9kZSA9IGlucHV0PGFueT4odW5kZWZpbmVkKTtcclxuICByZWFkb25seSBsYXlvdXRJbmRleCA9IGlucHV0PG51bWJlcltdPih1bmRlZmluZWQpO1xyXG4gIHJlYWRvbmx5IGRhdGFJbmRleCA9IGlucHV0PG51bWJlcltdPih1bmRlZmluZWQpO1xyXG5cclxuICBuZ09uSW5pdCgpIHtcclxuICAgIHRoaXMub3B0aW9ucyA9IHRoaXMubGF5b3V0Tm9kZSgpLm9wdGlvbnMgfHwge307XHJcbiAgICB0aGlzLnJhZGlvc0xpc3QgPSBidWlsZFRpdGxlTWFwKFxyXG4gICAgICB0aGlzLm9wdGlvbnMudGl0bGVNYXAgfHwgdGhpcy5vcHRpb25zLmVudW1OYW1lcyxcclxuICAgICAgdGhpcy5vcHRpb25zLmVudW0sIHRydWVcclxuICAgICk7XHJcbiAgICB0aGlzLmpzZi5pbml0aWFsaXplQ29udHJvbCh0aGlzKTtcclxuICB9XHJcblxyXG4gIHVwZGF0ZVZhbHVlKHZhbHVlKSB7XHJcbiAgICB0aGlzLm9wdGlvbnMuc2hvd0Vycm9ycyA9IHRydWU7XHJcbiAgICB0aGlzLmpzZi51cGRhdGVWYWx1ZSh0aGlzLCB2YWx1ZSk7XHJcbiAgfVxyXG4gIG5nT25EZXN0cm95ICgpIHtcclxuICAgIHRoaXMuanNmLnVwZGF0ZVZhbHVlKHRoaXMsIG51bGwpO1xyXG4gIH1cclxufVxyXG4iXX0=
|