barsa-sap-ui 0.0.2
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.
- package/README.md +25 -0
- package/esm2020/barsa-sap-ui.mjs +5 -0
- package/esm2020/lib/apply-conditional-formmatings.directive.mjs +84 -0
- package/esm2020/lib/barsa-asp-viewer/barsa-asp-viewer.component.mjs +109 -0
- package/esm2020/lib/barsa-base-layout/barsa-base-layout.component.mjs +34 -0
- package/esm2020/lib/barsa-date-time-picker/barsa-date-time-picker.component.mjs +71 -0
- package/esm2020/lib/barsa-list-file-linear/barsa-list-file-linear.component.mjs +28 -0
- package/esm2020/lib/barsa-monaco-editor/barsa-monaco-editor.component.mjs +77 -0
- package/esm2020/lib/barsa-network-offline/barsa-network-offline.component.mjs +45 -0
- package/esm2020/lib/barsa-sap-ui-routing.module.mjs +17 -0
- package/esm2020/lib/barsa-sap-ui.module.mjs +277 -0
- package/esm2020/lib/barsa-search-form/barsa-search-form.component.mjs +29 -0
- package/esm2020/lib/barsa-table-header/barsa-table-header.component.mjs +122 -0
- package/esm2020/lib/barsa-table-row/barsa-table-row.component.mjs +57 -0
- package/esm2020/lib/barsa-tinyemce/barsa-tinyemce.component.mjs +334 -0
- package/esm2020/lib/barsa-tree-item/barsa-tree-item.component.mjs +120 -0
- package/esm2020/lib/barsa-tree-item/node-has-one-depth-level.pipe.mjs +19 -0
- package/esm2020/lib/barsa-ulv-main/barsa-ulv-main.component.mjs +156 -0
- package/esm2020/lib/breadcrumb/breadcrumb.component.mjs +45 -0
- package/esm2020/lib/captcha-field/captcha-field.component.mjs +28 -0
- package/esm2020/lib/card-item/card-item.component.mjs +60 -0
- package/esm2020/lib/card-view-content/card-view-content.component.mjs +23 -0
- package/esm2020/lib/col-renderer.directive.mjs +50 -0
- package/esm2020/lib/column-matrix-renderer/column-matrix-renderer.component.mjs +56 -0
- package/esm2020/lib/column-matrix-renderer/matrix-value.pipe.mjs +60 -0
- package/esm2020/lib/column-renderer/column-renderer.component.mjs +84 -0
- package/esm2020/lib/constants.mjs +413 -0
- package/esm2020/lib/custom-date-time/custom-date-time.component.mjs +41 -0
- package/esm2020/lib/device-info-field-base.mjs +23 -0
- package/esm2020/lib/dynamic-page-size.pipe.mjs +26 -0
- package/esm2020/lib/empty-page/empty-page.component.mjs +38 -0
- package/esm2020/lib/file-in-dialog/file-in-dialog.component.mjs +44 -0
- package/esm2020/lib/form-dialog/form-dialog.component.mjs +125 -0
- package/esm2020/lib/form-dialog-less/form-dialog-less.component.mjs +38 -0
- package/esm2020/lib/form-page/form-page.component.mjs +51 -0
- package/esm2020/lib/form-page-base.mjs +129 -0
- package/esm2020/lib/form-toolbar-button/form-toolbar-button.component.mjs +44 -0
- package/esm2020/lib/form-wizard/form-wizard.component.mjs +21 -0
- package/esm2020/lib/fullscreen-dialog.directive.mjs +40 -0
- package/esm2020/lib/fundamental-dynamic-form/fundamental-dynamic-form.component.mjs +152 -0
- package/esm2020/lib/gantt-dhtml-chart-view/gantt-dhtml-chart-view.component.mjs +203 -0
- package/esm2020/lib/global-search/global-search.component.mjs +26 -0
- package/esm2020/lib/global-search-module/global-search-module.component.mjs +30 -0
- package/esm2020/lib/global-search-panel/global-search-panel.component.mjs +30 -0
- package/esm2020/lib/header-avatar/header-avatar.component.mjs +19 -0
- package/esm2020/lib/header-facet-form/header-facet-form.component.mjs +22 -0
- package/esm2020/lib/header-facet-key-value/header-facet-key-value.component.mjs +31 -0
- package/esm2020/lib/header-facet-microchart/header-facet-microchart.component.mjs +21 -0
- package/esm2020/lib/header-facet-plain-text/header-facet-plain-text.component.mjs +28 -0
- package/esm2020/lib/header-facet-progress/header-facet-progress.component.mjs +26 -0
- package/esm2020/lib/header-facet-rate/header-facet-rate.component.mjs +26 -0
- package/esm2020/lib/htree-create-new/htree-create-new.component.mjs +49 -0
- package/esm2020/lib/hyperlink/hyperlink.component.mjs +19 -0
- package/esm2020/lib/index.mjs +412 -0
- package/esm2020/lib/inline-save-and-cancel/inline-save-and-cancel.component.mjs +32 -0
- package/esm2020/lib/layout-actions/layout-actions.component.mjs +65 -0
- package/esm2020/lib/layout-control/layout-control.component.mjs +214 -0
- package/esm2020/lib/layout-wizard/layout-wizard.component.mjs +133 -0
- package/esm2020/lib/list-item/list-item.component.mjs +30 -0
- package/esm2020/lib/ly-empty-space/ly-empty-space.component.mjs +37 -0
- package/esm2020/lib/ly-horizontal-layout/ly-horizontal-layout.component.mjs +70 -0
- package/esm2020/lib/ly-label/ly-label.component.mjs +31 -0
- package/esm2020/lib/ly-layout-container/ly-layout-container.component.mjs +83 -0
- package/esm2020/lib/ly-layout-container-of-root/ly-layout-container-of-root.component.mjs +17 -0
- package/esm2020/lib/ly-layout-field-label/ly-layout-field-label.component.mjs +24 -0
- package/esm2020/lib/ly-layout-panel/ly-layout-panel.component.mjs +64 -0
- package/esm2020/lib/ly-line/ly-line.component.mjs +56 -0
- package/esm2020/lib/ly-simple-label/ly-simple-label.component.mjs +27 -0
- package/esm2020/lib/ly-tab-container/ly-tab-container.component.mjs +43 -0
- package/esm2020/lib/ly-tab-page/ly-tab-page.component.mjs +35 -0
- package/esm2020/lib/ly-vertical-layout/ly-vertical-layout.component.mjs +49 -0
- package/esm2020/lib/manage-filters-report/manage-filters-report.component.mjs +45 -0
- package/esm2020/lib/mask/mask.component.mjs +22 -0
- package/esm2020/lib/message-strip/message-strip.component.mjs +28 -0
- package/esm2020/lib/models/grid-data-provider.mjs +219 -0
- package/esm2020/lib/models/grid-view.mjs +2 -0
- package/esm2020/lib/models/index.mjs +2 -0
- package/esm2020/lib/no-data/no-data.component.mjs +20 -0
- package/esm2020/lib/page-with-form-handler-base.mjs +42 -0
- package/esm2020/lib/page-with-header/page-with-header.component.mjs +76 -0
- package/esm2020/lib/progress-indicator/progress-indicator.component.mjs +18 -0
- package/esm2020/lib/report-navigator/report-navigator.component.mjs +62 -0
- package/esm2020/lib/report-new-top-form/report-new-top-form.component.mjs +60 -0
- package/esm2020/lib/report-search-fields-hidden-settings/report-search-fields-hidden-settings.component.mjs +35 -0
- package/esm2020/lib/report-search-fields-manage/report-search-fields-manage.component.mjs +99 -0
- package/esm2020/lib/report-search-panel-save/report-search-panel-save.component.mjs +90 -0
- package/esm2020/lib/report-tree-base.mjs +405 -0
- package/esm2020/lib/report-view-renderer.directive.mjs +248 -0
- package/esm2020/lib/responsive-toolbar/responsive-toolbar.component.mjs +50 -0
- package/esm2020/lib/responsive-toolbar-renderer/responsive-toolbar-renderer.component.mjs +84 -0
- package/esm2020/lib/rich-text-static/rich-text-static.component.mjs +35 -0
- package/esm2020/lib/sap-font-class.pipe.mjs +29 -0
- package/esm2020/lib/sap-font.pipe.mjs +29 -0
- package/esm2020/lib/sap-ui-report-base.component.mjs +689 -0
- package/esm2020/lib/search-panel/search-panel.component.mjs +40 -0
- package/esm2020/lib/static-text/static-text.component.mjs +15 -0
- package/esm2020/lib/title/title.component.mjs +15 -0
- package/esm2020/lib/ui-asp-report-viewer/ui-asp-report-viewer.component.mjs +14 -0
- package/esm2020/lib/ui-button/ui-button.component.mjs +31 -0
- package/esm2020/lib/ui-calendar/ui-calendar.component.mjs +46 -0
- package/esm2020/lib/ui-card-view/ui-card-view.component.mjs +60 -0
- package/esm2020/lib/ui-card-view-horizontal-group/ui-card-view-horizontal-group.component.mjs +27 -0
- package/esm2020/lib/ui-check-box/ui-check-box.component.mjs +29 -0
- package/esm2020/lib/ui-color-ui/ui-color-ui.component.mjs +50 -0
- package/esm2020/lib/ui-container-with-button/ui-container-with-button.component.mjs +34 -0
- package/esm2020/lib/ui-date-range-ex/ui-date-range-ex.component.mjs +194 -0
- package/esm2020/lib/ui-date-time/ui-date-time.component.mjs +116 -0
- package/esm2020/lib/ui-editable-grid/ui-editable-grid.component.mjs +110 -0
- package/esm2020/lib/ui-exception-form/ui-exception-form.component.mjs +61 -0
- package/esm2020/lib/ui-file-linear-list-box/ui-file-linear-list-box.component.mjs +181 -0
- package/esm2020/lib/ui-form-panel/ui-form-panel.component.mjs +43 -0
- package/esm2020/lib/ui-form-panel-toolbar/ui-form-panel-toolbar.component.mjs +26 -0
- package/esm2020/lib/ui-gantt-chart/ui-gantt-chart.component.mjs +32 -0
- package/esm2020/lib/ui-graph/ui-graph.component.mjs +16 -0
- package/esm2020/lib/ui-grid/ui-grid.component.mjs +25 -0
- package/esm2020/lib/ui-grid-columns/ui-grid-columns.component.mjs +44 -0
- package/esm2020/lib/ui-grid-filter-item/ui-grid-filter-item.component.mjs +67 -0
- package/esm2020/lib/ui-grid-filter-settings/ui-grid-filter-settings.component.mjs +76 -0
- package/esm2020/lib/ui-grid-sort-item/ui-grid-sort-item.component.mjs +59 -0
- package/esm2020/lib/ui-grid-sort-setting/ui-grid-sort-setting.component.mjs +156 -0
- package/esm2020/lib/ui-info-bar-panel/ui-info-bar-panel.component.mjs +11 -0
- package/esm2020/lib/ui-label/ui-label.component.mjs +12 -0
- package/esm2020/lib/ui-linear-list-container-with-button/ui-linear-list-container-with-button.component.mjs +299 -0
- package/esm2020/lib/ui-list-view/ui-list-view.component.mjs +44 -0
- package/esm2020/lib/ui-matrix-view/ui-matrix-view.component.mjs +125 -0
- package/esm2020/lib/ui-mo-info-combo-viewer/ui-mo-info-combo-viewer.component.mjs +19 -0
- package/esm2020/lib/ui-mo-info-general-object-ui/ui-mo-info-general-object-ui.component.mjs +13 -0
- package/esm2020/lib/ui-mo-info-sub-form-ui/ui-mo-info-sub-form-ui.component.mjs +46 -0
- package/esm2020/lib/ui-mo-info-ulv-combo/ui-mo-info-ulv-combo.component.mjs +335 -0
- package/esm2020/lib/ui-monaco-editor/ui-monaco-editor.component.mjs +18 -0
- package/esm2020/lib/ui-multi-select-combo/ui-multi-select-combo.component.mjs +83 -0
- package/esm2020/lib/ui-num-decimal-ui/ui-num-decimal-ui.component.mjs +24 -0
- package/esm2020/lib/ui-num-int-ui/ui-num-int-ui.component.mjs +21 -0
- package/esm2020/lib/ui-pdf-viewer/ui-pdf-viewer.component.mjs +216 -0
- package/esm2020/lib/ui-picture-file/ui-picture-file.component.mjs +95 -0
- package/esm2020/lib/ui-pictures-info/ui-pictures-info.component.mjs +215 -0
- package/esm2020/lib/ui-radio-group/ui-radio-group.component.mjs +24 -0
- package/esm2020/lib/ui-read-only-field/ui-read-only-field.component.mjs +29 -0
- package/esm2020/lib/ui-report-container/ui-report-container.component.mjs +46 -0
- package/esm2020/lib/ui-search-command-info-ui/ui-search-command-info-ui.component.mjs +24 -0
- package/esm2020/lib/ui-simple-combo/ui-simple-combo.component.mjs +29 -0
- package/esm2020/lib/ui-single-picture/ui-single-picture.component.mjs +36 -0
- package/esm2020/lib/ui-switch-button/ui-switch-button.component.mjs +20 -0
- package/esm2020/lib/ui-table-view/ui-table-view.component.mjs +106 -0
- package/esm2020/lib/ui-text-area/ui-text-area.component.mjs +44 -0
- package/esm2020/lib/ui-text-field/ui-text-field.component.mjs +47 -0
- package/esm2020/lib/ui-text-field-auto-complete/ui-text-field-auto-complete.component.mjs +47 -0
- package/esm2020/lib/ui-time-span/ui-time-span.component.mjs +24 -0
- package/esm2020/lib/ui-tinymce/ui-tinymce.component.mjs +53 -0
- package/esm2020/lib/ui-tree/ui-tree.component.mjs +69 -0
- package/esm2020/lib/ui-tree-view/ui-tree-view.component.mjs +75 -0
- package/esm2020/lib/ui-ulv-form-multi-select-ui/ui-ulv-form-multi-select-ui.component.mjs +24 -0
- package/esm2020/lib/ui-ulv-main-ui/ui-ulv-main-ui.component.mjs +276 -0
- package/esm2020/lib/ui-workflow-panel-ui/ui-workflow-panel-ui.component.mjs +26 -0
- package/esm2020/lib/ul-loading-mask-ui/ul-loading-mask-ui.component.mjs +86 -0
- package/esm2020/lib/ul-msg-box-adapter/ul-msg-box-adapter.component.mjs +117 -0
- package/esm2020/lib/ul-notify-popup/ul-notify-popup.component.mjs +114 -0
- package/esm2020/lib/ul-toast-adapter/ul-toast-adapter.component.mjs +44 -0
- package/esm2020/lib/ulv-column-settings/ulv-column-settings.component.mjs +53 -0
- package/esm2020/lib/ulv-context-menu/ulv-context-menu.component.mjs +74 -0
- package/esm2020/lib/ulv-filter-settings/ulv-filter-settings.component.mjs +43 -0
- package/esm2020/lib/ulv-form-multi-select/ulv-form-multi-select.component.mjs +183 -0
- package/esm2020/lib/ulv-groupby-settings/ulv-groupby-settings.component.mjs +44 -0
- package/esm2020/lib/ulv-paging/ulv-paging.component.mjs +73 -0
- package/esm2020/lib/ulv-selection/ulv-selection.component.mjs +66 -0
- package/esm2020/lib/ulv-settings/ulv-settings.component.mjs +117 -0
- package/esm2020/lib/ulv-sort-settings/ulv-sort-settings.component.mjs +44 -0
- package/esm2020/lib/ulv-toolbar/ulv-toolbar.component.mjs +110 -0
- package/esm2020/lib/upload-file-status.pipe.mjs +28 -0
- package/esm2020/lib/wizard-layout.directive.mjs +102 -0
- package/esm2020/public-api.mjs +170 -0
- package/fesm2015/barsa-sap-ui.mjs +11437 -0
- package/fesm2015/barsa-sap-ui.mjs.map +1 -0
- package/fesm2020/barsa-sap-ui.mjs +11427 -0
- package/fesm2020/barsa-sap-ui.mjs.map +1 -0
- package/index.d.ts +5 -0
- package/lib/apply-conditional-formmatings.directive.d.ts +25 -0
- package/lib/barsa-asp-viewer/barsa-asp-viewer.component.d.ts +26 -0
- package/lib/barsa-base-layout/barsa-base-layout.component.d.ts +18 -0
- package/lib/barsa-date-time-picker/barsa-date-time-picker.component.d.ts +18 -0
- package/lib/barsa-list-file-linear/barsa-list-file-linear.component.d.ts +8 -0
- package/lib/barsa-monaco-editor/barsa-monaco-editor.component.d.ts +18 -0
- package/lib/barsa-network-offline/barsa-network-offline.component.d.ts +13 -0
- package/lib/barsa-sap-ui-routing.module.d.ts +7 -0
- package/lib/barsa-sap-ui.module.d.ts +181 -0
- package/lib/barsa-search-form/barsa-search-form.component.d.ts +8 -0
- package/lib/barsa-table-header/barsa-table-header.component.d.ts +37 -0
- package/lib/barsa-table-row/barsa-table-row.component.d.ts +20 -0
- package/lib/barsa-tinyemce/barsa-tinyemce.component.d.ts +43 -0
- package/lib/barsa-tree-item/barsa-tree-item.component.d.ts +48 -0
- package/lib/barsa-tree-item/node-has-one-depth-level.pipe.d.ts +8 -0
- package/lib/barsa-ulv-main/barsa-ulv-main.component.d.ts +52 -0
- package/lib/breadcrumb/breadcrumb.component.d.ts +17 -0
- package/lib/captcha-field/captcha-field.component.d.ts +10 -0
- package/lib/card-item/card-item.component.d.ts +17 -0
- package/lib/card-view-content/card-view-content.component.d.ts +8 -0
- package/lib/col-renderer.directive.d.ts +12 -0
- package/lib/column-matrix-renderer/column-matrix-renderer.component.d.ts +23 -0
- package/lib/column-matrix-renderer/matrix-value.pipe.d.ts +8 -0
- package/lib/column-renderer/column-renderer.component.d.ts +29 -0
- package/lib/constants.d.ts +6 -0
- package/lib/custom-date-time/custom-date-time.component.d.ts +26 -0
- package/lib/device-info-field-base.d.ts +12 -0
- package/lib/dynamic-page-size.pipe.d.ts +8 -0
- package/lib/empty-page/empty-page.component.d.ts +11 -0
- package/lib/file-in-dialog/file-in-dialog.component.d.ts +16 -0
- package/lib/form-dialog/form-dialog.component.d.ts +40 -0
- package/lib/form-dialog-less/form-dialog-less.component.d.ts +27 -0
- package/lib/form-page/form-page.component.d.ts +17 -0
- package/lib/form-page-base.d.ts +26 -0
- package/lib/form-toolbar-button/form-toolbar-button.component.d.ts +18 -0
- package/lib/form-wizard/form-wizard.component.d.ts +8 -0
- package/lib/fullscreen-dialog.directive.d.ts +14 -0
- package/lib/fundamental-dynamic-form/fundamental-dynamic-form.component.d.ts +58 -0
- package/lib/gantt-dhtml-chart-view/gantt-dhtml-chart-view.component.d.ts +18 -0
- package/lib/global-search/global-search.component.d.ts +12 -0
- package/lib/global-search-module/global-search-module.component.d.ts +18 -0
- package/lib/global-search-panel/global-search-panel.component.d.ts +11 -0
- package/lib/header-avatar/header-avatar.component.d.ts +8 -0
- package/lib/header-facet-form/header-facet-form.component.d.ts +9 -0
- package/lib/header-facet-key-value/header-facet-key-value.component.d.ts +11 -0
- package/lib/header-facet-microchart/header-facet-microchart.component.d.ts +8 -0
- package/lib/header-facet-plain-text/header-facet-plain-text.component.d.ts +11 -0
- package/lib/header-facet-progress/header-facet-progress.component.d.ts +11 -0
- package/lib/header-facet-rate/header-facet-rate.component.d.ts +11 -0
- package/lib/htree-create-new/htree-create-new.component.d.ts +13 -0
- package/lib/hyperlink/hyperlink.component.d.ts +7 -0
- package/lib/index.d.ts +85 -0
- package/lib/inline-save-and-cancel/inline-save-and-cancel.component.d.ts +11 -0
- package/lib/layout-actions/layout-actions.component.d.ts +23 -0
- package/lib/layout-control/layout-control.component.d.ts +65 -0
- package/lib/layout-wizard/layout-wizard.component.d.ts +27 -0
- package/lib/list-item/list-item.component.d.ts +13 -0
- package/lib/ly-empty-space/ly-empty-space.component.d.ts +14 -0
- package/lib/ly-horizontal-layout/ly-horizontal-layout.component.d.ts +22 -0
- package/lib/ly-label/ly-label.component.d.ts +15 -0
- package/lib/ly-layout-container/ly-layout-container.component.d.ts +26 -0
- package/lib/ly-layout-container-of-root/ly-layout-container-of-root.component.d.ts +8 -0
- package/lib/ly-layout-field-label/ly-layout-field-label.component.d.ts +13 -0
- package/lib/ly-layout-panel/ly-layout-panel.component.d.ts +25 -0
- package/lib/ly-line/ly-line.component.d.ts +17 -0
- package/lib/ly-simple-label/ly-simple-label.component.d.ts +11 -0
- package/lib/ly-tab-container/ly-tab-container.component.d.ts +16 -0
- package/lib/ly-tab-page/ly-tab-page.component.d.ts +18 -0
- package/lib/ly-vertical-layout/ly-vertical-layout.component.d.ts +18 -0
- package/lib/manage-filters-report/manage-filters-report.component.d.ts +24 -0
- package/lib/mask/mask.component.d.ts +9 -0
- package/lib/message-strip/message-strip.component.d.ts +11 -0
- package/lib/models/grid-data-provider.d.ts +26 -0
- package/lib/models/grid-view.d.ts +64 -0
- package/lib/models/index.d.ts +1 -0
- package/lib/no-data/no-data.component.d.ts +8 -0
- package/lib/page-with-form-handler-base.d.ts +10 -0
- package/lib/page-with-header/page-with-header.component.d.ts +29 -0
- package/lib/progress-indicator/progress-indicator.component.d.ts +8 -0
- package/lib/report-navigator/report-navigator.component.d.ts +21 -0
- package/lib/report-new-top-form/report-new-top-form.component.d.ts +18 -0
- package/lib/report-search-fields-hidden-settings/report-search-fields-hidden-settings.component.d.ts +14 -0
- package/lib/report-search-fields-manage/report-search-fields-manage.component.d.ts +20 -0
- package/lib/report-search-panel-save/report-search-panel-save.component.d.ts +27 -0
- package/lib/report-tree-base.d.ts +61 -0
- package/lib/report-view-renderer.directive.d.ts +82 -0
- package/lib/responsive-toolbar/responsive-toolbar.component.d.ts +19 -0
- package/lib/responsive-toolbar-renderer/responsive-toolbar-renderer.component.d.ts +24 -0
- package/lib/rich-text-static/rich-text-static.component.d.ts +24 -0
- package/lib/sap-font-class.pipe.d.ts +8 -0
- package/lib/sap-font.pipe.d.ts +9 -0
- package/lib/sap-ui-report-base.component.d.ts +133 -0
- package/lib/search-panel/search-panel.component.d.ts +13 -0
- package/lib/static-text/static-text.component.d.ts +7 -0
- package/lib/title/title.component.d.ts +7 -0
- package/lib/ui-asp-report-viewer/ui-asp-report-viewer.component.d.ts +7 -0
- package/lib/ui-button/ui-button.component.d.ts +11 -0
- package/lib/ui-calendar/ui-calendar.component.d.ts +16 -0
- package/lib/ui-card-view/ui-card-view.component.d.ts +16 -0
- package/lib/ui-card-view-horizontal-group/ui-card-view-horizontal-group.component.d.ts +9 -0
- package/lib/ui-check-box/ui-check-box.component.d.ts +12 -0
- package/lib/ui-color-ui/ui-color-ui.component.d.ts +16 -0
- package/lib/ui-container-with-button/ui-container-with-button.component.d.ts +11 -0
- package/lib/ui-date-range-ex/ui-date-range-ex.component.d.ts +36 -0
- package/lib/ui-date-time/ui-date-time.component.d.ts +24 -0
- package/lib/ui-editable-grid/ui-editable-grid.component.d.ts +43 -0
- package/lib/ui-exception-form/ui-exception-form.component.d.ts +16 -0
- package/lib/ui-file-linear-list-box/ui-file-linear-list-box.component.d.ts +51 -0
- package/lib/ui-form-panel/ui-form-panel.component.d.ts +24 -0
- package/lib/ui-form-panel-toolbar/ui-form-panel-toolbar.component.d.ts +13 -0
- package/lib/ui-gantt-chart/ui-gantt-chart.component.d.ts +15 -0
- package/lib/ui-graph/ui-graph.component.d.ts +9 -0
- package/lib/ui-grid/ui-grid.component.d.ts +12 -0
- package/lib/ui-grid-columns/ui-grid-columns.component.d.ts +14 -0
- package/lib/ui-grid-filter-item/ui-grid-filter-item.component.d.ts +19 -0
- package/lib/ui-grid-filter-settings/ui-grid-filter-settings.component.d.ts +24 -0
- package/lib/ui-grid-sort-item/ui-grid-sort-item.component.d.ts +25 -0
- package/lib/ui-grid-sort-setting/ui-grid-sort-setting.component.d.ts +28 -0
- package/lib/ui-info-bar-panel/ui-info-bar-panel.component.d.ts +5 -0
- package/lib/ui-label/ui-label.component.d.ts +6 -0
- package/lib/ui-linear-list-container-with-button/ui-linear-list-container-with-button.component.d.ts +62 -0
- package/lib/ui-list-view/ui-list-view.component.d.ts +15 -0
- package/lib/ui-matrix-view/ui-matrix-view.component.d.ts +45 -0
- package/lib/ui-mo-info-combo-viewer/ui-mo-info-combo-viewer.component.d.ts +7 -0
- package/lib/ui-mo-info-general-object-ui/ui-mo-info-general-object-ui.component.d.ts +6 -0
- package/lib/ui-mo-info-sub-form-ui/ui-mo-info-sub-form-ui.component.d.ts +13 -0
- package/lib/ui-mo-info-ulv-combo/ui-mo-info-ulv-combo.component.d.ts +78 -0
- package/lib/ui-monaco-editor/ui-monaco-editor.component.d.ts +7 -0
- package/lib/ui-multi-select-combo/ui-multi-select-combo.component.d.ts +21 -0
- package/lib/ui-num-decimal-ui/ui-num-decimal-ui.component.d.ts +11 -0
- package/lib/ui-num-int-ui/ui-num-int-ui.component.d.ts +10 -0
- package/lib/ui-pdf-viewer/ui-pdf-viewer.component.d.ts +63 -0
- package/lib/ui-picture-file/ui-picture-file.component.d.ts +27 -0
- package/lib/ui-pictures-info/ui-pictures-info.component.d.ts +68 -0
- package/lib/ui-radio-group/ui-radio-group.component.d.ts +9 -0
- package/lib/ui-read-only-field/ui-read-only-field.component.d.ts +11 -0
- package/lib/ui-report-container/ui-report-container.component.d.ts +17 -0
- package/lib/ui-search-command-info-ui/ui-search-command-info-ui.component.d.ts +9 -0
- package/lib/ui-simple-combo/ui-simple-combo.component.d.ts +13 -0
- package/lib/ui-single-picture/ui-single-picture.component.d.ts +13 -0
- package/lib/ui-switch-button/ui-switch-button.component.d.ts +11 -0
- package/lib/ui-table-view/ui-table-view.component.d.ts +29 -0
- package/lib/ui-text-area/ui-text-area.component.d.ts +15 -0
- package/lib/ui-text-field/ui-text-field.component.d.ts +14 -0
- package/lib/ui-text-field-auto-complete/ui-text-field-auto-complete.component.d.ts +13 -0
- package/lib/ui-time-span/ui-time-span.component.d.ts +10 -0
- package/lib/ui-tinymce/ui-tinymce.component.d.ts +17 -0
- package/lib/ui-tree/ui-tree.component.d.ts +32 -0
- package/lib/ui-tree-view/ui-tree-view.component.d.ts +41 -0
- package/lib/ui-ulv-form-multi-select-ui/ui-ulv-form-multi-select-ui.component.d.ts +9 -0
- package/lib/ui-ulv-main-ui/ui-ulv-main-ui.component.d.ts +67 -0
- package/lib/ui-workflow-panel-ui/ui-workflow-panel-ui.component.d.ts +16 -0
- package/lib/ul-loading-mask-ui/ul-loading-mask-ui.component.d.ts +20 -0
- package/lib/ul-msg-box-adapter/ul-msg-box-adapter.component.d.ts +48 -0
- package/lib/ul-notify-popup/ul-notify-popup.component.d.ts +41 -0
- package/lib/ul-toast-adapter/ul-toast-adapter.component.d.ts +13 -0
- package/lib/ulv-column-settings/ulv-column-settings.component.d.ts +19 -0
- package/lib/ulv-context-menu/ulv-context-menu.component.d.ts +24 -0
- package/lib/ulv-filter-settings/ulv-filter-settings.component.d.ts +19 -0
- package/lib/ulv-form-multi-select/ulv-form-multi-select.component.d.ts +26 -0
- package/lib/ulv-groupby-settings/ulv-groupby-settings.component.d.ts +16 -0
- package/lib/ulv-paging/ulv-paging.component.d.ts +27 -0
- package/lib/ulv-selection/ulv-selection.component.d.ts +43 -0
- package/lib/ulv-settings/ulv-settings.component.d.ts +43 -0
- package/lib/ulv-sort-settings/ulv-sort-settings.component.d.ts +16 -0
- package/lib/ulv-toolbar/ulv-toolbar.component.d.ts +47 -0
- package/lib/upload-file-status.pipe.d.ts +9 -0
- package/lib/wizard-layout.directive.d.ts +39 -0
- package/package.json +31 -0
- package/public-api.d.ts +166 -0
package/README.md
ADDED
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
# BarsaSapUi
|
|
2
|
+
|
|
3
|
+
This library was generated with [Angular CLI](https://github.com/angular/angular-cli) version 10.0.6.
|
|
4
|
+
|
|
5
|
+
## Code scaffolding
|
|
6
|
+
|
|
7
|
+
Run `ng generate component component-name --project BarsaSapUi` to generate a new component. You can also use `ng generate directive|pipe|service|class|guard|interface|enum|module --project BarsaSapUi`.
|
|
8
|
+
|
|
9
|
+
> Note: Don't forget to add `--project BarsaSapUi` or else it will be added to the default project in your `angular.json` file.
|
|
10
|
+
|
|
11
|
+
## Build
|
|
12
|
+
|
|
13
|
+
Run `ng build BarsaSapUi` to build the project. The build artifacts will be stored in the `dist/` directory.
|
|
14
|
+
|
|
15
|
+
## Publishing
|
|
16
|
+
|
|
17
|
+
After building your library with `ng build BarsaSapUi`, go to the dist folder `cd dist/barsa-sap-ui` and run `npm publish`.
|
|
18
|
+
|
|
19
|
+
## Running unit tests
|
|
20
|
+
|
|
21
|
+
Run `ng test BarsaSapUi` to execute the unit tests via [Karma](https://karma-runner.github.io).
|
|
22
|
+
|
|
23
|
+
## Further help
|
|
24
|
+
|
|
25
|
+
To get more help on the Angular CLI use `ng help` or go check out the [Angular CLI README](https://github.com/angular/angular-cli/blob/master/README.md).
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Generated bundle index. Do not edit.
|
|
3
|
+
*/
|
|
4
|
+
export * from './public-api';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFyc2Etc2FwLXVpLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vcHJvamVjdHMvYmFyc2Etc2FwLXVpL3NyYy9iYXJzYS1zYXAtdWkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWMtYXBpJztcbiJdfQ==
|
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
import { Directive, HostBinding, Input } from '@angular/core';
|
|
2
|
+
import { BaseDirective } from 'barsa-novin-ray-core';
|
|
3
|
+
import { takeUntil } from 'rxjs/operators';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "barsa-novin-ray-core";
|
|
6
|
+
export class ApplyConditionalFormatsDirective extends BaseDirective {
|
|
7
|
+
constructor(el, renderer2, ulvMainService) {
|
|
8
|
+
super();
|
|
9
|
+
this.el = el;
|
|
10
|
+
this.renderer2 = renderer2;
|
|
11
|
+
this.ulvMainService = ulvMainService;
|
|
12
|
+
this.style = '';
|
|
13
|
+
}
|
|
14
|
+
ngOnInit() {
|
|
15
|
+
super.ngOnInit();
|
|
16
|
+
this._apply();
|
|
17
|
+
this.ulvMainService.moDataList$.pipe(takeUntil(this._onDestroy$)).subscribe(() => {
|
|
18
|
+
this._apply();
|
|
19
|
+
});
|
|
20
|
+
}
|
|
21
|
+
_apply() {
|
|
22
|
+
const mo = this.mo;
|
|
23
|
+
const styles = this.applyConditionalFormats;
|
|
24
|
+
const htmlElement = this.hostEl instanceof HTMLElement
|
|
25
|
+
? this.hostEl
|
|
26
|
+
: typeof this.hostEl.elementRef === 'function'
|
|
27
|
+
? this.hostEl.elementRef().nativeElement
|
|
28
|
+
: this.hostEl.elementRef.nativeElement;
|
|
29
|
+
styles?.forEach((style) => {
|
|
30
|
+
if (style.IsCommand && this.dbName === style.Alias) {
|
|
31
|
+
if (htmlElement.classList.contains(style.CssClass)) {
|
|
32
|
+
this.renderer2.removeClass(htmlElement, style.CssClass);
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
});
|
|
36
|
+
if (!mo) {
|
|
37
|
+
return;
|
|
38
|
+
}
|
|
39
|
+
mo.$StyleIndex?.forEach((val) => {
|
|
40
|
+
styles.forEach((style, index) => {
|
|
41
|
+
if (index === val && style.IsCommand) {
|
|
42
|
+
if (this.dbName === style.Alias) {
|
|
43
|
+
this.renderer2.addClass(this.el.nativeElement, style.CssClass);
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
else if (val === index && this.dbName) {
|
|
47
|
+
if (style.Column === this.dbName) {
|
|
48
|
+
this.renderer2.setAttribute(htmlElement, 'style', style.Style);
|
|
49
|
+
if (style.CssClass) {
|
|
50
|
+
this.renderer2.addClass(htmlElement, style.CssClass);
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
else if (val === index && !style.Column) {
|
|
55
|
+
this.renderer2.setAttribute(htmlElement, 'style', style.Style);
|
|
56
|
+
if (style.CssClass) {
|
|
57
|
+
this.renderer2.addClass(htmlElement, style.CssClass);
|
|
58
|
+
}
|
|
59
|
+
// htmlElement.style.cssText = style.Style;
|
|
60
|
+
}
|
|
61
|
+
});
|
|
62
|
+
});
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
ApplyConditionalFormatsDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: ApplyConditionalFormatsDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i1.UlvMainService }], target: i0.ɵɵFactoryTarget.Directive });
|
|
66
|
+
ApplyConditionalFormatsDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.7", type: ApplyConditionalFormatsDirective, selector: "[applyConditionalFormats]", inputs: { applyConditionalFormats: "applyConditionalFormats", mo: "mo", hostEl: "hostEl", dbName: "dbName" }, host: { properties: { "style": "this.style" } }, usesInheritance: true, ngImport: i0 });
|
|
67
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: ApplyConditionalFormatsDirective, decorators: [{
|
|
68
|
+
type: Directive,
|
|
69
|
+
args: [{
|
|
70
|
+
selector: '[applyConditionalFormats]'
|
|
71
|
+
}]
|
|
72
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i1.UlvMainService }]; }, propDecorators: { applyConditionalFormats: [{
|
|
73
|
+
type: Input
|
|
74
|
+
}], mo: [{
|
|
75
|
+
type: Input
|
|
76
|
+
}], hostEl: [{
|
|
77
|
+
type: Input
|
|
78
|
+
}], dbName: [{
|
|
79
|
+
type: Input
|
|
80
|
+
}], style: [{
|
|
81
|
+
type: HostBinding,
|
|
82
|
+
args: ['style']
|
|
83
|
+
}] } });
|
|
84
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBwbHktY29uZGl0aW9uYWwtZm9ybW1hdGluZ3MuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2Etc2FwLXVpL3NyYy9saWIvYXBwbHktY29uZGl0aW9uYWwtZm9ybW1hdGluZ3MuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQWMsV0FBVyxFQUFFLEtBQUssRUFBcUIsTUFBTSxlQUFlLENBQUM7QUFDN0YsT0FBTyxFQUFFLGFBQWEsRUFBdUMsTUFBTSxzQkFBc0IsQ0FBQztBQUMxRixPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7OztBQUszQyxNQUFNLE9BQU8sZ0NBQWlDLFNBQVEsYUFBYTtJQWEvRCxZQUFvQixFQUFjLEVBQVUsU0FBb0IsRUFBVSxjQUE4QjtRQUNwRyxLQUFLLEVBQUUsQ0FBQztRQURRLE9BQUUsR0FBRixFQUFFLENBQVk7UUFBVSxjQUFTLEdBQVQsU0FBUyxDQUFXO1FBQVUsbUJBQWMsR0FBZCxjQUFjLENBQWdCO1FBRGxGLFVBQUssR0FBRyxFQUFFLENBQUM7SUFHakMsQ0FBQztJQUNELFFBQVE7UUFDSixLQUFLLENBQUMsUUFBUSxFQUFFLENBQUM7UUFDakIsSUFBSSxDQUFDLE1BQU0sRUFBRSxDQUFDO1FBQ2QsSUFBSSxDQUFDLGNBQWMsQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFO1lBQzdFLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQztRQUNsQixDQUFDLENBQUMsQ0FBQztJQUNQLENBQUM7SUFFTyxNQUFNO1FBQ1YsTUFBTSxFQUFFLEdBQUcsSUFBSSxDQUFDLEVBQUUsQ0FBQztRQUNuQixNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsdUJBQXVCLENBQUM7UUFDNUMsTUFBTSxXQUFXLEdBQ2IsSUFBSSxDQUFDLE1BQU0sWUFBWSxXQUFXO1lBQzlCLENBQUMsQ0FBQyxJQUFJLENBQUMsTUFBTTtZQUNiLENBQUMsQ0FBQyxPQUFPLElBQUksQ0FBQyxNQUFNLENBQUMsVUFBVSxLQUFLLFVBQVU7Z0JBQzlDLENBQUMsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLFVBQVUsRUFBRSxDQUFDLGFBQWE7Z0JBQ3hDLENBQUMsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLFVBQVUsQ0FBQyxhQUFhLENBQUM7UUFFL0MsTUFBTSxFQUFFLE9BQU8sQ0FBQyxDQUFDLEtBQUssRUFBRSxFQUFFO1lBQ3RCLElBQUksS0FBSyxDQUFDLFNBQVMsSUFBSSxJQUFJLENBQUMsTUFBTSxLQUFLLEtBQUssQ0FBQyxLQUFLLEVBQUU7Z0JBQ2hELElBQUksV0FBVyxDQUFDLFNBQVMsQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxFQUFFO29CQUNoRCxJQUFJLENBQUMsU0FBUyxDQUFDLFdBQVcsQ0FBQyxXQUFXLEVBQUUsS0FBSyxDQUFDLFFBQVEsQ0FBQyxDQUFDO2lCQUMzRDthQUNKO1FBQ0wsQ0FBQyxDQUFDLENBQUM7UUFDSCxJQUFJLENBQUMsRUFBRSxFQUFFO1lBQ0wsT0FBTztTQUNWO1FBQ0QsRUFBRSxDQUFDLFdBQVcsRUFBRSxPQUFPLENBQUMsQ0FBQyxHQUFHLEVBQUUsRUFBRTtZQUM1QixNQUFNLENBQUMsT0FBTyxDQUFDLENBQUMsS0FBSyxFQUFFLEtBQUssRUFBRSxFQUFFO2dCQUM1QixJQUFJLEtBQUssS0FBSyxHQUFHLElBQUksS0FBSyxDQUFDLFNBQVMsRUFBRTtvQkFDbEMsSUFBSSxJQUFJLENBQUMsTUFBTSxLQUFLLEtBQUssQ0FBQyxLQUFLLEVBQUU7d0JBQzdCLElBQUksQ0FBQyxTQUFTLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsYUFBYSxFQUFFLEtBQUssQ0FBQyxRQUFRLENBQUMsQ0FBQztxQkFDbEU7aUJBQ0o7cUJBQU0sSUFBSSxHQUFHLEtBQUssS0FBSyxJQUFJLElBQUksQ0FBQyxNQUFNLEVBQUU7b0JBQ3JDLElBQUksS0FBSyxDQUFDLE1BQU0sS0FBSyxJQUFJLENBQUMsTUFBTSxFQUFFO3dCQUM5QixJQUFJLENBQUMsU0FBUyxDQUFDLFlBQVksQ0FBQyxXQUFXLEVBQUUsT0FBTyxFQUFFLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQzt3QkFDL0QsSUFBSSxLQUFLLENBQUMsUUFBUSxFQUFFOzRCQUNoQixJQUFJLENBQUMsU0FBUyxDQUFDLFFBQVEsQ0FBQyxXQUFXLEVBQUUsS0FBSyxDQUFDLFFBQVEsQ0FBQyxDQUFDO3lCQUN4RDtxQkFDSjtpQkFDSjtxQkFBTSxJQUFJLEdBQUcsS0FBSyxLQUFLLElBQUksQ0FBQyxLQUFLLENBQUMsTUFBTSxFQUFFO29CQUN2QyxJQUFJLENBQUMsU0FBUyxDQUFDLFlBQVksQ0FBQyxXQUFXLEVBQUUsT0FBTyxFQUFFLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQztvQkFDL0QsSUFBSSxLQUFLLENBQUMsUUFBUSxFQUFFO3dCQUNoQixJQUFJLENBQUMsU0FBUyxDQUFDLFFBQVEsQ0FBQyxXQUFXLEVBQUUsS0FBSyxDQUFDLFFBQVEsQ0FBQyxDQUFDO3FCQUN4RDtvQkFDRCwyQ0FBMkM7aUJBQzlDO1lBQ0wsQ0FBQyxDQUFDLENBQUM7UUFDUCxDQUFDLENBQUMsQ0FBQztJQUNQLENBQUM7OzZIQWxFUSxnQ0FBZ0M7aUhBQWhDLGdDQUFnQzsyRkFBaEMsZ0NBQWdDO2tCQUg1QyxTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSwyQkFBMkI7aUJBQ3hDO3NKQUVZLHVCQUF1QjtzQkFBL0IsS0FBSztnQkFRRyxFQUFFO3NCQUFWLEtBQUs7Z0JBQ0csTUFBTTtzQkFBZCxLQUFLO2dCQUNHLE1BQU07c0JBQWQsS0FBSztnQkFDZ0IsS0FBSztzQkFBMUIsV0FBVzt1QkFBQyxPQUFPIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBFbGVtZW50UmVmLCBIb3N0QmluZGluZywgSW5wdXQsIE9uSW5pdCwgUmVuZGVyZXIyIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBCYXNlRGlyZWN0aXZlLCBNZXRhb2JqZWN0RGF0YU1vZGVsLCBVbHZNYWluU2VydmljZSB9IGZyb20gJ2JhcnNhLW5vdmluLXJheS1jb3JlJztcbmltcG9ydCB7IHRha2VVbnRpbCB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcblxuQERpcmVjdGl2ZSh7XG4gICAgc2VsZWN0b3I6ICdbYXBwbHlDb25kaXRpb25hbEZvcm1hdHNdJ1xufSlcbmV4cG9ydCBjbGFzcyBBcHBseUNvbmRpdGlvbmFsRm9ybWF0c0RpcmVjdGl2ZSBleHRlbmRzIEJhc2VEaXJlY3RpdmUgaW1wbGVtZW50cyBPbkluaXQge1xuICAgIEBJbnB1dCgpIGFwcGx5Q29uZGl0aW9uYWxGb3JtYXRzOiB7XG4gICAgICAgIENsczogc3RyaW5nO1xuICAgICAgICBDb2x1bW4/OiBzdHJpbmc7XG4gICAgICAgIFN0eWxlOiBzdHJpbmc7XG4gICAgICAgIElzQ29tbWFuZDogYm9vbGVhbjtcbiAgICAgICAgQWxpYXM6IHN0cmluZztcbiAgICAgICAgQ3NzQ2xhc3M6IHN0cmluZztcbiAgICB9W107XG4gICAgQElucHV0KCkgbW86IE1ldGFvYmplY3REYXRhTW9kZWw7XG4gICAgQElucHV0KCkgaG9zdEVsOiBhbnk7XG4gICAgQElucHV0KCkgZGJOYW1lOiBzdHJpbmc7XG4gICAgQEhvc3RCaW5kaW5nKCdzdHlsZScpIHN0eWxlID0gJyc7XG4gICAgY29uc3RydWN0b3IocHJpdmF0ZSBlbDogRWxlbWVudFJlZiwgcHJpdmF0ZSByZW5kZXJlcjI6IFJlbmRlcmVyMiwgcHJpdmF0ZSB1bHZNYWluU2VydmljZTogVWx2TWFpblNlcnZpY2UpIHtcbiAgICAgICAgc3VwZXIoKTtcbiAgICB9XG4gICAgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgICAgIHN1cGVyLm5nT25Jbml0KCk7XG4gICAgICAgIHRoaXMuX2FwcGx5KCk7XG4gICAgICAgIHRoaXMudWx2TWFpblNlcnZpY2UubW9EYXRhTGlzdCQucGlwZSh0YWtlVW50aWwodGhpcy5fb25EZXN0cm95JCkpLnN1YnNjcmliZSgoKSA9PiB7XG4gICAgICAgICAgICB0aGlzLl9hcHBseSgpO1xuICAgICAgICB9KTtcbiAgICB9XG5cbiAgICBwcml2YXRlIF9hcHBseSgpOiB2b2lkIHtcbiAgICAgICAgY29uc3QgbW8gPSB0aGlzLm1vO1xuICAgICAgICBjb25zdCBzdHlsZXMgPSB0aGlzLmFwcGx5Q29uZGl0aW9uYWxGb3JtYXRzO1xuICAgICAgICBjb25zdCBodG1sRWxlbWVudDogSFRNTEVsZW1lbnQgPVxuICAgICAgICAgICAgdGhpcy5ob3N0RWwgaW5zdGFuY2VvZiBIVE1MRWxlbWVudFxuICAgICAgICAgICAgICAgID8gdGhpcy5ob3N0RWxcbiAgICAgICAgICAgICAgICA6IHR5cGVvZiB0aGlzLmhvc3RFbC5lbGVtZW50UmVmID09PSAnZnVuY3Rpb24nXG4gICAgICAgICAgICAgICAgPyB0aGlzLmhvc3RFbC5lbGVtZW50UmVmKCkubmF0aXZlRWxlbWVudFxuICAgICAgICAgICAgICAgIDogdGhpcy5ob3N0RWwuZWxlbWVudFJlZi5uYXRpdmVFbGVtZW50O1xuXG4gICAgICAgIHN0eWxlcz8uZm9yRWFjaCgoc3R5bGUpID0+IHtcbiAgICAgICAgICAgIGlmIChzdHlsZS5Jc0NvbW1hbmQgJiYgdGhpcy5kYk5hbWUgPT09IHN0eWxlLkFsaWFzKSB7XG4gICAgICAgICAgICAgICAgaWYgKGh0bWxFbGVtZW50LmNsYXNzTGlzdC5jb250YWlucyhzdHlsZS5Dc3NDbGFzcykpIHtcbiAgICAgICAgICAgICAgICAgICAgdGhpcy5yZW5kZXJlcjIucmVtb3ZlQ2xhc3MoaHRtbEVsZW1lbnQsIHN0eWxlLkNzc0NsYXNzKTtcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9XG4gICAgICAgIH0pO1xuICAgICAgICBpZiAoIW1vKSB7XG4gICAgICAgICAgICByZXR1cm47XG4gICAgICAgIH1cbiAgICAgICAgbW8uJFN0eWxlSW5kZXg/LmZvckVhY2goKHZhbCkgPT4ge1xuICAgICAgICAgICAgc3R5bGVzLmZvckVhY2goKHN0eWxlLCBpbmRleCkgPT4ge1xuICAgICAgICAgICAgICAgIGlmIChpbmRleCA9PT0gdmFsICYmIHN0eWxlLklzQ29tbWFuZCkge1xuICAgICAgICAgICAgICAgICAgICBpZiAodGhpcy5kYk5hbWUgPT09IHN0eWxlLkFsaWFzKSB7XG4gICAgICAgICAgICAgICAgICAgICAgICB0aGlzLnJlbmRlcmVyMi5hZGRDbGFzcyh0aGlzLmVsLm5hdGl2ZUVsZW1lbnQsIHN0eWxlLkNzc0NsYXNzKTtcbiAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgIH0gZWxzZSBpZiAodmFsID09PSBpbmRleCAmJiB0aGlzLmRiTmFtZSkge1xuICAgICAgICAgICAgICAgICAgICBpZiAoc3R5bGUuQ29sdW1uID09PSB0aGlzLmRiTmFtZSkge1xuICAgICAgICAgICAgICAgICAgICAgICAgdGhpcy5yZW5kZXJlcjIuc2V0QXR0cmlidXRlKGh0bWxFbGVtZW50LCAnc3R5bGUnLCBzdHlsZS5TdHlsZSk7XG4gICAgICAgICAgICAgICAgICAgICAgICBpZiAoc3R5bGUuQ3NzQ2xhc3MpIHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICB0aGlzLnJlbmRlcmVyMi5hZGRDbGFzcyhodG1sRWxlbWVudCwgc3R5bGUuQ3NzQ2xhc3MpO1xuICAgICAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgfSBlbHNlIGlmICh2YWwgPT09IGluZGV4ICYmICFzdHlsZS5Db2x1bW4pIHtcbiAgICAgICAgICAgICAgICAgICAgdGhpcy5yZW5kZXJlcjIuc2V0QXR0cmlidXRlKGh0bWxFbGVtZW50LCAnc3R5bGUnLCBzdHlsZS5TdHlsZSk7XG4gICAgICAgICAgICAgICAgICAgIGlmIChzdHlsZS5Dc3NDbGFzcykge1xuICAgICAgICAgICAgICAgICAgICAgICAgdGhpcy5yZW5kZXJlcjIuYWRkQ2xhc3MoaHRtbEVsZW1lbnQsIHN0eWxlLkNzc0NsYXNzKTtcbiAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgICAgICAvLyBodG1sRWxlbWVudC5zdHlsZS5jc3NUZXh0ID0gc3R5bGUuU3R5bGU7XG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfSk7XG4gICAgICAgIH0pO1xuICAgIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,109 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, HostListener, Input, ViewChild } from '@angular/core';
|
|
2
|
+
import { BaseComponent, BarsaApi } from 'dist/barsa-novin-ray-core';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@angular/forms";
|
|
5
|
+
export class BarsaAspViewerComponent extends BaseComponent {
|
|
6
|
+
constructor(el, renderer) {
|
|
7
|
+
super();
|
|
8
|
+
this.el = el;
|
|
9
|
+
this.renderer = renderer;
|
|
10
|
+
}
|
|
11
|
+
handleKeyDown(event) {
|
|
12
|
+
this.ctrlIsPressed = event.ctrlKey;
|
|
13
|
+
}
|
|
14
|
+
ngOnInit() {
|
|
15
|
+
super.ngOnInit();
|
|
16
|
+
this.context.on({
|
|
17
|
+
Reload: this._reload.bind(this)
|
|
18
|
+
});
|
|
19
|
+
this._frameId = this.context._frameId;
|
|
20
|
+
}
|
|
21
|
+
ngAfterViewInit() {
|
|
22
|
+
super.ngAfterViewInit();
|
|
23
|
+
this._reload();
|
|
24
|
+
this._loadIFrame();
|
|
25
|
+
}
|
|
26
|
+
_reload() {
|
|
27
|
+
const basket = {};
|
|
28
|
+
this.context.fireEvent('RequestForParams', this, basket);
|
|
29
|
+
if (!basket.UlvParams) {
|
|
30
|
+
return;
|
|
31
|
+
}
|
|
32
|
+
basket.UlvParams.Height = this.el.nativeElement.offsetHeight;
|
|
33
|
+
basket.UlvParams.Width = this.el.nativeElement.offsetWidth;
|
|
34
|
+
this._submitForm(basket.UlvParams);
|
|
35
|
+
}
|
|
36
|
+
_loadIFrame() {
|
|
37
|
+
const iframEl = this.iframe.nativeElement;
|
|
38
|
+
this.renderer.setStyle(iframEl, 'min-height', this.parentHeight + 'px');
|
|
39
|
+
iframEl.addEventListener('load', this._onLoadIfram.bind(this));
|
|
40
|
+
}
|
|
41
|
+
_unLoadIfram() {
|
|
42
|
+
this.unload = true;
|
|
43
|
+
}
|
|
44
|
+
_onLoadIfram() {
|
|
45
|
+
const iframEl = this.iframe.nativeElement;
|
|
46
|
+
if (this.unload) {
|
|
47
|
+
iframEl.removeEventListener('load', this._onLoadIfram);
|
|
48
|
+
iframEl.removeEventListener('unload', this._unLoadIfram);
|
|
49
|
+
this.unload = false;
|
|
50
|
+
this._reload();
|
|
51
|
+
return;
|
|
52
|
+
}
|
|
53
|
+
if (iframEl.contentWindow) {
|
|
54
|
+
iframEl.contentWindow.addEventListener('unload', this._unLoadIfram.bind(this));
|
|
55
|
+
}
|
|
56
|
+
const head = iframEl.contentDocument?.getElementsByTagName('head')[0];
|
|
57
|
+
const link1 = this.renderer.createElement('link');
|
|
58
|
+
link1.setAttribute('rel', 'stylesheet');
|
|
59
|
+
link1.setAttribute('href', '/assets/Resources/fonts/defaultFontFaces.css');
|
|
60
|
+
link1.setAttribute('type', 'text/css');
|
|
61
|
+
head?.appendChild(link1);
|
|
62
|
+
const link2 = this.renderer.createElement('link');
|
|
63
|
+
link2.setAttribute('rel', 'stylesheet');
|
|
64
|
+
link2.setAttribute('href', '/Customization/Usercss.css');
|
|
65
|
+
link2.setAttribute('type', 'text/css');
|
|
66
|
+
head?.appendChild(link2);
|
|
67
|
+
}
|
|
68
|
+
_submitForm(params) {
|
|
69
|
+
const form = this.form.nativeElement;
|
|
70
|
+
const aspUrl = this.context._aspUrl;
|
|
71
|
+
const frameId = this.context._frameId;
|
|
72
|
+
form.action =
|
|
73
|
+
aspUrl +
|
|
74
|
+
'?ReportId=' +
|
|
75
|
+
params.FolderId +
|
|
76
|
+
'&FrameId=' +
|
|
77
|
+
frameId +
|
|
78
|
+
'&Language=' +
|
|
79
|
+
BarsaApi.BBB.CurrentCulture +
|
|
80
|
+
'&CtrlIsPressed=' +
|
|
81
|
+
this.ctrlIsPressed;
|
|
82
|
+
const value = BarsaApi.Ext.util.JSON.encode(params);
|
|
83
|
+
this.hidden.nativeElement.value = escape(value);
|
|
84
|
+
form.submit();
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
BarsaAspViewerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: BarsaAspViewerComponent, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component });
|
|
88
|
+
BarsaAspViewerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: BarsaAspViewerComponent, selector: "bsu-barsa-asp-viewer", inputs: { context: "context", parentHeight: "parentHeight" }, host: { listeners: { "window:keypress": "handleKeyDown(event)" } }, viewQueries: [{ propertyName: "form", first: true, predicate: ["form"], descendants: true }, { propertyName: "iframe", first: true, predicate: ["iframe"], descendants: true }, { propertyName: "hidden", first: true, predicate: ["hidden"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<form #form method=\"post\" target=\"ppppp\" [name]=\"'frm_' + _frameId\" [id]=\"'frm_' + _frameId\">\r\n <input #hidden [name]=\"'hidden_' + _frameId\" [id]=\"'hidden_' + _frameId\" type=\"hidden\" />\r\n</form>\r\n<iframe #iframe name=\"ppppp\" id=\"ppppp\" class=\"iframe\" src=\"about:blank\"></iframe>\r\n", styles: [":host{display:block;width:100%;height:100%}.iframe{border-style:none;height:98%;width:98%}\n"], dependencies: [{ kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
89
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: BarsaAspViewerComponent, decorators: [{
|
|
90
|
+
type: Component,
|
|
91
|
+
args: [{ selector: 'bsu-barsa-asp-viewer', changeDetection: ChangeDetectionStrategy.OnPush, template: "<form #form method=\"post\" target=\"ppppp\" [name]=\"'frm_' + _frameId\" [id]=\"'frm_' + _frameId\">\r\n <input #hidden [name]=\"'hidden_' + _frameId\" [id]=\"'hidden_' + _frameId\" type=\"hidden\" />\r\n</form>\r\n<iframe #iframe name=\"ppppp\" id=\"ppppp\" class=\"iframe\" src=\"about:blank\"></iframe>\r\n", styles: [":host{display:block;width:100%;height:100%}.iframe{border-style:none;height:98%;width:98%}\n"] }]
|
|
92
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }]; }, propDecorators: { context: [{
|
|
93
|
+
type: Input
|
|
94
|
+
}], parentHeight: [{
|
|
95
|
+
type: Input
|
|
96
|
+
}], form: [{
|
|
97
|
+
type: ViewChild,
|
|
98
|
+
args: ['form']
|
|
99
|
+
}], iframe: [{
|
|
100
|
+
type: ViewChild,
|
|
101
|
+
args: ['iframe']
|
|
102
|
+
}], hidden: [{
|
|
103
|
+
type: ViewChild,
|
|
104
|
+
args: ['hidden']
|
|
105
|
+
}], handleKeyDown: [{
|
|
106
|
+
type: HostListener,
|
|
107
|
+
args: ['window:keypress', ['event']]
|
|
108
|
+
}] } });
|
|
109
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"barsa-asp-viewer.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-sap-ui/src/lib/barsa-asp-viewer/barsa-asp-viewer.component.ts","../../../../../projects/barsa-sap-ui/src/lib/barsa-asp-viewer/barsa-asp-viewer.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    Component,\n    ElementRef,\n    HostListener,\n    Input,\n    OnInit,\n    Renderer2,\n    ViewChild\n} from '@angular/core';\n\nimport { BaseComponent, BarsaApi } from 'dist/barsa-novin-ray-core';\n@Component({\n    selector: 'bsu-barsa-asp-viewer',\n    templateUrl: './barsa-asp-viewer.component.html',\n    styleUrls: ['./barsa-asp-viewer.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class BarsaAspViewerComponent extends BaseComponent implements OnInit, AfterViewInit {\n    @Input() context: any;\n    @Input() parentHeight: number;\n    @ViewChild('form') form: ElementRef<HTMLFormElement>;\n    @ViewChild('iframe') iframe: ElementRef<HTMLIFrameElement>;\n    @ViewChild('hidden') hidden: ElementRef<HTMLInputElement>;\n\n    ctrlIsPressed: boolean;\n    _frameId;\n    unload: boolean;\n\n    constructor(private el: ElementRef, private renderer: Renderer2) {\n        super();\n    }\n    @HostListener('window:keypress', ['event'])\n    handleKeyDown(event: KeyboardEvent): void {\n        this.ctrlIsPressed = event.ctrlKey;\n    }\n    ngOnInit(): void {\n        super.ngOnInit();\n        this.context.on({\n            Reload: this._reload.bind(this)\n        });\n        this._frameId = this.context._frameId;\n    }\n    ngAfterViewInit(): void {\n        super.ngAfterViewInit();\n        this._reload();\n        this._loadIFrame();\n    }\n\n    private _reload(): void {\n        const basket: any = {};\n        this.context.fireEvent('RequestForParams', this, basket);\n        if (!basket.UlvParams) {\n            return;\n        }\n        basket.UlvParams.Height = this.el.nativeElement.offsetHeight;\n        basket.UlvParams.Width = this.el.nativeElement.offsetWidth;\n        this._submitForm(basket.UlvParams);\n    }\n    private _loadIFrame(): void {\n        const iframEl: HTMLIFrameElement = this.iframe.nativeElement;\n        this.renderer.setStyle(iframEl, 'min-height', this.parentHeight + 'px');\n        iframEl.addEventListener('load', this._onLoadIfram.bind(this));\n    }\n    private _unLoadIfram(): void {\n        this.unload = true;\n    }\n\n    private _onLoadIfram(): void {\n        const iframEl: HTMLIFrameElement = this.iframe.nativeElement;\n        if (this.unload) {\n            iframEl.removeEventListener('load', this._onLoadIfram);\n            iframEl.removeEventListener('unload', this._unLoadIfram);\n            this.unload = false;\n            this._reload();\n            return;\n        }\n        if (iframEl.contentWindow) {\n            iframEl.contentWindow.addEventListener('unload', this._unLoadIfram.bind(this));\n        }\n        const head = iframEl.contentDocument?.getElementsByTagName('head')[0];\n        const link1: HTMLLinkElement = this.renderer.createElement('link');\n        link1.setAttribute('rel', 'stylesheet');\n        link1.setAttribute('href', '/assets/Resources/fonts/defaultFontFaces.css');\n        link1.setAttribute('type', 'text/css');\n        head?.appendChild(link1);\n\n        const link2: HTMLLinkElement = this.renderer.createElement('link');\n        link2.setAttribute('rel', 'stylesheet');\n        link2.setAttribute('href', '/Customization/Usercss.css');\n        link2.setAttribute('type', 'text/css');\n        head?.appendChild(link2);\n    }\n    private _submitForm(params): void {\n        const form = this.form.nativeElement;\n        const aspUrl = this.context._aspUrl;\n        const frameId = this.context._frameId;\n        form.action =\n            aspUrl +\n            '?ReportId=' +\n            params.FolderId +\n            '&FrameId=' +\n            frameId +\n            '&Language=' +\n            BarsaApi.BBB.CurrentCulture +\n            '&CtrlIsPressed=' +\n            this.ctrlIsPressed;\n        const value = BarsaApi.Ext.util.JSON.encode(params);\n        this.hidden.nativeElement.value = escape(value);\n        form.submit();\n    }\n}\n","<form #form method=\"post\" target=\"ppppp\" [name]=\"'frm_' + _frameId\" [id]=\"'frm_' + _frameId\">\r\n    <input #hidden [name]=\"'hidden_' + _frameId\" [id]=\"'hidden_' + _frameId\" type=\"hidden\" />\r\n</form>\r\n<iframe #iframe name=\"ppppp\" id=\"ppppp\" class=\"iframe\" src=\"about:blank\"></iframe>\r\n"]}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
|
|
2
|
+
import { BaseComponent } 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
|
+
export class BarsaBaseLayoutComponent extends BaseComponent {
|
|
7
|
+
/**
|
|
8
|
+
*
|
|
9
|
+
*/
|
|
10
|
+
constructor(viewRef) {
|
|
11
|
+
super();
|
|
12
|
+
this.viewRef = viewRef;
|
|
13
|
+
}
|
|
14
|
+
ngOnInit() {
|
|
15
|
+
super.ngOnInit();
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
BarsaBaseLayoutComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: BarsaBaseLayoutComponent, deps: [{ token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
19
|
+
BarsaBaseLayoutComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: BarsaBaseLayoutComponent, selector: "bsu-barsa-base-layout", inputs: { config: "config", maxLabelWidth: "maxLabelWidth", setFlex: "setFlex", hasHorizontalText: "hasHorizontalText", isSearchPanel: "isSearchPanel" }, usesInheritance: true, ngImport: i0, template: "<ng-container *ngFor=\"let item of config | filterToolbarControl\">\n <ng-container [ngSwitch]=\"item.xtype\">\n <ng-container *ngSwitchCase=\"'Ly.LayoutTabPanel'\">\n <ng-container\n *ngTemplateOutlet=\"\n dynamicLayout;\n context: { $implicit: item, selector: 'bsu-ly-tab-container', name: 'LyTabContainerComponent' }\n \"\n ></ng-container>\n <!-- <bsu-ly-tab-container [config]=\"item\"></bsu-ly-tab-container> -->\n </ng-container>\n <ng-container *ngSwitchCase=\"'Ly.LayoutPanel'\">\n <ng-container\n *ngTemplateOutlet=\"\n dynamicLayout;\n context: { $implicit: item, selector: 'bsu-ly-layout-panel', name: 'LyLayoutPanelComponent' }\n \"\n ></ng-container>\n <!-- <bsu-ly-layout-panel [config]=\"item\"></bsu-ly-layout-panel> -->\n </ng-container>\n <ng-container *ngSwitchCase=\"'Ly.LayoutContainer'\">\n <ng-container\n *ngTemplateOutlet=\"\n dynamicLayout;\n context: {\n $implicit: item,\n selector: 'bsu-ly-layout-container',\n name: 'LyLayoutContainerComponent'\n }\n \"\n ></ng-container>\n <!-- <bsu-ly-layout-container [config]=\"item\"></bsu-ly-layout-container> -->\n </ng-container>\n <ng-container *ngSwitchCase=\"'Ly.EmptySpace'\">\n <ng-container\n *ngTemplateOutlet=\"\n dynamicLayout;\n context: { $implicit: item, selector: 'bsu-ly-empty-space', name: 'LyEmptySpaceComponent' }\n \"\n ></ng-container>\n <!-- <bsu-ly-empty-space [config]=\"item\"></bsu-ly-empty-space> -->\n </ng-container>\n <ng-container *ngSwitchCase=\"'Ly.SimpleLabel'\">\n <ng-container\n *ngTemplateOutlet=\"\n dynamicLayout;\n context: { $implicit: item, selector: 'bsu-ly-simple-label', name: 'LySimpleLabelComponent' }\n \"\n ></ng-container>\n <!-- <bsu-ly-simple-label [config]=\"item\"></bsu-ly-simple-label> -->\n </ng-container>\n <ng-container *ngSwitchCase=\"'Ly.LayoutLine'\">\n <ng-container\n *ngTemplateOutlet=\"\n dynamicLayout;\n context: { $implicit: item, selector: 'bsu-ly-line', name: 'LyLineComponent' }\n \"\n ></ng-container>\n <!-- <bsu-ly-line [isVertical]=\"item.IsVertical\"></bsu-ly-line> -->\n </ng-container>\n <ng-container *ngSwitchCase=\"'Ly.LayoutJoin'\">\n <ng-container *ngIf=\"item.Type === 'HorizontalJoin'; else verticalJoin\">\n <ng-container\n *ngTemplateOutlet=\"\n dynamicLayout;\n context: {\n $implicit: item,\n selector: 'bsu-ly-horizontal-layout',\n name: 'LyHorizontalLayoutComponent',\n maxLabelWidth: this.maxLabelWidth\n }\n \"\n ></ng-container>\n <!-- <bsu-ly-horizontal-layout [config]=\"item\" [maxLabelWidth]=\"maxLabelWidth\"></bsu-ly-horizontal-layout> -->\n </ng-container>\n <ng-template #verticalJoin>\n <ng-container\n *ngTemplateOutlet=\"\n dynamicLayout;\n context: {\n $implicit: item,\n selector: 'bsu-ly-vertical-layout',\n name: 'LyVerticalLayoutComponent',\n maxLabelWidth: this.maxLabelWidth\n }\n \"\n ></ng-container>\n <!-- <bsu-ly-vertical-layout [config]=\"item\" [maxLabelWidth]=\"maxLabelWidth\"></bsu-ly-vertical-layout> -->\n </ng-template>\n </ng-container>\n <ng-container *ngSwitchCase=\"'Ly.LayoutControl'\">\n <ng-container\n *ngTemplateOutlet=\"\n dynamicLayout;\n context: {\n $implicit: item,\n selector: 'bsu-layout-control',\n name: 'LayoutControlComponent',\n maxLabelWidth: this.maxLabelWidth\n }\n \"\n ></ng-container>\n <!-- <bsu-layout-control [config]=\"item\" [maxLabelWidth]=\"maxLabelWidth\"></bsu-layout-control> -->\n </ng-container>\n </ng-container>\n</ng-container>\n<ng-template #dynamicLayout let-config let-selector=\"selector\" let-name=\"name\" let-maxLabelWidth=\"maxLabelWidth\">\n <bnrc-dynamic-layout\n [flex]=\"!setFlex ? null : isSearchPanel ? 'unset' : config.Bounds.width\"\n [config]=\"config\"\n [selector]=\"selector\"\n [name]=\"name\"\n [module]=\"'BarsaSapUi'\"\n [moduleFileName]=\"'BarsaSapUi'\"\n [maxLabelWidth]=\"maxLabelWidth\"\n [hasHorizontalText]=\"hasHorizontalText\"\n [isSearchPanel]=\"isSearchPanel\"\n [componentContainer]=\"viewRef\"\n >\n </bnrc-dynamic-layout>\n</ng-template>\n", styles: [""], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "component", type: i2.DynamicLayoutComponent, selector: "bnrc-dynamic-layout", inputs: ["selector", "module", "name", "parameters", "moduleFileName", "flex", "config", "maxLabelWidth", "hasHorizontalText", "isSearchPanel"] }, { kind: "pipe", type: i2.FilterToolbarControlPipe, name: "filterToolbarControl" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
20
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: BarsaBaseLayoutComponent, decorators: [{
|
|
21
|
+
type: Component,
|
|
22
|
+
args: [{ selector: 'bsu-barsa-base-layout', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngFor=\"let item of config | filterToolbarControl\">\n <ng-container [ngSwitch]=\"item.xtype\">\n <ng-container *ngSwitchCase=\"'Ly.LayoutTabPanel'\">\n <ng-container\n *ngTemplateOutlet=\"\n dynamicLayout;\n context: { $implicit: item, selector: 'bsu-ly-tab-container', name: 'LyTabContainerComponent' }\n \"\n ></ng-container>\n <!-- <bsu-ly-tab-container [config]=\"item\"></bsu-ly-tab-container> -->\n </ng-container>\n <ng-container *ngSwitchCase=\"'Ly.LayoutPanel'\">\n <ng-container\n *ngTemplateOutlet=\"\n dynamicLayout;\n context: { $implicit: item, selector: 'bsu-ly-layout-panel', name: 'LyLayoutPanelComponent' }\n \"\n ></ng-container>\n <!-- <bsu-ly-layout-panel [config]=\"item\"></bsu-ly-layout-panel> -->\n </ng-container>\n <ng-container *ngSwitchCase=\"'Ly.LayoutContainer'\">\n <ng-container\n *ngTemplateOutlet=\"\n dynamicLayout;\n context: {\n $implicit: item,\n selector: 'bsu-ly-layout-container',\n name: 'LyLayoutContainerComponent'\n }\n \"\n ></ng-container>\n <!-- <bsu-ly-layout-container [config]=\"item\"></bsu-ly-layout-container> -->\n </ng-container>\n <ng-container *ngSwitchCase=\"'Ly.EmptySpace'\">\n <ng-container\n *ngTemplateOutlet=\"\n dynamicLayout;\n context: { $implicit: item, selector: 'bsu-ly-empty-space', name: 'LyEmptySpaceComponent' }\n \"\n ></ng-container>\n <!-- <bsu-ly-empty-space [config]=\"item\"></bsu-ly-empty-space> -->\n </ng-container>\n <ng-container *ngSwitchCase=\"'Ly.SimpleLabel'\">\n <ng-container\n *ngTemplateOutlet=\"\n dynamicLayout;\n context: { $implicit: item, selector: 'bsu-ly-simple-label', name: 'LySimpleLabelComponent' }\n \"\n ></ng-container>\n <!-- <bsu-ly-simple-label [config]=\"item\"></bsu-ly-simple-label> -->\n </ng-container>\n <ng-container *ngSwitchCase=\"'Ly.LayoutLine'\">\n <ng-container\n *ngTemplateOutlet=\"\n dynamicLayout;\n context: { $implicit: item, selector: 'bsu-ly-line', name: 'LyLineComponent' }\n \"\n ></ng-container>\n <!-- <bsu-ly-line [isVertical]=\"item.IsVertical\"></bsu-ly-line> -->\n </ng-container>\n <ng-container *ngSwitchCase=\"'Ly.LayoutJoin'\">\n <ng-container *ngIf=\"item.Type === 'HorizontalJoin'; else verticalJoin\">\n <ng-container\n *ngTemplateOutlet=\"\n dynamicLayout;\n context: {\n $implicit: item,\n selector: 'bsu-ly-horizontal-layout',\n name: 'LyHorizontalLayoutComponent',\n maxLabelWidth: this.maxLabelWidth\n }\n \"\n ></ng-container>\n <!-- <bsu-ly-horizontal-layout [config]=\"item\" [maxLabelWidth]=\"maxLabelWidth\"></bsu-ly-horizontal-layout> -->\n </ng-container>\n <ng-template #verticalJoin>\n <ng-container\n *ngTemplateOutlet=\"\n dynamicLayout;\n context: {\n $implicit: item,\n selector: 'bsu-ly-vertical-layout',\n name: 'LyVerticalLayoutComponent',\n maxLabelWidth: this.maxLabelWidth\n }\n \"\n ></ng-container>\n <!-- <bsu-ly-vertical-layout [config]=\"item\" [maxLabelWidth]=\"maxLabelWidth\"></bsu-ly-vertical-layout> -->\n </ng-template>\n </ng-container>\n <ng-container *ngSwitchCase=\"'Ly.LayoutControl'\">\n <ng-container\n *ngTemplateOutlet=\"\n dynamicLayout;\n context: {\n $implicit: item,\n selector: 'bsu-layout-control',\n name: 'LayoutControlComponent',\n maxLabelWidth: this.maxLabelWidth\n }\n \"\n ></ng-container>\n <!-- <bsu-layout-control [config]=\"item\" [maxLabelWidth]=\"maxLabelWidth\"></bsu-layout-control> -->\n </ng-container>\n </ng-container>\n</ng-container>\n<ng-template #dynamicLayout let-config let-selector=\"selector\" let-name=\"name\" let-maxLabelWidth=\"maxLabelWidth\">\n <bnrc-dynamic-layout\n [flex]=\"!setFlex ? null : isSearchPanel ? 'unset' : config.Bounds.width\"\n [config]=\"config\"\n [selector]=\"selector\"\n [name]=\"name\"\n [module]=\"'BarsaSapUi'\"\n [moduleFileName]=\"'BarsaSapUi'\"\n [maxLabelWidth]=\"maxLabelWidth\"\n [hasHorizontalText]=\"hasHorizontalText\"\n [isSearchPanel]=\"isSearchPanel\"\n [componentContainer]=\"viewRef\"\n >\n </bnrc-dynamic-layout>\n</ng-template>\n" }]
|
|
23
|
+
}], ctorParameters: function () { return [{ type: i0.ViewContainerRef }]; }, propDecorators: { config: [{
|
|
24
|
+
type: Input
|
|
25
|
+
}], maxLabelWidth: [{
|
|
26
|
+
type: Input
|
|
27
|
+
}], setFlex: [{
|
|
28
|
+
type: Input
|
|
29
|
+
}], hasHorizontalText: [{
|
|
30
|
+
type: Input
|
|
31
|
+
}], isSearchPanel: [{
|
|
32
|
+
type: Input
|
|
33
|
+
}] } });
|
|
34
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"barsa-base-layout.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-sap-ui/src/lib/barsa-base-layout/barsa-base-layout.component.ts","../../../../../projects/barsa-sap-ui/src/lib/barsa-base-layout/barsa-base-layout.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,KAAK,EAAuC,MAAM,eAAe,CAAC;AAC/G,OAAO,EAAE,aAAa,EAAiB,MAAM,sBAAsB,CAAC;;;;AAQpE,MAAM,OAAO,wBAAyB,SAAQ,aAAa;IAOvD;;OAEG;IACH,YAAmB,OAAyB;QACxC,KAAK,EAAE,CAAC;QADO,YAAO,GAAP,OAAO,CAAkB;IAE5C,CAAC;IACD,QAAQ;QACJ,KAAK,CAAC,QAAQ,EAAE,CAAC;IACrB,CAAC;;qHAfQ,wBAAwB;yGAAxB,wBAAwB,8OCTrC,k9KAyHA;2FDhHa,wBAAwB;kBANpC,SAAS;+BACI,uBAAuB,mBAGhB,uBAAuB,CAAC,MAAM;uGAItC,MAAM;sBAAd,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,iBAAiB;sBAAzB,KAAK;gBACG,aAAa;sBAArB,KAAK","sourcesContent":["import { ChangeDetectionStrategy, Component, Input, OnInit, ViewChild, ViewContainerRef } from '@angular/core';\nimport { BaseComponent, LayoutSetting } from 'barsa-novin-ray-core';\n\n@Component({\n    selector: 'bsu-barsa-base-layout',\n    templateUrl: './barsa-base-layout.component.html',\n    styleUrls: ['./barsa-base-layout.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class BarsaBaseLayoutComponent extends BaseComponent {\n    // @ViewChild('viewRefTemplate', { read: ViewContainerRef, static: true }) viewRef: ViewContainerRef;\n    @Input() config: LayoutSetting;\n    @Input() maxLabelWidth: number;\n    @Input() setFlex: boolean;\n    @Input() hasHorizontalText: boolean;\n    @Input() isSearchPanel: boolean;\n    /**\n     *\n     */\n    constructor(public viewRef: ViewContainerRef) {\n        super();\n    }\n    ngOnInit(): void {\n        super.ngOnInit();\n    }\n}\n","<ng-container *ngFor=\"let item of config | filterToolbarControl\">\n    <ng-container [ngSwitch]=\"item.xtype\">\n        <ng-container *ngSwitchCase=\"'Ly.LayoutTabPanel'\">\n            <ng-container\n                *ngTemplateOutlet=\"\n                    dynamicLayout;\n                    context: { $implicit: item, selector: 'bsu-ly-tab-container', name: 'LyTabContainerComponent' }\n                \"\n            ></ng-container>\n            <!-- <bsu-ly-tab-container [config]=\"item\"></bsu-ly-tab-container> -->\n        </ng-container>\n        <ng-container *ngSwitchCase=\"'Ly.LayoutPanel'\">\n            <ng-container\n                *ngTemplateOutlet=\"\n                    dynamicLayout;\n                    context: { $implicit: item, selector: 'bsu-ly-layout-panel', name: 'LyLayoutPanelComponent' }\n                \"\n            ></ng-container>\n            <!-- <bsu-ly-layout-panel [config]=\"item\"></bsu-ly-layout-panel> -->\n        </ng-container>\n        <ng-container *ngSwitchCase=\"'Ly.LayoutContainer'\">\n            <ng-container\n                *ngTemplateOutlet=\"\n                    dynamicLayout;\n                    context: {\n                        $implicit: item,\n                        selector: 'bsu-ly-layout-container',\n                        name: 'LyLayoutContainerComponent'\n                    }\n                \"\n            ></ng-container>\n            <!-- <bsu-ly-layout-container [config]=\"item\"></bsu-ly-layout-container> -->\n        </ng-container>\n        <ng-container *ngSwitchCase=\"'Ly.EmptySpace'\">\n            <ng-container\n                *ngTemplateOutlet=\"\n                    dynamicLayout;\n                    context: { $implicit: item, selector: 'bsu-ly-empty-space', name: 'LyEmptySpaceComponent' }\n                \"\n            ></ng-container>\n            <!-- <bsu-ly-empty-space [config]=\"item\"></bsu-ly-empty-space> -->\n        </ng-container>\n        <ng-container *ngSwitchCase=\"'Ly.SimpleLabel'\">\n            <ng-container\n                *ngTemplateOutlet=\"\n                    dynamicLayout;\n                    context: { $implicit: item, selector: 'bsu-ly-simple-label', name: 'LySimpleLabelComponent' }\n                \"\n            ></ng-container>\n            <!-- <bsu-ly-simple-label [config]=\"item\"></bsu-ly-simple-label> -->\n        </ng-container>\n        <ng-container *ngSwitchCase=\"'Ly.LayoutLine'\">\n            <ng-container\n                *ngTemplateOutlet=\"\n                    dynamicLayout;\n                    context: { $implicit: item, selector: 'bsu-ly-line', name: 'LyLineComponent' }\n                \"\n            ></ng-container>\n            <!-- <bsu-ly-line [isVertical]=\"item.IsVertical\"></bsu-ly-line> -->\n        </ng-container>\n        <ng-container *ngSwitchCase=\"'Ly.LayoutJoin'\">\n            <ng-container *ngIf=\"item.Type === 'HorizontalJoin'; else verticalJoin\">\n                <ng-container\n                    *ngTemplateOutlet=\"\n                        dynamicLayout;\n                        context: {\n                            $implicit: item,\n                            selector: 'bsu-ly-horizontal-layout',\n                            name: 'LyHorizontalLayoutComponent',\n                            maxLabelWidth: this.maxLabelWidth\n                        }\n                    \"\n                ></ng-container>\n                <!-- <bsu-ly-horizontal-layout [config]=\"item\" [maxLabelWidth]=\"maxLabelWidth\"></bsu-ly-horizontal-layout> -->\n            </ng-container>\n            <ng-template #verticalJoin>\n                <ng-container\n                    *ngTemplateOutlet=\"\n                        dynamicLayout;\n                        context: {\n                            $implicit: item,\n                            selector: 'bsu-ly-vertical-layout',\n                            name: 'LyVerticalLayoutComponent',\n                            maxLabelWidth: this.maxLabelWidth\n                        }\n                    \"\n                ></ng-container>\n                <!-- <bsu-ly-vertical-layout [config]=\"item\" [maxLabelWidth]=\"maxLabelWidth\"></bsu-ly-vertical-layout> -->\n            </ng-template>\n        </ng-container>\n        <ng-container *ngSwitchCase=\"'Ly.LayoutControl'\">\n            <ng-container\n                *ngTemplateOutlet=\"\n                    dynamicLayout;\n                    context: {\n                        $implicit: item,\n                        selector: 'bsu-layout-control',\n                        name: 'LayoutControlComponent',\n                        maxLabelWidth: this.maxLabelWidth\n                    }\n                \"\n            ></ng-container>\n            <!-- <bsu-layout-control [config]=\"item\" [maxLabelWidth]=\"maxLabelWidth\"></bsu-layout-control> -->\n        </ng-container>\n    </ng-container>\n</ng-container>\n<ng-template #dynamicLayout let-config let-selector=\"selector\" let-name=\"name\" let-maxLabelWidth=\"maxLabelWidth\">\n    <bnrc-dynamic-layout\n        [flex]=\"!setFlex ? null : isSearchPanel ? 'unset' : config.Bounds.width\"\n        [config]=\"config\"\n        [selector]=\"selector\"\n        [name]=\"name\"\n        [module]=\"'BarsaSapUi'\"\n        [moduleFileName]=\"'BarsaSapUi'\"\n        [maxLabelWidth]=\"maxLabelWidth\"\n        [hasHorizontalText]=\"hasHorizontalText\"\n        [isSearchPanel]=\"isSearchPanel\"\n        [componentContainer]=\"viewRef\"\n    >\n    </bnrc-dynamic-layout>\n</ng-template>\n"]}
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, ViewChild } from '@angular/core';
|
|
2
|
+
import { FieldBaseComponent } from 'barsa-novin-ray-core';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@angular/common";
|
|
5
|
+
import * as i2 from "@fundamental-ngx/core/form";
|
|
6
|
+
export class BarsaDateTimePickerComponent extends FieldBaseComponent {
|
|
7
|
+
get caption() {
|
|
8
|
+
const fieldName = this.context.Setting.ControlName;
|
|
9
|
+
const fieldNameCaption = fieldName + '$Caption';
|
|
10
|
+
const mo = this.context.FormPanelUi.Mo;
|
|
11
|
+
let caption = '';
|
|
12
|
+
if (!mo[fieldNameCaption]) {
|
|
13
|
+
if (this.fullCalendar) {
|
|
14
|
+
caption = this.datetimePickerRef ? this.datetimePickerRef.nativeElement.value : '';
|
|
15
|
+
}
|
|
16
|
+
else {
|
|
17
|
+
caption = '';
|
|
18
|
+
if (this.Setting.ShowDate1) {
|
|
19
|
+
caption += this.datePickerRef ? this.datePickerRef.nativeElement.value : '';
|
|
20
|
+
}
|
|
21
|
+
if (this.Setting.ShowTime1) {
|
|
22
|
+
caption += this.durationPickerRef ? this.durationPickerRef.nativeElement.value : '';
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
else {
|
|
27
|
+
caption = mo[fieldNameCaption];
|
|
28
|
+
}
|
|
29
|
+
return caption || '';
|
|
30
|
+
}
|
|
31
|
+
ngOnInit() {
|
|
32
|
+
super.ngOnInit();
|
|
33
|
+
this.fullCalendar = this.Setting.ShowTime1 && this.Setting.ShowDate1;
|
|
34
|
+
}
|
|
35
|
+
onDateTimeChange() {
|
|
36
|
+
this.value = this.datetimePickerRef.nativeElement.dateValue;
|
|
37
|
+
this.valueCaption = this.datetimePickerRef.nativeElement.value;
|
|
38
|
+
this.valueChange.emit(this.value);
|
|
39
|
+
}
|
|
40
|
+
onDateChange() {
|
|
41
|
+
this.value = this.datePickerRef.nativeElement.dateValue;
|
|
42
|
+
this.valueCaption = this.datePickerRef.nativeElement.value;
|
|
43
|
+
this.valueChange.emit(this.value);
|
|
44
|
+
}
|
|
45
|
+
onDurationChange(e) {
|
|
46
|
+
const { value } = e.detail;
|
|
47
|
+
if (!this.value) {
|
|
48
|
+
this.value = new Date();
|
|
49
|
+
}
|
|
50
|
+
const time = value.split(':');
|
|
51
|
+
this.value.setHours(Number(time[0]), Number(time[1]), Number(time[2]));
|
|
52
|
+
this.valueCaption = this.durationPickerRef.nativeElement.value;
|
|
53
|
+
this.valueChange.emit(this.value);
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
BarsaDateTimePickerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: BarsaDateTimePickerComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
57
|
+
BarsaDateTimePickerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: BarsaDateTimePickerComponent, selector: "bsu-barsa-date-time-picker", viewQueries: [{ propertyName: "datetimePickerRef", first: true, predicate: ["datetimePicker"], descendants: true }, { propertyName: "datePickerRef", first: true, predicate: ["datePicker"], descendants: true }, { propertyName: "durationPickerRef", first: true, predicate: ["durationPicker"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<input\r\n *ngIf=\"(disableOrReadonly$ | async)!!; else datetime\"\r\n fd-form-control\r\n type=\"text\"\r\n [attr.readonly]=\"(readonly$ | async) === true ? true : null\"\r\n [attr.disabled]=\"(readonly$ | async) === true ? true : null\"\r\n [value]=\"caption\"\r\n/>\r\n<ng-template #datetime>\r\n <div [style.display]=\"(disableOrReadonly$ | async)!! ? 'hidden' : 'block'\">\r\n <ng-container *ngIf=\"fullCalendar; else simple\">\r\n <ui5-datetime-picker\r\n #datetimePicker\r\n style=\"width: 100%\"\r\n [attr.readonly]=\"(readonly$ | async) === true ? true : null\"\r\n [attr.disabled]=\"(readonly$ | async) === true ? true : null\"\r\n [primaryCalendarType]=\"Setting.CalendarType !== 'Gregorian' ? 'Persian' : Setting.CalendarType\"\r\n [value]=\"caption\"\r\n (change)=\"onDateTimeChange()\"\r\n ></ui5-datetime-picker>\r\n </ng-container>\r\n <ng-template #simple>\r\n <ui5-date-picker\r\n #datePicker\r\n format-pattern=\"yyyy/MM/dd\"\r\n [attr.readonly]=\"(readonly$ | async) === true ? true : null\"\r\n [attr.disabled]=\"(readonly$ | async) === true ? true : null\"\r\n style=\"width: 100%\"\r\n *ngIf=\"Setting.ShowDate1\"\r\n [primaryCalendarType]=\"Setting.CalendarType !== 'Gregorian' ? 'Persian' : Setting.CalendarType\"\r\n [value]=\"caption\"\r\n (change)=\"onDateChange()\"\r\n ></ui5-date-picker>\r\n <ui5-duration-picker\r\n #durationPicker\r\n [attr.readonly]=\"(readonly$ | async) === true ? true : null\"\r\n [attr.disabled]=\"(readonly$ | async) === true ? true : null\"\r\n style=\"width: 100%\"\r\n [primaryCalendarType]=\"Setting.CalendarType !== 'Gregorian' ? 'Persian' : Setting.CalendarType\"\r\n *ngIf=\"Setting.ShowTime1\"\r\n [value]=\"caption\"\r\n (change)=\"onDurationChange($event)\"\r\n ></ui5-duration-picker>\r\n </ng-template>\r\n </div>\r\n</ng-template>\r\n", styles: [""], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.FormControlComponent, selector: "[fd-form-control]", inputs: ["state", "type", "class"] }, { kind: "directive", type: i2.InputFormControlDirective, selector: "input[fd-form-control]" }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
58
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: BarsaDateTimePickerComponent, decorators: [{
|
|
59
|
+
type: Component,
|
|
60
|
+
args: [{ selector: 'bsu-barsa-date-time-picker', changeDetection: ChangeDetectionStrategy.OnPush, template: "<input\r\n *ngIf=\"(disableOrReadonly$ | async)!!; else datetime\"\r\n fd-form-control\r\n type=\"text\"\r\n [attr.readonly]=\"(readonly$ | async) === true ? true : null\"\r\n [attr.disabled]=\"(readonly$ | async) === true ? true : null\"\r\n [value]=\"caption\"\r\n/>\r\n<ng-template #datetime>\r\n <div [style.display]=\"(disableOrReadonly$ | async)!! ? 'hidden' : 'block'\">\r\n <ng-container *ngIf=\"fullCalendar; else simple\">\r\n <ui5-datetime-picker\r\n #datetimePicker\r\n style=\"width: 100%\"\r\n [attr.readonly]=\"(readonly$ | async) === true ? true : null\"\r\n [attr.disabled]=\"(readonly$ | async) === true ? true : null\"\r\n [primaryCalendarType]=\"Setting.CalendarType !== 'Gregorian' ? 'Persian' : Setting.CalendarType\"\r\n [value]=\"caption\"\r\n (change)=\"onDateTimeChange()\"\r\n ></ui5-datetime-picker>\r\n </ng-container>\r\n <ng-template #simple>\r\n <ui5-date-picker\r\n #datePicker\r\n format-pattern=\"yyyy/MM/dd\"\r\n [attr.readonly]=\"(readonly$ | async) === true ? true : null\"\r\n [attr.disabled]=\"(readonly$ | async) === true ? true : null\"\r\n style=\"width: 100%\"\r\n *ngIf=\"Setting.ShowDate1\"\r\n [primaryCalendarType]=\"Setting.CalendarType !== 'Gregorian' ? 'Persian' : Setting.CalendarType\"\r\n [value]=\"caption\"\r\n (change)=\"onDateChange()\"\r\n ></ui5-date-picker>\r\n <ui5-duration-picker\r\n #durationPicker\r\n [attr.readonly]=\"(readonly$ | async) === true ? true : null\"\r\n [attr.disabled]=\"(readonly$ | async) === true ? true : null\"\r\n style=\"width: 100%\"\r\n [primaryCalendarType]=\"Setting.CalendarType !== 'Gregorian' ? 'Persian' : Setting.CalendarType\"\r\n *ngIf=\"Setting.ShowTime1\"\r\n [value]=\"caption\"\r\n (change)=\"onDurationChange($event)\"\r\n ></ui5-duration-picker>\r\n </ng-template>\r\n </div>\r\n</ng-template>\r\n" }]
|
|
61
|
+
}], propDecorators: { datetimePickerRef: [{
|
|
62
|
+
type: ViewChild,
|
|
63
|
+
args: ['datetimePicker']
|
|
64
|
+
}], datePickerRef: [{
|
|
65
|
+
type: ViewChild,
|
|
66
|
+
args: ['datePicker']
|
|
67
|
+
}], durationPickerRef: [{
|
|
68
|
+
type: ViewChild,
|
|
69
|
+
args: ['durationPicker']
|
|
70
|
+
}] } });
|
|
71
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"barsa-date-time-picker.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-sap-ui/src/lib/barsa-date-time-picker/barsa-date-time-picker.component.ts","../../../../../projects/barsa-sap-ui/src/lib/barsa-date-time-picker/barsa-date-time-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, ElementRef, OnInit, ViewChild } from '@angular/core';\n\nimport { FieldBaseComponent } from 'barsa-novin-ray-core';\n\n@Component({\n    selector: 'bsu-barsa-date-time-picker',\n    templateUrl: './barsa-date-time-picker.component.html',\n    styleUrls: ['./barsa-date-time-picker.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class BarsaDateTimePickerComponent extends FieldBaseComponent implements OnInit {\n    @ViewChild('datetimePicker') datetimePickerRef: ElementRef;\n    @ViewChild('datePicker') datePickerRef: ElementRef;\n    @ViewChild('durationPicker') durationPickerRef: ElementRef;\n    fullCalendar: boolean;\n    value: Date;\n    valueCaption: string;\n\n    get caption(): string {\n        const fieldName = this.context.Setting.ControlName;\n        const fieldNameCaption = fieldName + '$Caption';\n        const mo = this.context.FormPanelUi.Mo;\n        let caption = '';\n        if (!mo[fieldNameCaption]) {\n            if (this.fullCalendar) {\n                caption = this.datetimePickerRef ? this.datetimePickerRef.nativeElement.value : '';\n            } else {\n                caption = '';\n                if (this.Setting.ShowDate1) {\n                    caption += this.datePickerRef ? this.datePickerRef.nativeElement.value : '';\n                }\n                if (this.Setting.ShowTime1) {\n                    caption += this.durationPickerRef ? this.durationPickerRef.nativeElement.value : '';\n                }\n            }\n        } else {\n            caption = mo[fieldNameCaption];\n        }\n        return caption || '';\n    }\n    ngOnInit(): void {\n        super.ngOnInit();\n        this.fullCalendar = this.Setting.ShowTime1 && this.Setting.ShowDate1;\n    }\n\n    onDateTimeChange(): void {\n        this.value = this.datetimePickerRef.nativeElement.dateValue;\n        this.valueCaption = this.datetimePickerRef.nativeElement.value;\n        this.valueChange.emit(this.value);\n    }\n    onDateChange(): void {\n        this.value = this.datePickerRef.nativeElement.dateValue;\n        this.valueCaption = this.datePickerRef.nativeElement.value;\n        this.valueChange.emit(this.value);\n    }\n    onDurationChange(e): void {\n        const { value } = e.detail;\n        if (!this.value) {\n            this.value = new Date();\n        }\n        const time = value.split(':');\n        this.value.setHours(Number(time[0]), Number(time[1]), Number(time[2]));\n        this.valueCaption = this.durationPickerRef.nativeElement.value;\n        this.valueChange.emit(this.value);\n    }\n}\n","<input\r\n    *ngIf=\"(disableOrReadonly$ | async)!!; else datetime\"\r\n    fd-form-control\r\n    type=\"text\"\r\n    [attr.readonly]=\"(readonly$ | async) === true ? true : null\"\r\n    [attr.disabled]=\"(readonly$ | async) === true ? true : null\"\r\n    [value]=\"caption\"\r\n/>\r\n<ng-template #datetime>\r\n    <div [style.display]=\"(disableOrReadonly$ | async)!! ? 'hidden' : 'block'\">\r\n        <ng-container *ngIf=\"fullCalendar; else simple\">\r\n            <ui5-datetime-picker\r\n                #datetimePicker\r\n                style=\"width: 100%\"\r\n                [attr.readonly]=\"(readonly$ | async) === true ? true : null\"\r\n                [attr.disabled]=\"(readonly$ | async) === true ? true : null\"\r\n                [primaryCalendarType]=\"Setting.CalendarType !== 'Gregorian' ? 'Persian' : Setting.CalendarType\"\r\n                [value]=\"caption\"\r\n                (change)=\"onDateTimeChange()\"\r\n            ></ui5-datetime-picker>\r\n        </ng-container>\r\n        <ng-template #simple>\r\n            <ui5-date-picker\r\n                #datePicker\r\n                format-pattern=\"yyyy/MM/dd\"\r\n                [attr.readonly]=\"(readonly$ | async) === true ? true : null\"\r\n                [attr.disabled]=\"(readonly$ | async) === true ? true : null\"\r\n                style=\"width: 100%\"\r\n                *ngIf=\"Setting.ShowDate1\"\r\n                [primaryCalendarType]=\"Setting.CalendarType !== 'Gregorian' ? 'Persian' : Setting.CalendarType\"\r\n                [value]=\"caption\"\r\n                (change)=\"onDateChange()\"\r\n            ></ui5-date-picker>\r\n            <ui5-duration-picker\r\n                #durationPicker\r\n                [attr.readonly]=\"(readonly$ | async) === true ? true : null\"\r\n                [attr.disabled]=\"(readonly$ | async) === true ? true : null\"\r\n                style=\"width: 100%\"\r\n                [primaryCalendarType]=\"Setting.CalendarType !== 'Gregorian' ? 'Persian' : Setting.CalendarType\"\r\n                *ngIf=\"Setting.ShowTime1\"\r\n                [value]=\"caption\"\r\n                (change)=\"onDurationChange($event)\"\r\n            ></ui5-duration-picker>\r\n        </ng-template>\r\n    </div>\r\n</ng-template>\r\n"]}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component } from '@angular/core';
|
|
2
|
+
import { UploadService } from 'barsa-novin-ray-core';
|
|
3
|
+
import { UiFileLinearListBoxComponent } from '../ui-file-linear-list-box/ui-file-linear-list-box.component';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@angular/common";
|
|
6
|
+
import * as i2 from "@fundamental-ngx/core/avatar";
|
|
7
|
+
import * as i3 from "@fundamental-ngx/core/button";
|
|
8
|
+
import * as i4 from "@fundamental-ngx/core/file-uploader";
|
|
9
|
+
import * as i5 from "@fundamental-ngx/core/icon";
|
|
10
|
+
import * as i6 from "@fundamental-ngx/core/list";
|
|
11
|
+
import * as i7 from "@fundamental-ngx/core/object-status";
|
|
12
|
+
import * as i8 from "@fundamental-ngx/core/toolbar";
|
|
13
|
+
import * as i9 from "@fundamental-ngx/platform/shared";
|
|
14
|
+
import * as i10 from "@fundamental-ngx/platform/slider";
|
|
15
|
+
import * as i11 from "barsa-novin-ray-core";
|
|
16
|
+
import * as i12 from "../upload-file-status.pipe";
|
|
17
|
+
export class BarsaListFileLinearComponent extends UiFileLinearListBoxComponent {
|
|
18
|
+
onRetry(fileAttachment) {
|
|
19
|
+
this.uploadFile(fileAttachment);
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
BarsaListFileLinearComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: BarsaListFileLinearComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
23
|
+
BarsaListFileLinearComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: BarsaListFileLinearComponent, selector: "bsu-barsa-list-file-linear", providers: [UploadService], usesInheritance: true, ngImport: i0, template: "<fd-toolbar [fdType]=\"'transparent'\" [clearBorder]=\"true\" *ngIf=\"(disableOrReadonly$ | async) === false\">\r\n <fd-file-uploader\r\n fd-toolbar-item\r\n [id]=\"id\"\r\n [name]=\"id\"\r\n [placeholder]=\"'AttachFile' | bbbTranslate\"\r\n [buttonLabel]=\"'AttachFile' | bbbTranslate\"\r\n [buttonAriaLabel]=\"'AttachFile' | bbbTranslate\"\r\n [accept]=\"Setting.ValidExtensions || ''\"\r\n [multiple]=\"maxFileCount > 1\"\r\n (selectedFilesChanged)=\"onFileSelection($event)\"\r\n [contentDensity]=\"(contentDensity$ | async)!!\"\r\n ></fd-file-uploader>\r\n</fd-toolbar>\r\n<ul fd-list [byline]=\"true\">\r\n <ng-container *ngIf=\"fileCount$ | async as fileCount\">\r\n <li fd-list-item *ngIf=\"fileCount === 0\">\r\n <div fd-list-content style=\"text-align: center\">\r\n <span>{{ 'NoFiles' | bbbTranslate }}</span>\r\n </div>\r\n </li>\r\n </ng-container>\r\n <ng-container *ngFor=\"let file of value\">\r\n <li fd-list-item *ngIf=\"!file.IsDeleted\">\r\n <span fd-list-thumbnail>\r\n <fd-icon\r\n *ngIf=\"valueExtra[file.Id].IsIcon; else isImage\"\r\n [glyph]=\"valueExtra[file.Id].FileUrl\"\r\n ></fd-icon>\r\n <ng-template #isImage>\r\n <fd-avatar size=\"m\" [image]=\"valueExtra[file.Id].FileUrl || ''\"></fd-avatar>\r\n </ng-template>\r\n </span>\r\n <!-- for byline, fd-list-content is mandatory -->\r\n <div fd-list-content>\r\n <div fd-list-title>{{ file.FileName }}</div>\r\n <div fd-list-byline [twoCol]=\"true\">\r\n <div fd-list-byline-left></div>\r\n <div fd-list-byline-right style=\"display: flex; justify-content: flex-end\">\r\n <fd-toolbar [fdType]=\"'transparent'\" [clearBorder]=\"true\">\r\n <ng-container *ngIf=\"file.IsNew\">\r\n <span\r\n fd-toolbar-item\r\n fd-object-status\r\n [status]=\"file.Id | uploadFileStatus: valueExtra\"\r\n [label]=\"valueExtra[file.Id]?.UploadState || ''\"\r\n [title]=\"valueExtra[file.Id]?.UploadState\"\r\n [aria-label]=\"'File Upload Status Is ' + valueExtra[file.Id]?.UploadState\"\r\n ></span>\r\n <ng-container *ngIf=\"valueExtra[file.Id].UploadState === 'Uploading'\">\r\n <fdp-slider\r\n fd-toolbar-item\r\n [id]=\"id\"\r\n [name]=\"'filerLinear_' + id\"\r\n [value]=\"valueExtra[file.Id]?.Progress\"\r\n [min]=\"0\"\r\n [max]=\"100\"\r\n [step]=\"1\"\r\n [contentDensity]=\"(contentDensity$ | async)!!\"\r\n >\r\n </fdp-slider>\r\n </ng-container>\r\n </ng-container>\r\n </fd-toolbar>\r\n </div>\r\n </div>\r\n </div>\r\n <button\r\n *ngIf=\"(disableOrReadonly$ | async) === false && valueExtra[file.Id].UploadState !== 'Uploading'\"\r\n fd-button\r\n fdType=\"transparent\"\r\n glyph=\"decline\"\r\n (click)=\"onFileDeleted(file.Id)\"\r\n ></button>\r\n <button\r\n *ngIf=\"valueExtra[file.Id].UploadState === 'Uploading'\"\r\n fd-button\r\n [fdType]=\"'transparent'\"\r\n [glyph]=\"'stop'\"\r\n (click)=\"onTerminate(file)\"\r\n ></button>\r\n <button\r\n *ngIf=\"valueExtra[file.Id].UploadState === 'Error'\"\r\n fd-button\r\n [fdType]=\"'transparent'\"\r\n [glyph]=\"'refresh'\"\r\n (click)=\"onRetry(file)\"\r\n ></button>\r\n </li>\r\n </ng-container>\r\n</ul>\r\n", styles: [":host{display:block;width:100%;height:100%}:host ::ng-deep .fd-slider__handle{display:none}:host ::ng-deep .fd-file-uploader input{display:none}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.AvatarComponent, selector: "fd-avatar", inputs: ["class", "id", "ariaLabel", "ariaLabelledby", "label", "size", "glyph", "zoomGlyph", "circle", "transparent", "contain", "placeholder", "tile", "border", "colorAccent", "random", "clickable", "backgroundImage", "image", "alterIcon", "backupImage"], outputs: ["avatarClicked", "zoomGlyphClicked"] }, { kind: "component", type: i3.ButtonComponent, selector: "button[fd-button], a[fd-button]", inputs: ["class"], exportAs: ["fd-button"] }, { kind: "component", type: i4.FileUploaderComponent, selector: "fd-file-uploader", inputs: ["disabled", "required", "multiple", "accept", "dragndrop", "maxFileSize", "minFileSize", "id", "ariaLabel", "ariaLabelledBy", "placeholder", "buttonLabel", "buttonAriaLabel", "state", "fileLimit", "inputHidden", "width"], outputs: ["selectedFilesChanged", "selectedInvalidFiles", "onDragEnter", "onDragLeave"] }, { kind: "component", type: i5.IconComponent, selector: "fd-icon", inputs: ["glyph", "font", "class", "ariaLabel"] }, { kind: "component", type: i6.ListComponent, selector: "[fd-list], [fdList]", inputs: ["dropdownMode", "multiInputMode", "mobileMode", "hasMessage", "noBorder", "navigationIndicator", "selection", "keyboardSupport", "byline"], outputs: ["focusEscapeList"] }, { kind: "component", type: i6.ListItemComponent, selector: "[fdListItem] ,[fd-list-item]", inputs: ["selected", "ariaDescribedBy", "noData", "action", "interactive", "growing", "counter", "unread", "selectedListItemScreenReaderText", "navigatedListItemScreenReaderText", "navigatableListItemScreenReaderText"], outputs: ["keyDown"] }, { kind: "directive", type: i6.ListTitleDirective, selector: "[fd-list-title], [fdListTitle]", inputs: ["wrap"] }, { kind: "directive", type: i6.ListBylineDirective, selector: "[fdListByline], [fd-list-byline]", inputs: ["twoCol", "wrap"] }, { kind: "directive", type: i6.ListBylineLeftDirective, selector: "[fdListBylineLeft], [fd-list-byline-left]", inputs: ["wrap"] }, { kind: "directive", type: i6.ListBylineRightDirective, selector: "[fdListBylineRight], [fd-list-byline-right]", inputs: ["status", "wrap"] }, { kind: "directive", type: i6.ListContentDirective, selector: "[fdListContent], [fd-list-content]", inputs: ["twoCol"] }, { kind: "directive", type: i6.ListThumbnailDirective, selector: "[fdListThumbnail], [fd-list-thumbnail]" }, { kind: "component", type: i7.ObjectStatusComponent, selector: "[fd-object-status]", inputs: ["class", "status", "glyph", "label", "glyphAriaLabel", "indicationColor", "clickable", "inverted", "large"] }, { kind: "component", type: i8.ToolbarComponent, selector: "fd-toolbar", inputs: ["class", "shouldOverflow", "fdType", "hasTitle", "title", "active", "clearBorder", "forceOverflow", "tabindex"] }, { kind: "directive", type: i8.ToolbarItemDirective, selector: "[fd-toolbar-item]" }, { kind: "directive", type: i9.PlatformContentDensityDeprecationDirective, selector: " fdp-action-bar[contentDensity], fdp-button[contentDensity], fdp-object-list-item[contentDensity], fdp-standard-list-item[contentDensity], fdp-menu[contentDensity], fdp-menu-button[contentDensity], fdp-panel[contentDensity], fdp-search-field[contentDensity], fdp-split-menu-button[contentDensity], fdp-file-uploader[contentDensity], fdp-upload-collection[contentDensity], fdp-table[contentDensity], fdp-multi-input[contentDensity], fdp-list[contentDensity], fdp-slider[contentDensity], fdp-time-picker[contentDensity], fdp-textarea[contentDensity], fdp-switch[contentDensity], fdp-number-step-input[contentDensity], fdp-select[contentDensity], fdp-date-picker[contentDensity], fdp-checkbox[contentDensity], fdp-checkbox-group[contentDensity], fdp-combobox[contentDensity], fdp-datetime-picker[contentDensity], fdp-input[contentDensity], fdp-radio-group[contentDensity], fdp-radio-button[contentDensity], fdp-multi-combobox[contentDensity], fdp-input-group-addon-body[contentDensity], fdp-input-group[contentDensity], fdp-value-help-dialog[contentDensity], fdp-filter-single-select[contentDensity], fdp-filter-multi-select[contentDensity], fdp-filter-custom[contentDensity] " }, { kind: "component", type: i10.SliderComponent, selector: "fdp-slider", inputs: ["class", "min", "max", "step", "jump", "tickmarksBetweenLabels", "mode", "showTicks", "showTicksLabels", "customValues", "tooltipMode", "hideProgressBar", "value"], outputs: ["sliderChange"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i11.BbbTranslatePipe, name: "bbbTranslate" }, { kind: "pipe", type: i12.UploadFileStatusPipe, name: "uploadFileStatus" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
24
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: BarsaListFileLinearComponent, decorators: [{
|
|
25
|
+
type: Component,
|
|
26
|
+
args: [{ selector: 'bsu-barsa-list-file-linear', changeDetection: ChangeDetectionStrategy.OnPush, providers: [UploadService], template: "<fd-toolbar [fdType]=\"'transparent'\" [clearBorder]=\"true\" *ngIf=\"(disableOrReadonly$ | async) === false\">\r\n <fd-file-uploader\r\n fd-toolbar-item\r\n [id]=\"id\"\r\n [name]=\"id\"\r\n [placeholder]=\"'AttachFile' | bbbTranslate\"\r\n [buttonLabel]=\"'AttachFile' | bbbTranslate\"\r\n [buttonAriaLabel]=\"'AttachFile' | bbbTranslate\"\r\n [accept]=\"Setting.ValidExtensions || ''\"\r\n [multiple]=\"maxFileCount > 1\"\r\n (selectedFilesChanged)=\"onFileSelection($event)\"\r\n [contentDensity]=\"(contentDensity$ | async)!!\"\r\n ></fd-file-uploader>\r\n</fd-toolbar>\r\n<ul fd-list [byline]=\"true\">\r\n <ng-container *ngIf=\"fileCount$ | async as fileCount\">\r\n <li fd-list-item *ngIf=\"fileCount === 0\">\r\n <div fd-list-content style=\"text-align: center\">\r\n <span>{{ 'NoFiles' | bbbTranslate }}</span>\r\n </div>\r\n </li>\r\n </ng-container>\r\n <ng-container *ngFor=\"let file of value\">\r\n <li fd-list-item *ngIf=\"!file.IsDeleted\">\r\n <span fd-list-thumbnail>\r\n <fd-icon\r\n *ngIf=\"valueExtra[file.Id].IsIcon; else isImage\"\r\n [glyph]=\"valueExtra[file.Id].FileUrl\"\r\n ></fd-icon>\r\n <ng-template #isImage>\r\n <fd-avatar size=\"m\" [image]=\"valueExtra[file.Id].FileUrl || ''\"></fd-avatar>\r\n </ng-template>\r\n </span>\r\n <!-- for byline, fd-list-content is mandatory -->\r\n <div fd-list-content>\r\n <div fd-list-title>{{ file.FileName }}</div>\r\n <div fd-list-byline [twoCol]=\"true\">\r\n <div fd-list-byline-left></div>\r\n <div fd-list-byline-right style=\"display: flex; justify-content: flex-end\">\r\n <fd-toolbar [fdType]=\"'transparent'\" [clearBorder]=\"true\">\r\n <ng-container *ngIf=\"file.IsNew\">\r\n <span\r\n fd-toolbar-item\r\n fd-object-status\r\n [status]=\"file.Id | uploadFileStatus: valueExtra\"\r\n [label]=\"valueExtra[file.Id]?.UploadState || ''\"\r\n [title]=\"valueExtra[file.Id]?.UploadState\"\r\n [aria-label]=\"'File Upload Status Is ' + valueExtra[file.Id]?.UploadState\"\r\n ></span>\r\n <ng-container *ngIf=\"valueExtra[file.Id].UploadState === 'Uploading'\">\r\n <fdp-slider\r\n fd-toolbar-item\r\n [id]=\"id\"\r\n [name]=\"'filerLinear_' + id\"\r\n [value]=\"valueExtra[file.Id]?.Progress\"\r\n [min]=\"0\"\r\n [max]=\"100\"\r\n [step]=\"1\"\r\n [contentDensity]=\"(contentDensity$ | async)!!\"\r\n >\r\n </fdp-slider>\r\n </ng-container>\r\n </ng-container>\r\n </fd-toolbar>\r\n </div>\r\n </div>\r\n </div>\r\n <button\r\n *ngIf=\"(disableOrReadonly$ | async) === false && valueExtra[file.Id].UploadState !== 'Uploading'\"\r\n fd-button\r\n fdType=\"transparent\"\r\n glyph=\"decline\"\r\n (click)=\"onFileDeleted(file.Id)\"\r\n ></button>\r\n <button\r\n *ngIf=\"valueExtra[file.Id].UploadState === 'Uploading'\"\r\n fd-button\r\n [fdType]=\"'transparent'\"\r\n [glyph]=\"'stop'\"\r\n (click)=\"onTerminate(file)\"\r\n ></button>\r\n <button\r\n *ngIf=\"valueExtra[file.Id].UploadState === 'Error'\"\r\n fd-button\r\n [fdType]=\"'transparent'\"\r\n [glyph]=\"'refresh'\"\r\n (click)=\"onRetry(file)\"\r\n ></button>\r\n </li>\r\n </ng-container>\r\n</ul>\r\n", styles: [":host{display:block;width:100%;height:100%}:host ::ng-deep .fd-slider__handle{display:none}:host ::ng-deep .fd-file-uploader input{display:none}\n"] }]
|
|
27
|
+
}] });
|
|
28
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"barsa-list-file-linear.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-sap-ui/src/lib/barsa-list-file-linear/barsa-list-file-linear.component.ts","../../../../../projects/barsa-sap-ui/src/lib/barsa-list-file-linear/barsa-list-file-linear.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AACnE,OAAO,EAAE,aAAa,EAAsB,MAAM,sBAAsB,CAAC;AACzE,OAAO,EAAE,4BAA4B,EAAE,MAAM,8DAA8D,CAAC;;;;;;;;;;;;;;AAS5G,MAAM,OAAO,4BAA6B,SAAQ,4BAA4B;IAC1E,OAAO,CAAC,cAAkC;QACtC,IAAI,CAAC,UAAU,CAAC,cAAc,CAAC,CAAC;IACpC,CAAC;;yHAHQ,4BAA4B;6GAA5B,4BAA4B,qDAF1B,CAAC,aAAa,CAAC,iDCT9B,ogJA2FA;2FDhFa,4BAA4B;kBAPxC,SAAS;+BACI,4BAA4B,mBAGrB,uBAAuB,CAAC,MAAM,aACpC,CAAC,aAAa,CAAC","sourcesContent":["import { ChangeDetectionStrategy, Component } from '@angular/core';\nimport { UploadService, FileAttachmentInfo } from 'barsa-novin-ray-core';\nimport { UiFileLinearListBoxComponent } from '../ui-file-linear-list-box/ui-file-linear-list-box.component';\n\n@Component({\n    selector: 'bsu-barsa-list-file-linear',\n    templateUrl: './barsa-list-file-linear.component.html',\n    styleUrls: ['./barsa-list-file-linear.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [UploadService]\n})\nexport class BarsaListFileLinearComponent extends UiFileLinearListBoxComponent {\n    onRetry(fileAttachment: FileAttachmentInfo): void {\n        this.uploadFile(fileAttachment);\n    }\n}\n","<fd-toolbar [fdType]=\"'transparent'\" [clearBorder]=\"true\" *ngIf=\"(disableOrReadonly$ | async) === false\">\r\n    <fd-file-uploader\r\n        fd-toolbar-item\r\n        [id]=\"id\"\r\n        [name]=\"id\"\r\n        [placeholder]=\"'AttachFile' | bbbTranslate\"\r\n        [buttonLabel]=\"'AttachFile' | bbbTranslate\"\r\n        [buttonAriaLabel]=\"'AttachFile' | bbbTranslate\"\r\n        [accept]=\"Setting.ValidExtensions || ''\"\r\n        [multiple]=\"maxFileCount > 1\"\r\n        (selectedFilesChanged)=\"onFileSelection($event)\"\r\n        [contentDensity]=\"(contentDensity$ | async)!!\"\r\n    ></fd-file-uploader>\r\n</fd-toolbar>\r\n<ul fd-list [byline]=\"true\">\r\n    <ng-container *ngIf=\"fileCount$ | async as fileCount\">\r\n        <li fd-list-item *ngIf=\"fileCount === 0\">\r\n            <div fd-list-content style=\"text-align: center\">\r\n                <span>{{ 'NoFiles' | bbbTranslate }}</span>\r\n            </div>\r\n        </li>\r\n    </ng-container>\r\n    <ng-container *ngFor=\"let file of value\">\r\n        <li fd-list-item *ngIf=\"!file.IsDeleted\">\r\n            <span fd-list-thumbnail>\r\n                <fd-icon\r\n                    *ngIf=\"valueExtra[file.Id].IsIcon; else isImage\"\r\n                    [glyph]=\"valueExtra[file.Id].FileUrl\"\r\n                ></fd-icon>\r\n                <ng-template #isImage>\r\n                    <fd-avatar size=\"m\" [image]=\"valueExtra[file.Id].FileUrl || ''\"></fd-avatar>\r\n                </ng-template>\r\n            </span>\r\n            <!-- for byline, fd-list-content is mandatory -->\r\n            <div fd-list-content>\r\n                <div fd-list-title>{{ file.FileName }}</div>\r\n                <div fd-list-byline [twoCol]=\"true\">\r\n                    <div fd-list-byline-left></div>\r\n                    <div fd-list-byline-right style=\"display: flex; justify-content: flex-end\">\r\n                        <fd-toolbar [fdType]=\"'transparent'\" [clearBorder]=\"true\">\r\n                            <ng-container *ngIf=\"file.IsNew\">\r\n                                <span\r\n                                    fd-toolbar-item\r\n                                    fd-object-status\r\n                                    [status]=\"file.Id | uploadFileStatus: valueExtra\"\r\n                                    [label]=\"valueExtra[file.Id]?.UploadState || ''\"\r\n                                    [title]=\"valueExtra[file.Id]?.UploadState\"\r\n                                    [aria-label]=\"'File Upload Status Is ' + valueExtra[file.Id]?.UploadState\"\r\n                                ></span>\r\n                                <ng-container *ngIf=\"valueExtra[file.Id].UploadState === 'Uploading'\">\r\n                                    <fdp-slider\r\n                                        fd-toolbar-item\r\n                                        [id]=\"id\"\r\n                                        [name]=\"'filerLinear_' + id\"\r\n                                        [value]=\"valueExtra[file.Id]?.Progress\"\r\n                                        [min]=\"0\"\r\n                                        [max]=\"100\"\r\n                                        [step]=\"1\"\r\n                                        [contentDensity]=\"(contentDensity$ | async)!!\"\r\n                                    >\r\n                                    </fdp-slider>\r\n                                </ng-container>\r\n                            </ng-container>\r\n                        </fd-toolbar>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n            <button\r\n                *ngIf=\"(disableOrReadonly$ | async) === false && valueExtra[file.Id].UploadState !== 'Uploading'\"\r\n                fd-button\r\n                fdType=\"transparent\"\r\n                glyph=\"decline\"\r\n                (click)=\"onFileDeleted(file.Id)\"\r\n            ></button>\r\n            <button\r\n                *ngIf=\"valueExtra[file.Id].UploadState === 'Uploading'\"\r\n                fd-button\r\n                [fdType]=\"'transparent'\"\r\n                [glyph]=\"'stop'\"\r\n                (click)=\"onTerminate(file)\"\r\n            ></button>\r\n            <button\r\n                *ngIf=\"valueExtra[file.Id].UploadState === 'Error'\"\r\n                fd-button\r\n                [fdType]=\"'transparent'\"\r\n                [glyph]=\"'refresh'\"\r\n                (click)=\"onRetry(file)\"\r\n            ></button>\r\n        </li>\r\n    </ng-container>\r\n</ul>\r\n"]}
|