barsa-sap-ui 2.0.64 → 2.0.66

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.
@@ -50,14 +50,14 @@ export class ReportNavigatorComponent extends BaseComponent {
50
50
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.5", type: ReportNavigatorComponent, selector: "bsu-report-navigator", host: { properties: { "style.min-height": "this.minheight" } }, viewQueries: [{ propertyName: "containerRef", first: true, predicate: ["containerRef"], descendants: true, read: ViewContainerRef, static: true }], usesInheritance: true, ngImport: i0, template: `<ng-container #containerRef></ng-container>
51
51
  @if ((loading$ | async) === true) {
52
52
  <bsu-mask></bsu-mask>
53
- }`, isInline: true, styles: [":host{display:block;background:var(--sapBaseColor)}\n"], dependencies: [{ kind: "component", type: i3.MaskComponent, selector: "bsu-mask", inputs: ["size", "top"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
53
+ }`, isInline: true, styles: [":host{display:block;width:100%;background:var(--sapBaseColor)}\n"], dependencies: [{ kind: "component", type: i3.MaskComponent, selector: "bsu-mask", inputs: ["size", "top"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
54
54
  }
55
55
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: ReportNavigatorComponent, decorators: [{
56
56
  type: Component,
57
57
  args: [{ selector: 'bsu-report-navigator', template: `<ng-container #containerRef></ng-container>
58
58
  @if ((loading$ | async) === true) {
59
59
  <bsu-mask></bsu-mask>
60
- }`, changeDetection: ChangeDetectionStrategy.OnPush, styles: [":host{display:block;background:var(--sapBaseColor)}\n"] }]
60
+ }`, changeDetection: ChangeDetectionStrategy.OnPush, styles: [":host{display:block;width:100%;background:var(--sapBaseColor)}\n"] }]
61
61
  }], ctorParameters: () => [{ type: i1.ActivatedRoute }, { type: i2.PortalService }, { type: i0.Injector }, { type: i0.ChangeDetectorRef }], propDecorators: { containerRef: [{
62
62
  type: ViewChild,
63
63
  args: ['containerRef', { static: true, read: ViewContainerRef }]
@@ -65,4 +65,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImpor
65
65
  type: HostBinding,
66
66
  args: ['style.min-height']
67
67
  }] } });
68
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"report-navigator.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-sap-ui/src/lib/report-navigator/report-navigator.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    HostBinding,\n    Injector,\n    OnDestroy,\n    OnInit,\n    ViewChild,\n    ViewContainerRef\n} from '@angular/core';\nimport { ActivatedRoute, Params } from '@angular/router';\nimport { BehaviorSubject, Observable } from 'rxjs';\nimport { debounceTime, map, switchMap, takeUntil, tap } from 'rxjs/operators';\n\nimport { BaseComponent, PortalService, BarsaApi } from 'barsa-novin-ray-core';\n@Component({\n    selector: 'bsu-report-navigator',\n    template: `<ng-container #containerRef></ng-container>\n        @if ((loading$ | async) === true) {\n        <bsu-mask></bsu-mask>\n        }`,\n    styles: `:host{display: block;        \n        background: var(--sapBaseColor);}`,\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class ReportNavigatorComponent extends BaseComponent implements OnInit, OnDestroy {\n    @ViewChild('containerRef', { static: true, read: ViewContainerRef }) containerRef: ViewContainerRef;\n    @HostBinding('style.min-height') minheight = '100svh';\n    // @HostBinding('class.section') sectionClass = true;\n    // @HostBinding('class.absolute-page') absolutePageClass = true;\n    loading$: Observable<boolean>;\n    private _loadingSource = new BehaviorSubject<boolean>(false);\n    constructor(\n        private _activatedRoute: ActivatedRoute,\n        private _portalService: PortalService,\n        private _injector: Injector,\n        private _cdr: ChangeDetectorRef\n    ) {\n        super();\n        this.loading$ = this._loadingSource.asObservable().pipe(takeUntil(this._onDestroy$), debounceTime(200));\n    }\n\n    ngOnInit(): void {\n        super.ngOnInit();\n\n        this._activatedRoute.params\n            .pipe(\n                takeUntil(this._onDestroy$),\n                tap(() => this._setLoading(true)),\n                map((params: Params) => ({\n                    Id: params.id.split('__')[0],\n                    ReportId: params.id.split('__').length > 2 ? params.id.split('__')[2] : '',\n                    isReportPage: params.id.split('__').length > 3 ? params.id.split('__')[3] : null\n                })),\n                tap((c) => (c.isReportPage ? (this.minheight = 'auto') : '100vh')),\n                tap((c) => this.containerRef.clear()),\n                switchMap((navItem) =>\n                    this._portalService.renderUlvMainUi(\n                        navItem,\n                        this.containerRef,\n                        this._injector,\n                        navItem.isReportPage ? false : true\n                    )\n                ),\n                tap((ulv: any) => this._setActiveReport(ulv))\n            )\n            .subscribe(() => {\n                this._setLoading(false);\n            });\n    }\n    ngOnDestroy(): void {\n        super.ngOnDestroy();\n        this._setActiveReport(null);\n    }\n    private _setLoading(val: boolean): void {\n        this._loadingSource.next(val);\n        this._cdr.detectChanges();\n    }\n    private _setActiveReport(ulv: unknown): void {\n        BarsaApi.Bw.App.GetActiveReport = () => {\n            if (ulv === null) {\n                return ulv;\n            }\n            return BarsaApi.Bw._wrap(ulv);\n        };\n    }\n}\n"]}
68
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"report-navigator.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-sap-ui/src/lib/report-navigator/report-navigator.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    HostBinding,\n    Injector,\n    OnDestroy,\n    OnInit,\n    ViewChild,\n    ViewContainerRef\n} from '@angular/core';\nimport { ActivatedRoute, Params } from '@angular/router';\nimport { BehaviorSubject, Observable } from 'rxjs';\nimport { debounceTime, map, switchMap, takeUntil, tap } from 'rxjs/operators';\n\nimport { BaseComponent, PortalService, BarsaApi } from 'barsa-novin-ray-core';\n@Component({\n    selector: 'bsu-report-navigator',\n    template: `<ng-container #containerRef></ng-container>\n        @if ((loading$ | async) === true) {\n        <bsu-mask></bsu-mask>\n        }`,\n    styles: `:host{display: block;width:100%;        \n        background: var(--sapBaseColor);}`,\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class ReportNavigatorComponent extends BaseComponent implements OnInit, OnDestroy {\n    @ViewChild('containerRef', { static: true, read: ViewContainerRef }) containerRef: ViewContainerRef;\n    @HostBinding('style.min-height') minheight = '100svh';\n    // @HostBinding('class.section') sectionClass = true;\n    // @HostBinding('class.absolute-page') absolutePageClass = true;\n    loading$: Observable<boolean>;\n    private _loadingSource = new BehaviorSubject<boolean>(false);\n    constructor(\n        private _activatedRoute: ActivatedRoute,\n        private _portalService: PortalService,\n        private _injector: Injector,\n        private _cdr: ChangeDetectorRef\n    ) {\n        super();\n        this.loading$ = this._loadingSource.asObservable().pipe(takeUntil(this._onDestroy$), debounceTime(200));\n    }\n\n    ngOnInit(): void {\n        super.ngOnInit();\n\n        this._activatedRoute.params\n            .pipe(\n                takeUntil(this._onDestroy$),\n                tap(() => this._setLoading(true)),\n                map((params: Params) => ({\n                    Id: params.id.split('__')[0],\n                    ReportId: params.id.split('__').length > 2 ? params.id.split('__')[2] : '',\n                    isReportPage: params.id.split('__').length > 3 ? params.id.split('__')[3] : null\n                })),\n                tap((c) => (c.isReportPage ? (this.minheight = 'auto') : '100vh')),\n                tap((c) => this.containerRef.clear()),\n                switchMap((navItem) =>\n                    this._portalService.renderUlvMainUi(\n                        navItem,\n                        this.containerRef,\n                        this._injector,\n                        navItem.isReportPage ? false : true\n                    )\n                ),\n                tap((ulv: any) => this._setActiveReport(ulv))\n            )\n            .subscribe(() => {\n                this._setLoading(false);\n            });\n    }\n    ngOnDestroy(): void {\n        super.ngOnDestroy();\n        this._setActiveReport(null);\n    }\n    private _setLoading(val: boolean): void {\n        this._loadingSource.next(val);\n        this._cdr.detectChanges();\n    }\n    private _setActiveReport(ulv: unknown): void {\n        BarsaApi.Bw.App.GetActiveReport = () => {\n            if (ulv === null) {\n                return ulv;\n            }\n            return BarsaApi.Bw._wrap(ulv);\n        };\n    }\n}\n"]}
@@ -92,6 +92,7 @@ export class UiTreeComponent extends ReportTreeBaseComponent {
92
92
  if (this.viewSetting?.DynamicCommandField) {
93
93
  const dyn = this._rval.transform(this.viewSetting?.DynamicCommandField, ev.node.Data, this.allColumns);
94
94
  if (dyn) {
95
+ this._selectNode(ev.node);
95
96
  ExecuteDynamicCommand(dyn, ev.node.Data);
96
97
  return;
97
98
  }
@@ -110,4 +111,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImpor
110
111
  }], propDecorators: { showOkCancelButtons: [{
111
112
  type: Input
112
113
  }] } });
113
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ui-tree.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-sap-ui/src/lib/ui-tree/ui-tree.component.ts","../../../../../projects/barsa-sap-ui/src/lib/ui-tree/ui-tree.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, inject, Input, OnInit } from '@angular/core';\n\nimport { ExecuteDynamicCommand, MoReportValuePipe, TreeNodeObj } from 'barsa-novin-ray-core';\nimport { Observable } from 'rxjs';\nimport { map } from 'rxjs/operators';\nimport { ReportTreeBaseComponent } from '../report-tree-base';\n\n@Component({\n    selector: 'bsu-ui-tree',\n    templateUrl: './ui-tree.component.html',\n    styleUrls: ['./ui-tree.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class UiTreeComponent extends ReportTreeBaseComponent implements OnInit {\n    @Input() showOkCancelButtons;\n    collapseIcon$: Observable<string>;\n    private _rval = inject(MoReportValuePipe);\n    ngOnInit(): void {\n        super.ngOnInit();\n        this.collapseIcon$ = this._portalService.rtl$.pipe(\n            // map((isRtl) => (isRtl ? 'navigation-left-arrow' : 'navigation-right-arrow'))\n            map((_) => 'add')\n        );\n    }\n    onDrop($event): void {\n        this.drop($event);\n    }\n\n    onDragMoved($event): void {\n        this.dragMoved($event);\n    }\n\n    onCollapseAll(): void {\n        this.collapseAll();\n    }\n\n    onOpenMoveToDialog(selectedNode, device, moveDialog): void {\n        this.openMoveToDialog(selectedNode, device, moveDialog);\n    }\n\n    onConfirmDialog(dialogSelectedNode): void {\n        this.confirmDialog(dialogSelectedNode);\n    }\n\n    onDismissDialog(): void {\n        this.dismissDialog();\n    }\n\n    onSelectNodeInMoveDialog($event): void {\n        this.selectNodeInMoveDialog($event);\n    }\n    onCheckChange(ev: { node: TreeNodeObj; index: number; checked: boolean }): void {\n        let selectedNode: TreeNodeObj | null = null;\n        if (ev.checked) {\n            ev.node.Data.$IsChecked = true;\n            selectedNode = ev.node;\n            this.context.selNode = selectedNode;\n            this.context.fireEvent('rowselect', this.context, ev.index, ev.node.Data);\n        } else {\n            ev.node.Data.$IsChecked = false;\n            const selected = this.moDataList.find((c) => c.$IsChecked);\n            if (selected) {\n                this.context.selNode = ev.node;\n                this._selectedNodeSource.next(ev.node);\n            } else {\n            }\n            this.context.fireEvent('rowdeselect', this.context, ev.index, ev.node.Data);\n        }\n        this._selectedNodeSource.next(selectedNode);\n        this._rebindRoot();\n    }\n    onNodeSelect(ev: { node: TreeNodeObj; index: number }): void {\n        if (this.context.selNode === ev.node) {\n            this._deselectNode();\n        } else {\n            this._selectNode(ev.node);\n            if (this.viewSetting?.OnlyExecuteLeafNode === true && !ev.node.leaf) {\n                this.loadChildren(ev.node);\n            }\n        }\n        this._rebindRoot();\n    }\n\n    onNodeUlvCommand(ev: { node: TreeNodeObj; index: number }): void {\n        this._ulvCommandClicked(ev.node.Data, ev.index);\n    }\n\n    onNodeViewClick(ev: { node: TreeNodeObj; index: number }): void {\n        if (this.viewSetting?.DisableShowFormOnDoubleClick === true) {\n            return;\n        }\n        if (this.viewSetting?.OnlyExecuteLeafNode === true && !ev.node.leaf) {\n            return;\n        }\n        if (this.viewSetting?.DynamicCommandField) {\n            const dyn = this._rval.transform(this.viewSetting?.DynamicCommandField, ev.node.Data, this.allColumns);\n            if (dyn) {\n                ExecuteDynamicCommand(dyn, ev.node.Data);\n                return;\n            }\n        }\n        this._raiseRowClick(ev.index, ev.node);\n    }\n\n    onLoadChildren(node: TreeNodeObj): void {\n        this.loadChildren(node);\n    }\n}\n","<ng-container\n    *ngTemplateOutlet=\"\n        renderTree;\n        context: {\n            $implicit: root$ | async,\n            moDataList: flatMoDataList,\n            isCheckList: context.Setting.View?.IsCheckList,\n            columns: visibleColumns$ | async,\n            groupby: groupby$ | async,\n            toolbarButtons: (toolbarButtons$ | async)!! | seperatorFix,\n            contextMenuItems: menuItems$ | async | contextMenu: context.Setting.View?.IsCheckList,\n            conditionalFormats: context.Setting.View?.ConditionalFormats,\n            deviceName: deviceName$ | async,\n            deviceSize: deviceSize$ | async,\n            access: context.Setting.Extra?.DefaultCommandsAccess,\n            title: title$ | async,\n            inlineEditMode: inlineEditMode$ | async,\n            allowInlineEdit: allowInlineEdit$ | async,\n            hideToolbar: hideToolbar$ | async,\n            gridSetting: gridSetting$ | async,\n            contentDensity: contentDensity$ | async,\n            hasSelected: hasSelected$ | async,\n            showOkCancelButtons: showOkCancelButtons,\n            hideOpenIcon: viewSetting?.HideOpenIcon,\n            openOnClick: viewSetting?.OpenOnClick,\n            onlyExecuteLeafNode: viewSetting?.OnlyExecuteLeafNode,\n            enableNodeReordering: viewSetting?.EnableNodeReordering,\n            viewSettingsContentDensity: viewSetting?.ContentDensity$Caption,\n            iconField: viewSetting?.IconField,\n            hideIcon: viewSetting?.HideIcon,\n            colorField: viewSetting?.ColorField,\n            selectedNode: selectedNode$ | async,\n            navigationArrow: navigationArrow$ | async,\n            collapseIcon: collapseIcon$ | async,\n            relationList: context.Setting.View.RelationList,\n            allColumns: allColumns,\n            rtl: rtl$ | async,\n            inDialog: inDialog$ | async,\n            isMultiSelect: isMultiSelect$ | async,\n            disableOverflowContextMenu: viewSetting?.DisableOverflowContextMenu,\n            isHetro: context.Setting.ClassNames.DataClass === 'Ul.HetroTreeUlvDataCtrlr',\n            selectedMo: selectedMo$ | async\n        }\n    \"\n></ng-container>\n\n<ng-template\n    #renderTree\n    let-root\n    let-moDataList=\"moDataList\"\n    let-deviceName=\"deviceName\"\n    let-deviceSize=\"deviceSize\"\n    let-toolbarButtons=\"toolbarButtons\"\n    let-title=\"title\"\n    let-inlineEditMode=\"inlineEditMode\"\n    let-allowInlineEdit=\"allowInlineEdit\"\n    let-hideToolbar=\"hideToolbar\"\n    let-gridSetting=\"gridSetting\"\n    let-contentDensity=\"contentDensity\"\n    let-access=\"access\"\n    let-contextMenuItems=\"contextMenuItems\"\n    let-conditionalFormats=\"conditionalFormats\"\n    let-isCheckList=\"isCheckList\"\n    let-groupby=\"groupby\"\n    let-hasSelected=\"hasSelected\"\n    let-showOkCancelButtons=\"showOkCancelButtons\"\n    let-selectedNode=\"selectedNode\"\n    let-navigationArrow=\"navigationArrow\"\n    let-collapseIcon=\"collapseIcon\"\n    let-rtl=\"rtl\"\n    let-disableOverflowContextMenu=\"disableOverflowContextMenu\"\n    let-relationList=\"relationList\"\n    let-isHetro=\"isHetro\"\n    let-inDialog=\"inDialog\"\n    let-isMultiSelect=\"isMultiSelect\"\n    let-selectedMo=\"selectedMo\"\n    let-hideOpenIcon=\"hideOpenIcon\"\n    let-openOnClick=\"openOnClick\"\n    let-enableNodeReordering=\"enableNodeReordering\"\n    let-onlyExecuteLeafNode=\"onlyExecuteLeafNode\"\n    let-iconField=\"iconField\"\n    let-colorField=\"colorField\"\n    let-allColumns=\"allColumns\"\n    let-hideIcon=\"hideIcon\"\n    let-viewSettingsContentDensity=\"viewSettingsContentDensity\"\n>\n    <bsu-ulv-toolbar\n        [hideToolbar]=\"hideToolbar\"\n        [deviceName]=\"deviceName\"\n        [deviceSize]=\"deviceSize\"\n        [toolbarButtons]=\"toolbarButtons\"\n        [gridSetting]=\"gridSetting\"\n        [title]=\"title\"\n        [hasSelected]=\"hasSelected\"\n        [inDialog]=\"inDialog\"\n        [isMultiSelect]=\"isMultiSelect\"\n        [contentDensity]=\"contentDensity\"\n        [inlineEditMode]=\"inlineEditMode\"\n        [allowInlineEdit]=\"allowInlineEdit\"\n        [moDataListCount]=\"moDataList.length\"\n        (sortClick)=\"onSortSettings(deviceName)\"\n        (groupbyClick)=\"onGroupbySettings(deviceName)\"\n        (columnClick)=\"onColumnSettings(deviceName)\"\n        (editModeClick)=\"onEditMode()\"\n    >\n        <button\n            fd-button\n            fd-toolbar-item\n            [fdType]=\"'transparent'\"\n            [glyph]=\"'collapse-all'\"\n            (click)=\"onCollapseAll()\"\n        ></button>\n        @if (!showOkCancelButtons && enableNodeReordering) {\n        <button\n            fd-button\n            fd-toolbar-item\n            [fdType]=\"'transparent'\"\n            [glyph]=\"'move'\"\n            (click)=\"onOpenMoveToDialog(selectedNode, deviceName, moveDialog)\"\n        ></button>\n        }\n    </bsu-ulv-toolbar>\n    <bsu-ui-tree-view\n        [leafCursorPointer]=\"onlyExecuteLeafNode && openOnClick\"\n        [rtl]=\"rtl\"\n        [relationList]=\"relationList\"\n        [root]=\"root\"\n        [allColumns]=\"allColumns\"\n        [hideIcon]=\"hideIcon\"\n        [selectedMo]=\"selectedMo\"\n        [hideOpenIcon]=\"hideOpenIcon\"\n        [disableOverflowContextMenu]=\"disableOverflowContextMenu\"\n        [iconField]=\"iconField\"\n        [colorField]=\"colorField\"\n        [navigationArrow]=\"navigationArrow\"\n        [collapseIcon]=\"collapseIcon\"\n        [selectedNode]=\"selectedNode\"\n        [access]=\"access\"\n        [viewSettingsContentDensity]=\"viewSettingsContentDensity\"\n        [deviceName]=\"deviceName\"\n        [deviceSize]=\"deviceSize\"\n        [enableNodeReordering]=\"enableNodeReordering\"\n        [inDialog]=\"inDialog\"\n        [isMultiSelect]=\"isMultiSelect\"\n        [openOnClick]=\"openOnClick\"\n        [contextMenuItems]=\"contextMenuItems\"\n        [moDataList]=\"moDataList\"\n        [groupby]=\"groupby\"\n        [isHetro]=\"isHetro\"\n        [isCheckList]=\"isCheckList\"\n        [conditionalFormats]=\"conditionalFormats\"\n        [showOkCancelButtons]=\"showOkCancelButtons\"\n        (checkChange)=\"onCheckChange($event)\"\n        (itemDrop)=\"onDrop($event)\"\n        (itemDragMoved)=\"onDragMoved($event)\"\n        (nodeUlvCommand)=\"onNodeUlvCommand($event)\"\n        (nodeViewClick)=\"onNodeViewClick($event)\"\n        (loadChildren)=\"onLoadChildren($event)\"\n        (nodeSelect)=\"onNodeSelect($event)\"\n        (rowCheck)=\"onRowCheck($event)\"\n        (rowClick)=\"onRowClick($event)\"\n        (allCheckbox)=\"onAllCheckbox($event)\"\n        (expandClick)=\"onExpandClick($event)\"\n        (editFormPanelCancel)=\"onEditFormPanelCancel($event)\"\n        (editFormPanelSave)=\"onEditFormPanelSave($event)\"\n        (createNew)=\"onCreateNew($event)\"\n    >\n    </bsu-ui-tree-view>\n    <ng-template let-dialog let-dialogConfig=\"dialogConfig\" #moveDialog>\n        <fd-dialog [dialogConfig]=\"dialogConfig\" [dialogRef]=\"dialog\">\n            <fd-dialog-header>\n                <h1 fd-title>{{ 'Move' | bbbTranslate }}</h1>\n                <button fd-dialog-close-button (click)=\"dialog.dismiss('Close button')\"></button>\n            </fd-dialog-header>\n\n            <fd-dialog-body>\n                <div class=\"move-to\" (keydown.enter)=\"onConfirmDialog(dialogSelectedNode)\">\n                    <bsu-ui-tree-view\n                        [rtl]=\"rtl\"\n                        [root]=\"root\"\n                        [access]=\"access\"\n                        [navigationArrow]=\"navigationArrow\"\n                        [collapseIcon]=\"collapseIcon\"\n                        [deviceName]=\"deviceName\"\n                        [deviceSize]=\"deviceSize\"\n                        [viewSettingsContentDensity]=\"viewSettingsContentDensity\"\n                        [enableNodeReordering]=\"enableNodeReordering\"\n                        [openOnClick]=\"openOnClick\"\n                        [selectedNode]=\"dialogSelectedNode\"\n                        [moDataList]=\"flatMoDataList\"\n                        [groupby]=\"groupby\"\n                        [isCheckList]=\"isCheckList\"\n                        [conditionalFormats]=\"conditionalFormats\"\n                        (loadChildren)=\"onLoadChildren($event)\"\n                        (nodeSelect)=\"onSelectNodeInMoveDialog($event)\"\n                    ></bsu-ui-tree-view>\n                </div>\n            </fd-dialog-body>\n\n            <fd-dialog-footer>\n                <ng-template fdkTemplate=\"footer\">\n                    <div fd-bar-right>\n                        <fd-button-bar\n                            fdType=\"emphasized\"\n                            [label]=\"'OK' | bbbTranslate\"\n                            (click)=\"onConfirmDialog(dialogSelectedNode)\"\n                        >\n                        </fd-button-bar>\n                        <fd-button-bar fd-initial-focus [label]=\"'Cancel' | bbbTranslate\" (click)=\"onDismissDialog()\">\n                        </fd-button-bar>\n                    </div>\n                </ng-template>\n            </fd-dialog-footer>\n        </fd-dialog>\n    </ng-template>\n</ng-template>\n"]}
114
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ui-tree.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-sap-ui/src/lib/ui-tree/ui-tree.component.ts","../../../../../projects/barsa-sap-ui/src/lib/ui-tree/ui-tree.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, inject, Input, OnInit } from '@angular/core';\n\nimport { ExecuteDynamicCommand, MoReportValuePipe, TreeNodeObj } from 'barsa-novin-ray-core';\nimport { Observable } from 'rxjs';\nimport { map } from 'rxjs/operators';\nimport { ReportTreeBaseComponent } from '../report-tree-base';\n\n@Component({\n    selector: 'bsu-ui-tree',\n    templateUrl: './ui-tree.component.html',\n    styleUrls: ['./ui-tree.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class UiTreeComponent extends ReportTreeBaseComponent implements OnInit {\n    @Input() showOkCancelButtons;\n    collapseIcon$: Observable<string>;\n    private _rval = inject(MoReportValuePipe);\n    ngOnInit(): void {\n        super.ngOnInit();\n        this.collapseIcon$ = this._portalService.rtl$.pipe(\n            // map((isRtl) => (isRtl ? 'navigation-left-arrow' : 'navigation-right-arrow'))\n            map((_) => 'add')\n        );\n    }\n    onDrop($event): void {\n        this.drop($event);\n    }\n\n    onDragMoved($event): void {\n        this.dragMoved($event);\n    }\n\n    onCollapseAll(): void {\n        this.collapseAll();\n    }\n\n    onOpenMoveToDialog(selectedNode, device, moveDialog): void {\n        this.openMoveToDialog(selectedNode, device, moveDialog);\n    }\n\n    onConfirmDialog(dialogSelectedNode): void {\n        this.confirmDialog(dialogSelectedNode);\n    }\n\n    onDismissDialog(): void {\n        this.dismissDialog();\n    }\n\n    onSelectNodeInMoveDialog($event): void {\n        this.selectNodeInMoveDialog($event);\n    }\n    onCheckChange(ev: { node: TreeNodeObj; index: number; checked: boolean }): void {\n        let selectedNode: TreeNodeObj | null = null;\n        if (ev.checked) {\n            ev.node.Data.$IsChecked = true;\n            selectedNode = ev.node;\n            this.context.selNode = selectedNode;\n            this.context.fireEvent('rowselect', this.context, ev.index, ev.node.Data);\n        } else {\n            ev.node.Data.$IsChecked = false;\n            const selected = this.moDataList.find((c) => c.$IsChecked);\n            if (selected) {\n                this.context.selNode = ev.node;\n                this._selectedNodeSource.next(ev.node);\n            } else {\n            }\n            this.context.fireEvent('rowdeselect', this.context, ev.index, ev.node.Data);\n        }\n        this._selectedNodeSource.next(selectedNode);\n        this._rebindRoot();\n    }\n    onNodeSelect(ev: { node: TreeNodeObj; index: number }): void {\n        if (this.context.selNode === ev.node) {\n            this._deselectNode();\n        } else {\n            this._selectNode(ev.node);\n            if (this.viewSetting?.OnlyExecuteLeafNode === true && !ev.node.leaf) {\n                this.loadChildren(ev.node);\n            }\n        }\n        this._rebindRoot();\n    }\n\n    onNodeUlvCommand(ev: { node: TreeNodeObj; index: number }): void {\n        this._ulvCommandClicked(ev.node.Data, ev.index);\n    }\n\n    onNodeViewClick(ev: { node: TreeNodeObj; index: number }): void {\n        if (this.viewSetting?.DisableShowFormOnDoubleClick === true) {\n            return;\n        }\n        if (this.viewSetting?.OnlyExecuteLeafNode === true && !ev.node.leaf) {\n            return;\n        }\n        if (this.viewSetting?.DynamicCommandField) {\n            const dyn = this._rval.transform(this.viewSetting?.DynamicCommandField, ev.node.Data, this.allColumns);\n            if (dyn) {\n                this._selectNode(ev.node);\n                ExecuteDynamicCommand(dyn, ev.node.Data);\n                return;\n            }\n        }\n        this._raiseRowClick(ev.index, ev.node);\n    }\n\n    onLoadChildren(node: TreeNodeObj): void {\n        this.loadChildren(node);\n    }\n}\n","<ng-container\n    *ngTemplateOutlet=\"\n        renderTree;\n        context: {\n            $implicit: root$ | async,\n            moDataList: flatMoDataList,\n            isCheckList: context.Setting.View?.IsCheckList,\n            columns: visibleColumns$ | async,\n            groupby: groupby$ | async,\n            toolbarButtons: (toolbarButtons$ | async)!! | seperatorFix,\n            contextMenuItems: menuItems$ | async | contextMenu: context.Setting.View?.IsCheckList,\n            conditionalFormats: context.Setting.View?.ConditionalFormats,\n            deviceName: deviceName$ | async,\n            deviceSize: deviceSize$ | async,\n            access: context.Setting.Extra?.DefaultCommandsAccess,\n            title: title$ | async,\n            inlineEditMode: inlineEditMode$ | async,\n            allowInlineEdit: allowInlineEdit$ | async,\n            hideToolbar: hideToolbar$ | async,\n            gridSetting: gridSetting$ | async,\n            contentDensity: contentDensity$ | async,\n            hasSelected: hasSelected$ | async,\n            showOkCancelButtons: showOkCancelButtons,\n            hideOpenIcon: viewSetting?.HideOpenIcon,\n            openOnClick: viewSetting?.OpenOnClick,\n            onlyExecuteLeafNode: viewSetting?.OnlyExecuteLeafNode,\n            enableNodeReordering: viewSetting?.EnableNodeReordering,\n            viewSettingsContentDensity: viewSetting?.ContentDensity$Caption,\n            iconField: viewSetting?.IconField,\n            hideIcon: viewSetting?.HideIcon,\n            colorField: viewSetting?.ColorField,\n            selectedNode: selectedNode$ | async,\n            navigationArrow: navigationArrow$ | async,\n            collapseIcon: collapseIcon$ | async,\n            relationList: context.Setting.View.RelationList,\n            allColumns: allColumns,\n            rtl: rtl$ | async,\n            inDialog: inDialog$ | async,\n            isMultiSelect: isMultiSelect$ | async,\n            disableOverflowContextMenu: viewSetting?.DisableOverflowContextMenu,\n            isHetro: context.Setting.ClassNames.DataClass === 'Ul.HetroTreeUlvDataCtrlr',\n            selectedMo: selectedMo$ | async\n        }\n    \"\n></ng-container>\n\n<ng-template\n    #renderTree\n    let-root\n    let-moDataList=\"moDataList\"\n    let-deviceName=\"deviceName\"\n    let-deviceSize=\"deviceSize\"\n    let-toolbarButtons=\"toolbarButtons\"\n    let-title=\"title\"\n    let-inlineEditMode=\"inlineEditMode\"\n    let-allowInlineEdit=\"allowInlineEdit\"\n    let-hideToolbar=\"hideToolbar\"\n    let-gridSetting=\"gridSetting\"\n    let-contentDensity=\"contentDensity\"\n    let-access=\"access\"\n    let-contextMenuItems=\"contextMenuItems\"\n    let-conditionalFormats=\"conditionalFormats\"\n    let-isCheckList=\"isCheckList\"\n    let-groupby=\"groupby\"\n    let-hasSelected=\"hasSelected\"\n    let-showOkCancelButtons=\"showOkCancelButtons\"\n    let-selectedNode=\"selectedNode\"\n    let-navigationArrow=\"navigationArrow\"\n    let-collapseIcon=\"collapseIcon\"\n    let-rtl=\"rtl\"\n    let-disableOverflowContextMenu=\"disableOverflowContextMenu\"\n    let-relationList=\"relationList\"\n    let-isHetro=\"isHetro\"\n    let-inDialog=\"inDialog\"\n    let-isMultiSelect=\"isMultiSelect\"\n    let-selectedMo=\"selectedMo\"\n    let-hideOpenIcon=\"hideOpenIcon\"\n    let-openOnClick=\"openOnClick\"\n    let-enableNodeReordering=\"enableNodeReordering\"\n    let-onlyExecuteLeafNode=\"onlyExecuteLeafNode\"\n    let-iconField=\"iconField\"\n    let-colorField=\"colorField\"\n    let-allColumns=\"allColumns\"\n    let-hideIcon=\"hideIcon\"\n    let-viewSettingsContentDensity=\"viewSettingsContentDensity\"\n>\n    <bsu-ulv-toolbar\n        [hideToolbar]=\"hideToolbar\"\n        [deviceName]=\"deviceName\"\n        [deviceSize]=\"deviceSize\"\n        [toolbarButtons]=\"toolbarButtons\"\n        [gridSetting]=\"gridSetting\"\n        [title]=\"title\"\n        [hasSelected]=\"hasSelected\"\n        [inDialog]=\"inDialog\"\n        [isMultiSelect]=\"isMultiSelect\"\n        [contentDensity]=\"contentDensity\"\n        [inlineEditMode]=\"inlineEditMode\"\n        [allowInlineEdit]=\"allowInlineEdit\"\n        [moDataListCount]=\"moDataList.length\"\n        (sortClick)=\"onSortSettings(deviceName)\"\n        (groupbyClick)=\"onGroupbySettings(deviceName)\"\n        (columnClick)=\"onColumnSettings(deviceName)\"\n        (editModeClick)=\"onEditMode()\"\n    >\n        <button\n            fd-button\n            fd-toolbar-item\n            [fdType]=\"'transparent'\"\n            [glyph]=\"'collapse-all'\"\n            (click)=\"onCollapseAll()\"\n        ></button>\n        @if (!showOkCancelButtons && enableNodeReordering) {\n        <button\n            fd-button\n            fd-toolbar-item\n            [fdType]=\"'transparent'\"\n            [glyph]=\"'move'\"\n            (click)=\"onOpenMoveToDialog(selectedNode, deviceName, moveDialog)\"\n        ></button>\n        }\n    </bsu-ulv-toolbar>\n    <bsu-ui-tree-view\n        [leafCursorPointer]=\"onlyExecuteLeafNode && openOnClick\"\n        [rtl]=\"rtl\"\n        [relationList]=\"relationList\"\n        [root]=\"root\"\n        [allColumns]=\"allColumns\"\n        [hideIcon]=\"hideIcon\"\n        [selectedMo]=\"selectedMo\"\n        [hideOpenIcon]=\"hideOpenIcon\"\n        [disableOverflowContextMenu]=\"disableOverflowContextMenu\"\n        [iconField]=\"iconField\"\n        [colorField]=\"colorField\"\n        [navigationArrow]=\"navigationArrow\"\n        [collapseIcon]=\"collapseIcon\"\n        [selectedNode]=\"selectedNode\"\n        [access]=\"access\"\n        [viewSettingsContentDensity]=\"viewSettingsContentDensity\"\n        [deviceName]=\"deviceName\"\n        [deviceSize]=\"deviceSize\"\n        [enableNodeReordering]=\"enableNodeReordering\"\n        [inDialog]=\"inDialog\"\n        [isMultiSelect]=\"isMultiSelect\"\n        [openOnClick]=\"openOnClick\"\n        [contextMenuItems]=\"contextMenuItems\"\n        [moDataList]=\"moDataList\"\n        [groupby]=\"groupby\"\n        [isHetro]=\"isHetro\"\n        [isCheckList]=\"isCheckList\"\n        [conditionalFormats]=\"conditionalFormats\"\n        [showOkCancelButtons]=\"showOkCancelButtons\"\n        (checkChange)=\"onCheckChange($event)\"\n        (itemDrop)=\"onDrop($event)\"\n        (itemDragMoved)=\"onDragMoved($event)\"\n        (nodeUlvCommand)=\"onNodeUlvCommand($event)\"\n        (nodeViewClick)=\"onNodeViewClick($event)\"\n        (loadChildren)=\"onLoadChildren($event)\"\n        (nodeSelect)=\"onNodeSelect($event)\"\n        (rowCheck)=\"onRowCheck($event)\"\n        (rowClick)=\"onRowClick($event)\"\n        (allCheckbox)=\"onAllCheckbox($event)\"\n        (expandClick)=\"onExpandClick($event)\"\n        (editFormPanelCancel)=\"onEditFormPanelCancel($event)\"\n        (editFormPanelSave)=\"onEditFormPanelSave($event)\"\n        (createNew)=\"onCreateNew($event)\"\n    >\n    </bsu-ui-tree-view>\n    <ng-template let-dialog let-dialogConfig=\"dialogConfig\" #moveDialog>\n        <fd-dialog [dialogConfig]=\"dialogConfig\" [dialogRef]=\"dialog\">\n            <fd-dialog-header>\n                <h1 fd-title>{{ 'Move' | bbbTranslate }}</h1>\n                <button fd-dialog-close-button (click)=\"dialog.dismiss('Close button')\"></button>\n            </fd-dialog-header>\n\n            <fd-dialog-body>\n                <div class=\"move-to\" (keydown.enter)=\"onConfirmDialog(dialogSelectedNode)\">\n                    <bsu-ui-tree-view\n                        [rtl]=\"rtl\"\n                        [root]=\"root\"\n                        [access]=\"access\"\n                        [navigationArrow]=\"navigationArrow\"\n                        [collapseIcon]=\"collapseIcon\"\n                        [deviceName]=\"deviceName\"\n                        [deviceSize]=\"deviceSize\"\n                        [viewSettingsContentDensity]=\"viewSettingsContentDensity\"\n                        [enableNodeReordering]=\"enableNodeReordering\"\n                        [openOnClick]=\"openOnClick\"\n                        [selectedNode]=\"dialogSelectedNode\"\n                        [moDataList]=\"flatMoDataList\"\n                        [groupby]=\"groupby\"\n                        [isCheckList]=\"isCheckList\"\n                        [conditionalFormats]=\"conditionalFormats\"\n                        (loadChildren)=\"onLoadChildren($event)\"\n                        (nodeSelect)=\"onSelectNodeInMoveDialog($event)\"\n                    ></bsu-ui-tree-view>\n                </div>\n            </fd-dialog-body>\n\n            <fd-dialog-footer>\n                <ng-template fdkTemplate=\"footer\">\n                    <div fd-bar-right>\n                        <fd-button-bar\n                            fdType=\"emphasized\"\n                            [label]=\"'OK' | bbbTranslate\"\n                            (click)=\"onConfirmDialog(dialogSelectedNode)\"\n                        >\n                        </fd-button-bar>\n                        <fd-button-bar fd-initial-focus [label]=\"'Cancel' | bbbTranslate\" (click)=\"onDismissDialog()\">\n                        </fd-button-bar>\n                    </div>\n                </ng-template>\n            </fd-dialog-footer>\n        </fd-dialog>\n    </ng-template>\n</ng-template>\n"]}
@@ -4167,6 +4167,7 @@ class UiTreeComponent extends ReportTreeBaseComponent {
4167
4167
  if (this.viewSetting?.DynamicCommandField) {
4168
4168
  const dyn = this._rval.transform(this.viewSetting?.DynamicCommandField, ev.node.Data, this.allColumns);
4169
4169
  if (dyn) {
4170
+ this._selectNode(ev.node);
4170
4171
  ExecuteDynamicCommand(dyn, ev.node.Data);
4171
4172
  return;
4172
4173
  }
@@ -6485,14 +6486,14 @@ class ReportNavigatorComponent extends BaseComponent {
6485
6486
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.5", type: ReportNavigatorComponent, selector: "bsu-report-navigator", host: { properties: { "style.min-height": "this.minheight" } }, viewQueries: [{ propertyName: "containerRef", first: true, predicate: ["containerRef"], descendants: true, read: ViewContainerRef, static: true }], usesInheritance: true, ngImport: i0, template: `<ng-container #containerRef></ng-container>
6486
6487
  @if ((loading$ | async) === true) {
6487
6488
  <bsu-mask></bsu-mask>
6488
- }`, isInline: true, styles: [":host{display:block;background:var(--sapBaseColor)}\n"], dependencies: [{ kind: "component", type: MaskComponent, selector: "bsu-mask", inputs: ["size", "top"] }, { kind: "pipe", type: i1$2.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
6489
+ }`, isInline: true, styles: [":host{display:block;width:100%;background:var(--sapBaseColor)}\n"], dependencies: [{ kind: "component", type: MaskComponent, selector: "bsu-mask", inputs: ["size", "top"] }, { kind: "pipe", type: i1$2.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
6489
6490
  }
6490
6491
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: ReportNavigatorComponent, decorators: [{
6491
6492
  type: Component,
6492
6493
  args: [{ selector: 'bsu-report-navigator', template: `<ng-container #containerRef></ng-container>
6493
6494
  @if ((loading$ | async) === true) {
6494
6495
  <bsu-mask></bsu-mask>
6495
- }`, changeDetection: ChangeDetectionStrategy.OnPush, styles: [":host{display:block;background:var(--sapBaseColor)}\n"] }]
6496
+ }`, changeDetection: ChangeDetectionStrategy.OnPush, styles: [":host{display:block;width:100%;background:var(--sapBaseColor)}\n"] }]
6496
6497
  }], ctorParameters: () => [{ type: i2$7.ActivatedRoute }, { type: i2.PortalService }, { type: i0.Injector }, { type: i0.ChangeDetectorRef }], propDecorators: { containerRef: [{
6497
6498
  type: ViewChild,
6498
6499
  args: ['containerRef', { static: true, read: ViewContainerRef }]