barsa-sap-ui 2.2.22 → 2.2.32

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (57) hide show
  1. package/esm2022/lib/barsa-chat/barsa-chat.component.mjs +2 -2
  2. package/esm2022/lib/barsa-form-layout-panel/barsa-form-layout-panel.component.mjs +58 -0
  3. package/esm2022/lib/barsa-form-side-content/barsa-form-side-content.component.mjs +1 -1
  4. package/esm2022/lib/barsa-group-cartable/barsa-cartable-group.component.mjs +1 -1
  5. package/esm2022/lib/barsa-list-file-linear/barsa-list-file-linear.component.mjs +1 -1
  6. package/esm2022/lib/barsa-list-file-linear-gmail/barsa-list-file-linear-gmail.component.mjs +1 -1
  7. package/esm2022/lib/barsa-list-layout-panel/barsa-list-layout-panel.component.mjs +1 -1
  8. package/esm2022/lib/barsa-pishnamayesh-payam/barsa-pishnamayesh-payam.component.mjs +1 -1
  9. package/esm2022/lib/barsa-sap-ui.module.mjs +24 -23
  10. package/esm2022/lib/barsa-table-header/barsa-table-header.component.mjs +1 -1
  11. package/esm2022/lib/barsa-table-row/barsa-table-row.component.mjs +3 -3
  12. package/esm2022/lib/barsa-tinyemce/barsa-tinyemce.component.mjs +10 -9
  13. package/esm2022/lib/barsa-tree-item/barsa-tree-item.component.mjs +2 -2
  14. package/esm2022/lib/barsa-ulv-main/barsa-ulv-main.component.mjs +1 -1
  15. package/esm2022/lib/file-viewer-content/file-viewer-content.component.mjs +1 -1
  16. package/esm2022/lib/fundamental-dynamic-form/fundamental-dynamic-form.component.mjs +7 -5
  17. package/esm2022/lib/index.mjs +4 -2
  18. package/esm2022/lib/layout-actions/layout-actions.component.mjs +3 -3
  19. package/esm2022/lib/layout-control/layout-control.component.mjs +4 -3
  20. package/esm2022/lib/list-item/list-item.component.mjs +1 -1
  21. package/esm2022/lib/ly-label/ly-label.component.mjs +5 -3
  22. package/esm2022/lib/manage-filters-report/manage-filters-report.component.mjs +1 -1
  23. package/esm2022/lib/report-search-fields-manage/report-search-fields-manage.component.mjs +1 -1
  24. package/esm2022/lib/report-view-renderer.directive.mjs +5 -2
  25. package/esm2022/lib/sap-ui-report-base.component.mjs +14 -4
  26. package/esm2022/lib/table-th.directive.mjs +2 -2
  27. package/esm2022/lib/ui-asp-report-viewer/ui-asp-report-viewer.component.mjs +1 -1
  28. package/esm2022/lib/ui-check-box/ui-check-box.component.mjs +9 -4
  29. package/esm2022/lib/ui-date-range-ex/ui-date-range-ex.component.mjs +1 -1
  30. package/esm2022/lib/ui-file-linear-list-box/ui-file-linear-list-box.component.mjs +27 -15
  31. package/esm2022/lib/ui-grid-columns/ui-grid-columns.component.mjs +1 -1
  32. package/esm2022/lib/ui-linear-list-container-with-button/ui-linear-list-container-with-button.component.mjs +29 -5
  33. package/esm2022/lib/ui-multi-select-card/ui-multi-select-card.component.mjs +1 -1
  34. package/esm2022/lib/ui-multi-select-radio/ui-multi-select-radio.component.mjs +1 -1
  35. package/esm2022/lib/ui-pdf-viewer/ui-pdf-viewer.component.mjs +1 -1
  36. package/esm2022/lib/ui-radio-group/ui-radio-group.component.mjs +1 -1
  37. package/esm2022/lib/ui-report-container/ui-report-container.component.mjs +3 -3
  38. package/esm2022/lib/ui-table-view/ui-table-view.component.mjs +3 -3
  39. package/esm2022/lib/ui-tinymce/ui-tinymce.component.mjs +8 -4
  40. package/esm2022/lib/ulv-context-menu/ulv-context-menu.component.mjs +3 -3
  41. package/esm2022/public-api.mjs +2 -1
  42. package/fesm2022/barsa-sap-ui.mjs +292 -179
  43. package/fesm2022/barsa-sap-ui.mjs.map +1 -1
  44. package/lib/barsa-form-layout-panel/barsa-form-layout-panel.component.d.ts +30 -0
  45. package/lib/barsa-sap-ui.module.d.ts +37 -36
  46. package/lib/barsa-tinyemce/barsa-tinyemce.component.d.ts +2 -3
  47. package/lib/index.d.ts +3 -3
  48. package/lib/layout-control/layout-control.component.d.ts +1 -0
  49. package/lib/ly-label/ly-label.component.d.ts +2 -1
  50. package/lib/report-view-renderer.directive.d.ts +2 -1
  51. package/lib/sap-ui-report-base.component.d.ts +5 -3
  52. package/lib/ui-check-box/ui-check-box.component.d.ts +1 -0
  53. package/lib/ui-file-linear-list-box/ui-file-linear-list-box.component.d.ts +2 -0
  54. package/lib/ui-linear-list-container-with-button/ui-linear-list-container-with-button.component.d.ts +3 -0
  55. package/lib/ui-tinymce/ui-tinymce.component.d.ts +1 -0
  56. package/package.json +1 -1
  57. package/public-api.d.ts +1 -0
@@ -1,18 +1,18 @@
1
- import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
1
+ import { ChangeDetectionStrategy, Component, ElementRef, EventEmitter, inject, Input, Output, ViewChild } from '@angular/core';
2
2
  import { concatMap, takeUntil, tap } from 'rxjs';
3
3
  import { BaseComponent, BarsaApi, getUniqueId, isFunction, UploadService } from 'barsa-novin-ray-core';
4
4
  import * as i0 from "@angular/core";
5
5
  import * as i1 from "barsa-novin-ray-core";
6
6
  import * as i2 from "@fundamental-ngx/core/file-uploader";
7
7
  export class BarsaTinyemceComponent extends BaseComponent {
8
- constructor(_uploadService, _el) {
9
- super();
10
- this._uploadService = _uploadService;
11
- this._el = _el;
8
+ constructor() {
9
+ super(...arguments);
12
10
  this.valueChange = new EventEmitter();
13
11
  this.tinyInit = new EventEmitter();
14
12
  this.tinyHostId = this._generateTinyHostId();
15
13
  this.tinyMCEConfig = {};
14
+ this._uploadService = inject(UploadService);
15
+ this._el = inject(ElementRef);
16
16
  this._onLoadIframe = () => {
17
17
  this.value = this.editorValue;
18
18
  // const ed = tinymce.get(this.tinyHostId);
@@ -75,6 +75,7 @@ export class BarsaTinyemceComponent extends BaseComponent {
75
75
  this.tinyMCEConfig.selector = '#' + this.tinyHostId;
76
76
  this.tinyMCEConfig.placeholder = this.Setting.ControlFieldCaptionTranslated;
77
77
  this.tinyMCEConfig.content_css = 'assets/Resources/fonts/Iran.css';
78
+ this.tinyMCEConfig.content_style = `body > p { overflow:auto }`;
78
79
  this.tinyMCEConfig.directionality = 'rtl';
79
80
  this.tinyMCEConfig.language = 'fa_IR';
80
81
  this.tinyMCEConfig.promotion = false;
@@ -91,7 +92,7 @@ export class BarsaTinyemceComponent extends BaseComponent {
91
92
  // this.tinyMCEConfig.toolbar_sticky = true;
92
93
  // this.tinyMCEConfig.toolbar_sticky_offset = 100;
93
94
  this.tinyMCEConfig.font_family_formats =
94
- 'BarsaFont=BarsaFont;Arial=arial,helvetica,sans-serif; Courier New=courier new,courier,monospace;';
95
+ 'B-Font=B-Font;Arial=arial,helvetica,sans-serif; Courier New=courier new,courier,monospace;';
95
96
  this.tinyMCEConfig.font_size_formats = '8pt 10pt 12pt 14pt 18pt 24pt 36pt';
96
97
  this.tinyMCEConfig.plugins = [
97
98
  'advlist',
@@ -391,13 +392,13 @@ export class BarsaTinyemceComponent extends BaseComponent {
391
392
  html.style.overflow = 'hidden';
392
393
  }
393
394
  }
394
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: BarsaTinyemceComponent, deps: [{ token: i1.UploadService }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
395
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: BarsaTinyemceComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
395
396
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: BarsaTinyemceComponent, selector: "bsu-barsa-tinyemce", inputs: { Setting: "Setting", isReadonly: "isReadonly", value: "value", IsInline: "IsInline", defaultVerbs: "defaultVerbs" }, outputs: { valueChange: "valueChange", tinyInit: "tinyInit" }, providers: [UploadService], viewQueries: [{ propertyName: "_uploader", first: true, predicate: ["uploader"], descendants: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div\r\n class=\"fd-input tinywrapper\"\r\n [style.min-height.px]=\"height\"\r\n [id]=\"tinyHostId\"\r\n intersectionObserver\r\n [intersectionThreshold]=\"0.1\"\r\n (visibilityChange)=\"onVisibilityChange($event)\"\r\n></div>\r\n<fd-file-uploader\r\n #uploader\r\n [style.display]=\"'none'\"\r\n [accept]=\"''\"\r\n [multiple]=\"false\"\r\n (selectedFilesChanged)=\"onFileSelection($event)\"\r\n></fd-file-uploader>\r\n<!-- <textarea [id]=\"tinyHostId\" style=\"height: 100%; visibility: hidden\"></textarea> -->\r\n", styles: [":host{display:block;width:100%;height:100%}.tinywrapper{overflow:auto}\n"], dependencies: [{ kind: "directive", type: i1.IntersectionObserverDirective, selector: "[intersectionObserver]", inputs: ["intersectionDebounce", "intersectionRootMargin", "intersectionRoot", "intersectionThreshold"], outputs: ["visibilityChange"] }, { kind: "component", type: i2.FileUploaderComponent, selector: "fd-file-uploader", inputs: ["disabled", "required", "multiple", "accept", "dragndrop", "maxFileSize", "minFileSize", "id", "ariaLabel", "ariaLabelledBy", "placeholder", "buttonLabel", "buttonAriaLabel", "state", "fileLimit", "inputHidden", "width"], outputs: ["selectedFilesChanged", "selectedInvalidFiles", "onDragEnter", "onDragLeave"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
396
397
  }
397
398
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: BarsaTinyemceComponent, decorators: [{
398
399
  type: Component,
399
400
  args: [{ selector: 'bsu-barsa-tinyemce', changeDetection: ChangeDetectionStrategy.OnPush, providers: [UploadService], standalone: false, template: "<div\r\n class=\"fd-input tinywrapper\"\r\n [style.min-height.px]=\"height\"\r\n [id]=\"tinyHostId\"\r\n intersectionObserver\r\n [intersectionThreshold]=\"0.1\"\r\n (visibilityChange)=\"onVisibilityChange($event)\"\r\n></div>\r\n<fd-file-uploader\r\n #uploader\r\n [style.display]=\"'none'\"\r\n [accept]=\"''\"\r\n [multiple]=\"false\"\r\n (selectedFilesChanged)=\"onFileSelection($event)\"\r\n></fd-file-uploader>\r\n<!-- <textarea [id]=\"tinyHostId\" style=\"height: 100%; visibility: hidden\"></textarea> -->\r\n", styles: [":host{display:block;width:100%;height:100%}.tinywrapper{overflow:auto}\n"] }]
400
- }], ctorParameters: () => [{ type: i1.UploadService }, { type: i0.ElementRef }], propDecorators: { _uploader: [{
401
+ }], propDecorators: { _uploader: [{
401
402
  type: ViewChild,
402
403
  args: ['uploader']
403
404
  }], Setting: [{
@@ -415,4 +416,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
415
416
  }], tinyInit: [{
416
417
  type: Output
417
418
  }] } });
418
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"barsa-tinyemce.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-sap-ui/src/lib/barsa-tinyemce/barsa-tinyemce.component.ts","../../../../../projects/barsa-sap-ui/src/lib/barsa-tinyemce/barsa-tinyemce.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    AfterViewInit,\r\n    ChangeDetectionStrategy,\r\n    Component,\r\n    ElementRef,\r\n    EventEmitter,\r\n    Input,\r\n    OnChanges,\r\n    OnDestroy,\r\n    Output,\r\n    SimpleChanges,\r\n    ViewChild\r\n} from '@angular/core';\r\nimport { FileUploaderComponent } from '@fundamental-ngx/core';\r\nimport { Observable, concatMap, takeUntil, tap } from 'rxjs';\r\n\r\nimport {\r\n    BaseComponent,\r\n    BarsaApi,\r\n    getUniqueId,\r\n    isFunction,\r\n    UploadService,\r\n    GeneralControlInfoModel\r\n} from 'barsa-novin-ray-core';\r\n\r\ndeclare const window: any;\r\ndeclare const tinymce: any;\r\ndeclare const head: any;\r\ndeclare const $: any;\r\n@Component({\r\n    selector: 'bsu-barsa-tinyemce',\r\n    templateUrl: './barsa-tinyemce.component.html',\r\n    styleUrls: ['./barsa-tinyemce.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    providers: [UploadService],\r\n    standalone: false\r\n})\r\nexport class BarsaTinyemceComponent extends BaseComponent implements AfterViewInit, OnDestroy, OnChanges {\r\n    @ViewChild('uploader') _uploader: FileUploaderComponent;\r\n    @Input() Setting: GeneralControlInfoModel;\r\n    @Input() isReadonly: boolean;\r\n    @Input() value: any;\r\n    @Input() IsInline: boolean;\r\n    @Input() defaultVerbs: { Title: string; Html: string }[];\r\n    @Output() valueChange = new EventEmitter<any>();\r\n    @Output() tinyInit = new EventEmitter();\r\n    tinyHostId = this._generateTinyHostId();\r\n    tinyMCEConfig: any = {};\r\n    editor: any;\r\n    wysiwygIntialized: boolean;\r\n    intializationInProgress: boolean;\r\n    editorValue: string;\r\n\r\n    iframBodyInnerHtml: string;\r\n    height: number;\r\n\r\n    constructor(protected _uploadService: UploadService, protected _el: ElementRef) {\r\n        super();\r\n    }\r\n    ngOnChanges(simpleChanges: SimpleChanges): void {\r\n        super.ngOnChanges(simpleChanges);\r\n        if (simpleChanges.value && !simpleChanges.value.firstChange) {\r\n            this.setValue(simpleChanges.value.currentValue);\r\n        }\r\n        if (simpleChanges.disable && !simpleChanges.disable.firstChange) {\r\n            const disbale = simpleChanges.disable.currentValue;\r\n            if (disbale) {\r\n                this.setDisable();\r\n            } else {\r\n                this.setEnable();\r\n            }\r\n        }\r\n        if (simpleChanges.readonly && !simpleChanges.readonly.firstChange) {\r\n            this.setReadOnly(simpleChanges.readonly.currentValue);\r\n        }\r\n    }\r\n    ngOnInit(): void {\r\n        super.ngOnInit();\r\n        this.height = (this._el.nativeElement as HTMLElement).clientHeight;\r\n    }\r\n\r\n    ngOnDestroy(): void {\r\n        super.ngOnDestroy();\r\n        this.destroyTinymce();\r\n    }\r\n\r\n    onFileSelection(files: File[]): void {\r\n        this.uploadFile(files).pipe(takeUntil(this._onDestroy$)).subscribe();\r\n    }\r\n    loadTinyMce(): void {\r\n        if (!this.Setting.IsHtmlViewer) {\r\n            head.load(['Lib/tinymce/tinymce.min.js'], () => {\r\n                setTimeout(() => {\r\n                    this.prepare();\r\n                });\r\n            });\r\n        }\r\n    }\r\n    onVisibilityChange(e): void {\r\n        if (e === 'Visible') {\r\n            this.loadTinyMce();\r\n        }\r\n    }\r\n    initilize(): void {\r\n        if (this.tinyMCEConfig.setup) {\r\n            return;\r\n        }\r\n        this.tinyMCEConfig.height = '100%';\r\n        this.tinyMCEConfig.width = '100%';\r\n        this.tinyMCEConfig.selector = '#' + this.tinyHostId;\r\n        this.tinyMCEConfig.placeholder = this.Setting.ControlFieldCaptionTranslated;\r\n        this.tinyMCEConfig.content_css = 'assets/Resources/fonts/Iran.css';\r\n        this.tinyMCEConfig.directionality = 'rtl';\r\n        this.tinyMCEConfig.language = 'fa_IR';\r\n        this.tinyMCEConfig.promotion = false;\r\n        this.tinyMCEConfig.skin = 'oxide';\r\n        this.tinyMCEConfig.paste_data_images = true;\r\n        this.tinyMCEConfig.defaultFontName = 'B-Font';\r\n        this.tinyMCEConfig.defaultFontSize = '12px';\r\n        this.tinyMCEConfig.statusbar = false;\r\n        this.tinyMCEConfig.resize = false;\r\n\r\n        this.tinyMCEConfig.inline = false;\r\n        this.tinyMCEConfig.menubar = false;\r\n        this.tinyMCEConfig.toolbar_location = 'top';\r\n\r\n        this.tinyMCEConfig.toolbar_mode = 'floating';\r\n        // this.tinyMCEConfig.toolbar_sticky = true;\r\n        // this.tinyMCEConfig.toolbar_sticky_offset = 100;\r\n        this.tinyMCEConfig.font_family_formats =\r\n            'BarsaFont=BarsaFont;Arial=arial,helvetica,sans-serif; Courier New=courier new,courier,monospace;';\r\n        this.tinyMCEConfig.font_size_formats = '8pt 10pt 12pt 14pt 18pt 24pt 36pt';\r\n\r\n        this.tinyMCEConfig.plugins = [\r\n            'advlist',\r\n            'anchor',\r\n            'autolink',\r\n            'autosave',\r\n            'charmap',\r\n            'code',\r\n            'codesample',\r\n            'directionality',\r\n            'emoticons',\r\n            'fullscreen',\r\n            'help',\r\n            'image',\r\n            'importcss',\r\n            'insertdatetime',\r\n            'link',\r\n            'lists',\r\n            'media',\r\n            'nonbreaking',\r\n            'pagebreak',\r\n            'preview',\r\n            'quickbars',\r\n            'save',\r\n            'searchreplace',\r\n            'table',\r\n            'template',\r\n            'visualblocks',\r\n            'visualchars',\r\n            'wordcount',\r\n            'autoresize'\r\n        ];\r\n        this.tinyMCEConfig.toolbar =\r\n            `defaultVerbs barsaImage | insert | forecolor backcolor fontfamily fontsize | bullist numlist outdent indent | removeformat` +\r\n            ` | undo redo | copy cut paste | blocks | bold italic | alignleft aligncenter alignright alignjustify ltr rtl`;\r\n\r\n        this.tinyMCEConfig.quickbars_selection_toolbar =\r\n            'bold italic fontsize | forecolor backcolor|defaultVerbs barsaImage';\r\n        const tinymceSettingsGlobal = window.tinymceSettings;\r\n        let tinymceSettings = BarsaApi.Common.Util.TryGetValue(this.Setting, 'JsonExtraProp.tinymceSettings');\r\n        tinymceSettings = BarsaApi.Common.Merger.Merge(tinymceSettingsGlobal, tinymceSettings);\r\n        if (!tinymceSettings && Array.isArray(tinymceSettings)) {\r\n            for (const item of tinymceSettings) {\r\n                this.tinyMCEConfig[item.key] = item.value;\r\n            }\r\n        }\r\n\r\n        if (this.isReadonly) {\r\n            this.tinyMCEConfig.menubar = false;\r\n            this.tinyMCEConfig.statusbar = false;\r\n            this.tinyMCEConfig.plugins = ['autoresize'];\r\n            // this.tinyMCEConfig.plugins = [];\r\n            this.tinyMCEConfig.toolbar = false;\r\n        }\r\n\r\n        let userSetup: (editor: any) => void;\r\n\r\n        if (this.tinyMCEConfig.setup) {\r\n            userSetup = this.tinyMCEConfig.setup;\r\n        }\r\n        let defaultVerbsMenu: any = [];\r\n\r\n        // BEGIN: setup\r\n        this.tinyMCEConfig.setup = (ed) => {\r\n            this.editor = ed;\r\n            if (!this.isReadonly) {\r\n                if (this.defaultVerbs) {\r\n                    defaultVerbsMenu = [];\r\n                    this.defaultVerbs.forEach((item) => {\r\n                        defaultVerbsMenu.push({\r\n                            value: item.Html,\r\n                            type: 'menuitem',\r\n                            text: item.Title || item.Html.replace(/<br\\s*\\/?>/gi, ' '),\r\n                            onAction: () => {\r\n                                // ed.execCommand('mceInsertRawHTML', false, item.Html);\r\n                                ed.insertContent(item.Html, { format: 'raw' });\r\n                            }\r\n                        });\r\n                    });\r\n                }\r\n                ed.ui.registry.addSplitButton('barsaImage', {\r\n                    text: 'insert',\r\n                    icon: 'image',\r\n                    tooltip: 'Insert Image As Base64',\r\n                    onAction: () => {\r\n                        BarsaApi.Common.Async.Waterfall(\r\n                            'Tinemce.EmbedImage',\r\n                            {\r\n                                openFileDialog: this.ShowOpenFileDialog.bind(this),\r\n                                insertBase64: this.InsertBase64.bind(this)\r\n                            },\r\n                            (err, result) => {\r\n                                BarsaApi.Common.Async.Finalize(err, result);\r\n                            }\r\n                        );\r\n                    },\r\n                    onItemAction: () => {\r\n                        BarsaApi.Common.Async.Waterfall(\r\n                            'Tinemce.UploadToDatabase',\r\n                            {\r\n                                openFileDialog: this.ShowUploadWindow.bind(this)\r\n                            },\r\n                            (err, result) => {\r\n                                BarsaApi.Common.Async.Finalize(err, result);\r\n                            }\r\n                        );\r\n                    },\r\n                    fetch: (callback) => {\r\n                        const items = [\r\n                            {\r\n                                type: 'choiceitem',\r\n                                text: 'upload',\r\n                                icon: 'image',\r\n                                tooltip: 'Upload Image',\r\n                                value: 'upload'\r\n                            }\r\n                        ];\r\n                        callback(items);\r\n                    }\r\n                });\r\n\r\n                ed.ui.registry.addMenuButton('defaultVerbs', {\r\n                    text: 'عبارتهای پیش فرض',\r\n                    fetch: (callback) => {\r\n                        callback(defaultVerbsMenu);\r\n                    }\r\n                });\r\n                if (isFunction(window.tinymceSetup)) {\r\n                    window.tinymceSetup.call(this, this, ed);\r\n                }\r\n            }\r\n            let hasInit = false;\r\n            ed.on('init', () => {\r\n                this.wysiwygIntialized = true;\r\n                this.intializationInProgress = false;\r\n                if (typeof this.value !== 'undefined') {\r\n                    this.setValue(this.value);\r\n                }\r\n                if (this.tinyMCEConfig.defaultFontName) {\r\n                    ed.execCommand('FontName', false, this.tinyMCEConfig.defaultFontName);\r\n                }\r\n                if (this.tinyMCEConfig.defaultFontSize) {\r\n                    ed.execCommand('FontSize', false, this.tinyMCEConfig.defaultFontSize);\r\n                }\r\n                if (this.isReadonly) {\r\n                    this.setReadOnly(this.isReadonly);\r\n                }\r\n                // This piece of code solves the problem of change propagation so that\r\n                // there is no need to call triggerSave\r\n                const setContent = ed.setContent;\r\n                ed.setContent = (...args) => {\r\n                    setContent.apply(ed, args);\r\n                    ed.dispatch('change', {});\r\n                };\r\n                hasInit = true;\r\n                this.tinyInit.emit();\r\n                const iframEl: HTMLIFrameElement = ed.iframeElement;\r\n                if (iframEl) {\r\n                    iframEl.addEventListener('load', this._onLoadIframe);\r\n                }\r\n            });\r\n\r\n            // Catch and propagate the change event\r\n            let oldContent = null;\r\n            ed.on('change keyup', () => {\r\n                const newval = ed.getContent();\r\n                if (newval === oldContent) {\r\n                    return;\r\n                }\r\n\r\n                oldContent = newval;\r\n                if (!hasInit) {\r\n                    return;\r\n                }\r\n\r\n                ed.save();\r\n                this.editorValue = newval;\r\n                this.valueChange.emit(newval);\r\n                // this.context.fireEvent('change', this, newval, oldval, {});\r\n            });\r\n\r\n            ed.on('focus', () => {\r\n                // TODO\r\n            });\r\n\r\n            if (userSetup) {\r\n                userSetup(ed);\r\n            }\r\n        };\r\n    }\r\n\r\n    ShowUploadWindow(): void {\r\n        this._uploader.open();\r\n    }\r\n    ShowOpenFileDialog(doReturn): void {\r\n        const input: any = document.createElement('input');\r\n        input.setAttribute('type', 'file');\r\n        input.setAttribute('accept', 'image/*');\r\n\r\n        input.onchange = () => {\r\n            const file = input.files[0];\r\n\r\n            const reader = new FileReader();\r\n            reader.onload = () => {\r\n                let base64 = reader.result as string;\r\n                base64 = base64.split(',')[1];\r\n                doReturn(null, base64);\r\n            };\r\n            reader.readAsDataURL(file);\r\n        };\r\n\r\n        input.click();\r\n    }\r\n    InsertBase64(base64, doReturn): void {\r\n        this.editor.execCommand('mceInsertContent', false, '<img src=data:image/png;base64,' + base64 + ' />');\r\n        doReturn();\r\n    }\r\n    getValue(): string | null {\r\n        let res = null;\r\n        if (this.wysiwygIntialized) {\r\n            const ed = tinymce.get(this.tinyHostId);\r\n            if (ed) {\r\n                res = ed.getContent();\r\n            }\r\n        }\r\n\r\n        return res;\r\n    }\r\n    setValue(value): void {\r\n        this.value = value;\r\n        this.setValueTiny();\r\n    }\r\n    setValueTiny(): string {\r\n        if (this.wysiwygIntialized) {\r\n            const ed = tinymce.get(this.tinyHostId);\r\n            if (ed) {\r\n                ed.setContent(this.value);\r\n            }\r\n        }\r\n        return this.value;\r\n    }\r\n    focus(): any {\r\n        if (this.isReadonly) {\r\n            return this;\r\n        }\r\n\r\n        if (this.wysiwygIntialized) {\r\n            tinymce.execCommand('mceFocus', false, 'id_of_textarea');\r\n        }\r\n        return this;\r\n    }\r\n\r\n    setEnable(): void {\r\n        if (this.wysiwygIntialized) {\r\n            const ed = tinymce.get(this.tinyHostId);\r\n            ed.getBody().setAttribute('contenteditable', true);\r\n        }\r\n    }\r\n\r\n    setDisable(): void {\r\n        if (this.wysiwygIntialized) {\r\n            const ed = tinymce.get(this.tinyHostId);\r\n            ed.getBody().setAttribute('contenteditable', false);\r\n        }\r\n    }\r\n    setReadOnly(readOnly): void {\r\n        if (this.wysiwygIntialized) {\r\n            const ed = tinymce.get(this.tinyHostId);\r\n            ed.getBody().setAttribute('contenteditable', !readOnly);\r\n            if (readOnly) {\r\n                $('.tox-editor-header').hide();\r\n            } else {\r\n                $('.tox-editor-header').hide();\r\n            }\r\n        }\r\n    }\r\n\r\n    destroyTinymce(): void {\r\n        if (this.Setting.IsHtmlViewer || !this.wysiwygIntialized) {\r\n            return;\r\n        }\r\n        const ed = tinymce.get(this.tinyHostId);\r\n        if (ed) {\r\n            // tinymce.execCommand('mceRemoveControl', true, this.tinyHostId);\r\n            if (ed.iframeElement) {\r\n                ed.iframeElement.removeEventListener('load', this._onLoadIframe);\r\n            }\r\n            ed.destroy(false);\r\n        }\r\n    }\r\n    private uploadFile(files: File[]): Observable<any> {\r\n        return this._uploadService.compressFiles$(files).pipe(\r\n            concatMap((formData: FormData) =>\r\n                this._uploadService.upload(formData, this.Setting.StorageFileFieldId).pipe(\r\n                    tap((res) => {\r\n                        if (Array.isArray(res)) {\r\n                            const picture = res[0];\r\n                            if (picture.ErrorMsg) {\r\n                                BarsaApi.Bw.Msg.Error(picture.ErrorMsg);\r\n                                return;\r\n                            }\r\n                            const value = {\r\n                                ...picture,\r\n                                FileId: picture.FileId\r\n                            };\r\n                            this._addImages(value);\r\n                        }\r\n                    })\r\n                )\r\n            )\r\n        );\r\n    }\r\n    private _addImages(file: { FileId: string }): void {\r\n        const url = '/IH.ashx?ty=StorageFile&key=' + file.FileId;\r\n        const html = '<img src=' + url + ' />';\r\n\r\n        this.editor.execCommand('mceInsertContent', false, html);\r\n    }\r\n    private prepare(): void {\r\n        this.initilize();\r\n        tinymce.init(this.tinyMCEConfig);\r\n        this.intializationInProgress = false;\r\n        this.wysiwygIntialized = true;\r\n    }\r\n    private _onLoadIframe = (): void => {\r\n        this.value = this.editorValue;\r\n        // const ed = tinymce.get(this.tinyHostId);\r\n        // ed.execCommand('mceInsertContent', false, this.value);\r\n\r\n        // ed.insertContent(this.value, { format: 'raw' });\r\n        // this._removeOverflow(ed);\r\n        this.destroyTinymce();\r\n        this.prepare();\r\n    };\r\n    private _generateTinyHostId(): string {\r\n        return `a_${getUniqueId(2)}`;\r\n    }\r\n\r\n    private _removeOverflow(ed: any): void {\r\n        const html = ed.iframeElement?.contentDocument?.querySelector('html');\r\n        if (html) {\r\n            html.style.overflow = 'hidden';\r\n        }\r\n    }\r\n}\r\n","<div\r\n    class=\"fd-input tinywrapper\"\r\n    [style.min-height.px]=\"height\"\r\n    [id]=\"tinyHostId\"\r\n    intersectionObserver\r\n    [intersectionThreshold]=\"0.1\"\r\n    (visibilityChange)=\"onVisibilityChange($event)\"\r\n></div>\r\n<fd-file-uploader\r\n    #uploader\r\n    [style.display]=\"'none'\"\r\n    [accept]=\"''\"\r\n    [multiple]=\"false\"\r\n    (selectedFilesChanged)=\"onFileSelection($event)\"\r\n></fd-file-uploader>\r\n<!-- <textarea [id]=\"tinyHostId\" style=\"height: 100%; visibility: hidden\"></textarea> -->\r\n"]}
419
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"barsa-tinyemce.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-sap-ui/src/lib/barsa-tinyemce/barsa-tinyemce.component.ts","../../../../../projects/barsa-sap-ui/src/lib/barsa-tinyemce/barsa-tinyemce.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    AfterViewInit,\r\n    ChangeDetectionStrategy,\r\n    Component,\r\n    ElementRef,\r\n    EventEmitter,\r\n    inject,\r\n    Input,\r\n    OnChanges,\r\n    OnDestroy,\r\n    Output,\r\n    SimpleChanges,\r\n    ViewChild\r\n} from '@angular/core';\r\nimport { FileUploaderComponent } from '@fundamental-ngx/core';\r\nimport { Observable, concatMap, takeUntil, tap } from 'rxjs';\r\n\r\nimport {\r\n    BaseComponent,\r\n    BarsaApi,\r\n    getUniqueId,\r\n    isFunction,\r\n    UploadService,\r\n    GeneralControlInfoModel\r\n} from 'barsa-novin-ray-core';\r\n\r\ndeclare const window: any;\r\ndeclare const tinymce: any;\r\ndeclare const head: any;\r\ndeclare const $: any;\r\n@Component({\r\n    selector: 'bsu-barsa-tinyemce',\r\n    templateUrl: './barsa-tinyemce.component.html',\r\n    styleUrls: ['./barsa-tinyemce.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    providers: [UploadService],\r\n    standalone: false\r\n})\r\nexport class BarsaTinyemceComponent extends BaseComponent implements AfterViewInit, OnDestroy, OnChanges {\r\n    @ViewChild('uploader') _uploader: FileUploaderComponent;\r\n    @Input() Setting: GeneralControlInfoModel;\r\n    @Input() isReadonly: boolean;\r\n    @Input() value: any;\r\n    @Input() IsInline: boolean;\r\n    @Input() defaultVerbs: { Title: string; Html: string }[];\r\n    @Output() valueChange = new EventEmitter<any>();\r\n    @Output() tinyInit = new EventEmitter();\r\n    tinyHostId = this._generateTinyHostId();\r\n    tinyMCEConfig: any = {};\r\n    editor: any;\r\n    wysiwygIntialized: boolean;\r\n    intializationInProgress: boolean;\r\n    editorValue: string;\r\n    iframBodyInnerHtml: string;\r\n    height: number;\r\n    protected _uploadService = inject(UploadService);\r\n    protected _el = inject(ElementRef);\r\n\r\n    ngOnChanges(simpleChanges: SimpleChanges): void {\r\n        super.ngOnChanges(simpleChanges);\r\n        if (simpleChanges.value && !simpleChanges.value.firstChange) {\r\n            this.setValue(simpleChanges.value.currentValue);\r\n        }\r\n        if (simpleChanges.disable && !simpleChanges.disable.firstChange) {\r\n            const disbale = simpleChanges.disable.currentValue;\r\n            if (disbale) {\r\n                this.setDisable();\r\n            } else {\r\n                this.setEnable();\r\n            }\r\n        }\r\n        if (simpleChanges.readonly && !simpleChanges.readonly.firstChange) {\r\n            this.setReadOnly(simpleChanges.readonly.currentValue);\r\n        }\r\n    }\r\n    ngOnInit(): void {\r\n        super.ngOnInit();\r\n        this.height = (this._el.nativeElement as HTMLElement).clientHeight;\r\n    }\r\n\r\n    ngOnDestroy(): void {\r\n        super.ngOnDestroy();\r\n        this.destroyTinymce();\r\n    }\r\n\r\n    onFileSelection(files: File[]): void {\r\n        this.uploadFile(files).pipe(takeUntil(this._onDestroy$)).subscribe();\r\n    }\r\n    loadTinyMce(): void {\r\n        if (!this.Setting.IsHtmlViewer) {\r\n            head.load(['Lib/tinymce/tinymce.min.js'], () => {\r\n                setTimeout(() => {\r\n                    this.prepare();\r\n                });\r\n            });\r\n        }\r\n    }\r\n    onVisibilityChange(e): void {\r\n        if (e === 'Visible') {\r\n            this.loadTinyMce();\r\n        }\r\n    }\r\n    initilize(): void {\r\n        if (this.tinyMCEConfig.setup) {\r\n            return;\r\n        }\r\n        this.tinyMCEConfig.height = '100%';\r\n        this.tinyMCEConfig.width = '100%';\r\n        this.tinyMCEConfig.selector = '#' + this.tinyHostId;\r\n        this.tinyMCEConfig.placeholder = this.Setting.ControlFieldCaptionTranslated;\r\n        this.tinyMCEConfig.content_css = 'assets/Resources/fonts/Iran.css';\r\n        this.tinyMCEConfig.content_style = `body > p { overflow:auto }`;\r\n        this.tinyMCEConfig.directionality = 'rtl';\r\n        this.tinyMCEConfig.language = 'fa_IR';\r\n        this.tinyMCEConfig.promotion = false;\r\n        this.tinyMCEConfig.skin = 'oxide';\r\n        this.tinyMCEConfig.paste_data_images = true;\r\n        this.tinyMCEConfig.defaultFontName = 'B-Font';\r\n        this.tinyMCEConfig.defaultFontSize = '12px';\r\n        this.tinyMCEConfig.statusbar = false;\r\n        this.tinyMCEConfig.resize = false;\r\n\r\n        this.tinyMCEConfig.inline = false;\r\n        this.tinyMCEConfig.menubar = false;\r\n        this.tinyMCEConfig.toolbar_location = 'top';\r\n\r\n        this.tinyMCEConfig.toolbar_mode = 'floating';\r\n        // this.tinyMCEConfig.toolbar_sticky = true;\r\n        // this.tinyMCEConfig.toolbar_sticky_offset = 100;\r\n        this.tinyMCEConfig.font_family_formats =\r\n            'B-Font=B-Font;Arial=arial,helvetica,sans-serif; Courier New=courier new,courier,monospace;';\r\n        this.tinyMCEConfig.font_size_formats = '8pt 10pt 12pt 14pt 18pt 24pt 36pt';\r\n\r\n        this.tinyMCEConfig.plugins = [\r\n            'advlist',\r\n            'anchor',\r\n            'autolink',\r\n            'autosave',\r\n            'charmap',\r\n            'code',\r\n            'codesample',\r\n            'directionality',\r\n            'emoticons',\r\n            'fullscreen',\r\n            'help',\r\n            'image',\r\n            'importcss',\r\n            'insertdatetime',\r\n            'link',\r\n            'lists',\r\n            'media',\r\n            'nonbreaking',\r\n            'pagebreak',\r\n            'preview',\r\n            'quickbars',\r\n            'save',\r\n            'searchreplace',\r\n            'table',\r\n            'template',\r\n            'visualblocks',\r\n            'visualchars',\r\n            'wordcount',\r\n            'autoresize'\r\n        ];\r\n        this.tinyMCEConfig.toolbar =\r\n            `defaultVerbs barsaImage | insert | forecolor backcolor fontfamily fontsize | bullist numlist outdent indent | removeformat` +\r\n            ` | undo redo | copy cut paste | blocks | bold italic | alignleft aligncenter alignright alignjustify ltr rtl`;\r\n\r\n        this.tinyMCEConfig.quickbars_selection_toolbar =\r\n            'bold italic fontsize | forecolor backcolor|defaultVerbs barsaImage';\r\n        const tinymceSettingsGlobal = window.tinymceSettings;\r\n        let tinymceSettings = BarsaApi.Common.Util.TryGetValue(this.Setting, 'JsonExtraProp.tinymceSettings');\r\n        tinymceSettings = BarsaApi.Common.Merger.Merge(tinymceSettingsGlobal, tinymceSettings);\r\n        if (!tinymceSettings && Array.isArray(tinymceSettings)) {\r\n            for (const item of tinymceSettings) {\r\n                this.tinyMCEConfig[item.key] = item.value;\r\n            }\r\n        }\r\n\r\n        if (this.isReadonly) {\r\n            this.tinyMCEConfig.menubar = false;\r\n            this.tinyMCEConfig.statusbar = false;\r\n            this.tinyMCEConfig.plugins = ['autoresize'];\r\n            // this.tinyMCEConfig.plugins = [];\r\n            this.tinyMCEConfig.toolbar = false;\r\n        }\r\n\r\n        let userSetup: (editor: any) => void;\r\n\r\n        if (this.tinyMCEConfig.setup) {\r\n            userSetup = this.tinyMCEConfig.setup;\r\n        }\r\n        let defaultVerbsMenu: any = [];\r\n\r\n        // BEGIN: setup\r\n        this.tinyMCEConfig.setup = (ed) => {\r\n            this.editor = ed;\r\n            if (!this.isReadonly) {\r\n                if (this.defaultVerbs) {\r\n                    defaultVerbsMenu = [];\r\n                    this.defaultVerbs.forEach((item) => {\r\n                        defaultVerbsMenu.push({\r\n                            value: item.Html,\r\n                            type: 'menuitem',\r\n                            text: item.Title || item.Html.replace(/<br\\s*\\/?>/gi, ' '),\r\n                            onAction: () => {\r\n                                // ed.execCommand('mceInsertRawHTML', false, item.Html);\r\n                                ed.insertContent(item.Html, { format: 'raw' });\r\n                            }\r\n                        });\r\n                    });\r\n                }\r\n                ed.ui.registry.addSplitButton('barsaImage', {\r\n                    text: 'insert',\r\n                    icon: 'image',\r\n                    tooltip: 'Insert Image As Base64',\r\n                    onAction: () => {\r\n                        BarsaApi.Common.Async.Waterfall(\r\n                            'Tinemce.EmbedImage',\r\n                            {\r\n                                openFileDialog: this.ShowOpenFileDialog.bind(this),\r\n                                insertBase64: this.InsertBase64.bind(this)\r\n                            },\r\n                            (err, result) => {\r\n                                BarsaApi.Common.Async.Finalize(err, result);\r\n                            }\r\n                        );\r\n                    },\r\n                    onItemAction: () => {\r\n                        BarsaApi.Common.Async.Waterfall(\r\n                            'Tinemce.UploadToDatabase',\r\n                            {\r\n                                openFileDialog: this.ShowUploadWindow.bind(this)\r\n                            },\r\n                            (err, result) => {\r\n                                BarsaApi.Common.Async.Finalize(err, result);\r\n                            }\r\n                        );\r\n                    },\r\n                    fetch: (callback) => {\r\n                        const items = [\r\n                            {\r\n                                type: 'choiceitem',\r\n                                text: 'upload',\r\n                                icon: 'image',\r\n                                tooltip: 'Upload Image',\r\n                                value: 'upload'\r\n                            }\r\n                        ];\r\n                        callback(items);\r\n                    }\r\n                });\r\n\r\n                ed.ui.registry.addMenuButton('defaultVerbs', {\r\n                    text: 'عبارتهای پیش فرض',\r\n                    fetch: (callback) => {\r\n                        callback(defaultVerbsMenu);\r\n                    }\r\n                });\r\n                if (isFunction(window.tinymceSetup)) {\r\n                    window.tinymceSetup.call(this, this, ed);\r\n                }\r\n            }\r\n            let hasInit = false;\r\n            ed.on('init', () => {\r\n                this.wysiwygIntialized = true;\r\n                this.intializationInProgress = false;\r\n                if (typeof this.value !== 'undefined') {\r\n                    this.setValue(this.value);\r\n                }\r\n                if (this.tinyMCEConfig.defaultFontName) {\r\n                    ed.execCommand('FontName', false, this.tinyMCEConfig.defaultFontName);\r\n                }\r\n                if (this.tinyMCEConfig.defaultFontSize) {\r\n                    ed.execCommand('FontSize', false, this.tinyMCEConfig.defaultFontSize);\r\n                }\r\n                if (this.isReadonly) {\r\n                    this.setReadOnly(this.isReadonly);\r\n                }\r\n                // This piece of code solves the problem of change propagation so that\r\n                // there is no need to call triggerSave\r\n                const setContent = ed.setContent;\r\n                ed.setContent = (...args) => {\r\n                    setContent.apply(ed, args);\r\n                    ed.dispatch('change', {});\r\n                };\r\n                hasInit = true;\r\n                this.tinyInit.emit();\r\n                const iframEl: HTMLIFrameElement = ed.iframeElement;\r\n                if (iframEl) {\r\n                    iframEl.addEventListener('load', this._onLoadIframe);\r\n                }\r\n            });\r\n\r\n            // Catch and propagate the change event\r\n            let oldContent = null;\r\n            ed.on('change keyup', () => {\r\n                const newval = ed.getContent();\r\n                if (newval === oldContent) {\r\n                    return;\r\n                }\r\n\r\n                oldContent = newval;\r\n                if (!hasInit) {\r\n                    return;\r\n                }\r\n\r\n                ed.save();\r\n                this.editorValue = newval;\r\n                this.valueChange.emit(newval);\r\n                // this.context.fireEvent('change', this, newval, oldval, {});\r\n            });\r\n\r\n            ed.on('focus', () => {\r\n                // TODO\r\n            });\r\n\r\n            if (userSetup) {\r\n                userSetup(ed);\r\n            }\r\n        };\r\n    }\r\n\r\n    ShowUploadWindow(): void {\r\n        this._uploader.open();\r\n    }\r\n    ShowOpenFileDialog(doReturn): void {\r\n        const input: any = document.createElement('input');\r\n        input.setAttribute('type', 'file');\r\n        input.setAttribute('accept', 'image/*');\r\n\r\n        input.onchange = () => {\r\n            const file = input.files[0];\r\n\r\n            const reader = new FileReader();\r\n            reader.onload = () => {\r\n                let base64 = reader.result as string;\r\n                base64 = base64.split(',')[1];\r\n                doReturn(null, base64);\r\n            };\r\n            reader.readAsDataURL(file);\r\n        };\r\n\r\n        input.click();\r\n    }\r\n    InsertBase64(base64, doReturn): void {\r\n        this.editor.execCommand('mceInsertContent', false, '<img src=data:image/png;base64,' + base64 + ' />');\r\n        doReturn();\r\n    }\r\n    getValue(): string | null {\r\n        let res = null;\r\n        if (this.wysiwygIntialized) {\r\n            const ed = tinymce.get(this.tinyHostId);\r\n            if (ed) {\r\n                res = ed.getContent();\r\n            }\r\n        }\r\n\r\n        return res;\r\n    }\r\n    setValue(value): void {\r\n        this.value = value;\r\n        this.setValueTiny();\r\n    }\r\n    setValueTiny(): string {\r\n        if (this.wysiwygIntialized) {\r\n            const ed = tinymce.get(this.tinyHostId);\r\n            if (ed) {\r\n                ed.setContent(this.value);\r\n            }\r\n        }\r\n        return this.value;\r\n    }\r\n    focus(): any {\r\n        if (this.isReadonly) {\r\n            return this;\r\n        }\r\n\r\n        if (this.wysiwygIntialized) {\r\n            tinymce.execCommand('mceFocus', false, 'id_of_textarea');\r\n        }\r\n        return this;\r\n    }\r\n\r\n    setEnable(): void {\r\n        if (this.wysiwygIntialized) {\r\n            const ed = tinymce.get(this.tinyHostId);\r\n            ed.getBody().setAttribute('contenteditable', true);\r\n        }\r\n    }\r\n\r\n    setDisable(): void {\r\n        if (this.wysiwygIntialized) {\r\n            const ed = tinymce.get(this.tinyHostId);\r\n            ed.getBody().setAttribute('contenteditable', false);\r\n        }\r\n    }\r\n    setReadOnly(readOnly): void {\r\n        if (this.wysiwygIntialized) {\r\n            const ed = tinymce.get(this.tinyHostId);\r\n            ed.getBody().setAttribute('contenteditable', !readOnly);\r\n            if (readOnly) {\r\n                $('.tox-editor-header').hide();\r\n            } else {\r\n                $('.tox-editor-header').hide();\r\n            }\r\n        }\r\n    }\r\n\r\n    destroyTinymce(): void {\r\n        if (this.Setting.IsHtmlViewer || !this.wysiwygIntialized) {\r\n            return;\r\n        }\r\n        const ed = tinymce.get(this.tinyHostId);\r\n        if (ed) {\r\n            // tinymce.execCommand('mceRemoveControl', true, this.tinyHostId);\r\n            if (ed.iframeElement) {\r\n                ed.iframeElement.removeEventListener('load', this._onLoadIframe);\r\n            }\r\n            ed.destroy(false);\r\n        }\r\n    }\r\n    private uploadFile(files: File[]): Observable<any> {\r\n        return this._uploadService.compressFiles$(files).pipe(\r\n            concatMap((formData: FormData) =>\r\n                this._uploadService.upload(formData, this.Setting.StorageFileFieldId).pipe(\r\n                    tap((res) => {\r\n                        if (Array.isArray(res)) {\r\n                            const picture = res[0];\r\n                            if (picture.ErrorMsg) {\r\n                                BarsaApi.Bw.Msg.Error(picture.ErrorMsg);\r\n                                return;\r\n                            }\r\n                            const value = {\r\n                                ...picture,\r\n                                FileId: picture.FileId\r\n                            };\r\n                            this._addImages(value);\r\n                        }\r\n                    })\r\n                )\r\n            )\r\n        );\r\n    }\r\n    private _addImages(file: { FileId: string }): void {\r\n        const url = '/IH.ashx?ty=StorageFile&key=' + file.FileId;\r\n        const html = '<img src=' + url + ' />';\r\n\r\n        this.editor.execCommand('mceInsertContent', false, html);\r\n    }\r\n    private prepare(): void {\r\n        this.initilize();\r\n        tinymce.init(this.tinyMCEConfig);\r\n        this.intializationInProgress = false;\r\n        this.wysiwygIntialized = true;\r\n    }\r\n    private _onLoadIframe = (): void => {\r\n        this.value = this.editorValue;\r\n        // const ed = tinymce.get(this.tinyHostId);\r\n        // ed.execCommand('mceInsertContent', false, this.value);\r\n\r\n        // ed.insertContent(this.value, { format: 'raw' });\r\n        // this._removeOverflow(ed);\r\n        this.destroyTinymce();\r\n        this.prepare();\r\n    };\r\n    private _generateTinyHostId(): string {\r\n        return `a_${getUniqueId(2)}`;\r\n    }\r\n\r\n    private _removeOverflow(ed: any): void {\r\n        const html = ed.iframeElement?.contentDocument?.querySelector('html');\r\n        if (html) {\r\n            html.style.overflow = 'hidden';\r\n        }\r\n    }\r\n}\r\n","<div\r\n    class=\"fd-input tinywrapper\"\r\n    [style.min-height.px]=\"height\"\r\n    [id]=\"tinyHostId\"\r\n    intersectionObserver\r\n    [intersectionThreshold]=\"0.1\"\r\n    (visibilityChange)=\"onVisibilityChange($event)\"\r\n></div>\r\n<fd-file-uploader\r\n    #uploader\r\n    [style.display]=\"'none'\"\r\n    [accept]=\"''\"\r\n    [multiple]=\"false\"\r\n    (selectedFilesChanged)=\"onFileSelection($event)\"\r\n></fd-file-uploader>\r\n<!-- <textarea [id]=\"tinyHostId\" style=\"height: 100%; visibility: hidden\"></textarea> -->\r\n"]}
@@ -96,7 +96,7 @@ export class BarsaTreeItemComponent extends BaseViewItemPropsComponent {
96
96
  this.dragMoved.emit($event);
97
97
  }
98
98
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: BarsaTreeItemComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
99
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: BarsaTreeItemComponent, selector: "bsu-barsa-tree-item", inputs: { node: "node", selectedNode: "selectedNode", relationList: "relationList", hideOpenIcon: "hideOpenIcon", hasArrowIcon: "hasArrowIcon", collapseIcon: "collapseIcon", loading: "loading", hasChildren: "hasChildren", leafCursorPointer: "leafCursorPointer", isExpand: "isExpand", children: "children", parentNode: "parentNode", text: "text", icon: "icon", color: "color", isHetro: "isHetro", enableNodeReordering: "enableNodeReordering", hideIcon: "hideIcon" }, outputs: { createNew: "createNew", select: "select", checkChange: "checkChange", viewClick: "viewClick", loadChildren: "loadChildren", dragMoved: "dragMoved" }, usesInheritance: true, ngImport: i0, template: "<li\r\n fd-list-item\r\n #liEl\r\n [class.!tw-cursor-pointer]=\"leafCursorPointer\"\r\n [applyConditionalFormats]=\"conditionalFormats\"\r\n [styleIndex]=\"styleIndex\"\r\n [hostEl]=\"liEl\"\r\n [focusable]=\"true\"\r\n [attr.level]=\"level\"\r\n [class.root-group]=\"level === 1\"\r\n [interactive]=\"true\"\r\n [selected]=\"isChecked\"\r\n (dblclick)=\"onNodeViewClick()\"\r\n cdkDrag\r\n [cdkDragDisabled]=\"!enableNodeReordering\"\r\n [cdkDragData]=\"node.Data.Id\"\r\n [class.isdirty]=\"isdirty\"\r\n (cdkDragMoved)=\"onDragMoved($event)\"\r\n (click)=\"openOnClick ? onNodeViewClick() : onListItemClick(liEl, $event)\"\r\n>\r\n <div (click)=\"onRowCheck()\" class=\"spacer\" [style.width]=\"(level - 1) * 4 + 'rem'\"></div>\r\n @if (enableNodeReordering && !isHetro) {\r\n <fd-icon glyph=\"grip\" font=\"BusinessSuiteInAppSymbols\" cdkDragHandle></fd-icon>\r\n } @if (inDialog && isMultiSelect) {\r\n <fd-checkbox [name]=\"node.Data.$Caption\" [ngModel]=\"isChecked\" (ngModelChange)=\"onCheckbox($event)\"></fd-checkbox>\r\n }\r\n\r\n <div (click)=\"onRowCheck()\" style=\"display: flex; width: 100%; justify-content: space-between\">\r\n <div style=\"display: flex; flex: 1; gap: 3px\">\r\n @if (hasArrowIcon) { @if (hasChildren) {\r\n <div class=\"arrow-container\">\r\n <button\r\n [attr.rtl]=\"rtl\"\r\n fd-button\r\n fdType=\"transparent\"\r\n class=\"arrow-children\"\r\n [fdCompact]\r\n [glyph]=\"hasChildren ? (isExpand ? 'slim-arrow-down' : collapseIcon) : ''\"\r\n (click)=\"onLoadChildren($event)\"\r\n (dblclick)=\"onExpandDblClick($event)\"\r\n ></button>\r\n </div>\r\n } @else { @if (!parentNode?.hasOneDepthLevel) {\r\n <div class=\"empty-container\" (click)=\"onRowCheck()\">\r\n <button fd-button></button>\r\n </div>\r\n } } @if (loading) {\r\n <fd-busy-indicator\r\n style=\"display: flex; align-items: center; width: 2rem\"\r\n size=\"s\"\r\n [loading]=\"true\"\r\n ></fd-busy-indicator>\r\n } @if(!hideIcon || appComponentIcon){ @if(icon || appComponentIcon){\r\n <i\r\n [style.color]=\"appComponentIconColor || color\"\r\n class=\"icon-item\"\r\n fd-list-icon\r\n [glyph]=\"appComponentIcon || icon\"\r\n ></i>\r\n }@else {\r\n <i fd-list-icon class=\"icon-item\" style=\"display: flex; align-items: center; justify-content: center\">\r\n <img [src]=\"node.icon\" width=\"16px\" />\r\n </i>\r\n } } }\r\n <div\r\n style=\"display: flex; flex: unset; align-items: center\"\r\n fd-list-title\r\n [focusable]=\"true\"\r\n #divEl\r\n [style.color]=\"styleIndex ? 'inherit' : color\"\r\n intersectionObserver\r\n [intersectionThreshold]=\"0.1\"\r\n (visibilityChange)=\"onVisibilityChange(divEl, spanEl, $event)\"\r\n >\r\n <span\r\n class=\"ellapsis\"\r\n #spanEl\r\n [style.color]=\"styleIndex ? 'inherit' : color\"\r\n [class.haschildren]=\"hasChildren\"\r\n >{{ text }}</span\r\n >\r\n @if (children) {\r\n <span>{{ ' ( ' + children.length + ' )' }}</span>\r\n }\r\n </div>\r\n </div>\r\n @if (contextMenuItems && contextMenuItems.length > 0) {\r\n <i\r\n ulvContextMenu\r\n [allColumns]=\"allColumns\"\r\n [menuItems]=\"contextMenuItems\"\r\n [conditionalFormats]=\"conditionalFormats\"\r\n [styleIndex]=\"styleIndex\"\r\n [disableOverflowContextMenu]=\"disableOverflowContextMenu\"\r\n [mo]=\"node.Data\"\r\n [index]=\"index\"\r\n (commandClick)=\"onUlvCommand()\"\r\n [deviceName]=\"deviceName\"\r\n ></i>\r\n } @if (access?.Add !== false && !inDialog) {\r\n <bsu-htree-create-new\r\n [node]=\"node\"\r\n [relationList]=\"relationList\"\r\n (createNew)=\"onCreateNew($event)\"\r\n ></bsu-htree-create-new>\r\n }\r\n </div>\r\n @if (access?.View && !showOkCancelButtons && deviceName !== 'desktop' && !hideOpenIcon) {\r\n <button fd-button [glyph]=\"navigationArrow\" fdType=\"transparent\" (click)=\"onNodeViewClick()\"></button>\r\n } @if (actionList?.length && !inlineEditMode) {\r\n <bsu-barsa-row-inline-actionlist\r\n [actionList]=\"actionList\"\r\n (btnClick)=\"actionListClick.emit($event)\"\r\n ></bsu-barsa-row-inline-actionlist>\r\n }\r\n\r\n <bsu-barsa-tree-item\r\n *cdkDragPreview\r\n [node]=\"node\"\r\n [rtl]=\"rtl\"\r\n [selectedNode]=\"selectedNode\"\r\n [hasArrowIcon]=\"false\"\r\n ></bsu-barsa-tree-item>\r\n</li>\r\n", styles: [":host{display:contents}li.isdirty{background:url(/Lib/ui/resources/images/default/grid/dirty.gif);background-repeat:no-repeat}li .cdk-drag-handle{opacity:.5;cursor:move}li .spacer{height:100%}li .arrow-children{border:none!important;background:transparent!important;color:var(--sapButton_Lite_TextColor)!important}li .arrow-container,li .empty-container{display:flex;width:28px;align-items:center;justify-content:center}li .arrow-container fd-icon,li .empty-container fd-icon{cursor:pointer;width:100%;height:100%;text-align:center}li .empty-container{visibility:hidden!important}.cdk-drag{cursor:default}.tree-icon-children{cursor:pointer}.icon-item{width:1rem}\n"], dependencies: [{ kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i2.IntersectionObserverDirective, selector: "[intersectionObserver]", inputs: ["intersectionDebounce", "intersectionRootMargin", "intersectionRoot", "intersectionThreshold"], outputs: ["visibilityChange"] }, { kind: "directive", type: i3.CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer", "cdkDragScale"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }, { kind: "directive", type: i3.CdkDragHandle, selector: "[cdkDragHandle]", inputs: ["cdkDragHandleDisabled"] }, { kind: "directive", type: i3.CdkDragPreview, selector: "ng-template[cdkDragPreview]", inputs: ["data", "matchSize"] }, { kind: "directive", type: i4.ContentDensityDirective, selector: "[fdContentDensity]:not([fdCompact]):not([fdCondensed]):not([fdCozy]), [fdCompact]:not([fdContentDensity]):not([fdCondensed]):not([fdCozy]), [fdCondensed]:not([fdContentDensity]):not([fdCompact]):not([fdCozy]), [fdCozy]:not([fdContentDensity]):not([fdCompact]):not([fdCondensed])", inputs: ["fdContentDensity", "fdCompact", "fdCondensed", "fdCozy"], exportAs: ["fdContentDensity"] }, { kind: "component", type: i5.BusyIndicatorComponent, selector: "fd-busy-indicator", inputs: ["loading", "size", "block", "ariaLabel", "title", "label", "ariaLive"] }, { kind: "component", type: i6.ButtonComponent, selector: "button[fd-button], a[fd-button], span[fd-button]", inputs: ["class"], exportAs: ["fd-button"] }, { kind: "component", type: i7.CheckboxComponent, selector: "fd-checkbox", inputs: ["wrapLabel", "valignLabel", "ariaLabel", "role", "value", "ariaLabelledBy", "ariaDescribedBy", "title", "inputId", "state", "name", "label", "disabled", "readonly", "tristate", "tristateSelectable", "labelClass", "required", "displayOnly", "values", "standalone"], outputs: ["focusChange"] }, { kind: "component", type: i8.IconComponent, selector: "fd-icon", inputs: ["glyph", "font", "color", "background", "class", "ariaLabel", "ariaHidden"] }, { kind: "component", type: i9.ListItemComponent, selector: "[fdListItem] ,[fd-list-item]", inputs: ["selected", "noData", "action", "interactive", "growing", "counter", "unread", "byline", "ariaRole", "id"], outputs: ["keyDown"] }, { kind: "directive", type: i9.ListTitleDirective, selector: "[fd-list-title], [fdListTitle]", inputs: ["wrap"] }, { kind: "directive", type: i9.ListIconDirective, selector: "[fdListIcon], [fd-list-icon]", inputs: ["glyph", "glyphFont", "class", "role", "ariaHidden"] }, { kind: "component", type: i10.UlvContextMenuComponent, selector: "bsu-ulv-context-menu,[ulvContextMenu]", inputs: ["onlyOverflow", "rightClickEnable", "deviceName", "menuItems", "allColumns", "index", "mo", "styleIndex", "conditionalFormats", "disableOverflowContextMenu", "footerMode", "contextMenuOverflowText", "appendTo"], outputs: ["commandClick"] }, { kind: "component", type: BarsaTreeItemComponent, selector: "bsu-barsa-tree-item", inputs: ["node", "selectedNode", "relationList", "hideOpenIcon", "hasArrowIcon", "collapseIcon", "loading", "hasChildren", "leafCursorPointer", "isExpand", "children", "parentNode", "text", "icon", "color", "isHetro", "enableNodeReordering", "hideIcon"], outputs: ["createNew", "select", "checkChange", "viewClick", "loadChildren", "dragMoved"] }, { kind: "component", type: i11.HtreeCreateNewComponent, selector: "bsu-htree-create-new", inputs: ["relationList", "node"], outputs: ["createNew"] }, { kind: "component", type: i12.BarsaRowInlineActionlistComponent, selector: "bsu-barsa-row-inline-actionlist", inputs: ["actionList", "mo", "index"], outputs: ["btnClick"] }, { kind: "directive", type: i13.ApplyConditionalFormatsDirective, selector: "[applyConditionalFormats]", inputs: ["applyConditionalFormats", "styleIndex", "hostEl", "dbName"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
99
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: BarsaTreeItemComponent, selector: "bsu-barsa-tree-item", inputs: { node: "node", selectedNode: "selectedNode", relationList: "relationList", hideOpenIcon: "hideOpenIcon", hasArrowIcon: "hasArrowIcon", collapseIcon: "collapseIcon", loading: "loading", hasChildren: "hasChildren", leafCursorPointer: "leafCursorPointer", isExpand: "isExpand", children: "children", parentNode: "parentNode", text: "text", icon: "icon", color: "color", isHetro: "isHetro", enableNodeReordering: "enableNodeReordering", hideIcon: "hideIcon" }, outputs: { createNew: "createNew", select: "select", checkChange: "checkChange", viewClick: "viewClick", loadChildren: "loadChildren", dragMoved: "dragMoved" }, usesInheritance: true, ngImport: i0, template: "<li\r\n fd-list-item\r\n #liEl\r\n [class.!tw-cursor-pointer]=\"leafCursorPointer\"\r\n [applyConditionalFormats]=\"conditionalFormats\"\r\n [styleIndex]=\"styleIndex\"\r\n [hostEl]=\"liEl\"\r\n [focusable]=\"true\"\r\n [attr.level]=\"level\"\r\n [class.root-group]=\"level === 1\"\r\n [interactive]=\"true\"\r\n [selected]=\"isChecked\"\r\n (dblclick)=\"onNodeViewClick()\"\r\n cdkDrag\r\n [cdkDragDisabled]=\"!enableNodeReordering\"\r\n [cdkDragData]=\"node.Data.Id\"\r\n [class.isdirty]=\"isdirty\"\r\n (cdkDragMoved)=\"onDragMoved($event)\"\r\n (click)=\"openOnClick ? onNodeViewClick() : onListItemClick(liEl, $event)\"\r\n>\r\n <div (click)=\"onRowCheck()\" class=\"spacer\" [style.width]=\"(level - 1) * 4 + 'rem'\"></div>\r\n @if (enableNodeReordering && !isHetro) {\r\n <fd-icon glyph=\"grip\" font=\"BusinessSuiteInAppSymbols\" cdkDragHandle></fd-icon>\r\n } @if (inDialog && isMultiSelect) {\r\n <fd-checkbox [name]=\"node.Data.$Caption\" [ngModel]=\"isChecked\" (ngModelChange)=\"onCheckbox($event)\"></fd-checkbox>\r\n }\r\n\r\n <div (click)=\"onRowCheck()\" style=\"display: flex; width: 100%; justify-content: space-between\">\r\n <div style=\"display: flex; flex: 1; gap: 3px\">\r\n @if (hasArrowIcon) { @if (hasChildren) {\r\n <div class=\"arrow-container\">\r\n <button\r\n [attr.rtl]=\"rtl\"\r\n fd-button\r\n fdType=\"transparent\"\r\n class=\"arrow-children\"\r\n [fdCompact]\r\n [glyph]=\"hasChildren ? (isExpand ? 'slim-arrow-down' : collapseIcon) : ''\"\r\n (click)=\"onLoadChildren($event)\"\r\n (dblclick)=\"onExpandDblClick($event)\"\r\n ></button>\r\n </div>\r\n } @else { @if (!parentNode?.hasOneDepthLevel) {\r\n <div class=\"empty-container\" (click)=\"onRowCheck()\">\r\n <button fd-button></button>\r\n </div>\r\n } } @if (loading) {\r\n <fd-busy-indicator\r\n style=\"display: flex; align-items: center; width: 2rem\"\r\n size=\"s\"\r\n [loading]=\"true\"\r\n ></fd-busy-indicator>\r\n } @if(!hideIcon || appComponentIcon){ @if(icon || appComponentIcon){\r\n <i\r\n [style.color]=\"appComponentIconColor || color\"\r\n class=\"icon-item\"\r\n fd-list-icon\r\n [glyph]=\"appComponentIcon || icon\"\r\n ></i>\r\n }@else {\r\n <i fd-list-icon class=\"icon-item\" style=\"display: flex; align-items: center; justify-content: center\">\r\n <img [src]=\"node.icon\" width=\"16px\" />\r\n </i>\r\n } } }\r\n <div\r\n style=\"display: flex; flex: unset; align-items: center\"\r\n fd-list-title\r\n [focusable]=\"true\"\r\n #divEl\r\n [style.color]=\"styleIndex ? 'inherit' : color\"\r\n intersectionObserver\r\n [intersectionThreshold]=\"0.1\"\r\n (visibilityChange)=\"onVisibilityChange(divEl, spanEl, $event)\"\r\n >\r\n <span\r\n class=\"ellapsis\"\r\n #spanEl\r\n [style.color]=\"styleIndex ? 'inherit' : color\"\r\n [class.haschildren]=\"hasChildren\"\r\n >{{ text }}</span\r\n >\r\n @if (children) {\r\n <span>{{ ' ( ' + children.length + ' )' }}</span>\r\n }\r\n </div>\r\n </div>\r\n @if (contextMenuItems && contextMenuItems.length > 0) {\r\n <i\r\n ulvContextMenu\r\n [allColumns]=\"allColumns\"\r\n [menuItems]=\"contextMenuItems\"\r\n [conditionalFormats]=\"conditionalFormats\"\r\n [styleIndex]=\"styleIndex\"\r\n [disableOverflowContextMenu]=\"disableOverflowContextMenu\"\r\n [mo]=\"node.Data\"\r\n [index]=\"index\"\r\n (commandClick)=\"onUlvCommand()\"\r\n [deviceName]=\"deviceName\"\r\n ></i>\r\n } @if (access?.Add !== false && !inDialog) {\r\n <bsu-htree-create-new\r\n [node]=\"node\"\r\n [relationList]=\"relationList\"\r\n (createNew)=\"onCreateNew($event)\"\r\n ></bsu-htree-create-new>\r\n }\r\n </div>\r\n @if (access?.View && !showOkCancelButtons && deviceName !== 'desktop' && !hideOpenIcon) {\r\n <button fd-button [glyph]=\"navigationArrow\" fdType=\"transparent\" (click)=\"onNodeViewClick()\"></button>\r\n } @if (actionList?.length && !inlineEditMode) {\r\n <bsu-barsa-row-inline-actionlist\r\n [actionList]=\"actionList\"\r\n (btnClick)=\"actionListClick.emit($event)\"\r\n ></bsu-barsa-row-inline-actionlist>\r\n }\r\n\r\n <bsu-barsa-tree-item\r\n *cdkDragPreview\r\n [node]=\"node\"\r\n [rtl]=\"rtl\"\r\n [selectedNode]=\"selectedNode\"\r\n [hasArrowIcon]=\"false\"\r\n ></bsu-barsa-tree-item>\r\n</li>\r\n", styles: [":host{display:contents}li.isdirty{background:url(/Lib/ui/resources/images/default/grid/dirty.gif);background-repeat:no-repeat}li .cdk-drag-handle{opacity:.5;cursor:move}li .spacer{height:100%}li .arrow-children{border:none!important;background:transparent!important;color:var(--sapButton_Lite_TextColor)!important}li .arrow-container,li .empty-container{display:flex;width:28px;align-items:center;justify-content:center}li .arrow-container fd-icon,li .empty-container fd-icon{cursor:pointer;width:100%;height:100%;text-align:center}li .empty-container{visibility:hidden!important}.cdk-drag{cursor:default}.tree-icon-children{cursor:pointer}.icon-item{width:1rem}\n"], dependencies: [{ kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i2.IntersectionObserverDirective, selector: "[intersectionObserver]", inputs: ["intersectionDebounce", "intersectionRootMargin", "intersectionRoot", "intersectionThreshold"], outputs: ["visibilityChange"] }, { kind: "directive", type: i3.CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer", "cdkDragScale"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }, { kind: "directive", type: i3.CdkDragHandle, selector: "[cdkDragHandle]", inputs: ["cdkDragHandleDisabled"] }, { kind: "directive", type: i3.CdkDragPreview, selector: "ng-template[cdkDragPreview]", inputs: ["data", "matchSize"] }, { kind: "directive", type: i4.ContentDensityDirective, selector: "[fdContentDensity]:not([fdCompact]):not([fdCondensed]):not([fdCozy]), [fdCompact]:not([fdContentDensity]):not([fdCondensed]):not([fdCozy]), [fdCondensed]:not([fdContentDensity]):not([fdCompact]):not([fdCozy]), [fdCozy]:not([fdContentDensity]):not([fdCompact]):not([fdCondensed])", inputs: ["fdContentDensity", "fdCompact", "fdCondensed", "fdCozy"], exportAs: ["fdContentDensity"] }, { kind: "component", type: i5.BusyIndicatorComponent, selector: "fd-busy-indicator", inputs: ["loading", "size", "block", "ariaLabel", "title", "label", "ariaLive"] }, { kind: "component", type: i6.ButtonComponent, selector: "button[fd-button], a[fd-button], span[fd-button]", inputs: ["class"], exportAs: ["fd-button"] }, { kind: "component", type: i7.CheckboxComponent, selector: "fd-checkbox", inputs: ["wrapLabel", "valignLabel", "ariaLabel", "role", "value", "ariaLabelledBy", "ariaDescribedBy", "title", "inputId", "state", "name", "label", "disabled", "readonly", "tristate", "tristateSelectable", "labelClass", "required", "displayOnly", "values", "standalone"], outputs: ["focusChange"] }, { kind: "component", type: i8.IconComponent, selector: "fd-icon", inputs: ["glyph", "font", "color", "background", "class", "ariaLabel", "ariaHidden"] }, { kind: "component", type: i9.ListItemComponent, selector: "[fdListItem] ,[fd-list-item]", inputs: ["selected", "noData", "action", "interactive", "growing", "counter", "unread", "byline", "ariaRole", "id", "preventClick"], outputs: ["keyDown"] }, { kind: "directive", type: i9.ListTitleDirective, selector: "[fd-list-title], [fdListTitle]", inputs: ["wrap"] }, { kind: "directive", type: i9.ListIconDirective, selector: "[fdListIcon], [fd-list-icon]", inputs: ["glyph", "glyphFont", "class", "role", "ariaHidden"] }, { kind: "component", type: i10.UlvContextMenuComponent, selector: "bsu-ulv-context-menu,[ulvContextMenu]", inputs: ["onlyOverflow", "rightClickEnable", "deviceName", "menuItems", "allColumns", "index", "mo", "styleIndex", "conditionalFormats", "disableOverflowContextMenu", "footerMode", "contextMenuOverflowText", "appendTo"], outputs: ["commandClick"] }, { kind: "component", type: BarsaTreeItemComponent, selector: "bsu-barsa-tree-item", inputs: ["node", "selectedNode", "relationList", "hideOpenIcon", "hasArrowIcon", "collapseIcon", "loading", "hasChildren", "leafCursorPointer", "isExpand", "children", "parentNode", "text", "icon", "color", "isHetro", "enableNodeReordering", "hideIcon"], outputs: ["createNew", "select", "checkChange", "viewClick", "loadChildren", "dragMoved"] }, { kind: "component", type: i11.HtreeCreateNewComponent, selector: "bsu-htree-create-new", inputs: ["relationList", "node"], outputs: ["createNew"] }, { kind: "component", type: i12.BarsaRowInlineActionlistComponent, selector: "bsu-barsa-row-inline-actionlist", inputs: ["actionList", "mo", "index"], outputs: ["btnClick"] }, { kind: "directive", type: i13.ApplyConditionalFormatsDirective, selector: "[applyConditionalFormats]", inputs: ["applyConditionalFormats", "styleIndex", "hostEl", "dbName"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
100
100
  }
101
101
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: BarsaTreeItemComponent, decorators: [{
102
102
  type: Component,
@@ -150,4 +150,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
150
150
  }], dragMoved: [{
151
151
  type: Output
152
152
  }] } });
153
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"barsa-tree-item.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-sap-ui/src/lib/barsa-tree-item/barsa-tree-item.component.ts","../../../../../projects/barsa-sap-ui/src/lib/barsa-tree-item/barsa-tree-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    ChangeDetectionStrategy,\r\n    Component,\r\n    EventEmitter,\r\n    Input,\r\n    OnInit,\r\n    Output,\r\n    Renderer2,\r\n    inject\r\n} from '@angular/core';\r\nimport { Observable } from 'rxjs';\r\n\r\nimport {\r\n    MetaobjectDataModel,\r\n    TreeNodeObj,\r\n    RelationItemType,\r\n    BaseViewItemPropsComponent,\r\n    BarsaApi\r\n} from 'barsa-novin-ray-core';\r\n\r\n@Component({\r\n    selector: 'bsu-barsa-tree-item',\r\n    templateUrl: './barsa-tree-item.component.html',\r\n    styleUrls: ['./barsa-tree-item.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    standalone: false\r\n})\r\nexport class BarsaTreeItemComponent extends BaseViewItemPropsComponent implements OnInit {\r\n    @Input() node: TreeNodeObj;\r\n    @Input() selectedNode: MetaobjectDataModel | null;\r\n    @Input() relationList: RelationItemType[];\r\n    @Input() hideOpenIcon: boolean;\r\n    @Input() hasArrowIcon = true;\r\n    @Input() collapseIcon: string;\r\n    @Input() loading: boolean;\r\n    @Input() hasChildren: boolean;\r\n    @Input() leafCursorPointer: boolean;\r\n    @Input() isExpand: boolean;\r\n    @Input() children: TreeNodeObj[];\r\n    @Input() parentNode: TreeNodeObj;\r\n    @Input() text: string;\r\n    @Input() icon: string;\r\n    @Input() color: string;\r\n    @Input() isHetro: boolean;\r\n    @Input() enableNodeReordering: boolean;\r\n    @Input() hideIcon: boolean;\r\n\r\n    /* eslint-disable */\r\n    @Output() createNew = new EventEmitter<RelationItemType>();\r\n    @Output() select = new EventEmitter<{\r\n        node: TreeNodeObj;\r\n        index: number;\r\n    }>();\r\n    @Output() checkChange = new EventEmitter<{\r\n        node: TreeNodeObj;\r\n        index: number;\r\n        checked: boolean;\r\n    }>();\r\n    @Output() viewClick = new EventEmitter<{\r\n        node: MetaobjectDataModel;\r\n        index: number;\r\n    }>();\r\n    @Output() loadChildren = new EventEmitter<MetaobjectDataModel>();\r\n    @Output() dragMoved = new EventEmitter<string>();\r\n    icon$: Observable<string>;\r\n    appComponentIcon: string | null = null;\r\n    appComponentIconColor: string | null = null;\r\n    rowBtns = [\r\n        { Icon: 'add', Action: 'console.log(\"add btn clicked\")' },\r\n        {\r\n            Icon: 'delete',\r\n            Action: 'console.log(\"delete btn clicked\")'\r\n        }\r\n    ];\r\n    _renderer2 = inject(Renderer2);\r\n    ngOnInit(): void {\r\n        super.ngOnInit();\r\n        this.appComponentIcon = BarsaApi.Common.Util.TryGetValue(this, 'node.Data.Component.Settings.Icon', null);\r\n        this.appComponentIconColor = BarsaApi.Common.Util.TryGetValue(\r\n            this,\r\n            'node.Data.Component.Settings.IconColor',\r\n            null\r\n        );\r\n        // if (!this.node.icon.startsWith('http')) {\r\n        //     this.hideIcon = true;\r\n        // }\r\n    }\r\n    onVisibilityChange(divEl: HTMLElement, spanEl: HTMLElement, e): void {\r\n        if (e === 'Visible') {\r\n            const maxWidthText = divEl.getBoundingClientRect().width;\r\n            this._renderer2.setStyle(spanEl, 'max-width', maxWidthText + 'px');\r\n        }\r\n    }\r\n    onListItemClick(liEl, e) {\r\n        if (e.target === liEl?.elementRef?.nativeElement) {\r\n            this.onRowCheck();\r\n        }\r\n    }\r\n    onCheckbox(checked: boolean): void {\r\n        this.checkChange.emit({ node: this.node, index: this.index, checked });\r\n    }\r\n    onRowCheck(): void {\r\n        if (this.inDialog && this.isMultiSelect) {\r\n            return;\r\n        }\r\n        this.select.emit({ node: this.node, index: this.index });\r\n    }\r\n\r\n    onUlvCommand(): void {\r\n        this.ulvCommand.emit({ mo: this.node.Data, index: this.index });\r\n    }\r\n\r\n    onNodeViewClick(): void {\r\n        this.viewClick.emit({ node: this.node.Data, index: this.index });\r\n    }\r\n\r\n    onLoadChildren(e): void {\r\n        this.loadChildren.emit(this.node.Data);\r\n        e.stopPropagation();\r\n        e.preventDefault();\r\n    }\r\n\r\n    onExpandDblClick(e): void {\r\n        e.stopPropagation();\r\n        e.preventDefault();\r\n    }\r\n    onCreateNew(e) {\r\n        if (!this.isChecked) {\r\n            this.onRowCheck();\r\n        }\r\n        this.createNew.emit(e);\r\n    }\r\n    onRowAction(commandBody: string): void {\r\n        const command = new Function(commandBody);\r\n        command();\r\n    }\r\n    onDragMoved($event): void {\r\n        if (this.isHetro) {\r\n            return;\r\n        }\r\n        this.dragMoved.emit($event);\r\n    }\r\n}\r\n","<li\r\n    fd-list-item\r\n    #liEl\r\n    [class.!tw-cursor-pointer]=\"leafCursorPointer\"\r\n    [applyConditionalFormats]=\"conditionalFormats\"\r\n    [styleIndex]=\"styleIndex\"\r\n    [hostEl]=\"liEl\"\r\n    [focusable]=\"true\"\r\n    [attr.level]=\"level\"\r\n    [class.root-group]=\"level === 1\"\r\n    [interactive]=\"true\"\r\n    [selected]=\"isChecked\"\r\n    (dblclick)=\"onNodeViewClick()\"\r\n    cdkDrag\r\n    [cdkDragDisabled]=\"!enableNodeReordering\"\r\n    [cdkDragData]=\"node.Data.Id\"\r\n    [class.isdirty]=\"isdirty\"\r\n    (cdkDragMoved)=\"onDragMoved($event)\"\r\n    (click)=\"openOnClick ? onNodeViewClick() : onListItemClick(liEl, $event)\"\r\n>\r\n    <div (click)=\"onRowCheck()\" class=\"spacer\" [style.width]=\"(level - 1) * 4 + 'rem'\"></div>\r\n    @if (enableNodeReordering && !isHetro) {\r\n    <fd-icon glyph=\"grip\" font=\"BusinessSuiteInAppSymbols\" cdkDragHandle></fd-icon>\r\n    } @if (inDialog && isMultiSelect) {\r\n    <fd-checkbox [name]=\"node.Data.$Caption\" [ngModel]=\"isChecked\" (ngModelChange)=\"onCheckbox($event)\"></fd-checkbox>\r\n    }\r\n\r\n    <div (click)=\"onRowCheck()\" style=\"display: flex; width: 100%; justify-content: space-between\">\r\n        <div style=\"display: flex; flex: 1; gap: 3px\">\r\n            @if (hasArrowIcon) { @if (hasChildren) {\r\n            <div class=\"arrow-container\">\r\n                <button\r\n                    [attr.rtl]=\"rtl\"\r\n                    fd-button\r\n                    fdType=\"transparent\"\r\n                    class=\"arrow-children\"\r\n                    [fdCompact]\r\n                    [glyph]=\"hasChildren ? (isExpand ? 'slim-arrow-down' : collapseIcon) : ''\"\r\n                    (click)=\"onLoadChildren($event)\"\r\n                    (dblclick)=\"onExpandDblClick($event)\"\r\n                ></button>\r\n            </div>\r\n            } @else { @if (!parentNode?.hasOneDepthLevel) {\r\n            <div class=\"empty-container\" (click)=\"onRowCheck()\">\r\n                <button fd-button></button>\r\n            </div>\r\n            } } @if (loading) {\r\n            <fd-busy-indicator\r\n                style=\"display: flex; align-items: center; width: 2rem\"\r\n                size=\"s\"\r\n                [loading]=\"true\"\r\n            ></fd-busy-indicator>\r\n            } @if(!hideIcon || appComponentIcon){ @if(icon || appComponentIcon){\r\n            <i\r\n                [style.color]=\"appComponentIconColor || color\"\r\n                class=\"icon-item\"\r\n                fd-list-icon\r\n                [glyph]=\"appComponentIcon || icon\"\r\n            ></i>\r\n            }@else {\r\n            <i fd-list-icon class=\"icon-item\" style=\"display: flex; align-items: center; justify-content: center\">\r\n                <img [src]=\"node.icon\" width=\"16px\" />\r\n            </i>\r\n            } } }\r\n            <div\r\n                style=\"display: flex; flex: unset; align-items: center\"\r\n                fd-list-title\r\n                [focusable]=\"true\"\r\n                #divEl\r\n                [style.color]=\"styleIndex ? 'inherit' : color\"\r\n                intersectionObserver\r\n                [intersectionThreshold]=\"0.1\"\r\n                (visibilityChange)=\"onVisibilityChange(divEl, spanEl, $event)\"\r\n            >\r\n                <span\r\n                    class=\"ellapsis\"\r\n                    #spanEl\r\n                    [style.color]=\"styleIndex ? 'inherit' : color\"\r\n                    [class.haschildren]=\"hasChildren\"\r\n                    >{{ text }}</span\r\n                >\r\n                @if (children) {\r\n                <span>{{ ' ( ' + children.length + ' )' }}</span>\r\n                }\r\n            </div>\r\n        </div>\r\n        @if (contextMenuItems && contextMenuItems.length > 0) {\r\n        <i\r\n            ulvContextMenu\r\n            [allColumns]=\"allColumns\"\r\n            [menuItems]=\"contextMenuItems\"\r\n            [conditionalFormats]=\"conditionalFormats\"\r\n            [styleIndex]=\"styleIndex\"\r\n            [disableOverflowContextMenu]=\"disableOverflowContextMenu\"\r\n            [mo]=\"node.Data\"\r\n            [index]=\"index\"\r\n            (commandClick)=\"onUlvCommand()\"\r\n            [deviceName]=\"deviceName\"\r\n        ></i>\r\n        } @if (access?.Add !== false && !inDialog) {\r\n        <bsu-htree-create-new\r\n            [node]=\"node\"\r\n            [relationList]=\"relationList\"\r\n            (createNew)=\"onCreateNew($event)\"\r\n        ></bsu-htree-create-new>\r\n        }\r\n    </div>\r\n    @if (access?.View && !showOkCancelButtons && deviceName !== 'desktop' && !hideOpenIcon) {\r\n    <button fd-button [glyph]=\"navigationArrow\" fdType=\"transparent\" (click)=\"onNodeViewClick()\"></button>\r\n    } @if (actionList?.length && !inlineEditMode) {\r\n    <bsu-barsa-row-inline-actionlist\r\n        [actionList]=\"actionList\"\r\n        (btnClick)=\"actionListClick.emit($event)\"\r\n    ></bsu-barsa-row-inline-actionlist>\r\n    }\r\n\r\n    <bsu-barsa-tree-item\r\n        *cdkDragPreview\r\n        [node]=\"node\"\r\n        [rtl]=\"rtl\"\r\n        [selectedNode]=\"selectedNode\"\r\n        [hasArrowIcon]=\"false\"\r\n    ></bsu-barsa-tree-item>\r\n</li>\r\n"]}
153
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"barsa-tree-item.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-sap-ui/src/lib/barsa-tree-item/barsa-tree-item.component.ts","../../../../../projects/barsa-sap-ui/src/lib/barsa-tree-item/barsa-tree-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    ChangeDetectionStrategy,\r\n    Component,\r\n    EventEmitter,\r\n    Input,\r\n    OnInit,\r\n    Output,\r\n    Renderer2,\r\n    inject\r\n} from '@angular/core';\r\nimport { Observable } from 'rxjs';\r\n\r\nimport {\r\n    MetaobjectDataModel,\r\n    TreeNodeObj,\r\n    RelationItemType,\r\n    BaseViewItemPropsComponent,\r\n    BarsaApi\r\n} from 'barsa-novin-ray-core';\r\n\r\n@Component({\r\n    selector: 'bsu-barsa-tree-item',\r\n    templateUrl: './barsa-tree-item.component.html',\r\n    styleUrls: ['./barsa-tree-item.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    standalone: false\r\n})\r\nexport class BarsaTreeItemComponent extends BaseViewItemPropsComponent implements OnInit {\r\n    @Input() node: TreeNodeObj;\r\n    @Input() selectedNode: MetaobjectDataModel | null;\r\n    @Input() relationList: RelationItemType[];\r\n    @Input() hideOpenIcon: boolean;\r\n    @Input() hasArrowIcon = true;\r\n    @Input() collapseIcon: string;\r\n    @Input() loading: boolean;\r\n    @Input() hasChildren: boolean;\r\n    @Input() leafCursorPointer: boolean;\r\n    @Input() isExpand: boolean;\r\n    @Input() children: TreeNodeObj[];\r\n    @Input() parentNode: TreeNodeObj;\r\n    @Input() text: string;\r\n    @Input() icon: string;\r\n    @Input() color: string;\r\n    @Input() isHetro: boolean;\r\n    @Input() enableNodeReordering: boolean;\r\n    @Input() hideIcon: boolean;\r\n\r\n    /* eslint-disable */\r\n    @Output() createNew = new EventEmitter<RelationItemType>();\r\n    @Output() select = new EventEmitter<{\r\n        node: TreeNodeObj;\r\n        index: number;\r\n    }>();\r\n    @Output() checkChange = new EventEmitter<{\r\n        node: TreeNodeObj;\r\n        index: number;\r\n        checked: boolean;\r\n    }>();\r\n    @Output() viewClick = new EventEmitter<{\r\n        node: MetaobjectDataModel;\r\n        index: number;\r\n    }>();\r\n    @Output() loadChildren = new EventEmitter<MetaobjectDataModel>();\r\n    @Output() dragMoved = new EventEmitter<string>();\r\n    icon$: Observable<string>;\r\n    appComponentIcon: string | null = null;\r\n    appComponentIconColor: string | null = null;\r\n    rowBtns = [\r\n        { Icon: 'add', Action: 'console.log(\"add btn clicked\")' },\r\n        {\r\n            Icon: 'delete',\r\n            Action: 'console.log(\"delete btn clicked\")'\r\n        }\r\n    ];\r\n    _renderer2 = inject(Renderer2);\r\n    ngOnInit(): void {\r\n        super.ngOnInit();\r\n        this.appComponentIcon = BarsaApi.Common.Util.TryGetValue(this, 'node.Data.Component.Settings.Icon', null);\r\n        this.appComponentIconColor = BarsaApi.Common.Util.TryGetValue(\r\n            this,\r\n            'node.Data.Component.Settings.IconColor',\r\n            null\r\n        );\r\n        // if (!this.node.icon.startsWith('http')) {\r\n        //     this.hideIcon = true;\r\n        // }\r\n    }\r\n    onVisibilityChange(divEl: HTMLElement, spanEl: HTMLElement, e): void {\r\n        if (e === 'Visible') {\r\n            const maxWidthText = divEl.getBoundingClientRect().width;\r\n            this._renderer2.setStyle(spanEl, 'max-width', maxWidthText + 'px');\r\n        }\r\n    }\r\n    onListItemClick(liEl, e) {\r\n        if (e.target === liEl?.elementRef?.nativeElement) {\r\n            this.onRowCheck();\r\n        }\r\n    }\r\n    onCheckbox(checked: boolean): void {\r\n        this.checkChange.emit({ node: this.node, index: this.index, checked });\r\n    }\r\n    onRowCheck(): void {\r\n        if (this.inDialog && this.isMultiSelect) {\r\n            return;\r\n        }\r\n        this.select.emit({ node: this.node, index: this.index });\r\n    }\r\n\r\n    onUlvCommand(): void {\r\n        this.ulvCommand.emit({ mo: this.node.Data, index: this.index });\r\n    }\r\n\r\n    onNodeViewClick(): void {\r\n        this.viewClick.emit({ node: this.node.Data, index: this.index });\r\n    }\r\n\r\n    onLoadChildren(e): void {\r\n        this.loadChildren.emit(this.node.Data);\r\n        e.stopPropagation();\r\n        e.preventDefault();\r\n    }\r\n\r\n    onExpandDblClick(e): void {\r\n        e.stopPropagation();\r\n        e.preventDefault();\r\n    }\r\n    onCreateNew(e) {\r\n        if (!this.isChecked) {\r\n            this.onRowCheck();\r\n        }\r\n        this.createNew.emit(e);\r\n    }\r\n    onRowAction(commandBody: string): void {\r\n        const command = new Function(commandBody);\r\n        command();\r\n    }\r\n    onDragMoved($event): void {\r\n        if (this.isHetro) {\r\n            return;\r\n        }\r\n        this.dragMoved.emit($event);\r\n    }\r\n}\r\n","<li\r\n    fd-list-item\r\n    #liEl\r\n    [class.!tw-cursor-pointer]=\"leafCursorPointer\"\r\n    [applyConditionalFormats]=\"conditionalFormats\"\r\n    [styleIndex]=\"styleIndex\"\r\n    [hostEl]=\"liEl\"\r\n    [focusable]=\"true\"\r\n    [attr.level]=\"level\"\r\n    [class.root-group]=\"level === 1\"\r\n    [interactive]=\"true\"\r\n    [selected]=\"isChecked\"\r\n    (dblclick)=\"onNodeViewClick()\"\r\n    cdkDrag\r\n    [cdkDragDisabled]=\"!enableNodeReordering\"\r\n    [cdkDragData]=\"node.Data.Id\"\r\n    [class.isdirty]=\"isdirty\"\r\n    (cdkDragMoved)=\"onDragMoved($event)\"\r\n    (click)=\"openOnClick ? onNodeViewClick() : onListItemClick(liEl, $event)\"\r\n>\r\n    <div (click)=\"onRowCheck()\" class=\"spacer\" [style.width]=\"(level - 1) * 4 + 'rem'\"></div>\r\n    @if (enableNodeReordering && !isHetro) {\r\n    <fd-icon glyph=\"grip\" font=\"BusinessSuiteInAppSymbols\" cdkDragHandle></fd-icon>\r\n    } @if (inDialog && isMultiSelect) {\r\n    <fd-checkbox [name]=\"node.Data.$Caption\" [ngModel]=\"isChecked\" (ngModelChange)=\"onCheckbox($event)\"></fd-checkbox>\r\n    }\r\n\r\n    <div (click)=\"onRowCheck()\" style=\"display: flex; width: 100%; justify-content: space-between\">\r\n        <div style=\"display: flex; flex: 1; gap: 3px\">\r\n            @if (hasArrowIcon) { @if (hasChildren) {\r\n            <div class=\"arrow-container\">\r\n                <button\r\n                    [attr.rtl]=\"rtl\"\r\n                    fd-button\r\n                    fdType=\"transparent\"\r\n                    class=\"arrow-children\"\r\n                    [fdCompact]\r\n                    [glyph]=\"hasChildren ? (isExpand ? 'slim-arrow-down' : collapseIcon) : ''\"\r\n                    (click)=\"onLoadChildren($event)\"\r\n                    (dblclick)=\"onExpandDblClick($event)\"\r\n                ></button>\r\n            </div>\r\n            } @else { @if (!parentNode?.hasOneDepthLevel) {\r\n            <div class=\"empty-container\" (click)=\"onRowCheck()\">\r\n                <button fd-button></button>\r\n            </div>\r\n            } } @if (loading) {\r\n            <fd-busy-indicator\r\n                style=\"display: flex; align-items: center; width: 2rem\"\r\n                size=\"s\"\r\n                [loading]=\"true\"\r\n            ></fd-busy-indicator>\r\n            } @if(!hideIcon || appComponentIcon){ @if(icon || appComponentIcon){\r\n            <i\r\n                [style.color]=\"appComponentIconColor || color\"\r\n                class=\"icon-item\"\r\n                fd-list-icon\r\n                [glyph]=\"appComponentIcon || icon\"\r\n            ></i>\r\n            }@else {\r\n            <i fd-list-icon class=\"icon-item\" style=\"display: flex; align-items: center; justify-content: center\">\r\n                <img [src]=\"node.icon\" width=\"16px\" />\r\n            </i>\r\n            } } }\r\n            <div\r\n                style=\"display: flex; flex: unset; align-items: center\"\r\n                fd-list-title\r\n                [focusable]=\"true\"\r\n                #divEl\r\n                [style.color]=\"styleIndex ? 'inherit' : color\"\r\n                intersectionObserver\r\n                [intersectionThreshold]=\"0.1\"\r\n                (visibilityChange)=\"onVisibilityChange(divEl, spanEl, $event)\"\r\n            >\r\n                <span\r\n                    class=\"ellapsis\"\r\n                    #spanEl\r\n                    [style.color]=\"styleIndex ? 'inherit' : color\"\r\n                    [class.haschildren]=\"hasChildren\"\r\n                    >{{ text }}</span\r\n                >\r\n                @if (children) {\r\n                <span>{{ ' ( ' + children.length + ' )' }}</span>\r\n                }\r\n            </div>\r\n        </div>\r\n        @if (contextMenuItems && contextMenuItems.length > 0) {\r\n        <i\r\n            ulvContextMenu\r\n            [allColumns]=\"allColumns\"\r\n            [menuItems]=\"contextMenuItems\"\r\n            [conditionalFormats]=\"conditionalFormats\"\r\n            [styleIndex]=\"styleIndex\"\r\n            [disableOverflowContextMenu]=\"disableOverflowContextMenu\"\r\n            [mo]=\"node.Data\"\r\n            [index]=\"index\"\r\n            (commandClick)=\"onUlvCommand()\"\r\n            [deviceName]=\"deviceName\"\r\n        ></i>\r\n        } @if (access?.Add !== false && !inDialog) {\r\n        <bsu-htree-create-new\r\n            [node]=\"node\"\r\n            [relationList]=\"relationList\"\r\n            (createNew)=\"onCreateNew($event)\"\r\n        ></bsu-htree-create-new>\r\n        }\r\n    </div>\r\n    @if (access?.View && !showOkCancelButtons && deviceName !== 'desktop' && !hideOpenIcon) {\r\n    <button fd-button [glyph]=\"navigationArrow\" fdType=\"transparent\" (click)=\"onNodeViewClick()\"></button>\r\n    } @if (actionList?.length && !inlineEditMode) {\r\n    <bsu-barsa-row-inline-actionlist\r\n        [actionList]=\"actionList\"\r\n        (btnClick)=\"actionListClick.emit($event)\"\r\n    ></bsu-barsa-row-inline-actionlist>\r\n    }\r\n\r\n    <bsu-barsa-tree-item\r\n        *cdkDragPreview\r\n        [node]=\"node\"\r\n        [rtl]=\"rtl\"\r\n        [selectedNode]=\"selectedNode\"\r\n        [hasArrowIcon]=\"false\"\r\n    ></bsu-barsa-tree-item>\r\n</li>\r\n"]}