@bizdoc/core 1.14.13 → 1.14.16
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 +146 -125
- package/esm2020/lib/admin/admin-dismiss.service.mjs +15 -9
- package/esm2020/lib/admin/core/color-picker.input.mjs +3 -3
- package/esm2020/lib/admin/form/workflow/node.component.mjs +63 -31
- package/esm2020/lib/admin/form/workflow/workflow.component.mjs +314 -166
- package/esm2020/lib/admin/positions/positions.component.mjs +6 -5
- package/esm2020/lib/admin/profiler/profiler.component.mjs +2 -2
- package/esm2020/lib/compose/dismiss.service.mjs +2 -2
- package/esm2020/lib/core/save-changes.dialog.mjs +18 -0
- package/esm2020/lib/core/slots/router.service.mjs +1 -1
- package/esm2020/lib/core/translations.mjs +2 -2
- package/esm2020/lib/shared.module.mjs +2 -2
- package/esm2020/public-api.mjs +2 -2
- package/fesm2015/bizdoc-core.mjs +432 -247
- package/fesm2015/bizdoc-core.mjs.map +1 -1
- package/fesm2020/bizdoc-core.mjs +429 -243
- package/fesm2020/bizdoc-core.mjs.map +1 -1
- package/lib/admin/admin-dismiss.service.d.ts +3 -3
- package/lib/admin/core/color-picker.input.d.ts +1 -1
- package/lib/admin/form/workflow/node.component.d.ts +8 -7
- package/lib/admin/form/workflow/workflow.component.d.ts +13 -12
- package/lib/admin/positions/positions.component.d.ts +1 -0
- package/lib/{compose → core}/save-changes.dialog.d.ts +0 -0
- package/lib/core/slots/router.service.d.ts +1 -1
- package/lib/shared.module.d.ts +1 -1
- package/package.json +1 -1
- package/public-api.d.ts +1 -1
- package/esm2020/lib/compose/save-changes.dialog.mjs +0 -18
@@ -1,8 +1,6 @@
|
|
1
|
-
import { Output, ViewChild, ViewContainerRef } from '@angular/core';
|
2
|
-
import { Component, Injector } from '@angular/core';
|
1
|
+
import { EventEmitter, Output, ViewChild, ViewContainerRef, Component, Injector } from '@angular/core';
|
3
2
|
import { Subject, takeUntil } from 'rxjs';
|
4
3
|
import { NodeRef } from './node-ref';
|
5
|
-
import { EventEmitter } from '@angular/core';
|
6
4
|
import { LayoutComponent } from '../../../core/layout/layout.component';
|
7
5
|
import { cleanup } from '../../../core/functions';
|
8
6
|
import * as i0 from "@angular/core";
|
@@ -15,8 +13,8 @@ import * as i6 from "@angular/material/form-field";
|
|
15
13
|
import * as i7 from "@angular/material/select";
|
16
14
|
import * as i8 from "@angular/material/core";
|
17
15
|
import * as i9 from "@angular/material/button-toggle";
|
18
|
-
import * as i10 from "@angular/
|
19
|
-
import * as i11 from "@angular/
|
16
|
+
import * as i10 from "@angular/flex-layout/flex";
|
17
|
+
import * as i11 from "@angular/common";
|
20
18
|
import * as i12 from "@angular/material/input";
|
21
19
|
import * as i13 from "../../../core/pipes/translate.pipe";
|
22
20
|
export class WorkflowNodeComponent {
|
@@ -29,9 +27,9 @@ export class WorkflowNodeComponent {
|
|
29
27
|
this._fb = _fb;
|
30
28
|
this._pane = _pane;
|
31
29
|
this.change = new EventEmitter();
|
32
|
-
this.
|
33
|
-
action:
|
34
|
-
case:
|
30
|
+
this.connector = this._fb.group({
|
31
|
+
action: null,
|
32
|
+
case: null
|
35
33
|
});
|
36
34
|
this._elementDestroy = new Subject();
|
37
35
|
this.actions = _session.profile.actions;
|
@@ -39,29 +37,47 @@ export class WorkflowNodeComponent {
|
|
39
37
|
ngOnInit() {
|
40
38
|
this._pane.dataChange.subscribe(d => {
|
41
39
|
this.nodes = d['nodes'];
|
40
|
+
this.diagram = d['diagram'];
|
42
41
|
this.connectors = d['connectors'];
|
43
42
|
this.tool = null;
|
44
43
|
this._elementDestroy.next();
|
44
|
+
this.argumentstemplate.clear();
|
45
45
|
if (this.connectors.length) {
|
46
|
-
this.connectorInfo.valueChanges.pipe(takeUntil(this._elementDestroy)).subscribe(() => {
|
47
|
-
this.connectors.forEach(c => {
|
48
|
-
Object.assign(c.addInfo, this.connectorInfo.getRawValue());
|
49
|
-
this.change.emit();
|
50
|
-
});
|
51
|
-
});
|
52
46
|
const connector = this.connectors[0];
|
53
|
-
|
54
|
-
|
55
|
-
|
56
|
-
|
57
|
-
|
58
|
-
|
59
|
-
}
|
47
|
+
if (connector.addInfo) {
|
48
|
+
const action = connector.addInfo['action'], acase = connector.addInfo['case'];
|
49
|
+
this.connector.patchValue({
|
50
|
+
action: this.connectors.length === 1 || this.connectors.every(c => c.addInfo && c.addInfo['action'] === action) ? action : null,
|
51
|
+
case: this.connectors.length === 1 || this.connectors.every(c => c.addInfo && c.addInfo['case'] === acase) ? acase : null
|
52
|
+
});
|
53
|
+
}
|
60
54
|
this._pane.title = this._translate.get(this.connectors.length === 1 ? 'Connector' : 'Connectors', this.connectors.length);
|
61
55
|
this._pane.icon = 'link';
|
56
|
+
this.connector.valueChanges.pipe(takeUntil(this._elementDestroy)).subscribe(v => {
|
57
|
+
const content = v['case'] || v['action'];
|
58
|
+
if (!connector.addInfo)
|
59
|
+
connector.addInfo = this.connector.getRawValue();
|
60
|
+
else
|
61
|
+
Object.assign(connector.addInfo, this.connector.getRawValue());
|
62
|
+
cleanup(connector.addInfo);
|
63
|
+
if (connector.annotations.length) {
|
64
|
+
connector.annotations[0].content = content;
|
65
|
+
this.diagram.dataBind();
|
66
|
+
}
|
67
|
+
else
|
68
|
+
this.diagram.addConnectorLabels(connector, [{
|
69
|
+
style: {
|
70
|
+
color: this._session.theme.dark ? 'white' : 'black',
|
71
|
+
fill: 'transparent',
|
72
|
+
opacity: .8,
|
73
|
+
},
|
74
|
+
content
|
75
|
+
}]);
|
76
|
+
this.change.emit();
|
77
|
+
});
|
78
|
+
this.argumentstemplate.createEmbeddedView(this.connectorargs);
|
62
79
|
}
|
63
|
-
|
64
|
-
if (this.nodes.length) {
|
80
|
+
else {
|
65
81
|
const node = this.node = this.nodes[0], addInfo = node.addInfo;
|
66
82
|
if (addInfo && addInfo.nodeType) {
|
67
83
|
const nodeType = addInfo.nodeType;
|
@@ -69,10 +85,23 @@ export class WorkflowNodeComponent {
|
|
69
85
|
this._pane.title = tool.title;
|
70
86
|
const annotationArg = tool.arguments.find(a => a.diagram);
|
71
87
|
function change(m) {
|
72
|
-
if (annotationArg && m[annotationArg.name] !== null
|
73
|
-
node.annotations
|
88
|
+
if (annotationArg && m[annotationArg.name] !== null) {
|
89
|
+
if (node.annotations.length) {
|
90
|
+
node.annotations[0].content = m[annotationArg.name] || null;
|
91
|
+
this.diagram.dataBind();
|
92
|
+
}
|
93
|
+
else
|
94
|
+
this.diagram.addNodeLabels(node, [{
|
95
|
+
style: {
|
96
|
+
color: this._session.theme.dark ? 'white' : 'black',
|
97
|
+
fill: 'transparent',
|
98
|
+
opacity: .8,
|
99
|
+
},
|
100
|
+
content: m[annotationArg.name] || null
|
101
|
+
}]);
|
74
102
|
}
|
75
|
-
Object.assign(addInfo,
|
103
|
+
Object.assign(addInfo, m);
|
104
|
+
cleanup(addInfo);
|
76
105
|
this.change.emit();
|
77
106
|
}
|
78
107
|
if (tool.template) {
|
@@ -105,8 +134,8 @@ export class WorkflowNodeComponent {
|
|
105
134
|
instance.form.patchValue(node.addInfo, { emitEvent: false });
|
106
135
|
return instance;
|
107
136
|
}
|
108
|
-
connectorCaseChange(
|
109
|
-
this.
|
137
|
+
connectorCaseChange(evt) {
|
138
|
+
this.connector.controls['case'].setValue(evt.value);
|
110
139
|
this.change.emit();
|
111
140
|
}
|
112
141
|
ngOnDestroy() {
|
@@ -115,14 +144,17 @@ export class WorkflowNodeComponent {
|
|
115
144
|
}
|
116
145
|
}
|
117
146
|
WorkflowNodeComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.9", ngImport: i0, type: WorkflowNodeComponent, deps: [{ token: i1.SessionService }, { token: i2.BizDocComponentFactoryResolver }, { token: i0.ComponentFactoryResolver }, { token: i0.Injector }, { token: i3.TranslateService }, { token: i4.FormBuilder }, { token: i5.PaneRef }], target: i0.ɵɵFactoryTarget.Component });
|
118
|
-
WorkflowNodeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.9", type: WorkflowNodeComponent, selector: "ng-component", outputs: { change: "change" }, viewQueries: [{ propertyName: "argumentstemplate", first: true, predicate: ["arguments"], descendants: true, read: ViewContainerRef, static: true }], ngImport: i0, template: "<ng-container #arguments>\r\n</ng-container>\r\n<
|
147
|
+
WorkflowNodeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.9", type: WorkflowNodeComponent, selector: "ng-component", outputs: { change: "change" }, viewQueries: [{ propertyName: "argumentstemplate", first: true, predicate: ["arguments"], descendants: true, read: ViewContainerRef, static: true }, { propertyName: "connectorargs", first: true, predicate: ["connectorargs"], descendants: true, static: true }], ngImport: i0, template: "<ng-container #arguments>\r\n</ng-container>\r\n<ng-template #connectorargs>\r\n <form [formGroup]=\"connector\" fxLayout=\"column\" autocomplete=\"off\">\r\n <mat-form-field>\r\n <mat-select [placeholder]=\"'Action' | translate\" formControlName=\"action\">\r\n <mat-option *ngFor=\"let action of actions\" [value]=\"action.name\">{{action.title}}</mat-option>\r\n <mat-option>{{'None' | translate}}</mat-option>\r\n </mat-select>\r\n </mat-form-field>\r\n <mat-button-toggle-group [value]=\"connector.controls['case'].value\" #acase=\"matButtonToggleGroup\" (change)=\"connectorCaseChange($event)\">\r\n <mat-button-toggle value=\"true\">{{'True' | translate}}</mat-button-toggle>\r\n <mat-button-toggle value=\"false\">{{'False' | translate}}</mat-button-toggle>\r\n <mat-button-toggle>{{'Case' | translate}}</mat-button-toggle>\r\n </mat-button-toggle-group>\r\n <mat-form-field [style.display]=\"connector.controls['case'].value==='true'||connector.controls['case'].value==='false'?'none':''\">\r\n <input matInput [placeholder]=\"'Case' | translate\" formControlName=\"case\" />\r\n </mat-form-field>\r\n </form>\r\n</ng-template>\r\n", styles: [":host{width:100%;padding:4px;display:block}\n"], components: [{ type: i6.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { type: i7.MatSelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex"], exportAs: ["matSelect"] }, { type: i8.MatOption, selector: "mat-option", exportAs: ["matOption"] }, { type: i9.MatButtonToggle, selector: "mat-button-toggle", inputs: ["disableRipple", "aria-label", "aria-labelledby", "id", "name", "value", "tabIndex", "appearance", "checked", "disabled"], outputs: ["change"], exportAs: ["matButtonToggle"] }], directives: [{ type: i4.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { type: i4.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i10.DefaultLayoutDirective, selector: " [fxLayout], [fxLayout.xs], [fxLayout.sm], [fxLayout.md], [fxLayout.lg], [fxLayout.xl], [fxLayout.lt-sm], [fxLayout.lt-md], [fxLayout.lt-lg], [fxLayout.lt-xl], [fxLayout.gt-xs], [fxLayout.gt-sm], [fxLayout.gt-md], [fxLayout.gt-lg]", inputs: ["fxLayout", "fxLayout.xs", "fxLayout.sm", "fxLayout.md", "fxLayout.lg", "fxLayout.xl", "fxLayout.lt-sm", "fxLayout.lt-md", "fxLayout.lt-lg", "fxLayout.lt-xl", "fxLayout.gt-xs", "fxLayout.gt-sm", "fxLayout.gt-md", "fxLayout.gt-lg"] }, { type: i4.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i4.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { type: i11.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i9.MatButtonToggleGroup, selector: "mat-button-toggle-group", inputs: ["appearance", "name", "vertical", "value", "multiple", "disabled"], outputs: ["valueChange", "change"], exportAs: ["matButtonToggleGroup"] }, { type: i12.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"] }, { type: i4.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }], pipes: { "translate": i13.TranslatePipe } });
|
119
148
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.9", ngImport: i0, type: WorkflowNodeComponent, decorators: [{
|
120
149
|
type: Component,
|
121
|
-
args: [{ template: "<ng-container #arguments>\r\n</ng-container>\r\n<
|
150
|
+
args: [{ template: "<ng-container #arguments>\r\n</ng-container>\r\n<ng-template #connectorargs>\r\n <form [formGroup]=\"connector\" fxLayout=\"column\" autocomplete=\"off\">\r\n <mat-form-field>\r\n <mat-select [placeholder]=\"'Action' | translate\" formControlName=\"action\">\r\n <mat-option *ngFor=\"let action of actions\" [value]=\"action.name\">{{action.title}}</mat-option>\r\n <mat-option>{{'None' | translate}}</mat-option>\r\n </mat-select>\r\n </mat-form-field>\r\n <mat-button-toggle-group [value]=\"connector.controls['case'].value\" #acase=\"matButtonToggleGroup\" (change)=\"connectorCaseChange($event)\">\r\n <mat-button-toggle value=\"true\">{{'True' | translate}}</mat-button-toggle>\r\n <mat-button-toggle value=\"false\">{{'False' | translate}}</mat-button-toggle>\r\n <mat-button-toggle>{{'Case' | translate}}</mat-button-toggle>\r\n </mat-button-toggle-group>\r\n <mat-form-field [style.display]=\"connector.controls['case'].value==='true'||connector.controls['case'].value==='false'?'none':''\">\r\n <input matInput [placeholder]=\"'Case' | translate\" formControlName=\"case\" />\r\n </mat-form-field>\r\n </form>\r\n</ng-template>\r\n", styles: [":host{width:100%;padding:4px;display:block}\n"] }]
|
122
151
|
}], ctorParameters: function () { return [{ type: i1.SessionService }, { type: i2.BizDocComponentFactoryResolver }, { type: i0.ComponentFactoryResolver }, { type: i0.Injector }, { type: i3.TranslateService }, { type: i4.FormBuilder }, { type: i5.PaneRef }]; }, propDecorators: { change: [{
|
123
152
|
type: Output
|
124
153
|
}], argumentstemplate: [{
|
125
154
|
type: ViewChild,
|
126
155
|
args: ['arguments', { static: true, read: ViewContainerRef }]
|
156
|
+
}], connectorargs: [{
|
157
|
+
type: ViewChild,
|
158
|
+
args: ['connectorargs', { static: true }]
|
127
159
|
}] } });
|
128
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node.component.js","sourceRoot":"","sources":["../../../../../../../libraries/core/src/lib/admin/form/workflow/node.component.ts","../../../../../../../libraries/core/src/lib/admin/form/workflow/node.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ComponentFactoryResolver, OnDestroy, OnInit, Output, ViewChild, ViewContainerRef } from '@angular/core';\r\nimport { Component, Injector } from '@angular/core';\r\nimport { FormBuilder } from '@angular/forms';\r\nimport { Subject, takeUntil } from 'rxjs';\r\nimport { ConnectorModel, NodeModel } from '@syncfusion/ej2-angular-diagrams';\r\nimport { BizDocComponentFactoryResolver } from '../../../core/component-factory-resolver';\r\nimport { Action, FlowNode } from '../../../core/models';\r\nimport { SessionService } from '../../../core/session.service';\r\nimport { PaneRef } from '../../../core/slots/pane-ref';\r\nimport { NodeRef } from './node-ref';\r\nimport { ArgumentsComponent } from '../../../core/base';\r\nimport { EventEmitter } from '@angular/core';\r\nimport { LayoutComponent } from '../../../core/layout/layout.component';\r\nimport { TranslateService } from '../../../core/translate.service';\r\nimport { cleanup } from '../../../core/functions';\r\n\r\n\r\n@Component({\r\n  templateUrl: './node.component.html',\r\n  styleUrls: ['./node.component.scss'],\r\n})\r\nexport\r\n  class WorkflowNodeComponent implements OnInit, OnDestroy {\r\n  @Output() readonly change = new EventEmitter();\r\n  @ViewChild('arguments', { static: true, read: ViewContainerRef }) argumentstemplate: ViewContainerRef;\r\n  nodes: NodeModel[];\r\n  connectors: ConnectorModel[];\r\n  readonly connectorInfo = this._fb.group({\r\n    action: '',\r\n    case: ''\r\n  });\r\n  actions: Action[];\r\n  tool?: FlowNode;\r\n  private _elementDestroy = new Subject<void>();\r\n  node: NodeModel;\r\n  constructor(\r\n    private _session: SessionService,\r\n    private _factoryResolver: BizDocComponentFactoryResolver,\r\n    private _cf: ComponentFactoryResolver,\r\n    private _injector: Injector,\r\n    private _translate: TranslateService,\r\n    private _fb: FormBuilder,\r\n    private _pane: PaneRef<WorkflowNodeComponent>) {\r\n    this.actions = _session.profile.actions;\r\n  }\r\n  ngOnInit(): void {\r\n    this._pane.dataChange.subscribe(d => {\r\n      this.nodes = d['nodes'];\r\n      this.connectors = d['connectors'];\r\n      this.tool = null;\r\n\r\n      this._elementDestroy.next();\r\n      if (this.connectors.length) {\r\n        this.connectorInfo.valueChanges.pipe(takeUntil(this._elementDestroy)).subscribe(() => {\r\n          this.connectors.forEach(c => {\r\n            Object.assign(c.addInfo, this.connectorInfo.getRawValue())\r\n            this.change.emit();\r\n          });\r\n        });\r\n        const connector = this.connectors[0];\r\n        this.connectors.forEach(c => { if (!c.addInfo) c.addInfo = {} });\r\n        const action = (connector.addInfo as any).action,\r\n          acase = (connector.addInfo as any).case;\r\n        this.connectorInfo.patchValue({\r\n          action: this.connectors.length === 1 || this.connectors.every(c => (c.addInfo as any).action === action) ? action : null,\r\n          case: this.connectors.length === 1 || this.connectors.every(c => (c.addInfo as any).case === acase) ? acase : null\r\n        });\r\n        this._pane.title = this._translate.get(this.connectors.length === 1 ? 'Connector' : 'Connectors', this.connectors.length);\r\n        this._pane.icon = 'link';\r\n      }\r\n      this.argumentstemplate.clear();\r\n      if (this.nodes.length) {\r\n        const node = this.node = this.nodes[0],\r\n          addInfo = node.addInfo as any;\r\n        if (addInfo && addInfo.nodeType) {\r\n          const nodeType = addInfo.nodeType;\r\n          const tool = this.tool = this._session.profile.nodes.find(n => n.name === nodeType);\r\n          this._pane.title = tool.title;\r\n          const annotationArg = tool.arguments.find(a => a.diagram);\r\n\r\n          function change(m) {\r\n            if (annotationArg && m[annotationArg.name] !== null && m[annotationArg.name] !== undefined) {\r\n              node.annotations[0].content = m[annotationArg.name];\r\n            }\r\n            Object.assign(addInfo, cleanup(m));\r\n            this.change.emit();\r\n          }\r\n\r\n          if (tool.template) {\r\n            var instance = this._createToolTemplate(tool, node);\r\n\r\n            instance.form.valueChanges.subscribe(change.bind(this));\r\n          }\r\n          else if (tool.arguments.length) {\r\n            let instance = this._createLayoutArguments(tool, node);\r\n\r\n            instance.modelChange.pipe(takeUntil(this._elementDestroy)).subscribe(change.bind(this));\r\n          }\r\n        }\r\n      }\r\n    });\r\n  }\r\n  private _createLayoutArguments(tool: FlowNode, node: NodeModel) {\r\n    const componentFactory = this._cf.resolveComponentFactory(LayoutComponent);\r\n    const componentRef = this.argumentstemplate.createComponent(componentFactory, 0, this._injector);\r\n    const instance = componentRef.instance as LayoutComponent;\r\n    instance.fields = tool.arguments;\r\n    instance.model = node.addInfo;\r\n    instance.create();\r\n    return instance;\r\n  }\r\n  private _createToolTemplate(tool: FlowNode, node: NodeModel) {\r\n    const componentFactory = this._factoryResolver.resolve(this.tool.template);\r\n    const nodeRef = new NodeRef(tool);\r\n    const injector = Injector.create([{ provide: NodeRef, useValue: nodeRef }], this._injector);\r\n    const componentRef = this.argumentstemplate.createComponent(componentFactory, 0, injector);\r\n    const instance = componentRef.instance as ArgumentsComponent<any>;\r\n    instance.form.patchValue(node.addInfo, { emitEvent: false });\r\n    return instance;\r\n  }\r\n  connectorCaseChange(acase?: string) {\r\n    this.connectorInfo.controls['case'].setValue(acase);\r\n    this.change.emit();\r\n  }\r\n  ngOnDestroy(): void {\r\n    this._elementDestroy.next();\r\n    this._elementDestroy.complete();\r\n  }\r\n}\r\n","<ng-container #arguments>\r\n</ng-container>\r\n<form *ngIf=\"connectors?.length\" [formGroup]=\"connectorInfo\" fxLayout=\"column\" autocomplete=\"off\">\r\n  <mat-form-field>\r\n    <mat-select [placeholder]=\"'Action' | translate\" formControlName=\"action\">\r\n      <mat-option *ngFor=\"let action of actions\" [value]=\"action.name\">{{action.title}}</mat-option>\r\n      <mat-option>{{'None' | translate}}</mat-option>\r\n    </mat-select>\r\n  </mat-form-field>\r\n  <mat-button-toggle-group [value]=\"connectorInfo.controls['case'].value\" #acase=\"matButtonToggleGroup\" (change)=\"connectorCaseChange(acase.value)\">\r\n    <mat-button-toggle value=\"true\">{{'True' | translate}}</mat-button-toggle>\r\n    <mat-button-toggle value=\"false\">{{'False' | translate}}</mat-button-toggle>\r\n    <mat-button-toggle>{{'Case' | translate}}</mat-button-toggle>\r\n  </mat-button-toggle-group>\r\n  <mat-form-field>\r\n    <input matInput [placeholder]=\"'Case' | translate\" formControlName=\"case\" />\r\n  </mat-form-field>\r\n</form>\r\n<!--<mat-expansion-panel fxLayout=\"column\" class=\"mat-elevation-z0\" [attr.aria-label]=\"'Design' | translate\" style=\"background: none\">\r\n  <mat-expansion-panel-header>\r\n    <mat-panel-title>{{'Design'|translate}}</mat-panel-title>\r\n  </mat-expansion-panel-header>\r\n  <ng-container *ngIf=\"connectors.length\">\r\n    < mat.get-color-from-palette-picker (valueChanges)='strokeChange($event)' [label]=\"'Stroke'|translate\"></ mat.get-color-from-palette-picker>\r\n  </ng-container>\r\n  <ng-container *ngIf=\"nodes.length\">\r\n    <ng-container *ngIf=\"nodes[0].annotations.length\">\r\n      <mat-form-field>\r\n        <input matInput type=\"number\" [placeholder]=\"'FontSize'|translate\" (change)=\"sizeChange($event.target.value)\" [value]=\"fontSize\" />\r\n      </mat-form-field>\r\n      < mat.get-color-from-palette-picker (valueChanges)='colorChange($event)' [label]=\"'Color'|translate\"></ mat.get-color-from-palette-picker>\r\n    </ng-container>\r\n    < mat.get-color-from-palette-picker (valueChanges)='bgChange($event)' [label]=\"'Background'|translate\"></ mat.get-color-from-palette-picker>\r\n    < mat.get-color-from-palette-picker (valueChanges)='strokeChange($event)' [label]=\"'Stroke'|translate\"></ mat.get-color-from-palette-picker>\r\n  </ng-container>\r\n</mat-expansion-panel>-->\r\n"]}
|
160
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node.component.js","sourceRoot":"","sources":["../../../../../../../libraries/core/src/lib/admin/form/workflow/node.component.ts","../../../../../../../libraries/core/src/lib/admin/form/workflow/node.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ComponentFactoryResolver, EventEmitter, OnDestroy, OnInit, Output, ViewChild, ViewContainerRef, TemplateRef, Component, Injector } from '@angular/core';\r\nimport { FormBuilder } from '@angular/forms';\r\nimport { MatButtonToggleChange } from '@angular/material/button-toggle';\r\nimport { Subject, takeUntil } from 'rxjs';\r\nimport { ConnectorModel, Diagram, NodeModel } from '@syncfusion/ej2-angular-diagrams';\r\nimport { BizDocComponentFactoryResolver } from '../../../core/component-factory-resolver';\r\nimport { Action, FlowNode } from '../../../core/models';\r\nimport { SessionService } from '../../../core/session.service';\r\nimport { PaneRef } from '../../../core/slots/pane-ref';\r\nimport { NodeRef } from './node-ref';\r\nimport { ArgumentsComponent } from '../../../core/base';\r\nimport { LayoutComponent } from '../../../core/layout/layout.component';\r\nimport { TranslateService } from '../../../core/translate.service';\r\nimport { cleanup } from '../../../core/functions';\r\n\r\n@Component({\r\n  templateUrl: './node.component.html',\r\n  styleUrls: ['./node.component.scss'],\r\n})\r\nexport\r\n  class WorkflowNodeComponent implements OnInit, OnDestroy {\r\n  @Output() readonly change = new EventEmitter();\r\n  @ViewChild('arguments', { static: true, read: ViewContainerRef }) argumentstemplate: ViewContainerRef;\r\n  @ViewChild('connectorargs', { static: true }) connectorargs: TemplateRef<any>;\r\n  nodes: NodeModel[];\r\n  connectors: ConnectorModel[];\r\n  diagram: Diagram;\r\n  readonly connector = this._fb.group({\r\n    action: null,\r\n    case: null\r\n  });\r\n  actions: Action[];\r\n  tool?: FlowNode;\r\n  node: NodeModel;\r\n  private _elementDestroy = new Subject<void>();\r\n  constructor(\r\n    private _session: SessionService,\r\n    private _factoryResolver: BizDocComponentFactoryResolver,\r\n    private _cf: ComponentFactoryResolver,\r\n    private _injector: Injector,\r\n    private _translate: TranslateService,\r\n    private _fb: FormBuilder,\r\n    private _pane: PaneRef<WorkflowNodeComponent>) {\r\n    this.actions = _session.profile.actions;\r\n  }\r\n  ngOnInit(): void {\r\n    this._pane.dataChange.subscribe(d => {\r\n      this.nodes = d['nodes'];\r\n      this.diagram = d['diagram'];\r\n      this.connectors = d['connectors'];\r\n      this.tool = null;\r\n\r\n      this._elementDestroy.next();\r\n      this.argumentstemplate.clear();\r\n      if (this.connectors.length) {\r\n        const connector = this.connectors[0];\r\n        if (connector.addInfo) {\r\n          const action = connector.addInfo['action'], acase = connector.addInfo['case'];\r\n          this.connector.patchValue({\r\n            action: this.connectors.length === 1 || this.connectors.every(c => c.addInfo && c.addInfo['action'] === action) ? action : null,\r\n            case: this.connectors.length === 1 || this.connectors.every(c => c.addInfo && c.addInfo['case'] === acase) ? acase : null\r\n          });\r\n        }\r\n        this._pane.title = this._translate.get(this.connectors.length === 1 ? 'Connector' : 'Connectors', this.connectors.length);\r\n        this._pane.icon = 'link';\r\n        this.connector.valueChanges.pipe(takeUntil(this._elementDestroy)).subscribe(v => {\r\n          const content = v['case'] || v['action'];\r\n          if (!connector.addInfo)\r\n            connector.addInfo = this.connector.getRawValue();\r\n          else\r\n            Object.assign(connector.addInfo, this.connector.getRawValue());\r\n          cleanup(connector.addInfo);\r\n          if (connector.annotations.length) {\r\n            connector.annotations[0].content = content;\r\n            this.diagram.dataBind();\r\n          }\r\n          else\r\n            this.diagram.addConnectorLabels(connector, [{\r\n              style: {\r\n                color: this._session.theme.dark ? 'white' : 'black',\r\n                fill: 'transparent',\r\n                opacity: .8,\r\n              },\r\n              content\r\n            }]);\r\n          this.change.emit();\r\n        });\r\n        this.argumentstemplate.createEmbeddedView(this.connectorargs);\r\n      } else {\r\n        const node = this.node = this.nodes[0],\r\n          addInfo = node.addInfo as any;\r\n        if (addInfo && addInfo.nodeType) {\r\n          const nodeType = addInfo.nodeType;\r\n          const tool = this.tool = this._session.profile.nodes.find(n => n.name === nodeType);\r\n          this._pane.title = tool.title;\r\n          const annotationArg = tool.arguments.find(a => a.diagram);\r\n\r\n          function change(m) {\r\n            if (annotationArg && m[annotationArg.name] !== null) {\r\n              if (node.annotations.length) {\r\n                node.annotations[0].content = m[annotationArg.name] || null;\r\n                this.diagram.dataBind();\r\n              }\r\n              else\r\n                this.diagram.addNodeLabels(node, [{\r\n                  style: {\r\n                    color: this._session.theme.dark ? 'white' : 'black',\r\n                    fill: 'transparent',\r\n                    opacity: .8,\r\n                  },\r\n                  content: m[annotationArg.name] || null\r\n                }]);\r\n            }\r\n            Object.assign(addInfo, m);\r\n            cleanup(addInfo);\r\n            this.change.emit();\r\n          }\r\n\r\n          if (tool.template) {\r\n            var instance = this._createToolTemplate(tool, node);\r\n\r\n            instance.form.valueChanges.subscribe(change.bind(this));\r\n          }\r\n          else if (tool.arguments.length) {\r\n            let instance = this._createLayoutArguments(tool, node);\r\n\r\n            instance.modelChange.pipe(takeUntil(this._elementDestroy)).subscribe(change.bind(this));\r\n          }\r\n        }\r\n      }\r\n    });\r\n  }\r\n  private _createLayoutArguments(tool: FlowNode, node: NodeModel) {\r\n    const componentFactory = this._cf.resolveComponentFactory(LayoutComponent);\r\n    const componentRef = this.argumentstemplate.createComponent(componentFactory, 0, this._injector);\r\n    const instance = componentRef.instance as LayoutComponent;\r\n    instance.fields = tool.arguments;\r\n    instance.model = node.addInfo;\r\n    instance.create();\r\n    return instance;\r\n  }\r\n  private _createToolTemplate(tool: FlowNode, node: NodeModel) {\r\n    const componentFactory = this._factoryResolver.resolve(this.tool.template);\r\n    const nodeRef = new NodeRef(tool);\r\n    const injector = Injector.create([{ provide: NodeRef, useValue: nodeRef }], this._injector);\r\n    const componentRef = this.argumentstemplate.createComponent(componentFactory, 0, injector);\r\n    const instance = componentRef.instance as ArgumentsComponent<any>;\r\n    instance.form.patchValue(node.addInfo, { emitEvent: false });\r\n    return instance;\r\n  }\r\n  connectorCaseChange(evt?: MatButtonToggleChange) {\r\n    this.connector.controls['case'].setValue(evt.value);\r\n    this.change.emit();\r\n  }\r\n  ngOnDestroy(): void {\r\n    this._elementDestroy.next();\r\n    this._elementDestroy.complete();\r\n  }\r\n}\r\n","<ng-container #arguments>\r\n</ng-container>\r\n<ng-template #connectorargs>\r\n  <form [formGroup]=\"connector\" fxLayout=\"column\" autocomplete=\"off\">\r\n    <mat-form-field>\r\n      <mat-select [placeholder]=\"'Action' | translate\" formControlName=\"action\">\r\n        <mat-option *ngFor=\"let action of actions\" [value]=\"action.name\">{{action.title}}</mat-option>\r\n        <mat-option>{{'None' | translate}}</mat-option>\r\n      </mat-select>\r\n    </mat-form-field>\r\n    <mat-button-toggle-group [value]=\"connector.controls['case'].value\" #acase=\"matButtonToggleGroup\" (change)=\"connectorCaseChange($event)\">\r\n      <mat-button-toggle value=\"true\">{{'True' | translate}}</mat-button-toggle>\r\n      <mat-button-toggle value=\"false\">{{'False' | translate}}</mat-button-toggle>\r\n      <mat-button-toggle>{{'Case' | translate}}</mat-button-toggle>\r\n    </mat-button-toggle-group>\r\n    <mat-form-field [style.display]=\"connector.controls['case'].value==='true'||connector.controls['case'].value==='false'?'none':''\">\r\n      <input matInput [placeholder]=\"'Case' | translate\" formControlName=\"case\" />\r\n    </mat-form-field>\r\n  </form>\r\n</ng-template>\r\n"]}
|