barsa-sap-ui 0.0.6 → 1.0.248
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/esm2020/lib/apply-conditional-formmatings.directive.mjs +1 -1
- package/esm2020/lib/barsa-asp-viewer/barsa-asp-viewer.component.mjs +2 -2
- package/esm2020/lib/barsa-date-time-picker/barsa-date-time-picker.component.mjs +1 -1
- package/esm2020/lib/barsa-list-file-linear/barsa-list-file-linear.component.mjs +4 -4
- package/esm2020/lib/barsa-monaco-editor/barsa-monaco-editor.component.mjs +14 -14
- package/esm2020/lib/barsa-network-offline/barsa-network-offline.component.mjs +20 -12
- package/esm2020/lib/barsa-sap-ui-routing.module.mjs +1 -1
- package/esm2020/lib/barsa-sap-ui.module.mjs +25 -16
- package/esm2020/lib/barsa-search-form/barsa-search-form.component.mjs +3 -3
- package/esm2020/lib/barsa-table-header/barsa-table-header.component.mjs +4 -4
- package/esm2020/lib/barsa-table-row/barsa-table-row.component.mjs +3 -3
- package/esm2020/lib/barsa-tinyemce/barsa-tinyemce.component.mjs +6 -6
- package/esm2020/lib/barsa-tree-item/barsa-tree-item.component.mjs +23 -12
- package/esm2020/lib/barsa-ulv-main/barsa-ulv-main.component.mjs +8 -7
- package/esm2020/lib/blob-viewer/blob-viewer.component.mjs +60 -0
- package/esm2020/lib/breadcrumb/breadcrumb.component.mjs +3 -3
- package/esm2020/lib/captcha-field/captcha-field.component.mjs +1 -1
- package/esm2020/lib/card-item/card-item.component.mjs +4 -4
- package/esm2020/lib/card-view-content/card-view-content.component.mjs +3 -3
- package/esm2020/lib/column-matrix-renderer/column-matrix-renderer.component.mjs +3 -3
- package/esm2020/lib/column-matrix-renderer/matrix-value.pipe.mjs +1 -1
- package/esm2020/lib/column-renderer/column-renderer.component.mjs +6 -5
- package/esm2020/lib/constants.mjs +1 -1
- package/esm2020/lib/custom-date-time/custom-date-time.component.mjs +1 -1
- package/esm2020/lib/device-info-field-base.mjs +1 -1
- package/esm2020/lib/download-files.directive.mjs +33 -0
- package/esm2020/lib/empty-page/empty-page.component.mjs +3 -3
- package/esm2020/lib/file-in-dialog/file-in-dialog.component.mjs +1 -1
- package/esm2020/lib/file-viewer/file-viewer.component.mjs +47 -0
- package/esm2020/lib/file-viewer-content/file-viewer-content.component.mjs +49 -0
- package/esm2020/lib/file-viewer-popover/file-viewer-popover.component.mjs +34 -0
- package/esm2020/lib/form-dialog/form-dialog.component.mjs +3 -3
- package/esm2020/lib/form-dialog-less/form-dialog-less.component.mjs +1 -1
- package/esm2020/lib/form-page/form-page.component.mjs +17 -17
- package/esm2020/lib/form-page-base.mjs +1 -1
- package/esm2020/lib/form-toolbar-button/form-toolbar-button.component.mjs +3 -3
- package/esm2020/lib/form-wizard/form-wizard.component.mjs +3 -3
- package/esm2020/lib/fullscreen-dialog.directive.mjs +1 -1
- package/esm2020/lib/fullscreen-files.directive.mjs +39 -0
- package/esm2020/lib/fundamental-dynamic-form/fundamental-dynamic-form.component.mjs +3 -3
- package/esm2020/lib/gantt-dhtml-chart-view/gantt-dhtml-chart-view.component.mjs +1 -1
- package/esm2020/lib/global-search/global-search.component.mjs +1 -1
- package/esm2020/lib/global-search-module/global-search-module.component.mjs +1 -1
- package/esm2020/lib/global-search-panel/global-search-panel.component.mjs +1 -1
- package/esm2020/lib/header-avatar/header-avatar.component.mjs +1 -1
- package/esm2020/lib/header-facet-form/header-facet-form.component.mjs +1 -1
- package/esm2020/lib/header-facet-key-value/header-facet-key-value.component.mjs +1 -1
- package/esm2020/lib/header-facet-microchart/header-facet-microchart.component.mjs +3 -3
- package/esm2020/lib/header-facet-plain-text/header-facet-plain-text.component.mjs +3 -3
- package/esm2020/lib/header-facet-rate/header-facet-rate.component.mjs +1 -1
- package/esm2020/lib/hyperlink/hyperlink.component.mjs +1 -1
- package/esm2020/lib/index.mjs +18 -3
- package/esm2020/lib/inline-save-and-cancel/inline-save-and-cancel.component.mjs +1 -1
- package/esm2020/lib/layout-actions/layout-actions.component.mjs +1 -1
- package/esm2020/lib/layout-control/layout-control.component.mjs +4 -4
- package/esm2020/lib/layout-wizard/layout-wizard.component.mjs +25 -3
- package/esm2020/lib/list-item/list-item.component.mjs +3 -3
- package/esm2020/lib/ly-empty-space/ly-empty-space.component.mjs +5 -7
- package/esm2020/lib/ly-horizontal-layout/ly-horizontal-layout.component.mjs +8 -7
- package/esm2020/lib/ly-layout-container/ly-layout-container.component.mjs +3 -3
- package/esm2020/lib/ly-layout-container-of-root/ly-layout-container-of-root.component.mjs +3 -3
- package/esm2020/lib/ly-layout-field-label/ly-layout-field-label.component.mjs +1 -1
- package/esm2020/lib/ly-layout-panel/ly-layout-panel.component.mjs +9 -3
- package/esm2020/lib/ly-line/ly-line.component.mjs +1 -1
- package/esm2020/lib/ly-simple-label/ly-simple-label.component.mjs +6 -10
- package/esm2020/lib/ly-tab-container/ly-tab-container.component.mjs +7 -3
- package/esm2020/lib/ly-tab-page/ly-tab-page.component.mjs +3 -3
- package/esm2020/lib/ly-vertical-layout/ly-vertical-layout.component.mjs +8 -7
- package/esm2020/lib/mask/mask.component.mjs +3 -3
- package/esm2020/lib/message-strip/message-strip.component.mjs +1 -1
- package/esm2020/lib/models/grid-data-provider.mjs +2 -2
- package/esm2020/lib/models/grid-view.mjs +1 -1
- package/esm2020/lib/no-data/no-data.component.mjs +3 -3
- package/esm2020/lib/page-with-form-handler-base.mjs +1 -1
- package/esm2020/lib/page-with-header/page-with-header.component.mjs +1 -1
- package/esm2020/lib/progress-indicator/progress-indicator.component.mjs +1 -1
- package/esm2020/lib/report-navigator/report-navigator.component.mjs +3 -3
- package/esm2020/lib/report-new-top-form/report-new-top-form.component.mjs +3 -3
- package/esm2020/lib/report-search-fields-hidden-settings/report-search-fields-hidden-settings.component.mjs +3 -3
- package/esm2020/lib/report-search-fields-manage/report-search-fields-manage.component.mjs +3 -3
- package/esm2020/lib/report-tree-base.mjs +4 -1
- package/esm2020/lib/report-view-renderer.directive.mjs +32 -2
- package/esm2020/lib/responsive-toolbar/responsive-toolbar.component.mjs +1 -1
- package/esm2020/lib/responsive-toolbar-renderer/responsive-toolbar-renderer.component.mjs +1 -1
- package/esm2020/lib/rich-text-static/rich-text-static.component.mjs +1 -1
- package/esm2020/lib/sap-ui-report-base.component.mjs +87 -64
- package/esm2020/lib/search-panel/search-panel.component.mjs +1 -1
- package/esm2020/lib/static-text/static-text.component.mjs +3 -3
- package/esm2020/lib/ui-asp-report-viewer/ui-asp-report-viewer.component.mjs +3 -3
- package/esm2020/lib/ui-button/ui-button.component.mjs +3 -3
- package/esm2020/lib/ui-calendar/ui-calendar.component.mjs +3 -3
- package/esm2020/lib/ui-card-view/ui-card-view.component.mjs +3 -3
- package/esm2020/lib/ui-check-box/ui-check-box.component.mjs +3 -3
- package/esm2020/lib/ui-color-ui/ui-color-ui.component.mjs +1 -1
- package/esm2020/lib/ui-container-with-button/ui-container-with-button.component.mjs +3 -3
- package/esm2020/lib/ui-date-range-ex/ui-date-range-ex.component.mjs +3 -3
- package/esm2020/lib/ui-date-time/ui-date-time.component.mjs +3 -3
- package/esm2020/lib/ui-editable-grid/ui-editable-grid.component.mjs +3 -3
- package/esm2020/lib/ui-exception-form/ui-exception-form.component.mjs +1 -1
- package/esm2020/lib/ui-file-linear-list-box/ui-file-linear-list-box.component.mjs +29 -90
- package/esm2020/lib/ui-form-panel/ui-form-panel.component.mjs +3 -3
- package/esm2020/lib/ui-gantt-chart/ui-gantt-chart.component.mjs +3 -3
- package/esm2020/lib/ui-graph/ui-graph.component.mjs +1 -1
- package/esm2020/lib/ui-grid/ui-grid.component.mjs +3 -3
- package/esm2020/lib/ui-grid-columns/ui-grid-columns.component.mjs +3 -3
- package/esm2020/lib/ui-grid-filter-item/ui-grid-filter-item.component.mjs +1 -1
- package/esm2020/lib/ui-grid-filter-settings/ui-grid-filter-settings.component.mjs +1 -1
- package/esm2020/lib/ui-grid-sort-item/ui-grid-sort-item.component.mjs +1 -1
- package/esm2020/lib/ui-grid-sort-setting/ui-grid-sort-setting.component.mjs +1 -1
- package/esm2020/lib/ui-info-bar-panel/ui-info-bar-panel.component.mjs +1 -1
- package/esm2020/lib/ui-label/ui-label.component.mjs +3 -3
- package/esm2020/lib/ui-linear-list-container-with-button/ui-linear-list-container-with-button.component.mjs +2 -2
- package/esm2020/lib/ui-list-view/ui-list-view.component.mjs +4 -3
- package/esm2020/lib/ui-matrix-view/ui-matrix-view.component.mjs +3 -3
- package/esm2020/lib/ui-mo-info-combo-viewer/ui-mo-info-combo-viewer.component.mjs +3 -3
- package/esm2020/lib/ui-mo-info-general-object-ui/ui-mo-info-general-object-ui.component.mjs +1 -1
- package/esm2020/lib/ui-mo-info-sub-form-ui/ui-mo-info-sub-form-ui.component.mjs +3 -3
- package/esm2020/lib/ui-mo-info-ulv-combo/ui-mo-info-ulv-combo.component.mjs +19 -14
- package/esm2020/lib/ui-monaco-editor/ui-monaco-editor.component.mjs +3 -3
- package/esm2020/lib/ui-multi-select-combo/ui-multi-select-combo.component.mjs +26 -9
- package/esm2020/lib/ui-num-decimal-ui/ui-num-decimal-ui.component.mjs +1 -1
- package/esm2020/lib/ui-num-int-ui/ui-num-int-ui.component.mjs +3 -3
- package/esm2020/lib/ui-pdf-viewer/ui-pdf-viewer.component.mjs +19 -20
- package/esm2020/lib/ui-picture-file/ui-picture-file.component.mjs +26 -30
- package/esm2020/lib/ui-pictures-info/ui-pictures-info.component.mjs +39 -31
- package/esm2020/lib/ui-radio-group/ui-radio-group.component.mjs +3 -3
- package/esm2020/lib/ui-read-only-field/ui-read-only-field.component.mjs +3 -3
- package/esm2020/lib/ui-report-container/ui-report-container.component.mjs +3 -3
- package/esm2020/lib/ui-search-command-info-ui/ui-search-command-info-ui.component.mjs +1 -1
- package/esm2020/lib/ui-simple-combo/ui-simple-combo.component.mjs +3 -3
- package/esm2020/lib/ui-single-picture/ui-single-picture.component.mjs +1 -1
- package/esm2020/lib/ui-switch-button/ui-switch-button.component.mjs +3 -3
- package/esm2020/lib/ui-table-view/ui-table-view.component.mjs +8 -3
- package/esm2020/lib/ui-text-area/ui-text-area.component.mjs +3 -3
- package/esm2020/lib/ui-text-field/ui-text-field.component.mjs +1 -1
- package/esm2020/lib/ui-text-field-auto-complete/ui-text-field-auto-complete.component.mjs +3 -3
- package/esm2020/lib/ui-time-span/ui-time-span.component.mjs +1 -1
- package/esm2020/lib/ui-tinymce/ui-tinymce.component.mjs +1 -1
- package/esm2020/lib/ui-tree/ui-tree.component.mjs +26 -3
- package/esm2020/lib/ui-tree-view/ui-tree-view.component.mjs +9 -3
- package/esm2020/lib/ui-ulv-form-multi-select-ui/ui-ulv-form-multi-select-ui.component.mjs +2 -2
- package/esm2020/lib/ui-ulv-main-ui/ui-ulv-main-ui.component.mjs +6 -3
- package/esm2020/lib/ui-workflow-panel-ui/ui-workflow-panel-ui.component.mjs +1 -1
- package/esm2020/lib/ul-loading-mask-ui/ul-loading-mask-ui.component.mjs +7 -2
- package/esm2020/lib/ul-msg-box-adapter/ul-msg-box-adapter.component.mjs +3 -3
- package/esm2020/lib/ul-notify-popup/ul-notify-popup.component.mjs +1 -1
- package/esm2020/lib/ul-toast-adapter/ul-toast-adapter.component.mjs +1 -1
- package/esm2020/lib/ulv-column-settings/ulv-column-settings.component.mjs +3 -3
- package/esm2020/lib/ulv-context-menu/ulv-context-menu.component.mjs +3 -3
- package/esm2020/lib/ulv-filter-settings/ulv-filter-settings.component.mjs +3 -3
- package/esm2020/lib/ulv-form-multi-select/ulv-form-multi-select.component.mjs +5 -5
- package/esm2020/lib/ulv-groupby-settings/ulv-groupby-settings.component.mjs +3 -3
- package/esm2020/lib/ulv-paging/ulv-paging.component.mjs +1 -1
- package/esm2020/lib/ulv-selection/ulv-selection.component.mjs +2 -2
- package/esm2020/lib/ulv-settings/ulv-settings.component.mjs +1 -1
- package/esm2020/lib/ulv-sort-settings/ulv-sort-settings.component.mjs +3 -3
- package/esm2020/lib/ulv-toolbar/ulv-toolbar.component.mjs +11 -5
- package/esm2020/lib/wizard-layout.directive.mjs +1 -1
- package/esm2020/public-api.mjs +7 -1
- package/fesm2015/barsa-sap-ui.mjs +888 -542
- package/fesm2015/barsa-sap-ui.mjs.map +1 -1
- package/fesm2020/barsa-sap-ui.mjs +879 -541
- package/fesm2020/barsa-sap-ui.mjs.map +1 -1
- package/lib/barsa-network-offline/barsa-network-offline.component.d.ts +3 -2
- package/lib/barsa-sap-ui.module.d.ts +31 -25
- package/lib/barsa-tree-item/barsa-tree-item.component.d.ts +7 -1
- package/lib/barsa-ulv-main/barsa-ulv-main.component.d.ts +3 -1
- package/lib/blob-viewer/blob-viewer.component.d.ts +20 -0
- package/lib/download-files.directive.d.ts +9 -0
- package/lib/file-viewer/file-viewer.component.d.ts +21 -0
- package/lib/file-viewer-content/file-viewer-content.component.d.ts +18 -0
- package/lib/file-viewer-popover/file-viewer-popover.component.d.ts +13 -0
- package/lib/fullscreen-files.directive.d.ts +15 -0
- package/lib/index.d.ts +8 -4
- package/lib/layout-control/layout-control.component.d.ts +5 -5
- package/lib/layout-wizard/layout-wizard.component.d.ts +1 -0
- package/lib/ly-empty-space/ly-empty-space.component.d.ts +1 -3
- package/lib/ly-horizontal-layout/ly-horizontal-layout.component.d.ts +4 -3
- package/lib/ly-simple-label/ly-simple-label.component.d.ts +1 -3
- package/lib/ly-tab-container/ly-tab-container.component.d.ts +3 -1
- package/lib/ly-vertical-layout/ly-vertical-layout.component.d.ts +4 -3
- package/lib/report-tree-base.d.ts +2 -1
- package/lib/report-view-renderer.directive.d.ts +10 -1
- package/lib/sap-ui-report-base.component.d.ts +13 -4
- package/lib/ui-file-linear-list-box/ui-file-linear-list-box.component.d.ts +15 -18
- package/lib/ui-multi-select-combo/ui-multi-select-combo.component.d.ts +9 -3
- package/lib/ui-pdf-viewer/ui-pdf-viewer.component.d.ts +5 -6
- package/lib/ui-picture-file/ui-picture-file.component.d.ts +4 -6
- package/lib/ui-pictures-info/ui-pictures-info.component.d.ts +8 -7
- package/lib/ui-table-view/ui-table-view.component.d.ts +1 -0
- package/lib/ui-tree/ui-tree.component.d.ts +5 -0
- package/lib/ui-tree-view/ui-tree-view.component.d.ts +7 -1
- package/lib/ui-ulv-main-ui/ui-ulv-main-ui.component.d.ts +2 -1
- package/lib/ul-loading-mask-ui/ul-loading-mask-ui.component.d.ts +2 -1
- package/lib/ulv-toolbar/ulv-toolbar.component.d.ts +4 -1
- package/package.json +3 -3
- package/public-api.d.ts +6 -0
|
@@ -10,12 +10,12 @@ export class UiNumIntUiComponent extends NumberBaseComponent {
|
|
|
10
10
|
}
|
|
11
11
|
}
|
|
12
12
|
UiNumIntUiComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: UiNumIntUiComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
13
|
-
UiNumIntUiComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: UiNumIntUiComponent, selector: "bsu-ui-num-int-ui", viewQueries: [{ propertyName: "inputRef", first: true, predicate: ["inputRef"], descendants: true, read: ElementRef, static: true }], usesInheritance: true, ngImport: i0, template: "<input\r\n #inputRef\r\n fd-form-control\r\n [placeholder]=\"Setting.NullText || ''\"\r\n [attr.readonly]=\"(readonly$ | async) === true ? true : null\"\r\n [attr.disabled]=\"(disable$ | async) === true ? true : null\"\r\n [type]=\"Setting.IsPassword ? 'password' : 'text'\"\r\n [type]=\"hasMask ? 'text' : 'number'\"\r\n [id]=\"id\"\r\n [style.direction]=\"Setting.IsLtr === true ? '
|
|
13
|
+
UiNumIntUiComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: UiNumIntUiComponent, selector: "bsu-ui-num-int-ui", viewQueries: [{ propertyName: "inputRef", first: true, predicate: ["inputRef"], descendants: true, read: ElementRef, static: true }], usesInheritance: true, ngImport: i0, template: "<input\r\n #inputRef\r\n fd-form-control\r\n [placeholder]=\"Setting.NullText || ''\"\r\n [attr.readonly]=\"(readonly$ | async) === true ? true : null\"\r\n [attr.disabled]=\"(disable$ | async) === true ? true : null\"\r\n [type]=\"Setting.IsPassword ? 'password' : 'text'\"\r\n [type]=\"hasMask ? 'text' : 'number'\"\r\n [id]=\"id\"\r\n [style.direction]=\"'ltr'\"\r\n [style.text-align]=\"Setting.IsLtr === true ? 'left' : 'right'\"\r\n (keydown)=\"onKeyDown($event)\"\r\n (input)=\"onValueChange($event)\"\r\n/>\r\n", styles: [":host{display:block}.number-input{display:block}\n"], dependencies: [{ kind: "component", type: i1.FormControlComponent, selector: "[fd-form-control]", inputs: ["state", "type", "class"] }, { kind: "directive", type: i1.InputFormControlDirective, selector: "input[fd-form-control]" }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }] });
|
|
14
14
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: UiNumIntUiComponent, decorators: [{
|
|
15
15
|
type: Component,
|
|
16
|
-
args: [{ selector: 'bsu-ui-num-int-ui', template: "<input\r\n #inputRef\r\n fd-form-control\r\n [placeholder]=\"Setting.NullText || ''\"\r\n [attr.readonly]=\"(readonly$ | async) === true ? true : null\"\r\n [attr.disabled]=\"(disable$ | async) === true ? true : null\"\r\n [type]=\"Setting.IsPassword ? 'password' : 'text'\"\r\n [type]=\"hasMask ? 'text' : 'number'\"\r\n [id]=\"id\"\r\n [style.direction]=\"Setting.IsLtr === true ? '
|
|
16
|
+
args: [{ selector: 'bsu-ui-num-int-ui', template: "<input\r\n #inputRef\r\n fd-form-control\r\n [placeholder]=\"Setting.NullText || ''\"\r\n [attr.readonly]=\"(readonly$ | async) === true ? true : null\"\r\n [attr.disabled]=\"(disable$ | async) === true ? true : null\"\r\n [type]=\"Setting.IsPassword ? 'password' : 'text'\"\r\n [type]=\"hasMask ? 'text' : 'number'\"\r\n [id]=\"id\"\r\n [style.direction]=\"'ltr'\"\r\n [style.text-align]=\"Setting.IsLtr === true ? 'left' : 'right'\"\r\n (keydown)=\"onKeyDown($event)\"\r\n (input)=\"onValueChange($event)\"\r\n/>\r\n", styles: [":host{display:block}.number-input{display:block}\n"] }]
|
|
17
17
|
}], propDecorators: { inputRef: [{
|
|
18
18
|
type: ViewChild,
|
|
19
19
|
args: ['inputRef', { read: ElementRef, static: true }]
|
|
20
20
|
}] } });
|
|
21
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
21
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidWktbnVtLWludC11aS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9iYXJzYS1zYXAtdWkvc3JjL2xpYi91aS1udW0taW50LXVpL3VpLW51bS1pbnQtdWkuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2Etc2FwLXVpL3NyYy9saWIvdWktbnVtLWludC11aS91aS1udW0taW50LXVpLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsVUFBVSxFQUFVLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUV6RSxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQzs7OztBQU0zRCxNQUFNLE9BQU8sbUJBQW9CLFNBQVEsbUJBQW1CO0lBS3hELFFBQVE7UUFDSixJQUFJLENBQUMsWUFBWSxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUMsYUFBYSxDQUFDO1FBQ2hELEtBQUssQ0FBQyxRQUFRLEVBQUUsQ0FBQztJQUNyQixDQUFDOztnSEFSUSxtQkFBbUI7b0dBQW5CLG1CQUFtQiwwSUFDRyxVQUFVLGtFQ1Q3Qyw0aUJBY0E7MkZETmEsbUJBQW1CO2tCQUwvQixTQUFTOytCQUNJLG1CQUFtQjs4QkFNN0IsUUFBUTtzQkFEUCxTQUFTO3VCQUFDLFVBQVUsRUFBRSxFQUFFLElBQUksRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFFLElBQUksRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgRWxlbWVudFJlZiwgT25Jbml0LCBWaWV3Q2hpbGQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbmltcG9ydCB7IE51bWJlckJhc2VDb21wb25lbnQgfSBmcm9tICdiYXJzYS1ub3Zpbi1yYXktY29yZSc7XHJcbkBDb21wb25lbnQoe1xyXG4gICAgc2VsZWN0b3I6ICdic3UtdWktbnVtLWludC11aScsXHJcbiAgICB0ZW1wbGF0ZVVybDogJy4vdWktbnVtLWludC11aS5jb21wb25lbnQuaHRtbCcsXHJcbiAgICBzdHlsZVVybHM6IFsnLi91aS1udW0taW50LXVpLmNvbXBvbmVudC5zY3NzJ11cclxufSlcclxuZXhwb3J0IGNsYXNzIFVpTnVtSW50VWlDb21wb25lbnQgZXh0ZW5kcyBOdW1iZXJCYXNlQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcclxuICAgIEBWaWV3Q2hpbGQoJ2lucHV0UmVmJywgeyByZWFkOiBFbGVtZW50UmVmLCBzdGF0aWM6IHRydWUgfSlcclxuICAgIGlucHV0UmVmOiBFbGVtZW50UmVmO1xyXG4gICAgaW5wdXRFbGVtZW50OiBIVE1MSW5wdXRFbGVtZW50IHwgbnVsbCB8IHVuZGVmaW5lZDtcclxuXHJcbiAgICBuZ09uSW5pdCgpOiB2b2lkIHtcclxuICAgICAgICB0aGlzLmlucHV0RWxlbWVudCA9IHRoaXMuaW5wdXRSZWYubmF0aXZlRWxlbWVudDtcclxuICAgICAgICBzdXBlci5uZ09uSW5pdCgpO1xyXG4gICAgfVxyXG59XHJcbiIsIjxpbnB1dFxyXG4gICAgI2lucHV0UmVmXHJcbiAgICBmZC1mb3JtLWNvbnRyb2xcclxuICAgIFtwbGFjZWhvbGRlcl09XCJTZXR0aW5nLk51bGxUZXh0IHx8ICcnXCJcclxuICAgIFthdHRyLnJlYWRvbmx5XT1cIihyZWFkb25seSQgfCBhc3luYykgPT09IHRydWUgPyB0cnVlIDogbnVsbFwiXHJcbiAgICBbYXR0ci5kaXNhYmxlZF09XCIoZGlzYWJsZSQgfCBhc3luYykgPT09IHRydWUgPyB0cnVlIDogbnVsbFwiXHJcbiAgICBbdHlwZV09XCJTZXR0aW5nLklzUGFzc3dvcmQgPyAncGFzc3dvcmQnIDogJ3RleHQnXCJcclxuICAgIFt0eXBlXT1cImhhc01hc2sgPyAndGV4dCcgOiAnbnVtYmVyJ1wiXHJcbiAgICBbaWRdPVwiaWRcIlxyXG4gICAgW3N0eWxlLmRpcmVjdGlvbl09XCInbHRyJ1wiXHJcbiAgICBbc3R5bGUudGV4dC1hbGlnbl09XCJTZXR0aW5nLklzTHRyID09PSB0cnVlID8gJ2xlZnQnIDogJ3JpZ2h0J1wiXHJcbiAgICAoa2V5ZG93bik9XCJvbktleURvd24oJGV2ZW50KVwiXHJcbiAgICAoaW5wdXQpPVwib25WYWx1ZUNoYW5nZSgkZXZlbnQpXCJcclxuLz5cclxuIl19
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { ChangeDetectionStrategy, Component } from '@angular/core';
|
|
2
|
-
import {
|
|
2
|
+
import { takeUntil, tap } from 'rxjs/operators';
|
|
3
3
|
import { BarsaApi, UploadService, FilesValidationHelper, isImage, getImagePath, getIcon, getValidExtension } from 'barsa-novin-ray-core';
|
|
4
4
|
import { DeviceInfoFieldBaseComponent } from '../device-info-field-base';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
@@ -18,9 +18,7 @@ export class UiPdfViewerComponent extends DeviceInfoFieldBaseComponent {
|
|
|
18
18
|
this.canSave = true;
|
|
19
19
|
}
|
|
20
20
|
ngOnInit() {
|
|
21
|
-
this.
|
|
22
|
-
this.uploadState$ = this._uploadService.uploadState$;
|
|
23
|
-
this.uploading$ = this._uploadService.uploading$;
|
|
21
|
+
this.uploadingState$ = this._uploadService.uploadingState$;
|
|
24
22
|
super.ngOnInit();
|
|
25
23
|
this.value$.subscribe((value) => {
|
|
26
24
|
this.value = value;
|
|
@@ -33,7 +31,7 @@ export class UiPdfViewerComponent extends DeviceInfoFieldBaseComponent {
|
|
|
33
31
|
this._refreshButtons();
|
|
34
32
|
this._refresh();
|
|
35
33
|
this.validExtension = this.context.useWordEditor
|
|
36
|
-
? '.doc,.docx'
|
|
34
|
+
? '.doc,.docx,application/msword,application/vnd.openxmlformats-officedocument.wordprocessingml.document'
|
|
37
35
|
: getValidExtension(this.Setting.ValidExtensions);
|
|
38
36
|
this.singleControl = this.Setting.ViewType === 'SingleFileControl';
|
|
39
37
|
}
|
|
@@ -66,7 +64,7 @@ export class UiPdfViewerComponent extends DeviceInfoFieldBaseComponent {
|
|
|
66
64
|
DownloadFileId(fileId, viewInBrowser, convertTo, forOcx, isOfficeOnline) {
|
|
67
65
|
setTimeout(() => {
|
|
68
66
|
BarsaApi.Ul.LoadingMask.Mask(this._el.nativeElement);
|
|
69
|
-
},
|
|
67
|
+
}, 0);
|
|
70
68
|
BarsaApi.Common.File.DownloadFileContent.bind(this)({
|
|
71
69
|
fileId,
|
|
72
70
|
fileUrl: null,
|
|
@@ -76,10 +74,7 @@ export class UiPdfViewerComponent extends DeviceInfoFieldBaseComponent {
|
|
|
76
74
|
forOcx
|
|
77
75
|
}, (response) => {
|
|
78
76
|
if (response.succeed) {
|
|
79
|
-
|
|
80
|
-
const url = window.URL || window.webkitURL;
|
|
81
|
-
this.pdfSource = this._domSanitizer.bypassSecurityTrustResourceUrl(url.createObjectURL(blob));
|
|
82
|
-
this.hasPdf = true;
|
|
77
|
+
this._downloadFileIdCompleted(response);
|
|
83
78
|
this._cdr.detectChanges();
|
|
84
79
|
this._hideMask();
|
|
85
80
|
}
|
|
@@ -88,11 +83,15 @@ export class UiPdfViewerComponent extends DeviceInfoFieldBaseComponent {
|
|
|
88
83
|
alert(error);
|
|
89
84
|
});
|
|
90
85
|
}
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
86
|
+
_downloadFileIdCompleted(response) {
|
|
87
|
+
const blob = BarsaApi.Common.File.B64toBlob(response.content, response.contentType);
|
|
88
|
+
const url = window.URL || window.webkitURL;
|
|
89
|
+
this.valueUrl = this._domSanitizer.bypassSecurityTrustResourceUrl(url.createObjectURL(blob));
|
|
90
|
+
this.hasPdf = true;
|
|
91
|
+
}
|
|
92
|
+
_uploadToServer(files) {
|
|
93
|
+
this.filesValidationHelper.validateFiles(files);
|
|
94
|
+
this._uploadFile(files).pipe(takeUntil(this._onDestroy$)).subscribe();
|
|
96
95
|
}
|
|
97
96
|
_refreshButtons() {
|
|
98
97
|
this._refreshButtonsHelper(false);
|
|
@@ -146,7 +145,7 @@ export class UiPdfViewerComponent extends DeviceInfoFieldBaseComponent {
|
|
|
146
145
|
}
|
|
147
146
|
return;
|
|
148
147
|
}
|
|
149
|
-
this.fallbackLink = `امکان نمایش فایل در این مرورگر وجود ندارد.
|
|
148
|
+
this.fallbackLink = `امکان نمایش فایل در این مرورگر وجود ندارد.
|
|
150
149
|
برای باز کردن فایل از لینک زیر استفاده کنید: </br> <a href='${BarsaApi.Common.File.CreateAttachmentUrl(fileId, false, true)}'>دانلود فایل بصورت pdf</a> </br> <a href='${BarsaApi.Common.File.CreateAttachmentUrl(fileId, false, false)}'>دانلود فایل بصورت بصورت اصلی</a>`;
|
|
151
150
|
if (!BarsaApi.Ext.isIE) {
|
|
152
151
|
// const options = {
|
|
@@ -204,13 +203,13 @@ export class UiPdfViewerComponent extends DeviceInfoFieldBaseComponent {
|
|
|
204
203
|
_hideMask() {
|
|
205
204
|
setTimeout(() => {
|
|
206
205
|
BarsaApi.Ul.LoadingMask.Unmask(this._el.nativeElement);
|
|
207
|
-
},
|
|
206
|
+
}, 0);
|
|
208
207
|
}
|
|
209
208
|
}
|
|
210
209
|
UiPdfViewerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: UiPdfViewerComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
211
|
-
UiPdfViewerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: UiPdfViewerComponent, selector: "bsu-ui-pdf-viewer", providers: [UploadService], usesInheritance: true, ngImport: i0, template: "<ng-container *untilInView=\"el\">\r\n <fd-toolbar [transparent]=\"true\" [shouldOverflow]=\"true\">\r\n <fd-file-uploader\r\n #uploader\r\n [style.display]=\"'none'\"\r\n fd-toolbar-item\r\n [id]=\"id\"\r\n [name]=\"'pdf_' + id\"\r\n [placeholder]=\"'AttachFile' | bbbTranslate\"\r\n [buttonLabel]=\"'AttachFile' | bbbTranslate\"\r\n [buttonAriaLabel]=\"'AttachFile' | bbbTranslate\"\r\n [accept]=\"validExtension\"\r\n [(ngModel)]=\"files\"\r\n [multiple]=\"false\"\r\n (selectedFilesChanged)=\"onFileSelection($event)\"\r\n [contentDensity]=\"(contentDensity$ | async)!!\"\r\n ></fd-file-uploader>\r\n <button\r\n fd-button\r\n fd-toolbar-item\r\n glyph=\"attachment\"\r\n [fdType]=\"'transparent'\"\r\n [disabled]=\"!canUpload\"\r\n (click)=\"uploader.open()\"\r\n ></button>\r\n <button\r\n [disabled]=\"!(canDelete && value)\"\r\n fd-button\r\n fd-toolbar-item\r\n class=\"delete\"\r\n glyph=\"delete\"\r\n [fdType]=\"'transparent'\"\r\n (click)=\"onDelete()\"\r\n ></button>\r\n <button\r\n *ngIf=\"canEdit\"\r\n fd-toolbar-item\r\n fd-button\r\n glyph=\"edit\"\r\n [fdType]=\"'transparent'\"\r\n (click)=\"onEdit()\"\r\n ></button>\r\n <button\r\n *ngIf=\"canDownload\"\r\n fd-toolbar-item\r\n fd-button\r\n glyph=\"download\"\r\n [fdType]=\"'transparent'\"\r\n (click)=\"onDownload()\"\r\n ></button>\r\n\r\n <button\r\n *ngIf=\"useWordEditor\"\r\n fd-toolbar-item\r\n fd-button\r\n glyph=\"doc-attachment\"\r\n [fdType]=\"'transparent'\"\r\n [label]=\"'EditInWord' | bbbTranslate\"\r\n (click)=\"onEditInWord()\"\r\n ></button>\r\n <button\r\n *ngIf=\"officeOnline\"\r\n fd-toolbar-item\r\n fd-button\r\n glyph=\"doc-attachment\"\r\n [fdType]=\"'transparent'\"\r\n [label]=\"'OfficeOnline' | bbbTranslate\"\r\n (click)=\"onOfficeOnline($event)\"\r\n ></button>\r\n <button fd-toolbar-item fd-button glyph=\"refresh\" [fdType]=\"'transparent'\" (click)=\"onRefresh()\"></button>\r\n\r\n <fd-busy-indicator
|
|
210
|
+
UiPdfViewerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: UiPdfViewerComponent, selector: "bsu-ui-pdf-viewer", providers: [UploadService], usesInheritance: true, ngImport: i0, template: "<ng-container *untilInView=\"el\">\r\n <fd-toolbar [transparent]=\"true\" [shouldOverflow]=\"true\">\r\n <fd-file-uploader\r\n #uploader\r\n [style.display]=\"'none'\"\r\n fd-toolbar-item\r\n [id]=\"id\"\r\n [name]=\"'pdf_' + id\"\r\n [placeholder]=\"'AttachFile' | bbbTranslate\"\r\n [buttonLabel]=\"'AttachFile' | bbbTranslate\"\r\n [buttonAriaLabel]=\"'AttachFile' | bbbTranslate\"\r\n [accept]=\"validExtension\"\r\n [(ngModel)]=\"files\"\r\n [multiple]=\"false\"\r\n (selectedFilesChanged)=\"onFileSelection($event)\"\r\n [contentDensity]=\"(contentDensity$ | async)!!\"\r\n ></fd-file-uploader>\r\n <button\r\n fd-button\r\n fd-toolbar-item\r\n glyph=\"attachment\"\r\n [fdType]=\"'transparent'\"\r\n [disabled]=\"!canUpload\"\r\n (click)=\"uploader.open()\"\r\n ></button>\r\n <button\r\n [disabled]=\"!(canDelete && value)\"\r\n fd-button\r\n fd-toolbar-item\r\n class=\"delete\"\r\n glyph=\"delete\"\r\n [fdType]=\"'transparent'\"\r\n (click)=\"onDelete()\"\r\n ></button>\r\n <button\r\n *ngIf=\"canEdit\"\r\n fd-toolbar-item\r\n fd-button\r\n glyph=\"edit\"\r\n [fdType]=\"'transparent'\"\r\n (click)=\"onEdit()\"\r\n ></button>\r\n <button\r\n *ngIf=\"canDownload\"\r\n fd-toolbar-item\r\n fd-button\r\n glyph=\"download\"\r\n [fdType]=\"'transparent'\"\r\n (click)=\"onDownload()\"\r\n ></button>\r\n\r\n <button\r\n *ngIf=\"useWordEditor\"\r\n fd-toolbar-item\r\n fd-button\r\n glyph=\"doc-attachment\"\r\n [fdType]=\"'transparent'\"\r\n [label]=\"'EditInWord' | bbbTranslate\"\r\n (click)=\"onEditInWord()\"\r\n ></button>\r\n <button\r\n *ngIf=\"officeOnline\"\r\n fd-toolbar-item\r\n fd-button\r\n glyph=\"doc-attachment\"\r\n [fdType]=\"'transparent'\"\r\n [label]=\"'OfficeOnline' | bbbTranslate\"\r\n (click)=\"onOfficeOnline($event)\"\r\n ></button>\r\n <button fd-toolbar-item fd-button glyph=\"refresh\" [fdType]=\"'transparent'\" (click)=\"onRefresh()\"></button>\r\n\r\n <fd-busy-indicator\r\n fd-toolbar-item\r\n [loading]=\"(uploadingState$ | async)?.uploading === true\"\r\n ></fd-busy-indicator>\r\n </fd-toolbar>\r\n <object\r\n *ngIf=\"hasPdf; else HatchBackground\"\r\n style=\"flex-grow: 1\"\r\n [attr.data]=\"valueUrl\"\r\n type=\"application/pdf\"\r\n width=\"100%\"\r\n height=\"100%\"\r\n [attr.html]=\"fallbackLink\"\r\n ></object>\r\n <ng-template #HatchBackground>\r\n <ng-container *ngIf=\"singleControl && value && !value.IsDeleted; else noFile\">\r\n <div style=\"display: flex\">\r\n <img *ngIf=\"singleFileThumbnailUrl\" [src]=\"singleFileThumbnailUrl\" />\r\n <fd-object-identifier>\r\n {{ value.FileName }}\r\n </fd-object-identifier>\r\n </div>\r\n </ng-container>\r\n <ng-template #noFile>\r\n <div class=\"hatchBackground\"></div>\r\n </ng-template>\r\n </ng-template>\r\n</ng-container>\r\n", styles: [":host{display:flex;flex-direction:column;min-height:calc(100vh - 250px)}:host ::ng-deep .delete button{border-color:transparent!important;background-color:transparent!important}:host ::ng-deep .fd-file-uploader input{display:none}.single-control{height:50px}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i3.UntilInViewDirective, selector: "[untilInView]", inputs: ["untilInView", "intersectionDebounce"] }, { kind: "component", type: i4.BusyIndicatorComponent, selector: "fd-busy-indicator", inputs: ["loading", "size", "block", "ariaLabel", "title", "label", "ariaLive"] }, { kind: "component", type: i5.ButtonComponent, selector: "button[fd-button], a[fd-button]", inputs: ["class"], exportAs: ["fd-button"] }, { kind: "component", type: i6.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: i7.ObjectIdentifierComponent, selector: "fd-object-identifier", inputs: ["description", "bold", "medium"] }, { 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: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i3.BbbTranslatePipe, name: "bbbTranslate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
212
211
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: UiPdfViewerComponent, decorators: [{
|
|
213
212
|
type: Component,
|
|
214
|
-
args: [{ selector: 'bsu-ui-pdf-viewer', providers: [UploadService], changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *untilInView=\"el\">\r\n <fd-toolbar [transparent]=\"true\" [shouldOverflow]=\"true\">\r\n <fd-file-uploader\r\n #uploader\r\n [style.display]=\"'none'\"\r\n fd-toolbar-item\r\n [id]=\"id\"\r\n [name]=\"'pdf_' + id\"\r\n [placeholder]=\"'AttachFile' | bbbTranslate\"\r\n [buttonLabel]=\"'AttachFile' | bbbTranslate\"\r\n [buttonAriaLabel]=\"'AttachFile' | bbbTranslate\"\r\n [accept]=\"validExtension\"\r\n [(ngModel)]=\"files\"\r\n [multiple]=\"false\"\r\n (selectedFilesChanged)=\"onFileSelection($event)\"\r\n [contentDensity]=\"(contentDensity$ | async)!!\"\r\n ></fd-file-uploader>\r\n <button\r\n fd-button\r\n fd-toolbar-item\r\n glyph=\"attachment\"\r\n [fdType]=\"'transparent'\"\r\n [disabled]=\"!canUpload\"\r\n (click)=\"uploader.open()\"\r\n ></button>\r\n <button\r\n [disabled]=\"!(canDelete && value)\"\r\n fd-button\r\n fd-toolbar-item\r\n class=\"delete\"\r\n glyph=\"delete\"\r\n [fdType]=\"'transparent'\"\r\n (click)=\"onDelete()\"\r\n ></button>\r\n <button\r\n *ngIf=\"canEdit\"\r\n fd-toolbar-item\r\n fd-button\r\n glyph=\"edit\"\r\n [fdType]=\"'transparent'\"\r\n (click)=\"onEdit()\"\r\n ></button>\r\n <button\r\n *ngIf=\"canDownload\"\r\n fd-toolbar-item\r\n fd-button\r\n glyph=\"download\"\r\n [fdType]=\"'transparent'\"\r\n (click)=\"onDownload()\"\r\n ></button>\r\n\r\n <button\r\n *ngIf=\"useWordEditor\"\r\n fd-toolbar-item\r\n fd-button\r\n glyph=\"doc-attachment\"\r\n [fdType]=\"'transparent'\"\r\n [label]=\"'EditInWord' | bbbTranslate\"\r\n (click)=\"onEditInWord()\"\r\n ></button>\r\n <button\r\n *ngIf=\"officeOnline\"\r\n fd-toolbar-item\r\n fd-button\r\n glyph=\"doc-attachment\"\r\n [fdType]=\"'transparent'\"\r\n [label]=\"'OfficeOnline' | bbbTranslate\"\r\n (click)=\"onOfficeOnline($event)\"\r\n ></button>\r\n <button fd-toolbar-item fd-button glyph=\"refresh\" [fdType]=\"'transparent'\" (click)=\"onRefresh()\"></button>\r\n\r\n <fd-busy-indicator
|
|
213
|
+
args: [{ selector: 'bsu-ui-pdf-viewer', providers: [UploadService], changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *untilInView=\"el\">\r\n <fd-toolbar [transparent]=\"true\" [shouldOverflow]=\"true\">\r\n <fd-file-uploader\r\n #uploader\r\n [style.display]=\"'none'\"\r\n fd-toolbar-item\r\n [id]=\"id\"\r\n [name]=\"'pdf_' + id\"\r\n [placeholder]=\"'AttachFile' | bbbTranslate\"\r\n [buttonLabel]=\"'AttachFile' | bbbTranslate\"\r\n [buttonAriaLabel]=\"'AttachFile' | bbbTranslate\"\r\n [accept]=\"validExtension\"\r\n [(ngModel)]=\"files\"\r\n [multiple]=\"false\"\r\n (selectedFilesChanged)=\"onFileSelection($event)\"\r\n [contentDensity]=\"(contentDensity$ | async)!!\"\r\n ></fd-file-uploader>\r\n <button\r\n fd-button\r\n fd-toolbar-item\r\n glyph=\"attachment\"\r\n [fdType]=\"'transparent'\"\r\n [disabled]=\"!canUpload\"\r\n (click)=\"uploader.open()\"\r\n ></button>\r\n <button\r\n [disabled]=\"!(canDelete && value)\"\r\n fd-button\r\n fd-toolbar-item\r\n class=\"delete\"\r\n glyph=\"delete\"\r\n [fdType]=\"'transparent'\"\r\n (click)=\"onDelete()\"\r\n ></button>\r\n <button\r\n *ngIf=\"canEdit\"\r\n fd-toolbar-item\r\n fd-button\r\n glyph=\"edit\"\r\n [fdType]=\"'transparent'\"\r\n (click)=\"onEdit()\"\r\n ></button>\r\n <button\r\n *ngIf=\"canDownload\"\r\n fd-toolbar-item\r\n fd-button\r\n glyph=\"download\"\r\n [fdType]=\"'transparent'\"\r\n (click)=\"onDownload()\"\r\n ></button>\r\n\r\n <button\r\n *ngIf=\"useWordEditor\"\r\n fd-toolbar-item\r\n fd-button\r\n glyph=\"doc-attachment\"\r\n [fdType]=\"'transparent'\"\r\n [label]=\"'EditInWord' | bbbTranslate\"\r\n (click)=\"onEditInWord()\"\r\n ></button>\r\n <button\r\n *ngIf=\"officeOnline\"\r\n fd-toolbar-item\r\n fd-button\r\n glyph=\"doc-attachment\"\r\n [fdType]=\"'transparent'\"\r\n [label]=\"'OfficeOnline' | bbbTranslate\"\r\n (click)=\"onOfficeOnline($event)\"\r\n ></button>\r\n <button fd-toolbar-item fd-button glyph=\"refresh\" [fdType]=\"'transparent'\" (click)=\"onRefresh()\"></button>\r\n\r\n <fd-busy-indicator\r\n fd-toolbar-item\r\n [loading]=\"(uploadingState$ | async)?.uploading === true\"\r\n ></fd-busy-indicator>\r\n </fd-toolbar>\r\n <object\r\n *ngIf=\"hasPdf; else HatchBackground\"\r\n style=\"flex-grow: 1\"\r\n [attr.data]=\"valueUrl\"\r\n type=\"application/pdf\"\r\n width=\"100%\"\r\n height=\"100%\"\r\n [attr.html]=\"fallbackLink\"\r\n ></object>\r\n <ng-template #HatchBackground>\r\n <ng-container *ngIf=\"singleControl && value && !value.IsDeleted; else noFile\">\r\n <div style=\"display: flex\">\r\n <img *ngIf=\"singleFileThumbnailUrl\" [src]=\"singleFileThumbnailUrl\" />\r\n <fd-object-identifier>\r\n {{ value.FileName }}\r\n </fd-object-identifier>\r\n </div>\r\n </ng-container>\r\n <ng-template #noFile>\r\n <div class=\"hatchBackground\"></div>\r\n </ng-template>\r\n </ng-template>\r\n</ng-container>\r\n", styles: [":host{display:flex;flex-direction:column;min-height:calc(100vh - 250px)}:host ::ng-deep .delete button{border-color:transparent!important;background-color:transparent!important}:host ::ng-deep .fd-file-uploader input{display:none}.single-control{height:50px}\n"] }]
|
|
215
214
|
}] });
|
|
216
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ui-pdf-viewer.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-sap-ui/src/lib/ui-pdf-viewer/ui-pdf-viewer.component.ts","../../../../../projects/barsa-sap-ui/src/lib/ui-pdf-viewer/ui-pdf-viewer.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, OnInit } from '@angular/core';\nimport { SafeResourceUrl } from '@angular/platform-browser';\nimport { Observable } from 'rxjs';\nimport { exhaustMap, filter, takeUntil, tap } from 'rxjs/operators';\nimport { ContentDensity } from '@fundamental-ngx/core';\nimport {\n    BarsaApi,\n    UploadService,\n    FilesValidationHelper,\n    isImage,\n    getImagePath,\n    getIcon,\n    getValidExtension\n} from 'barsa-novin-ray-core';\nimport { DeviceInfoFieldBaseComponent } from '../device-info-field-base';\n\n@Component({\n    selector: 'bsu-ui-pdf-viewer',\n    templateUrl: './ui-pdf-viewer.component.html',\n    styleUrls: ['./ui-pdf-viewer.component.scss'],\n    providers: [UploadService],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class UiPdfViewerComponent extends DeviceInfoFieldBaseComponent implements OnInit {\n    fileName: string;\n    fallbackLink: any;\n    canNotRenderPdf: boolean;\n    pdfSource: SafeResourceUrl;\n    hasPdf: boolean;\n    pdfObject: {\n        autoEl: {\n            tag: string;\n            data: string;\n            type: string;\n            width: string;\n            height: string;\n            html: any;\n        };\n    };\n\n    uploadState$: Observable<string>;\n    progress$: Observable<any>;\n    uploading$: Observable<boolean>;\n    files: File[];\n    contentDensity$: Observable<ContentDensity>;\n    officeOnline: any;\n    useWordEditor: any;\n    hasFileName: boolean;\n    canRemove: boolean;\n    canUpload: boolean;\n    canEdit: boolean;\n    canDownload: boolean;\n    canDelete = true;\n    canSave = true;\n    validExtension: string;\n    filesValidationHelper: FilesValidationHelper;\n    singleControl: boolean;\n    singleFileThumbnailUrl: string;\n\n    ngOnInit(): void {\n        this.progress$ = this._uploadService.progress$;\n        this.uploadState$ = this._uploadService.uploadState$;\n        this.uploading$ = this._uploadService.uploading$;\n        super.ngOnInit();\n        this.value$.subscribe((value) => {\n            this.value = value;\n            this._refresh();\n        });\n        this.refresh$.subscribe((fromServer: boolean) => {\n            this._refresh(fromServer);\n        });\n        this.filesValidationHelper = new FilesValidationHelper(\n            this.Setting.MaxFileCount,\n            this.Setting.MaxFileSizeKb,\n            this.Setting.MaxTotalFileSizeKb\n        );\n        this._refreshButtons();\n        this._refresh();\n        this.validExtension = this.context.useWordEditor\n            ? '.doc,.docx'\n            : getValidExtension(this.Setting.ValidExtensions);\n        this.singleControl = this.Setting.ViewType === 'SingleFileControl';\n    }\n    onEdit(): void {\n        this._commandClickHandler('Edit');\n    }\n    onView(event: MouseEvent): void {\n        const e = { ctrlKey: event.ctrlKey };\n        this._commandClickHandler('OOView', e);\n    }\n    onDownload(): void {\n        this._commandClickHandler('Download');\n    }\n    onFileSelection(files: File[]): void {\n        this._uploadToServer(files);\n    }\n    onDelete(): void {\n        this._commandClickHandler('Delete');\n    }\n    onEditInWord(): void {\n        this._commandClickHandler('ODEdit');\n    }\n    onOfficeOnline(event: MouseEvent): void {\n        const e = { ctrlKey: event.ctrlKey };\n\n        this._commandClickHandler('OOEdit', e);\n    }\n    onRefresh(): void {\n        this._commandClickHandler('Refresh');\n    }\n    DownloadFileId(fileId, viewInBrowser, convertTo, forOcx, isOfficeOnline): void {\n        setTimeout(() => {\n            BarsaApi.Ul.LoadingMask.Mask(this._el.nativeElement);\n        }, 30);\n\n        BarsaApi.Common.File.DownloadFileContent.bind(this)(\n            {\n                fileId,\n                fileUrl: null,\n                viewInBrowser,\n                convertTo,\n                isOfficeOnline,\n                forOcx\n            },\n            (response) => {\n                if (response.succeed) {\n                    const blob = BarsaApi.Common.File.B64toBlob(response.content, response.contentType);\n                    const url = window.URL || window.webkitURL;\n                    this.pdfSource = this._domSanitizer.bypassSecurityTrustResourceUrl(url.createObjectURL(blob));\n                    this.hasPdf = true;\n                    this._cdr.detectChanges();\n                    this._hideMask();\n                }\n            },\n            (error) => {\n                this._hideMask();\n                alert(error);\n            }\n        );\n    }\n    protected _uploadToServer(selectedFiles: File[]): void {\n        this.filesValidationHelper\n            .validateFiles(selectedFiles)\n            .pipe(\n                takeUntil(this._onDestroy$),\n                filter((files) => files.length > 0),\n                exhaustMap((files: File[]) => this._uploadFile(files))\n            )\n            .subscribe();\n    }\n\n    protected _refreshButtons(): void {\n        this._refreshButtonsHelper(false);\n        BarsaApi.Common.Async.Waterfall(\n            'Common.File.IsAgentActive',\n            [\n                // Common.FileAgent.IsAgentActive.bind(Common.FileAgent),\n                BarsaApi.Common.AgentHelper.Init.bind(BarsaApi.Common.AgentHelper)\n            ],\n            (err, result) => {\n                const agentIsActive = result === 'OK';\n                this._refreshButtonsHelper(agentIsActive);\n            }\n        );\n    }\n    protected _refreshButtonsHelper(isAgentActive): void {\n        this.disableOrReadonly$.subscribe((disableOrReadonly) => {\n            const canSave = this.canSave;\n            this.canDelete = !disableOrReadonly;\n            const hasValue = !BarsaApi.Ext.isEmpty(this.value);\n            const edit0 = canSave && disableOrReadonly !== true;\n            this.canEdit = edit0 && isAgentActive;\n            this.canDownload = !this.Setting.IsWordViewer || (!isAgentActive && edit0);\n            this.canUpload = this.canDownload && canSave && disableOrReadonly !== true;\n            this.hasFileName = !this.context.Setting.IsWordViewer;\n            this.canRemove = this.canDownload && canSave && disableOrReadonly !== true;\n\n            this.officeOnline = hasValue && canSave && disableOrReadonly !== true && this.context.OfficeOnline;\n            this.useWordEditor = hasValue && canSave && disableOrReadonly !== true && this.context.useWordEditor;\n        });\n    }\n    protected _commandClickHandler(itemId, keyboardEvent?): void {\n        const commandId = itemId;\n\n        let files = this.value;\n        if (BarsaApi.Ext.isArray(files)) {\n            files = files[0];\n        }\n\n        const fileId = files?.Id;\n        this.context.fireEvent('CommandRequest', this, commandId, fileId, keyboardEvent);\n    }\n    protected _refresh(fromServer?: boolean): void {\n        const officeOnline = fromServer === false;\n\n        this.fileName = '';\n\n        if (BarsaApi.Ext.isEmpty(this.value)) {\n            this.hasPdf = false;\n            return;\n        }\n\n        let files = this.value;\n        if (BarsaApi.Ext.isArray(files)) {\n            files = files[0];\n        }\n\n        const fileId = files.Id;\n        if (!fileId || files.IsDeleted) {\n            if (files.IsDeleted) {\n                this.hasPdf = false;\n            }\n            return;\n        }\n        this.fallbackLink = `امکان نمایش فایل در این مرورگر وجود ندارد.\n         برای باز کردن فایل از لینک زیر استفاده کنید:  </br> <a href='${BarsaApi.Common.File.CreateAttachmentUrl(\n             fileId,\n             false,\n             true\n         )}'>دانلود فایل بصورت pdf</a>  </br>  <a href='${BarsaApi.Common.File.CreateAttachmentUrl(\n            fileId,\n            false,\n            false\n        )}'>دانلود فایل بصورت بصورت اصلی</a>`;\n\n        if (!BarsaApi.Ext.isIE) {\n            // const options = {\n            //     fallbackLink: this.fallbackLink,\n            //     pdfOpenParams: {\n            //         view: 'FitH',\n            //         scrollbar: '0',\n            //         toolbar: '0',\n            //         statusbar: '0',\n            //         messages: '0',\n            //         navpanes: '0'\n            //     }\n            // };\n            let convertTo = isImage(files.Type) ? files.Type : '';\n            convertTo = 'pdf,doc,docx,word'.indexOf(files.Type) > -1 ? 'pdf' : convertTo;\n\n            if (!convertTo) {\n                this.singleControl = true;\n                this.updateSingleControl(files);\n                return;\n            }\n            this.singleControl = false;\n\n            this.DownloadFileId(fileId, true, convertTo, null, officeOnline);\n        } else {\n            // const url = Common.File.CreateAttachmentUrl(fileId, false);\n            this.canNotRenderPdf = true;\n        }\n    }\n\n    protected _uploadFile(files: File[]): Observable<any> {\n        const formData = new FormData();\n        files.forEach((file) => {\n            formData.append('unicFileName', 'x' + BarsaApi.Common.Util.GetNewMetaGuid() + ';;;' + file.name);\n            formData.append('file', file);\n        });\n\n        return this._uploadService.upload(formData, this.Setting.ControlFieldDefId).pipe(\n            tap((res) => {\n                if (Array.isArray(res)) {\n                    this._updateValue(res);\n                }\n            })\n        );\n    }\n\n    protected _updateValue(res: any[]): void {\n        if (this.Setting.ViewType !== 'LinearListBox') {\n            this.updateSingleControl(res[0]);\n        }\n        this.fireContextEvent('Change', this.context, res);\n    }\n\n    private updateSingleControl(val: any): void {\n        if (isImage(val.Type)) {\n            this.singleFileThumbnailUrl = getImagePath('ID', '', val.Id);\n        } else {\n            this.singleFileThumbnailUrl = getIcon(val.Type);\n        }\n    }\n    private _hideMask(): void {\n        setTimeout(() => {\n            BarsaApi.Ul.LoadingMask.Unmask(this._el.nativeElement);\n        }, 30);\n    }\n}\n","<ng-container *untilInView=\"el\">\r\n    <fd-toolbar [transparent]=\"true\" [shouldOverflow]=\"true\">\r\n        <fd-file-uploader\r\n            #uploader\r\n            [style.display]=\"'none'\"\r\n            fd-toolbar-item\r\n            [id]=\"id\"\r\n            [name]=\"'pdf_' + id\"\r\n            [placeholder]=\"'AttachFile' | bbbTranslate\"\r\n            [buttonLabel]=\"'AttachFile' | bbbTranslate\"\r\n            [buttonAriaLabel]=\"'AttachFile' | bbbTranslate\"\r\n            [accept]=\"validExtension\"\r\n            [(ngModel)]=\"files\"\r\n            [multiple]=\"false\"\r\n            (selectedFilesChanged)=\"onFileSelection($event)\"\r\n            [contentDensity]=\"(contentDensity$ | async)!!\"\r\n        ></fd-file-uploader>\r\n        <button\r\n            fd-button\r\n            fd-toolbar-item\r\n            glyph=\"attachment\"\r\n            [fdType]=\"'transparent'\"\r\n            [disabled]=\"!canUpload\"\r\n            (click)=\"uploader.open()\"\r\n        ></button>\r\n        <button\r\n            [disabled]=\"!(canDelete && value)\"\r\n            fd-button\r\n            fd-toolbar-item\r\n            class=\"delete\"\r\n            glyph=\"delete\"\r\n            [fdType]=\"'transparent'\"\r\n            (click)=\"onDelete()\"\r\n        ></button>\r\n        <button\r\n            *ngIf=\"canEdit\"\r\n            fd-toolbar-item\r\n            fd-button\r\n            glyph=\"edit\"\r\n            [fdType]=\"'transparent'\"\r\n            (click)=\"onEdit()\"\r\n        ></button>\r\n        <button\r\n            *ngIf=\"canDownload\"\r\n            fd-toolbar-item\r\n            fd-button\r\n            glyph=\"download\"\r\n            [fdType]=\"'transparent'\"\r\n            (click)=\"onDownload()\"\r\n        ></button>\r\n\r\n        <button\r\n            *ngIf=\"useWordEditor\"\r\n            fd-toolbar-item\r\n            fd-button\r\n            glyph=\"doc-attachment\"\r\n            [fdType]=\"'transparent'\"\r\n            [label]=\"'EditInWord' | bbbTranslate\"\r\n            (click)=\"onEditInWord()\"\r\n        ></button>\r\n        <button\r\n            *ngIf=\"officeOnline\"\r\n            fd-toolbar-item\r\n            fd-button\r\n            glyph=\"doc-attachment\"\r\n            [fdType]=\"'transparent'\"\r\n            [label]=\"'OfficeOnline' | bbbTranslate\"\r\n            (click)=\"onOfficeOnline($event)\"\r\n        ></button>\r\n        <button fd-toolbar-item fd-button glyph=\"refresh\" [fdType]=\"'transparent'\" (click)=\"onRefresh()\"></button>\r\n\r\n        <fd-busy-indicator fd-toolbar-item [loading]=\"(uploading$ | async)!!\"></fd-busy-indicator>\r\n    </fd-toolbar>\r\n    <object\r\n        *ngIf=\"hasPdf; else HatchBackground\"\r\n        style=\"flex-grow: 1\"\r\n        [attr.data]=\"pdfSource\"\r\n        type=\"application/pdf\"\r\n        width=\"100%\"\r\n        height=\"100%\"\r\n        [attr.html]=\"fallbackLink\"\r\n    ></object>\r\n    <ng-template #HatchBackground>\r\n        <ng-container *ngIf=\"singleControl && value && !value.IsDeleted; else noFile\">\r\n            <div style=\"display: flex\">\r\n                <img *ngIf=\"singleFileThumbnailUrl\" [src]=\"singleFileThumbnailUrl\" />\r\n                <fd-object-identifier>\r\n                    {{ value.FileName }}\r\n                </fd-object-identifier>\r\n            </div>\r\n        </ng-container>\r\n        <ng-template #noFile>\r\n            <div class=\"hatchBackground\"></div>\r\n        </ng-template>\r\n    </ng-template>\r\n</ng-container>\r\n"]}
|
|
215
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ui-pdf-viewer.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-sap-ui/src/lib/ui-pdf-viewer/ui-pdf-viewer.component.ts","../../../../../projects/barsa-sap-ui/src/lib/ui-pdf-viewer/ui-pdf-viewer.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, OnInit } from '@angular/core';\r\nimport { SafeResourceUrl } from '@angular/platform-browser';\r\nimport { Observable } from 'rxjs';\r\nimport { takeUntil, tap } from 'rxjs/operators';\r\nimport { ContentDensity } from '@fundamental-ngx/core';\r\nimport {\r\n    BarsaApi,\r\n    UploadService,\r\n    FilesValidationHelper,\r\n    isImage,\r\n    getImagePath,\r\n    getIcon,\r\n    getValidExtension,\r\n    IUploadingState\r\n} from 'barsa-novin-ray-core';\r\nimport { DeviceInfoFieldBaseComponent } from '../device-info-field-base';\r\n\r\n@Component({\r\n    selector: 'bsu-ui-pdf-viewer',\r\n    templateUrl: './ui-pdf-viewer.component.html',\r\n    styleUrls: ['./ui-pdf-viewer.component.scss'],\r\n    providers: [UploadService],\r\n    changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class UiPdfViewerComponent extends DeviceInfoFieldBaseComponent implements OnInit {\r\n    fileName: string;\r\n    fallbackLink: any;\r\n    canNotRenderPdf: boolean;\r\n    valueUrl: SafeResourceUrl | null;\r\n    hasPdf: boolean;\r\n    pdfObject: {\r\n        autoEl: {\r\n            tag: string;\r\n            data: string;\r\n            type: string;\r\n            width: string;\r\n            height: string;\r\n            html: any;\r\n        };\r\n    };\r\n\r\n    uploadingState$: Observable<IUploadingState>;\r\n    files: File[];\r\n    contentDensity$: Observable<ContentDensity>;\r\n    officeOnline: any;\r\n    useWordEditor: any;\r\n    hasFileName: boolean;\r\n    canRemove: boolean;\r\n    canUpload: boolean;\r\n    canEdit: boolean;\r\n    canDownload: boolean;\r\n    canDelete = true;\r\n    canSave = true;\r\n    validExtension: string;\r\n    filesValidationHelper: FilesValidationHelper;\r\n    singleControl: boolean;\r\n    singleFileThumbnailUrl: string;\r\n\r\n    ngOnInit(): void {\r\n        this.uploadingState$ = this._uploadService.uploadingState$;\r\n        super.ngOnInit();\r\n        this.value$.subscribe((value) => {\r\n            this.value = value;\r\n            this._refresh();\r\n        });\r\n        this.refresh$.subscribe((fromServer: boolean) => {\r\n            this._refresh(fromServer);\r\n        });\r\n        this.filesValidationHelper = new FilesValidationHelper(\r\n            this.Setting.MaxFileCount,\r\n            this.Setting.MaxFileSizeKb,\r\n            this.Setting.MaxTotalFileSizeKb\r\n        );\r\n        this._refreshButtons();\r\n        this._refresh();\r\n        this.validExtension = this.context.useWordEditor\r\n            ? '.doc,.docx,application/msword,application/vnd.openxmlformats-officedocument.wordprocessingml.document'\r\n            : getValidExtension(this.Setting.ValidExtensions);\r\n        this.singleControl = this.Setting.ViewType === 'SingleFileControl';\r\n    }\r\n    onEdit(): void {\r\n        this._commandClickHandler('Edit');\r\n    }\r\n    onView(event: MouseEvent): void {\r\n        const e = { ctrlKey: event.ctrlKey };\r\n        this._commandClickHandler('OOView', e);\r\n    }\r\n    onDownload(): void {\r\n        this._commandClickHandler('Download');\r\n    }\r\n    onFileSelection(files: File[]): void {\r\n        this._uploadToServer(files);\r\n    }\r\n    onDelete(): void {\r\n        this._commandClickHandler('Delete');\r\n    }\r\n    onEditInWord(): void {\r\n        this._commandClickHandler('ODEdit');\r\n    }\r\n    onOfficeOnline(event: MouseEvent): void {\r\n        const e = { ctrlKey: event.ctrlKey };\r\n\r\n        this._commandClickHandler('OOEdit', e);\r\n    }\r\n    onRefresh(): void {\r\n        this._commandClickHandler('Refresh');\r\n    }\r\n    DownloadFileId(fileId, viewInBrowser, convertTo, forOcx, isOfficeOnline): void {\r\n        setTimeout(() => {\r\n            BarsaApi.Ul.LoadingMask.Mask(this._el.nativeElement);\r\n        }, 0);\r\n\r\n        BarsaApi.Common.File.DownloadFileContent.bind(this)(\r\n            {\r\n                fileId,\r\n                fileUrl: null,\r\n                viewInBrowser,\r\n                convertTo,\r\n                isOfficeOnline,\r\n                forOcx\r\n            },\r\n            (response) => {\r\n                if (response.succeed) {\r\n                    this._downloadFileIdCompleted(response);\r\n                    this._cdr.detectChanges();\r\n                    this._hideMask();\r\n                }\r\n            },\r\n            (error) => {\r\n                this._hideMask();\r\n                alert(error);\r\n            }\r\n        );\r\n    }\r\n    protected _downloadFileIdCompleted(response): void {\r\n        const blob = BarsaApi.Common.File.B64toBlob(response.content, response.contentType);\r\n        const url = window.URL || window.webkitURL;\r\n        this.valueUrl = this._domSanitizer.bypassSecurityTrustResourceUrl(url.createObjectURL(blob));\r\n        this.hasPdf = true;\r\n    }\r\n    protected _uploadToServer(files: File[]): void {\r\n        this.filesValidationHelper.validateFiles(files);\r\n        this._uploadFile(files).pipe(takeUntil(this._onDestroy$)).subscribe();\r\n    }\r\n\r\n    protected _refreshButtons(): void {\r\n        this._refreshButtonsHelper(false);\r\n        BarsaApi.Common.Async.Waterfall(\r\n            'Common.File.IsAgentActive',\r\n            [\r\n                // Common.FileAgent.IsAgentActive.bind(Common.FileAgent),\r\n                BarsaApi.Common.AgentHelper.Init.bind(BarsaApi.Common.AgentHelper)\r\n            ],\r\n            (err, result) => {\r\n                const agentIsActive = result === 'OK';\r\n                this._refreshButtonsHelper(agentIsActive);\r\n            }\r\n        );\r\n    }\r\n    protected _refreshButtonsHelper(isAgentActive): void {\r\n        this.disableOrReadonly$.subscribe((disableOrReadonly) => {\r\n            const canSave = this.canSave;\r\n            this.canDelete = !disableOrReadonly;\r\n            const hasValue = !BarsaApi.Ext.isEmpty(this.value);\r\n            const edit0 = canSave && disableOrReadonly !== true;\r\n            this.canEdit = edit0 && isAgentActive;\r\n            this.canDownload = !this.Setting.IsWordViewer || (!isAgentActive && edit0);\r\n            this.canUpload = this.canDownload && canSave && disableOrReadonly !== true;\r\n            this.hasFileName = !this.context.Setting.IsWordViewer;\r\n            this.canRemove = this.canDownload && canSave && disableOrReadonly !== true;\r\n\r\n            this.officeOnline = hasValue && canSave && disableOrReadonly !== true && this.context.OfficeOnline;\r\n            this.useWordEditor = hasValue && canSave && disableOrReadonly !== true && this.context.useWordEditor;\r\n        });\r\n    }\r\n    protected _commandClickHandler(itemId, keyboardEvent?): void {\r\n        const commandId = itemId;\r\n\r\n        let files = this.value;\r\n        if (BarsaApi.Ext.isArray(files)) {\r\n            files = files[0];\r\n        }\r\n\r\n        const fileId = files?.Id;\r\n        this.context.fireEvent('CommandRequest', this, commandId, fileId, keyboardEvent);\r\n    }\r\n    protected _refresh(fromServer?: boolean): void {\r\n        const officeOnline = fromServer === false;\r\n\r\n        this.fileName = '';\r\n\r\n        if (BarsaApi.Ext.isEmpty(this.value)) {\r\n            this.hasPdf = false;\r\n            return;\r\n        }\r\n\r\n        let files = this.value;\r\n        if (BarsaApi.Ext.isArray(files)) {\r\n            files = files[0];\r\n        }\r\n\r\n        const fileId = files.Id;\r\n        if (!fileId || files.IsDeleted) {\r\n            if (files.IsDeleted) {\r\n                this.hasPdf = false;\r\n            }\r\n            return;\r\n        }\r\n        this.fallbackLink = `امکان نمایش فایل در این مرورگر وجود ندارد.\r\n         برای باز کردن فایل از لینک زیر استفاده کنید:  </br> <a href='${BarsaApi.Common.File.CreateAttachmentUrl(\r\n             fileId,\r\n             false,\r\n             true\r\n         )}'>دانلود فایل بصورت pdf</a>  </br>  <a href='${BarsaApi.Common.File.CreateAttachmentUrl(\r\n            fileId,\r\n            false,\r\n            false\r\n        )}'>دانلود فایل بصورت بصورت اصلی</a>`;\r\n\r\n        if (!BarsaApi.Ext.isIE) {\r\n            // const options = {\r\n            //     fallbackLink: this.fallbackLink,\r\n            //     pdfOpenParams: {\r\n            //         view: 'FitH',\r\n            //         scrollbar: '0',\r\n            //         toolbar: '0',\r\n            //         statusbar: '0',\r\n            //         messages: '0',\r\n            //         navpanes: '0'\r\n            //     }\r\n            // };\r\n            let convertTo = isImage(files.Type) ? files.Type : '';\r\n            convertTo = 'pdf,doc,docx,word'.indexOf(files.Type) > -1 ? 'pdf' : convertTo;\r\n\r\n            if (!convertTo) {\r\n                this.singleControl = true;\r\n                this.updateSingleControl(files);\r\n                return;\r\n            }\r\n            this.singleControl = false;\r\n\r\n            this.DownloadFileId(fileId, true, convertTo, null, officeOnline);\r\n        } else {\r\n            // const url = Common.File.CreateAttachmentUrl(fileId, false);\r\n            this.canNotRenderPdf = true;\r\n        }\r\n    }\r\n\r\n    protected _uploadFile(files: File[]): Observable<any> {\r\n        const formData = new FormData();\r\n        files.forEach((file) => {\r\n            formData.append('unicFileName', 'x' + BarsaApi.Common.Util.GetNewMetaGuid() + ';;;' + file.name);\r\n            formData.append('file', file);\r\n        });\r\n\r\n        return this._uploadService.upload(formData, this.Setting.ControlFieldDefId).pipe(\r\n            tap((res) => {\r\n                if (Array.isArray(res)) {\r\n                    this._updateValue(res);\r\n                }\r\n            })\r\n        );\r\n    }\r\n\r\n    protected _updateValue(res: any[]): void {\r\n        if (this.Setting.ViewType !== 'LinearListBox') {\r\n            this.updateSingleControl(res[0]);\r\n        }\r\n        this.fireContextEvent('Change', this.context, res);\r\n    }\r\n\r\n    private updateSingleControl(val: any): void {\r\n        if (isImage(val.Type)) {\r\n            this.singleFileThumbnailUrl = getImagePath('ID', '', val.Id);\r\n        } else {\r\n            this.singleFileThumbnailUrl = getIcon(val.Type);\r\n        }\r\n    }\r\n    private _hideMask(): void {\r\n        setTimeout(() => {\r\n            BarsaApi.Ul.LoadingMask.Unmask(this._el.nativeElement);\r\n        }, 0);\r\n    }\r\n}\r\n","<ng-container *untilInView=\"el\">\r\n    <fd-toolbar [transparent]=\"true\" [shouldOverflow]=\"true\">\r\n        <fd-file-uploader\r\n            #uploader\r\n            [style.display]=\"'none'\"\r\n            fd-toolbar-item\r\n            [id]=\"id\"\r\n            [name]=\"'pdf_' + id\"\r\n            [placeholder]=\"'AttachFile' | bbbTranslate\"\r\n            [buttonLabel]=\"'AttachFile' | bbbTranslate\"\r\n            [buttonAriaLabel]=\"'AttachFile' | bbbTranslate\"\r\n            [accept]=\"validExtension\"\r\n            [(ngModel)]=\"files\"\r\n            [multiple]=\"false\"\r\n            (selectedFilesChanged)=\"onFileSelection($event)\"\r\n            [contentDensity]=\"(contentDensity$ | async)!!\"\r\n        ></fd-file-uploader>\r\n        <button\r\n            fd-button\r\n            fd-toolbar-item\r\n            glyph=\"attachment\"\r\n            [fdType]=\"'transparent'\"\r\n            [disabled]=\"!canUpload\"\r\n            (click)=\"uploader.open()\"\r\n        ></button>\r\n        <button\r\n            [disabled]=\"!(canDelete && value)\"\r\n            fd-button\r\n            fd-toolbar-item\r\n            class=\"delete\"\r\n            glyph=\"delete\"\r\n            [fdType]=\"'transparent'\"\r\n            (click)=\"onDelete()\"\r\n        ></button>\r\n        <button\r\n            *ngIf=\"canEdit\"\r\n            fd-toolbar-item\r\n            fd-button\r\n            glyph=\"edit\"\r\n            [fdType]=\"'transparent'\"\r\n            (click)=\"onEdit()\"\r\n        ></button>\r\n        <button\r\n            *ngIf=\"canDownload\"\r\n            fd-toolbar-item\r\n            fd-button\r\n            glyph=\"download\"\r\n            [fdType]=\"'transparent'\"\r\n            (click)=\"onDownload()\"\r\n        ></button>\r\n\r\n        <button\r\n            *ngIf=\"useWordEditor\"\r\n            fd-toolbar-item\r\n            fd-button\r\n            glyph=\"doc-attachment\"\r\n            [fdType]=\"'transparent'\"\r\n            [label]=\"'EditInWord' | bbbTranslate\"\r\n            (click)=\"onEditInWord()\"\r\n        ></button>\r\n        <button\r\n            *ngIf=\"officeOnline\"\r\n            fd-toolbar-item\r\n            fd-button\r\n            glyph=\"doc-attachment\"\r\n            [fdType]=\"'transparent'\"\r\n            [label]=\"'OfficeOnline' | bbbTranslate\"\r\n            (click)=\"onOfficeOnline($event)\"\r\n        ></button>\r\n        <button fd-toolbar-item fd-button glyph=\"refresh\" [fdType]=\"'transparent'\" (click)=\"onRefresh()\"></button>\r\n\r\n        <fd-busy-indicator\r\n            fd-toolbar-item\r\n            [loading]=\"(uploadingState$ | async)?.uploading === true\"\r\n        ></fd-busy-indicator>\r\n    </fd-toolbar>\r\n    <object\r\n        *ngIf=\"hasPdf; else HatchBackground\"\r\n        style=\"flex-grow: 1\"\r\n        [attr.data]=\"valueUrl\"\r\n        type=\"application/pdf\"\r\n        width=\"100%\"\r\n        height=\"100%\"\r\n        [attr.html]=\"fallbackLink\"\r\n    ></object>\r\n    <ng-template #HatchBackground>\r\n        <ng-container *ngIf=\"singleControl && value && !value.IsDeleted; else noFile\">\r\n            <div style=\"display: flex\">\r\n                <img *ngIf=\"singleFileThumbnailUrl\" [src]=\"singleFileThumbnailUrl\" />\r\n                <fd-object-identifier>\r\n                    {{ value.FileName }}\r\n                </fd-object-identifier>\r\n            </div>\r\n        </ng-container>\r\n        <ng-template #noFile>\r\n            <div class=\"hatchBackground\"></div>\r\n        </ng-template>\r\n    </ng-template>\r\n</ng-container>\r\n"]}
|
|
@@ -1,44 +1,40 @@
|
|
|
1
1
|
import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
|
|
2
|
-
import { FieldBaseComponent, BarsaApi, UploadService, getValidExtension } from 'barsa-novin-ray-core';
|
|
3
|
-
import { of
|
|
4
|
-
import { exhaustMap, takeUntil, tap } from 'rxjs/operators';
|
|
2
|
+
import { FieldBaseComponent, BarsaApi, UploadService, getValidExtension, FilesValidationHelper, ImageMimeType } from 'barsa-novin-ray-core';
|
|
3
|
+
import { of } from 'rxjs';
|
|
4
|
+
import { concatMap, exhaustMap, takeUntil, tap } from 'rxjs/operators';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
import * as i1 from "@angular/common";
|
|
7
7
|
import * as i2 from "@angular/forms";
|
|
8
|
-
import * as i3 from "
|
|
9
|
-
import * as i4 from "@fundamental-ngx/core/
|
|
10
|
-
import * as i5 from "@fundamental-ngx/core/
|
|
11
|
-
import * as i6 from "@fundamental-ngx/core/
|
|
12
|
-
import * as i7 from "@fundamental-ngx/
|
|
13
|
-
import * as i8 from "
|
|
14
|
-
import * as i9 from "
|
|
8
|
+
import * as i3 from "barsa-novin-ray-core";
|
|
9
|
+
import * as i4 from "@fundamental-ngx/core/avatar";
|
|
10
|
+
import * as i5 from "@fundamental-ngx/core/button";
|
|
11
|
+
import * as i6 from "@fundamental-ngx/core/file-uploader";
|
|
12
|
+
import * as i7 from "@fundamental-ngx/core/toolbar";
|
|
13
|
+
import * as i8 from "@fundamental-ngx/platform/slider";
|
|
14
|
+
import * as i9 from "../mask/mask.component";
|
|
15
15
|
export class UiPictureFileComponent extends FieldBaseComponent {
|
|
16
16
|
constructor() {
|
|
17
17
|
super(...arguments);
|
|
18
18
|
this.files = [];
|
|
19
|
-
this.cancelation$ = new Subject();
|
|
20
19
|
}
|
|
21
20
|
ngOnInit() {
|
|
22
21
|
super.ngOnInit();
|
|
23
|
-
this.
|
|
24
|
-
this.uploadState$ = this._uploadService.uploadState$;
|
|
25
|
-
this.uploading$ = this._uploadService.uploading$;
|
|
22
|
+
this.uploadingState$ = this._uploadService.uploadingState$;
|
|
26
23
|
this.context.on({
|
|
27
24
|
DispalyImage: this._displayImage.bind(this)
|
|
28
25
|
});
|
|
29
26
|
this.imageUrl = this.context.imageUrl;
|
|
30
27
|
this.value = this.context._value;
|
|
31
|
-
this.validExtensions = this.Setting.
|
|
32
|
-
|
|
33
|
-
: '.jpeg,.jpg,.gif,.png,.bmp,.tif';
|
|
28
|
+
this.validExtensions = getValidExtension(this.Setting.ValidExtensions) || ImageMimeType;
|
|
29
|
+
this.filesValidationHelper = new FilesValidationHelper(1, this.Setting.MaxFileSizeKb, this.Setting.MaxFileSizeKb);
|
|
34
30
|
}
|
|
35
31
|
ngOnDestroy() {
|
|
36
32
|
super.ngOnDestroy();
|
|
37
33
|
this.context.un('DisplayImage', this._displayImage);
|
|
38
34
|
}
|
|
39
35
|
onFileSelection(files) {
|
|
40
|
-
this.files
|
|
41
|
-
this.
|
|
36
|
+
this.filesValidationHelper.validateFiles(files);
|
|
37
|
+
this.uploadFile(files).pipe(takeUntil(this._onDestroy$)).subscribe();
|
|
42
38
|
}
|
|
43
39
|
onFileDeleted(uploaderComponent) {
|
|
44
40
|
uploaderComponent.inputRef.nativeElement.value = null;
|
|
@@ -52,7 +48,8 @@ export class UiPictureFileComponent extends FieldBaseComponent {
|
|
|
52
48
|
this._upload(this.files);
|
|
53
49
|
}
|
|
54
50
|
onTerminate() {
|
|
55
|
-
this.cancelation$.next();
|
|
51
|
+
this._uploadService.cancelation$.next();
|
|
52
|
+
this._cdr.detectChanges();
|
|
56
53
|
}
|
|
57
54
|
_displayImage(imageUrl, sizeMode, value) {
|
|
58
55
|
this.imageUrl = imageUrl;
|
|
@@ -65,31 +62,30 @@ export class UiPictureFileComponent extends FieldBaseComponent {
|
|
|
65
62
|
.subscribe();
|
|
66
63
|
}
|
|
67
64
|
uploadFile(files) {
|
|
68
|
-
|
|
69
|
-
files.forEach((file) => {
|
|
70
|
-
formData.append('unicFileName', 'x' + BarsaApi.Common.Util.GetNewMetaGuid() + ';;;' + file.name);
|
|
71
|
-
formData.append('file', file);
|
|
72
|
-
});
|
|
73
|
-
return this._uploadService.upload(formData, this.Setting.ControlFieldDefId).pipe(tap((res) => {
|
|
65
|
+
return this._uploadService.compressFiles$(files).pipe(concatMap((formData) => this._uploadService.upload(formData, this.Setting.ControlFieldDefId).pipe(tap((res) => {
|
|
74
66
|
if (Array.isArray(res)) {
|
|
75
67
|
const picture = res[0];
|
|
68
|
+
if (picture.ErrorMsg) {
|
|
69
|
+
BarsaApi.Bw.Msg.Error(picture.ErrorMsg);
|
|
70
|
+
return;
|
|
71
|
+
}
|
|
76
72
|
const value = {
|
|
77
73
|
...picture,
|
|
78
74
|
FileId: picture.FileId
|
|
79
75
|
};
|
|
80
76
|
this.fireContextEvent('Change', this.context, value);
|
|
81
77
|
}
|
|
82
|
-
}));
|
|
78
|
+
}))));
|
|
83
79
|
}
|
|
84
80
|
}
|
|
85
81
|
UiPictureFileComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: UiPictureFileComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
86
|
-
UiPictureFileComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: UiPictureFileComponent, selector: "bsu-ui-picture-file", inputs: { imageUrl: "imageUrl", sizeMode: "sizeMode" }, providers: [UploadService], usesInheritance: true, ngImport: i0, template: "<div\n [style.max-height.px]=\"Setting.SizeMode === '2' ? null : layoutInfo.ControlBounds.height\"\n [class.no-inlineEdit]=\"!inlineEdit\"\n [class.inlineEdit]=\"inlineEdit\"\n>\n <div *ngIf=\"!((disableOrReadonly$ | async) === true || Setting.IsReadOnly === true)\">\n <fd-toolbar [fdType]=\"'transparent'\">\n <fd-file-uploader\n #uploader\n fd-toolbar-item\n [style.display]=\"'none'\"\n [id]=\"id\"\n [name]=\"'uploader_' + id\"\n [placeholder]=\"'AttachPicture' | bbbTranslate\"\n [buttonLabel]=\"'AttachPicture' | bbbTranslate\"\n [buttonAriaLabel]=\"'AttachPicture' | bbbTranslate\"\n [accept]=\"validExtensions\"\n [(ngModel)]=\"files\"\n [multiple]=\"false\"\n (selectedFilesChanged)=\"onFileSelection($event)\"\n ></fd-file-uploader>\n <button\n fd-toolbar-item\n fd-button\n [disabled]=\"this.value && value?.IsDeleted !== true\"\n glyph=\"attachment\"\n [fdType]=\"'transparent'\"\n (click)=\"uploader.open()\"\n ></button>\n <button\n class=\"delete\"\n fd-button\n fd-toolbar-item\n [disabled]=\"!this.value || value?.IsDeleted\"\n glyph=\"delete\"\n [fdType]=\"'transparent'\"\n (click)=\"onFileDeleted(uploader)\"\n ></button>\
|
|
82
|
+
UiPictureFileComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: UiPictureFileComponent, selector: "bsu-ui-picture-file", inputs: { imageUrl: "imageUrl", sizeMode: "sizeMode" }, providers: [UploadService], usesInheritance: true, ngImport: i0, template: "<div\r\n [style.max-height.px]=\"Setting.SizeMode === '2' ? null : layoutInfo.ControlBounds.height\"\r\n [class.no-inlineEdit]=\"!inlineEdit\"\r\n [class.inlineEdit]=\"inlineEdit\"\r\n>\r\n <div *ngIf=\"!((disableOrReadonly$ | async) === true || Setting.IsReadOnly === true)\">\r\n <fd-toolbar [fdType]=\"'transparent'\">\r\n <fd-file-uploader\r\n #uploader\r\n fd-toolbar-item\r\n [style.display]=\"'none'\"\r\n [id]=\"id\"\r\n [name]=\"'uploader_' + id\"\r\n [placeholder]=\"'AttachPicture' | bbbTranslate\"\r\n [buttonLabel]=\"'AttachPicture' | bbbTranslate\"\r\n [buttonAriaLabel]=\"'AttachPicture' | bbbTranslate\"\r\n [accept]=\"validExtensions\"\r\n [(ngModel)]=\"files\"\r\n [multiple]=\"false\"\r\n (selectedFilesChanged)=\"onFileSelection($event)\"\r\n ></fd-file-uploader>\r\n <button\r\n fd-toolbar-item\r\n fd-button\r\n [disabled]=\"this.value && value?.IsDeleted !== true\"\r\n glyph=\"attachment\"\r\n [fdType]=\"'transparent'\"\r\n (click)=\"uploader.open()\"\r\n ></button>\r\n <button\r\n class=\"delete\"\r\n fd-button\r\n fd-toolbar-item\r\n [disabled]=\"!this.value || value?.IsDeleted\"\r\n glyph=\"delete\"\r\n [fdType]=\"'transparent'\"\r\n (click)=\"onFileDeleted(uploader)\"\r\n ></button>\r\n <ng-container\r\n *ngTemplateOutlet=\"\r\n loadingTpl;\r\n context: {\r\n uploadingState: uploadingState$ | async\r\n }\r\n \"\r\n >\r\n </ng-container>\r\n </fd-toolbar>\r\n </div>\r\n <div\r\n *ngIf=\"!inlineEdit; else avatarTemplate\"\r\n [style.max-height.px]=\"Setting.SizeMode === '0' ? layoutInfo.ControlBounds.height : null\"\r\n [style.max-width.px]=\"Setting.SizeMode === '0' ? layoutInfo.ControlBounds.width : null\"\r\n [style.text-align]=\"Setting.SizeMode === '3' ? 'center' : null\"\r\n >\r\n <bsu-mask *ngIf=\"value && imageUrl\" [marginTop]=\"'0px'\"></bsu-mask>\r\n <img\r\n *ngIf=\"(value && imageUrl) || Setting.HasDefaultPicture\"\r\n imgLazy\r\n [imgLazy]=\"imageUrl\"\r\n [src]=\"imageUrl\"\r\n [ngClass]=\"Setting.SizeMode === '1' ? 'cover' : 'contain'\"\r\n [style.height.px]=\"Setting.SizeMode !== '2' ? layoutInfo.ControlBounds.height : null\"\r\n />\r\n </div>\r\n <ng-template #avatarTemplate>\r\n <fd-avatar [size]=\"'m'\" [image]=\"imageUrl\"></fd-avatar>\r\n </ng-template>\r\n</div>\r\n<!-- <bsu-mask *ngIf=\"uploading$ | async\"></bsu-mask> -->\r\n<ng-template #loadingTpl let-uploadingState=\"uploadingState\">\r\n <ng-container *ngIf=\"uploadingState && uploadingState.state !== 'Complete' && uploadingState.uploading\">\r\n <fdp-slider\r\n fd-toolbar-item\r\n [id]=\"id + '1'\"\r\n [name]=\"'slider_' + id\"\r\n [value]=\"uploadingState.progress\"\r\n [min]=\"0\"\r\n [max]=\"100\"\r\n [step]=\"1\"\r\n >\r\n </fdp-slider>\r\n <button\r\n *ngIf=\"uploadingState.state === 'Uploading'\"\r\n fd-toolbar-item\r\n fd-button\r\n glyph=\"stop\"\r\n fdType=\"transparent\"\r\n (click)=\"onTerminate()\"\r\n ></button>\r\n <button\r\n *ngIf=\"uploadingState.state === 'Error'\"\r\n fd-toolbar-item\r\n fd-button\r\n glyph=\"refresh\"\r\n [fdType]=\"'transparent'\"\r\n (click)=\"onRetry()\"\r\n ></button>\r\n </ng-container>\r\n</ng-template>\r\n", styles: [":host{width:100%;height:100%;display:flex;flex-direction:column;justify-content:center;align-items:center;position:relative;overflow:hidden;margin-bottom:.25rem;margin-top:.1875rem}:host ::ng-deep .fd-slider__handle{display:none}:host ::ng-deep .delete button{border-color:transparent!important;background-color:transparent!important}img{width:100%}.pic-wrapper{background-repeat:no-repeat;background-position:center}.cover{max-width:100%;max-height:100%;min-height:100%;width:100%;height:100%;background-size:cover}.contain{max-width:100%;max-height:100%;min-height:100%;width:auto;height:100%;background-size:contain}.no-inlineEdit{min-height:140px;width:100%;position:relative;display:flex;flex-direction:column}.inlineEdit{width:100%;position:relative;display:flex;flex-direction:row-reverse;align-items:flex-end;justify-content:flex-start}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i3.ImageLazyDirective, selector: "[imgLazy]", inputs: ["auto", "threshold", "imgLazy"], outputs: ["imageLoaded"] }, { kind: "component", type: i4.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: i5.ButtonComponent, selector: "button[fd-button], a[fd-button]", inputs: ["class"], exportAs: ["fd-button"] }, { kind: "component", type: i6.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: i7.ToolbarComponent, selector: "fd-toolbar", inputs: ["class", "shouldOverflow", "fdType", "hasTitle", "title", "active", "clearBorder", "forceOverflow", "tabindex"] }, { kind: "directive", type: i7.ToolbarItemDirective, selector: "[fd-toolbar-item]" }, { kind: "component", type: i8.SliderComponent, selector: "fdp-slider", inputs: ["class", "min", "max", "step", "jump", "tickmarksBetweenLabels", "mode", "showTicks", "showTicksLabels", "customValues", "tooltipMode", "hideProgressBar", "value"], outputs: ["sliderChange"] }, { kind: "component", type: i9.MaskComponent, selector: "bsu-mask", inputs: ["size", "marginTop"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i3.BbbTranslatePipe, name: "bbbTranslate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
87
83
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: UiPictureFileComponent, decorators: [{
|
|
88
84
|
type: Component,
|
|
89
|
-
args: [{ selector: 'bsu-ui-picture-file', changeDetection: ChangeDetectionStrategy.OnPush, providers: [UploadService], template: "<div\n [style.max-height.px]=\"Setting.SizeMode === '2' ? null : layoutInfo.ControlBounds.height\"\n [class.no-inlineEdit]=\"!inlineEdit\"\n [class.inlineEdit]=\"inlineEdit\"\n>\n <div *ngIf=\"!((disableOrReadonly$ | async) === true || Setting.IsReadOnly === true)\">\n <fd-toolbar [fdType]=\"'transparent'\">\n <fd-file-uploader\n #uploader\n fd-toolbar-item\n [style.display]=\"'none'\"\n [id]=\"id\"\n [name]=\"'uploader_' + id\"\n [placeholder]=\"'AttachPicture' | bbbTranslate\"\n [buttonLabel]=\"'AttachPicture' | bbbTranslate\"\n [buttonAriaLabel]=\"'AttachPicture' | bbbTranslate\"\n [accept]=\"validExtensions\"\n [(ngModel)]=\"files\"\n [multiple]=\"false\"\n (selectedFilesChanged)=\"onFileSelection($event)\"\n ></fd-file-uploader>\n <button\n fd-toolbar-item\n fd-button\n [disabled]=\"this.value && value?.IsDeleted !== true\"\n glyph=\"attachment\"\n [fdType]=\"'transparent'\"\n (click)=\"uploader.open()\"\n ></button>\n <button\n class=\"delete\"\n fd-button\n fd-toolbar-item\n [disabled]=\"!this.value || value?.IsDeleted\"\n glyph=\"delete\"\n [fdType]=\"'transparent'\"\n (click)=\"onFileDeleted(uploader)\"\n ></button>\
|
|
85
|
+
args: [{ selector: 'bsu-ui-picture-file', changeDetection: ChangeDetectionStrategy.OnPush, providers: [UploadService], template: "<div\r\n [style.max-height.px]=\"Setting.SizeMode === '2' ? null : layoutInfo.ControlBounds.height\"\r\n [class.no-inlineEdit]=\"!inlineEdit\"\r\n [class.inlineEdit]=\"inlineEdit\"\r\n>\r\n <div *ngIf=\"!((disableOrReadonly$ | async) === true || Setting.IsReadOnly === true)\">\r\n <fd-toolbar [fdType]=\"'transparent'\">\r\n <fd-file-uploader\r\n #uploader\r\n fd-toolbar-item\r\n [style.display]=\"'none'\"\r\n [id]=\"id\"\r\n [name]=\"'uploader_' + id\"\r\n [placeholder]=\"'AttachPicture' | bbbTranslate\"\r\n [buttonLabel]=\"'AttachPicture' | bbbTranslate\"\r\n [buttonAriaLabel]=\"'AttachPicture' | bbbTranslate\"\r\n [accept]=\"validExtensions\"\r\n [(ngModel)]=\"files\"\r\n [multiple]=\"false\"\r\n (selectedFilesChanged)=\"onFileSelection($event)\"\r\n ></fd-file-uploader>\r\n <button\r\n fd-toolbar-item\r\n fd-button\r\n [disabled]=\"this.value && value?.IsDeleted !== true\"\r\n glyph=\"attachment\"\r\n [fdType]=\"'transparent'\"\r\n (click)=\"uploader.open()\"\r\n ></button>\r\n <button\r\n class=\"delete\"\r\n fd-button\r\n fd-toolbar-item\r\n [disabled]=\"!this.value || value?.IsDeleted\"\r\n glyph=\"delete\"\r\n [fdType]=\"'transparent'\"\r\n (click)=\"onFileDeleted(uploader)\"\r\n ></button>\r\n <ng-container\r\n *ngTemplateOutlet=\"\r\n loadingTpl;\r\n context: {\r\n uploadingState: uploadingState$ | async\r\n }\r\n \"\r\n >\r\n </ng-container>\r\n </fd-toolbar>\r\n </div>\r\n <div\r\n *ngIf=\"!inlineEdit; else avatarTemplate\"\r\n [style.max-height.px]=\"Setting.SizeMode === '0' ? layoutInfo.ControlBounds.height : null\"\r\n [style.max-width.px]=\"Setting.SizeMode === '0' ? layoutInfo.ControlBounds.width : null\"\r\n [style.text-align]=\"Setting.SizeMode === '3' ? 'center' : null\"\r\n >\r\n <bsu-mask *ngIf=\"value && imageUrl\" [marginTop]=\"'0px'\"></bsu-mask>\r\n <img\r\n *ngIf=\"(value && imageUrl) || Setting.HasDefaultPicture\"\r\n imgLazy\r\n [imgLazy]=\"imageUrl\"\r\n [src]=\"imageUrl\"\r\n [ngClass]=\"Setting.SizeMode === '1' ? 'cover' : 'contain'\"\r\n [style.height.px]=\"Setting.SizeMode !== '2' ? layoutInfo.ControlBounds.height : null\"\r\n />\r\n </div>\r\n <ng-template #avatarTemplate>\r\n <fd-avatar [size]=\"'m'\" [image]=\"imageUrl\"></fd-avatar>\r\n </ng-template>\r\n</div>\r\n<!-- <bsu-mask *ngIf=\"uploading$ | async\"></bsu-mask> -->\r\n<ng-template #loadingTpl let-uploadingState=\"uploadingState\">\r\n <ng-container *ngIf=\"uploadingState && uploadingState.state !== 'Complete' && uploadingState.uploading\">\r\n <fdp-slider\r\n fd-toolbar-item\r\n [id]=\"id + '1'\"\r\n [name]=\"'slider_' + id\"\r\n [value]=\"uploadingState.progress\"\r\n [min]=\"0\"\r\n [max]=\"100\"\r\n [step]=\"1\"\r\n >\r\n </fdp-slider>\r\n <button\r\n *ngIf=\"uploadingState.state === 'Uploading'\"\r\n fd-toolbar-item\r\n fd-button\r\n glyph=\"stop\"\r\n fdType=\"transparent\"\r\n (click)=\"onTerminate()\"\r\n ></button>\r\n <button\r\n *ngIf=\"uploadingState.state === 'Error'\"\r\n fd-toolbar-item\r\n fd-button\r\n glyph=\"refresh\"\r\n [fdType]=\"'transparent'\"\r\n (click)=\"onRetry()\"\r\n ></button>\r\n </ng-container>\r\n</ng-template>\r\n", styles: [":host{width:100%;height:100%;display:flex;flex-direction:column;justify-content:center;align-items:center;position:relative;overflow:hidden;margin-bottom:.25rem;margin-top:.1875rem}:host ::ng-deep .fd-slider__handle{display:none}:host ::ng-deep .delete button{border-color:transparent!important;background-color:transparent!important}img{width:100%}.pic-wrapper{background-repeat:no-repeat;background-position:center}.cover{max-width:100%;max-height:100%;min-height:100%;width:100%;height:100%;background-size:cover}.contain{max-width:100%;max-height:100%;min-height:100%;width:auto;height:100%;background-size:contain}.no-inlineEdit{min-height:140px;width:100%;position:relative;display:flex;flex-direction:column}.inlineEdit{width:100%;position:relative;display:flex;flex-direction:row-reverse;align-items:flex-end;justify-content:flex-start}\n"] }]
|
|
90
86
|
}], propDecorators: { imageUrl: [{
|
|
91
87
|
type: Input
|
|
92
88
|
}], sizeMode: [{
|
|
93
89
|
type: Input
|
|
94
90
|
}] } });
|
|
95
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ui-picture-file.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-sap-ui/src/lib/ui-picture-file/ui-picture-file.component.ts","../../../../../projects/barsa-sap-ui/src/lib/ui-picture-file/ui-picture-file.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, Input, OnDestroy, OnInit } from '@angular/core';\nimport { FileUploaderComponent } from '@fundamental-ngx/core';\n\nimport { FieldBaseComponent, BarsaApi, UploadService, getValidExtension } from 'barsa-novin-ray-core';\nimport { Observable, of, Subject } from 'rxjs';\nimport { exhaustMap, takeUntil, tap } from 'rxjs/operators';\n\n@Component({\n    selector: 'bsu-ui-picture-file',\n    templateUrl: './ui-picture-file.component.html',\n    styleUrls: ['./ui-picture-file.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [UploadService]\n})\nexport class UiPictureFileComponent extends FieldBaseComponent implements OnInit, OnDestroy {\n    @Input() imageUrl: any;\n    @Input() sizeMode: any;\n    files: File[] = [];\n    uploadState$: Observable<string>;\n    progress$: Observable<any>;\n    uploading$: Observable<boolean>;\n    cancelation$ = new Subject<void>();\n    validExtensions: any;\n\n    ngOnInit(): void {\n        super.ngOnInit();\n        this.progress$ = this._uploadService.progress$;\n        this.uploadState$ = this._uploadService.uploadState$;\n        this.uploading$ = this._uploadService.uploading$;\n        this.context.on({\n            DispalyImage: this._displayImage.bind(this)\n        });\n        this.imageUrl = this.context.imageUrl;\n        this.value = this.context._value;\n        this.validExtensions = this.Setting.ValidExtension\n            ? getValidExtension(this.Setting.ValidExtensions)\n            : '.jpeg,.jpg,.gif,.png,.bmp,.tif';\n    }\n    ngOnDestroy(): void {\n        super.ngOnDestroy();\n        this.context.un('DisplayImage', this._displayImage);\n    }\n    onFileSelection(files: File[]): void {\n        this.files = files;\n        this._upload(files);\n    }\n    onFileDeleted(uploaderComponent: FileUploaderComponent): void {\n        uploaderComponent.inputRef.nativeElement.value = null;\n        this.value = null;\n        this.fireContextEvent('Change', this.context, null);\n    }\n\n    onDownloadFile(): void {\n        BarsaApi.Common.File.OpenFile(this.value.FileId, false, this, true, false);\n    }\n\n    onRetry(): void {\n        this._upload(this.files);\n    }\n\n    onTerminate(): void {\n        this.cancelation$.next();\n    }\n    private _displayImage(imageUrl, sizeMode, value): void {\n        this.imageUrl = imageUrl;\n        this.value = value;\n        this.sizeMode = sizeMode;\n    }\n\n    private _upload(files: File[]): void {\n        of(true)\n            .pipe(\n                takeUntil(this._onDestroy$),\n                exhaustMap(() => this.uploadFile(files))\n            )\n            .subscribe();\n    }\n\n    private uploadFile(files: File[]): Observable<any> {\n        const formData = new FormData();\n        files.forEach((file) => {\n            formData.append('unicFileName', 'x' + BarsaApi.Common.Util.GetNewMetaGuid() + ';;;' + file.name);\n            formData.append('file', file);\n        });\n\n        return this._uploadService.upload(formData, this.Setting.ControlFieldDefId).pipe(\n            tap((res) => {\n                if (Array.isArray(res)) {\n                    const picture = res[0];\n                    const value = {\n                        ...picture,\n                        FileId: picture.FileId\n                    };\n                    this.fireContextEvent('Change', this.context, value);\n                }\n            })\n        );\n    }\n}\n","<div\n    [style.max-height.px]=\"Setting.SizeMode === '2' ? null : layoutInfo.ControlBounds.height\"\n    [class.no-inlineEdit]=\"!inlineEdit\"\n    [class.inlineEdit]=\"inlineEdit\"\n>\n    <div *ngIf=\"!((disableOrReadonly$ | async) === true || Setting.IsReadOnly === true)\">\n        <fd-toolbar [fdType]=\"'transparent'\">\n            <fd-file-uploader\n                #uploader\n                fd-toolbar-item\n                [style.display]=\"'none'\"\n                [id]=\"id\"\n                [name]=\"'uploader_' + id\"\n                [placeholder]=\"'AttachPicture' | bbbTranslate\"\n                [buttonLabel]=\"'AttachPicture' | bbbTranslate\"\n                [buttonAriaLabel]=\"'AttachPicture' | bbbTranslate\"\n                [accept]=\"validExtensions\"\n                [(ngModel)]=\"files\"\n                [multiple]=\"false\"\n                (selectedFilesChanged)=\"onFileSelection($event)\"\n            ></fd-file-uploader>\n            <button\n                fd-toolbar-item\n                fd-button\n                [disabled]=\"this.value && value?.IsDeleted !== true\"\n                glyph=\"attachment\"\n                [fdType]=\"'transparent'\"\n                (click)=\"uploader.open()\"\n            ></button>\n            <button\n                class=\"delete\"\n                fd-button\n                fd-toolbar-item\n                [disabled]=\"!this.value || value?.IsDeleted\"\n                glyph=\"delete\"\n                [fdType]=\"'transparent'\"\n                (click)=\"onFileDeleted(uploader)\"\n            ></button>\n\n            <ng-container *ngIf=\"uploadState$ | async as uploadState\">\n                <ng-container *ngIf=\"uploadState !== 'Complete'\">\n                    <fdp-slider\n                        fd-toolbar-item\n                        [id]=\"id + '1'\"\n                        [name]=\"'slider_' + id\"\n                        [value]=\"progress$ | async\"\n                        [min]=\"0\"\n                        [max]=\"100\"\n                        [step]=\"1\"\n                    >\n                    </fdp-slider>\n                    <button\n                        *ngIf=\"uploadState === 'Uploading'\"\n                        fd-toolbar-item\n                        fd-button\n                        glyph=\"stop\"\n                        fdType=\"transparent\"\n                        (click)=\"onTerminate()\"\n                    ></button>\n                    <button\n                        *ngIf=\"uploadState === 'Error'\"\n                        fd-toolbar-item\n                        fd-button\n                        glyph=\"refresh\"\n                        [fdType]=\"'transparent'\"\n                        (click)=\"onRetry()\"\n                    ></button>\n                </ng-container>\n            </ng-container>\n        </fd-toolbar>\n    </div>\n    <div\n        *ngIf=\"!inlineEdit; else avatarTemplate\"\n        [style.max-height.px]=\"Setting.SizeMode === '0' ? layoutInfo.ControlBounds.height : null\"\n        [style.max-width.px]=\"Setting.SizeMode === '0' ? layoutInfo.ControlBounds.width : null\"\n        [style.text-align]=\"Setting.SizeMode === '3' ? 'center' : null\"\n    >\n        <img\n            *ngIf=\"(value && imageUrl) || Setting.HasDefaultPicture\"\n            [src]=\"imageUrl\"\n            [ngClass]=\"Setting.SizeMode === '1' ? 'cover' : 'contain'\"\n            [style.height.px]=\"Setting.SizeMode !== '2' ? layoutInfo.ControlBounds.height : null\"\n        />\n    </div>\n    <ng-template #avatarTemplate>\n        <fd-avatar [size]=\"'m'\" [image]=\"imageUrl\"></fd-avatar>\n    </ng-template>\n</div>\n<bsu-mask *ngIf=\"uploading$ | async\"></bsu-mask>\n"]}
|
|
91
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ui-picture-file.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-sap-ui/src/lib/ui-picture-file/ui-picture-file.component.ts","../../../../../projects/barsa-sap-ui/src/lib/ui-picture-file/ui-picture-file.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,KAAK,EAAqB,MAAM,eAAe,CAAC;AAG7F,OAAO,EACH,kBAAkB,EAClB,QAAQ,EACR,aAAa,EACb,iBAAiB,EACjB,qBAAqB,EACrB,aAAa,EAEhB,MAAM,sBAAsB,CAAC;AAE9B,OAAO,EAAc,EAAE,EAAE,MAAM,MAAM,CAAC;AACtC,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,SAAS,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;;;;;;;;;;;AASvE,MAAM,OAAO,sBAAuB,SAAQ,kBAAkB;IAP9D;;QAUI,UAAK,GAAW,EAAE,CAAC;KAkFtB;IA9EG,QAAQ;QACJ,KAAK,CAAC,QAAQ,EAAE,CAAC;QACjB,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,cAAc,CAAC,eAAe,CAAC;QAC3D,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC;YACZ,YAAY,EAAE,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC;SAC9C,CAAC,CAAC;QACH,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC;QACtC,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC;QACjC,IAAI,CAAC,eAAe,GAAG,iBAAiB,CAAC,IAAI,CAAC,OAAO,CAAC,eAAe,CAAC,IAAI,aAAa,CAAC;QACxF,IAAI,CAAC,qBAAqB,GAAG,IAAI,qBAAqB,CAClD,CAAC,EACD,IAAI,CAAC,OAAO,CAAC,aAAa,EAC1B,IAAI,CAAC,OAAO,CAAC,aAAa,CAC7B,CAAC;IACN,CAAC;IACD,WAAW;QACP,KAAK,CAAC,WAAW,EAAE,CAAC;QACpB,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,cAAc,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;IACxD,CAAC;IACD,eAAe,CAAC,KAAa;QACzB,IAAI,CAAC,qBAAqB,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QAChD,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,SAAS,EAAE,CAAC;IACzE,CAAC;IACD,aAAa,CAAC,iBAAwC;QAClD,iBAAiB,CAAC,QAAQ,CAAC,aAAa,CAAC,KAAK,GAAG,IAAI,CAAC;QACtD,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;QAClB,IAAI,CAAC,gBAAgB,CAAC,QAAQ,EAAE,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;IACxD,CAAC;IAED,cAAc;QACV,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,IAAI,EAAE,KAAK,CAAC,CAAC;IAC/E,CAAC;IAED,OAAO;QACH,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC7B,CAAC;IAED,WAAW;QACP,IAAI,CAAC,cAAc,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;QACxC,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC;IAC9B,CAAC;IACO,aAAa,CAAC,QAAQ,EAAE,QAAQ,EAAE,KAAK;QAC3C,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;IAC7B,CAAC;IAEO,OAAO,CAAC,KAAa;QACzB,EAAE,CAAC,IAAI,CAAC;aACH,IAAI,CACD,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,EAC3B,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,CAC3C;aACA,SAAS,EAAE,CAAC;IACrB,CAAC;IAEO,UAAU,CAAC,KAAa;QAC5B,OAAO,IAAI,CAAC,cAAc,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC,IAAI,CACjD,SAAS,CAAC,CAAC,QAAkB,EAAE,EAAE,CAC7B,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,QAAQ,EAAE,IAAI,CAAC,OAAO,CAAC,iBAAiB,CAAC,CAAC,IAAI,CACrE,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE;YACR,IAAI,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE;gBACpB,MAAM,OAAO,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC;gBACvB,IAAI,OAAO,CAAC,QAAQ,EAAE;oBAClB,QAAQ,CAAC,EAAE,CAAC,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;oBACxC,OAAO;iBACV;gBACD,MAAM,KAAK,GAAG;oBACV,GAAG,OAAO;oBACV,MAAM,EAAE,OAAO,CAAC,MAAM;iBACzB,CAAC;gBACF,IAAI,CAAC,gBAAgB,CAAC,QAAQ,EAAE,IAAI,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;aACxD;QACL,CAAC,CAAC,CACL,CACJ,CACJ,CAAC;IACN,CAAC;;mHApFQ,sBAAsB;uGAAtB,sBAAsB,sGAFpB,CAAC,aAAa,CAAC,iDCrB9B,ihIAoGA;2FD7Ea,sBAAsB;kBAPlC,SAAS;+BACI,qBAAqB,mBAGd,uBAAuB,CAAC,MAAM,aACpC,CAAC,aAAa,CAAC;8BAGjB,QAAQ;sBAAhB,KAAK;gBACG,QAAQ;sBAAhB,KAAK","sourcesContent":["import { ChangeDetectionStrategy, Component, Input, OnDestroy, OnInit } from '@angular/core';\r\nimport { FileUploaderComponent } from '@fundamental-ngx/core';\r\n\r\nimport {\r\n    FieldBaseComponent,\r\n    BarsaApi,\r\n    UploadService,\r\n    getValidExtension,\r\n    FilesValidationHelper,\r\n    ImageMimeType,\r\n    IUploadingState\r\n} from 'barsa-novin-ray-core';\r\n\r\nimport { Observable, of } from 'rxjs';\r\nimport { concatMap, exhaustMap, takeUntil, tap } from 'rxjs/operators';\r\n\r\n@Component({\r\n    selector: 'bsu-ui-picture-file',\r\n    templateUrl: './ui-picture-file.component.html',\r\n    styleUrls: ['./ui-picture-file.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    providers: [UploadService]\r\n})\r\nexport class UiPictureFileComponent extends FieldBaseComponent implements OnInit, OnDestroy {\r\n    @Input() imageUrl: any;\r\n    @Input() sizeMode: any;\r\n    files: File[] = [];\r\n    uploadingState$: Observable<IUploadingState>;\r\n    validExtensions: any;\r\n    filesValidationHelper: FilesValidationHelper;\r\n    ngOnInit(): void {\r\n        super.ngOnInit();\r\n        this.uploadingState$ = this._uploadService.uploadingState$;\r\n        this.context.on({\r\n            DispalyImage: this._displayImage.bind(this)\r\n        });\r\n        this.imageUrl = this.context.imageUrl;\r\n        this.value = this.context._value;\r\n        this.validExtensions = getValidExtension(this.Setting.ValidExtensions) || ImageMimeType;\r\n        this.filesValidationHelper = new FilesValidationHelper(\r\n            1,\r\n            this.Setting.MaxFileSizeKb,\r\n            this.Setting.MaxFileSizeKb\r\n        );\r\n    }\r\n    ngOnDestroy(): void {\r\n        super.ngOnDestroy();\r\n        this.context.un('DisplayImage', this._displayImage);\r\n    }\r\n    onFileSelection(files: File[]): void {\r\n        this.filesValidationHelper.validateFiles(files);\r\n        this.uploadFile(files).pipe(takeUntil(this._onDestroy$)).subscribe();\r\n    }\r\n    onFileDeleted(uploaderComponent: FileUploaderComponent): void {\r\n        uploaderComponent.inputRef.nativeElement.value = null;\r\n        this.value = null;\r\n        this.fireContextEvent('Change', this.context, null);\r\n    }\r\n\r\n    onDownloadFile(): void {\r\n        BarsaApi.Common.File.OpenFile(this.value.FileId, false, this, true, false);\r\n    }\r\n\r\n    onRetry(): void {\r\n        this._upload(this.files);\r\n    }\r\n\r\n    onTerminate(): void {\r\n        this._uploadService.cancelation$.next();\r\n        this._cdr.detectChanges();\r\n    }\r\n    private _displayImage(imageUrl, sizeMode, value): void {\r\n        this.imageUrl = imageUrl;\r\n        this.value = value;\r\n        this.sizeMode = sizeMode;\r\n    }\r\n\r\n    private _upload(files: File[]): void {\r\n        of(true)\r\n            .pipe(\r\n                takeUntil(this._onDestroy$),\r\n                exhaustMap(() => this.uploadFile(files))\r\n            )\r\n            .subscribe();\r\n    }\r\n\r\n    private uploadFile(files: File[]): Observable<any> {\r\n        return this._uploadService.compressFiles$(files).pipe(\r\n            concatMap((formData: FormData) =>\r\n                this._uploadService.upload(formData, this.Setting.ControlFieldDefId).pipe(\r\n                    tap((res) => {\r\n                        if (Array.isArray(res)) {\r\n                            const picture = res[0];\r\n                            if (picture.ErrorMsg) {\r\n                                BarsaApi.Bw.Msg.Error(picture.ErrorMsg);\r\n                                return;\r\n                            }\r\n                            const value = {\r\n                                ...picture,\r\n                                FileId: picture.FileId\r\n                            };\r\n                            this.fireContextEvent('Change', this.context, value);\r\n                        }\r\n                    })\r\n                )\r\n            )\r\n        );\r\n    }\r\n}\r\n","<div\r\n    [style.max-height.px]=\"Setting.SizeMode === '2' ? null : layoutInfo.ControlBounds.height\"\r\n    [class.no-inlineEdit]=\"!inlineEdit\"\r\n    [class.inlineEdit]=\"inlineEdit\"\r\n>\r\n    <div *ngIf=\"!((disableOrReadonly$ | async) === true || Setting.IsReadOnly === true)\">\r\n        <fd-toolbar [fdType]=\"'transparent'\">\r\n            <fd-file-uploader\r\n                #uploader\r\n                fd-toolbar-item\r\n                [style.display]=\"'none'\"\r\n                [id]=\"id\"\r\n                [name]=\"'uploader_' + id\"\r\n                [placeholder]=\"'AttachPicture' | bbbTranslate\"\r\n                [buttonLabel]=\"'AttachPicture' | bbbTranslate\"\r\n                [buttonAriaLabel]=\"'AttachPicture' | bbbTranslate\"\r\n                [accept]=\"validExtensions\"\r\n                [(ngModel)]=\"files\"\r\n                [multiple]=\"false\"\r\n                (selectedFilesChanged)=\"onFileSelection($event)\"\r\n            ></fd-file-uploader>\r\n            <button\r\n                fd-toolbar-item\r\n                fd-button\r\n                [disabled]=\"this.value && value?.IsDeleted !== true\"\r\n                glyph=\"attachment\"\r\n                [fdType]=\"'transparent'\"\r\n                (click)=\"uploader.open()\"\r\n            ></button>\r\n            <button\r\n                class=\"delete\"\r\n                fd-button\r\n                fd-toolbar-item\r\n                [disabled]=\"!this.value || value?.IsDeleted\"\r\n                glyph=\"delete\"\r\n                [fdType]=\"'transparent'\"\r\n                (click)=\"onFileDeleted(uploader)\"\r\n            ></button>\r\n            <ng-container\r\n                *ngTemplateOutlet=\"\r\n                    loadingTpl;\r\n                    context: {\r\n                        uploadingState: uploadingState$ | async\r\n                    }\r\n                \"\r\n            >\r\n            </ng-container>\r\n        </fd-toolbar>\r\n    </div>\r\n    <div\r\n        *ngIf=\"!inlineEdit; else avatarTemplate\"\r\n        [style.max-height.px]=\"Setting.SizeMode === '0' ? layoutInfo.ControlBounds.height : null\"\r\n        [style.max-width.px]=\"Setting.SizeMode === '0' ? layoutInfo.ControlBounds.width : null\"\r\n        [style.text-align]=\"Setting.SizeMode === '3' ? 'center' : null\"\r\n    >\r\n        <bsu-mask *ngIf=\"value && imageUrl\" [marginTop]=\"'0px'\"></bsu-mask>\r\n        <img\r\n            *ngIf=\"(value && imageUrl) || Setting.HasDefaultPicture\"\r\n            imgLazy\r\n            [imgLazy]=\"imageUrl\"\r\n            [src]=\"imageUrl\"\r\n            [ngClass]=\"Setting.SizeMode === '1' ? 'cover' : 'contain'\"\r\n            [style.height.px]=\"Setting.SizeMode !== '2' ? layoutInfo.ControlBounds.height : null\"\r\n        />\r\n    </div>\r\n    <ng-template #avatarTemplate>\r\n        <fd-avatar [size]=\"'m'\" [image]=\"imageUrl\"></fd-avatar>\r\n    </ng-template>\r\n</div>\r\n<!-- <bsu-mask *ngIf=\"uploading$ | async\"></bsu-mask> -->\r\n<ng-template #loadingTpl let-uploadingState=\"uploadingState\">\r\n    <ng-container *ngIf=\"uploadingState && uploadingState.state !== 'Complete' && uploadingState.uploading\">\r\n        <fdp-slider\r\n            fd-toolbar-item\r\n            [id]=\"id + '1'\"\r\n            [name]=\"'slider_' + id\"\r\n            [value]=\"uploadingState.progress\"\r\n            [min]=\"0\"\r\n            [max]=\"100\"\r\n            [step]=\"1\"\r\n        >\r\n        </fdp-slider>\r\n        <button\r\n            *ngIf=\"uploadingState.state === 'Uploading'\"\r\n            fd-toolbar-item\r\n            fd-button\r\n            glyph=\"stop\"\r\n            fdType=\"transparent\"\r\n            (click)=\"onTerminate()\"\r\n        ></button>\r\n        <button\r\n            *ngIf=\"uploadingState.state === 'Error'\"\r\n            fd-toolbar-item\r\n            fd-button\r\n            glyph=\"refresh\"\r\n            [fdType]=\"'transparent'\"\r\n            (click)=\"onRetry()\"\r\n        ></button>\r\n    </ng-container>\r\n</ng-template>\r\n"]}
|