barsa-sap-ui 1.0.258 → 1.0.261

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.
@@ -7,7 +7,7 @@ export class BarsaTinyemceComponent extends BaseComponent {
7
7
  this._el = _el;
8
8
  this.valueChange = new EventEmitter();
9
9
  this.tinyInit = new EventEmitter();
10
- this.tinyHostId = getUniqueId(2);
10
+ this.tinyHostId = `a_${getUniqueId(2)}`;
11
11
  this.tinyMCEConfig = {};
12
12
  }
13
13
  ngOnChanges(simpleChanges) {
@@ -51,29 +51,54 @@ export class BarsaTinyemceComponent extends BaseComponent {
51
51
  this.tinyMCEConfig.height = '100%';
52
52
  this.tinyMCEConfig.width = '100%';
53
53
  this.tinyMCEConfig.selector = '#' + this.tinyHostId;
54
- this.tinyMCEConfig.skin = 'oxide';
55
54
  this.tinyMCEConfig.content_css = 'assets/Resources/fonts/Iran.css';
56
55
  this.tinyMCEConfig.directionality = 'rtl';
57
56
  this.tinyMCEConfig.language = 'fa_IR';
58
- this.tinyMCEConfig.menubar = false;
59
- this.tinyMCEConfig.statusbar = false;
57
+ this.tinyMCEConfig.promotion = false;
60
58
  this.tinyMCEConfig.paste_data_images = true;
61
59
  this.tinyMCEConfig.defaultFontName = 'BarsaFont';
62
60
  this.tinyMCEConfig.defaultFontSize = '12px';
63
- this.tinyMCEConfig.inline = true;
61
+ this.tinyMCEConfig.statusbar = false;
62
+ this.tinyMCEConfig.inline = false;
64
63
  this.tinyMCEConfig.theme_advanced_resizing = true;
65
- this.tinyMCEConfig.images_dataimg_filter = (img) => img.hasAttribute('internal-blob');
66
- this.tinyMCEConfig.toolbar = true;
67
- this.tinyMCEConfig.font_formats =
64
+ this.tinyMCEConfig.font_family_formats =
68
65
  'BarsaFont=BarsaFont;Arial=arial,helvetica,sans-serif; Courier New=courier new,courier,monospace;';
69
- this.tinyMCEConfig.fontsize_formats = '8pt 10pt 12pt 14pt 18pt 24pt 36pt';
66
+ this.tinyMCEConfig.font_size_formats = '8pt 10pt 12pt 14pt 18pt 24pt 36pt';
70
67
  this.tinyMCEConfig.plugins = [
71
- `print preview importcss searchreplace autolink autoresize autosave save directionality visualblocks visualchars fullscreen
72
- link media template codesample table charmap hr pagebreak nonbreaking anchor toc insertdatetime advlist lists wordcount
73
- imagetools textpattern noneditable help charmap quickbars emoticons`
68
+ 'advlist',
69
+ 'anchor',
70
+ 'autolink',
71
+ 'autosave',
72
+ 'charmap',
73
+ 'code',
74
+ 'codesample',
75
+ 'directionality',
76
+ 'emoticons',
77
+ 'fullscreen',
78
+ 'help',
79
+ 'image',
80
+ 'importcss',
81
+ 'insertdatetime',
82
+ 'link',
83
+ 'lists',
84
+ 'media',
85
+ 'nonbreaking',
86
+ 'pagebreak',
87
+ 'preview',
88
+ 'quickbars',
89
+ 'save',
90
+ 'searchreplace',
91
+ 'table',
92
+ 'template',
93
+ 'visualblocks',
94
+ 'visualchars',
95
+ 'wordcount',
96
+ 'autoresize'
97
+ ];
98
+ this.tinyMCEConfig.toolbar = [
99
+ `defaultVerbs barsaImage | insert | forecolor backcolor fontfamily fontsize | bullist numlist outdent indent | removeformat` +
100
+ ` | undo redo | copy cut paste | blocks | bold italic | alignleft aligncenter alignright alignjustify ltr rtl`
74
101
  ];
75
- this.tinyMCEConfig.toolbar = `defaultVerbs barsaImage | insert | forecolor backcolor fontselect fontsizeselect | undo redo | copy cut paste
76
- | formatselect | bold italic backcolor | alignleft aligncenter alignright alignjustify ltr rtl | bullist numlist outdent indent | removeformat`;
77
102
  const tinymceSettingsGlobal = window.tinymceSettings;
78
103
  let tinymceSettings = BarsaApi.Common.Util.TryGetValue(this.Setting, 'JsonExtraProp.tinymceSettings');
79
104
  tinymceSettings = BarsaApi.Common.Merger.Merge(tinymceSettingsGlobal, tinymceSettings);
@@ -173,7 +198,7 @@ export class BarsaTinyemceComponent extends BaseComponent {
173
198
  const setContent = ed.setContent;
174
199
  ed.setContent = (...args) => {
175
200
  setContent.apply(ed, args);
176
- ed.fire('change', {});
201
+ ed.dispatch('change', {});
177
202
  };
178
203
  hasInit = true;
179
204
  this.tinyInit.emit();
@@ -331,4 +356,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImpor
331
356
  }], tinyInit: [{
332
357
  type: Output
333
358
  }] } });
334
- //# 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} from '@angular/core';\r\n\r\nimport { BaseComponent, BarsaApi, getUniqueId, isFunction } from 'barsa-novin-ray-core';\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})\r\nexport class BarsaTinyemceComponent extends BaseComponent implements AfterViewInit, OnDestroy, OnChanges {\r\n    @Input() Setting: any;\r\n    @Input() isReadonly: boolean;\r\n    @Input() value: any;\r\n    @Output() valueChange = new EventEmitter<any>();\r\n    @Output() tinyInit = new EventEmitter();\r\n    tinyHostId = getUniqueId(2);\r\n    tinyMCEConfig: any = {};\r\n    editor: any;\r\n    defaultVerbs: 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 _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    ngAfterViewInit(): void {\r\n        super.ngAfterViewInit();\r\n        this.loadTinyMce();\r\n    }\r\n    ngOnDestroy(): void {\r\n        super.ngOnDestroy();\r\n        this.destroyTinymce();\r\n    }\r\n    loadTinyMce(): void {\r\n        if (!this.Setting.IsHtmlViewer) {\r\n            head.load(['Lib/tinymce/tinymce.min.js'], () => {\r\n                this.prepare();\r\n            });\r\n        }\r\n    }\r\n\r\n    initilize(): void {\r\n        this.tinyMCEConfig.height = '100%';\r\n        this.tinyMCEConfig.width = '100%';\r\n        this.tinyMCEConfig.selector = '#' + this.tinyHostId;\r\n        this.tinyMCEConfig.skin = 'oxide';\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.menubar = false;\r\n        this.tinyMCEConfig.statusbar = false;\r\n        this.tinyMCEConfig.paste_data_images = true;\r\n        this.tinyMCEConfig.defaultFontName = 'BarsaFont';\r\n        this.tinyMCEConfig.defaultFontSize = '12px';\r\n        this.tinyMCEConfig.inline = true;\r\n        this.tinyMCEConfig.theme_advanced_resizing = true;\r\n        this.tinyMCEConfig.images_dataimg_filter = (img) => img.hasAttribute('internal-blob');\r\n        this.tinyMCEConfig.toolbar = true;\r\n        this.tinyMCEConfig.font_formats =\r\n            'BarsaFont=BarsaFont;Arial=arial,helvetica,sans-serif; Courier New=courier new,courier,monospace;';\r\n        this.tinyMCEConfig.fontsize_formats = '8pt 10pt 12pt 14pt 18pt 24pt 36pt';\r\n        this.tinyMCEConfig.plugins = [\r\n            `print preview importcss searchreplace autolink autoresize autosave save directionality visualblocks visualchars fullscreen \r\n            link media template codesample table charmap hr pagebreak nonbreaking anchor toc insertdatetime advlist lists wordcount \r\n            imagetools textpattern noneditable help charmap quickbars emoticons`\r\n        ];\r\n        this.tinyMCEConfig.toolbar = `defaultVerbs barsaImage | insert | forecolor backcolor fontselect fontsizeselect | undo redo | copy cut paste \r\n            | formatselect | bold italic backcolor  | alignleft aligncenter alignright alignjustify ltr rtl  | bullist numlist outdent indent | removeformat`;\r\n\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        const defaultVerbsMenu: any = [];\r\n        // BEGIN: setup\r\n        this.tinyMCEConfig.setup = (ed) => {\r\n            this.editor = ed;\r\n\r\n            if (!this.isReadonly) {\r\n                if (this.defaultVerbs) {\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                            }\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.fire('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.bind(this));\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    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('mceInsertRawHTML', 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) {\r\n            return;\r\n        }\r\n        const ed = tinymce.get(this.tinyHostId);\r\n        if (ed) {\r\n            if (ed.iframeElement) {\r\n                ed.iframeElement.removeAllListeners();\r\n            }\r\n            ed.destroy(false);\r\n        }\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        // this._removeOverflow(ed);\r\n        // this.destroyTinymce();\r\n        // this.prepare();\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 class=\"fd-input tinywrapper\" [style.min-height.px]=\"height\" [id]=\"tinyHostId\"></div>\r\n\r\n<!-- <textarea [id]=\"tinyHostId\" style=\"height: 100%; visibility: hidden\"></textarea> -->\r\n"]}
359
+ //# 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 {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    Component,\n    ElementRef,\n    EventEmitter,\n    Input,\n    OnChanges,\n    OnDestroy,\n    Output,\n    SimpleChanges\n} from '@angular/core';\n\nimport { BaseComponent, BarsaApi, getUniqueId, isFunction } from 'barsa-novin-ray-core';\ndeclare const window: any;\ndeclare const tinymce: any;\ndeclare const head: any;\ndeclare const $: any;\n@Component({\n    selector: 'bsu-barsa-tinyemce',\n    templateUrl: './barsa-tinyemce.component.html',\n    styleUrls: ['./barsa-tinyemce.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class BarsaTinyemceComponent extends BaseComponent implements AfterViewInit, OnDestroy, OnChanges {\n    @Input() Setting: any;\n    @Input() isReadonly: boolean;\n    @Input() value: any;\n    @Output() valueChange = new EventEmitter<any>();\n    @Output() tinyInit = new EventEmitter();\n    tinyHostId = `a_${getUniqueId(2)}`;\n    tinyMCEConfig: any = {};\n    editor: any;\n    defaultVerbs: any;\n    wysiwygIntialized: boolean;\n    intializationInProgress: boolean;\n    editorValue: string;\n\n    iframBodyInnerHtml: string;\n    height: number;\n\n    constructor(protected _el: ElementRef) {\n        super();\n    }\n    ngOnChanges(simpleChanges: SimpleChanges): void {\n        super.ngOnChanges(simpleChanges);\n        if (simpleChanges.value && !simpleChanges.value.firstChange) {\n            this.setValue(simpleChanges.value.currentValue);\n        }\n        if (simpleChanges.disable && !simpleChanges.disable.firstChange) {\n            const disbale = simpleChanges.disable.currentValue;\n            if (disbale) {\n                this.setDisable();\n            } else {\n                this.setEnable();\n            }\n        }\n        if (simpleChanges.readonly && !simpleChanges.readonly.firstChange) {\n            this.setReadOnly(simpleChanges.readonly.currentValue);\n        }\n    }\n    ngOnInit(): void {\n        super.ngOnInit();\n        this.height = (this._el.nativeElement as HTMLElement).clientHeight;\n    }\n\n    ngAfterViewInit(): void {\n        super.ngAfterViewInit();\n        this.loadTinyMce();\n    }\n    ngOnDestroy(): void {\n        super.ngOnDestroy();\n        this.destroyTinymce();\n    }\n    loadTinyMce(): void {\n        if (!this.Setting.IsHtmlViewer) {\n            head.load(['Lib/tinymce/tinymce.min.js'], () => {\n                this.prepare();\n            });\n        }\n    }\n\n    initilize(): void {\n        this.tinyMCEConfig.height = '100%';\n        this.tinyMCEConfig.width = '100%';\n        this.tinyMCEConfig.selector = '#' + this.tinyHostId;\n\n        this.tinyMCEConfig.content_css = 'assets/Resources/fonts/Iran.css';\n        this.tinyMCEConfig.directionality = 'rtl';\n        this.tinyMCEConfig.language = 'fa_IR';\n        this.tinyMCEConfig.promotion = false;\n        this.tinyMCEConfig.paste_data_images = true;\n        this.tinyMCEConfig.defaultFontName = 'BarsaFont';\n        this.tinyMCEConfig.defaultFontSize = '12px';\n        this.tinyMCEConfig.statusbar = false;\n        this.tinyMCEConfig.inline = false;\n        this.tinyMCEConfig.theme_advanced_resizing = true;\n        this.tinyMCEConfig.font_family_formats =\n            'BarsaFont=BarsaFont;Arial=arial,helvetica,sans-serif; Courier New=courier new,courier,monospace;';\n        this.tinyMCEConfig.font_size_formats = '8pt 10pt 12pt 14pt 18pt 24pt 36pt';\n\n        this.tinyMCEConfig.plugins = [\n            'advlist',\n            'anchor',\n            'autolink',\n            'autosave',\n            'charmap',\n            'code',\n            'codesample',\n            'directionality',\n            'emoticons',\n            'fullscreen',\n            'help',\n            'image',\n            'importcss',\n            'insertdatetime',\n            'link',\n            'lists',\n            'media',\n            'nonbreaking',\n            'pagebreak',\n            'preview',\n            'quickbars',\n            'save',\n            'searchreplace',\n            'table',\n            'template',\n            'visualblocks',\n            'visualchars',\n            'wordcount',\n            'autoresize'\n        ];\n        this.tinyMCEConfig.toolbar = [\n            `defaultVerbs barsaImage | insert | forecolor backcolor fontfamily fontsize | bullist numlist outdent indent | removeformat` +\n                ` | undo redo | copy cut paste | blocks | bold italic | alignleft aligncenter alignright alignjustify ltr rtl`\n        ];\n\n        const tinymceSettingsGlobal = window.tinymceSettings;\n        let tinymceSettings = BarsaApi.Common.Util.TryGetValue(this.Setting, 'JsonExtraProp.tinymceSettings');\n        tinymceSettings = BarsaApi.Common.Merger.Merge(tinymceSettingsGlobal, tinymceSettings);\n        if (!tinymceSettings && Array.isArray(tinymceSettings)) {\n            for (const item of tinymceSettings) {\n                this.tinyMCEConfig[item.key] = item.value;\n            }\n        }\n\n        if (this.isReadonly) {\n            this.tinyMCEConfig.menubar = false;\n            this.tinyMCEConfig.statusbar = false;\n            this.tinyMCEConfig.plugins = ['autoresize'];\n            // this.tinyMCEConfig.plugins = [];\n            this.tinyMCEConfig.toolbar = false;\n        }\n\n        let userSetup: (editor: any) => void;\n\n        if (this.tinyMCEConfig.setup) {\n            userSetup = this.tinyMCEConfig.setup;\n        }\n        const defaultVerbsMenu: any = [];\n        // BEGIN: setup\n        this.tinyMCEConfig.setup = (ed) => {\n            this.editor = ed;\n\n            if (!this.isReadonly) {\n                if (this.defaultVerbs) {\n                    this.defaultVerbs.forEach((item) => {\n                        defaultVerbsMenu.push({\n                            value: item.Html,\n                            type: 'menuitem',\n                            text: item.Title || item.Html.replace(/<br\\s*\\/?>/gi, ' '),\n                            onAction: () => {\n                                ed.execCommand('mceInsertRawHTML', false, item.Html);\n                            }\n                        });\n                    });\n                }\n                ed.ui.registry.addSplitButton('barsaImage', {\n                    text: 'insert',\n                    icon: 'image',\n                    tooltip: 'Insert Image As Base64',\n                    onAction: () => {\n                        BarsaApi.Common.Async.Waterfall(\n                            'Tinemce.EmbedImage',\n                            {\n                                openFileDialog: this.ShowOpenFileDialog.bind(this),\n                                insertBase64: this.InsertBase64.bind(this)\n                            },\n                            (err, result) => {\n                                BarsaApi.Common.Async.Finalize(err, result);\n                            }\n                        );\n                    },\n                    onItemAction: () => {\n                        BarsaApi.Common.Async.Waterfall(\n                            'Tinemce.UploadToDatabase',\n                            {\n                                openFileDialog: this.ShowUploadWindow.bind(this)\n                            },\n                            (err, result) => {\n                                BarsaApi.Common.Async.Finalize(err, result);\n                            }\n                        );\n                    },\n                    fetch: (callback) => {\n                        const items = [\n                            {\n                                type: 'choiceitem',\n                                text: 'upload',\n                                icon: 'image',\n                                tooltip: 'Upload Image',\n                                value: 'upload'\n                            }\n                        ];\n                        callback(items);\n                    }\n                });\n\n                ed.ui.registry.addMenuButton('defaultVerbs', {\n                    text: 'عبارتهای پیش فرض',\n                    fetch: (callback) => {\n                        callback(defaultVerbsMenu);\n                    }\n                });\n                if (isFunction(window.tinymceSetup)) {\n                    window.tinymceSetup.call(this, this, ed);\n                }\n            }\n            let hasInit = false;\n            ed.on('init', () => {\n                this.wysiwygIntialized = true;\n                this.intializationInProgress = false;\n                if (typeof this.value !== 'undefined') {\n                    this.setValue(this.value);\n                }\n                if (this.tinyMCEConfig.defaultFontName) {\n                    ed.execCommand('FontName', false, this.tinyMCEConfig.defaultFontName);\n                }\n                if (this.tinyMCEConfig.defaultFontSize) {\n                    ed.execCommand('FontSize', false, this.tinyMCEConfig.defaultFontSize);\n                }\n                if (this.isReadonly) {\n                    this.setReadOnly(this.isReadonly);\n                }\n                // This piece of code solves the problem of change propagation so that\n                // there is no need to call triggerSave\n                const setContent = ed.setContent;\n                ed.setContent = (...args) => {\n                    setContent.apply(ed, args);\n                    ed.dispatch('change', {});\n                };\n                hasInit = true;\n                this.tinyInit.emit();\n                const iframEl: HTMLIFrameElement = ed.iframeElement;\n                if (iframEl) {\n                    iframEl.addEventListener('load', this._onLoadIframe.bind(this));\n                }\n            });\n\n            // Catch and propagate the change event\n            let oldContent = null;\n            ed.on('change keyup', () => {\n                const newval = ed.getContent();\n                if (newval === oldContent) {\n                    return;\n                }\n\n                oldContent = newval;\n                if (!hasInit) {\n                    return;\n                }\n\n                ed.save();\n                this.editorValue = newval;\n                this.valueChange.emit(newval);\n                // this.context.fireEvent('change', this, newval, oldval, {});\n            });\n\n            ed.on('focus', () => {\n                // TODO\n            });\n\n            if (userSetup) {\n                userSetup(ed);\n            }\n        };\n    }\n\n    ShowUploadWindow(): void {}\n    ShowOpenFileDialog(doReturn): void {\n        const input: any = document.createElement('input');\n        input.setAttribute('type', 'file');\n        input.setAttribute('accept', 'image/*');\n\n        input.onchange = () => {\n            const file = input.files[0];\n\n            const reader = new FileReader();\n            reader.onload = () => {\n                let base64 = reader.result as string;\n                base64 = base64.split(',')[1];\n                doReturn(null, base64);\n            };\n            reader.readAsDataURL(file);\n        };\n\n        input.click();\n    }\n    InsertBase64(base64, doReturn): void {\n        this.editor.execCommand('mceInsertRawHTML', false, '<img src=data:image/png;base64,' + base64 + ' />');\n        doReturn();\n    }\n    getValue(): string | null {\n        let res = null;\n        if (this.wysiwygIntialized) {\n            const ed = tinymce.get(this.tinyHostId);\n            if (ed) {\n                res = ed.getContent();\n            }\n        }\n\n        return res;\n    }\n    setValue(value): void {\n        this.value = value;\n        this.setValueTiny();\n    }\n    setValueTiny(): string {\n        if (this.wysiwygIntialized) {\n            const ed = tinymce.get(this.tinyHostId);\n            if (ed) {\n                ed.setContent(this.value);\n            }\n        }\n        return this.value;\n    }\n    focus(): any {\n        if (this.isReadonly) {\n            return this;\n        }\n\n        if (this.wysiwygIntialized) {\n            tinymce.execCommand('mceFocus', false, 'id_of_textarea');\n        }\n        return this;\n    }\n\n    setEnable(): void {\n        if (this.wysiwygIntialized) {\n            const ed = tinymce.get(this.tinyHostId);\n            ed.getBody().setAttribute('contenteditable', true);\n        }\n    }\n\n    setDisable(): void {\n        if (this.wysiwygIntialized) {\n            const ed = tinymce.get(this.tinyHostId);\n            ed.getBody().setAttribute('contenteditable', false);\n        }\n    }\n    setReadOnly(readOnly): void {\n        if (this.wysiwygIntialized) {\n            const ed = tinymce.get(this.tinyHostId);\n            ed.getBody().setAttribute('contenteditable', !readOnly);\n            if (readOnly) {\n                $('.tox-editor-header').hide();\n            } else {\n                $('.tox-editor-header').hide();\n            }\n        }\n    }\n\n    destroyTinymce(): void {\n        if (this.Setting.IsHtmlViewer) {\n            return;\n        }\n        const ed = tinymce.get(this.tinyHostId);\n        if (ed) {\n            if (ed.iframeElement) {\n                ed.iframeElement.removeAllListeners();\n            }\n            ed.destroy(false);\n        }\n    }\n    private prepare(): void {\n        this.initilize();\n        tinymce.init(this.tinyMCEConfig);\n        this.intializationInProgress = false;\n        this.wysiwygIntialized = true;\n    }\n    private _onLoadIframe(): void {\n        this.value = this.editorValue;\n        // const ed = tinymce.get(this.tinyHostId);\n        // this._removeOverflow(ed);\n        // this.destroyTinymce();\n        // this.prepare();\n    }\n\n    private _removeOverflow(ed: any): void {\n        const html = ed.iframeElement?.contentDocument?.querySelector('html');\n        if (html) {\n            html.style.overflow = 'hidden';\n        }\n    }\n}\n","<div class=\"fd-input tinywrapper\" [style.min-height.px]=\"height\" [id]=\"tinyHostId\"></div>\r\n\r\n<!-- <textarea [id]=\"tinyHostId\" style=\"height: 100%; visibility: hidden\"></textarea> -->\r\n"]}
@@ -30,14 +30,14 @@ export class UiFormPanelComponent extends FormBaseComponent {
30
30
  }
31
31
  }
32
32
  UiFormPanelComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: UiFormPanelComponent, deps: [{ token: i1.BreadcrumbService }, { token: i2.ContentDensityService }, { token: i1.PortalService }, { token: i3.ActivatedRoute }, { token: i3.Router }, { token: i1.FormPanelService, self: true }], target: i0.ɵɵFactoryTarget.Component });
33
- UiFormPanelComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: UiFormPanelComponent, selector: "bsu-ui-form-panel", host: { properties: { "attr.typeDefName": "this._typeDefName" } }, providers: [FormPanelService], usesInheritance: true, ngImport: i0, template: "<ng-container *ngIf=\"isSearchPanel || (isSimple$ | async) || isSubForm || isModal || isFormReport; else dynamicPage\">\r\n <bsu-mask *ngIf=\"mask$ | async\"> </bsu-mask>\r\n <div>\r\n <bsu-ly-layout-container-of-root\r\n [config]=\"layout94$ | async\"\r\n [isPanel]=\"false\"\r\n [isRoot]=\"true\"\r\n ></bsu-ly-layout-container-of-root>\r\n <div class=\"workflow-buttons\" *ngIf=\"toolbarItems$ | async as toolbarItems\">\r\n <div style=\"flex-grow: 1\"></div>\r\n <bsu-layout-actions\r\n style=\"display: flex; column-gap: 1rem\"\r\n [simple]=\"true\"\r\n [buttons]=\"[]\"\r\n [workflowButtons]=\"toolbarItems\"\r\n (toolClick)=\"onToolbarClick($event)\"\r\n >\r\n </bsu-layout-actions>\r\n </div>\r\n </div>\r\n <!-- <div fd-bar barDesign=\"floating-footer\">\r\n <div\r\n *ngIf=\"context.WorkflowPanelUi\"\r\n fd-bar-right\r\n [footerActions]=\"context.WorkflowPanelUi\"\r\n ></div>\r\n <div\r\n *ngIf=\"\r\n !context.WorkflowPanelUi &&\r\n showToolbar &&\r\n \r\n toolbar.items.length > 0\r\n \"\r\n fd-bar-right\r\n [footerActions]=\"toolbar\"\r\n ></div>\r\n </div> -->\r\n</ng-container>\r\n<ng-template #dynamicPage>\r\n <bsu-fundamental-dynamic-form\r\n [style.position]=\"(mask$ | async) ? 'relative' : null\"\r\n [canSend]=\"(canSend$ | async) === true\"\r\n [removeContentPadding]=\"(headerRemoveContentPadding$ | async)!!\"\r\n [breadCrumbs]=\"breadCrumbs$ | async\"\r\n [description]=\"(headerDescription$ | async)!!\"\r\n [hideClose]=\"(hideClose$ | async)!!\"\r\n [hideTitle]=\"(hideTitle$ | async)!!\"\r\n [hidePin]=\"(hidePin$ | async)!!\"\r\n [title]=\"(title$ | async)!!\"\r\n [subtitle]=\"(headerSubtitle$ | async)!!\"\r\n [toolbarItems]=\"toolbarItems$ | async | tlbButtons: 'inFooter':false\"\r\n [layoutActions]=\"toolbarItems$ | async | tlbButtons: 'inFooter':true\"\r\n [toolbarVisible]=\"(toolbarVisible$ | async)!!\"\r\n [facetList]=\"(headerLayout$ | async)?.FacetList2\"\r\n [parameters]=\"parameters\"\r\n [workflowPanelUi]=\"workflowPanelUi$ | async\"\r\n [isMobile]=\"isMobile\"\r\n [layout94]=\"layout94$ | async\"\r\n [rtl]=\"(rtl$ | async)!!\"\r\n [mask]=\"(mask$ | async)!!\"\r\n [mo]=\"(mo$ | async)!!\"\r\n [dirValue]=\"(dirValue$ | async)!!\"\r\n [deviceSize]=\"(deviceSize$ | async)!!\"\r\n [contentDensity]=\"(contentDensity$ | async)!!\"\r\n [modernTabs]=\"(modernTabs$ | async)!!\"\r\n [avatar]=\"(avatar$ | async)!!\"\r\n [fieldDict]=\"(fieldDict$ | async)!!\"\r\n (close)=\"onClose()\"\r\n (toolbarClick)=\"onToolbarClick($event)\"\r\n [contentIsPage]=\"parameters?.ContentIsPage\"\r\n (workflowChoiceClick)=\"onWorkflowChoiceClick($event)\"\r\n ></bsu-fundamental-dynamic-form>\r\n</ng-template>\r\n", styles: [":host{display:block;width:100%;min-height:100%}.workflow-buttons{display:flex;margin-top:5px;padding:5px}\n"], dependencies: [{ kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i5.LyLayoutContainerOfRootComponent, selector: "bsu-ly-layout-container-of-root" }, { kind: "component", type: i6.MaskComponent, selector: "bsu-mask", inputs: ["size", "marginTop"] }, { kind: "component", type: i7.FundamentalDynamicFormComponent, selector: "bsu-fundamental-dynamic-form", inputs: ["breadCrumbs", "toolbarVisible", "toolbarItems", "layoutActions", "layout94", "parameters", "workflowPanelUi", "context", "title", "subtitle", "description", "facetList", "fieldDict", "removeHeaderBorder", "removeContentPadding", "isMobile", "mo", "avatar", "rtl", "hideTitle", "hideClose", "hidePin", "mask", "canSend", "contentIsPage", "contentDensity", "deviceSize", "dirValue", "modernTabs"], outputs: ["toolbarClick", "workflowChoiceClick", "close"] }, { kind: "component", type: i8.LayoutActionsComponent, selector: "bsu-layout-actions", inputs: ["workflowButtons", "workflowButtonsComboMode", "canSend", "simple"], outputs: ["workflowChoiceSelect"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }, { kind: "pipe", type: i1.TlbButtonsPipe, name: "tlbButtons" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
33
+ UiFormPanelComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: UiFormPanelComponent, selector: "bsu-ui-form-panel", host: { properties: { "attr.typeDefName": "this._typeDefName" } }, providers: [FormPanelService], usesInheritance: true, ngImport: i0, template: "<ng-container *ngIf=\"isSearchPanel || (isSimple$ | async) || isSubForm || isModal || isFormReport; else dynamicPage\">\n <bsu-mask *ngIf=\"mask$ | async\"> </bsu-mask>\n <div>\n <bsu-ly-layout-container-of-root\n [config]=\"layout94$ | async\"\n [isPanel]=\"false\"\n [isRoot]=\"true\"\n ></bsu-ly-layout-container-of-root>\n <div class=\"workflow-buttons\" *ngIf=\"workflowButtons$ | async as workflowButtons\">\n <div style=\"flex-grow: 1\"></div>\n <bsu-layout-actions\n style=\"display: flex; column-gap: 1rem\"\n [simple]=\"true\"\n [buttons]=\"[]\"\n [workflowButtons]=\"workflowButtons\"\n (toolClick)=\"onToolbarClick($event)\"\n >\n </bsu-layout-actions>\n </div>\n </div>\n <!-- <div fd-bar barDesign=\"floating-footer\">\n <div\n *ngIf=\"context.WorkflowPanelUi\"\n fd-bar-right\n [footerActions]=\"context.WorkflowPanelUi\"\n ></div>\n <div\n *ngIf=\"\n !context.WorkflowPanelUi &&\n showToolbar &&\n \n toolbar.items.length > 0\n \"\n fd-bar-right\n [footerActions]=\"toolbar\"\n ></div>\n </div> -->\n</ng-container>\n<ng-template #dynamicPage>\n <bsu-fundamental-dynamic-form\n [style.position]=\"(mask$ | async) ? 'relative' : null\"\n [canSend]=\"(canSend$ | async) === true\"\n [removeContentPadding]=\"(headerRemoveContentPadding$ | async)!!\"\n [breadCrumbs]=\"breadCrumbs$ | async\"\n [description]=\"(headerDescription$ | async)!!\"\n [hideClose]=\"(hideClose$ | async)!!\"\n [hideTitle]=\"(hideTitle$ | async)!!\"\n [hidePin]=\"(hidePin$ | async)!!\"\n [title]=\"(title$ | async)!!\"\n [subtitle]=\"(headerSubtitle$ | async)!!\"\n [toolbarItems]=\"toolbarItems$ | async | tlbButtons: 'inFooter':false\"\n [layoutActions]=\"toolbarItems$ | async | tlbButtons: 'inFooter':true\"\n [toolbarVisible]=\"(toolbarVisible$ | async)!!\"\n [facetList]=\"(headerLayout$ | async)?.FacetList2\"\n [parameters]=\"parameters\"\n [workflowPanelUi]=\"workflowPanelUi$ | async\"\n [isMobile]=\"isMobile\"\n [layout94]=\"layout94$ | async\"\n [rtl]=\"(rtl$ | async)!!\"\n [mask]=\"(mask$ | async)!!\"\n [mo]=\"(mo$ | async)!!\"\n [dirValue]=\"(dirValue$ | async)!!\"\n [deviceSize]=\"(deviceSize$ | async)!!\"\n [contentDensity]=\"(contentDensity$ | async)!!\"\n [modernTabs]=\"(modernTabs$ | async)!!\"\n [avatar]=\"(avatar$ | async)!!\"\n [fieldDict]=\"(fieldDict$ | async)!!\"\n (close)=\"onClose()\"\n (toolbarClick)=\"onToolbarClick($event)\"\n [contentIsPage]=\"parameters?.ContentIsPage\"\n (workflowChoiceClick)=\"onWorkflowChoiceClick($event)\"\n ></bsu-fundamental-dynamic-form>\n</ng-template>\n", styles: [":host{display:block;width:100%;min-height:100%}.workflow-buttons{display:flex;margin-top:5px;padding:5px}\n"], dependencies: [{ kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i5.LyLayoutContainerOfRootComponent, selector: "bsu-ly-layout-container-of-root" }, { kind: "component", type: i6.MaskComponent, selector: "bsu-mask", inputs: ["size", "marginTop"] }, { kind: "component", type: i7.FundamentalDynamicFormComponent, selector: "bsu-fundamental-dynamic-form", inputs: ["breadCrumbs", "toolbarVisible", "toolbarItems", "layoutActions", "layout94", "parameters", "workflowPanelUi", "context", "title", "subtitle", "description", "facetList", "fieldDict", "removeHeaderBorder", "removeContentPadding", "isMobile", "mo", "avatar", "rtl", "hideTitle", "hideClose", "hidePin", "mask", "canSend", "contentIsPage", "contentDensity", "deviceSize", "dirValue", "modernTabs"], outputs: ["toolbarClick", "workflowChoiceClick", "close"] }, { kind: "component", type: i8.LayoutActionsComponent, selector: "bsu-layout-actions", inputs: ["workflowButtons", "workflowButtonsComboMode", "canSend", "simple"], outputs: ["workflowChoiceSelect"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }, { kind: "pipe", type: i1.TlbButtonsPipe, name: "tlbButtons" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
34
34
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: UiFormPanelComponent, decorators: [{
35
35
  type: Component,
36
- args: [{ selector: 'bsu-ui-form-panel', changeDetection: ChangeDetectionStrategy.OnPush, providers: [FormPanelService], template: "<ng-container *ngIf=\"isSearchPanel || (isSimple$ | async) || isSubForm || isModal || isFormReport; else dynamicPage\">\r\n <bsu-mask *ngIf=\"mask$ | async\"> </bsu-mask>\r\n <div>\r\n <bsu-ly-layout-container-of-root\r\n [config]=\"layout94$ | async\"\r\n [isPanel]=\"false\"\r\n [isRoot]=\"true\"\r\n ></bsu-ly-layout-container-of-root>\r\n <div class=\"workflow-buttons\" *ngIf=\"toolbarItems$ | async as toolbarItems\">\r\n <div style=\"flex-grow: 1\"></div>\r\n <bsu-layout-actions\r\n style=\"display: flex; column-gap: 1rem\"\r\n [simple]=\"true\"\r\n [buttons]=\"[]\"\r\n [workflowButtons]=\"toolbarItems\"\r\n (toolClick)=\"onToolbarClick($event)\"\r\n >\r\n </bsu-layout-actions>\r\n </div>\r\n </div>\r\n <!-- <div fd-bar barDesign=\"floating-footer\">\r\n <div\r\n *ngIf=\"context.WorkflowPanelUi\"\r\n fd-bar-right\r\n [footerActions]=\"context.WorkflowPanelUi\"\r\n ></div>\r\n <div\r\n *ngIf=\"\r\n !context.WorkflowPanelUi &&\r\n showToolbar &&\r\n \r\n toolbar.items.length > 0\r\n \"\r\n fd-bar-right\r\n [footerActions]=\"toolbar\"\r\n ></div>\r\n </div> -->\r\n</ng-container>\r\n<ng-template #dynamicPage>\r\n <bsu-fundamental-dynamic-form\r\n [style.position]=\"(mask$ | async) ? 'relative' : null\"\r\n [canSend]=\"(canSend$ | async) === true\"\r\n [removeContentPadding]=\"(headerRemoveContentPadding$ | async)!!\"\r\n [breadCrumbs]=\"breadCrumbs$ | async\"\r\n [description]=\"(headerDescription$ | async)!!\"\r\n [hideClose]=\"(hideClose$ | async)!!\"\r\n [hideTitle]=\"(hideTitle$ | async)!!\"\r\n [hidePin]=\"(hidePin$ | async)!!\"\r\n [title]=\"(title$ | async)!!\"\r\n [subtitle]=\"(headerSubtitle$ | async)!!\"\r\n [toolbarItems]=\"toolbarItems$ | async | tlbButtons: 'inFooter':false\"\r\n [layoutActions]=\"toolbarItems$ | async | tlbButtons: 'inFooter':true\"\r\n [toolbarVisible]=\"(toolbarVisible$ | async)!!\"\r\n [facetList]=\"(headerLayout$ | async)?.FacetList2\"\r\n [parameters]=\"parameters\"\r\n [workflowPanelUi]=\"workflowPanelUi$ | async\"\r\n [isMobile]=\"isMobile\"\r\n [layout94]=\"layout94$ | async\"\r\n [rtl]=\"(rtl$ | async)!!\"\r\n [mask]=\"(mask$ | async)!!\"\r\n [mo]=\"(mo$ | async)!!\"\r\n [dirValue]=\"(dirValue$ | async)!!\"\r\n [deviceSize]=\"(deviceSize$ | async)!!\"\r\n [contentDensity]=\"(contentDensity$ | async)!!\"\r\n [modernTabs]=\"(modernTabs$ | async)!!\"\r\n [avatar]=\"(avatar$ | async)!!\"\r\n [fieldDict]=\"(fieldDict$ | async)!!\"\r\n (close)=\"onClose()\"\r\n (toolbarClick)=\"onToolbarClick($event)\"\r\n [contentIsPage]=\"parameters?.ContentIsPage\"\r\n (workflowChoiceClick)=\"onWorkflowChoiceClick($event)\"\r\n ></bsu-fundamental-dynamic-form>\r\n</ng-template>\r\n", styles: [":host{display:block;width:100%;min-height:100%}.workflow-buttons{display:flex;margin-top:5px;padding:5px}\n"] }]
36
+ args: [{ selector: 'bsu-ui-form-panel', changeDetection: ChangeDetectionStrategy.OnPush, providers: [FormPanelService], template: "<ng-container *ngIf=\"isSearchPanel || (isSimple$ | async) || isSubForm || isModal || isFormReport; else dynamicPage\">\n <bsu-mask *ngIf=\"mask$ | async\"> </bsu-mask>\n <div>\n <bsu-ly-layout-container-of-root\n [config]=\"layout94$ | async\"\n [isPanel]=\"false\"\n [isRoot]=\"true\"\n ></bsu-ly-layout-container-of-root>\n <div class=\"workflow-buttons\" *ngIf=\"workflowButtons$ | async as workflowButtons\">\n <div style=\"flex-grow: 1\"></div>\n <bsu-layout-actions\n style=\"display: flex; column-gap: 1rem\"\n [simple]=\"true\"\n [buttons]=\"[]\"\n [workflowButtons]=\"workflowButtons\"\n (toolClick)=\"onToolbarClick($event)\"\n >\n </bsu-layout-actions>\n </div>\n </div>\n <!-- <div fd-bar barDesign=\"floating-footer\">\n <div\n *ngIf=\"context.WorkflowPanelUi\"\n fd-bar-right\n [footerActions]=\"context.WorkflowPanelUi\"\n ></div>\n <div\n *ngIf=\"\n !context.WorkflowPanelUi &&\n showToolbar &&\n \n toolbar.items.length > 0\n \"\n fd-bar-right\n [footerActions]=\"toolbar\"\n ></div>\n </div> -->\n</ng-container>\n<ng-template #dynamicPage>\n <bsu-fundamental-dynamic-form\n [style.position]=\"(mask$ | async) ? 'relative' : null\"\n [canSend]=\"(canSend$ | async) === true\"\n [removeContentPadding]=\"(headerRemoveContentPadding$ | async)!!\"\n [breadCrumbs]=\"breadCrumbs$ | async\"\n [description]=\"(headerDescription$ | async)!!\"\n [hideClose]=\"(hideClose$ | async)!!\"\n [hideTitle]=\"(hideTitle$ | async)!!\"\n [hidePin]=\"(hidePin$ | async)!!\"\n [title]=\"(title$ | async)!!\"\n [subtitle]=\"(headerSubtitle$ | async)!!\"\n [toolbarItems]=\"toolbarItems$ | async | tlbButtons: 'inFooter':false\"\n [layoutActions]=\"toolbarItems$ | async | tlbButtons: 'inFooter':true\"\n [toolbarVisible]=\"(toolbarVisible$ | async)!!\"\n [facetList]=\"(headerLayout$ | async)?.FacetList2\"\n [parameters]=\"parameters\"\n [workflowPanelUi]=\"workflowPanelUi$ | async\"\n [isMobile]=\"isMobile\"\n [layout94]=\"layout94$ | async\"\n [rtl]=\"(rtl$ | async)!!\"\n [mask]=\"(mask$ | async)!!\"\n [mo]=\"(mo$ | async)!!\"\n [dirValue]=\"(dirValue$ | async)!!\"\n [deviceSize]=\"(deviceSize$ | async)!!\"\n [contentDensity]=\"(contentDensity$ | async)!!\"\n [modernTabs]=\"(modernTabs$ | async)!!\"\n [avatar]=\"(avatar$ | async)!!\"\n [fieldDict]=\"(fieldDict$ | async)!!\"\n (close)=\"onClose()\"\n (toolbarClick)=\"onToolbarClick($event)\"\n [contentIsPage]=\"parameters?.ContentIsPage\"\n (workflowChoiceClick)=\"onWorkflowChoiceClick($event)\"\n ></bsu-fundamental-dynamic-form>\n</ng-template>\n", styles: [":host{display:block;width:100%;min-height:100%}.workflow-buttons{display:flex;margin-top:5px;padding:5px}\n"] }]
37
37
  }], ctorParameters: function () { return [{ type: i1.BreadcrumbService }, { type: i2.ContentDensityService }, { type: i1.PortalService }, { type: i3.ActivatedRoute }, { type: i3.Router }, { type: i1.FormPanelService, decorators: [{
38
38
  type: Self
39
39
  }] }]; }, propDecorators: { _typeDefName: [{
40
40
  type: HostBinding,
41
41
  args: ['attr.typeDefName']
42
42
  }] } });
43
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ui-form-panel.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-sap-ui/src/lib/ui-form-panel/ui-form-panel.component.ts","../../../../../projects/barsa-sap-ui/src/lib/ui-form-panel/ui-form-panel.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,WAAW,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AAItF,OAAO,EACH,iBAAiB,EAGjB,gBAAgB,EAEnB,MAAM,sBAAsB,CAAC;;;;;;;;;;AAU9B,MAAM,OAAO,oBAAqB,SAAQ,iBAAiB;IAQvD,YACc,kBAAqC,EACrC,sBAA6C,EAC7C,cAA6B,EAC7B,eAA+B,EAC/B,OAAe,EACP,iBAAmC,CAAC,uCAAuC;;QAE7F,KAAK,CAAC,iBAAiB,CAAC,CAAC;QAPf,uBAAkB,GAAlB,kBAAkB,CAAmB;QACrC,2BAAsB,GAAtB,sBAAsB,CAAuB;QAC7C,mBAAc,GAAd,cAAc,CAAe;QAC7B,oBAAe,GAAf,eAAe,CAAgB;QAC/B,YAAO,GAAP,OAAO,CAAQ;QACP,sBAAiB,GAAjB,iBAAiB,CAAkB;QAbxB,iBAAY,GAAG,EAAE,CAAC;QAgB/C,IAAI,CAAC,YAAY,GAAG,kBAAkB,CAAC,YAAY,CAAC;QACpD,IAAI,CAAC,eAAe,GAAG,sBAAsB,CAAC,cAAc,CAAC;QAC7D,IAAI,CAAC,WAAW,GAAG,cAAc,CAAC,WAAW,CAAC;QAC9C,IAAI,CAAC,SAAS,GAAG,cAAc,CAAC,SAAS,CAAC;QAC1C,IAAI,CAAC,IAAI,GAAG,cAAc,CAAC,IAAI,CAAC;QAChC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,iBAAiB,CAAC,QAAQ,CAAC;QAChD,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,YAAY,GAAG,CAAC,EAAE,YAAY,IAAI,EAAE,CAAC,CAAC,CAAC;IAC7F,CAAC;;iHAxBQ,oBAAoB;qGAApB,oBAAoB,+GAFlB,CAAC,gBAAgB,CAAC,iDClBjC,qkGAyEA;2FDrDa,oBAAoB;kBAPhC,SAAS;+BACI,mBAAmB,mBAGZ,uBAAuB,CAAC,MAAM,aACpC,CAAC,gBAAgB,CAAC;;0BAgBxB,IAAI;4CAbwB,YAAY;sBAA5C,WAAW;uBAAC,kBAAkB","sourcesContent":["import { ChangeDetectionStrategy, Component, HostBinding, Self } from '@angular/core';\r\nimport { Observable } from 'rxjs';\r\nimport { ContentDensity, ContentDensityService } from '@fundamental-ngx/core';\r\n\r\nimport {\r\n    FormBaseComponent,\r\n    PortalService,\r\n    BreadCrumbInfo,\r\n    FormPanelService,\r\n    BreadcrumbService\r\n} from 'barsa-novin-ray-core';\r\nimport { ActivatedRoute, Router } from '@angular/router';\r\n\r\n@Component({\r\n    selector: 'bsu-ui-form-panel',\r\n    templateUrl: './ui-form-panel.component.html',\r\n    styleUrls: ['./ui-form-panel.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    providers: [FormPanelService]\r\n})\r\nexport class UiFormPanelComponent extends FormBaseComponent {\r\n    @HostBinding('attr.typeDefName') _typeDefName = '';\r\n    breadCrumbs$: Observable<BreadCrumbInfo[]>;\r\n    contentDensity$: Observable<ContentDensity>;\r\n    deviceSize$: Observable<'s' | 'm' | 'l' | 'xl'>;\r\n    dirValue$: Observable<'rtl' | 'ltr'>;\r\n    rtl$: Observable<boolean>;\r\n    canSend$: Observable<boolean>;\r\n    constructor(\r\n        protected _breadcrumbService: BreadcrumbService,\r\n        protected _contentDensityService: ContentDensityService,\r\n        protected _portalService: PortalService,\r\n        protected _activatedRoute: ActivatedRoute,\r\n        protected _router: Router,\r\n        @Self() protected _formPanelService: FormPanelService // private layoutService: LayoutService\r\n    ) {\r\n        super(_formPanelService);\r\n        this.breadCrumbs$ = _breadcrumbService.breadcrumbs$;\r\n        this.contentDensity$ = _contentDensityService.contentDensity;\r\n        this.deviceSize$ = _portalService.deviceSize$;\r\n        this.dirValue$ = _portalService.dirValue$;\r\n        this.rtl$ = _portalService.rtl$;\r\n        this.canSend$ = this._formPanelService.canSend$;\r\n        this._formPanelService.mo$.subscribe((c) => (this._typeDefName = c?.$TypeDefName ?? ''));\r\n    }\r\n}\r\n","<ng-container *ngIf=\"isSearchPanel || (isSimple$ | async) || isSubForm || isModal || isFormReport; else dynamicPage\">\r\n    <bsu-mask *ngIf=\"mask$ | async\"> </bsu-mask>\r\n    <div>\r\n        <bsu-ly-layout-container-of-root\r\n            [config]=\"layout94$ | async\"\r\n            [isPanel]=\"false\"\r\n            [isRoot]=\"true\"\r\n        ></bsu-ly-layout-container-of-root>\r\n        <div class=\"workflow-buttons\" *ngIf=\"toolbarItems$ | async as toolbarItems\">\r\n            <div style=\"flex-grow: 1\"></div>\r\n            <bsu-layout-actions\r\n                style=\"display: flex; column-gap: 1rem\"\r\n                [simple]=\"true\"\r\n                [buttons]=\"[]\"\r\n                [workflowButtons]=\"toolbarItems\"\r\n                (toolClick)=\"onToolbarClick($event)\"\r\n            >\r\n            </bsu-layout-actions>\r\n        </div>\r\n    </div>\r\n    <!-- <div fd-bar barDesign=\"floating-footer\">\r\n    <div\r\n      *ngIf=\"context.WorkflowPanelUi\"\r\n      fd-bar-right\r\n      [footerActions]=\"context.WorkflowPanelUi\"\r\n    ></div>\r\n    <div\r\n      *ngIf=\"\r\n        !context.WorkflowPanelUi &&\r\n        showToolbar &&\r\n        \r\n        toolbar.items.length > 0\r\n      \"\r\n      fd-bar-right\r\n      [footerActions]=\"toolbar\"\r\n    ></div>\r\n  </div> -->\r\n</ng-container>\r\n<ng-template #dynamicPage>\r\n    <bsu-fundamental-dynamic-form\r\n        [style.position]=\"(mask$ | async) ? 'relative' : null\"\r\n        [canSend]=\"(canSend$ | async) === true\"\r\n        [removeContentPadding]=\"(headerRemoveContentPadding$ | async)!!\"\r\n        [breadCrumbs]=\"breadCrumbs$ | async\"\r\n        [description]=\"(headerDescription$ | async)!!\"\r\n        [hideClose]=\"(hideClose$ | async)!!\"\r\n        [hideTitle]=\"(hideTitle$ | async)!!\"\r\n        [hidePin]=\"(hidePin$ | async)!!\"\r\n        [title]=\"(title$ | async)!!\"\r\n        [subtitle]=\"(headerSubtitle$ | async)!!\"\r\n        [toolbarItems]=\"toolbarItems$ | async | tlbButtons: 'inFooter':false\"\r\n        [layoutActions]=\"toolbarItems$ | async | tlbButtons: 'inFooter':true\"\r\n        [toolbarVisible]=\"(toolbarVisible$ | async)!!\"\r\n        [facetList]=\"(headerLayout$ | async)?.FacetList2\"\r\n        [parameters]=\"parameters\"\r\n        [workflowPanelUi]=\"workflowPanelUi$ | async\"\r\n        [isMobile]=\"isMobile\"\r\n        [layout94]=\"layout94$ | async\"\r\n        [rtl]=\"(rtl$ | async)!!\"\r\n        [mask]=\"(mask$ | async)!!\"\r\n        [mo]=\"(mo$ | async)!!\"\r\n        [dirValue]=\"(dirValue$ | async)!!\"\r\n        [deviceSize]=\"(deviceSize$ | async)!!\"\r\n        [contentDensity]=\"(contentDensity$ | async)!!\"\r\n        [modernTabs]=\"(modernTabs$ | async)!!\"\r\n        [avatar]=\"(avatar$ | async)!!\"\r\n        [fieldDict]=\"(fieldDict$ | async)!!\"\r\n        (close)=\"onClose()\"\r\n        (toolbarClick)=\"onToolbarClick($event)\"\r\n        [contentIsPage]=\"parameters?.ContentIsPage\"\r\n        (workflowChoiceClick)=\"onWorkflowChoiceClick($event)\"\r\n    ></bsu-fundamental-dynamic-form>\r\n</ng-template>\r\n"]}
43
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ui-form-panel.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-sap-ui/src/lib/ui-form-panel/ui-form-panel.component.ts","../../../../../projects/barsa-sap-ui/src/lib/ui-form-panel/ui-form-panel.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,WAAW,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AAItF,OAAO,EACH,iBAAiB,EAGjB,gBAAgB,EAEnB,MAAM,sBAAsB,CAAC;;;;;;;;;;AAU9B,MAAM,OAAO,oBAAqB,SAAQ,iBAAiB;IAQvD,YACc,kBAAqC,EACrC,sBAA6C,EAC7C,cAA6B,EAC7B,eAA+B,EAC/B,OAAe,EACP,iBAAmC,CAAC,uCAAuC;;QAE7F,KAAK,CAAC,iBAAiB,CAAC,CAAC;QAPf,uBAAkB,GAAlB,kBAAkB,CAAmB;QACrC,2BAAsB,GAAtB,sBAAsB,CAAuB;QAC7C,mBAAc,GAAd,cAAc,CAAe;QAC7B,oBAAe,GAAf,eAAe,CAAgB;QAC/B,YAAO,GAAP,OAAO,CAAQ;QACP,sBAAiB,GAAjB,iBAAiB,CAAkB;QAbxB,iBAAY,GAAG,EAAE,CAAC;QAgB/C,IAAI,CAAC,YAAY,GAAG,kBAAkB,CAAC,YAAY,CAAC;QACpD,IAAI,CAAC,eAAe,GAAG,sBAAsB,CAAC,cAAc,CAAC;QAC7D,IAAI,CAAC,WAAW,GAAG,cAAc,CAAC,WAAW,CAAC;QAC9C,IAAI,CAAC,SAAS,GAAG,cAAc,CAAC,SAAS,CAAC;QAC1C,IAAI,CAAC,IAAI,GAAG,cAAc,CAAC,IAAI,CAAC;QAChC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,iBAAiB,CAAC,QAAQ,CAAC;QAChD,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,YAAY,GAAG,CAAC,EAAE,YAAY,IAAI,EAAE,CAAC,CAAC,CAAC;IAC7F,CAAC;;iHAxBQ,oBAAoB;qGAApB,oBAAoB,+GAFlB,CAAC,gBAAgB,CAAC,iDClBjC,47FAyEA;2FDrDa,oBAAoB;kBAPhC,SAAS;+BACI,mBAAmB,mBAGZ,uBAAuB,CAAC,MAAM,aACpC,CAAC,gBAAgB,CAAC;;0BAgBxB,IAAI;4CAbwB,YAAY;sBAA5C,WAAW;uBAAC,kBAAkB","sourcesContent":["import { ChangeDetectionStrategy, Component, HostBinding, Self } from '@angular/core';\r\nimport { Observable } from 'rxjs';\r\nimport { ContentDensity, ContentDensityService } from '@fundamental-ngx/core';\r\n\r\nimport {\r\n    FormBaseComponent,\r\n    PortalService,\r\n    BreadCrumbInfo,\r\n    FormPanelService,\r\n    BreadcrumbService\r\n} from 'barsa-novin-ray-core';\r\nimport { ActivatedRoute, Router } from '@angular/router';\r\n\r\n@Component({\r\n    selector: 'bsu-ui-form-panel',\r\n    templateUrl: './ui-form-panel.component.html',\r\n    styleUrls: ['./ui-form-panel.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    providers: [FormPanelService]\r\n})\r\nexport class UiFormPanelComponent extends FormBaseComponent {\r\n    @HostBinding('attr.typeDefName') _typeDefName = '';\r\n    breadCrumbs$: Observable<BreadCrumbInfo[]>;\r\n    contentDensity$: Observable<ContentDensity>;\r\n    deviceSize$: Observable<'s' | 'm' | 'l' | 'xl'>;\r\n    dirValue$: Observable<'rtl' | 'ltr'>;\r\n    rtl$: Observable<boolean>;\r\n    canSend$: Observable<boolean>;\r\n    constructor(\r\n        protected _breadcrumbService: BreadcrumbService,\r\n        protected _contentDensityService: ContentDensityService,\r\n        protected _portalService: PortalService,\r\n        protected _activatedRoute: ActivatedRoute,\r\n        protected _router: Router,\r\n        @Self() protected _formPanelService: FormPanelService // private layoutService: LayoutService\r\n    ) {\r\n        super(_formPanelService);\r\n        this.breadCrumbs$ = _breadcrumbService.breadcrumbs$;\r\n        this.contentDensity$ = _contentDensityService.contentDensity;\r\n        this.deviceSize$ = _portalService.deviceSize$;\r\n        this.dirValue$ = _portalService.dirValue$;\r\n        this.rtl$ = _portalService.rtl$;\r\n        this.canSend$ = this._formPanelService.canSend$;\r\n        this._formPanelService.mo$.subscribe((c) => (this._typeDefName = c?.$TypeDefName ?? ''));\r\n    }\r\n}\r\n","<ng-container *ngIf=\"isSearchPanel || (isSimple$ | async) || isSubForm || isModal || isFormReport; else dynamicPage\">\n    <bsu-mask *ngIf=\"mask$ | async\"> </bsu-mask>\n    <div>\n        <bsu-ly-layout-container-of-root\n            [config]=\"layout94$ | async\"\n            [isPanel]=\"false\"\n            [isRoot]=\"true\"\n        ></bsu-ly-layout-container-of-root>\n        <div class=\"workflow-buttons\" *ngIf=\"workflowButtons$ | async as workflowButtons\">\n            <div style=\"flex-grow: 1\"></div>\n            <bsu-layout-actions\n                style=\"display: flex; column-gap: 1rem\"\n                [simple]=\"true\"\n                [buttons]=\"[]\"\n                [workflowButtons]=\"workflowButtons\"\n                (toolClick)=\"onToolbarClick($event)\"\n            >\n            </bsu-layout-actions>\n        </div>\n    </div>\n    <!-- <div fd-bar barDesign=\"floating-footer\">\n    <div\n      *ngIf=\"context.WorkflowPanelUi\"\n      fd-bar-right\n      [footerActions]=\"context.WorkflowPanelUi\"\n    ></div>\n    <div\n      *ngIf=\"\n        !context.WorkflowPanelUi &&\n        showToolbar &&\n        \n        toolbar.items.length > 0\n      \"\n      fd-bar-right\n      [footerActions]=\"toolbar\"\n    ></div>\n  </div> -->\n</ng-container>\n<ng-template #dynamicPage>\n    <bsu-fundamental-dynamic-form\n        [style.position]=\"(mask$ | async) ? 'relative' : null\"\n        [canSend]=\"(canSend$ | async) === true\"\n        [removeContentPadding]=\"(headerRemoveContentPadding$ | async)!!\"\n        [breadCrumbs]=\"breadCrumbs$ | async\"\n        [description]=\"(headerDescription$ | async)!!\"\n        [hideClose]=\"(hideClose$ | async)!!\"\n        [hideTitle]=\"(hideTitle$ | async)!!\"\n        [hidePin]=\"(hidePin$ | async)!!\"\n        [title]=\"(title$ | async)!!\"\n        [subtitle]=\"(headerSubtitle$ | async)!!\"\n        [toolbarItems]=\"toolbarItems$ | async | tlbButtons: 'inFooter':false\"\n        [layoutActions]=\"toolbarItems$ | async | tlbButtons: 'inFooter':true\"\n        [toolbarVisible]=\"(toolbarVisible$ | async)!!\"\n        [facetList]=\"(headerLayout$ | async)?.FacetList2\"\n        [parameters]=\"parameters\"\n        [workflowPanelUi]=\"workflowPanelUi$ | async\"\n        [isMobile]=\"isMobile\"\n        [layout94]=\"layout94$ | async\"\n        [rtl]=\"(rtl$ | async)!!\"\n        [mask]=\"(mask$ | async)!!\"\n        [mo]=\"(mo$ | async)!!\"\n        [dirValue]=\"(dirValue$ | async)!!\"\n        [deviceSize]=\"(deviceSize$ | async)!!\"\n        [contentDensity]=\"(contentDensity$ | async)!!\"\n        [modernTabs]=\"(modernTabs$ | async)!!\"\n        [avatar]=\"(avatar$ | async)!!\"\n        [fieldDict]=\"(fieldDict$ | async)!!\"\n        (close)=\"onClose()\"\n        (toolbarClick)=\"onToolbarClick($event)\"\n        [contentIsPage]=\"parameters?.ContentIsPage\"\n        (workflowChoiceClick)=\"onWorkflowChoiceClick($event)\"\n    ></bsu-fundamental-dynamic-form>\n</ng-template>\n"]}
@@ -87,10 +87,10 @@ export class UiTableViewComponent extends ReportViewBaseComponent {
87
87
  }
88
88
  }
89
89
  UiTableViewComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: UiTableViewComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
90
- UiTableViewComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: UiTableViewComponent, selector: "bsu-ui-table-view", inputs: { columnWidth: "columnWidth", minWidth: "minWidth", minHeight: "minHeight", rowResizer: "rowResizer", enableResizing: "enableResizing" }, host: { properties: { "style.height.px": "this.height", "style.max-height": "this.maxHeight" } }, usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<table\n fd-table\n [popIn]=\"popin\"\n [class.fixed]=\"!contextView?.Grid_HideHeader && (!popin || secondaryColumns.length === 0)\"\n [noBorderX]=\"viewSetting?.NoVerticalBorders === true || (popin && secondaryColumns.length > 0)\"\n [noBorderY]=\"viewSetting?.NoHoriztonalBorders === true || (popin && secondaryColumns.length > 0)\"\n tableResizer\n [fitWidth]=\"fitWidth\"\n (columnResized)=\"onColumnResized($event)\"\n [containerWidth]=\"containerWidth\"\n [minWidth]=\"30\"\n [minHeight]=\"22\"\n [rowResizer]=\"rowResizer\"\n [enableResizing]=\"enableResizing\"\n>\n <ng-container\n *ngIf=\"columns | mergeFieldsToColumns: viewSetting?.MergeFieldsToColumns?.MoDataList as mergeFieldsToColumns\"\n >\n <ng-container *ngTemplateOutlet=\"headerTemplate; context: { $implicit: mergeFieldsToColumns }\"></ng-container>\n <ng-container *ngTemplateOutlet=\"bodyTemplate; context: { $implicit: mergeFieldsToColumns }\"></ng-container>\n <ng-container *ngTemplateOutlet=\"footerTemplate; context: { $implicit: mergeFieldsToColumns }\"></ng-container>\n </ng-container>\n</table>\n<ng-template #headerTemplate let-columns>\n <bsu-barsa-table-header\n [tableWidth]=\"elWidth\"\n [showDetailsInRow]=\"showDetailsInRow\"\n [hideOpenIcon]=\"hideOpenIcon\"\n [resizedByUser]=\"resizedByUser\"\n [allChecked]=\"allChecked\"\n [disableResponsive]=\"disableResponsive\"\n [isCheckList]=\"isCheckList\"\n [columns]=\"columns | filterColumnsByDetails: detailsColumns\"\n [fitWidth]=\"fitWidth\"\n [disableOverflowContextMenu]=\"disableOverflowContextMenu\"\n [inlineEditMode]=\"inlineEditMode\"\n [contextMenuItems]=\"contextMenuItems\"\n [canView]=\"canView\"\n [viewSetting]=\"viewSetting\"\n [hideHeader]=\"contextView.Grid_HideHeader\"\n (allCheckbox)=\"onAllCheckbox($event)\"\n (sortAscending)=\"onSortAscending($event)\"\n (sortDescending)=\"onSortDescending($event)\"\n (filter)=\"onFilter($event)\"\n ></bsu-barsa-table-header>\n</ng-template>\n<ng-template #bodyTemplate let-columns>\n <tbody\n fd-table-body\n [noBorderX]=\"popin && secondaryColumns.length > 0\"\n [noBorderY]=\"popin && secondaryColumns.length > 0\"\n >\n <ng-container *ngIf=\"moDataList && moDataList.length > 0; else noData\">\n <ng-container\n *ngFor=\"let mo of moDataList | multipleGroupBy: groupby; let index = index; trackBy: _trackByRow\"\n >\n <ng-container\n *ngTemplateOutlet=\"\n rowTemplate;\n context: { $implicit: mo, index: index, columns: columns, moDataListCount: moDataList.length }\n \"\n ></ng-container>\n </ng-container>\n </ng-container>\n </tbody>\n</ng-template>\n<ng-template #footerTemplate let-columns>\n <tfoot fd-table-footer *ngIf=\"hasSummary\">\n <tr fd-table-row class=\"row-summary\">\n <td fd-table-cell *ngIf=\"isCheckList\" columnResizer>\n <strong class=\"col-total-text\">{{ 'Total' | bbbTranslate }}</strong>\n </td>\n <td fd-table-cell *ngIf=\"!isCheckList\" class=\"single-select\">\n <strong class=\"col-total-text\">{{ 'Total' | bbbTranslate }}</strong>\n </td>\n <td *ngFor=\"let column of columns; let i = index\">\n <ng-container *ngIf=\"column.HasSummary\">\n <strong style=\"direction: ltr; display: block\">\n {{ moDataList | totalSummary: column.Name | number }}</strong\n >\n </ng-container>\n </td>\n <ng-container *ngIf=\"contextMenuItems && contextMenuItems.length > 0\">\n <td fd-table-cell style=\"width: 100px\"></td>\n </ng-container>\n <td fd-table-cell *ngIf=\"canView\"></td>\n </tr>\n </tfoot>\n</ng-template>\n<ng-template #rowTemplate let-mo let-index=\"index\" let-columns=\"columns\" let-moDataListCount=\"moDataListCount\">\n <bsu-barsa-table-row\n [mo]=\"mo\"\n [showDetailsInRow]=\"showDetailsInRow\"\n [hideOpenIcon]=\"hideOpenIcon\"\n [detailsColumns]=\"detailsColumns\"\n [cartableTemplate]=\"cartableTemplates[mo.RelatedMo?.$TypeDefId]\"\n [cartableMo]=\"mo.RelatedMo\"\n [cartableWorkflowData]=\"mo.SerializedWorkflowData\"\n [detailsText]=\"viewSetting?.DetailsSetting?.ButtonText\"\n [detailsComponent]=\"detailsComponent\"\n [isChecked]=\"mo.$IsChecked\"\n [visibility]=\"mo.$Visibility\"\n [expanded]=\"mo.$Expanded\"\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\"\n [columns]=\"columns | filterColumnsByDetails: detailsColumns\"\n [isNewInlineMo]=\"mo.$NewInlineMo\"\n [access]=\"access\"\n [inlineEditMode]=\"inlineEditMode\"\n [allowInlineEdit]=\"allowInlineEdit\"\n [rtl]=\"rtl\"\n [deviceName]=\"deviceName\"\n [deviceSize]=\"deviceSize\"\n [index]=\"index\"\n [allColumns]=\"allColumns\"\n [contextMenuItems]=\"contextMenuItems\"\n [canView]=\"canView\"\n [conditionalFormats]=\"conditionalFormats\"\n [disableOverflowContextMenu]=\"disableOverflowContextMenu\"\n [navigationArrow]=\"navigationArrow\"\n [isCheckList]=\"isCheckList\"\n (expandClick)=\"onExpandClick($event)\"\n (rowCheck)=\"onRowCheck($event)\"\n (rowClick)=\"onRowClick($event)\"\n (ulvCommand)=\"onUlvCommand($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</ng-template>\n<!--renderColumn-->\n<ng-template #noData>\n <tr *ngIf=\"!inlineEditMode || !newInlineEditMo\">\n <td colspan=\"100%\" style=\"padding: 10px\">{{ 'NoData' | bbbTranslate }}</td>\n </tr>\n</ng-template>\n", styles: [":host{display:block;width:100%;overflow-x:auto;max-width:100vw}table{margin-bottom:5px}table.fixed{table-layout:fixed}table.fixed td{overflow:hidden}tr td{font-weight:inherit}::ng-deep span.fd-toolbar__spacer{display:none}.row-summary{position:relative}.row-summary .col-total-text{position:absolute;top:25%}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.TableResizerDirective, selector: "[tableResizer]", inputs: ["fitWidth", "minWidth", "minHeight", "containerWidth", "rowResizer", "enableResizing"], outputs: ["columnResized"] }, { kind: "directive", type: i2.ColumnResizerDirective, selector: "[columnResizer]", inputs: ["disableResizer"] }, { kind: "component", type: i3.TableComponent, selector: "table[fd-table]", inputs: ["noBorderX", "noBorderY", "popIn", "responsive", "keys", "allCellsFocusable"], exportAs: ["fd-table"] }, { kind: "directive", type: i3.TableFooterDirective, selector: "[fdTableFooter], [fd-table-footer]" }, { kind: "directive", type: i3.TableBodyDirective, selector: "[fdTableBody], [fd-table-body]", inputs: ["noBorderX", "noBorderY"] }, { kind: "directive", type: i3.TableRowDirective, selector: "[fdTableRow], [fd-table-row]", inputs: ["activable", "highlightActive", "hoverable", "focusable", "main", "secondary", "active"] }, { kind: "directive", type: i3.TableCellDirective, selector: "[fdTableCell], [fd-table-cell]", inputs: ["noBorderX", "noBorderY", "activable", "focusable", "tabindex", "hoverable", "fitContent", "noPadding", "noData", "key", "cellFocusedEventAnnouncer"] }, { kind: "component", type: i4.BarsaTableHeaderComponent, selector: "bsu-barsa-table-header", inputs: ["allChecked", "isCheckList", "columns", "fitWidth", "contextMenuItems", "canView", "hideOpenIcon", "disableOverflowContextMenu", "inlineEditMode", "hideHeader", "showDetailsInRow", "viewSetting", "tableWidth", "resizedByUser", "disableResponsive"], outputs: ["allCheckbox", "sortAscending", "sortDescending", "filter"] }, { kind: "component", type: i5.BarsaTableRowComponent, selector: "bsu-barsa-table-row", inputs: ["showDetailsInRow", "detailsComponent", "detailsColumns", "detailsText", "columnComponents"] }, { kind: "pipe", type: i1.DecimalPipe, name: "number" }, { kind: "pipe", type: i2.MultipleGroupByPipe, name: "multipleGroupBy" }, { kind: "pipe", type: i2.BbbTranslatePipe, name: "bbbTranslate" }, { kind: "pipe", type: i2.TotalSummaryPipe, name: "totalSummary" }, { kind: "pipe", type: i2.MergeFieldsToColumnsPipe, name: "mergeFieldsToColumns" }, { kind: "pipe", type: i2.FilterColumnsByDetailsPipe, name: "filterColumnsByDetails" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
90
+ UiTableViewComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: UiTableViewComponent, selector: "bsu-ui-table-view", inputs: { columnWidth: "columnWidth", minWidth: "minWidth", minHeight: "minHeight", rowResizer: "rowResizer", enableResizing: "enableResizing" }, host: { properties: { "style.height.px": "this.height", "style.max-height": "this.maxHeight" } }, usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<table\r\n fd-table\r\n [popIn]=\"popin\"\r\n [class.fixed]=\"!contextView?.Grid_HideHeader && (!popin || secondaryColumns.length === 0)\"\r\n [noBorderX]=\"viewSetting?.NoVerticalBorders === true || (popin && secondaryColumns.length > 0)\"\r\n [noBorderY]=\"viewSetting?.NoHoriztonalBorders === true || (popin && secondaryColumns.length > 0)\"\r\n tableResizer\r\n [fitWidth]=\"fitWidth\"\r\n (columnResized)=\"onColumnResized($event)\"\r\n [containerWidth]=\"containerWidth\"\r\n [minWidth]=\"30\"\r\n [minHeight]=\"22\"\r\n [rowResizer]=\"rowResizer\"\r\n [enableResizing]=\"enableResizing\"\r\n>\r\n <ng-container\r\n *ngIf=\"columns | mergeFieldsToColumns: viewSetting?.MergeFieldsToColumns?.MoDataList as mergeFieldsToColumns\"\r\n >\r\n <ng-container *ngTemplateOutlet=\"headerTemplate; context: { $implicit: mergeFieldsToColumns }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"bodyTemplate; context: { $implicit: mergeFieldsToColumns }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"footerTemplate; context: { $implicit: mergeFieldsToColumns }\"></ng-container>\r\n </ng-container>\r\n</table>\r\n<ng-template #headerTemplate let-columns>\r\n <bsu-barsa-table-header\r\n [tableWidth]=\"elWidth\"\r\n [showDetailsInRow]=\"showDetailsInRow\"\r\n [hideOpenIcon]=\"hideOpenIcon\"\r\n [resizedByUser]=\"resizedByUser\"\r\n [allChecked]=\"allChecked\"\r\n [disableResponsive]=\"disableResponsive\"\r\n [isCheckList]=\"isCheckList\"\r\n [columns]=\"columns | filterColumnsByDetails: detailsColumns\"\r\n [fitWidth]=\"fitWidth\"\r\n [disableOverflowContextMenu]=\"disableOverflowContextMenu\"\r\n [inlineEditMode]=\"inlineEditMode\"\r\n [contextMenuItems]=\"contextMenuItems\"\r\n [canView]=\"canView\"\r\n [viewSetting]=\"viewSetting\"\r\n [hideHeader]=\"contextView.Grid_HideHeader\"\r\n (allCheckbox)=\"onAllCheckbox($event)\"\r\n (sortAscending)=\"onSortAscending($event)\"\r\n (sortDescending)=\"onSortDescending($event)\"\r\n (filter)=\"onFilter($event)\"\r\n ></bsu-barsa-table-header>\r\n</ng-template>\r\n<ng-template #bodyTemplate let-columns>\r\n <tbody\r\n fd-table-body\r\n [noBorderX]=\"popin && secondaryColumns.length > 0\"\r\n [noBorderY]=\"popin && secondaryColumns.length > 0\"\r\n >\r\n <ng-container *ngIf=\"moDataList && moDataList.length > 0; else noData\">\r\n <ng-container\r\n *ngFor=\"let mo of moDataList | multipleGroupBy: groupby; let index = index; trackBy: _trackByRow\"\r\n >\r\n <ng-container\r\n *ngTemplateOutlet=\"\r\n rowTemplate;\r\n context: { $implicit: mo, index: index, columns: columns, moDataListCount: moDataList.length }\r\n \"\r\n ></ng-container>\r\n </ng-container>\r\n </ng-container>\r\n </tbody>\r\n</ng-template>\r\n<ng-template #footerTemplate let-columns>\r\n <tfoot fd-table-footer *ngIf=\"hasSummary\">\r\n <tr fd-table-row class=\"row-summary\">\r\n <td fd-table-cell *ngIf=\"isCheckList\" columnResizer>\r\n <strong class=\"col-total-text\">{{ 'Total' | bbbTranslate }}</strong>\r\n </td>\r\n <td fd-table-cell *ngIf=\"!isCheckList\" class=\"single-select\">\r\n <strong class=\"col-total-text\">{{ 'Total' | bbbTranslate }}</strong>\r\n </td>\r\n <td *ngFor=\"let column of columns; let i = index\">\r\n <ng-container *ngIf=\"column.HasSummary\">\r\n <strong style=\"direction: ltr; display: block\">\r\n {{ moDataList | totalSummary: column.Name | number }}</strong\r\n >\r\n </ng-container>\r\n </td>\r\n <ng-container *ngIf=\"contextMenuItems && contextMenuItems.length > 0\">\r\n <td fd-table-cell style=\"width: 100px\"></td>\r\n </ng-container>\r\n <td fd-table-cell *ngIf=\"canView\"></td>\r\n </tr>\r\n </tfoot>\r\n</ng-template>\r\n<ng-template #rowTemplate let-mo let-index=\"index\" let-columns=\"columns\" let-moDataListCount=\"moDataListCount\">\r\n <bsu-barsa-table-row\r\n [mo]=\"mo\"\r\n [showDetailsInRow]=\"showDetailsInRow\"\r\n [hideOpenIcon]=\"hideOpenIcon\"\r\n [detailsColumns]=\"detailsColumns\"\r\n [cartableTemplate]=\"cartableTemplates[mo.RelatedMo?.$TypeDefId]\"\r\n [cartableMo]=\"mo.RelatedMo\"\r\n [cartableWorkflowData]=\"mo.SerializedWorkflowData\"\r\n [serializedRelatedMo]=\"mo.SerializedRelatedMo\"\r\n [detailsText]=\"viewSetting?.DetailsSetting?.ButtonText\"\r\n [detailsComponent]=\"detailsComponent\"\r\n [isChecked]=\"mo.$IsChecked\"\r\n [visibility]=\"mo.$Visibility\"\r\n [expanded]=\"mo.$Expanded\"\r\n [level]=\"mo.$Level\"\r\n [parentExpanded]=\"mo.$Parent?.$Expanded\"\r\n [moDataListCount]=\"moDataListCount\"\r\n [columnsCount]=\"columnsCount - detailsColumns.length\"\r\n [typeDefId]=\"typeDefId\"\r\n [extraRelation]=\"extraRelation\"\r\n [formSetting]=\"formSetting\"\r\n [index]=\"index\"\r\n [setting]=\"viewSetting\"\r\n [secondaryColumns]=\"secondaryColumns | filterColumnsByDetails: detailsColumns\"\r\n [columns]=\"columns | filterColumnsByDetails: detailsColumns\"\r\n [isNewInlineMo]=\"mo.$NewInlineMo\"\r\n [access]=\"access\"\r\n [inlineEditMode]=\"inlineEditMode\"\r\n [allowInlineEdit]=\"allowInlineEdit\"\r\n [rtl]=\"rtl\"\r\n [deviceName]=\"deviceName\"\r\n [deviceSize]=\"deviceSize\"\r\n [index]=\"index\"\r\n [allColumns]=\"allColumns\"\r\n [contextMenuItems]=\"contextMenuItems\"\r\n [canView]=\"canView\"\r\n [conditionalFormats]=\"conditionalFormats\"\r\n [disableOverflowContextMenu]=\"disableOverflowContextMenu\"\r\n [navigationArrow]=\"navigationArrow\"\r\n [isCheckList]=\"isCheckList\"\r\n (expandClick)=\"onExpandClick($event)\"\r\n (rowCheck)=\"onRowCheck($event)\"\r\n (rowClick)=\"onRowClick($event)\"\r\n (ulvCommand)=\"onUlvCommand($event)\"\r\n (selectNextInlineRecord)=\"onSelectNextInlineRecord($event)\"\r\n (editFormPanelSave)=\"onEditFormPanelSave($event)\"\r\n (editFormPanelCancel)=\"onEditFormPanelCancel($event)\"\r\n (editFormPanelValueChange)=\"onEditFormPanelValueChange($event)\"\r\n (cartableFormClosed)=\"onCartableFormClosed($event)\"\r\n >\r\n </bsu-barsa-table-row>\r\n</ng-template>\r\n<!--renderColumn-->\r\n<ng-template #noData>\r\n <tr *ngIf=\"!inlineEditMode || !newInlineEditMo\">\r\n <td colspan=\"100%\" style=\"padding: 10px\">{{ 'NoData' | bbbTranslate }}</td>\r\n </tr>\r\n</ng-template>\r\n", styles: [":host{display:block;width:100%;overflow-x:auto;max-width:100vw}table{margin-bottom:5px}table.fixed{table-layout:fixed}table.fixed td{overflow:hidden}tr td{font-weight:inherit}::ng-deep span.fd-toolbar__spacer{display:none}.row-summary{position:relative}.row-summary .col-total-text{position:absolute;top:25%}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.TableResizerDirective, selector: "[tableResizer]", inputs: ["fitWidth", "minWidth", "minHeight", "containerWidth", "rowResizer", "enableResizing"], outputs: ["columnResized"] }, { kind: "directive", type: i2.ColumnResizerDirective, selector: "[columnResizer]", inputs: ["disableResizer"] }, { kind: "component", type: i3.TableComponent, selector: "table[fd-table]", inputs: ["noBorderX", "noBorderY", "popIn", "responsive", "keys", "allCellsFocusable"], exportAs: ["fd-table"] }, { kind: "directive", type: i3.TableFooterDirective, selector: "[fdTableFooter], [fd-table-footer]" }, { kind: "directive", type: i3.TableBodyDirective, selector: "[fdTableBody], [fd-table-body]", inputs: ["noBorderX", "noBorderY"] }, { kind: "directive", type: i3.TableRowDirective, selector: "[fdTableRow], [fd-table-row]", inputs: ["activable", "highlightActive", "hoverable", "focusable", "main", "secondary", "active"] }, { kind: "directive", type: i3.TableCellDirective, selector: "[fdTableCell], [fd-table-cell]", inputs: ["noBorderX", "noBorderY", "activable", "focusable", "tabindex", "hoverable", "fitContent", "noPadding", "noData", "key", "cellFocusedEventAnnouncer"] }, { kind: "component", type: i4.BarsaTableHeaderComponent, selector: "bsu-barsa-table-header", inputs: ["allChecked", "isCheckList", "columns", "fitWidth", "contextMenuItems", "canView", "hideOpenIcon", "disableOverflowContextMenu", "inlineEditMode", "hideHeader", "showDetailsInRow", "viewSetting", "tableWidth", "resizedByUser", "disableResponsive"], outputs: ["allCheckbox", "sortAscending", "sortDescending", "filter"] }, { kind: "component", type: i5.BarsaTableRowComponent, selector: "bsu-barsa-table-row", inputs: ["showDetailsInRow", "detailsComponent", "detailsColumns", "detailsText", "columnComponents"] }, { kind: "pipe", type: i1.DecimalPipe, name: "number" }, { kind: "pipe", type: i2.MultipleGroupByPipe, name: "multipleGroupBy" }, { kind: "pipe", type: i2.BbbTranslatePipe, name: "bbbTranslate" }, { kind: "pipe", type: i2.TotalSummaryPipe, name: "totalSummary" }, { kind: "pipe", type: i2.MergeFieldsToColumnsPipe, name: "mergeFieldsToColumns" }, { kind: "pipe", type: i2.FilterColumnsByDetailsPipe, name: "filterColumnsByDetails" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
91
91
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: UiTableViewComponent, decorators: [{
92
92
  type: Component,
93
- args: [{ selector: 'bsu-ui-table-view', changeDetection: ChangeDetectionStrategy.OnPush, template: "<table\n fd-table\n [popIn]=\"popin\"\n [class.fixed]=\"!contextView?.Grid_HideHeader && (!popin || secondaryColumns.length === 0)\"\n [noBorderX]=\"viewSetting?.NoVerticalBorders === true || (popin && secondaryColumns.length > 0)\"\n [noBorderY]=\"viewSetting?.NoHoriztonalBorders === true || (popin && secondaryColumns.length > 0)\"\n tableResizer\n [fitWidth]=\"fitWidth\"\n (columnResized)=\"onColumnResized($event)\"\n [containerWidth]=\"containerWidth\"\n [minWidth]=\"30\"\n [minHeight]=\"22\"\n [rowResizer]=\"rowResizer\"\n [enableResizing]=\"enableResizing\"\n>\n <ng-container\n *ngIf=\"columns | mergeFieldsToColumns: viewSetting?.MergeFieldsToColumns?.MoDataList as mergeFieldsToColumns\"\n >\n <ng-container *ngTemplateOutlet=\"headerTemplate; context: { $implicit: mergeFieldsToColumns }\"></ng-container>\n <ng-container *ngTemplateOutlet=\"bodyTemplate; context: { $implicit: mergeFieldsToColumns }\"></ng-container>\n <ng-container *ngTemplateOutlet=\"footerTemplate; context: { $implicit: mergeFieldsToColumns }\"></ng-container>\n </ng-container>\n</table>\n<ng-template #headerTemplate let-columns>\n <bsu-barsa-table-header\n [tableWidth]=\"elWidth\"\n [showDetailsInRow]=\"showDetailsInRow\"\n [hideOpenIcon]=\"hideOpenIcon\"\n [resizedByUser]=\"resizedByUser\"\n [allChecked]=\"allChecked\"\n [disableResponsive]=\"disableResponsive\"\n [isCheckList]=\"isCheckList\"\n [columns]=\"columns | filterColumnsByDetails: detailsColumns\"\n [fitWidth]=\"fitWidth\"\n [disableOverflowContextMenu]=\"disableOverflowContextMenu\"\n [inlineEditMode]=\"inlineEditMode\"\n [contextMenuItems]=\"contextMenuItems\"\n [canView]=\"canView\"\n [viewSetting]=\"viewSetting\"\n [hideHeader]=\"contextView.Grid_HideHeader\"\n (allCheckbox)=\"onAllCheckbox($event)\"\n (sortAscending)=\"onSortAscending($event)\"\n (sortDescending)=\"onSortDescending($event)\"\n (filter)=\"onFilter($event)\"\n ></bsu-barsa-table-header>\n</ng-template>\n<ng-template #bodyTemplate let-columns>\n <tbody\n fd-table-body\n [noBorderX]=\"popin && secondaryColumns.length > 0\"\n [noBorderY]=\"popin && secondaryColumns.length > 0\"\n >\n <ng-container *ngIf=\"moDataList && moDataList.length > 0; else noData\">\n <ng-container\n *ngFor=\"let mo of moDataList | multipleGroupBy: groupby; let index = index; trackBy: _trackByRow\"\n >\n <ng-container\n *ngTemplateOutlet=\"\n rowTemplate;\n context: { $implicit: mo, index: index, columns: columns, moDataListCount: moDataList.length }\n \"\n ></ng-container>\n </ng-container>\n </ng-container>\n </tbody>\n</ng-template>\n<ng-template #footerTemplate let-columns>\n <tfoot fd-table-footer *ngIf=\"hasSummary\">\n <tr fd-table-row class=\"row-summary\">\n <td fd-table-cell *ngIf=\"isCheckList\" columnResizer>\n <strong class=\"col-total-text\">{{ 'Total' | bbbTranslate }}</strong>\n </td>\n <td fd-table-cell *ngIf=\"!isCheckList\" class=\"single-select\">\n <strong class=\"col-total-text\">{{ 'Total' | bbbTranslate }}</strong>\n </td>\n <td *ngFor=\"let column of columns; let i = index\">\n <ng-container *ngIf=\"column.HasSummary\">\n <strong style=\"direction: ltr; display: block\">\n {{ moDataList | totalSummary: column.Name | number }}</strong\n >\n </ng-container>\n </td>\n <ng-container *ngIf=\"contextMenuItems && contextMenuItems.length > 0\">\n <td fd-table-cell style=\"width: 100px\"></td>\n </ng-container>\n <td fd-table-cell *ngIf=\"canView\"></td>\n </tr>\n </tfoot>\n</ng-template>\n<ng-template #rowTemplate let-mo let-index=\"index\" let-columns=\"columns\" let-moDataListCount=\"moDataListCount\">\n <bsu-barsa-table-row\n [mo]=\"mo\"\n [showDetailsInRow]=\"showDetailsInRow\"\n [hideOpenIcon]=\"hideOpenIcon\"\n [detailsColumns]=\"detailsColumns\"\n [cartableTemplate]=\"cartableTemplates[mo.RelatedMo?.$TypeDefId]\"\n [cartableMo]=\"mo.RelatedMo\"\n [cartableWorkflowData]=\"mo.SerializedWorkflowData\"\n [detailsText]=\"viewSetting?.DetailsSetting?.ButtonText\"\n [detailsComponent]=\"detailsComponent\"\n [isChecked]=\"mo.$IsChecked\"\n [visibility]=\"mo.$Visibility\"\n [expanded]=\"mo.$Expanded\"\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\"\n [columns]=\"columns | filterColumnsByDetails: detailsColumns\"\n [isNewInlineMo]=\"mo.$NewInlineMo\"\n [access]=\"access\"\n [inlineEditMode]=\"inlineEditMode\"\n [allowInlineEdit]=\"allowInlineEdit\"\n [rtl]=\"rtl\"\n [deviceName]=\"deviceName\"\n [deviceSize]=\"deviceSize\"\n [index]=\"index\"\n [allColumns]=\"allColumns\"\n [contextMenuItems]=\"contextMenuItems\"\n [canView]=\"canView\"\n [conditionalFormats]=\"conditionalFormats\"\n [disableOverflowContextMenu]=\"disableOverflowContextMenu\"\n [navigationArrow]=\"navigationArrow\"\n [isCheckList]=\"isCheckList\"\n (expandClick)=\"onExpandClick($event)\"\n (rowCheck)=\"onRowCheck($event)\"\n (rowClick)=\"onRowClick($event)\"\n (ulvCommand)=\"onUlvCommand($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</ng-template>\n<!--renderColumn-->\n<ng-template #noData>\n <tr *ngIf=\"!inlineEditMode || !newInlineEditMo\">\n <td colspan=\"100%\" style=\"padding: 10px\">{{ 'NoData' | bbbTranslate }}</td>\n </tr>\n</ng-template>\n", styles: [":host{display:block;width:100%;overflow-x:auto;max-width:100vw}table{margin-bottom:5px}table.fixed{table-layout:fixed}table.fixed td{overflow:hidden}tr td{font-weight:inherit}::ng-deep span.fd-toolbar__spacer{display:none}.row-summary{position:relative}.row-summary .col-total-text{position:absolute;top:25%}\n"] }]
93
+ args: [{ selector: 'bsu-ui-table-view', changeDetection: ChangeDetectionStrategy.OnPush, template: "<table\r\n fd-table\r\n [popIn]=\"popin\"\r\n [class.fixed]=\"!contextView?.Grid_HideHeader && (!popin || secondaryColumns.length === 0)\"\r\n [noBorderX]=\"viewSetting?.NoVerticalBorders === true || (popin && secondaryColumns.length > 0)\"\r\n [noBorderY]=\"viewSetting?.NoHoriztonalBorders === true || (popin && secondaryColumns.length > 0)\"\r\n tableResizer\r\n [fitWidth]=\"fitWidth\"\r\n (columnResized)=\"onColumnResized($event)\"\r\n [containerWidth]=\"containerWidth\"\r\n [minWidth]=\"30\"\r\n [minHeight]=\"22\"\r\n [rowResizer]=\"rowResizer\"\r\n [enableResizing]=\"enableResizing\"\r\n>\r\n <ng-container\r\n *ngIf=\"columns | mergeFieldsToColumns: viewSetting?.MergeFieldsToColumns?.MoDataList as mergeFieldsToColumns\"\r\n >\r\n <ng-container *ngTemplateOutlet=\"headerTemplate; context: { $implicit: mergeFieldsToColumns }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"bodyTemplate; context: { $implicit: mergeFieldsToColumns }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"footerTemplate; context: { $implicit: mergeFieldsToColumns }\"></ng-container>\r\n </ng-container>\r\n</table>\r\n<ng-template #headerTemplate let-columns>\r\n <bsu-barsa-table-header\r\n [tableWidth]=\"elWidth\"\r\n [showDetailsInRow]=\"showDetailsInRow\"\r\n [hideOpenIcon]=\"hideOpenIcon\"\r\n [resizedByUser]=\"resizedByUser\"\r\n [allChecked]=\"allChecked\"\r\n [disableResponsive]=\"disableResponsive\"\r\n [isCheckList]=\"isCheckList\"\r\n [columns]=\"columns | filterColumnsByDetails: detailsColumns\"\r\n [fitWidth]=\"fitWidth\"\r\n [disableOverflowContextMenu]=\"disableOverflowContextMenu\"\r\n [inlineEditMode]=\"inlineEditMode\"\r\n [contextMenuItems]=\"contextMenuItems\"\r\n [canView]=\"canView\"\r\n [viewSetting]=\"viewSetting\"\r\n [hideHeader]=\"contextView.Grid_HideHeader\"\r\n (allCheckbox)=\"onAllCheckbox($event)\"\r\n (sortAscending)=\"onSortAscending($event)\"\r\n (sortDescending)=\"onSortDescending($event)\"\r\n (filter)=\"onFilter($event)\"\r\n ></bsu-barsa-table-header>\r\n</ng-template>\r\n<ng-template #bodyTemplate let-columns>\r\n <tbody\r\n fd-table-body\r\n [noBorderX]=\"popin && secondaryColumns.length > 0\"\r\n [noBorderY]=\"popin && secondaryColumns.length > 0\"\r\n >\r\n <ng-container *ngIf=\"moDataList && moDataList.length > 0; else noData\">\r\n <ng-container\r\n *ngFor=\"let mo of moDataList | multipleGroupBy: groupby; let index = index; trackBy: _trackByRow\"\r\n >\r\n <ng-container\r\n *ngTemplateOutlet=\"\r\n rowTemplate;\r\n context: { $implicit: mo, index: index, columns: columns, moDataListCount: moDataList.length }\r\n \"\r\n ></ng-container>\r\n </ng-container>\r\n </ng-container>\r\n </tbody>\r\n</ng-template>\r\n<ng-template #footerTemplate let-columns>\r\n <tfoot fd-table-footer *ngIf=\"hasSummary\">\r\n <tr fd-table-row class=\"row-summary\">\r\n <td fd-table-cell *ngIf=\"isCheckList\" columnResizer>\r\n <strong class=\"col-total-text\">{{ 'Total' | bbbTranslate }}</strong>\r\n </td>\r\n <td fd-table-cell *ngIf=\"!isCheckList\" class=\"single-select\">\r\n <strong class=\"col-total-text\">{{ 'Total' | bbbTranslate }}</strong>\r\n </td>\r\n <td *ngFor=\"let column of columns; let i = index\">\r\n <ng-container *ngIf=\"column.HasSummary\">\r\n <strong style=\"direction: ltr; display: block\">\r\n {{ moDataList | totalSummary: column.Name | number }}</strong\r\n >\r\n </ng-container>\r\n </td>\r\n <ng-container *ngIf=\"contextMenuItems && contextMenuItems.length > 0\">\r\n <td fd-table-cell style=\"width: 100px\"></td>\r\n </ng-container>\r\n <td fd-table-cell *ngIf=\"canView\"></td>\r\n </tr>\r\n </tfoot>\r\n</ng-template>\r\n<ng-template #rowTemplate let-mo let-index=\"index\" let-columns=\"columns\" let-moDataListCount=\"moDataListCount\">\r\n <bsu-barsa-table-row\r\n [mo]=\"mo\"\r\n [showDetailsInRow]=\"showDetailsInRow\"\r\n [hideOpenIcon]=\"hideOpenIcon\"\r\n [detailsColumns]=\"detailsColumns\"\r\n [cartableTemplate]=\"cartableTemplates[mo.RelatedMo?.$TypeDefId]\"\r\n [cartableMo]=\"mo.RelatedMo\"\r\n [cartableWorkflowData]=\"mo.SerializedWorkflowData\"\r\n [serializedRelatedMo]=\"mo.SerializedRelatedMo\"\r\n [detailsText]=\"viewSetting?.DetailsSetting?.ButtonText\"\r\n [detailsComponent]=\"detailsComponent\"\r\n [isChecked]=\"mo.$IsChecked\"\r\n [visibility]=\"mo.$Visibility\"\r\n [expanded]=\"mo.$Expanded\"\r\n [level]=\"mo.$Level\"\r\n [parentExpanded]=\"mo.$Parent?.$Expanded\"\r\n [moDataListCount]=\"moDataListCount\"\r\n [columnsCount]=\"columnsCount - detailsColumns.length\"\r\n [typeDefId]=\"typeDefId\"\r\n [extraRelation]=\"extraRelation\"\r\n [formSetting]=\"formSetting\"\r\n [index]=\"index\"\r\n [setting]=\"viewSetting\"\r\n [secondaryColumns]=\"secondaryColumns | filterColumnsByDetails: detailsColumns\"\r\n [columns]=\"columns | filterColumnsByDetails: detailsColumns\"\r\n [isNewInlineMo]=\"mo.$NewInlineMo\"\r\n [access]=\"access\"\r\n [inlineEditMode]=\"inlineEditMode\"\r\n [allowInlineEdit]=\"allowInlineEdit\"\r\n [rtl]=\"rtl\"\r\n [deviceName]=\"deviceName\"\r\n [deviceSize]=\"deviceSize\"\r\n [index]=\"index\"\r\n [allColumns]=\"allColumns\"\r\n [contextMenuItems]=\"contextMenuItems\"\r\n [canView]=\"canView\"\r\n [conditionalFormats]=\"conditionalFormats\"\r\n [disableOverflowContextMenu]=\"disableOverflowContextMenu\"\r\n [navigationArrow]=\"navigationArrow\"\r\n [isCheckList]=\"isCheckList\"\r\n (expandClick)=\"onExpandClick($event)\"\r\n (rowCheck)=\"onRowCheck($event)\"\r\n (rowClick)=\"onRowClick($event)\"\r\n (ulvCommand)=\"onUlvCommand($event)\"\r\n (selectNextInlineRecord)=\"onSelectNextInlineRecord($event)\"\r\n (editFormPanelSave)=\"onEditFormPanelSave($event)\"\r\n (editFormPanelCancel)=\"onEditFormPanelCancel($event)\"\r\n (editFormPanelValueChange)=\"onEditFormPanelValueChange($event)\"\r\n (cartableFormClosed)=\"onCartableFormClosed($event)\"\r\n >\r\n </bsu-barsa-table-row>\r\n</ng-template>\r\n<!--renderColumn-->\r\n<ng-template #noData>\r\n <tr *ngIf=\"!inlineEditMode || !newInlineEditMo\">\r\n <td colspan=\"100%\" style=\"padding: 10px\">{{ 'NoData' | bbbTranslate }}</td>\r\n </tr>\r\n</ng-template>\r\n", styles: [":host{display:block;width:100%;overflow-x:auto;max-width:100vw}table{margin-bottom:5px}table.fixed{table-layout:fixed}table.fixed td{overflow:hidden}tr td{font-weight:inherit}::ng-deep span.fd-toolbar__spacer{display:none}.row-summary{position:relative}.row-summary .col-total-text{position:absolute;top:25%}\n"] }]
94
94
  }], propDecorators: { columnWidth: [{
95
95
  type: Input
96
96
  }], minWidth: [{
@@ -108,4 +108,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImpor
108
108
  type: HostBinding,
109
109
  args: ['style.max-height']
110
110
  }] } });
111
- //# 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 {\r\n    ChangeDetectionStrategy,\r\n    Component,\r\n    HostBinding,\r\n    Input,\r\n    OnChanges,\r\n    OnInit,\r\n    SimpleChanges\r\n} from '@angular/core';\r\nimport { EjrayOlgo, MetaobjectDataModel, ReportViewBaseComponent, ReportViewColumn } from 'barsa-novin-ray-core';\r\nimport { UiTableViewSetting } from '../models/grid-view';\r\n\r\n@Component({\r\n    selector: 'bsu-ui-table-view',\r\n    templateUrl: './ui-table-view.component.html',\r\n    styleUrls: ['./ui-table-view.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class UiTableViewComponent extends ReportViewBaseComponent<UiTableViewSetting> implements OnInit, OnChanges {\r\n    @Input() columnWidth: number;\r\n    @Input() minWidth;\r\n    @Input() minHeight;\r\n    @Input() rowResizer;\r\n    @Input() enableResizing;\r\n\r\n    @HostBinding('style.height.px') height: number | null = null;\r\n    @HostBinding('style.max-height') maxHeight: string | null = null;\r\n\r\n    _width = '100%';\r\n    detailsColumns: ReportViewColumn[] = [];\r\n    detailsComponent: EjrayOlgo;\r\n    showDetailsInRow: boolean;\r\n    columnComponents: { column: ReportViewColumn; component: MetaobjectDataModel }[] = [];\r\n\r\n    ngOnInit(): void {\r\n        super.ngOnInit();\r\n        const detailsSetting = this.viewSetting?.DetailsSetting;\r\n        this.maxHeight = this.viewSetting?.BodyHeight;\r\n        if (detailsSetting) {\r\n            this.detailsComponent = detailsSetting.Component;\r\n            detailsSetting.Columns.split(',').forEach((column: string) => {\r\n                const columnFound = this.findColumn(this.allColumns, column);\r\n                if (columnFound) {\r\n                    this.detailsColumns.push(columnFound);\r\n                }\r\n            });\r\n        }\r\n        this._setHasSummery(this.cartableChildsMo);\r\n        this._setColumnsComponent(this.allColumns);\r\n        this._setHeight(this.parentHeight);\r\n    }\r\n    ngOnChanges(changes: SimpleChanges): void {\r\n        super.ngOnChanges(changes);\r\n        const { allColumns, cartableTemplates, parentHeight } = changes;\r\n        if (allColumns && !allColumns.firstChange) {\r\n            this._setColumnsComponent(allColumns.currentValue);\r\n        }\r\n        if (cartableTemplates && !cartableTemplates.firstChange && !this.hasSummary) {\r\n            this._setHasSummery(cartableTemplates.currentValue);\r\n            this._cdr.detectChanges();\r\n        }\r\n        if (parentHeight && !parentHeight.firstChange) {\r\n            this._setHeight(parentHeight.currentValue);\r\n        }\r\n    }\r\n    protected _setHeight(parentHeight: number): void {\r\n        if (this.inDialog) {\r\n            this.height = parentHeight;\r\n        }\r\n    }\r\n    protected _setHasSummery(cartableTemplates): void {\r\n        if (\r\n            this.detailsColumns?.length > 0 ||\r\n            this.detailsComponent?.Selector ||\r\n            (cartableTemplates && Object.keys(cartableTemplates).length > 0)\r\n        ) {\r\n            this.showDetailsInRow = true;\r\n        }\r\n    }\r\n    protected _containerWidthChanged(val: number): void {\r\n        if (val === 0) {\r\n            this._width = '100%';\r\n        } else {\r\n            this._width = val + 'px';\r\n        }\r\n        this._renderer2.setStyle(this._el.nativeElement, 'width', this._width);\r\n    }\r\n    private _setColumnsComponent(columns: ReportViewColumn[]): void {\r\n        const columnComponents = this.viewSetting?.ColumnComponents;\r\n        if (columnComponents) {\r\n            columnComponents.MoDataList.forEach((c: MetaobjectDataModel) => {\r\n                const column = this.findColumn(columns, c.Title);\r\n                if (column) {\r\n                    column.$CustomComponent = c.Component;\r\n                }\r\n            });\r\n        }\r\n    }\r\n\r\n    private findColumn(columns: ReportViewColumn[], column: string): ReportViewColumn | undefined {\r\n        let columnFound = this._findColumnByDbName.transform(columns, column);\r\n        if (!columnFound && this.secondaryColumns.length) {\r\n            columnFound = this._findColumnByDbName.transform(this.secondaryColumns, column);\r\n        }\r\n        return columnFound;\r\n    }\r\n}\r\n","<table\n    fd-table\n    [popIn]=\"popin\"\n    [class.fixed]=\"!contextView?.Grid_HideHeader && (!popin || secondaryColumns.length === 0)\"\n    [noBorderX]=\"viewSetting?.NoVerticalBorders === true || (popin && secondaryColumns.length > 0)\"\n    [noBorderY]=\"viewSetting?.NoHoriztonalBorders === true || (popin && secondaryColumns.length > 0)\"\n    tableResizer\n    [fitWidth]=\"fitWidth\"\n    (columnResized)=\"onColumnResized($event)\"\n    [containerWidth]=\"containerWidth\"\n    [minWidth]=\"30\"\n    [minHeight]=\"22\"\n    [rowResizer]=\"rowResizer\"\n    [enableResizing]=\"enableResizing\"\n>\n    <ng-container\n        *ngIf=\"columns | mergeFieldsToColumns: viewSetting?.MergeFieldsToColumns?.MoDataList as mergeFieldsToColumns\"\n    >\n        <ng-container *ngTemplateOutlet=\"headerTemplate; context: { $implicit: mergeFieldsToColumns }\"></ng-container>\n        <ng-container *ngTemplateOutlet=\"bodyTemplate; context: { $implicit: mergeFieldsToColumns }\"></ng-container>\n        <ng-container *ngTemplateOutlet=\"footerTemplate; context: { $implicit: mergeFieldsToColumns }\"></ng-container>\n    </ng-container>\n</table>\n<ng-template #headerTemplate let-columns>\n    <bsu-barsa-table-header\n        [tableWidth]=\"elWidth\"\n        [showDetailsInRow]=\"showDetailsInRow\"\n        [hideOpenIcon]=\"hideOpenIcon\"\n        [resizedByUser]=\"resizedByUser\"\n        [allChecked]=\"allChecked\"\n        [disableResponsive]=\"disableResponsive\"\n        [isCheckList]=\"isCheckList\"\n        [columns]=\"columns | filterColumnsByDetails: detailsColumns\"\n        [fitWidth]=\"fitWidth\"\n        [disableOverflowContextMenu]=\"disableOverflowContextMenu\"\n        [inlineEditMode]=\"inlineEditMode\"\n        [contextMenuItems]=\"contextMenuItems\"\n        [canView]=\"canView\"\n        [viewSetting]=\"viewSetting\"\n        [hideHeader]=\"contextView.Grid_HideHeader\"\n        (allCheckbox)=\"onAllCheckbox($event)\"\n        (sortAscending)=\"onSortAscending($event)\"\n        (sortDescending)=\"onSortDescending($event)\"\n        (filter)=\"onFilter($event)\"\n    ></bsu-barsa-table-header>\n</ng-template>\n<ng-template #bodyTemplate let-columns>\n    <tbody\n        fd-table-body\n        [noBorderX]=\"popin && secondaryColumns.length > 0\"\n        [noBorderY]=\"popin && secondaryColumns.length > 0\"\n    >\n        <ng-container *ngIf=\"moDataList && moDataList.length > 0; else noData\">\n            <ng-container\n                *ngFor=\"let mo of moDataList | multipleGroupBy: groupby; let index = index; trackBy: _trackByRow\"\n            >\n                <ng-container\n                    *ngTemplateOutlet=\"\n                        rowTemplate;\n                        context: { $implicit: mo, index: index, columns: columns, moDataListCount: moDataList.length }\n                    \"\n                ></ng-container>\n            </ng-container>\n        </ng-container>\n    </tbody>\n</ng-template>\n<ng-template #footerTemplate let-columns>\n    <tfoot fd-table-footer *ngIf=\"hasSummary\">\n        <tr fd-table-row class=\"row-summary\">\n            <td fd-table-cell *ngIf=\"isCheckList\" columnResizer>\n                <strong class=\"col-total-text\">{{ 'Total' | bbbTranslate }}</strong>\n            </td>\n            <td fd-table-cell *ngIf=\"!isCheckList\" class=\"single-select\">\n                <strong class=\"col-total-text\">{{ 'Total' | bbbTranslate }}</strong>\n            </td>\n            <td *ngFor=\"let column of columns; let i = index\">\n                <ng-container *ngIf=\"column.HasSummary\">\n                    <strong style=\"direction: ltr; display: block\">\n                        {{ moDataList | totalSummary: column.Name | number }}</strong\n                    >\n                </ng-container>\n            </td>\n            <ng-container *ngIf=\"contextMenuItems && contextMenuItems.length > 0\">\n                <td fd-table-cell style=\"width: 100px\"></td>\n            </ng-container>\n            <td fd-table-cell *ngIf=\"canView\"></td>\n        </tr>\n    </tfoot>\n</ng-template>\n<ng-template #rowTemplate let-mo let-index=\"index\" let-columns=\"columns\" let-moDataListCount=\"moDataListCount\">\n    <bsu-barsa-table-row\n        [mo]=\"mo\"\n        [showDetailsInRow]=\"showDetailsInRow\"\n        [hideOpenIcon]=\"hideOpenIcon\"\n        [detailsColumns]=\"detailsColumns\"\n        [cartableTemplate]=\"cartableTemplates[mo.RelatedMo?.$TypeDefId]\"\n        [cartableMo]=\"mo.RelatedMo\"\n        [cartableWorkflowData]=\"mo.SerializedWorkflowData\"\n        [detailsText]=\"viewSetting?.DetailsSetting?.ButtonText\"\n        [detailsComponent]=\"detailsComponent\"\n        [isChecked]=\"mo.$IsChecked\"\n        [visibility]=\"mo.$Visibility\"\n        [expanded]=\"mo.$Expanded\"\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\"\n        [columns]=\"columns | filterColumnsByDetails: detailsColumns\"\n        [isNewInlineMo]=\"mo.$NewInlineMo\"\n        [access]=\"access\"\n        [inlineEditMode]=\"inlineEditMode\"\n        [allowInlineEdit]=\"allowInlineEdit\"\n        [rtl]=\"rtl\"\n        [deviceName]=\"deviceName\"\n        [deviceSize]=\"deviceSize\"\n        [index]=\"index\"\n        [allColumns]=\"allColumns\"\n        [contextMenuItems]=\"contextMenuItems\"\n        [canView]=\"canView\"\n        [conditionalFormats]=\"conditionalFormats\"\n        [disableOverflowContextMenu]=\"disableOverflowContextMenu\"\n        [navigationArrow]=\"navigationArrow\"\n        [isCheckList]=\"isCheckList\"\n        (expandClick)=\"onExpandClick($event)\"\n        (rowCheck)=\"onRowCheck($event)\"\n        (rowClick)=\"onRowClick($event)\"\n        (ulvCommand)=\"onUlvCommand($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</ng-template>\n<!--renderColumn-->\n<ng-template #noData>\n    <tr *ngIf=\"!inlineEditMode || !newInlineEditMo\">\n        <td colspan=\"100%\" style=\"padding: 10px\">{{ 'NoData' | bbbTranslate }}</td>\n    </tr>\n</ng-template>\n"]}
111
+ //# 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 {\r\n    ChangeDetectionStrategy,\r\n    Component,\r\n    HostBinding,\r\n    Input,\r\n    OnChanges,\r\n    OnInit,\r\n    SimpleChanges\r\n} from '@angular/core';\r\nimport { EjrayOlgo, MetaobjectDataModel, ReportViewBaseComponent, ReportViewColumn } from 'barsa-novin-ray-core';\r\nimport { UiTableViewSetting } from '../models/grid-view';\r\n\r\n@Component({\r\n    selector: 'bsu-ui-table-view',\r\n    templateUrl: './ui-table-view.component.html',\r\n    styleUrls: ['./ui-table-view.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class UiTableViewComponent extends ReportViewBaseComponent<UiTableViewSetting> implements OnInit, OnChanges {\r\n    @Input() columnWidth: number;\r\n    @Input() minWidth;\r\n    @Input() minHeight;\r\n    @Input() rowResizer;\r\n    @Input() enableResizing;\r\n\r\n    @HostBinding('style.height.px') height: number | null = null;\r\n    @HostBinding('style.max-height') maxHeight: string | null = null;\r\n\r\n    _width = '100%';\r\n    detailsColumns: ReportViewColumn[] = [];\r\n    detailsComponent: EjrayOlgo;\r\n    showDetailsInRow: boolean;\r\n    columnComponents: { column: ReportViewColumn; component: MetaobjectDataModel }[] = [];\r\n\r\n    ngOnInit(): void {\r\n        super.ngOnInit();\r\n        const detailsSetting = this.viewSetting?.DetailsSetting;\r\n        this.maxHeight = this.viewSetting?.BodyHeight;\r\n        if (detailsSetting) {\r\n            this.detailsComponent = detailsSetting.Component;\r\n            detailsSetting.Columns.split(',').forEach((column: string) => {\r\n                const columnFound = this.findColumn(this.allColumns, column);\r\n                if (columnFound) {\r\n                    this.detailsColumns.push(columnFound);\r\n                }\r\n            });\r\n        }\r\n        this._setHasSummery(this.cartableChildsMo);\r\n        this._setColumnsComponent(this.allColumns);\r\n        this._setHeight(this.parentHeight);\r\n    }\r\n    ngOnChanges(changes: SimpleChanges): void {\r\n        super.ngOnChanges(changes);\r\n        const { allColumns, cartableTemplates, parentHeight } = changes;\r\n        if (allColumns && !allColumns.firstChange) {\r\n            this._setColumnsComponent(allColumns.currentValue);\r\n        }\r\n        if (cartableTemplates && !cartableTemplates.firstChange && !this.hasSummary) {\r\n            this._setHasSummery(cartableTemplates.currentValue);\r\n            this._cdr.detectChanges();\r\n        }\r\n        if (parentHeight && !parentHeight.firstChange) {\r\n            this._setHeight(parentHeight.currentValue);\r\n        }\r\n    }\r\n    protected _setHeight(parentHeight: number): void {\r\n        if (this.inDialog) {\r\n            this.height = parentHeight;\r\n        }\r\n    }\r\n    protected _setHasSummery(cartableTemplates): void {\r\n        if (\r\n            this.detailsColumns?.length > 0 ||\r\n            this.detailsComponent?.Selector ||\r\n            (cartableTemplates && Object.keys(cartableTemplates).length > 0)\r\n        ) {\r\n            this.showDetailsInRow = true;\r\n        }\r\n    }\r\n    protected _containerWidthChanged(val: number): void {\r\n        if (val === 0) {\r\n            this._width = '100%';\r\n        } else {\r\n            this._width = val + 'px';\r\n        }\r\n        this._renderer2.setStyle(this._el.nativeElement, 'width', this._width);\r\n    }\r\n    private _setColumnsComponent(columns: ReportViewColumn[]): void {\r\n        const columnComponents = this.viewSetting?.ColumnComponents;\r\n        if (columnComponents) {\r\n            columnComponents.MoDataList.forEach((c: MetaobjectDataModel) => {\r\n                const column = this.findColumn(columns, c.Title);\r\n                if (column) {\r\n                    column.$CustomComponent = c.Component;\r\n                }\r\n            });\r\n        }\r\n    }\r\n\r\n    private findColumn(columns: ReportViewColumn[], column: string): ReportViewColumn | undefined {\r\n        let columnFound = this._findColumnByDbName.transform(columns, column);\r\n        if (!columnFound && this.secondaryColumns.length) {\r\n            columnFound = this._findColumnByDbName.transform(this.secondaryColumns, column);\r\n        }\r\n        return columnFound;\r\n    }\r\n}\r\n","<table\r\n    fd-table\r\n    [popIn]=\"popin\"\r\n    [class.fixed]=\"!contextView?.Grid_HideHeader && (!popin || secondaryColumns.length === 0)\"\r\n    [noBorderX]=\"viewSetting?.NoVerticalBorders === true || (popin && secondaryColumns.length > 0)\"\r\n    [noBorderY]=\"viewSetting?.NoHoriztonalBorders === true || (popin && secondaryColumns.length > 0)\"\r\n    tableResizer\r\n    [fitWidth]=\"fitWidth\"\r\n    (columnResized)=\"onColumnResized($event)\"\r\n    [containerWidth]=\"containerWidth\"\r\n    [minWidth]=\"30\"\r\n    [minHeight]=\"22\"\r\n    [rowResizer]=\"rowResizer\"\r\n    [enableResizing]=\"enableResizing\"\r\n>\r\n    <ng-container\r\n        *ngIf=\"columns | mergeFieldsToColumns: viewSetting?.MergeFieldsToColumns?.MoDataList as mergeFieldsToColumns\"\r\n    >\r\n        <ng-container *ngTemplateOutlet=\"headerTemplate; context: { $implicit: mergeFieldsToColumns }\"></ng-container>\r\n        <ng-container *ngTemplateOutlet=\"bodyTemplate; context: { $implicit: mergeFieldsToColumns }\"></ng-container>\r\n        <ng-container *ngTemplateOutlet=\"footerTemplate; context: { $implicit: mergeFieldsToColumns }\"></ng-container>\r\n    </ng-container>\r\n</table>\r\n<ng-template #headerTemplate let-columns>\r\n    <bsu-barsa-table-header\r\n        [tableWidth]=\"elWidth\"\r\n        [showDetailsInRow]=\"showDetailsInRow\"\r\n        [hideOpenIcon]=\"hideOpenIcon\"\r\n        [resizedByUser]=\"resizedByUser\"\r\n        [allChecked]=\"allChecked\"\r\n        [disableResponsive]=\"disableResponsive\"\r\n        [isCheckList]=\"isCheckList\"\r\n        [columns]=\"columns | filterColumnsByDetails: detailsColumns\"\r\n        [fitWidth]=\"fitWidth\"\r\n        [disableOverflowContextMenu]=\"disableOverflowContextMenu\"\r\n        [inlineEditMode]=\"inlineEditMode\"\r\n        [contextMenuItems]=\"contextMenuItems\"\r\n        [canView]=\"canView\"\r\n        [viewSetting]=\"viewSetting\"\r\n        [hideHeader]=\"contextView.Grid_HideHeader\"\r\n        (allCheckbox)=\"onAllCheckbox($event)\"\r\n        (sortAscending)=\"onSortAscending($event)\"\r\n        (sortDescending)=\"onSortDescending($event)\"\r\n        (filter)=\"onFilter($event)\"\r\n    ></bsu-barsa-table-header>\r\n</ng-template>\r\n<ng-template #bodyTemplate let-columns>\r\n    <tbody\r\n        fd-table-body\r\n        [noBorderX]=\"popin && secondaryColumns.length > 0\"\r\n        [noBorderY]=\"popin && secondaryColumns.length > 0\"\r\n    >\r\n        <ng-container *ngIf=\"moDataList && moDataList.length > 0; else noData\">\r\n            <ng-container\r\n                *ngFor=\"let mo of moDataList | multipleGroupBy: groupby; let index = index; trackBy: _trackByRow\"\r\n            >\r\n                <ng-container\r\n                    *ngTemplateOutlet=\"\r\n                        rowTemplate;\r\n                        context: { $implicit: mo, index: index, columns: columns, moDataListCount: moDataList.length }\r\n                    \"\r\n                ></ng-container>\r\n            </ng-container>\r\n        </ng-container>\r\n    </tbody>\r\n</ng-template>\r\n<ng-template #footerTemplate let-columns>\r\n    <tfoot fd-table-footer *ngIf=\"hasSummary\">\r\n        <tr fd-table-row class=\"row-summary\">\r\n            <td fd-table-cell *ngIf=\"isCheckList\" columnResizer>\r\n                <strong class=\"col-total-text\">{{ 'Total' | bbbTranslate }}</strong>\r\n            </td>\r\n            <td fd-table-cell *ngIf=\"!isCheckList\" class=\"single-select\">\r\n                <strong class=\"col-total-text\">{{ 'Total' | bbbTranslate }}</strong>\r\n            </td>\r\n            <td *ngFor=\"let column of columns; let i = index\">\r\n                <ng-container *ngIf=\"column.HasSummary\">\r\n                    <strong style=\"direction: ltr; display: block\">\r\n                        {{ moDataList | totalSummary: column.Name | number }}</strong\r\n                    >\r\n                </ng-container>\r\n            </td>\r\n            <ng-container *ngIf=\"contextMenuItems && contextMenuItems.length > 0\">\r\n                <td fd-table-cell style=\"width: 100px\"></td>\r\n            </ng-container>\r\n            <td fd-table-cell *ngIf=\"canView\"></td>\r\n        </tr>\r\n    </tfoot>\r\n</ng-template>\r\n<ng-template #rowTemplate let-mo let-index=\"index\" let-columns=\"columns\" let-moDataListCount=\"moDataListCount\">\r\n    <bsu-barsa-table-row\r\n        [mo]=\"mo\"\r\n        [showDetailsInRow]=\"showDetailsInRow\"\r\n        [hideOpenIcon]=\"hideOpenIcon\"\r\n        [detailsColumns]=\"detailsColumns\"\r\n        [cartableTemplate]=\"cartableTemplates[mo.RelatedMo?.$TypeDefId]\"\r\n        [cartableMo]=\"mo.RelatedMo\"\r\n        [cartableWorkflowData]=\"mo.SerializedWorkflowData\"\r\n        [serializedRelatedMo]=\"mo.SerializedRelatedMo\"\r\n        [detailsText]=\"viewSetting?.DetailsSetting?.ButtonText\"\r\n        [detailsComponent]=\"detailsComponent\"\r\n        [isChecked]=\"mo.$IsChecked\"\r\n        [visibility]=\"mo.$Visibility\"\r\n        [expanded]=\"mo.$Expanded\"\r\n        [level]=\"mo.$Level\"\r\n        [parentExpanded]=\"mo.$Parent?.$Expanded\"\r\n        [moDataListCount]=\"moDataListCount\"\r\n        [columnsCount]=\"columnsCount - detailsColumns.length\"\r\n        [typeDefId]=\"typeDefId\"\r\n        [extraRelation]=\"extraRelation\"\r\n        [formSetting]=\"formSetting\"\r\n        [index]=\"index\"\r\n        [setting]=\"viewSetting\"\r\n        [secondaryColumns]=\"secondaryColumns | filterColumnsByDetails: detailsColumns\"\r\n        [columns]=\"columns | filterColumnsByDetails: detailsColumns\"\r\n        [isNewInlineMo]=\"mo.$NewInlineMo\"\r\n        [access]=\"access\"\r\n        [inlineEditMode]=\"inlineEditMode\"\r\n        [allowInlineEdit]=\"allowInlineEdit\"\r\n        [rtl]=\"rtl\"\r\n        [deviceName]=\"deviceName\"\r\n        [deviceSize]=\"deviceSize\"\r\n        [index]=\"index\"\r\n        [allColumns]=\"allColumns\"\r\n        [contextMenuItems]=\"contextMenuItems\"\r\n        [canView]=\"canView\"\r\n        [conditionalFormats]=\"conditionalFormats\"\r\n        [disableOverflowContextMenu]=\"disableOverflowContextMenu\"\r\n        [navigationArrow]=\"navigationArrow\"\r\n        [isCheckList]=\"isCheckList\"\r\n        (expandClick)=\"onExpandClick($event)\"\r\n        (rowCheck)=\"onRowCheck($event)\"\r\n        (rowClick)=\"onRowClick($event)\"\r\n        (ulvCommand)=\"onUlvCommand($event)\"\r\n        (selectNextInlineRecord)=\"onSelectNextInlineRecord($event)\"\r\n        (editFormPanelSave)=\"onEditFormPanelSave($event)\"\r\n        (editFormPanelCancel)=\"onEditFormPanelCancel($event)\"\r\n        (editFormPanelValueChange)=\"onEditFormPanelValueChange($event)\"\r\n        (cartableFormClosed)=\"onCartableFormClosed($event)\"\r\n    >\r\n    </bsu-barsa-table-row>\r\n</ng-template>\r\n<!--renderColumn-->\r\n<ng-template #noData>\r\n    <tr *ngIf=\"!inlineEditMode || !newInlineEditMo\">\r\n        <td colspan=\"100%\" style=\"padding: 10px\">{{ 'NoData' | bbbTranslate }}</td>\r\n    </tr>\r\n</ng-template>\r\n"]}