barsa-sap-ui 1.0.382 → 1.0.384

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (28) hide show
  1. package/esm2020/lib/barsa-sap-ui.module.mjs +141 -141
  2. package/esm2020/lib/barsa-search-form/barsa-search-form.component.mjs +3 -3
  3. package/esm2020/lib/barsa-tinyemce/barsa-tinyemce.component.mjs +2 -2
  4. package/esm2020/lib/form-dialog/form-dialog.component.mjs +11 -7
  5. package/esm2020/lib/form-toolbar/form-toolbar.component.mjs +42 -0
  6. package/esm2020/lib/form-toolbar-button/form-toolbar-button.component.mjs +5 -4
  7. package/esm2020/lib/fullscreen-dialog.directive.mjs +29 -11
  8. package/esm2020/lib/fundamental-dynamic-form/fundamental-dynamic-form.component.mjs +17 -24
  9. package/esm2020/lib/index.mjs +4 -4
  10. package/esm2020/lib/ui-form-panel/ui-form-panel.component.mjs +27 -8
  11. package/esm2020/lib/ui-linear-list-container-with-button/ui-linear-list-container-with-button.component.mjs +3 -3
  12. package/esm2020/lib/ulv-form-multi-select/ulv-form-multi-select.component.mjs +3 -3
  13. package/esm2020/public-api.mjs +2 -2
  14. package/fesm2015/barsa-sap-ui.mjs +155 -105
  15. package/fesm2015/barsa-sap-ui.mjs.map +1 -1
  16. package/fesm2020/barsa-sap-ui.mjs +154 -102
  17. package/fesm2020/barsa-sap-ui.mjs.map +1 -1
  18. package/lib/barsa-sap-ui.module.d.ts +140 -140
  19. package/lib/form-toolbar/form-toolbar.component.d.ts +14 -0
  20. package/lib/form-toolbar-button/form-toolbar-button.component.d.ts +1 -0
  21. package/lib/fullscreen-dialog.directive.d.ts +8 -3
  22. package/lib/fundamental-dynamic-form/fundamental-dynamic-form.component.d.ts +3 -3
  23. package/lib/index.d.ts +2 -2
  24. package/lib/ui-form-panel/ui-form-panel.component.d.ts +21 -2
  25. package/package.json +1 -1
  26. package/public-api.d.ts +1 -1
  27. package/esm2020/lib/ui-form-panel-toolbar/ui-form-panel-toolbar.component.mjs +0 -24
  28. package/lib/ui-form-panel-toolbar/ui-form-panel-toolbar.component.d.ts +0 -13
@@ -84,7 +84,7 @@ export class BarsaTinyemceComponent extends BaseComponent {
84
84
  this.tinyMCEConfig.inline = false;
85
85
  this.tinyMCEConfig.menubar = false;
86
86
  this.tinyMCEConfig.toolbar_location = 'top';
87
- // this.tinyMCEConfig.toolbar_mode = 'floating';
87
+ this.tinyMCEConfig.toolbar_mode = 'floating';
88
88
  // this.tinyMCEConfig.toolbar_sticky = true;
89
89
  // this.tinyMCEConfig.toolbar_sticky_offset = 100;
90
90
  this.tinyMCEConfig.font_family_formats =
@@ -412,4 +412,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImpor
412
412
  }], tinyInit: [{
413
413
  type: Output
414
414
  }] } });
415
- //# 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    ViewChild\n} from '@angular/core';\nimport { FileUploaderComponent } from '@fundamental-ngx/core';\nimport { Observable, concatMap, takeUntil, tap } from 'rxjs';\n\nimport {\n    BaseComponent,\n    BarsaApi,\n    getUniqueId,\n    isFunction,\n    UploadService,\n    GeneralControlInfoModel\n} from 'barsa-novin-ray-core';\n\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    providers: [UploadService]\n})\nexport class BarsaTinyemceComponent extends BaseComponent implements AfterViewInit, OnDestroy, OnChanges {\n    @ViewChild('uploader') _uploader: FileUploaderComponent;\n    @Input() Setting: GeneralControlInfoModel;\n    @Input() isReadonly: boolean;\n    @Input() value: any;\n    @Input() IsInline: boolean;\n    @Input() defaultVerbs: { Title: string; Html: string }[];\n    @Output() valueChange = new EventEmitter<any>();\n    @Output() tinyInit = new EventEmitter();\n    tinyHostId = this._generateTinyHostId();\n    tinyMCEConfig: any = {};\n    editor: any;\n    wysiwygIntialized: boolean;\n    intializationInProgress: boolean;\n    editorValue: string;\n\n    iframBodyInnerHtml: string;\n    height: number;\n\n    constructor(protected _uploadService: UploadService, 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\n    onFileSelection(files: File[]): void {\n        this.uploadFile(files).pipe(takeUntil(this._onDestroy$)).subscribe();\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        if (this.tinyMCEConfig.setup) {\n            return;\n        }\n        this.tinyMCEConfig.height = '100%';\n        this.tinyMCEConfig.width = '100%';\n        this.tinyMCEConfig.selector = '#' + this.tinyHostId;\n        this.tinyMCEConfig.placeholder = this.Setting.ControlFieldCaptionTranslated;\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.skin = 'oxide';\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.resize = false;\n\n        this.tinyMCEConfig.inline = false;\n        this.tinyMCEConfig.menubar = false;\n        this.tinyMCEConfig.toolbar_location = 'top';\n\n        // this.tinyMCEConfig.toolbar_mode = 'floating';\n        // this.tinyMCEConfig.toolbar_sticky = true;\n        // this.tinyMCEConfig.toolbar_sticky_offset = 100;\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        this.tinyMCEConfig.quickbars_selection_toolbar =\n            'bold italic fontsize | forecolor backcolor|defaultVerbs barsaImage';\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        let defaultVerbsMenu: any = [];\n\n        // BEGIN: setup\n        this.tinyMCEConfig.setup = (ed) => {\n            this.editor = ed;\n            if (!this.isReadonly) {\n                if (this.defaultVerbs) {\n                    defaultVerbsMenu = [];\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                                ed.insertContent(item.Html, { format: 'raw' });\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);\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        this._uploader.open();\n    }\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('mceInsertContent', 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            // tinymce.execCommand('mceRemoveControl', true, this.tinyHostId);\n            if (ed.iframeElement) {\n                ed.iframeElement.removeEventListener('load', this._onLoadIframe);\n            }\n            ed.destroy(false);\n        }\n    }\n    private uploadFile(files: File[]): Observable<any> {\n        return this._uploadService.compressFiles$(files).pipe(\n            concatMap((formData: FormData) =>\n                this._uploadService.upload(formData, this.Setting.StorageFileFieldId).pipe(\n                    tap((res) => {\n                        if (Array.isArray(res)) {\n                            const picture = res[0];\n                            if (picture.ErrorMsg) {\n                                BarsaApi.Bw.Msg.Error(picture.ErrorMsg);\n                                return;\n                            }\n                            const value = {\n                                ...picture,\n                                FileId: picture.FileId\n                            };\n                            this._addImages(value);\n                        }\n                    })\n                )\n            )\n        );\n    }\n    private _addImages(file: { FileId: string }): void {\n        const url = '/IH.ashx?ty=StorageFile&key=' + file.FileId;\n        const html = '<img src=' + url + ' />';\n\n        this.editor.execCommand('mceInsertContent', false, html);\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        // ed.execCommand('mceInsertContent', false, this.value);\n\n        // ed.insertContent(this.value, { format: 'raw' });\n        // this._removeOverflow(ed);\n        this.destroyTinymce();\n        this.prepare();\n    };\n    private _generateTinyHostId(): string {\n        return `a_${getUniqueId(2)}`;\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>\n<fd-file-uploader\n    #uploader\n    [style.display]=\"'none'\"\n    [accept]=\"''\"\n    [multiple]=\"false\"\n    (selectedFilesChanged)=\"onFileSelection($event)\"\n></fd-file-uploader>\n<!-- <textarea [id]=\"tinyHostId\" style=\"height: 100%; visibility: hidden\"></textarea> -->\n"]}
415
+ //# 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    ViewChild\n} from '@angular/core';\nimport { FileUploaderComponent } from '@fundamental-ngx/core';\nimport { Observable, concatMap, takeUntil, tap } from 'rxjs';\n\nimport {\n    BaseComponent,\n    BarsaApi,\n    getUniqueId,\n    isFunction,\n    UploadService,\n    GeneralControlInfoModel\n} from 'barsa-novin-ray-core';\n\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    providers: [UploadService]\n})\nexport class BarsaTinyemceComponent extends BaseComponent implements AfterViewInit, OnDestroy, OnChanges {\n    @ViewChild('uploader') _uploader: FileUploaderComponent;\n    @Input() Setting: GeneralControlInfoModel;\n    @Input() isReadonly: boolean;\n    @Input() value: any;\n    @Input() IsInline: boolean;\n    @Input() defaultVerbs: { Title: string; Html: string }[];\n    @Output() valueChange = new EventEmitter<any>();\n    @Output() tinyInit = new EventEmitter();\n    tinyHostId = this._generateTinyHostId();\n    tinyMCEConfig: any = {};\n    editor: any;\n    wysiwygIntialized: boolean;\n    intializationInProgress: boolean;\n    editorValue: string;\n\n    iframBodyInnerHtml: string;\n    height: number;\n\n    constructor(protected _uploadService: UploadService, 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\n    onFileSelection(files: File[]): void {\n        this.uploadFile(files).pipe(takeUntil(this._onDestroy$)).subscribe();\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        if (this.tinyMCEConfig.setup) {\n            return;\n        }\n        this.tinyMCEConfig.height = '100%';\n        this.tinyMCEConfig.width = '100%';\n        this.tinyMCEConfig.selector = '#' + this.tinyHostId;\n        this.tinyMCEConfig.placeholder = this.Setting.ControlFieldCaptionTranslated;\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.skin = 'oxide';\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.resize = false;\n\n        this.tinyMCEConfig.inline = false;\n        this.tinyMCEConfig.menubar = false;\n        this.tinyMCEConfig.toolbar_location = 'top';\n\n        this.tinyMCEConfig.toolbar_mode = 'floating';\n        // this.tinyMCEConfig.toolbar_sticky = true;\n        // this.tinyMCEConfig.toolbar_sticky_offset = 100;\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        this.tinyMCEConfig.quickbars_selection_toolbar =\n            'bold italic fontsize | forecolor backcolor|defaultVerbs barsaImage';\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        let defaultVerbsMenu: any = [];\n\n        // BEGIN: setup\n        this.tinyMCEConfig.setup = (ed) => {\n            this.editor = ed;\n            if (!this.isReadonly) {\n                if (this.defaultVerbs) {\n                    defaultVerbsMenu = [];\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                                ed.insertContent(item.Html, { format: 'raw' });\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);\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        this._uploader.open();\n    }\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('mceInsertContent', 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            // tinymce.execCommand('mceRemoveControl', true, this.tinyHostId);\n            if (ed.iframeElement) {\n                ed.iframeElement.removeEventListener('load', this._onLoadIframe);\n            }\n            ed.destroy(false);\n        }\n    }\n    private uploadFile(files: File[]): Observable<any> {\n        return this._uploadService.compressFiles$(files).pipe(\n            concatMap((formData: FormData) =>\n                this._uploadService.upload(formData, this.Setting.StorageFileFieldId).pipe(\n                    tap((res) => {\n                        if (Array.isArray(res)) {\n                            const picture = res[0];\n                            if (picture.ErrorMsg) {\n                                BarsaApi.Bw.Msg.Error(picture.ErrorMsg);\n                                return;\n                            }\n                            const value = {\n                                ...picture,\n                                FileId: picture.FileId\n                            };\n                            this._addImages(value);\n                        }\n                    })\n                )\n            )\n        );\n    }\n    private _addImages(file: { FileId: string }): void {\n        const url = '/IH.ashx?ty=StorageFile&key=' + file.FileId;\n        const html = '<img src=' + url + ' />';\n\n        this.editor.execCommand('mceInsertContent', false, html);\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        // ed.execCommand('mceInsertContent', false, this.value);\n\n        // ed.insertContent(this.value, { format: 'raw' });\n        // this._removeOverflow(ed);\n        this.destroyTinymce();\n        this.prepare();\n    };\n    private _generateTinyHostId(): string {\n        return `a_${getUniqueId(2)}`;\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>\n<fd-file-uploader\n    #uploader\n    [style.display]=\"'none'\"\n    [accept]=\"''\"\n    [multiple]=\"false\"\n    (selectedFilesChanged)=\"onFileSelection($event)\"\n></fd-file-uploader>\n<!-- <textarea [id]=\"tinyHostId\" style=\"height: 100%; visibility: hidden\"></textarea> -->\n"]}
@@ -8,7 +8,8 @@ import * as i4 from "@fundamental-ngx/core/bar";
8
8
  import * as i5 from "@fundamental-ngx/core/dialog";
9
9
  import * as i6 from "@fundamental-ngx/core/title";
10
10
  import * as i7 from "@fundamental-ngx/core/utils";
11
- import * as i8 from "../fullscreen-dialog.directive";
11
+ import * as i8 from "@fundamental-ngx/core/toolbar";
12
+ import * as i9 from "../fullscreen-dialog.directive";
12
13
  export class FormDialogComponent extends BaseComponent {
13
14
  constructor(_dialogService, dialogParams, _portalService) {
14
15
  super();
@@ -32,6 +33,9 @@ export class FormDialogComponent extends BaseComponent {
32
33
  this.fullscreen = this.dialogParams.context.fullscreen;
33
34
  this.canFullscreen = parameters?.CanFullscreen;
34
35
  this.fullscreenDefault = parameters?.FullscreenDefault;
36
+ if (this.fullscreenDefault) {
37
+ this.fullscreen = true;
38
+ }
35
39
  this.canMove = parameters?.CanMove;
36
40
  this.canResize = parameters?.CanResize;
37
41
  this.params = { moId, typeDefId, reportId, inDialog: true };
@@ -57,8 +61,8 @@ export class FormDialogComponent extends BaseComponent {
57
61
  }
58
62
  openDialog() {
59
63
  const smallDevice = this.deviceSize === 's' || this.deviceSize === 'm';
60
- const width = smallDevice || this.fullscreenDefault ? '100vw' : '30vw';
61
- let height = smallDevice || this.fullscreenDefault ? '100vh' : 'auto';
64
+ const width = smallDevice ? '100vw' : '30vw';
65
+ let height = smallDevice ? '100vh' : 'auto';
62
66
  const viewWidth = BarsaApi.Common.Util.TryGetValue(this.formPanelCtrlr, 'Setting.View.MinSize.width', null);
63
67
  const viewHieght = BarsaApi.Common.Util.TryGetValue(this.formPanelCtrlr, 'Setting.View.MinSize.height', null);
64
68
  const minWidth = smallDevice ? '100vw' : viewWidth ? viewWidth + 'px' : 'auto';
@@ -77,7 +81,7 @@ export class FormDialogComponent extends BaseComponent {
77
81
  // bodyMinHeight: minHeight,
78
82
  minHeight,
79
83
  minWidth,
80
- fullScreen: smallDevice || this.fullscreenDefault,
84
+ fullScreen: smallDevice,
81
85
  verticalPadding: true,
82
86
  draggable: this.canMove,
83
87
  resizable: this.canResize,
@@ -126,12 +130,12 @@ export class FormDialogComponent extends BaseComponent {
126
130
  }
127
131
  }
128
132
  FormDialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: FormDialogComponent, deps: [{ token: i1.DialogService }, { token: i2.DialogParams }, { token: i2.PortalService }], target: i0.ɵɵFactoryTarget.Component });
129
- FormDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: FormDialogComponent, selector: "bsu-form-dialog", providers: [ContainerService], viewQueries: [{ propertyName: "dialogTemplateRef", first: true, predicate: ["dialog"], descendants: true, read: TemplateRef, static: true }], usesInheritance: true, ngImport: i0, template: "<ng-template let-dialog let-dialogConfig=\"dialogConfig\" #dialog>\n <fd-dialog [dialogConfig]=\"dialogConfig\" [dialogRef]=\"dialog\" #dialogTplRef>\n <fd-dialog-header>\n <ng-template fdTemplate=\"header\">\n <div fd-bar-left>\n <h1 fd-title>{{ dialogConfig.data.caption }}</h1>\n </div>\n <div fd-bar-right>\n <fd-button-bar\n *ngIf=\"dialogConfig.height !== '100vh' && dialogConfig.data.canFullscreen\"\n ariaLabel=\"fullscreen\"\n [glyph]=\"dialog.data.fullscreen ? 'exitfullscreen' : 'resize'\"\n fullscreenDialog\n [dialog]=\"dialog\"\n [dialogComponent]=\"dialogTplRef\"\n ></fd-button-bar>\n <fd-button-bar ariaLabel=\"close\" glyph=\"decline\" (click)=\"onCancel()\"></fd-button-bar>\n </div>\n </ng-template>\n </fd-dialog-header>\n\n <fd-dialog-body>\n <bnrc-form [formPanelCtrl]=\"formPanelCtrlr\" [params]=\"params\" (formClose)=\"onFormClose()\"></bnrc-form>\n </fd-dialog-body>\n <fd-dialog-footer [style.display]=\"!showFooter ? 'none' : null\">\n <ng-container *ngIf=\"isNonePersistance; else saveBtn\">\n <fd-dialog-footer-button>\n <fd-button-bar\n fd-dialog-decisive-button\n fdType=\"emphasized\"\n [label]=\"'Ok' | bbbTranslate\"\n (click)=\"onOk()\"\n ></fd-button-bar>\n </fd-dialog-footer-button>\n </ng-container>\n <ng-template #saveBtn>\n <fd-dialog-footer-button>\n <fd-button-bar\n fd-dialog-decisive-button\n fdType=\"emphasized\"\n [label]=\"'Save' | bbbTranslate\"\n (click)=\"onSave()\"\n ></fd-button-bar>\n </fd-dialog-footer-button>\n </ng-template>\n\n <fd-dialog-footer-button>\n <fd-button-bar\n fd-initial-focus\n fd-dialog-decisive-button\n fdType=\"transparent\"\n [label]=\"'Cancel' | bbbTranslate\"\n (click)=\"onCancel()\"\n ></fd-button-bar>\n </fd-dialog-footer-button>\n </fd-dialog-footer>\n </fd-dialog>\n</ng-template>\n", styles: [":host{display:block;height:auto}fd-dialog-body{display:flex;flex-direction:column;height:100%;align-items:stretch;justify-content:stretch}fd-dialog-body>bnrc-form{flex-grow:1;display:flex;flex-direction:row;height:100%;justify-content:stretch;align-items:stretch}\n"], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.FormComponent, selector: "bnrc-form", inputs: ["params", "customFormPanelUi", "formPanelCtrl", "UlvMainCtrlr", "formPanelCtrlId"], outputs: ["titleChanged", "moChanged", "formClose", "formRendered"] }, { kind: "directive", type: i2.FormCloseDirective, selector: "[formClose]", inputs: ["isMobile"] }, { kind: "directive", type: i4.BarLeftDirective, selector: "[fd-bar-left]" }, { kind: "directive", type: i4.BarRightDirective, selector: "[fd-bar-right]" }, { kind: "component", type: i4.ButtonBarComponent, selector: "fd-button-bar", inputs: ["fullWidth", "fdType", "title", "ariaLabel", "ariaLabelledby", "id"] }, { kind: "component", type: i5.DialogComponent, selector: "fd-dialog", inputs: ["class", "dialogRef", "dialogConfig"] }, { kind: "component", type: i5.DialogBodyComponent, selector: "fd-dialog-body" }, { kind: "component", type: i5.DialogFooterComponent, selector: "fd-dialog-footer" }, { kind: "component", type: i5.DialogHeaderComponent, selector: "fd-dialog-header" }, { kind: "component", type: i5.DialogFooterButtonComponent, selector: "fd-dialog-footer-button" }, { kind: "directive", type: i5.DialogDecisiveButtonDirective, selector: "[fd-dialog-decisive-button]" }, { kind: "component", type: i6.TitleComponent, selector: "h1[fd-title], h2[fd-title], h3[fd-title], h4[fd-title], h5[fd-title], h6[fd-title]", inputs: ["headerSize", "wrap"], exportAs: ["fd-title"] }, { kind: "directive", type: i7.TemplateDirective, selector: "[fdTemplate]", inputs: ["fdTemplate"] }, { kind: "directive", type: i7.InitialFocusDirective, selector: "[fdInitialFocus], [fd-initial-focus]", inputs: ["fd-initial-focus", "enabled", "focusLastElement"] }, { kind: "directive", type: i8.FullscreenDialogDirective, selector: "[fullscreenDialog]", inputs: ["dialog", "dialogComponent"] }, { kind: "pipe", type: i2.BbbTranslatePipe, name: "bbbTranslate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
133
+ FormDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: FormDialogComponent, selector: "bsu-form-dialog", providers: [ContainerService], viewQueries: [{ propertyName: "dialogTemplateRef", first: true, predicate: ["dialog"], descendants: true, read: TemplateRef, static: true }], usesInheritance: true, ngImport: i0, template: "<ng-template let-dialog let-dialogConfig=\"dialogConfig\" #dialog>\n <fd-dialog [dialogConfig]=\"dialogConfig\" [dialogRef]=\"dialog\" #dialogTplRef>\n <fd-dialog-header>\n <ng-template fdTemplate=\"header\">\n <div fd-bar-left>\n <h1 fd-title>{{ dialogConfig.data.caption }}</h1>\n </div>\n <div fd-bar-right>\n <fd-button-bar\n *ngIf=\"dialogConfig.data.canFullscreen\"\n ariaLabel=\"fullscreen\"\n [glyph]=\"fullscreen ? 'exitfullscreen' : 'resize'\"\n fullscreenDialog\n [dialog]=\"dialog\"\n [fullscreen]=\"fullscreen\"\n (fullscreenChanged)=\"fullscreen = $event\"\n [dialogComponent]=\"dialogTplRef\"\n ></fd-button-bar>\n <fd-button-bar ariaLabel=\"close\" glyph=\"decline\" (click)=\"onCancel()\"></fd-button-bar>\n </div>\n </ng-template>\n </fd-dialog-header>\n\n <fd-dialog-body>\n <bnrc-form [formPanelCtrl]=\"formPanelCtrlr\" [params]=\"params\" (formClose)=\"onFormClose()\"></bnrc-form>\n </fd-dialog-body>\n <fd-dialog-footer [style.display]=\"!showFooter ? 'none' : null\">\n <ng-container *ngFor=\"let btn of formPanelCtrlr?.Adapter?.Control?.toolbar?.items\">\n <ng-container *ngIf=\"!(btn === '-' || btn.text === '-') && btn.isBuiltin\">\n <ng-container\n *ngTemplateOutlet=\"\n btn.Data?.CustomUi?.Selector ? dynamicBtnTemplate : btnTemplate;\n context: { $implicit: btn }\n \"\n ></ng-container>\n <ng-template #btnTemplate let-btn>\n <fd-dialog-footer-button>\n <fd-button-bar\n fd-dialog-decisive-button\n [fdType]=\"btn.design\"\n [label]=\"btn.text | bbbTranslate\"\n [glyph]=\"btn.newIcon ? btn.newIcon : null\"\n (click)=\"btn.handler(btn, formPanelCtrlr?.Adapter?.Control)\"\n ></fd-button-bar>\n </fd-dialog-footer-button>\n </ng-template>\n <ng-template #dynamicBtnTemplate let-btn>\n <fd-dialog-footer-button>\n <bnrc-dynamic-form-toolbaritem\n fd-toolbar-item\n [component]=\"btn.Data.CustomUi\"\n [context]=\"btn\"\n [isEnable]=\"btn.Command?._isEnable\"\n (btnClick)=\"btn.handler(btn, formPanelCtrlr?.Adapter?.Control)\"\n ></bnrc-dynamic-form-toolbaritem>\n </fd-dialog-footer-button>\n </ng-template>\n </ng-container>\n </ng-container>\n <!-- <ng-template #saveBtn>\n <fd-dialog-footer-button>\n <fd-button-bar\n fd-dialog-decisive-button\n fdType=\"emphasized\"\n [label]=\"'Save' | bbbTranslate\"\n (click)=\"onSave()\"\n ></fd-button-bar>\n </fd-dialog-footer-button>\n </ng-template>-->\n\n <fd-dialog-footer-button *ngIf=\"!isNonePersistance\">\n <fd-button-bar\n fd-initial-focus\n fd-dialog-decisive-button\n [label]=\"'Cancel' | bbbTranslate\"\n (click)=\"onCancel()\"\n ></fd-button-bar>\n </fd-dialog-footer-button>\n </fd-dialog-footer>\n </fd-dialog>\n</ng-template>\n", styles: [":host{display:block;height:auto}fd-dialog-body{display:flex;flex-direction:column;height:100%;align-items:stretch;justify-content:stretch}fd-dialog-body>bnrc-form{flex-grow:1;display:flex;flex-direction:row;height:100%;justify-content:stretch;align-items:stretch}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.FormComponent, selector: "bnrc-form", inputs: ["params", "customFormPanelUi", "formPanelCtrl", "UlvMainCtrlr", "formPanelCtrlId"], outputs: ["titleChanged", "moChanged", "formClose", "formRendered"] }, { kind: "component", type: i2.DynamicFormToolbaritemComponent, selector: "bnrc-dynamic-form-toolbaritem", inputs: ["mo", "index", "deviceName", "deviceSize", "context", "btn", "isEnable", "showText", "allColumns", "conditionalFormats"], outputs: ["btnClick"] }, { kind: "directive", type: i2.FormCloseDirective, selector: "[formClose]", inputs: ["isMobile"] }, { kind: "directive", type: i4.BarLeftDirective, selector: "[fd-bar-left]" }, { kind: "directive", type: i4.BarRightDirective, selector: "[fd-bar-right]" }, { kind: "component", type: i4.ButtonBarComponent, selector: "fd-button-bar", inputs: ["fullWidth", "fdType", "title", "ariaLabel", "ariaLabelledby", "id"] }, { kind: "component", type: i5.DialogComponent, selector: "fd-dialog", inputs: ["class", "dialogRef", "dialogConfig"] }, { kind: "component", type: i5.DialogBodyComponent, selector: "fd-dialog-body" }, { kind: "component", type: i5.DialogFooterComponent, selector: "fd-dialog-footer" }, { kind: "component", type: i5.DialogHeaderComponent, selector: "fd-dialog-header" }, { kind: "component", type: i5.DialogFooterButtonComponent, selector: "fd-dialog-footer-button" }, { kind: "directive", type: i5.DialogDecisiveButtonDirective, selector: "[fd-dialog-decisive-button]" }, { kind: "component", type: i6.TitleComponent, selector: "h1[fd-title], h2[fd-title], h3[fd-title], h4[fd-title], h5[fd-title], h6[fd-title]", inputs: ["headerSize", "wrap"], exportAs: ["fd-title"] }, { kind: "directive", type: i7.TemplateDirective, selector: "[fdTemplate]", inputs: ["fdTemplate"] }, { kind: "directive", type: i7.InitialFocusDirective, selector: "[fdInitialFocus], [fd-initial-focus]", inputs: ["fd-initial-focus", "enabled", "focusLastElement"] }, { kind: "directive", type: i8.ToolbarItemDirective, selector: "[fd-toolbar-item]" }, { kind: "directive", type: i9.FullscreenDialogDirective, selector: "[fullscreenDialog]", inputs: ["dialog", "dialogComponent", "fullscreen"], outputs: ["fullscreenChanged"] }, { kind: "pipe", type: i2.BbbTranslatePipe, name: "bbbTranslate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
130
134
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: FormDialogComponent, decorators: [{
131
135
  type: Component,
132
- args: [{ selector: 'bsu-form-dialog', providers: [ContainerService], changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-template let-dialog let-dialogConfig=\"dialogConfig\" #dialog>\n <fd-dialog [dialogConfig]=\"dialogConfig\" [dialogRef]=\"dialog\" #dialogTplRef>\n <fd-dialog-header>\n <ng-template fdTemplate=\"header\">\n <div fd-bar-left>\n <h1 fd-title>{{ dialogConfig.data.caption }}</h1>\n </div>\n <div fd-bar-right>\n <fd-button-bar\n *ngIf=\"dialogConfig.height !== '100vh' && dialogConfig.data.canFullscreen\"\n ariaLabel=\"fullscreen\"\n [glyph]=\"dialog.data.fullscreen ? 'exitfullscreen' : 'resize'\"\n fullscreenDialog\n [dialog]=\"dialog\"\n [dialogComponent]=\"dialogTplRef\"\n ></fd-button-bar>\n <fd-button-bar ariaLabel=\"close\" glyph=\"decline\" (click)=\"onCancel()\"></fd-button-bar>\n </div>\n </ng-template>\n </fd-dialog-header>\n\n <fd-dialog-body>\n <bnrc-form [formPanelCtrl]=\"formPanelCtrlr\" [params]=\"params\" (formClose)=\"onFormClose()\"></bnrc-form>\n </fd-dialog-body>\n <fd-dialog-footer [style.display]=\"!showFooter ? 'none' : null\">\n <ng-container *ngIf=\"isNonePersistance; else saveBtn\">\n <fd-dialog-footer-button>\n <fd-button-bar\n fd-dialog-decisive-button\n fdType=\"emphasized\"\n [label]=\"'Ok' | bbbTranslate\"\n (click)=\"onOk()\"\n ></fd-button-bar>\n </fd-dialog-footer-button>\n </ng-container>\n <ng-template #saveBtn>\n <fd-dialog-footer-button>\n <fd-button-bar\n fd-dialog-decisive-button\n fdType=\"emphasized\"\n [label]=\"'Save' | bbbTranslate\"\n (click)=\"onSave()\"\n ></fd-button-bar>\n </fd-dialog-footer-button>\n </ng-template>\n\n <fd-dialog-footer-button>\n <fd-button-bar\n fd-initial-focus\n fd-dialog-decisive-button\n fdType=\"transparent\"\n [label]=\"'Cancel' | bbbTranslate\"\n (click)=\"onCancel()\"\n ></fd-button-bar>\n </fd-dialog-footer-button>\n </fd-dialog-footer>\n </fd-dialog>\n</ng-template>\n", styles: [":host{display:block;height:auto}fd-dialog-body{display:flex;flex-direction:column;height:100%;align-items:stretch;justify-content:stretch}fd-dialog-body>bnrc-form{flex-grow:1;display:flex;flex-direction:row;height:100%;justify-content:stretch;align-items:stretch}\n"] }]
136
+ args: [{ selector: 'bsu-form-dialog', providers: [ContainerService], changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-template let-dialog let-dialogConfig=\"dialogConfig\" #dialog>\n <fd-dialog [dialogConfig]=\"dialogConfig\" [dialogRef]=\"dialog\" #dialogTplRef>\n <fd-dialog-header>\n <ng-template fdTemplate=\"header\">\n <div fd-bar-left>\n <h1 fd-title>{{ dialogConfig.data.caption }}</h1>\n </div>\n <div fd-bar-right>\n <fd-button-bar\n *ngIf=\"dialogConfig.data.canFullscreen\"\n ariaLabel=\"fullscreen\"\n [glyph]=\"fullscreen ? 'exitfullscreen' : 'resize'\"\n fullscreenDialog\n [dialog]=\"dialog\"\n [fullscreen]=\"fullscreen\"\n (fullscreenChanged)=\"fullscreen = $event\"\n [dialogComponent]=\"dialogTplRef\"\n ></fd-button-bar>\n <fd-button-bar ariaLabel=\"close\" glyph=\"decline\" (click)=\"onCancel()\"></fd-button-bar>\n </div>\n </ng-template>\n </fd-dialog-header>\n\n <fd-dialog-body>\n <bnrc-form [formPanelCtrl]=\"formPanelCtrlr\" [params]=\"params\" (formClose)=\"onFormClose()\"></bnrc-form>\n </fd-dialog-body>\n <fd-dialog-footer [style.display]=\"!showFooter ? 'none' : null\">\n <ng-container *ngFor=\"let btn of formPanelCtrlr?.Adapter?.Control?.toolbar?.items\">\n <ng-container *ngIf=\"!(btn === '-' || btn.text === '-') && btn.isBuiltin\">\n <ng-container\n *ngTemplateOutlet=\"\n btn.Data?.CustomUi?.Selector ? dynamicBtnTemplate : btnTemplate;\n context: { $implicit: btn }\n \"\n ></ng-container>\n <ng-template #btnTemplate let-btn>\n <fd-dialog-footer-button>\n <fd-button-bar\n fd-dialog-decisive-button\n [fdType]=\"btn.design\"\n [label]=\"btn.text | bbbTranslate\"\n [glyph]=\"btn.newIcon ? btn.newIcon : null\"\n (click)=\"btn.handler(btn, formPanelCtrlr?.Adapter?.Control)\"\n ></fd-button-bar>\n </fd-dialog-footer-button>\n </ng-template>\n <ng-template #dynamicBtnTemplate let-btn>\n <fd-dialog-footer-button>\n <bnrc-dynamic-form-toolbaritem\n fd-toolbar-item\n [component]=\"btn.Data.CustomUi\"\n [context]=\"btn\"\n [isEnable]=\"btn.Command?._isEnable\"\n (btnClick)=\"btn.handler(btn, formPanelCtrlr?.Adapter?.Control)\"\n ></bnrc-dynamic-form-toolbaritem>\n </fd-dialog-footer-button>\n </ng-template>\n </ng-container>\n </ng-container>\n <!-- <ng-template #saveBtn>\n <fd-dialog-footer-button>\n <fd-button-bar\n fd-dialog-decisive-button\n fdType=\"emphasized\"\n [label]=\"'Save' | bbbTranslate\"\n (click)=\"onSave()\"\n ></fd-button-bar>\n </fd-dialog-footer-button>\n </ng-template>-->\n\n <fd-dialog-footer-button *ngIf=\"!isNonePersistance\">\n <fd-button-bar\n fd-initial-focus\n fd-dialog-decisive-button\n [label]=\"'Cancel' | bbbTranslate\"\n (click)=\"onCancel()\"\n ></fd-button-bar>\n </fd-dialog-footer-button>\n </fd-dialog-footer>\n </fd-dialog>\n</ng-template>\n", styles: [":host{display:block;height:auto}fd-dialog-body{display:flex;flex-direction:column;height:100%;align-items:stretch;justify-content:stretch}fd-dialog-body>bnrc-form{flex-grow:1;display:flex;flex-direction:row;height:100%;justify-content:stretch;align-items:stretch}\n"] }]
133
137
  }], ctorParameters: function () { return [{ type: i1.DialogService }, { type: i2.DialogParams }, { type: i2.PortalService }]; }, propDecorators: { dialogTemplateRef: [{
134
138
  type: ViewChild,
135
139
  args: ['dialog', { read: TemplateRef, static: true }]
136
140
  }] } });
137
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-dialog.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-sap-ui/src/lib/form-dialog/form-dialog.component.ts","../../../../../projects/barsa-sap-ui/src/lib/form-dialog/form-dialog.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAwB,WAAW,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAEjH,OAAO,EACH,QAAQ,EAIR,gBAAgB,EAChB,aAAa,EAChB,MAAM,sBAAsB,CAAC;;;;;;;;;;AAS9B,MAAM,OAAO,mBAAoB,SAAQ,aAAa;IA2BlD,YACY,cAA6B,EAC7B,YAA0B,EAC1B,cAA6B;QAErC,KAAK,EAAE,CAAC;QAJA,mBAAc,GAAd,cAAc,CAAe;QAC7B,iBAAY,GAAZ,YAAY,CAAc;QAC1B,mBAAc,GAAd,cAAc,CAAe;QAxBzC,YAAO,GAAG,EAAE,CAAC;QACb,eAAU,GAAG,KAAK,CAAC;QAYnB,sBAAiB,GAAG,KAAK,CAAC;QAC1B,mBAAc,GAAG,IAAI,CAAC;QACtB,gBAAW,GAAG,IAAI,CAAC;QAYf,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC,UAAU,EAAE,EAAE;YACrD,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;QACjC,CAAC,CAAC,CAAC;QACH,MAAM,cAAc,GAAG,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,cAAc,CAAC;QAChE,MAAM,UAAU,GAAG,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,cAAc,EAAE,kCAAkC,EAAE,IAAI,CAAC,CAAC;QAC9G,MAAM,IAAI,GAAG,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,EAAE,CAAC;QAC1C,MAAM,SAAS,GAAG,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,IAAI,CAAC;QACjD,MAAM,QAAQ,GAAG,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,KAAK,CAAC;QACjD,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,QAAQ,CAAC;QACnD,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,UAAU,CAAC;QACvD,IAAI,CAAC,aAAa,GAAG,UAAU,EAAE,aAAa,CAAC;QAC/C,IAAI,CAAC,iBAAiB,GAAG,UAAU,EAAE,iBAAiB,CAAC;QACvD,IAAI,CAAC,OAAO,GAAG,UAAU,EAAE,OAAO,CAAC;QACnC,IAAI,CAAC,SAAS,GAAG,UAAU,EAAE,SAAS,CAAC;QACvC,IAAI,CAAC,MAAM,GAAG,EAAE,IAAI,EAAE,SAAS,EAAE,QAAQ,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;QAC5D,IAAI,CAAC,WAAW,CAAC,cAAc,CAAC,CAAC;QACjC,IAAI,CAAC,cAAc,GAAG,cAAc,CAAC;IACzC,CAAC;IACD,IAAI,OAAO;QACP,OAAO,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC;IACvC,CAAC;IACD,QAAQ;QACJ,KAAK,CAAC,QAAQ,EAAE,CAAC;QACjB,MAAM,cAAc,GAAG,IAAI,CAAC,cAAc,CAAC;QAC3C,IAAI,CAAC,cAAc,GAAG,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,CAClD,cAAc,EACd,0CAA0C,CAC7C,CAAC;QACF,IAAI,CAAC,WAAW,GAAG,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,cAAc,EAAE,uCAAuC,CAAC,CAAC;QAC7G,IAAI,CAAC,iBAAiB,GAAG,cAAc,EAAE,OAAO,EAAE,IAAI,EAAE,iBAAiB,CAAC;QAC1E,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,iBAAiB;YACpC,CAAC,CAAC,IAAI,CAAC,cAAc,KAAK,KAAK,IAAI,IAAI,CAAC,WAAW,KAAK,KAAK;YAC7D,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC;QAC1B,IAAI,OAAO,IAAI,CAAC,UAAU,IAAI,OAAO,IAAI,EAAE;YACvC,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;SAC1B;QACD,IAAI,CAAC,UAAU,EAAE,CAAC;IACtB,CAAC;IACD,UAAU;QACN,MAAM,WAAW,GAAG,IAAI,CAAC,UAAU,KAAK,GAAG,IAAI,IAAI,CAAC,UAAU,KAAK,GAAG,CAAC;QACvE,MAAM,KAAK,GAAG,WAAW,IAAI,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC;QACvE,IAAI,MAAM,GAAG,WAAW,IAAI,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC;QACtE,MAAM,SAAS,GAAG,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,cAAc,EAAE,4BAA4B,EAAE,IAAI,CAAC,CAAC;QAC5G,MAAM,UAAU,GAAG,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,cAAc,EAAE,6BAA6B,EAAE,IAAI,CAAC,CAAC;QAC9G,MAAM,QAAQ,GAAG,WAAW,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,GAAG,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC;QAC/E,MAAM,SAAS,GAAG,WAAW,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,UAAU,GAAG,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC;QAClF,IAAI,UAAU,EAAE;YACZ,MAAM,GAAG,MAAM,CAAC;SACnB;QACD,MAAM,YAAY,GAAG,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,CACjD,IAAI,CAAC,cAAc,EACnB,+CAA+C,EAC/C,IAAI,CACP,CAAC;QAEF,IAAI,OAAO,GAAiB;YACxB,eAAe,EAAE,KAAK;YACtB,iBAAiB,EAAE,IAAI;YACvB,sBAAsB,EAAE,KAAK;YAC7B,MAAM,EAAE,WAAW;YACnB,KAAK;YACL,MAAM;YACN,4BAA4B;YAC5B,SAAS;YACT,QAAQ;YACR,UAAU,EAAE,WAAW,IAAI,IAAI,CAAC,iBAAiB;YACjD,eAAe,EAAE,IAAI;YACrB,SAAS,EAAE,IAAI,CAAC,OAAO;YACvB,SAAS,EAAE,IAAI,CAAC,SAAS;YACzB,IAAI,EAAE,EAAE,OAAO,EAAE,IAAI,CAAC,OAAO,EAAE,aAAa,EAAE,IAAI,CAAC,aAAa,EAAE,OAAO,EAAE,IAAI,CAAC,OAAO,EAAE;SAC5F,CAAC;QACF,IAAI,YAAY,EAAE;YACd,OAAO,GAAG,EAAE,GAAG,OAAO,EAAE,GAAG,YAAY,EAAE,CAAC;SAC7C;QACD,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,iBAAiB,EAAE,OAAO,CAAC,CAAC;IAC/E,CAAC;IAED,QAAQ;QACJ,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC;QAC7B,OAAO,CAAC,SAAS,CAAC,WAAW,EAAE,OAAO,EAAE,EAAE,GAAG,EAAE,QAAQ,EAAE,CAAC,CAAC;QAC3D,IAAI,CAAC,MAAM,EAAE,CAAC;IAClB,CAAC;IACD,MAAM;QACF,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC;QAC7B,OAAO,CAAC,SAAS,CAAC,WAAW,EAAE,OAAO,EAAE,EAAE,GAAG,EAAE,cAAc,EAAE,CAAC,CAAC;IACrE,CAAC;IACD,IAAI;QACA,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC;QAC7B,OAAO,CAAC,SAAS,CAAC,WAAW,EAAE,OAAO,EAAE,EAAE,GAAG,EAAE,IAAI,EAAE,CAAC,CAAC;IAC3D,CAAC;IAED,WAAW;QACP,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC;QACvB,IAAI,CAAC,YAAY,CAAC,KAAK,EAAE,CAAC;QAC1B,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;IAC9B,CAAC;IACD,uBAAuB;IACvB,0DAA0D;IAC1D,uBAAuB;IACvB,uCAAuC;IACvC,uBAAuB;IACvB,6DAA6D;IAErD,MAAM;QACV,wCAAwC;QACxC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,SAAS,CAAC,iBAAiB,EAAE,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;QACxE,0BAA0B;QAC1B,6BAA6B;QAC7B,6BAA6B;IACjC,CAAC;IAEO,WAAW,CAAC,cAAmB;QACnC,MAAM,WAAW,GAAG,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,cAAc,EAAE,iBAAiB,EAAE,EAAE,CAAC,CAAC;QAC5F,MAAM,SAAS,GAAG,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,cAAc,EAAE,aAAa,EAAE,EAAE,CAAC,CAAC;QACtF,IAAI,CAAC,OAAO,GAAG,WAAW,GAAG,GAAG,GAAG,SAAS,CAAC;IACjD,CAAC;;gHApJQ,mBAAmB;oGAAnB,mBAAmB,0CAHjB,CAAC,gBAAgB,CAAC,kHAIA,WAAW,kECnB5C,ilFA0DA;2FDxCa,mBAAmB;kBAP/B,SAAS;+BACI,iBAAiB,aAGhB,CAAC,gBAAgB,CAAC,mBACZ,uBAAuB,CAAC,MAAM;2JAI/C,iBAAiB;sBADhB,SAAS;uBAAC,QAAQ,EAAE,EAAE,IAAI,EAAE,WAAW,EAAE,MAAM,EAAE,IAAI,EAAE","sourcesContent":["import { ChangeDetectionStrategy, Component, ComponentRef, OnInit, TemplateRef, ViewChild } from '@angular/core';\nimport { DialogConfig, DialogRef, DialogService } from '@fundamental-ngx/core';\nimport {\n    BarsaApi,\n    DialogParams,\n    FormComponent,\n    PortalService,\n    ContainerService,\n    BaseComponent\n} from 'barsa-novin-ray-core';\n\n@Component({\n    selector: 'bsu-form-dialog',\n    templateUrl: './form-dialog.component.html',\n    styleUrls: ['./form-dialog.component.scss'],\n    providers: [ContainerService],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class FormDialogComponent extends BaseComponent implements OnInit {\n    @ViewChild('dialog', { read: TemplateRef, static: true })\n    dialogTemplateRef: TemplateRef<any>;\n\n    formPanelCtrlr: any;\n    formComponentRef: ComponentRef<FormComponent>;\n    caption = '';\n    fullscreen = false;\n    dialogOpened: boolean;\n    dialogRef: DialogRef;\n    inDialog: any;\n    params: {\n        moId: string;\n        typeDefId: string;\n        reportId: string;\n        inDialog: boolean;\n    };\n    parentContainer: any;\n    deviceSize: string;\n    isNonePersistance = false;\n    showSaveButton = true;\n    showToolbar = true;\n    showFooter: boolean;\n    canFullscreen: boolean;\n    canMove: boolean;\n    canResize: boolean;\n    fullscreenDefault: boolean;\n    constructor(\n        private _dialogService: DialogService,\n        private dialogParams: DialogParams,\n        private _portalService: PortalService\n    ) {\n        super();\n        this._portalService.deviceSize$.subscribe((deviceSize) => {\n            this.deviceSize = deviceSize;\n        });\n        const formPanelCtrlr = this.dialogParams.context.formpanelCtrlr;\n        const parameters = BarsaApi.Common.Util.TryGetValue(formPanelCtrlr, 'Setting.View.CustomUi.Parameters', null);\n        const moId = this.dialogParams.context.id;\n        const typeDefId = this.dialogParams.context.tyid;\n        const reportId = this.dialogParams.context.repid;\n        this.inDialog = this.dialogParams.context.inDialog;\n        this.fullscreen = this.dialogParams.context.fullscreen;\n        this.canFullscreen = parameters?.CanFullscreen;\n        this.fullscreenDefault = parameters?.FullscreenDefault;\n        this.canMove = parameters?.CanMove;\n        this.canResize = parameters?.CanResize;\n        this.params = { moId, typeDefId, reportId, inDialog: true };\n        this._setCaption(formPanelCtrlr);\n        this.formPanelCtrlr = formPanelCtrlr;\n    }\n    get Adapter(): any {\n        return this.formPanelCtrlr.Adapter;\n    }\n    ngOnInit(): void {\n        super.ngOnInit();\n        const formPanelCtrlr = this.formPanelCtrlr;\n        this.showSaveButton = BarsaApi.Common.Util.TryGetValue(\n            formPanelCtrlr,\n            'Setting.View.FormSettings.ShowSaveButton'\n        );\n        this.showToolbar = BarsaApi.Common.Util.TryGetValue(formPanelCtrlr, 'Setting.View.FormSettings.ShowToolbar');\n        this.isNonePersistance = formPanelCtrlr?.Setting?.View?.IsNonePersistance;\n        this.showFooter = this.isNonePersistance\n            ? this.showSaveButton !== false && this.showToolbar !== false\n            : this.showSaveButton;\n        if (typeof this.showFooter == typeof null) {\n            this.showFooter = true;\n        }\n        this.openDialog();\n    }\n    openDialog(): void {\n        const smallDevice = this.deviceSize === 's' || this.deviceSize === 'm';\n        const width = smallDevice || this.fullscreenDefault ? '100vw' : '30vw';\n        let height = smallDevice || this.fullscreenDefault ? '100vh' : 'auto';\n        const viewWidth = BarsaApi.Common.Util.TryGetValue(this.formPanelCtrlr, 'Setting.View.MinSize.width', null);\n        const viewHieght = BarsaApi.Common.Util.TryGetValue(this.formPanelCtrlr, 'Setting.View.MinSize.height', null);\n        const minWidth = smallDevice ? '100vw' : viewWidth ? viewWidth + 'px' : 'auto';\n        const minHeight = smallDevice ? '100vw' : viewHieght ? viewHieght + 'px' : 'auto';\n        if (viewHieght) {\n            height = '100%';\n        }\n        const modalSetting = BarsaApi.Common.Util.TryGetValue(\n            this.formPanelCtrlr,\n            'Setting.View.CustomUi.Parameters.ModalSetting',\n            null\n        );\n\n        let setting: DialogConfig = {\n            escKeyCloseable: false,\n            responsivePadding: true,\n            backdropClickCloseable: false,\n            mobile: smallDevice,\n            width,\n            height,\n            // bodyMinHeight: minHeight,\n            minHeight,\n            minWidth,\n            fullScreen: smallDevice || this.fullscreenDefault,\n            verticalPadding: true,\n            draggable: this.canMove,\n            resizable: this.canResize,\n            data: { caption: this.caption, canFullscreen: this.canFullscreen, canMove: this.canMove }\n        };\n        if (modalSetting) {\n            setting = { ...setting, ...modalSetting };\n        }\n        this.dialogRef = this._dialogService.open(this.dialogTemplateRef, setting);\n    }\n\n    onCancel(): void {\n        const adapter = this.Adapter;\n        adapter.fireEvent('ToolClick', adapter, { Key: 'Cancel' });\n        this._close();\n    }\n    onSave(): void {\n        const adapter = this.Adapter;\n        adapter.fireEvent('ToolClick', adapter, { Key: 'SaveAndClose' });\n    }\n    onOk(): void {\n        const adapter = this.Adapter;\n        adapter.fireEvent('ToolClick', adapter, { Key: 'Ok' });\n    }\n\n    onFormClose(): void {\n        this.dialogRef.close();\n        this.dialogParams.close();\n        this.dialogOpened = false;\n    }\n    // /* eslint-disable */\n    // @Input() ShowFormPanelControl = (formpanelCtrlr) => {};\n    // /* eslint-disable */\n    // @Input() ForceCloseChild = () => {};\n    // /* eslint-disable */\n    // @Input() RefreshFormPanelControl = (formpanelCtrlr) => {};\n\n    private _close(): void {\n        // this.dialogRef.nativeElement.close();\n        this.Adapter.Control.fireEvent('RequestForClose', this.Adapter.Control);\n        // this.dialogRef.close();\n        // this.dialogParams.close();\n        // this.dialogOpened = false;\n    }\n\n    private _setCaption(formPanelCtrlr: any): void {\n        const typeDefName = BarsaApi.Common.Util.TryGetValue(formPanelCtrlr, 'Mo.$TypeDefName', '');\n        const moCaption = BarsaApi.Common.Util.TryGetValue(formPanelCtrlr, 'Mo.$Caption', '');\n        this.caption = typeDefName + ':' + moCaption;\n    }\n}\n","<ng-template let-dialog let-dialogConfig=\"dialogConfig\" #dialog>\n    <fd-dialog [dialogConfig]=\"dialogConfig\" [dialogRef]=\"dialog\" #dialogTplRef>\n        <fd-dialog-header>\n            <ng-template fdTemplate=\"header\">\n                <div fd-bar-left>\n                    <h1 fd-title>{{ dialogConfig.data.caption }}</h1>\n                </div>\n                <div fd-bar-right>\n                    <fd-button-bar\n                        *ngIf=\"dialogConfig.height !== '100vh' && dialogConfig.data.canFullscreen\"\n                        ariaLabel=\"fullscreen\"\n                        [glyph]=\"dialog.data.fullscreen ? 'exitfullscreen' : 'resize'\"\n                        fullscreenDialog\n                        [dialog]=\"dialog\"\n                        [dialogComponent]=\"dialogTplRef\"\n                    ></fd-button-bar>\n                    <fd-button-bar ariaLabel=\"close\" glyph=\"decline\" (click)=\"onCancel()\"></fd-button-bar>\n                </div>\n            </ng-template>\n        </fd-dialog-header>\n\n        <fd-dialog-body>\n            <bnrc-form [formPanelCtrl]=\"formPanelCtrlr\" [params]=\"params\" (formClose)=\"onFormClose()\"></bnrc-form>\n        </fd-dialog-body>\n        <fd-dialog-footer [style.display]=\"!showFooter ? 'none' : null\">\n            <ng-container *ngIf=\"isNonePersistance; else saveBtn\">\n                <fd-dialog-footer-button>\n                    <fd-button-bar\n                        fd-dialog-decisive-button\n                        fdType=\"emphasized\"\n                        [label]=\"'Ok' | bbbTranslate\"\n                        (click)=\"onOk()\"\n                    ></fd-button-bar>\n                </fd-dialog-footer-button>\n            </ng-container>\n            <ng-template #saveBtn>\n                <fd-dialog-footer-button>\n                    <fd-button-bar\n                        fd-dialog-decisive-button\n                        fdType=\"emphasized\"\n                        [label]=\"'Save' | bbbTranslate\"\n                        (click)=\"onSave()\"\n                    ></fd-button-bar>\n                </fd-dialog-footer-button>\n            </ng-template>\n\n            <fd-dialog-footer-button>\n                <fd-button-bar\n                    fd-initial-focus\n                    fd-dialog-decisive-button\n                    fdType=\"transparent\"\n                    [label]=\"'Cancel' | bbbTranslate\"\n                    (click)=\"onCancel()\"\n                ></fd-button-bar>\n            </fd-dialog-footer-button>\n        </fd-dialog-footer>\n    </fd-dialog>\n</ng-template>\n"]}
141
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-dialog.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-sap-ui/src/lib/form-dialog/form-dialog.component.ts","../../../../../projects/barsa-sap-ui/src/lib/form-dialog/form-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, ComponentRef, OnInit, TemplateRef, ViewChild } from '@angular/core';\nimport { DialogConfig, DialogRef, DialogService } from '@fundamental-ngx/core';\nimport {\n    BarsaApi,\n    DialogParams,\n    FormComponent,\n    PortalService,\n    ContainerService,\n    BaseComponent\n} from 'barsa-novin-ray-core';\n\n@Component({\n    selector: 'bsu-form-dialog',\n    templateUrl: './form-dialog.component.html',\n    styleUrls: ['./form-dialog.component.scss'],\n    providers: [ContainerService],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class FormDialogComponent extends BaseComponent implements OnInit {\n    @ViewChild('dialog', { read: TemplateRef, static: true })\n    dialogTemplateRef: TemplateRef<any>;\n\n    formPanelCtrlr: any;\n    formComponentRef: ComponentRef<FormComponent>;\n    caption = '';\n    fullscreen = false;\n    dialogOpened: boolean;\n    dialogRef: DialogRef;\n    inDialog: any;\n    params: {\n        moId: string;\n        typeDefId: string;\n        reportId: string;\n        inDialog: boolean;\n    };\n    parentContainer: any;\n    deviceSize: string;\n    isNonePersistance = false;\n    showSaveButton = true;\n    showToolbar = true;\n    showFooter: boolean;\n    canFullscreen: boolean;\n    canMove: boolean;\n    canResize: boolean;\n    fullscreenDefault: boolean;\n    constructor(\n        private _dialogService: DialogService,\n        private dialogParams: DialogParams,\n        private _portalService: PortalService\n    ) {\n        super();\n        this._portalService.deviceSize$.subscribe((deviceSize) => {\n            this.deviceSize = deviceSize;\n        });\n        const formPanelCtrlr = this.dialogParams.context.formpanelCtrlr;\n        const parameters = BarsaApi.Common.Util.TryGetValue(formPanelCtrlr, 'Setting.View.CustomUi.Parameters', null);\n        const moId = this.dialogParams.context.id;\n        const typeDefId = this.dialogParams.context.tyid;\n        const reportId = this.dialogParams.context.repid;\n        this.inDialog = this.dialogParams.context.inDialog;\n        this.fullscreen = this.dialogParams.context.fullscreen;\n        this.canFullscreen = parameters?.CanFullscreen;\n        this.fullscreenDefault = parameters?.FullscreenDefault;\n        if (this.fullscreenDefault) {\n            this.fullscreen = true;\n        }\n        this.canMove = parameters?.CanMove;\n        this.canResize = parameters?.CanResize;\n        this.params = { moId, typeDefId, reportId, inDialog: true };\n        this._setCaption(formPanelCtrlr);\n        this.formPanelCtrlr = formPanelCtrlr;\n    }\n    get Adapter(): any {\n        return this.formPanelCtrlr.Adapter;\n    }\n    ngOnInit(): void {\n        super.ngOnInit();\n        const formPanelCtrlr = this.formPanelCtrlr;\n        this.showSaveButton = BarsaApi.Common.Util.TryGetValue(\n            formPanelCtrlr,\n            'Setting.View.FormSettings.ShowSaveButton'\n        );\n        this.showToolbar = BarsaApi.Common.Util.TryGetValue(formPanelCtrlr, 'Setting.View.FormSettings.ShowToolbar');\n        this.isNonePersistance = formPanelCtrlr?.Setting?.View?.IsNonePersistance;\n        this.showFooter = this.isNonePersistance\n            ? this.showSaveButton !== false && this.showToolbar !== false\n            : this.showSaveButton;\n        if (typeof this.showFooter == typeof null) {\n            this.showFooter = true;\n        }\n        this.openDialog();\n    }\n    openDialog(): void {\n        const smallDevice = this.deviceSize === 's' || this.deviceSize === 'm';\n        const width = smallDevice ? '100vw' : '30vw';\n        let height = smallDevice ? '100vh' : 'auto';\n        const viewWidth = BarsaApi.Common.Util.TryGetValue(this.formPanelCtrlr, 'Setting.View.MinSize.width', null);\n        const viewHieght = BarsaApi.Common.Util.TryGetValue(this.formPanelCtrlr, 'Setting.View.MinSize.height', null);\n        const minWidth = smallDevice ? '100vw' : viewWidth ? viewWidth + 'px' : 'auto';\n        const minHeight = smallDevice ? '100vw' : viewHieght ? viewHieght + 'px' : 'auto';\n        if (viewHieght) {\n            height = '100%';\n        }\n        const modalSetting = BarsaApi.Common.Util.TryGetValue(\n            this.formPanelCtrlr,\n            'Setting.View.CustomUi.Parameters.ModalSetting',\n            null\n        );\n\n        let setting: DialogConfig = {\n            escKeyCloseable: false,\n            responsivePadding: true,\n            backdropClickCloseable: false,\n            mobile: smallDevice,\n            width,\n            height,\n            // bodyMinHeight: minHeight,\n            minHeight,\n            minWidth,\n            fullScreen: smallDevice,\n            verticalPadding: true,\n            draggable: this.canMove,\n            resizable: this.canResize,\n            data: { caption: this.caption, canFullscreen: this.canFullscreen, canMove: this.canMove }\n        };\n        if (modalSetting) {\n            setting = { ...setting, ...modalSetting };\n        }\n        this.dialogRef = this._dialogService.open(this.dialogTemplateRef, setting);\n    }\n\n    onCancel(): void {\n        const adapter = this.Adapter;\n        adapter.fireEvent('ToolClick', adapter, { Key: 'Cancel' });\n        this._close();\n    }\n    onSave(): void {\n        const adapter = this.Adapter;\n        adapter.fireEvent('ToolClick', adapter, { Key: 'SaveAndClose' });\n    }\n    onOk(): void {\n        const adapter = this.Adapter;\n        adapter.fireEvent('ToolClick', adapter, { Key: 'Ok' });\n    }\n\n    onFormClose(): void {\n        this.dialogRef.close();\n        this.dialogParams.close();\n        this.dialogOpened = false;\n    }\n    // /* eslint-disable */\n    // @Input() ShowFormPanelControl = (formpanelCtrlr) => {};\n    // /* eslint-disable */\n    // @Input() ForceCloseChild = () => {};\n    // /* eslint-disable */\n    // @Input() RefreshFormPanelControl = (formpanelCtrlr) => {};\n\n    private _close(): void {\n        // this.dialogRef.nativeElement.close();\n        this.Adapter.Control.fireEvent('RequestForClose', this.Adapter.Control);\n        // this.dialogRef.close();\n        // this.dialogParams.close();\n        // this.dialogOpened = false;\n    }\n\n    private _setCaption(formPanelCtrlr: any): void {\n        const typeDefName = BarsaApi.Common.Util.TryGetValue(formPanelCtrlr, 'Mo.$TypeDefName', '');\n        const moCaption = BarsaApi.Common.Util.TryGetValue(formPanelCtrlr, 'Mo.$Caption', '');\n        this.caption = typeDefName + ':' + moCaption;\n    }\n}\n","<ng-template let-dialog let-dialogConfig=\"dialogConfig\" #dialog>\n    <fd-dialog [dialogConfig]=\"dialogConfig\" [dialogRef]=\"dialog\" #dialogTplRef>\n        <fd-dialog-header>\n            <ng-template fdTemplate=\"header\">\n                <div fd-bar-left>\n                    <h1 fd-title>{{ dialogConfig.data.caption }}</h1>\n                </div>\n                <div fd-bar-right>\n                    <fd-button-bar\n                        *ngIf=\"dialogConfig.data.canFullscreen\"\n                        ariaLabel=\"fullscreen\"\n                        [glyph]=\"fullscreen ? 'exitfullscreen' : 'resize'\"\n                        fullscreenDialog\n                        [dialog]=\"dialog\"\n                        [fullscreen]=\"fullscreen\"\n                        (fullscreenChanged)=\"fullscreen = $event\"\n                        [dialogComponent]=\"dialogTplRef\"\n                    ></fd-button-bar>\n                    <fd-button-bar ariaLabel=\"close\" glyph=\"decline\" (click)=\"onCancel()\"></fd-button-bar>\n                </div>\n            </ng-template>\n        </fd-dialog-header>\n\n        <fd-dialog-body>\n            <bnrc-form [formPanelCtrl]=\"formPanelCtrlr\" [params]=\"params\" (formClose)=\"onFormClose()\"></bnrc-form>\n        </fd-dialog-body>\n        <fd-dialog-footer [style.display]=\"!showFooter ? 'none' : null\">\n            <ng-container *ngFor=\"let btn of formPanelCtrlr?.Adapter?.Control?.toolbar?.items\">\n                <ng-container *ngIf=\"!(btn === '-' || btn.text === '-') && btn.isBuiltin\">\n                    <ng-container\n                        *ngTemplateOutlet=\"\n                            btn.Data?.CustomUi?.Selector ? dynamicBtnTemplate : btnTemplate;\n                            context: { $implicit: btn }\n                        \"\n                    ></ng-container>\n                    <ng-template #btnTemplate let-btn>\n                        <fd-dialog-footer-button>\n                            <fd-button-bar\n                                fd-dialog-decisive-button\n                                [fdType]=\"btn.design\"\n                                [label]=\"btn.text | bbbTranslate\"\n                                [glyph]=\"btn.newIcon ? btn.newIcon : null\"\n                                (click)=\"btn.handler(btn, formPanelCtrlr?.Adapter?.Control)\"\n                            ></fd-button-bar>\n                        </fd-dialog-footer-button>\n                    </ng-template>\n                    <ng-template #dynamicBtnTemplate let-btn>\n                        <fd-dialog-footer-button>\n                            <bnrc-dynamic-form-toolbaritem\n                                fd-toolbar-item\n                                [component]=\"btn.Data.CustomUi\"\n                                [context]=\"btn\"\n                                [isEnable]=\"btn.Command?._isEnable\"\n                                (btnClick)=\"btn.handler(btn, formPanelCtrlr?.Adapter?.Control)\"\n                            ></bnrc-dynamic-form-toolbaritem>\n                        </fd-dialog-footer-button>\n                    </ng-template>\n                </ng-container>\n            </ng-container>\n            <!--  <ng-template #saveBtn>\n                <fd-dialog-footer-button>\n                    <fd-button-bar\n                        fd-dialog-decisive-button\n                        fdType=\"emphasized\"\n                        [label]=\"'Save' | bbbTranslate\"\n                        (click)=\"onSave()\"\n                    ></fd-button-bar>\n                </fd-dialog-footer-button>\n            </ng-template>-->\n\n            <fd-dialog-footer-button *ngIf=\"!isNonePersistance\">\n                <fd-button-bar\n                    fd-initial-focus\n                    fd-dialog-decisive-button\n                    [label]=\"'Cancel' | bbbTranslate\"\n                    (click)=\"onCancel()\"\n                ></fd-button-bar>\n            </fd-dialog-footer-button>\n        </fd-dialog-footer>\n    </fd-dialog>\n</ng-template>\n"]}
@@ -0,0 +1,42 @@
1
+ import { Component, ChangeDetectionStrategy, ViewChild, Output, EventEmitter } from '@angular/core';
2
+ import { FormToolbarBaseComponent } from 'barsa-novin-ray-core';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "@angular/common";
5
+ import * as i2 from "barsa-novin-ray-core";
6
+ import * as i3 from "@fundamental-ngx/core/button";
7
+ import * as i4 from "@fundamental-ngx/core/menu";
8
+ import * as i5 from "@fundamental-ngx/core/split-button";
9
+ import * as i6 from "@fundamental-ngx/core/toolbar";
10
+ export class FormToolbarComponent extends FormToolbarBaseComponent {
11
+ constructor() {
12
+ super(...arguments);
13
+ this.toolbarClick = new EventEmitter();
14
+ }
15
+ ngOnInit() {
16
+ super.ngOnInit();
17
+ }
18
+ ngOnChanges(changes) {
19
+ super.ngOnChanges(changes);
20
+ }
21
+ onToolbarClick(btn, menu = null) {
22
+ if (menu) {
23
+ menu.close();
24
+ }
25
+ this.toolbarClick.emit(btn);
26
+ }
27
+ updateCollapsibleItems() {
28
+ this._toolbarComponent.updateCollapsibleItems();
29
+ }
30
+ }
31
+ FormToolbarComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: FormToolbarComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
32
+ FormToolbarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: FormToolbarComponent, selector: "bsu-form-toolbar", outputs: { toolbarClick: "toolbarClick" }, viewQueries: [{ propertyName: "_toolbarComponent", first: true, predicate: ["formToolbar"], descendants: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<fd-toolbar\n #formToolbar\n fdType=\"transparent\"\n [clearBorder]=\"true\"\n [shouldOverflow]=\"deviceSize === 's'\"\n [class.firefox]=\"isFirefox\"\n>\n <ng-container *ngFor=\"let btn of buttons; let i = index; let last = last; let first = first\">\n <fd-toolbar-separator\n [attr.i]=\"i\"\n [attr.last]=\"last\"\n [attr.first]=\"first\"\n *ngIf=\"(btn === '-' || btn.text === '-') && !last && !first\"\n ></fd-toolbar-separator>\n <ng-container *ngIf=\"btn.IAmMenu; else simpleButton\">\n <fd-split-button\n *ngIf=\"btn.isBuiltin\"\n [dir]=\"dirValue\"\n fd-toolbar-item\n [attr.fdOverflowPriority]=\"'low'\"\n [mainAction]=\"{ mainActionTitle: btn.text, keepMainAction: true }\"\n [fdType]=\"btn.design ? btn.design : btn.Data?.JsonExtraProp?.Design\"\n (primaryButtonClicked)=\"btn.isBuiltin && onToolbarClick(btn)\"\n (click)=\"menu2.open()\"\n >\n <fd-menu #menu2>\n <li\n fd-menu-item\n *ngFor=\"let menuItem of btn.menu.items\"\n [disabled]=\"menuItem.disabled\"\n (click)=\"onToolbarClick(menuItem, menu2)\"\n >\n <div fd-menu-interactive>\n <fd-menu-addon\n position=\"before\"\n [glyph]=\"menuItem.newIcon ? menuItem.newIcon : menuItem.Data?.JsonExtraProp?.Icon\"\n >\n </fd-menu-addon>\n <img class=\"mr8\" *ngIf=\"!menuItem.newIcon && menuItem.icon\" [src]=\"menuItem.icon\" />\n <span fd-menu-title>{{ menuItem.text }}</span>\n </div>\n </li>\n </fd-menu>\n </fd-split-button>\n <button\n *ngIf=\"!btn.isBuiltin\"\n fd-button\n fd-toolbar-item\n [fdMenu]=\"true\"\n [glyph]=\"btn.FontIcon\"\n [style.color]=\"btn.IconColor\"\n [fdType]=\"btn.design ? btn.design : btn.Data?.JsonExtraProp?.Design\"\n [label]=\"btn.text | bbbTranslate\"\n [ariaLabel]=\"btn.text | bbbTranslate\"\n [fdMenuTrigger]=\"menu\"\n >\n <img *ngIf=\"!btn.Data?.JsonExtraProp?.Icon && !btn.newIcon && btn.icon\" width=\"16\" [src]=\"btn.icon\" />\n <fd-menu #menu>\n <li\n fd-menu-item\n *ngFor=\"let menuItem of btn.menu.items\"\n [disabled]=\"menuItem.disabled\"\n (click)=\"onToolbarClick(menuItem, menu)\"\n >\n <div fd-menu-interactive>\n <fd-menu-addon\n *ngIf=\"\n menuItem.newIcon ||\n menuItem.Data?.JsonExtraProp?.Icon ||\n menuItem.FontIcon ||\n menuItem.Data?.CustomUi?.Parameters?.Icon\n \"\n position=\"before\"\n [ngClass]=\"\n menuItem.Data?.CustomUi?.Parameters?.FdType$Caption\n ? 'fd-button--' + menuItem.Data?.CustomUi?.Parameters?.FdType$Caption\n : ''\n \"\n [style.color]=\"menuItem.IconColor\"\n [glyph]=\"\n menuItem.newIcon ||\n menuItem.Data?.JsonExtraProp?.Icon ||\n menuItem.FontIcon ||\n menuItem.Data?.CustomUi?.Parameters?.Icon\n \"\n >\n </fd-menu-addon>\n <img\n class=\"mr8\"\n *ngIf=\"\n !(\n menuItem.newIcon ||\n menuItem.Data?.JsonExtraProp?.Icon ||\n menuItem.Data?.CustomUi?.Parameters?.Icon ||\n menuItem.FontIcon\n ) && menuItem.icon\n \"\n [src]=\"menuItem.icon\"\n />\n <span fd-menu-title>{{ menuItem.text }}</span>\n </div>\n </li>\n </fd-menu>\n </button>\n </ng-container>\n <ng-template #simpleButton>\n <ng-container *ngIf=\"!(btn === '-' || btn.text === '-')\">\n <ng-container\n *ngTemplateOutlet=\"\n btn.Data?.CustomUi?.Selector ? dynamicBtnTemplate : btnTemplate;\n context: { $implicit: btn }\n \"\n ></ng-container>\n <ng-template #btnTemplate let-btn>\n <button\n fd-toolbar-item\n fd-button\n [disabled]=\"btn.disabled\"\n [attr.fdOverflowPriority]=\"btn.priority\"\n [fdType]=\"\n btn.isWorkflow ? 'positive' : btn.design ? btn.design : btn.Data?.JsonExtraProp?.Design\n \"\n [glyph]=\"btn.newIcon ? btn.newIcon : btn.Data?.JsonExtraProp?.Icon\"\n (click)=\"onToolbarClick(btn)\"\n >\n <img\n *ngIf=\"!btn.Data?.JsonExtraProp?.Icon && !btn.newIcon && btn.icon\"\n width=\"16\"\n [src]=\"btn.icon\"\n />\n <span *ngIf=\"btn.text\">{{ btn.text }}</span>\n </button>\n </ng-template>\n <ng-template #dynamicBtnTemplate let-btn>\n <bnrc-dynamic-form-toolbaritem\n fd-toolbar-item\n [component]=\"btn.Data.CustomUi\"\n [context]=\"btn\"\n [isEnable]=\"btn.Command?._isEnable\"\n (btnClick)=\"onToolbarClick(btn)\"\n ></bnrc-dynamic-form-toolbaritem>\n </ng-template>\n </ng-container>\n </ng-template>\n </ng-container>\n</fd-toolbar>\n", styles: [""], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { 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: "component", type: i2.DynamicFormToolbaritemComponent, selector: "bnrc-dynamic-form-toolbaritem", inputs: ["mo", "index", "deviceName", "deviceSize", "context", "btn", "isEnable", "showText", "allColumns", "conditionalFormats"], outputs: ["btnClick"] }, { kind: "component", type: i3.ButtonComponent, selector: "button[fd-button], a[fd-button]", inputs: ["class"], exportAs: ["fd-button"] }, { kind: "component", type: i4.MenuComponent, selector: "fd-menu", inputs: ["mobile", "disabled", "focusTrapped", "openOnHoverTime", "mobileConfig", "ariaLabel", "ariaLabelledby", "id"], outputs: ["activePath"] }, { kind: "component", type: i4.MenuItemComponent, selector: "li[fd-menu-item]", inputs: ["disabled", "itemId", "submenu"], outputs: ["onSelect"], exportAs: ["fd-menu-item"] }, { kind: "directive", type: i4.MenuInteractiveDirective, selector: "[fd-menu-interactive]" }, { kind: "directive", type: i4.MenuTitleDirective, selector: "[fd-menu-title]" }, { kind: "component", type: i4.MenuAddonDirective, selector: "fd-menu-addon", inputs: ["position", "glyph", "submenuIndicator", "ariaHidden"] }, { kind: "directive", type: i4.MenuTriggerDirective, selector: "[fdMenuTrigger]", inputs: ["fdMenuTrigger"] }, { kind: "component", type: i5.SplitButtonComponent, selector: "fd-split-button", inputs: ["glyph", "disabled", "mainActionTitle", "fdType", "expandButtonAriaLabel", "expandButtonTitle", "selected", "fixedWidth", "mainAction", "arialLabel"], outputs: ["primaryButtonClicked"] }, { kind: "component", type: i6.ToolbarComponent, selector: "fd-toolbar", inputs: ["class", "shouldOverflow", "fdType", "hasTitle", "title", "active", "clearBorder", "forceOverflow", "tabindex"] }, { kind: "directive", type: i6.ToolbarItemDirective, selector: "[fd-toolbar-item]" }, { kind: "component", type: i6.ToolbarSeparatorComponent, selector: "fd-toolbar-separator" }, { kind: "directive", type: i6.ToolbarOverflowPriorityDirective, selector: "[fdOverflowPriority]", inputs: ["fdOverflowPriority"] }, { kind: "pipe", type: i2.BbbTranslatePipe, name: "bbbTranslate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
33
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: FormToolbarComponent, decorators: [{
34
+ type: Component,
35
+ args: [{ selector: 'bsu-form-toolbar', changeDetection: ChangeDetectionStrategy.OnPush, template: "<fd-toolbar\n #formToolbar\n fdType=\"transparent\"\n [clearBorder]=\"true\"\n [shouldOverflow]=\"deviceSize === 's'\"\n [class.firefox]=\"isFirefox\"\n>\n <ng-container *ngFor=\"let btn of buttons; let i = index; let last = last; let first = first\">\n <fd-toolbar-separator\n [attr.i]=\"i\"\n [attr.last]=\"last\"\n [attr.first]=\"first\"\n *ngIf=\"(btn === '-' || btn.text === '-') && !last && !first\"\n ></fd-toolbar-separator>\n <ng-container *ngIf=\"btn.IAmMenu; else simpleButton\">\n <fd-split-button\n *ngIf=\"btn.isBuiltin\"\n [dir]=\"dirValue\"\n fd-toolbar-item\n [attr.fdOverflowPriority]=\"'low'\"\n [mainAction]=\"{ mainActionTitle: btn.text, keepMainAction: true }\"\n [fdType]=\"btn.design ? btn.design : btn.Data?.JsonExtraProp?.Design\"\n (primaryButtonClicked)=\"btn.isBuiltin && onToolbarClick(btn)\"\n (click)=\"menu2.open()\"\n >\n <fd-menu #menu2>\n <li\n fd-menu-item\n *ngFor=\"let menuItem of btn.menu.items\"\n [disabled]=\"menuItem.disabled\"\n (click)=\"onToolbarClick(menuItem, menu2)\"\n >\n <div fd-menu-interactive>\n <fd-menu-addon\n position=\"before\"\n [glyph]=\"menuItem.newIcon ? menuItem.newIcon : menuItem.Data?.JsonExtraProp?.Icon\"\n >\n </fd-menu-addon>\n <img class=\"mr8\" *ngIf=\"!menuItem.newIcon && menuItem.icon\" [src]=\"menuItem.icon\" />\n <span fd-menu-title>{{ menuItem.text }}</span>\n </div>\n </li>\n </fd-menu>\n </fd-split-button>\n <button\n *ngIf=\"!btn.isBuiltin\"\n fd-button\n fd-toolbar-item\n [fdMenu]=\"true\"\n [glyph]=\"btn.FontIcon\"\n [style.color]=\"btn.IconColor\"\n [fdType]=\"btn.design ? btn.design : btn.Data?.JsonExtraProp?.Design\"\n [label]=\"btn.text | bbbTranslate\"\n [ariaLabel]=\"btn.text | bbbTranslate\"\n [fdMenuTrigger]=\"menu\"\n >\n <img *ngIf=\"!btn.Data?.JsonExtraProp?.Icon && !btn.newIcon && btn.icon\" width=\"16\" [src]=\"btn.icon\" />\n <fd-menu #menu>\n <li\n fd-menu-item\n *ngFor=\"let menuItem of btn.menu.items\"\n [disabled]=\"menuItem.disabled\"\n (click)=\"onToolbarClick(menuItem, menu)\"\n >\n <div fd-menu-interactive>\n <fd-menu-addon\n *ngIf=\"\n menuItem.newIcon ||\n menuItem.Data?.JsonExtraProp?.Icon ||\n menuItem.FontIcon ||\n menuItem.Data?.CustomUi?.Parameters?.Icon\n \"\n position=\"before\"\n [ngClass]=\"\n menuItem.Data?.CustomUi?.Parameters?.FdType$Caption\n ? 'fd-button--' + menuItem.Data?.CustomUi?.Parameters?.FdType$Caption\n : ''\n \"\n [style.color]=\"menuItem.IconColor\"\n [glyph]=\"\n menuItem.newIcon ||\n menuItem.Data?.JsonExtraProp?.Icon ||\n menuItem.FontIcon ||\n menuItem.Data?.CustomUi?.Parameters?.Icon\n \"\n >\n </fd-menu-addon>\n <img\n class=\"mr8\"\n *ngIf=\"\n !(\n menuItem.newIcon ||\n menuItem.Data?.JsonExtraProp?.Icon ||\n menuItem.Data?.CustomUi?.Parameters?.Icon ||\n menuItem.FontIcon\n ) && menuItem.icon\n \"\n [src]=\"menuItem.icon\"\n />\n <span fd-menu-title>{{ menuItem.text }}</span>\n </div>\n </li>\n </fd-menu>\n </button>\n </ng-container>\n <ng-template #simpleButton>\n <ng-container *ngIf=\"!(btn === '-' || btn.text === '-')\">\n <ng-container\n *ngTemplateOutlet=\"\n btn.Data?.CustomUi?.Selector ? dynamicBtnTemplate : btnTemplate;\n context: { $implicit: btn }\n \"\n ></ng-container>\n <ng-template #btnTemplate let-btn>\n <button\n fd-toolbar-item\n fd-button\n [disabled]=\"btn.disabled\"\n [attr.fdOverflowPriority]=\"btn.priority\"\n [fdType]=\"\n btn.isWorkflow ? 'positive' : btn.design ? btn.design : btn.Data?.JsonExtraProp?.Design\n \"\n [glyph]=\"btn.newIcon ? btn.newIcon : btn.Data?.JsonExtraProp?.Icon\"\n (click)=\"onToolbarClick(btn)\"\n >\n <img\n *ngIf=\"!btn.Data?.JsonExtraProp?.Icon && !btn.newIcon && btn.icon\"\n width=\"16\"\n [src]=\"btn.icon\"\n />\n <span *ngIf=\"btn.text\">{{ btn.text }}</span>\n </button>\n </ng-template>\n <ng-template #dynamicBtnTemplate let-btn>\n <bnrc-dynamic-form-toolbaritem\n fd-toolbar-item\n [component]=\"btn.Data.CustomUi\"\n [context]=\"btn\"\n [isEnable]=\"btn.Command?._isEnable\"\n (btnClick)=\"onToolbarClick(btn)\"\n ></bnrc-dynamic-form-toolbaritem>\n </ng-template>\n </ng-container>\n </ng-template>\n </ng-container>\n</fd-toolbar>\n" }]
36
+ }], propDecorators: { toolbarClick: [{
37
+ type: Output
38
+ }], _toolbarComponent: [{
39
+ type: ViewChild,
40
+ args: ['formToolbar']
41
+ }] } });
42
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-toolbar.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-sap-ui/src/lib/form-toolbar/form-toolbar.component.ts","../../../../../projects/barsa-sap-ui/src/lib/form-toolbar/form-toolbar.component.html"],"names":[],"mappings":"AAAA,OAAO,EACH,SAAS,EACT,uBAAuB,EAIvB,SAAS,EACT,MAAM,EACN,YAAY,EACf,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAE,wBAAwB,EAAE,MAAM,sBAAsB,CAAC;;;;;;;;AAQhE,MAAM,OAAO,oBAAqB,SAAQ,wBAAwB;IANlE;;QAOc,iBAAY,GAAG,IAAI,YAAY,EAAO,CAAC;KAkBpD;IAfG,QAAQ;QACJ,KAAK,CAAC,QAAQ,EAAE,CAAC;IACrB,CAAC;IACD,WAAW,CAAC,OAAsB;QAC9B,KAAK,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;IAC/B,CAAC;IACD,cAAc,CAAC,GAAG,EAAE,OAAY,IAAI;QAChC,IAAI,IAAI,EAAE;YACN,IAAI,CAAC,KAAK,EAAE,CAAC;SAChB;QACD,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAChC,CAAC;IACD,sBAAsB;QAClB,IAAI,CAAC,iBAAiB,CAAC,sBAAsB,EAAE,CAAC;IACpD,CAAC;;iHAlBQ,oBAAoB;qGAApB,oBAAoB,iQCnBjC,o8NAkJA;2FD/Ha,oBAAoB;kBANhC,SAAS;+BACI,kBAAkB,mBAGX,uBAAuB,CAAC,MAAM;8BAGrC,YAAY;sBAArB,MAAM;gBAEmB,iBAAiB;sBAA1C,SAAS;uBAAC,aAAa","sourcesContent":["import {\n    Component,\n    ChangeDetectionStrategy,\n    OnInit,\n    SimpleChanges,\n    OnChanges,\n    ViewChild,\n    Output,\n    EventEmitter\n} from '@angular/core';\nimport { ToolbarComponent } from '@fundamental-ngx/core';\nimport { FormToolbarBaseComponent } from 'barsa-novin-ray-core';\n\n@Component({\n    selector: 'bsu-form-toolbar',\n    templateUrl: './form-toolbar.component.html',\n    styleUrls: ['./form-toolbar.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class FormToolbarComponent extends FormToolbarBaseComponent implements OnInit, OnChanges {\n    @Output() toolbarClick = new EventEmitter<any>();\n\n    @ViewChild('formToolbar') _toolbarComponent: ToolbarComponent;\n    ngOnInit(): void {\n        super.ngOnInit();\n    }\n    ngOnChanges(changes: SimpleChanges): void {\n        super.ngOnChanges(changes);\n    }\n    onToolbarClick(btn, menu: any = null): void {\n        if (menu) {\n            menu.close();\n        }\n        this.toolbarClick.emit(btn);\n    }\n    updateCollapsibleItems(): void {\n        this._toolbarComponent.updateCollapsibleItems();\n    }\n}\n","<fd-toolbar\n    #formToolbar\n    fdType=\"transparent\"\n    [clearBorder]=\"true\"\n    [shouldOverflow]=\"deviceSize === 's'\"\n    [class.firefox]=\"isFirefox\"\n>\n    <ng-container *ngFor=\"let btn of buttons; let i = index; let last = last; let first = first\">\n        <fd-toolbar-separator\n            [attr.i]=\"i\"\n            [attr.last]=\"last\"\n            [attr.first]=\"first\"\n            *ngIf=\"(btn === '-' || btn.text === '-') && !last && !first\"\n        ></fd-toolbar-separator>\n        <ng-container *ngIf=\"btn.IAmMenu; else simpleButton\">\n            <fd-split-button\n                *ngIf=\"btn.isBuiltin\"\n                [dir]=\"dirValue\"\n                fd-toolbar-item\n                [attr.fdOverflowPriority]=\"'low'\"\n                [mainAction]=\"{ mainActionTitle: btn.text, keepMainAction: true }\"\n                [fdType]=\"btn.design ? btn.design : btn.Data?.JsonExtraProp?.Design\"\n                (primaryButtonClicked)=\"btn.isBuiltin && onToolbarClick(btn)\"\n                (click)=\"menu2.open()\"\n            >\n                <fd-menu #menu2>\n                    <li\n                        fd-menu-item\n                        *ngFor=\"let menuItem of btn.menu.items\"\n                        [disabled]=\"menuItem.disabled\"\n                        (click)=\"onToolbarClick(menuItem, menu2)\"\n                    >\n                        <div fd-menu-interactive>\n                            <fd-menu-addon\n                                position=\"before\"\n                                [glyph]=\"menuItem.newIcon ? menuItem.newIcon : menuItem.Data?.JsonExtraProp?.Icon\"\n                            >\n                            </fd-menu-addon>\n                            <img class=\"mr8\" *ngIf=\"!menuItem.newIcon && menuItem.icon\" [src]=\"menuItem.icon\" />\n                            <span fd-menu-title>{{ menuItem.text }}</span>\n                        </div>\n                    </li>\n                </fd-menu>\n            </fd-split-button>\n            <button\n                *ngIf=\"!btn.isBuiltin\"\n                fd-button\n                fd-toolbar-item\n                [fdMenu]=\"true\"\n                [glyph]=\"btn.FontIcon\"\n                [style.color]=\"btn.IconColor\"\n                [fdType]=\"btn.design ? btn.design : btn.Data?.JsonExtraProp?.Design\"\n                [label]=\"btn.text | bbbTranslate\"\n                [ariaLabel]=\"btn.text | bbbTranslate\"\n                [fdMenuTrigger]=\"menu\"\n            >\n                <img *ngIf=\"!btn.Data?.JsonExtraProp?.Icon && !btn.newIcon && btn.icon\" width=\"16\" [src]=\"btn.icon\" />\n                <fd-menu #menu>\n                    <li\n                        fd-menu-item\n                        *ngFor=\"let menuItem of btn.menu.items\"\n                        [disabled]=\"menuItem.disabled\"\n                        (click)=\"onToolbarClick(menuItem, menu)\"\n                    >\n                        <div fd-menu-interactive>\n                            <fd-menu-addon\n                                *ngIf=\"\n                                    menuItem.newIcon ||\n                                    menuItem.Data?.JsonExtraProp?.Icon ||\n                                    menuItem.FontIcon ||\n                                    menuItem.Data?.CustomUi?.Parameters?.Icon\n                                \"\n                                position=\"before\"\n                                [ngClass]=\"\n                                    menuItem.Data?.CustomUi?.Parameters?.FdType$Caption\n                                        ? 'fd-button--' + menuItem.Data?.CustomUi?.Parameters?.FdType$Caption\n                                        : ''\n                                \"\n                                [style.color]=\"menuItem.IconColor\"\n                                [glyph]=\"\n                                    menuItem.newIcon ||\n                                    menuItem.Data?.JsonExtraProp?.Icon ||\n                                    menuItem.FontIcon ||\n                                    menuItem.Data?.CustomUi?.Parameters?.Icon\n                                \"\n                            >\n                            </fd-menu-addon>\n                            <img\n                                class=\"mr8\"\n                                *ngIf=\"\n                                    !(\n                                        menuItem.newIcon ||\n                                        menuItem.Data?.JsonExtraProp?.Icon ||\n                                        menuItem.Data?.CustomUi?.Parameters?.Icon ||\n                                        menuItem.FontIcon\n                                    ) && menuItem.icon\n                                \"\n                                [src]=\"menuItem.icon\"\n                            />\n                            <span fd-menu-title>{{ menuItem.text }}</span>\n                        </div>\n                    </li>\n                </fd-menu>\n            </button>\n        </ng-container>\n        <ng-template #simpleButton>\n            <ng-container *ngIf=\"!(btn === '-' || btn.text === '-')\">\n                <ng-container\n                    *ngTemplateOutlet=\"\n                        btn.Data?.CustomUi?.Selector ? dynamicBtnTemplate : btnTemplate;\n                        context: { $implicit: btn }\n                    \"\n                ></ng-container>\n                <ng-template #btnTemplate let-btn>\n                    <button\n                        fd-toolbar-item\n                        fd-button\n                        [disabled]=\"btn.disabled\"\n                        [attr.fdOverflowPriority]=\"btn.priority\"\n                        [fdType]=\"\n                            btn.isWorkflow ? 'positive' : btn.design ? btn.design : btn.Data?.JsonExtraProp?.Design\n                        \"\n                        [glyph]=\"btn.newIcon ? btn.newIcon : btn.Data?.JsonExtraProp?.Icon\"\n                        (click)=\"onToolbarClick(btn)\"\n                    >\n                        <img\n                            *ngIf=\"!btn.Data?.JsonExtraProp?.Icon && !btn.newIcon && btn.icon\"\n                            width=\"16\"\n                            [src]=\"btn.icon\"\n                        />\n                        <span *ngIf=\"btn.text\">{{ btn.text }}</span>\n                    </button>\n                </ng-template>\n                <ng-template #dynamicBtnTemplate let-btn>\n                    <bnrc-dynamic-form-toolbaritem\n                        fd-toolbar-item\n                        [component]=\"btn.Data.CustomUi\"\n                        [context]=\"btn\"\n                        [isEnable]=\"btn.Command?._isEnable\"\n                        (btnClick)=\"onToolbarClick(btn)\"\n                    ></bnrc-dynamic-form-toolbaritem>\n                </ng-template>\n            </ng-container>\n        </ng-template>\n    </ng-container>\n</fd-toolbar>\n"]}
@@ -17,7 +17,8 @@ export class FormToolbarButtonComponent extends BaseFormToolbaritemPropsComponen
17
17
  this.icon = this.parameters.Icon;
18
18
  this.fdType = this.parameters.FdType$Caption;
19
19
  this.minWidth = this.parameters.MinWidth;
20
- this.text = this.inlineHelp = this.context.text;
20
+ this.customText = this.parameters.Title;
21
+ this.text = this.inlineHelp = this.customText || this.context.text;
21
22
  // this.inlineHelpDirective.disabled = this.parameters.ShowTooltip === false;
22
23
  }
23
24
  ngOnChanges(changes) {
@@ -30,10 +31,10 @@ export class FormToolbarButtonComponent extends BaseFormToolbaritemPropsComponen
30
31
  }
31
32
  }
32
33
  FormToolbarButtonComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: FormToolbarButtonComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
33
- FormToolbarButtonComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: FormToolbarButtonComponent, selector: "bsu-form-toolbar-button", inputs: { parameters: "parameters" }, outputs: { btnClick: "btnClick" }, viewQueries: [{ propertyName: "inlineHelpDirective", first: true, predicate: InlineHelpDirective, descendants: true, static: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<button\n fd-toolbar-item\n fd-button\n [title]=\"inlineHelp | bbbTranslate\"\n [glyph]=\"icon\"\n [class.control-disabled]=\"isEnable === false ? true : false\"\n [fdType]=\"fdType || (!isEnable ? 'transparent' : fdType)\"\n (click)=\"btnClick.emit()\"\n [style.min-width.px]=\"minWidth ? minWidth : null\"\n>\n <span *ngIf=\"!onlyIcon || showText\">{{ text | bbbTranslate }}</span>\n</button>\n", styles: [""], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.ButtonComponent, selector: "button[fd-button], a[fd-button]", inputs: ["class"], exportAs: ["fd-button"] }, { kind: "directive", type: i3.ToolbarItemDirective, selector: "[fd-toolbar-item]" }, { kind: "pipe", type: i4.BbbTranslatePipe, name: "bbbTranslate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
34
+ FormToolbarButtonComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: FormToolbarButtonComponent, selector: "bsu-form-toolbar-button", inputs: { parameters: "parameters" }, outputs: { btnClick: "btnClick" }, viewQueries: [{ propertyName: "inlineHelpDirective", first: true, predicate: InlineHelpDirective, descendants: true, static: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<button\n fd-toolbar-item\n fd-button\n [title]=\"inlineHelp | bbbTranslate\"\n [glyph]=\"icon\"\n [class.control-disabled]=\"isEnable === false ? true : false\"\n [fdType]=\"fdType || (!isEnable ? 'transparent' : fdType)\"\n (click)=\"btnClick.emit()\"\n [style.min-width.px]=\"minWidth ? minWidth : null\"\n>\n <span *ngIf=\"!onlyIcon || showText\">{{ customText || text | bbbTranslate }}</span>\n</button>\n", styles: [""], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.ButtonComponent, selector: "button[fd-button], a[fd-button]", inputs: ["class"], exportAs: ["fd-button"] }, { kind: "directive", type: i3.ToolbarItemDirective, selector: "[fd-toolbar-item]" }, { kind: "pipe", type: i4.BbbTranslatePipe, name: "bbbTranslate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
34
35
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: FormToolbarButtonComponent, decorators: [{
35
36
  type: Component,
36
- args: [{ selector: 'bsu-form-toolbar-button', changeDetection: ChangeDetectionStrategy.OnPush, template: "<button\n fd-toolbar-item\n fd-button\n [title]=\"inlineHelp | bbbTranslate\"\n [glyph]=\"icon\"\n [class.control-disabled]=\"isEnable === false ? true : false\"\n [fdType]=\"fdType || (!isEnable ? 'transparent' : fdType)\"\n (click)=\"btnClick.emit()\"\n [style.min-width.px]=\"minWidth ? minWidth : null\"\n>\n <span *ngIf=\"!onlyIcon || showText\">{{ text | bbbTranslate }}</span>\n</button>\n" }]
37
+ args: [{ selector: 'bsu-form-toolbar-button', changeDetection: ChangeDetectionStrategy.OnPush, template: "<button\n fd-toolbar-item\n fd-button\n [title]=\"inlineHelp | bbbTranslate\"\n [glyph]=\"icon\"\n [class.control-disabled]=\"isEnable === false ? true : false\"\n [fdType]=\"fdType || (!isEnable ? 'transparent' : fdType)\"\n (click)=\"btnClick.emit()\"\n [style.min-width.px]=\"minWidth ? minWidth : null\"\n>\n <span *ngIf=\"!onlyIcon || showText\">{{ customText || text | bbbTranslate }}</span>\n</button>\n" }]
37
38
  }], propDecorators: { inlineHelpDirective: [{
38
39
  type: ViewChild,
39
40
  args: [InlineHelpDirective, { static: true }]
@@ -42,4 +43,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImpor
42
43
  }], btnClick: [{
43
44
  type: Output
44
45
  }] } });
45
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS10b29sYmFyLWJ1dHRvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9iYXJzYS1zYXAtdWkvc3JjL2xpYi9mb3JtLXRvb2xiYXItYnV0dG9uL2Zvcm0tdG9vbGJhci1idXR0b24uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2Etc2FwLXVpL3NyYy9saWIvZm9ybS10b29sYmFyLWJ1dHRvbi9mb3JtLXRvb2xiYXItYnV0dG9uLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDSCxTQUFTLEVBQ1QsdUJBQXVCLEVBQ3ZCLEtBQUssRUFDTCxNQUFNLEVBQ04sWUFBWSxFQUVaLFNBQVMsRUFHWixNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQWMsbUJBQW1CLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUN4RSxPQUFPLEVBQUUsaUNBQWlDLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQzs7Ozs7O0FBUXpFLE1BQU0sT0FBTywwQkFBMkIsU0FBUSxpQ0FBaUM7SUFOakY7O1FBU2MsYUFBUSxHQUFHLElBQUksWUFBWSxFQUFRLENBQUM7S0F3QmpEO0lBakJHLFFBQVE7UUFDSixLQUFLLENBQUMsUUFBUSxFQUFFLENBQUM7UUFDakIsSUFBSSxDQUFDLFFBQVEsR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLFFBQVEsQ0FBQztRQUN6QyxJQUFJLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDO1FBQ2pDLElBQUksQ0FBQyxNQUFNLEdBQUcsSUFBSSxDQUFDLFVBQVUsQ0FBQyxjQUFjLENBQUM7UUFDN0MsSUFBSSxDQUFDLFFBQVEsR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLFFBQVEsQ0FBQztRQUN6QyxJQUFJLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQyxVQUFVLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUM7UUFDaEQsNkVBQTZFO0lBQ2pGLENBQUM7SUFDRCxXQUFXLENBQUMsT0FBc0I7UUFDOUIsS0FBSyxDQUFDLFdBQVcsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUMzQixNQUFNLEVBQUUsUUFBUSxFQUFFLEdBQUcsT0FBTyxDQUFDO1FBQzdCLElBQUksUUFBUSxJQUFJLENBQUMsUUFBUSxDQUFDLFdBQVcsSUFBSSxRQUFRLENBQUMsWUFBWSxLQUFLLElBQUksQ0FBQyxRQUFRLEVBQUU7WUFDOUUsSUFBSSxDQUFDLFFBQVEsR0FBRyxRQUFRLENBQUMsWUFBWSxDQUFDO1lBQ3RDLElBQUksQ0FBQyxJQUFJLENBQUMsWUFBWSxFQUFFLENBQUM7U0FDNUI7SUFDTCxDQUFDOzt1SEExQlEsMEJBQTBCOzJHQUExQiwwQkFBMEIsNkxBQ3hCLG1CQUFtQiwwR0NyQmxDLHlhQVlBOzJGRFFhLDBCQUEwQjtrQkFOdEMsU0FBUzsrQkFDSSx5QkFBeUIsbUJBR2xCLHVCQUF1QixDQUFDLE1BQU07OEJBR0csbUJBQW1CO3NCQUFwRSxTQUFTO3VCQUFDLG1CQUFtQixFQUFFLEVBQUUsTUFBTSxFQUFFLElBQUksRUFBRTtnQkFDdkMsVUFBVTtzQkFBbEIsS0FBSztnQkFDSSxRQUFRO3NCQUFqQixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgICBDb21wb25lbnQsXG4gICAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gICAgSW5wdXQsXG4gICAgT3V0cHV0LFxuICAgIEV2ZW50RW1pdHRlcixcbiAgICBPbkluaXQsXG4gICAgVmlld0NoaWxkLFxuICAgIFNpbXBsZUNoYW5nZXMsXG4gICAgT25DaGFuZ2VzXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQnV0dG9uVHlwZSwgSW5saW5lSGVscERpcmVjdGl2ZSB9IGZyb20gJ0BmdW5kYW1lbnRhbC1uZ3gvY29yZSc7XG5pbXBvcnQgeyBCYXNlRm9ybVRvb2xiYXJpdGVtUHJvcHNDb21wb25lbnQgfSBmcm9tICdiYXJzYS1ub3Zpbi1yYXktY29yZSc7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnYnN1LWZvcm0tdG9vbGJhci1idXR0b24nLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9mb3JtLXRvb2xiYXItYnV0dG9uLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9mb3JtLXRvb2xiYXItYnV0dG9uLmNvbXBvbmVudC5zY3NzJ10sXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcbn0pXG5leHBvcnQgY2xhc3MgRm9ybVRvb2xiYXJCdXR0b25Db21wb25lbnQgZXh0ZW5kcyBCYXNlRm9ybVRvb2xiYXJpdGVtUHJvcHNDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQsIE9uQ2hhbmdlcyB7XG4gICAgQFZpZXdDaGlsZChJbmxpbmVIZWxwRGlyZWN0aXZlLCB7IHN0YXRpYzogdHJ1ZSB9KSBpbmxpbmVIZWxwRGlyZWN0aXZlOiBJbmxpbmVIZWxwRGlyZWN0aXZlO1xuICAgIEBJbnB1dCgpIHBhcmFtZXRlcnM7XG4gICAgQE91dHB1dCgpIGJ0bkNsaWNrID0gbmV3IEV2ZW50RW1pdHRlcjx2b2lkPigpO1xuICAgIG9ubHlJY29uOiBib29sZWFuO1xuICAgIGljb246IHN0cmluZztcbiAgICBpbmxpbmVIZWxwOiBzdHJpbmc7XG4gICAgZmRUeXBlOiBCdXR0b25UeXBlO1xuICAgIHRleHQ6IHN0cmluZztcbiAgICBtaW5XaWR0aDogbnVtYmVyO1xuICAgIG5nT25Jbml0KCk6IHZvaWQge1xuICAgICAgICBzdXBlci5uZ09uSW5pdCgpO1xuICAgICAgICB0aGlzLm9ubHlJY29uID0gdGhpcy5wYXJhbWV0ZXJzLk9ubHlJY29uO1xuICAgICAgICB0aGlzLmljb24gPSB0aGlzLnBhcmFtZXRlcnMuSWNvbjtcbiAgICAgICAgdGhpcy5mZFR5cGUgPSB0aGlzLnBhcmFtZXRlcnMuRmRUeXBlJENhcHRpb247XG4gICAgICAgIHRoaXMubWluV2lkdGggPSB0aGlzLnBhcmFtZXRlcnMuTWluV2lkdGg7XG4gICAgICAgIHRoaXMudGV4dCA9IHRoaXMuaW5saW5lSGVscCA9IHRoaXMuY29udGV4dC50ZXh0O1xuICAgICAgICAvLyB0aGlzLmlubGluZUhlbHBEaXJlY3RpdmUuZGlzYWJsZWQgPSB0aGlzLnBhcmFtZXRlcnMuU2hvd1Rvb2x0aXAgPT09IGZhbHNlO1xuICAgIH1cbiAgICBuZ09uQ2hhbmdlcyhjaGFuZ2VzOiBTaW1wbGVDaGFuZ2VzKTogdm9pZCB7XG4gICAgICAgIHN1cGVyLm5nT25DaGFuZ2VzKGNoYW5nZXMpO1xuICAgICAgICBjb25zdCB7IGlzRW5hYmxlIH0gPSBjaGFuZ2VzO1xuICAgICAgICBpZiAoaXNFbmFibGUgJiYgIWlzRW5hYmxlLmZpcnN0Q2hhbmdlICYmIGlzRW5hYmxlLmN1cnJlbnRWYWx1ZSAhPT0gdGhpcy5pc0VuYWJsZSkge1xuICAgICAgICAgICAgdGhpcy5pc0VuYWJsZSA9IGlzRW5hYmxlLmN1cnJlbnRWYWx1ZTtcbiAgICAgICAgICAgIHRoaXMuX2Nkci5tYXJrRm9yQ2hlY2soKTtcbiAgICAgICAgfVxuICAgIH1cbn1cbiIsIjxidXR0b25cbiAgICBmZC10b29sYmFyLWl0ZW1cbiAgICBmZC1idXR0b25cbiAgICBbdGl0bGVdPVwiaW5saW5lSGVscCB8IGJiYlRyYW5zbGF0ZVwiXG4gICAgW2dseXBoXT1cImljb25cIlxuICAgIFtjbGFzcy5jb250cm9sLWRpc2FibGVkXT1cImlzRW5hYmxlID09PSBmYWxzZSA/IHRydWUgOiBmYWxzZVwiXG4gICAgW2ZkVHlwZV09XCJmZFR5cGUgfHwgKCFpc0VuYWJsZSA/ICd0cmFuc3BhcmVudCcgOiBmZFR5cGUpXCJcbiAgICAoY2xpY2spPVwiYnRuQ2xpY2suZW1pdCgpXCJcbiAgICBbc3R5bGUubWluLXdpZHRoLnB4XT1cIm1pbldpZHRoID8gbWluV2lkdGggOiBudWxsXCJcbj5cbiAgICA8c3BhbiAqbmdJZj1cIiFvbmx5SWNvbiB8fCBzaG93VGV4dFwiPnt7IHRleHQgfCBiYmJUcmFuc2xhdGUgfX08L3NwYW4+XG48L2J1dHRvbj5cbiJdfQ==
46
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS10b29sYmFyLWJ1dHRvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9iYXJzYS1zYXAtdWkvc3JjL2xpYi9mb3JtLXRvb2xiYXItYnV0dG9uL2Zvcm0tdG9vbGJhci1idXR0b24uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2Etc2FwLXVpL3NyYy9saWIvZm9ybS10b29sYmFyLWJ1dHRvbi9mb3JtLXRvb2xiYXItYnV0dG9uLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDSCxTQUFTLEVBQ1QsdUJBQXVCLEVBQ3ZCLEtBQUssRUFDTCxNQUFNLEVBQ04sWUFBWSxFQUVaLFNBQVMsRUFHWixNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQWMsbUJBQW1CLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUN4RSxPQUFPLEVBQUUsaUNBQWlDLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQzs7Ozs7O0FBUXpFLE1BQU0sT0FBTywwQkFBMkIsU0FBUSxpQ0FBaUM7SUFOakY7O1FBU2MsYUFBUSxHQUFHLElBQUksWUFBWSxFQUFRLENBQUM7S0EwQmpEO0lBbEJHLFFBQVE7UUFDSixLQUFLLENBQUMsUUFBUSxFQUFFLENBQUM7UUFDakIsSUFBSSxDQUFDLFFBQVEsR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLFFBQVEsQ0FBQztRQUN6QyxJQUFJLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDO1FBQ2pDLElBQUksQ0FBQyxNQUFNLEdBQUcsSUFBSSxDQUFDLFVBQVUsQ0FBQyxjQUFjLENBQUM7UUFDN0MsSUFBSSxDQUFDLFFBQVEsR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLFFBQVEsQ0FBQztRQUN6QyxJQUFJLENBQUMsVUFBVSxHQUFHLElBQUksQ0FBQyxVQUFVLENBQUMsS0FBSyxDQUFDO1FBQ3hDLElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDLFVBQVUsR0FBRyxJQUFJLENBQUMsVUFBVSxJQUFJLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDO1FBQ25FLDZFQUE2RTtJQUNqRixDQUFDO0lBQ0QsV0FBVyxDQUFDLE9BQXNCO1FBQzlCLEtBQUssQ0FBQyxXQUFXLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDM0IsTUFBTSxFQUFFLFFBQVEsRUFBRSxHQUFHLE9BQU8sQ0FBQztRQUM3QixJQUFJLFFBQVEsSUFBSSxDQUFDLFFBQVEsQ0FBQyxXQUFXLElBQUksUUFBUSxDQUFDLFlBQVksS0FBSyxJQUFJLENBQUMsUUFBUSxFQUFFO1lBQzlFLElBQUksQ0FBQyxRQUFRLEdBQUcsUUFBUSxDQUFDLFlBQVksQ0FBQztZQUN0QyxJQUFJLENBQUMsSUFBSSxDQUFDLFlBQVksRUFBRSxDQUFDO1NBQzVCO0lBQ0wsQ0FBQzs7dUhBNUJRLDBCQUEwQjsyR0FBMUIsMEJBQTBCLDZMQUN4QixtQkFBbUIsMEdDckJsQyx1YkFZQTsyRkRRYSwwQkFBMEI7a0JBTnRDLFNBQVM7K0JBQ0kseUJBQXlCLG1CQUdsQix1QkFBdUIsQ0FBQyxNQUFNOzhCQUdHLG1CQUFtQjtzQkFBcEUsU0FBUzt1QkFBQyxtQkFBbUIsRUFBRSxFQUFFLE1BQU0sRUFBRSxJQUFJLEVBQUU7Z0JBQ3ZDLFVBQVU7c0JBQWxCLEtBQUs7Z0JBQ0ksUUFBUTtzQkFBakIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gICAgQ29tcG9uZW50LFxuICAgIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxuICAgIElucHV0LFxuICAgIE91dHB1dCxcbiAgICBFdmVudEVtaXR0ZXIsXG4gICAgT25Jbml0LFxuICAgIFZpZXdDaGlsZCxcbiAgICBTaW1wbGVDaGFuZ2VzLFxuICAgIE9uQ2hhbmdlc1xufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEJ1dHRvblR5cGUsIElubGluZUhlbHBEaXJlY3RpdmUgfSBmcm9tICdAZnVuZGFtZW50YWwtbmd4L2NvcmUnO1xuaW1wb3J0IHsgQmFzZUZvcm1Ub29sYmFyaXRlbVByb3BzQ29tcG9uZW50IH0gZnJvbSAnYmFyc2Etbm92aW4tcmF5LWNvcmUnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ2JzdS1mb3JtLXRvb2xiYXItYnV0dG9uJyxcbiAgICB0ZW1wbGF0ZVVybDogJy4vZm9ybS10b29sYmFyLWJ1dHRvbi5jb21wb25lbnQuaHRtbCcsXG4gICAgc3R5bGVVcmxzOiBbJy4vZm9ybS10b29sYmFyLWJ1dHRvbi5jb21wb25lbnQuc2NzcyddLFxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXG59KVxuZXhwb3J0IGNsYXNzIEZvcm1Ub29sYmFyQnV0dG9uQ29tcG9uZW50IGV4dGVuZHMgQmFzZUZvcm1Ub29sYmFyaXRlbVByb3BzQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0LCBPbkNoYW5nZXMge1xuICAgIEBWaWV3Q2hpbGQoSW5saW5lSGVscERpcmVjdGl2ZSwgeyBzdGF0aWM6IHRydWUgfSkgaW5saW5lSGVscERpcmVjdGl2ZTogSW5saW5lSGVscERpcmVjdGl2ZTtcbiAgICBASW5wdXQoKSBwYXJhbWV0ZXJzO1xuICAgIEBPdXRwdXQoKSBidG5DbGljayA9IG5ldyBFdmVudEVtaXR0ZXI8dm9pZD4oKTtcbiAgICBvbmx5SWNvbjogYm9vbGVhbjtcbiAgICBpY29uOiBzdHJpbmc7XG4gICAgaW5saW5lSGVscDogc3RyaW5nO1xuICAgIGZkVHlwZTogQnV0dG9uVHlwZTtcbiAgICB0ZXh0OiBzdHJpbmc7XG4gICAgY3VzdG9tVGV4dDogc3RyaW5nO1xuICAgIG1pbldpZHRoOiBudW1iZXI7XG4gICAgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgICAgIHN1cGVyLm5nT25Jbml0KCk7XG4gICAgICAgIHRoaXMub25seUljb24gPSB0aGlzLnBhcmFtZXRlcnMuT25seUljb247XG4gICAgICAgIHRoaXMuaWNvbiA9IHRoaXMucGFyYW1ldGVycy5JY29uO1xuICAgICAgICB0aGlzLmZkVHlwZSA9IHRoaXMucGFyYW1ldGVycy5GZFR5cGUkQ2FwdGlvbjtcbiAgICAgICAgdGhpcy5taW5XaWR0aCA9IHRoaXMucGFyYW1ldGVycy5NaW5XaWR0aDtcbiAgICAgICAgdGhpcy5jdXN0b21UZXh0ID0gdGhpcy5wYXJhbWV0ZXJzLlRpdGxlO1xuICAgICAgICB0aGlzLnRleHQgPSB0aGlzLmlubGluZUhlbHAgPSB0aGlzLmN1c3RvbVRleHQgfHwgdGhpcy5jb250ZXh0LnRleHQ7XG4gICAgICAgIC8vIHRoaXMuaW5saW5lSGVscERpcmVjdGl2ZS5kaXNhYmxlZCA9IHRoaXMucGFyYW1ldGVycy5TaG93VG9vbHRpcCA9PT0gZmFsc2U7XG4gICAgfVxuICAgIG5nT25DaGFuZ2VzKGNoYW5nZXM6IFNpbXBsZUNoYW5nZXMpOiB2b2lkIHtcbiAgICAgICAgc3VwZXIubmdPbkNoYW5nZXMoY2hhbmdlcyk7XG4gICAgICAgIGNvbnN0IHsgaXNFbmFibGUgfSA9IGNoYW5nZXM7XG4gICAgICAgIGlmIChpc0VuYWJsZSAmJiAhaXNFbmFibGUuZmlyc3RDaGFuZ2UgJiYgaXNFbmFibGUuY3VycmVudFZhbHVlICE9PSB0aGlzLmlzRW5hYmxlKSB7XG4gICAgICAgICAgICB0aGlzLmlzRW5hYmxlID0gaXNFbmFibGUuY3VycmVudFZhbHVlO1xuICAgICAgICAgICAgdGhpcy5fY2RyLm1hcmtGb3JDaGVjaygpO1xuICAgICAgICB9XG4gICAgfVxufVxuIiwiPGJ1dHRvblxuICAgIGZkLXRvb2xiYXItaXRlbVxuICAgIGZkLWJ1dHRvblxuICAgIFt0aXRsZV09XCJpbmxpbmVIZWxwIHwgYmJiVHJhbnNsYXRlXCJcbiAgICBbZ2x5cGhdPVwiaWNvblwiXG4gICAgW2NsYXNzLmNvbnRyb2wtZGlzYWJsZWRdPVwiaXNFbmFibGUgPT09IGZhbHNlID8gdHJ1ZSA6IGZhbHNlXCJcbiAgICBbZmRUeXBlXT1cImZkVHlwZSB8fCAoIWlzRW5hYmxlID8gJ3RyYW5zcGFyZW50JyA6IGZkVHlwZSlcIlxuICAgIChjbGljayk9XCJidG5DbGljay5lbWl0KClcIlxuICAgIFtzdHlsZS5taW4td2lkdGgucHhdPVwibWluV2lkdGggPyBtaW5XaWR0aCA6IG51bGxcIlxuPlxuICAgIDxzcGFuICpuZ0lmPVwiIW9ubHlJY29uIHx8IHNob3dUZXh0XCI+e3sgY3VzdG9tVGV4dCB8fCB0ZXh0IHwgYmJiVHJhbnNsYXRlIH19PC9zcGFuPlxuPC9idXR0b24+XG4iXX0=