@bizdoc/core 3.2.6 → 3.2.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/assets/themes/brown.min.css +1 -1
- package/assets/themes/dark.min.css +1 -1
- package/assets/themes/deep-purple-light-blue.min.css +1 -1
- package/assets/themes/deep-purple-teal.min.css +1 -1
- package/assets/themes/default.min.css +1 -1
- package/assets/themes/green.min.css +1 -1
- package/assets/themes/indigo-amber.min.css +1 -1
- package/assets/themes/indigo.min.css +1 -1
- package/esm2022/lib/admin/admin-menu.component.mjs +7 -8
- package/esm2022/lib/admin/architecture/designer-element.component.mjs +2 -2
- package/esm2022/lib/admin/architecture/designer.component.mjs +3 -3
- package/esm2022/lib/admin/core/localized-string.component.mjs +2 -2
- package/esm2022/lib/compose/tag/tags.component.mjs +2 -2
- package/esm2022/lib/compose/trace/flow.component.mjs +114 -116
- package/esm2022/lib/core/configuration.mjs +5 -5
- package/esm2022/lib/core/slots/slots.component.mjs +6 -3
- package/esm2022/lib/core/translations.mjs +7 -2
- package/esm2022/lib/modules/diagram.module.mjs +3 -3
- package/esm2022/lib/routes.desktop.mjs +2 -2
- package/fesm2022/bizdoc-core.mjs +139 -134
- package/fesm2022/bizdoc-core.mjs.map +1 -1
- package/lib/compose/trace/flow.component.d.ts +1 -11
- package/lib/core/configuration.d.ts +4 -4
- package/lib/core/slots/slots.component.d.ts +1 -0
- package/lib/cube/cube.service.d.ts +1 -1
- package/package.json +1 -1
    
        package/fesm2022/bizdoc-core.mjs
    CHANGED
    
    | @@ -127,7 +127,7 @@ import EventEmitter$1 from 'events'; | |
| 127 127 | 
             
            import * as i4$3 from '@ctrl/ngx-emoji-mart';
         | 
| 128 128 | 
             
            import { PickerModule } from '@ctrl/ngx-emoji-mart';
         | 
| 129 129 | 
             
            import { Diagram, UndoRedo, ConnectorBridging, ConnectorEditing, Snapping, SymbolPalette, BpmnDiagrams, PortVisibility, PortConstraints, DiagramConstraints, SelectorConstraints, NodeConstraints, ConnectorConstraints, DiagramTools, Connector, Node, ToolBase, ConnectionPointOrigin as ConnectionPointOrigin$1 } from '@syncfusion/ej2-diagrams';
         | 
| 130 | 
            -
            import { DiagramAction, DiagramTools as DiagramTools$1, DiagramConstraints as DiagramConstraints$1, ConnectionPointOrigin, SnapConstraints, Diagram as Diagram$1, NodeConstraints as NodeConstraints$1, ComplexHierarchicalTreeService,  | 
| 130 | 
            +
            import { DiagramAction, DiagramTools as DiagramTools$1, DiagramConstraints as DiagramConstraints$1, ConnectionPointOrigin, SnapConstraints, Diagram as Diagram$1, NodeConstraints as NodeConstraints$1, ComplexHierarchicalTreeService, DiagramModule, SymbolPaletteModule, ConnectorBridgingService, LineRoutingService, BpmnDiagramsService, LayoutAnimationService, UndoRedoService, SnappingService, ConnectorEditingService, LineDistributionService, ComplexHierarchicalTree, BpmnDiagrams as BpmnDiagrams$1, DataBinding, LineDistribution, LineRouting, ConnectorBridging as ConnectorBridging$1, LayoutAnimation } from '@syncfusion/ej2-angular-diagrams';
         | 
| 131 131 | 
             
            import * as i5$3 from '@syncfusion/ej2-angular-schedule';
         | 
| 132 132 | 
             
            import { Schedule, Day, WorkWeek, Month, MonthAgenda, Agenda, Year, ScheduleModule, ExcelExportService as ExcelExportService$2, DayService, WorkWeekService, MonthService, MonthAgendaService, ICalendarExportService, AgendaService, YearService } from '@syncfusion/ej2-angular-schedule';
         | 
| 133 133 | 
             
            import * as i10$3 from '@syncfusion/ej2-angular-kanban';
         | 
| @@ -163,10 +163,10 @@ var OpenPolicy; | |
| 163 163 | 
             
                OpenPolicy[OpenPolicy["Pinnable"] = 8] = "Pinnable";
         | 
| 164 164 | 
             
                OpenPolicy[OpenPolicy["Stretch"] = 16] = "Stretch";
         | 
| 165 165 | 
             
                OpenPolicy[OpenPolicy["Expandable"] = 32] = "Expandable";
         | 
| 166 | 
            -
                OpenPolicy[OpenPolicy[" | 
| 167 | 
            -
                OpenPolicy[OpenPolicy[" | 
| 168 | 
            -
                OpenPolicy[OpenPolicy[" | 
| 169 | 
            -
                OpenPolicy[OpenPolicy["Dialog"] =  | 
| 166 | 
            +
                OpenPolicy[OpenPolicy["Dismissable"] = 64] = "Dismissable";
         | 
| 167 | 
            +
                OpenPolicy[OpenPolicy["Toggle"] = 128] = "Toggle";
         | 
| 168 | 
            +
                OpenPolicy[OpenPolicy["Tab"] = 320] = "Tab";
         | 
| 169 | 
            +
                OpenPolicy[OpenPolicy["Dialog"] = 832] = "Dialog";
         | 
| 170 170 | 
             
            })(OpenPolicy || (OpenPolicy = {}));
         | 
| 171 171 | 
             
            const DEFAULT_POLICY = OpenPolicy.Pane;
         | 
| 172 172 |  | 
| @@ -1613,7 +1613,7 @@ const STRINGS = { | |
| 1613 1613 | 
             
                    Preferences: 'Settings',
         | 
| 1614 1614 | 
             
                    Tags: 'Tags',
         | 
| 1615 1615 | 
             
                    Mention: 'Mention',
         | 
| 1616 | 
            -
                    TagsHint: 'Choose or type tags',
         | 
| 1616 | 
            +
                    TagsHint: 'Choose or type personal tags',
         | 
| 1617 1617 | 
             
                    ContinueEditing: 'Continue editing',
         | 
| 1618 1618 | 
             
                    Close: 'Close',
         | 
| 1619 1619 | 
             
                    View: 'View',
         | 
| @@ -1967,6 +1967,10 @@ const STRINGS = { | |
| 1967 1967 | 
             
                    MaxLengthErr: 'Maximum <strong>{0}</strong> length',
         | 
| 1968 1968 | 
             
                },
         | 
| 1969 1969 | 
             
                'he': {
         | 
| 1970 | 
            +
                    SettingThingsUp: 'אוסף נתונים',
         | 
| 1971 | 
            +
                    PleaseWait: 'אנא המתן/י',
         | 
| 1972 | 
            +
                    Enable: 'אפשר/י',
         | 
| 1973 | 
            +
                    Disable: 'הסתר/י',
         | 
| 1970 1974 | 
             
                    Insights: 'תובנות',
         | 
| 1971 1975 | 
             
                    CheckOut: 'הורד/י',
         | 
| 1972 1976 | 
             
                    CheckIn: 'העלה/י',
         | 
| @@ -2517,6 +2521,7 @@ const STRINGS = { | |
| 2517 2521 | 
             
                    Copyright: '© מודינג',
         | 
| 2518 2522 | 
             
                    Map: 'מפה',
         | 
| 2519 2523 | 
             
                    Watched: 'נצפה {0}',
         | 
| 2524 | 
            +
                    LicencedTo: 'רשיון ל-<strong>{0}</strong>',
         | 
| 2520 2525 | 
             
                    NothingHere: 'אין נתונים נוספים'
         | 
| 2521 2526 | 
             
                }
         | 
| 2522 2527 | 
             
            };
         | 
| @@ -4075,7 +4080,7 @@ class LocalizedStringComponent { | |
| 4075 4080 | 
             
                    const currentLang = this._session.language;
         | 
| 4076 4081 | 
             
                    for (let lang of this._session.languages) {
         | 
| 4077 4082 | 
             
                        let val = this.multilingual ? this._value[lang] :
         | 
| 4078 | 
            -
                            lang === currentLang ? this._value : null, ctrl = this._fb.control(val, this.required ? Validators.required : null);
         | 
| 4083 | 
            +
                            lang === currentLang ? this._value : null, ctrl = this._fb.control(val, this.required && lang === currentLang ? Validators.required : null);
         | 
| 4079 4084 | 
             
                        this.group.addControl(lang, ctrl);
         | 
| 4080 4085 | 
             
                        if (lang === currentLang)
         | 
| 4081 4086 | 
             
                            this.control = ctrl;
         | 
| @@ -9531,11 +9536,11 @@ class TagsComponent { | |
| 9531 9536 | 
             
                    this._destroy.complete();
         | 
| 9532 9537 | 
             
                }
         | 
| 9533 9538 | 
             
                static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.5", ngImport: i0, type: TagsComponent, deps: [{ token: POPUP_DATA }, { token: MailboxService }, { token: SessionService }], target: i0.ɵɵFactoryTarget.Component }); }
         | 
| 9534 | 
            -
                static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.5", type: TagsComponent, selector: "ng-component", viewQueries: [{ propertyName: "inputElement", first: true, predicate: ["input"], descendants: true, static: true }, { propertyName: "auto", first: true, predicate: ["auto"], descendants: true, static: true }], ngImport: i0, template: "<mat-form-field floatLabel=\"never\" subscriptSizing=\"dynamic\">\r\n  <mat-chip-grid #chipList [attr.aria-label]=\"'Tags'|translate\">\r\n    @for (item of tags; track item) {\r\n      <mat-chip\r\n        [removable]=\"true\" (removed)=\"remove(item)\">\r\n        {{item}}\r\n        <mat-icon matChipRemove>cancel</mat-icon>\r\n      </mat-chip>\r\n    }\r\n  </mat-chip-grid>\r\n  <input [placeholder]=\"'TagsHint'|translate\"\r\n    [matAutocomplete]=\"auto\"\r\n    [matChipInputFor]=\"chipList\"\r\n    [formControl]=\"control\"\r\n    #input autocomplete=\"off\"\r\n    [matChipInputSeparatorKeyCodes]=\"separatorKeysCodes\"\r\n    [matChipInputAddOnBlur]=\"true\"\r\n    (matChipInputTokenEnd)=\"add($event)\">\r\n    <mat-autocomplete #auto=\"matAutocomplete\" (optionSelected)=\"selected($event)\">\r\n      @for (item of options | async; track item) {\r\n        <mat-option [value]=\"item\">\r\n          {{item}}\r\n        </mat-option>\r\n      }\r\n    </mat-autocomplete>\r\n  </mat-form-field>\r\n", styles: [":host{padding:8px}\n"], dependencies: [{ kind: "directive", type: i1$3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1$3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1$3.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "component", type: i4.MatChip, selector: "mat-basic-chip, [mat-basic-chip], mat-chip, [mat-chip]", inputs: ["role", "id", "aria-label", "aria-description", "value", "color", "removable", "highlighted", "disableRipple", "disabled"], outputs: ["removed", "destroyed"], exportAs: ["matChip"] }, { kind: "component", type: i4.MatChipGrid, selector: "mat-chip-grid", inputs: ["disabled", "placeholder", "required", "value", "errorStateMatcher"], outputs: ["change", "valueChange"] }, { kind: "directive", type: i4.MatChipInput, selector: "input[matChipInputFor]", inputs: ["matChipInputFor", "matChipInputAddOnBlur", "matChipInputSeparatorKeyCodes", "placeholder", "id", "disabled"], outputs: ["matChipInputTokenEnd"], exportAs: ["matChipInput", "matChipInputFor"] }, { kind: "directive", type: i4.MatChipRemove, selector: "[matChipRemove]" }, { kind: "component", type: i4$1.MatAutocomplete, selector: "mat-autocomplete", inputs: ["aria-label", "aria-labelledby", "displayWith", "autoActiveFirstOption", "autoSelectActiveOption", "requireSelection", "panelWidth", "disableRipple", "class", "hideSingleSelectionIndicator"], outputs: ["optionSelected", "opened", "closed", "optionActivated"], exportAs: ["matAutocomplete"] }, { kind: "component", type: i2$5.MatOption, selector: "mat-option", inputs: ["value", "id", "disabled"], outputs: ["onSelectionChange"], exportAs: ["matOption"] }, { kind: "directive", type: i4$1.MatAutocompleteTrigger, selector: "input[matAutocomplete], textarea[matAutocomplete]", inputs: ["matAutocomplete", "matAutocompletePosition", "matAutocompleteConnectedTo", "autocomplete", "matAutocompleteDisabled"], exportAs: ["matAutocompleteTrigger"] }, { kind: "component", type: i3$1.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "component", type: i10.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "pipe", type: i5.AsyncPipe, name: "async" }, { kind: "pipe", type: TranslatePipe, name: "translate" }] }); }
         | 
| 9539 | 
            +
                static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.5", type: TagsComponent, selector: "ng-component", viewQueries: [{ propertyName: "inputElement", first: true, predicate: ["input"], descendants: true, static: true }, { propertyName: "auto", first: true, predicate: ["auto"], descendants: true, static: true }], ngImport: i0, template: "<mat-form-field floatLabel=\"never\" subscriptSizing=\"dynamic\">\r\n  <mat-chip-grid #chipList [attr.aria-label]=\"'Tags'|translate\">\r\n    @for (item of tags; track item) {\r\n      <mat-chip\r\n        [removable]=\"true\" (removed)=\"remove(item)\">\r\n        {{item}}\r\n        <mat-icon matChipRemove>cancel</mat-icon>\r\n      </mat-chip>\r\n    }\r\n  </mat-chip-grid>\r\n  <input [placeholder]=\"'TagsHint'|translate\"\r\n    [matAutocomplete]=\"auto\"\r\n    [matChipInputFor]=\"chipList\"\r\n    [formControl]=\"control\"\r\n    #input autocomplete=\"off\"\r\n    [matChipInputSeparatorKeyCodes]=\"separatorKeysCodes\"\r\n    [matChipInputAddOnBlur]=\"true\"\r\n    (matChipInputTokenEnd)=\"add($event)\">\r\n    <mat-autocomplete #auto=\"matAutocomplete\" (optionSelected)=\"selected($event)\">\r\n      @for (item of options | async; track item) {\r\n        <mat-option [value]=\"item\">\r\n          {{item}}\r\n        </mat-option>\r\n      }\r\n    </mat-autocomplete>\r\n  </mat-form-field>\r\n", styles: [":host{min-width:260px;padding:8px}\n"], dependencies: [{ kind: "directive", type: i1$3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1$3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1$3.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "component", type: i4.MatChip, selector: "mat-basic-chip, [mat-basic-chip], mat-chip, [mat-chip]", inputs: ["role", "id", "aria-label", "aria-description", "value", "color", "removable", "highlighted", "disableRipple", "disabled"], outputs: ["removed", "destroyed"], exportAs: ["matChip"] }, { kind: "component", type: i4.MatChipGrid, selector: "mat-chip-grid", inputs: ["disabled", "placeholder", "required", "value", "errorStateMatcher"], outputs: ["change", "valueChange"] }, { kind: "directive", type: i4.MatChipInput, selector: "input[matChipInputFor]", inputs: ["matChipInputFor", "matChipInputAddOnBlur", "matChipInputSeparatorKeyCodes", "placeholder", "id", "disabled"], outputs: ["matChipInputTokenEnd"], exportAs: ["matChipInput", "matChipInputFor"] }, { kind: "directive", type: i4.MatChipRemove, selector: "[matChipRemove]" }, { kind: "component", type: i4$1.MatAutocomplete, selector: "mat-autocomplete", inputs: ["aria-label", "aria-labelledby", "displayWith", "autoActiveFirstOption", "autoSelectActiveOption", "requireSelection", "panelWidth", "disableRipple", "class", "hideSingleSelectionIndicator"], outputs: ["optionSelected", "opened", "closed", "optionActivated"], exportAs: ["matAutocomplete"] }, { kind: "component", type: i2$5.MatOption, selector: "mat-option", inputs: ["value", "id", "disabled"], outputs: ["onSelectionChange"], exportAs: ["matOption"] }, { kind: "directive", type: i4$1.MatAutocompleteTrigger, selector: "input[matAutocomplete], textarea[matAutocomplete]", inputs: ["matAutocomplete", "matAutocompletePosition", "matAutocompleteConnectedTo", "autocomplete", "matAutocompleteDisabled"], exportAs: ["matAutocompleteTrigger"] }, { kind: "component", type: i3$1.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "component", type: i10.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "pipe", type: i5.AsyncPipe, name: "async" }, { kind: "pipe", type: TranslatePipe, name: "translate" }] }); }
         | 
| 9535 9540 | 
             
            }
         | 
| 9536 9541 | 
             
            i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.5", ngImport: i0, type: TagsComponent, decorators: [{
         | 
| 9537 9542 | 
             
                        type: Component,
         | 
| 9538 | 
            -
                        args: [{ template: "<mat-form-field floatLabel=\"never\" subscriptSizing=\"dynamic\">\r\n  <mat-chip-grid #chipList [attr.aria-label]=\"'Tags'|translate\">\r\n    @for (item of tags; track item) {\r\n      <mat-chip\r\n        [removable]=\"true\" (removed)=\"remove(item)\">\r\n        {{item}}\r\n        <mat-icon matChipRemove>cancel</mat-icon>\r\n      </mat-chip>\r\n    }\r\n  </mat-chip-grid>\r\n  <input [placeholder]=\"'TagsHint'|translate\"\r\n    [matAutocomplete]=\"auto\"\r\n    [matChipInputFor]=\"chipList\"\r\n    [formControl]=\"control\"\r\n    #input autocomplete=\"off\"\r\n    [matChipInputSeparatorKeyCodes]=\"separatorKeysCodes\"\r\n    [matChipInputAddOnBlur]=\"true\"\r\n    (matChipInputTokenEnd)=\"add($event)\">\r\n    <mat-autocomplete #auto=\"matAutocomplete\" (optionSelected)=\"selected($event)\">\r\n      @for (item of options | async; track item) {\r\n        <mat-option [value]=\"item\">\r\n          {{item}}\r\n        </mat-option>\r\n      }\r\n    </mat-autocomplete>\r\n  </mat-form-field>\r\n", styles: [":host{padding:8px}\n"] }]
         | 
| 9543 | 
            +
                        args: [{ template: "<mat-form-field floatLabel=\"never\" subscriptSizing=\"dynamic\">\r\n  <mat-chip-grid #chipList [attr.aria-label]=\"'Tags'|translate\">\r\n    @for (item of tags; track item) {\r\n      <mat-chip\r\n        [removable]=\"true\" (removed)=\"remove(item)\">\r\n        {{item}}\r\n        <mat-icon matChipRemove>cancel</mat-icon>\r\n      </mat-chip>\r\n    }\r\n  </mat-chip-grid>\r\n  <input [placeholder]=\"'TagsHint'|translate\"\r\n    [matAutocomplete]=\"auto\"\r\n    [matChipInputFor]=\"chipList\"\r\n    [formControl]=\"control\"\r\n    #input autocomplete=\"off\"\r\n    [matChipInputSeparatorKeyCodes]=\"separatorKeysCodes\"\r\n    [matChipInputAddOnBlur]=\"true\"\r\n    (matChipInputTokenEnd)=\"add($event)\">\r\n    <mat-autocomplete #auto=\"matAutocomplete\" (optionSelected)=\"selected($event)\">\r\n      @for (item of options | async; track item) {\r\n        <mat-option [value]=\"item\">\r\n          {{item}}\r\n        </mat-option>\r\n      }\r\n    </mat-autocomplete>\r\n  </mat-form-field>\r\n", styles: [":host{min-width:260px;padding:8px}\n"] }]
         | 
| 9539 9544 | 
             
                    }], ctorParameters: () => [{ type: undefined, decorators: [{
         | 
| 9540 9545 | 
             
                                type: Inject,
         | 
| 9541 9546 | 
             
                                args: [POPUP_DATA]
         | 
| @@ -15139,9 +15144,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.5", ngImpor | |
| 15139 15144 | 
             
                        args: [{ name: 'amDurationFormat' }]
         | 
| 15140 15145 | 
             
                    }], ctorParameters: () => [{ type: TranslateService }] });
         | 
| 15141 15146 |  | 
| 15142 | 
            -
            const 
         | 
| 15143 | 
            -
            //ELLIPSIS = 'M 650, 150 a 75,150 0 1,0 1,0 z',
         | 
| 15144 | 
            -
            FYI_PATH = 'M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm1 15h-2v-6h2v6zm0-8h-2V7h2v2z', ESCALATED_PATH = 'M22 5.72l-4.6-3.86-1.29 1.53 4.6 3.86L22 5.72zM7.88 3.39L6.6 1.86 2 5.71l1.29 1.53 4.59-3.85zM12.5 8H11v6l4.75 2.85.75-1.23-4-2.37V8zM12 4c-4.97 0-9 4.03-9 9s4.02 9 9 9c4.97 0 9-4.03 9-9s-4.03-9-9-9zm0 16c-3.87 0-7-3.13-7-7s3.13-7 7-7 7 3.13 7 7-3.13 7-7 7z', WARNNING_PATH$1 = 'M 13.763735,1.8433735 H 6.3037349 l -5.27,5.27 v 7.4599995 l 5.27,5.27 h 7.4600001 l 5.27,-5.27 V 7.1133735 Z m -3.73,14.2999995 c -0.7200001,0 -1.3000001,-0.58 -1.3000001,-1.3 0,-0.72 0.58,-1.3 1.3000001,-1.3 0.72,0 1.3,0.58 1.3,1.3 0,0.72 -0.58,1.3 -1.3,1.3 z m 1,-4.3 H 9.0337349 V 5.8433735 h 2.0000001 z';
         | 
| 15147 | 
            +
            const FYI_PATH = 'M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm1 15h-2v-6h2v6zm0-8h-2V7h2v2z', ESCALATED_PATH = 'M22 5.72l-4.6-3.86-1.29 1.53 4.6 3.86L22 5.72zM7.88 3.39L6.6 1.86 2 5.71l1.29 1.53 4.59-3.85zM12.5 8H11v6l4.75 2.85.75-1.23-4-2.37V8zM12 4c-4.97 0-9 4.03-9 9s4.02 9 9 9c4.97 0 9-4.03 9-9s-4.03-9-9-9zm0 16c-3.87 0-7-3.13-7-7s3.13-7 7-7 7 3.13 7 7-3.13 7-7 7z', WARNNING_PATH$1 = 'M 13.763735,1.8433735 H 6.3037349 l -5.27,5.27 v 7.4599995 l 5.27,5.27 h 7.4600001 l 5.27,-5.27 V 7.1133735 Z m -3.73,14.2999995 c -0.7200001,0 -1.3000001,-0.58 -1.3000001,-1.3 0,-0.72 0.58,-1.3 1.3000001,-1.3 0.72,0 1.3,0.58 1.3,1.3 0,0.72 -0.58,1.3 -1.3,1.3 z m 1,-4.3 H 9.0337349 V 5.8433735 h 2.0000001 z';
         | 
| 15145 15148 | 
             
            /** flow-view component*/
         | 
| 15146 15149 | 
             
            class FlowViewComponent extends TraceBase {
         | 
| 15147 15150 | 
             
                /** workflow-view ctor */
         | 
| @@ -15153,8 +15156,7 @@ class FlowViewComponent extends TraceBase { | |
| 15153 15156 | 
             
                    this._elementRef = _elementRef;
         | 
| 15154 15157 | 
             
                    this.connectorType = 'Orthogonal';
         | 
| 15155 15158 | 
             
                    this.tool = DiagramTools$1.ZoomPan;
         | 
| 15156 | 
            -
                    this.diagramConstraints = DiagramConstraints$1. | 
| 15157 | 
            -
                        DiagramConstraints$1.Pan |
         | 
| 15159 | 
            +
                    this.diagramConstraints = DiagramConstraints$1.Pan |
         | 
| 15158 15160 | 
             
                        DiagramConstraints$1.LineRouting |
         | 
| 15159 15161 | 
             
                        DiagramConstraints$1.Bridging |
         | 
| 15160 15162 | 
             
                        DiagramConstraints$1.Zoom;
         | 
| @@ -15167,7 +15169,7 @@ class FlowViewComponent extends TraceBase { | |
| 15167 15169 | 
             
                        enableRouting: true,
         | 
| 15168 15170 | 
             
                        verticalSpacing: 50,
         | 
| 15169 15171 | 
             
                        margin: { top: 4 },
         | 
| 15170 | 
            -
                        //arrangement:  | 
| 15172 | 
            +
                        //arrangement: ChildArrangement.Nonlinear,
         | 
| 15171 15173 | 
             
                        //enableAnimation: true,
         | 
| 15172 15174 | 
             
                        //root: 'start',
         | 
| 15173 15175 | 
             
                        orientation: this.enableRtl ? 'RightToLeft' : 'LeftToRight',
         | 
| @@ -15208,10 +15210,9 @@ class FlowViewComponent extends TraceBase { | |
| 15208 15210 | 
             
                        scrollSettings: this.scrollSettings,
         | 
| 15209 15211 | 
             
                        snapSettings: this.snapSettings,
         | 
| 15210 15212 | 
             
                        constraints: this.diagramConstraints,
         | 
| 15211 | 
            -
                        getConnectorDefaults: this.connDefaults.bind(this),
         | 
| 15212 | 
            -
                        getNodeDefaults: this.nodeDefaults.bind(this),
         | 
| 15213 15213 | 
             
                    }, this._elementRef.nativeElement);
         | 
| 15214 15214 | 
             
                    this.diagram.doLayout();
         | 
| 15215 | 
            +
                    this.diagram.fitToPage({ margin: { top: 10 } });
         | 
| 15215 15216 | 
             
                    indicators.forEach((n, i) => {
         | 
| 15216 15217 | 
             
                        const parent = this.diagram.getNodeObject(n.addInfo.parentId);
         | 
| 15217 15218 | 
             
                        n.offsetX = parent.offsetX + (this.enableRtl ? -25 : 25);
         | 
| @@ -15219,7 +15220,6 @@ class FlowViewComponent extends TraceBase { | |
| 15219 15220 | 
             
                        n.zIndex = 1000 + i;
         | 
| 15220 15221 | 
             
                        this.diagram.add(n);
         | 
| 15221 15222 | 
             
                    });
         | 
| 15222 | 
            -
                    this.diagram.fitToPage({ margin: { top: 10 } });
         | 
| 15223 15223 | 
             
                    interval(60000).pipe(takeUntil(this._destroy)).subscribe(this._refresh.bind(this));
         | 
| 15224 15224 | 
             
                }
         | 
| 15225 15225 | 
             
                _refresh() {
         | 
| @@ -15242,63 +15242,12 @@ class FlowViewComponent extends TraceBase { | |
| 15242 15242 | 
             
                            n.addInfo.tooltip.estimatedTime = this._timeEstimate(node),
         | 
| 15243 15243 | 
             
                                n.tooltip.content = this._tooltip(n.addInfo.tooltip);
         | 
| 15244 15244 | 
             
                    });
         | 
| 15245 | 
            -
                    // this.diagram.dataBind();
         | 
| 15246 | 
            -
                }
         | 
| 15247 | 
            -
                /**
         | 
| 15248 | 
            -
                 *
         | 
| 15249 | 
            -
                 * @param obj
         | 
| 15250 | 
            -
                 */
         | 
| 15251 | 
            -
                nodeDefaults(obj) {
         | 
| 15252 | 
            -
                    const { recipient, node, indicator } = obj.addInfo;
         | 
| 15253 | 
            -
                    if (indicator) {
         | 
| 15254 | 
            -
                        obj.width = obj.height = 15;
         | 
| 15255 | 
            -
                        obj.style.strokeWidth = 0;
         | 
| 15256 | 
            -
                    }
         | 
| 15257 | 
            -
                    else {
         | 
| 15258 | 
            -
                        obj.width = obj.height = 50;
         | 
| 15259 | 
            -
                        if (obj.annotations && obj.annotations.length)
         | 
| 15260 | 
            -
                            obj.annotations[0].style.color = this._session.theme.dark ? 'white' : 'black';
         | 
| 15261 | 
            -
                        if (node && node.estimate) {
         | 
| 15262 | 
            -
                            obj.style.strokeColor = this._session.theme.dark ? 'white' : 'black';
         | 
| 15263 | 
            -
                            obj.style.opacity = obj.annotations[0].style.opacity = .6;
         | 
| 15264 | 
            -
                            obj.style.fill = 'transparent';
         | 
| 15265 | 
            -
                        }
         | 
| 15266 | 
            -
                        else {
         | 
| 15267 | 
            -
                            obj.style.strokeColor = this._accentColor;
         | 
| 15268 | 
            -
                            obj.style.fill = recipient && recipient.pending ?
         | 
| 15269 | 
            -
                                this._session.getAccent(recipient.userId === this._session.userId ? 500 : 400) : 'transparent';
         | 
| 15270 | 
            -
                        }
         | 
| 15271 | 
            -
                        obj.style.strokeWidth = 2;
         | 
| 15272 | 
            -
                    }
         | 
| 15273 | 
            -
                    return obj;
         | 
| 15274 | 
            -
                }
         | 
| 15275 | 
            -
                /**
         | 
| 15276 | 
            -
                 *
         | 
| 15277 | 
            -
                 * @param connector
         | 
| 15278 | 
            -
                 */
         | 
| 15279 | 
            -
                connDefaults(connector) {
         | 
| 15280 | 
            -
                    connector.type = this.connectorType;
         | 
| 15281 | 
            -
                    connector.cornerRadius = 6;
         | 
| 15282 | 
            -
                    connector.targetDecorator.height = 7;
         | 
| 15283 | 
            -
                    connector.targetDecorator.width = 7;
         | 
| 15284 | 
            -
                    if (connector.addInfo.estimate) {
         | 
| 15285 | 
            -
                        connector.style.strokeDashArray = '2 2';
         | 
| 15286 | 
            -
                        connector.style.strokeColor =
         | 
| 15287 | 
            -
                            connector.targetDecorator.style.fill =
         | 
| 15288 | 
            -
                                connector.targetDecorator.style.strokeColor =
         | 
| 15289 | 
            -
                                    this._session.theme.dark ? 'white' : 'black';
         | 
| 15290 | 
            -
                        connector.style.strokeWidth = 1;
         | 
| 15291 | 
            -
                    }
         | 
| 15292 | 
            -
                    else {
         | 
| 15293 | 
            -
                        connector.style.strokeColor = connector.targetDecorator.style.strokeColor = connector.targetDecorator.style.fill = this._accentColor;
         | 
| 15294 | 
            -
                        connector.style.strokeWidth = 2;
         | 
| 15295 | 
            -
                    }
         | 
| 15296 | 
            -
                    connector.targetDecorator.shape = 'None';
         | 
| 15297 15245 | 
             
                }
         | 
| 15298 15246 | 
             
                /** */
         | 
| 15299 15247 | 
             
                async _prepare() {
         | 
| 15300 15248 | 
             
                    const { connectors: dconnectors, nodes: dnodes } = this.model.workflow;
         | 
| 15301 15249 | 
             
                    const indicators = [], connectors = [], nodes = [];
         | 
| 15250 | 
            +
                    const color = this._session.theme.dark ? 'white' : 'black';
         | 
| 15302 15251 | 
             
                    let zIndex = 500;
         | 
| 15303 15252 | 
             
                    for (let node of dnodes) {
         | 
| 15304 15253 | 
             
                        if (nodes.find(n => n.id == node.id))
         | 
| @@ -15328,10 +15277,18 @@ class FlowViewComponent extends TraceBase { | |
| 15328 15277 | 
             
                            } while (r < recipients.length);
         | 
| 15329 15278 | 
             
                            for (r = 0; r < recipients.length; r++) {
         | 
| 15330 15279 | 
             
                                let recipient = recipients[r];
         | 
| 15331 | 
            -
                                const { annotation, tooltip } = await this._note(node, recipient);
         | 
| 15332 | 
            -
                                 | 
| 15333 | 
            -
             | 
| 15334 | 
            -
                                     | 
| 15280 | 
            +
                                const { annotation, tooltip } = await this._note(node, recipient), content = this._tooltip(tooltip), id = r === 0 ? node.id : node.id + r.toString();
         | 
| 15281 | 
            +
                                nodes.push({
         | 
| 15282 | 
            +
                                    id,
         | 
| 15283 | 
            +
                                    width: 50,
         | 
| 15284 | 
            +
                                    height: 50,
         | 
| 15285 | 
            +
                                    style: {
         | 
| 15286 | 
            +
                                        strokeWidth: 2,
         | 
| 15287 | 
            +
                                        opacity: node.estimate ? .6 : 1,
         | 
| 15288 | 
            +
                                        strokeColor: node.estimate ? color : this._accentColor,
         | 
| 15289 | 
            +
                                        fill: !node.estimate && recipient.pending ?
         | 
| 15290 | 
            +
                                            this._session.getAccent(recipient.userId === this._session.userId ? 500 : 400) : 'transparent'
         | 
| 15291 | 
            +
                                    },
         | 
| 15335 15292 | 
             
                                    shape: this._configuration[node.type].shape,
         | 
| 15336 15293 | 
             
                                    zIndex: zIndex++,
         | 
| 15337 15294 | 
             
                                    tooltip: {
         | 
| @@ -15347,6 +15304,10 @@ class FlowViewComponent extends TraceBase { | |
| 15347 15304 | 
             
                                        node
         | 
| 15348 15305 | 
             
                                    },
         | 
| 15349 15306 | 
             
                                    annotations: [{
         | 
| 15307 | 
            +
                                            style: {
         | 
| 15308 | 
            +
                                                color: color,
         | 
| 15309 | 
            +
                                                opacity: node.estimate ? .6 : 1,
         | 
| 15310 | 
            +
                                            },
         | 
| 15350 15311 | 
             
                                            content: annotation,
         | 
| 15351 15312 | 
             
                                            margin: { top: 4 },
         | 
| 15352 15313 | 
             
                                            verticalAlignment: 'Top',
         | 
| @@ -15355,74 +15316,84 @@ class FlowViewComponent extends TraceBase { | |
| 15355 15316 | 
             
                                                x: .5
         | 
| 15356 15317 | 
             
                                            }
         | 
| 15357 15318 | 
             
                                        }]
         | 
| 15358 | 
            -
                                };
         | 
| 15359 | 
            -
                                nodes.push(nod);
         | 
| 15319 | 
            +
                                });
         | 
| 15360 15320 | 
             
                                // add action indicator
         | 
| 15361 15321 | 
             
                                if (recipient.action) {
         | 
| 15362 15322 | 
             
                                    const action = this._session.profile.actions.find(a => a.name === recipient.action);
         | 
| 15363 | 
            -
                                     | 
| 15364 | 
            -
                                         | 
| 15365 | 
            -
                                            id:  | 
| 15323 | 
            +
                                    action.shape && !recipient.pending &&
         | 
| 15324 | 
            +
                                        indicators.push({
         | 
| 15325 | 
            +
                                            id: id + 'action',
         | 
| 15326 | 
            +
                                            width: 15,
         | 
| 15327 | 
            +
                                            height: 15,
         | 
| 15366 15328 | 
             
                                            shape: {
         | 
| 15367 15329 | 
             
                                                type: 'Path',
         | 
| 15368 15330 | 
             
                                                data: action.shape,
         | 
| 15369 15331 | 
             
                                                align: this.enableRtl ? 'XMinYMax' : 'XMaxYMax',
         | 
| 15370 15332 | 
             
                                            },
         | 
| 15371 15333 | 
             
                                            style: {
         | 
| 15334 | 
            +
                                                strokeWidth: 0,
         | 
| 15372 15335 | 
             
                                                fill: action.color || this._session.getAccent(900)
         | 
| 15373 15336 | 
             
                                            },
         | 
| 15374 15337 | 
             
                                            addInfo: {
         | 
| 15375 15338 | 
             
                                                indicator: true,
         | 
| 15376 | 
            -
                                                parentId:  | 
| 15339 | 
            +
                                                parentId: id
         | 
| 15377 15340 | 
             
                                            }
         | 
| 15378 | 
            -
                                        };
         | 
| 15379 | 
            -
                                        indicators.push(actionIndicator);
         | 
| 15380 | 
            -
                                    }
         | 
| 15341 | 
            +
                                        });
         | 
| 15381 15342 | 
             
                                }
         | 
| 15382 15343 | 
             
                                // fyi indicator
         | 
| 15383 | 
            -
                                 | 
| 15344 | 
            +
                                recipient.fyi &&
         | 
| 15384 15345 | 
             
                                    indicators.push({
         | 
| 15385 | 
            -
                                        id:  | 
| 15346 | 
            +
                                        id: id + 'fyi',
         | 
| 15347 | 
            +
                                        width: 15,
         | 
| 15348 | 
            +
                                        height: 15,
         | 
| 15386 15349 | 
             
                                        shape: {
         | 
| 15387 15350 | 
             
                                            type: 'Path',
         | 
| 15388 15351 | 
             
                                            data: FYI_PATH,
         | 
| 15389 15352 | 
             
                                            align: this.enableRtl ? 'XMinYMax' : 'XMaxYMax'
         | 
| 15390 15353 | 
             
                                        },
         | 
| 15391 15354 | 
             
                                        style: {
         | 
| 15355 | 
            +
                                            strokeWidth: 0,
         | 
| 15392 15356 | 
             
                                            fill: '#1976d2'
         | 
| 15393 15357 | 
             
                                        },
         | 
| 15394 15358 | 
             
                                        addInfo: {
         | 
| 15395 15359 | 
             
                                            indicator: true,
         | 
| 15396 | 
            -
                                            parentId:  | 
| 15360 | 
            +
                                            parentId: id
         | 
| 15397 15361 | 
             
                                        }
         | 
| 15398 15362 | 
             
                                    });
         | 
| 15399 15363 | 
             
                                // escalate indicator
         | 
| 15400 | 
            -
                                 | 
| 15401 | 
            -
                                     | 
| 15402 | 
            -
                                        id:  | 
| 15364 | 
            +
                                recipient.escalated &&
         | 
| 15365 | 
            +
                                    indicators.push({
         | 
| 15366 | 
            +
                                        id: id + 'escalate',
         | 
| 15367 | 
            +
                                        width: 15,
         | 
| 15368 | 
            +
                                        height: 15,
         | 
| 15403 15369 | 
             
                                        shape: {
         | 
| 15404 15370 | 
             
                                            type: 'Path',
         | 
| 15405 15371 | 
             
                                            data: ESCALATED_PATH,
         | 
| 15406 15372 | 
             
                                            align: this.enableRtl ? 'XMinYMax' : 'XMaxYMax'
         | 
| 15407 15373 | 
             
                                        },
         | 
| 15408 15374 | 
             
                                        style: {
         | 
| 15375 | 
            +
                                            strokeWidth: 0,
         | 
| 15409 15376 | 
             
                                            fill: this._session.getAccent(900)
         | 
| 15410 15377 | 
             
                                        },
         | 
| 15411 15378 | 
             
                                        addInfo: {
         | 
| 15412 15379 | 
             
                                            indicator: true,
         | 
| 15413 | 
            -
                                            parentId:  | 
| 15380 | 
            +
                                            parentId: id
         | 
| 15414 15381 | 
             
                                        }
         | 
| 15415 | 
            -
                                    };
         | 
| 15416 | 
            -
                                    indicators.push(escalateIndicator);
         | 
| 15417 | 
            -
                                }
         | 
| 15382 | 
            +
                                    });
         | 
| 15418 15383 | 
             
                            }
         | 
| 15419 15384 | 
             
                        }
         | 
| 15420 15385 | 
             
                        else {
         | 
| 15421 | 
            -
                            const { state, annotation, tooltip } = await this._shape(node);
         | 
| 15422 | 
            -
                            const { shape } = configuration;
         | 
| 15423 | 
            -
                            const content = this._tooltip(tooltip);
         | 
| 15386 | 
            +
                            const { state, annotation, tooltip } = await this._shape(node), { shape } = configuration, content = this._tooltip(tooltip);
         | 
| 15424 15387 | 
             
                            nodes.push({
         | 
| 15425 15388 | 
             
                                id: node.id,
         | 
| 15389 | 
            +
                                width: 50,
         | 
| 15390 | 
            +
                                height: 50,
         | 
| 15391 | 
            +
                                style: {
         | 
| 15392 | 
            +
                                    strokeWidth: 2,
         | 
| 15393 | 
            +
                                    opacity: node.estimate ? .6 : 1,
         | 
| 15394 | 
            +
                                    strokeColor: node.estimate ? color : this._accentColor,
         | 
| 15395 | 
            +
                                    fill: 'transparent'
         | 
| 15396 | 
            +
                                },
         | 
| 15426 15397 | 
             
                                shape, //: {type: 'Path', data: ELLIPSIS },
         | 
| 15427 15398 | 
             
                                zIndex: zIndex++,
         | 
| 15428 15399 | 
             
                                tooltip: {
         | 
| @@ -15441,19 +15412,25 @@ class FlowViewComponent extends TraceBase { | |
| 15441 15412 | 
             
                                        offset: shape.type === 'Path' ? {
         | 
| 15442 15413 | 
             
                                            y: 1
         | 
| 15443 15414 | 
             
                                        } : { x: .5 },
         | 
| 15444 | 
            -
                                        style: { | 
| 15415 | 
            +
                                        style: {
         | 
| 15416 | 
            +
                                            color: color,
         | 
| 15417 | 
            +
                                            opacity: node.estimate ? .6 : 1,
         | 
| 15418 | 
            +
                                        },
         | 
| 15445 15419 | 
             
                                        verticalAlignment: shape.type === 'Path' ? 'Top' : 'Center'
         | 
| 15446 15420 | 
             
                                    }]
         | 
| 15447 15421 | 
             
                            });
         | 
| 15448 | 
            -
                             | 
| 15422 | 
            +
                            state && state.shape && !node.estimate &&
         | 
| 15449 15423 | 
             
                                indicators.push({
         | 
| 15450 15424 | 
             
                                    id: node.id + 'state',
         | 
| 15425 | 
            +
                                    width: 15,
         | 
| 15426 | 
            +
                                    height: 15,
         | 
| 15451 15427 | 
             
                                    shape: {
         | 
| 15452 15428 | 
             
                                        type: 'Path',
         | 
| 15453 15429 | 
             
                                        data: state.shape,
         | 
| 15454 15430 | 
             
                                        align: this.enableRtl ? 'XMaxYMax' : 'XMinYMax'
         | 
| 15455 15431 | 
             
                                    },
         | 
| 15456 15432 | 
             
                                    style: {
         | 
| 15433 | 
            +
                                        strokeWidth: 0,
         | 
| 15457 15434 | 
             
                                        fill: state.color || 'black'
         | 
| 15458 15435 | 
             
                                    },
         | 
| 15459 15436 | 
             
                                    addInfo: {
         | 
| @@ -15462,49 +15439,52 @@ class FlowViewComponent extends TraceBase { | |
| 15462 15439 | 
             
                                        node: node
         | 
| 15463 15440 | 
             
                                    }
         | 
| 15464 15441 | 
             
                                });
         | 
| 15465 | 
            -
                             | 
| 15466 | 
            -
                                 | 
| 15442 | 
            +
                            node.error &&
         | 
| 15443 | 
            +
                                indicators.push({
         | 
| 15467 15444 | 
             
                                    id: node.id + 'exception',
         | 
| 15445 | 
            +
                                    width: 15,
         | 
| 15446 | 
            +
                                    height: 15,
         | 
| 15468 15447 | 
             
                                    shape: {
         | 
| 15469 15448 | 
             
                                        type: 'Path',
         | 
| 15470 15449 | 
             
                                        data: WARNNING_PATH$1,
         | 
| 15471 15450 | 
             
                                        align: this.enableRtl ? 'XMinYMax' : 'XMaxYMax'
         | 
| 15472 15451 | 
             
                                    },
         | 
| 15473 15452 | 
             
                                    style: {
         | 
| 15453 | 
            +
                                        strokeWidth: 0,
         | 
| 15474 15454 | 
             
                                        fill: getWarn(800)
         | 
| 15475 15455 | 
             
                                    },
         | 
| 15476 15456 | 
             
                                    addInfo: {
         | 
| 15477 15457 | 
             
                                        indicator: true,
         | 
| 15478 15458 | 
             
                                        parentId: node.id
         | 
| 15479 15459 | 
             
                                    }
         | 
| 15480 | 
            -
                                };
         | 
| 15481 | 
            -
                                indicators.push(warnningIndicator);
         | 
| 15482 | 
            -
                            }
         | 
| 15460 | 
            +
                                });
         | 
| 15483 15461 | 
             
                        }
         | 
| 15484 15462 | 
             
                    }
         | 
| 15485 15463 | 
             
                    // TODO
         | 
| 15486 15464 | 
             
                    // longest path, remove short path connectors
         | 
| 15487 | 
            -
                    function deepen(nodeId, depth = 0) {
         | 
| 15488 | 
            -
             | 
| 15489 | 
            -
             | 
| 15490 | 
            -
             | 
| 15491 | 
            -
             | 
| 15492 | 
            -
             | 
| 15493 | 
            -
             | 
| 15494 | 
            -
             | 
| 15495 | 
            -
             | 
| 15496 | 
            -
             | 
| 15497 | 
            -
             | 
| 15498 | 
            -
             | 
| 15499 | 
            -
             | 
| 15500 | 
            -
             | 
| 15501 | 
            -
             | 
| 15502 | 
            -
             | 
| 15503 | 
            -
             | 
| 15504 | 
            -
             | 
| 15505 | 
            -
             | 
| 15506 | 
            -
             | 
| 15507 | 
            -
                    }
         | 
| 15465 | 
            +
                    //function deepen(nodeId: string, depth = 0) {
         | 
| 15466 | 
            +
                    //  nodes.filter(n => (n.addInfo as NodeInfoModel).node.id === nodeId).
         | 
| 15467 | 
            +
                    //    forEach(n => {
         | 
| 15468 | 
            +
                    //      const { depth: nodeDepth } = n.addInfo as NodeInfoModel;
         | 
| 15469 | 
            +
                    //      if (nodeDepth) {
         | 
| 15470 | 
            +
                    //        if (nodeDepth < depth) {
         | 
| 15471 | 
            +
                    //          dconnectors.filter(c => c.targetId === nodeId &&
         | 
| 15472 | 
            +
                    //            nodes.filter(n => (n.addInfo as NodeInfoModel).node.id === c.sourceId &&
         | 
| 15473 | 
            +
                    //              (n.addInfo as NodeInfoModel).depth === nodeDepth - 1).length).
         | 
| 15474 | 
            +
                    //            forEach(c =>
         | 
| 15475 | 
            +
                    //              dconnectors.remove(c)
         | 
| 15476 | 
            +
                    //            );
         | 
| 15477 | 
            +
                    //          (n.addInfo as NodeInfoModel).depth = depth;
         | 
| 15478 | 
            +
                    //        } else if (nodeDepth > depth)
         | 
| 15479 | 
            +
                    //          dconnectors.filter(c => c.sourceId === nodeId).forEach(c => dconnectors.remove(c));
         | 
| 15480 | 
            +
                    //      } else {
         | 
| 15481 | 
            +
                    //        (n.addInfo as NodeInfoModel).depth = depth;
         | 
| 15482 | 
            +
                    //        dconnectors.filter(c => c.sourceId === nodeId).forEach(c =>
         | 
| 15483 | 
            +
                    //          deepen(c.targetId, depth + 1)
         | 
| 15484 | 
            +
                    //        );
         | 
| 15485 | 
            +
                    //      }
         | 
| 15486 | 
            +
                    //    });
         | 
| 15487 | 
            +
                    //}
         | 
| 15508 15488 | 
             
                    for (let connector of dconnectors) {
         | 
| 15509 15489 | 
             
                        let sources = nodes.filter(n => n.addInfo.node.id === connector.sourceId), targets = nodes.filter(n => n.addInfo.node.id === connector.targetId);
         | 
| 15510 15490 | 
             
                        for (let source of sources)
         | 
| @@ -15512,6 +15492,28 @@ class FlowViewComponent extends TraceBase { | |
| 15512 15492 | 
             
                                connectors.push({
         | 
| 15513 15493 | 
             
                                    sourceID: source.id,
         | 
| 15514 15494 | 
             
                                    targetID: target.id,
         | 
| 15495 | 
            +
                                    type: this.connectorType,
         | 
| 15496 | 
            +
                                    cornerRadius: 6,
         | 
| 15497 | 
            +
                                    targetDecorator: {
         | 
| 15498 | 
            +
                                        shape: 'None',
         | 
| 15499 | 
            +
                                        height: 7,
         | 
| 15500 | 
            +
                                        width: 7,
         | 
| 15501 | 
            +
                                        style: connector.estimate ? {
         | 
| 15502 | 
            +
                                            fill: color,
         | 
| 15503 | 
            +
                                            strokeColor: color
         | 
| 15504 | 
            +
                                        } : {
         | 
| 15505 | 
            +
                                            strokeColor: this._accentColor,
         | 
| 15506 | 
            +
                                            fill: this._accentColor
         | 
| 15507 | 
            +
                                        },
         | 
| 15508 | 
            +
                                    },
         | 
| 15509 | 
            +
                                    style: connector.estimate ? {
         | 
| 15510 | 
            +
                                        strokeDashArray: '2 2',
         | 
| 15511 | 
            +
                                        strokeColor: color,
         | 
| 15512 | 
            +
                                        strokeWidth: 1
         | 
| 15513 | 
            +
                                    } : {
         | 
| 15514 | 
            +
                                        strokeColor: this._accentColor,
         | 
| 15515 | 
            +
                                        strokeWidth: 2
         | 
| 15516 | 
            +
                                    },
         | 
| 15515 15517 | 
             
                                    addInfo: {
         | 
| 15516 15518 | 
             
                                        estimate: connector.estimate,
         | 
| 15517 15519 | 
             
                                        time: connector.time
         | 
| @@ -19123,6 +19125,9 @@ class SlotsComponent { | |
| 19123 19125 | 
             
                    this._selectedTabIndex = value;
         | 
| 19124 19126 | 
             
                    this._setTabAnimation();
         | 
| 19125 19127 | 
             
                }
         | 
| 19128 | 
            +
                get selectedTab() {
         | 
| 19129 | 
            +
                    return this.tabs[this.selectedTabIndex];
         | 
| 19130 | 
            +
                }
         | 
| 19126 19131 | 
             
                constructor(data, _session, _cd, _router, _title, _injector) {
         | 
| 19127 19132 | 
             
                    this._session = _session;
         | 
| 19128 19133 | 
             
                    this._cd = _cd;
         | 
| @@ -20214,7 +20219,7 @@ class SlotsComponent { | |
| 20214 20219 | 
             
                    this._destroy.complete();
         | 
| 20215 20220 | 
             
                }
         | 
| 20216 20221 | 
             
                static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.5", ngImport: i0, type: SlotsComponent, deps: [{ token: PANES_DATA }, { token: SessionService }, { token: i0.ChangeDetectorRef }, { token: PanesRouter }, { token: WindowTitleService }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Component }); }
         | 
| 20217 | 
            -
                static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.5", type: SlotsComponent, selector: "bizdoc-panes-outlet", outputs: { dialogChange: "dialogChange" }, host: { listeners: { "document:keydown": "handleKeydown($event)", "window:resize": "onResize()" } }, viewQueries: [{ propertyName: "_panesContainerRef", first: true, predicate: ["panesEl"], descendants: true, read: ViewContainerRef, static: true }, { propertyName: "_tabsElement", first: true, predicate: ["tabsEl"], descendants: true }, { propertyName: "_scrollable", first: true, predicate: CdkScrollable, descendants: true, static: true }], ngImport: i0, template: "<div #panesEl class=\"panes\"\r\n     cdkScrollable\r\n     @panes\r\n     (scroll)=\"enableNavigationArrows($event)\">\r\n  <!---->\r\n  @if (prev) {\r\n  <div class=\"scroll-arrow\" (click)=\"scrollBy(-400)\" matRipple [matRippleUnbounded]=\"true\" [matRippleCentered]=\"true\" [matRippleColor]=\"accent\">\r\n    <i class=\"material-icons mat-icon-rtl-mirror\">\r\n      arrow_back_ios\r\n    </i>\r\n  </div>\r\n  }\r\n  <!--panes-->\r\n  @for (p of panes; track p; let i = $index) {\r\n  <div (mouseenter)=\"selectedIndex !== i && !dragging && select(i)\"\r\n       (click)=\"select(i)\"\r\n       [class.active]=\"selectedIndex === i && panes.length > 1\" class=\"pane\" @pane>\r\n    <ng-container [cdkPortalOutlet]=\"p._portal\" (attached)=\"p._instance = $event.instance\"></ng-container>\r\n  </div>\r\n  @if (i < panes.length - 1) {\r\n  <div class=\"pane-separator\" (mousedown)=\"onPaneResize(p, $event)\"></div>\r\n  }\r\n  }\r\n  <!--dialog-->\r\n  @if (dialog) {\r\n  <div class=\"backdrop\" (click)=\"closeTab(0)\"></div>\r\n  }\r\n  <!--next-->\r\n  @if (next) {\r\n  <div class=\"scroll-arrow forward\">\r\n    <i class=\"material-icons mat-icon-rtl-mirror\" matRipple [matRippleUnbounded]=\"true\" [matRippleCentered]=\"true\" [matRippleRadius]=\"30\" [matRippleColor]=\"accent\"\r\n       (click)=\"scrollBy(400)\">\r\n      arrow_forward_ios\r\n    </i>\r\n  </div>\r\n  }\r\n</div>\r\n<!--tabs-->\r\n@if (tabs.length) {\r\n<div class=\"tabs-separator\" (mousedown)=\"onTabResize($event)\"></div>\r\n<div class=\"tabs mat-elevation-z18\" #tabsEl [@tabs]=\"tabsAnimation\" (@tabs.done)=\"done()\">\r\n  <!--title-->\r\n  <div class=\"row tabs-title\">\r\n    @if (swapTab) {\r\n    <button mat-icon-button (click)=\"tabBack()\" [bizdocTooltip]=\"prevGroup || ('Back'|translate)\"><mat-icon class=\"mat-icon-rtl-mirror\">arrow_back</mat-icon></button>\r\n    }\r\n    <h2>{{group}}</h2>\r\n    @if | 
| 20222 | 
            +
                static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.5", type: SlotsComponent, selector: "bizdoc-panes-outlet", outputs: { dialogChange: "dialogChange" }, host: { listeners: { "document:keydown": "handleKeydown($event)", "window:resize": "onResize()" } }, viewQueries: [{ propertyName: "_panesContainerRef", first: true, predicate: ["panesEl"], descendants: true, read: ViewContainerRef, static: true }, { propertyName: "_tabsElement", first: true, predicate: ["tabsEl"], descendants: true }, { propertyName: "_scrollable", first: true, predicate: CdkScrollable, descendants: true, static: true }], ngImport: i0, template: "<div #panesEl class=\"panes\"\r\n     cdkScrollable\r\n     @panes\r\n     (scroll)=\"enableNavigationArrows($event)\">\r\n  <!---->\r\n  @if (prev) {\r\n  <div class=\"scroll-arrow\" (click)=\"scrollBy(-400)\" matRipple [matRippleUnbounded]=\"true\" [matRippleCentered]=\"true\" [matRippleColor]=\"accent\">\r\n    <i class=\"material-icons mat-icon-rtl-mirror\">\r\n      arrow_back_ios\r\n    </i>\r\n  </div>\r\n  }\r\n  <!--panes-->\r\n  @for (p of panes; track p; let i = $index) {\r\n  <div (mouseenter)=\"selectedIndex !== i && !dragging && select(i)\"\r\n       (click)=\"select(i)\"\r\n       [class.active]=\"selectedIndex === i && panes.length > 1\" class=\"pane\" @pane>\r\n    <ng-container [cdkPortalOutlet]=\"p._portal\" (attached)=\"p._instance = $event.instance\"></ng-container>\r\n  </div>\r\n  @if (i < panes.length - 1) {\r\n  <div class=\"pane-separator\" (mousedown)=\"onPaneResize(p, $event)\"></div>\r\n  }\r\n  }\r\n  <!--dialog-->\r\n  @if (dialog) {\r\n  <div class=\"backdrop\" (click)=\"closeTab(0)\"></div>\r\n  }\r\n  <!--next-->\r\n  @if (next) {\r\n  <div class=\"scroll-arrow forward\">\r\n    <i class=\"material-icons mat-icon-rtl-mirror\" matRipple [matRippleUnbounded]=\"true\" [matRippleCentered]=\"true\" [matRippleRadius]=\"30\" [matRippleColor]=\"accent\"\r\n       (click)=\"scrollBy(400)\">\r\n      arrow_forward_ios\r\n    </i>\r\n  </div>\r\n  }\r\n</div>\r\n<!--tabs-->\r\n@if (tabs.length) {\r\n<div class=\"tabs-separator\" (mousedown)=\"onTabResize($event)\"></div>\r\n<div class=\"tabs mat-elevation-z18\" #tabsEl [@tabs]=\"tabsAnimation\" (@tabs.done)=\"done()\">\r\n  <!--title-->\r\n  <div class=\"row tabs-title\">\r\n    @if (swapTab) {\r\n    <button mat-icon-button (click)=\"tabBack()\" [bizdocTooltip]=\"prevGroup || ('Back'|translate)\"><mat-icon class=\"mat-icon-rtl-mirror\">arrow_back</mat-icon></button>\r\n    }\r\n    <h2>{{group}}</h2>\r\n    @if(selectedTab?.expandable) {\r\n    <button mat-icon-button (click)=\"expandTab()\" [bizdocTooltip]=\"'Expand'| translate\"><mat-icon class=\"mat-icon-rtl-mirror\" style=\"font-size: 22px\">open_in_full</mat-icon></button>\r\n    }\r\n    @if(selectedTab?.dismissable) {\r\n    <span class=\"divider\"></span>\r\n    <button mat-icon-button (click)=\"collapse()\" bizdocTooltip=\"Esc\"><mat-icon>close</mat-icon></button>\r\n    }\r\n  </div>\r\n  <nav mat-tab-nav-bar color=\"accent\" [disablePagination]=\"true\" [tabPanel]=\"tabPanel\">\r\n    @for (t of tabs; track t; let i = $index) {\r\n    <a mat-tab-link class=\"mat-tab-link\"\r\n       (click)=\"selectedTabIndex = i\"\r\n       [active]=\"selectedTabIndex === i\">\r\n      <mat-icon [matBadge]=\"t.badge\" [matBadgeHidden]=\"!t.badge\" matBadgeSize=\"small\" matBadgeColor=\"accent\" aria-hidden=\"false\">{{t.icon}}</mat-icon> \r\n      {{t.title}}\r\n      <!--@if (t.dismissable) {\r\n      <mat-icon (click)=\"closeTab(i)\" class=\"tool\">close</mat-icon>\r\n      }-->\r\n      <!--inline=\"true\"-->\r\n    </a>\r\n    }\r\n  </nav>\r\n  <mat-tab-nav-panel #tabPanel class=\"flex\">\r\n    @for (t of tabs; track t; let i = $index) {\r\n    <div [style.display]=\"selectedTabIndex === i ? '': 'none'\" class=\"tab\" [@tab]=\"selectedTabIndex\">\r\n      <ng-container [cdkPortalOutlet]=\"t._portal\" (attached)=\"t._instance = $event.instance\"></ng-container>\r\n    </div>\r\n    }\r\n  </mat-tab-nav-panel>\r\n</div>\r\n}\r\n", styles: [":host{flex:1;overflow:hidden;display:flex}.scroll-arrow{cursor:pointer;align-self:center;position:sticky;top:50%;z-index:200}.scroll-arrow i{font-size:50px;opacity:.2}.scroll-arrow i:hover{opacity:.9}.scroll-arrow:first-child{margin-inline-start:-50px;left:15px}.scroll-arrow:last-child{margin-inline-end:-50px;right:0}.panes{overflow-x:auto;position:relative;flex:1;height:100%;display:flex;-ms-flex-direction:row;-webkit-flex-direction:row;flex-direction:row}.panes .pane{-webkit-flex-grow:1;flex-grow:1;min-width:420px;overflow-y:auto;overflow-x:clip}.panes .pane>*{display:flex;-ms-flex-direction:column;-webkit-flex-direction:column;flex-direction:column;overflow-x:hidden;flex-grow:1}.pane-separator,.tabs-separator{cursor:ew-resize;background-repeat:no-repeat;background-position:center;display:table;height:100%;-moz-user-select:none;-ms-user-select:none;-webkit-user-select:none;user-select:none}.pane-separator{width:8px}.tabs-separator{width:12px}::ng-deep .mat-mdc-tab-link-container{overflow-x:auto;border-bottom:1px solid lightgray;-ms-overflow-style:none;scrollbar-width:none}::ng-deep .mat-mdc-tab-link-container::-webkit-scrollbar{display:none}::ng-deep .mat-mdc-tab-nav-panel{overflow-y:auto}.tabs{display:flex;-ms-flex-direction:column;-webkit-flex-direction:column;flex-direction:column;z-index:300;-webkit-flex-grow:0;flex-shrink:1;flex-basis:0;max-width:80vw}.tabs .tabs-title{align-items:center}.tabs .tabs-title h2{font-size:x-large;margin:9px;font-weight:100}.tabs .tabs-title:hover{opacity:1}.tabs .mat-mdc-tab-link .tool{opacity:0}.tabs .mat-mdc-tab-link:hover .tool{opacity:1}.tabs .tab{overflow-y:auto;overflow-x:hidden;display:flex;height:100%}\n"], dependencies: [{ kind: "directive", type: i5$4.CdkScrollable, selector: "[cdk-scrollable], [cdkScrollable]" }, { kind: "directive", type: i5$1.CdkPortalOutlet, selector: "[cdkPortalOutlet]", inputs: ["cdkPortalOutlet"], outputs: ["attached"], exportAs: ["cdkPortalOutlet"] }, { kind: "directive", type: i2$5.MatRipple, selector: "[mat-ripple], [matRipple]", inputs: ["matRippleColor", "matRippleUnbounded", "matRippleCentered", "matRippleRadius", "matRippleAnimation", "matRippleDisabled", "matRippleTrigger"], exportAs: ["matRipple"] }, { kind: "component", type: i7$5.MatTabNav, selector: "[mat-tab-nav-bar]", inputs: ["fitInkBarToContent", "mat-stretch-tabs", "animationDuration", "backgroundColor", "disableRipple", "color", "tabPanel"], exportAs: ["matTabNavBar", "matTabNav"] }, { kind: "component", type: i7$5.MatTabNavPanel, selector: "mat-tab-nav-panel", inputs: ["id"], exportAs: ["matTabNavPanel"] }, { kind: "component", type: i7$5.MatTabLink, selector: "[mat-tab-link], [matTabLink]", inputs: ["active", "disabled", "disableRipple", "tabIndex", "id"], exportAs: ["matTabLink"] }, { kind: "directive", type: i11.MatBadge, selector: "[matBadge]", inputs: ["matBadgeColor", "matBadgeOverlap", "matBadgeDisabled", "matBadgePosition", "matBadge", "matBadgeDescription", "matBadgeSize", "matBadgeHidden"] }, { kind: "component", type: i8.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "component", type: i10.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: TooltipDirective, selector: "[bizdocTooltip]", inputs: ["bizdocTooltip", "bizdocTooltipTemplate", "bizdocTooltipContext", "bizdocTooltipPosition", "bizdocTooltipDuration", "bizdocTooltipDisabled"] }, { kind: "pipe", type: TranslatePipe, name: "translate" }], animations: [
         | 
| 20218 20223 | 
             
                        panesAnimation,
         | 
| 20219 20224 | 
             
                        paneAnimation,
         | 
| 20220 20225 | 
             
                        paramAnimation,
         | 
| @@ -20232,7 +20237,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.5", ngImpor | |
| 20232 20237 | 
             
                                    queryAnimation,
         | 
| 20233 20238 | 
             
                                    tabsAnimation,
         | 
| 20234 20239 | 
             
                                    tabAnimation
         | 
| 20235 | 
            -
                                ], template: "<div #panesEl class=\"panes\"\r\n     cdkScrollable\r\n     @panes\r\n     (scroll)=\"enableNavigationArrows($event)\">\r\n  <!---->\r\n  @if (prev) {\r\n  <div class=\"scroll-arrow\" (click)=\"scrollBy(-400)\" matRipple [matRippleUnbounded]=\"true\" [matRippleCentered]=\"true\" [matRippleColor]=\"accent\">\r\n    <i class=\"material-icons mat-icon-rtl-mirror\">\r\n      arrow_back_ios\r\n    </i>\r\n  </div>\r\n  }\r\n  <!--panes-->\r\n  @for (p of panes; track p; let i = $index) {\r\n  <div (mouseenter)=\"selectedIndex !== i && !dragging && select(i)\"\r\n       (click)=\"select(i)\"\r\n       [class.active]=\"selectedIndex === i && panes.length > 1\" class=\"pane\" @pane>\r\n    <ng-container [cdkPortalOutlet]=\"p._portal\" (attached)=\"p._instance = $event.instance\"></ng-container>\r\n  </div>\r\n  @if (i < panes.length - 1) {\r\n  <div class=\"pane-separator\" (mousedown)=\"onPaneResize(p, $event)\"></div>\r\n  }\r\n  }\r\n  <!--dialog-->\r\n  @if (dialog) {\r\n  <div class=\"backdrop\" (click)=\"closeTab(0)\"></div>\r\n  }\r\n  <!--next-->\r\n  @if (next) {\r\n  <div class=\"scroll-arrow forward\">\r\n    <i class=\"material-icons mat-icon-rtl-mirror\" matRipple [matRippleUnbounded]=\"true\" [matRippleCentered]=\"true\" [matRippleRadius]=\"30\" [matRippleColor]=\"accent\"\r\n       (click)=\"scrollBy(400)\">\r\n      arrow_forward_ios\r\n    </i>\r\n  </div>\r\n  }\r\n</div>\r\n<!--tabs-->\r\n@if (tabs.length) {\r\n<div class=\"tabs-separator\" (mousedown)=\"onTabResize($event)\"></div>\r\n<div class=\"tabs mat-elevation-z18\" #tabsEl [@tabs]=\"tabsAnimation\" (@tabs.done)=\"done()\">\r\n  <!--title-->\r\n  <div class=\"row tabs-title\">\r\n    @if (swapTab) {\r\n    <button mat-icon-button (click)=\"tabBack()\" [bizdocTooltip]=\"prevGroup || ('Back'|translate)\"><mat-icon class=\"mat-icon-rtl-mirror\">arrow_back</mat-icon></button>\r\n    }\r\n    <h2>{{group}}</h2>\r\n    @if | 
| 20240 | 
            +
                                ], template: "<div #panesEl class=\"panes\"\r\n     cdkScrollable\r\n     @panes\r\n     (scroll)=\"enableNavigationArrows($event)\">\r\n  <!---->\r\n  @if (prev) {\r\n  <div class=\"scroll-arrow\" (click)=\"scrollBy(-400)\" matRipple [matRippleUnbounded]=\"true\" [matRippleCentered]=\"true\" [matRippleColor]=\"accent\">\r\n    <i class=\"material-icons mat-icon-rtl-mirror\">\r\n      arrow_back_ios\r\n    </i>\r\n  </div>\r\n  }\r\n  <!--panes-->\r\n  @for (p of panes; track p; let i = $index) {\r\n  <div (mouseenter)=\"selectedIndex !== i && !dragging && select(i)\"\r\n       (click)=\"select(i)\"\r\n       [class.active]=\"selectedIndex === i && panes.length > 1\" class=\"pane\" @pane>\r\n    <ng-container [cdkPortalOutlet]=\"p._portal\" (attached)=\"p._instance = $event.instance\"></ng-container>\r\n  </div>\r\n  @if (i < panes.length - 1) {\r\n  <div class=\"pane-separator\" (mousedown)=\"onPaneResize(p, $event)\"></div>\r\n  }\r\n  }\r\n  <!--dialog-->\r\n  @if (dialog) {\r\n  <div class=\"backdrop\" (click)=\"closeTab(0)\"></div>\r\n  }\r\n  <!--next-->\r\n  @if (next) {\r\n  <div class=\"scroll-arrow forward\">\r\n    <i class=\"material-icons mat-icon-rtl-mirror\" matRipple [matRippleUnbounded]=\"true\" [matRippleCentered]=\"true\" [matRippleRadius]=\"30\" [matRippleColor]=\"accent\"\r\n       (click)=\"scrollBy(400)\">\r\n      arrow_forward_ios\r\n    </i>\r\n  </div>\r\n  }\r\n</div>\r\n<!--tabs-->\r\n@if (tabs.length) {\r\n<div class=\"tabs-separator\" (mousedown)=\"onTabResize($event)\"></div>\r\n<div class=\"tabs mat-elevation-z18\" #tabsEl [@tabs]=\"tabsAnimation\" (@tabs.done)=\"done()\">\r\n  <!--title-->\r\n  <div class=\"row tabs-title\">\r\n    @if (swapTab) {\r\n    <button mat-icon-button (click)=\"tabBack()\" [bizdocTooltip]=\"prevGroup || ('Back'|translate)\"><mat-icon class=\"mat-icon-rtl-mirror\">arrow_back</mat-icon></button>\r\n    }\r\n    <h2>{{group}}</h2>\r\n    @if(selectedTab?.expandable) {\r\n    <button mat-icon-button (click)=\"expandTab()\" [bizdocTooltip]=\"'Expand'| translate\"><mat-icon class=\"mat-icon-rtl-mirror\" style=\"font-size: 22px\">open_in_full</mat-icon></button>\r\n    }\r\n    @if(selectedTab?.dismissable) {\r\n    <span class=\"divider\"></span>\r\n    <button mat-icon-button (click)=\"collapse()\" bizdocTooltip=\"Esc\"><mat-icon>close</mat-icon></button>\r\n    }\r\n  </div>\r\n  <nav mat-tab-nav-bar color=\"accent\" [disablePagination]=\"true\" [tabPanel]=\"tabPanel\">\r\n    @for (t of tabs; track t; let i = $index) {\r\n    <a mat-tab-link class=\"mat-tab-link\"\r\n       (click)=\"selectedTabIndex = i\"\r\n       [active]=\"selectedTabIndex === i\">\r\n      <mat-icon [matBadge]=\"t.badge\" [matBadgeHidden]=\"!t.badge\" matBadgeSize=\"small\" matBadgeColor=\"accent\" aria-hidden=\"false\">{{t.icon}}</mat-icon> \r\n      {{t.title}}\r\n      <!--@if (t.dismissable) {\r\n      <mat-icon (click)=\"closeTab(i)\" class=\"tool\">close</mat-icon>\r\n      }-->\r\n      <!--inline=\"true\"-->\r\n    </a>\r\n    }\r\n  </nav>\r\n  <mat-tab-nav-panel #tabPanel class=\"flex\">\r\n    @for (t of tabs; track t; let i = $index) {\r\n    <div [style.display]=\"selectedTabIndex === i ? '': 'none'\" class=\"tab\" [@tab]=\"selectedTabIndex\">\r\n      <ng-container [cdkPortalOutlet]=\"t._portal\" (attached)=\"t._instance = $event.instance\"></ng-container>\r\n    </div>\r\n    }\r\n  </mat-tab-nav-panel>\r\n</div>\r\n}\r\n", styles: [":host{flex:1;overflow:hidden;display:flex}.scroll-arrow{cursor:pointer;align-self:center;position:sticky;top:50%;z-index:200}.scroll-arrow i{font-size:50px;opacity:.2}.scroll-arrow i:hover{opacity:.9}.scroll-arrow:first-child{margin-inline-start:-50px;left:15px}.scroll-arrow:last-child{margin-inline-end:-50px;right:0}.panes{overflow-x:auto;position:relative;flex:1;height:100%;display:flex;-ms-flex-direction:row;-webkit-flex-direction:row;flex-direction:row}.panes .pane{-webkit-flex-grow:1;flex-grow:1;min-width:420px;overflow-y:auto;overflow-x:clip}.panes .pane>*{display:flex;-ms-flex-direction:column;-webkit-flex-direction:column;flex-direction:column;overflow-x:hidden;flex-grow:1}.pane-separator,.tabs-separator{cursor:ew-resize;background-repeat:no-repeat;background-position:center;display:table;height:100%;-moz-user-select:none;-ms-user-select:none;-webkit-user-select:none;user-select:none}.pane-separator{width:8px}.tabs-separator{width:12px}::ng-deep .mat-mdc-tab-link-container{overflow-x:auto;border-bottom:1px solid lightgray;-ms-overflow-style:none;scrollbar-width:none}::ng-deep .mat-mdc-tab-link-container::-webkit-scrollbar{display:none}::ng-deep .mat-mdc-tab-nav-panel{overflow-y:auto}.tabs{display:flex;-ms-flex-direction:column;-webkit-flex-direction:column;flex-direction:column;z-index:300;-webkit-flex-grow:0;flex-shrink:1;flex-basis:0;max-width:80vw}.tabs .tabs-title{align-items:center}.tabs .tabs-title h2{font-size:x-large;margin:9px;font-weight:100}.tabs .tabs-title:hover{opacity:1}.tabs .mat-mdc-tab-link .tool{opacity:0}.tabs .mat-mdc-tab-link:hover .tool{opacity:1}.tabs .tab{overflow-y:auto;overflow-x:hidden;display:flex;height:100%}\n"] }]
         | 
| 20236 20241 | 
             
                    }], ctorParameters: () => [{ type: undefined, decorators: [{
         | 
| 20237 20242 | 
             
                                type: Inject,
         | 
| 20238 20243 | 
             
                                args: [PANES_DATA]
         | 
| @@ -20626,11 +20631,11 @@ class AdminMenuComponent { | |
| 20626 20631 | 
             
                ngOnInit() {
         | 
| 20627 20632 | 
             
                }
         | 
| 20628 20633 | 
             
                static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.5", ngImport: i0, type: AdminMenuComponent, deps: [{ token: SessionService }], target: i0.ɵɵFactoryTarget.Component }); }
         | 
| 20629 | 
            -
                static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.5", type: AdminMenuComponent, selector: "bizdoc-admin-menu", inputs: { collapsed: "collapsed" }, ngImport: i0, template: "<!--<span class=\"mat-subheader\">BizDoc</span>\r\n<h1 class=\"mat-headline-5\">{{'System'|translate}}</h1>-->\r\n\r\n<mat-nav-list>\r\n   | 
| 20634 | 
            +
                static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.5", type: AdminMenuComponent, selector: "bizdoc-admin-menu", inputs: { collapsed: "collapsed" }, ngImport: i0, template: "<!--<span class=\"mat-subheader\">BizDoc</span>\r\n<h1 class=\"mat-headline-5\">{{'System'|translate}}</h1>-->\r\n\r\n<mat-nav-list>\r\n  <!--@if (!collapsed) {\r\n  <h3 mat-subheader>{{'Workflow'|translate}}</h3>\r\n  }\r\n  @for (f of profile.forms; track f) {\r\n  <mat-list-item [slotRouterLink]='[\"admin/forms\", f.name]' slotRouterLinkActive=\"active\">\r\n    <mat-icon matListItemIcon [bizdocTooltip]=\"f.title\" bizdocTooltipPosition=\"end\" [bizdocTooltipDisabled]=\"!collapsed\">{{f.icon|| 'description'}}</mat-icon>\r\n    <span matListItemTitle>{{f.title}}</span>\r\n  </mat-list-item>\r\n  }\r\n  <mat-divider></mat-divider>-->\r\n\r\n  @if (!collapsed) {\r\n  <h3 mat-subheader>{{'Tools'|translate}}</h3>\r\n  }\r\n\r\n  @for (u of profile.utilities; track u) {\r\n  <mat-list-item [slotRouterLink]='[\"admin/tools\", u.name]' slotRouterLinkActive=\"active\">\r\n    <mat-icon matListItemIcon [bizdocTooltip]=\"u.title\" bizdocTooltipPosition=\"end\" [bizdocTooltipDisabled]=\"!collapsed\">{{u.icon || 'build'}}</mat-icon>\r\n    <span matListItemTitle>{{u.title}}</span>\r\n  </mat-list-item>\r\n  }\r\n</mat-nav-list>\r\n", dependencies: [{ kind: "component", type: i2$4.MatNavList, selector: "mat-nav-list", exportAs: ["matNavList"] }, { kind: "component", type: i2$4.MatListItem, selector: "mat-list-item, a[mat-list-item], button[mat-list-item]", inputs: ["activated"], exportAs: ["matListItem"] }, { kind: "directive", type: i2$4.MatListItemIcon, selector: "[matListItemIcon]" }, { kind: "directive", type: i2$4.MatListSubheaderCssMatStyler, selector: "[mat-subheader], [matSubheader]" }, { kind: "directive", type: i2$4.MatListItemTitle, selector: "[matListItemTitle]" }, { kind: "component", type: i10.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: TooltipDirective, selector: "[bizdocTooltip]", inputs: ["bizdocTooltip", "bizdocTooltipTemplate", "bizdocTooltipContext", "bizdocTooltipPosition", "bizdocTooltipDuration", "bizdocTooltipDisabled"] }, { kind: "directive", type: SlotRouterDirective, selector: "[slotRouterLink]", inputs: ["slotRouterLink", "slotRouterLinkActive", "slotRouterLinkDisabled", "slotRouterLinkPolicy", "slotRouterLinkOptions"] }, { kind: "pipe", type: TranslatePipe, name: "translate" }] }); }
         | 
| 20630 20635 | 
             
            }
         | 
| 20631 20636 | 
             
            i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.5", ngImport: i0, type: AdminMenuComponent, decorators: [{
         | 
| 20632 20637 | 
             
                        type: Component,
         | 
| 20633 | 
            -
                        args: [{ selector: 'bizdoc-admin-menu', template: "<!--<span class=\"mat-subheader\">BizDoc</span>\r\n<h1 class=\"mat-headline-5\">{{'System'|translate}}</h1>-->\r\n\r\n<mat-nav-list>\r\n   | 
| 20638 | 
            +
                        args: [{ selector: 'bizdoc-admin-menu', template: "<!--<span class=\"mat-subheader\">BizDoc</span>\r\n<h1 class=\"mat-headline-5\">{{'System'|translate}}</h1>-->\r\n\r\n<mat-nav-list>\r\n  <!--@if (!collapsed) {\r\n  <h3 mat-subheader>{{'Workflow'|translate}}</h3>\r\n  }\r\n  @for (f of profile.forms; track f) {\r\n  <mat-list-item [slotRouterLink]='[\"admin/forms\", f.name]' slotRouterLinkActive=\"active\">\r\n    <mat-icon matListItemIcon [bizdocTooltip]=\"f.title\" bizdocTooltipPosition=\"end\" [bizdocTooltipDisabled]=\"!collapsed\">{{f.icon|| 'description'}}</mat-icon>\r\n    <span matListItemTitle>{{f.title}}</span>\r\n  </mat-list-item>\r\n  }\r\n  <mat-divider></mat-divider>-->\r\n\r\n  @if (!collapsed) {\r\n  <h3 mat-subheader>{{'Tools'|translate}}</h3>\r\n  }\r\n\r\n  @for (u of profile.utilities; track u) {\r\n  <mat-list-item [slotRouterLink]='[\"admin/tools\", u.name]' slotRouterLinkActive=\"active\">\r\n    <mat-icon matListItemIcon [bizdocTooltip]=\"u.title\" bizdocTooltipPosition=\"end\" [bizdocTooltipDisabled]=\"!collapsed\">{{u.icon || 'build'}}</mat-icon>\r\n    <span matListItemTitle>{{u.title}}</span>\r\n  </mat-list-item>\r\n  }\r\n</mat-nav-list>\r\n" }]
         | 
| 20634 20639 | 
             
                    }], ctorParameters: () => [{ type: SessionService }], propDecorators: { collapsed: [{
         | 
| 20635 20640 | 
             
                            type: Input
         | 
| 20636 20641 | 
             
                        }] } });
         | 
| @@ -21466,7 +21471,7 @@ const PANES_CONFIG = [ | |
| 21466 21471 | 
             
                                    ]
         | 
| 21467 21472 | 
             
                                }, {
         | 
| 21468 21473 | 
             
                                    path: 'trace',
         | 
| 21469 | 
            -
                                    icon: ' | 
| 21474 | 
            +
                                    icon: 'timeline',
         | 
| 21470 21475 | 
             
                                    component: TracePaneComponent,
         | 
| 21471 21476 | 
             
                                    policy: OpenPolicy.Tab | OpenPolicy.Expandable
         | 
| 21472 21477 | 
             
                                }, {
         | 
| @@ -22328,7 +22333,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.5", ngImpor | |
| 22328 22333 |  | 
| 22329 22334 | 
             
            class SyncfusionDiagramModule {
         | 
| 22330 22335 | 
             
                constructor() {
         | 
| 22331 | 
            -
                    Diagram$1.Inject(ComplexHierarchicalTree, BpmnDiagrams$1, DataBinding, LineDistribution, LineRouting, ConnectorBridging$1 /*, LayoutAnimation*/);
         | 
| 22332 22336 | 
             
                }
         | 
| 22333 22337 | 
             
                static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.5", ngImport: i0, type: SyncfusionDiagramModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
         | 
| 22334 22338 | 
             
                static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.5", ngImport: i0, type: SyncfusionDiagramModule, imports: [CommonModule,
         | 
| @@ -22356,6 +22360,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.5", ngImpor | |
| 22356 22360 | 
             
                                providers: [ConnectorBridgingService, LineRoutingService, ComplexHierarchicalTreeService, BpmnDiagramsService, LayoutAnimationService, UndoRedoService, SnappingService, ConnectorEditingService, LineDistributionService]
         | 
| 22357 22361 | 
             
                            }]
         | 
| 22358 22362 | 
             
                    }], ctorParameters: () => [] });
         | 
| 22363 | 
            +
            Diagram$1.Inject(ComplexHierarchicalTree, BpmnDiagrams$1, DataBinding, LineDistribution, LineRouting, ConnectorBridging$1, LayoutAnimation);
         | 
| 22359 22364 |  | 
| 22360 22365 | 
             
            class SyncfusionGridModule {
         | 
| 22361 22366 | 
             
                constructor() {
         | 
| @@ -34115,11 +34120,11 @@ class DesignerItemComponent { | |
| 34115 34120 | 
             
                    this._destroy?.complete();
         | 
| 34116 34121 | 
             
                }
         | 
| 34117 34122 | 
             
                static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.5", ngImport: i0, type: DesignerItemComponent, deps: [{ token: i0.ElementRef }, { token: i1$3.FormBuilder }, { token: i2$1.DomSanitizer }, { token: DesignerRef }, { token: BizDocComponentFactoryResolver }], target: i0.ɵɵFactoryTarget.Component }); }
         | 
| 34118 | 
            -
                static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.5", type: DesignerItemComponent, selector: "bizdoc-designer-element", inputs: { privileges: "privileges", icon: "icon", form: "form", context: "context" }, outputs: { onSave: "save", onContinue: "continue" }, queries: [{ propertyName: "editContent", first: true, predicate: EditContentDirective, descendants: true }, { propertyName: "addContent", first: true, predicate: AddContentDirective, descendants: true }, { propertyName: "widgetContent", first: true, predicate: WidgetContentDirective, descendants: true }, { propertyName: "customContents", predicate: CustomContentDirective }], usesOnChanges: true, ngImport: i0, template: "@switch (mode) {\r\n<!--widget mode -->\r\n@case ('widget') {\r\n<!--icon -->\r\n  @if (model.familyKey) {\r\n    @if (SVG[model.familyKey]) {\r\n<img class=\"logo\" [src]=\"resource(SVG[model.familyKey])\" [bizdocTooltip]=\"model.family\" />\r\n    }\r\n    @else {\r\n<div>{{model.family}}</div>\r\n    }\r\n  }\r\n<!--options-->\r\n<ng-container (attached)=\"optionsAttached($event)\" [cdkPortalOutlet]=\"options\"></ng-container>\r\n<!--designer widget-->\r\n<ng-container [ngTemplateOutlet]=\"widgetContent?.templateRef\"></ng-container>\r\n}\r\n@case ('edit') {\r\n<!--edit / custom mode -->\r\n@if (context?.active) {\r\n<mat-toolbar class=\"row\">\r\n  @if(context.mode === 'add') {\r\n  <button mat-icon-button (click)=\"closeView(true)\" [disabled]=\"context.form.invalid\"><mat-icon>save</mat-icon></button>\r\n  <span class=\"divider\"></span>\r\n  <button mat-icon-button (click)=\"closeView()\" [bizdocTooltip]=\"'Close'|translate\"><mat-icon>close</mat-icon></button>\r\n  }\r\n  @else {\r\n  <button mat-icon-button (click)=\"closeView(true)\" [bizdocTooltip]=\"'Back'|translate\"><mat-icon>keyboard_backspace</mat-icon></button>\r\n  }\r\n</mat-toolbar>\r\n<form autocomplete=\"off\" class=\"column\" (keydown)=\"handleKeyboardEvent($event)\">\r\n  <h2 class=\"mat-h2\">{{context.title|translate}}</h2>\r\n  <ng-container *ngTemplateOutlet=\"customView; context: context\"></ng-container>\r\n</form>\r\n}\r\n@else {\r\n<!--edit mode -->\r\n<mat-toolbar bizdoc-sticky>\r\n  <button mat-icon-button (click)=\"save()\" [disabled]=\"form.invalid || !form.dirty\"><mat-icon>save</mat-icon></button>\r\n  <span class=\"divider\"></span>\r\n  <button mat-icon-button (click)=\"close()\"  [bizdocTooltip]=\"'Close'|translate\"><mat-icon>close</mat-icon></button>\r\n</mat-toolbar>\r\n<form autocomplete=\"off\" class=\"column\" (keydown)=\"handleKeyboardEvent($event)\">\r\n  @if (model.resourceType) {\r\n  <p class=\"message\" (click)=\"unlock($event)\" [innerHTML]=\"'UnlockMultilang'|translate\"></p>\r\n  <br />\r\n  }\r\n  <ng-container [formGroup]=\"form\">\r\n    <div class=\"row gap\">\r\n      <bizdoc-localized-string #title formControlName=\"title\" [placeholder]=\"'Title'|translate\" required class=\"flex column\"></bizdoc-localized-string>\r\n      <mat-form-field class=\"flex\">\r\n        <mat-label>{{'Name'|translate}}</mat-label>\r\n        <input matInput formControlName=\"name\" required />\r\n        @if (form.controls.name.hasError('required')) {\r\n        <mat-error [innerHTML]=\"'RequiredErr'|translate:('Name'|translate)\"></mat-error>\r\n        }\r\n        @if (form.controls.name.hasError('duplicate')) {\r\n        <mat-error [innerHTML]=\"'DuplicateErr'|translate:('Name'|translate)\"></mat-error>\r\n        }\r\n      </mat-form-field>\r\n    </div>\r\n    @if (icon) {\r\n    <bizdoc-icon-picker formControlName=\"icon\" required></bizdoc-icon-picker>\r\n    }\r\n  </ng-container>\r\n  <!--arguments-->\r\n  @if (arguments) {\r\n  <ng-container (attached)=\"argumentsAttached($event)\" [cdkPortalOutlet]=\"arguments\"></ng-container>\r\n  }\r\n  <!--edit template-->\r\n  <ng-container [ngTemplateOutlet]=\"editContent?.templateRef\"></ng-container>\r\n  <!--options-->\r\n  @if (options) {\r\n  <ng-container (attached)=\"optionsAttached($event)\" [cdkPortalOutlet]=\"options\"></ng-container>\r\n  }\r\n  <!--privileges-->\r\n  @if (form.controls.privileges) {\r\n  <bizdoc-designer-privileges [form]=\"form.controls.privileges\"></bizdoc-designer-privileges>\r\n  }\r\n</form>\r\n}\r\n}\r\n<!--add-->\r\n@case ('add') {\r\n<form autocomplete=\"off\" class=\"column\" (keydown)=\"handleKeyboardEvent($event)\">\r\n  <!--arguments-->\r\n  @if (arguments) {\r\n  <ng-container (attached)=\"argumentsAttached($event)\" [cdkPortalOutlet]=\"arguments\"></ng-container>\r\n  }\r\n  <!--add template-->\r\n  <ng-container [ngTemplateOutlet]=\"addContent?.templateRef\"></ng-container>\r\n  @if (options) {\r\n  <!--options-->\r\n  <ng-container (attached)=\"optionsAttached($event)\" [cdkPortalOutlet]=\"options\"></ng-container>\r\n  }\r\n  <!-- continue-->\r\n  <div class=\"row actions\">\r\n    <span class=\"divider\"></span>\r\n    <button mat-stroked-button [disabled]=\"form.invalid\" (click)=\"continue()\" type=\"button\">{{'Continue'|translate}} <mat-icon class=\"mat-icon-rtl-mirror\">double_arrow</mat-icon></button>\r\n  </div>\r\n</form>\r\n  }\r\n}\r\n", styles: ["img.logo{display:block;height:26px}:host{flex:1}form{min-width:280px;padding:8px}p.message{margin:5px}:host ::ng-deep .cdk-drag-handle{cursor:move}\n"], dependencies: [{ kind: "directive", type: i5.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1$3.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1$3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1$3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1$3.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1$3.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i1$3.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1$3.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: i5$1.CdkPortalOutlet, selector: "[cdkPortalOutlet]", inputs: ["cdkPortalOutlet"], outputs: ["attached"], exportAs: ["cdkPortalOutlet"] }, { kind: "component", type: i8$1.MatToolbar, selector: "mat-toolbar", inputs: ["color"], exportAs: ["matToolbar"] }, { kind: "component", type: i3$1.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i3$1.MatLabel, selector: "mat-label" }, { kind: "directive", type: i3$1.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "component", type: i8.MatButton, selector: "    button[mat-button], button[mat-raised-button], button[mat-flat-button],    button[mat-stroked-button]  ", exportAs: ["matButton"] }, { kind: "component", type: i8.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "directive", type: i3$3.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl],      input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i10.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: TooltipDirective, selector: "[bizdocTooltip]", inputs: ["bizdocTooltip", "bizdocTooltipTemplate", "bizdocTooltipContext", "bizdocTooltipPosition", "bizdocTooltipDuration", "bizdocTooltipDisabled"] }, { kind: "component", type: LocalizedStringComponent, selector: "bizdoc-localized-string", inputs: ["class", "floatLabel", "value", "placeholder", "required", "disabled", "maxlength"] }, { kind: "component", type: DesignerPrivilegesComponent, selector: "bizdoc-designer-privileges", inputs: ["form"] }, { kind: "component", type: IconPickerComponent, selector: "bizdoc-icon-picker", inputs: ["value", "required", "disabled"], outputs: ["valueChanges"] }, { kind: "pipe", type: TranslatePipe, name: "translate" }] }); }
         | 
| 34123 | 
            +
                static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.5", type: DesignerItemComponent, selector: "bizdoc-designer-element", inputs: { privileges: "privileges", icon: "icon", form: "form", context: "context" }, outputs: { onSave: "save", onContinue: "continue" }, queries: [{ propertyName: "editContent", first: true, predicate: EditContentDirective, descendants: true }, { propertyName: "addContent", first: true, predicate: AddContentDirective, descendants: true }, { propertyName: "widgetContent", first: true, predicate: WidgetContentDirective, descendants: true }, { propertyName: "customContents", predicate: CustomContentDirective }], usesOnChanges: true, ngImport: i0, template: "@switch (mode) {\r\n<!--widget mode -->\r\n@case ('widget') {\r\n<!--icon -->\r\n  @if (model.familyKey) {\r\n    @if (SVG[model.familyKey]) {\r\n<img class=\"logo\" [src]=\"resource(SVG[model.familyKey])\" [bizdocTooltip]=\"model.family\" />\r\n    }\r\n    @else {\r\n<div>{{model.family}}</div>\r\n    }\r\n  }\r\n<!--options-->\r\n<ng-container (attached)=\"optionsAttached($event)\" [cdkPortalOutlet]=\"options\"></ng-container>\r\n<!--designer widget-->\r\n<ng-container [ngTemplateOutlet]=\"widgetContent?.templateRef\"></ng-container>\r\n}\r\n@case ('edit') {\r\n<!--edit / custom mode -->\r\n@if (context?.active) {\r\n<mat-toolbar class=\"row\">\r\n  @if(context.mode === 'add') {\r\n  <button mat-icon-button (click)=\"closeView(true)\" [disabled]=\"context.form.invalid\"><mat-icon>save</mat-icon></button>\r\n  <span class=\"divider\"></span>\r\n  <button mat-icon-button (click)=\"closeView()\" [bizdocTooltip]=\"'Close'|translate\"><mat-icon>close</mat-icon></button>\r\n  }\r\n  @else {\r\n  <button mat-icon-button (click)=\"closeView(true)\" [bizdocTooltip]=\"'Back'|translate\"><mat-icon>keyboard_backspace</mat-icon></button>\r\n  }\r\n</mat-toolbar>\r\n<form autocomplete=\"off\" class=\"column\" (keydown)=\"handleKeyboardEvent($event)\">\r\n  <h2 class=\"mat-h2\">{{context.title|translate}}</h2>\r\n  <ng-container *ngTemplateOutlet=\"customView; context: context\"></ng-container>\r\n</form>\r\n}\r\n@else {\r\n<!--edit mode -->\r\n<mat-toolbar bizdoc-sticky>\r\n  <button mat-icon-button (click)=\"save()\" [disabled]=\"form.invalid || !form.dirty\"><mat-icon>save</mat-icon></button>\r\n  <span class=\"divider\"></span>\r\n  <button mat-icon-button (click)=\"close()\"  [bizdocTooltip]=\"'Close'|translate\"><mat-icon>close</mat-icon></button>\r\n</mat-toolbar>\r\n<form autocomplete=\"off\" class=\"column\" (keydown)=\"handleKeyboardEvent($event)\">\r\n  @if (model.resourceType) {\r\n  <p class=\"message\" (click)=\"unlock($event)\" [innerHTML]=\"'UnlockMultilang'|translate\"></p>\r\n  <br />\r\n  }\r\n  <ng-container [formGroup]=\"form\">\r\n    <div class=\"row gap\">\r\n      <bizdoc-localized-string #title formControlName=\"title\" [placeholder]=\"'Title'|translate\" required class=\"flex column\"></bizdoc-localized-string>\r\n      <mat-form-field class=\"flex\">\r\n        <mat-label>{{'Name'|translate}}</mat-label>\r\n        <input matInput formControlName=\"name\" required />\r\n        @if (form.controls.name.hasError('required')) {\r\n        <mat-error [innerHTML]=\"'RequiredErr'|translate:('Name'|translate)\"></mat-error>\r\n        }\r\n        @if (form.controls.name.hasError('duplicate')) {\r\n        <mat-error [innerHTML]=\"'DuplicateErr'|translate:('Name'|translate)\"></mat-error>\r\n        }\r\n      </mat-form-field>\r\n    </div>\r\n    @if (icon) {\r\n    <bizdoc-icon-picker formControlName=\"icon\" required></bizdoc-icon-picker>\r\n    }\r\n  </ng-container>\r\n  <!--arguments-->\r\n  @if (arguments) {\r\n  <ng-container (attached)=\"argumentsAttached($event)\" [cdkPortalOutlet]=\"arguments\"></ng-container>\r\n  }\r\n  <!--edit template-->\r\n  <ng-container [ngTemplateOutlet]=\"editContent?.templateRef\"></ng-container>\r\n  <!--options-->\r\n  @if (options) {\r\n  <ng-container (attached)=\"optionsAttached($event)\" [cdkPortalOutlet]=\"options\"></ng-container>\r\n  }\r\n  <!--privileges-->\r\n  @if (form.controls.privileges) {\r\n  <bizdoc-designer-privileges [form]=\"form.controls.privileges\"></bizdoc-designer-privileges>\r\n  }\r\n</form>\r\n}\r\n}\r\n<!--add-->\r\n@case ('add') {\r\n<form autocomplete=\"off\" class=\"column\" (keydown)=\"handleKeyboardEvent($event)\">\r\n  <!--arguments-->\r\n  @if (arguments) {\r\n  <ng-container (attached)=\"argumentsAttached($event)\" [cdkPortalOutlet]=\"arguments\"></ng-container>\r\n  }\r\n  <!--add template-->\r\n  <ng-container [ngTemplateOutlet]=\"addContent?.templateRef\"></ng-container>\r\n  @if (options) {\r\n  <!--options-->\r\n  <ng-container (attached)=\"optionsAttached($event)\" [cdkPortalOutlet]=\"options\"></ng-container>\r\n  }\r\n  <!-- continue-->\r\n  <div class=\"row actions\">\r\n    <span class=\"divider\"></span>\r\n    <button mat-stroked-button [disabled]=\"form.invalid\" (click)=\"continue()\" type=\"button\">{{'Continue'|translate}} <mat-icon class=\"mat-icon-rtl-mirror\">double_arrow</mat-icon></button>\r\n  </div>\r\n</form>\r\n  }\r\n}\r\n", styles: ["img.logo{display:block;height:26px}:host{flex:1;width:100%}form{min-width:280px;padding:8px}p.message{margin:5px}:host ::ng-deep .cdk-drag-handle{cursor:move}\n"], dependencies: [{ kind: "directive", type: i5.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1$3.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1$3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1$3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1$3.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1$3.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i1$3.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1$3.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: i5$1.CdkPortalOutlet, selector: "[cdkPortalOutlet]", inputs: ["cdkPortalOutlet"], outputs: ["attached"], exportAs: ["cdkPortalOutlet"] }, { kind: "component", type: i8$1.MatToolbar, selector: "mat-toolbar", inputs: ["color"], exportAs: ["matToolbar"] }, { kind: "component", type: i3$1.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i3$1.MatLabel, selector: "mat-label" }, { kind: "directive", type: i3$1.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "component", type: i8.MatButton, selector: "    button[mat-button], button[mat-raised-button], button[mat-flat-button],    button[mat-stroked-button]  ", exportAs: ["matButton"] }, { kind: "component", type: i8.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "directive", type: i3$3.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl],      input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i10.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: TooltipDirective, selector: "[bizdocTooltip]", inputs: ["bizdocTooltip", "bizdocTooltipTemplate", "bizdocTooltipContext", "bizdocTooltipPosition", "bizdocTooltipDuration", "bizdocTooltipDisabled"] }, { kind: "component", type: LocalizedStringComponent, selector: "bizdoc-localized-string", inputs: ["class", "floatLabel", "value", "placeholder", "required", "disabled", "maxlength"] }, { kind: "component", type: DesignerPrivilegesComponent, selector: "bizdoc-designer-privileges", inputs: ["form"] }, { kind: "component", type: IconPickerComponent, selector: "bizdoc-icon-picker", inputs: ["value", "required", "disabled"], outputs: ["valueChanges"] }, { kind: "pipe", type: TranslatePipe, name: "translate" }] }); }
         | 
| 34119 34124 | 
             
            }
         | 
| 34120 34125 | 
             
            i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.5", ngImport: i0, type: DesignerItemComponent, decorators: [{
         | 
| 34121 34126 | 
             
                        type: Component,
         | 
| 34122 | 
            -
                        args: [{ selector: 'bizdoc-designer-element', template: "@switch (mode) {\r\n<!--widget mode -->\r\n@case ('widget') {\r\n<!--icon -->\r\n  @if (model.familyKey) {\r\n    @if (SVG[model.familyKey]) {\r\n<img class=\"logo\" [src]=\"resource(SVG[model.familyKey])\" [bizdocTooltip]=\"model.family\" />\r\n    }\r\n    @else {\r\n<div>{{model.family}}</div>\r\n    }\r\n  }\r\n<!--options-->\r\n<ng-container (attached)=\"optionsAttached($event)\" [cdkPortalOutlet]=\"options\"></ng-container>\r\n<!--designer widget-->\r\n<ng-container [ngTemplateOutlet]=\"widgetContent?.templateRef\"></ng-container>\r\n}\r\n@case ('edit') {\r\n<!--edit / custom mode -->\r\n@if (context?.active) {\r\n<mat-toolbar class=\"row\">\r\n  @if(context.mode === 'add') {\r\n  <button mat-icon-button (click)=\"closeView(true)\" [disabled]=\"context.form.invalid\"><mat-icon>save</mat-icon></button>\r\n  <span class=\"divider\"></span>\r\n  <button mat-icon-button (click)=\"closeView()\" [bizdocTooltip]=\"'Close'|translate\"><mat-icon>close</mat-icon></button>\r\n  }\r\n  @else {\r\n  <button mat-icon-button (click)=\"closeView(true)\" [bizdocTooltip]=\"'Back'|translate\"><mat-icon>keyboard_backspace</mat-icon></button>\r\n  }\r\n</mat-toolbar>\r\n<form autocomplete=\"off\" class=\"column\" (keydown)=\"handleKeyboardEvent($event)\">\r\n  <h2 class=\"mat-h2\">{{context.title|translate}}</h2>\r\n  <ng-container *ngTemplateOutlet=\"customView; context: context\"></ng-container>\r\n</form>\r\n}\r\n@else {\r\n<!--edit mode -->\r\n<mat-toolbar bizdoc-sticky>\r\n  <button mat-icon-button (click)=\"save()\" [disabled]=\"form.invalid || !form.dirty\"><mat-icon>save</mat-icon></button>\r\n  <span class=\"divider\"></span>\r\n  <button mat-icon-button (click)=\"close()\"  [bizdocTooltip]=\"'Close'|translate\"><mat-icon>close</mat-icon></button>\r\n</mat-toolbar>\r\n<form autocomplete=\"off\" class=\"column\" (keydown)=\"handleKeyboardEvent($event)\">\r\n  @if (model.resourceType) {\r\n  <p class=\"message\" (click)=\"unlock($event)\" [innerHTML]=\"'UnlockMultilang'|translate\"></p>\r\n  <br />\r\n  }\r\n  <ng-container [formGroup]=\"form\">\r\n    <div class=\"row gap\">\r\n      <bizdoc-localized-string #title formControlName=\"title\" [placeholder]=\"'Title'|translate\" required class=\"flex column\"></bizdoc-localized-string>\r\n      <mat-form-field class=\"flex\">\r\n        <mat-label>{{'Name'|translate}}</mat-label>\r\n        <input matInput formControlName=\"name\" required />\r\n        @if (form.controls.name.hasError('required')) {\r\n        <mat-error [innerHTML]=\"'RequiredErr'|translate:('Name'|translate)\"></mat-error>\r\n        }\r\n        @if (form.controls.name.hasError('duplicate')) {\r\n        <mat-error [innerHTML]=\"'DuplicateErr'|translate:('Name'|translate)\"></mat-error>\r\n        }\r\n      </mat-form-field>\r\n    </div>\r\n    @if (icon) {\r\n    <bizdoc-icon-picker formControlName=\"icon\" required></bizdoc-icon-picker>\r\n    }\r\n  </ng-container>\r\n  <!--arguments-->\r\n  @if (arguments) {\r\n  <ng-container (attached)=\"argumentsAttached($event)\" [cdkPortalOutlet]=\"arguments\"></ng-container>\r\n  }\r\n  <!--edit template-->\r\n  <ng-container [ngTemplateOutlet]=\"editContent?.templateRef\"></ng-container>\r\n  <!--options-->\r\n  @if (options) {\r\n  <ng-container (attached)=\"optionsAttached($event)\" [cdkPortalOutlet]=\"options\"></ng-container>\r\n  }\r\n  <!--privileges-->\r\n  @if (form.controls.privileges) {\r\n  <bizdoc-designer-privileges [form]=\"form.controls.privileges\"></bizdoc-designer-privileges>\r\n  }\r\n</form>\r\n}\r\n}\r\n<!--add-->\r\n@case ('add') {\r\n<form autocomplete=\"off\" class=\"column\" (keydown)=\"handleKeyboardEvent($event)\">\r\n  <!--arguments-->\r\n  @if (arguments) {\r\n  <ng-container (attached)=\"argumentsAttached($event)\" [cdkPortalOutlet]=\"arguments\"></ng-container>\r\n  }\r\n  <!--add template-->\r\n  <ng-container [ngTemplateOutlet]=\"addContent?.templateRef\"></ng-container>\r\n  @if (options) {\r\n  <!--options-->\r\n  <ng-container (attached)=\"optionsAttached($event)\" [cdkPortalOutlet]=\"options\"></ng-container>\r\n  }\r\n  <!-- continue-->\r\n  <div class=\"row actions\">\r\n    <span class=\"divider\"></span>\r\n    <button mat-stroked-button [disabled]=\"form.invalid\" (click)=\"continue()\" type=\"button\">{{'Continue'|translate}} <mat-icon class=\"mat-icon-rtl-mirror\">double_arrow</mat-icon></button>\r\n  </div>\r\n</form>\r\n  }\r\n}\r\n", styles: ["img.logo{display:block;height:26px}:host{flex:1}form{min-width:280px;padding:8px}p.message{margin:5px}:host ::ng-deep .cdk-drag-handle{cursor:move}\n"] }]
         | 
| 34127 | 
            +
                        args: [{ selector: 'bizdoc-designer-element', template: "@switch (mode) {\r\n<!--widget mode -->\r\n@case ('widget') {\r\n<!--icon -->\r\n  @if (model.familyKey) {\r\n    @if (SVG[model.familyKey]) {\r\n<img class=\"logo\" [src]=\"resource(SVG[model.familyKey])\" [bizdocTooltip]=\"model.family\" />\r\n    }\r\n    @else {\r\n<div>{{model.family}}</div>\r\n    }\r\n  }\r\n<!--options-->\r\n<ng-container (attached)=\"optionsAttached($event)\" [cdkPortalOutlet]=\"options\"></ng-container>\r\n<!--designer widget-->\r\n<ng-container [ngTemplateOutlet]=\"widgetContent?.templateRef\"></ng-container>\r\n}\r\n@case ('edit') {\r\n<!--edit / custom mode -->\r\n@if (context?.active) {\r\n<mat-toolbar class=\"row\">\r\n  @if(context.mode === 'add') {\r\n  <button mat-icon-button (click)=\"closeView(true)\" [disabled]=\"context.form.invalid\"><mat-icon>save</mat-icon></button>\r\n  <span class=\"divider\"></span>\r\n  <button mat-icon-button (click)=\"closeView()\" [bizdocTooltip]=\"'Close'|translate\"><mat-icon>close</mat-icon></button>\r\n  }\r\n  @else {\r\n  <button mat-icon-button (click)=\"closeView(true)\" [bizdocTooltip]=\"'Back'|translate\"><mat-icon>keyboard_backspace</mat-icon></button>\r\n  }\r\n</mat-toolbar>\r\n<form autocomplete=\"off\" class=\"column\" (keydown)=\"handleKeyboardEvent($event)\">\r\n  <h2 class=\"mat-h2\">{{context.title|translate}}</h2>\r\n  <ng-container *ngTemplateOutlet=\"customView; context: context\"></ng-container>\r\n</form>\r\n}\r\n@else {\r\n<!--edit mode -->\r\n<mat-toolbar bizdoc-sticky>\r\n  <button mat-icon-button (click)=\"save()\" [disabled]=\"form.invalid || !form.dirty\"><mat-icon>save</mat-icon></button>\r\n  <span class=\"divider\"></span>\r\n  <button mat-icon-button (click)=\"close()\"  [bizdocTooltip]=\"'Close'|translate\"><mat-icon>close</mat-icon></button>\r\n</mat-toolbar>\r\n<form autocomplete=\"off\" class=\"column\" (keydown)=\"handleKeyboardEvent($event)\">\r\n  @if (model.resourceType) {\r\n  <p class=\"message\" (click)=\"unlock($event)\" [innerHTML]=\"'UnlockMultilang'|translate\"></p>\r\n  <br />\r\n  }\r\n  <ng-container [formGroup]=\"form\">\r\n    <div class=\"row gap\">\r\n      <bizdoc-localized-string #title formControlName=\"title\" [placeholder]=\"'Title'|translate\" required class=\"flex column\"></bizdoc-localized-string>\r\n      <mat-form-field class=\"flex\">\r\n        <mat-label>{{'Name'|translate}}</mat-label>\r\n        <input matInput formControlName=\"name\" required />\r\n        @if (form.controls.name.hasError('required')) {\r\n        <mat-error [innerHTML]=\"'RequiredErr'|translate:('Name'|translate)\"></mat-error>\r\n        }\r\n        @if (form.controls.name.hasError('duplicate')) {\r\n        <mat-error [innerHTML]=\"'DuplicateErr'|translate:('Name'|translate)\"></mat-error>\r\n        }\r\n      </mat-form-field>\r\n    </div>\r\n    @if (icon) {\r\n    <bizdoc-icon-picker formControlName=\"icon\" required></bizdoc-icon-picker>\r\n    }\r\n  </ng-container>\r\n  <!--arguments-->\r\n  @if (arguments) {\r\n  <ng-container (attached)=\"argumentsAttached($event)\" [cdkPortalOutlet]=\"arguments\"></ng-container>\r\n  }\r\n  <!--edit template-->\r\n  <ng-container [ngTemplateOutlet]=\"editContent?.templateRef\"></ng-container>\r\n  <!--options-->\r\n  @if (options) {\r\n  <ng-container (attached)=\"optionsAttached($event)\" [cdkPortalOutlet]=\"options\"></ng-container>\r\n  }\r\n  <!--privileges-->\r\n  @if (form.controls.privileges) {\r\n  <bizdoc-designer-privileges [form]=\"form.controls.privileges\"></bizdoc-designer-privileges>\r\n  }\r\n</form>\r\n}\r\n}\r\n<!--add-->\r\n@case ('add') {\r\n<form autocomplete=\"off\" class=\"column\" (keydown)=\"handleKeyboardEvent($event)\">\r\n  <!--arguments-->\r\n  @if (arguments) {\r\n  <ng-container (attached)=\"argumentsAttached($event)\" [cdkPortalOutlet]=\"arguments\"></ng-container>\r\n  }\r\n  <!--add template-->\r\n  <ng-container [ngTemplateOutlet]=\"addContent?.templateRef\"></ng-container>\r\n  @if (options) {\r\n  <!--options-->\r\n  <ng-container (attached)=\"optionsAttached($event)\" [cdkPortalOutlet]=\"options\"></ng-container>\r\n  }\r\n  <!-- continue-->\r\n  <div class=\"row actions\">\r\n    <span class=\"divider\"></span>\r\n    <button mat-stroked-button [disabled]=\"form.invalid\" (click)=\"continue()\" type=\"button\">{{'Continue'|translate}} <mat-icon class=\"mat-icon-rtl-mirror\">double_arrow</mat-icon></button>\r\n  </div>\r\n</form>\r\n  }\r\n}\r\n", styles: ["img.logo{display:block;height:26px}:host{flex:1;width:100%}form{min-width:280px;padding:8px}p.message{margin:5px}:host ::ng-deep .cdk-drag-handle{cursor:move}\n"] }]
         | 
| 34123 34128 | 
             
                    }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i1$3.FormBuilder }, { type: i2$1.DomSanitizer }, { type: DesignerRef, decorators: [{
         | 
| 34124 34129 | 
             
                                type: Inject,
         | 
| 34125 34130 | 
             
                                args: [DesignerRef]
         | 
| @@ -35321,8 +35326,8 @@ let ConfigurationDesignerComponent = class ConfigurationDesignerComponent { | |
| 35321 35326 | 
             
                    eclone = clone(eclone); // deep
         | 
| 35322 35327 | 
             
                    const injector = this._createInjector(eclone, section.elements, mode);
         | 
| 35323 35328 | 
             
                    return new Promise((resolve, reject) => this._panes.navigate(section.comp, {
         | 
| 35324 | 
            -
                        policy: mode === 'add' ? OpenPolicy.Dialog  | 
| 35325 | 
            -
                             | 
| 35329 | 
            +
                        policy: mode === 'add' ? OpenPolicy.Dialog : OpenPolicy.Tab & ~OpenPolicy.Dismissable
         | 
| 35330 | 
            +
                            | OpenPolicy.Toggle | OpenPolicy.Defer,
         | 
| 35326 35331 | 
             
                        group: this._translate.get(section.title),
         | 
| 35327 35332 | 
             
                        //title,
         | 
| 35328 35333 | 
             
                        injector: injector
         |