@bizdoc/core 1.16.3 → 1.16.6
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/system/Microsoft_Azure.svg +23 -0
- package/assets/system/QAD.svg +359 -0
- package/assets/system/sap.svg +1 -0
- package/esm2020/lib/admin/configuration-designer/cube-axes-filter.component.mjs +112 -0
- package/esm2020/lib/admin/configuration-designer/designer-element.component.mjs +204 -131
- package/esm2020/lib/admin/configuration-designer/designer.base.mjs +57 -10
- package/esm2020/lib/admin/configuration-designer/designer.component.mjs +86 -56
- package/esm2020/lib/admin/configuration-designer/elements/action.component.mjs +36 -16
- package/esm2020/lib/admin/configuration-designer/elements/analysis-view.component.mjs +5 -4
- package/esm2020/lib/admin/configuration-designer/elements/analysis-widget.component.mjs +5 -4
- package/esm2020/lib/admin/configuration-designer/elements/anomaly-rule.component.mjs +3 -3
- package/esm2020/lib/admin/configuration-designer/elements/box-form.component.mjs +3 -3
- package/esm2020/lib/admin/configuration-designer/elements/configuration-datasource.component.mjs +3 -3
- package/esm2020/lib/admin/configuration-designer/elements/cube-index-utility.component.mjs +3 -3
- package/esm2020/lib/admin/configuration-designer/elements/cube-view.component.mjs +3 -3
- package/esm2020/lib/admin/configuration-designer/elements/cube.component.mjs +81 -63
- package/esm2020/lib/admin/configuration-designer/elements/documents-report.component.mjs +3 -3
- package/esm2020/lib/admin/configuration-designer/elements/documents-widget.component.mjs +3 -3
- package/esm2020/lib/admin/configuration-designer/elements/explore-view.component.mjs +3 -3
- package/esm2020/lib/admin/configuration-designer/elements/folder.component.mjs +42 -13
- package/esm2020/lib/admin/configuration-designer/elements/form.component.mjs +12 -17
- package/esm2020/lib/admin/configuration-designer/elements/guide.component.mjs +8 -13
- package/esm2020/lib/admin/configuration-designer/elements/matrix-view.component.mjs +5 -4
- package/esm2020/lib/admin/configuration-designer/elements/parallel-view.component.mjs +4 -4
- package/esm2020/lib/admin/configuration-designer/elements/performance-widget.component.mjs +3 -3
- package/esm2020/lib/admin/configuration-designer/elements/pivot-view.component.mjs +4 -4
- package/esm2020/lib/admin/configuration-designer/elements/report.component.mjs +9 -14
- package/esm2020/lib/admin/configuration-designer/elements/return-to-role-action.component.mjs +3 -3
- package/esm2020/lib/admin/configuration-designer/elements/role.component.mjs +13 -5
- package/esm2020/lib/admin/configuration-designer/elements/rule.component.mjs +6 -13
- package/esm2020/lib/admin/configuration-designer/elements/state.component.mjs +20 -15
- package/esm2020/lib/admin/configuration-designer/elements/sum-view.component.mjs +4 -4
- package/esm2020/lib/admin/configuration-designer/elements/tasks-report.component.mjs +3 -3
- package/esm2020/lib/admin/configuration-designer/elements/type.component.mjs +8 -14
- package/esm2020/lib/admin/configuration-designer/elements/usage-report.component.mjs +4 -4
- package/esm2020/lib/admin/configuration-designer/elements/utility.component.mjs +6 -6
- package/esm2020/lib/admin/configuration-designer/elements/view.component.mjs +6 -13
- package/esm2020/lib/admin/configuration-designer/elements/widget.component.mjs +7 -12
- package/esm2020/lib/admin/configuration-designer/icon-picker.component.mjs +3 -3
- package/esm2020/lib/admin/form/workflow/node.component.mjs +2 -2
- package/esm2020/lib/bizdoc.module.mjs +1 -3
- package/esm2020/lib/core/functions.mjs +4 -3
- package/esm2020/lib/core/layout/input.base.mjs +45 -1
- package/esm2020/lib/core/layout/input.field.mjs +3 -2
- package/esm2020/lib/core/layout/layout.component.mjs +16 -58
- package/esm2020/lib/core/models.mjs +1 -1
- package/esm2020/lib/core/slots/router.service.mjs +1 -1
- package/esm2020/lib/core/slots/slots.component.mjs +12 -7
- package/esm2020/lib/core/translations.mjs +15 -2
- package/esm2020/lib/dashboard/widget-item.component.mjs +2 -2
- package/esm2020/lib/reports/arguments-component.mjs +2 -2
- package/esm2020/lib/shared.module.mjs +3 -1
- package/esm2020/lib/system.module.mjs +10 -9
- package/esm2020/lib/views/cube/sum.component.mjs +1 -1
- package/fesm2015/bizdoc-core.mjs +1604 -1306
- package/fesm2015/bizdoc-core.mjs.map +1 -1
- package/fesm2020/bizdoc-core.mjs +1591 -1294
- package/fesm2020/bizdoc-core.mjs.map +1 -1
- package/lib/admin/configuration-designer/cube-axes-filter.component.d.ts +35 -0
- package/lib/admin/configuration-designer/designer-element.component.d.ts +66 -27
- package/lib/admin/configuration-designer/designer.base.d.ts +99 -38
- package/lib/admin/configuration-designer/designer.component.d.ts +8 -4
- package/lib/admin/configuration-designer/elements/action.component.d.ts +18 -4
- package/lib/admin/configuration-designer/elements/cube.component.d.ts +1 -8
- package/lib/admin/configuration-designer/elements/folder.component.d.ts +8 -4
- package/lib/admin/configuration-designer/elements/report.component.d.ts +3 -3
- package/lib/admin/configuration-designer/elements/role.component.d.ts +2 -0
- package/lib/admin/configuration-designer/elements/state.component.d.ts +4 -0
- package/lib/core/layout/input.base.d.ts +4 -1
- package/lib/core/layout/input.field.d.ts +1 -1
- package/lib/core/layout/layout.component.d.ts +5 -7
- package/lib/core/models.d.ts +5 -4
- package/lib/core/slots/router.service.d.ts +2 -0
- package/lib/core/translations.d.ts +13 -0
- package/lib/system.module.d.ts +50 -49
- package/lib/views/cube/sum.component.d.ts +3 -3
- package/package.json +16 -16
@@ -1,137 +1,143 @@
|
|
1
|
-
import { Component, EventEmitter, HostListener,
|
1
|
+
import { Component, ContentChild, ContentChildren, EventEmitter, HostListener, Inject, Input, Optional, Output, ViewChild, ViewContainerRef } from "@angular/core";
|
2
2
|
import { Validators } from "@angular/forms";
|
3
|
-
import {
|
4
|
-
import {
|
3
|
+
import { Subject, takeUntil } from "rxjs";
|
4
|
+
import { LayoutComponent } from "../../core/layout/layout.component";
|
5
|
+
import { DesignerRef, programName, FAMILY_SVG } from "./designer.base";
|
5
6
|
import * as i0 from "@angular/core";
|
6
|
-
import * as i1 from "../../core/
|
7
|
-
import * as i2 from "@angular/
|
8
|
-
import * as i3 from "
|
9
|
-
import * as i4 from "
|
10
|
-
import * as i5 from "@angular/
|
11
|
-
import * as i6 from "
|
12
|
-
import * as i7 from "@angular/material/
|
13
|
-
import * as i8 from "@angular/material/
|
14
|
-
import * as i9 from "@angular/material/
|
15
|
-
import * as i10 from "@angular/material/
|
16
|
-
import * as i11 from "@angular/material/
|
17
|
-
import * as i12 from "
|
7
|
+
import * as i1 from "../../core/component-factory-resolver";
|
8
|
+
import * as i2 from "@angular/common";
|
9
|
+
import * as i3 from "../../core/pipes/sanitize-html.pipe";
|
10
|
+
import * as i4 from "./designer.base";
|
11
|
+
import * as i5 from "@angular/forms";
|
12
|
+
import * as i6 from "../system.service";
|
13
|
+
import * as i7 from "@angular/material/list";
|
14
|
+
import * as i8 from "@angular/material/toolbar";
|
15
|
+
import * as i9 from "@angular/material/form-field";
|
16
|
+
import * as i10 from "@angular/material/button";
|
17
|
+
import * as i11 from "@angular/material/input";
|
18
|
+
import * as i12 from "@angular/material/icon";
|
18
19
|
import * as i13 from "../core/ace.input";
|
19
20
|
import * as i14 from "../../core/pipes/translate.pipe";
|
20
|
-
|
21
|
-
export class
|
22
|
-
constructor(
|
23
|
-
this._injector = _injector;
|
24
|
-
this._pane = _pane;
|
25
|
-
this._fb = _fb;
|
26
|
-
this._service = _service;
|
21
|
+
import * as i15 from "../../core/slots/pane-ref";
|
22
|
+
export class DesignerElementInfoComponent {
|
23
|
+
constructor(_cfr, _ref) {
|
27
24
|
this._cfr = _cfr;
|
28
|
-
this.
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
|
25
|
+
this._ref = _ref;
|
26
|
+
this.svg = FAMILY_SVG;
|
27
|
+
this.model = _ref.model;
|
28
|
+
}
|
29
|
+
ngOnInit() {
|
30
|
+
if (this.model.template) {
|
31
|
+
const factory = this._cfr.resolve(this.model.template);
|
32
|
+
const cRef = this._econtainer.createComponent(factory, 0);
|
33
|
+
cRef.instance.model = this.model;
|
34
|
+
cRef.instance.mode = 'widget';
|
35
|
+
}
|
36
|
+
else if (this.model.arguments?.length) {
|
36
37
|
}
|
37
38
|
}
|
38
|
-
|
39
|
-
|
40
|
-
|
39
|
+
}
|
40
|
+
DesignerElementInfoComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.3", ngImport: i0, type: DesignerElementInfoComponent, deps: [{ token: i1.BizDocComponentFactoryResolver }, { token: DesignerRef }], target: i0.ɵɵFactoryTarget.Component });
|
41
|
+
DesignerElementInfoComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.3", type: DesignerElementInfoComponent, selector: "bizdoc-designer-element-info", viewQueries: [{ propertyName: "_econtainer", first: true, predicate: ["econtainer"], descendants: true, read: ViewContainerRef, static: true }, { propertyName: "_arguments", first: true, predicate: ["arguments"], descendants: true, read: ViewContainerRef, static: true }], ngImport: i0, template: `
|
42
|
+
<div [innerHTML]="(svg[model.family]|sanitizeHtml)||model.family" *ngIf="model.family"></div>
|
43
|
+
<ng-content></ng-content>
|
44
|
+
<ng-container #econtainer></ng-container>
|
45
|
+
`, isInline: true, dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i3.SanitizeHtmlPipe, name: "sanitizeHtml" }] });
|
46
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.3", ngImport: i0, type: DesignerElementInfoComponent, decorators: [{
|
47
|
+
type: Component,
|
48
|
+
args: [{
|
49
|
+
selector: 'bizdoc-designer-element-info', template: `
|
50
|
+
<div [innerHTML]="(svg[model.family]|sanitizeHtml)||model.family" *ngIf="model.family"></div>
|
51
|
+
<ng-content></ng-content>
|
52
|
+
<ng-container #econtainer></ng-container>
|
53
|
+
`
|
54
|
+
}]
|
55
|
+
}], ctorParameters: function () { return [{ type: i1.BizDocComponentFactoryResolver }, { type: i4.DesignerRef, decorators: [{
|
56
|
+
type: Inject,
|
57
|
+
args: [DesignerRef]
|
58
|
+
}] }]; }, propDecorators: { _econtainer: [{
|
59
|
+
type: ViewChild,
|
60
|
+
args: ['econtainer', { static: true, read: ViewContainerRef }]
|
61
|
+
}], _arguments: [{
|
62
|
+
type: ViewChild,
|
63
|
+
args: ['arguments', { static: true, read: ViewContainerRef }]
|
64
|
+
}] } });
|
65
|
+
export class DesignerElementPhaseComponent {
|
66
|
+
constructor(_ref, _fb, _injector, _cfr, _componentFactoryResolver, _service, _element) {
|
67
|
+
this._ref = _ref;
|
68
|
+
this._fb = _fb;
|
69
|
+
this._injector = _injector;
|
70
|
+
this._cfr = _cfr;
|
71
|
+
this._componentFactoryResolver = _componentFactoryResolver;
|
72
|
+
this._service = _service;
|
73
|
+
this._element = _element;
|
74
|
+
this.onSave = new EventEmitter();
|
75
|
+
this._destroy = new Subject();
|
76
|
+
this.model = _ref.model;
|
77
|
+
if (_ref.mode === 'add')
|
78
|
+
this.dirty = true;
|
79
|
+
this.active = this._ref.mode !== 'widget';
|
41
80
|
}
|
42
81
|
ngOnInit() {
|
43
|
-
if (!this.
|
44
|
-
|
45
|
-
const
|
46
|
-
|
47
|
-
|
48
|
-
|
49
|
-
|
50
|
-
|
51
|
-
|
52
|
-
|
53
|
-
|
54
|
-
|
82
|
+
if (!this.active)
|
83
|
+
return;
|
84
|
+
const name = this._fb.control(null, Validators.required), title = this._fb.control(null, Validators.required);
|
85
|
+
this.model.resource && title.disable();
|
86
|
+
!this.model.draft && name.disable();
|
87
|
+
this.model.draft && title.valueChanges.pipe(takeUntil(this._destroy)).subscribe((t) => t && name.setValue(programName(t)));
|
88
|
+
this.form.addControl('name', name);
|
89
|
+
this.form.addControl('title', title);
|
90
|
+
if (this.model.privileges) {
|
91
|
+
this.form.addControl('privileges', this._fb.group({
|
92
|
+
rule: null,
|
93
|
+
roles: this._fb.control(null),
|
94
|
+
}), { emitEvent: false });
|
95
|
+
this._service.roles().subscribe(r => {
|
96
|
+
this.roles = r.concat(this._ref.designer.roles.
|
97
|
+
filter(r => !r.disabled).
|
98
|
+
map(r => ({
|
99
|
+
name: r.name,
|
100
|
+
title: r.title,
|
101
|
+
dataType: r.dataType
|
102
|
+
})));
|
103
|
+
});
|
104
|
+
}
|
55
105
|
if (this.model.template) {
|
56
|
-
|
57
|
-
|
106
|
+
const factory = this._cfr.resolve(this.model.template);
|
107
|
+
const cRef = this._econtainer.createComponent(factory, 0, this._injector);
|
58
108
|
cRef.instance.model = this.model;
|
59
|
-
cRef.instance.mode =
|
60
|
-
elementinstance = cRef.instance;
|
109
|
+
cRef.instance.mode = 'edit';
|
110
|
+
const elementinstance = cRef.instance;
|
111
|
+
elementinstance.form.patchValue(this.model.options);
|
112
|
+
this.form.addControl('options', elementinstance.form, { emitEvent: false });
|
61
113
|
}
|
62
|
-
if (this.
|
63
|
-
|
64
|
-
|
65
|
-
|
66
|
-
|
67
|
-
});
|
68
|
-
this._destroy = new Subject();
|
69
|
-
const { name, title } = this.form.controls;
|
70
|
-
!this.model.draft && name.disable();
|
71
|
-
this.model.draft && title.valueChanges.pipe(takeUntil(this._destroy), debounceTime(100)).subscribe((t) => t && name.setValue(programName(t)));
|
72
|
-
if (this.model.privileges) {
|
73
|
-
this.form.addControl('privileges', this._fb.group({
|
74
|
-
rule: null,
|
75
|
-
roles: this._fb.control(null),
|
76
|
-
}), { emitEvent: false });
|
77
|
-
this._service.roles().subscribe(r => {
|
78
|
-
this.roles = r.concat(this.designer.roles.
|
79
|
-
filter(r => !r.disabled).
|
80
|
-
map(r => ({
|
81
|
-
name: r.name,
|
82
|
-
title: r.title,
|
83
|
-
dataType: r.dataType
|
84
|
-
})));
|
85
|
-
});
|
86
|
-
}
|
87
|
-
if (!elementinstance && this.model.arguments?.length) {
|
88
|
-
const options = this._fb.group({});
|
89
|
-
this.model.arguments?.forEach(a => options.addControl(a.name, this._fb.control(null, a.required ? Validators.required : null)));
|
90
|
-
this.form.addControl('options', options, { emitEvent: false });
|
91
|
-
}
|
92
|
-
this.form.patchValue(this.model);
|
93
|
-
this.form.valueChanges.pipe(takeUntil(this._destroy), debounceTime(100)).
|
94
|
-
subscribe(v => {
|
95
|
-
Object.assign(this.model, v);
|
96
|
-
this.dirty = true;
|
97
|
-
});
|
98
|
-
let state, typestate, elementstate;
|
99
|
-
function validate() {
|
100
|
-
return (!typestate || typestate === 'VALID') && (!state || state === 'VALID') && (!elementstate || elementstate === 'VALID');
|
101
|
-
}
|
102
|
-
this.form.statusChanges.pipe(takeUntil(this._destroy)).subscribe(s => {
|
103
|
-
state = s;
|
104
|
-
this.valid = validate();
|
105
|
-
});
|
106
|
-
typeinstance.form.patchValue(this.model);
|
107
|
-
typeinstance.form.statusChanges.pipe(takeUntil(this._destroy), debounceTime(100)).subscribe(s => {
|
108
|
-
typestate = s;
|
109
|
-
this.valid = validate();
|
110
|
-
});
|
111
|
-
typeinstance.form.valueChanges.pipe(takeUntil(this._destroy), debounceTime(100)).subscribe(v => {
|
112
|
-
Object.assign(this.model, v);
|
113
|
-
this.dirty = true;
|
114
|
-
});
|
115
|
-
if (elementinstance) {
|
116
|
-
elementinstance.form.patchValue(this.model.options);
|
117
|
-
elementinstance.form.valueChanges.pipe(takeUntil(this._destroy), debounceTime(100)).
|
118
|
-
subscribe(v => this.assignargs(v));
|
119
|
-
elementinstance.form.statusChanges.pipe(takeUntil(this._destroy), debounceTime(100)).subscribe(s => {
|
120
|
-
typestate = s;
|
121
|
-
this.valid = validate();
|
122
|
-
});
|
123
|
-
}
|
114
|
+
else if (this.model.arguments?.length) {
|
115
|
+
const factory = this._componentFactoryResolver.resolveComponentFactory(LayoutComponent);
|
116
|
+
const cRef = this._arguments.createComponent(factory);
|
117
|
+
cRef.instance.fields = this.model.arguments;
|
118
|
+
cRef.instance.formulate();
|
119
|
+
this.form.addControl('options', cRef.instance.form, { emitEvent: false });
|
124
120
|
}
|
121
|
+
this.form.patchValue(this.model, { emitEvent: false });
|
122
|
+
this.form.statusChanges.pipe(takeUntil(this._destroy)).subscribe(s => {
|
123
|
+
this.valid = s === 'VALID';
|
124
|
+
this.dirty = true;
|
125
|
+
});
|
126
|
+
this.valid = this.form.valid;
|
125
127
|
}
|
126
|
-
|
127
|
-
this.
|
128
|
+
ngAfterViewInit() {
|
129
|
+
this._element.nativeElement.querySelector('input')?.focus();
|
128
130
|
}
|
129
|
-
|
131
|
+
unlock(evt) {
|
132
|
+
if (evt.srcElement.tagName !== 'A')
|
133
|
+
return;
|
134
|
+
this.model.resource = null;
|
130
135
|
this.form.get('title').enable();
|
136
|
+
this._ref._lock$.next(false);
|
131
137
|
}
|
132
|
-
|
133
|
-
Object.assign(this.model
|
134
|
-
this.
|
138
|
+
save() {
|
139
|
+
Object.assign(this.model, this.form.value);
|
140
|
+
this.onSave.emit(this.model);
|
135
141
|
}
|
136
142
|
/**
|
137
143
|
* Ctrl-s save
|
@@ -145,29 +151,96 @@ export class DesignerItemComponent {
|
|
145
151
|
}
|
146
152
|
ngOnDestroy() {
|
147
153
|
this._destroy?.next();
|
154
|
+
this._destroy?.complete();
|
148
155
|
}
|
149
156
|
}
|
150
|
-
|
151
|
-
|
152
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.3", ngImport: i0, type:
|
157
|
+
DesignerElementPhaseComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.3", ngImport: i0, type: DesignerElementPhaseComponent, deps: [{ token: DesignerRef }, { token: i5.FormBuilder }, { token: i0.Injector }, { token: i1.BizDocComponentFactoryResolver }, { token: i0.ComponentFactoryResolver }, { token: i6.SystemService }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
|
158
|
+
DesignerElementPhaseComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.3", type: DesignerElementPhaseComponent, selector: "bizdoc-designer-element-edit", inputs: { state: "state", form: "form" }, outputs: { onSave: "save" }, host: { listeners: { "document:keydown": "handleKeyboardEvent($event)" } }, viewQueries: [{ propertyName: "_econtainer", first: true, predicate: ["econtainer"], descendants: true, read: ViewContainerRef, static: true }, { propertyName: "_arguments", first: true, predicate: ["arguments"], descendants: true, read: ViewContainerRef, static: true }], ngImport: i0, template: "<mat-toolbar>\r\n <button mat-icon-button (click)=\"save()\" [disabled]=\"!valid || !dirty\"><mat-icon>save</mat-icon></button>\r\n</mat-toolbar>\r\n<p class=\"help\">{{model.help}}</p>\r\n<form autocomplete=\"off\" [formGroup]=\"form\" class=\"column\">\r\n <ng-container *ngIf=\"active\">\r\n\r\n <div class=\"row\">\r\n <mat-form-field class=\"flex\">\r\n <mat-label>{{'Title'|translate}}</mat-label>\r\n <input matInput formControlName=\"title\" required #title />\r\n </mat-form-field>\r\n \r\n <mat-form-field class=\"flex\">\r\n <mat-label>{{'Name'|translate}}</mat-label>\r\n <input matInput formControlName=\"name\" required />\r\n </mat-form-field>\r\n\r\n </div>\r\n <p *ngIf=\"model.resource\" class=\"message\" (click)=\"unlock($event)\" [innerHTML]=\"'Unlock'|translate\"></p>\r\n\r\n <!--<ng-container *ngTemplateOutlet=\"_template\"></ng-container>-->\r\n <ng-content></ng-content>\r\n </ng-container>\r\n\r\n <ng-container #econtainer></ng-container>\r\n\r\n <div #arguments></div>\r\n\r\n <ng-container *ngIf=\"form.controls.privileges\" formGroupName=\"privileges\">\r\n <h2 class=\"mat-title\">{{'Privileges'|translate}}</h2>\r\n <mat-selection-list formControlName=\"roles\" *ngIf=\"roles\">\r\n <mat-list-option *ngFor=\"let r of roles\" [value]=\"r.name\">{{r.title}}</mat-list-option>\r\n </mat-selection-list>\r\n <mat-form-field>\r\n <bizdoc-ace-input [placeholder]=\"'Condition'|translate\" formControlName=\"rule\"></bizdoc-ace-input>\r\n <mat-hint> {{ 'ProgrammableExpression'|translate }}</mat-hint>\r\n </mat-form-field>\r\n </ng-container>\r\n</form>\r\n", dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i5.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: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i5.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i5.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i5.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: i5.FormGroupName, selector: "[formGroupName]", inputs: ["formGroupName"] }, { kind: "component", type: i7.MatSelectionList, selector: "mat-selection-list", inputs: ["disableRipple", "color", "compareWith", "disabled", "multiple"], outputs: ["selectionChange"], exportAs: ["matSelectionList"] }, { kind: "component", type: i7.MatListOption, selector: "mat-list-option", inputs: ["disableRipple", "checkboxPosition", "color", "value", "disabled", "selected"], outputs: ["selectedChange"], exportAs: ["matListOption"] }, { kind: "component", type: i8.MatToolbar, selector: "mat-toolbar", inputs: ["color"], exportAs: ["matToolbar"] }, { kind: "component", type: i9.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i9.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { kind: "directive", type: i9.MatLabel, selector: "mat-label" }, { kind: "component", type: i10.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: "directive", type: i11.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: i12.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i13.AceInput, selector: "bizdoc-ace-input", inputs: ["params", "placeholder", "required", "disabled", "value"] }, { kind: "pipe", type: i14.TranslatePipe, name: "translate" }] });
|
159
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.3", ngImport: i0, type: DesignerElementPhaseComponent, decorators: [{
|
153
160
|
type: Component,
|
154
|
-
args: [{ selector: 'bizdoc-designer-element', template: "<
|
155
|
-
}], ctorParameters: function () { return [{ type:
|
156
|
-
type:
|
157
|
-
|
161
|
+
args: [{ selector: 'bizdoc-designer-element-edit', template: "<mat-toolbar>\r\n <button mat-icon-button (click)=\"save()\" [disabled]=\"!valid || !dirty\"><mat-icon>save</mat-icon></button>\r\n</mat-toolbar>\r\n<p class=\"help\">{{model.help}}</p>\r\n<form autocomplete=\"off\" [formGroup]=\"form\" class=\"column\">\r\n <ng-container *ngIf=\"active\">\r\n\r\n <div class=\"row\">\r\n <mat-form-field class=\"flex\">\r\n <mat-label>{{'Title'|translate}}</mat-label>\r\n <input matInput formControlName=\"title\" required #title />\r\n </mat-form-field>\r\n \r\n <mat-form-field class=\"flex\">\r\n <mat-label>{{'Name'|translate}}</mat-label>\r\n <input matInput formControlName=\"name\" required />\r\n </mat-form-field>\r\n\r\n </div>\r\n <p *ngIf=\"model.resource\" class=\"message\" (click)=\"unlock($event)\" [innerHTML]=\"'Unlock'|translate\"></p>\r\n\r\n <!--<ng-container *ngTemplateOutlet=\"_template\"></ng-container>-->\r\n <ng-content></ng-content>\r\n </ng-container>\r\n\r\n <ng-container #econtainer></ng-container>\r\n\r\n <div #arguments></div>\r\n\r\n <ng-container *ngIf=\"form.controls.privileges\" formGroupName=\"privileges\">\r\n <h2 class=\"mat-title\">{{'Privileges'|translate}}</h2>\r\n <mat-selection-list formControlName=\"roles\" *ngIf=\"roles\">\r\n <mat-list-option *ngFor=\"let r of roles\" [value]=\"r.name\">{{r.title}}</mat-list-option>\r\n </mat-selection-list>\r\n <mat-form-field>\r\n <bizdoc-ace-input [placeholder]=\"'Condition'|translate\" formControlName=\"rule\"></bizdoc-ace-input>\r\n <mat-hint> {{ 'ProgrammableExpression'|translate }}</mat-hint>\r\n </mat-form-field>\r\n </ng-container>\r\n</form>\r\n" }]
|
162
|
+
}], ctorParameters: function () { return [{ type: i4.DesignerRef, decorators: [{
|
163
|
+
type: Inject,
|
164
|
+
args: [DesignerRef]
|
165
|
+
}] }, { type: i5.FormBuilder }, { type: i0.Injector }, { type: i1.BizDocComponentFactoryResolver }, { type: i0.ComponentFactoryResolver }, { type: i6.SystemService }, { type: i0.ElementRef }]; }, propDecorators: { state: [{
|
158
166
|
type: Input
|
159
|
-
}],
|
167
|
+
}], form: [{
|
160
168
|
type: Input
|
161
|
-
}],
|
162
|
-
type:
|
163
|
-
|
164
|
-
type: ViewChild,
|
165
|
-
args: ['container', { static: true, read: ViewContainerRef }]
|
169
|
+
}], onSave: [{
|
170
|
+
type: Output,
|
171
|
+
args: ['save']
|
166
172
|
}], _econtainer: [{
|
167
173
|
type: ViewChild,
|
168
174
|
args: ['econtainer', { static: true, read: ViewContainerRef }]
|
175
|
+
}], _arguments: [{
|
176
|
+
type: ViewChild,
|
177
|
+
args: ['arguments', { static: true, read: ViewContainerRef }]
|
169
178
|
}], handleKeyboardEvent: [{
|
170
179
|
type: HostListener,
|
171
180
|
args: ['document:keydown', ['$event']]
|
172
181
|
}] } });
|
173
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"designer-element.component.js","sourceRoot":"","sources":["../../../../../../libraries/core/src/lib/admin/configuration-designer/designer-element.component.ts","../../../../../../libraries/core/src/lib/admin/configuration-designer/designer-element.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, EventEmitter, HostListener, Injector, Input, OnDestroy, OnInit, Optional, Output, ViewChild, ViewContainerRef } from \"@angular/core\";\r\nimport { FormBuilder, FormControlStatus, FormGroup, Validators } from \"@angular/forms\";\r\nimport { MatSelectionList } from \"@angular/material/list\";\r\nimport { debounceTime, Subject, takeUntil } from \"rxjs\";\r\nimport { BizDocComponentFactoryResolver } from \"../../core/component-factory-resolver\";\r\nimport { PaneRef } from \"../../core/slots/pane-ref\";\r\nimport { SystemService } from \"../system.service\";\r\nimport { DesignerRef, ElementModel, DesignerElementComponentBase, DesignerModel, DesignerTypeElementComponent, programName, DesignMode } from \"./designer.base\";\r\n\r\nexport interface ElemetData {\r\n  mode: DesignMode;\r\n  template: string;\r\n  model: ElementModel;\r\n  designer: DesignerModel;\r\n}\r\n/**/\r\n@Component({\r\n  selector: 'bizdoc-designer-element',\r\n  styleUrls: ['designer-element.component.scss'],\r\n  templateUrl: 'designer-element.component.html'\r\n})\r\nexport\r\n  class DesignerItemComponent implements OnInit, OnDestroy {\r\n  form: FormGroup;\r\n  mode: DesignMode;\r\n  @Input() template!: string;\r\n  @Input() model!: ElementModel;\r\n  @Input() designer!: DesignerModel;\r\n  change: EventEmitter<ElementModel>;\r\n  @ViewChild('container', { static: true, read: ViewContainerRef }) _container: ViewContainerRef;\r\n  @ViewChild('econtainer', { static: true, read: ViewContainerRef }) _econtainer: ViewContainerRef;\r\n  valid: boolean;\r\n  dirty: boolean;\r\n  roles: ElementModel[];\r\n  private _destroy: Subject<void>;\r\n  constructor(\r\n    private _injector: Injector,\r\n    @Optional() private _pane: PaneRef,\r\n    private _fb: FormBuilder,\r\n    private _service: SystemService,\r\n    private _cfr: BizDocComponentFactoryResolver,\r\n    private _cd: ChangeDetectorRef,\r\n  ) {\r\n    if (_pane && _pane.dialog) {\r\n      const { designer, mode, model, template } = _pane.data as ElemetData;\r\n      Object.assign(this, {\r\n        designer, mode,\r\n        model: JSON.parse(JSON.stringify(model)),\r\n        template\r\n      });\r\n    }\r\n  }\r\n  save() {\r\n    this.change.emit(this.model);\r\n    this._pane.close();\r\n  }\r\n  ngOnInit(): void {\r\n    if (!this.model.options) this.model.options = {};\r\n\r\n    const injector = Injector.create([{\r\n      provide: DesignerRef, useValue: new DesignerRef(this.designer, this.model)\r\n    }], this._injector);\r\n\r\n    let typeinstance;\r\n\r\n    let factory = this._cfr.resolve(this.template);\r\n\r\n    let cRef = this._container.createComponent<DesignerTypeElementComponent>(factory, 0, injector);\r\n    cRef.instance.model = this.model;\r\n    cRef.instance.mode = this.mode;\r\n    typeinstance = cRef.instance;\r\n\r\n    let elementinstance;\r\n\r\n    if (this.model.template) {\r\n      let factory = this._cfr.resolve(this.model.template);\r\n\r\n      let cRef = this._econtainer.createComponent<DesignerElementComponentBase>(factory, 0, injector);\r\n      cRef.instance.model = this.model;\r\n      cRef.instance.mode = this.mode;\r\n      elementinstance = cRef.instance;\r\n    }\r\n\r\n    if (this.mode === 'edit') {\r\n      this.change = new EventEmitter<ElementModel>();\r\n      this.form = this._fb.group({\r\n        name: this._fb.control(null, Validators.required),\r\n        title: this._fb.control({ disabled: this.model.resource }, Validators.required),\r\n      });\r\n      this._destroy = new Subject<void>();\r\n      const { name, title } = this.form.controls;\r\n      !this.model.draft && name.disable();\r\n      this.model.draft && title.valueChanges.pipe(takeUntil(this._destroy), debounceTime(100)).subscribe((t: string) =>\r\n        t && name.setValue(programName(t))\r\n      );\r\n      if (this.model.privileges) {\r\n        this.form.addControl('privileges',\r\n          this._fb.group({\r\n            rule: null,\r\n            roles: this._fb.control<string[]>(null),\r\n          }), { emitEvent: false });\r\n        this._service.roles().subscribe(r => {\r\n          this.roles = r.concat(this.designer.roles.\r\n            filter(r => !r.disabled).\r\n            map(r => ({\r\n              name: r.name,\r\n              title: r.title,\r\n              dataType: r.dataType\r\n            })));\r\n        });\r\n      }\r\n      if (!elementinstance && this.model.arguments?.length) {\r\n        const options = this._fb.group({});\r\n        this.model.arguments?.forEach(a =>\r\n          options.addControl(a.name, this._fb.control(null, a.required ? Validators.required : null)));\r\n        this.form.addControl('options', options, { emitEvent: false });\r\n      }\r\n      this.form.patchValue(this.model);\r\n      this.form.valueChanges.pipe(takeUntil(this._destroy), debounceTime(100)).\r\n        subscribe(v => {\r\n          Object.assign(this.model, v);\r\n          this.dirty = true;\r\n        });\r\n      let state: FormControlStatus, typestate: FormControlStatus, elementstate: FormControlStatus;\r\n      function validate() {\r\n        return (!typestate || typestate === 'VALID') && (!state || state === 'VALID') && (!elementstate || elementstate === 'VALID');\r\n      }\r\n      this.form.statusChanges.pipe(takeUntil(this._destroy)).subscribe(s => {\r\n        state = s;\r\n        this.valid = validate();\r\n      });\r\n      typeinstance.form.patchValue(this.model);\r\n      typeinstance.form.statusChanges.pipe(takeUntil(this._destroy), debounceTime(100)).subscribe(s => {\r\n        typestate = s;\r\n        this.valid = validate();\r\n      });\r\n      typeinstance.form.valueChanges.pipe(takeUntil(this._destroy), debounceTime(100)).subscribe(v => {\r\n        Object.assign(this.model, v);\r\n        this.dirty = true;\r\n      });\r\n      if (elementinstance) {\r\n        elementinstance.form.patchValue(this.model.options);\r\n        elementinstance.form.valueChanges.pipe(takeUntil(this._destroy), debounceTime(100)).\r\n          subscribe(v => this.assignargs(v));\r\n        elementinstance.form.statusChanges.pipe(takeUntil(this._destroy), debounceTime(100)).subscribe(s => {\r\n          typestate = s;\r\n          this.valid = validate();\r\n        });\r\n      }\r\n    }\r\n  }\r\n  setOptions(obj: any) {\r\n    this.form.get('options').patchValue(obj);\r\n  }\r\n  overrideResource() {\r\n    this.form.get('title').enable();\r\n  }\r\n  assignargs(evt) {\r\n    Object.assign(this.model.options, evt);\r\n    this.dirty = true;\r\n  }\r\n  /**\r\n   * Ctrl-s save\r\n   * @param event\r\n   */\r\n  @HostListener('document:keydown', ['$event'])\r\n  handleKeyboardEvent(event: KeyboardEvent) {\r\n    if (event.ctrlKey && (event.which === 83 || event.which === 115)) {\r\n      this.valid && this.save();\r\n      event.preventDefault();\r\n    }\r\n  }\r\n  ngOnDestroy(): void {\r\n    this._destroy?.next();\r\n  }\r\n}\r\n","<ng-container *ngIf=\"mode === 'edit'; else info\">\r\n  <mat-toolbar>\r\n    <button mat-icon-button (click)=\"save()\" [disabled]=\"!valid\"><mat-icon>save</mat-icon></button>\r\n  </mat-toolbar>\r\n  <span class=\"help\">{{model.help}}</span>\r\n  <form autocomplete=\"off\" [formGroup]=\"form\" class=\"row\">\r\n    <mat-form-field class=\"flex\">\r\n      <mat-label>{{'Title'|translate}}</mat-label>\r\n      <input matInput formControlName=\"title\" required />\r\n    </mat-form-field>\r\n    &nbsp;\r\n    <mat-form-field class=\"flex\">\r\n      <mat-label>{{'Name'|translate}}</mat-label>\r\n      <input matInput formControlName=\"name\" required />\r\n    </mat-form-field>\r\n  </form>\r\n</ng-container>\r\n\r\n<ng-template #info>\r\n  <span class=\"family\">{{model.family}}</span>\r\n</ng-template>\r\n\r\n<ng-container #econtainer></ng-container>\r\n<ng-container #container></ng-container>\r\n\r\n\r\n<form autocomplete=\"off\" [formGroup]=\"form\" class=\"column\" *ngIf=\"mode === 'edit'\">\r\n  <ng-container *ngIf=\"model.arguments?.length\">\r\n    <bizdoc-layout [fields]=\"model.arguments\" [model]=\"model.options\"\r\n                   (modelChange)=\"setOptions($event)\"></bizdoc-layout>\r\n  </ng-container>\r\n  <h2 class=\"mat-title\">{{'Privileges'|translate}}</h2>\r\n  <ng-container *ngIf=\"model.privileges\" formGroupName=\"privileges\">\r\n    <mat-selection-list formControlName=\"roles\" *ngIf=\"roles\">\r\n      <mat-list-option *ngFor=\"let r of roles\" [value]=\"r.name\">{{r.title}}</mat-list-option>\r\n    </mat-selection-list>\r\n    <mat-form-field>\r\n      <bizdoc-ace-input [placeholder]=\"'Condition'|translate\" formControlName=\"rule\"></bizdoc-ace-input>\r\n      <mat-hint> {{ 'ProgrammableExpression'|translate }}</mat-hint>\r\n    </mat-form-field>\r\n  </ng-container>\r\n</form>\r\n"]}
|
182
|
+
/**
|
183
|
+
```html
|
184
|
+
<bizdoc-designer-element (save)="save.emit($event)">
|
185
|
+
<bizdoc-designer-element-info>
|
186
|
+
</bizdoc-designer-element-info>
|
187
|
+
<bizdoc-designer-element-edit [form]="form">
|
188
|
+
<form autocomplete="off" [formGroup]="form">
|
189
|
+
</form>
|
190
|
+
</bizdoc-designer-element-edit>
|
191
|
+
</bizdoc-designer-element>
|
192
|
+
```
|
193
|
+
*/
|
194
|
+
export class DesignerItemComponent {
|
195
|
+
constructor(ref, _pane) {
|
196
|
+
this._pane = _pane;
|
197
|
+
this.save = new EventEmitter();
|
198
|
+
this.mode = ref.mode;
|
199
|
+
this.model = ref.model;
|
200
|
+
}
|
201
|
+
ngOnChanges() {
|
202
|
+
//if (this.state) this.phase = this.phases?.find(p => p.state === this.state);
|
203
|
+
//else this.phase = this.phases?.first;
|
204
|
+
}
|
205
|
+
ngAfterContentInit() {
|
206
|
+
this.mode !== 'widget' &&
|
207
|
+
this.phases?.forEach(p => p.onSave.subscribe(e => {
|
208
|
+
this.save.emit(e);
|
209
|
+
this._pane.close();
|
210
|
+
}));
|
211
|
+
}
|
212
|
+
}
|
213
|
+
DesignerItemComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.3", ngImport: i0, type: DesignerItemComponent, deps: [{ token: DesignerRef }, { token: i15.PaneRef, optional: true }], target: i0.ɵɵFactoryTarget.Component });
|
214
|
+
DesignerItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.3", type: DesignerItemComponent, selector: "bizdoc-designer-element", inputs: { state: "state" }, outputs: { save: "save" }, queries: [{ propertyName: "info", first: true, predicate: DesignerElementInfoComponent, descendants: true }, { propertyName: "phases", predicate: DesignerElementPhaseComponent }], usesOnChanges: true, ngImport: i0, template: `<ng-container *ngIf="mode === 'widget'; else edit">
|
215
|
+
<ng-content select="bizdoc-designer-element-info"></ng-content>
|
216
|
+
</ng-container>
|
217
|
+
<ng-template #edit>
|
218
|
+
<ng-content select="bizdoc-designer-element-edit"></ng-content>
|
219
|
+
</ng-template>
|
220
|
+
`, isInline: true, styles: [":host{flex:1}::ng-deep form{padding:8px}::ng-deep .flex{flex:1}p.message{margin:5px}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
|
221
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.3", ngImport: i0, type: DesignerItemComponent, decorators: [{
|
222
|
+
type: Component,
|
223
|
+
args: [{ selector: 'bizdoc-designer-element', template: `<ng-container *ngIf="mode === 'widget'; else edit">
|
224
|
+
<ng-content select="bizdoc-designer-element-info"></ng-content>
|
225
|
+
</ng-container>
|
226
|
+
<ng-template #edit>
|
227
|
+
<ng-content select="bizdoc-designer-element-edit"></ng-content>
|
228
|
+
</ng-template>
|
229
|
+
`, styles: [":host{flex:1}::ng-deep form{padding:8px}::ng-deep .flex{flex:1}p.message{margin:5px}\n"] }]
|
230
|
+
}], ctorParameters: function () { return [{ type: i4.DesignerRef, decorators: [{
|
231
|
+
type: Inject,
|
232
|
+
args: [DesignerRef]
|
233
|
+
}] }, { type: i15.PaneRef, decorators: [{
|
234
|
+
type: Optional
|
235
|
+
}] }]; }, propDecorators: { info: [{
|
236
|
+
type: ContentChild,
|
237
|
+
args: [DesignerElementInfoComponent]
|
238
|
+
}], phases: [{
|
239
|
+
type: ContentChildren,
|
240
|
+
args: [DesignerElementPhaseComponent]
|
241
|
+
}], state: [{
|
242
|
+
type: Input
|
243
|
+
}], save: [{
|
244
|
+
type: Output
|
245
|
+
}] } });
|
246
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"designer-element.component.js","sourceRoot":"","sources":["../../../../../../libraries/core/src/lib/admin/configuration-designer/designer-element.component.ts","../../../../../../libraries/core/src/lib/admin/configuration-designer/designer-element.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, ComponentFactoryResolver, ContentChild, ContentChildren, ElementRef, EventEmitter, HostListener, Inject, Injector, Input, OnDestroy, OnInit, Optional, Output, QueryList, TemplateRef, ViewChild, ViewChildren, ViewContainerRef } from \"@angular/core\";\r\nimport { FormBuilder, FormGroup, Validators } from \"@angular/forms\";\r\nimport { Subject, takeUntil } from \"rxjs\";\r\nimport { BizDocComponentFactoryResolver } from \"../../core/component-factory-resolver\";\r\nimport { LayoutComponent } from \"../../core/layout/layout.component\";\r\nimport { Role } from \"../../core/models\";\r\nimport { PaneRef } from \"../../core/slots/pane-ref\";\r\nimport { SystemService } from \"../system.service\";\r\nimport { DesignerRef, ElementModel, DesignerModel, programName, DesignMode, FAMILY_SVG, DesignerElementComponent } from \"./designer.base\";\r\n\r\n@Component({\r\n  selector: 'bizdoc-designer-element-info', template: `\r\n  <div [innerHTML]=\"(svg[model.family]|sanitizeHtml)||model.family\" *ngIf=\"model.family\"></div>\r\n<ng-content></ng-content>\r\n<ng-container #econtainer></ng-container>\r\n` })\r\nexport class DesignerElementInfoComponent {\r\n  svg = FAMILY_SVG;\r\n  model: ElementModel<any>;\r\n  @ViewChild('econtainer', { static: true, read: ViewContainerRef }) _econtainer: ViewContainerRef;\r\n  @ViewChild('arguments', { static: true, read: ViewContainerRef }) _arguments: ViewContainerRef;\r\n  constructor(\r\n    private _cfr: BizDocComponentFactoryResolver,\r\n    @Inject(DesignerRef) private _ref: DesignerRef<any>,\r\n  ) {\r\n    this.model = _ref.model as ElementModel;\r\n  }\r\n  ngOnInit() {\r\n    if (this.model.template) {\r\n      const factory = this._cfr.resolve(this.model.template);\r\n\r\n      const cRef = this._econtainer.createComponent<DesignerElementComponent<any>>(factory, 0);\r\n      cRef.instance.model = this.model;\r\n      cRef.instance.mode = 'widget';\r\n    }\r\n    else if (this.model.arguments?.length) {\r\n    }\r\n  }\r\n\r\n}\r\n@Component({\r\n  selector: 'bizdoc-designer-element-edit',\r\n  templateUrl: 'designer-element.component.html'\r\n})\r\nexport class DesignerElementPhaseComponent implements AfterViewInit, OnDestroy {\r\n  @Input() state: string;\r\n  @Input() form!: FormGroup;\r\n  @Output('save') readonly onSave = new EventEmitter();\r\n  //@ViewChild('[bizdocContent]', { static: true, read: TemplateRef }) _template: TemplateRef<any>;\r\n  @ViewChild('econtainer', { static: true, read: ViewContainerRef }) _econtainer: ViewContainerRef;\r\n  @ViewChild('arguments', { static: true, read: ViewContainerRef }) _arguments: ViewContainerRef;\r\n  model: ElementModel<any>;\r\n  roles: Role[];\r\n  valid: boolean;\r\n  dirty: boolean;\r\n  private readonly _destroy = new Subject<void>();\r\n  active: boolean;\r\n  constructor(\r\n    @Inject(DesignerRef) private _ref: DesignerRef<any>,\r\n    private _fb: FormBuilder,\r\n    private _injector: Injector,\r\n    private _cfr: BizDocComponentFactoryResolver,\r\n    private _componentFactoryResolver: ComponentFactoryResolver,\r\n    private _service: SystemService,\r\n    private _element: ElementRef<HTMLDivElement>) {\r\n    this.model = _ref.model as ElementModel;\r\n    if (_ref.mode === 'add') this.dirty = true;\r\n    this.active = this._ref.mode !== 'widget';\r\n  }\r\n  ngOnInit() {\r\n    if (!this.active) return;\r\n    const name = this._fb.control(null, Validators.required),\r\n      title = this._fb.control(null, Validators.required);\r\n    this.model.resource && title.disable();\r\n    !this.model.draft && name.disable();\r\n    this.model.draft && title.valueChanges.pipe(takeUntil(this._destroy)).subscribe((t: string) =>\r\n      t && name.setValue(programName(t))\r\n    );\r\n    this.form.addControl('name', name);\r\n    this.form.addControl('title', title);\r\n    if (this.model.privileges) {\r\n      this.form.addControl('privileges',\r\n        this._fb.group({\r\n          rule: null,\r\n          roles: this._fb.control<string[]>(null),\r\n        }), { emitEvent: false });\r\n      this._service.roles().subscribe(r => {\r\n        this.roles = r.concat((this._ref.designer.roles as ElementModel[]).\r\n          filter(r => !r.disabled).\r\n          map(r => ({\r\n            name: r.name,\r\n            title: r.title,\r\n            dataType: r.dataType\r\n          })));\r\n      });\r\n    }\r\n    if (this.model.template) {\r\n      const factory = this._cfr.resolve(this.model.template);\r\n\r\n      const cRef = this._econtainer.createComponent<DesignerElementComponent<any>>(factory, 0, this._injector);\r\n      cRef.instance.model = this.model;\r\n      cRef.instance.mode = 'edit';\r\n      const elementinstance = cRef.instance;\r\n      elementinstance.form.patchValue(this.model.options);\r\n      this.form.addControl('options', elementinstance.form, { emitEvent: false });\r\n    }\r\n    else if (this.model.arguments?.length) {\r\n      const factory = this._componentFactoryResolver.resolveComponentFactory(LayoutComponent);\r\n      const cRef = this._arguments.createComponent(factory);\r\n      cRef.instance.fields = this.model.arguments;\r\n      cRef.instance.formulate();\r\n      this.form.addControl('options', cRef.instance.form, { emitEvent: false });\r\n    }\r\n\r\n    this.form.patchValue(this.model, { emitEvent: false });\r\n    this.form.statusChanges.pipe(takeUntil(this._destroy)).subscribe(s => {\r\n      this.valid = s === 'VALID';\r\n      this.dirty = true;\r\n    });\r\n    this.valid = this.form.valid;\r\n  }\r\n  ngAfterViewInit(): void {\r\n    this._element.nativeElement.querySelector('input')?.focus();\r\n  }\r\n  unlock(evt: Event) {\r\n    if ((evt.srcElement as HTMLElement).tagName !== 'A') return;\r\n    this.model.resource = null;\r\n    this.form.get('title').enable();\r\n    this._ref._lock$.next(false);\r\n  }\r\n  save() {\r\n    Object.assign(this.model, this.form.value);\r\n    this.onSave.emit(this.model);\r\n  }\r\n  /**\r\n   * Ctrl-s save\r\n   * @param event\r\n   */\r\n  @HostListener('document:keydown', ['$event'])\r\n  handleKeyboardEvent(event: KeyboardEvent) {\r\n    if (event.ctrlKey && (event.which === 83 || event.which === 115)) {\r\n      this.valid && this.save();\r\n      event.preventDefault();\r\n    }\r\n  }\r\n  ngOnDestroy(): void {\r\n    this._destroy?.next();\r\n    this._destroy?.complete();\r\n  }\r\n}\r\n\r\n/**\r\n ```html\r\n<bizdoc-designer-element (save)=\"save.emit($event)\">\r\n  <bizdoc-designer-element-info>\r\n  </bizdoc-designer-element-info>\r\n  <bizdoc-designer-element-edit [form]=\"form\">\r\n    <form autocomplete=\"off\" [formGroup]=\"form\">\r\n    </form>\r\n  </bizdoc-designer-element-edit>\r\n</bizdoc-designer-element>\r\n ```\r\n*/\r\n@Component({\r\n  selector: 'bizdoc-designer-element',\r\n  styleUrls: ['designer-element.component.scss'],\r\n  template:\r\n    `<ng-container *ngIf=\"mode === 'widget'; else edit\">\r\n  <ng-content select=\"bizdoc-designer-element-info\"></ng-content>\r\n</ng-container>\r\n<ng-template #edit>\r\n  <ng-content select=\"bizdoc-designer-element-edit\"></ng-content>\r\n</ng-template>\r\n`\r\n})\r\nexport\r\n  class DesignerItemComponent {\r\n  @ContentChild(DesignerElementInfoComponent) info: DesignerElementInfoComponent;\r\n  @ContentChildren(DesignerElementPhaseComponent) phases: QueryList<DesignerElementPhaseComponent>;\r\n  @Input() state: string;\r\n  @Output() readonly save = new EventEmitter();\r\n  mode: DesignMode;\r\n  valid: boolean;\r\n  dirty: boolean;\r\n  model: ElementModel<any>;\r\n  phase: DesignerElementPhaseComponent;\r\n  constructor(\r\n    @Inject(DesignerRef) ref: DesignerRef<any>,\r\n    @Optional() private _pane: PaneRef,\r\n  ) {\r\n    this.mode = ref.mode;\r\n    this.model = ref.model as ElementModel;\r\n  }\r\n  ngOnChanges() {\r\n    //if (this.state) this.phase = this.phases?.find(p => p.state === this.state);\r\n    //else this.phase = this.phases?.first;\r\n  }\r\n  ngAfterContentInit() {\r\n    this.mode !== 'widget' &&\r\n      this.phases?.forEach(p => p.onSave.subscribe(e => {\r\n        this.save.emit(e);\r\n        this._pane.close();\r\n      }))\r\n  }\r\n}\r\n","<mat-toolbar>\r\n  <button mat-icon-button (click)=\"save()\" [disabled]=\"!valid || !dirty\"><mat-icon>save</mat-icon></button>\r\n</mat-toolbar>\r\n<p class=\"help\">{{model.help}}</p>\r\n<form autocomplete=\"off\" [formGroup]=\"form\" class=\"column\">\r\n  <ng-container *ngIf=\"active\">\r\n\r\n    <div class=\"row\">\r\n      <mat-form-field class=\"flex\">\r\n        <mat-label>{{'Title'|translate}}</mat-label>\r\n        <input matInput formControlName=\"title\" required #title />\r\n      </mat-form-field>\r\n      &nbsp;\r\n      <mat-form-field class=\"flex\">\r\n        <mat-label>{{'Name'|translate}}</mat-label>\r\n        <input matInput formControlName=\"name\" required />\r\n      </mat-form-field>\r\n\r\n    </div>\r\n    <p *ngIf=\"model.resource\" class=\"message\" (click)=\"unlock($event)\" [innerHTML]=\"'Unlock'|translate\"></p>\r\n\r\n    <!--<ng-container *ngTemplateOutlet=\"_template\"></ng-container>-->\r\n    <ng-content></ng-content>\r\n  </ng-container>\r\n\r\n  <ng-container #econtainer></ng-container>\r\n\r\n  <div #arguments></div>\r\n\r\n  <ng-container *ngIf=\"form.controls.privileges\" formGroupName=\"privileges\">\r\n    <h2 class=\"mat-title\">{{'Privileges'|translate}}</h2>\r\n    <mat-selection-list formControlName=\"roles\" *ngIf=\"roles\">\r\n      <mat-list-option *ngFor=\"let r of roles\" [value]=\"r.name\">{{r.title}}</mat-list-option>\r\n    </mat-selection-list>\r\n    <mat-form-field>\r\n      <bizdoc-ace-input [placeholder]=\"'Condition'|translate\" formControlName=\"rule\"></bizdoc-ace-input>\r\n      <mat-hint> {{ 'ProgrammableExpression'|translate }}</mat-hint>\r\n    </mat-form-field>\r\n  </ng-container>\r\n</form>\r\n"]}
|