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.
Files changed (197) hide show
  1. package/esm2020/lib/apply-conditional-formmatings.directive.mjs +1 -1
  2. package/esm2020/lib/barsa-asp-viewer/barsa-asp-viewer.component.mjs +2 -2
  3. package/esm2020/lib/barsa-date-time-picker/barsa-date-time-picker.component.mjs +1 -1
  4. package/esm2020/lib/barsa-list-file-linear/barsa-list-file-linear.component.mjs +4 -4
  5. package/esm2020/lib/barsa-monaco-editor/barsa-monaco-editor.component.mjs +14 -14
  6. package/esm2020/lib/barsa-network-offline/barsa-network-offline.component.mjs +20 -12
  7. package/esm2020/lib/barsa-sap-ui-routing.module.mjs +1 -1
  8. package/esm2020/lib/barsa-sap-ui.module.mjs +25 -16
  9. package/esm2020/lib/barsa-search-form/barsa-search-form.component.mjs +3 -3
  10. package/esm2020/lib/barsa-table-header/barsa-table-header.component.mjs +4 -4
  11. package/esm2020/lib/barsa-table-row/barsa-table-row.component.mjs +3 -3
  12. package/esm2020/lib/barsa-tinyemce/barsa-tinyemce.component.mjs +6 -6
  13. package/esm2020/lib/barsa-tree-item/barsa-tree-item.component.mjs +23 -12
  14. package/esm2020/lib/barsa-ulv-main/barsa-ulv-main.component.mjs +8 -7
  15. package/esm2020/lib/blob-viewer/blob-viewer.component.mjs +60 -0
  16. package/esm2020/lib/breadcrumb/breadcrumb.component.mjs +3 -3
  17. package/esm2020/lib/captcha-field/captcha-field.component.mjs +1 -1
  18. package/esm2020/lib/card-item/card-item.component.mjs +4 -4
  19. package/esm2020/lib/card-view-content/card-view-content.component.mjs +3 -3
  20. package/esm2020/lib/column-matrix-renderer/column-matrix-renderer.component.mjs +3 -3
  21. package/esm2020/lib/column-matrix-renderer/matrix-value.pipe.mjs +1 -1
  22. package/esm2020/lib/column-renderer/column-renderer.component.mjs +6 -5
  23. package/esm2020/lib/constants.mjs +1 -1
  24. package/esm2020/lib/custom-date-time/custom-date-time.component.mjs +1 -1
  25. package/esm2020/lib/device-info-field-base.mjs +1 -1
  26. package/esm2020/lib/download-files.directive.mjs +33 -0
  27. package/esm2020/lib/empty-page/empty-page.component.mjs +3 -3
  28. package/esm2020/lib/file-in-dialog/file-in-dialog.component.mjs +1 -1
  29. package/esm2020/lib/file-viewer/file-viewer.component.mjs +47 -0
  30. package/esm2020/lib/file-viewer-content/file-viewer-content.component.mjs +49 -0
  31. package/esm2020/lib/file-viewer-popover/file-viewer-popover.component.mjs +34 -0
  32. package/esm2020/lib/form-dialog/form-dialog.component.mjs +3 -3
  33. package/esm2020/lib/form-dialog-less/form-dialog-less.component.mjs +1 -1
  34. package/esm2020/lib/form-page/form-page.component.mjs +17 -17
  35. package/esm2020/lib/form-page-base.mjs +1 -1
  36. package/esm2020/lib/form-toolbar-button/form-toolbar-button.component.mjs +3 -3
  37. package/esm2020/lib/form-wizard/form-wizard.component.mjs +3 -3
  38. package/esm2020/lib/fullscreen-dialog.directive.mjs +1 -1
  39. package/esm2020/lib/fullscreen-files.directive.mjs +39 -0
  40. package/esm2020/lib/fundamental-dynamic-form/fundamental-dynamic-form.component.mjs +3 -3
  41. package/esm2020/lib/gantt-dhtml-chart-view/gantt-dhtml-chart-view.component.mjs +1 -1
  42. package/esm2020/lib/global-search/global-search.component.mjs +1 -1
  43. package/esm2020/lib/global-search-module/global-search-module.component.mjs +1 -1
  44. package/esm2020/lib/global-search-panel/global-search-panel.component.mjs +1 -1
  45. package/esm2020/lib/header-avatar/header-avatar.component.mjs +1 -1
  46. package/esm2020/lib/header-facet-form/header-facet-form.component.mjs +1 -1
  47. package/esm2020/lib/header-facet-key-value/header-facet-key-value.component.mjs +1 -1
  48. package/esm2020/lib/header-facet-microchart/header-facet-microchart.component.mjs +3 -3
  49. package/esm2020/lib/header-facet-plain-text/header-facet-plain-text.component.mjs +3 -3
  50. package/esm2020/lib/header-facet-rate/header-facet-rate.component.mjs +1 -1
  51. package/esm2020/lib/hyperlink/hyperlink.component.mjs +1 -1
  52. package/esm2020/lib/index.mjs +18 -3
  53. package/esm2020/lib/inline-save-and-cancel/inline-save-and-cancel.component.mjs +1 -1
  54. package/esm2020/lib/layout-actions/layout-actions.component.mjs +1 -1
  55. package/esm2020/lib/layout-control/layout-control.component.mjs +4 -4
  56. package/esm2020/lib/layout-wizard/layout-wizard.component.mjs +25 -3
  57. package/esm2020/lib/list-item/list-item.component.mjs +3 -3
  58. package/esm2020/lib/ly-empty-space/ly-empty-space.component.mjs +5 -7
  59. package/esm2020/lib/ly-horizontal-layout/ly-horizontal-layout.component.mjs +8 -7
  60. package/esm2020/lib/ly-layout-container/ly-layout-container.component.mjs +3 -3
  61. package/esm2020/lib/ly-layout-container-of-root/ly-layout-container-of-root.component.mjs +3 -3
  62. package/esm2020/lib/ly-layout-field-label/ly-layout-field-label.component.mjs +1 -1
  63. package/esm2020/lib/ly-layout-panel/ly-layout-panel.component.mjs +9 -3
  64. package/esm2020/lib/ly-line/ly-line.component.mjs +1 -1
  65. package/esm2020/lib/ly-simple-label/ly-simple-label.component.mjs +6 -10
  66. package/esm2020/lib/ly-tab-container/ly-tab-container.component.mjs +7 -3
  67. package/esm2020/lib/ly-tab-page/ly-tab-page.component.mjs +3 -3
  68. package/esm2020/lib/ly-vertical-layout/ly-vertical-layout.component.mjs +8 -7
  69. package/esm2020/lib/mask/mask.component.mjs +3 -3
  70. package/esm2020/lib/message-strip/message-strip.component.mjs +1 -1
  71. package/esm2020/lib/models/grid-data-provider.mjs +2 -2
  72. package/esm2020/lib/models/grid-view.mjs +1 -1
  73. package/esm2020/lib/no-data/no-data.component.mjs +3 -3
  74. package/esm2020/lib/page-with-form-handler-base.mjs +1 -1
  75. package/esm2020/lib/page-with-header/page-with-header.component.mjs +1 -1
  76. package/esm2020/lib/progress-indicator/progress-indicator.component.mjs +1 -1
  77. package/esm2020/lib/report-navigator/report-navigator.component.mjs +3 -3
  78. package/esm2020/lib/report-new-top-form/report-new-top-form.component.mjs +3 -3
  79. package/esm2020/lib/report-search-fields-hidden-settings/report-search-fields-hidden-settings.component.mjs +3 -3
  80. package/esm2020/lib/report-search-fields-manage/report-search-fields-manage.component.mjs +3 -3
  81. package/esm2020/lib/report-tree-base.mjs +4 -1
  82. package/esm2020/lib/report-view-renderer.directive.mjs +32 -2
  83. package/esm2020/lib/responsive-toolbar/responsive-toolbar.component.mjs +1 -1
  84. package/esm2020/lib/responsive-toolbar-renderer/responsive-toolbar-renderer.component.mjs +1 -1
  85. package/esm2020/lib/rich-text-static/rich-text-static.component.mjs +1 -1
  86. package/esm2020/lib/sap-ui-report-base.component.mjs +87 -64
  87. package/esm2020/lib/search-panel/search-panel.component.mjs +1 -1
  88. package/esm2020/lib/static-text/static-text.component.mjs +3 -3
  89. package/esm2020/lib/ui-asp-report-viewer/ui-asp-report-viewer.component.mjs +3 -3
  90. package/esm2020/lib/ui-button/ui-button.component.mjs +3 -3
  91. package/esm2020/lib/ui-calendar/ui-calendar.component.mjs +3 -3
  92. package/esm2020/lib/ui-card-view/ui-card-view.component.mjs +3 -3
  93. package/esm2020/lib/ui-check-box/ui-check-box.component.mjs +3 -3
  94. package/esm2020/lib/ui-color-ui/ui-color-ui.component.mjs +1 -1
  95. package/esm2020/lib/ui-container-with-button/ui-container-with-button.component.mjs +3 -3
  96. package/esm2020/lib/ui-date-range-ex/ui-date-range-ex.component.mjs +3 -3
  97. package/esm2020/lib/ui-date-time/ui-date-time.component.mjs +3 -3
  98. package/esm2020/lib/ui-editable-grid/ui-editable-grid.component.mjs +3 -3
  99. package/esm2020/lib/ui-exception-form/ui-exception-form.component.mjs +1 -1
  100. package/esm2020/lib/ui-file-linear-list-box/ui-file-linear-list-box.component.mjs +29 -90
  101. package/esm2020/lib/ui-form-panel/ui-form-panel.component.mjs +3 -3
  102. package/esm2020/lib/ui-gantt-chart/ui-gantt-chart.component.mjs +3 -3
  103. package/esm2020/lib/ui-graph/ui-graph.component.mjs +1 -1
  104. package/esm2020/lib/ui-grid/ui-grid.component.mjs +3 -3
  105. package/esm2020/lib/ui-grid-columns/ui-grid-columns.component.mjs +3 -3
  106. package/esm2020/lib/ui-grid-filter-item/ui-grid-filter-item.component.mjs +1 -1
  107. package/esm2020/lib/ui-grid-filter-settings/ui-grid-filter-settings.component.mjs +1 -1
  108. package/esm2020/lib/ui-grid-sort-item/ui-grid-sort-item.component.mjs +1 -1
  109. package/esm2020/lib/ui-grid-sort-setting/ui-grid-sort-setting.component.mjs +1 -1
  110. package/esm2020/lib/ui-info-bar-panel/ui-info-bar-panel.component.mjs +1 -1
  111. package/esm2020/lib/ui-label/ui-label.component.mjs +3 -3
  112. package/esm2020/lib/ui-linear-list-container-with-button/ui-linear-list-container-with-button.component.mjs +2 -2
  113. package/esm2020/lib/ui-list-view/ui-list-view.component.mjs +4 -3
  114. package/esm2020/lib/ui-matrix-view/ui-matrix-view.component.mjs +3 -3
  115. package/esm2020/lib/ui-mo-info-combo-viewer/ui-mo-info-combo-viewer.component.mjs +3 -3
  116. package/esm2020/lib/ui-mo-info-general-object-ui/ui-mo-info-general-object-ui.component.mjs +1 -1
  117. package/esm2020/lib/ui-mo-info-sub-form-ui/ui-mo-info-sub-form-ui.component.mjs +3 -3
  118. package/esm2020/lib/ui-mo-info-ulv-combo/ui-mo-info-ulv-combo.component.mjs +19 -14
  119. package/esm2020/lib/ui-monaco-editor/ui-monaco-editor.component.mjs +3 -3
  120. package/esm2020/lib/ui-multi-select-combo/ui-multi-select-combo.component.mjs +26 -9
  121. package/esm2020/lib/ui-num-decimal-ui/ui-num-decimal-ui.component.mjs +1 -1
  122. package/esm2020/lib/ui-num-int-ui/ui-num-int-ui.component.mjs +3 -3
  123. package/esm2020/lib/ui-pdf-viewer/ui-pdf-viewer.component.mjs +19 -20
  124. package/esm2020/lib/ui-picture-file/ui-picture-file.component.mjs +26 -30
  125. package/esm2020/lib/ui-pictures-info/ui-pictures-info.component.mjs +39 -31
  126. package/esm2020/lib/ui-radio-group/ui-radio-group.component.mjs +3 -3
  127. package/esm2020/lib/ui-read-only-field/ui-read-only-field.component.mjs +3 -3
  128. package/esm2020/lib/ui-report-container/ui-report-container.component.mjs +3 -3
  129. package/esm2020/lib/ui-search-command-info-ui/ui-search-command-info-ui.component.mjs +1 -1
  130. package/esm2020/lib/ui-simple-combo/ui-simple-combo.component.mjs +3 -3
  131. package/esm2020/lib/ui-single-picture/ui-single-picture.component.mjs +1 -1
  132. package/esm2020/lib/ui-switch-button/ui-switch-button.component.mjs +3 -3
  133. package/esm2020/lib/ui-table-view/ui-table-view.component.mjs +8 -3
  134. package/esm2020/lib/ui-text-area/ui-text-area.component.mjs +3 -3
  135. package/esm2020/lib/ui-text-field/ui-text-field.component.mjs +1 -1
  136. package/esm2020/lib/ui-text-field-auto-complete/ui-text-field-auto-complete.component.mjs +3 -3
  137. package/esm2020/lib/ui-time-span/ui-time-span.component.mjs +1 -1
  138. package/esm2020/lib/ui-tinymce/ui-tinymce.component.mjs +1 -1
  139. package/esm2020/lib/ui-tree/ui-tree.component.mjs +26 -3
  140. package/esm2020/lib/ui-tree-view/ui-tree-view.component.mjs +9 -3
  141. package/esm2020/lib/ui-ulv-form-multi-select-ui/ui-ulv-form-multi-select-ui.component.mjs +2 -2
  142. package/esm2020/lib/ui-ulv-main-ui/ui-ulv-main-ui.component.mjs +6 -3
  143. package/esm2020/lib/ui-workflow-panel-ui/ui-workflow-panel-ui.component.mjs +1 -1
  144. package/esm2020/lib/ul-loading-mask-ui/ul-loading-mask-ui.component.mjs +7 -2
  145. package/esm2020/lib/ul-msg-box-adapter/ul-msg-box-adapter.component.mjs +3 -3
  146. package/esm2020/lib/ul-notify-popup/ul-notify-popup.component.mjs +1 -1
  147. package/esm2020/lib/ul-toast-adapter/ul-toast-adapter.component.mjs +1 -1
  148. package/esm2020/lib/ulv-column-settings/ulv-column-settings.component.mjs +3 -3
  149. package/esm2020/lib/ulv-context-menu/ulv-context-menu.component.mjs +3 -3
  150. package/esm2020/lib/ulv-filter-settings/ulv-filter-settings.component.mjs +3 -3
  151. package/esm2020/lib/ulv-form-multi-select/ulv-form-multi-select.component.mjs +5 -5
  152. package/esm2020/lib/ulv-groupby-settings/ulv-groupby-settings.component.mjs +3 -3
  153. package/esm2020/lib/ulv-paging/ulv-paging.component.mjs +1 -1
  154. package/esm2020/lib/ulv-selection/ulv-selection.component.mjs +2 -2
  155. package/esm2020/lib/ulv-settings/ulv-settings.component.mjs +1 -1
  156. package/esm2020/lib/ulv-sort-settings/ulv-sort-settings.component.mjs +3 -3
  157. package/esm2020/lib/ulv-toolbar/ulv-toolbar.component.mjs +11 -5
  158. package/esm2020/lib/wizard-layout.directive.mjs +1 -1
  159. package/esm2020/public-api.mjs +7 -1
  160. package/fesm2015/barsa-sap-ui.mjs +888 -542
  161. package/fesm2015/barsa-sap-ui.mjs.map +1 -1
  162. package/fesm2020/barsa-sap-ui.mjs +879 -541
  163. package/fesm2020/barsa-sap-ui.mjs.map +1 -1
  164. package/lib/barsa-network-offline/barsa-network-offline.component.d.ts +3 -2
  165. package/lib/barsa-sap-ui.module.d.ts +31 -25
  166. package/lib/barsa-tree-item/barsa-tree-item.component.d.ts +7 -1
  167. package/lib/barsa-ulv-main/barsa-ulv-main.component.d.ts +3 -1
  168. package/lib/blob-viewer/blob-viewer.component.d.ts +20 -0
  169. package/lib/download-files.directive.d.ts +9 -0
  170. package/lib/file-viewer/file-viewer.component.d.ts +21 -0
  171. package/lib/file-viewer-content/file-viewer-content.component.d.ts +18 -0
  172. package/lib/file-viewer-popover/file-viewer-popover.component.d.ts +13 -0
  173. package/lib/fullscreen-files.directive.d.ts +15 -0
  174. package/lib/index.d.ts +8 -4
  175. package/lib/layout-control/layout-control.component.d.ts +5 -5
  176. package/lib/layout-wizard/layout-wizard.component.d.ts +1 -0
  177. package/lib/ly-empty-space/ly-empty-space.component.d.ts +1 -3
  178. package/lib/ly-horizontal-layout/ly-horizontal-layout.component.d.ts +4 -3
  179. package/lib/ly-simple-label/ly-simple-label.component.d.ts +1 -3
  180. package/lib/ly-tab-container/ly-tab-container.component.d.ts +3 -1
  181. package/lib/ly-vertical-layout/ly-vertical-layout.component.d.ts +4 -3
  182. package/lib/report-tree-base.d.ts +2 -1
  183. package/lib/report-view-renderer.directive.d.ts +10 -1
  184. package/lib/sap-ui-report-base.component.d.ts +13 -4
  185. package/lib/ui-file-linear-list-box/ui-file-linear-list-box.component.d.ts +15 -18
  186. package/lib/ui-multi-select-combo/ui-multi-select-combo.component.d.ts +9 -3
  187. package/lib/ui-pdf-viewer/ui-pdf-viewer.component.d.ts +5 -6
  188. package/lib/ui-picture-file/ui-picture-file.component.d.ts +4 -6
  189. package/lib/ui-pictures-info/ui-pictures-info.component.d.ts +8 -7
  190. package/lib/ui-table-view/ui-table-view.component.d.ts +1 -0
  191. package/lib/ui-tree/ui-tree.component.d.ts +5 -0
  192. package/lib/ui-tree-view/ui-tree-view.component.d.ts +7 -1
  193. package/lib/ui-ulv-main-ui/ui-ulv-main-ui.component.d.ts +2 -1
  194. package/lib/ul-loading-mask-ui/ul-loading-mask-ui.component.d.ts +2 -1
  195. package/lib/ulv-toolbar/ulv-toolbar.component.d.ts +4 -1
  196. package/package.json +3 -3
  197. package/public-api.d.ts +6 -0
@@ -171,7 +171,7 @@ UiDateRangeExComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0",
171
171
  useFactory: getDateService,
172
172
  deps: [LogService]
173
173
  }
174
- ], viewQueries: [{ propertyName: "dateRangePicker", first: true, predicate: ["dateRangePicker"], descendants: true }, { propertyName: "popover", first: true, predicate: ["popover"], descendants: true, static: true }, { propertyName: "alert", first: true, predicate: ["alert"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<ng-container *ngIf=\"value?.DateRangeType === 'SpecificRange'; else input\">\n <div class=\"input-container\">\n <ui5-daterange-picker\n id=\"mydaterange-picker1\"\n (mouseover)=\"onOpenPopover()\"\n (mouseleave)=\"popover.close()\"\n #dateRangePicker\n (change)=\"onDateRangeChange()\"\n format-pattern=\"yyyy/MM/dd\"\n [attr.readonly]=\"(readonly$ | async) === true ? true : null\"\n [attr.disabled]=\"(disable$ | async) === true ? true : null\"\n [primaryCalendarType]=\"Setting.CalendarType !== 'Gregorian' ? 'Persian' : Setting.CalendarType\"\n >\n </ui5-daterange-picker>\n <button\n class=\"btn-drop-down\"\n fd-button\n [fdType]=\"'standard'\"\n [glyph]=\"'slim-arrow-down'\"\n (click)=\"popover.open()\"\n ></button>\n </div>\n</ng-container>\n<ng-template #input>\n <!-- <input fd-form-control [(ngModel)]=\"valueStr\" [fd-inline-help]=\"valueStr\" [readOnly]=\"true\" /> -->\n\n <fd-input-group\n placement=\"after\"\n glyph=\"slim-arrow-down\"\n glyphAriaLabel=\"Select Date Range\"\n [button]=\"true\"\n [ngModel]=\"valueStr\"\n (addOnButtonClicked)=\"popover.open()\"\n >\n </fd-input-group>\n</ng-template>\n\n<!-- <button fd-button>\n <fd-select (valueChange)=\"onDateRangeTypeChange($event)\">\n <fd-option *ngFor=\"let option of dateRanges\" [value]=\"option\">{{ option | bbbTranslate }}</fd-option>\n </fd-select>\n</button> -->\n\n<fd-popover\n #popover\n style=\"display: block\"\n [fillControlMode]=\"'at-least'\"\n placement=\"bottom-start\"\n [(isOpen)]=\"isOpenPopover\"\n>\n <fd-popover-body>\n <ul fd-list>\n <li fd-list-item *ngFor=\"let option of dateRanges\" (click)=\"popover.close(); onDateRangeTypeChange(option)\">\n <a fd-list-link>\n <span fd-list-title>{{ option | bbbTranslate }}</span>\n </a>\n </li>\n </ul>\n </fd-popover-body>\n</fd-popover>\n", styles: [":host{display:block}:host input{border-top-left-radius:0;border-left:none;border-bottom-left-radius:0}:host .input-container{width:100%;display:flex;align-items:center}:host .input-container ui5-daterange-picker{padding:3px 0;min-width:2rem;width:100%;flex-grow:1}.btn-drop-down{border-right:none;border-top-right-radius:0;border-bottom-right-radius:0;background-color:var(--sapField_ReadOnly_Background);border-color:var(--sapField_ReadOnly_BorderColor)}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: 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: "component", type: i3.ButtonComponent, selector: "button[fd-button], a[fd-button]", inputs: ["class"], exportAs: ["fd-button"] }, { kind: "component", type: i4.InputGroupComponent, selector: "fd-input-group", inputs: ["inputTemplate", "placement", "required", "inline", "placeholder", "addOnText", "buttonFocusable", "type", "glyph", "button", "disabled", "readonly", "state", "isControl", "showFocus", "isExpanded", "glyphAriaLabel", "iconTitle", "ariaLabelledby", "ariaLabelledBy"], outputs: ["addOnButtonClicked", "search"] }, { kind: "component", type: i5.ListComponent, selector: "[fd-list], [fdList]", inputs: ["dropdownMode", "multiInputMode", "mobileMode", "hasMessage", "noBorder", "navigationIndicator", "selection", "keyboardSupport", "byline"], outputs: ["focusEscapeList"] }, { kind: "component", type: i5.ListItemComponent, selector: "[fdListItem] ,[fd-list-item]", inputs: ["selected", "ariaDescribedBy", "noData", "action", "interactive", "growing", "counter", "unread", "selectedListItemScreenReaderText", "navigatedListItemScreenReaderText", "navigatableListItemScreenReaderText"], outputs: ["keyDown"] }, { kind: "directive", type: i5.ListTitleDirective, selector: "[fd-list-title], [fdListTitle]", inputs: ["wrap"] }, { kind: "directive", type: i5.ListLinkDirective, selector: "[fd-list-link], [fdListLink]", inputs: ["navigationIndicator", "navigated"] }, { kind: "component", type: i6.PopoverBodyComponent, selector: "fd-popover-body" }, { kind: "component", type: i6.PopoverComponent, selector: "fd-popover", inputs: ["title", "trigger", "fixedPosition", "id", "mobile", "mobileConfig"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i7.BbbTranslatePipe, name: "bbbTranslate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
174
+ ], viewQueries: [{ propertyName: "dateRangePicker", first: true, predicate: ["dateRangePicker"], descendants: true }, { propertyName: "popover", first: true, predicate: ["popover"], descendants: true, static: true }, { propertyName: "alert", first: true, predicate: ["alert"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<ng-container *ngIf=\"value?.DateRangeType === 'SpecificRange'; else input\">\r\n <div class=\"input-container\">\r\n <ui5-daterange-picker\r\n id=\"mydaterange-picker1\"\r\n (mouseover)=\"onOpenPopover()\"\r\n (mouseleave)=\"popover.close()\"\r\n #dateRangePicker\r\n (change)=\"onDateRangeChange()\"\r\n format-pattern=\"yyyy/MM/dd\"\r\n [attr.readonly]=\"(readonly$ | async) === true ? true : null\"\r\n [attr.disabled]=\"(disable$ | async) === true ? true : null\"\r\n [primaryCalendarType]=\"Setting.CalendarType !== 'Gregorian' ? 'Persian' : Setting.CalendarType\"\r\n >\r\n </ui5-daterange-picker>\r\n <button\r\n class=\"btn-drop-down\"\r\n fd-button\r\n [fdType]=\"'standard'\"\r\n [glyph]=\"'slim-arrow-down'\"\r\n (click)=\"popover.open()\"\r\n ></button>\r\n </div>\r\n</ng-container>\r\n<ng-template #input>\r\n <!-- <input fd-form-control [(ngModel)]=\"valueStr\" [fd-inline-help]=\"valueStr\" [readOnly]=\"true\" /> -->\r\n\r\n <fd-input-group\r\n placement=\"after\"\r\n glyph=\"slim-arrow-down\"\r\n glyphAriaLabel=\"Select Date Range\"\r\n [button]=\"true\"\r\n [ngModel]=\"valueStr\"\r\n (addOnButtonClicked)=\"popover.open()\"\r\n >\r\n </fd-input-group>\r\n</ng-template>\r\n\r\n<!-- <button fd-button>\r\n <fd-select (valueChange)=\"onDateRangeTypeChange($event)\">\r\n <fd-option *ngFor=\"let option of dateRanges\" [value]=\"option\">{{ option | bbbTranslate }}</fd-option>\r\n </fd-select>\r\n</button> -->\r\n\r\n<fd-popover\r\n #popover\r\n style=\"display: block\"\r\n [fillControlMode]=\"'at-least'\"\r\n placement=\"bottom-start\"\r\n [(isOpen)]=\"isOpenPopover\"\r\n>\r\n <fd-popover-body>\r\n <ul fd-list>\r\n <li fd-list-item *ngFor=\"let option of dateRanges\" (click)=\"popover.close(); onDateRangeTypeChange(option)\">\r\n <a fd-list-link>\r\n <span fd-list-title>{{ option | bbbTranslate }}</span>\r\n </a>\r\n </li>\r\n </ul>\r\n </fd-popover-body>\r\n</fd-popover>\r\n", styles: [":host{display:block}:host input{border-top-left-radius:0;border-left:none;border-bottom-left-radius:0}:host .input-container{width:100%;display:flex;align-items:center}:host .input-container ui5-daterange-picker{padding:3px 0;min-width:2rem;width:100%;flex-grow:1}.btn-drop-down{border-right:none;border-top-right-radius:0;border-bottom-right-radius:0;background-color:var(--sapField_ReadOnly_Background);border-color:var(--sapField_ReadOnly_BorderColor)}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: 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: "component", type: i3.ButtonComponent, selector: "button[fd-button], a[fd-button]", inputs: ["class"], exportAs: ["fd-button"] }, { kind: "component", type: i4.InputGroupComponent, selector: "fd-input-group", inputs: ["inputTemplate", "placement", "required", "inline", "placeholder", "addOnText", "buttonFocusable", "type", "glyph", "button", "disabled", "readonly", "state", "isControl", "showFocus", "isExpanded", "glyphAriaLabel", "iconTitle", "ariaLabelledby", "ariaLabelledBy"], outputs: ["addOnButtonClicked", "search"] }, { kind: "component", type: i5.ListComponent, selector: "[fd-list], [fdList]", inputs: ["dropdownMode", "multiInputMode", "mobileMode", "hasMessage", "noBorder", "navigationIndicator", "selection", "keyboardSupport", "byline"], outputs: ["focusEscapeList"] }, { kind: "component", type: i5.ListItemComponent, selector: "[fdListItem] ,[fd-list-item]", inputs: ["selected", "ariaDescribedBy", "noData", "action", "interactive", "growing", "counter", "unread", "selectedListItemScreenReaderText", "navigatedListItemScreenReaderText", "navigatableListItemScreenReaderText"], outputs: ["keyDown"] }, { kind: "directive", type: i5.ListTitleDirective, selector: "[fd-list-title], [fdListTitle]", inputs: ["wrap"] }, { kind: "directive", type: i5.ListLinkDirective, selector: "[fd-list-link], [fdListLink]", inputs: ["navigationIndicator", "navigated"] }, { kind: "component", type: i6.PopoverBodyComponent, selector: "fd-popover-body" }, { kind: "component", type: i6.PopoverComponent, selector: "fd-popover", inputs: ["title", "trigger", "fixedPosition", "id", "mobile", "mobileConfig"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i7.BbbTranslatePipe, name: "bbbTranslate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
175
175
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: UiDateRangeExComponent, decorators: [{
176
176
  type: Component,
177
177
  args: [{ selector: 'bsu-ui-date-range-ex', changeDetection: ChangeDetectionStrategy.OnPush, providers: [
@@ -180,7 +180,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImpor
180
180
  useFactory: getDateService,
181
181
  deps: [LogService]
182
182
  }
183
- ], template: "<ng-container *ngIf=\"value?.DateRangeType === 'SpecificRange'; else input\">\n <div class=\"input-container\">\n <ui5-daterange-picker\n id=\"mydaterange-picker1\"\n (mouseover)=\"onOpenPopover()\"\n (mouseleave)=\"popover.close()\"\n #dateRangePicker\n (change)=\"onDateRangeChange()\"\n format-pattern=\"yyyy/MM/dd\"\n [attr.readonly]=\"(readonly$ | async) === true ? true : null\"\n [attr.disabled]=\"(disable$ | async) === true ? true : null\"\n [primaryCalendarType]=\"Setting.CalendarType !== 'Gregorian' ? 'Persian' : Setting.CalendarType\"\n >\n </ui5-daterange-picker>\n <button\n class=\"btn-drop-down\"\n fd-button\n [fdType]=\"'standard'\"\n [glyph]=\"'slim-arrow-down'\"\n (click)=\"popover.open()\"\n ></button>\n </div>\n</ng-container>\n<ng-template #input>\n <!-- <input fd-form-control [(ngModel)]=\"valueStr\" [fd-inline-help]=\"valueStr\" [readOnly]=\"true\" /> -->\n\n <fd-input-group\n placement=\"after\"\n glyph=\"slim-arrow-down\"\n glyphAriaLabel=\"Select Date Range\"\n [button]=\"true\"\n [ngModel]=\"valueStr\"\n (addOnButtonClicked)=\"popover.open()\"\n >\n </fd-input-group>\n</ng-template>\n\n<!-- <button fd-button>\n <fd-select (valueChange)=\"onDateRangeTypeChange($event)\">\n <fd-option *ngFor=\"let option of dateRanges\" [value]=\"option\">{{ option | bbbTranslate }}</fd-option>\n </fd-select>\n</button> -->\n\n<fd-popover\n #popover\n style=\"display: block\"\n [fillControlMode]=\"'at-least'\"\n placement=\"bottom-start\"\n [(isOpen)]=\"isOpenPopover\"\n>\n <fd-popover-body>\n <ul fd-list>\n <li fd-list-item *ngFor=\"let option of dateRanges\" (click)=\"popover.close(); onDateRangeTypeChange(option)\">\n <a fd-list-link>\n <span fd-list-title>{{ option | bbbTranslate }}</span>\n </a>\n </li>\n </ul>\n </fd-popover-body>\n</fd-popover>\n", styles: [":host{display:block}:host input{border-top-left-radius:0;border-left:none;border-bottom-left-radius:0}:host .input-container{width:100%;display:flex;align-items:center}:host .input-container ui5-daterange-picker{padding:3px 0;min-width:2rem;width:100%;flex-grow:1}.btn-drop-down{border-right:none;border-top-right-radius:0;border-bottom-right-radius:0;background-color:var(--sapField_ReadOnly_Background);border-color:var(--sapField_ReadOnly_BorderColor)}\n"] }]
183
+ ], template: "<ng-container *ngIf=\"value?.DateRangeType === 'SpecificRange'; else input\">\r\n <div class=\"input-container\">\r\n <ui5-daterange-picker\r\n id=\"mydaterange-picker1\"\r\n (mouseover)=\"onOpenPopover()\"\r\n (mouseleave)=\"popover.close()\"\r\n #dateRangePicker\r\n (change)=\"onDateRangeChange()\"\r\n format-pattern=\"yyyy/MM/dd\"\r\n [attr.readonly]=\"(readonly$ | async) === true ? true : null\"\r\n [attr.disabled]=\"(disable$ | async) === true ? true : null\"\r\n [primaryCalendarType]=\"Setting.CalendarType !== 'Gregorian' ? 'Persian' : Setting.CalendarType\"\r\n >\r\n </ui5-daterange-picker>\r\n <button\r\n class=\"btn-drop-down\"\r\n fd-button\r\n [fdType]=\"'standard'\"\r\n [glyph]=\"'slim-arrow-down'\"\r\n (click)=\"popover.open()\"\r\n ></button>\r\n </div>\r\n</ng-container>\r\n<ng-template #input>\r\n <!-- <input fd-form-control [(ngModel)]=\"valueStr\" [fd-inline-help]=\"valueStr\" [readOnly]=\"true\" /> -->\r\n\r\n <fd-input-group\r\n placement=\"after\"\r\n glyph=\"slim-arrow-down\"\r\n glyphAriaLabel=\"Select Date Range\"\r\n [button]=\"true\"\r\n [ngModel]=\"valueStr\"\r\n (addOnButtonClicked)=\"popover.open()\"\r\n >\r\n </fd-input-group>\r\n</ng-template>\r\n\r\n<!-- <button fd-button>\r\n <fd-select (valueChange)=\"onDateRangeTypeChange($event)\">\r\n <fd-option *ngFor=\"let option of dateRanges\" [value]=\"option\">{{ option | bbbTranslate }}</fd-option>\r\n </fd-select>\r\n</button> -->\r\n\r\n<fd-popover\r\n #popover\r\n style=\"display: block\"\r\n [fillControlMode]=\"'at-least'\"\r\n placement=\"bottom-start\"\r\n [(isOpen)]=\"isOpenPopover\"\r\n>\r\n <fd-popover-body>\r\n <ul fd-list>\r\n <li fd-list-item *ngFor=\"let option of dateRanges\" (click)=\"popover.close(); onDateRangeTypeChange(option)\">\r\n <a fd-list-link>\r\n <span fd-list-title>{{ option | bbbTranslate }}</span>\r\n </a>\r\n </li>\r\n </ul>\r\n </fd-popover-body>\r\n</fd-popover>\r\n", styles: [":host{display:block}:host input{border-top-left-radius:0;border-left:none;border-bottom-left-radius:0}:host .input-container{width:100%;display:flex;align-items:center}:host .input-container ui5-daterange-picker{padding:3px 0;min-width:2rem;width:100%;flex-grow:1}.btn-drop-down{border-right:none;border-top-right-radius:0;border-bottom-right-radius:0;background-color:var(--sapField_ReadOnly_Background);border-color:var(--sapField_ReadOnly_BorderColor)}\n"] }]
184
184
  }], propDecorators: { dateRangePicker: [{
185
185
  type: ViewChild,
186
186
  args: ['dateRangePicker']
@@ -191,4 +191,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImpor
191
191
  type: ViewChild,
192
192
  args: ['alert']
193
193
  }] } });
194
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ui-date-range-ex.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-sap-ui/src/lib/ui-date-range-ex/ui-date-range-ex.component.ts","../../../../../projects/barsa-sap-ui/src/lib/ui-date-range-ex/ui-date-range-ex.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, ViewChild, OnInit, ChangeDetectionStrategy } from '@angular/core';\n\nimport {\n    FieldBaseComponent,\n    BarsaApi,\n    DateService,\n    DateShamsiService,\n    LogService,\n    DateMiladiService,\n    DateHijriService,\n    DateRanges\n} from 'barsa-novin-ray-core';\nimport { AlertComponent, PopoverComponent } from '@fundamental-ngx/core';\n\nfunction getDateService(logService: LogService): DateService {\n    const culture = BarsaApi.LoginFormData.Culture;\n    switch (culture) {\n        case 'fa-IR':\n            return new DateShamsiService(logService);\n        case 'ar-AE':\n            return new DateHijriService(logService);\n        default:\n            return new DateMiladiService(logService);\n    }\n}\n\n@Component({\n    selector: 'bsu-ui-date-range-ex',\n    templateUrl: './ui-date-range-ex.component.html',\n    styleUrls: ['./ui-date-range-ex.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        {\n            provide: DateService,\n            useFactory: getDateService,\n            deps: [LogService]\n        }\n    ]\n})\nexport class UiDateRangeExComponent extends FieldBaseComponent implements OnInit {\n    @ViewChild('dateRangePicker') dateRangePicker: ElementRef<HTMLElement>;\n    @ViewChild('popover', { static: true }) popover: PopoverComponent;\n    @ViewChild('alert') alert: AlertComponent;\n\n    valueStr = '';\n    value: any = new BarsaApi.Common.DateRangeData();\n    dateRanges = DateRanges;\n    isOpenPopover: boolean;\n\n    get _isValidPopover(): boolean {\n        const mode = this.value.DateRangeType;\n        return /Week|Day|Today|Range/.test(mode) && this.valueStr !== '';\n    }\n    ngOnInit(): void {\n        super.ngOnInit();\n        if (!this.value) {\n            this.context.value = this.value = this._defaultValue(this.value);\n        }\n        this._decorateDateRangePicker();\n    }\n\n    onDateRangeTypeChange(dateRangeType): void {\n        this._setValueStr(dateRangeType.replace('DateR_', ''));\n        this.valueChange.emit(this.value);\n    }\n    onDateRangeChange(): void {\n        const el: any = this.dateRangePicker.nativeElement;\n        this.value.FirstDate = el.firstDateValue;\n        this.value.SecondDate = el.lastDateValue;\n        this.valueChange.emit(this.value);\n        const firstDateStr = this._dateService.getDateString(this.value.FirstDate, true, false);\n        const secondDateStr = this._dateService.getDateString(this.value.SecondDate, true, false);\n        this.valueStr = firstDateStr + ' تا ' + secondDateStr;\n    }\n\n    onOpenPopover(): void {\n        if (this._isValidPopover && this._isValidPopover) {\n            this.popover.open();\n        }\n    }\n\n    protected _setValue(value: any): void {\n        if (!value) {\n            this.context.value = value = this._defaultValue(value);\n        }\n        this._setValueStr(value.DateRangeType);\n        super._setValue(value);\n    }\n    private _defaultValue(value): any {\n        if (!value) {\n            value = {\n                DateRangeType: 'None'\n            };\n        }\n        return value;\n    }\n    private _setValueStr(dateRangeType: string): void {\n        this.value.DateRangeType = dateRangeType;\n        switch (dateRangeType) {\n            case 'SpecificRange':\n                this.valueStr = '';\n                this._decorateDateRangePicker();\n                return;\n            case 'DaysBefore':\n                this.valueStr = this._getDaysBefore();\n                break;\n            case 'Today':\n                this.valueStr = this._getToday();\n                break;\n            case 'DaysAfter':\n                this.valueStr = this._getDaysAfter();\n                break;\n            case 'PrevWeek':\n                this.valueStr = this._getPrevWeek();\n                break;\n            case 'ThisWeek':\n                this.valueStr = this._getThisWeek();\n                break;\n            case 'NextWeek':\n                this.valueStr = this._getNextWeek();\n                break;\n            case 'PrevMonth':\n                this.valueStr = this._getPrevMonth();\n                break;\n            case 'ThisMonth':\n                this.valueStr = this._getThisMonth();\n                break;\n            case 'NextMonth':\n                this.valueStr = this._getNextMonth();\n                break;\n            case 'PrevYear':\n                this.valueStr = this._getPrevYear();\n                break;\n            case 'ThisYear':\n                this.valueStr = this._getThisYear();\n                break;\n            case 'NextYear':\n                this.valueStr = this._getNextYear();\n                break;\n            default:\n                this.valueStr = BarsaApi.BBB.DateR_None;\n                this._decorateDateRangePicker();\n        }\n    }\n\n    private _getToday(): string {\n        return BarsaApi.BBB.DateR_Today + ': ' + this._dateService.getDayStr('Today');\n    }\n\n    private _getThisWeek(): string {\n        return BarsaApi.BBB.DateR_ThisWeek + ': ' + this._dateService.getWeekStr('ThisWeek');\n    }\n\n    private _getThisMonth(): string {\n        return BarsaApi.BBB.DateR_ThisMonth + ': ' + this._dateService.getMonthStr('ThisMonth');\n    }\n\n    private _getThisYear(): string {\n        return BarsaApi.BBB.DateR_ThisYear + ': ' + this._dateService.getYearStr('ThisYear');\n    }\n\n    private _getDaysBefore(): string {\n        return BarsaApi.BBB.DateR_DaysBefore + ': ' + this._dateService.getDayStr('DaysBefore');\n    }\n\n    private _getPrevWeek(): string {\n        return BarsaApi.BBB.DateR_PrevWeek + ': ' + this._dateService.getWeekStr('PrevWeek');\n    }\n\n    private _getPrevMonth(): string {\n        return BarsaApi.BBB.DateR_PrevMonth + ': ' + this._dateService.getMonthStr('PrevMonth');\n    }\n\n    private _getPrevYear(): string {\n        return BarsaApi.BBB.DateR_PrevYear + ': ' + this._dateService.getYearStr('PrevYear');\n    }\n\n    private _getDaysAfter(): string {\n        return BarsaApi.BBB.DateR_DaysAfter + ': ' + this._dateService.getDayStr('DaysAfter');\n    }\n\n    private _getNextWeek(): string {\n        return BarsaApi.BBB.DateR_NextWeek + ': ' + this._dateService.getWeekStr('NextWeek');\n    }\n\n    private _getNextMonth(): string {\n        return BarsaApi.BBB.DateR_NextMonth + ': ' + this._dateService.getMonthStr('NextMonth');\n    }\n\n    private _getNextYear(): string {\n        return BarsaApi.BBB.DateR_NextYear + ': ' + this._dateService.getYearStr('NextYear');\n    }\n\n    private _decorateDateRangePicker(): void {\n        setTimeout(() => {\n            const elDateRangePicker = this.dateRangePicker?.nativeElement;\n            if (elDateRangePicker) {\n                const ui5InputEl = elDateRangePicker.shadowRoot?.querySelector('.ui5-date-picker-input');\n                this._renderer2.setAttribute(\n                    ui5InputEl,\n                    'style',\n                    'border-top-left-radius: 0; border-bottom-left-radius: 0'\n                );\n            }\n        }, 500);\n    }\n}\n","<ng-container *ngIf=\"value?.DateRangeType === 'SpecificRange'; else input\">\n    <div class=\"input-container\">\n        <ui5-daterange-picker\n            id=\"mydaterange-picker1\"\n            (mouseover)=\"onOpenPopover()\"\n            (mouseleave)=\"popover.close()\"\n            #dateRangePicker\n            (change)=\"onDateRangeChange()\"\n            format-pattern=\"yyyy/MM/dd\"\n            [attr.readonly]=\"(readonly$ | async) === true ? true : null\"\n            [attr.disabled]=\"(disable$ | async) === true ? true : null\"\n            [primaryCalendarType]=\"Setting.CalendarType !== 'Gregorian' ? 'Persian' : Setting.CalendarType\"\n        >\n        </ui5-daterange-picker>\n        <button\n            class=\"btn-drop-down\"\n            fd-button\n            [fdType]=\"'standard'\"\n            [glyph]=\"'slim-arrow-down'\"\n            (click)=\"popover.open()\"\n        ></button>\n    </div>\n</ng-container>\n<ng-template #input>\n    <!-- <input fd-form-control [(ngModel)]=\"valueStr\" [fd-inline-help]=\"valueStr\" [readOnly]=\"true\" /> -->\n\n    <fd-input-group\n        placement=\"after\"\n        glyph=\"slim-arrow-down\"\n        glyphAriaLabel=\"Select Date Range\"\n        [button]=\"true\"\n        [ngModel]=\"valueStr\"\n        (addOnButtonClicked)=\"popover.open()\"\n    >\n    </fd-input-group>\n</ng-template>\n\n<!-- <button fd-button>\n    <fd-select (valueChange)=\"onDateRangeTypeChange($event)\">\n        <fd-option *ngFor=\"let option of dateRanges\" [value]=\"option\">{{ option | bbbTranslate }}</fd-option>\n    </fd-select>\n</button> -->\n\n<fd-popover\n    #popover\n    style=\"display: block\"\n    [fillControlMode]=\"'at-least'\"\n    placement=\"bottom-start\"\n    [(isOpen)]=\"isOpenPopover\"\n>\n    <fd-popover-body>\n        <ul fd-list>\n            <li fd-list-item *ngFor=\"let option of dateRanges\" (click)=\"popover.close(); onDateRangeTypeChange(option)\">\n                <a fd-list-link>\n                    <span fd-list-title>{{ option | bbbTranslate }}</span>\n                </a>\n            </li>\n        </ul>\n    </fd-popover-body>\n</fd-popover>\n"]}
194
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ui-date-range-ex.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-sap-ui/src/lib/ui-date-range-ex/ui-date-range-ex.component.ts","../../../../../projects/barsa-sap-ui/src/lib/ui-date-range-ex/ui-date-range-ex.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, ViewChild, OnInit, ChangeDetectionStrategy } from '@angular/core';\r\n\r\nimport {\r\n    FieldBaseComponent,\r\n    BarsaApi,\r\n    DateService,\r\n    DateShamsiService,\r\n    LogService,\r\n    DateMiladiService,\r\n    DateHijriService,\r\n    DateRanges\r\n} from 'barsa-novin-ray-core';\r\nimport { AlertComponent, PopoverComponent } from '@fundamental-ngx/core';\r\n\r\nfunction getDateService(logService: LogService): DateService {\r\n    const culture = BarsaApi.LoginFormData.Culture;\r\n    switch (culture) {\r\n        case 'fa-IR':\r\n            return new DateShamsiService(logService);\r\n        case 'ar-AE':\r\n            return new DateHijriService(logService);\r\n        default:\r\n            return new DateMiladiService(logService);\r\n    }\r\n}\r\n\r\n@Component({\r\n    selector: 'bsu-ui-date-range-ex',\r\n    templateUrl: './ui-date-range-ex.component.html',\r\n    styleUrls: ['./ui-date-range-ex.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    providers: [\r\n        {\r\n            provide: DateService,\r\n            useFactory: getDateService,\r\n            deps: [LogService]\r\n        }\r\n    ]\r\n})\r\nexport class UiDateRangeExComponent extends FieldBaseComponent implements OnInit {\r\n    @ViewChild('dateRangePicker') dateRangePicker: ElementRef<HTMLElement>;\r\n    @ViewChild('popover', { static: true }) popover: PopoverComponent;\r\n    @ViewChild('alert') alert: AlertComponent;\r\n\r\n    valueStr = '';\r\n    value: any = new BarsaApi.Common.DateRangeData();\r\n    dateRanges = DateRanges;\r\n    isOpenPopover: boolean;\r\n\r\n    get _isValidPopover(): boolean {\r\n        const mode = this.value.DateRangeType;\r\n        return /Week|Day|Today|Range/.test(mode) && this.valueStr !== '';\r\n    }\r\n    ngOnInit(): void {\r\n        super.ngOnInit();\r\n        if (!this.value) {\r\n            this.context.value = this.value = this._defaultValue(this.value);\r\n        }\r\n        this._decorateDateRangePicker();\r\n    }\r\n\r\n    onDateRangeTypeChange(dateRangeType): void {\r\n        this._setValueStr(dateRangeType.replace('DateR_', ''));\r\n        this.valueChange.emit(this.value);\r\n    }\r\n    onDateRangeChange(): void {\r\n        const el: any = this.dateRangePicker.nativeElement;\r\n        this.value.FirstDate = el.firstDateValue;\r\n        this.value.SecondDate = el.lastDateValue;\r\n        this.valueChange.emit(this.value);\r\n        const firstDateStr = this._dateService.getDateString(this.value.FirstDate, true, false);\r\n        const secondDateStr = this._dateService.getDateString(this.value.SecondDate, true, false);\r\n        this.valueStr = firstDateStr + ' تا ' + secondDateStr;\r\n    }\r\n\r\n    onOpenPopover(): void {\r\n        if (this._isValidPopover && this._isValidPopover) {\r\n            this.popover.open();\r\n        }\r\n    }\r\n\r\n    protected _setValue(value: any): void {\r\n        if (!value) {\r\n            this.context.value = value = this._defaultValue(value);\r\n        }\r\n        this._setValueStr(value.DateRangeType);\r\n        super._setValue(value);\r\n    }\r\n    private _defaultValue(value): any {\r\n        if (!value) {\r\n            value = {\r\n                DateRangeType: 'None'\r\n            };\r\n        }\r\n        return value;\r\n    }\r\n    private _setValueStr(dateRangeType: string): void {\r\n        this.value.DateRangeType = dateRangeType;\r\n        switch (dateRangeType) {\r\n            case 'SpecificRange':\r\n                this.valueStr = '';\r\n                this._decorateDateRangePicker();\r\n                return;\r\n            case 'DaysBefore':\r\n                this.valueStr = this._getDaysBefore();\r\n                break;\r\n            case 'Today':\r\n                this.valueStr = this._getToday();\r\n                break;\r\n            case 'DaysAfter':\r\n                this.valueStr = this._getDaysAfter();\r\n                break;\r\n            case 'PrevWeek':\r\n                this.valueStr = this._getPrevWeek();\r\n                break;\r\n            case 'ThisWeek':\r\n                this.valueStr = this._getThisWeek();\r\n                break;\r\n            case 'NextWeek':\r\n                this.valueStr = this._getNextWeek();\r\n                break;\r\n            case 'PrevMonth':\r\n                this.valueStr = this._getPrevMonth();\r\n                break;\r\n            case 'ThisMonth':\r\n                this.valueStr = this._getThisMonth();\r\n                break;\r\n            case 'NextMonth':\r\n                this.valueStr = this._getNextMonth();\r\n                break;\r\n            case 'PrevYear':\r\n                this.valueStr = this._getPrevYear();\r\n                break;\r\n            case 'ThisYear':\r\n                this.valueStr = this._getThisYear();\r\n                break;\r\n            case 'NextYear':\r\n                this.valueStr = this._getNextYear();\r\n                break;\r\n            default:\r\n                this.valueStr = BarsaApi.BBB.DateR_None;\r\n                this._decorateDateRangePicker();\r\n        }\r\n    }\r\n\r\n    private _getToday(): string {\r\n        return BarsaApi.BBB.DateR_Today + ': ' + this._dateService.getDayStr('Today');\r\n    }\r\n\r\n    private _getThisWeek(): string {\r\n        return BarsaApi.BBB.DateR_ThisWeek + ': ' + this._dateService.getWeekStr('ThisWeek');\r\n    }\r\n\r\n    private _getThisMonth(): string {\r\n        return BarsaApi.BBB.DateR_ThisMonth + ': ' + this._dateService.getMonthStr('ThisMonth');\r\n    }\r\n\r\n    private _getThisYear(): string {\r\n        return BarsaApi.BBB.DateR_ThisYear + ': ' + this._dateService.getYearStr('ThisYear');\r\n    }\r\n\r\n    private _getDaysBefore(): string {\r\n        return BarsaApi.BBB.DateR_DaysBefore + ': ' + this._dateService.getDayStr('DaysBefore');\r\n    }\r\n\r\n    private _getPrevWeek(): string {\r\n        return BarsaApi.BBB.DateR_PrevWeek + ': ' + this._dateService.getWeekStr('PrevWeek');\r\n    }\r\n\r\n    private _getPrevMonth(): string {\r\n        return BarsaApi.BBB.DateR_PrevMonth + ': ' + this._dateService.getMonthStr('PrevMonth');\r\n    }\r\n\r\n    private _getPrevYear(): string {\r\n        return BarsaApi.BBB.DateR_PrevYear + ': ' + this._dateService.getYearStr('PrevYear');\r\n    }\r\n\r\n    private _getDaysAfter(): string {\r\n        return BarsaApi.BBB.DateR_DaysAfter + ': ' + this._dateService.getDayStr('DaysAfter');\r\n    }\r\n\r\n    private _getNextWeek(): string {\r\n        return BarsaApi.BBB.DateR_NextWeek + ': ' + this._dateService.getWeekStr('NextWeek');\r\n    }\r\n\r\n    private _getNextMonth(): string {\r\n        return BarsaApi.BBB.DateR_NextMonth + ': ' + this._dateService.getMonthStr('NextMonth');\r\n    }\r\n\r\n    private _getNextYear(): string {\r\n        return BarsaApi.BBB.DateR_NextYear + ': ' + this._dateService.getYearStr('NextYear');\r\n    }\r\n\r\n    private _decorateDateRangePicker(): void {\r\n        setTimeout(() => {\r\n            const elDateRangePicker = this.dateRangePicker?.nativeElement;\r\n            if (elDateRangePicker) {\r\n                const ui5InputEl = elDateRangePicker.shadowRoot?.querySelector('.ui5-date-picker-input');\r\n                this._renderer2.setAttribute(\r\n                    ui5InputEl,\r\n                    'style',\r\n                    'border-top-left-radius: 0; border-bottom-left-radius: 0'\r\n                );\r\n            }\r\n        }, 500);\r\n    }\r\n}\r\n","<ng-container *ngIf=\"value?.DateRangeType === 'SpecificRange'; else input\">\r\n    <div class=\"input-container\">\r\n        <ui5-daterange-picker\r\n            id=\"mydaterange-picker1\"\r\n            (mouseover)=\"onOpenPopover()\"\r\n            (mouseleave)=\"popover.close()\"\r\n            #dateRangePicker\r\n            (change)=\"onDateRangeChange()\"\r\n            format-pattern=\"yyyy/MM/dd\"\r\n            [attr.readonly]=\"(readonly$ | async) === true ? true : null\"\r\n            [attr.disabled]=\"(disable$ | async) === true ? true : null\"\r\n            [primaryCalendarType]=\"Setting.CalendarType !== 'Gregorian' ? 'Persian' : Setting.CalendarType\"\r\n        >\r\n        </ui5-daterange-picker>\r\n        <button\r\n            class=\"btn-drop-down\"\r\n            fd-button\r\n            [fdType]=\"'standard'\"\r\n            [glyph]=\"'slim-arrow-down'\"\r\n            (click)=\"popover.open()\"\r\n        ></button>\r\n    </div>\r\n</ng-container>\r\n<ng-template #input>\r\n    <!-- <input fd-form-control [(ngModel)]=\"valueStr\" [fd-inline-help]=\"valueStr\" [readOnly]=\"true\" /> -->\r\n\r\n    <fd-input-group\r\n        placement=\"after\"\r\n        glyph=\"slim-arrow-down\"\r\n        glyphAriaLabel=\"Select Date Range\"\r\n        [button]=\"true\"\r\n        [ngModel]=\"valueStr\"\r\n        (addOnButtonClicked)=\"popover.open()\"\r\n    >\r\n    </fd-input-group>\r\n</ng-template>\r\n\r\n<!-- <button fd-button>\r\n    <fd-select (valueChange)=\"onDateRangeTypeChange($event)\">\r\n        <fd-option *ngFor=\"let option of dateRanges\" [value]=\"option\">{{ option | bbbTranslate }}</fd-option>\r\n    </fd-select>\r\n</button> -->\r\n\r\n<fd-popover\r\n    #popover\r\n    style=\"display: block\"\r\n    [fillControlMode]=\"'at-least'\"\r\n    placement=\"bottom-start\"\r\n    [(isOpen)]=\"isOpenPopover\"\r\n>\r\n    <fd-popover-body>\r\n        <ul fd-list>\r\n            <li fd-list-item *ngFor=\"let option of dateRanges\" (click)=\"popover.close(); onDateRangeTypeChange(option)\">\r\n                <a fd-list-link>\r\n                    <span fd-list-title>{{ option | bbbTranslate }}</span>\r\n                </a>\r\n            </li>\r\n        </ul>\r\n    </fd-popover-body>\r\n</fd-popover>\r\n"]}
@@ -91,7 +91,7 @@ UiDateTimeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", ve
91
91
  useFactory: getDateService,
92
92
  deps: [LogService]
93
93
  }
94
- ], viewQueries: [{ propertyName: "datetimePickerRef", first: true, predicate: ["datetimePicker"], descendants: true }, { propertyName: "datePickerRef", first: true, predicate: ["datePicker"], descendants: true }, { propertyName: "durationPickerRef", first: true, predicate: ["durationPicker"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<input\n *ngIf=\"(disableOrReadonly$ | async)!!; else datetime\"\n fd-form-control\n type=\"text\"\n [attr.readonly]=\"(readonly$ | async) === true ? true : null\"\n [attr.disabled]=\"(disable$ | async) === true ? true : null\"\n [value]=\"valueCaption\"\n/>\n<ng-template #datetime>\n <div\n [style.display]=\"(disableOrReadonly$ | async)!! ? 'hidden' : 'block'\"\n [attr.dir]=\"Setting.IsLtr === true ? 'ltr' : 'rtl'\"\n >\n <bc-date-time-picker\n [value]=\"value\"\n [showDate]=\"Setting.ShowDate1\"\n [showTime]=\"Setting.ShowTime1\"\n [primaryCalendarType]=\"Setting.CalendarType\"\n [formatPattern]=\"formatPattern\"\n (valueChange)=\"onDateChange2($event)\"\n [readonly]=\"(readonly$ | async) === true ? true : false\"\n [disabled]=\"(disable$ | async) === true ? true : false\"\n >\n </bc-date-time-picker>\n </div>\n</ng-template>\n", styles: [":host{display:block}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.FormControlComponent, selector: "[fd-form-control]", inputs: ["state", "type", "class"] }, { kind: "directive", type: i2.InputFormControlDirective, selector: "input[fd-form-control]" }, { kind: "component", type: i3.DateTimePickerComponent, selector: "bc-date-time-picker", inputs: ["placeholder", "primaryCalendarType", "formatPattern", "value", "timeValue", "startRangeDate", "endRangeDate", "isRangePicker", "showTime", "showDate", "rtl", "readonly", "disabled"], outputs: ["rangeChange", "valueChange"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
94
+ ], viewQueries: [{ propertyName: "datetimePickerRef", first: true, predicate: ["datetimePicker"], descendants: true }, { propertyName: "datePickerRef", first: true, predicate: ["datePicker"], descendants: true }, { propertyName: "durationPickerRef", first: true, predicate: ["durationPicker"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<input\n *ngIf=\"(disableOrReadonly$ | async)!!; else datetime\"\n fd-form-control\n type=\"text\"\n [attr.readonly]=\"(readonly$ | async) === true ? true : null\"\n [attr.disabled]=\"(disable$ | async) === true ? true : null\"\n [value]=\"value ? valueCaption : ''\"\n/>\n<ng-template #datetime>\n <div\n [style.display]=\"(disableOrReadonly$ | async)!! ? 'hidden' : 'block'\"\n [attr.dir]=\"Setting.IsLtr === true ? 'ltr' : 'rtl'\"\n >\n <bc-date-time-picker\n [value]=\"value\"\n [showDate]=\"Setting.ShowDate1\"\n [showTime]=\"Setting.ShowTime1\"\n [primaryCalendarType]=\"Setting.CalendarType\"\n [formatPattern]=\"formatPattern\"\n (valueChange)=\"onDateChange2($event)\"\n [readonly]=\"(readonly$ | async) === true ? true : false\"\n [disabled]=\"(disable$ | async) === true ? true : false\"\n >\n </bc-date-time-picker>\n </div>\n</ng-template>\n", styles: [":host{display:block}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.FormControlComponent, selector: "[fd-form-control]", inputs: ["state", "type", "class"] }, { kind: "directive", type: i2.InputFormControlDirective, selector: "input[fd-form-control]" }, { kind: "component", type: i3.DateTimePickerComponent, selector: "bc-date-time-picker", inputs: ["placeholder", "primaryCalendarType", "formatPattern", "value", "timeValue", "startRangeDate", "endRangeDate", "isRangePicker", "showTime", "showDate", "rtl", "readonly", "disabled"], outputs: ["rangeChange", "valueChange"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
95
95
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: UiDateTimeComponent, decorators: [{
96
96
  type: Component,
97
97
  args: [{ selector: 'bsu-ui-date-time', providers: [
@@ -100,7 +100,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImpor
100
100
  useFactory: getDateService,
101
101
  deps: [LogService]
102
102
  }
103
- ], changeDetection: ChangeDetectionStrategy.OnPush, template: "<input\n *ngIf=\"(disableOrReadonly$ | async)!!; else datetime\"\n fd-form-control\n type=\"text\"\n [attr.readonly]=\"(readonly$ | async) === true ? true : null\"\n [attr.disabled]=\"(disable$ | async) === true ? true : null\"\n [value]=\"valueCaption\"\n/>\n<ng-template #datetime>\n <div\n [style.display]=\"(disableOrReadonly$ | async)!! ? 'hidden' : 'block'\"\n [attr.dir]=\"Setting.IsLtr === true ? 'ltr' : 'rtl'\"\n >\n <bc-date-time-picker\n [value]=\"value\"\n [showDate]=\"Setting.ShowDate1\"\n [showTime]=\"Setting.ShowTime1\"\n [primaryCalendarType]=\"Setting.CalendarType\"\n [formatPattern]=\"formatPattern\"\n (valueChange)=\"onDateChange2($event)\"\n [readonly]=\"(readonly$ | async) === true ? true : false\"\n [disabled]=\"(disable$ | async) === true ? true : false\"\n >\n </bc-date-time-picker>\n </div>\n</ng-template>\n", styles: [":host{display:block}\n"] }]
103
+ ], changeDetection: ChangeDetectionStrategy.OnPush, template: "<input\n *ngIf=\"(disableOrReadonly$ | async)!!; else datetime\"\n fd-form-control\n type=\"text\"\n [attr.readonly]=\"(readonly$ | async) === true ? true : null\"\n [attr.disabled]=\"(disable$ | async) === true ? true : null\"\n [value]=\"value ? valueCaption : ''\"\n/>\n<ng-template #datetime>\n <div\n [style.display]=\"(disableOrReadonly$ | async)!! ? 'hidden' : 'block'\"\n [attr.dir]=\"Setting.IsLtr === true ? 'ltr' : 'rtl'\"\n >\n <bc-date-time-picker\n [value]=\"value\"\n [showDate]=\"Setting.ShowDate1\"\n [showTime]=\"Setting.ShowTime1\"\n [primaryCalendarType]=\"Setting.CalendarType\"\n [formatPattern]=\"formatPattern\"\n (valueChange)=\"onDateChange2($event)\"\n [readonly]=\"(readonly$ | async) === true ? true : false\"\n [disabled]=\"(disable$ | async) === true ? true : false\"\n >\n </bc-date-time-picker>\n </div>\n</ng-template>\n", styles: [":host{display:block}\n"] }]
104
104
  }], propDecorators: { datetimePickerRef: [{
105
105
  type: ViewChild,
106
106
  args: ['datetimePicker']
@@ -113,4 +113,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImpor
113
113
  }], GetCaption: [{
114
114
  type: Input
115
115
  }] } });
116
- //# 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 { AfterViewInit, Component, ElementRef, OnInit, Input, ViewChild, ChangeDetectionStrategy } from '@angular/core';\nimport { FieldBaseComponent, DateService, LogService, getDateService } from 'barsa-novin-ray-core';\n\n@Component({\n    selector: 'bsu-ui-date-time',\n    templateUrl: './ui-date-time.component.html',\n    styleUrls: ['./ui-date-time.component.scss'],\n    providers: [\n        {\n            provide: DateService,\n            useFactory: getDateService,\n            deps: [LogService]\n        }\n    ],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class UiDateTimeComponent extends FieldBaseComponent implements OnInit, AfterViewInit {\n    @ViewChild('datetimePicker') datetimePickerRef: ElementRef;\n    @ViewChild('datePicker') datePickerRef: ElementRef;\n    @ViewChild('durationPicker') durationPickerRef: ElementRef;\n    fullCalendar: boolean;\n    value: Date;\n    valueCaption = '';\n    formatPattern: string;\n\n    ngOnInit(): void {\n        super.ngOnInit();\n        if (typeof this.value === 'string' && this.value) {\n            this.value = this.context.value = new Date(this.value);\n        }\n        this.fullCalendar = this.Setting.ShowTime1 && this.Setting.ShowDate1;\n        const timeFormat: string = this.Setting.TimeFormat?.toLowerCase();\n        let timeFormat2 = '';\n        if (timeFormat) {\n            timeFormat2 = ' ';\n            timeFormat.split(':').forEach((val) => {\n                switch (val) {\n                    case 'h':\n                        timeFormat2 += 'HH';\n                        break;\n                    case 'i':\n                        timeFormat2 += ':mm';\n                        break;\n                    case 's':\n                        timeFormat2 += ':SS';\n                        break;\n                }\n            });\n        }\n        // timeFormat2 += ' A';\n        this.formatPattern = `YYYY/MM/DD${timeFormat2}`;\n        // this.value$.pipe(takeUntil(this._onDestroy$)).subscribe((value) => {\n        //   this.value = <Date>value;\n\n        //   // this._setValueCaption(value);\n        // });\n        // // this._setValueCaption(this.value);\n    }\n\n    ngAfterViewInit(): void {\n        super.ngAfterViewInit();\n        this._setCaption(this.value);\n    }\n    onDateTimeChange(): void {\n        const datetimePickerControl = this.datetimePickerRef.nativeElement;\n        this.value = datetimePickerControl.dateValue;\n        this.valueCaption = datetimePickerControl.value;\n        this.valueChange.emit(this.value);\n    }\n    onDateChange(): void {\n        const datePickerControl = this.datePickerRef.nativeElement;\n        this._valueDateChange(datePickerControl.dateValue);\n    }\n    onDateChange2(date): void {\n        this._valueDateChange(date);\n    }\n\n    onDurationChange(e): void {\n        const { value } = e.detail;\n        if (!this.value) {\n            this.value = new Date();\n        }\n        const time = value.split(':');\n        this.value.setHours(Number(time[0]), Number(time[1]), Number(time[2]));\n        this.valueCaption = this.durationPickerRef.nativeElement.value;\n        this.valueChange.emit(this.value);\n    }\n    protected _setValue(value: Date): void {\n        this._setCaption(value);\n        super._setValue(value);\n    }\n    private _valueDateChange(dateValue: Date): void {\n        this.value = dateValue;\n        this.valueCaption = this._setCaption(dateValue); // datePickerControl.value;\n        this.valueChange.emit(this.value);\n    }\n    private _setCaption(value: Date): string {\n        return (this.context.caption = this.valueCaption =\n            this._dateService.getMoment(value).format(this.formatPattern));\n    }\n    /* eslint-disable */\n    @Input() GetCaption = () => this.valueCaption;\n}\n","<input\n    *ngIf=\"(disableOrReadonly$ | async)!!; else datetime\"\n    fd-form-control\n    type=\"text\"\n    [attr.readonly]=\"(readonly$ | async) === true ? true : null\"\n    [attr.disabled]=\"(disable$ | async) === true ? true : null\"\n    [value]=\"valueCaption\"\n/>\n<ng-template #datetime>\n    <div\n        [style.display]=\"(disableOrReadonly$ | async)!! ? 'hidden' : 'block'\"\n        [attr.dir]=\"Setting.IsLtr === true ? 'ltr' : 'rtl'\"\n    >\n        <bc-date-time-picker\n            [value]=\"value\"\n            [showDate]=\"Setting.ShowDate1\"\n            [showTime]=\"Setting.ShowTime1\"\n            [primaryCalendarType]=\"Setting.CalendarType\"\n            [formatPattern]=\"formatPattern\"\n            (valueChange)=\"onDateChange2($event)\"\n            [readonly]=\"(readonly$ | async) === true ? true : false\"\n            [disabled]=\"(disable$ | async) === true ? true : false\"\n        >\n        </bc-date-time-picker>\n    </div>\n</ng-template>\n"]}
116
+ //# 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 { AfterViewInit, Component, ElementRef, OnInit, Input, ViewChild, ChangeDetectionStrategy } from '@angular/core';\r\nimport { FieldBaseComponent, DateService, LogService, getDateService } 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})\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\r\n    ngOnInit(): void {\r\n        super.ngOnInit();\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        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        // timeFormat2 += ' A';\r\n        this.formatPattern = `YYYY/MM/DD${timeFormat2}`;\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    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        return (this.context.caption = this.valueCaption =\r\n            this._dateService.getMoment(value).format(this.formatPattern));\r\n    }\r\n    /* eslint-disable */\r\n    @Input() GetCaption = () => this.valueCaption;\r\n}\r\n","<input\n    *ngIf=\"(disableOrReadonly$ | async)!!; else datetime\"\n    fd-form-control\n    type=\"text\"\n    [attr.readonly]=\"(readonly$ | async) === true ? true : null\"\n    [attr.disabled]=\"(disable$ | async) === true ? true : null\"\n    [value]=\"value ? valueCaption : ''\"\n/>\n<ng-template #datetime>\n    <div\n        [style.display]=\"(disableOrReadonly$ | async)!! ? 'hidden' : 'block'\"\n        [attr.dir]=\"Setting.IsLtr === true ? 'ltr' : 'rtl'\"\n    >\n        <bc-date-time-picker\n            [value]=\"value\"\n            [showDate]=\"Setting.ShowDate1\"\n            [showTime]=\"Setting.ShowTime1\"\n            [primaryCalendarType]=\"Setting.CalendarType\"\n            [formatPattern]=\"formatPattern\"\n            (valueChange)=\"onDateChange2($event)\"\n            [readonly]=\"(readonly$ | async) === true ? true : false\"\n            [disabled]=\"(disable$ | async) === true ? true : false\"\n        >\n        </bc-date-time-picker>\n    </div>\n</ng-template>\n"]}
@@ -97,14 +97,14 @@ export class UiEditableGridComponent extends SapUiReportBaseComponent {
97
97
  }
98
98
  }
99
99
  UiEditableGridComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: UiEditableGridComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
100
- UiEditableGridComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: UiEditableGridComponent, selector: "bsu-ui-editable-grid", providers: [FormPanelService], usesInheritance: true, ngImport: i0, template: "<ng-container\n *ngTemplateOutlet=\"\n matrixTemplate;\n context: {\n moDataList: matrixMoList$ | async,\n columns: horizontalRows,\n conditionalFormats: conditionalFormats$ | async,\n deviceName: deviceName$ | async,\n deviceSize: deviceSize$ | async,\n title: title$ | async,\n inlineEditMode: inlineEditMode$ | async,\n allowInlineEdit: allowInlineEdit$ | async,\n hideToolbar: hideToolbar$ | async,\n contentDensity: contentDensity$ | async,\n activeCell: activeCell,\n valueControlFieldCaption: valueControlFieldCaption,\n valueType: valueType,\n formSetting: context.Setting.FormTemplate,\n matrixWidthType: matrixWidthType,\n cellWidth: cellWidth,\n verticalLabelWidth: verticalLabelWidth,\n fitWidth: fitWidth,\n access: context.Setting.Extra?.DefaultCommandsAccess,\n hasSelected: hasSelected$ | async,\n containerWidth: containerWidth$ | async,\n formLayout: formLayout\n }\n \"\n></ng-container>\n\n<ng-template\n #matrixTemplate\n let-moDataList=\"moDataList\"\n let-deviceName=\"deviceName\"\n let-deviceSize=\"deviceSize\"\n let-title=\"title\"\n let-inlineEditMode=\"inlineEditMode\"\n let-allowInlineEdit=\"allowInlineEdit\"\n let-hideToolbar=\"hideToolbar\"\n let-contentDensity=\"contentDensity\"\n let-columns=\"columns\"\n let-conditionalFormats=\"conditionalFormats\"\n let-activeCell=\"activeCell\"\n let-valueControlFieldCaption=\"valueControlFieldCaption\"\n let-valueType=\"valueType\"\n let-formSetting=\"formSetting\"\n let-matrixWidthType=\"matrixWidthType\"\n let-cellWidth=\"cellWidth\"\n let-verticalLabelWidth=\"verticalLabelWidth\"\n let-fitWidth=\"fitWidth\"\n let-access=\"access\"\n let-hasSelected=\"hasSelected\"\n let-containerWidth=\"containterWidth\"\n let-formLayout=\"formLayout\"\n>\n <bsu-ulv-toolbar\n [hideToolbar]=\"hideToolbar\"\n [deviceName]=\"deviceName\"\n [deviceSize]=\"deviceSize\"\n [title]=\"title\"\n [hasSelected]=\"hasSelected\"\n [access]=\"access\"\n [contentDensity]=\"contentDensity\"\n [inlineEditMode]=\"inlineEditMode\"\n [allowInlineEdit]=\"allowInlineEdit\"\n (sortClick)=\"onSortSettings(deviceName)\"\n (editModeClick)=\"onEditMode()\"\n >\n <button\n fd-toolbar-item\n fd-button\n [fdType]=\"'emphasized'\"\n [label]=\"'Save' | bbbTranslate\"\n [glyph]=\"'save'\"\n (click)=\"onSave()\"\n ></button>\n <fd-split-button\n fd-toolbar-item\n [mainAction]=\"{\n keepMainAction: true,\n mainActionTitle: splitBtnTitle\n }\"\n >\n <fd-menu>\n <li fd-menu-item>\n <div fd-menu-interactive (click)=\"onChangeView(true)\">\n <span fd-menu-title>\n {{ widthTypeEnum.FitWidth }}\n </span>\n </div>\n </li>\n <li fd-menu-item>\n <div fd-menu-interactive (click)=\"onChangeView(false)\">\n <span fd-menu-title>\n {{ widthTypeEnum.StaticWidth }}\n </span>\n </div>\n </li>\n </fd-menu>\n </fd-split-button>\n\n <ng-template #splitBtnTitle>\n <span>{{ fitWidth ? widthTypeEnum.FitWidth : widthTypeEnum.StaticWidth }}</span>\n </ng-template>\n </bsu-ulv-toolbar>\n <bsu-ui-matrix-view\n [moDataList]=\"moDataList\"\n [columns]=\"columns\"\n [conditionalFormats]=\"conditionalFormats\"\n [activeCell]=\"activeCell\"\n [valueControlFieldCaption]=\"valueControlFieldCaption\"\n [valueType]=\"valueType\"\n [access]=\"access\"\n [formLayout]=\"formLayout\"\n [matrixWidthType]=\"matrixWidthType\"\n [cellWidth]=\"cellWidth\"\n [cellHeight]=\"cellHeight\"\n [verticalLabelWidth]=\"verticalLabelWidth\"\n [fitWidth]=\"fitWidth\"\n [minWidth]=\"minWidth\"\n [minHeight]=\"minHeight\"\n [rowResizer]=\"rowResizer\"\n [enableResizing]=\"enableResizing\"\n [containerWidth]=\"containerWidth\"\n (selectionChange)=\"onSelectionChange($event)\"\n ></bsu-ui-matrix-view>\n</ng-template>\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]", inputs: ["class"], exportAs: ["fd-button"] }, { kind: "component", type: i3.MenuComponent, selector: "fd-menu", inputs: ["mobile", "disabled", "focusTrapped", "openOnHoverTime", "mobileConfig", "ariaLabel", "ariaLabelledby", "id"], outputs: ["activePath"] }, { kind: "component", type: i3.MenuItemComponent, selector: "li[fd-menu-item]", inputs: ["disabled", "itemId", "submenu"], outputs: ["onSelect"], exportAs: ["fd-menu-item"] }, { kind: "directive", type: i3.MenuInteractiveDirective, selector: "[fd-menu-interactive]" }, { kind: "directive", type: i3.MenuTitleDirective, selector: "[fd-menu-title]" }, { kind: "component", type: i4.SplitButtonComponent, selector: "fd-split-button", inputs: ["glyph", "disabled", "mainActionTitle", "fdType", "expandButtonAriaLabel", "expandButtonTitle", "selected", "fixedWidth", "mainAction", "arialLabel"], outputs: ["primaryButtonClicked"] }, { kind: "directive", type: i5.ToolbarItemDirective, selector: "[fd-toolbar-item]" }, { kind: "component", type: i6.UlvToolbarComponent, selector: "bsu-ulv-toolbar", inputs: ["useLayoutItemTextForControl", "enableSearch", "hideTitle", "title", "deviceName", "deviceSize", "access", "hideToolbar", "toolbarButtons", "contentDensity", "inlineEditMode", "allowInlineEdit", "gridSetting", "viewCollection", "reportView", "hasSelected", "config", "hidden", "buttons"], outputs: ["search", "groupbyClick", "sortClick", "columnClick", "editModeClick", "viewClick"] }, { kind: "component", type: i7.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: i8.BbbTranslatePipe, name: "bbbTranslate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
100
+ UiEditableGridComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", 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 (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]", inputs: ["class"], exportAs: ["fd-button"] }, { kind: "component", type: i3.MenuComponent, selector: "fd-menu", inputs: ["mobile", "disabled", "focusTrapped", "openOnHoverTime", "mobileConfig", "ariaLabel", "ariaLabelledby", "id"], outputs: ["activePath"] }, { kind: "component", type: i3.MenuItemComponent, selector: "li[fd-menu-item]", inputs: ["disabled", "itemId", "submenu"], outputs: ["onSelect"], exportAs: ["fd-menu-item"] }, { kind: "directive", type: i3.MenuInteractiveDirective, selector: "[fd-menu-interactive]" }, { kind: "directive", type: i3.MenuTitleDirective, selector: "[fd-menu-title]" }, { kind: "component", type: i4.SplitButtonComponent, selector: "fd-split-button", inputs: ["glyph", "disabled", "mainActionTitle", "fdType", "expandButtonAriaLabel", "expandButtonTitle", "selected", "fixedWidth", "mainAction", "arialLabel"], outputs: ["primaryButtonClicked"] }, { kind: "directive", type: i5.ToolbarItemDirective, selector: "[fd-toolbar-item]" }, { kind: "component", type: i6.UlvToolbarComponent, selector: "bsu-ulv-toolbar", inputs: ["useLayoutItemTextForControl", "enableSearch", "hideTitle", "title", "deviceName", "deviceSize", "access", "hideToolbar", "toolbarButtons", "contentDensity", "inlineEditMode", "allowInlineEdit", "gridSetting", "viewCollection", "reportView", "inDialog", "isMultiSelect", "hasSelected", "config", "hidden", "buttons"], outputs: ["search", "groupbyClick", "sortClick", "columnClick", "editModeClick", "viewClick", "createNewInlineMo"] }, { kind: "component", type: i7.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: i8.BbbTranslatePipe, name: "bbbTranslate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
101
101
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: UiEditableGridComponent, decorators: [{
102
102
  type: Component,
103
- args: [{ selector: 'bsu-ui-editable-grid', changeDetection: ChangeDetectionStrategy.OnPush, providers: [FormPanelService], template: "<ng-container\n *ngTemplateOutlet=\"\n matrixTemplate;\n context: {\n moDataList: matrixMoList$ | async,\n columns: horizontalRows,\n conditionalFormats: conditionalFormats$ | async,\n deviceName: deviceName$ | async,\n deviceSize: deviceSize$ | async,\n title: title$ | async,\n inlineEditMode: inlineEditMode$ | async,\n allowInlineEdit: allowInlineEdit$ | async,\n hideToolbar: hideToolbar$ | async,\n contentDensity: contentDensity$ | async,\n activeCell: activeCell,\n valueControlFieldCaption: valueControlFieldCaption,\n valueType: valueType,\n formSetting: context.Setting.FormTemplate,\n matrixWidthType: matrixWidthType,\n cellWidth: cellWidth,\n verticalLabelWidth: verticalLabelWidth,\n fitWidth: fitWidth,\n access: context.Setting.Extra?.DefaultCommandsAccess,\n hasSelected: hasSelected$ | async,\n containerWidth: containerWidth$ | async,\n formLayout: formLayout\n }\n \"\n></ng-container>\n\n<ng-template\n #matrixTemplate\n let-moDataList=\"moDataList\"\n let-deviceName=\"deviceName\"\n let-deviceSize=\"deviceSize\"\n let-title=\"title\"\n let-inlineEditMode=\"inlineEditMode\"\n let-allowInlineEdit=\"allowInlineEdit\"\n let-hideToolbar=\"hideToolbar\"\n let-contentDensity=\"contentDensity\"\n let-columns=\"columns\"\n let-conditionalFormats=\"conditionalFormats\"\n let-activeCell=\"activeCell\"\n let-valueControlFieldCaption=\"valueControlFieldCaption\"\n let-valueType=\"valueType\"\n let-formSetting=\"formSetting\"\n let-matrixWidthType=\"matrixWidthType\"\n let-cellWidth=\"cellWidth\"\n let-verticalLabelWidth=\"verticalLabelWidth\"\n let-fitWidth=\"fitWidth\"\n let-access=\"access\"\n let-hasSelected=\"hasSelected\"\n let-containerWidth=\"containterWidth\"\n let-formLayout=\"formLayout\"\n>\n <bsu-ulv-toolbar\n [hideToolbar]=\"hideToolbar\"\n [deviceName]=\"deviceName\"\n [deviceSize]=\"deviceSize\"\n [title]=\"title\"\n [hasSelected]=\"hasSelected\"\n [access]=\"access\"\n [contentDensity]=\"contentDensity\"\n [inlineEditMode]=\"inlineEditMode\"\n [allowInlineEdit]=\"allowInlineEdit\"\n (sortClick)=\"onSortSettings(deviceName)\"\n (editModeClick)=\"onEditMode()\"\n >\n <button\n fd-toolbar-item\n fd-button\n [fdType]=\"'emphasized'\"\n [label]=\"'Save' | bbbTranslate\"\n [glyph]=\"'save'\"\n (click)=\"onSave()\"\n ></button>\n <fd-split-button\n fd-toolbar-item\n [mainAction]=\"{\n keepMainAction: true,\n mainActionTitle: splitBtnTitle\n }\"\n >\n <fd-menu>\n <li fd-menu-item>\n <div fd-menu-interactive (click)=\"onChangeView(true)\">\n <span fd-menu-title>\n {{ widthTypeEnum.FitWidth }}\n </span>\n </div>\n </li>\n <li fd-menu-item>\n <div fd-menu-interactive (click)=\"onChangeView(false)\">\n <span fd-menu-title>\n {{ widthTypeEnum.StaticWidth }}\n </span>\n </div>\n </li>\n </fd-menu>\n </fd-split-button>\n\n <ng-template #splitBtnTitle>\n <span>{{ fitWidth ? widthTypeEnum.FitWidth : widthTypeEnum.StaticWidth }}</span>\n </ng-template>\n </bsu-ulv-toolbar>\n <bsu-ui-matrix-view\n [moDataList]=\"moDataList\"\n [columns]=\"columns\"\n [conditionalFormats]=\"conditionalFormats\"\n [activeCell]=\"activeCell\"\n [valueControlFieldCaption]=\"valueControlFieldCaption\"\n [valueType]=\"valueType\"\n [access]=\"access\"\n [formLayout]=\"formLayout\"\n [matrixWidthType]=\"matrixWidthType\"\n [cellWidth]=\"cellWidth\"\n [cellHeight]=\"cellHeight\"\n [verticalLabelWidth]=\"verticalLabelWidth\"\n [fitWidth]=\"fitWidth\"\n [minWidth]=\"minWidth\"\n [minHeight]=\"minHeight\"\n [rowResizer]=\"rowResizer\"\n [enableResizing]=\"enableResizing\"\n [containerWidth]=\"containerWidth\"\n (selectionChange)=\"onSelectionChange($event)\"\n ></bsu-ui-matrix-view>\n</ng-template>\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"] }]
103
+ args: [{ selector: 'bsu-ui-editable-grid', changeDetection: ChangeDetectionStrategy.OnPush, providers: [FormPanelService], 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 (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"] }]
104
104
  }] });
105
105
  export var WidthTypeEnum;
106
106
  (function (WidthTypeEnum) {
107
107
  WidthTypeEnum["FitWidth"] = "\u0633\u062A\u0648\u0646 \u0647\u0627\u06CC \u0647\u0645 \u0639\u0631\u0636";
108
108
  WidthTypeEnum["StaticWidth"] = "\u0633\u062A\u0648\u0646 \u0647\u0627\u06CC \u0628\u0627 \u0639\u0631\u0636 \u062F\u0644\u062E\u0648\u0627\u0647";
109
109
  })(WidthTypeEnum || (WidthTypeEnum = {}));
110
- //# 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';\nimport { map, takeUntil, tap } from 'rxjs/operators';\n\nimport {\n    createGridEditorFormPanel,\n    FormPanelService,\n    LayoutSetting,\n    MetaobjectDataModel,\n    UiReportViewBaseSetting\n} from 'barsa-novin-ray-core';\nimport { SapUiReportBaseComponent } from '../sap-ui-report-base.component';\nimport { Observable } from 'rxjs';\n\n@Component({\n    selector: 'bsu-ui-editable-grid',\n    templateUrl: './ui-editable-grid.component.html',\n    styleUrls: ['./ui-editable-grid.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [FormPanelService]\n})\nexport class UiEditableGridComponent\n    extends SapUiReportBaseComponent<UiReportViewBaseSetting>\n    implements OnInit, OnDestroy\n{\n    valueControlFieldCaption;\n    valueDbName;\n    horizontalRows: any[];\n    activeCell;\n    valueType;\n    formLayout: LayoutSetting;\n    matrixWidthType;\n    cellWidth = 100;\n    cellHeight = 38;\n    verticalLabelWidth = 100;\n    minWidth = 100;\n    minHeight = 22;\n    enableResizing = true;\n    rowResizer = true;\n    widthTypeEnum = WidthTypeEnum;\n    fitWidth = true;\n    matrixMoList$: Observable<MetaobjectDataModel[]>;\n\n    ngOnInit(): void {\n        super.ngOnInit();\n        this.valueDbName = this.context.Setting.View.ValueDbName;\n        this.valueType = this.context.valueFieldType;\n        const formSetting = this.context.Setting.FormTemplate;\n        // this.formLayout = this.context.Setting.FormTemplate.View.ControlInfo;\n        this.horizontalRows = this.context.Setting.View.HorizontalColumn;\n        this.valueControlFieldCaption = this.context.Setting.FormTemplate.View.ControlInfo.find(\n            (col) => col.ControlName === this.valueDbName\n        ).ControlFieldCaption;\n        // there is different between ulv modatalist and viewer datalist. in matrixviewer adapter modatalist transformed.\n        // so we need tell to ulvmainservice to update modatalist\n        this._ulvMainService.reSetMoDataList(this.context.moDataList);\n\n        this.matrixMoList$ = this.moDataList$.pipe(\n            takeUntil(this._onDestroy$),\n            map((moDataList) => this._matrixMoList(moDataList))\n        );\n\n        if (!this.formPanelCtrlr) {\n            this.formPanelCtrlr = createGridEditorFormPanel(\n                formSetting,\n                formSetting.Data.Mo,\n                this._typeDefId,\n                null\n                // BarsaApi.Common.Util.TryGetValue(this.context.Setting, 'Extra.Relation')\n            );\n            const formPanelCtrlr = this.formPanelCtrlr;\n            this.formLayout = formPanelCtrlr.Setting.View.Layout94;\n\n            formPanelCtrlr.on({\n                ValueChange: this._cellValueChange.bind(this)\n            });\n            this.formPanelCtrlr.LoadAndCreate(null, false, false, () => {\n                const customFormPanelUi = formPanelCtrlr.Adapter.Control;\n                customFormPanelUi.Refresh = () => {};\n                this._formpanelService.context = formPanelCtrlr.Adapter.Control;\n            });\n        }\n    }\n    onSave(): void {\n        this.context.fireEvent(\n            'SaveBatchClicked',\n            this.moDataList.filter((c) => c.$Modified).map((c) => ({ data: c, modified: c.$Modified }))\n        );\n    }\n    onSelectionChange(cellInfo: { value: any; index: { i: number; j: number } }): void {\n        const { value, index } = cellInfo;\n        this.activeCell = index;\n        // const newMo = getNewMoGridEditor(this.context.Setting.FormTemplate, this._typeDefId);\n        // newMo[this.valueDbName] = value;\n\n        const controlUi = this.formPanelCtrlr.GetFieldlByName(this.valueDbName);\n        controlUi.SetValue(value);\n    }\n    onChangeView(isFit: boolean): void {\n        this.fitWidth = isFit;\n    }\n\n    /* eslint-disable */\n    protected _select(mo, index): MetaobjectDataModel {\n        return mo;\n    }\n    private _matrixMoList(moDataList): MetaobjectDataModel[] {\n        moDataList.forEach((mo) => {\n            this.horizontalRows.forEach((col) => {\n                if (mo[col.Caption] === undefined) {\n                    mo[col.Caption] = null;\n                }\n            });\n        });\n        return moDataList;\n    }\n    private _cellValueChange(sender): void {\n        const indexI = this.activeCell.i;\n        const indexJ = this.activeCell.j;\n        this.moDataList$\n            .pipe(\n                takeUntil(this._onDestroy$),\n                tap((moDataList) => {\n                    moDataList[indexI][this.horizontalRows[indexJ].Caption] = sender.Mo[this.valueDbName];\n                    if (moDataList[indexI].$Modified) {\n                        moDataList[indexI].$Modified[this.horizontalRows[indexJ].Caption] = 1;\n                    } else {\n                        moDataList[indexI].$Modified = { [this.horizontalRows[indexJ].Caption]: 1 };\n                    }\n                })\n            )\n            .subscribe();\n    }\n}\nexport enum WidthTypeEnum {\n    FitWidth = 'ستون های هم عرض',\n    StaticWidth = 'ستون های با عرض دلخواه'\n}\n","<ng-container\n    *ngTemplateOutlet=\"\n        matrixTemplate;\n        context: {\n            moDataList: matrixMoList$ | async,\n            columns: horizontalRows,\n            conditionalFormats: conditionalFormats$ | async,\n            deviceName: deviceName$ | async,\n            deviceSize: deviceSize$ | async,\n            title: title$ | async,\n            inlineEditMode: inlineEditMode$ | async,\n            allowInlineEdit: allowInlineEdit$ | async,\n            hideToolbar: hideToolbar$ | async,\n            contentDensity: contentDensity$ | async,\n            activeCell: activeCell,\n            valueControlFieldCaption: valueControlFieldCaption,\n            valueType: valueType,\n            formSetting: context.Setting.FormTemplate,\n            matrixWidthType: matrixWidthType,\n            cellWidth: cellWidth,\n            verticalLabelWidth: verticalLabelWidth,\n            fitWidth: fitWidth,\n            access: context.Setting.Extra?.DefaultCommandsAccess,\n            hasSelected: hasSelected$ | async,\n            containerWidth: containerWidth$ | async,\n            formLayout: formLayout\n        }\n    \"\n></ng-container>\n\n<ng-template\n    #matrixTemplate\n    let-moDataList=\"moDataList\"\n    let-deviceName=\"deviceName\"\n    let-deviceSize=\"deviceSize\"\n    let-title=\"title\"\n    let-inlineEditMode=\"inlineEditMode\"\n    let-allowInlineEdit=\"allowInlineEdit\"\n    let-hideToolbar=\"hideToolbar\"\n    let-contentDensity=\"contentDensity\"\n    let-columns=\"columns\"\n    let-conditionalFormats=\"conditionalFormats\"\n    let-activeCell=\"activeCell\"\n    let-valueControlFieldCaption=\"valueControlFieldCaption\"\n    let-valueType=\"valueType\"\n    let-formSetting=\"formSetting\"\n    let-matrixWidthType=\"matrixWidthType\"\n    let-cellWidth=\"cellWidth\"\n    let-verticalLabelWidth=\"verticalLabelWidth\"\n    let-fitWidth=\"fitWidth\"\n    let-access=\"access\"\n    let-hasSelected=\"hasSelected\"\n    let-containerWidth=\"containterWidth\"\n    let-formLayout=\"formLayout\"\n>\n    <bsu-ulv-toolbar\n        [hideToolbar]=\"hideToolbar\"\n        [deviceName]=\"deviceName\"\n        [deviceSize]=\"deviceSize\"\n        [title]=\"title\"\n        [hasSelected]=\"hasSelected\"\n        [access]=\"access\"\n        [contentDensity]=\"contentDensity\"\n        [inlineEditMode]=\"inlineEditMode\"\n        [allowInlineEdit]=\"allowInlineEdit\"\n        (sortClick)=\"onSortSettings(deviceName)\"\n        (editModeClick)=\"onEditMode()\"\n    >\n        <button\n            fd-toolbar-item\n            fd-button\n            [fdType]=\"'emphasized'\"\n            [label]=\"'Save' | bbbTranslate\"\n            [glyph]=\"'save'\"\n            (click)=\"onSave()\"\n        ></button>\n        <fd-split-button\n            fd-toolbar-item\n            [mainAction]=\"{\n                keepMainAction: true,\n                mainActionTitle: splitBtnTitle\n            }\"\n        >\n            <fd-menu>\n                <li fd-menu-item>\n                    <div fd-menu-interactive (click)=\"onChangeView(true)\">\n                        <span fd-menu-title>\n                            {{ widthTypeEnum.FitWidth }}\n                        </span>\n                    </div>\n                </li>\n                <li fd-menu-item>\n                    <div fd-menu-interactive (click)=\"onChangeView(false)\">\n                        <span fd-menu-title>\n                            {{ widthTypeEnum.StaticWidth }}\n                        </span>\n                    </div>\n                </li>\n            </fd-menu>\n        </fd-split-button>\n\n        <ng-template #splitBtnTitle>\n            <span>{{ fitWidth ? widthTypeEnum.FitWidth : widthTypeEnum.StaticWidth }}</span>\n        </ng-template>\n    </bsu-ulv-toolbar>\n    <bsu-ui-matrix-view\n        [moDataList]=\"moDataList\"\n        [columns]=\"columns\"\n        [conditionalFormats]=\"conditionalFormats\"\n        [activeCell]=\"activeCell\"\n        [valueControlFieldCaption]=\"valueControlFieldCaption\"\n        [valueType]=\"valueType\"\n        [access]=\"access\"\n        [formLayout]=\"formLayout\"\n        [matrixWidthType]=\"matrixWidthType\"\n        [cellWidth]=\"cellWidth\"\n        [cellHeight]=\"cellHeight\"\n        [verticalLabelWidth]=\"verticalLabelWidth\"\n        [fitWidth]=\"fitWidth\"\n        [minWidth]=\"minWidth\"\n        [minHeight]=\"minHeight\"\n        [rowResizer]=\"rowResizer\"\n        [enableResizing]=\"enableResizing\"\n        [containerWidth]=\"containerWidth\"\n        (selectionChange)=\"onSelectionChange($event)\"\n    ></bsu-ui-matrix-view>\n</ng-template>\n"]}
110
+ //# 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})\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        (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"]}
@@ -58,4 +58,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImpor
58
58
  type: ViewChild,
59
59
  args: ['templateRef']
60
60
  }] } });
61
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidWktZXhjZXB0aW9uLWZvcm0uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2Etc2FwLXVpL3NyYy9saWIvdWktZXhjZXB0aW9uLWZvcm0vdWktZXhjZXB0aW9uLWZvcm0uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2Etc2FwLXVpL3NyYy9saWIvdWktZXhjZXB0aW9uLWZvcm0vdWktZXhjZXB0aW9uLWZvcm0uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBdUIsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBR25HLE9BQU8sRUFBRSxhQUFhLEVBQUUsUUFBUSxFQUFFLE1BQU0sc0JBQXNCLENBQUM7Ozs7Ozs7QUFPL0QsTUFBTSxPQUFPLHdCQUF5QixTQUFRLGFBQWE7SUFFdkQsWUFBb0IsY0FBNkI7UUFDN0MsS0FBSyxFQUFFLENBQUM7UUFEUSxtQkFBYyxHQUFkLGNBQWMsQ0FBZTtJQUVqRCxDQUFDO0lBRUQsUUFBUTtRQUNKLEtBQUssQ0FBQyxRQUFRLEVBQUUsQ0FBQztRQUNqQixRQUFRLENBQUMsRUFBRSxDQUFDLGFBQWEsQ0FBQyxTQUFTLEdBQUcsSUFBSSxDQUFDO1FBQzNDLFFBQVEsQ0FBQyxFQUFFLENBQUMsYUFBYSxDQUFDLElBQUksR0FBRyxDQUFDLElBQUksRUFBRSxNQUFNLEVBQUUsUUFBUSxFQUFFLEVBQUU7WUFDeEQsSUFBSSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFdBQVcsRUFBRTtnQkFDdkMsR0FBRyxFQUFFLElBQUksRUFBRSxNQUFNLEVBQUUsUUFBUSxFQUFFO2dCQUM3QixpQkFBaUIsRUFBRSxJQUFJO2FBQzFCLENBQUMsQ0FBQztRQUNQLENBQUMsQ0FBQztJQUNOLENBQUM7SUFDRCxPQUFPLENBQUMsTUFBTSxFQUFFLFlBQVk7UUFDeEIsTUFBTSxDQUFDLEtBQUssRUFBRSxDQUFDO1FBQ2YsSUFBSSxZQUFZLENBQUMsUUFBUSxFQUFFO1lBQ3ZCLFlBQVksQ0FBQyxRQUFRLEVBQUUsQ0FBQztTQUMzQjtJQUNMLENBQUM7SUFDRCxVQUFVLENBQUMsTUFBTSxFQUFFLFlBQVk7UUFDM0IsTUFBTSxDQUFDLEtBQUssRUFBRSxDQUFDO1FBQ2YsSUFBSSxZQUFZLENBQUMsUUFBUSxFQUFFO1lBQ3ZCLFlBQVksQ0FBQyxRQUFRLEVBQUUsQ0FBQztTQUMzQjtJQUNMLENBQUM7SUFDRCxNQUFNLENBQUMsT0FBeUI7UUFDNUIsTUFBTSxRQUFRLEdBQUcsT0FBTyxDQUFDO1FBQ3pCLDJCQUEyQjtRQUMzQixRQUFRLENBQUMsTUFBTSxFQUFFLENBQUM7UUFDbEIsUUFBUSxDQUFDLGlCQUFpQixDQUFDLENBQUMsRUFBRSxPQUFPLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsd0JBQXdCO1FBQzdFLHlDQUF5QztRQUN6QyxTQUFTLENBQUMsU0FBUyxDQUFDLFNBQVMsQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDbEQsQ0FBQztJQUNELFFBQVEsQ0FBQyxNQUFNLEVBQUUsWUFBWTtRQUN6QixNQUFNLENBQUMsS0FBSyxFQUFFLENBQUM7UUFDZixJQUFJLFlBQVksQ0FBQyxRQUFRLEVBQUU7WUFDdkIsWUFBWSxDQUFDLFFBQVEsRUFBRSxDQUFDO1NBQzNCO1FBQ0QsUUFBUSxDQUFDLEVBQUUsQ0FBQyxNQUFNLEVBQUUsQ0FBQztJQUN6QixDQUFDOztxSEExQ1Esd0JBQXdCO3lHQUF4Qix3QkFBd0IsZ01DVnJDLHMrREFnREE7MkZEdENhLHdCQUF3QjtrQkFOcEMsU0FBUzsrQkFDSSx1QkFBdUIsbUJBR2hCLHVCQUF1QixDQUFDLE1BQU07b0dBR3JCLFdBQVc7c0JBQXBDLFNBQVM7dUJBQUMsYUFBYSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIE9uSW5pdCwgVGVtcGxhdGVSZWYsIFZpZXdDaGlsZCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRGlhbG9nU2VydmljZSB9IGZyb20gJ0BmdW5kYW1lbnRhbC1uZ3gvY29yZSc7XG5cbmltcG9ydCB7IEJhc2VDb21wb25lbnQsIEJhcnNhQXBpIH0gZnJvbSAnYmFyc2Etbm92aW4tcmF5LWNvcmUnO1xuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdic3UtdWktZXhjZXB0aW9uLWZvcm0nLFxuICAgIHRlbXBsYXRlVXJsOiAnLi91aS1leGNlcHRpb24tZm9ybS5jb21wb25lbnQuaHRtbCcsXG4gICAgc3R5bGVVcmxzOiBbJy4vdWktZXhjZXB0aW9uLWZvcm0uY29tcG9uZW50LnNjc3MnXSxcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxufSlcbmV4cG9ydCBjbGFzcyBVaUV4Y2VwdGlvbkZvcm1Db21wb25lbnQgZXh0ZW5kcyBCYXNlQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcbiAgICBAVmlld0NoaWxkKCd0ZW1wbGF0ZVJlZicpIHRlbXBsYXRlUmVmOiBUZW1wbGF0ZVJlZjxhbnk+O1xuICAgIGNvbnN0cnVjdG9yKHByaXZhdGUgX2RpYWxvZ1NlcnZpY2U6IERpYWxvZ1NlcnZpY2UpIHtcbiAgICAgICAgc3VwZXIoKTtcbiAgICB9XG5cbiAgICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICAgICAgc3VwZXIubmdPbkluaXQoKTtcbiAgICAgICAgQmFyc2FBcGkuVWkuRXhjZXB0aW9uRm9ybS5Jc0hhbmRsZWQgPSB0cnVlO1xuICAgICAgICBCYXJzYUFwaS5VaS5FeGNlcHRpb25Gb3JtLlNob3cgPSAodGV4dCwgZGV0YWlsLCBjYWxsYmFjaykgPT4ge1xuICAgICAgICAgICAgdGhpcy5fZGlhbG9nU2VydmljZS5vcGVuKHRoaXMudGVtcGxhdGVSZWYsIHtcbiAgICAgICAgICAgICAgICAuLi57IHRleHQsIGRldGFpbCwgY2FsbGJhY2sgfSxcbiAgICAgICAgICAgICAgICByZXNwb25zaXZlUGFkZGluZzogdHJ1ZVxuICAgICAgICAgICAgfSk7XG4gICAgICAgIH07XG4gICAgfVxuICAgIG9uQ2xvc2UoZGlhbG9nLCBkaWFsb2dDb25maWcpOiB2b2lkIHtcbiAgICAgICAgZGlhbG9nLmNsb3NlKCk7XG4gICAgICAgIGlmIChkaWFsb2dDb25maWcuY2FsbGJhY2spIHtcbiAgICAgICAgICAgIGRpYWxvZ0NvbmZpZy5jYWxsYmFjaygpO1xuICAgICAgICB9XG4gICAgfVxuICAgIG9uQ29udGludWUoZGlhbG9nLCBkaWFsb2dDb25maWcpOiB2b2lkIHtcbiAgICAgICAgZGlhbG9nLmNsb3NlKCk7XG4gICAgICAgIGlmIChkaWFsb2dDb25maWcuY2FsbGJhY2spIHtcbiAgICAgICAgICAgIGRpYWxvZ0NvbmZpZy5jYWxsYmFjaygpO1xuICAgICAgICB9XG4gICAgfVxuICAgIG9uQ29weShpbnB1dEVsOiBIVE1MSW5wdXRFbGVtZW50KTogdm9pZCB7XG4gICAgICAgIGNvbnN0IGNvcHlUZXh0ID0gaW5wdXRFbDtcbiAgICAgICAgLyogU2VsZWN0IHRoZSB0ZXh0IGZpZWxkICovXG4gICAgICAgIGNvcHlUZXh0LnNlbGVjdCgpO1xuICAgICAgICBjb3B5VGV4dC5zZXRTZWxlY3Rpb25SYW5nZSgwLCBpbnB1dEVsLnZhbHVlLmxlbmd0aCk7IC8qIEZvciBtb2JpbGUgZGV2aWNlcyAqL1xuICAgICAgICAvKiBDb3B5IHRoZSB0ZXh0IGluc2lkZSB0aGUgdGV4dCBmaWVsZCAqL1xuICAgICAgICBuYXZpZ2F0b3IuY2xpcGJvYXJkLndyaXRlVGV4dChjb3B5VGV4dC52YWx1ZSk7XG4gICAgfVxuICAgIG9uTG9nb3V0KGRpYWxvZywgZGlhbG9nQ29uZmlnKTogdm9pZCB7XG4gICAgICAgIGRpYWxvZy5jbG9zZSgpO1xuICAgICAgICBpZiAoZGlhbG9nQ29uZmlnLmNhbGxiYWNrKSB7XG4gICAgICAgICAgICBkaWFsb2dDb25maWcuY2FsbGJhY2soKTtcbiAgICAgICAgfVxuICAgICAgICBCYXJzYUFwaS5Cdy5Mb2dvdXQoKTtcbiAgICB9XG59XG4iLCI8bmctdGVtcGxhdGUgbGV0LWRpYWxvZyBsZXQtZGlhbG9nQ29uZmlnPVwiZGlhbG9nQ29uZmlnXCIgI3RlbXBsYXRlUmVmPlxyXG4gICAgPGZkLWRpYWxvZyBbZGlhbG9nQ29uZmlnXT1cImRpYWxvZ0NvbmZpZ1wiIFtkaWFsb2dSZWZdPVwiZGlhbG9nXCI+XHJcbiAgICAgICAgPGZkLWRpYWxvZy1oZWFkZXI+XHJcbiAgICAgICAgICAgIDxoMSBmZC10aXRsZT5cclxuICAgICAgICAgICAgICAgIHt7IGRpYWxvZ0NvbmZpZy50ZXh0IH19XHJcbiAgICAgICAgICAgIDwvaDE+XHJcblxyXG4gICAgICAgICAgICA8YnV0dG9uIGZkLWRpYWxvZy1jbG9zZS1idXR0b24gKGNsaWNrKT1cIm9uQ2xvc2UoZGlhbG9nLCBkaWFsb2dDb25maWcpXCI+PC9idXR0b24+XHJcbiAgICAgICAgPC9mZC1kaWFsb2ctaGVhZGVyPlxyXG5cclxuICAgICAgICA8ZmQtZGlhbG9nLWJvZHkgc3R5bGU9XCJwYWRkaW5nOiAxNXB4XCI+XHJcbiAgICAgICAgICAgIDxkaXYgc3R5bGU9XCJtaW4taGVpZ2h0OiAxMjVweFwiPlxyXG4gICAgICAgICAgICAgICAgPGxhYmVsIGZkLWxhYmVsIFtpbm5lckh0bWxdPVwiZGlhbG9nQ29uZmlnLmRldGFpbFwiPiA8L2xhYmVsPlxyXG4gICAgICAgICAgICA8L2Rpdj5cclxuICAgICAgICAgICAgPGlucHV0ICNpbnB1dEVsIHR5cGU9XCJ0ZXh0XCIgc3R5bGU9XCJkaXNwbGF5OiBub25lXCIgW3ZhbHVlXT1cImRpYWxvZ0NvbmZpZy5kZXRhaWxcIiAvPlxyXG4gICAgICAgIDwvZmQtZGlhbG9nLWJvZHk+XHJcblxyXG4gICAgICAgIDxmZC1kaWFsb2ctZm9vdGVyPlxyXG4gICAgICAgICAgICA8ZmQtZGlhbG9nLWZvb3Rlci1idXR0b24+XHJcbiAgICAgICAgICAgICAgICA8YnV0dG9uXHJcbiAgICAgICAgICAgICAgICAgICAgZmQtYnV0dG9uXHJcbiAgICAgICAgICAgICAgICAgICAgZmQtZGlhbG9nLWRlY2lzaXZlLWJ1dHRvblxyXG4gICAgICAgICAgICAgICAgICAgIFtmZFR5cGVdPVwiJ2VtcGhhc2l6ZWQnXCJcclxuICAgICAgICAgICAgICAgICAgICBbbGFiZWxdPVwiJ0NvbnRpbnVlJyB8IGJiYlRyYW5zbGF0ZVwiXHJcbiAgICAgICAgICAgICAgICAgICAgKGNsaWNrKT1cIm9uQ29udGludWUoZGlhbG9nLCBkaWFsb2dDb25maWcpXCJcclxuICAgICAgICAgICAgICAgID48L2J1dHRvbj5cclxuICAgICAgICAgICAgPC9mZC1kaWFsb2ctZm9vdGVyLWJ1dHRvbj5cclxuICAgICAgICAgICAgPGZkLWRpYWxvZy1mb290ZXItYnV0dG9uPlxyXG4gICAgICAgICAgICAgICAgPGJ1dHRvblxyXG4gICAgICAgICAgICAgICAgICAgIGZkLWJ1dHRvblxyXG4gICAgICAgICAgICAgICAgICAgIGZkLWRpYWxvZy1kZWNpc2l2ZS1idXR0b25cclxuICAgICAgICAgICAgICAgICAgICBbZmRUeXBlXT1cIidzdGFuZGFyZCdcIlxyXG4gICAgICAgICAgICAgICAgICAgIFtsYWJlbF09XCInQ29weScgfCBiYmJUcmFuc2xhdGVcIlxyXG4gICAgICAgICAgICAgICAgICAgIChjbGljayk9XCJvbkNvcHkoaW5wdXRFbClcIlxyXG4gICAgICAgICAgICAgICAgPjwvYnV0dG9uPlxyXG4gICAgICAgICAgICA8L2ZkLWRpYWxvZy1mb290ZXItYnV0dG9uPlxyXG4gICAgICAgICAgICA8ZmQtZGlhbG9nLWZvb3Rlci1idXR0b24+XHJcbiAgICAgICAgICAgICAgICA8YnV0dG9uXHJcbiAgICAgICAgICAgICAgICAgICAgZmQtYnV0dG9uXHJcbiAgICAgICAgICAgICAgICAgICAgZmQtZGlhbG9nLWRlY2lzaXZlLWJ1dHRvblxyXG4gICAgICAgICAgICAgICAgICAgIFtmZFR5cGVdPVwiJ25lZ2F0aXZlJ1wiXHJcbiAgICAgICAgICAgICAgICAgICAgW2xhYmVsXT1cIidMb2dvdXQnIHwgYmJiVHJhbnNsYXRlXCJcclxuICAgICAgICAgICAgICAgICAgICAoY2xpY2spPVwib25Mb2dvdXQoZGlhbG9nLCBkaWFsb2dDb25maWcpXCJcclxuICAgICAgICAgICAgICAgID48L2J1dHRvbj5cclxuICAgICAgICAgICAgPC9mZC1kaWFsb2ctZm9vdGVyLWJ1dHRvbj5cclxuICAgICAgICA8L2ZkLWRpYWxvZy1mb290ZXI+XHJcbiAgICA8L2ZkLWRpYWxvZz5cclxuPC9uZy10ZW1wbGF0ZT5cclxuIl19
61
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidWktZXhjZXB0aW9uLWZvcm0uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2Etc2FwLXVpL3NyYy9saWIvdWktZXhjZXB0aW9uLWZvcm0vdWktZXhjZXB0aW9uLWZvcm0uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2Etc2FwLXVpL3NyYy9saWIvdWktZXhjZXB0aW9uLWZvcm0vdWktZXhjZXB0aW9uLWZvcm0uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBdUIsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBR25HLE9BQU8sRUFBRSxhQUFhLEVBQUUsUUFBUSxFQUFFLE1BQU0sc0JBQXNCLENBQUM7Ozs7Ozs7QUFPL0QsTUFBTSxPQUFPLHdCQUF5QixTQUFRLGFBQWE7SUFFdkQsWUFBb0IsY0FBNkI7UUFDN0MsS0FBSyxFQUFFLENBQUM7UUFEUSxtQkFBYyxHQUFkLGNBQWMsQ0FBZTtJQUVqRCxDQUFDO0lBRUQsUUFBUTtRQUNKLEtBQUssQ0FBQyxRQUFRLEVBQUUsQ0FBQztRQUNqQixRQUFRLENBQUMsRUFBRSxDQUFDLGFBQWEsQ0FBQyxTQUFTLEdBQUcsSUFBSSxDQUFDO1FBQzNDLFFBQVEsQ0FBQyxFQUFFLENBQUMsYUFBYSxDQUFDLElBQUksR0FBRyxDQUFDLElBQUksRUFBRSxNQUFNLEVBQUUsUUFBUSxFQUFFLEVBQUU7WUFDeEQsSUFBSSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFdBQVcsRUFBRTtnQkFDdkMsR0FBRyxFQUFFLElBQUksRUFBRSxNQUFNLEVBQUUsUUFBUSxFQUFFO2dCQUM3QixpQkFBaUIsRUFBRSxJQUFJO2FBQzFCLENBQUMsQ0FBQztRQUNQLENBQUMsQ0FBQztJQUNOLENBQUM7SUFDRCxPQUFPLENBQUMsTUFBTSxFQUFFLFlBQVk7UUFDeEIsTUFBTSxDQUFDLEtBQUssRUFBRSxDQUFDO1FBQ2YsSUFBSSxZQUFZLENBQUMsUUFBUSxFQUFFO1lBQ3ZCLFlBQVksQ0FBQyxRQUFRLEVBQUUsQ0FBQztTQUMzQjtJQUNMLENBQUM7SUFDRCxVQUFVLENBQUMsTUFBTSxFQUFFLFlBQVk7UUFDM0IsTUFBTSxDQUFDLEtBQUssRUFBRSxDQUFDO1FBQ2YsSUFBSSxZQUFZLENBQUMsUUFBUSxFQUFFO1lBQ3ZCLFlBQVksQ0FBQyxRQUFRLEVBQUUsQ0FBQztTQUMzQjtJQUNMLENBQUM7SUFDRCxNQUFNLENBQUMsT0FBeUI7UUFDNUIsTUFBTSxRQUFRLEdBQUcsT0FBTyxDQUFDO1FBQ3pCLDJCQUEyQjtRQUMzQixRQUFRLENBQUMsTUFBTSxFQUFFLENBQUM7UUFDbEIsUUFBUSxDQUFDLGlCQUFpQixDQUFDLENBQUMsRUFBRSxPQUFPLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsd0JBQXdCO1FBQzdFLHlDQUF5QztRQUN6QyxTQUFTLENBQUMsU0FBUyxDQUFDLFNBQVMsQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDbEQsQ0FBQztJQUNELFFBQVEsQ0FBQyxNQUFNLEVBQUUsWUFBWTtRQUN6QixNQUFNLENBQUMsS0FBSyxFQUFFLENBQUM7UUFDZixJQUFJLFlBQVksQ0FBQyxRQUFRLEVBQUU7WUFDdkIsWUFBWSxDQUFDLFFBQVEsRUFBRSxDQUFDO1NBQzNCO1FBQ0QsUUFBUSxDQUFDLEVBQUUsQ0FBQyxNQUFNLEVBQUUsQ0FBQztJQUN6QixDQUFDOztxSEExQ1Esd0JBQXdCO3lHQUF4Qix3QkFBd0IsZ01DVnJDLHMrREFnREE7MkZEdENhLHdCQUF3QjtrQkFOcEMsU0FBUzsrQkFDSSx1QkFBdUIsbUJBR2hCLHVCQUF1QixDQUFDLE1BQU07b0dBR3JCLFdBQVc7c0JBQXBDLFNBQVM7dUJBQUMsYUFBYSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIE9uSW5pdCwgVGVtcGxhdGVSZWYsIFZpZXdDaGlsZCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBEaWFsb2dTZXJ2aWNlIH0gZnJvbSAnQGZ1bmRhbWVudGFsLW5neC9jb3JlJztcclxuXHJcbmltcG9ydCB7IEJhc2VDb21wb25lbnQsIEJhcnNhQXBpIH0gZnJvbSAnYmFyc2Etbm92aW4tcmF5LWNvcmUnO1xyXG5AQ29tcG9uZW50KHtcclxuICAgIHNlbGVjdG9yOiAnYnN1LXVpLWV4Y2VwdGlvbi1mb3JtJyxcclxuICAgIHRlbXBsYXRlVXJsOiAnLi91aS1leGNlcHRpb24tZm9ybS5jb21wb25lbnQuaHRtbCcsXHJcbiAgICBzdHlsZVVybHM6IFsnLi91aS1leGNlcHRpb24tZm9ybS5jb21wb25lbnQuc2NzcyddLFxyXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcclxufSlcclxuZXhwb3J0IGNsYXNzIFVpRXhjZXB0aW9uRm9ybUNvbXBvbmVudCBleHRlbmRzIEJhc2VDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xyXG4gICAgQFZpZXdDaGlsZCgndGVtcGxhdGVSZWYnKSB0ZW1wbGF0ZVJlZjogVGVtcGxhdGVSZWY8YW55PjtcclxuICAgIGNvbnN0cnVjdG9yKHByaXZhdGUgX2RpYWxvZ1NlcnZpY2U6IERpYWxvZ1NlcnZpY2UpIHtcclxuICAgICAgICBzdXBlcigpO1xyXG4gICAgfVxyXG5cclxuICAgIG5nT25Jbml0KCk6IHZvaWQge1xyXG4gICAgICAgIHN1cGVyLm5nT25Jbml0KCk7XHJcbiAgICAgICAgQmFyc2FBcGkuVWkuRXhjZXB0aW9uRm9ybS5Jc0hhbmRsZWQgPSB0cnVlO1xyXG4gICAgICAgIEJhcnNhQXBpLlVpLkV4Y2VwdGlvbkZvcm0uU2hvdyA9ICh0ZXh0LCBkZXRhaWwsIGNhbGxiYWNrKSA9PiB7XHJcbiAgICAgICAgICAgIHRoaXMuX2RpYWxvZ1NlcnZpY2Uub3Blbih0aGlzLnRlbXBsYXRlUmVmLCB7XHJcbiAgICAgICAgICAgICAgICAuLi57IHRleHQsIGRldGFpbCwgY2FsbGJhY2sgfSxcclxuICAgICAgICAgICAgICAgIHJlc3BvbnNpdmVQYWRkaW5nOiB0cnVlXHJcbiAgICAgICAgICAgIH0pO1xyXG4gICAgICAgIH07XHJcbiAgICB9XHJcbiAgICBvbkNsb3NlKGRpYWxvZywgZGlhbG9nQ29uZmlnKTogdm9pZCB7XHJcbiAgICAgICAgZGlhbG9nLmNsb3NlKCk7XHJcbiAgICAgICAgaWYgKGRpYWxvZ0NvbmZpZy5jYWxsYmFjaykge1xyXG4gICAgICAgICAgICBkaWFsb2dDb25maWcuY2FsbGJhY2soKTtcclxuICAgICAgICB9XHJcbiAgICB9XHJcbiAgICBvbkNvbnRpbnVlKGRpYWxvZywgZGlhbG9nQ29uZmlnKTogdm9pZCB7XHJcbiAgICAgICAgZGlhbG9nLmNsb3NlKCk7XHJcbiAgICAgICAgaWYgKGRpYWxvZ0NvbmZpZy5jYWxsYmFjaykge1xyXG4gICAgICAgICAgICBkaWFsb2dDb25maWcuY2FsbGJhY2soKTtcclxuICAgICAgICB9XHJcbiAgICB9XHJcbiAgICBvbkNvcHkoaW5wdXRFbDogSFRNTElucHV0RWxlbWVudCk6IHZvaWQge1xyXG4gICAgICAgIGNvbnN0IGNvcHlUZXh0ID0gaW5wdXRFbDtcclxuICAgICAgICAvKiBTZWxlY3QgdGhlIHRleHQgZmllbGQgKi9cclxuICAgICAgICBjb3B5VGV4dC5zZWxlY3QoKTtcclxuICAgICAgICBjb3B5VGV4dC5zZXRTZWxlY3Rpb25SYW5nZSgwLCBpbnB1dEVsLnZhbHVlLmxlbmd0aCk7IC8qIEZvciBtb2JpbGUgZGV2aWNlcyAqL1xyXG4gICAgICAgIC8qIENvcHkgdGhlIHRleHQgaW5zaWRlIHRoZSB0ZXh0IGZpZWxkICovXHJcbiAgICAgICAgbmF2aWdhdG9yLmNsaXBib2FyZC53cml0ZVRleHQoY29weVRleHQudmFsdWUpO1xyXG4gICAgfVxyXG4gICAgb25Mb2dvdXQoZGlhbG9nLCBkaWFsb2dDb25maWcpOiB2b2lkIHtcclxuICAgICAgICBkaWFsb2cuY2xvc2UoKTtcclxuICAgICAgICBpZiAoZGlhbG9nQ29uZmlnLmNhbGxiYWNrKSB7XHJcbiAgICAgICAgICAgIGRpYWxvZ0NvbmZpZy5jYWxsYmFjaygpO1xyXG4gICAgICAgIH1cclxuICAgICAgICBCYXJzYUFwaS5Cdy5Mb2dvdXQoKTtcclxuICAgIH1cclxufVxyXG4iLCI8bmctdGVtcGxhdGUgbGV0LWRpYWxvZyBsZXQtZGlhbG9nQ29uZmlnPVwiZGlhbG9nQ29uZmlnXCIgI3RlbXBsYXRlUmVmPlxyXG4gICAgPGZkLWRpYWxvZyBbZGlhbG9nQ29uZmlnXT1cImRpYWxvZ0NvbmZpZ1wiIFtkaWFsb2dSZWZdPVwiZGlhbG9nXCI+XHJcbiAgICAgICAgPGZkLWRpYWxvZy1oZWFkZXI+XHJcbiAgICAgICAgICAgIDxoMSBmZC10aXRsZT5cclxuICAgICAgICAgICAgICAgIHt7IGRpYWxvZ0NvbmZpZy50ZXh0IH19XHJcbiAgICAgICAgICAgIDwvaDE+XHJcblxyXG4gICAgICAgICAgICA8YnV0dG9uIGZkLWRpYWxvZy1jbG9zZS1idXR0b24gKGNsaWNrKT1cIm9uQ2xvc2UoZGlhbG9nLCBkaWFsb2dDb25maWcpXCI+PC9idXR0b24+XHJcbiAgICAgICAgPC9mZC1kaWFsb2ctaGVhZGVyPlxyXG5cclxuICAgICAgICA8ZmQtZGlhbG9nLWJvZHkgc3R5bGU9XCJwYWRkaW5nOiAxNXB4XCI+XHJcbiAgICAgICAgICAgIDxkaXYgc3R5bGU9XCJtaW4taGVpZ2h0OiAxMjVweFwiPlxyXG4gICAgICAgICAgICAgICAgPGxhYmVsIGZkLWxhYmVsIFtpbm5lckh0bWxdPVwiZGlhbG9nQ29uZmlnLmRldGFpbFwiPiA8L2xhYmVsPlxyXG4gICAgICAgICAgICA8L2Rpdj5cclxuICAgICAgICAgICAgPGlucHV0ICNpbnB1dEVsIHR5cGU9XCJ0ZXh0XCIgc3R5bGU9XCJkaXNwbGF5OiBub25lXCIgW3ZhbHVlXT1cImRpYWxvZ0NvbmZpZy5kZXRhaWxcIiAvPlxyXG4gICAgICAgIDwvZmQtZGlhbG9nLWJvZHk+XHJcblxyXG4gICAgICAgIDxmZC1kaWFsb2ctZm9vdGVyPlxyXG4gICAgICAgICAgICA8ZmQtZGlhbG9nLWZvb3Rlci1idXR0b24+XHJcbiAgICAgICAgICAgICAgICA8YnV0dG9uXHJcbiAgICAgICAgICAgICAgICAgICAgZmQtYnV0dG9uXHJcbiAgICAgICAgICAgICAgICAgICAgZmQtZGlhbG9nLWRlY2lzaXZlLWJ1dHRvblxyXG4gICAgICAgICAgICAgICAgICAgIFtmZFR5cGVdPVwiJ2VtcGhhc2l6ZWQnXCJcclxuICAgICAgICAgICAgICAgICAgICBbbGFiZWxdPVwiJ0NvbnRpbnVlJyB8IGJiYlRyYW5zbGF0ZVwiXHJcbiAgICAgICAgICAgICAgICAgICAgKGNsaWNrKT1cIm9uQ29udGludWUoZGlhbG9nLCBkaWFsb2dDb25maWcpXCJcclxuICAgICAgICAgICAgICAgID48L2J1dHRvbj5cclxuICAgICAgICAgICAgPC9mZC1kaWFsb2ctZm9vdGVyLWJ1dHRvbj5cclxuICAgICAgICAgICAgPGZkLWRpYWxvZy1mb290ZXItYnV0dG9uPlxyXG4gICAgICAgICAgICAgICAgPGJ1dHRvblxyXG4gICAgICAgICAgICAgICAgICAgIGZkLWJ1dHRvblxyXG4gICAgICAgICAgICAgICAgICAgIGZkLWRpYWxvZy1kZWNpc2l2ZS1idXR0b25cclxuICAgICAgICAgICAgICAgICAgICBbZmRUeXBlXT1cIidzdGFuZGFyZCdcIlxyXG4gICAgICAgICAgICAgICAgICAgIFtsYWJlbF09XCInQ29weScgfCBiYmJUcmFuc2xhdGVcIlxyXG4gICAgICAgICAgICAgICAgICAgIChjbGljayk9XCJvbkNvcHkoaW5wdXRFbClcIlxyXG4gICAgICAgICAgICAgICAgPjwvYnV0dG9uPlxyXG4gICAgICAgICAgICA8L2ZkLWRpYWxvZy1mb290ZXItYnV0dG9uPlxyXG4gICAgICAgICAgICA8ZmQtZGlhbG9nLWZvb3Rlci1idXR0b24+XHJcbiAgICAgICAgICAgICAgICA8YnV0dG9uXHJcbiAgICAgICAgICAgICAgICAgICAgZmQtYnV0dG9uXHJcbiAgICAgICAgICAgICAgICAgICAgZmQtZGlhbG9nLWRlY2lzaXZlLWJ1dHRvblxyXG4gICAgICAgICAgICAgICAgICAgIFtmZFR5cGVdPVwiJ25lZ2F0aXZlJ1wiXHJcbiAgICAgICAgICAgICAgICAgICAgW2xhYmVsXT1cIidMb2dvdXQnIHwgYmJiVHJhbnNsYXRlXCJcclxuICAgICAgICAgICAgICAgICAgICAoY2xpY2spPVwib25Mb2dvdXQoZGlhbG9nLCBkaWFsb2dDb25maWcpXCJcclxuICAgICAgICAgICAgICAgID48L2J1dHRvbj5cclxuICAgICAgICAgICAgPC9mZC1kaWFsb2ctZm9vdGVyLWJ1dHRvbj5cclxuICAgICAgICA8L2ZkLWRpYWxvZy1mb290ZXI+XHJcbiAgICA8L2ZkLWRpYWxvZz5cclxuPC9uZy10ZW1wbGF0ZT5cclxuIl19