@bizdoc/core 1.15.4 → 1.15.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.
- package/assets/bizdoc-schema.json +6 -8
- package/assets/system/icons.json +1 -0
- package/esm2020/lib/admin/admin-menu.component.mjs +3 -3
- package/esm2020/lib/admin/configuration-designer/designer-element.component.mjs +2 -2
- package/esm2020/lib/admin/configuration-designer/designer.base.mjs +55 -11
- package/esm2020/lib/admin/configuration-designer/designer.component.mjs +90 -44
- package/esm2020/lib/admin/configuration-designer/elements/action.component.mjs +12 -18
- package/esm2020/lib/admin/configuration-designer/elements/analysis-view.component.mjs +5 -6
- package/esm2020/lib/admin/configuration-designer/elements/analysis-widget.component.mjs +7 -6
- package/esm2020/lib/admin/configuration-designer/elements/anomaly-rule.component.mjs +8 -11
- package/esm2020/lib/admin/configuration-designer/elements/box-form.component.mjs +13 -14
- package/esm2020/lib/admin/configuration-designer/elements/configuration-datasource.component.mjs +61 -0
- package/esm2020/lib/admin/configuration-designer/elements/cube.component.mjs +47 -29
- package/esm2020/lib/admin/configuration-designer/elements/documents-report.component.mjs +15 -32
- package/esm2020/lib/admin/configuration-designer/elements/documents-widget.component.mjs +15 -14
- package/esm2020/lib/admin/configuration-designer/elements/folder.component.mjs +16 -17
- package/esm2020/lib/admin/configuration-designer/elements/form.component.mjs +50 -21
- package/esm2020/lib/admin/configuration-designer/elements/guide.component.mjs +34 -19
- package/esm2020/lib/admin/configuration-designer/elements/matrix-view.component.mjs +41 -9
- package/esm2020/lib/admin/configuration-designer/elements/parallel-view.component.mjs +5 -4
- package/esm2020/lib/admin/configuration-designer/elements/performance-widget.component.mjs +14 -26
- package/esm2020/lib/admin/configuration-designer/elements/pivot-view.component.mjs +5 -4
- package/esm2020/lib/admin/configuration-designer/elements/report.component.mjs +12 -18
- package/esm2020/lib/admin/configuration-designer/elements/return-to-role-action.component.mjs +3 -4
- package/esm2020/lib/admin/configuration-designer/elements/role.component.mjs +18 -18
- package/esm2020/lib/admin/configuration-designer/elements/rule.component.mjs +9 -18
- package/esm2020/lib/admin/configuration-designer/elements/state.component.mjs +16 -18
- package/esm2020/lib/admin/configuration-designer/elements/sum-view.component.mjs +6 -4
- package/esm2020/lib/admin/configuration-designer/elements/type.component.mjs +15 -19
- package/esm2020/lib/admin/configuration-designer/elements/usage-report.component.mjs +35 -8
- package/esm2020/lib/admin/configuration-designer/elements/utility.component.mjs +12 -16
- package/esm2020/lib/admin/configuration-designer/elements/view.component.mjs +13 -12
- package/esm2020/lib/admin/configuration-designer/elements/widget.component.mjs +10 -19
- package/esm2020/lib/admin/configuration-designer/icon-picker.component.mjs +162 -0
- package/esm2020/lib/admin/configuration-designer/privileges.component.mjs +25 -17
- package/esm2020/lib/admin/core/ace.input.mjs +14 -16
- package/esm2020/lib/admin/core/color-picker.input.mjs +10 -33
- package/esm2020/lib/admin/form/designer/designer.component.mjs +192 -22
- package/esm2020/lib/admin/form/workflow/workflow.component.mjs +6 -6
- package/esm2020/lib/admin/system.service.mjs +7 -1
- package/esm2020/lib/compose/box/box.component.mjs +44 -0
- package/esm2020/lib/compose/document.component.mjs +2 -2
- package/esm2020/lib/compose/form-ref.mjs +7 -2
- package/esm2020/lib/compose/form-selector/form-selector.sheet.mjs +3 -3
- package/esm2020/lib/compose/form.component.mjs +2 -2
- package/esm2020/lib/compose/new-menu.component.mjs +3 -3
- package/esm2020/lib/compose/version-compare/version-compare.component.mjs +2 -2
- package/esm2020/lib/core/functions.mjs +14 -2
- package/esm2020/lib/core/models.mjs +1 -1
- package/esm2020/lib/core/translations.mjs +4 -1
- package/esm2020/lib/cube/filter/filter.component.mjs +3 -3
- package/esm2020/lib/cube/matrix/table.component.mjs +1 -1
- package/esm2020/lib/dashboard/cube/compare.widget.mjs +1 -1
- package/esm2020/lib/dashboard/cube/cube-analysis.base.mjs +1 -1
- package/esm2020/lib/reports/cube/documents.component.mjs +1 -1
- package/esm2020/lib/reports/cube/grid-documents.component.mjs +1 -1
- package/esm2020/lib/reports/cube/table-documents.component.mjs +1 -1
- package/esm2020/lib/reports/cube/usage-base.mjs +1 -1
- package/esm2020/lib/shared.module.mjs +7 -7
- package/esm2020/lib/system.module.mjs +11 -6
- package/esm2020/lib/views/cube/chart.component.mjs +1 -1
- package/esm2020/public-api.mjs +1 -2
- package/fesm2015/bizdoc-core.mjs +1453 -945
- package/fesm2015/bizdoc-core.mjs.map +1 -1
- package/fesm2020/bizdoc-core.mjs +1436 -946
- package/fesm2020/bizdoc-core.mjs.map +1 -1
- package/lib/admin/configuration-designer/designer.base.d.ts +83 -29
- package/lib/admin/configuration-designer/designer.component.d.ts +14 -3
- package/lib/admin/configuration-designer/elements/action.component.d.ts +2 -13
- package/lib/admin/configuration-designer/elements/anomaly-rule.component.d.ts +0 -5
- package/lib/admin/configuration-designer/elements/box-form.component.d.ts +3 -13
- package/lib/admin/configuration-designer/elements/configuration-datasource.component.d.ts +26 -0
- package/lib/admin/configuration-designer/elements/cube.component.d.ts +12 -13
- package/lib/admin/configuration-designer/elements/documents-report.component.d.ts +3 -27
- package/lib/admin/configuration-designer/elements/documents-widget.component.d.ts +3 -2
- package/lib/admin/configuration-designer/elements/folder.component.d.ts +2 -12
- package/lib/admin/configuration-designer/elements/form.component.d.ts +6 -12
- package/lib/admin/configuration-designer/elements/guide.component.d.ts +7 -12
- package/lib/admin/configuration-designer/elements/matrix-view.component.d.ts +7 -1
- package/lib/admin/configuration-designer/elements/performance-widget.component.d.ts +3 -21
- package/lib/admin/configuration-designer/elements/report.component.d.ts +2 -15
- package/lib/admin/configuration-designer/elements/return-to-role-action.component.d.ts +1 -2
- package/lib/admin/configuration-designer/elements/role.component.d.ts +3 -15
- package/lib/admin/configuration-designer/elements/rule.component.d.ts +2 -13
- package/lib/admin/configuration-designer/elements/state.component.d.ts +2 -14
- package/lib/admin/configuration-designer/elements/sum-view.component.d.ts +1 -0
- package/lib/admin/configuration-designer/elements/type.component.d.ts +2 -15
- package/lib/admin/configuration-designer/elements/usage-report.component.d.ts +7 -1
- package/lib/admin/configuration-designer/elements/utility.component.d.ts +2 -12
- package/lib/admin/configuration-designer/elements/view.component.d.ts +5 -10
- package/lib/admin/configuration-designer/elements/widget.component.d.ts +2 -13
- package/lib/admin/configuration-designer/icon-picker.component.d.ts +67 -0
- package/lib/admin/configuration-designer/privileges.component.d.ts +3 -4
- package/lib/admin/core/ace.input.d.ts +4 -4
- package/lib/admin/core/color-picker.input.d.ts +4 -6
- package/lib/admin/form/designer/designer.component.d.ts +68 -20
- package/lib/admin/form/workflow/workflow.component.d.ts +2 -2
- package/lib/admin/system.service.d.ts +7 -0
- package/lib/compose/box/box.component.d.ts +17 -0
- package/lib/compose/form-ref.d.ts +6 -2
- package/lib/core/models.d.ts +4 -1
- package/lib/core/translations.d.ts +3 -0
- package/lib/cube/matrix/table.component.d.ts +0 -1
- package/lib/dashboard/cube/compare.widget.d.ts +7 -1
- package/lib/dashboard/cube/cube-analysis.base.d.ts +1 -0
- package/lib/reports/cube/documents.component.d.ts +2 -3
- package/lib/reports/cube/grid-documents.component.d.ts +2 -2
- package/lib/reports/cube/table-documents.component.d.ts +2 -2
- package/lib/reports/cube/usage-base.d.ts +2 -1
- package/lib/shared.module.d.ts +33 -33
- package/lib/system.module.d.ts +62 -59
- package/lib/views/cube/chart.component.d.ts +2 -1
- package/package.json +1 -1
- package/public-api.d.ts +0 -1
@@ -4,7 +4,6 @@ import { merge, Subject } from "rxjs";
|
|
4
4
|
import { filter } from "rxjs/operators";
|
5
5
|
import { ESCAPE } from "@angular/cdk/keycodes";
|
6
6
|
import { TemplatePortal } from "@angular/cdk/portal";
|
7
|
-
import { MatButton } from "@angular/material/button";
|
8
7
|
import { MATERIAL_PALETTES } from "../../core/colors";
|
9
8
|
import * as i0 from "@angular/core";
|
10
9
|
import * as i1 from "@angular/forms";
|
@@ -21,6 +20,7 @@ export class ColorPicker {
|
|
21
20
|
this._vc = _vc;
|
22
21
|
this._element = _element;
|
23
22
|
this._dir = _dir;
|
23
|
+
this.controlType = 'bizdoc-color-picker';
|
24
24
|
this._palettes = MATERIAL_PALETTES;
|
25
25
|
this.scales = ["50",
|
26
26
|
"100",
|
@@ -53,7 +53,6 @@ export class ColorPicker {
|
|
53
53
|
this.Object = Object;
|
54
54
|
this._required = false;
|
55
55
|
this._disabled = false;
|
56
|
-
this._opened = false;
|
57
56
|
this.stateChanges = new Subject();
|
58
57
|
this.valueChanges = new Subject();
|
59
58
|
this.id = `color-picker-${ColorPicker.nextId++}`;
|
@@ -99,7 +98,7 @@ export class ColorPicker {
|
|
99
98
|
}
|
100
99
|
get disabled() { return this._disabled; }
|
101
100
|
set disabled(value) {
|
102
|
-
this.
|
101
|
+
this._disabled = value;
|
103
102
|
this.stateChanges.next();
|
104
103
|
}
|
105
104
|
setDescribedByIds(ids) {
|
@@ -107,21 +106,20 @@ export class ColorPicker {
|
|
107
106
|
}
|
108
107
|
onContainerClick(_event) {
|
109
108
|
this._onTouched && this._onTouched();
|
110
|
-
|
109
|
+
this.open();
|
111
110
|
}
|
112
111
|
ngOnDestroy() {
|
113
112
|
this._destroy.next();
|
113
|
+
this._destroy.complete();
|
114
114
|
}
|
115
115
|
open() {
|
116
116
|
if (!this._overlayRef)
|
117
117
|
this._overlayRef = this._createOverlay();
|
118
118
|
const portal = new TemplatePortal(this._colorPalette, this._vc);
|
119
119
|
this._overlayRef.attach(portal);
|
120
|
-
this._opened = true;
|
121
120
|
}
|
122
121
|
close() {
|
123
122
|
this._overlayRef.detach();
|
124
|
-
this._opened = false;
|
125
123
|
}
|
126
124
|
_pick(color) {
|
127
125
|
this.value = color;
|
@@ -150,40 +148,22 @@ export class ColorPicker {
|
|
150
148
|
}
|
151
149
|
ColorPicker.nextId = 0;
|
152
150
|
ColorPicker.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.3", ngImport: i0, type: ColorPicker, deps: [{ token: i1.NgControl, optional: true, self: true }, { token: i2.Overlay }, { token: i0.ViewContainerRef }, { token: i0.ElementRef }, { token: i3.Directionality }], target: i0.ɵɵFactoryTarget.Component });
|
153
|
-
ColorPicker.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.3", type: ColorPicker, selector: "bizdoc-color-picker", inputs: { label: "label", required: "required", disabled: "disabled" }, outputs: { valueChanges: "valueChanges" }, host: { properties: { "class.floating": "this.shouldLabelFloat", "id": "this.id", "attr.aria-describedby": "this.describedBy" } }, providers: [{ provide: MatFormFieldControl, useExisting: ColorPicker }], viewQueries: [{ propertyName: "
|
154
|
-
<span>{{label}}</span>
|
155
|
-
<mat-icon>arrow_drop_down</mat-icon>
|
156
|
-
</button>
|
157
|
-
<ng-template>
|
158
|
-
<div class="color-palette">
|
159
|
-
<div *ngFor='let p of Object.keys(_palettes)' class="color-container">
|
160
|
-
<span *ngFor='let c of Object.keys(_palettes[p])' (click)='_pick(_palettes[p][c])' [style.background-color]='_palettes[p][c]' class="color-item"></span>
|
161
|
-
</div>
|
162
|
-
</div>
|
163
|
-
</ng-template>`, isInline: true, styles: [".color-palette{display:flex;flex-direction:column}.color-palette .color-container{display:flex}button{width:100%}.color-item{width:20px;height:20px}\n"], dependencies: [{ kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: i5.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i6.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }] });
|
151
|
+
ColorPicker.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.3", type: ColorPicker, selector: "bizdoc-color-picker", inputs: { label: "label", value: "value", required: "required", disabled: "disabled" }, outputs: { valueChanges: "valueChanges" }, host: { properties: { "class.floating": "this.shouldLabelFloat", "id": "this.id", "attr.aria-describedby": "this.describedBy" } }, providers: [{ provide: MatFormFieldControl, useExisting: ColorPicker }], viewQueries: [{ propertyName: "_colorPalette", first: true, predicate: TemplateRef, descendants: true, static: true }], ngImport: i0, template: "<button mat-button (click)='open()' [disabled]=\"disabled\">\r\n <span>{{label}}</span>\r\n <mat-icon>arrow_drop_down</mat-icon>\r\n</button>\r\n<ng-template>\r\n <div class=\"color-palette\">\r\n <div *ngFor='let p of Object.keys(_palettes)' class=\"color-container\">\r\n <span *ngFor='let c of Object.keys(_palettes[p])' (click)='_pick(_palettes[p][c])' [style.background-color]='_palettes[p][c]' class=\"color-item\"></span>\r\n </div>\r\n </div>\r\n</ng-template>\r\n", styles: [".color-palette{display:flex;flex-direction:column}.color-palette .color-container{display:flex}button{width:100%}.color-item{width:20px;height:20px}\n"], dependencies: [{ kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: i5.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i6.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }] });
|
164
152
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.3", ngImport: i0, type: ColorPicker, decorators: [{
|
165
153
|
type: Component,
|
166
|
-
args: [{ selector: 'bizdoc-color-picker', providers: [{ provide: MatFormFieldControl, useExisting: ColorPicker }],
|
167
|
-
<span>{{label}}</span>
|
168
|
-
<mat-icon>arrow_drop_down</mat-icon>
|
169
|
-
</button>
|
170
|
-
<ng-template>
|
171
|
-
<div class="color-palette">
|
172
|
-
<div *ngFor='let p of Object.keys(_palettes)' class="color-container">
|
173
|
-
<span *ngFor='let c of Object.keys(_palettes[p])' (click)='_pick(_palettes[p][c])' [style.background-color]='_palettes[p][c]' class="color-item"></span>
|
174
|
-
</div>
|
175
|
-
</div>
|
176
|
-
</ng-template>`, host: {
|
154
|
+
args: [{ selector: 'bizdoc-color-picker', providers: [{ provide: MatFormFieldControl, useExisting: ColorPicker }], host: {
|
177
155
|
'[class.floating]': 'shouldLabelFloat',
|
178
156
|
'[id]': 'id',
|
179
157
|
'[attr.aria-describedby]': 'describedBy'
|
180
|
-
}, styles: [".color-palette{display:flex;flex-direction:column}.color-palette .color-container{display:flex}button{width:100%}.color-item{width:20px;height:20px}\n"] }]
|
158
|
+
}, template: "<button mat-button (click)='open()' [disabled]=\"disabled\">\r\n <span>{{label}}</span>\r\n <mat-icon>arrow_drop_down</mat-icon>\r\n</button>\r\n<ng-template>\r\n <div class=\"color-palette\">\r\n <div *ngFor='let p of Object.keys(_palettes)' class=\"color-container\">\r\n <span *ngFor='let c of Object.keys(_palettes[p])' (click)='_pick(_palettes[p][c])' [style.background-color]='_palettes[p][c]' class=\"color-item\"></span>\r\n </div>\r\n </div>\r\n</ng-template>\r\n", styles: [".color-palette{display:flex;flex-direction:column}.color-palette .color-container{display:flex}button{width:100%}.color-item{width:20px;height:20px}\n"] }]
|
181
159
|
}], ctorParameters: function () { return [{ type: i1.NgControl, decorators: [{
|
182
160
|
type: Optional
|
183
161
|
}, {
|
184
162
|
type: Self
|
185
163
|
}] }, { type: i2.Overlay }, { type: i0.ViewContainerRef }, { type: i0.ElementRef }, { type: i3.Directionality }]; }, propDecorators: { label: [{
|
186
164
|
type: Input
|
165
|
+
}], value: [{
|
166
|
+
type: Input
|
187
167
|
}], valueChanges: [{
|
188
168
|
type: Output
|
189
169
|
}], id: [{
|
@@ -198,11 +178,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.3", ngImpor
|
|
198
178
|
}], describedBy: [{
|
199
179
|
type: HostBinding,
|
200
180
|
args: ['attr.aria-describedby']
|
201
|
-
}], _trigger: [{
|
202
|
-
type: ViewChild,
|
203
|
-
args: [MatButton, { static: true }]
|
204
181
|
}], _colorPalette: [{
|
205
182
|
type: ViewChild,
|
206
183
|
args: [TemplateRef, { static: true }]
|
207
184
|
}] } });
|
208
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"color-picker.input.js","sourceRoot":"","sources":["../../../../../../libraries/core/src/lib/admin/core/color-picker.input.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAA+B,WAAW,EAAE,SAAS,EAAE,IAAI,EAAE,QAAQ,EAAc,WAAW,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACvJ,OAAO,EAAE,mBAAmB,EAAE,MAAM,8BAA8B,CAAC;AAGnE,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AACtC,OAAO,EAAE,MAAM,EAAE,MAAM,gBAAgB,CAAC;AACxC,OAAO,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAC/C,OAAO,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;AACrD,OAAO,EAAE,SAAS,EAAE,MAAM,0BAA0B,CAAC;AACrD,OAAO,EAAE,iBAAiB,EAAE,MAAM,mBAAmB,CAAC;;;;;;;;AAEtD,kCAAkC;AAsBlC,MAAM,OAAO,WAAW;IAsGtB,YAAuC,SAAoB,EAAU,QAAiB,EAAU,GAAqB,EAAU,QAAoB,EAAU,IAAoB;QAA1I,cAAS,GAAT,SAAS,CAAW;QAAU,aAAQ,GAAR,QAAQ,CAAS;QAAU,QAAG,GAAH,GAAG,CAAkB;QAAU,aAAQ,GAAR,QAAQ,CAAY;QAAU,SAAI,GAAJ,IAAI,CAAgB;QApGxK,cAAS,GAAG,iBAAiB,CAAC;QAEvC,WAAM,GAAG,CAAC,IAAI;YACZ,KAAK;YACL,KAAK;YACL,KAAK;YACL,KAAK;YACL,KAAK;YACL,KAAK;YACL,KAAK;YACL,KAAK;YACL,KAAK,CAAC,CAAC;QACT,WAAM,GAAG,CAAC,KAAK;YACb,MAAM;YACN,QAAQ;YACR,YAAY;YACZ,QAAQ;YACR,MAAM;YACN,WAAW;YACX,MAAM;YACN,MAAM;YACN,OAAO;YACP,YAAY;YACZ,MAAM;YACN,QAAQ;YACR,OAAO;YACP,QAAQ;YACR,OAAO;YACP,MAAM;YACN,UAAU,CAAC,CAAC;QAEL,WAAM,GAAG,MAAM,CAAC;QAGjB,cAAS,GAAG,KAAK,CAAC;QAClB,cAAS,GAAG,KAAK,CAAC;QAClB,YAAO,GAAG,KAAK,CAAC;QAqBf,iBAAY,GAAG,IAAI,OAAO,EAAQ,CAAC;QAEnC,iBAAY,GAAG,IAAI,OAAO,EAAU,CAAC;QAC/B,OAAE,GAAG,gBAAgB,WAAW,CAAC,MAAM,EAAE,EAAE,CAAC;QAE3D,YAAO,GAAG,KAAK,CAAC;QAsBhB,eAAU,GAAG,KAAK,CAAC;QACmB,gBAAW,GAAG,EAAE,CAAC;QActC,aAAQ,GAAG,IAAI,OAAO,EAAQ,CAAC;QAE9C,IAAI,IAAI,CAAC,SAAS,IAAI,IAAI,EAAE;YAC1B,IAAI,CAAC,SAAS,CAAC,aAAa,GAAG,IAAI,CAAC;SACrC;IACH,CAAC;IAlED,UAAU,CAAC,GAAQ;QACjB,IAAI,CAAC,MAAM,GAAG,GAAG,CAAC;IACpB,CAAC;IACD,gBAAgB,CAAC,EAAO;QACtB,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACtB,CAAC;IACD,iBAAiB,CAAC,EAAO;QACvB,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;IACvB,CAAC;IACD,gBAAgB,CAAE,UAAmB;QACnC,IAAI,CAAC,QAAQ,GAAG,UAAU,CAAC;IAC7B,CAAC;IACD,IAAI,KAAK,KAAa,OAAO,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC;IAC3C,IAAI,KAAK,CAAC,GAAW;QACnB,IAAI,CAAC,MAAM,GAAG,GAAG,CAAC;QAClB,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;QACtC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAC5B,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;IAC3B,CAAC;IAOD,IAAI,KAAK;QACP,OAAO,IAAI,CAAC,MAAM,KAAK,IAAI,CAAC;IAC9B,CAAC;IACD,IACI,gBAAgB;QAClB,OAAO,IAAI,CAAC,OAAO,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC;IACrC,CAAC;IACD,IACI,QAAQ;QACV,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;IACD,IAAI,QAAQ,CAAC,GAAG;QACd,IAAI,CAAC,SAAS,GAAG,GAAG,CAAC;QACrB,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;IAC3B,CAAC;IACD,IACI,QAAQ,KAAc,OAAO,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC;IAClD,IAAI,QAAQ,CAAC,KAAc;QACzB,IAAI,CAAC,QAAQ,CAAC,QAAQ,GAAG,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QAChD,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;IAC3B,CAAC;IAGD,iBAAiB,CAAC,GAAa;QAC7B,IAAI,CAAC,WAAW,GAAG,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IACnC,CAAC;IACD,gBAAgB,CAAC,MAAkB;QACjC,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;QACrC,CAAC,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,IAAI,EAAE,CAAC;IAC/B,CAAC;IAGD,WAAW;QACT,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;IACvB,CAAC;IAQD,IAAI;QACF,IAAI,CAAC,IAAI,CAAC,WAAW;YAAE,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,cAAc,EAAE,CAAC;QAChE,MAAM,MAAM,GAAG,IAAI,cAAc,CAAC,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC;QAChE,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;QAChC,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;IACtB,CAAC;IACD,KAAK;QACH,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,CAAC;QAC1B,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;IACvB,CAAC;IACD,KAAK,CAAC,KAAa;QACjB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,EAAE,CAAC;IACf,CAAC;IACO,cAAc;QACpB,MAAM,GAAG,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC;YAC/B,gBAAgB,EAAE,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC,mBAAmB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,aAAa,CAAC,CAAC;oBAC3F,OAAO,EAAE,OAAO;oBAChB,OAAO,EAAE,QAAQ;oBACjB,QAAQ,EAAE,OAAO;oBACjB,QAAQ,EAAE,KAAK;iBAChB,EAAE;oBACD,OAAO,EAAE,OAAO;oBAChB,OAAO,EAAE,KAAK;oBACd,QAAQ,EAAE,OAAO;oBACjB,QAAQ,EAAE,QAAQ;iBACnB,CAAC,CAAC;YACH,SAAS,EAAE,IAAI,CAAC,IAAI,CAAC,KAAK;YAC1B,WAAW,EAAE,IAAI;YACjB,aAAa,EAAE,kCAAkC;SAClD,CAAC,CAAC;QACH,KAAK,CAAC,GAAG,CAAC,aAAa,EAAE,EAAE,GAAG,CAAC,aAAa,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,KAAK,MAAM,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC;QACtH,OAAO,GAAG,CAAC;IACb,CAAC;;AA3Ic,kBAAM,GAAG,CAAE,CAAA;wGADf,WAAW;4FAAX,WAAW,oSAnBX,CAAC,EAAE,OAAO,EAAE,mBAAmB,EAAE,WAAW,EAAE,WAAW,EAAE,CAAC,oEAkH5D,SAAS,8FACT,WAAW,8DAlHZ;;;;;;;;;;eAUG;2FAQF,WAAW;kBArBvB,SAAS;+BACE,qBAAqB,aACpB,CAAC,EAAE,OAAO,EAAE,mBAAmB,EAAE,WAAW,aAAa,EAAE,CAAC,YAC7D;;;;;;;;;;eAUG,QAEP;wBACJ,kBAAkB,EAAE,kBAAkB;wBACtC,MAAM,EAAE,IAAI;wBACZ,yBAAyB,EAAE,aAAa;qBACzC;;0BAwGY,QAAQ;;0BAAI,IAAI;uJAnGpB,KAAK;sBAAb,KAAK;gBA0DG,YAAY;sBADpB,MAAM;gBAEQ,EAAE;sBAAhB,WAAW;gBAOR,gBAAgB;sBADnB,WAAW;uBAAC,gBAAgB;gBAKzB,QAAQ;sBADX,KAAK;gBASF,QAAQ;sBADX,KAAK;gBAOgC,WAAW;sBAAhD,WAAW;uBAAC,uBAAuB;gBAQI,QAAQ;sBAA/C,SAAS;uBAAC,SAAS,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBACI,aAAa;sBAAtD,SAAS;uBAAC,WAAW,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE","sourcesContent":["import { Component, OnDestroy, ViewContainerRef, TemplateRef, ViewChild, Self, Optional, ElementRef, HostBinding, Input, Output } from \"@angular/core\";\r\nimport { MatFormFieldControl } from \"@angular/material/form-field\";\r\nimport { ControlValueAccessor, NgControl } from \"@angular/forms\";\r\nimport { OverlayRef, Overlay } from \"@angular/cdk/overlay\";\r\nimport { merge, Subject } from \"rxjs\";\r\nimport { filter } from \"rxjs/operators\";\r\nimport { ESCAPE } from \"@angular/cdk/keycodes\";\r\nimport { TemplatePortal } from \"@angular/cdk/portal\";\r\nimport { MatButton } from \"@angular/material/button\";\r\nimport { MATERIAL_PALETTES } from \"../../core/colors\";\r\nimport { Directionality } from \"@angular/cdk/bidi\";\r\n//[style.background-color]='value'\r\n@Component({\r\n  selector: 'bizdoc-color-picker',\r\n  providers: [{ provide: MatFormFieldControl, useExisting: ColorPicker }],\r\n  template: `<button mat-button (click)='open()'>\r\n<span>{{label}}</span>\r\n      <mat-icon>arrow_drop_down</mat-icon>\r\n    </button>\r\n<ng-template>\r\n  <div class=\"color-palette\">\r\n    <div *ngFor='let p of Object.keys(_palettes)' class=\"color-container\">\r\n      <span *ngFor='let c of Object.keys(_palettes[p])' (click)='_pick(_palettes[p][c])' [style.background-color]='_palettes[p][c]' class=\"color-item\"></span>\r\n    </div>\r\n  </div>\r\n</ng-template>`,\r\n  styleUrls: ['./color-picker.input.scss'],\r\n  host: {\r\n    '[class.floating]': 'shouldLabelFloat',\r\n    '[id]': 'id',\r\n    '[attr.aria-describedby]': 'describedBy'\r\n  }\r\n})\r\nexport class ColorPicker implements MatFormFieldControl<string>, ControlValueAccessor, OnDestroy {\r\n  private static nextId = 0;\r\n  readonly _palettes = MATERIAL_PALETTES;\r\n  @Input() label: string;\r\n  scales = [\"50\",\r\n    \"100\",\r\n    \"200\",\r\n    \"300\",\r\n    \"400\",\r\n    \"500\",\r\n    \"600\",\r\n    \"700\",\r\n    \"800\",\r\n    \"900\"];\r\n  colors = [\"red\",\r\n    \"pink\",\r\n    \"purple\",\r\n    \"deepPurple\",\r\n    \"indigo\",\r\n    \"blue\",\r\n    \"lightBlue\",\r\n    \"cyan\",\r\n    \"teal\",\r\n    \"green\",\r\n    \"lightGreen\",\r\n    \"lime\",\r\n    \"yellow\",\r\n    \"amber\",\r\n    \"orange\",\r\n    \"brown\",\r\n    \"grey\",\r\n    \"blueGrey\"];\r\n\r\n  readonly Object = Object;\r\n  private _onChange: any;\r\n  private _onTouched: any;\r\n  private _required = false;\r\n  private _disabled = false;\r\n  private _opened = false;\r\n  private _value: string;\r\n  writeValue(obj: any): void {\r\n    this._value = obj;\r\n  }\r\n  registerOnChange(fn: any): void {\r\n    this._onChange = fn;\r\n  }\r\n  registerOnTouched(fn: any): void {\r\n    this._onTouched = fn;\r\n  }\r\n  setDisabledState?(isDisabled: boolean): void {\r\n    this.disabled = isDisabled;\r\n  }\r\n  get value(): string { return this._value; }\r\n  set value(val: string) {\r\n    this._value = val;\r\n    this._onChange && this._onChange(val);\r\n    this.valueChanges.next(val);\r\n    this.stateChanges.next();\r\n  }\r\n  readonly stateChanges = new Subject<void>();\r\n  @Output()\r\n  readonly valueChanges = new Subject<string>();\r\n  @HostBinding() id = `color-picker-${ColorPicker.nextId++}`;\r\n  placeholder: string;\r\n  focused = false;\r\n  get empty(): boolean {\r\n    return this._value === null;\r\n  }\r\n  @HostBinding('class.floating')\r\n  get shouldLabelFloat() {\r\n    return this.focused || !this.empty;\r\n  }\r\n  @Input()\r\n  get required() {\r\n    return this._required;\r\n  }\r\n  set required(req) {\r\n    this._required = req;\r\n    this.stateChanges.next();\r\n  }\r\n  @Input()\r\n  get disabled(): boolean { return this._disabled; }\r\n  set disabled(value: boolean) {\r\n    this._trigger.disabled = this._disabled = value;\r\n    this.stateChanges.next();\r\n  }\r\n  errorState = false;\r\n  @HostBinding('attr.aria-describedby') describedBy = '';\r\n  setDescribedByIds(ids: string[]): void {\r\n    this.describedBy = ids.join(' ');\r\n  }\r\n  onContainerClick(_event: MouseEvent): void {\r\n    this._onTouched && this._onTouched();\r\n    !this._opened && this.open();\r\n  }\r\n  @ViewChild(MatButton, { static: true }) _trigger: MatButton;\r\n  @ViewChild(TemplateRef, { static: true }) _colorPalette: TemplateRef<any>;\r\n  ngOnDestroy(): void {\r\n    this._destroy.next();\r\n  }\r\n  private _overlayRef: OverlayRef;\r\n  private readonly _destroy = new Subject<void>();\r\n  constructor(@Optional() @Self() public ngControl: NgControl, private _overlay: Overlay, private _vc: ViewContainerRef, private _element: ElementRef, private _dir: Directionality) {\r\n    if (this.ngControl != null) {\r\n      this.ngControl.valueAccessor = this;\r\n    }\r\n  }\r\n  open() {\r\n    if (!this._overlayRef) this._overlayRef = this._createOverlay();\r\n    const portal = new TemplatePortal(this._colorPalette, this._vc);\r\n    this._overlayRef.attach(portal);\r\n    this._opened = true;\r\n  }\r\n  close() {\r\n    this._overlayRef.detach();\r\n    this._opened = false;\r\n  }\r\n  _pick(color: string) {\r\n    this.value = color;\r\n    this.close();\r\n  }\r\n  private _createOverlay(): OverlayRef {\r\n    const ref = this._overlay.create({\r\n      positionStrategy: this._overlay.position().flexibleConnectedTo(this._element).withPositions([{\r\n        originX: 'start',\r\n        originY: 'bottom',\r\n        overlayX: 'start',\r\n        overlayY: 'top'\r\n      }, {\r\n        originX: 'start',\r\n        originY: 'top',\r\n        overlayX: 'start',\r\n        overlayY: 'bottom'\r\n      }]),\r\n      direction: this._dir.value,\r\n      hasBackdrop: true,\r\n      backdropClass: 'cdk-overlay-transparent-backdrop'\r\n    });\r\n    merge(ref.backdropClick(), ref.keydownEvents().pipe(filter(k => k.keyCode === ESCAPE))).subscribe(() => this.close());\r\n    return ref;\r\n  }\r\n}\r\n"]}
|
185
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"color-picker.input.js","sourceRoot":"","sources":["../../../../../../libraries/core/src/lib/admin/core/color-picker.input.ts","../../../../../../libraries/core/src/lib/admin/core/color-picker.input.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnDestroy, ViewContainerRef, TemplateRef, ViewChild, Self, Optional, ElementRef, HostBinding, Input, Output } from \"@angular/core\";\r\nimport { MatFormFieldControl } from \"@angular/material/form-field\";\r\nimport { ControlValueAccessor, NgControl } from \"@angular/forms\";\r\nimport { OverlayRef, Overlay } from \"@angular/cdk/overlay\";\r\nimport { merge, Subject } from \"rxjs\";\r\nimport { filter } from \"rxjs/operators\";\r\nimport { ESCAPE } from \"@angular/cdk/keycodes\";\r\nimport { TemplatePortal } from \"@angular/cdk/portal\";\r\nimport { MATERIAL_PALETTES } from \"../../core/colors\";\r\nimport { Directionality } from \"@angular/cdk/bidi\";\r\n//[style.background-color]='value'\r\n@Component({\r\n  selector: 'bizdoc-color-picker',\r\n  providers: [{ provide: MatFormFieldControl, useExisting: ColorPicker }],\r\n  templateUrl: `./color-picker.input.html`,\r\n  styleUrls: ['./color-picker.input.scss'],\r\n  host: {\r\n    '[class.floating]': 'shouldLabelFloat',\r\n    '[id]': 'id',\r\n    '[attr.aria-describedby]': 'describedBy'\r\n  }\r\n})\r\nexport class ColorPicker implements MatFormFieldControl<string>, ControlValueAccessor, OnDestroy {\r\n  controlType?: string = 'bizdoc-color-picker';\r\n  private static nextId = 0;\r\n  readonly _palettes = MATERIAL_PALETTES;\r\n  @Input() label: string;\r\n  readonly scales = [\"50\",\r\n    \"100\",\r\n    \"200\",\r\n    \"300\",\r\n    \"400\",\r\n    \"500\",\r\n    \"600\",\r\n    \"700\",\r\n    \"800\",\r\n    \"900\"];\r\n  readonly colors = [\"red\",\r\n    \"pink\",\r\n    \"purple\",\r\n    \"deepPurple\",\r\n    \"indigo\",\r\n    \"blue\",\r\n    \"lightBlue\",\r\n    \"cyan\",\r\n    \"teal\",\r\n    \"green\",\r\n    \"lightGreen\",\r\n    \"lime\",\r\n    \"yellow\",\r\n    \"amber\",\r\n    \"orange\",\r\n    \"brown\",\r\n    \"grey\",\r\n    \"blueGrey\"];\r\n\r\n  readonly Object = Object;\r\n  private _onChange: any;\r\n  private _onTouched: any;\r\n  private _required = false;\r\n  private _disabled = false;\r\n  private _value: string;\r\n  writeValue(obj: any): void {\r\n    this._value = obj;\r\n  }\r\n  registerOnChange(fn: any): void {\r\n    this._onChange = fn;\r\n  }\r\n  registerOnTouched(fn: any): void {\r\n    this._onTouched = fn;\r\n  }\r\n  setDisabledState?(isDisabled: boolean): void {\r\n    this.disabled = isDisabled;\r\n  }\r\n  get value(): string { return this._value; }\r\n  @Input()\r\n  set value(val: string) {\r\n    this._value = val;\r\n    this._onChange && this._onChange(val);\r\n    this.valueChanges.next(val);\r\n    this.stateChanges.next();\r\n  }\r\n  readonly stateChanges = new Subject<void>();\r\n  @Output()\r\n  readonly valueChanges = new Subject<string>();\r\n  @HostBinding() id = `color-picker-${ColorPicker.nextId++}`;\r\n  placeholder: string;\r\n  focused = false;\r\n  get empty(): boolean {\r\n    return this._value === null;\r\n  }\r\n  @HostBinding('class.floating')\r\n  get shouldLabelFloat() {\r\n    return this.focused || !this.empty;\r\n  }\r\n  @Input()\r\n  get required() {\r\n    return this._required;\r\n  }\r\n  set required(req) {\r\n    this._required = req;\r\n    this.stateChanges.next();\r\n  }\r\n  @Input()\r\n  get disabled(): boolean { return this._disabled; }\r\n  set disabled(value: boolean) {\r\n    this._disabled = value;\r\n    this.stateChanges.next();\r\n  }\r\n  errorState = false;\r\n  @HostBinding('attr.aria-describedby') describedBy = '';\r\n  setDescribedByIds(ids: string[]): void {\r\n    this.describedBy = ids.join(' ');\r\n  }\r\n  onContainerClick(_event: MouseEvent): void {\r\n    this._onTouched && this._onTouched();\r\n    this.open();\r\n  }\r\n  @ViewChild(TemplateRef, { static: true }) _colorPalette: TemplateRef<any>;\r\n  ngOnDestroy(): void {\r\n    this._destroy.next();\r\n    this._destroy.complete();\r\n  }\r\n  private _overlayRef: OverlayRef;\r\n  private readonly _destroy = new Subject<void>();\r\n  constructor(\r\n    @Optional() @Self() public ngControl: NgControl,\r\n    private _overlay: Overlay,\r\n    private _vc: ViewContainerRef,\r\n    private _element: ElementRef,\r\n    private _dir: Directionality) {\r\n    if (this.ngControl != null) {\r\n      this.ngControl.valueAccessor = this;\r\n    }\r\n  }\r\n  open() {\r\n    if (!this._overlayRef) this._overlayRef = this._createOverlay();\r\n    const portal = new TemplatePortal(this._colorPalette, this._vc);\r\n    this._overlayRef.attach(portal);\r\n  }\r\n  close() {\r\n    this._overlayRef.detach();\r\n  }\r\n  _pick(color: string) {\r\n    this.value = color;\r\n    this.close();\r\n  }\r\n  private _createOverlay(): OverlayRef {\r\n    const ref = this._overlay.create({\r\n      positionStrategy: this._overlay.position().flexibleConnectedTo(this._element).withPositions([{\r\n        originX: 'start',\r\n        originY: 'bottom',\r\n        overlayX: 'start',\r\n        overlayY: 'top'\r\n      }, {\r\n        originX: 'start',\r\n        originY: 'top',\r\n        overlayX: 'start',\r\n        overlayY: 'bottom'\r\n      }]),\r\n      direction: this._dir.value,\r\n      hasBackdrop: true,\r\n      backdropClass: 'cdk-overlay-transparent-backdrop'\r\n    });\r\n    merge(ref.backdropClick(), ref.keydownEvents().pipe(filter(k => k.keyCode === ESCAPE))).subscribe(() => this.close());\r\n    return ref;\r\n  }\r\n}\r\n","<button mat-button (click)='open()' [disabled]=\"disabled\">\r\n  <span>{{label}}</span>\r\n  <mat-icon>arrow_drop_down</mat-icon>\r\n</button>\r\n<ng-template>\r\n  <div class=\"color-palette\">\r\n    <div *ngFor='let p of Object.keys(_palettes)' class=\"color-container\">\r\n      <span *ngFor='let c of Object.keys(_palettes[p])' (click)='_pick(_palettes[p][c])' [style.background-color]='_palettes[p][c]' class=\"color-item\"></span>\r\n    </div>\r\n  </div>\r\n</ng-template>\r\n"]}
|
@@ -1,56 +1,226 @@
|
|
1
1
|
import { __decorate } from "tslib";
|
2
|
-
import {
|
3
|
-
import {
|
2
|
+
import { Component, HostListener } from "@angular/core";
|
3
|
+
import { Validators } from "@angular/forms";
|
4
4
|
import { BizDoc } from "../../../core/decorators";
|
5
|
+
import { cleanup } from "../../../core/functions";
|
5
6
|
import * as i0 from "@angular/core";
|
6
7
|
import * as i1 from "@angular/forms";
|
7
|
-
import * as i2 from "../../../core/
|
8
|
-
import * as i3 from "
|
9
|
-
import * as i4 from "
|
10
|
-
import * as i5 from "
|
8
|
+
import * as i2 from "../../../core/slots/pane-ref";
|
9
|
+
import * as i3 from "../../../core/prompt.service";
|
10
|
+
import * as i4 from "../../../core/session.service";
|
11
|
+
import * as i5 from "../../utility-ref";
|
12
|
+
import * as i6 from "@angular/common";
|
13
|
+
import * as i7 from "@angular/cdk/drag-drop";
|
14
|
+
import * as i8 from "@angular/material/toolbar";
|
15
|
+
import * as i9 from "@angular/material/core";
|
16
|
+
import * as i10 from "@angular/material/form-field";
|
17
|
+
import * as i11 from "@angular/material/select";
|
18
|
+
import * as i12 from "@angular/material/button";
|
19
|
+
import * as i13 from "@angular/material/checkbox";
|
20
|
+
import * as i14 from "@angular/material/input";
|
21
|
+
import * as i15 from "@angular/material/icon";
|
22
|
+
import * as i16 from "@angular/material/menu";
|
23
|
+
import * as i17 from "../../../core/popup/tooltip.directive";
|
24
|
+
import * as i18 from "../../core/ace.input";
|
25
|
+
import * as i19 from "../../../core/pipes/translate.pipe";
|
11
26
|
/** */
|
12
27
|
let FormDesignerComponent = class FormDesignerComponent {
|
13
|
-
constructor(_fb, _session, _ref) {
|
28
|
+
constructor(_fb, _pane, _cd, _ps, _session, _el, _ref) {
|
14
29
|
this._fb = _fb;
|
30
|
+
this._pane = _pane;
|
31
|
+
this._cd = _cd;
|
32
|
+
this._ps = _ps;
|
15
33
|
this._session = _session;
|
34
|
+
this._el = _el;
|
16
35
|
this._ref = _ref;
|
17
36
|
this.loading = true;
|
18
37
|
this.tools = true;
|
19
38
|
this.saving = false;
|
39
|
+
this.history = [];
|
40
|
+
this.historyIndex = -1;
|
20
41
|
this.form = this._fb.group({
|
21
|
-
|
22
|
-
|
23
|
-
|
42
|
+
subject: null,
|
43
|
+
value: null,
|
44
|
+
cube: null,
|
45
|
+
summary: null,
|
46
|
+
sections: this._fb.array([])
|
24
47
|
});
|
48
|
+
this.dirty = false;
|
49
|
+
this.settings = false;
|
50
|
+
this.datatypes = this._session.profile.types;
|
51
|
+
this.cubes = this._session.profile.cubes;
|
25
52
|
}
|
26
53
|
ngOnInit() {
|
27
|
-
this.
|
28
|
-
|
29
|
-
this.
|
54
|
+
this._pane.queryParamsChange.subscribe(p => {
|
55
|
+
const { formId } = p;
|
56
|
+
formId && this._open(formId);
|
57
|
+
});
|
58
|
+
this.form.valueChanges.pipe().
|
59
|
+
subscribe(v => {
|
60
|
+
//this._notifyChange();
|
61
|
+
Object.assign(this.model, v);
|
62
|
+
});
|
63
|
+
}
|
64
|
+
_open(formId) {
|
65
|
+
this._ref.populate(formId).subscribe(r => {
|
66
|
+
this._formId = formId;
|
67
|
+
this._assign(r);
|
30
68
|
this.loading = false;
|
31
69
|
});
|
32
70
|
}
|
33
|
-
|
71
|
+
_assign(model) {
|
72
|
+
this.model = model || { sections: [] };
|
73
|
+
const sections = this.form.get('sections');
|
74
|
+
sections.clear({ emitEvent: false });
|
75
|
+
this.form.patchValue(this.model, { emitEvent: false });
|
76
|
+
model.sections?.forEach(s => sections.push(this._sectionform(s), { emitEvent: false }));
|
77
|
+
}
|
78
|
+
_sectionform(section) {
|
79
|
+
const name = this._fb.control(section.name, Validators.required);
|
80
|
+
return this._fb.group({
|
81
|
+
name,
|
82
|
+
title: section.title,
|
83
|
+
multiLine: section.multiLine || false,
|
84
|
+
value: section.value || null,
|
85
|
+
rows: this._fb.array(section.rows?.map(r => this._rowform(r)) || [])
|
86
|
+
});
|
87
|
+
}
|
88
|
+
_rowform(row) {
|
89
|
+
return this._fb.group({
|
90
|
+
fields: this._fb.array(row.fields.map(f => this._fieldform(f)))
|
91
|
+
});
|
92
|
+
}
|
93
|
+
_fieldform(field) {
|
94
|
+
const name = this._fb.control(field.name, Validators.required), label = this._fb.control(field.label, Validators.required);
|
95
|
+
return this._fb.group({
|
96
|
+
name,
|
97
|
+
label,
|
98
|
+
kind: field.kind,
|
99
|
+
dataType: field.dataType,
|
100
|
+
required: field.required
|
101
|
+
});
|
102
|
+
}
|
103
|
+
addSection(evt) {
|
104
|
+
this._notifyChange();
|
105
|
+
let n = 0, name, title;
|
106
|
+
do {
|
107
|
+
n++;
|
108
|
+
name = 'section' + '_' + n;
|
109
|
+
title = 'Section' + ' ' + n;
|
110
|
+
} while (this.model.sections.find(s => s.name === name || s.title === title));
|
111
|
+
this.form.get('sections').push(this._sectionform({
|
112
|
+
name,
|
113
|
+
title,
|
114
|
+
rows: [{ fields: [] }]
|
115
|
+
}));
|
116
|
+
this._cd.detectChanges();
|
117
|
+
this._el.nativeElement.querySelector('section:last-child button')?.focus();
|
118
|
+
}
|
119
|
+
addRow(section, evt) {
|
120
|
+
this._notifyChange();
|
121
|
+
section.get('rows').push(this._rowform({
|
122
|
+
fields: []
|
123
|
+
}));
|
124
|
+
this._cd.detectChanges();
|
125
|
+
this._el.nativeElement.querySelector(`section[data-index='${this.form.get('sections').controls.indexOf(section)}'] .designer-row:last-child button`)?.focus();
|
126
|
+
}
|
127
|
+
addField(section, row, kind, evt) {
|
128
|
+
let n = 0, name, label;
|
129
|
+
do {
|
130
|
+
n++;
|
131
|
+
name = 'field' + '_' + n;
|
132
|
+
label = 'Field' + ' ' + n;
|
133
|
+
} while (section.get('rows').controls.
|
134
|
+
find(r => r.get('fields').controls.find(f => f.value.name === name || f.value.label === label) != null));
|
135
|
+
this._notifyChange();
|
136
|
+
row.get('fields').push(this._fieldform({
|
137
|
+
kind,
|
138
|
+
name,
|
139
|
+
label,
|
140
|
+
}));
|
141
|
+
this._cd.detectChanges();
|
142
|
+
this._el.nativeElement.querySelector(`section[data-index='${this.form.get('sections').controls.indexOf(section)}'] .designer-row[data-index='${section.get('rows').controls.indexOf(row)}'] .designer-field:last-child input`)?.focus();
|
143
|
+
}
|
144
|
+
removeField(row, field) {
|
145
|
+
this._notifyChange();
|
146
|
+
row.get('fields').controls.remove(field);
|
147
|
+
}
|
148
|
+
removeSection(section) {
|
149
|
+
this._notifyChange();
|
150
|
+
this.form.get('sections').controls.remove(section);
|
151
|
+
}
|
152
|
+
removeRow(section, row) {
|
153
|
+
this._notifyChange();
|
154
|
+
section.get('rows').controls.remove(row);
|
155
|
+
}
|
156
|
+
_notifyChange() {
|
157
|
+
this.history.push(JSON.stringify(this.model));
|
158
|
+
this.historyIndex = this.history.length - 1;
|
159
|
+
this.dirty = true;
|
160
|
+
}
|
161
|
+
_restore() {
|
162
|
+
this._assign(JSON.parse(this.history[this.historyIndex]));
|
163
|
+
}
|
164
|
+
undo() {
|
165
|
+
this._restore();
|
166
|
+
this.historyIndex--;
|
167
|
+
}
|
168
|
+
redo() {
|
169
|
+
this.historyIndex++;
|
170
|
+
this._restore();
|
171
|
+
}
|
172
|
+
/**
|
173
|
+
* Ctrl-s save; Ctrl-z undo
|
174
|
+
* @param event
|
175
|
+
*/
|
176
|
+
handleKeyboardEvent(event) {
|
177
|
+
if (event.ctrlKey) {
|
178
|
+
if (event.which === 83 || event.which === 115) {
|
179
|
+
this.dirty && this.save();
|
180
|
+
event.preventDefault();
|
181
|
+
}
|
182
|
+
}
|
183
|
+
}
|
184
|
+
drop(event, collection) {
|
185
|
+
this._notifyChange();
|
34
186
|
if (event.previousContainer === event.container) {
|
35
|
-
|
187
|
+
const element = collection.at(event.previousIndex);
|
188
|
+
collection.removeAt(event.previousIndex);
|
189
|
+
collection.insert(event.currentIndex, element);
|
190
|
+
//moveItemInArray(event.container.data, event.previousIndex, event.currentIndex);
|
36
191
|
}
|
37
192
|
else {
|
38
|
-
transferArrayItem(
|
193
|
+
// transferArrayItem(
|
194
|
+
// event.previousContainer.data,
|
195
|
+
// event.container.data,
|
196
|
+
// event.previousIndex,
|
197
|
+
// event.currentIndex,
|
198
|
+
// );
|
39
199
|
}
|
40
200
|
}
|
41
201
|
save() {
|
42
202
|
this.saving = true;
|
43
|
-
this._ref.execute(this.model).subscribe(() =>
|
203
|
+
this._ref.execute({ metadata: cleanup(this.model), formId: this._formId }).subscribe(() => {
|
204
|
+
this._ps.toast('ChangesSaved');
|
205
|
+
this.dirty = false;
|
206
|
+
this.saving = false;
|
207
|
+
}, () => {
|
208
|
+
this._ps.error();
|
209
|
+
this.saving = false;
|
210
|
+
});
|
44
211
|
}
|
45
212
|
};
|
46
|
-
FormDesignerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.3", ngImport: i0, type: FormDesignerComponent, deps: [{ token: i1.FormBuilder }, { token: i2.
|
47
|
-
FormDesignerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.3", type: FormDesignerComponent, selector: "ng-component", ngImport: i0, template: "<mat-toolbar></mat-toolbar>\r\n<div class=\"row\">\r\n <div></div>\r\n <div *ngIf=\"tools\"></div>\r\n</div>\r\n", dependencies: [{ kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i5.MatToolbar, selector: "mat-toolbar", inputs: ["color"], exportAs: ["matToolbar"] }] });
|
213
|
+
FormDesignerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.3", ngImport: i0, type: FormDesignerComponent, deps: [{ token: i1.FormBuilder }, { token: i2.PaneRef }, { token: i0.ChangeDetectorRef }, { token: i3.PromptService }, { token: i4.SessionService }, { token: i0.ElementRef }, { token: i5.UtilityRef }], target: i0.ɵɵFactoryTarget.Component });
|
214
|
+
FormDesignerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.3", type: FormDesignerComponent, selector: "ng-component", host: { listeners: { "document:keydown": "handleKeyboardEvent($event)" } }, ngImport: i0, template: "<mat-toolbar>\r\n <button mat-icon-button (click)=\"save()\" [disabled]=\"!dirty || loading || saving\" [bizdocTooltip]=\"'Save'|translate\"><mat-icon>save</mat-icon></button>\r\n <button mat-icon-button (click)=\"undo()\" [bizdocTooltip]=\"'Undo' | translate\" [disabled]=\"historyIndex === -1\"><mat-icon>undo</mat-icon></button>\r\n <button mat-icon-button (click)=\"redo()\" [bizdocTooltip]=\"'Redo' | translate\" [disabled]=\"historyIndex === history.length - 1\"><mat-icon>redo</mat-icon></button>\r\n</mat-toolbar>\r\n<button mat-icon-button (click)=\"settings = !settings\" [bizdocTooltip]=\"'Settings'|translate\" type=\"button\"><mat-icon>settings</mat-icon></button>\r\n<form autocomplete=\"off\" [formGroup]=\"form\" *ngIf=\"model\">\r\n <div class=\"column\" *ngIf=\"settings\">\r\n <mat-form-field>\r\n <mat-label>{{'Value'|translate}}</mat-label>\r\n <bizdoc-ace-input formControlName=\"value\"></bizdoc-ace-input>\r\n <mat-hint> {{ 'Expression'|translate }}</mat-hint>\r\n </mat-form-field>\r\n <mat-form-field>\r\n <mat-label>{{'Subject'|translate}}</mat-label>\r\n <bizdoc-ace-input formControlName=\"subject\"></bizdoc-ace-input>\r\n <mat-hint> {{ 'Expression'|translate }}</mat-hint>\r\n </mat-form-field>\r\n <mat-form-field>\r\n <mat-label>{{'Summary'|translate}}</mat-label>\r\n <bizdoc-ace-input formControlName=\"summary\"></bizdoc-ace-input>\r\n <mat-hint> {{ 'Expression'|translate }}</mat-hint>\r\n </mat-form-field>\r\n <mat-form-field>\r\n <mat-label>{{'Analysis'|translate}}</mat-label>\r\n <mat-select formControlName=\"cube\">\r\n <mat-option>{{'None'|translate}}</mat-option>\r\n <mat-option *ngFor=\"let c of cubes\" [value]=\"c.name\">{{c.title}}</mat-option>\r\n </mat-select>\r\n </mat-form-field>\r\n </div>\r\n <div cdkDropList (cdkDropListDropped)=\"drop($event, form.get('sections'))\">\r\n <section class=\"column\" *ngFor=\"let s of form.get('sections').controls; let si = index\" cdkDrag [attr.data-index]=\"si\">\r\n <div class=\"row\">\r\n <mat-icon class=\"section-drag\" cdkDragHandle>drag_indicator</mat-icon>\r\n <div class=\"column\" [formGroup]=\"s\">\r\n <mat-form-field>\r\n <mat-label>{{'Title'|translate}}</mat-label>\r\n <input matInput formControlName=\"title\" />\r\n </mat-form-field>\r\n <mat-form-field>\r\n <mat-label>{{'Name'|translate}}</mat-label>\r\n <input matInput formControlName=\"name\" required />\r\n </mat-form-field>\r\n <div cdkDropList (cdkDropListDropped)=\"drop($event, s.get('rows'))\">\r\n <div *ngFor=\"let r of s.get('rows').controls; let ri = index\" class=\"row designer-row\" cdkDrag [attr.data-index]=\"ri\">\r\n <mat-icon cdkDragHandle>drag_indicator</mat-icon>\r\n <div cdkDropList cdkDropListOrientation=\"horizontal\" (cdkDropListDropped)=\"drop($event, r.get('fields'))\" class=\"row\">\r\n <div *ngFor=\"let f of r.get('fields').controls; let fi = index\" cdkDrag class=\"designer-field row\" [attr.data-index]=\"fi\">\r\n <mat-icon cdkDragHandle>drag_indicator</mat-icon>\r\n <div class=\"column\" [formGroup]=\"f\">\r\n <mat-form-field>\r\n <mat-label>{{'Name'|translate}}</mat-label>\r\n <input matInput required formControlName=\"name\" />\r\n </mat-form-field>\r\n <mat-form-field>\r\n <mat-label>{{'Label'|translate}}</mat-label>\r\n <input matInput required formControlName=\"label\" />\r\n </mat-form-field>\r\n <mat-checkbox formControlName=\"required\">{{'Mandatory'|translate}}</mat-checkbox>\r\n <ng-container [ngSwitch]=\"f.get('kind').value\">\r\n <div *ngSwitchCase=\"'Date'\">\r\n </div>\r\n <div *ngSwitchCase=\"'Text'\">\r\n </div>\r\n <div *ngSwitchCase=\"'Number'\">\r\n </div>\r\n <div *ngSwitchCase=\"'Date'\">\r\n </div>\r\n <mat-form-field *ngSwitchCase=\"'Select'\">\r\n <mat-label>{{'DataType'|translate}}</mat-label>\r\n <mat-select formControlName=\"dataType\" required>\r\n <mat-option *ngFor=\"let t of datatypes\" [value]=\"t.name\">{{t.title}}</mat-option>\r\n </mat-select>\r\n </mat-form-field>\r\n <div *ngSwitchDefault>\r\n <mat-form-field>\r\n <mat-label>{{'Type'|translate}}</mat-label>\r\n <mat-select formControlName=\"kind\" required>\r\n <mat-option value=\"String\">{{'Text'|translate}}</mat-option>\r\n <mat-option value=\"PhoneNumber\">{{'Tel'|translate}}</mat-option>\r\n <mat-option value=\"EmailAddress\">{{'Email'|translate}}</mat-option>\r\n <mat-option value=\"Url\">{{'Url'|translate}}</mat-option>\r\n </mat-select>\r\n </mat-form-field>\r\n </div>\r\n </ng-container>\r\n </div>\r\n <div class=\"actions\">\r\n <button mat-stroked-button (click)=\"removeField(r, f)\" [bizdocTooltip]=\"'Discard'|translate\" type=\"button\"><mat-icon>delete</mat-icon></button>\r\n </div>\r\n <!--<div *cdkDragPlaceholder class=\"drag-placeholder\"></div>-->\r\n </div>\r\n </div>\r\n <div class=\"column\">\r\n <button mat-stroked-button [matMenuTriggerFor]=\"fieldKindMenu\" [bizdocTooltip]=\"'Add'|translate\" type=\"button\"><mat-icon>add</mat-icon></button>\r\n <mat-menu #fieldKindMenu>\r\n <button mat-menu-item (click)=\"addField(s, r, 'String', $event)\">{{'Input'|translate}}</button>\r\n <button mat-menu-item (click)=\"addField(s, r, 'Date', $event)\">{{'Date'|translate}}</button>\r\n <button mat-menu-item (click)=\"addField(s, r, 'Number', $event)\">{{'Numeric'|translate}}</button>\r\n <button mat-menu-item (click)=\"addField(s, r, 'Select', $event)\">{{'Select'|translate}}</button>\r\n <button mat-menu-item (click)=\"addField(s, r, 'Checkbox', $event)\">{{'Checkbox'|translate}}</button>\r\n <button mat-menu-item (click)=\"addField(s, r, 'Switch', $event)\">{{'Switch'|translate}}</button>\r\n <button mat-menu-item (click)=\"addField(s, r, 'Text', $event)\">{{'Text'|translate}}</button>\r\n </mat-menu>\r\n <span class=\"divider\"></span>\r\n <button mat-stroked-button (click)=\"removeRow(s, r)\" [bizdocTooltip]=\"'Discard'|translate\" type=\"button\"><mat-icon>delete</mat-icon></button>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"row\">\r\n <button mat-stroked-button (click)=\"addRow(s, $event)\" [bizdocTooltip]=\"'Add'|translate\" type=\"button\"><mat-icon>add</mat-icon></button>\r\n <span class=\"divider\"></span>\r\n <button mat-stroked-button (click)=\"settings = !settings\" [bizdocTooltip]=\"'Settings'|translate\" type=\"button\"><mat-icon>settings</mat-icon></button>\r\n <button mat-stroked-button (click)=\"removeSection(s)\" [bizdocTooltip]=\"'Discard'|translate\" type=\"button\"><mat-icon>delete</mat-icon></button>\r\n </div>\r\n <div class=\"column\" *ngIf=\"settings\">\r\n <mat-form-field>\r\n <mat-label>{{'Value'|translate}}</mat-label>\r\n <bizdoc-ace-input formControlName=\"value\"></bizdoc-ace-input>\r\n <mat-hint> {{ 'Expression'|translate }}</mat-hint>\r\n </mat-form-field>\r\n </div>\r\n </section>\r\n <button mat-stroked-button (click)=\"addSection($event)\" [bizdocTooltip]=\"'Add'|translate\" type=\"button\"><mat-icon>add</mat-icon></button>\r\n </div>\r\n</form>\r\n", styles: ["form{margin:8px}section,.designer-row,.designer-field{border:2px solid transparent;border-radius:3px;padding:8px}section:hover,.designer-row:hover,.designer-field:hover{border:2px dotted}section .designer-row{margin:5px 0}section .designer-row .designer-field{flex:1}.drag-placeholder{border:2px dashed}\n"], dependencies: [{ kind: "directive", type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i6.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i6.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i6.NgSwitchDefault, selector: "[ngSwitchDefault]" }, { kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: i7.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: i7.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: "directive", type: i7.CdkDragHandle, selector: "[cdkDragHandle]", inputs: ["cdkDragHandleDisabled"] }, { kind: "component", type: i8.MatToolbar, selector: "mat-toolbar", inputs: ["color"], exportAs: ["matToolbar"] }, { kind: "component", type: i9.MatOption, selector: "mat-option", exportAs: ["matOption"] }, { kind: "component", type: i10.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i10.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { kind: "directive", type: i10.MatLabel, selector: "mat-label" }, { kind: "component", type: i11.MatSelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex"], exportAs: ["matSelect"] }, { kind: "component", type: i12.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i13.MatCheckbox, selector: "mat-checkbox", inputs: ["disableRipple", "color", "tabIndex"], exportAs: ["matCheckbox"] }, { kind: "directive", type: i14.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i15.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i16.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { kind: "component", type: i16.MatMenuItem, selector: "[mat-menu-item]", inputs: ["disabled", "disableRipple", "role"], exportAs: ["matMenuItem"] }, { kind: "directive", type: i16.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", exportAs: ["matMenuTrigger"] }, { kind: "directive", type: i17.TooltipDirective, selector: "[bizdocTooltip]", inputs: ["bizdocTooltip", "bizdocTooltipTemplate", "bizdocTooltipContext", "bizdocTooltipPosition", "bizdocTooltipDuration", "bizdocTooltipDisabled"] }, { kind: "component", type: i18.AceInput, selector: "bizdoc-ace-input", inputs: ["params", "placeholder", "required", "disabled", "value"] }, { kind: "pipe", type: i19.TranslatePipe, name: "translate" }] });
|
48
215
|
FormDesignerComponent = __decorate([
|
49
216
|
BizDoc({ selector: 'bizdoc-form-designer' })
|
50
217
|
], FormDesignerComponent);
|
51
218
|
export { FormDesignerComponent };
|
52
219
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.3", ngImport: i0, type: FormDesignerComponent, decorators: [{
|
53
220
|
type: Component,
|
54
|
-
args: [{ template: "<mat-toolbar></mat-toolbar>\r\n<div class=\"
|
55
|
-
}], ctorParameters: function () { return [{ type: i1.FormBuilder }, { type: i2.
|
56
|
-
|
221
|
+
args: [{ template: "<mat-toolbar>\r\n <button mat-icon-button (click)=\"save()\" [disabled]=\"!dirty || loading || saving\" [bizdocTooltip]=\"'Save'|translate\"><mat-icon>save</mat-icon></button>\r\n <button mat-icon-button (click)=\"undo()\" [bizdocTooltip]=\"'Undo' | translate\" [disabled]=\"historyIndex === -1\"><mat-icon>undo</mat-icon></button>\r\n <button mat-icon-button (click)=\"redo()\" [bizdocTooltip]=\"'Redo' | translate\" [disabled]=\"historyIndex === history.length - 1\"><mat-icon>redo</mat-icon></button>\r\n</mat-toolbar>\r\n<button mat-icon-button (click)=\"settings = !settings\" [bizdocTooltip]=\"'Settings'|translate\" type=\"button\"><mat-icon>settings</mat-icon></button>\r\n<form autocomplete=\"off\" [formGroup]=\"form\" *ngIf=\"model\">\r\n <div class=\"column\" *ngIf=\"settings\">\r\n <mat-form-field>\r\n <mat-label>{{'Value'|translate}}</mat-label>\r\n <bizdoc-ace-input formControlName=\"value\"></bizdoc-ace-input>\r\n <mat-hint> {{ 'Expression'|translate }}</mat-hint>\r\n </mat-form-field>\r\n <mat-form-field>\r\n <mat-label>{{'Subject'|translate}}</mat-label>\r\n <bizdoc-ace-input formControlName=\"subject\"></bizdoc-ace-input>\r\n <mat-hint> {{ 'Expression'|translate }}</mat-hint>\r\n </mat-form-field>\r\n <mat-form-field>\r\n <mat-label>{{'Summary'|translate}}</mat-label>\r\n <bizdoc-ace-input formControlName=\"summary\"></bizdoc-ace-input>\r\n <mat-hint> {{ 'Expression'|translate }}</mat-hint>\r\n </mat-form-field>\r\n <mat-form-field>\r\n <mat-label>{{'Analysis'|translate}}</mat-label>\r\n <mat-select formControlName=\"cube\">\r\n <mat-option>{{'None'|translate}}</mat-option>\r\n <mat-option *ngFor=\"let c of cubes\" [value]=\"c.name\">{{c.title}}</mat-option>\r\n </mat-select>\r\n </mat-form-field>\r\n </div>\r\n <div cdkDropList (cdkDropListDropped)=\"drop($event, form.get('sections'))\">\r\n <section class=\"column\" *ngFor=\"let s of form.get('sections').controls; let si = index\" cdkDrag [attr.data-index]=\"si\">\r\n <div class=\"row\">\r\n <mat-icon class=\"section-drag\" cdkDragHandle>drag_indicator</mat-icon>\r\n <div class=\"column\" [formGroup]=\"s\">\r\n <mat-form-field>\r\n <mat-label>{{'Title'|translate}}</mat-label>\r\n <input matInput formControlName=\"title\" />\r\n </mat-form-field>\r\n <mat-form-field>\r\n <mat-label>{{'Name'|translate}}</mat-label>\r\n <input matInput formControlName=\"name\" required />\r\n </mat-form-field>\r\n <div cdkDropList (cdkDropListDropped)=\"drop($event, s.get('rows'))\">\r\n <div *ngFor=\"let r of s.get('rows').controls; let ri = index\" class=\"row designer-row\" cdkDrag [attr.data-index]=\"ri\">\r\n <mat-icon cdkDragHandle>drag_indicator</mat-icon>\r\n <div cdkDropList cdkDropListOrientation=\"horizontal\" (cdkDropListDropped)=\"drop($event, r.get('fields'))\" class=\"row\">\r\n <div *ngFor=\"let f of r.get('fields').controls; let fi = index\" cdkDrag class=\"designer-field row\" [attr.data-index]=\"fi\">\r\n <mat-icon cdkDragHandle>drag_indicator</mat-icon>\r\n <div class=\"column\" [formGroup]=\"f\">\r\n <mat-form-field>\r\n <mat-label>{{'Name'|translate}}</mat-label>\r\n <input matInput required formControlName=\"name\" />\r\n </mat-form-field>\r\n <mat-form-field>\r\n <mat-label>{{'Label'|translate}}</mat-label>\r\n <input matInput required formControlName=\"label\" />\r\n </mat-form-field>\r\n <mat-checkbox formControlName=\"required\">{{'Mandatory'|translate}}</mat-checkbox>\r\n <ng-container [ngSwitch]=\"f.get('kind').value\">\r\n <div *ngSwitchCase=\"'Date'\">\r\n </div>\r\n <div *ngSwitchCase=\"'Text'\">\r\n </div>\r\n <div *ngSwitchCase=\"'Number'\">\r\n </div>\r\n <div *ngSwitchCase=\"'Date'\">\r\n </div>\r\n <mat-form-field *ngSwitchCase=\"'Select'\">\r\n <mat-label>{{'DataType'|translate}}</mat-label>\r\n <mat-select formControlName=\"dataType\" required>\r\n <mat-option *ngFor=\"let t of datatypes\" [value]=\"t.name\">{{t.title}}</mat-option>\r\n </mat-select>\r\n </mat-form-field>\r\n <div *ngSwitchDefault>\r\n <mat-form-field>\r\n <mat-label>{{'Type'|translate}}</mat-label>\r\n <mat-select formControlName=\"kind\" required>\r\n <mat-option value=\"String\">{{'Text'|translate}}</mat-option>\r\n <mat-option value=\"PhoneNumber\">{{'Tel'|translate}}</mat-option>\r\n <mat-option value=\"EmailAddress\">{{'Email'|translate}}</mat-option>\r\n <mat-option value=\"Url\">{{'Url'|translate}}</mat-option>\r\n </mat-select>\r\n </mat-form-field>\r\n </div>\r\n </ng-container>\r\n </div>\r\n <div class=\"actions\">\r\n <button mat-stroked-button (click)=\"removeField(r, f)\" [bizdocTooltip]=\"'Discard'|translate\" type=\"button\"><mat-icon>delete</mat-icon></button>\r\n </div>\r\n <!--<div *cdkDragPlaceholder class=\"drag-placeholder\"></div>-->\r\n </div>\r\n </div>\r\n <div class=\"column\">\r\n <button mat-stroked-button [matMenuTriggerFor]=\"fieldKindMenu\" [bizdocTooltip]=\"'Add'|translate\" type=\"button\"><mat-icon>add</mat-icon></button>\r\n <mat-menu #fieldKindMenu>\r\n <button mat-menu-item (click)=\"addField(s, r, 'String', $event)\">{{'Input'|translate}}</button>\r\n <button mat-menu-item (click)=\"addField(s, r, 'Date', $event)\">{{'Date'|translate}}</button>\r\n <button mat-menu-item (click)=\"addField(s, r, 'Number', $event)\">{{'Numeric'|translate}}</button>\r\n <button mat-menu-item (click)=\"addField(s, r, 'Select', $event)\">{{'Select'|translate}}</button>\r\n <button mat-menu-item (click)=\"addField(s, r, 'Checkbox', $event)\">{{'Checkbox'|translate}}</button>\r\n <button mat-menu-item (click)=\"addField(s, r, 'Switch', $event)\">{{'Switch'|translate}}</button>\r\n <button mat-menu-item (click)=\"addField(s, r, 'Text', $event)\">{{'Text'|translate}}</button>\r\n </mat-menu>\r\n <span class=\"divider\"></span>\r\n <button mat-stroked-button (click)=\"removeRow(s, r)\" [bizdocTooltip]=\"'Discard'|translate\" type=\"button\"><mat-icon>delete</mat-icon></button>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"row\">\r\n <button mat-stroked-button (click)=\"addRow(s, $event)\" [bizdocTooltip]=\"'Add'|translate\" type=\"button\"><mat-icon>add</mat-icon></button>\r\n <span class=\"divider\"></span>\r\n <button mat-stroked-button (click)=\"settings = !settings\" [bizdocTooltip]=\"'Settings'|translate\" type=\"button\"><mat-icon>settings</mat-icon></button>\r\n <button mat-stroked-button (click)=\"removeSection(s)\" [bizdocTooltip]=\"'Discard'|translate\" type=\"button\"><mat-icon>delete</mat-icon></button>\r\n </div>\r\n <div class=\"column\" *ngIf=\"settings\">\r\n <mat-form-field>\r\n <mat-label>{{'Value'|translate}}</mat-label>\r\n <bizdoc-ace-input formControlName=\"value\"></bizdoc-ace-input>\r\n <mat-hint> {{ 'Expression'|translate }}</mat-hint>\r\n </mat-form-field>\r\n </div>\r\n </section>\r\n <button mat-stroked-button (click)=\"addSection($event)\" [bizdocTooltip]=\"'Add'|translate\" type=\"button\"><mat-icon>add</mat-icon></button>\r\n </div>\r\n</form>\r\n", styles: ["form{margin:8px}section,.designer-row,.designer-field{border:2px solid transparent;border-radius:3px;padding:8px}section:hover,.designer-row:hover,.designer-field:hover{border:2px dotted}section .designer-row{margin:5px 0}section .designer-row .designer-field{flex:1}.drag-placeholder{border:2px dashed}\n"] }]
|
222
|
+
}], ctorParameters: function () { return [{ type: i1.FormBuilder }, { type: i2.PaneRef }, { type: i0.ChangeDetectorRef }, { type: i3.PromptService }, { type: i4.SessionService }, { type: i0.ElementRef }, { type: i5.UtilityRef }]; }, propDecorators: { handleKeyboardEvent: [{
|
223
|
+
type: HostListener,
|
224
|
+
args: ['document:keydown', ['$event']]
|
225
|
+
}] } });
|
226
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"designer.component.js","sourceRoot":"","sources":["../../../../../../../libraries/core/src/lib/admin/form/designer/designer.component.ts","../../../../../../../libraries/core/src/lib/admin/form/designer/designer.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CdkDragDrop, moveItemInArray, transferArrayItem } from \"@angular/cdk/drag-drop\";\r\nimport { ChangeDetectorRef, Component, ElementRef, HostListener, OnInit } from \"@angular/core\";\r\nimport { FormArray, FormBuilder, FormGroup, Validators } from \"@angular/forms\";\r\nimport { BizDoc } from \"../../../core/decorators\";\r\nimport { cleanup } from \"../../../core/functions\";\r\nimport { Cube, FieldType, Type } from \"../../../core/models\";\r\nimport { PromptService } from \"../../../core/prompt.service\";\r\nimport { SessionService } from \"../../../core/session.service\";\r\nimport { PaneRef } from \"../../../core/slots/pane-ref\";\r\nimport { UtilityRef } from \"../../utility-ref\";\r\n\r\n/** */\r\n@Component({\r\n  templateUrl: 'designer.component.html',\r\n  styleUrls: ['designer.component.scss']\r\n})\r\n@BizDoc({ selector: 'bizdoc-form-designer' })\r\nexport class FormDesignerComponent implements OnInit {\r\n  loading = true;\r\n  tools = true;\r\n  saving = false;\r\n  model: BoxFormMetadata;\r\n  readonly history: string[] = [];\r\n  historyIndex = -1;\r\n  readonly datatypes: Type[];\r\n  readonly cubes: Cube[];\r\n  readonly form = this._fb.group({\r\n    subject: null,\r\n    value: null,\r\n    cube: null,\r\n    summary: null,\r\n    sections: this._fb.array([])\r\n  });\r\n  title: string;\r\n  dirty = false;\r\n  settings = false;\r\n  private _formId: string;\r\n  constructor(\r\n    private _fb: FormBuilder,\r\n    private _pane: PaneRef<any>,\r\n    private _cd: ChangeDetectorRef,\r\n    private _ps: PromptService,\r\n    private _session: SessionService,\r\n    private _el: ElementRef,\r\n    private _ref: UtilityRef<boolean, { metadata: BoxFormMetadata, formId: string }, BoxFormMetadata, string>) {\r\n    this.datatypes = this._session.profile.types;\r\n    this.cubes = this._session.profile.cubes;\r\n  }\r\n  ngOnInit(): void {\r\n    this._pane.queryParamsChange.subscribe(p => {\r\n      const { formId } = p;\r\n      formId && this._open(formId);\r\n    });\r\n    this.form.valueChanges.pipe().\r\n      subscribe(v => {\r\n        //this._notifyChange();\r\n        Object.assign(this.model, v);\r\n      });\r\n  }\r\n  private _open(formId: string) {\r\n    this._ref.populate(formId).subscribe(r => {\r\n      this._formId = formId;\r\n      this._assign(r);\r\n      this.loading = false;\r\n    });\r\n  }\r\n  private _assign(model: BoxFormMetadata) {\r\n    this.model = model || { sections: [] };\r\n    const sections = (this.form.get('sections') as FormArray);\r\n    sections.clear({ emitEvent: false });\r\n    this.form.patchValue(this.model, { emitEvent: false });\r\n    model.sections?.forEach(s => sections.push(this._sectionform(s), { emitEvent: false })\r\n    );\r\n  }\r\n\r\n  private _sectionform(section: SectionModel) {\r\n    const name = this._fb.control(section.name, Validators.required);\r\n    return this._fb.group({\r\n      name,\r\n      title: section.title,\r\n      multiLine: section.multiLine || false,\r\n      value: section.value || null,\r\n      rows: this._fb.array(section.rows?.map(r =>\r\n        this._rowform(r)) || [])\r\n    })\r\n  }\r\n  private _rowform(row: RowModel): any {\r\n    return this._fb.group({\r\n      fields: this._fb.array(row.fields.map(f => this._fieldform(f)))\r\n    })\r\n  }\r\n  private _fieldform(field: FieldModel): any {\r\n    const name = this._fb.control(field.name, Validators.required),\r\n      label = this._fb.control(field.label, Validators.required);\r\n    return this._fb.group({\r\n      name,\r\n      label,\r\n      kind: field.kind,\r\n      dataType: field.dataType,\r\n      required: field.required\r\n    })\r\n  }\r\n  addSection(evt?: Event) {\r\n    this._notifyChange();\r\n    let n = 0, name, title;\r\n    do {\r\n      n++;\r\n      name = 'section' + '_' + n;\r\n      title = 'Section' + ' ' + n;\r\n    } while (this.model.sections.find(s => s.name === name || s.title === title));\r\n    (this.form.get('sections') as FormArray).push(this._sectionform({\r\n      name,\r\n      title,\r\n      rows: [{ fields: [] }]\r\n    }));\r\n    this._cd.detectChanges();\r\n    this._el.nativeElement.querySelector('section:last-child button')?.focus()\r\n  }\r\n  addRow(section: FormGroup, evt?: Event) {\r\n    this._notifyChange();\r\n    (section.get('rows') as FormArray).push(this._rowform({\r\n      fields: []\r\n    }));\r\n    this._cd.detectChanges();\r\n    this._el.nativeElement.querySelector(`section[data-index='${(this.form.get('sections') as FormArray).controls.indexOf(section)}'] .designer-row:last-child button`)?.focus()\r\n  }\r\n  addField(section: FormGroup, row: FormGroup, kind: FieldType, evt?: Event) {\r\n    let n = 0, name, label;\r\n    do {\r\n      n++;\r\n      name = 'field' + '_' + n;\r\n      label = 'Field' + ' ' + n;\r\n    } while ((section.get('rows') as FormArray).controls.\r\n      find(r => (r.get('fields') as FormArray).controls.find(f => f.value.name === name || f.value.label === label) != null));\r\n    this._notifyChange();\r\n    (row.get('fields') as FormArray).push(this._fieldform({\r\n      kind,\r\n      name,\r\n      label,\r\n    }));\r\n    this._cd.detectChanges();\r\n    this._el.nativeElement.querySelector(`section[data-index='${(this.form.get('sections') as FormArray).controls.indexOf(section)}'] .designer-row[data-index='${(section.get('rows') as FormArray).controls.indexOf(row)}'] .designer-field:last-child input`)?.focus()\r\n  }\r\n  removeField(row: FormGroup, field: FormGroup) {\r\n    this._notifyChange();\r\n    (row.get('fields') as FormArray).controls.remove(field);\r\n  }\r\n  removeSection(section: FormGroup) {\r\n    this._notifyChange();\r\n    (this.form.get('sections') as FormArray).controls.remove(section);\r\n  }\r\n  removeRow(section: FormGroup, row: FormGroup) {\r\n    this._notifyChange();\r\n    (section.get('rows') as FormArray).controls.remove(row);\r\n  }\r\n  private _notifyChange() {\r\n    this.history.push(JSON.stringify(this.model));\r\n    this.historyIndex = this.history.length - 1;\r\n    this.dirty = true;\r\n  }\r\n  private _restore() {\r\n    this._assign(JSON.parse( this.history[this.historyIndex]));\r\n  }\r\n  undo() {\r\n    this._restore();\r\n    this.historyIndex--;\r\n  }\r\n  redo() {\r\n    this.historyIndex++;\r\n    this._restore();\r\n  }\r\n  /**\r\n   * Ctrl-s save; Ctrl-z undo\r\n   * @param event\r\n   */\r\n  @HostListener('document:keydown', ['$event'])\r\n  handleKeyboardEvent(event: KeyboardEvent) {\r\n    if (event.ctrlKey) {\r\n      if (event.which === 83 || event.which === 115) {\r\n        this.dirty && this.save();\r\n        event.preventDefault();\r\n      }\r\n    }\r\n  }\r\n  drop(event: CdkDragDrop<FormGroup>, collection: FormArray) {\r\n    this._notifyChange();\r\n    if (event.previousContainer === event.container) {\r\n      const element = collection.at(event.previousIndex);\r\n      collection.removeAt(event.previousIndex);\r\n      collection.insert(event.currentIndex, element);\r\n      //moveItemInArray(event.container.data, event.previousIndex, event.currentIndex);\r\n    } else {\r\n      //  transferArrayItem(\r\n      //    event.previousContainer.data,\r\n      //    event.container.data,\r\n      //    event.previousIndex,\r\n      //    event.currentIndex,\r\n      //  );\r\n    }\r\n  }\r\n  save() {\r\n    this.saving = true;\r\n    this._ref.execute({ metadata: cleanup(this.model), formId: this._formId }).subscribe(() => {\r\n      this._ps.toast('ChangesSaved');\r\n      this.dirty = false;\r\n      this.saving = false;\r\n    }, () => {\r\n      this._ps.error();\r\n      this.saving = false;\r\n    });\r\n  }\r\n}\r\nexport interface BoxFormMetadata {\r\n  sections: SectionModel[];\r\n  value?: string;\r\n  subject?: string;\r\n  summary?: string;\r\n  cube?: string;\r\n}\r\n\r\ninterface SectionModel {\r\n  name: string;\r\n  title: string;\r\n  value?: string;\r\n  multiLine?: boolean;\r\n  rows: RowModel[];\r\n}\r\ninterface RowModel {\r\n  fields: FieldModel[];\r\n}\r\ninterface FieldModel {\r\n  name: string;\r\n  label: string;\r\n  kind: FieldType;\r\n  required?: boolean;\r\n  dataType?: string;\r\n  min?: any;\r\n  max?: any;\r\n}\r\n","<mat-toolbar>\r\n  <button mat-icon-button (click)=\"save()\" [disabled]=\"!dirty || loading || saving\" [bizdocTooltip]=\"'Save'|translate\"><mat-icon>save</mat-icon></button>\r\n  <button mat-icon-button (click)=\"undo()\" [bizdocTooltip]=\"'Undo' | translate\" [disabled]=\"historyIndex === -1\"><mat-icon>undo</mat-icon></button>\r\n  <button mat-icon-button (click)=\"redo()\" [bizdocTooltip]=\"'Redo' | translate\" [disabled]=\"historyIndex === history.length - 1\"><mat-icon>redo</mat-icon></button>\r\n</mat-toolbar>\r\n<button mat-icon-button (click)=\"settings = !settings\" [bizdocTooltip]=\"'Settings'|translate\" type=\"button\"><mat-icon>settings</mat-icon></button>\r\n<form autocomplete=\"off\" [formGroup]=\"form\" *ngIf=\"model\">\r\n  <div class=\"column\" *ngIf=\"settings\">\r\n    <mat-form-field>\r\n      <mat-label>{{'Value'|translate}}</mat-label>\r\n      <bizdoc-ace-input formControlName=\"value\"></bizdoc-ace-input>\r\n      <mat-hint> {{ 'Expression'|translate }}</mat-hint>\r\n    </mat-form-field>\r\n    <mat-form-field>\r\n      <mat-label>{{'Subject'|translate}}</mat-label>\r\n      <bizdoc-ace-input formControlName=\"subject\"></bizdoc-ace-input>\r\n      <mat-hint> {{ 'Expression'|translate }}</mat-hint>\r\n    </mat-form-field>\r\n    <mat-form-field>\r\n      <mat-label>{{'Summary'|translate}}</mat-label>\r\n      <bizdoc-ace-input formControlName=\"summary\"></bizdoc-ace-input>\r\n      <mat-hint> {{ 'Expression'|translate }}</mat-hint>\r\n    </mat-form-field>\r\n    <mat-form-field>\r\n      <mat-label>{{'Analysis'|translate}}</mat-label>\r\n      <mat-select formControlName=\"cube\">\r\n        <mat-option>{{'None'|translate}}</mat-option>\r\n        <mat-option *ngFor=\"let c of cubes\" [value]=\"c.name\">{{c.title}}</mat-option>\r\n      </mat-select>\r\n    </mat-form-field>\r\n  </div>\r\n  <div cdkDropList (cdkDropListDropped)=\"drop($event, form.get('sections'))\">\r\n    <section class=\"column\" *ngFor=\"let s of form.get('sections').controls; let si = index\" cdkDrag [attr.data-index]=\"si\">\r\n      <div class=\"row\">\r\n        <mat-icon class=\"section-drag\" cdkDragHandle>drag_indicator</mat-icon>\r\n        <div class=\"column\" [formGroup]=\"s\">\r\n          <mat-form-field>\r\n            <mat-label>{{'Title'|translate}}</mat-label>\r\n            <input matInput formControlName=\"title\" />\r\n          </mat-form-field>\r\n          <mat-form-field>\r\n            <mat-label>{{'Name'|translate}}</mat-label>\r\n            <input matInput formControlName=\"name\" required />\r\n          </mat-form-field>\r\n          <div cdkDropList (cdkDropListDropped)=\"drop($event, s.get('rows'))\">\r\n            <div *ngFor=\"let r of s.get('rows').controls; let ri = index\" class=\"row designer-row\" cdkDrag [attr.data-index]=\"ri\">\r\n              <mat-icon cdkDragHandle>drag_indicator</mat-icon>\r\n              <div cdkDropList cdkDropListOrientation=\"horizontal\" (cdkDropListDropped)=\"drop($event, r.get('fields'))\" class=\"row\">\r\n                <div *ngFor=\"let f of r.get('fields').controls; let fi = index\" cdkDrag class=\"designer-field row\" [attr.data-index]=\"fi\">\r\n                  <mat-icon cdkDragHandle>drag_indicator</mat-icon>\r\n                  <div class=\"column\" [formGroup]=\"f\">\r\n                    <mat-form-field>\r\n                      <mat-label>{{'Name'|translate}}</mat-label>\r\n                      <input matInput required formControlName=\"name\" />\r\n                    </mat-form-field>\r\n                    <mat-form-field>\r\n                      <mat-label>{{'Label'|translate}}</mat-label>\r\n                      <input matInput required formControlName=\"label\" />\r\n                    </mat-form-field>\r\n                    <mat-checkbox formControlName=\"required\">{{'Mandatory'|translate}}</mat-checkbox>\r\n                    <ng-container [ngSwitch]=\"f.get('kind').value\">\r\n                      <div *ngSwitchCase=\"'Date'\">\r\n                      </div>\r\n                      <div *ngSwitchCase=\"'Text'\">\r\n                      </div>\r\n                      <div *ngSwitchCase=\"'Number'\">\r\n                      </div>\r\n                      <div *ngSwitchCase=\"'Date'\">\r\n                      </div>\r\n                      <mat-form-field *ngSwitchCase=\"'Select'\">\r\n                        <mat-label>{{'DataType'|translate}}</mat-label>\r\n                        <mat-select formControlName=\"dataType\" required>\r\n                          <mat-option *ngFor=\"let t of datatypes\" [value]=\"t.name\">{{t.title}}</mat-option>\r\n                        </mat-select>\r\n                      </mat-form-field>\r\n                      <div *ngSwitchDefault>\r\n                        <mat-form-field>\r\n                          <mat-label>{{'Type'|translate}}</mat-label>\r\n                          <mat-select formControlName=\"kind\" required>\r\n                            <mat-option value=\"String\">{{'Text'|translate}}</mat-option>\r\n                            <mat-option value=\"PhoneNumber\">{{'Tel'|translate}}</mat-option>\r\n                            <mat-option value=\"EmailAddress\">{{'Email'|translate}}</mat-option>\r\n                            <mat-option value=\"Url\">{{'Url'|translate}}</mat-option>\r\n                          </mat-select>\r\n                        </mat-form-field>\r\n                      </div>\r\n                    </ng-container>\r\n                  </div>\r\n                  <div class=\"actions\">\r\n                    <button mat-stroked-button (click)=\"removeField(r, f)\" [bizdocTooltip]=\"'Discard'|translate\" type=\"button\"><mat-icon>delete</mat-icon></button>\r\n                  </div>\r\n                  <!--<div *cdkDragPlaceholder class=\"drag-placeholder\"></div>-->\r\n                </div>\r\n              </div>\r\n              <div class=\"column\">\r\n                <button mat-stroked-button [matMenuTriggerFor]=\"fieldKindMenu\" [bizdocTooltip]=\"'Add'|translate\" type=\"button\"><mat-icon>add</mat-icon></button>\r\n                <mat-menu #fieldKindMenu>\r\n                  <button mat-menu-item (click)=\"addField(s, r, 'String', $event)\">{{'Input'|translate}}</button>\r\n                  <button mat-menu-item (click)=\"addField(s, r, 'Date', $event)\">{{'Date'|translate}}</button>\r\n                  <button mat-menu-item (click)=\"addField(s, r, 'Number', $event)\">{{'Numeric'|translate}}</button>\r\n                  <button mat-menu-item (click)=\"addField(s, r, 'Select', $event)\">{{'Select'|translate}}</button>\r\n                  <button mat-menu-item (click)=\"addField(s, r, 'Checkbox', $event)\">{{'Checkbox'|translate}}</button>\r\n                  <button mat-menu-item (click)=\"addField(s, r, 'Switch', $event)\">{{'Switch'|translate}}</button>\r\n                  <button mat-menu-item (click)=\"addField(s, r, 'Text', $event)\">{{'Text'|translate}}</button>\r\n                </mat-menu>\r\n                <span class=\"divider\"></span>\r\n                <button mat-stroked-button (click)=\"removeRow(s, r)\" [bizdocTooltip]=\"'Discard'|translate\" type=\"button\"><mat-icon>delete</mat-icon></button>\r\n              </div>\r\n            </div>\r\n          </div>\r\n        </div>\r\n      </div>\r\n      <div class=\"row\">\r\n        <button mat-stroked-button (click)=\"addRow(s, $event)\" [bizdocTooltip]=\"'Add'|translate\" type=\"button\"><mat-icon>add</mat-icon></button>\r\n        <span class=\"divider\"></span>\r\n        <button mat-stroked-button (click)=\"settings = !settings\" [bizdocTooltip]=\"'Settings'|translate\" type=\"button\"><mat-icon>settings</mat-icon></button>\r\n        <button mat-stroked-button (click)=\"removeSection(s)\" [bizdocTooltip]=\"'Discard'|translate\" type=\"button\"><mat-icon>delete</mat-icon></button>\r\n      </div>\r\n      <div class=\"column\" *ngIf=\"settings\">\r\n        <mat-form-field>\r\n          <mat-label>{{'Value'|translate}}</mat-label>\r\n          <bizdoc-ace-input formControlName=\"value\"></bizdoc-ace-input>\r\n          <mat-hint> {{ 'Expression'|translate }}</mat-hint>\r\n        </mat-form-field>\r\n      </div>\r\n    </section>\r\n    <button mat-stroked-button (click)=\"addSection($event)\" [bizdocTooltip]=\"'Add'|translate\" type=\"button\"><mat-icon>add</mat-icon></button>\r\n  </div>\r\n</form>\r\n"]}
|