@bizdoc/core 1.13.34 → 1.13.38

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (60) hide show
  1. package/assets/themes/brown.min.css +0 -2
  2. package/assets/themes/dark.min.css +3 -5
  3. package/assets/themes/deep-purple-light-blue.min.css +0 -2
  4. package/assets/themes/deep-purple-teal.min.css +0 -2
  5. package/assets/themes/default.min.css +0 -2
  6. package/assets/themes/green.min.css +0 -2
  7. package/assets/themes/indigo.min.css +0 -2
  8. package/esm2020/lib/admin/document-trace/trace-element.component.mjs +4 -4
  9. package/esm2020/lib/admin/form/workflow/workflow.component.mjs +52 -19
  10. package/esm2020/lib/browse/expanded-item/expanded-item.component.mjs +16 -13
  11. package/esm2020/lib/chat/chat-info.mjs +2 -3
  12. package/esm2020/lib/chat/conversation.component.mjs +2 -2
  13. package/esm2020/lib/chat/conversation.pane.component.mjs +11 -2
  14. package/esm2020/lib/compose/action/assign-action.component.mjs +19 -43
  15. package/esm2020/lib/compose/trace/flow.component.mjs +46 -32
  16. package/esm2020/lib/compose/trace/trace.component.mjs +8 -12
  17. package/esm2020/lib/core/controls/auto-complete.input.mjs +3 -2
  18. package/esm2020/lib/core/models.mjs +1 -1
  19. package/esm2020/lib/core/slots/slots.component.mjs +2 -2
  20. package/esm2020/lib/core/translations.mjs +11 -7
  21. package/esm2020/lib/cube/grid/spreadsheet.component.mjs +2 -1
  22. package/esm2020/lib/dashboard/cube/compare.widget.mjs +6 -5
  23. package/esm2020/lib/dashboard/score/compare-groups.widget.mjs +206 -0
  24. package/esm2020/lib/dashboard/score/peers-performance.widget.mjs +2 -2
  25. package/esm2020/lib/dashboard/score/pending-results.widget.mjs +5 -9
  26. package/esm2020/lib/home/home.desktop.component.mjs +4 -4
  27. package/esm2020/lib/modules/chart.module.mjs +10 -10
  28. package/esm2020/lib/modules/circular-gauge.module.mjs +1 -1
  29. package/esm2020/lib/modules/dayjs.module.mjs +41 -0
  30. package/esm2020/lib/modules/diagram.module.mjs +1 -1
  31. package/esm2020/lib/modules/gantt.module.mjs +4 -3
  32. package/esm2020/lib/modules/pivot.module.mjs +1 -1
  33. package/esm2020/lib/reports/cube/usage-base.mjs +2 -2
  34. package/esm2020/lib/reports/cube/usage-chart.component.mjs +11 -7
  35. package/esm2020/lib/reports/cube/usage-pivot.component.mjs +21 -3
  36. package/esm2020/lib/reports/report.mobile.component.mjs +3 -3
  37. package/esm2020/lib/reports/report.pane.component.mjs +3 -3
  38. package/esm2020/lib/shared.module.mjs +14 -32
  39. package/esm2020/lib/system.module.mjs +2 -1
  40. package/esm2020/public-api.mjs +2 -2
  41. package/fesm2015/bizdoc-core.mjs +423 -343
  42. package/fesm2015/bizdoc-core.mjs.map +1 -1
  43. package/fesm2020/bizdoc-core.mjs +423 -344
  44. package/fesm2020/bizdoc-core.mjs.map +1 -1
  45. package/lib/admin/form/workflow/workflow.component.d.ts +9 -6
  46. package/lib/compose/action/assign-action.component.d.ts +3 -9
  47. package/lib/core/models.d.ts +1 -0
  48. package/lib/core/translations.d.ts +6 -2
  49. package/lib/dashboard/score/{compare-departments.widget.d.ts → compare-groups.widget.d.ts} +3 -3
  50. package/lib/dashboard/score/pending-results.widget.d.ts +0 -1
  51. package/lib/home/home.desktop.component.d.ts +1 -1
  52. package/lib/modules/chart.module.d.ts +1 -1
  53. package/lib/modules/dayjs.module.d.ts +6 -0
  54. package/lib/reports/cube/usage-base.d.ts +1 -1
  55. package/lib/reports/cube/usage-pivot.component.d.ts +5 -1
  56. package/lib/shared.module.d.ts +21 -19
  57. package/lib/system.module.d.ts +1 -0
  58. package/package.json +1 -1
  59. package/public-api.d.ts +1 -1
  60. package/esm2020/lib/dashboard/score/compare-departments.widget.mjs +0 -206
@@ -44,9 +44,9 @@ export class TraceElementComponent {
44
44
  const info = [];
45
45
  const who = await this._accounts.get(recipient.userId).toPromise();
46
46
  if (recipient.escalated) {
47
- const escalations = this.timeline.log.filter(l => l.type === 'Escalation' && l.recipientId === recipient.id);
48
- const escalate = await this._accounts.get(escalations[0].userId).toPromise();
49
- info.push(this._translate.get('EscalatedBy', this._chat.format(escalate), this._chat.format(who)));
47
+ const escalation = this.timeline.log.find(l => l.type === 'Escalation' && l.recipientId === recipient.originId);
48
+ const to = await this._accounts.get(escalation.userId).toPromise();
49
+ info.push(this._translate.get('EscalatedBy', this._chat.format(to), this._chat.format(who)));
50
50
  }
51
51
  if (recipient.substituteId) {
52
52
  const substitute = await this._accounts.get(recipient.substituteId).toPromise();
@@ -102,4 +102,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.5", ngImpor
102
102
  }], node: [{
103
103
  type: Input
104
104
  }] } });
105
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"trace-element.component.js","sourceRoot":"","sources":["../../../../../../libraries/core/src/lib/admin/document-trace/trace-element.component.ts","../../../../../../libraries/core/src/lib/admin/document-trace/trace-element.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnChanges, Output } from \"@angular/core\";\r\nimport { forkJoin, Observable, of } from \"rxjs\";\r\nimport { map } from \"rxjs/operators\";\r\nimport { Log, LogType, Recipient } from \"../../core/models\";\r\nimport { NodeModel } from \"@syncfusion/ej2-angular-diagrams\";\r\nimport { TranslateService } from '../../core/translate.service';\r\nimport { AccountService } from '../../core/account.service';\r\nimport { ChatInfo } from '../../chat/chat-info';\r\nimport { Timeline, DiagramInfo } from \"./timeline\";\r\nimport { SessionService } from \"../../core/session.service\";\r\nimport { PanesRouter } from \"../../core/slots/router.service\";\r\nimport { OpenPolicy } from \"../../core/configuration\";\r\n\r\nconst VISIABLE_LOG_TYPES: LogType[] = ['StateChange', 'ModelChange', 'Download'];\r\n\r\n@Component({\r\n  selector: 'bizdoc-document-trace-element',\r\n  templateUrl: 'trace-element.component.html',\r\n  styleUrls: ['trace-element.component.scss']\r\n})\r\nexport class TraceElementComponent implements OnChanges {\r\n  @Output() readonly assign = new EventEmitter<Recipient>();\r\n\r\n  @Input() model: DiagramInfo;\r\n  @Input() timeline: Timeline;\r\n  @Input() node: NodeModel;\r\n\r\n  recipients: Recipient[];\r\n  log: Log[];\r\n  estimate: boolean;\r\n  recurring: boolean;\r\n  none: boolean;\r\n  skip: boolean;\r\n  nodeType: any;\r\n\r\n  constructor(\r\n    private _chat: ChatInfo,\r\n    private _router: PanesRouter,\r\n    private _translate: TranslateService,\r\n    private _accounts: AccountService,\r\n    private _session: SessionService\r\n  ) {\r\n  }\r\n  ngOnChanges(): void {\r\n    const { id, addInfo } = this.node;\r\n    const recipients = this.timeline.recipients.filter(r => r.nodeId === id),\r\n      log = this.timeline.log.filter(l => l.nodeId === id);\r\n    this.recipients = recipients,\r\n      this.recurring = recipients.length < this.model.recipients.filter(r => r.nodeId === id).length ||\r\n      log.length < this.model.log.filter(l => l.nodeId === id).length,\r\n      this.log = log.filter(l => VISIABLE_LOG_TYPES.indexOf(l.type) > -1),\r\n      this.estimate = log.find(l => l.estimate) !== undefined,\r\n      this.skip = log.find(l => l.type === 'NodeJump') !== undefined,\r\n      this.none = log.length === 0,\r\n      this.nodeType = this._session.profile.nodes.find(n => n.name === (addInfo as any).nodeType);\r\n  }\r\n\r\n  async recipientInfo(recipient: Recipient) {\r\n    const info = [];\r\n    const who = await this._accounts.get(recipient.userId).toPromise();\r\n    if (recipient.escalated) {\r\n      const escalations = this.timeline.log.filter(l => l.type === 'Escalation' && l.recipientId === recipient.id);\r\n      const escalate = await this._accounts.get(escalations[0].userId).toPromise();\r\n      info.push(this._translate.get('EscalatedBy', this._chat.format(escalate), this._chat.format(who)));\r\n    }\r\n    if (recipient.substituteId) {\r\n      const substitute = await this._accounts.get(recipient.substituteId).toPromise();\r\n      if (recipient.byId) {\r\n        const by = await this._accounts.get(recipient.byId).toPromise();\r\n        info.push(this._translate.get('SubstitutingBy', this._chat.format(who), this._chat.format(substitute), this._chat.format(by)));\r\n      }\r\n      else info.push(this._translate.get('Substituting', this._chat.format(who), this._chat.format(substitute)));\r\n    }\r\n    else if (recipient.byId) {\r\n      const by = await this._accounts.get(recipient.byId).toPromise();\r\n      info.push(this._translate.get('By', this._chat.format(who), this._chat.format(by)));\r\n    }\r\n    else info.push(this._chat.format(who));\r\n    return info.join(this._translate.comma);\r\n  }\r\n  logInfo(log: Log): Observable<string> {\r\n    const observables: Observable<any>[] = [];\r\n\r\n    if (log.userId) {\r\n      const observe = this._accounts.get(log.userId);\r\n      observables.push(observe);\r\n    }\r\n    if (log.byId) {\r\n      const observe = this._accounts.get(log.byId);\r\n      observables.push(observe);\r\n    }\r\n    return observables.length ? forkJoin(observables).pipe(map(us => us.map(u => this._chat.format(u))),\r\n      map(us =>\r\n        log.byId ? this._translate.get('By', us[0], us[1]) : us[0])) : of('');\r\n  }\r\n  compare(item: Log) {\r\n    this._router.navigate(['mailbox/d', this.model.documentId.encodeId(), 'version', new Date(item.time).valueOf().encodeId()], {\r\n      policy: OpenPolicy.Tab | OpenPolicy.Toggle,\r\n    })\r\n  }\r\n  chat(e: MouseEvent) {\r\n    const userId = (e.srcElement as HTMLElement).getAttribute('data-info');\r\n    userId &&\r\n      this._chat.open(userId);\r\n  }\r\n}\r\n","<h3>\r\n  {{nodeType.title}}\r\n</h3>\r\n\r\n<h4 *ngIf=\"estimate\">{{'Estimate' | translate}}</h4>\r\n<h4 *ngIf=\"none\">{{'NoEstimate' | translate}}</h4>\r\n<h4 *ngIf=\"skip\">{{'Skipped' | translate}}</h4>\r\n\r\n<h4 *ngIf=\"recurring\" class=\"message mat-body-1\"><mat-icon>info</mat-icon> {{'TimelineMore' | translate}}</h4>\r\n\r\n<table class=\"mat-table\">\r\n  <tbody class=\"mat-table-body\">\r\n    <tr *ngFor=\"let r of recipients\" class=\"mat-row\">\r\n      <td class=\"mat-cell\" (click)=\"chat($event)\" [innerHTML]=\"recipientInfo(r) | async | sanitizeHtml\">\r\n      </td>\r\n      <td class=\"mat-cell\">\r\n        <span *ngIf=\"r.action\">\r\n          {{r.action | action : 'past'}}\r\n        </span>\r\n        <span *ngIf=\"r.pending\">\r\n          <span *ngIf=\"!r.estimate; else estimate\">\r\n            {{'IsPending' | translate}}\r\n          </span>\r\n        </span>\r\n      </td>\r\n      <td class=\"mat-cell\">\r\n        <span *ngIf=\"!r.estimate; estimate\">{{r.received || r.replied | amDateFormat: 'lll'}}</span>\r\n      </td>\r\n      <td class=\"mat-cell\">\r\n        <button mat-icon-button *ngIf=\"!r.estimate\" [matMenuTriggerFor]=\"options\" [disabled]=\"!r.pending\"><mat-icon>more_vert</mat-icon></button>\r\n        <mat-menu #options>\r\n          <button mat-menu-item (click)=\"assign.emit(r)\" *ngIf=\"r.pending\">{{'Reassign'|translate}}</button>\r\n        </mat-menu>\r\n      </td>\r\n    </tr>\r\n  </tbody>\r\n  <tbody class=\"mat-table-body\">\r\n    <tr *ngFor=\"let l of log\" class=\"mat-row\">\r\n      <td class=\"mat-cell\" (click)=\"chat($event)\" [innerHTML]=\"logInfo(l) | async | sanitizeHtml\">\r\n      </td>\r\n      <td [ngSwitch]=\"l.type\" class=\"mat-cell\">\r\n        <span *ngSwitchCase=\"'StateChange'\">\r\n          {{l.state | state : (l.estimate ? 'future' : 'past')}}\r\n        </span>\r\n        <span *ngSwitchCase=\"'ModelChange'\">\r\n          {{'Changed' | translate}}\r\n        </span>\r\n      </td>\r\n      <td class=\"mat-cell\">\r\n        <span *ngIf=\"!l.estimate\">{{l.time | amDateFormat: 'lll'}}</span>\r\n      </td>\r\n      <td class=\"mat-cell\">\r\n        <button mat-icon-button (click)=\"compare(l)\" *ngIf=\"l.type==='ModelChange'\" [bizdocTooltip]=\"'Compare'|translate\"><mat-icon>visibility</mat-icon></button>\r\n      </td>\r\n    </tr>\r\n  </tbody>\r\n</table>\r\n"]}
105
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"trace-element.component.js","sourceRoot":"","sources":["../../../../../../libraries/core/src/lib/admin/document-trace/trace-element.component.ts","../../../../../../libraries/core/src/lib/admin/document-trace/trace-element.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnChanges, Output } from \"@angular/core\";\r\nimport { forkJoin, Observable, of } from \"rxjs\";\r\nimport { map } from \"rxjs/operators\";\r\nimport { Log, LogType, Recipient } from \"../../core/models\";\r\nimport { NodeModel } from \"@syncfusion/ej2-angular-diagrams\";\r\nimport { TranslateService } from '../../core/translate.service';\r\nimport { AccountService } from '../../core/account.service';\r\nimport { ChatInfo } from '../../chat/chat-info';\r\nimport { Timeline, DiagramInfo } from \"./timeline\";\r\nimport { SessionService } from \"../../core/session.service\";\r\nimport { PanesRouter } from \"../../core/slots/router.service\";\r\nimport { OpenPolicy } from \"../../core/configuration\";\r\n\r\nconst VISIABLE_LOG_TYPES: LogType[] = ['StateChange', 'ModelChange', 'Download'];\r\n\r\n@Component({\r\n  selector: 'bizdoc-document-trace-element',\r\n  templateUrl: 'trace-element.component.html',\r\n  styleUrls: ['trace-element.component.scss']\r\n})\r\nexport class TraceElementComponent implements OnChanges {\r\n  @Output() readonly assign = new EventEmitter<Recipient>();\r\n\r\n  @Input() model: DiagramInfo;\r\n  @Input() timeline: Timeline;\r\n  @Input() node: NodeModel;\r\n\r\n  recipients: Recipient[];\r\n  log: Log[];\r\n  estimate: boolean;\r\n  recurring: boolean;\r\n  none: boolean;\r\n  skip: boolean;\r\n  nodeType: any;\r\n\r\n  constructor(\r\n    private _chat: ChatInfo,\r\n    private _router: PanesRouter,\r\n    private _translate: TranslateService,\r\n    private _accounts: AccountService,\r\n    private _session: SessionService\r\n  ) {\r\n  }\r\n  ngOnChanges(): void {\r\n    const { id, addInfo } = this.node;\r\n    const recipients = this.timeline.recipients.filter(r => r.nodeId === id),\r\n      log = this.timeline.log.filter(l => l.nodeId === id);\r\n    this.recipients = recipients,\r\n      this.recurring = recipients.length < this.model.recipients.filter(r => r.nodeId === id).length ||\r\n      log.length < this.model.log.filter(l => l.nodeId === id).length,\r\n      this.log = log.filter(l => VISIABLE_LOG_TYPES.indexOf(l.type) > -1),\r\n      this.estimate = log.find(l => l.estimate) !== undefined,\r\n      this.skip = log.find(l => l.type === 'NodeJump') !== undefined,\r\n      this.none = log.length === 0,\r\n      this.nodeType = this._session.profile.nodes.find(n => n.name === (addInfo as any).nodeType);\r\n  }\r\n\r\n  async recipientInfo(recipient: Recipient) {\r\n    const info = [];\r\n    const who = await this._accounts.get(recipient.userId).toPromise();\r\n    if (recipient.escalated) {\r\n      const escalation = this.timeline.log.find(l => l.type === 'Escalation' && l.recipientId === recipient.originId);\r\n      const to = await this._accounts.get(escalation.userId).toPromise();\r\n      info.push(this._translate.get('EscalatedBy', this._chat.format(to), this._chat.format(who)));\r\n    }\r\n    if (recipient.substituteId) {\r\n      const substitute = await this._accounts.get(recipient.substituteId).toPromise();\r\n      if (recipient.byId) {\r\n        const by = await this._accounts.get(recipient.byId).toPromise();\r\n        info.push(this._translate.get('SubstitutingBy', this._chat.format(who), this._chat.format(substitute), this._chat.format(by)));\r\n      }\r\n      else info.push(this._translate.get('Substituting', this._chat.format(who), this._chat.format(substitute)));\r\n    }\r\n    else if (recipient.byId) {\r\n      const by = await this._accounts.get(recipient.byId).toPromise();\r\n      info.push(this._translate.get('By', this._chat.format(who), this._chat.format(by)));\r\n    }\r\n    else info.push(this._chat.format(who));\r\n    return info.join(this._translate.comma);\r\n  }\r\n  logInfo(log: Log): Observable<string> {\r\n    const observables: Observable<any>[] = [];\r\n\r\n    if (log.userId) {\r\n      const observe = this._accounts.get(log.userId);\r\n      observables.push(observe);\r\n    }\r\n    if (log.byId) {\r\n      const observe = this._accounts.get(log.byId);\r\n      observables.push(observe);\r\n    }\r\n    return observables.length ? forkJoin(observables).pipe(map(us => us.map(u => this._chat.format(u))),\r\n      map(us =>\r\n        log.byId ? this._translate.get('By', us[0], us[1]) : us[0])) : of('');\r\n  }\r\n  compare(item: Log) {\r\n    this._router.navigate(['mailbox/d', this.model.documentId.encodeId(), 'version', new Date(item.time).valueOf().encodeId()], {\r\n      policy: OpenPolicy.Tab | OpenPolicy.Toggle,\r\n    })\r\n  }\r\n  chat(e: MouseEvent) {\r\n    const userId = (e.srcElement as HTMLElement).getAttribute('data-info');\r\n    userId &&\r\n      this._chat.open(userId);\r\n  }\r\n}\r\n","<h3>\r\n  {{nodeType.title}}\r\n</h3>\r\n\r\n<h4 *ngIf=\"estimate\">{{'Estimate' | translate}}</h4>\r\n<h4 *ngIf=\"none\">{{'NoEstimate' | translate}}</h4>\r\n<h4 *ngIf=\"skip\">{{'Skipped' | translate}}</h4>\r\n\r\n<h4 *ngIf=\"recurring\" class=\"message mat-body-1\"><mat-icon>info</mat-icon> {{'TimelineMore' | translate}}</h4>\r\n\r\n<table class=\"mat-table\">\r\n  <tbody class=\"mat-table-body\">\r\n    <tr *ngFor=\"let r of recipients\" class=\"mat-row\">\r\n      <td class=\"mat-cell\" (click)=\"chat($event)\" [innerHTML]=\"recipientInfo(r) | async | sanitizeHtml\">\r\n      </td>\r\n      <td class=\"mat-cell\">\r\n        <span *ngIf=\"r.action\">\r\n          {{r.action | action : 'past'}}\r\n        </span>\r\n        <span *ngIf=\"r.pending\">\r\n          <span *ngIf=\"!r.estimate; else estimate\">\r\n            {{'IsPending' | translate}}\r\n          </span>\r\n        </span>\r\n      </td>\r\n      <td class=\"mat-cell\">\r\n        <span *ngIf=\"!r.estimate; estimate\">{{r.received || r.replied | amDateFormat: 'lll'}}</span>\r\n      </td>\r\n      <td class=\"mat-cell\">\r\n        <button mat-icon-button *ngIf=\"!r.estimate\" [matMenuTriggerFor]=\"options\" [disabled]=\"!r.pending\"><mat-icon>more_vert</mat-icon></button>\r\n        <mat-menu #options>\r\n          <button mat-menu-item (click)=\"assign.emit(r)\" *ngIf=\"r.pending\">{{'Reassign'|translate}}</button>\r\n        </mat-menu>\r\n      </td>\r\n    </tr>\r\n  </tbody>\r\n  <tbody class=\"mat-table-body\">\r\n    <tr *ngFor=\"let l of log\" class=\"mat-row\">\r\n      <td class=\"mat-cell\" (click)=\"chat($event)\" [innerHTML]=\"logInfo(l) | async | sanitizeHtml\">\r\n      </td>\r\n      <td [ngSwitch]=\"l.type\" class=\"mat-cell\">\r\n        <span *ngSwitchCase=\"'StateChange'\">\r\n          {{l.state | state : (l.estimate ? 'future' : 'past')}}\r\n        </span>\r\n        <span *ngSwitchCase=\"'ModelChange'\">\r\n          {{'Changed' | translate}}\r\n        </span>\r\n      </td>\r\n      <td class=\"mat-cell\">\r\n        <span *ngIf=\"!l.estimate\">{{l.time | amDateFormat: 'lll'}}</span>\r\n      </td>\r\n      <td class=\"mat-cell\">\r\n        <button mat-icon-button (click)=\"compare(l)\" *ngIf=\"l.type==='ModelChange'\" [bizdocTooltip]=\"'Compare'|translate\"><mat-icon>visibility</mat-icon></button>\r\n      </td>\r\n    </tr>\r\n  </tbody>\r\n</table>\r\n"]}
@@ -1,7 +1,7 @@
1
1
  import { Component, ViewChild, HostListener } from '@angular/core';
2
2
  import { Subject } from 'rxjs';
3
3
  import { takeUntil } from 'rxjs/operators';
4
- import { SymbolPaletteComponent, DiagramConstraints, SelectorConstraints, ConnectorDrawingTool, NodeConstraints, Diagram, UndoRedo, Node, DiagramTools, ConnectorConstraints } from '@syncfusion/ej2-angular-diagrams';
4
+ import { DiagramConstraints, SelectorConstraints, ConnectorDrawingTool, NodeConstraints, Diagram, UndoRedo, Node, DiagramTools, ConnectorConstraints, SymbolPalette, BpmnDiagrams, DataBinding, ConnectorEditing, ConnectorBridging, Snapping } from '@syncfusion/ej2-diagrams';
5
5
  import { WorkflowNodeComponent } from './node.component';
6
6
  import { OpenPolicy } from '../../../core/configuration';
7
7
  import * as i0 from "@angular/core";
@@ -15,14 +15,14 @@ import * as i7 from "@angular/material/toolbar";
15
15
  import * as i8 from "@angular/material/button";
16
16
  import * as i9 from "@angular/material/icon";
17
17
  import * as i10 from "@angular/material/menu";
18
- import * as i11 from "@syncfusion/ej2-angular-diagrams";
19
- import * as i12 from "../../../core/popup/tooltip.directive";
20
- import * as i13 from "@angular/common";
21
- import * as i14 from "@angular/flex-layout/extended";
22
- import * as i15 from "@angular/cdk/bidi";
23
- import * as i16 from "@angular/flex-layout/flex";
24
- import * as i17 from "../../../core/pipes/translate.pipe";
25
- Diagram.Inject(UndoRedo);
18
+ import * as i11 from "../../../core/popup/tooltip.directive";
19
+ import * as i12 from "@angular/common";
20
+ import * as i13 from "@angular/flex-layout/extended";
21
+ import * as i14 from "@angular/cdk/bidi";
22
+ import * as i15 from "@angular/flex-layout/flex";
23
+ import * as i16 from "../../../core/pipes/translate.pipe";
24
+ Diagram.Inject(BpmnDiagrams, UndoRedo, ConnectorBridging, ConnectorEditing, Snapping, DataBinding);
25
+ SymbolPalette.Inject(BpmnDiagrams);
26
26
  function getPorts() {
27
27
  const ports = [
28
28
  { id: 'port1', shape: 'Circle', offset: { x: 0, y: 0.5 } },
@@ -87,7 +87,6 @@ export class WorkflowComponent {
87
87
  this.connectorType = 'Bezier';
88
88
  this.alignment = 'Center';
89
89
  this.fontSize = 12;
90
- this.getCustomTool = this.getTool.bind(this);
91
90
  this.saving = false;
92
91
  this.dirty = false;
93
92
  this.palettes = [];
@@ -158,6 +157,38 @@ export class WorkflowComponent {
158
157
  tool = new DrawTool(this.diagram, this.connectorType);
159
158
  return tool;
160
159
  }
160
+ ngOnInit() {
161
+ }
162
+ ngAfterViewInit() {
163
+ this.symbolPalette = new SymbolPalette({
164
+ expandMode: 'Multiple',
165
+ palettes: this.palettes,
166
+ width: "100%", height: "100%", symbolHeight: 80,
167
+ enableRtl: false, enableAnimation: false, symbolWidth: 80,
168
+ symbolMargin: this.symbolMargin,
169
+ getSymbolInfo: this.getSymbolInfo.bind(this),
170
+ getNodeDefaults: this.getSymbolDefaults.bind(this)
171
+ });
172
+ this.symbolPalette.appendTo(this.symbolPaletteEl.nativeElement);
173
+ this.diagram = new Diagram({
174
+ width: "100%", height: "100%",
175
+ snapSettings: this.snapSettings,
176
+ getConnectorDefaults: this.connDefaults.bind(this),
177
+ constraints: this.diagramConstraints,
178
+ tool: this.diagramTool,
179
+ getNodeDefaults: this.nodeDefaults.bind(this),
180
+ getCustomTool: this.getTool.bind(this),
181
+ scrollSettings: this.scrollSettings,
182
+ selectedItems: this.selectedItems,
183
+ rulerSettings: this.rulerSettings,
184
+ dragEnter: this.dragEnter.bind(this),
185
+ connectionChange: this.change.bind(this),
186
+ collectionChange: this.change.bind(this),
187
+ propertyChange: this.propertyChange.bind(this),
188
+ selectionChange: this.selectionChange.bind(this),
189
+ }, this.diagramEl.nativeElement);
190
+ this.diagramCreate();
191
+ }
161
192
  diagramCreate() {
162
193
  paletteIconClick();
163
194
  this._pane.paramsChange.pipe(takeUntil(this._destroy)).subscribe(p => {
@@ -186,7 +217,7 @@ export class WorkflowComponent {
186
217
  addInfo: {
187
218
  nodeType: n.name,
188
219
  title: n.title
189
- }
220
+ },
190
221
  };
191
222
  node.node = n.name;
192
223
  let palette = this.palettes.find(p => p.title === (n.palette || ''));
@@ -362,7 +393,7 @@ export class WorkflowComponent {
362
393
  this.dirty = true;
363
394
  }
364
395
  save() {
365
- this.diagram.serializationSettings = {};
396
+ this.diagram.serializationSettings = { preventDefaults: true };
366
397
  const obj = JSON.parse(this.diagram.saveDiagram());
367
398
  this._form.workflow.connectors = obj.connectors;
368
399
  this._form.workflow.nodes = obj.nodes.filter(n => n.id !== 'version').map((n) => {
@@ -388,25 +419,27 @@ export class WorkflowComponent {
388
419
  });
389
420
  }
390
421
  ngOnDestroy() {
422
+ this.symbolPalette?.destroy();
423
+ this.diagram?.destroy();
391
424
  this._destroy.next();
392
425
  this._destroy.complete();
393
426
  }
394
427
  }
395
428
  WorkflowComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.5", ngImport: i0, type: WorkflowComponent, deps: [{ token: i1.PromptService }, { token: i2.FormService }, { token: i3.PaneRef }, { token: i4.PanesRouter }, { token: i5.SessionService }, { token: i6.TranslateService }], target: i0.ɵɵFactoryTarget.Component });
396
- WorkflowComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.5", type: WorkflowComponent, selector: "bizdoc-workflow", host: { listeners: { "document:keydown": "handleKeyboardEvent($event)" }, classAttribute: "pane" }, viewQueries: [{ propertyName: "symbolPalette", first: true, predicate: SymbolPaletteComponent, descendants: true }, { propertyName: "diagram", first: true, predicate: ["diagram"], descendants: true }], ngImport: i0, template: "<mat-toolbar>\r\n <button mat-icon-button (click)=\"tools = !tools\" [bizdocTooltip]=\"'Collapse' | translate\"><mat-icon>view_sidebar</mat-icon></button>\r\n <button mat-button (click)=\"save()\" color=\"primary\" [disabled]=\"!dirty || saving\">{{'SaveChanges' | translate}}</button>\r\n <button mat-icon-button (click)=\"diagram.fitToPage()\" [bizdocTooltip]=\"'FitToPage' | translate\"><mat-icon>fullscreen_exit</mat-icon></button>\r\n <button mat-icon-button (click)=\"diagram.undo()\" [bizdocTooltip]=\"'Undo' | translate\" [disabled]=\"!diagram.historyManager?.canUndo\"><mat-icon>undo</mat-icon></button>\r\n <button mat-icon-button (click)=\"diagram.redo()\" [bizdocTooltip]=\"'Redo' | translate\" [disabled]=\"!diagram.historyManager?.canRedo\"><mat-icon>redo</mat-icon></button>\r\n &nbsp;\r\n <button mat-icon-button (click)=\"pan()\" [bizdocTooltip]=\"'Pan' | translate\"><span class=\"e-icons sf-icon-pan\"></span></button>\r\n <button mat-icon-button (click)=\"cursor()\" [bizdocTooltip]=\"'Cursor' | translate\"><span class=\"e-icons sf-icon-cursor\"></span></button>\r\n <span class=\"divider\"></span>\r\n <button mat-icon-button (click)=\"addText()\" [bizdocTooltip]=\"'Text' | translate\"><mat-icon>title</mat-icon></button>\r\n <button mat-button [matMenuTriggerFor]=\"lineMenu\" [disabled]=\"!diagram.selectedItems?.connectors.length\" [bizdocTooltip]=\"'ConnectorMode'|translate\">\r\n <span class=\"e-menu-icon\" [ngClass]=\"{'sf-icon-straight-line': connectorType === 'Straight',\r\n 'sf-icon-orthogonal-line': connectorType === 'Orthogonal',\r\n 'sf-icon-beizer-line': connectorType === 'Bezier'}\"></span>\r\n <mat-icon>arrow_drop_down</mat-icon>\r\n </button>\r\n <mat-menu #lineMenu panelClass=\"icon-menu-panel\">\r\n <button mat-menu-item (click)=\"connectorTypeChange('Straight')\">\r\n <span class=\"e-menu-icon sf-icon-straight-line\"></span>\r\n </button>\r\n <button mat-menu-item (click)=\"connectorTypeChange('Orthogonal')\">\r\n <span class=\"e-menu-icon sf-icon-orthogonal-line\"></span>\r\n </button>\r\n <button mat-menu-item (click)=\"connectorTypeChange('Bezier')\">\r\n <span class=\"e-menu-icon sf-icon-beizer-line\"></span>\r\n </button>\r\n </mat-menu>\r\n &nbsp;\r\n <button mat-button [matMenuTriggerFor]=\"alignMenu\" [disabled]=\"!diagram.selectedItems?.nodes.length && !diagram.selectedItems?.connectors.length\" [bizdocTooltip]=\"'Align'|translate\">\r\n <span class=\"e-icons\" [ngClass]=\"{'sf-icon-top': alignment === 'Top',\r\n 'sf-icon-left': alignment === 'Left',\r\n 'sf-icon-center': alignment === 'Center',\r\n 'sf-icon-bottom': alignment === 'Bottom',\r\n 'sf-icon-right': alignment === 'Right'}\"></span>\r\n <mat-icon>arrow_drop_down</mat-icon>\r\n </button>\r\n <mat-menu #alignMenu panelClass=\"icon-menu-panel\">\r\n <button mat-menu-item (click)=\"align('Top')\">\r\n <span class=\"e-icons sf-icon-top\"></span>\r\n </button>\r\n <button mat-menu-item (click)=\"align('Left')\">\r\n <span class=\"e-icons sf-icon-left\"></span>\r\n </button>\r\n <button mat-menu-item (click)=\"align('Center')\">\r\n <span class=\"e-icons sf-icon-center\"></span>\r\n </button>\r\n <button mat-menu-item (click)=\"align('Bottom')\">\r\n <span class=\"e-icons sf-icon-bottom\"></span>\r\n </button>\r\n <button mat-menu-item (click)=\"align('Right')\">\r\n <span class=\"e-icons sf-icon-right\"></span>\r\n </button>\r\n </mat-menu>\r\n</mat-toolbar>\r\n<div class=\"row container\">\r\n <div id=\"symbolpalette\" *ngIf=\"tools\">\r\n <ejs-symbolpalette dir=\"ltr\" expandMode='Multiple' [palettes]='palettes' width=\"100%\" height=\"100%\" [symbolHeight]=80\r\n [enableRtl]=\"false\" [enableAnimation]=\"false\" [symbolWidth]=80 [symbolMargin]='symbolMargin' [getSymbolInfo]='getSymbolInfo' [getNodeDefaults]='getSymbolDefaults'>\r\n </ejs-symbolpalette>\r\n </div>\r\n <ejs-diagram #diagram id=\"diagram\" width=\"100%\" height=\"100%\" dir=\"ltr\" [snapSettings]='snapSettings' [getConnectorDefaults]='connDefaults' fxFlex\r\n [constraints]=\"diagramConstraints\" [tool]=diagramTool [getNodeDefaults]='nodeDefaults' [getCustomTool]='getCustomTool' [scrollSettings]=\"scrollSettings\"\r\n [selectedItems]=\"selectedItems\"\r\n [rulerSettings]=\"rulerSettings\"\r\n (dragEnter)='dragEnter($event)'\r\n (connectionChange)=\"change()\"\r\n (collectionChange)=\"change()\"\r\n (propertyChange)=\"propertyChange($event)\"\r\n (selectionChange)=\"selectionChange()\"\r\n (created)=\"diagramCreate()\">\r\n </ejs-diagram>\r\n</div>\r\n", styles: [":host{display:flex;flex-direction:column;flex-grow:1;height:100%}.container{flex-grow:1;overflow-y:auto}#diagram{flex-grow:1}#symbolpalette{width:210px}::ng-deep .e-rtl{direction:ltr}::ng-deep .mat-toolbar .mat-button-toggle{background:transparent!important}.e-menu-icon{font-family:diagram-icons!important;speak:none;font-size:18px;font-style:normal;font-weight:400;font-feature-settings:normal;font-variant:normal;text-transform:none;line-height:1;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}::ng-deep .icon-menu-panel{min-width:0}\n"], components: [{ type: i7.MatToolbar, selector: "mat-toolbar", inputs: ["color"], exportAs: ["matToolbar"] }, { type: i8.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"] }, { type: i9.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i10.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { type: i10.MatMenuItem, selector: "[mat-menu-item]", inputs: ["disabled", "disableRipple", "role"], exportAs: ["matMenuItem"] }, { type: i11.SymbolPaletteComponent, selector: "ejs-symbolpalette", inputs: ["accessKey", "allowDrag", "connectorDefaults", "enableAnimation", "enablePersistence", "enableRtl", "enableSearch", "expandMode", "filterSymbols", "getConnectorDefaults", "getNodeDefaults", "getSymbolInfo", "getSymbolTemplate", "height", "ignoreSymbolsOnSearch", "locale", "nodeDefaults", "palettes", "symbolDragSize", "symbolHeight", "symbolInfo", "symbolMargin", "symbolPreview", "symbolWidth", "width"], outputs: ["paletteExpanding", "paletteSelectionChange"] }, { type: i11.DiagramComponent, selector: "ejs-diagram", inputs: ["addInfo", "annotationTemplate", "backgroundColor", "bridgeDirection", "commandManager", "connectorDefaults", "connectors", "constraints", "contextMenuSettings", "customCursor", "dataSourceSettings", "diagramSettings", "drawingObject", "enablePersistence", "enableRtl", "getConnectorDefaults", "getCustomCursor", "getCustomProperty", "getCustomTool", "getDescription", "getNodeDefaults", "height", "historyManager", "layers", "layout", "locale", "mode", "nodeDefaults", "nodeTemplate", "nodes", "pageSettings", "rulerSettings", "scrollSettings", "selectedItems", "serializationSettings", "setNodeTemplate", "snapSettings", "tool", "tooltip", "updateSelection", "userHandleTemplate", "width"], outputs: ["animationComplete", "click", "collectionChange", "commandExecute", "connectionChange", "contextMenuBeforeItemRender", "contextMenuClick", "contextMenuOpen", "created", "dataLoaded", "doubleClick", "dragEnter", "dragLeave", "dragOver", "drop", "expandStateChange", "fixedUserHandleClick", "historyChange", "historyStateChange", "keyDown", "keyUp", "mouseEnter", "mouseLeave", "mouseOver", "onImageLoad", "onUserHandleMouseDown", "onUserHandleMouseEnter", "onUserHandleMouseLeave", "onUserHandleMouseUp", "positionChange", "propertyChange", "rotateChange", "scrollChange", "segmentCollectionChange", "selectionChange", "sizeChange", "sourcePointChange", "targetPointChange", "textEdit"] }], directives: [{ type: i12.TooltipDirective, selector: "[bizdocTooltip]", inputs: ["bizdocTooltip", "bizdocTooltipTemplate", "bizdocTooltipContext", "bizdocTooltipPosition", "bizdocTooltipDuration", "bizdocTooltipDisabled"] }, { type: i10.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", exportAs: ["matMenuTrigger"] }, { type: i13.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i14.DefaultClassDirective, selector: " [ngClass], [ngClass.xs], [ngClass.sm], [ngClass.md], [ngClass.lg], [ngClass.xl], [ngClass.lt-sm], [ngClass.lt-md], [ngClass.lt-lg], [ngClass.lt-xl], [ngClass.gt-xs], [ngClass.gt-sm], [ngClass.gt-md], [ngClass.gt-lg]", inputs: ["ngClass", "ngClass.xs", "ngClass.sm", "ngClass.md", "ngClass.lg", "ngClass.xl", "ngClass.lt-sm", "ngClass.lt-md", "ngClass.lt-lg", "ngClass.lt-xl", "ngClass.gt-xs", "ngClass.gt-sm", "ngClass.gt-md", "ngClass.gt-lg"] }, { type: i13.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i15.Dir, selector: "[dir]", inputs: ["dir"], outputs: ["dirChange"], exportAs: ["dir"] }, { type: i16.DefaultFlexDirective, selector: " [fxFlex], [fxFlex.xs], [fxFlex.sm], [fxFlex.md], [fxFlex.lg], [fxFlex.xl], [fxFlex.lt-sm], [fxFlex.lt-md], [fxFlex.lt-lg], [fxFlex.lt-xl], [fxFlex.gt-xs], [fxFlex.gt-sm], [fxFlex.gt-md], [fxFlex.gt-lg]", inputs: ["fxFlex", "fxFlex.xs", "fxFlex.sm", "fxFlex.md", "fxFlex.lg", "fxFlex.xl", "fxFlex.lt-sm", "fxFlex.lt-md", "fxFlex.lt-lg", "fxFlex.lt-xl", "fxFlex.gt-xs", "fxFlex.gt-sm", "fxFlex.gt-md", "fxFlex.gt-lg"] }], pipes: { "translate": i17.TranslatePipe } });
429
+ WorkflowComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.5", type: WorkflowComponent, selector: "bizdoc-workflow", host: { listeners: { "document:keydown": "handleKeyboardEvent($event)" }, classAttribute: "pane" }, viewQueries: [{ propertyName: "symbolPaletteEl", first: true, predicate: ["symbolPalette"], descendants: true, static: true }, { propertyName: "diagramEl", first: true, predicate: ["diagram"], descendants: true, static: true }], ngImport: i0, template: "<mat-toolbar>\r\n <button mat-icon-button (click)=\"tools = !tools\" [bizdocTooltip]=\"'Collapse' | translate\"><mat-icon>view_sidebar</mat-icon></button>\r\n <button mat-button (click)=\"save()\" color=\"primary\" [disabled]=\"!dirty || saving\">{{'SaveChanges' | translate}}</button>\r\n <button mat-icon-button (click)=\"diagram.fitToPage()\" [bizdocTooltip]=\"'FitToPage' | translate\"><mat-icon>fullscreen_exit</mat-icon></button>\r\n <button mat-icon-button (click)=\"diagram.undo()\" [bizdocTooltip]=\"'Undo' | translate\" [disabled]=\"!diagram.historyManager?.canUndo\"><mat-icon>undo</mat-icon></button>\r\n <button mat-icon-button (click)=\"diagram.redo()\" [bizdocTooltip]=\"'Redo' | translate\" [disabled]=\"!diagram.historyManager?.canRedo\"><mat-icon>redo</mat-icon></button>\r\n &nbsp;\r\n <button mat-icon-button (click)=\"pan()\" [bizdocTooltip]=\"'Pan' | translate\"><span class=\"e-icons sf-icon-pan\"></span></button>\r\n <button mat-icon-button (click)=\"cursor()\" [bizdocTooltip]=\"'Cursor' | translate\"><span class=\"e-icons sf-icon-cursor\"></span></button>\r\n <span class=\"divider\"></span>\r\n <button mat-icon-button (click)=\"addText()\" [bizdocTooltip]=\"'Text' | translate\"><mat-icon>title</mat-icon></button>\r\n <button mat-button [matMenuTriggerFor]=\"lineMenu\" [disabled]=\"!diagram.selectedItems?.connectors.length\" [bizdocTooltip]=\"'ConnectorMode'|translate\">\r\n <span class=\"e-menu-icon\" [ngClass]=\"{'sf-icon-straight-line': connectorType === 'Straight',\r\n 'sf-icon-orthogonal-line': connectorType === 'Orthogonal',\r\n 'sf-icon-beizer-line': connectorType === 'Bezier'}\"></span>\r\n <mat-icon>arrow_drop_down</mat-icon>\r\n </button>\r\n <mat-menu #lineMenu panelClass=\"icon-menu-panel\">\r\n <button mat-menu-item (click)=\"connectorTypeChange('Straight')\">\r\n <span class=\"e-menu-icon sf-icon-straight-line\"></span>\r\n </button>\r\n <button mat-menu-item (click)=\"connectorTypeChange('Orthogonal')\">\r\n <span class=\"e-menu-icon sf-icon-orthogonal-line\"></span>\r\n </button>\r\n <button mat-menu-item (click)=\"connectorTypeChange('Bezier')\">\r\n <span class=\"e-menu-icon sf-icon-beizer-line\"></span>\r\n </button>\r\n </mat-menu>\r\n &nbsp;\r\n <button mat-button [matMenuTriggerFor]=\"alignMenu\" [disabled]=\"!diagram.selectedItems?.nodes.length && !diagram.selectedItems?.connectors.length\" [bizdocTooltip]=\"'Align'|translate\">\r\n <span class=\"e-icons\" [ngClass]=\"{'sf-icon-top': alignment === 'Top',\r\n 'sf-icon-left': alignment === 'Left',\r\n 'sf-icon-center': alignment === 'Center',\r\n 'sf-icon-bottom': alignment === 'Bottom',\r\n 'sf-icon-right': alignment === 'Right'}\"></span>\r\n <mat-icon>arrow_drop_down</mat-icon>\r\n </button>\r\n <mat-menu #alignMenu panelClass=\"icon-menu-panel\">\r\n <button mat-menu-item (click)=\"align('Top')\">\r\n <span class=\"e-icons sf-icon-top\"></span>\r\n </button>\r\n <button mat-menu-item (click)=\"align('Left')\">\r\n <span class=\"e-icons sf-icon-left\"></span>\r\n </button>\r\n <button mat-menu-item (click)=\"align('Center')\">\r\n <span class=\"e-icons sf-icon-center\"></span>\r\n </button>\r\n <button mat-menu-item (click)=\"align('Bottom')\">\r\n <span class=\"e-icons sf-icon-bottom\"></span>\r\n </button>\r\n <button mat-menu-item (click)=\"align('Right')\">\r\n <span class=\"e-icons sf-icon-right\"></span>\r\n </button>\r\n </mat-menu>\r\n</mat-toolbar>\r\n<div class=\"row container\">\r\n <div id=\"symbolpalette\" [style.display]=\"tools?'':'none'\">\r\n <div dir=\"ltr\" #symbolPalette>\r\n </div>\r\n </div>\r\n <div #diagram id=\"diagram\" fxFlex dir=\"ltr\">\r\n </div>\r\n</div>\r\n", styles: [":host{display:flex;flex-direction:column;flex-grow:1;height:100%}.container{flex-grow:1;overflow-y:auto}#diagram{flex-grow:1}#symbolpalette{width:210px}::ng-deep .e-rtl{direction:ltr}::ng-deep .mat-toolbar .mat-button-toggle{background:transparent!important}.e-menu-icon{font-family:diagram-icons!important;speak:none;font-size:18px;font-style:normal;font-weight:400;font-feature-settings:normal;font-variant:normal;text-transform:none;line-height:1;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}::ng-deep .icon-menu-panel{min-width:0}\n"], components: [{ type: i7.MatToolbar, selector: "mat-toolbar", inputs: ["color"], exportAs: ["matToolbar"] }, { type: i8.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"] }, { type: i9.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i10.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { type: i10.MatMenuItem, selector: "[mat-menu-item]", inputs: ["disabled", "disableRipple", "role"], exportAs: ["matMenuItem"] }], directives: [{ type: i11.TooltipDirective, selector: "[bizdocTooltip]", inputs: ["bizdocTooltip", "bizdocTooltipTemplate", "bizdocTooltipContext", "bizdocTooltipPosition", "bizdocTooltipDuration", "bizdocTooltipDisabled"] }, { type: i10.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", exportAs: ["matMenuTrigger"] }, { type: i12.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i13.DefaultClassDirective, selector: " [ngClass], [ngClass.xs], [ngClass.sm], [ngClass.md], [ngClass.lg], [ngClass.xl], [ngClass.lt-sm], [ngClass.lt-md], [ngClass.lt-lg], [ngClass.lt-xl], [ngClass.gt-xs], [ngClass.gt-sm], [ngClass.gt-md], [ngClass.gt-lg]", inputs: ["ngClass", "ngClass.xs", "ngClass.sm", "ngClass.md", "ngClass.lg", "ngClass.xl", "ngClass.lt-sm", "ngClass.lt-md", "ngClass.lt-lg", "ngClass.lt-xl", "ngClass.gt-xs", "ngClass.gt-sm", "ngClass.gt-md", "ngClass.gt-lg"] }, { type: i14.Dir, selector: "[dir]", inputs: ["dir"], outputs: ["dirChange"], exportAs: ["dir"] }, { type: i15.DefaultFlexDirective, selector: " [fxFlex], [fxFlex.xs], [fxFlex.sm], [fxFlex.md], [fxFlex.lg], [fxFlex.xl], [fxFlex.lt-sm], [fxFlex.lt-md], [fxFlex.lt-lg], [fxFlex.lt-xl], [fxFlex.gt-xs], [fxFlex.gt-sm], [fxFlex.gt-md], [fxFlex.gt-lg]", inputs: ["fxFlex", "fxFlex.xs", "fxFlex.sm", "fxFlex.md", "fxFlex.lg", "fxFlex.xl", "fxFlex.lt-sm", "fxFlex.lt-md", "fxFlex.lt-lg", "fxFlex.lt-xl", "fxFlex.gt-xs", "fxFlex.gt-sm", "fxFlex.gt-md", "fxFlex.gt-lg"] }], pipes: { "translate": i16.TranslatePipe } });
397
430
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.5", ngImport: i0, type: WorkflowComponent, decorators: [{
398
431
  type: Component,
399
432
  args: [{ selector: 'bizdoc-workflow', host: {
400
433
  class: 'pane'
401
- }, template: "<mat-toolbar>\r\n <button mat-icon-button (click)=\"tools = !tools\" [bizdocTooltip]=\"'Collapse' | translate\"><mat-icon>view_sidebar</mat-icon></button>\r\n <button mat-button (click)=\"save()\" color=\"primary\" [disabled]=\"!dirty || saving\">{{'SaveChanges' | translate}}</button>\r\n <button mat-icon-button (click)=\"diagram.fitToPage()\" [bizdocTooltip]=\"'FitToPage' | translate\"><mat-icon>fullscreen_exit</mat-icon></button>\r\n <button mat-icon-button (click)=\"diagram.undo()\" [bizdocTooltip]=\"'Undo' | translate\" [disabled]=\"!diagram.historyManager?.canUndo\"><mat-icon>undo</mat-icon></button>\r\n <button mat-icon-button (click)=\"diagram.redo()\" [bizdocTooltip]=\"'Redo' | translate\" [disabled]=\"!diagram.historyManager?.canRedo\"><mat-icon>redo</mat-icon></button>\r\n &nbsp;\r\n <button mat-icon-button (click)=\"pan()\" [bizdocTooltip]=\"'Pan' | translate\"><span class=\"e-icons sf-icon-pan\"></span></button>\r\n <button mat-icon-button (click)=\"cursor()\" [bizdocTooltip]=\"'Cursor' | translate\"><span class=\"e-icons sf-icon-cursor\"></span></button>\r\n <span class=\"divider\"></span>\r\n <button mat-icon-button (click)=\"addText()\" [bizdocTooltip]=\"'Text' | translate\"><mat-icon>title</mat-icon></button>\r\n <button mat-button [matMenuTriggerFor]=\"lineMenu\" [disabled]=\"!diagram.selectedItems?.connectors.length\" [bizdocTooltip]=\"'ConnectorMode'|translate\">\r\n <span class=\"e-menu-icon\" [ngClass]=\"{'sf-icon-straight-line': connectorType === 'Straight',\r\n 'sf-icon-orthogonal-line': connectorType === 'Orthogonal',\r\n 'sf-icon-beizer-line': connectorType === 'Bezier'}\"></span>\r\n <mat-icon>arrow_drop_down</mat-icon>\r\n </button>\r\n <mat-menu #lineMenu panelClass=\"icon-menu-panel\">\r\n <button mat-menu-item (click)=\"connectorTypeChange('Straight')\">\r\n <span class=\"e-menu-icon sf-icon-straight-line\"></span>\r\n </button>\r\n <button mat-menu-item (click)=\"connectorTypeChange('Orthogonal')\">\r\n <span class=\"e-menu-icon sf-icon-orthogonal-line\"></span>\r\n </button>\r\n <button mat-menu-item (click)=\"connectorTypeChange('Bezier')\">\r\n <span class=\"e-menu-icon sf-icon-beizer-line\"></span>\r\n </button>\r\n </mat-menu>\r\n &nbsp;\r\n <button mat-button [matMenuTriggerFor]=\"alignMenu\" [disabled]=\"!diagram.selectedItems?.nodes.length && !diagram.selectedItems?.connectors.length\" [bizdocTooltip]=\"'Align'|translate\">\r\n <span class=\"e-icons\" [ngClass]=\"{'sf-icon-top': alignment === 'Top',\r\n 'sf-icon-left': alignment === 'Left',\r\n 'sf-icon-center': alignment === 'Center',\r\n 'sf-icon-bottom': alignment === 'Bottom',\r\n 'sf-icon-right': alignment === 'Right'}\"></span>\r\n <mat-icon>arrow_drop_down</mat-icon>\r\n </button>\r\n <mat-menu #alignMenu panelClass=\"icon-menu-panel\">\r\n <button mat-menu-item (click)=\"align('Top')\">\r\n <span class=\"e-icons sf-icon-top\"></span>\r\n </button>\r\n <button mat-menu-item (click)=\"align('Left')\">\r\n <span class=\"e-icons sf-icon-left\"></span>\r\n </button>\r\n <button mat-menu-item (click)=\"align('Center')\">\r\n <span class=\"e-icons sf-icon-center\"></span>\r\n </button>\r\n <button mat-menu-item (click)=\"align('Bottom')\">\r\n <span class=\"e-icons sf-icon-bottom\"></span>\r\n </button>\r\n <button mat-menu-item (click)=\"align('Right')\">\r\n <span class=\"e-icons sf-icon-right\"></span>\r\n </button>\r\n </mat-menu>\r\n</mat-toolbar>\r\n<div class=\"row container\">\r\n <div id=\"symbolpalette\" *ngIf=\"tools\">\r\n <ejs-symbolpalette dir=\"ltr\" expandMode='Multiple' [palettes]='palettes' width=\"100%\" height=\"100%\" [symbolHeight]=80\r\n [enableRtl]=\"false\" [enableAnimation]=\"false\" [symbolWidth]=80 [symbolMargin]='symbolMargin' [getSymbolInfo]='getSymbolInfo' [getNodeDefaults]='getSymbolDefaults'>\r\n </ejs-symbolpalette>\r\n </div>\r\n <ejs-diagram #diagram id=\"diagram\" width=\"100%\" height=\"100%\" dir=\"ltr\" [snapSettings]='snapSettings' [getConnectorDefaults]='connDefaults' fxFlex\r\n [constraints]=\"diagramConstraints\" [tool]=diagramTool [getNodeDefaults]='nodeDefaults' [getCustomTool]='getCustomTool' [scrollSettings]=\"scrollSettings\"\r\n [selectedItems]=\"selectedItems\"\r\n [rulerSettings]=\"rulerSettings\"\r\n (dragEnter)='dragEnter($event)'\r\n (connectionChange)=\"change()\"\r\n (collectionChange)=\"change()\"\r\n (propertyChange)=\"propertyChange($event)\"\r\n (selectionChange)=\"selectionChange()\"\r\n (created)=\"diagramCreate()\">\r\n </ejs-diagram>\r\n</div>\r\n", styles: [":host{display:flex;flex-direction:column;flex-grow:1;height:100%}.container{flex-grow:1;overflow-y:auto}#diagram{flex-grow:1}#symbolpalette{width:210px}::ng-deep .e-rtl{direction:ltr}::ng-deep .mat-toolbar .mat-button-toggle{background:transparent!important}.e-menu-icon{font-family:diagram-icons!important;speak:none;font-size:18px;font-style:normal;font-weight:400;font-feature-settings:normal;font-variant:normal;text-transform:none;line-height:1;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}::ng-deep .icon-menu-panel{min-width:0}\n"] }]
402
- }], ctorParameters: function () { return [{ type: i1.PromptService }, { type: i2.FormService }, { type: i3.PaneRef }, { type: i4.PanesRouter }, { type: i5.SessionService }, { type: i6.TranslateService }]; }, propDecorators: { symbolPalette: [{
434
+ }, template: "<mat-toolbar>\r\n <button mat-icon-button (click)=\"tools = !tools\" [bizdocTooltip]=\"'Collapse' | translate\"><mat-icon>view_sidebar</mat-icon></button>\r\n <button mat-button (click)=\"save()\" color=\"primary\" [disabled]=\"!dirty || saving\">{{'SaveChanges' | translate}}</button>\r\n <button mat-icon-button (click)=\"diagram.fitToPage()\" [bizdocTooltip]=\"'FitToPage' | translate\"><mat-icon>fullscreen_exit</mat-icon></button>\r\n <button mat-icon-button (click)=\"diagram.undo()\" [bizdocTooltip]=\"'Undo' | translate\" [disabled]=\"!diagram.historyManager?.canUndo\"><mat-icon>undo</mat-icon></button>\r\n <button mat-icon-button (click)=\"diagram.redo()\" [bizdocTooltip]=\"'Redo' | translate\" [disabled]=\"!diagram.historyManager?.canRedo\"><mat-icon>redo</mat-icon></button>\r\n &nbsp;\r\n <button mat-icon-button (click)=\"pan()\" [bizdocTooltip]=\"'Pan' | translate\"><span class=\"e-icons sf-icon-pan\"></span></button>\r\n <button mat-icon-button (click)=\"cursor()\" [bizdocTooltip]=\"'Cursor' | translate\"><span class=\"e-icons sf-icon-cursor\"></span></button>\r\n <span class=\"divider\"></span>\r\n <button mat-icon-button (click)=\"addText()\" [bizdocTooltip]=\"'Text' | translate\"><mat-icon>title</mat-icon></button>\r\n <button mat-button [matMenuTriggerFor]=\"lineMenu\" [disabled]=\"!diagram.selectedItems?.connectors.length\" [bizdocTooltip]=\"'ConnectorMode'|translate\">\r\n <span class=\"e-menu-icon\" [ngClass]=\"{'sf-icon-straight-line': connectorType === 'Straight',\r\n 'sf-icon-orthogonal-line': connectorType === 'Orthogonal',\r\n 'sf-icon-beizer-line': connectorType === 'Bezier'}\"></span>\r\n <mat-icon>arrow_drop_down</mat-icon>\r\n </button>\r\n <mat-menu #lineMenu panelClass=\"icon-menu-panel\">\r\n <button mat-menu-item (click)=\"connectorTypeChange('Straight')\">\r\n <span class=\"e-menu-icon sf-icon-straight-line\"></span>\r\n </button>\r\n <button mat-menu-item (click)=\"connectorTypeChange('Orthogonal')\">\r\n <span class=\"e-menu-icon sf-icon-orthogonal-line\"></span>\r\n </button>\r\n <button mat-menu-item (click)=\"connectorTypeChange('Bezier')\">\r\n <span class=\"e-menu-icon sf-icon-beizer-line\"></span>\r\n </button>\r\n </mat-menu>\r\n &nbsp;\r\n <button mat-button [matMenuTriggerFor]=\"alignMenu\" [disabled]=\"!diagram.selectedItems?.nodes.length && !diagram.selectedItems?.connectors.length\" [bizdocTooltip]=\"'Align'|translate\">\r\n <span class=\"e-icons\" [ngClass]=\"{'sf-icon-top': alignment === 'Top',\r\n 'sf-icon-left': alignment === 'Left',\r\n 'sf-icon-center': alignment === 'Center',\r\n 'sf-icon-bottom': alignment === 'Bottom',\r\n 'sf-icon-right': alignment === 'Right'}\"></span>\r\n <mat-icon>arrow_drop_down</mat-icon>\r\n </button>\r\n <mat-menu #alignMenu panelClass=\"icon-menu-panel\">\r\n <button mat-menu-item (click)=\"align('Top')\">\r\n <span class=\"e-icons sf-icon-top\"></span>\r\n </button>\r\n <button mat-menu-item (click)=\"align('Left')\">\r\n <span class=\"e-icons sf-icon-left\"></span>\r\n </button>\r\n <button mat-menu-item (click)=\"align('Center')\">\r\n <span class=\"e-icons sf-icon-center\"></span>\r\n </button>\r\n <button mat-menu-item (click)=\"align('Bottom')\">\r\n <span class=\"e-icons sf-icon-bottom\"></span>\r\n </button>\r\n <button mat-menu-item (click)=\"align('Right')\">\r\n <span class=\"e-icons sf-icon-right\"></span>\r\n </button>\r\n </mat-menu>\r\n</mat-toolbar>\r\n<div class=\"row container\">\r\n <div id=\"symbolpalette\" [style.display]=\"tools?'':'none'\">\r\n <div dir=\"ltr\" #symbolPalette>\r\n </div>\r\n </div>\r\n <div #diagram id=\"diagram\" fxFlex dir=\"ltr\">\r\n </div>\r\n</div>\r\n", styles: [":host{display:flex;flex-direction:column;flex-grow:1;height:100%}.container{flex-grow:1;overflow-y:auto}#diagram{flex-grow:1}#symbolpalette{width:210px}::ng-deep .e-rtl{direction:ltr}::ng-deep .mat-toolbar .mat-button-toggle{background:transparent!important}.e-menu-icon{font-family:diagram-icons!important;speak:none;font-size:18px;font-style:normal;font-weight:400;font-feature-settings:normal;font-variant:normal;text-transform:none;line-height:1;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}::ng-deep .icon-menu-panel{min-width:0}\n"] }]
435
+ }], ctorParameters: function () { return [{ type: i1.PromptService }, { type: i2.FormService }, { type: i3.PaneRef }, { type: i4.PanesRouter }, { type: i5.SessionService }, { type: i6.TranslateService }]; }, propDecorators: { symbolPaletteEl: [{
403
436
  type: ViewChild,
404
- args: [SymbolPaletteComponent]
405
- }], diagram: [{
437
+ args: ['symbolPalette', { static: true }]
438
+ }], diagramEl: [{
406
439
  type: ViewChild,
407
- args: ['diagram']
440
+ args: ['diagram', { static: true }]
408
441
  }], handleKeyboardEvent: [{
409
442
  type: HostListener,
410
443
  args: ['document:keydown', ['$event']]
411
444
  }] } });
412
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"workflow.component.js","sourceRoot":"","sources":["../../../../../../../libraries/core/src/lib/admin/form/workflow/workflow.component.ts","../../../../../../../libraries/core/src/lib/admin/form/workflow/workflow.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,SAAS,EAAa,YAAY,EAAE,MAAM,eAAe,CAAC;AAC9E,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAC/B,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAC3C,OAAO,EACL,sBAAsB,EAAE,kBAAkB,EAAmB,mBAAmB,EAA4C,oBAAoB,EAA+C,eAAe,EAC9M,OAAO,EAAa,QAAQ,EAAmE,IAAI,EAA0B,YAAY,EAAE,oBAAoB,EAChK,MAAM,kCAAkC,CAAC;AAQ1C,OAAO,EAAE,qBAAqB,EAAE,MAAM,kBAAkB,CAAC;AAEzD,OAAO,EAAE,UAAU,EAAE,MAAM,6BAA6B,CAAC;;;;;;;;;;;;;;;;;;;AAEzD,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;AAEzB,SAAS,QAAQ;IACf,MAAM,KAAK,GAAqB;QAC9B,EAAE,EAAE,EAAE,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,GAAG,EAAE,EAAE;QAC1D,EAAE,EAAE,EAAE,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE;QAC1D,EAAE,EAAE,EAAE,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,GAAG,EAAE,EAAE;QAC1D,EAAE,EAAE,EAAE,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE;KAC3D,CAAC;IACF,OAAO,KAAK,CAAC;AACf,CAAC;AAED,SAAS,eAAe;IACtB,MAAM,YAAY,GAAgB,QAAQ,CAAC,cAAc,CAAC,eAAe,CAAC,CAAC;IAC3E,MAAM,QAAQ,GAAG,MAAM,CAAC,UAAU,CAAC,mBAAmB,CAAC,CAAC,OAAO,CAAC;IAChE,IAAI,QAAQ,EAAE;QACZ,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,QAAQ,CAAC,wBAAwB,CAAC,EAAE;YAC9D,YAAY,CAAC,SAAS,CAAC,GAAG,CAAC,wBAAwB,CAAC,CAAC;SACtD;aAAM;YACL,YAAY,CAAC,SAAS,CAAC,MAAM,CAAC,wBAAwB,CAAC,CAAC;SACzD;KACF;AACH,CAAC;AAED,SAAS,gBAAgB;IACvB,MAAM,QAAQ,GAAG,MAAM,CAAC,UAAU,CAAC,mBAAmB,CAAC,CAAC,OAAO,CAAC;IAChE,IAAI,QAAQ,EAAE;QACZ,MAAM,WAAW,GAAG,QAAQ,CAAC,cAAc,CAAC,cAAc,CAAC,CAAC;QAC5D,IAAI,WAAW,EAAE;YACf,WAAW,CAAC,gBAAgB,CAAC,OAAO,EAAE,eAAe,EAAE,KAAK,CAAC,CAAC;SAC/D;KACF;AACH,CAAC;AAED,kBAAkB;AAClB,MAAM,QAAS,SAAQ,oBAAoB;IAYzC,YAAoB,OAAgB,EAAU,QAAkB;QAC9D,KAAK,CAAC,OAAO,CAAC,cAAc,EAAE,oBAAoB,EAAE,IAAI,CAAC,CAAC;QADxC,YAAO,GAAP,OAAO,CAAS;QAAU,aAAQ,GAAR,QAAQ,CAAU;IAEhE,CAAC;IAbM,SAAS,CAAC,IAAoB;QACnC,IAAI,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,KAAK,CAAC,MAAM,EAAE;YAC3C,IAAI,CAAC,OAAO,CAAC,aAAa,GAAG;gBAC3B,IAAI,EAAE,IAAI,CAAC,QAAQ,IAAI,QAAQ;gBAC/B,QAAQ,EAAE,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE;aACjD,CAAC;YACF,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;SACtB;QACD,MAAM,EAAE,GAAG,KAAK,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QACjC,OAAO,EAAE,CAAC;IACZ,CAAC;CAIF;AACD,MAAM,SAAS,GAAG,sgCAAsgC,CAAC;AAUzhC,wBAAwB;AACxB,MAAM,OAAO,iBAAiB;IAkD5B,oBAAoB;IACpB,YAAoB,EAAiB,EAC3B,QAAqB,EACrB,KAAiC,EACjC,OAAoB,EACpB,QAAwB,EACxB,UAA4B;QALlB,OAAE,GAAF,EAAE,CAAe;QAC3B,aAAQ,GAAR,QAAQ,CAAa;QACrB,UAAK,GAAL,KAAK,CAA4B;QACjC,YAAO,GAAP,OAAO,CAAa;QACpB,aAAQ,GAAR,QAAQ,CAAgB;QACxB,eAAU,GAAV,UAAU,CAAkB;QArDtC,UAAK,GAAG,IAAI,CAAC;QACb,kBAAa,GAAa,QAAQ,CAAC;QACnC,cAAS,GAAqB,QAAQ,CAAC;QACvC,aAAQ,GAAG,EAAE,CAAC;QACP,kBAAa,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAO/C,WAAM,GAAG,KAAK,CAAC;QAEf,UAAK,GAAG,KAAK,CAAC;QAEd,aAAQ,GAAmB,EAAE,CAAC;QAC9B,uBAAkB,GAAuB,kBAAkB,CAAC,OAAO,GAAG,kBAAkB,CAAC,QAAQ,GAAG,kBAAkB,CAAC,eAAe,GAAG,kBAAkB,CAAC,IAAI,CAAC;QACjK,gBAAW,GAAiB,YAAY,CAAC,OAAO,CAAC;QACjD,yDAAyD;QACxC,iBAAY,GAAsB;YACjD;gBACE,IAAI,EAAE,SAAS;gBACf,QAAQ,EAAE,SAAS;gBACnB,OAAO,EAAE,IAAI;gBACb,MAAM,EAAE,CAAC;gBACT,IAAI,EAAE,OAAO;gBACb,YAAY,EAAE,EAAE;gBAChB,MAAM,EAAE,EAAE,GAAG,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE;aACjD;SACF,CAAC;QACF,0BAA0B;QACjB,iBAAY,GAAgB,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,CAAC;QACzE,iBAAY,GAAsB,EAC1C,CAAC;QACO,kBAAa,GAAkB,EACvC,CAAC;QACO,mBAAc,GAAwB;YAC7C,OAAO,EAAE,EAAE;YACX,OAAO,EAAE,GAAG;SACb,CAAC;QACM,gBAAW,GAAG,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;QAC1C,kBAAa,GAAuB;YAC3C,eAAe,EAAE,EAAE,WAAW,EAAE,IAAI,CAAC,WAAW,EAAE;YAClD,aAAa,EAAE,EAAE,WAAW,EAAE,IAAI,CAAC,WAAW,EAAE;SACjD,CAAC;QAEe,aAAQ,GAAG,IAAI,OAAO,EAAQ,CAAC;QAuEhD,iBAAY,GAAG,GAAc,EAAE;YAC7B,MAAM,GAAG,GAAc;gBACrB,KAAK,EAAE;oBACL,IAAI,EAAE,aAAa;oBACnB,WAAW,EAAE,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,OAAO;oBACzD,WAAW,EAAE,CAAC;iBACf;gBACD,WAAW,EAAE,CAAC;wBACZ,KAAK,EAAE;4BACL,KAAK,EAAE,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,OAAO;4BACnD,IAAI,EAAE,aAAa;4BACnB,OAAO,EAAE,EAAE;yBACZ;qBACF,CAAC;aACH,CAAC;YACF,IAAI,GAAG,CAAC,KAAK,KAAK,SAAS,EAAE;gBAC3B,GAAG,CAAC,KAAK,GAAG,GAAG,CAAC;aACjB;iBAAM;gBACL,MAAM,KAAK,GAAW,GAAG,GAAG,GAAG,CAAC,KAAK,CAAC;gBACtC,GAAG,CAAC,KAAK,GAAG,GAAG,CAAC;gBAChB,GAAG,CAAC,MAAM,IAAI,KAAK,CAAC;aACrB;YACD,GAAG,CAAC,WAAW,GAAG,eAAe,CAAC,OAAO,GAAG,eAAe,CAAC,WAAW,CAAC;YACxE,GAAG,CAAC,KAAK,GAAG,QAAQ,EAAE,CAAC;YACvB,OAAO,GAAG,CAAC;QACb,CAAC,CAAA;QACM,iBAAY,GAAG,CAAC,GAAmB,EAAQ,EAAE;YAClD,GAAG,CAAC,WAAW,GAAG,oBAAoB,CAAC,OAAO,GAAG,oBAAoB,CAAC,QAAQ,GAAG,oBAAoB,CAAC,gBAAgB,CAAC;YACvH,GAAG,CAAC,KAAK,CAAC,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC;QACvE,CAAC,CAAA;QA5FC,IAAI,CAAC,SAAS,EAAE,CAAC;IACnB,CAAC;IAlDM,OAAO,CAAC,MAAc;QAC3B,IAAI,IAAI,GAAa,IAAI,CAAC;QAC1B,IAAI,MAAM,KAAK,SAAS;YACtB,IAAI,GAAG,IAAI,QAAQ,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;QACxD,OAAO,IAAI,CAAC;IACd,CAAC;IA8CM,aAAa;QAClB,gBAAgB,EAAE,CAAC;QACnB,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE;YACnE,MAAM,EAAE,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC;YACnB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,EAAE,CAAC,CAAC;YAClE,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC;YACpC,IAAI,CAAC,MAAM,GAAG,EAAE,EAAE,EAAE,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC;QACxC,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE;YACjE,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC;YAClC,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC;YACjC,IAAI,CAAC,OAAO,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC;YAChC,IAAI,CAAC,OAAO,CAAC,UAAU,GAAG,IAAI,CAAC,UAAU,CAAC;YAC1C,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC;YACxB,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC;YAClD,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE,CAAC;YACzB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACrB,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE,CAC9D,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC,CAAC;IAC5B,CAAC;IACO,SAAS;QACf,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE;YACtC,MAAM,IAAI,GAAc;gBACtB,EAAE,EAAE,CAAC,CAAC,IAAI;gBACV,KAAK,EAAE,CAAC,CAAC,KAAK;gBACd,OAAO,EAAE;oBACP,QAAQ,EAAE,CAAC,CAAC,IAAI;oBAChB,KAAK,EAAE,CAAC,CAAC,KAAK;iBACf;aACF,CAAC;YACD,IAAY,CAAC,IAAI,GAAG,CAAC,CAAC,IAAI,CAAC;YAC5B,IAAI,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,CAAC,CAAC,CAAC,OAAO,IAAI,EAAE,CAAC,CAAC,CAAC;YACrE,IAAI,CAAC,OAAO,EAAE;gBACZ,OAAO,GAAG,EAAE,EAAE,EAAE,IAAI,CAAC,CAAC,OAAO,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC,OAAO,IAAI,EAAE,EAAE,OAAO,EAAE,EAAE,EAAE,CAAC;gBACvF,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;aAC7B;YACD,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC7B,CAAC,CAAC,CAAC;QACH,wMAAwM;QACxM,kCAAkC;IACpC,CAAC;IAEO,YAAY,CAAC,OAAe;QAClC,OAAO;YACL,EAAE,EAAE,SAAS;YACb,KAAK,EAAE;gBACL,IAAI,EAAE,MAAM;gBACZ,OAAO,EAAE,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,gBAAgB,EAAE,OAAO,IAAI,CAAC,CAAC;aAC7D;YACD,OAAO,EAAE,CAAC;YACV,OAAO,EAAE,CAAC;YACV,KAAK,EAAE;gBACL,QAAQ,EAAE,EAAE;gBACZ,KAAK,EAAE,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,OAAO;gBACnD,OAAO,EAAE,EAAE;aACM;YACnB,WAAW,EAAE,eAAe,CAAC,QAAQ;YACrC,MAAM,EAAE,CAAC,CAAC;SACE,CAAC;IACjB,CAAC;IA+BM,aAAa,CAAC,MAAiB;QACpC,OAAO;YACL,GAAG,EAAE,IAAI;YACT,OAAO,EAAG,MAAM,CAAC,OAAe,CAAC,KAAK;YACtC,WAAW,EAAE,EAAE,IAAI,EAAG,MAAM,CAAC,OAAe,CAAC,KAAK,EAAE,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,kBAAkB,EAAE;SACjG,CAAC;IACJ,CAAC;IACM,iBAAiB,CAAC,MAAiB;QACxC,MAAM,CAAC,KAAK,GAAG,MAAM,CAAC,MAAM,GAAG,EAAE,CAAC;QAClC,MAAM,CAAC,WAAW,GAAG,eAAe,CAAC,OAAO,GAAG,eAAe,CAAC,WAAW,CAAC;IAC7E,CAAC;IACD,GAAG;QACD,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,kBAAkB,GAAG,kBAAkB,CAAC,GAAG,CAAC;QAC3E,IAAI,CAAC,WAAW,GAAG,YAAY,CAAC,OAAO,CAAC;IAC1C,CAAC;IACD,MAAM;QACJ,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,kBAAkB,GAAG,CAAC,kBAAkB,CAAC,GAAG,CAAC;QAC5E,IAAI,CAAC,WAAW,GAAG,YAAY,CAAC,OAAO,CAAC;IAC1C,CAAC;IACD,eAAe;QACb,MAAM,EAAE,KAAK,EAAE,UAAU,EAAE,GAAG,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC;QACzD,IAAI,UAAU,CAAC,MAAM,IAAI,KAAK,CAAC,MAAM,EAAE;YACrC,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,IAAI,KAAK,CAAC,CAAC,CAAC,CAAC,OAAO,EAAE;gBAC1C,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,WAAW,GAAG,mBAAmB,CAAC,GAAG,GAAG,mBAAmB,CAAC,UAAU,CAAC;gBAClG,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,WAAW,GAAG,IAAI,CAAC,YAAY,CAAC;aAC5D;;gBACI,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,WAAW,GAAG,mBAAmB,CAAC,GAAG,GAAG,mBAAmB,CAAC,UAAU,CAAC;YAEvG,IAAI,UAAU,CAAC,MAAM,EAAE;gBACrB,MAAM,SAAS,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC;gBAChC,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,GAAG,IAAI,CAAC,CAAC,CAAC,OAAO;oBAAE,CAAC,CAAC,OAAO,GAAG,EAAE,CAAA,CAAC,CAAC,CAAC,CAAC;gBAC5D,MAAM,IAAI,GAAG,SAAS,CAAC,IAAI,CAAC;gBAC5B,IAAI,CAAC,aAAa,GAAG,UAAU,CAAC,MAAM,KAAK,CAAC,IAAI,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC;gBACrG,IAAI,SAAS,CAAC,WAAW,CAAC,MAAM;oBAC9B,IAAI,CAAC,QAAQ,GAAG,SAAS,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,QAAQ,CAAC;gBAC1D,IAAI,CAAC,aAAa,GAAG,UAAU,CAAC,MAAM,KAAK,CAAC,IAAI,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC;aACtG;YACD,IAAI,KAAK,CAAC,MAAM,EAAE;gBAChB,MAAM,IAAI,GAAG,KAAK,CAAC,CAAC,CAAC,EACnB,OAAO,GAAG,IAAI,CAAC,OAAc,CAAC;gBAChC,IAAI,OAAO,IAAI,OAAO,CAAC,QAAQ,EAAE;oBAC/B,IAAI,IAAI,CAAC,WAAW,CAAC,MAAM;wBACzB,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,QAAQ,CAAC;iBACtD;aACF;YACD,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAA;YACvB,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,qBAAqB,EAAE;gBAC3C,KAAK,EAAE;oBACL,KAAK,EAAE,UAAU;iBAClB;gBACD,MAAM,EAAE,UAAU,CAAC,GAAG;gBACtB,UAAU,EAAE,KAAK;gBACjB,KAAK,EAAE,EAAE;aACV,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE;gBACT,CAAC,CAAC,QAAkC,CAAC,MAAM;oBAC1C,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;oBAC5C,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;oBAClB,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC;gBAC1B,CAAC,CAAC,CAAC;YACP,CAAC,CAAC,CAAC;SACJ;;YAEC,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC;IAC5B,CAAC;IACD,KAAK,CAAC,KAAuB;QAC3B,SAAS,KAAK,CAAC,CAA6B;YAC1C,CAAC,CAAC,WAAW,CAAC,MAAM,IAAI,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,EAAE;gBACtD,MAAM,EAAE;oBACN,CAAC,EAAE,KAAK,KAAK,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,KAAK,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE;oBACpD,CAAC,EAAE,KAAK,KAAK,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,KAAK,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE;iBACrD;gBACD,iBAAiB,EAAE,KAAK,KAAK,KAAK,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAK,KAAK,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,QAAQ;gBACrF,mBAAmB,EAAE,KAAK,KAAK,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,KAAK,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,QAAQ;aACxF,CAAC,CAAC;QACL,CAAC;QACD,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QAChD,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,UAAU,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QACrD,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QACvB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;IACpB,CAAC;IACM,SAAS,CAAC,IAAyB;QACxC,MAAM,GAAG,GAAc,IAAI,CAAC,OAAoB,CAAC;QACjD,IAAI,GAAG,YAAY,IAAI,EAAE;YACvB,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,GAAG,GAAG,CAAC;YAC9B,GAAG,CAAC,KAAK,GAAG,GAAG,CAAC;YAChB,GAAG,CAAC,MAAM,IAAI,GAAG,GAAG,KAAK,CAAC;YAC1B,GAAG,CAAC,OAAO,IAAI,CAAC,GAAG,CAAC,KAAK,GAAG,KAAK,CAAC,GAAG,CAAC,CAAC;YACvC,GAAG,CAAC,OAAO,IAAI,CAAC,GAAG,CAAC,MAAM,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC;YACzC,GAAG,CAAC,KAAK,GAAG,EAAE,IAAI,EAAE,OAAO,EAAE,WAAW,EAAE,OAAO,EAAE,CAAC;SACrD;IACH,CAAC;IACD,cAAc,CAAC,CAAC;QACd,IAAI,CAAC,CAAC,KAAK,KAAK,CAAC;YAAE,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;IACvC,CAAC;IACD,MAAM;QACJ,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;IACpB,CAAC;IACD,OAAO;QACL,IAAI,CAAC,OAAO,CAAC,aAAa,GAAG;YAC3B,KAAK,EAAE;gBACL,IAAI,EAAE,MAAM;aACb;YACD,WAAW,EAAE,eAAe,CAAC,OAAO,GAAG,CAAC,eAAe,CAAC,SAAS,GAAG,CAAC,eAAe,CAAC,UAAU;SACnF,CAAC;QACf,IAAI,CAAC,WAAW,GAAG,YAAY,CAAC,QAAQ,CAAC;IAC3C,CAAC;IACD;;;OAGG;IAEH,mBAAmB,CAAC,KAAoB;QACtC,IAAI,IAAI,CAAC,KAAK,IAAI,KAAK,CAAC,OAAO,IAAI,CAAC,KAAK,CAAC,KAAK,KAAK,EAAE,IAAI,KAAK,CAAC,KAAK,KAAK,GAAG,CAAC,EAAE;YAC9E,IAAI,CAAC,IAAI,EAAE,CAAC;YACZ,KAAK,CAAC,cAAc,EAAE,CAAC;SACxB;IACH,CAAC;IACD,QAAQ,CAAC,GAAW;QAClB,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,GAAG,GAAG,CAAC,CAAC;QAClE,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;IACpB,CAAC;IACD,WAAW,CAAC,GAAW;QACrB,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,GAAG,GAAG,CAAC,CAAC,CAAC;QAC/F,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,GAAG,GAAG,CAAC,CAAC,CAAC;QACpG,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;IACpB,CAAC;IACD,mBAAmB,CAAC,IAAc;QAChC,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,GAAG,IAAI,CAAC,CAAC;QAClE,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;QAC1B,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;IACpB,CAAC;IACD,UAAU,CAAC,GAAW;QACpB,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,QAAQ,GAAG,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QAC5G,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC;IAC1B,CAAC;IACD,YAAY,CAAC,GAAW;QACtB,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE;YAChD,CAAC,CAAC,KAAK,CAAC,WAAW,GAAG,GAAG,CAAC;YAC1B,IAAI,CAAC,CAAC,WAAW;gBAAE,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,GAAG,GAAG,CAAC;QACxD,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,WAAW,GAAG,GAAG,CAAC,CAAC;QACzE,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;IACpB,CAAC;IACD,IAAI;QACF,IAAI,CAAC,OAAO,CAAC,qBAAqB,GAAG,EAAE,CAAC;QACxC,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE,CAAC,CAAC;QACnD,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,UAAU,GAAG,GAAG,CAAC,UAAU,CAAC;QAChD,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,KAAK,GAAG,GAAG,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,SAAS,CAAC,CAAC,GAAG,CAAC,CAAC,CAAY,EAAE,EAAE;YACzF,CAAC,CAAC,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC;YAClC,CAAC,CAAC,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC;YAClC,OAAO,CAAC,CAAC;QACX,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;QACnB,OAAO,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,SAAS,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE;YACzD,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,cAAc,CAAC,CAAC;YAC9B,IAAI,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,OAAO,GAAG,CAAC,EAAE;gBACnC,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,gBAAgB,EAAE,CAAC,CAAC,CAAC;gBACnC,MAAM,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC;gBAClD,IAAI,CAAC,KAAmB,CAAC,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,gBAAgB,EAAE,CAAC,CAAC,CAAC;gBAC7E,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC;aACzB;YACD,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,OAAO,GAAG,CAAC,CAAC;YAChC,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;YACnB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACtB,CAAC,EAAE,GAAG,EAAE;YACN,IAAI,CAAC,EAAE,CAAC,KAAK,EAAE,CAAC;YAChB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACtB,CAAC,CAAC,CAAC;IACL,CAAC;IACD,WAAW;QACT,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;QACrB,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;IAC3B,CAAC;;8GAlUU,iBAAiB;kGAAjB,iBAAiB,0MACjB,sBAAsB,qICjFnC,0sJAyEA;2FDOa,iBAAiB;kBAT7B,SAAS;+BACE,iBAAiB,QAGrB;wBACJ,KAAK,EAAE,MAAM;qBACd;0OAIkC,aAAa;sBAA/C,SAAS;uBAAC,sBAAsB;gBACX,OAAO;sBAA5B,SAAS;uBAAC,SAAS;gBAmQpB,mBAAmB;sBADlB,YAAY;uBAAC,kBAAkB,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["import { Component, ViewChild, OnDestroy, HostListener } from '@angular/core';\r\nimport { Subject } from 'rxjs';\r\nimport { takeUntil } from 'rxjs/operators';\r\nimport {\r\n  SymbolPaletteComponent, DiagramConstraints, UserHandleModel, SelectorConstraints, ToolBase, MouseEventArgs, ConnectorModel, ConnectorDrawingTool, TextModel, PointPortModel, DiagramComponent, NodeConstraints, ScrollSettingsModel,\r\n  Diagram, NodeModel, UndoRedo, SymbolInfo, IDragEnterEventArgs, SnapSettingsModel, MarginModel, Node, PaletteModel, Segments, DiagramTools, ConnectorConstraints, SelectorModel, RulerSettingsModel, AlignmentOptions, TextStyleModel\r\n} from '@syncfusion/ej2-angular-diagrams';\r\nimport { Form } from '../../../core/models';\r\nimport { SessionService } from '../../../core/session.service';\r\nimport { FormService } from '../form.service';\r\nimport { PromptService } from '../../../core/prompt.service';\r\nimport { TranslateService } from '../../../core/translate.service';\r\nimport { PaneRef } from '../../../core/slots/pane-ref';\r\nimport { PanesRouter } from '../../../core/slots/router.service';\r\nimport { WorkflowNodeComponent } from './node.component';\r\nimport { AdminComponent } from '../../admin-dismiss.service';\r\nimport { OpenPolicy } from '../../../core/configuration';\r\n\r\nDiagram.Inject(UndoRedo);\r\n\r\nfunction getPorts(): PointPortModel[] {\r\n  const ports: PointPortModel[] = [\r\n    { id: 'port1', shape: 'Circle', offset: { x: 0, y: 0.5 } },\r\n    { id: 'port2', shape: 'Circle', offset: { x: 0.5, y: 1 } },\r\n    { id: 'port3', shape: 'Circle', offset: { x: 1, y: 0.5 } },\r\n    { id: 'port4', shape: 'Circle', offset: { x: 0.5, y: 0 } }\r\n  ];\r\n  return ports;\r\n}\r\n\r\nfunction showPaletteIcon(): void {\r\n  const paletteSpace: HTMLElement = document.getElementById('palette-space');\r\n  const isMobile = window.matchMedia('(max-width:550px)').matches;\r\n  if (isMobile) {\r\n    if (!paletteSpace.classList.contains('sb-mobile-palette-open')) {\r\n      paletteSpace.classList.add('sb-mobile-palette-open');\r\n    } else {\r\n      paletteSpace.classList.remove('sb-mobile-palette-open');\r\n    }\r\n  }\r\n}\r\n\r\nfunction paletteIconClick() {\r\n  const isMobile = window.matchMedia('(max-width:550px)').matches;\r\n  if (isMobile) {\r\n    const paletteIcon = document.getElementById('palette-icon');\r\n    if (paletteIcon) {\r\n      paletteIcon.addEventListener('click', showPaletteIcon, false);\r\n    }\r\n  }\r\n}\r\n\r\n//Defines the tool\r\nclass DrawTool extends ConnectorDrawingTool {\r\n  public mouseMove(args: MouseEventArgs): boolean {\r\n    if (this.diagram.selectedItems.nodes.length) {\r\n      this.diagram.drawingObject = {\r\n        type: this.segments || 'Bezier',\r\n        sourceID: this.diagram.selectedItems.nodes[0].id\r\n      };\r\n      this.inAction = true;\r\n    }\r\n    const ok = super.mouseMove(args);\r\n    return ok;\r\n  }\r\n  constructor(private diagram: Diagram, private segments: Segments) {\r\n    super(diagram.commandHandler, 'ConnectorSourceEnd', null);\r\n  }\r\n}\r\nconst LINK_PATH = 'M346.7,714.6l368.1-368.1c17.9-17.9,17.9-47.1,0-64.9c-17.9-17.9-47.1-17.9-64.9,0l-368,368c-17.9,17.9-17.9,47.1,0,64.9C299.6,732.5,328.9,732.5,346.7,714.6z M468.2,651c6.4,9,7.6,18.5,7.6,23.8c0,6.3-1.5,18.6-11.8,28.9L271,896.5c-10.3,10.3-22.5,11.8-28.9,11.8c-6.3,0-18.6-1.5-28.9-11.8L103.5,786.8c-10.3-10.3-11.8-22.5-11.8-28.9c0-6.4,1.5-18.6,11.8-28.9l192.9-192.9c10.3-10.3,22.5-11.8,28.9-11.8c4.5,0,11.8,0.8,19.3,4.8l58.6-58.6c-48-39.6-119.6-36.9-164.5,7.9L45.7,671.3c-47.7,47.7-47.7,125.5,0,173.2l109.7,109.7c47.7,47.7,125.5,47.7,173.2,0l192.9-192.9c46-46,47.6-120.4,4.6-168.4L468.2,651z M954.2,155.5L844.5,45.8C796.9-1.9,719-1.9,671.3,45.8L478.4,238.7c-44.8,44.8-47.5,116.5-7.9,164.5l58.6-58.6c-4-7.6-4.8-14.9-4.8-19.3c0-6.3,1.5-18.6,11.8-28.9l192.9-192.9c10.3-10.3,22.5-11.8,28.9-11.8c6.3,0,18.6,1.5,28.9,11.8l109.7,109.7c10.3,10.3,11.8,22.5,11.8,28.9c0,6.3-1.5,18.6-11.8,28.9L703.7,464c-10.3,10.3-22.5,11.8-28.9,11.8c-5.3,0-14.8-1.1-23.8-7.6l-58,58c48,43,122.3,41.5,168.4-4.6l192.9-192.9C1001.9,281.1,1001.9,203.1,954.2,155.5z';\r\n\r\n@Component({\r\n  selector: 'bizdoc-workflow',\r\n  templateUrl: './workflow.component.html',\r\n  styleUrls: ['./workflow.component.scss'],\r\n  host: {\r\n    class: 'pane'\r\n  }\r\n})\r\n/** workflow component*/\r\nexport class WorkflowComponent implements OnDestroy, AdminComponent {\r\n  @ViewChild(SymbolPaletteComponent) symbolPalette: SymbolPaletteComponent;\r\n  @ViewChild('diagram') diagram: DiagramComponent;\r\n  tools = true;\r\n  connectorType: Segments = 'Bezier';\r\n  alignment: AlignmentOptions = 'Center';\r\n  fontSize = 12;\r\n  public getCustomTool = this.getTool.bind(this);\r\n  public getTool(action: string): ToolBase {\r\n    let tool: ToolBase = null;\r\n    if (action === 'connect')\r\n      tool = new DrawTool(this.diagram, this.connectorType);\r\n    return tool;\r\n  }\r\n  saving = false;\r\n  element?: any;\r\n  dirty = false;\r\n  params: {};\r\n  palettes: PaletteModel[] = [];\r\n  diagramConstraints: DiagramConstraints = DiagramConstraints.Default | DiagramConstraints.Bridging | DiagramConstraints.UserInteraction | DiagramConstraints.Zoom;\r\n  diagramTool: DiagramTools = DiagramTools.Default;\r\n  //Defines the user handle collection for nodes in diagram\r\n  private readonly _userHandles: UserHandleModel[] = [\r\n    {\r\n      name: 'connect',\r\n      pathData: LINK_PATH,\r\n      visible: true,\r\n      offset: 0,\r\n      side: 'Right',\r\n      displacement: 20,\r\n      margin: { top: 0, bottom: 0, left: 0, right: 0 }\r\n    }\r\n  ];\r\n  //SymbolPalette Properties\r\n  readonly symbolMargin: MarginModel = { left: 10, right: 10, top: 10, bottom: 10 };\r\n  readonly snapSettings: SnapSettingsModel = {\r\n  };\r\n  readonly selectedItems: SelectorModel = {\r\n  };\r\n  readonly scrollSettings: ScrollSettingsModel = {\r\n    minZoom: .5,\r\n    maxZoom: 2.5\r\n  };\r\n  private _rulerColor = this._session.getAccent(100);\r\n  readonly rulerSettings: RulerSettingsModel = {\r\n    horizontalRuler: { markerColor: this._rulerColor },\r\n    verticalRuler: { markerColor: this._rulerColor }\r\n  };\r\n  private _form: Form;\r\n  private readonly _destroy = new Subject<void>();\r\n  /** workflow ctor */\r\n  constructor(private ps: PromptService,\r\n    private _service: FormService,\r\n    private _pane: PaneRef<WorkflowComponent>,\r\n    private _router: PanesRouter,\r\n    private _session: SessionService,\r\n    private _translate: TranslateService) {\r\n    this._palettes();\r\n  }\r\n  public diagramCreate(): void {\r\n    paletteIconClick();\r\n    this._pane.paramsChange.pipe(takeUntil(this._destroy)).subscribe(p => {\r\n      const id = p['id'];\r\n      this._form = this._session.profile.forms.find(f => f.name === id);\r\n      this._pane.title = this._form.title;\r\n      this.params = { id: this._form.name };\r\n    });\r\n    this._pane.dataChange.pipe(takeUntil(this._destroy)).subscribe(d => {\r\n      Object.assign(this._form, d.form);\r\n      const flow = this._form.workflow;\r\n      this.diagram.nodes = flow.nodes;\r\n      this.diagram.connectors = flow.connectors;\r\n      this.diagram.dataBind();\r\n      this.diagram.add(this._versionNode(flow.version));\r\n      this.diagram.fitToPage();\r\n      this.dirty = false;\r\n    });\r\n    this._pane.resize.pipe(takeUntil(this._destroy)).subscribe(() =>\r\n      this.diagram.refresh());\r\n  }\r\n  private _palettes() {\r\n    this._session.profile.nodes.forEach(n => {\r\n      const node: NodeModel = {\r\n        id: n.name,\r\n        shape: n.shape,\r\n        addInfo: {\r\n          nodeType: n.name,\r\n          title: n.title\r\n        }\r\n      };\r\n      (node as any).node = n.name;\r\n      let palette = this.palettes.find(p => p.title === (n.palette || ''));\r\n      if (!palette) {\r\n        palette = { id: `_${n.palette}`, expanded: true, title: n.palette || '', symbols: [] };\r\n        this.palettes.push(palette);\r\n      }\r\n      palette.symbols.push(node);\r\n    });\r\n    //this.palettes.push({ id: 'design', title: this._translation.get('Design'), symbols: [{ id: 'text', shape: { type: 'Text', textContent: 'T' }, addInfo: { title: this._translation.get('Text') } }] });\r\n    /*this.palettes.push(swimlane );*/\r\n  }\r\n\r\n  private _versionNode(version: number): NodeModel {\r\n    return {\r\n      id: 'version',\r\n      shape: {\r\n        type: 'Text',\r\n        content: this._translate.get('DiagramVersion', version || 0)\r\n      },\r\n      offsetY: 5,\r\n      offsetX: 5,\r\n      style: {\r\n        fontSize: 50,\r\n        color: this._session.theme.dark ? 'white' : 'black',\r\n        opacity: .1\r\n      } as TextStyleModel,\r\n      constraints: NodeConstraints.ReadOnly,\r\n      zIndex: -1\r\n    } as TextModel;\r\n  }\r\n  nodeDefaults = (): NodeModel => {\r\n    const obj: NodeModel = {\r\n      style: {\r\n        fill: 'transparent',\r\n        strokeColor: this._session.theme.dark ? 'white' : 'black',\r\n        strokeWidth: 1\r\n      },\r\n      annotations: [{\r\n        style: {\r\n          color: this._session.theme.dark ? 'white' : 'black',\r\n          fill: 'transparent',\r\n          opacity: .8\r\n        }\r\n      }]\r\n    };\r\n    if (obj.width === undefined) {\r\n      obj.width = 145;\r\n    } else {\r\n      const ratio: number = 100 / obj.width;\r\n      obj.width = 100;\r\n      obj.height *= ratio;\r\n    }\r\n    obj.constraints = NodeConstraints.Default | NodeConstraints.AspectRatio;\r\n    obj.ports = getPorts();\r\n    return obj;\r\n  }\r\n  public connDefaults = (obj: ConnectorModel): void => {\r\n    obj.constraints = ConnectorConstraints.Default | ConnectorConstraints.Bridging | ConnectorConstraints.DragSegmentThumb;\r\n    obj.style.strokeColor = this._session.theme.dark ? 'white' : 'black';\r\n  }\r\n  public getSymbolInfo(symbol: NodeModel): SymbolInfo {\r\n    return {\r\n      fit: true,\r\n      tooltip: (symbol.addInfo as any).title,\r\n      description: { text: (symbol.addInfo as any).title, overflow: 'Wrap', wrap: 'WrapWithOverflow' }\r\n    };\r\n  }\r\n  public getSymbolDefaults(symbol: NodeModel): void {\r\n    symbol.width = symbol.height = 40;\r\n    symbol.constraints = NodeConstraints.Default | NodeConstraints.AspectRatio;\r\n  }\r\n  pan() {\r\n    this.diagramConstraints = this.diagramConstraints | DiagramConstraints.Pan;\r\n    this.diagramTool = DiagramTools.ZoomPan;\r\n  }\r\n  cursor() {\r\n    this.diagramConstraints = this.diagramConstraints & ~DiagramConstraints.Pan;\r\n    this.diagramTool = DiagramTools.Default;\r\n  }\r\n  selectionChange() {\r\n    const { nodes, connectors } = this.diagram.selectedItems;\r\n    if (connectors.length || nodes.length) {\r\n      if (nodes.length === 1 && nodes[0].addInfo) {\r\n        this.diagram.selectedItems.constraints = SelectorConstraints.All | SelectorConstraints.UserHandle;\r\n        this.diagram.selectedItems.userHandles = this._userHandles;\r\n      }\r\n      else this.diagram.selectedItems.constraints = SelectorConstraints.All ^ SelectorConstraints.UserHandle;\r\n\r\n      if (connectors.length) {\r\n        const connector = connectors[0];\r\n        connectors.forEach(c => { if (!c.addInfo) c.addInfo = {} });\r\n        const type = connector.type;\r\n        this.connectorType = connectors.length === 1 || connectors.every(c => c.type === type) ? type : null;\r\n        if (connector.annotations.length)\r\n          this.fontSize = connector.annotations[0].style.fontSize;\r\n        this.connectorType = connectors.length === 1 || connectors.every(c => c.type === type) ? type : null;\r\n      }\r\n      if (nodes.length) {\r\n        const node = nodes[0],\r\n          addInfo = node.addInfo as any;\r\n        if (addInfo && addInfo.nodeType) {\r\n          if (node.annotations.length)\r\n            this.fontSize = node.annotations[0].style.fontSize;\r\n        }\r\n      }\r\n      this._router.collapse()\r\n      this._router.navigate(WorkflowNodeComponent, {\r\n        state: {\r\n          nodes, connectors\r\n        },\r\n        policy: OpenPolicy.Tab,\r\n        expandable: false,\r\n        group: ''\r\n      }).then(p => {\r\n        (p.instance as WorkflowNodeComponent).change.\r\n          pipe(takeUntil(this._destroy)).subscribe(() => {\r\n            this.dirty = true;\r\n            this.diagram.dataBind();\r\n          });\r\n      });\r\n    }\r\n    else\r\n      this._router.collapse();\r\n  }\r\n  align(value: AlignmentOptions) {\r\n    function align(n: NodeModel | ConnectorModel) {\r\n      n.annotations.length && Object.assign(n.annotations[0], {\r\n        offset: {\r\n          x: value === 'Right' ? 1 : value === 'Left' ? 0 : .5,\r\n          y: value === 'Top' ? 0 : value === 'Bottom' ? 1 : .5\r\n        },\r\n        verticalAlignment: value === 'Top' ? 'Bottom' : value === 'Bottom' ? 'Top' : 'Center',\r\n        horizontalAlignment: value === 'Right' ? 'Left' : value === 'Left' ? 'Right' : 'Center'\r\n      });\r\n    }\r\n    this.diagram.selectedItems.nodes.forEach(align);\r\n    this.diagram.selectedItems.connectors.forEach(align);\r\n    this.alignment = value;\r\n    this.dirty = true;\r\n  }\r\n  public dragEnter(args: IDragEnterEventArgs): void {\r\n    const obj: NodeModel = args.element as NodeModel;\r\n    if (obj instanceof Node) {\r\n      const { width, height } = obj;\r\n      obj.width = 100;\r\n      obj.height *= 100 / width;\r\n      obj.offsetX += (obj.width - width) / 2;\r\n      obj.offsetY += (obj.height - height) / 2;\r\n      obj.style = { fill: 'white', strokeColor: 'black' };\r\n    }\r\n  }\r\n  propertyChange(e) {\r\n    if (e.cause !== 2) this.dirty = true;\r\n  }\r\n  change() {\r\n    this.dirty = true;\r\n  }\r\n  addText() {\r\n    this.diagram.drawingObject = {\r\n      shape: {\r\n        type: 'Text',\r\n      },\r\n      constraints: NodeConstraints.Default & ~NodeConstraints.InConnect & ~NodeConstraints.OutConnect\r\n    } as NodeModel;\r\n    this.diagramTool = DiagramTools.DrawOnce;\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 (this.dirty && event.ctrlKey && (event.which === 83 || event.which === 115)) {\r\n      this.save();\r\n      event.preventDefault();\r\n    }\r\n  }\r\n  bgChange(val: string) {\r\n    this.diagram.selectedItems.nodes.forEach(n => n.style.fill = val);\r\n    this.dirty = true;\r\n  }\r\n  colorChange(val: string) {\r\n    this.diagram.selectedItems.nodes.forEach(n => n.annotations.forEach(a => a.style.color = val));\r\n    this.diagram.selectedItems.connectors.forEach(c => c.annotations.forEach(a => a.style.color = val));\r\n    this.dirty = true;\r\n  }\r\n  connectorTypeChange(type: Segments) {\r\n    this.diagram.selectedItems.connectors.forEach(c => c.type = type);\r\n    this.connectorType = type;\r\n    this.dirty = true;\r\n  }\r\n  sizeChange(val: string) {\r\n    this.diagram.selectedItems.nodes.forEach(n => n.annotations.forEach(a => a.style.fontSize = parseInt(val)));\r\n    this.diagram.dataBind();\r\n  }\r\n  strokeChange(val: string) {\r\n    this.diagram.selectedItems.connectors.forEach(c => {\r\n      c.style.strokeColor = val;\r\n      if (c.annotations) c.annotations[0].style.color = val;\r\n    });\r\n    this.diagram.selectedItems.nodes.forEach(n => n.style.strokeColor = val);\r\n    this.dirty = true;\r\n  }\r\n  save(): Promise<any> {\r\n    this.diagram.serializationSettings = {};\r\n    const obj = JSON.parse(this.diagram.saveDiagram());\r\n    this._form.workflow.connectors = obj.connectors;\r\n    this._form.workflow.nodes = obj.nodes.filter(n => n.id !== 'version').map((n: NodeModel) => {\r\n      n.offsetX = Math.round(n.offsetX);\r\n      n.offsetY = Math.round(n.offsetY);\r\n      return n;\r\n    });\r\n    this.saving = true;\r\n    return this._service.save(this._form).toPromise().then(v => {\r\n      this.ps.toast('ChangesSaved');\r\n      if (this._form.workflow.version < v) {\r\n        this.ps.toast('DiagramVersion', v);\r\n        const node = this.diagram.getNodeObject('version');\r\n        (node.shape as TextModel).content = this._translate.get('DiagramVersion', v);\r\n        this.diagram.dataBind();\r\n      }\r\n      this._form.workflow.version = v;\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  ngOnDestroy(): void {\r\n    this._destroy.next();\r\n    this._destroy.complete();\r\n  }\r\n}\r\n","<mat-toolbar>\r\n  <button mat-icon-button (click)=\"tools = !tools\" [bizdocTooltip]=\"'Collapse' | translate\"><mat-icon>view_sidebar</mat-icon></button>\r\n  <button mat-button (click)=\"save()\" color=\"primary\" [disabled]=\"!dirty || saving\">{{'SaveChanges' | translate}}</button>\r\n  <button mat-icon-button (click)=\"diagram.fitToPage()\" [bizdocTooltip]=\"'FitToPage' | translate\"><mat-icon>fullscreen_exit</mat-icon></button>\r\n  <button mat-icon-button (click)=\"diagram.undo()\" [bizdocTooltip]=\"'Undo' | translate\" [disabled]=\"!diagram.historyManager?.canUndo\"><mat-icon>undo</mat-icon></button>\r\n  <button mat-icon-button (click)=\"diagram.redo()\" [bizdocTooltip]=\"'Redo' | translate\" [disabled]=\"!diagram.historyManager?.canRedo\"><mat-icon>redo</mat-icon></button>\r\n  &nbsp;\r\n  <button mat-icon-button (click)=\"pan()\" [bizdocTooltip]=\"'Pan' | translate\"><span class=\"e-icons sf-icon-pan\"></span></button>\r\n  <button mat-icon-button (click)=\"cursor()\" [bizdocTooltip]=\"'Cursor' | translate\"><span class=\"e-icons sf-icon-cursor\"></span></button>\r\n  <span class=\"divider\"></span>\r\n  <button mat-icon-button (click)=\"addText()\" [bizdocTooltip]=\"'Text' | translate\"><mat-icon>title</mat-icon></button>\r\n  <button mat-button [matMenuTriggerFor]=\"lineMenu\" [disabled]=\"!diagram.selectedItems?.connectors.length\" [bizdocTooltip]=\"'ConnectorMode'|translate\">\r\n    <span class=\"e-menu-icon\" [ngClass]=\"{'sf-icon-straight-line': connectorType === 'Straight',\r\n          'sf-icon-orthogonal-line': connectorType === 'Orthogonal',\r\n          'sf-icon-beizer-line': connectorType === 'Bezier'}\"></span>\r\n    <mat-icon>arrow_drop_down</mat-icon>\r\n  </button>\r\n  <mat-menu #lineMenu panelClass=\"icon-menu-panel\">\r\n    <button mat-menu-item (click)=\"connectorTypeChange('Straight')\">\r\n      <span class=\"e-menu-icon sf-icon-straight-line\"></span>\r\n    </button>\r\n    <button mat-menu-item (click)=\"connectorTypeChange('Orthogonal')\">\r\n      <span class=\"e-menu-icon sf-icon-orthogonal-line\"></span>\r\n    </button>\r\n    <button mat-menu-item (click)=\"connectorTypeChange('Bezier')\">\r\n      <span class=\"e-menu-icon sf-icon-beizer-line\"></span>\r\n    </button>\r\n  </mat-menu>\r\n  &nbsp;\r\n  <button mat-button [matMenuTriggerFor]=\"alignMenu\" [disabled]=\"!diagram.selectedItems?.nodes.length && !diagram.selectedItems?.connectors.length\" [bizdocTooltip]=\"'Align'|translate\">\r\n    <span class=\"e-icons\" [ngClass]=\"{'sf-icon-top': alignment === 'Top',\r\n          'sf-icon-left': alignment === 'Left',\r\n          'sf-icon-center': alignment === 'Center',\r\n          'sf-icon-bottom': alignment === 'Bottom',\r\n          'sf-icon-right': alignment === 'Right'}\"></span>\r\n    <mat-icon>arrow_drop_down</mat-icon>\r\n  </button>\r\n  <mat-menu #alignMenu panelClass=\"icon-menu-panel\">\r\n    <button mat-menu-item (click)=\"align('Top')\">\r\n      <span class=\"e-icons sf-icon-top\"></span>\r\n    </button>\r\n    <button mat-menu-item (click)=\"align('Left')\">\r\n      <span class=\"e-icons sf-icon-left\"></span>\r\n    </button>\r\n    <button mat-menu-item (click)=\"align('Center')\">\r\n      <span class=\"e-icons sf-icon-center\"></span>\r\n    </button>\r\n    <button mat-menu-item (click)=\"align('Bottom')\">\r\n      <span class=\"e-icons sf-icon-bottom\"></span>\r\n    </button>\r\n    <button mat-menu-item (click)=\"align('Right')\">\r\n      <span class=\"e-icons sf-icon-right\"></span>\r\n    </button>\r\n  </mat-menu>\r\n</mat-toolbar>\r\n<div class=\"row container\">\r\n  <div id=\"symbolpalette\" *ngIf=\"tools\">\r\n  <ejs-symbolpalette dir=\"ltr\" expandMode='Multiple' [palettes]='palettes' width=\"100%\" height=\"100%\" [symbolHeight]=80\r\n                     [enableRtl]=\"false\" [enableAnimation]=\"false\" [symbolWidth]=80 [symbolMargin]='symbolMargin' [getSymbolInfo]='getSymbolInfo' [getNodeDefaults]='getSymbolDefaults'>\r\n  </ejs-symbolpalette>\r\n  </div>\r\n  <ejs-diagram #diagram id=\"diagram\" width=\"100%\" height=\"100%\" dir=\"ltr\" [snapSettings]='snapSettings' [getConnectorDefaults]='connDefaults' fxFlex\r\n               [constraints]=\"diagramConstraints\" [tool]=diagramTool [getNodeDefaults]='nodeDefaults' [getCustomTool]='getCustomTool' [scrollSettings]=\"scrollSettings\"\r\n               [selectedItems]=\"selectedItems\"\r\n               [rulerSettings]=\"rulerSettings\"\r\n               (dragEnter)='dragEnter($event)'\r\n               (connectionChange)=\"change()\"\r\n               (collectionChange)=\"change()\"\r\n               (propertyChange)=\"propertyChange($event)\"\r\n               (selectionChange)=\"selectionChange()\"\r\n               (created)=\"diagramCreate()\">\r\n  </ejs-diagram>\r\n</div>\r\n"]}
445
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"workflow.component.js","sourceRoot":"","sources":["../../../../../../../libraries/core/src/lib/admin/form/workflow/workflow.component.ts","../../../../../../../libraries/core/src/lib/admin/form/workflow/workflow.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ViewChild, OnDestroy, HostListener, ElementRef, OnInit, AfterViewInit } from '@angular/core';\r\nimport { Subject } from 'rxjs';\r\nimport { takeUntil } from 'rxjs/operators';\r\nimport {\r\n  DiagramConstraints, UserHandleModel, SelectorConstraints, ToolBase, MouseEventArgs, ConnectorModel, ConnectorDrawingTool, TextModel, PointPortModel, NodeConstraints, ScrollSettingsModel,\r\n  Diagram, NodeModel, UndoRedo, SymbolInfo, IDragEnterEventArgs, SnapSettingsModel, MarginModel, Node, PaletteModel, Segments, DiagramTools, ConnectorConstraints, SelectorModel, RulerSettingsModel, AlignmentOptions, TextStyleModel, SymbolPalette, BpmnDiagrams, DataBinding,\r\n  ConnectorEditing, ConnectorBridging, Snapping\r\n} from '@syncfusion/ej2-diagrams';\r\nimport { Form } from '../../../core/models';\r\nimport { SessionService } from '../../../core/session.service';\r\nimport { FormService } from '../form.service';\r\nimport { PromptService } from '../../../core/prompt.service';\r\nimport { TranslateService } from '../../../core/translate.service';\r\nimport { PaneRef } from '../../../core/slots/pane-ref';\r\nimport { PanesRouter } from '../../../core/slots/router.service';\r\nimport { WorkflowNodeComponent } from './node.component';\r\nimport { AdminComponent } from '../../admin-dismiss.service';\r\nimport { OpenPolicy } from '../../../core/configuration';\r\n\r\nDiagram.Inject(BpmnDiagrams, UndoRedo, ConnectorBridging, ConnectorEditing, Snapping, DataBinding);\r\nSymbolPalette.Inject(BpmnDiagrams);\r\n\r\nfunction getPorts(): PointPortModel[] {\r\n  const ports: PointPortModel[] = [\r\n    { id: 'port1', shape: 'Circle', offset: { x: 0, y: 0.5 } },\r\n    { id: 'port2', shape: 'Circle', offset: { x: 0.5, y: 1 } },\r\n    { id: 'port3', shape: 'Circle', offset: { x: 1, y: 0.5 } },\r\n    { id: 'port4', shape: 'Circle', offset: { x: 0.5, y: 0 } }\r\n  ];\r\n  return ports;\r\n}\r\n\r\nfunction showPaletteIcon(): void {\r\n  const paletteSpace: HTMLElement = document.getElementById('palette-space');\r\n  const isMobile = window.matchMedia('(max-width:550px)').matches;\r\n  if (isMobile) {\r\n    if (!paletteSpace.classList.contains('sb-mobile-palette-open')) {\r\n      paletteSpace.classList.add('sb-mobile-palette-open');\r\n    } else {\r\n      paletteSpace.classList.remove('sb-mobile-palette-open');\r\n    }\r\n  }\r\n}\r\n\r\nfunction paletteIconClick() {\r\n  const isMobile = window.matchMedia('(max-width:550px)').matches;\r\n  if (isMobile) {\r\n    const paletteIcon = document.getElementById('palette-icon');\r\n    if (paletteIcon) {\r\n      paletteIcon.addEventListener('click', showPaletteIcon, false);\r\n    }\r\n  }\r\n}\r\n\r\n//Defines the tool\r\nclass DrawTool extends ConnectorDrawingTool {\r\n  public mouseMove(args: MouseEventArgs): boolean {\r\n    if (this.diagram.selectedItems.nodes.length) {\r\n      this.diagram.drawingObject = {\r\n        type: this.segments || 'Bezier',\r\n        sourceID: this.diagram.selectedItems.nodes[0].id\r\n      };\r\n      this.inAction = true;\r\n    }\r\n    const ok = super.mouseMove(args);\r\n    return ok;\r\n  }\r\n  constructor(private diagram: Diagram, private segments: Segments) {\r\n    super(diagram.commandHandler, 'ConnectorSourceEnd', null);\r\n  }\r\n}\r\nconst LINK_PATH = 'M346.7,714.6l368.1-368.1c17.9-17.9,17.9-47.1,0-64.9c-17.9-17.9-47.1-17.9-64.9,0l-368,368c-17.9,17.9-17.9,47.1,0,64.9C299.6,732.5,328.9,732.5,346.7,714.6z M468.2,651c6.4,9,7.6,18.5,7.6,23.8c0,6.3-1.5,18.6-11.8,28.9L271,896.5c-10.3,10.3-22.5,11.8-28.9,11.8c-6.3,0-18.6-1.5-28.9-11.8L103.5,786.8c-10.3-10.3-11.8-22.5-11.8-28.9c0-6.4,1.5-18.6,11.8-28.9l192.9-192.9c10.3-10.3,22.5-11.8,28.9-11.8c4.5,0,11.8,0.8,19.3,4.8l58.6-58.6c-48-39.6-119.6-36.9-164.5,7.9L45.7,671.3c-47.7,47.7-47.7,125.5,0,173.2l109.7,109.7c47.7,47.7,125.5,47.7,173.2,0l192.9-192.9c46-46,47.6-120.4,4.6-168.4L468.2,651z M954.2,155.5L844.5,45.8C796.9-1.9,719-1.9,671.3,45.8L478.4,238.7c-44.8,44.8-47.5,116.5-7.9,164.5l58.6-58.6c-4-7.6-4.8-14.9-4.8-19.3c0-6.3,1.5-18.6,11.8-28.9l192.9-192.9c10.3-10.3,22.5-11.8,28.9-11.8c6.3,0,18.6,1.5,28.9,11.8l109.7,109.7c10.3,10.3,11.8,22.5,11.8,28.9c0,6.3-1.5,18.6-11.8,28.9L703.7,464c-10.3,10.3-22.5,11.8-28.9,11.8c-5.3,0-14.8-1.1-23.8-7.6l-58,58c48,43,122.3,41.5,168.4-4.6l192.9-192.9C1001.9,281.1,1001.9,203.1,954.2,155.5z';\r\n\r\n@Component({\r\n  selector: 'bizdoc-workflow',\r\n  templateUrl: './workflow.component.html',\r\n  styleUrls: ['./workflow.component.scss'],\r\n  host: {\r\n    class: 'pane'\r\n  }\r\n})\r\n/** workflow component*/\r\nexport class WorkflowComponent implements OnInit, AfterViewInit, OnDestroy, AdminComponent {\r\n  symbolPalette: SymbolPalette;\r\n  diagram: Diagram;\r\n  @ViewChild('symbolPalette', { static: true }) symbolPaletteEl: ElementRef;\r\n  @ViewChild('diagram', { static: true }) diagramEl: ElementRef;\r\n  tools = true;\r\n  connectorType: Segments = 'Bezier';\r\n  alignment: AlignmentOptions = 'Center';\r\n  fontSize = 12;\r\n  public getTool(action: string): ToolBase {\r\n    let tool: ToolBase = null;\r\n    if (action === 'connect')\r\n      tool = new DrawTool(this.diagram, this.connectorType);\r\n    return tool;\r\n  }\r\n  saving = false;\r\n  element?: any;\r\n  dirty = false;\r\n  params: {};\r\n  palettes: PaletteModel[] = [];\r\n  diagramConstraints: DiagramConstraints = DiagramConstraints.Default | DiagramConstraints.Bridging | DiagramConstraints.UserInteraction | DiagramConstraints.Zoom;\r\n  diagramTool: DiagramTools = DiagramTools.Default;\r\n  //Defines the user handle collection for nodes in diagram\r\n  private readonly _userHandles: UserHandleModel[] = [\r\n    {\r\n      name: 'connect',\r\n      pathData: LINK_PATH,\r\n      visible: true,\r\n      offset: 0,\r\n      side: 'Right',\r\n      displacement: 20,\r\n      margin: { top: 0, bottom: 0, left: 0, right: 0 }\r\n    }\r\n  ];\r\n  //SymbolPalette Properties\r\n  readonly symbolMargin: MarginModel = { left: 10, right: 10, top: 10, bottom: 10 };\r\n  readonly snapSettings: SnapSettingsModel = {\r\n  };\r\n  readonly selectedItems: SelectorModel = {\r\n  };\r\n  readonly scrollSettings: ScrollSettingsModel = {\r\n    minZoom: .5,\r\n    maxZoom: 2.5\r\n  };\r\n  private _rulerColor = this._session.getAccent(100);\r\n  readonly rulerSettings: RulerSettingsModel = {\r\n    horizontalRuler: { markerColor: this._rulerColor },\r\n    verticalRuler: { markerColor: this._rulerColor }\r\n  };\r\n  private _form: Form;\r\n  private readonly _destroy = new Subject<void>();\r\n  /** workflow ctor */\r\n  constructor(private ps: PromptService,\r\n    private _service: FormService,\r\n    private _pane: PaneRef<WorkflowComponent>,\r\n    private _router: PanesRouter,\r\n    private _session: SessionService,\r\n    private _translate: TranslateService) {\r\n    this._palettes();\r\n  }\r\n  ngOnInit() {\r\n  }\r\n  ngAfterViewInit(): void {\r\n    this.symbolPalette = new SymbolPalette({\r\n      expandMode: 'Multiple',\r\n      palettes: this.palettes,\r\n      width: \"100%\", height: \"100%\", symbolHeight: 80,\r\n      enableRtl: false, enableAnimation: false, symbolWidth: 80,\r\n      symbolMargin: this.symbolMargin,\r\n      getSymbolInfo: this.getSymbolInfo.bind(this),\r\n      getNodeDefaults: this.getSymbolDefaults.bind(this)\r\n    });\r\n    this.symbolPalette.appendTo(this.symbolPaletteEl.nativeElement);\r\n    this.diagram = new Diagram({\r\n      width: \"100%\", height: \"100%\",\r\n      snapSettings: this.snapSettings,\r\n      getConnectorDefaults: this.connDefaults.bind(this),\r\n      constraints: this.diagramConstraints,\r\n      tool: this.diagramTool,\r\n      getNodeDefaults: this.nodeDefaults.bind(this),\r\n      getCustomTool: this.getTool.bind(this),\r\n      scrollSettings: this.scrollSettings,\r\n      selectedItems: this.selectedItems,\r\n      rulerSettings: this.rulerSettings,\r\n      dragEnter: this.dragEnter.bind(this),\r\n      connectionChange: this.change.bind(this),\r\n      collectionChange: this.change.bind(this),\r\n      propertyChange: this.propertyChange.bind(this),\r\n      selectionChange: this.selectionChange.bind(this),\r\n    }, this.diagramEl.nativeElement);\r\n    this.diagramCreate();\r\n  }\r\n  public diagramCreate(): void {\r\n    paletteIconClick();\r\n    this._pane.paramsChange.pipe(takeUntil(this._destroy)).subscribe(p => {\r\n      const id = p['id'];\r\n      this._form = this._session.profile.forms.find(f => f.name === id);\r\n      this._pane.title = this._form.title;\r\n      this.params = { id: this._form.name };\r\n    });\r\n    this._pane.dataChange.pipe(takeUntil(this._destroy)).subscribe(d => {\r\n      Object.assign(this._form, d.form);\r\n      const flow = this._form.workflow;\r\n      this.diagram.nodes = flow.nodes;\r\n      this.diagram.connectors = flow.connectors;\r\n      this.diagram.dataBind();\r\n      this.diagram.add(this._versionNode(flow.version));\r\n      this.diagram.fitToPage();\r\n      this.dirty = false;\r\n    });\r\n    this._pane.resize.pipe(takeUntil(this._destroy)).subscribe(() =>\r\n      this.diagram.refresh());\r\n  }\r\n  private _palettes() {\r\n    this._session.profile.nodes.forEach(n => {\r\n      const node: NodeModel = {\r\n        id: n.name,\r\n        shape: n.shape,\r\n        addInfo: {\r\n          nodeType: n.name,\r\n          title: n.title\r\n        },\r\n      };\r\n      (node as any).node = n.name;\r\n      let palette = this.palettes.find(p => p.title === (n.palette || ''));\r\n      if (!palette) {\r\n        palette = { id: `_${n.palette}`, expanded: true, title: n.palette || '', symbols: [] };\r\n        this.palettes.push(palette);\r\n      }\r\n      palette.symbols.push(node);\r\n    });\r\n    //this.palettes.push({ id: 'design', title: this._translation.get('Design'), symbols: [{ id: 'text', shape: { type: 'Text', textContent: 'T' }, addInfo: { title: this._translation.get('Text') } }] });\r\n    /*this.palettes.push(swimlane );*/\r\n  }\r\n\r\n  private _versionNode(version: number): NodeModel {\r\n    return {\r\n      id: 'version',\r\n      shape: {\r\n        type: 'Text',\r\n        content: this._translate.get('DiagramVersion', version || 0)\r\n      },\r\n      offsetY: 5,\r\n      offsetX: 5,\r\n      style: {\r\n        fontSize: 50,\r\n        color: this._session.theme.dark ? 'white' : 'black',\r\n        opacity: .1\r\n      } as TextStyleModel,\r\n      constraints: NodeConstraints.ReadOnly,\r\n      zIndex: -1\r\n    } as TextModel;\r\n  }\r\n  nodeDefaults = (): NodeModel => {\r\n    const obj: NodeModel = {\r\n      style: {\r\n        fill: 'transparent',\r\n        strokeColor: this._session.theme.dark ? 'white' : 'black',\r\n        strokeWidth: 1\r\n      },\r\n      annotations: [{\r\n        style: {\r\n          color: this._session.theme.dark ? 'white' : 'black',\r\n          fill: 'transparent',\r\n          opacity: .8\r\n        }\r\n      }]\r\n    };\r\n    if (obj.width === undefined) {\r\n      obj.width = 145;\r\n    } else {\r\n      const ratio: number = 100 / obj.width;\r\n      obj.width = 100;\r\n      obj.height *= ratio;\r\n    }\r\n    obj.constraints = NodeConstraints.Default | NodeConstraints.AspectRatio;\r\n    obj.ports = getPorts();\r\n    return obj;\r\n  }\r\n  public connDefaults = (obj: ConnectorModel): void => {\r\n    obj.constraints = ConnectorConstraints.Default | ConnectorConstraints.Bridging | ConnectorConstraints.DragSegmentThumb;\r\n    obj.style.strokeColor = this._session.theme.dark ? 'white' : 'black';\r\n  }\r\n  public getSymbolInfo(symbol: NodeModel): SymbolInfo {\r\n    return {\r\n      fit: true,\r\n      tooltip: (symbol.addInfo as any).title,\r\n      description: { text: (symbol.addInfo as any).title, overflow: 'Wrap', wrap: 'WrapWithOverflow' }\r\n    };\r\n  }\r\n  public getSymbolDefaults(symbol: NodeModel): void {\r\n    symbol.width = symbol.height = 40;\r\n    symbol.constraints = NodeConstraints.Default | NodeConstraints.AspectRatio;\r\n  }\r\n  pan() {\r\n    this.diagramConstraints = this.diagramConstraints | DiagramConstraints.Pan;\r\n    this.diagramTool = DiagramTools.ZoomPan;\r\n  }\r\n  cursor() {\r\n    this.diagramConstraints = this.diagramConstraints & ~DiagramConstraints.Pan;\r\n    this.diagramTool = DiagramTools.Default;\r\n  }\r\n  selectionChange() {\r\n    const { nodes, connectors } = this.diagram.selectedItems;\r\n    if (connectors.length || nodes.length) {\r\n      if (nodes.length === 1 && nodes[0].addInfo) {\r\n        this.diagram.selectedItems.constraints = SelectorConstraints.All | SelectorConstraints.UserHandle;\r\n        this.diagram.selectedItems.userHandles = this._userHandles;\r\n      }\r\n      else this.diagram.selectedItems.constraints = SelectorConstraints.All ^ SelectorConstraints.UserHandle;\r\n\r\n      if (connectors.length) {\r\n        const connector = connectors[0];\r\n        connectors.forEach(c => { if (!c.addInfo) c.addInfo = {} });\r\n        const type = connector.type;\r\n        this.connectorType = connectors.length === 1 || connectors.every(c => c.type === type) ? type : null;\r\n        if (connector.annotations.length)\r\n          this.fontSize = connector.annotations[0].style.fontSize;\r\n        this.connectorType = connectors.length === 1 || connectors.every(c => c.type === type) ? type : null;\r\n      }\r\n      if (nodes.length) {\r\n        const node = nodes[0],\r\n          addInfo = node.addInfo as any;\r\n        if (addInfo && addInfo.nodeType) {\r\n          if (node.annotations.length)\r\n            this.fontSize = node.annotations[0].style.fontSize;\r\n        }\r\n      }\r\n      this._router.collapse()\r\n      this._router.navigate(WorkflowNodeComponent, {\r\n        state: {\r\n          nodes, connectors\r\n        },\r\n        policy: OpenPolicy.Tab,\r\n        expandable: false,\r\n        group: ''\r\n      }).then(p => {\r\n        (p.instance as WorkflowNodeComponent).change.\r\n          pipe(takeUntil(this._destroy)).subscribe(() => {\r\n            this.dirty = true;\r\n            this.diagram.dataBind();\r\n          });\r\n      });\r\n    }\r\n    else\r\n      this._router.collapse();\r\n  }\r\n  align(value: AlignmentOptions) {\r\n    function align(n: NodeModel | ConnectorModel) {\r\n      n.annotations.length && Object.assign(n.annotations[0], {\r\n        offset: {\r\n          x: value === 'Right' ? 1 : value === 'Left' ? 0 : .5,\r\n          y: value === 'Top' ? 0 : value === 'Bottom' ? 1 : .5\r\n        },\r\n        verticalAlignment: value === 'Top' ? 'Bottom' : value === 'Bottom' ? 'Top' : 'Center',\r\n        horizontalAlignment: value === 'Right' ? 'Left' : value === 'Left' ? 'Right' : 'Center'\r\n      });\r\n    }\r\n    this.diagram.selectedItems.nodes.forEach(align);\r\n    this.diagram.selectedItems.connectors.forEach(align);\r\n    this.alignment = value;\r\n    this.dirty = true;\r\n  }\r\n  public dragEnter(args: IDragEnterEventArgs): void {\r\n    const obj: NodeModel = args.element as NodeModel;\r\n    if (obj instanceof Node) {\r\n      const { width, height } = obj;\r\n      obj.width = 100;\r\n      obj.height *= 100 / width;\r\n      obj.offsetX += (obj.width - width) / 2;\r\n      obj.offsetY += (obj.height - height) / 2;\r\n      obj.style = { fill: 'white', strokeColor: 'black' };\r\n    }\r\n  }\r\n  propertyChange(e) {\r\n    if (e.cause !== 2) this.dirty = true;\r\n  }\r\n  change() {\r\n    this.dirty = true;\r\n  }\r\n  addText() {\r\n    this.diagram.drawingObject = {\r\n      shape: {\r\n        type: 'Text',\r\n      },\r\n      constraints: NodeConstraints.Default & ~NodeConstraints.InConnect & ~NodeConstraints.OutConnect\r\n    } as NodeModel;\r\n    this.diagramTool = DiagramTools.DrawOnce;\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 (this.dirty && event.ctrlKey && (event.which === 83 || event.which === 115)) {\r\n      this.save();\r\n      event.preventDefault();\r\n    }\r\n  }\r\n  bgChange(val: string) {\r\n    this.diagram.selectedItems.nodes.forEach(n => n.style.fill = val);\r\n    this.dirty = true;\r\n  }\r\n  colorChange(val: string) {\r\n    this.diagram.selectedItems.nodes.forEach(n => n.annotations.forEach(a => a.style.color = val));\r\n    this.diagram.selectedItems.connectors.forEach(c => c.annotations.forEach(a => a.style.color = val));\r\n    this.dirty = true;\r\n  }\r\n  connectorTypeChange(type: Segments) {\r\n    this.diagram.selectedItems.connectors.forEach(c => c.type = type);\r\n    this.connectorType = type;\r\n    this.dirty = true;\r\n  }\r\n  sizeChange(val: string) {\r\n    this.diagram.selectedItems.nodes.forEach(n => n.annotations.forEach(a => a.style.fontSize = parseInt(val)));\r\n    this.diagram.dataBind();\r\n  }\r\n  strokeChange(val: string) {\r\n    this.diagram.selectedItems.connectors.forEach(c => {\r\n      c.style.strokeColor = val;\r\n      if (c.annotations) c.annotations[0].style.color = val;\r\n    });\r\n    this.diagram.selectedItems.nodes.forEach(n => n.style.strokeColor = val);\r\n    this.dirty = true;\r\n  }\r\n  save(): Promise<any> {\r\n    this.diagram.serializationSettings = {preventDefaults: true};\r\n    const obj = JSON.parse(this.diagram.saveDiagram());\r\n    this._form.workflow.connectors = obj.connectors;\r\n    this._form.workflow.nodes = obj.nodes.filter(n => n.id !== 'version').map((n: NodeModel) => {\r\n      n.offsetX = Math.round(n.offsetX);\r\n      n.offsetY = Math.round(n.offsetY);\r\n      return n;\r\n    });\r\n    this.saving = true;\r\n    return this._service.save(this._form).toPromise().then(v => {\r\n      this.ps.toast('ChangesSaved');\r\n      if (this._form.workflow.version < v) {\r\n        this.ps.toast('DiagramVersion', v);\r\n        const node = this.diagram.getNodeObject('version');\r\n        (node.shape as TextModel).content = this._translate.get('DiagramVersion', v);\r\n        this.diagram.dataBind();\r\n      }\r\n      this._form.workflow.version = v;\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  ngOnDestroy(): void {\r\n    this.symbolPalette?.destroy();\r\n    this.diagram?.destroy();\r\n    this._destroy.next();\r\n    this._destroy.complete();\r\n  }\r\n}\r\n","<mat-toolbar>\r\n  <button mat-icon-button (click)=\"tools = !tools\" [bizdocTooltip]=\"'Collapse' | translate\"><mat-icon>view_sidebar</mat-icon></button>\r\n  <button mat-button (click)=\"save()\" color=\"primary\" [disabled]=\"!dirty || saving\">{{'SaveChanges' | translate}}</button>\r\n  <button mat-icon-button (click)=\"diagram.fitToPage()\" [bizdocTooltip]=\"'FitToPage' | translate\"><mat-icon>fullscreen_exit</mat-icon></button>\r\n  <button mat-icon-button (click)=\"diagram.undo()\" [bizdocTooltip]=\"'Undo' | translate\" [disabled]=\"!diagram.historyManager?.canUndo\"><mat-icon>undo</mat-icon></button>\r\n  <button mat-icon-button (click)=\"diagram.redo()\" [bizdocTooltip]=\"'Redo' | translate\" [disabled]=\"!diagram.historyManager?.canRedo\"><mat-icon>redo</mat-icon></button>\r\n  &nbsp;\r\n  <button mat-icon-button (click)=\"pan()\" [bizdocTooltip]=\"'Pan' | translate\"><span class=\"e-icons sf-icon-pan\"></span></button>\r\n  <button mat-icon-button (click)=\"cursor()\" [bizdocTooltip]=\"'Cursor' | translate\"><span class=\"e-icons sf-icon-cursor\"></span></button>\r\n  <span class=\"divider\"></span>\r\n  <button mat-icon-button (click)=\"addText()\" [bizdocTooltip]=\"'Text' | translate\"><mat-icon>title</mat-icon></button>\r\n  <button mat-button [matMenuTriggerFor]=\"lineMenu\" [disabled]=\"!diagram.selectedItems?.connectors.length\" [bizdocTooltip]=\"'ConnectorMode'|translate\">\r\n    <span class=\"e-menu-icon\" [ngClass]=\"{'sf-icon-straight-line': connectorType === 'Straight',\r\n          'sf-icon-orthogonal-line': connectorType === 'Orthogonal',\r\n          'sf-icon-beizer-line': connectorType === 'Bezier'}\"></span>\r\n    <mat-icon>arrow_drop_down</mat-icon>\r\n  </button>\r\n  <mat-menu #lineMenu panelClass=\"icon-menu-panel\">\r\n    <button mat-menu-item (click)=\"connectorTypeChange('Straight')\">\r\n      <span class=\"e-menu-icon sf-icon-straight-line\"></span>\r\n    </button>\r\n    <button mat-menu-item (click)=\"connectorTypeChange('Orthogonal')\">\r\n      <span class=\"e-menu-icon sf-icon-orthogonal-line\"></span>\r\n    </button>\r\n    <button mat-menu-item (click)=\"connectorTypeChange('Bezier')\">\r\n      <span class=\"e-menu-icon sf-icon-beizer-line\"></span>\r\n    </button>\r\n  </mat-menu>\r\n  &nbsp;\r\n  <button mat-button [matMenuTriggerFor]=\"alignMenu\" [disabled]=\"!diagram.selectedItems?.nodes.length && !diagram.selectedItems?.connectors.length\" [bizdocTooltip]=\"'Align'|translate\">\r\n    <span class=\"e-icons\" [ngClass]=\"{'sf-icon-top': alignment === 'Top',\r\n          'sf-icon-left': alignment === 'Left',\r\n          'sf-icon-center': alignment === 'Center',\r\n          'sf-icon-bottom': alignment === 'Bottom',\r\n          'sf-icon-right': alignment === 'Right'}\"></span>\r\n    <mat-icon>arrow_drop_down</mat-icon>\r\n  </button>\r\n  <mat-menu #alignMenu panelClass=\"icon-menu-panel\">\r\n    <button mat-menu-item (click)=\"align('Top')\">\r\n      <span class=\"e-icons sf-icon-top\"></span>\r\n    </button>\r\n    <button mat-menu-item (click)=\"align('Left')\">\r\n      <span class=\"e-icons sf-icon-left\"></span>\r\n    </button>\r\n    <button mat-menu-item (click)=\"align('Center')\">\r\n      <span class=\"e-icons sf-icon-center\"></span>\r\n    </button>\r\n    <button mat-menu-item (click)=\"align('Bottom')\">\r\n      <span class=\"e-icons sf-icon-bottom\"></span>\r\n    </button>\r\n    <button mat-menu-item (click)=\"align('Right')\">\r\n      <span class=\"e-icons sf-icon-right\"></span>\r\n    </button>\r\n  </mat-menu>\r\n</mat-toolbar>\r\n<div class=\"row container\">\r\n  <div id=\"symbolpalette\" [style.display]=\"tools?'':'none'\">\r\n    <div dir=\"ltr\" #symbolPalette>\r\n    </div>\r\n  </div>\r\n  <div #diagram id=\"diagram\" fxFlex dir=\"ltr\">\r\n  </div>\r\n</div>\r\n"]}