barsa-sap-ui 2.2.2 → 2.2.4
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/esm2022/barsa-sap-ui.mjs +5 -0
- package/esm2022/lib/apply-conditional-formmatings.directive.mjs +90 -0
- package/esm2022/lib/avatar-size.pipe.mjs +41 -0
- package/esm2022/lib/barsa-answer-card/barsa-answer-card.component.mjs +41 -0
- package/esm2022/lib/barsa-asp-viewer/barsa-asp-viewer.component.mjs +145 -0
- package/esm2022/lib/barsa-bar-download-file/barsa-bar-download-file.component.mjs +23 -0
- package/esm2022/lib/barsa-bar-panel/barsa-bar-panel.component.mjs +23 -0
- package/esm2022/lib/barsa-base-panel/barsa-base-layout-panel.component.mjs +29 -0
- package/esm2022/lib/barsa-breadcrumbs/barsa-breadcrumbs.component.mjs +24 -0
- package/esm2022/lib/barsa-card-layout-panel/barsa-card-layout-panel.component.mjs +24 -0
- package/esm2022/lib/barsa-card-row-payam/barsa-card-row-payam.component.mjs +31 -0
- package/esm2022/lib/barsa-cartable-form/barsa-cartable-form.component.mjs +41 -0
- package/esm2022/lib/barsa-cartable-template/barsa-cartable-template.component.mjs +24 -0
- package/esm2022/lib/barsa-chat/barsa-chat.component.mjs +242 -0
- package/esm2022/lib/barsa-chat/chat.model.mjs +8 -0
- package/esm2022/lib/barsa-chat-content/barsa-chat-content.component.mjs +13 -0
- package/esm2022/lib/barsa-chat-content-toolbar/barsa-chat-content-toolbar.component.mjs +22 -0
- package/esm2022/lib/barsa-chat-list/barsa-chat-list.component.mjs +66 -0
- package/esm2022/lib/barsa-chat-message/barsa-chat-message.component.mjs +78 -0
- package/esm2022/lib/barsa-chat-thread/barsa-chat-thread.component.mjs +22 -0
- package/esm2022/lib/barsa-chat-threads-list/barsa-chat-threads-list.component.mjs +13 -0
- package/esm2022/lib/barsa-chat-threads-list-toolbar/barsa-chat-threads-list-toolbar.component.mjs +15 -0
- package/esm2022/lib/barsa-chip/barsa-chip.component.mjs +72 -0
- package/esm2022/lib/barsa-column-indicator/barsa-column-indicator.component.mjs +23 -0
- package/esm2022/lib/barsa-column-rownumber/barsa-column-rownumber.component.mjs +14 -0
- package/esm2022/lib/barsa-custom-inline-edit/barsa-custom-inline-edit.component.mjs +14 -0
- package/esm2022/lib/barsa-custom-inline-edit-row/barsa-custom-inline-edit-row.component.mjs +26 -0
- package/esm2022/lib/barsa-date-time-picker/barsa-date-time-picker.component.mjs +71 -0
- package/esm2022/lib/barsa-dynamic-field/barsa-dynamic-field.component.mjs +40 -0
- package/esm2022/lib/barsa-enum-menu-button/barsa-enum-menu-button.component.mjs +61 -0
- package/esm2022/lib/barsa-field-key-value/barsa-field-key-value.component.mjs +45 -0
- package/esm2022/lib/barsa-form-side-content/barsa-form-side-content.component.mjs +58 -0
- package/esm2022/lib/barsa-grid-layout-panel/barsa-grid-layout-panel.component.mjs +27 -0
- package/esm2022/lib/barsa-group-cartable/barsa-cartable-group.component.mjs +94 -0
- package/esm2022/lib/barsa-horizontal-flex-panel/barsa-horizontal-flex-panel.component.mjs +22 -0
- package/esm2022/lib/barsa-linkable-items-panel/barsa-linkable-items-panel.component.mjs +37 -0
- package/esm2022/lib/barsa-list-file-linear/barsa-list-file-linear.component.mjs +41 -0
- package/esm2022/lib/barsa-list-file-linear-gmail/barsa-list-file-linear-gmail.component.mjs +29 -0
- package/esm2022/lib/barsa-list-layout-panel/barsa-list-layout-panel.component.mjs +23 -0
- package/esm2022/lib/barsa-modal/barsa-modal.component.mjs +43 -0
- package/esm2022/lib/barsa-monaco-editor/barsa-monaco-editor.component.mjs +83 -0
- package/esm2022/lib/barsa-network-offline/barsa-network-offline.component.mjs +57 -0
- package/esm2022/lib/barsa-pishnamayesh-payam/barsa-pishnamayesh-payam.component.mjs +159 -0
- package/esm2022/lib/barsa-question-answer-comments-section/barsa-question-answer-comments-section.component.mjs +17 -0
- package/esm2022/lib/barsa-question-answer-content-actions-section/barsa-question-answer-content-actions-section.component.mjs +30 -0
- package/esm2022/lib/barsa-question-answer-creator-time-section/barsa-question-answer-creator-time-section.component.mjs +14 -0
- package/esm2022/lib/barsa-question-answer-form/barsa-question-answer-form.component.mjs +34 -0
- package/esm2022/lib/barsa-question-answer-form-add-comment/barsa-question-answer-form-add-comment.component.mjs +46 -0
- package/esm2022/lib/barsa-question-answer-vote-section/barsa-question-answer-vote-section.component.mjs +79 -0
- package/esm2022/lib/barsa-question-post/barsa-question-post.component.mjs +30 -0
- package/esm2022/lib/barsa-report-card-flex-view/barsa-report-card-flex-view.component.mjs +31 -0
- package/esm2022/lib/barsa-report-checkbox-switch-button/barsa-report-checkbox-switch-button.component.mjs +28 -0
- package/esm2022/lib/barsa-report-one-of-list/barsa-report-one-of-list.component.mjs +102 -0
- package/esm2022/lib/barsa-row-inline-actionlist/barsa-row-inline-actionlist.component.mjs +26 -0
- package/esm2022/lib/barsa-sap-ui-routing.module.mjs +18 -0
- package/esm2022/lib/barsa-sap-ui.module.mjs +377 -0
- package/esm2022/lib/barsa-search-form/barsa-search-form.component.mjs +29 -0
- package/esm2022/lib/barsa-simple-form/barsa-simple-form.component.mjs +170 -0
- package/esm2022/lib/barsa-tab-route-manager/barsa-tab-route-manager.component.mjs +18 -0
- package/esm2022/lib/barsa-table-column/barsa-table-column.component.mjs +29 -0
- package/esm2022/lib/barsa-table-header/barsa-table-header.component.mjs +222 -0
- package/esm2022/lib/barsa-table-row/barsa-table-row.component.mjs +87 -0
- package/esm2022/lib/barsa-tag-categories/barsa-tag-categories.component.mjs +60 -0
- package/esm2022/lib/barsa-tag-chip/barsa-tag-chip.component.mjs +26 -0
- package/esm2022/lib/barsa-tags-category-row/barsa-tags-category-row.component.mjs +23 -0
- package/esm2022/lib/barsa-text-ellipsis/barsa-text-ellipsis.component.mjs +37 -0
- package/esm2022/lib/barsa-tinyemce/barsa-tinyemce.component.mjs +418 -0
- package/esm2022/lib/barsa-toolbaritem-search/barsa-toolbaritem-search.component.mjs +36 -0
- package/esm2022/lib/barsa-tree-item/barsa-tree-item.component.mjs +153 -0
- package/esm2022/lib/barsa-tree-item/node-has-one-depth-level.pipe.mjs +20 -0
- package/esm2022/lib/barsa-ulv-main/barsa-ulv-main.component.mjs +216 -0
- package/esm2022/lib/blob-viewer/blob-viewer.component.mjs +74 -0
- package/esm2022/lib/breadcrumb/breadcrumb.component.mjs +50 -0
- package/esm2022/lib/captcha-field/captcha-field.component.mjs +28 -0
- package/esm2022/lib/card-item/card-item.component.mjs +74 -0
- package/esm2022/lib/card-view-content/card-view-content.component.mjs +46 -0
- package/esm2022/lib/col-renderer.directive.mjs +47 -0
- package/esm2022/lib/column-matrix-renderer/column-matrix-renderer.component.mjs +56 -0
- package/esm2022/lib/column-matrix-renderer/matrix-value.pipe.mjs +61 -0
- package/esm2022/lib/column-renderer/column-renderer.component.mjs +97 -0
- package/esm2022/lib/constants.mjs +450 -0
- package/esm2022/lib/custom-date-time/custom-date-time.component.mjs +41 -0
- package/esm2022/lib/device-info-field-base.mjs +24 -0
- package/esm2022/lib/dialog-handler.directive.mjs +29 -0
- package/esm2022/lib/download-files.directive.mjs +34 -0
- package/esm2022/lib/dynamic-page-size.pipe.mjs +27 -0
- package/esm2022/lib/file-in-dialog/file-in-dialog.component.mjs +44 -0
- package/esm2022/lib/file-viewer/file-viewer.component.mjs +47 -0
- package/esm2022/lib/file-viewer-content/file-viewer-content.component.mjs +71 -0
- package/esm2022/lib/file-viewer-popover/file-viewer-popover.component.mjs +37 -0
- package/esm2022/lib/form-dialog/form-dialog.component.mjs +171 -0
- package/esm2022/lib/form-dialog-less/form-dialog-less.component.mjs +50 -0
- package/esm2022/lib/form-toolbar/form-toolbar.component.mjs +62 -0
- package/esm2022/lib/form-toolbar-button/form-toolbar-button.component.mjs +45 -0
- package/esm2022/lib/form-wizard/form-wizard.component.mjs +21 -0
- package/esm2022/lib/fullscreen-dialog.directive.mjs +60 -0
- package/esm2022/lib/fullscreen-files.directive.mjs +43 -0
- package/esm2022/lib/fundamental-dynamic-form/fundamental-dynamic-form.component.mjs +217 -0
- package/esm2022/lib/gantt-dhtml-chart-view/gantt-dhtml-chart-view.component.mjs +215 -0
- package/esm2022/lib/global-search/global-search.component.mjs +27 -0
- package/esm2022/lib/global-search-module/global-search-module.component.mjs +29 -0
- package/esm2022/lib/global-search-panel/global-search-panel.component.mjs +25 -0
- package/esm2022/lib/header-avatar/header-avatar.component.mjs +18 -0
- package/esm2022/lib/htree-create-new/htree-create-new.component.mjs +48 -0
- package/esm2022/lib/hyperlink/hyperlink.component.mjs +23 -0
- package/esm2022/lib/index.mjs +549 -0
- package/esm2022/lib/inline-save-and-cancel/inline-save-and-cancel.component.mjs +32 -0
- package/esm2022/lib/layout-actions/layout-actions.component.mjs +70 -0
- package/esm2022/lib/layout-control/layout-control.component.mjs +302 -0
- package/esm2022/lib/layout-wizard/layout-wizard.component.mjs +180 -0
- package/esm2022/lib/list-item/list-item.component.mjs +34 -0
- package/esm2022/lib/ly-empty-space/ly-empty-space.component.mjs +42 -0
- package/esm2022/lib/ly-horizontal-layout/ly-horizontal-layout.component.mjs +82 -0
- package/esm2022/lib/ly-label/ly-label.component.mjs +37 -0
- package/esm2022/lib/ly-layout-container/ly-layout-container.component.mjs +83 -0
- package/esm2022/lib/ly-layout-container-of-root/ly-layout-container-of-root.component.mjs +17 -0
- package/esm2022/lib/ly-layout-field-label/ly-layout-field-label.component.mjs +24 -0
- package/esm2022/lib/ly-layout-panel/ly-layout-panel.component.mjs +83 -0
- package/esm2022/lib/ly-line/ly-line.component.mjs +56 -0
- package/esm2022/lib/ly-simple-label/ly-simple-label.component.mjs +22 -0
- package/esm2022/lib/ly-tab-container/ly-tab-container.component.mjs +44 -0
- package/esm2022/lib/ly-tab-page/ly-tab-page.component.mjs +44 -0
- package/esm2022/lib/ly-vertical-layout/ly-vertical-layout.component.mjs +51 -0
- package/esm2022/lib/manage-filters-report/manage-filters-report.component.mjs +43 -0
- package/esm2022/lib/mask/mask.component.mjs +22 -0
- package/esm2022/lib/message-strip/message-strip.component.mjs +28 -0
- package/esm2022/lib/models/grid-data-provider.mjs +114 -0
- package/esm2022/lib/models/grid-view.mjs +2 -0
- package/esm2022/lib/models/index.mjs +2 -0
- package/esm2022/lib/no-data/no-data.component.mjs +31 -0
- package/esm2022/lib/notification-item/notification-item.component.mjs +57 -0
- package/esm2022/lib/notification-item-actions/notification-item-actions.component.mjs +79 -0
- package/esm2022/lib/notification-popup.service.mjs +92 -0
- package/esm2022/lib/object-status-icon.pipe.mjs +27 -0
- package/esm2022/lib/progress-indicator/progress-indicator.component.mjs +18 -0
- package/esm2022/lib/report-navigator/report-navigator.component.mjs +68 -0
- package/esm2022/lib/report-new-top-form/report-new-top-form.component.mjs +60 -0
- package/esm2022/lib/report-search-fields-hidden-settings/report-search-fields-hidden-settings.component.mjs +35 -0
- package/esm2022/lib/report-search-fields-manage/report-search-fields-manage.component.mjs +97 -0
- package/esm2022/lib/report-search-panel-save/report-search-panel-save.component.mjs +88 -0
- package/esm2022/lib/report-tree-base.mjs +387 -0
- package/esm2022/lib/report-view-renderer.directive.mjs +392 -0
- package/esm2022/lib/responsive-toolbar/responsive-toolbar.component.mjs +50 -0
- package/esm2022/lib/responsive-toolbar-renderer/responsive-toolbar-renderer.component.mjs +84 -0
- package/esm2022/lib/rich-text-static/rich-text-static.component.mjs +72 -0
- package/esm2022/lib/sap-font-class.pipe.mjs +30 -0
- package/esm2022/lib/sap-font.pipe.mjs +30 -0
- package/esm2022/lib/sap-size.pipe.mjs +28 -0
- package/esm2022/lib/sap-ui-report-base.component.mjs +809 -0
- package/esm2022/lib/search-panel/search-panel.component.mjs +63 -0
- package/esm2022/lib/static-text/static-text.component.mjs +15 -0
- package/esm2022/lib/table-th.directive.mjs +87 -0
- package/esm2022/lib/title/title.component.mjs +15 -0
- package/esm2022/lib/ui-asp-report-viewer/ui-asp-report-viewer.component.mjs +34 -0
- package/esm2022/lib/ui-bpmn-viewer/ui-bpmn-viewer.component.mjs +33 -0
- package/esm2022/lib/ui-button/ui-button.component.mjs +32 -0
- package/esm2022/lib/ui-calendar/ui-calendar.component.mjs +53 -0
- package/esm2022/lib/ui-card-view/ui-card-view.component.mjs +58 -0
- package/esm2022/lib/ui-card-view-horizontal-group/ui-card-view-horizontal-group.component.mjs +42 -0
- package/esm2022/lib/ui-check-box/ui-check-box.component.mjs +39 -0
- package/esm2022/lib/ui-color-ui/ui-color-ui.component.mjs +50 -0
- package/esm2022/lib/ui-container-with-button/ui-container-with-button.component.mjs +38 -0
- package/esm2022/lib/ui-date-range-ex/ui-date-range-ex.component.mjs +191 -0
- package/esm2022/lib/ui-date-time/ui-date-time.component.mjs +150 -0
- package/esm2022/lib/ui-editable-grid/ui-editable-grid.component.mjs +108 -0
- package/esm2022/lib/ui-exception-form/ui-exception-form.component.mjs +53 -0
- package/esm2022/lib/ui-file-linear-list-box/ui-file-linear-list-box.component.mjs +124 -0
- package/esm2022/lib/ui-form-panel/ui-form-panel.component.mjs +103 -0
- package/esm2022/lib/ui-gantt-chart/ui-gantt-chart.component.mjs +32 -0
- package/esm2022/lib/ui-graph/ui-graph.component.mjs +17 -0
- package/esm2022/lib/ui-grid/ui-grid.component.mjs +25 -0
- package/esm2022/lib/ui-grid-columns/ui-grid-columns.component.mjs +43 -0
- package/esm2022/lib/ui-grid-filter-item/ui-grid-filter-item.component.mjs +66 -0
- package/esm2022/lib/ui-grid-filter-settings/ui-grid-filter-settings.component.mjs +75 -0
- package/esm2022/lib/ui-grid-sort-item/ui-grid-sort-item.component.mjs +58 -0
- package/esm2022/lib/ui-grid-sort-setting/ui-grid-sort-setting.component.mjs +123 -0
- package/esm2022/lib/ui-html-viewer/ui-html-viewer.component.mjs +16 -0
- package/esm2022/lib/ui-info-bar-panel/ui-info-bar-panel.component.mjs +11 -0
- package/esm2022/lib/ui-label/ui-label.component.mjs +12 -0
- package/esm2022/lib/ui-linear-list-container-with-button/ui-linear-list-container-with-button.component.mjs +379 -0
- package/esm2022/lib/ui-list-view/ui-list-view.component.mjs +84 -0
- package/esm2022/lib/ui-map/ui-map.component.mjs +68 -0
- package/esm2022/lib/ui-matrix-view/ui-matrix-view.component.mjs +124 -0
- package/esm2022/lib/ui-mo-info-combo-viewer/ui-mo-info-combo-viewer.component.mjs +19 -0
- package/esm2022/lib/ui-mo-info-general-object-ui/ui-mo-info-general-object-ui.component.mjs +14 -0
- package/esm2022/lib/ui-mo-info-sub-form-ui/ui-mo-info-sub-form-ui.component.mjs +55 -0
- package/esm2022/lib/ui-mo-info-ulv-combo/ui-mo-info-ulv-combo.component.mjs +429 -0
- package/esm2022/lib/ui-monaco-editor/ui-monaco-editor.component.mjs +28 -0
- package/esm2022/lib/ui-multi-select-card/ui-multi-select-card.component.mjs +37 -0
- package/esm2022/lib/ui-multi-select-checkbox/ui-multi-select-checkbox.component.mjs +59 -0
- package/esm2022/lib/ui-multi-select-combo/ui-multi-select-combo.component.mjs +93 -0
- package/esm2022/lib/ui-multi-select-radio/ui-multi-select-radio.component.mjs +36 -0
- package/esm2022/lib/ui-multi-select-slider/ui-multi-select-slider.component.mjs +56 -0
- package/esm2022/lib/ui-multi-select-smile/ui-multi-select-smile.component.mjs +28 -0
- package/esm2022/lib/ui-notification-view/ui-notification-view.component.mjs +47 -0
- package/esm2022/lib/ui-num-decimal-ui/ui-num-decimal-ui.component.mjs +33 -0
- package/esm2022/lib/ui-num-int-slider/ui-num-int-slider.component.mjs +27 -0
- package/esm2022/lib/ui-num-int-ui/ui-num-int-ui.component.mjs +21 -0
- package/esm2022/lib/ui-pdf-viewer/ui-pdf-viewer.component.mjs +268 -0
- package/esm2022/lib/ui-picture-file/ui-picture-file.component.mjs +101 -0
- package/esm2022/lib/ui-pictures-info/ui-pictures-info.component.mjs +261 -0
- package/esm2022/lib/ui-radio-group/ui-radio-group.component.mjs +48 -0
- package/esm2022/lib/ui-read-only-field/ui-read-only-field.component.mjs +36 -0
- package/esm2022/lib/ui-report-container/ui-report-container.component.mjs +46 -0
- package/esm2022/lib/ui-search-command-info-ui/ui-search-command-info-ui.component.mjs +24 -0
- package/esm2022/lib/ui-simple-combo/ui-simple-combo.component.mjs +55 -0
- package/esm2022/lib/ui-single-picture/ui-single-picture.component.mjs +36 -0
- package/esm2022/lib/ui-switch-button/ui-switch-button.component.mjs +20 -0
- package/esm2022/lib/ui-table-view/ui-table-view.component.mjs +296 -0
- package/esm2022/lib/ui-text-area/ui-text-area.component.mjs +49 -0
- package/esm2022/lib/ui-text-field/ui-text-field.component.mjs +52 -0
- package/esm2022/lib/ui-text-field-auto-complete/ui-text-field-auto-complete.component.mjs +48 -0
- package/esm2022/lib/ui-time-span/ui-time-span.component.mjs +24 -0
- package/esm2022/lib/ui-tinymce/ui-tinymce.component.mjs +53 -0
- package/esm2022/lib/ui-tree/ui-tree.component.mjs +114 -0
- package/esm2022/lib/ui-tree-view/ui-tree-view.component.mjs +100 -0
- package/esm2022/lib/ui-ulv-form-multi-select-ui/ui-ulv-form-multi-select-ui.component.mjs +23 -0
- package/esm2022/lib/ui-ulv-main-ui/ui-ulv-main-ui.component.mjs +310 -0
- package/esm2022/lib/ui-workflow-panel-ui/ui-workflow-panel-ui.component.mjs +25 -0
- package/esm2022/lib/ul-loading-mask-ui/ul-loading-mask-ui.component.mjs +93 -0
- package/esm2022/lib/ul-msg-box-adapter/ul-msg-box-adapter.component.mjs +119 -0
- package/esm2022/lib/ul-notify-popup/ul-notify-popup.component.mjs +32 -0
- package/esm2022/lib/ul-toast-adapter/ul-toast-adapter.component.mjs +48 -0
- package/esm2022/lib/ulv-column-settings/ulv-column-settings.component.mjs +53 -0
- package/esm2022/lib/ulv-context-menu/ulv-context-menu.component.mjs +116 -0
- package/esm2022/lib/ulv-filter-settings/ulv-filter-settings.component.mjs +43 -0
- package/esm2022/lib/ulv-form-multi-select/ulv-form-multi-select.component.mjs +196 -0
- package/esm2022/lib/ulv-groupby-settings/ulv-groupby-settings.component.mjs +44 -0
- package/esm2022/lib/ulv-paging/ulv-paging.component.mjs +84 -0
- package/esm2022/lib/ulv-selection/ulv-selection.component.mjs +65 -0
- package/esm2022/lib/ulv-settings/ulv-settings.component.mjs +116 -0
- package/esm2022/lib/ulv-sort-settings/ulv-sort-settings.component.mjs +54 -0
- package/esm2022/lib/ulv-toolbar/ulv-toolbar.component.mjs +177 -0
- package/esm2022/lib/upload-file-status.pipe.mjs +29 -0
- package/esm2022/lib/util-chat-time-badge.pipe.mjs +18 -0
- package/esm2022/lib/util-date-to-hh-mm.pipe.mjs +23 -0
- package/esm2022/lib/wizard-layout.directive.mjs +104 -0
- package/esm2022/public-api.mjs +236 -0
- package/fesm2022/barsa-sap-ui.mjs +6 -6
- package/fesm2022/barsa-sap-ui.mjs.map +1 -1
- package/package.json +3 -1
|
@@ -0,0 +1,150 @@
|
|
|
1
|
+
import { Component, Input, ViewChild, ChangeDetectionStrategy, NgZone, inject } from '@angular/core';
|
|
2
|
+
import { BarsaApi, FieldBaseComponent, DateService, LogService, getDateService } from 'barsa-novin-ray-core';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@fundamental-ngx/core/form";
|
|
5
|
+
import * as i2 from "barsa-calendar";
|
|
6
|
+
import * as i3 from "@angular/common";
|
|
7
|
+
export class UiDateTimeComponent extends FieldBaseComponent {
|
|
8
|
+
constructor() {
|
|
9
|
+
super(...arguments);
|
|
10
|
+
this.valueCaption = '';
|
|
11
|
+
this._ngZone = inject(NgZone);
|
|
12
|
+
/* eslint-disable */
|
|
13
|
+
this.GetCaption = () => this.valueCaption;
|
|
14
|
+
}
|
|
15
|
+
ngOnInit() {
|
|
16
|
+
super.ngOnInit();
|
|
17
|
+
if (this.parameters?.DateRangeMode && this.parameters?.DateRangeOtherField) {
|
|
18
|
+
const formpanel = BarsaApi.Common.Util.TryGetValue(this.context, 'LayoutControl.config.FormPanelUi', null);
|
|
19
|
+
if (formpanel) {
|
|
20
|
+
formpanel.fireEvent('ChangeFieldVisible', this.parameters.DateRangeOtherField, false);
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
if (typeof this.value === 'string' && this.value) {
|
|
24
|
+
this.value = this.context.value = new Date(this.value);
|
|
25
|
+
}
|
|
26
|
+
this.fullCalendar = this.Setting.ShowTime1 && this.Setting.ShowDate1;
|
|
27
|
+
this._setTimeFormat();
|
|
28
|
+
// this.value$.pipe(takeUntil(this._onDestroy$)).subscribe((value) => {
|
|
29
|
+
// this.value = <Date>value;
|
|
30
|
+
// // this._setValueCaption(value);
|
|
31
|
+
// });
|
|
32
|
+
// // this._setValueCaption(this.value);
|
|
33
|
+
}
|
|
34
|
+
ngAfterViewInit() {
|
|
35
|
+
super.ngAfterViewInit();
|
|
36
|
+
this._setCaption(this.value);
|
|
37
|
+
}
|
|
38
|
+
onDateTimeChange() {
|
|
39
|
+
const datetimePickerControl = this.datetimePickerRef.nativeElement;
|
|
40
|
+
this.value = datetimePickerControl.dateValue;
|
|
41
|
+
this.valueCaption = datetimePickerControl.value;
|
|
42
|
+
this.valueChange.emit(this.value);
|
|
43
|
+
}
|
|
44
|
+
onDateChange() {
|
|
45
|
+
const datePickerControl = this.datePickerRef.nativeElement;
|
|
46
|
+
this._valueDateChange(datePickerControl.dateValue);
|
|
47
|
+
}
|
|
48
|
+
onDateChange2(date) {
|
|
49
|
+
this._valueDateChange(date);
|
|
50
|
+
}
|
|
51
|
+
onDurationChange(e) {
|
|
52
|
+
const { value } = e.detail;
|
|
53
|
+
if (!this.value) {
|
|
54
|
+
this.value = new Date();
|
|
55
|
+
}
|
|
56
|
+
const time = value.split(':');
|
|
57
|
+
this.value.setHours(Number(time[0]), Number(time[1]), Number(time[2]));
|
|
58
|
+
this.valueCaption = this.durationPickerRef.nativeElement.value;
|
|
59
|
+
this.valueChange.emit(this.value);
|
|
60
|
+
}
|
|
61
|
+
onRangeChange(rangeValue) {
|
|
62
|
+
console.log('endDate', rangeValue);
|
|
63
|
+
}
|
|
64
|
+
_setTimeFormat() {
|
|
65
|
+
const timeFormat = this.Setting.TimeFormat?.toLowerCase();
|
|
66
|
+
let timeFormat2 = '';
|
|
67
|
+
if (timeFormat) {
|
|
68
|
+
timeFormat2 = ' ';
|
|
69
|
+
timeFormat.split(':').forEach((val) => {
|
|
70
|
+
switch (val) {
|
|
71
|
+
case 'h':
|
|
72
|
+
timeFormat2 += 'HH';
|
|
73
|
+
break;
|
|
74
|
+
case 'i':
|
|
75
|
+
timeFormat2 += ':mm';
|
|
76
|
+
break;
|
|
77
|
+
case 's':
|
|
78
|
+
timeFormat2 += ':SS';
|
|
79
|
+
break;
|
|
80
|
+
}
|
|
81
|
+
});
|
|
82
|
+
}
|
|
83
|
+
const dateFormat = !this.Setting.ShowDate1 ? '' : 'YYYY/MM/DD';
|
|
84
|
+
const timeFormat3 = !this.Setting.ShowTime1 ? '' : timeFormat2;
|
|
85
|
+
// timeFormat2 += ' A';
|
|
86
|
+
this.formatPattern = `${dateFormat}${timeFormat3}`;
|
|
87
|
+
}
|
|
88
|
+
_configChaned(options) {
|
|
89
|
+
// implemented by child components
|
|
90
|
+
this._setTimeFormat();
|
|
91
|
+
const temp = this.value;
|
|
92
|
+
if (!this.Setting.ShowTime1) {
|
|
93
|
+
if (typeof temp === 'object') {
|
|
94
|
+
temp.setHours(0);
|
|
95
|
+
temp.setMinutes(0);
|
|
96
|
+
temp.setSeconds(0);
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
if (typeof temp === 'object') {
|
|
100
|
+
this._valueDateChange(new Date(temp));
|
|
101
|
+
}
|
|
102
|
+
super._configChaned(options);
|
|
103
|
+
}
|
|
104
|
+
_setValue(value) {
|
|
105
|
+
this._setCaption(value);
|
|
106
|
+
super._setValue(value);
|
|
107
|
+
}
|
|
108
|
+
_valueDateChange(dateValue) {
|
|
109
|
+
this.value = dateValue;
|
|
110
|
+
this.valueCaption = this._setCaption(dateValue); // datePickerControl.value;
|
|
111
|
+
this.valueChange.emit(this.value);
|
|
112
|
+
}
|
|
113
|
+
_setCaption(value) {
|
|
114
|
+
const caption = (this.context.caption =
|
|
115
|
+
this.valueCaption =
|
|
116
|
+
this._dateService.format(value, this.formatPattern));
|
|
117
|
+
this._cdr.detectChanges();
|
|
118
|
+
return caption;
|
|
119
|
+
}
|
|
120
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: UiDateTimeComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
121
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: UiDateTimeComponent, selector: "bsu-ui-date-time", inputs: { GetCaption: "GetCaption" }, providers: [
|
|
122
|
+
{
|
|
123
|
+
provide: DateService,
|
|
124
|
+
useFactory: getDateService,
|
|
125
|
+
deps: [LogService]
|
|
126
|
+
}
|
|
127
|
+
], viewQueries: [{ propertyName: "datetimePickerRef", first: true, predicate: ["datetimePicker"], descendants: true }, { propertyName: "datePickerRef", first: true, predicate: ["datePicker"], descendants: true }, { propertyName: "durationPickerRef", first: true, predicate: ["durationPicker"], descendants: true }], usesInheritance: true, ngImport: i0, template: "@if ((readonly$ | async) === true) {\r\n<input fd-form-control type=\"text\" [attr.readonly]=\"true\" [value]=\"value ? valueCaption : ''\" />\r\n} @else{\r\n<div\r\n [class.disabled]=\"(disable$ | async) === true\"\r\n [style.display]=\"(disableOrReadonly$ | async)!! ? 'hidden' : 'block'\"\r\n [attr.dir]=\"Setting.IsLtr === true ? 'ltr' : 'rtl'\"\r\n>\r\n <bc-date-time-picker\r\n [value]=\"value\"\r\n [buttonMenuMode]=\"parameters?.ButtonMenuMode === true\"\r\n [showDate]=\"Setting.ShowDate1\"\r\n [showTime]=\"Setting.ShowTime1\"\r\n [placeholder]=\"parameters?.ButtonMenuMode === true ? parameters.Placeholder : formatPattern\"\r\n [primaryCalendarType]=\"Setting.CalendarType\"\r\n [formatPattern]=\"formatPattern\"\r\n [deviceSize]=\"(deviceSize$ | async)!!\"\r\n [isMobile]=\"isMobile\"\r\n [daterangeMode]=\"parameters?.DateRangeMode === true\"\r\n [inlineMode]=\"parameters?.InlineMode === true\"\r\n [readonly]=\"(readonly$ | async) === true ? true : false\"\r\n [disabled]=\"(disable$ | async) === true ? true : false\"\r\n (valueChange)=\"onDateChange2($event)\"\r\n (rangeChange)=\"onRangeChange($event)\"\r\n >\r\n </bc-date-time-picker>\r\n</div>\r\n}\r\n", styles: [":host{display:block}\n"], dependencies: [{ kind: "component", type: i1.FormControlComponent, selector: "input[fd-form-control], textarea[fd-form-control]", inputs: ["state", "type", "class", "ariaLabel", "ariaLabelledBy"] }, { kind: "component", type: i2.DateTimePickerComponent, selector: "bc-date-time-picker", inputs: ["placeholder", "primaryCalendarType", "formatPattern", "value", "timeValue", "startRangeDate", "endRangeDate", "isRangePicker", "showTime", "showDate", "rtl", "deviceSize", "isMobile", "readonly", "disabled", "buttonMenuMode", "inlineMode", "daterangeMode"], outputs: ["rangeChange", "valueChange"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
128
|
+
}
|
|
129
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: UiDateTimeComponent, decorators: [{
|
|
130
|
+
type: Component,
|
|
131
|
+
args: [{ selector: 'bsu-ui-date-time', providers: [
|
|
132
|
+
{
|
|
133
|
+
provide: DateService,
|
|
134
|
+
useFactory: getDateService,
|
|
135
|
+
deps: [LogService]
|
|
136
|
+
}
|
|
137
|
+
], changeDetection: ChangeDetectionStrategy.OnPush, standalone: false, template: "@if ((readonly$ | async) === true) {\r\n<input fd-form-control type=\"text\" [attr.readonly]=\"true\" [value]=\"value ? valueCaption : ''\" />\r\n} @else{\r\n<div\r\n [class.disabled]=\"(disable$ | async) === true\"\r\n [style.display]=\"(disableOrReadonly$ | async)!! ? 'hidden' : 'block'\"\r\n [attr.dir]=\"Setting.IsLtr === true ? 'ltr' : 'rtl'\"\r\n>\r\n <bc-date-time-picker\r\n [value]=\"value\"\r\n [buttonMenuMode]=\"parameters?.ButtonMenuMode === true\"\r\n [showDate]=\"Setting.ShowDate1\"\r\n [showTime]=\"Setting.ShowTime1\"\r\n [placeholder]=\"parameters?.ButtonMenuMode === true ? parameters.Placeholder : formatPattern\"\r\n [primaryCalendarType]=\"Setting.CalendarType\"\r\n [formatPattern]=\"formatPattern\"\r\n [deviceSize]=\"(deviceSize$ | async)!!\"\r\n [isMobile]=\"isMobile\"\r\n [daterangeMode]=\"parameters?.DateRangeMode === true\"\r\n [inlineMode]=\"parameters?.InlineMode === true\"\r\n [readonly]=\"(readonly$ | async) === true ? true : false\"\r\n [disabled]=\"(disable$ | async) === true ? true : false\"\r\n (valueChange)=\"onDateChange2($event)\"\r\n (rangeChange)=\"onRangeChange($event)\"\r\n >\r\n </bc-date-time-picker>\r\n</div>\r\n}\r\n", styles: [":host{display:block}\n"] }]
|
|
138
|
+
}], propDecorators: { datetimePickerRef: [{
|
|
139
|
+
type: ViewChild,
|
|
140
|
+
args: ['datetimePicker']
|
|
141
|
+
}], datePickerRef: [{
|
|
142
|
+
type: ViewChild,
|
|
143
|
+
args: ['datePicker']
|
|
144
|
+
}], durationPickerRef: [{
|
|
145
|
+
type: ViewChild,
|
|
146
|
+
args: ['durationPicker']
|
|
147
|
+
}], GetCaption: [{
|
|
148
|
+
type: Input
|
|
149
|
+
}] } });
|
|
150
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ui-date-time.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-sap-ui/src/lib/ui-date-time/ui-date-time.component.ts","../../../../../projects/barsa-sap-ui/src/lib/ui-date-time/ui-date-time.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    AfterViewInit,\r\n    Component,\r\n    ElementRef,\r\n    OnInit,\r\n    Input,\r\n    ViewChild,\r\n    ChangeDetectionStrategy,\r\n    NgZone,\r\n    inject\r\n} from '@angular/core';\r\n\r\nimport {\r\n    MetaobjectDataModel,\r\n    BarsaApi,\r\n    FieldBaseComponent,\r\n    DateService,\r\n    LogService,\r\n    getDateService\r\n} from 'barsa-novin-ray-core';\r\n\r\n@Component({\r\n    selector: 'bsu-ui-date-time',\r\n    templateUrl: './ui-date-time.component.html',\r\n    styleUrls: ['./ui-date-time.component.scss'],\r\n    providers: [\r\n        {\r\n            provide: DateService,\r\n            useFactory: getDateService,\r\n            deps: [LogService]\r\n        }\r\n    ],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    standalone: false\r\n})\r\nexport class UiDateTimeComponent extends FieldBaseComponent implements OnInit, AfterViewInit {\r\n    @ViewChild('datetimePicker') datetimePickerRef: ElementRef;\r\n    @ViewChild('datePicker') datePickerRef: ElementRef;\r\n    @ViewChild('durationPicker') durationPickerRef: ElementRef;\r\n    fullCalendar: boolean;\r\n    value: Date;\r\n    valueCaption = '';\r\n    formatPattern: string;\r\n    parameters: UiDateTimeSetting;\r\n    private _ngZone = inject(NgZone);\r\n    ngOnInit(): void {\r\n        super.ngOnInit();\r\n        if (this.parameters?.DateRangeMode && this.parameters?.DateRangeOtherField) {\r\n            const formpanel = BarsaApi.Common.Util.TryGetValue(this.context, 'LayoutControl.config.FormPanelUi', null);\r\n            if (formpanel) {\r\n                formpanel.fireEvent('ChangeFieldVisible', this.parameters.DateRangeOtherField, false);\r\n            }\r\n        }\r\n        if (typeof this.value === 'string' && this.value) {\r\n            this.value = this.context.value = new Date(this.value);\r\n        }\r\n        this.fullCalendar = this.Setting.ShowTime1 && this.Setting.ShowDate1;\r\n        this._setTimeFormat();\r\n        // this.value$.pipe(takeUntil(this._onDestroy$)).subscribe((value) => {\r\n        //   this.value = <Date>value;\r\n\r\n        //   // this._setValueCaption(value);\r\n        // });\r\n        // // this._setValueCaption(this.value);\r\n    }\r\n\r\n    ngAfterViewInit(): void {\r\n        super.ngAfterViewInit();\r\n        this._setCaption(this.value);\r\n    }\r\n    onDateTimeChange(): void {\r\n        const datetimePickerControl = this.datetimePickerRef.nativeElement;\r\n        this.value = datetimePickerControl.dateValue;\r\n        this.valueCaption = datetimePickerControl.value;\r\n        this.valueChange.emit(this.value);\r\n    }\r\n    onDateChange(): void {\r\n        const datePickerControl = this.datePickerRef.nativeElement;\r\n        this._valueDateChange(datePickerControl.dateValue);\r\n    }\r\n    onDateChange2(date): void {\r\n        this._valueDateChange(date);\r\n    }\r\n\r\n    onDurationChange(e): void {\r\n        const { value } = e.detail;\r\n        if (!this.value) {\r\n            this.value = new Date();\r\n        }\r\n        const time = value.split(':');\r\n        this.value.setHours(Number(time[0]), Number(time[1]), Number(time[2]));\r\n        this.valueCaption = this.durationPickerRef.nativeElement.value;\r\n        this.valueChange.emit(this.value);\r\n    }\r\n    onRangeChange(rangeValue: { startDay: Date; endDay: Date }): void {\r\n        console.log('endDate', rangeValue);\r\n    }\r\n    protected _setTimeFormat(): void {\r\n        const timeFormat: string = this.Setting.TimeFormat?.toLowerCase();\r\n        let timeFormat2 = '';\r\n        if (timeFormat) {\r\n            timeFormat2 = ' ';\r\n            timeFormat.split(':').forEach((val) => {\r\n                switch (val) {\r\n                    case 'h':\r\n                        timeFormat2 += 'HH';\r\n                        break;\r\n                    case 'i':\r\n                        timeFormat2 += ':mm';\r\n                        break;\r\n                    case 's':\r\n                        timeFormat2 += ':SS';\r\n                        break;\r\n                }\r\n            });\r\n        }\r\n        const dateFormat = !this.Setting.ShowDate1 ? '' : 'YYYY/MM/DD';\r\n        const timeFormat3 = !this.Setting.ShowTime1 ? '' : timeFormat2;\r\n\r\n        // timeFormat2 += ' A';\r\n        this.formatPattern = `${dateFormat}${timeFormat3}`;\r\n    }\r\n    protected _configChaned(options): void {\r\n        // implemented by child components\r\n        this._setTimeFormat();\r\n\r\n        const temp = this.value;\r\n        if (!this.Setting.ShowTime1) {\r\n            if (typeof temp === 'object') {\r\n                temp.setHours(0);\r\n                temp.setMinutes(0);\r\n                temp.setSeconds(0);\r\n            }\r\n        }\r\n        if (typeof temp === 'object') {\r\n            this._valueDateChange(new Date(temp));\r\n        }\r\n        super._configChaned(options);\r\n    }\r\n    protected _setValue(value: Date): void {\r\n        this._setCaption(value);\r\n        super._setValue(value);\r\n    }\r\n    private _valueDateChange(dateValue: Date): void {\r\n        this.value = dateValue;\r\n        this.valueCaption = this._setCaption(dateValue); // datePickerControl.value;\r\n        this.valueChange.emit(this.value);\r\n    }\r\n    private _setCaption(value: Date): string {\r\n        const caption =\r\n            (this.context.caption =\r\n            this.valueCaption =\r\n                this._dateService.format(value, this.formatPattern));\r\n        this._cdr.detectChanges();\r\n        return caption;\r\n    }\r\n    /* eslint-disable */\r\n    @Input() GetCaption = () => this.valueCaption;\r\n}\r\ninterface UiDateTimeSetting extends MetaobjectDataModel {\r\n    ButtonMenuMode: boolean;\r\n    Placeholder: string;\r\n    InlineMode: boolean;\r\n    DateRangeMode: boolean;\r\n    DateRangeOtherField: string;\r\n}\r\n","@if ((readonly$ | async) === true) {\r\n<input fd-form-control type=\"text\" [attr.readonly]=\"true\" [value]=\"value ? valueCaption : ''\" />\r\n} @else{\r\n<div\r\n    [class.disabled]=\"(disable$ | async) === true\"\r\n    [style.display]=\"(disableOrReadonly$ | async)!! ? 'hidden' : 'block'\"\r\n    [attr.dir]=\"Setting.IsLtr === true ? 'ltr' : 'rtl'\"\r\n>\r\n    <bc-date-time-picker\r\n        [value]=\"value\"\r\n        [buttonMenuMode]=\"parameters?.ButtonMenuMode === true\"\r\n        [showDate]=\"Setting.ShowDate1\"\r\n        [showTime]=\"Setting.ShowTime1\"\r\n        [placeholder]=\"parameters?.ButtonMenuMode === true ? parameters.Placeholder : formatPattern\"\r\n        [primaryCalendarType]=\"Setting.CalendarType\"\r\n        [formatPattern]=\"formatPattern\"\r\n        [deviceSize]=\"(deviceSize$ | async)!!\"\r\n        [isMobile]=\"isMobile\"\r\n        [daterangeMode]=\"parameters?.DateRangeMode === true\"\r\n        [inlineMode]=\"parameters?.InlineMode === true\"\r\n        [readonly]=\"(readonly$ | async) === true ? true : false\"\r\n        [disabled]=\"(disable$ | async) === true ? true : false\"\r\n        (valueChange)=\"onDateChange2($event)\"\r\n        (rangeChange)=\"onRangeChange($event)\"\r\n    >\r\n    </bc-date-time-picker>\r\n</div>\r\n}\r\n"]}
|
|
@@ -0,0 +1,108 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component } from '@angular/core';
|
|
2
|
+
import { map, takeUntil, tap } from 'rxjs/operators';
|
|
3
|
+
import { createGridEditorFormPanel, FormPanelService } from 'barsa-novin-ray-core';
|
|
4
|
+
import { SapUiReportBaseComponent } from '../sap-ui-report-base.component';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "@angular/common";
|
|
7
|
+
import * as i2 from "@fundamental-ngx/core/button";
|
|
8
|
+
import * as i3 from "@fundamental-ngx/core/toolbar";
|
|
9
|
+
import * as i4 from "../ulv-toolbar/ulv-toolbar.component";
|
|
10
|
+
import * as i5 from "../ui-matrix-view/ui-matrix-view.component";
|
|
11
|
+
import * as i6 from "barsa-novin-ray-core";
|
|
12
|
+
export class UiEditableGridComponent extends SapUiReportBaseComponent {
|
|
13
|
+
constructor() {
|
|
14
|
+
super(...arguments);
|
|
15
|
+
this.cellWidth = 100;
|
|
16
|
+
this.cellHeight = 38;
|
|
17
|
+
this.verticalLabelWidth = 100;
|
|
18
|
+
this.minWidth = 100;
|
|
19
|
+
this.minHeight = 22;
|
|
20
|
+
this.enableResizing = true;
|
|
21
|
+
this.rowResizer = true;
|
|
22
|
+
this.widthTypeEnum = WidthTypeEnum;
|
|
23
|
+
this.fitWidth = true;
|
|
24
|
+
}
|
|
25
|
+
ngOnInit() {
|
|
26
|
+
super.ngOnInit();
|
|
27
|
+
this.valueDbName = this.context.Setting.View.ValueDbName;
|
|
28
|
+
this.valueType = this.context.valueFieldType;
|
|
29
|
+
const formSetting = this.context.Setting.FormTemplate;
|
|
30
|
+
// this.formLayout = this.context.Setting.FormTemplate.View.ControlInfo;
|
|
31
|
+
this.horizontalRows = this.context.Setting.View.HorizontalColumn;
|
|
32
|
+
this.valueControlFieldCaption = this.context.Setting.FormTemplate.View.ControlInfo.find((col) => col.ControlName === this.valueDbName).ControlFieldCaption;
|
|
33
|
+
// there is different between ulv modatalist and viewer datalist. in matrixviewer adapter modatalist transformed.
|
|
34
|
+
// so we need tell to ulvmainservice to update modatalist
|
|
35
|
+
this._ulvMainService.reSetMoDataList(this.context.moDataList);
|
|
36
|
+
this.matrixMoList$ = this.moDataList$.pipe(takeUntil(this._onDestroy$), map((moDataList) => this._matrixMoList(moDataList)));
|
|
37
|
+
if (!this.formPanelCtrlr) {
|
|
38
|
+
this.formPanelCtrlr = createGridEditorFormPanel(formSetting, formSetting.Data.Mo, this._typeDefId, null
|
|
39
|
+
// BarsaApi.Common.Util.TryGetValue(this.context.Setting, 'Extra.Relation')
|
|
40
|
+
);
|
|
41
|
+
const formPanelCtrlr = this.formPanelCtrlr;
|
|
42
|
+
this.formLayout = formPanelCtrlr.Setting.View.Layout94;
|
|
43
|
+
formPanelCtrlr.on({
|
|
44
|
+
ValueChange: this._cellValueChange.bind(this)
|
|
45
|
+
});
|
|
46
|
+
this.formPanelCtrlr.LoadAndCreate(null, false, false, () => {
|
|
47
|
+
const customFormPanelUi = formPanelCtrlr.Adapter.Control;
|
|
48
|
+
customFormPanelUi.Refresh = () => { };
|
|
49
|
+
this._formpanelService.context = formPanelCtrlr.Adapter.Control;
|
|
50
|
+
});
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
onSave() {
|
|
54
|
+
this.context.fireEvent('SaveBatchClicked', this.moDataList.filter((c) => c.$Modified).map((c) => ({ data: c, modified: c.$Modified })));
|
|
55
|
+
}
|
|
56
|
+
onSelectionChange(cellInfo) {
|
|
57
|
+
const { value, index } = cellInfo;
|
|
58
|
+
this.activeCell = index;
|
|
59
|
+
// const newMo = getNewMoGridEditor(this.context.Setting.FormTemplate, this._typeDefId);
|
|
60
|
+
// newMo[this.valueDbName] = value;
|
|
61
|
+
const controlUi = this.formPanelCtrlr.GetFieldlByName(this.valueDbName);
|
|
62
|
+
controlUi.SetValue(value);
|
|
63
|
+
}
|
|
64
|
+
onChangeView(isFit) {
|
|
65
|
+
this.fitWidth = isFit;
|
|
66
|
+
}
|
|
67
|
+
/* eslint-disable */
|
|
68
|
+
_select(mo, index) {
|
|
69
|
+
return mo;
|
|
70
|
+
}
|
|
71
|
+
_matrixMoList(moDataList) {
|
|
72
|
+
moDataList.forEach((mo) => {
|
|
73
|
+
this.horizontalRows.forEach((col) => {
|
|
74
|
+
if (mo[col.Caption] === undefined) {
|
|
75
|
+
mo[col.Caption] = null;
|
|
76
|
+
}
|
|
77
|
+
});
|
|
78
|
+
});
|
|
79
|
+
return moDataList;
|
|
80
|
+
}
|
|
81
|
+
_cellValueChange(sender) {
|
|
82
|
+
const indexI = this.activeCell.i;
|
|
83
|
+
const indexJ = this.activeCell.j;
|
|
84
|
+
this.moDataList$
|
|
85
|
+
.pipe(takeUntil(this._onDestroy$), tap((moDataList) => {
|
|
86
|
+
moDataList[indexI][this.horizontalRows[indexJ].Caption] = sender.Mo[this.valueDbName];
|
|
87
|
+
if (moDataList[indexI].$Modified) {
|
|
88
|
+
moDataList[indexI].$Modified[this.horizontalRows[indexJ].Caption] = 1;
|
|
89
|
+
}
|
|
90
|
+
else {
|
|
91
|
+
moDataList[indexI].$Modified = { [this.horizontalRows[indexJ].Caption]: 1 };
|
|
92
|
+
}
|
|
93
|
+
}))
|
|
94
|
+
.subscribe();
|
|
95
|
+
}
|
|
96
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: UiEditableGridComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
97
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: UiEditableGridComponent, selector: "bsu-ui-editable-grid", providers: [FormPanelService], usesInheritance: true, ngImport: i0, template: "<ng-container\r\n *ngTemplateOutlet=\"\r\n matrixTemplate;\r\n context: {\r\n moDataList: matrixMoList$ | async,\r\n columns: horizontalRows,\r\n conditionalFormats: conditionalFormats$ | async,\r\n deviceName: deviceName$ | async,\r\n deviceSize: deviceSize$ | async,\r\n title: title$ | async,\r\n inlineEditMode: inlineEditMode$ | async,\r\n allowInlineEdit: allowInlineEdit$ | async,\r\n hideToolbar: hideToolbar$ | async,\r\n contentDensity: contentDensity$ | async,\r\n activeCell: activeCell,\r\n valueControlFieldCaption: valueControlFieldCaption,\r\n valueType: valueType,\r\n formSetting: context.Setting.FormTemplate,\r\n matrixWidthType: matrixWidthType,\r\n cellWidth: cellWidth,\r\n verticalLabelWidth: verticalLabelWidth,\r\n fitWidth: fitWidth,\r\n access: context.Setting.Extra?.DefaultCommandsAccess,\r\n hasSelected: hasSelected$ | async,\r\n containerWidth: containerWidth$ | async,\r\n formLayout: formLayout\r\n }\r\n \"\r\n></ng-container>\r\n\r\n<ng-template\r\n #matrixTemplate\r\n let-moDataList=\"moDataList\"\r\n let-deviceName=\"deviceName\"\r\n let-deviceSize=\"deviceSize\"\r\n let-title=\"title\"\r\n let-inlineEditMode=\"inlineEditMode\"\r\n let-allowInlineEdit=\"allowInlineEdit\"\r\n let-hideToolbar=\"hideToolbar\"\r\n let-contentDensity=\"contentDensity\"\r\n let-columns=\"columns\"\r\n let-conditionalFormats=\"conditionalFormats\"\r\n let-activeCell=\"activeCell\"\r\n let-valueControlFieldCaption=\"valueControlFieldCaption\"\r\n let-valueType=\"valueType\"\r\n let-formSetting=\"formSetting\"\r\n let-matrixWidthType=\"matrixWidthType\"\r\n let-cellWidth=\"cellWidth\"\r\n let-verticalLabelWidth=\"verticalLabelWidth\"\r\n let-fitWidth=\"fitWidth\"\r\n let-access=\"access\"\r\n let-hasSelected=\"hasSelected\"\r\n let-containerWidth=\"containterWidth\"\r\n let-formLayout=\"formLayout\"\r\n>\r\n <bsu-ulv-toolbar\r\n [hideToolbar]=\"hideToolbar\"\r\n [deviceName]=\"deviceName\"\r\n [deviceSize]=\"deviceSize\"\r\n [title]=\"title\"\r\n [hasSelected]=\"hasSelected\"\r\n [access]=\"access\"\r\n [contentDensity]=\"contentDensity\"\r\n [inlineEditMode]=\"inlineEditMode\"\r\n [allowInlineEdit]=\"allowInlineEdit\"\r\n [moDataListCount]=\"moDataList.length\"\r\n (sortClick)=\"onSortSettings(deviceName)\"\r\n (editModeClick)=\"onEditMode()\"\r\n >\r\n <button\r\n fd-toolbar-item\r\n fd-button\r\n [fdType]=\"'emphasized'\"\r\n [label]=\"'Save' | bbbTranslate\"\r\n [glyph]=\"'save'\"\r\n (click)=\"onSave()\"\r\n ></button>\r\n <!-- <fd-split-button\r\n fd-toolbar-item\r\n [mainAction]=\"{\r\n keepMainAction: true,\r\n mainActionTitle: splitBtnTitle\r\n }\"\r\n >\r\n <fd-menu>\r\n <li fd-menu-item>\r\n <div fd-menu-interactive (click)=\"onChangeView(true)\">\r\n <span fd-menu-title>\r\n {{ widthTypeEnum.FitWidth }}\r\n </span>\r\n </div>\r\n </li>\r\n <li fd-menu-item>\r\n <div fd-menu-interactive (click)=\"onChangeView(false)\">\r\n <span fd-menu-title>\r\n {{ widthTypeEnum.StaticWidth }}\r\n </span>\r\n </div>\r\n </li>\r\n </fd-menu>\r\n </fd-split-button> -->\r\n\r\n <ng-template #splitBtnTitle>\r\n <span>{{ fitWidth ? widthTypeEnum.FitWidth : widthTypeEnum.StaticWidth }}</span>\r\n </ng-template>\r\n </bsu-ulv-toolbar>\r\n <bsu-ui-matrix-view\r\n [moDataList]=\"moDataList\"\r\n [columns]=\"columns\"\r\n [conditionalFormats]=\"conditionalFormats\"\r\n [activeCell]=\"activeCell\"\r\n [valueControlFieldCaption]=\"valueControlFieldCaption\"\r\n [valueType]=\"valueType\"\r\n [access]=\"access\"\r\n [formLayout]=\"formLayout\"\r\n [matrixWidthType]=\"matrixWidthType\"\r\n [cellWidth]=\"cellWidth\"\r\n [cellHeight]=\"cellHeight\"\r\n [verticalLabelWidth]=\"verticalLabelWidth\"\r\n [fitWidth]=\"fitWidth\"\r\n [minWidth]=\"minWidth\"\r\n [minHeight]=\"minHeight\"\r\n [rowResizer]=\"rowResizer\"\r\n [enableResizing]=\"enableResizing\"\r\n [containerWidth]=\"containerWidth\"\r\n (selectionChange)=\"onSelectionChange($event)\"\r\n ></bsu-ui-matrix-view>\r\n</ng-template>\r\n", styles: [":host{display:flex;width:100%;height:100%;flex-direction:column}.fd-table__row th.fd-table__cell{background-color:var(--sapList_HeaderBackground, #f2f2f2);color:var(--sapList_HeaderTextColor, #32363a)}\n"], dependencies: [{ kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.ButtonComponent, selector: "button[fd-button], a[fd-button], span[fd-button]", inputs: ["class"], exportAs: ["fd-button"] }, { kind: "directive", type: i3.ToolbarItemDirective, selector: "[fd-toolbar-item], [fdOverflowGroup], [fdOverflowPriority]", inputs: ["fdOverflowPriority", "fdOverflowGroup"] }, { kind: "component", type: i4.UlvToolbarComponent, selector: "bsu-ulv-toolbar", inputs: ["allowGridColumnSort", "useLayoutItemTextForControl", "enableSearch", "hideTitle", "title", "icon", "deviceName", "deviceSize", "access", "hideToolbar", "toolbarButtons", "contentDensity", "inlineEditMode", "allowInlineEdit", "gridSetting", "viewCollection", "reportView", "inDialog", "isMultiSelect", "cls", "hasSelected", "config", "hidden", "buttons", "moDataListCount"], outputs: ["search", "groupbyClick", "sortClick", "columnClick", "editModeClick", "viewClick", "createNewInlineMo"] }, { kind: "component", type: i5.UiMatrixViewComponent, selector: "bsu-ui-matrix-view", inputs: ["deviceSize", "deviceName", "moDataList", "columns", "formLayout", "conditionalFormat", "activeCell", "valueControlFieldCaption", "formTemplate", "valueType", "cellWidth", "cellHeight", "verticalLabelWidth", "fitWidth", "minWidth", "minHeight", "rowResizer", "enableResizing"], outputs: ["selectionChange"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i6.BbbTranslatePipe, name: "bbbTranslate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
98
|
+
}
|
|
99
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: UiEditableGridComponent, decorators: [{
|
|
100
|
+
type: Component,
|
|
101
|
+
args: [{ selector: 'bsu-ui-editable-grid', changeDetection: ChangeDetectionStrategy.OnPush, providers: [FormPanelService], standalone: false, template: "<ng-container\r\n *ngTemplateOutlet=\"\r\n matrixTemplate;\r\n context: {\r\n moDataList: matrixMoList$ | async,\r\n columns: horizontalRows,\r\n conditionalFormats: conditionalFormats$ | async,\r\n deviceName: deviceName$ | async,\r\n deviceSize: deviceSize$ | async,\r\n title: title$ | async,\r\n inlineEditMode: inlineEditMode$ | async,\r\n allowInlineEdit: allowInlineEdit$ | async,\r\n hideToolbar: hideToolbar$ | async,\r\n contentDensity: contentDensity$ | async,\r\n activeCell: activeCell,\r\n valueControlFieldCaption: valueControlFieldCaption,\r\n valueType: valueType,\r\n formSetting: context.Setting.FormTemplate,\r\n matrixWidthType: matrixWidthType,\r\n cellWidth: cellWidth,\r\n verticalLabelWidth: verticalLabelWidth,\r\n fitWidth: fitWidth,\r\n access: context.Setting.Extra?.DefaultCommandsAccess,\r\n hasSelected: hasSelected$ | async,\r\n containerWidth: containerWidth$ | async,\r\n formLayout: formLayout\r\n }\r\n \"\r\n></ng-container>\r\n\r\n<ng-template\r\n #matrixTemplate\r\n let-moDataList=\"moDataList\"\r\n let-deviceName=\"deviceName\"\r\n let-deviceSize=\"deviceSize\"\r\n let-title=\"title\"\r\n let-inlineEditMode=\"inlineEditMode\"\r\n let-allowInlineEdit=\"allowInlineEdit\"\r\n let-hideToolbar=\"hideToolbar\"\r\n let-contentDensity=\"contentDensity\"\r\n let-columns=\"columns\"\r\n let-conditionalFormats=\"conditionalFormats\"\r\n let-activeCell=\"activeCell\"\r\n let-valueControlFieldCaption=\"valueControlFieldCaption\"\r\n let-valueType=\"valueType\"\r\n let-formSetting=\"formSetting\"\r\n let-matrixWidthType=\"matrixWidthType\"\r\n let-cellWidth=\"cellWidth\"\r\n let-verticalLabelWidth=\"verticalLabelWidth\"\r\n let-fitWidth=\"fitWidth\"\r\n let-access=\"access\"\r\n let-hasSelected=\"hasSelected\"\r\n let-containerWidth=\"containterWidth\"\r\n let-formLayout=\"formLayout\"\r\n>\r\n <bsu-ulv-toolbar\r\n [hideToolbar]=\"hideToolbar\"\r\n [deviceName]=\"deviceName\"\r\n [deviceSize]=\"deviceSize\"\r\n [title]=\"title\"\r\n [hasSelected]=\"hasSelected\"\r\n [access]=\"access\"\r\n [contentDensity]=\"contentDensity\"\r\n [inlineEditMode]=\"inlineEditMode\"\r\n [allowInlineEdit]=\"allowInlineEdit\"\r\n [moDataListCount]=\"moDataList.length\"\r\n (sortClick)=\"onSortSettings(deviceName)\"\r\n (editModeClick)=\"onEditMode()\"\r\n >\r\n <button\r\n fd-toolbar-item\r\n fd-button\r\n [fdType]=\"'emphasized'\"\r\n [label]=\"'Save' | bbbTranslate\"\r\n [glyph]=\"'save'\"\r\n (click)=\"onSave()\"\r\n ></button>\r\n <!-- <fd-split-button\r\n fd-toolbar-item\r\n [mainAction]=\"{\r\n keepMainAction: true,\r\n mainActionTitle: splitBtnTitle\r\n }\"\r\n >\r\n <fd-menu>\r\n <li fd-menu-item>\r\n <div fd-menu-interactive (click)=\"onChangeView(true)\">\r\n <span fd-menu-title>\r\n {{ widthTypeEnum.FitWidth }}\r\n </span>\r\n </div>\r\n </li>\r\n <li fd-menu-item>\r\n <div fd-menu-interactive (click)=\"onChangeView(false)\">\r\n <span fd-menu-title>\r\n {{ widthTypeEnum.StaticWidth }}\r\n </span>\r\n </div>\r\n </li>\r\n </fd-menu>\r\n </fd-split-button> -->\r\n\r\n <ng-template #splitBtnTitle>\r\n <span>{{ fitWidth ? widthTypeEnum.FitWidth : widthTypeEnum.StaticWidth }}</span>\r\n </ng-template>\r\n </bsu-ulv-toolbar>\r\n <bsu-ui-matrix-view\r\n [moDataList]=\"moDataList\"\r\n [columns]=\"columns\"\r\n [conditionalFormats]=\"conditionalFormats\"\r\n [activeCell]=\"activeCell\"\r\n [valueControlFieldCaption]=\"valueControlFieldCaption\"\r\n [valueType]=\"valueType\"\r\n [access]=\"access\"\r\n [formLayout]=\"formLayout\"\r\n [matrixWidthType]=\"matrixWidthType\"\r\n [cellWidth]=\"cellWidth\"\r\n [cellHeight]=\"cellHeight\"\r\n [verticalLabelWidth]=\"verticalLabelWidth\"\r\n [fitWidth]=\"fitWidth\"\r\n [minWidth]=\"minWidth\"\r\n [minHeight]=\"minHeight\"\r\n [rowResizer]=\"rowResizer\"\r\n [enableResizing]=\"enableResizing\"\r\n [containerWidth]=\"containerWidth\"\r\n (selectionChange)=\"onSelectionChange($event)\"\r\n ></bsu-ui-matrix-view>\r\n</ng-template>\r\n", styles: [":host{display:flex;width:100%;height:100%;flex-direction:column}.fd-table__row th.fd-table__cell{background-color:var(--sapList_HeaderBackground, #f2f2f2);color:var(--sapList_HeaderTextColor, #32363a)}\n"] }]
|
|
102
|
+
}] });
|
|
103
|
+
export var WidthTypeEnum;
|
|
104
|
+
(function (WidthTypeEnum) {
|
|
105
|
+
WidthTypeEnum["FitWidth"] = "\u0633\u062A\u0648\u0646 \u0647\u0627\u06CC \u0647\u0645 \u0639\u0631\u0636";
|
|
106
|
+
WidthTypeEnum["StaticWidth"] = "\u0633\u062A\u0648\u0646 \u0647\u0627\u06CC \u0628\u0627 \u0639\u0631\u0636 \u062F\u0644\u062E\u0648\u0627\u0647";
|
|
107
|
+
})(WidthTypeEnum || (WidthTypeEnum = {}));
|
|
108
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ui-editable-grid.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-sap-ui/src/lib/ui-editable-grid/ui-editable-grid.component.ts","../../../../../projects/barsa-sap-ui/src/lib/ui-editable-grid/ui-editable-grid.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, OnDestroy, OnInit } from '@angular/core';\r\nimport { map, takeUntil, tap } from 'rxjs/operators';\r\n\r\nimport {\r\n    createGridEditorFormPanel,\r\n    FormPanelService,\r\n    LayoutSetting,\r\n    MetaobjectDataModel,\r\n    UiReportViewBaseSetting\r\n} from 'barsa-novin-ray-core';\r\nimport { SapUiReportBaseComponent } from '../sap-ui-report-base.component';\r\nimport { Observable } from 'rxjs';\r\n\r\n@Component({\r\n    selector: 'bsu-ui-editable-grid',\r\n    templateUrl: './ui-editable-grid.component.html',\r\n    styleUrls: ['./ui-editable-grid.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    providers: [FormPanelService],\r\n    standalone: false\r\n})\r\nexport class UiEditableGridComponent\r\n    extends SapUiReportBaseComponent<UiReportViewBaseSetting>\r\n    implements OnInit, OnDestroy\r\n{\r\n    valueControlFieldCaption;\r\n    valueDbName;\r\n    horizontalRows: any[];\r\n    activeCell;\r\n    valueType;\r\n    formLayout: LayoutSetting;\r\n    matrixWidthType;\r\n    cellWidth = 100;\r\n    cellHeight = 38;\r\n    verticalLabelWidth = 100;\r\n    minWidth = 100;\r\n    minHeight = 22;\r\n    enableResizing = true;\r\n    rowResizer = true;\r\n    widthTypeEnum = WidthTypeEnum;\r\n    fitWidth = true;\r\n    matrixMoList$: Observable<MetaobjectDataModel[]>;\r\n\r\n    ngOnInit(): void {\r\n        super.ngOnInit();\r\n        this.valueDbName = this.context.Setting.View.ValueDbName;\r\n        this.valueType = this.context.valueFieldType;\r\n        const formSetting = this.context.Setting.FormTemplate;\r\n        // this.formLayout = this.context.Setting.FormTemplate.View.ControlInfo;\r\n        this.horizontalRows = this.context.Setting.View.HorizontalColumn;\r\n        this.valueControlFieldCaption = this.context.Setting.FormTemplate.View.ControlInfo.find(\r\n            (col) => col.ControlName === this.valueDbName\r\n        ).ControlFieldCaption;\r\n        // there is different between ulv modatalist and viewer datalist. in matrixviewer adapter modatalist transformed.\r\n        // so we need tell to ulvmainservice to update modatalist\r\n        this._ulvMainService.reSetMoDataList(this.context.moDataList);\r\n\r\n        this.matrixMoList$ = this.moDataList$.pipe(\r\n            takeUntil(this._onDestroy$),\r\n            map((moDataList) => this._matrixMoList(moDataList))\r\n        );\r\n\r\n        if (!this.formPanelCtrlr) {\r\n            this.formPanelCtrlr = createGridEditorFormPanel(\r\n                formSetting,\r\n                formSetting.Data.Mo,\r\n                this._typeDefId,\r\n                null\r\n                // BarsaApi.Common.Util.TryGetValue(this.context.Setting, 'Extra.Relation')\r\n            );\r\n            const formPanelCtrlr = this.formPanelCtrlr;\r\n            this.formLayout = formPanelCtrlr.Setting.View.Layout94;\r\n\r\n            formPanelCtrlr.on({\r\n                ValueChange: this._cellValueChange.bind(this)\r\n            });\r\n            this.formPanelCtrlr.LoadAndCreate(null, false, false, () => {\r\n                const customFormPanelUi = formPanelCtrlr.Adapter.Control;\r\n                customFormPanelUi.Refresh = () => {};\r\n                this._formpanelService.context = formPanelCtrlr.Adapter.Control;\r\n            });\r\n        }\r\n    }\r\n    onSave(): void {\r\n        this.context.fireEvent(\r\n            'SaveBatchClicked',\r\n            this.moDataList.filter((c) => c.$Modified).map((c) => ({ data: c, modified: c.$Modified }))\r\n        );\r\n    }\r\n    onSelectionChange(cellInfo: { value: any; index: { i: number; j: number } }): void {\r\n        const { value, index } = cellInfo;\r\n        this.activeCell = index;\r\n        // const newMo = getNewMoGridEditor(this.context.Setting.FormTemplate, this._typeDefId);\r\n        // newMo[this.valueDbName] = value;\r\n\r\n        const controlUi = this.formPanelCtrlr.GetFieldlByName(this.valueDbName);\r\n        controlUi.SetValue(value);\r\n    }\r\n    onChangeView(isFit: boolean): void {\r\n        this.fitWidth = isFit;\r\n    }\r\n\r\n    /* eslint-disable */\r\n    protected _select(mo, index): MetaobjectDataModel {\r\n        return mo;\r\n    }\r\n    private _matrixMoList(moDataList): MetaobjectDataModel[] {\r\n        moDataList.forEach((mo) => {\r\n            this.horizontalRows.forEach((col) => {\r\n                if (mo[col.Caption] === undefined) {\r\n                    mo[col.Caption] = null;\r\n                }\r\n            });\r\n        });\r\n        return moDataList;\r\n    }\r\n    private _cellValueChange(sender): void {\r\n        const indexI = this.activeCell.i;\r\n        const indexJ = this.activeCell.j;\r\n        this.moDataList$\r\n            .pipe(\r\n                takeUntil(this._onDestroy$),\r\n                tap((moDataList) => {\r\n                    moDataList[indexI][this.horizontalRows[indexJ].Caption] = sender.Mo[this.valueDbName];\r\n                    if (moDataList[indexI].$Modified) {\r\n                        moDataList[indexI].$Modified[this.horizontalRows[indexJ].Caption] = 1;\r\n                    } else {\r\n                        moDataList[indexI].$Modified = { [this.horizontalRows[indexJ].Caption]: 1 };\r\n                    }\r\n                })\r\n            )\r\n            .subscribe();\r\n    }\r\n}\r\nexport enum WidthTypeEnum {\r\n    FitWidth = 'ستون های هم عرض',\r\n    StaticWidth = 'ستون های با عرض دلخواه'\r\n}\r\n","<ng-container\r\n    *ngTemplateOutlet=\"\r\n        matrixTemplate;\r\n        context: {\r\n            moDataList: matrixMoList$ | async,\r\n            columns: horizontalRows,\r\n            conditionalFormats: conditionalFormats$ | async,\r\n            deviceName: deviceName$ | async,\r\n            deviceSize: deviceSize$ | async,\r\n            title: title$ | async,\r\n            inlineEditMode: inlineEditMode$ | async,\r\n            allowInlineEdit: allowInlineEdit$ | async,\r\n            hideToolbar: hideToolbar$ | async,\r\n            contentDensity: contentDensity$ | async,\r\n            activeCell: activeCell,\r\n            valueControlFieldCaption: valueControlFieldCaption,\r\n            valueType: valueType,\r\n            formSetting: context.Setting.FormTemplate,\r\n            matrixWidthType: matrixWidthType,\r\n            cellWidth: cellWidth,\r\n            verticalLabelWidth: verticalLabelWidth,\r\n            fitWidth: fitWidth,\r\n            access: context.Setting.Extra?.DefaultCommandsAccess,\r\n            hasSelected: hasSelected$ | async,\r\n            containerWidth: containerWidth$ | async,\r\n            formLayout: formLayout\r\n        }\r\n    \"\r\n></ng-container>\r\n\r\n<ng-template\r\n    #matrixTemplate\r\n    let-moDataList=\"moDataList\"\r\n    let-deviceName=\"deviceName\"\r\n    let-deviceSize=\"deviceSize\"\r\n    let-title=\"title\"\r\n    let-inlineEditMode=\"inlineEditMode\"\r\n    let-allowInlineEdit=\"allowInlineEdit\"\r\n    let-hideToolbar=\"hideToolbar\"\r\n    let-contentDensity=\"contentDensity\"\r\n    let-columns=\"columns\"\r\n    let-conditionalFormats=\"conditionalFormats\"\r\n    let-activeCell=\"activeCell\"\r\n    let-valueControlFieldCaption=\"valueControlFieldCaption\"\r\n    let-valueType=\"valueType\"\r\n    let-formSetting=\"formSetting\"\r\n    let-matrixWidthType=\"matrixWidthType\"\r\n    let-cellWidth=\"cellWidth\"\r\n    let-verticalLabelWidth=\"verticalLabelWidth\"\r\n    let-fitWidth=\"fitWidth\"\r\n    let-access=\"access\"\r\n    let-hasSelected=\"hasSelected\"\r\n    let-containerWidth=\"containterWidth\"\r\n    let-formLayout=\"formLayout\"\r\n>\r\n    <bsu-ulv-toolbar\r\n        [hideToolbar]=\"hideToolbar\"\r\n        [deviceName]=\"deviceName\"\r\n        [deviceSize]=\"deviceSize\"\r\n        [title]=\"title\"\r\n        [hasSelected]=\"hasSelected\"\r\n        [access]=\"access\"\r\n        [contentDensity]=\"contentDensity\"\r\n        [inlineEditMode]=\"inlineEditMode\"\r\n        [allowInlineEdit]=\"allowInlineEdit\"\r\n        [moDataListCount]=\"moDataList.length\"\r\n        (sortClick)=\"onSortSettings(deviceName)\"\r\n        (editModeClick)=\"onEditMode()\"\r\n    >\r\n        <button\r\n            fd-toolbar-item\r\n            fd-button\r\n            [fdType]=\"'emphasized'\"\r\n            [label]=\"'Save' | bbbTranslate\"\r\n            [glyph]=\"'save'\"\r\n            (click)=\"onSave()\"\r\n        ></button>\r\n        <!-- <fd-split-button\r\n            fd-toolbar-item\r\n            [mainAction]=\"{\r\n                keepMainAction: true,\r\n                mainActionTitle: splitBtnTitle\r\n            }\"\r\n        >\r\n            <fd-menu>\r\n                <li fd-menu-item>\r\n                    <div fd-menu-interactive (click)=\"onChangeView(true)\">\r\n                        <span fd-menu-title>\r\n                            {{ widthTypeEnum.FitWidth }}\r\n                        </span>\r\n                    </div>\r\n                </li>\r\n                <li fd-menu-item>\r\n                    <div fd-menu-interactive (click)=\"onChangeView(false)\">\r\n                        <span fd-menu-title>\r\n                            {{ widthTypeEnum.StaticWidth }}\r\n                        </span>\r\n                    </div>\r\n                </li>\r\n            </fd-menu>\r\n        </fd-split-button> -->\r\n\r\n        <ng-template #splitBtnTitle>\r\n            <span>{{ fitWidth ? widthTypeEnum.FitWidth : widthTypeEnum.StaticWidth }}</span>\r\n        </ng-template>\r\n    </bsu-ulv-toolbar>\r\n    <bsu-ui-matrix-view\r\n        [moDataList]=\"moDataList\"\r\n        [columns]=\"columns\"\r\n        [conditionalFormats]=\"conditionalFormats\"\r\n        [activeCell]=\"activeCell\"\r\n        [valueControlFieldCaption]=\"valueControlFieldCaption\"\r\n        [valueType]=\"valueType\"\r\n        [access]=\"access\"\r\n        [formLayout]=\"formLayout\"\r\n        [matrixWidthType]=\"matrixWidthType\"\r\n        [cellWidth]=\"cellWidth\"\r\n        [cellHeight]=\"cellHeight\"\r\n        [verticalLabelWidth]=\"verticalLabelWidth\"\r\n        [fitWidth]=\"fitWidth\"\r\n        [minWidth]=\"minWidth\"\r\n        [minHeight]=\"minHeight\"\r\n        [rowResizer]=\"rowResizer\"\r\n        [enableResizing]=\"enableResizing\"\r\n        [containerWidth]=\"containerWidth\"\r\n        (selectionChange)=\"onSelectionChange($event)\"\r\n    ></bsu-ui-matrix-view>\r\n</ng-template>\r\n"]}
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, ViewChild } from '@angular/core';
|
|
2
|
+
import { BaseComponent, BarsaApi } from 'barsa-novin-ray-core';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@fundamental-ngx/core";
|
|
5
|
+
import * as i2 from "barsa-novin-ray-core";
|
|
6
|
+
import * as i3 from "@fundamental-ngx/core/button";
|
|
7
|
+
import * as i4 from "@fundamental-ngx/core/dialog";
|
|
8
|
+
import * as i5 from "@fundamental-ngx/core/title";
|
|
9
|
+
export class UiExceptionFormComponent extends BaseComponent {
|
|
10
|
+
constructor(_dialogService) {
|
|
11
|
+
super();
|
|
12
|
+
this._dialogService = _dialogService;
|
|
13
|
+
}
|
|
14
|
+
ngOnInit() {
|
|
15
|
+
super.ngOnInit();
|
|
16
|
+
BarsaApi.Ui.ExceptionForm.IsHandled = true;
|
|
17
|
+
BarsaApi.Ui.ExceptionForm.Show = (text, detail, callback) => {
|
|
18
|
+
this._dialogService.open(this.templateRef, {
|
|
19
|
+
...{ text, detail, callback },
|
|
20
|
+
responsivePadding: true
|
|
21
|
+
});
|
|
22
|
+
};
|
|
23
|
+
}
|
|
24
|
+
onClose(dialog, dialogConfig) {
|
|
25
|
+
dialog.close();
|
|
26
|
+
if (dialogConfig.callback) {
|
|
27
|
+
dialogConfig.callback();
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
onContinue(dialog, dialogConfig) {
|
|
31
|
+
dialog.close();
|
|
32
|
+
if (dialogConfig.callback) {
|
|
33
|
+
dialogConfig.callback();
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
onLogout(dialog, dialogConfig) {
|
|
37
|
+
dialog.close();
|
|
38
|
+
if (dialogConfig.callback) {
|
|
39
|
+
dialogConfig.callback();
|
|
40
|
+
}
|
|
41
|
+
BarsaApi.Bw.Logout();
|
|
42
|
+
}
|
|
43
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: UiExceptionFormComponent, deps: [{ token: i1.DialogService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
44
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: UiExceptionFormComponent, selector: "bsu-ui-exception-form", viewQueries: [{ propertyName: "templateRef", first: true, predicate: ["templateRef"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<ng-template let-dialog let-dialogConfig=\"dialogConfig\" #templateRef>\n <fd-dialog [dialogConfig]=\"dialogConfig\" [dialogRef]=\"dialog\">\n <fd-dialog-header>\n <h1 fd-title>\n {{ dialogConfig.text }}\n </h1>\n\n <button fd-dialog-close-button (click)=\"onClose(dialog, dialogConfig)\"></button>\n </fd-dialog-header>\n\n <fd-dialog-body style=\"padding: 15px\">\n <div style=\"min-height: 125px\">\n <label fd-label [innerHtml]=\"dialogConfig.detail\"> </label>\n </div>\n </fd-dialog-body>\n\n <fd-dialog-footer>\n <fd-dialog-footer-button>\n <button\n fd-button\n fd-dialog-decisive-button\n [fdType]=\"'emphasized'\"\n [label]=\"'Continue' | bbbTranslate\"\n (click)=\"onContinue(dialog, dialogConfig)\"\n ></button>\n </fd-dialog-footer-button>\n <fd-dialog-footer-button>\n <button\n fd-button\n fd-dialog-decisive-button\n [fdType]=\"'standard'\"\n [label]=\"'Copy' | bbbTranslate\"\n [copy]=\"dialogConfig.detail\"\n ></button>\n </fd-dialog-footer-button>\n <fd-dialog-footer-button>\n <button\n fd-button\n fd-dialog-decisive-button\n [fdType]=\"'negative'\"\n [label]=\"'Logout' | bbbTranslate\"\n (click)=\"onLogout(dialog, dialogConfig)\"\n ></button>\n </fd-dialog-footer-button>\n </fd-dialog-footer>\n </fd-dialog>\n</ng-template>\n", styles: [""], dependencies: [{ kind: "directive", type: i2.CopyDirective, selector: "[copy]", inputs: ["copy"] }, { kind: "component", type: i3.ButtonComponent, selector: "button[fd-button], a[fd-button], span[fd-button]", inputs: ["class"], exportAs: ["fd-button"] }, { kind: "component", type: i4.DialogComponent, selector: "fd-dialog", inputs: ["class", "dialogRef", "dialogConfig"] }, { kind: "component", type: i4.DialogBodyComponent, selector: "fd-dialog-body", inputs: ["disablePaddings"] }, { kind: "component", type: i4.DialogFooterComponent, selector: "fd-dialog-footer" }, { kind: "component", type: i4.DialogHeaderComponent, selector: "fd-dialog-header" }, { kind: "component", type: i4.DialogCloseButtonComponent, selector: "[fd-dialog-close-button]", inputs: ["mobile", "title", "ariaLabel"] }, { kind: "component", type: i5.TitleComponent, selector: "[fd-title], [fdTitle]", inputs: ["headerSize", "wrap"], exportAs: ["fd-title"] }, { kind: "pipe", type: i2.BbbTranslatePipe, name: "bbbTranslate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
45
|
+
}
|
|
46
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: UiExceptionFormComponent, decorators: [{
|
|
47
|
+
type: Component,
|
|
48
|
+
args: [{ selector: 'bsu-ui-exception-form', changeDetection: ChangeDetectionStrategy.OnPush, standalone: false, template: "<ng-template let-dialog let-dialogConfig=\"dialogConfig\" #templateRef>\n <fd-dialog [dialogConfig]=\"dialogConfig\" [dialogRef]=\"dialog\">\n <fd-dialog-header>\n <h1 fd-title>\n {{ dialogConfig.text }}\n </h1>\n\n <button fd-dialog-close-button (click)=\"onClose(dialog, dialogConfig)\"></button>\n </fd-dialog-header>\n\n <fd-dialog-body style=\"padding: 15px\">\n <div style=\"min-height: 125px\">\n <label fd-label [innerHtml]=\"dialogConfig.detail\"> </label>\n </div>\n </fd-dialog-body>\n\n <fd-dialog-footer>\n <fd-dialog-footer-button>\n <button\n fd-button\n fd-dialog-decisive-button\n [fdType]=\"'emphasized'\"\n [label]=\"'Continue' | bbbTranslate\"\n (click)=\"onContinue(dialog, dialogConfig)\"\n ></button>\n </fd-dialog-footer-button>\n <fd-dialog-footer-button>\n <button\n fd-button\n fd-dialog-decisive-button\n [fdType]=\"'standard'\"\n [label]=\"'Copy' | bbbTranslate\"\n [copy]=\"dialogConfig.detail\"\n ></button>\n </fd-dialog-footer-button>\n <fd-dialog-footer-button>\n <button\n fd-button\n fd-dialog-decisive-button\n [fdType]=\"'negative'\"\n [label]=\"'Logout' | bbbTranslate\"\n (click)=\"onLogout(dialog, dialogConfig)\"\n ></button>\n </fd-dialog-footer-button>\n </fd-dialog-footer>\n </fd-dialog>\n</ng-template>\n" }]
|
|
49
|
+
}], ctorParameters: () => [{ type: i1.DialogService }], propDecorators: { templateRef: [{
|
|
50
|
+
type: ViewChild,
|
|
51
|
+
args: ['templateRef']
|
|
52
|
+
}] } });
|
|
53
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidWktZXhjZXB0aW9uLWZvcm0uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2Etc2FwLXVpL3NyYy9saWIvdWktZXhjZXB0aW9uLWZvcm0vdWktZXhjZXB0aW9uLWZvcm0uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2Etc2FwLXVpL3NyYy9saWIvdWktZXhjZXB0aW9uLWZvcm0vdWktZXhjZXB0aW9uLWZvcm0uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBdUIsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBR25HLE9BQU8sRUFBRSxhQUFhLEVBQUUsUUFBUSxFQUFFLE1BQU0sc0JBQXNCLENBQUM7Ozs7Ozs7QUFRL0QsTUFBTSxPQUFPLHdCQUF5QixTQUFRLGFBQWE7SUFFdkQsWUFBb0IsY0FBNkI7UUFDN0MsS0FBSyxFQUFFLENBQUM7UUFEUSxtQkFBYyxHQUFkLGNBQWMsQ0FBZTtJQUVqRCxDQUFDO0lBRUQsUUFBUTtRQUNKLEtBQUssQ0FBQyxRQUFRLEVBQUUsQ0FBQztRQUNqQixRQUFRLENBQUMsRUFBRSxDQUFDLGFBQWEsQ0FBQyxTQUFTLEdBQUcsSUFBSSxDQUFDO1FBQzNDLFFBQVEsQ0FBQyxFQUFFLENBQUMsYUFBYSxDQUFDLElBQUksR0FBRyxDQUFDLElBQUksRUFBRSxNQUFNLEVBQUUsUUFBUSxFQUFFLEVBQUU7WUFDeEQsSUFBSSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFdBQVcsRUFBRTtnQkFDdkMsR0FBRyxFQUFFLElBQUksRUFBRSxNQUFNLEVBQUUsUUFBUSxFQUFFO2dCQUM3QixpQkFBaUIsRUFBRSxJQUFJO2FBQzFCLENBQUMsQ0FBQztRQUNQLENBQUMsQ0FBQztJQUNOLENBQUM7SUFDRCxPQUFPLENBQUMsTUFBTSxFQUFFLFlBQVk7UUFDeEIsTUFBTSxDQUFDLEtBQUssRUFBRSxDQUFDO1FBQ2YsSUFBSSxZQUFZLENBQUMsUUFBUSxFQUFFLENBQUM7WUFDeEIsWUFBWSxDQUFDLFFBQVEsRUFBRSxDQUFDO1FBQzVCLENBQUM7SUFDTCxDQUFDO0lBQ0QsVUFBVSxDQUFDLE1BQU0sRUFBRSxZQUFZO1FBQzNCLE1BQU0sQ0FBQyxLQUFLLEVBQUUsQ0FBQztRQUNmLElBQUksWUFBWSxDQUFDLFFBQVEsRUFBRSxDQUFDO1lBQ3hCLFlBQVksQ0FBQyxRQUFRLEVBQUUsQ0FBQztRQUM1QixDQUFDO0lBQ0wsQ0FBQztJQUNELFFBQVEsQ0FBQyxNQUFNLEVBQUUsWUFBWTtRQUN6QixNQUFNLENBQUMsS0FBSyxFQUFFLENBQUM7UUFDZixJQUFJLFlBQVksQ0FBQyxRQUFRLEVBQUUsQ0FBQztZQUN4QixZQUFZLENBQUMsUUFBUSxFQUFFLENBQUM7UUFDNUIsQ0FBQztRQUNELFFBQVEsQ0FBQyxFQUFFLENBQUMsTUFBTSxFQUFFLENBQUM7SUFDekIsQ0FBQzsrR0FsQ1Esd0JBQXdCO21HQUF4Qix3QkFBd0IsZ01DWHJDLG15REErQ0E7OzRGRHBDYSx3QkFBd0I7a0JBUHBDLFNBQVM7K0JBQ0ksdUJBQXVCLG1CQUdoQix1QkFBdUIsQ0FBQyxNQUFNLGNBQ25DLEtBQUs7a0ZBR1MsV0FBVztzQkFBcEMsU0FBUzt1QkFBQyxhQUFhIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgT25Jbml0LCBUZW1wbGF0ZVJlZiwgVmlld0NoaWxkIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IERpYWxvZ1NlcnZpY2UgfSBmcm9tICdAZnVuZGFtZW50YWwtbmd4L2NvcmUnO1xyXG5cclxuaW1wb3J0IHsgQmFzZUNvbXBvbmVudCwgQmFyc2FBcGkgfSBmcm9tICdiYXJzYS1ub3Zpbi1yYXktY29yZSc7XHJcbkBDb21wb25lbnQoe1xyXG4gICAgc2VsZWN0b3I6ICdic3UtdWktZXhjZXB0aW9uLWZvcm0nLFxyXG4gICAgdGVtcGxhdGVVcmw6ICcuL3VpLWV4Y2VwdGlvbi1mb3JtLmNvbXBvbmVudC5odG1sJyxcclxuICAgIHN0eWxlVXJsczogWycuL3VpLWV4Y2VwdGlvbi1mb3JtLmNvbXBvbmVudC5zY3NzJ10sXHJcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcclxuICAgIHN0YW5kYWxvbmU6IGZhbHNlXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBVaUV4Y2VwdGlvbkZvcm1Db21wb25lbnQgZXh0ZW5kcyBCYXNlQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcclxuICAgIEBWaWV3Q2hpbGQoJ3RlbXBsYXRlUmVmJykgdGVtcGxhdGVSZWY6IFRlbXBsYXRlUmVmPGFueT47XHJcbiAgICBjb25zdHJ1Y3Rvcihwcml2YXRlIF9kaWFsb2dTZXJ2aWNlOiBEaWFsb2dTZXJ2aWNlKSB7XHJcbiAgICAgICAgc3VwZXIoKTtcclxuICAgIH1cclxuXHJcbiAgICBuZ09uSW5pdCgpOiB2b2lkIHtcclxuICAgICAgICBzdXBlci5uZ09uSW5pdCgpO1xyXG4gICAgICAgIEJhcnNhQXBpLlVpLkV4Y2VwdGlvbkZvcm0uSXNIYW5kbGVkID0gdHJ1ZTtcclxuICAgICAgICBCYXJzYUFwaS5VaS5FeGNlcHRpb25Gb3JtLlNob3cgPSAodGV4dCwgZGV0YWlsLCBjYWxsYmFjaykgPT4ge1xyXG4gICAgICAgICAgICB0aGlzLl9kaWFsb2dTZXJ2aWNlLm9wZW4odGhpcy50ZW1wbGF0ZVJlZiwge1xyXG4gICAgICAgICAgICAgICAgLi4ueyB0ZXh0LCBkZXRhaWwsIGNhbGxiYWNrIH0sXHJcbiAgICAgICAgICAgICAgICByZXNwb25zaXZlUGFkZGluZzogdHJ1ZVxyXG4gICAgICAgICAgICB9KTtcclxuICAgICAgICB9O1xyXG4gICAgfVxyXG4gICAgb25DbG9zZShkaWFsb2csIGRpYWxvZ0NvbmZpZyk6IHZvaWQge1xyXG4gICAgICAgIGRpYWxvZy5jbG9zZSgpO1xyXG4gICAgICAgIGlmIChkaWFsb2dDb25maWcuY2FsbGJhY2spIHtcclxuICAgICAgICAgICAgZGlhbG9nQ29uZmlnLmNhbGxiYWNrKCk7XHJcbiAgICAgICAgfVxyXG4gICAgfVxyXG4gICAgb25Db250aW51ZShkaWFsb2csIGRpYWxvZ0NvbmZpZyk6IHZvaWQge1xyXG4gICAgICAgIGRpYWxvZy5jbG9zZSgpO1xyXG4gICAgICAgIGlmIChkaWFsb2dDb25maWcuY2FsbGJhY2spIHtcclxuICAgICAgICAgICAgZGlhbG9nQ29uZmlnLmNhbGxiYWNrKCk7XHJcbiAgICAgICAgfVxyXG4gICAgfVxyXG4gICAgb25Mb2dvdXQoZGlhbG9nLCBkaWFsb2dDb25maWcpOiB2b2lkIHtcclxuICAgICAgICBkaWFsb2cuY2xvc2UoKTtcclxuICAgICAgICBpZiAoZGlhbG9nQ29uZmlnLmNhbGxiYWNrKSB7XHJcbiAgICAgICAgICAgIGRpYWxvZ0NvbmZpZy5jYWxsYmFjaygpO1xyXG4gICAgICAgIH1cclxuICAgICAgICBCYXJzYUFwaS5Cdy5Mb2dvdXQoKTtcclxuICAgIH1cclxufVxyXG4iLCI8bmctdGVtcGxhdGUgbGV0LWRpYWxvZyBsZXQtZGlhbG9nQ29uZmlnPVwiZGlhbG9nQ29uZmlnXCIgI3RlbXBsYXRlUmVmPlxuICAgIDxmZC1kaWFsb2cgW2RpYWxvZ0NvbmZpZ109XCJkaWFsb2dDb25maWdcIiBbZGlhbG9nUmVmXT1cImRpYWxvZ1wiPlxuICAgICAgICA8ZmQtZGlhbG9nLWhlYWRlcj5cbiAgICAgICAgICAgIDxoMSBmZC10aXRsZT5cbiAgICAgICAgICAgICAgICB7eyBkaWFsb2dDb25maWcudGV4dCB9fVxuICAgICAgICAgICAgPC9oMT5cblxuICAgICAgICAgICAgPGJ1dHRvbiBmZC1kaWFsb2ctY2xvc2UtYnV0dG9uIChjbGljayk9XCJvbkNsb3NlKGRpYWxvZywgZGlhbG9nQ29uZmlnKVwiPjwvYnV0dG9uPlxuICAgICAgICA8L2ZkLWRpYWxvZy1oZWFkZXI+XG5cbiAgICAgICAgPGZkLWRpYWxvZy1ib2R5IHN0eWxlPVwicGFkZGluZzogMTVweFwiPlxuICAgICAgICAgICAgPGRpdiBzdHlsZT1cIm1pbi1oZWlnaHQ6IDEyNXB4XCI+XG4gICAgICAgICAgICAgICAgPGxhYmVsIGZkLWxhYmVsIFtpbm5lckh0bWxdPVwiZGlhbG9nQ29uZmlnLmRldGFpbFwiPiA8L2xhYmVsPlxuICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgIDwvZmQtZGlhbG9nLWJvZHk+XG5cbiAgICAgICAgPGZkLWRpYWxvZy1mb290ZXI+XG4gICAgICAgICAgICA8ZmQtZGlhbG9nLWZvb3Rlci1idXR0b24+XG4gICAgICAgICAgICAgICAgPGJ1dHRvblxuICAgICAgICAgICAgICAgICAgICBmZC1idXR0b25cbiAgICAgICAgICAgICAgICAgICAgZmQtZGlhbG9nLWRlY2lzaXZlLWJ1dHRvblxuICAgICAgICAgICAgICAgICAgICBbZmRUeXBlXT1cIidlbXBoYXNpemVkJ1wiXG4gICAgICAgICAgICAgICAgICAgIFtsYWJlbF09XCInQ29udGludWUnIHwgYmJiVHJhbnNsYXRlXCJcbiAgICAgICAgICAgICAgICAgICAgKGNsaWNrKT1cIm9uQ29udGludWUoZGlhbG9nLCBkaWFsb2dDb25maWcpXCJcbiAgICAgICAgICAgICAgICA+PC9idXR0b24+XG4gICAgICAgICAgICA8L2ZkLWRpYWxvZy1mb290ZXItYnV0dG9uPlxuICAgICAgICAgICAgPGZkLWRpYWxvZy1mb290ZXItYnV0dG9uPlxuICAgICAgICAgICAgICAgIDxidXR0b25cbiAgICAgICAgICAgICAgICAgICAgZmQtYnV0dG9uXG4gICAgICAgICAgICAgICAgICAgIGZkLWRpYWxvZy1kZWNpc2l2ZS1idXR0b25cbiAgICAgICAgICAgICAgICAgICAgW2ZkVHlwZV09XCInc3RhbmRhcmQnXCJcbiAgICAgICAgICAgICAgICAgICAgW2xhYmVsXT1cIidDb3B5JyB8IGJiYlRyYW5zbGF0ZVwiXG4gICAgICAgICAgICAgICAgICAgIFtjb3B5XT1cImRpYWxvZ0NvbmZpZy5kZXRhaWxcIlxuICAgICAgICAgICAgICAgID48L2J1dHRvbj5cbiAgICAgICAgICAgIDwvZmQtZGlhbG9nLWZvb3Rlci1idXR0b24+XG4gICAgICAgICAgICA8ZmQtZGlhbG9nLWZvb3Rlci1idXR0b24+XG4gICAgICAgICAgICAgICAgPGJ1dHRvblxuICAgICAgICAgICAgICAgICAgICBmZC1idXR0b25cbiAgICAgICAgICAgICAgICAgICAgZmQtZGlhbG9nLWRlY2lzaXZlLWJ1dHRvblxuICAgICAgICAgICAgICAgICAgICBbZmRUeXBlXT1cIiduZWdhdGl2ZSdcIlxuICAgICAgICAgICAgICAgICAgICBbbGFiZWxdPVwiJ0xvZ291dCcgfCBiYmJUcmFuc2xhdGVcIlxuICAgICAgICAgICAgICAgICAgICAoY2xpY2spPVwib25Mb2dvdXQoZGlhbG9nLCBkaWFsb2dDb25maWcpXCJcbiAgICAgICAgICAgICAgICA+PC9idXR0b24+XG4gICAgICAgICAgICA8L2ZkLWRpYWxvZy1mb290ZXItYnV0dG9uPlxuICAgICAgICA8L2ZkLWRpYWxvZy1mb290ZXI+XG4gICAgPC9mZC1kaWFsb2c+XG48L25nLXRlbXBsYXRlPlxuIl19
|