barsa-sap-ui 2.0.125 → 2.0.127

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.
@@ -30,13 +30,14 @@ export class UiTableViewComponent extends ReportViewBaseComponent {
30
30
  }
31
31
  ngOnInit() {
32
32
  super.ngOnInit();
33
- const x = this._el.nativeElement.parentNode.getBoundingClientRect().width;
33
+ const x = Math.floor(this._el.nativeElement.parentNode.getBoundingClientRect().width);
34
34
  if (x) {
35
35
  this._renderer2.setStyle(this._el.nativeElement, 'width', `${x}px`);
36
36
  }
37
37
  this._portalService.windowResize$.pipe(takeUntil(this._onDestroy$)).subscribe(() => {
38
- this._renderer2.setStyle(this._tableRef.nativeElement, 'width', this._el.nativeElement.parentNode.getBoundingClientRect().width + 'px');
39
- this._renderer2.setStyle(this._tableRef.nativeElement, 'max-width', this._el.nativeElement.parentNode.getBoundingClientRect().width + 'px');
38
+ const x = Math.floor(this._el.nativeElement.parentNode.getBoundingClientRect().width);
39
+ this._renderer2.setStyle(this._tableRef.nativeElement, 'width', x + 'px');
40
+ this._renderer2.setStyle(this._tableRef.nativeElement, 'max-width', x + 'px');
40
41
  this._refreshThWidth();
41
42
  });
42
43
  this.hasRowOlgo = this.viewSetting?.RowOlgo?.Selector;
@@ -279,4 +280,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImpor
279
280
  type: HostBinding,
280
281
  args: ['style.max-height']
281
282
  }] } });
282
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ui-table-view.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-sap-ui/src/lib/ui-table-view/ui-table-view.component.ts","../../../../../projects/barsa-sap-ui/src/lib/ui-table-view/ui-table-view.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    Component,\n    ElementRef,\n    HostBinding,\n    Input,\n    OnChanges,\n    OnInit,\n    signal,\n    SimpleChanges,\n    ViewChild\n} from '@angular/core';\nimport { Subject, takeUntil } from 'rxjs';\nimport {\n    MetaobjectDataModel,\n    ReportViewBaseComponent,\n    ReportViewColumn,\n    TableHeaderWidthMode,\n    ColumnResizedArgs,\n    calcContextMenuWidth,\n    calculateColumnWidth,\n    calculateColumnWidthFitToContainer,\n    calculateFreeColumnSize,\n    calculateColumnContent,\n    setColumnWidthByMaxMoContentWidth\n} from 'barsa-novin-ray-core';\nimport { UiTableViewSetting } from '../models/grid-view';\nimport { BarsaTableHeaderComponent } from '../barsa-table-header/barsa-table-header.component';\n\n@Component({\n    selector: 'bsu-ui-table-view',\n    templateUrl: './ui-table-view.component.html',\n    styleUrls: ['./ui-table-view.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class UiTableViewComponent\n    extends ReportViewBaseComponent<UiTableViewSetting>\n    implements OnInit, AfterViewInit, OnChanges\n{\n    @ViewChild('tableTpl', { static: true, read: ElementRef }) _tableRef: ElementRef;\n    @ViewChild(BarsaTableHeaderComponent) _tableHeaderComponent: BarsaTableHeaderComponent;\n    @Input() columnWidth: number;\n    @Input() minWidth;\n    @Input() minHeight;\n    @Input() disableResize;\n    @Input() disableHeaderContextMenu;\n    @Input() rowResizer;\n    @Input() enableResizing;\n    @Input() disableFixedTableLayout;\n    @HostBinding('style.height.px') height: number | null = null;\n    @HostBinding('style.max-height') maxHeight: string | null = null;\n    _width = '100%';\n    showDetailsInRow: boolean;\n    hasRowOlgo: boolean;\n    columnComponents: { column: ReportViewColumn; component: MetaobjectDataModel }[] = [];\n    rowIndicator: boolean;\n    tableHeaderMode = TableHeaderWidthMode.FitToContainer;\n    stickyEnable = signal(false);\n    rowVisibiltyChange = signal(false);\n    tableHeaderDom: HTMLElement;\n    _headerTop$ = new Subject<string>();\n    rowVisible$ = new Subject<{ index; dom }>();\n    _isParentWidthSet = false;\n    tableHeaderTop = 0;\n    tableHeaderHeight = 0;\n    headerObserverDom: HTMLElement;\n    notVisibleItems: number[] = [];\n    visibleItems: number[] = [];\n    oldWidth = 0;\n    ngOnInit(): void {\n        super.ngOnInit();\n\n        const x = this._el.nativeElement.parentNode.getBoundingClientRect().width;\n        if (x) {\n            this._renderer2.setStyle(this._el.nativeElement, 'width', `${x}px`);\n        }\n        this._portalService.windowResize$.pipe(takeUntil(this._onDestroy$)).subscribe(() => {\n            this._renderer2.setStyle(\n                this._tableRef.nativeElement,\n                'width',\n                this._el.nativeElement.parentNode.getBoundingClientRect().width + 'px'\n            );\n            this._renderer2.setStyle(\n                this._tableRef.nativeElement,\n                'max-width',\n                this._el.nativeElement.parentNode.getBoundingClientRect().width + 'px'\n            );\n            this._refreshThWidth();\n        });\n        this.hasRowOlgo = this.viewSetting?.RowOlgo?.Selector;\n        this.maxHeight = this.viewSetting?.BodyHeight;\n        this._setHasSummery(this.cartableChildsMo);\n        this._setHeight(this.parentHeight);\n        this._setWidth();\n        this._calculateColumnsWidth(this.moDataList, this.columns);\n        this.tableHeaderMode = this.gridFreeColumnSizing\n            ? TableHeaderWidthMode.FreeColumnSize\n            : TableHeaderWidthMode.FitToContainer;\n        this._calcContextMenuWidth(this.contextMenuItems);\n    }\n\n    _calcContextMenuWidth(contextMenuItems): void {\n        this.contextMenuWidth = calcContextMenuWidth(contextMenuItems, this.disableOverflowContextMenu);\n    }\n    onTableVisibilityChange(e, dom): void {\n        if (e === 'Visible') {\n            this._setWidth(true);\n        }\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        const { cartableTemplates, parentHeight, contextMenuItems, columnsCount, columns, secondaryColumns } = changes;\n        if (contextMenuItems && !contextMenuItems.firstChange) {\n            this._calcContextMenuWidth(contextMenuItems.currentValue);\n            this._cdr.detectChanges();\n        }\n        if (cartableTemplates && !cartableTemplates.firstChange && !this.hasSummary) {\n            this._setHasSummery(cartableTemplates.currentValue);\n        }\n        if ((columnsCount && !columnsCount.firstChange) || (secondaryColumns && !secondaryColumns.firstChange)) {\n            this._calculateColumnsWidth(this.moDataList, columns.currentValue);\n        }\n        if (parentHeight && !parentHeight.firstChange) {\n            this._setHeight(parentHeight.currentValue);\n        }\n        super.ngOnChanges(changes);\n    }\n    onColumnResizing(e: { column: ReportViewColumn; width: number }): void {\n        this._tableHeaderComponent.SetColumnWidthToThWidth();\n        this._setParentWidth();\n    }\n    onColumnResized(arr: Array<ColumnResizedArgs>): void {\n        if (this.secondaryColumns.length) {\n            return;\n        }\n\n        if (this.tableHeaderMode === TableHeaderWidthMode.FreeColumnSize) {\n            this._tableHeaderComponent.SetColumnWidthToThWidth();\n        } else {\n            this._tableHeaderComponent.SetColumnWidthToPercent();\n        }\n        this._tableHeaderComponent.RefreshTableThWidth();\n        this.resizedByUser = true;\n\n        // this._renderer2.setStyle(lastTh, 'width', `100%`);\n        this.columnResized.emit({ columns: this.columns, resized: arr });\n    }\n    onFitToContainer(): void {\n        this.tableHeaderMode = TableHeaderWidthMode.FitToContainer;\n        this._setParentWidthFit();\n        this._tableHeaderComponent.SetColumnWidthToPercent();\n        // this._refreshThWidth();\n        // this._fireResizeChanged();\n    }\n    onFreeColumnSizing(): void {\n        this.tableHeaderMode = TableHeaderWidthMode.FreeColumnSize;\n        this._tableHeaderComponent.SetColumnWidthToThWidth();\n        this._setParentWidthFitToOffsetWidth();\n        this._calculateColumnsWidth(this.moDataList, this.columns);\n    }\n    onFitToContent(e: { column: ReportViewColumn; thDom: HTMLTableCellElement }): void {\n        const { column, thDom } = e;\n        this.tableHeaderMode = TableHeaderWidthMode.FreeColumnSize;\n        setColumnWidthByMaxMoContentWidth(this.moDataList, column);\n        column.$Width = column.$ContentWidth;\n        this._renderer2.setStyle(thDom, 'width', column.$Width);\n        this._fireResizeChanged();\n    }\n\n    onSetTableHeaderDom(dom): void {\n        this.tableHeaderDom = dom;\n        const rect = dom.getBoundingClientRect();\n        this.tableHeaderTop = rect.top;\n        this.tableHeaderHeight = rect.height;\n    }\n    onHeaderVisibilityChange(e, dom): void {\n        return;\n        this.headerObserverDom = dom;\n        if (e === 'NotVisible') {\n            this.stickyEnable.set(true);\n        } else {\n            this.stickyEnable.set(false);\n        }\n    }\n\n    onRowVisibilityChange(e, index, dom): void {\n        return;\n        if (e !== 'Pending') {\n            if (e === 'NotVisible') {\n                if (this.visibleItems.indexOf(index) !== -1) {\n                    this.rowVisible$.next({ index, dom });\n                    this.visibleItems = this.visibleItems.filter((c) => c !== index);\n                }\n                this.notVisibleItems.push(index);\n            }\n            if (e === 'Visible') {\n                this.notVisibleItems = this.notVisibleItems.filter((c) => c !== index);\n\n                this.visibleItems.push(index);\n            }\n            // this.rowVisible$.next({ index, dom });\n        }\n    }\n    private _setParentWidthFit(): void {\n        this._renderer2.setStyle(this._el.nativeElement.parentNode, 'width', `100%`);\n        this._renderer2.setStyle(this._tableRef.nativeElement, 'min-width', `100%`);\n        this._renderer2.setStyle(this._tableRef.nativeElement, 'width', `100%`);\n    }\n    private _setParentWidthFitToOffsetWidth(): void {\n        this._renderer2.setStyle(\n            this._el.nativeElement.parentNode,\n            'width',\n            `${this._el.nativeElement.parentNode.getBoundingClientRect().width}px`\n        );\n        this._renderer2.setStyle(this._tableRef.nativeElement, 'min-width', `${this._el.nativeElement.offsetWidth}px`);\n        this._renderer2.setStyle(this._tableRef.nativeElement, 'width', `${this._el.nativeElement.offsetWidth}px`);\n    }\n    private _setParentWidth(): void {\n        this._renderer2.setStyle(\n            this._el.nativeElement.parentNode,\n            'width',\n            `${this._el.nativeElement.parentNode.getBoundingClientRect().width}px`\n        );\n    }\n    private _refreshThWidth(): void {\n        this._calculateColumnsWidth(this.moDataList, this.columns);\n        this._tableHeaderComponent?.RefreshTableThWidth();\n    }\n    private _setWidth(setWidth?: boolean): void {\n        const widthOfDom = this._el.nativeElement.parentNode.getBoundingClientRect().width;\n        if (widthOfDom === 0) {\n            return;\n        }\n        if (widthOfDom !== this.oldWidth) {\n            this._refreshThWidth();\n        }\n        this.oldWidth = widthOfDom;\n        this._renderer2.setStyle(\n            this._tableRef.nativeElement,\n            'max-width',\n            this._el.nativeElement.parentNode.getBoundingClientRect().width + 'px'\n        );\n        this._renderer2.setStyle(this._tableRef.nativeElement, 'width', widthOfDom + 'px');\n    }\n    private _calculateHeaderStickyTop(dom: HTMLElement): void {\n        if (this.stickyEnable() && this.tableHeaderDom) {\n            // const rec = this.headerObserverDom.getBoundingClientRect();\n            // const top = rec.top;\n            // const calc = this.tableHeaderTop - top - this.tableHeaderHeight + 'px';\n            const rec = dom.getBoundingClientRect();\n\n            this._headerTop$.next(rec.top - 12 + this.tableHeaderHeight + 'px');\n        }\n    }\n\n    protected _fireResizeChanged(): void {\n        this.columnResized.emit({\n            columns: this.columns,\n            resized: this.columns.map((c) => ({ name: c.Name, width: c.Width }))\n        });\n    }\n    protected _calculateColumnsWidth(moDataList: MetaobjectDataModel[], columns: ReportViewColumn[]): void {\n        switch (this.tableHeaderMode) {\n            case TableHeaderWidthMode.FreeColumnSize:\n                this._freeColumnSize(moDataList, columns);\n                break;\n            case TableHeaderWidthMode.FitToRowContent:\n                this._fitToRowContentColumn(moDataList, columns);\n                break;\n            case TableHeaderWidthMode.FitToContainer:\n                this._fitToContainer(moDataList, columns);\n                break;\n        }\n    }\n    protected _fitToColumn(moDataList, columns): void {\n        const elDom = this._el.nativeElement as HTMLElement;\n        calculateColumnWidth(elDom, columns, moDataList, this.disableOverflowContextMenu, this.contextMenuItems);\n    }\n    protected _fitToRowContentColumn(moDataList: MetaobjectDataModel[], columns: ReportViewColumn[]): void {\n        calculateColumnContent(columns, moDataList);\n    }\n    protected _fitToContainer(moDataList, columns): void {\n        const elDom = this._el.nativeElement.parentElement as HTMLElement;\n        calculateColumnWidthFitToContainer(\n            elDom,\n            this.canView,\n            this.disableHeaderContextMenu,\n            this.contextMenuItems,\n            this.columns\n        );\n    }\n    protected _freeColumnSize(moDataList, columns): void {\n        calculateFreeColumnSize(this.columns);\n    }\n    protected _setHeight(parentHeight: number): void {\n        if (this.inDialog) {\n            this.height = parentHeight;\n        }\n    }\n    protected _setHasSummery(cartableTemplates): void {\n        if (\n            this.detailsColumns?.length > 0 ||\n            this.detailsComponent?.Selector ||\n            (cartableTemplates && Object.keys(cartableTemplates).length > 0)\n        ) {\n            this.showDetailsInRow = true;\n            this.hasDetailsInRow.emit(true);\n        } else {\n            this.hasDetailsInRow.emit(false);\n        }\n    }\n    protected _containerWidthChanged(val: number): void {\n        if (val === 0) {\n            this._width = '100%';\n        } else {\n            this._width = val ? val + 'px' : '100%';\n        }\n        this._renderer2.setStyle(this._el.nativeElement, 'width', this._width);\n    }\n}\n","<table\n    fd-table\n    #tableTpl\n    #headerBottomObserver\n    intersectionObserver\n    [intersectionThreshold]=\"0.1\"\n    (visibilityChange)=\"onTableVisibilityChange($event, headerBottomObserver)\"\n    [popIn]=\"popin\"\n    [class.table-fixed]=\"\n        !contextView?.Grid_HideHeader && (!popin || secondaryColumns.length === 0) && !disableFixedTableLayout\n    \"\n    [noBorderX]=\"viewSetting?.NoHoriztonalBorders === true\"\n    [noBorderY]=\"viewSetting?.NoVerticalBorders === true || (popin && secondaryColumns.length > 0)\"\n>\n    @if (columns | mergeFieldsToColumns: viewSetting?.MergeFieldsToColumns?.MoDataList; as mergeFieldsToColumns) {\n    <ng-container\n        *ngTemplateOutlet=\"\n            headerTemplate;\n            context: { $implicit: mergeFieldsToColumns, moDataListCount: moDataList?.length }\n        \"\n    ></ng-container>\n    @if (moDataList?.length) {\n    <ng-container\n        *ngTemplateOutlet=\"\n            bodyTemplate;\n            context: { $implicit: mergeFieldsToColumns, previewColumn: allColumns | findPreviewColumn }\n        \"\n    ></ng-container>\n    <ng-container *ngTemplateOutlet=\"footerTemplate; context: { $implicit: mergeFieldsToColumns }\"></ng-container>\n    } }\n</table>\n<!--renderColumn-->\n\n@if (!moDataList?.length) {\n<bsu-no-data\n    [class.no-topborder]=\"!hideToolbar\"\n    [class.noborder]=\"contextView.Grid_HideHeader && hideToolbar\"\n    [simple]=\"true\"\n>\n</bsu-no-data>\n}\n\n<ng-template #headerTemplate let-columns let-moDataListCount>\n    <bsu-barsa-table-header\n        [sticky]=\"stickyEnable()\"\n        [hasSecondaryColumns]=\"secondaryColumns.length > 0\"\n        [class.has-toolbar]=\"!hideToolbar\"\n        [style.pointer-events]=\"moDataListCount ? 'auto' : 'none'\"\n        [tableWidth]=\"elWidth\"\n        [showDetailsInRow]=\"showDetailsInRow\"\n        [hideOpenIcon]=\"hideOpenIcon\"\n        [resizedByUser]=\"resizedByUser\"\n        [tableHeaderMode]=\"tableHeaderMode\"\n        [showRowNumber]=\"contextView?.Grid_ShowRowNumber\"\n        [allChecked]=\"allChecked\"\n        [rtl]=\"rtl\"\n        [actionList]=\"actionList\"\n        [disableResponsive]=\"disableResponsive\"\n        [isCheckList]=\"isCheckList\"\n        [columns]=\"\n            columns\n                | filterColumnsByDetails: detailsColumns:rowIndicator\n                | filter: { IsPreview: false }\n                | hideColumnsInmobile: viewSetting?.HideColumnsInMobile\n        \"\n        [fitWidth]=\"fitWidth\"\n        [disableOverflowContextMenu]=\"disableOverflowContextMenu\"\n        [inlineEditMode]=\"inlineEditMode\"\n        [contextMenuItems]=\"contextMenuItems\"\n        [contextMenuWidth]=\"contextMenuWidth\"\n        [showViewButton]=\"showViewButton\"\n        [deviceSize]=\"deviceSize\"\n        [viewSetting]=\"viewSetting\"\n        [hideHeader]=\"contextView.Grid_HideHeader\"\n        [rowIndicator]=\"rowIndicator\"\n        [disableResize]=\"disableResize\"\n        [disableHeaderContextMenu]=\"disableHeaderContextMenu\"\n        (headerRender)=\"onSetTableHeaderDom($event)\"\n        (columnResize)=\"onColumnResized($event)\"\n        (columnResizing)=\"onColumnResizing($event)\"\n        (fitToContent)=\"onFitToContent($event)\"\n        (fitToContainer)=\"onFitToContainer()\"\n        (freeColumnSize)=\"onFreeColumnSizing()\"\n        (allCheckbox)=\"onAllCheckbox($event)\"\n        (sortAscending)=\"onSortAscending($event)\"\n        (sortDescending)=\"onSortDescending($event)\"\n        (filter)=\"onFilter($event)\"\n        (resetGridSettings)=\"resetGridSettings.emit()\"\n    ></bsu-barsa-table-header>\n    <!-- <div\n        #headerBottomObserver\n        intersectionObserver\n        [intersectionThreshold]=\"0.1\"\n        (visibilityChange)=\"onHeaderVisibilityChange($event, headerBottomObserver)\"\n    ></div> -->\n</ng-template>\n<ng-template #bodyTemplate let-columns let-previewColumn=\"previewColumn\">\n    <tbody\n        #body\n        fd-table-body\n        [class.noborder]=\"viewSetting?.NoBodyBorders === true\"\n        [noBorderX]=\"viewSetting?.NoHoriztonalBorders === true || previewColumn\"\n        [noBorderY]=\"(popin && secondaryColumns.length > 0) || previewColumn\"\n    >\n        <ng-container>\n            @for (mo of moDataList | multipleGroupBy: groupby; track _trackByRow(index, mo); let index = $index) {\n            <ng-container\n                *ngTemplateOutlet=\"\n                    hasRowOlgo ? rowOlgoTemplate : rowTemplate;\n                    context: {\n                        $implicit: mo,\n                        index: index,\n                        rowNumber: mo.Id | rowNumber: pagingSetting:moDataList,\n                        rowIndicatorColor: !columns.length ? '' : (columns[0].Caption | rval: mo:columns),\n                        columns: columns | columnCustomComponent: viewSetting?.ColumnComponents?.MoDataList,\n                        secondaryColumns:\n                            secondaryColumns | columnCustomComponent: viewSetting?.ColumnComponents?.MoDataList,\n                        moDataList: moDataList,\n                        moDataListCount: moDataList.length,\n                        cartableTemplate: cartableTemplates[mo.RelatedMo?.$TypeDefId + '@' + mo.CartableSettings?.Id],\n                        previewColumn: previewColumn,\n                        detailsCollapsed: viewSetting?.DetailsSetting?.DetailsCollapsed === true,\n                        hideDetailsText: viewSetting?.DetailsSetting?.HideDetailsText === true\n                    }\n                \"\n            ></ng-container>\n            }\n        </ng-container>\n    </tbody>\n</ng-template>\n<ng-template #footerTemplate let-columns>\n    @if (hasSummary) {\n    <tfoot fd-table-footer>\n        <tr fd-table-row class=\"row-summary\">\n            @if (isCheckList) {\n            <td fd-table-cell columnResizer>\n                <strong class=\"col-total-text\">{{ 'Total' | bbbTranslate }}</strong>\n            </td>\n            } @if (!isCheckList) {\n            <td fd-table-cell class=\"single-select\">\n                <strong class=\"col-total-text\">{{ 'Total' | bbbTranslate }}</strong>\n            </td>\n            } @for (column of columns; track column; let i = $index) {\n            <td>\n                @if (column.HasSummary) {\n                <strong style=\"direction: ltr; display: block\">\n                    {{ moDataList | totalSummary: column.Name | number }}</strong\n                >\n                }\n            </td>\n            } @if (contextMenuItems && contextMenuItems.length > 0) {\n            <td fd-table-cell style=\"width: 100px\"></td>\n            } @if (!hideOpenIcon && canView && (!inlineEditMode || !allowInlineEdit)) {\n            <td fd-table-cell></td>\n            }\n        </tr>\n    </tfoot>\n    }\n</ng-template>\n<ng-template\n    #rowOlgoTemplate\n    let-mo\n    let-index=\"index\"\n    let-columns=\"columns\"\n    let-moDataListCount=\"moDataListCount\"\n    let-moDataList=\"moDataList\"\n    let-cartableTemplate=\"cartableTemplate\"\n    let-secondaryColumns=\"secondaryColumns\"\n    let-rowIndicatorColor=\"rowIndicatorColor\"\n    let-rowNumber=\"rowNumber\"\n    let-previewColumn=\"previewColumn\"\n    let-detailsCollapsed=\"detailsCollapsed\"\n    let-hideDetailsText=\"hideDetailsText\"\n>\n    <bnrc-dynamic-item-component\n        [component]=\"viewSetting.RowOlgo\"\n        [mo]=\"mo\"\n        [detailsCollapsed]=\"detailsCollapsed\"\n        [hideDetailsText]=\"hideDetailsText\"\n        [isLastChildGroup]=\"mo.$IsLastChildGroup\"\n        [groupSummary]=\"groupSummary\"\n        [showViewButton]=\"showViewButton\"\n        [UlvMainCtrlr]=\"UlvMainCtrlr\"\n        [moDataList]=\"moDataList\"\n        [showDetailsInRow]=\"showDetailsInRow\"\n        [hideOpenIcon]=\"hideOpenIcon\"\n        [detailsColumns]=\"detailsColumns\"\n        [showRowNumber]=\"contextView?.Grid_ShowRowNumber\"\n        [rowNumber]=\"rowNumber\"\n        [columnComponents]=\"viewSetting?.ColumnComponents || null\"\n        [cartableTemplate]=\"cartableTemplate\"\n        [cartableMo]=\"mo.RelatedMo\"\n        [dirtyColumns]=\"mo.$DirtyColumns\"\n        [cartableWorkflowData]=\"mo.SerializedWorkflowData\"\n        [serializedRelatedMo]=\"mo.SerializedRelatedMo\"\n        [detailsText]=\"viewSetting?.DetailsSetting?.ButtonText\"\n        [detailsTextFunction]=\"viewSetting?.DetailsSetting?.ButtonTextFunction\"\n        [detailsComponent]=\"detailsComponent\"\n        [coloringRow]=\"viewSetting?.ColoringRow\"\n        [isChecked]=\"mo.$IsChecked\"\n        [visibility]=\"mo.$Visibility\"\n        [expanded]=\"mo.$Expanded\"\n        [styleIndex]=\"mo.$StyleIndex\"\n        [level]=\"mo.$Level\"\n        [parentExpanded]=\"mo.$Parent?.$Expanded\"\n        [moDataListCount]=\"moDataListCount\"\n        [columnsCount]=\"columnsCount - detailsColumns.length\"\n        [typeDefId]=\"typeDefId\"\n        [extraRelation]=\"extraRelation\"\n        [formSetting]=\"formSetting\"\n        [index]=\"index\"\n        [setting]=\"viewSetting\"\n        [secondaryColumns]=\"secondaryColumns | filterColumnsByDetails: detailsColumns:rowIndicator\"\n        [columns]=\"columns | filterColumnsByDetails: detailsColumns:rowIndicator\"\n        [isNewInlineMo]=\"mo.$NewInlineMo\"\n        [access]=\"access\"\n        [inlineEditMode]=\"inlineEditMode\"\n        [allowInlineEdit]=\"allowInlineEdit\"\n        [rtl]=\"rtl\"\n        [deviceName]=\"deviceName\"\n        [deviceSize]=\"deviceSize\"\n        [allColumns]=\"allColumns\"\n        [contextMenuItems]=\"contextMenuItems\"\n        [canView]=\"canView\"\n        [conditionalFormats]=\"conditionalFormats\"\n        [disableOverflowContextMenu]=\"disableOverflowContextMenu\"\n        [navigationArrow]=\"navigationArrow\"\n        [isCheckList]=\"isCheckList\"\n        [rowIndicator]=\"rowIndicator\"\n        [rowIndicatorColor]=\"rowIndicatorColor\"\n        (events)=\"onOlgoEvents($event)\"\n    >\n    </bnrc-dynamic-item-component>\n</ng-template>\n<ng-template\n    #rowTemplate\n    let-mo\n    let-index=\"index\"\n    let-rowNumber=\"rowNumber\"\n    let-columns=\"columns\"\n    let-moDataListCount=\"moDataListCount\"\n    let-moDataList=\"moDataList\"\n    let-cartableTemplate=\"cartableTemplate\"\n    let-secondaryColumns=\"secondaryColumns\"\n    let-rowIndicatorColor=\"rowIndicatorColor\"\n    let-previewColumn=\"previewColumn\"\n    let-detailsCollapsed=\"detailsCollapsed\"\n    let-hideDetailsText=\"hideDetailsText\"\n>\n    <bsu-barsa-table-row\n        [mo]=\"mo\"\n        [dirtyColumns]=\"mo.$DirtyColumns\"\n        [isLastChildGroup]=\"mo.$IsLastChildGroup\"\n        [moDataList]=\"moDataList\"\n        [hideDetailsText]=\"hideDetailsText\"\n        [detailsCollapsed]=\"detailsCollapsed\"\n        [groupSummary]=\"groupSummary\"\n        [UlvMainCtrlr]=\"UlvMainCtrlr\"\n        [showDetailsInRow]=\"showDetailsInRow\"\n        [hideOpenIcon]=\"hideOpenIcon\"\n        [showRowNumber]=\"contextView?.Grid_ShowRowNumber\"\n        [rowNumber]=\"rowNumber\"\n        [coloringRow]=\"viewSetting?.ColoringRow\"\n        [disableEllapsis]=\"viewSetting?.DisableEllapsis\"\n        [showViewButton]=\"showViewButton\"\n        [detailsColumns]=\"detailsColumns\"\n        [columnComponents]=\"viewSetting?.ColumnComponents || null\"\n        [cartableTemplate]=\"cartableTemplate\"\n        [cartableMo]=\"mo.RelatedMo\"\n        [cartableWorkflowData]=\"mo.SerializedWorkflowData\"\n        [serializedRelatedMo]=\"mo.SerializedRelatedMo\"\n        [detailsText]=\"viewSetting?.DetailsSetting?.ButtonText\"\n        [detailsComponent]=\"detailsComponent\"\n        [isChecked]=\"mo.$IsChecked\"\n        [visibility]=\"mo.$Visibility\"\n        [expanded]=\"mo.$Expanded\"\n        [styleIndex]=\"mo.$StyleIndex\"\n        [level]=\"mo.$Level\"\n        [parentExpanded]=\"mo.$Parent?.$Expanded\"\n        [moDataListCount]=\"moDataListCount\"\n        [columnsCount]=\"columnsCount - detailsColumns.length\"\n        [typeDefId]=\"typeDefId\"\n        [extraRelation]=\"extraRelation\"\n        [formSetting]=\"formSetting\"\n        [index]=\"index\"\n        [setting]=\"viewSetting\"\n        [checkboxComponent]=\"viewSetting?.CheckboxComponent\"\n        [secondaryColumns]=\"\n            secondaryColumns\n                | filterColumnsByDetails: detailsColumns:false\n                | filter: { IsPreview: false }\n                | hideColumnsInmobile: viewSetting?.HideColumnsInMobile\n        \"\n        [columns]=\"\n            columns\n                | filterColumnsByDetails: detailsColumns:rowIndicator\n                | filter: { IsPreview: false }\n                | hideColumnsInmobile: viewSetting?.HideColumnsInMobile\n        \"\n        [isNewInlineMo]=\"mo.$NewInlineMo\"\n        [access]=\"access\"\n        [simpleInlineEdit]=\"simpleInlineEdit\"\n        [noSaveInlineEditInServer]=\"simpleInlineEdit\"\n        [actionList]=\"actionList\"\n        [inlineEditMode]=\"inlineEditMode\"\n        [allowInlineEdit]=\"allowInlineEdit\"\n        [rtl]=\"rtl\"\n        [deviceName]=\"deviceName\"\n        [deviceSize]=\"deviceSize\"\n        [allColumns]=\"allColumns\"\n        [contextMenuItems]=\"contextMenuItems\"\n        [canView]=\"canView\"\n        [conditionalFormats]=\"conditionalFormats\"\n        [disableOverflowContextMenu]=\"disableOverflowContextMenu\"\n        [navigationArrow]=\"navigationArrow\"\n        [isCheckList]=\"isCheckList\"\n        [rowIndicator]=\"rowIndicator\"\n        [rowIndicatorColor]=\"rowIndicatorColor\"\n        [previewColumn]=\"previewColumn\"\n        (columnSummary)=\"columnSummary.emit($event)\"\n        (resetWorkflowState)=\"resetWorkflowState.emit(mo)\"\n        (escapeKey)=\"onEscapeKey($event)\"\n        (expandClick)=\"onExpandClick($event)\"\n        (rowCheck)=\"onRowCheck($event)\"\n        (workflowShareButtons)=\"onWorkflowShareButtons($event)\"\n        (deselectAll)=\"onDeselectAll()\"\n        (rowClick)=\"onRowClick($event)\"\n        (ulvCommand)=\"onUlvCommand($event)\"\n        (actionListClick)=\"onActionListClick(mo, index, $event)\"\n        (selectNextInlineRecord)=\"onSelectNextInlineRecord($event)\"\n        (editFormPanelSave)=\"onEditFormPanelSave($event)\"\n        (editFormPanelCancel)=\"onEditFormPanelCancel($event)\"\n        (editFormPanelValueChange)=\"onEditFormPanelValueChange($event)\"\n        (cartableFormClosed)=\"onCartableFormClosed($event)\"\n    >\n    </bsu-barsa-table-row>\n    <!-- <div\n        #rowBottom\n        intersectionObserver\n        [intersectionThreshold]=\"0.1\"\n        (visibilityChange)=\"onRowVisibilityChange($event, index, rowBottom)\"\n    ></div> -->\n</ng-template>\n<div #tableBottomObserve></div>\n"]}
283
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ui-table-view.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-sap-ui/src/lib/ui-table-view/ui-table-view.component.ts","../../../../../projects/barsa-sap-ui/src/lib/ui-table-view/ui-table-view.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    Component,\n    ElementRef,\n    HostBinding,\n    Input,\n    OnChanges,\n    OnInit,\n    signal,\n    SimpleChanges,\n    ViewChild\n} from '@angular/core';\nimport { Subject, takeUntil } from 'rxjs';\nimport {\n    MetaobjectDataModel,\n    ReportViewBaseComponent,\n    ReportViewColumn,\n    TableHeaderWidthMode,\n    ColumnResizedArgs,\n    calcContextMenuWidth,\n    calculateColumnWidth,\n    calculateColumnWidthFitToContainer,\n    calculateFreeColumnSize,\n    calculateColumnContent,\n    setColumnWidthByMaxMoContentWidth\n} from 'barsa-novin-ray-core';\nimport { UiTableViewSetting } from '../models/grid-view';\nimport { BarsaTableHeaderComponent } from '../barsa-table-header/barsa-table-header.component';\n\n@Component({\n    selector: 'bsu-ui-table-view',\n    templateUrl: './ui-table-view.component.html',\n    styleUrls: ['./ui-table-view.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class UiTableViewComponent\n    extends ReportViewBaseComponent<UiTableViewSetting>\n    implements OnInit, AfterViewInit, OnChanges\n{\n    @ViewChild('tableTpl', { static: true, read: ElementRef }) _tableRef: ElementRef;\n    @ViewChild(BarsaTableHeaderComponent) _tableHeaderComponent: BarsaTableHeaderComponent;\n    @Input() columnWidth: number;\n    @Input() minWidth;\n    @Input() minHeight;\n    @Input() disableResize;\n    @Input() disableHeaderContextMenu;\n    @Input() rowResizer;\n    @Input() enableResizing;\n    @Input() disableFixedTableLayout;\n    @HostBinding('style.height.px') height: number | null = null;\n    @HostBinding('style.max-height') maxHeight: string | null = null;\n    _width = '100%';\n    showDetailsInRow: boolean;\n    hasRowOlgo: boolean;\n    columnComponents: { column: ReportViewColumn; component: MetaobjectDataModel }[] = [];\n    rowIndicator: boolean;\n    tableHeaderMode = TableHeaderWidthMode.FitToContainer;\n    stickyEnable = signal(false);\n    rowVisibiltyChange = signal(false);\n    tableHeaderDom: HTMLElement;\n    _headerTop$ = new Subject<string>();\n    rowVisible$ = new Subject<{ index; dom }>();\n    _isParentWidthSet = false;\n    tableHeaderTop = 0;\n    tableHeaderHeight = 0;\n    headerObserverDom: HTMLElement;\n    notVisibleItems: number[] = [];\n    visibleItems: number[] = [];\n    oldWidth = 0;\n    ngOnInit(): void {\n        super.ngOnInit();\n\n        const x = Math.floor(this._el.nativeElement.parentNode.getBoundingClientRect().width);\n        if (x) {\n            this._renderer2.setStyle(this._el.nativeElement, 'width', `${x}px`);\n        }\n        this._portalService.windowResize$.pipe(takeUntil(this._onDestroy$)).subscribe(() => {\n            const x = Math.floor(this._el.nativeElement.parentNode.getBoundingClientRect().width);\n            this._renderer2.setStyle(this._tableRef.nativeElement, 'width', x + 'px');\n            this._renderer2.setStyle(this._tableRef.nativeElement, 'max-width', x + 'px');\n            this._refreshThWidth();\n        });\n        this.hasRowOlgo = this.viewSetting?.RowOlgo?.Selector;\n        this.maxHeight = this.viewSetting?.BodyHeight;\n        this._setHasSummery(this.cartableChildsMo);\n        this._setHeight(this.parentHeight);\n        this._setWidth();\n        this._calculateColumnsWidth(this.moDataList, this.columns);\n        this.tableHeaderMode = this.gridFreeColumnSizing\n            ? TableHeaderWidthMode.FreeColumnSize\n            : TableHeaderWidthMode.FitToContainer;\n        this._calcContextMenuWidth(this.contextMenuItems);\n    }\n\n    _calcContextMenuWidth(contextMenuItems): void {\n        this.contextMenuWidth = calcContextMenuWidth(contextMenuItems, this.disableOverflowContextMenu);\n    }\n    onTableVisibilityChange(e, dom): void {\n        if (e === 'Visible') {\n            this._setWidth(true);\n        }\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        const { cartableTemplates, parentHeight, contextMenuItems, columnsCount, columns, secondaryColumns } = changes;\n        if (contextMenuItems && !contextMenuItems.firstChange) {\n            this._calcContextMenuWidth(contextMenuItems.currentValue);\n            this._cdr.detectChanges();\n        }\n        if (cartableTemplates && !cartableTemplates.firstChange && !this.hasSummary) {\n            this._setHasSummery(cartableTemplates.currentValue);\n        }\n        if ((columnsCount && !columnsCount.firstChange) || (secondaryColumns && !secondaryColumns.firstChange)) {\n            this._calculateColumnsWidth(this.moDataList, columns.currentValue);\n        }\n        if (parentHeight && !parentHeight.firstChange) {\n            this._setHeight(parentHeight.currentValue);\n        }\n        super.ngOnChanges(changes);\n    }\n    onColumnResizing(e: { column: ReportViewColumn; width: number }): void {\n        this._tableHeaderComponent.SetColumnWidthToThWidth();\n        this._setParentWidth();\n    }\n    onColumnResized(arr: Array<ColumnResizedArgs>): void {\n        if (this.secondaryColumns.length) {\n            return;\n        }\n\n        if (this.tableHeaderMode === TableHeaderWidthMode.FreeColumnSize) {\n            this._tableHeaderComponent.SetColumnWidthToThWidth();\n        } else {\n            this._tableHeaderComponent.SetColumnWidthToPercent();\n        }\n        this._tableHeaderComponent.RefreshTableThWidth();\n        this.resizedByUser = true;\n\n        // this._renderer2.setStyle(lastTh, 'width', `100%`);\n        this.columnResized.emit({ columns: this.columns, resized: arr });\n    }\n    onFitToContainer(): void {\n        this.tableHeaderMode = TableHeaderWidthMode.FitToContainer;\n        this._setParentWidthFit();\n        this._tableHeaderComponent.SetColumnWidthToPercent();\n        // this._refreshThWidth();\n        // this._fireResizeChanged();\n    }\n    onFreeColumnSizing(): void {\n        this.tableHeaderMode = TableHeaderWidthMode.FreeColumnSize;\n        this._tableHeaderComponent.SetColumnWidthToThWidth();\n        this._setParentWidthFitToOffsetWidth();\n        this._calculateColumnsWidth(this.moDataList, this.columns);\n    }\n    onFitToContent(e: { column: ReportViewColumn; thDom: HTMLTableCellElement }): void {\n        const { column, thDom } = e;\n        this.tableHeaderMode = TableHeaderWidthMode.FreeColumnSize;\n        setColumnWidthByMaxMoContentWidth(this.moDataList, column);\n        column.$Width = column.$ContentWidth;\n        this._renderer2.setStyle(thDom, 'width', column.$Width);\n        this._fireResizeChanged();\n    }\n\n    onSetTableHeaderDom(dom): void {\n        this.tableHeaderDom = dom;\n        const rect = dom.getBoundingClientRect();\n        this.tableHeaderTop = rect.top;\n        this.tableHeaderHeight = rect.height;\n    }\n    onHeaderVisibilityChange(e, dom): void {\n        return;\n        this.headerObserverDom = dom;\n        if (e === 'NotVisible') {\n            this.stickyEnable.set(true);\n        } else {\n            this.stickyEnable.set(false);\n        }\n    }\n\n    onRowVisibilityChange(e, index, dom): void {\n        return;\n        if (e !== 'Pending') {\n            if (e === 'NotVisible') {\n                if (this.visibleItems.indexOf(index) !== -1) {\n                    this.rowVisible$.next({ index, dom });\n                    this.visibleItems = this.visibleItems.filter((c) => c !== index);\n                }\n                this.notVisibleItems.push(index);\n            }\n            if (e === 'Visible') {\n                this.notVisibleItems = this.notVisibleItems.filter((c) => c !== index);\n\n                this.visibleItems.push(index);\n            }\n            // this.rowVisible$.next({ index, dom });\n        }\n    }\n    private _setParentWidthFit(): void {\n        this._renderer2.setStyle(this._el.nativeElement.parentNode, 'width', `100%`);\n        this._renderer2.setStyle(this._tableRef.nativeElement, 'min-width', `100%`);\n        this._renderer2.setStyle(this._tableRef.nativeElement, 'width', `100%`);\n    }\n    private _setParentWidthFitToOffsetWidth(): void {\n        this._renderer2.setStyle(\n            this._el.nativeElement.parentNode,\n            'width',\n            `${this._el.nativeElement.parentNode.getBoundingClientRect().width}px`\n        );\n        this._renderer2.setStyle(this._tableRef.nativeElement, 'min-width', `${this._el.nativeElement.offsetWidth}px`);\n        this._renderer2.setStyle(this._tableRef.nativeElement, 'width', `${this._el.nativeElement.offsetWidth}px`);\n    }\n    private _setParentWidth(): void {\n        this._renderer2.setStyle(\n            this._el.nativeElement.parentNode,\n            'width',\n            `${this._el.nativeElement.parentNode.getBoundingClientRect().width}px`\n        );\n    }\n    private _refreshThWidth(): void {\n        this._calculateColumnsWidth(this.moDataList, this.columns);\n        this._tableHeaderComponent?.RefreshTableThWidth();\n    }\n    private _setWidth(setWidth?: boolean): void {\n        const widthOfDom = this._el.nativeElement.parentNode.getBoundingClientRect().width;\n        if (widthOfDom === 0) {\n            return;\n        }\n        if (widthOfDom !== this.oldWidth) {\n            this._refreshThWidth();\n        }\n        this.oldWidth = widthOfDom;\n        this._renderer2.setStyle(\n            this._tableRef.nativeElement,\n            'max-width',\n            this._el.nativeElement.parentNode.getBoundingClientRect().width + 'px'\n        );\n        this._renderer2.setStyle(this._tableRef.nativeElement, 'width', widthOfDom + 'px');\n    }\n    private _calculateHeaderStickyTop(dom: HTMLElement): void {\n        if (this.stickyEnable() && this.tableHeaderDom) {\n            // const rec = this.headerObserverDom.getBoundingClientRect();\n            // const top = rec.top;\n            // const calc = this.tableHeaderTop - top - this.tableHeaderHeight + 'px';\n            const rec = dom.getBoundingClientRect();\n\n            this._headerTop$.next(rec.top - 12 + this.tableHeaderHeight + 'px');\n        }\n    }\n\n    protected _fireResizeChanged(): void {\n        this.columnResized.emit({\n            columns: this.columns,\n            resized: this.columns.map((c) => ({ name: c.Name, width: c.Width }))\n        });\n    }\n    protected _calculateColumnsWidth(moDataList: MetaobjectDataModel[], columns: ReportViewColumn[]): void {\n        switch (this.tableHeaderMode) {\n            case TableHeaderWidthMode.FreeColumnSize:\n                this._freeColumnSize(moDataList, columns);\n                break;\n            case TableHeaderWidthMode.FitToRowContent:\n                this._fitToRowContentColumn(moDataList, columns);\n                break;\n            case TableHeaderWidthMode.FitToContainer:\n                this._fitToContainer(moDataList, columns);\n                break;\n        }\n    }\n    protected _fitToColumn(moDataList, columns): void {\n        const elDom = this._el.nativeElement as HTMLElement;\n        calculateColumnWidth(elDom, columns, moDataList, this.disableOverflowContextMenu, this.contextMenuItems);\n    }\n    protected _fitToRowContentColumn(moDataList: MetaobjectDataModel[], columns: ReportViewColumn[]): void {\n        calculateColumnContent(columns, moDataList);\n    }\n    protected _fitToContainer(moDataList, columns): void {\n        const elDom = this._el.nativeElement.parentElement as HTMLElement;\n        calculateColumnWidthFitToContainer(\n            elDom,\n            this.canView,\n            this.disableHeaderContextMenu,\n            this.contextMenuItems,\n            this.columns\n        );\n    }\n    protected _freeColumnSize(moDataList, columns): void {\n        calculateFreeColumnSize(this.columns);\n    }\n    protected _setHeight(parentHeight: number): void {\n        if (this.inDialog) {\n            this.height = parentHeight;\n        }\n    }\n    protected _setHasSummery(cartableTemplates): void {\n        if (\n            this.detailsColumns?.length > 0 ||\n            this.detailsComponent?.Selector ||\n            (cartableTemplates && Object.keys(cartableTemplates).length > 0)\n        ) {\n            this.showDetailsInRow = true;\n            this.hasDetailsInRow.emit(true);\n        } else {\n            this.hasDetailsInRow.emit(false);\n        }\n    }\n    protected _containerWidthChanged(val: number): void {\n        if (val === 0) {\n            this._width = '100%';\n        } else {\n            this._width = val ? val + 'px' : '100%';\n        }\n        this._renderer2.setStyle(this._el.nativeElement, 'width', this._width);\n    }\n}\n","<table\n    fd-table\n    #tableTpl\n    #headerBottomObserver\n    intersectionObserver\n    [intersectionThreshold]=\"0.1\"\n    (visibilityChange)=\"onTableVisibilityChange($event, headerBottomObserver)\"\n    [popIn]=\"popin\"\n    [class.table-fixed]=\"\n        !contextView?.Grid_HideHeader && (!popin || secondaryColumns.length === 0) && !disableFixedTableLayout\n    \"\n    [noBorderX]=\"viewSetting?.NoHoriztonalBorders === true\"\n    [noBorderY]=\"viewSetting?.NoVerticalBorders === true || (popin && secondaryColumns.length > 0)\"\n>\n    @if (columns | mergeFieldsToColumns: viewSetting?.MergeFieldsToColumns?.MoDataList; as mergeFieldsToColumns) {\n    <ng-container\n        *ngTemplateOutlet=\"\n            headerTemplate;\n            context: { $implicit: mergeFieldsToColumns, moDataListCount: moDataList?.length }\n        \"\n    ></ng-container>\n    @if (moDataList?.length) {\n    <ng-container\n        *ngTemplateOutlet=\"\n            bodyTemplate;\n            context: { $implicit: mergeFieldsToColumns, previewColumn: allColumns | findPreviewColumn }\n        \"\n    ></ng-container>\n    <ng-container *ngTemplateOutlet=\"footerTemplate; context: { $implicit: mergeFieldsToColumns }\"></ng-container>\n    } }\n</table>\n<!--renderColumn-->\n\n@if (!moDataList?.length) {\n<bsu-no-data\n    [class.no-topborder]=\"!hideToolbar\"\n    [class.noborder]=\"contextView.Grid_HideHeader && hideToolbar\"\n    [simple]=\"true\"\n>\n</bsu-no-data>\n}\n\n<ng-template #headerTemplate let-columns let-moDataListCount>\n    <bsu-barsa-table-header\n        [sticky]=\"stickyEnable()\"\n        [hasSecondaryColumns]=\"secondaryColumns.length > 0\"\n        [class.has-toolbar]=\"!hideToolbar\"\n        [style.pointer-events]=\"moDataListCount ? 'auto' : 'none'\"\n        [tableWidth]=\"elWidth\"\n        [showDetailsInRow]=\"showDetailsInRow\"\n        [hideOpenIcon]=\"hideOpenIcon\"\n        [resizedByUser]=\"resizedByUser\"\n        [tableHeaderMode]=\"tableHeaderMode\"\n        [showRowNumber]=\"contextView?.Grid_ShowRowNumber\"\n        [allChecked]=\"allChecked\"\n        [rtl]=\"rtl\"\n        [actionList]=\"actionList\"\n        [disableResponsive]=\"disableResponsive\"\n        [isCheckList]=\"isCheckList\"\n        [columns]=\"\n            columns\n                | filterColumnsByDetails: detailsColumns:rowIndicator\n                | filter: { IsPreview: false }\n                | hideColumnsInmobile: viewSetting?.HideColumnsInMobile\n        \"\n        [fitWidth]=\"fitWidth\"\n        [disableOverflowContextMenu]=\"disableOverflowContextMenu\"\n        [inlineEditMode]=\"inlineEditMode\"\n        [contextMenuItems]=\"contextMenuItems\"\n        [contextMenuWidth]=\"contextMenuWidth\"\n        [showViewButton]=\"showViewButton\"\n        [deviceSize]=\"deviceSize\"\n        [viewSetting]=\"viewSetting\"\n        [hideHeader]=\"contextView.Grid_HideHeader\"\n        [rowIndicator]=\"rowIndicator\"\n        [disableResize]=\"disableResize\"\n        [disableHeaderContextMenu]=\"disableHeaderContextMenu\"\n        (headerRender)=\"onSetTableHeaderDom($event)\"\n        (columnResize)=\"onColumnResized($event)\"\n        (columnResizing)=\"onColumnResizing($event)\"\n        (fitToContent)=\"onFitToContent($event)\"\n        (fitToContainer)=\"onFitToContainer()\"\n        (freeColumnSize)=\"onFreeColumnSizing()\"\n        (allCheckbox)=\"onAllCheckbox($event)\"\n        (sortAscending)=\"onSortAscending($event)\"\n        (sortDescending)=\"onSortDescending($event)\"\n        (filter)=\"onFilter($event)\"\n        (resetGridSettings)=\"resetGridSettings.emit()\"\n    ></bsu-barsa-table-header>\n    <!-- <div\n        #headerBottomObserver\n        intersectionObserver\n        [intersectionThreshold]=\"0.1\"\n        (visibilityChange)=\"onHeaderVisibilityChange($event, headerBottomObserver)\"\n    ></div> -->\n</ng-template>\n<ng-template #bodyTemplate let-columns let-previewColumn=\"previewColumn\">\n    <tbody\n        #body\n        fd-table-body\n        [class.noborder]=\"viewSetting?.NoBodyBorders === true\"\n        [noBorderX]=\"viewSetting?.NoHoriztonalBorders === true || previewColumn\"\n        [noBorderY]=\"(popin && secondaryColumns.length > 0) || previewColumn\"\n    >\n        <ng-container>\n            @for (mo of moDataList | multipleGroupBy: groupby; track _trackByRow(index, mo); let index = $index) {\n            <ng-container\n                *ngTemplateOutlet=\"\n                    hasRowOlgo ? rowOlgoTemplate : rowTemplate;\n                    context: {\n                        $implicit: mo,\n                        index: index,\n                        rowNumber: mo.Id | rowNumber: pagingSetting:moDataList,\n                        rowIndicatorColor: !columns.length ? '' : (columns[0].Caption | rval: mo:columns),\n                        columns: columns | columnCustomComponent: viewSetting?.ColumnComponents?.MoDataList,\n                        secondaryColumns:\n                            secondaryColumns | columnCustomComponent: viewSetting?.ColumnComponents?.MoDataList,\n                        moDataList: moDataList,\n                        moDataListCount: moDataList.length,\n                        cartableTemplate: cartableTemplates[mo.RelatedMo?.$TypeDefId + '@' + mo.CartableSettings?.Id],\n                        previewColumn: previewColumn,\n                        detailsCollapsed: viewSetting?.DetailsSetting?.DetailsCollapsed === true,\n                        hideDetailsText: viewSetting?.DetailsSetting?.HideDetailsText === true\n                    }\n                \"\n            ></ng-container>\n            }\n        </ng-container>\n    </tbody>\n</ng-template>\n<ng-template #footerTemplate let-columns>\n    @if (hasSummary) {\n    <tfoot fd-table-footer>\n        <tr fd-table-row class=\"row-summary\">\n            @if (isCheckList) {\n            <td fd-table-cell columnResizer>\n                <strong class=\"col-total-text\">{{ 'Total' | bbbTranslate }}</strong>\n            </td>\n            } @if (!isCheckList) {\n            <td fd-table-cell class=\"single-select\">\n                <strong class=\"col-total-text\">{{ 'Total' | bbbTranslate }}</strong>\n            </td>\n            } @for (column of columns; track column; let i = $index) {\n            <td>\n                @if (column.HasSummary) {\n                <strong style=\"direction: ltr; display: block\">\n                    {{ moDataList | totalSummary: column.Name | number }}</strong\n                >\n                }\n            </td>\n            } @if (contextMenuItems && contextMenuItems.length > 0) {\n            <td fd-table-cell style=\"width: 100px\"></td>\n            } @if (!hideOpenIcon && canView && (!inlineEditMode || !allowInlineEdit)) {\n            <td fd-table-cell></td>\n            }\n        </tr>\n    </tfoot>\n    }\n</ng-template>\n<ng-template\n    #rowOlgoTemplate\n    let-mo\n    let-index=\"index\"\n    let-columns=\"columns\"\n    let-moDataListCount=\"moDataListCount\"\n    let-moDataList=\"moDataList\"\n    let-cartableTemplate=\"cartableTemplate\"\n    let-secondaryColumns=\"secondaryColumns\"\n    let-rowIndicatorColor=\"rowIndicatorColor\"\n    let-rowNumber=\"rowNumber\"\n    let-previewColumn=\"previewColumn\"\n    let-detailsCollapsed=\"detailsCollapsed\"\n    let-hideDetailsText=\"hideDetailsText\"\n>\n    <bnrc-dynamic-item-component\n        [component]=\"viewSetting.RowOlgo\"\n        [mo]=\"mo\"\n        [detailsCollapsed]=\"detailsCollapsed\"\n        [hideDetailsText]=\"hideDetailsText\"\n        [isLastChildGroup]=\"mo.$IsLastChildGroup\"\n        [groupSummary]=\"groupSummary\"\n        [showViewButton]=\"showViewButton\"\n        [UlvMainCtrlr]=\"UlvMainCtrlr\"\n        [moDataList]=\"moDataList\"\n        [showDetailsInRow]=\"showDetailsInRow\"\n        [hideOpenIcon]=\"hideOpenIcon\"\n        [detailsColumns]=\"detailsColumns\"\n        [showRowNumber]=\"contextView?.Grid_ShowRowNumber\"\n        [rowNumber]=\"rowNumber\"\n        [columnComponents]=\"viewSetting?.ColumnComponents || null\"\n        [cartableTemplate]=\"cartableTemplate\"\n        [cartableMo]=\"mo.RelatedMo\"\n        [dirtyColumns]=\"mo.$DirtyColumns\"\n        [cartableWorkflowData]=\"mo.SerializedWorkflowData\"\n        [serializedRelatedMo]=\"mo.SerializedRelatedMo\"\n        [detailsText]=\"viewSetting?.DetailsSetting?.ButtonText\"\n        [detailsTextFunction]=\"viewSetting?.DetailsSetting?.ButtonTextFunction\"\n        [detailsComponent]=\"detailsComponent\"\n        [coloringRow]=\"viewSetting?.ColoringRow\"\n        [isChecked]=\"mo.$IsChecked\"\n        [visibility]=\"mo.$Visibility\"\n        [expanded]=\"mo.$Expanded\"\n        [styleIndex]=\"mo.$StyleIndex\"\n        [level]=\"mo.$Level\"\n        [parentExpanded]=\"mo.$Parent?.$Expanded\"\n        [moDataListCount]=\"moDataListCount\"\n        [columnsCount]=\"columnsCount - detailsColumns.length\"\n        [typeDefId]=\"typeDefId\"\n        [extraRelation]=\"extraRelation\"\n        [formSetting]=\"formSetting\"\n        [index]=\"index\"\n        [setting]=\"viewSetting\"\n        [secondaryColumns]=\"secondaryColumns | filterColumnsByDetails: detailsColumns:rowIndicator\"\n        [columns]=\"columns | filterColumnsByDetails: detailsColumns:rowIndicator\"\n        [isNewInlineMo]=\"mo.$NewInlineMo\"\n        [access]=\"access\"\n        [inlineEditMode]=\"inlineEditMode\"\n        [allowInlineEdit]=\"allowInlineEdit\"\n        [rtl]=\"rtl\"\n        [deviceName]=\"deviceName\"\n        [deviceSize]=\"deviceSize\"\n        [allColumns]=\"allColumns\"\n        [contextMenuItems]=\"contextMenuItems\"\n        [canView]=\"canView\"\n        [conditionalFormats]=\"conditionalFormats\"\n        [disableOverflowContextMenu]=\"disableOverflowContextMenu\"\n        [navigationArrow]=\"navigationArrow\"\n        [isCheckList]=\"isCheckList\"\n        [rowIndicator]=\"rowIndicator\"\n        [rowIndicatorColor]=\"rowIndicatorColor\"\n        (events)=\"onOlgoEvents($event)\"\n    >\n    </bnrc-dynamic-item-component>\n</ng-template>\n<ng-template\n    #rowTemplate\n    let-mo\n    let-index=\"index\"\n    let-rowNumber=\"rowNumber\"\n    let-columns=\"columns\"\n    let-moDataListCount=\"moDataListCount\"\n    let-moDataList=\"moDataList\"\n    let-cartableTemplate=\"cartableTemplate\"\n    let-secondaryColumns=\"secondaryColumns\"\n    let-rowIndicatorColor=\"rowIndicatorColor\"\n    let-previewColumn=\"previewColumn\"\n    let-detailsCollapsed=\"detailsCollapsed\"\n    let-hideDetailsText=\"hideDetailsText\"\n>\n    <bsu-barsa-table-row\n        [mo]=\"mo\"\n        [dirtyColumns]=\"mo.$DirtyColumns\"\n        [isLastChildGroup]=\"mo.$IsLastChildGroup\"\n        [moDataList]=\"moDataList\"\n        [hideDetailsText]=\"hideDetailsText\"\n        [detailsCollapsed]=\"detailsCollapsed\"\n        [groupSummary]=\"groupSummary\"\n        [UlvMainCtrlr]=\"UlvMainCtrlr\"\n        [showDetailsInRow]=\"showDetailsInRow\"\n        [hideOpenIcon]=\"hideOpenIcon\"\n        [showRowNumber]=\"contextView?.Grid_ShowRowNumber\"\n        [rowNumber]=\"rowNumber\"\n        [coloringRow]=\"viewSetting?.ColoringRow\"\n        [disableEllapsis]=\"viewSetting?.DisableEllapsis\"\n        [showViewButton]=\"showViewButton\"\n        [detailsColumns]=\"detailsColumns\"\n        [columnComponents]=\"viewSetting?.ColumnComponents || null\"\n        [cartableTemplate]=\"cartableTemplate\"\n        [cartableMo]=\"mo.RelatedMo\"\n        [cartableWorkflowData]=\"mo.SerializedWorkflowData\"\n        [serializedRelatedMo]=\"mo.SerializedRelatedMo\"\n        [detailsText]=\"viewSetting?.DetailsSetting?.ButtonText\"\n        [detailsComponent]=\"detailsComponent\"\n        [isChecked]=\"mo.$IsChecked\"\n        [visibility]=\"mo.$Visibility\"\n        [expanded]=\"mo.$Expanded\"\n        [styleIndex]=\"mo.$StyleIndex\"\n        [level]=\"mo.$Level\"\n        [parentExpanded]=\"mo.$Parent?.$Expanded\"\n        [moDataListCount]=\"moDataListCount\"\n        [columnsCount]=\"columnsCount - detailsColumns.length\"\n        [typeDefId]=\"typeDefId\"\n        [extraRelation]=\"extraRelation\"\n        [formSetting]=\"formSetting\"\n        [index]=\"index\"\n        [setting]=\"viewSetting\"\n        [checkboxComponent]=\"viewSetting?.CheckboxComponent\"\n        [secondaryColumns]=\"\n            secondaryColumns\n                | filterColumnsByDetails: detailsColumns:false\n                | filter: { IsPreview: false }\n                | hideColumnsInmobile: viewSetting?.HideColumnsInMobile\n        \"\n        [columns]=\"\n            columns\n                | filterColumnsByDetails: detailsColumns:rowIndicator\n                | filter: { IsPreview: false }\n                | hideColumnsInmobile: viewSetting?.HideColumnsInMobile\n        \"\n        [isNewInlineMo]=\"mo.$NewInlineMo\"\n        [access]=\"access\"\n        [simpleInlineEdit]=\"simpleInlineEdit\"\n        [noSaveInlineEditInServer]=\"simpleInlineEdit\"\n        [actionList]=\"actionList\"\n        [inlineEditMode]=\"inlineEditMode\"\n        [allowInlineEdit]=\"allowInlineEdit\"\n        [rtl]=\"rtl\"\n        [deviceName]=\"deviceName\"\n        [deviceSize]=\"deviceSize\"\n        [allColumns]=\"allColumns\"\n        [contextMenuItems]=\"contextMenuItems\"\n        [canView]=\"canView\"\n        [conditionalFormats]=\"conditionalFormats\"\n        [disableOverflowContextMenu]=\"disableOverflowContextMenu\"\n        [navigationArrow]=\"navigationArrow\"\n        [isCheckList]=\"isCheckList\"\n        [rowIndicator]=\"rowIndicator\"\n        [rowIndicatorColor]=\"rowIndicatorColor\"\n        [previewColumn]=\"previewColumn\"\n        (columnSummary)=\"columnSummary.emit($event)\"\n        (resetWorkflowState)=\"resetWorkflowState.emit(mo)\"\n        (escapeKey)=\"onEscapeKey($event)\"\n        (expandClick)=\"onExpandClick($event)\"\n        (rowCheck)=\"onRowCheck($event)\"\n        (workflowShareButtons)=\"onWorkflowShareButtons($event)\"\n        (deselectAll)=\"onDeselectAll()\"\n        (rowClick)=\"onRowClick($event)\"\n        (ulvCommand)=\"onUlvCommand($event)\"\n        (actionListClick)=\"onActionListClick(mo, index, $event)\"\n        (selectNextInlineRecord)=\"onSelectNextInlineRecord($event)\"\n        (editFormPanelSave)=\"onEditFormPanelSave($event)\"\n        (editFormPanelCancel)=\"onEditFormPanelCancel($event)\"\n        (editFormPanelValueChange)=\"onEditFormPanelValueChange($event)\"\n        (cartableFormClosed)=\"onCartableFormClosed($event)\"\n    >\n    </bsu-barsa-table-row>\n    <!-- <div\n        #rowBottom\n        intersectionObserver\n        [intersectionThreshold]=\"0.1\"\n        (visibilityChange)=\"onRowVisibilityChange($event, index, rowBottom)\"\n    ></div> -->\n</ng-template>\n<div #tableBottomObserve></div>\n"]}
@@ -4,15 +4,15 @@ import { map } from 'rxjs/operators';
4
4
  import { ReportTreeBaseComponent } from '../report-tree-base';
5
5
  import * as i0 from "@angular/core";
6
6
  import * as i1 from "@angular/common";
7
- import * as i2 from "@fundamental-ngx/core/bar";
8
- import * as i3 from "@fundamental-ngx/core/button";
9
- import * as i4 from "@fundamental-ngx/core/dialog";
10
- import * as i5 from "@fundamental-ngx/cdk/utils";
11
- import * as i6 from "@fundamental-ngx/core/title";
12
- import * as i7 from "@fundamental-ngx/core/toolbar";
13
- import * as i8 from "../ulv-toolbar/ulv-toolbar.component";
14
- import * as i9 from "../ui-tree-view/ui-tree-view.component";
15
- import * as i10 from "barsa-novin-ray-core";
7
+ import * as i2 from "barsa-novin-ray-core";
8
+ import * as i3 from "@fundamental-ngx/core/bar";
9
+ import * as i4 from "@fundamental-ngx/core/button";
10
+ import * as i5 from "@fundamental-ngx/core/dialog";
11
+ import * as i6 from "@fundamental-ngx/cdk/utils";
12
+ import * as i7 from "@fundamental-ngx/core/title";
13
+ import * as i8 from "@fundamental-ngx/core/toolbar";
14
+ import * as i9 from "../ulv-toolbar/ulv-toolbar.component";
15
+ import * as i10 from "../ui-tree-view/ui-tree-view.component";
16
16
  export class UiTreeComponent extends ReportTreeBaseComponent {
17
17
  constructor() {
18
18
  super(...arguments);
@@ -103,12 +103,12 @@ export class UiTreeComponent extends ReportTreeBaseComponent {
103
103
  this.loadChildren(node);
104
104
  }
105
105
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: UiTreeComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
106
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.5", type: UiTreeComponent, selector: "bsu-ui-tree", inputs: { showOkCancelButtons: "showOkCancelButtons" }, usesInheritance: true, ngImport: i0, template: "<ng-container\r\n *ngTemplateOutlet=\"\r\n renderTree;\r\n context: {\r\n $implicit: root$ | async,\r\n moDataList: flatMoDataList,\r\n isCheckList: context.Setting.View?.IsCheckList,\r\n columns: visibleColumns$ | async,\r\n groupby: groupby$ | async,\r\n toolbarButtons: (toolbarButtons$ | async)!! | seperatorFix,\r\n contextMenuItems: menuItems$ | async | contextMenu: context.Setting.View?.IsCheckList,\r\n conditionalFormats: context.Setting.View?.ConditionalFormats,\r\n deviceName: deviceName$ | async,\r\n deviceSize: deviceSize$ | async,\r\n access: context.Setting.Extra?.DefaultCommandsAccess,\r\n title: title$ | async,\r\n inlineEditMode: inlineEditMode$ | async,\r\n allowInlineEdit: allowInlineEdit$ | async,\r\n hideToolbar: hideToolbar$ | async,\r\n gridSetting: gridSetting$ | async,\r\n contentDensity: contentDensity$ | async,\r\n hasSelected: hasSelected$ | async,\r\n showOkCancelButtons: showOkCancelButtons,\r\n hideOpenIcon: viewSetting?.HideOpenIcon,\r\n openOnClick: viewSetting?.OpenOnClick,\r\n onlyExecuteLeafNode: viewSetting?.OnlyExecuteLeafNode,\r\n enableNodeReordering: viewSetting?.EnableNodeReordering,\r\n viewSettingsContentDensity: viewSetting?.ContentDensity$Caption,\r\n iconField: viewSetting?.IconField,\r\n hideIcon: viewSetting?.HideIcon,\r\n colorField: viewSetting?.ColorField,\r\n hasInlineEditButton: viewSetting?.HasInlineEditButton,\r\n hasInlineDeleteButton: viewSetting?.HasInlineDeleteButton,\r\n selectedNode: selectedNode$ | async,\r\n navigationArrow: navigationArrow$ | async,\r\n collapseIcon: collapseIcon$ | async,\r\n relationList: context.Setting.View.RelationList,\r\n allColumns: allColumns,\r\n rtl: rtl$ | async,\r\n inDialog: inDialog$ | async,\r\n isMultiSelect: isMultiSelect$ | async,\r\n disableOverflowContextMenu: viewSetting?.DisableOverflowContextMenu,\r\n isHetro: context.Setting.ClassNames.DataClass === 'Ul.HetroTreeUlvDataCtrlr',\r\n selectedMo: selectedMo$ | async\r\n }\r\n \"\r\n></ng-container>\r\n\r\n<ng-template\r\n #renderTree\r\n let-root\r\n let-moDataList=\"moDataList\"\r\n let-deviceName=\"deviceName\"\r\n let-deviceSize=\"deviceSize\"\r\n let-toolbarButtons=\"toolbarButtons\"\r\n let-title=\"title\"\r\n let-inlineEditMode=\"inlineEditMode\"\r\n let-allowInlineEdit=\"allowInlineEdit\"\r\n let-hideToolbar=\"hideToolbar\"\r\n let-gridSetting=\"gridSetting\"\r\n let-contentDensity=\"contentDensity\"\r\n let-access=\"access\"\r\n let-contextMenuItems=\"contextMenuItems\"\r\n let-conditionalFormats=\"conditionalFormats\"\r\n let-isCheckList=\"isCheckList\"\r\n let-groupby=\"groupby\"\r\n let-hasSelected=\"hasSelected\"\r\n let-showOkCancelButtons=\"showOkCancelButtons\"\r\n let-selectedNode=\"selectedNode\"\r\n let-navigationArrow=\"navigationArrow\"\r\n let-collapseIcon=\"collapseIcon\"\r\n let-rtl=\"rtl\"\r\n let-disableOverflowContextMenu=\"disableOverflowContextMenu\"\r\n let-relationList=\"relationList\"\r\n let-isHetro=\"isHetro\"\r\n let-inDialog=\"inDialog\"\r\n let-isMultiSelect=\"isMultiSelect\"\r\n let-selectedMo=\"selectedMo\"\r\n let-hideOpenIcon=\"hideOpenIcon\"\r\n let-openOnClick=\"openOnClick\"\r\n let-enableNodeReordering=\"enableNodeReordering\"\r\n let-onlyExecuteLeafNode=\"onlyExecuteLeafNode\"\r\n let-iconField=\"iconField\"\r\n let-colorField=\"colorField\"\r\n let-allColumns=\"allColumns\"\r\n let-hideIcon=\"hideIcon\"\r\n let-viewSettingsContentDensity=\"viewSettingsContentDensity\"\r\n let-hasInlineDeleteButton=\"hasInlineDeleteButton\"\r\n let-hasInlineEditButton=\"hasInlineEditButton\"\r\n>\r\n <bsu-ulv-toolbar\r\n [hideToolbar]=\"hideToolbar\"\r\n [deviceName]=\"deviceName\"\r\n [deviceSize]=\"deviceSize\"\r\n [toolbarButtons]=\"toolbarButtons\"\r\n [gridSetting]=\"gridSetting\"\r\n [title]=\"title\"\r\n [hasSelected]=\"hasSelected\"\r\n [inDialog]=\"inDialog\"\r\n [isMultiSelect]=\"isMultiSelect\"\r\n [contentDensity]=\"contentDensity\"\r\n [inlineEditMode]=\"inlineEditMode\"\r\n [allowInlineEdit]=\"allowInlineEdit\"\r\n [moDataListCount]=\"moDataList.length\"\r\n (sortClick)=\"onSortSettings(deviceName)\"\r\n (groupbyClick)=\"onGroupbySettings(deviceName)\"\r\n (columnClick)=\"onColumnSettings(deviceName)\"\r\n (editModeClick)=\"onEditMode()\"\r\n >\r\n <button\r\n fd-button\r\n fd-toolbar-item\r\n [fdType]=\"'transparent'\"\r\n [glyph]=\"'collapse-all'\"\r\n (click)=\"onCollapseAll()\"\r\n ></button>\r\n @if (!showOkCancelButtons && enableNodeReordering) {\r\n <button\r\n fd-button\r\n fd-toolbar-item\r\n [fdType]=\"'transparent'\"\r\n [glyph]=\"'move'\"\r\n (click)=\"onOpenMoveToDialog(selectedNode, deviceName, moveDialog)\"\r\n ></button>\r\n }\r\n </bsu-ulv-toolbar>\r\n <bsu-ui-tree-view\r\n [leafCursorPointer]=\"onlyExecuteLeafNode && openOnClick\"\r\n [rtl]=\"rtl\"\r\n [hasInlineDeleteButton]=\"hasInlineDeleteButton\"\r\n [hasInlineEditButton]=\"hasInlineEditButton\"\r\n [relationList]=\"relationList\"\r\n [toolbarButtons]=\"toolbarButtons\"\r\n [root]=\"root\"\r\n [allColumns]=\"allColumns\"\r\n [hideIcon]=\"hideIcon\"\r\n [selectedMo]=\"selectedMo\"\r\n [hideOpenIcon]=\"hideOpenIcon\"\r\n [disableOverflowContextMenu]=\"disableOverflowContextMenu\"\r\n [iconField]=\"iconField\"\r\n [colorField]=\"colorField\"\r\n [navigationArrow]=\"navigationArrow\"\r\n [collapseIcon]=\"collapseIcon\"\r\n [selectedNode]=\"selectedNode\"\r\n [access]=\"access\"\r\n [viewSettingsContentDensity]=\"viewSettingsContentDensity\"\r\n [deviceName]=\"deviceName\"\r\n [deviceSize]=\"deviceSize\"\r\n [enableNodeReordering]=\"enableNodeReordering\"\r\n [inDialog]=\"inDialog\"\r\n [isMultiSelect]=\"isMultiSelect\"\r\n [openOnClick]=\"openOnClick\"\r\n [contextMenuItems]=\"contextMenuItems\"\r\n [moDataList]=\"moDataList\"\r\n [groupby]=\"groupby\"\r\n [isHetro]=\"isHetro\"\r\n [isCheckList]=\"isCheckList\"\r\n [conditionalFormats]=\"conditionalFormats\"\r\n [showOkCancelButtons]=\"showOkCancelButtons\"\r\n (checkChange)=\"onCheckChange($event)\"\r\n (itemDrop)=\"onDrop($event)\"\r\n (itemDragMoved)=\"onDragMoved($event)\"\r\n (nodeUlvCommand)=\"onNodeUlvCommand($event)\"\r\n (nodeViewClick)=\"onNodeViewClick($event)\"\r\n (loadChildren)=\"onLoadChildren($event)\"\r\n (nodeSelect)=\"onNodeSelect($event)\"\r\n (rowCheck)=\"onRowCheck($event)\"\r\n (rowClick)=\"onRowClick($event)\"\r\n (allCheckbox)=\"onAllCheckbox($event)\"\r\n (expandClick)=\"onExpandClick($event)\"\r\n (editFormPanelCancel)=\"onEditFormPanelCancel($event)\"\r\n (editFormPanelSave)=\"onEditFormPanelSave($event)\"\r\n (createNew)=\"onCreateNew($event)\"\r\n >\r\n </bsu-ui-tree-view>\r\n <ng-template let-dialog let-dialogConfig=\"dialogConfig\" #moveDialog>\r\n <fd-dialog [dialogConfig]=\"dialogConfig\" [dialogRef]=\"dialog\">\r\n <fd-dialog-header>\r\n <h1 fd-title>{{ 'Move' | bbbTranslate }}</h1>\r\n <button fd-dialog-close-button (click)=\"dialog.dismiss('Close button')\"></button>\r\n </fd-dialog-header>\r\n\r\n <fd-dialog-body>\r\n <div class=\"move-to\" (keydown.enter)=\"onConfirmDialog(dialogSelectedNode)\">\r\n <bsu-ui-tree-view\r\n [rtl]=\"rtl\"\r\n [root]=\"root\"\r\n [access]=\"access\"\r\n [navigationArrow]=\"navigationArrow\"\r\n [collapseIcon]=\"collapseIcon\"\r\n [deviceName]=\"deviceName\"\r\n [deviceSize]=\"deviceSize\"\r\n [viewSettingsContentDensity]=\"viewSettingsContentDensity\"\r\n [enableNodeReordering]=\"enableNodeReordering\"\r\n [openOnClick]=\"openOnClick\"\r\n [selectedNode]=\"dialogSelectedNode\"\r\n [moDataList]=\"flatMoDataList\"\r\n [groupby]=\"groupby\"\r\n [isCheckList]=\"isCheckList\"\r\n [conditionalFormats]=\"conditionalFormats\"\r\n (loadChildren)=\"onLoadChildren($event)\"\r\n (nodeSelect)=\"onSelectNodeInMoveDialog($event)\"\r\n ></bsu-ui-tree-view>\r\n </div>\r\n </fd-dialog-body>\r\n\r\n <fd-dialog-footer>\r\n <ng-template fdkTemplate=\"footer\">\r\n <div fd-bar-right>\r\n <fd-button-bar\r\n fdType=\"emphasized\"\r\n [label]=\"'OK' | bbbTranslate\"\r\n (click)=\"onConfirmDialog(dialogSelectedNode)\"\r\n >\r\n </fd-button-bar>\r\n <fd-button-bar fd-initial-focus [label]=\"'Cancel' | bbbTranslate\" (click)=\"onDismissDialog()\">\r\n </fd-button-bar>\r\n </div>\r\n </ng-template>\r\n </fd-dialog-footer>\r\n </fd-dialog>\r\n </ng-template>\r\n</ng-template>\r\n", styles: [":host{width:100%;box-sizing:border-box;display:inline-block}\n"], dependencies: [{ kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.BarRightDirective, selector: "[fd-bar-right]" }, { kind: "component", type: i2.ButtonBarComponent, selector: "fd-button-bar", inputs: ["fullWidth", "fdType", "title", "ariaLabelledby", "id"] }, { kind: "component", type: i3.ButtonComponent, selector: "button[fd-button], a[fd-button], span[fd-button]", inputs: ["class"], exportAs: ["fd-button"] }, { kind: "component", type: i4.DialogComponent, selector: "fd-dialog", inputs: ["class", "dialogRef", "dialogConfig"] }, { kind: "component", type: i4.DialogBodyComponent, selector: "fd-dialog-body" }, { kind: "component", type: i4.DialogFooterComponent, selector: "fd-dialog-footer" }, { kind: "component", type: i4.DialogHeaderComponent, selector: "fd-dialog-header" }, { kind: "component", type: i4.DialogCloseButtonComponent, selector: "[fd-dialog-close-button]", inputs: ["mobile", "title", "ariaLabel"] }, { kind: "directive", type: i5.TemplateDirective, selector: "[fdkTemplate]", inputs: ["fdkTemplate"] }, { kind: "component", type: i6.TitleComponent, selector: "[fd-title], [fdTitle]", inputs: ["headerSize", "wrap"], exportAs: ["fd-title"] }, { kind: "directive", type: i7.ToolbarItemDirective, selector: "[fd-toolbar-item], [fdOverflowGroup], [fdOverflowPriority]", inputs: ["fdOverflowPriority", "fdOverflowGroup"] }, { kind: "component", type: i8.UlvToolbarComponent, selector: "bsu-ulv-toolbar", inputs: ["allowGridColumnSort", "useLayoutItemTextForControl", "enableSearch", "hideTitle", "title", "icon", "deviceName", "deviceSize", "access", "hideToolbar", "toolbarButtons", "contentDensity", "inlineEditMode", "allowInlineEdit", "gridSetting", "viewCollection", "reportView", "inDialog", "isMultiSelect", "cls", "hasSelected", "config", "hidden", "buttons", "moDataListCount"], outputs: ["search", "groupbyClick", "sortClick", "columnClick", "editModeClick", "viewClick", "createNewInlineMo"] }, { kind: "component", type: i9.UiTreeViewComponent, selector: "bsu-ui-tree-view", inputs: ["root", "selectedNode", "isHetro", "leafCursorPointer", "relationList", "showOkCancelButtons", "enableNodeReordering", "collapseIcon", "iconField", "colorField", "viewSettingsContentDensity"], outputs: ["checkChange", "nodeSelect", "createNew", "loadChildren", "nodeViewClick", "nodeUlvCommand", "itemDrop", "itemDragMoved"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i10.SeperatorFixPipe, name: "seperatorFix" }, { kind: "pipe", type: i10.ContextMenuPipe, name: "contextMenu" }, { kind: "pipe", type: i10.BbbTranslatePipe, name: "bbbTranslate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
106
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.5", type: UiTreeComponent, selector: "bsu-ui-tree", inputs: { showOkCancelButtons: "showOkCancelButtons" }, usesInheritance: true, ngImport: i0, template: "<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 hasInlineEditButton: viewSetting?.HasInlineEditButton,\n hasInlineDeleteButton: viewSetting?.HasInlineDeleteButton,\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 let-hasInlineDeleteButton=\"hasInlineDeleteButton\"\n let-hasInlineEditButton=\"hasInlineEditButton\"\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 *untilInView=\"el\"\n [leafCursorPointer]=\"onlyExecuteLeafNode && openOnClick\"\n [rtl]=\"rtl\"\n [hasInlineDeleteButton]=\"hasInlineDeleteButton\"\n [hasInlineEditButton]=\"hasInlineEditButton\"\n [relationList]=\"relationList\"\n [toolbarButtons]=\"toolbarButtons\"\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", styles: [":host{width:100%;box-sizing:border-box;display:inline-block}\n"], dependencies: [{ kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.UntilInViewDirective, selector: "[untilInView]", inputs: ["untilInView", "intersectionDebounce"] }, { kind: "directive", type: i3.BarRightDirective, selector: "[fd-bar-right]" }, { kind: "component", type: i3.ButtonBarComponent, selector: "fd-button-bar", inputs: ["fullWidth", "fdType", "title", "ariaLabelledby", "id"] }, { kind: "component", type: i4.ButtonComponent, selector: "button[fd-button], a[fd-button], span[fd-button]", inputs: ["class"], exportAs: ["fd-button"] }, { kind: "component", type: i5.DialogComponent, selector: "fd-dialog", inputs: ["class", "dialogRef", "dialogConfig"] }, { kind: "component", type: i5.DialogBodyComponent, selector: "fd-dialog-body" }, { kind: "component", type: i5.DialogFooterComponent, selector: "fd-dialog-footer" }, { kind: "component", type: i5.DialogHeaderComponent, selector: "fd-dialog-header" }, { kind: "component", type: i5.DialogCloseButtonComponent, selector: "[fd-dialog-close-button]", inputs: ["mobile", "title", "ariaLabel"] }, { kind: "directive", type: i6.TemplateDirective, selector: "[fdkTemplate]", inputs: ["fdkTemplate"] }, { kind: "component", type: i7.TitleComponent, selector: "[fd-title], [fdTitle]", inputs: ["headerSize", "wrap"], exportAs: ["fd-title"] }, { kind: "directive", type: i8.ToolbarItemDirective, selector: "[fd-toolbar-item], [fdOverflowGroup], [fdOverflowPriority]", inputs: ["fdOverflowPriority", "fdOverflowGroup"] }, { kind: "component", type: i9.UlvToolbarComponent, selector: "bsu-ulv-toolbar", inputs: ["allowGridColumnSort", "useLayoutItemTextForControl", "enableSearch", "hideTitle", "title", "icon", "deviceName", "deviceSize", "access", "hideToolbar", "toolbarButtons", "contentDensity", "inlineEditMode", "allowInlineEdit", "gridSetting", "viewCollection", "reportView", "inDialog", "isMultiSelect", "cls", "hasSelected", "config", "hidden", "buttons", "moDataListCount"], outputs: ["search", "groupbyClick", "sortClick", "columnClick", "editModeClick", "viewClick", "createNewInlineMo"] }, { kind: "component", type: i10.UiTreeViewComponent, selector: "bsu-ui-tree-view", inputs: ["root", "selectedNode", "isHetro", "leafCursorPointer", "relationList", "showOkCancelButtons", "enableNodeReordering", "collapseIcon", "iconField", "colorField", "viewSettingsContentDensity"], outputs: ["checkChange", "nodeSelect", "createNew", "loadChildren", "nodeViewClick", "nodeUlvCommand", "itemDrop", "itemDragMoved"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i2.SeperatorFixPipe, name: "seperatorFix" }, { kind: "pipe", type: i2.ContextMenuPipe, name: "contextMenu" }, { kind: "pipe", type: i2.BbbTranslatePipe, name: "bbbTranslate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
107
107
  }
108
108
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: UiTreeComponent, decorators: [{
109
109
  type: Component,
110
- args: [{ selector: 'bsu-ui-tree', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container\r\n *ngTemplateOutlet=\"\r\n renderTree;\r\n context: {\r\n $implicit: root$ | async,\r\n moDataList: flatMoDataList,\r\n isCheckList: context.Setting.View?.IsCheckList,\r\n columns: visibleColumns$ | async,\r\n groupby: groupby$ | async,\r\n toolbarButtons: (toolbarButtons$ | async)!! | seperatorFix,\r\n contextMenuItems: menuItems$ | async | contextMenu: context.Setting.View?.IsCheckList,\r\n conditionalFormats: context.Setting.View?.ConditionalFormats,\r\n deviceName: deviceName$ | async,\r\n deviceSize: deviceSize$ | async,\r\n access: context.Setting.Extra?.DefaultCommandsAccess,\r\n title: title$ | async,\r\n inlineEditMode: inlineEditMode$ | async,\r\n allowInlineEdit: allowInlineEdit$ | async,\r\n hideToolbar: hideToolbar$ | async,\r\n gridSetting: gridSetting$ | async,\r\n contentDensity: contentDensity$ | async,\r\n hasSelected: hasSelected$ | async,\r\n showOkCancelButtons: showOkCancelButtons,\r\n hideOpenIcon: viewSetting?.HideOpenIcon,\r\n openOnClick: viewSetting?.OpenOnClick,\r\n onlyExecuteLeafNode: viewSetting?.OnlyExecuteLeafNode,\r\n enableNodeReordering: viewSetting?.EnableNodeReordering,\r\n viewSettingsContentDensity: viewSetting?.ContentDensity$Caption,\r\n iconField: viewSetting?.IconField,\r\n hideIcon: viewSetting?.HideIcon,\r\n colorField: viewSetting?.ColorField,\r\n hasInlineEditButton: viewSetting?.HasInlineEditButton,\r\n hasInlineDeleteButton: viewSetting?.HasInlineDeleteButton,\r\n selectedNode: selectedNode$ | async,\r\n navigationArrow: navigationArrow$ | async,\r\n collapseIcon: collapseIcon$ | async,\r\n relationList: context.Setting.View.RelationList,\r\n allColumns: allColumns,\r\n rtl: rtl$ | async,\r\n inDialog: inDialog$ | async,\r\n isMultiSelect: isMultiSelect$ | async,\r\n disableOverflowContextMenu: viewSetting?.DisableOverflowContextMenu,\r\n isHetro: context.Setting.ClassNames.DataClass === 'Ul.HetroTreeUlvDataCtrlr',\r\n selectedMo: selectedMo$ | async\r\n }\r\n \"\r\n></ng-container>\r\n\r\n<ng-template\r\n #renderTree\r\n let-root\r\n let-moDataList=\"moDataList\"\r\n let-deviceName=\"deviceName\"\r\n let-deviceSize=\"deviceSize\"\r\n let-toolbarButtons=\"toolbarButtons\"\r\n let-title=\"title\"\r\n let-inlineEditMode=\"inlineEditMode\"\r\n let-allowInlineEdit=\"allowInlineEdit\"\r\n let-hideToolbar=\"hideToolbar\"\r\n let-gridSetting=\"gridSetting\"\r\n let-contentDensity=\"contentDensity\"\r\n let-access=\"access\"\r\n let-contextMenuItems=\"contextMenuItems\"\r\n let-conditionalFormats=\"conditionalFormats\"\r\n let-isCheckList=\"isCheckList\"\r\n let-groupby=\"groupby\"\r\n let-hasSelected=\"hasSelected\"\r\n let-showOkCancelButtons=\"showOkCancelButtons\"\r\n let-selectedNode=\"selectedNode\"\r\n let-navigationArrow=\"navigationArrow\"\r\n let-collapseIcon=\"collapseIcon\"\r\n let-rtl=\"rtl\"\r\n let-disableOverflowContextMenu=\"disableOverflowContextMenu\"\r\n let-relationList=\"relationList\"\r\n let-isHetro=\"isHetro\"\r\n let-inDialog=\"inDialog\"\r\n let-isMultiSelect=\"isMultiSelect\"\r\n let-selectedMo=\"selectedMo\"\r\n let-hideOpenIcon=\"hideOpenIcon\"\r\n let-openOnClick=\"openOnClick\"\r\n let-enableNodeReordering=\"enableNodeReordering\"\r\n let-onlyExecuteLeafNode=\"onlyExecuteLeafNode\"\r\n let-iconField=\"iconField\"\r\n let-colorField=\"colorField\"\r\n let-allColumns=\"allColumns\"\r\n let-hideIcon=\"hideIcon\"\r\n let-viewSettingsContentDensity=\"viewSettingsContentDensity\"\r\n let-hasInlineDeleteButton=\"hasInlineDeleteButton\"\r\n let-hasInlineEditButton=\"hasInlineEditButton\"\r\n>\r\n <bsu-ulv-toolbar\r\n [hideToolbar]=\"hideToolbar\"\r\n [deviceName]=\"deviceName\"\r\n [deviceSize]=\"deviceSize\"\r\n [toolbarButtons]=\"toolbarButtons\"\r\n [gridSetting]=\"gridSetting\"\r\n [title]=\"title\"\r\n [hasSelected]=\"hasSelected\"\r\n [inDialog]=\"inDialog\"\r\n [isMultiSelect]=\"isMultiSelect\"\r\n [contentDensity]=\"contentDensity\"\r\n [inlineEditMode]=\"inlineEditMode\"\r\n [allowInlineEdit]=\"allowInlineEdit\"\r\n [moDataListCount]=\"moDataList.length\"\r\n (sortClick)=\"onSortSettings(deviceName)\"\r\n (groupbyClick)=\"onGroupbySettings(deviceName)\"\r\n (columnClick)=\"onColumnSettings(deviceName)\"\r\n (editModeClick)=\"onEditMode()\"\r\n >\r\n <button\r\n fd-button\r\n fd-toolbar-item\r\n [fdType]=\"'transparent'\"\r\n [glyph]=\"'collapse-all'\"\r\n (click)=\"onCollapseAll()\"\r\n ></button>\r\n @if (!showOkCancelButtons && enableNodeReordering) {\r\n <button\r\n fd-button\r\n fd-toolbar-item\r\n [fdType]=\"'transparent'\"\r\n [glyph]=\"'move'\"\r\n (click)=\"onOpenMoveToDialog(selectedNode, deviceName, moveDialog)\"\r\n ></button>\r\n }\r\n </bsu-ulv-toolbar>\r\n <bsu-ui-tree-view\r\n [leafCursorPointer]=\"onlyExecuteLeafNode && openOnClick\"\r\n [rtl]=\"rtl\"\r\n [hasInlineDeleteButton]=\"hasInlineDeleteButton\"\r\n [hasInlineEditButton]=\"hasInlineEditButton\"\r\n [relationList]=\"relationList\"\r\n [toolbarButtons]=\"toolbarButtons\"\r\n [root]=\"root\"\r\n [allColumns]=\"allColumns\"\r\n [hideIcon]=\"hideIcon\"\r\n [selectedMo]=\"selectedMo\"\r\n [hideOpenIcon]=\"hideOpenIcon\"\r\n [disableOverflowContextMenu]=\"disableOverflowContextMenu\"\r\n [iconField]=\"iconField\"\r\n [colorField]=\"colorField\"\r\n [navigationArrow]=\"navigationArrow\"\r\n [collapseIcon]=\"collapseIcon\"\r\n [selectedNode]=\"selectedNode\"\r\n [access]=\"access\"\r\n [viewSettingsContentDensity]=\"viewSettingsContentDensity\"\r\n [deviceName]=\"deviceName\"\r\n [deviceSize]=\"deviceSize\"\r\n [enableNodeReordering]=\"enableNodeReordering\"\r\n [inDialog]=\"inDialog\"\r\n [isMultiSelect]=\"isMultiSelect\"\r\n [openOnClick]=\"openOnClick\"\r\n [contextMenuItems]=\"contextMenuItems\"\r\n [moDataList]=\"moDataList\"\r\n [groupby]=\"groupby\"\r\n [isHetro]=\"isHetro\"\r\n [isCheckList]=\"isCheckList\"\r\n [conditionalFormats]=\"conditionalFormats\"\r\n [showOkCancelButtons]=\"showOkCancelButtons\"\r\n (checkChange)=\"onCheckChange($event)\"\r\n (itemDrop)=\"onDrop($event)\"\r\n (itemDragMoved)=\"onDragMoved($event)\"\r\n (nodeUlvCommand)=\"onNodeUlvCommand($event)\"\r\n (nodeViewClick)=\"onNodeViewClick($event)\"\r\n (loadChildren)=\"onLoadChildren($event)\"\r\n (nodeSelect)=\"onNodeSelect($event)\"\r\n (rowCheck)=\"onRowCheck($event)\"\r\n (rowClick)=\"onRowClick($event)\"\r\n (allCheckbox)=\"onAllCheckbox($event)\"\r\n (expandClick)=\"onExpandClick($event)\"\r\n (editFormPanelCancel)=\"onEditFormPanelCancel($event)\"\r\n (editFormPanelSave)=\"onEditFormPanelSave($event)\"\r\n (createNew)=\"onCreateNew($event)\"\r\n >\r\n </bsu-ui-tree-view>\r\n <ng-template let-dialog let-dialogConfig=\"dialogConfig\" #moveDialog>\r\n <fd-dialog [dialogConfig]=\"dialogConfig\" [dialogRef]=\"dialog\">\r\n <fd-dialog-header>\r\n <h1 fd-title>{{ 'Move' | bbbTranslate }}</h1>\r\n <button fd-dialog-close-button (click)=\"dialog.dismiss('Close button')\"></button>\r\n </fd-dialog-header>\r\n\r\n <fd-dialog-body>\r\n <div class=\"move-to\" (keydown.enter)=\"onConfirmDialog(dialogSelectedNode)\">\r\n <bsu-ui-tree-view\r\n [rtl]=\"rtl\"\r\n [root]=\"root\"\r\n [access]=\"access\"\r\n [navigationArrow]=\"navigationArrow\"\r\n [collapseIcon]=\"collapseIcon\"\r\n [deviceName]=\"deviceName\"\r\n [deviceSize]=\"deviceSize\"\r\n [viewSettingsContentDensity]=\"viewSettingsContentDensity\"\r\n [enableNodeReordering]=\"enableNodeReordering\"\r\n [openOnClick]=\"openOnClick\"\r\n [selectedNode]=\"dialogSelectedNode\"\r\n [moDataList]=\"flatMoDataList\"\r\n [groupby]=\"groupby\"\r\n [isCheckList]=\"isCheckList\"\r\n [conditionalFormats]=\"conditionalFormats\"\r\n (loadChildren)=\"onLoadChildren($event)\"\r\n (nodeSelect)=\"onSelectNodeInMoveDialog($event)\"\r\n ></bsu-ui-tree-view>\r\n </div>\r\n </fd-dialog-body>\r\n\r\n <fd-dialog-footer>\r\n <ng-template fdkTemplate=\"footer\">\r\n <div fd-bar-right>\r\n <fd-button-bar\r\n fdType=\"emphasized\"\r\n [label]=\"'OK' | bbbTranslate\"\r\n (click)=\"onConfirmDialog(dialogSelectedNode)\"\r\n >\r\n </fd-button-bar>\r\n <fd-button-bar fd-initial-focus [label]=\"'Cancel' | bbbTranslate\" (click)=\"onDismissDialog()\">\r\n </fd-button-bar>\r\n </div>\r\n </ng-template>\r\n </fd-dialog-footer>\r\n </fd-dialog>\r\n </ng-template>\r\n</ng-template>\r\n", styles: [":host{width:100%;box-sizing:border-box;display:inline-block}\n"] }]
110
+ args: [{ selector: 'bsu-ui-tree', changeDetection: ChangeDetectionStrategy.OnPush, template: "<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 hasInlineEditButton: viewSetting?.HasInlineEditButton,\n hasInlineDeleteButton: viewSetting?.HasInlineDeleteButton,\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 let-hasInlineDeleteButton=\"hasInlineDeleteButton\"\n let-hasInlineEditButton=\"hasInlineEditButton\"\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 *untilInView=\"el\"\n [leafCursorPointer]=\"onlyExecuteLeafNode && openOnClick\"\n [rtl]=\"rtl\"\n [hasInlineDeleteButton]=\"hasInlineDeleteButton\"\n [hasInlineEditButton]=\"hasInlineEditButton\"\n [relationList]=\"relationList\"\n [toolbarButtons]=\"toolbarButtons\"\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", styles: [":host{width:100%;box-sizing:border-box;display:inline-block}\n"] }]
111
111
  }], propDecorators: { showOkCancelButtons: [{
112
112
  type: Input
113
113
  }] } });
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';\r\n\r\nimport { ExecuteDynamicCommand, MoReportValuePipe, TreeNodeObj } from 'barsa-novin-ray-core';\r\nimport { Observable } from 'rxjs';\r\nimport { map } from 'rxjs/operators';\r\nimport { ReportTreeBaseComponent } from '../report-tree-base';\r\n\r\n@Component({\r\n    selector: 'bsu-ui-tree',\r\n    templateUrl: './ui-tree.component.html',\r\n    styleUrls: ['./ui-tree.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class UiTreeComponent extends ReportTreeBaseComponent implements OnInit {\r\n    @Input() showOkCancelButtons;\r\n    collapseIcon$: Observable<string>;\r\n    private _rval = inject(MoReportValuePipe);\r\n    ngOnInit(): void {\r\n        super.ngOnInit();\r\n        this.collapseIcon$ = this._portalService.rtl$.pipe(\r\n            // map((isRtl) => (isRtl ? 'navigation-left-arrow' : 'navigation-right-arrow'))\r\n            map((_) => 'add')\r\n        );\r\n    }\r\n    onDrop($event): void {\r\n        this.drop($event);\r\n    }\r\n\r\n    onDragMoved($event): void {\r\n        this.dragMoved($event);\r\n    }\r\n\r\n    onCollapseAll(): void {\r\n        this.collapseAll();\r\n    }\r\n\r\n    onOpenMoveToDialog(selectedNode, device, moveDialog): void {\r\n        this.openMoveToDialog(selectedNode, device, moveDialog);\r\n    }\r\n\r\n    onConfirmDialog(dialogSelectedNode): void {\r\n        this.confirmDialog(dialogSelectedNode);\r\n    }\r\n\r\n    onDismissDialog(): void {\r\n        this.dismissDialog();\r\n    }\r\n\r\n    onSelectNodeInMoveDialog($event): void {\r\n        this.selectNodeInMoveDialog($event);\r\n    }\r\n    onCheckChange(ev: { node: TreeNodeObj; index: number; checked: boolean }): void {\r\n        let selectedNode: TreeNodeObj | null = null;\r\n        if (ev.checked) {\r\n            ev.node.Data.$IsChecked = true;\r\n            selectedNode = ev.node;\r\n            this.context.selNode = selectedNode;\r\n            this.context.fireEvent('rowselect', this.context, ev.index, ev.node.Data);\r\n        } else {\r\n            ev.node.Data.$IsChecked = false;\r\n            const selected = this.moDataList.find((c) => c.$IsChecked);\r\n            if (selected) {\r\n                this.context.selNode = ev.node;\r\n                this._selectedNodeSource.next(ev.node);\r\n            } else {\r\n            }\r\n            this.context.fireEvent('rowdeselect', this.context, ev.index, ev.node.Data);\r\n        }\r\n        this._selectedNodeSource.next(selectedNode);\r\n        this._rebindRoot();\r\n    }\r\n    onNodeSelect(ev: { node: TreeNodeObj; index: number }): void {\r\n        if (this.context.selNode === ev.node) {\r\n            this._deselectNode();\r\n        } else {\r\n            this._selectNode(ev.node);\r\n            if (this.viewSetting?.OnlyExecuteLeafNode === true && !ev.node.leaf) {\r\n                this.loadChildren(ev.node);\r\n            }\r\n        }\r\n        this._rebindRoot();\r\n    }\r\n\r\n    onNodeUlvCommand(ev: { node: TreeNodeObj; index: number }): void {\r\n        this._ulvCommandClicked(ev.node.Data, ev.index);\r\n    }\r\n\r\n    onNodeViewClick(ev: { node: TreeNodeObj; index: number }): void {\r\n        if (this.viewSetting?.DisableShowFormOnDoubleClick === true) {\r\n            return;\r\n        }\r\n        if (this.viewSetting?.OnlyExecuteLeafNode === true && !ev.node.leaf) {\r\n            return;\r\n        }\r\n        if (this.viewSetting?.DynamicCommandField) {\r\n            const dyn = this._rval.transform(this.viewSetting?.DynamicCommandField, ev.node.Data, this.allColumns);\r\n            if (dyn) {\r\n                this._selectNode(ev.node);\r\n                ExecuteDynamicCommand(dyn, ev.node.Data);\r\n                return;\r\n            }\r\n        }\r\n        this._raiseRowClick(ev.index, ev.node);\r\n    }\r\n\r\n    onLoadChildren(node: TreeNodeObj): void {\r\n        this.loadChildren(node);\r\n    }\r\n}\r\n","<ng-container\r\n    *ngTemplateOutlet=\"\r\n        renderTree;\r\n        context: {\r\n            $implicit: root$ | async,\r\n            moDataList: flatMoDataList,\r\n            isCheckList: context.Setting.View?.IsCheckList,\r\n            columns: visibleColumns$ | async,\r\n            groupby: groupby$ | async,\r\n            toolbarButtons: (toolbarButtons$ | async)!! | seperatorFix,\r\n            contextMenuItems: menuItems$ | async | contextMenu: context.Setting.View?.IsCheckList,\r\n            conditionalFormats: context.Setting.View?.ConditionalFormats,\r\n            deviceName: deviceName$ | async,\r\n            deviceSize: deviceSize$ | async,\r\n            access: context.Setting.Extra?.DefaultCommandsAccess,\r\n            title: title$ | async,\r\n            inlineEditMode: inlineEditMode$ | async,\r\n            allowInlineEdit: allowInlineEdit$ | async,\r\n            hideToolbar: hideToolbar$ | async,\r\n            gridSetting: gridSetting$ | async,\r\n            contentDensity: contentDensity$ | async,\r\n            hasSelected: hasSelected$ | async,\r\n            showOkCancelButtons: showOkCancelButtons,\r\n            hideOpenIcon: viewSetting?.HideOpenIcon,\r\n            openOnClick: viewSetting?.OpenOnClick,\r\n            onlyExecuteLeafNode: viewSetting?.OnlyExecuteLeafNode,\r\n            enableNodeReordering: viewSetting?.EnableNodeReordering,\r\n            viewSettingsContentDensity: viewSetting?.ContentDensity$Caption,\r\n            iconField: viewSetting?.IconField,\r\n            hideIcon: viewSetting?.HideIcon,\r\n            colorField: viewSetting?.ColorField,\r\n            hasInlineEditButton: viewSetting?.HasInlineEditButton,\r\n            hasInlineDeleteButton: viewSetting?.HasInlineDeleteButton,\r\n            selectedNode: selectedNode$ | async,\r\n            navigationArrow: navigationArrow$ | async,\r\n            collapseIcon: collapseIcon$ | async,\r\n            relationList: context.Setting.View.RelationList,\r\n            allColumns: allColumns,\r\n            rtl: rtl$ | async,\r\n            inDialog: inDialog$ | async,\r\n            isMultiSelect: isMultiSelect$ | async,\r\n            disableOverflowContextMenu: viewSetting?.DisableOverflowContextMenu,\r\n            isHetro: context.Setting.ClassNames.DataClass === 'Ul.HetroTreeUlvDataCtrlr',\r\n            selectedMo: selectedMo$ | async\r\n        }\r\n    \"\r\n></ng-container>\r\n\r\n<ng-template\r\n    #renderTree\r\n    let-root\r\n    let-moDataList=\"moDataList\"\r\n    let-deviceName=\"deviceName\"\r\n    let-deviceSize=\"deviceSize\"\r\n    let-toolbarButtons=\"toolbarButtons\"\r\n    let-title=\"title\"\r\n    let-inlineEditMode=\"inlineEditMode\"\r\n    let-allowInlineEdit=\"allowInlineEdit\"\r\n    let-hideToolbar=\"hideToolbar\"\r\n    let-gridSetting=\"gridSetting\"\r\n    let-contentDensity=\"contentDensity\"\r\n    let-access=\"access\"\r\n    let-contextMenuItems=\"contextMenuItems\"\r\n    let-conditionalFormats=\"conditionalFormats\"\r\n    let-isCheckList=\"isCheckList\"\r\n    let-groupby=\"groupby\"\r\n    let-hasSelected=\"hasSelected\"\r\n    let-showOkCancelButtons=\"showOkCancelButtons\"\r\n    let-selectedNode=\"selectedNode\"\r\n    let-navigationArrow=\"navigationArrow\"\r\n    let-collapseIcon=\"collapseIcon\"\r\n    let-rtl=\"rtl\"\r\n    let-disableOverflowContextMenu=\"disableOverflowContextMenu\"\r\n    let-relationList=\"relationList\"\r\n    let-isHetro=\"isHetro\"\r\n    let-inDialog=\"inDialog\"\r\n    let-isMultiSelect=\"isMultiSelect\"\r\n    let-selectedMo=\"selectedMo\"\r\n    let-hideOpenIcon=\"hideOpenIcon\"\r\n    let-openOnClick=\"openOnClick\"\r\n    let-enableNodeReordering=\"enableNodeReordering\"\r\n    let-onlyExecuteLeafNode=\"onlyExecuteLeafNode\"\r\n    let-iconField=\"iconField\"\r\n    let-colorField=\"colorField\"\r\n    let-allColumns=\"allColumns\"\r\n    let-hideIcon=\"hideIcon\"\r\n    let-viewSettingsContentDensity=\"viewSettingsContentDensity\"\r\n    let-hasInlineDeleteButton=\"hasInlineDeleteButton\"\r\n    let-hasInlineEditButton=\"hasInlineEditButton\"\r\n>\r\n    <bsu-ulv-toolbar\r\n        [hideToolbar]=\"hideToolbar\"\r\n        [deviceName]=\"deviceName\"\r\n        [deviceSize]=\"deviceSize\"\r\n        [toolbarButtons]=\"toolbarButtons\"\r\n        [gridSetting]=\"gridSetting\"\r\n        [title]=\"title\"\r\n        [hasSelected]=\"hasSelected\"\r\n        [inDialog]=\"inDialog\"\r\n        [isMultiSelect]=\"isMultiSelect\"\r\n        [contentDensity]=\"contentDensity\"\r\n        [inlineEditMode]=\"inlineEditMode\"\r\n        [allowInlineEdit]=\"allowInlineEdit\"\r\n        [moDataListCount]=\"moDataList.length\"\r\n        (sortClick)=\"onSortSettings(deviceName)\"\r\n        (groupbyClick)=\"onGroupbySettings(deviceName)\"\r\n        (columnClick)=\"onColumnSettings(deviceName)\"\r\n        (editModeClick)=\"onEditMode()\"\r\n    >\r\n        <button\r\n            fd-button\r\n            fd-toolbar-item\r\n            [fdType]=\"'transparent'\"\r\n            [glyph]=\"'collapse-all'\"\r\n            (click)=\"onCollapseAll()\"\r\n        ></button>\r\n        @if (!showOkCancelButtons && enableNodeReordering) {\r\n        <button\r\n            fd-button\r\n            fd-toolbar-item\r\n            [fdType]=\"'transparent'\"\r\n            [glyph]=\"'move'\"\r\n            (click)=\"onOpenMoveToDialog(selectedNode, deviceName, moveDialog)\"\r\n        ></button>\r\n        }\r\n    </bsu-ulv-toolbar>\r\n    <bsu-ui-tree-view\r\n        [leafCursorPointer]=\"onlyExecuteLeafNode && openOnClick\"\r\n        [rtl]=\"rtl\"\r\n        [hasInlineDeleteButton]=\"hasInlineDeleteButton\"\r\n        [hasInlineEditButton]=\"hasInlineEditButton\"\r\n        [relationList]=\"relationList\"\r\n        [toolbarButtons]=\"toolbarButtons\"\r\n        [root]=\"root\"\r\n        [allColumns]=\"allColumns\"\r\n        [hideIcon]=\"hideIcon\"\r\n        [selectedMo]=\"selectedMo\"\r\n        [hideOpenIcon]=\"hideOpenIcon\"\r\n        [disableOverflowContextMenu]=\"disableOverflowContextMenu\"\r\n        [iconField]=\"iconField\"\r\n        [colorField]=\"colorField\"\r\n        [navigationArrow]=\"navigationArrow\"\r\n        [collapseIcon]=\"collapseIcon\"\r\n        [selectedNode]=\"selectedNode\"\r\n        [access]=\"access\"\r\n        [viewSettingsContentDensity]=\"viewSettingsContentDensity\"\r\n        [deviceName]=\"deviceName\"\r\n        [deviceSize]=\"deviceSize\"\r\n        [enableNodeReordering]=\"enableNodeReordering\"\r\n        [inDialog]=\"inDialog\"\r\n        [isMultiSelect]=\"isMultiSelect\"\r\n        [openOnClick]=\"openOnClick\"\r\n        [contextMenuItems]=\"contextMenuItems\"\r\n        [moDataList]=\"moDataList\"\r\n        [groupby]=\"groupby\"\r\n        [isHetro]=\"isHetro\"\r\n        [isCheckList]=\"isCheckList\"\r\n        [conditionalFormats]=\"conditionalFormats\"\r\n        [showOkCancelButtons]=\"showOkCancelButtons\"\r\n        (checkChange)=\"onCheckChange($event)\"\r\n        (itemDrop)=\"onDrop($event)\"\r\n        (itemDragMoved)=\"onDragMoved($event)\"\r\n        (nodeUlvCommand)=\"onNodeUlvCommand($event)\"\r\n        (nodeViewClick)=\"onNodeViewClick($event)\"\r\n        (loadChildren)=\"onLoadChildren($event)\"\r\n        (nodeSelect)=\"onNodeSelect($event)\"\r\n        (rowCheck)=\"onRowCheck($event)\"\r\n        (rowClick)=\"onRowClick($event)\"\r\n        (allCheckbox)=\"onAllCheckbox($event)\"\r\n        (expandClick)=\"onExpandClick($event)\"\r\n        (editFormPanelCancel)=\"onEditFormPanelCancel($event)\"\r\n        (editFormPanelSave)=\"onEditFormPanelSave($event)\"\r\n        (createNew)=\"onCreateNew($event)\"\r\n    >\r\n    </bsu-ui-tree-view>\r\n    <ng-template let-dialog let-dialogConfig=\"dialogConfig\" #moveDialog>\r\n        <fd-dialog [dialogConfig]=\"dialogConfig\" [dialogRef]=\"dialog\">\r\n            <fd-dialog-header>\r\n                <h1 fd-title>{{ 'Move' | bbbTranslate }}</h1>\r\n                <button fd-dialog-close-button (click)=\"dialog.dismiss('Close button')\"></button>\r\n            </fd-dialog-header>\r\n\r\n            <fd-dialog-body>\r\n                <div class=\"move-to\" (keydown.enter)=\"onConfirmDialog(dialogSelectedNode)\">\r\n                    <bsu-ui-tree-view\r\n                        [rtl]=\"rtl\"\r\n                        [root]=\"root\"\r\n                        [access]=\"access\"\r\n                        [navigationArrow]=\"navigationArrow\"\r\n                        [collapseIcon]=\"collapseIcon\"\r\n                        [deviceName]=\"deviceName\"\r\n                        [deviceSize]=\"deviceSize\"\r\n                        [viewSettingsContentDensity]=\"viewSettingsContentDensity\"\r\n                        [enableNodeReordering]=\"enableNodeReordering\"\r\n                        [openOnClick]=\"openOnClick\"\r\n                        [selectedNode]=\"dialogSelectedNode\"\r\n                        [moDataList]=\"flatMoDataList\"\r\n                        [groupby]=\"groupby\"\r\n                        [isCheckList]=\"isCheckList\"\r\n                        [conditionalFormats]=\"conditionalFormats\"\r\n                        (loadChildren)=\"onLoadChildren($event)\"\r\n                        (nodeSelect)=\"onSelectNodeInMoveDialog($event)\"\r\n                    ></bsu-ui-tree-view>\r\n                </div>\r\n            </fd-dialog-body>\r\n\r\n            <fd-dialog-footer>\r\n                <ng-template fdkTemplate=\"footer\">\r\n                    <div fd-bar-right>\r\n                        <fd-button-bar\r\n                            fdType=\"emphasized\"\r\n                            [label]=\"'OK' | bbbTranslate\"\r\n                            (click)=\"onConfirmDialog(dialogSelectedNode)\"\r\n                        >\r\n                        </fd-button-bar>\r\n                        <fd-button-bar fd-initial-focus [label]=\"'Cancel' | bbbTranslate\" (click)=\"onDismissDialog()\">\r\n                        </fd-button-bar>\r\n                    </div>\r\n                </ng-template>\r\n            </fd-dialog-footer>\r\n        </fd-dialog>\r\n    </ng-template>\r\n</ng-template>\r\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';\r\n\r\nimport { ExecuteDynamicCommand, MoReportValuePipe, TreeNodeObj } from 'barsa-novin-ray-core';\r\nimport { Observable } from 'rxjs';\r\nimport { map } from 'rxjs/operators';\r\nimport { ReportTreeBaseComponent } from '../report-tree-base';\r\n\r\n@Component({\r\n    selector: 'bsu-ui-tree',\r\n    templateUrl: './ui-tree.component.html',\r\n    styleUrls: ['./ui-tree.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class UiTreeComponent extends ReportTreeBaseComponent implements OnInit {\r\n    @Input() showOkCancelButtons;\r\n    collapseIcon$: Observable<string>;\r\n    private _rval = inject(MoReportValuePipe);\r\n    ngOnInit(): void {\r\n        super.ngOnInit();\r\n        this.collapseIcon$ = this._portalService.rtl$.pipe(\r\n            // map((isRtl) => (isRtl ? 'navigation-left-arrow' : 'navigation-right-arrow'))\r\n            map((_) => 'add')\r\n        );\r\n    }\r\n    onDrop($event): void {\r\n        this.drop($event);\r\n    }\r\n\r\n    onDragMoved($event): void {\r\n        this.dragMoved($event);\r\n    }\r\n\r\n    onCollapseAll(): void {\r\n        this.collapseAll();\r\n    }\r\n\r\n    onOpenMoveToDialog(selectedNode, device, moveDialog): void {\r\n        this.openMoveToDialog(selectedNode, device, moveDialog);\r\n    }\r\n\r\n    onConfirmDialog(dialogSelectedNode): void {\r\n        this.confirmDialog(dialogSelectedNode);\r\n    }\r\n\r\n    onDismissDialog(): void {\r\n        this.dismissDialog();\r\n    }\r\n\r\n    onSelectNodeInMoveDialog($event): void {\r\n        this.selectNodeInMoveDialog($event);\r\n    }\r\n    onCheckChange(ev: { node: TreeNodeObj; index: number; checked: boolean }): void {\r\n        let selectedNode: TreeNodeObj | null = null;\r\n        if (ev.checked) {\r\n            ev.node.Data.$IsChecked = true;\r\n            selectedNode = ev.node;\r\n            this.context.selNode = selectedNode;\r\n            this.context.fireEvent('rowselect', this.context, ev.index, ev.node.Data);\r\n        } else {\r\n            ev.node.Data.$IsChecked = false;\r\n            const selected = this.moDataList.find((c) => c.$IsChecked);\r\n            if (selected) {\r\n                this.context.selNode = ev.node;\r\n                this._selectedNodeSource.next(ev.node);\r\n            } else {\r\n            }\r\n            this.context.fireEvent('rowdeselect', this.context, ev.index, ev.node.Data);\r\n        }\r\n        this._selectedNodeSource.next(selectedNode);\r\n        this._rebindRoot();\r\n    }\r\n    onNodeSelect(ev: { node: TreeNodeObj; index: number }): void {\r\n        if (this.context.selNode === ev.node) {\r\n            this._deselectNode();\r\n        } else {\r\n            this._selectNode(ev.node);\r\n            if (this.viewSetting?.OnlyExecuteLeafNode === true && !ev.node.leaf) {\r\n                this.loadChildren(ev.node);\r\n            }\r\n        }\r\n        this._rebindRoot();\r\n    }\r\n\r\n    onNodeUlvCommand(ev: { node: TreeNodeObj; index: number }): void {\r\n        this._ulvCommandClicked(ev.node.Data, ev.index);\r\n    }\r\n\r\n    onNodeViewClick(ev: { node: TreeNodeObj; index: number }): void {\r\n        if (this.viewSetting?.DisableShowFormOnDoubleClick === true) {\r\n            return;\r\n        }\r\n        if (this.viewSetting?.OnlyExecuteLeafNode === true && !ev.node.leaf) {\r\n            return;\r\n        }\r\n        if (this.viewSetting?.DynamicCommandField) {\r\n            const dyn = this._rval.transform(this.viewSetting?.DynamicCommandField, ev.node.Data, this.allColumns);\r\n            if (dyn) {\r\n                this._selectNode(ev.node);\r\n                ExecuteDynamicCommand(dyn, ev.node.Data);\r\n                return;\r\n            }\r\n        }\r\n        this._raiseRowClick(ev.index, ev.node);\r\n    }\r\n\r\n    onLoadChildren(node: TreeNodeObj): void {\r\n        this.loadChildren(node);\r\n    }\r\n}\r\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            hasInlineEditButton: viewSetting?.HasInlineEditButton,\n            hasInlineDeleteButton: viewSetting?.HasInlineDeleteButton,\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    let-hasInlineDeleteButton=\"hasInlineDeleteButton\"\n    let-hasInlineEditButton=\"hasInlineEditButton\"\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        *untilInView=\"el\"\n        [leafCursorPointer]=\"onlyExecuteLeafNode && openOnClick\"\n        [rtl]=\"rtl\"\n        [hasInlineDeleteButton]=\"hasInlineDeleteButton\"\n        [hasInlineEditButton]=\"hasInlineEditButton\"\n        [relationList]=\"relationList\"\n        [toolbarButtons]=\"toolbarButtons\"\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"]}