barsa-sap-ui 0.0.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (346) hide show
  1. package/README.md +25 -0
  2. package/esm2020/barsa-sap-ui.mjs +5 -0
  3. package/esm2020/lib/apply-conditional-formmatings.directive.mjs +84 -0
  4. package/esm2020/lib/barsa-asp-viewer/barsa-asp-viewer.component.mjs +109 -0
  5. package/esm2020/lib/barsa-base-layout/barsa-base-layout.component.mjs +34 -0
  6. package/esm2020/lib/barsa-date-time-picker/barsa-date-time-picker.component.mjs +71 -0
  7. package/esm2020/lib/barsa-list-file-linear/barsa-list-file-linear.component.mjs +28 -0
  8. package/esm2020/lib/barsa-monaco-editor/barsa-monaco-editor.component.mjs +77 -0
  9. package/esm2020/lib/barsa-network-offline/barsa-network-offline.component.mjs +45 -0
  10. package/esm2020/lib/barsa-sap-ui-routing.module.mjs +17 -0
  11. package/esm2020/lib/barsa-sap-ui.module.mjs +277 -0
  12. package/esm2020/lib/barsa-search-form/barsa-search-form.component.mjs +29 -0
  13. package/esm2020/lib/barsa-table-header/barsa-table-header.component.mjs +122 -0
  14. package/esm2020/lib/barsa-table-row/barsa-table-row.component.mjs +57 -0
  15. package/esm2020/lib/barsa-tinyemce/barsa-tinyemce.component.mjs +334 -0
  16. package/esm2020/lib/barsa-tree-item/barsa-tree-item.component.mjs +120 -0
  17. package/esm2020/lib/barsa-tree-item/node-has-one-depth-level.pipe.mjs +19 -0
  18. package/esm2020/lib/barsa-ulv-main/barsa-ulv-main.component.mjs +156 -0
  19. package/esm2020/lib/breadcrumb/breadcrumb.component.mjs +45 -0
  20. package/esm2020/lib/captcha-field/captcha-field.component.mjs +28 -0
  21. package/esm2020/lib/card-item/card-item.component.mjs +60 -0
  22. package/esm2020/lib/card-view-content/card-view-content.component.mjs +23 -0
  23. package/esm2020/lib/col-renderer.directive.mjs +50 -0
  24. package/esm2020/lib/column-matrix-renderer/column-matrix-renderer.component.mjs +56 -0
  25. package/esm2020/lib/column-matrix-renderer/matrix-value.pipe.mjs +60 -0
  26. package/esm2020/lib/column-renderer/column-renderer.component.mjs +84 -0
  27. package/esm2020/lib/constants.mjs +413 -0
  28. package/esm2020/lib/custom-date-time/custom-date-time.component.mjs +41 -0
  29. package/esm2020/lib/device-info-field-base.mjs +23 -0
  30. package/esm2020/lib/dynamic-page-size.pipe.mjs +26 -0
  31. package/esm2020/lib/empty-page/empty-page.component.mjs +38 -0
  32. package/esm2020/lib/file-in-dialog/file-in-dialog.component.mjs +44 -0
  33. package/esm2020/lib/form-dialog/form-dialog.component.mjs +125 -0
  34. package/esm2020/lib/form-dialog-less/form-dialog-less.component.mjs +38 -0
  35. package/esm2020/lib/form-page/form-page.component.mjs +51 -0
  36. package/esm2020/lib/form-page-base.mjs +129 -0
  37. package/esm2020/lib/form-toolbar-button/form-toolbar-button.component.mjs +44 -0
  38. package/esm2020/lib/form-wizard/form-wizard.component.mjs +21 -0
  39. package/esm2020/lib/fullscreen-dialog.directive.mjs +40 -0
  40. package/esm2020/lib/fundamental-dynamic-form/fundamental-dynamic-form.component.mjs +152 -0
  41. package/esm2020/lib/gantt-dhtml-chart-view/gantt-dhtml-chart-view.component.mjs +203 -0
  42. package/esm2020/lib/global-search/global-search.component.mjs +26 -0
  43. package/esm2020/lib/global-search-module/global-search-module.component.mjs +30 -0
  44. package/esm2020/lib/global-search-panel/global-search-panel.component.mjs +30 -0
  45. package/esm2020/lib/header-avatar/header-avatar.component.mjs +19 -0
  46. package/esm2020/lib/header-facet-form/header-facet-form.component.mjs +22 -0
  47. package/esm2020/lib/header-facet-key-value/header-facet-key-value.component.mjs +31 -0
  48. package/esm2020/lib/header-facet-microchart/header-facet-microchart.component.mjs +21 -0
  49. package/esm2020/lib/header-facet-plain-text/header-facet-plain-text.component.mjs +28 -0
  50. package/esm2020/lib/header-facet-progress/header-facet-progress.component.mjs +26 -0
  51. package/esm2020/lib/header-facet-rate/header-facet-rate.component.mjs +26 -0
  52. package/esm2020/lib/htree-create-new/htree-create-new.component.mjs +49 -0
  53. package/esm2020/lib/hyperlink/hyperlink.component.mjs +19 -0
  54. package/esm2020/lib/index.mjs +412 -0
  55. package/esm2020/lib/inline-save-and-cancel/inline-save-and-cancel.component.mjs +32 -0
  56. package/esm2020/lib/layout-actions/layout-actions.component.mjs +65 -0
  57. package/esm2020/lib/layout-control/layout-control.component.mjs +214 -0
  58. package/esm2020/lib/layout-wizard/layout-wizard.component.mjs +133 -0
  59. package/esm2020/lib/list-item/list-item.component.mjs +30 -0
  60. package/esm2020/lib/ly-empty-space/ly-empty-space.component.mjs +37 -0
  61. package/esm2020/lib/ly-horizontal-layout/ly-horizontal-layout.component.mjs +70 -0
  62. package/esm2020/lib/ly-label/ly-label.component.mjs +31 -0
  63. package/esm2020/lib/ly-layout-container/ly-layout-container.component.mjs +83 -0
  64. package/esm2020/lib/ly-layout-container-of-root/ly-layout-container-of-root.component.mjs +17 -0
  65. package/esm2020/lib/ly-layout-field-label/ly-layout-field-label.component.mjs +24 -0
  66. package/esm2020/lib/ly-layout-panel/ly-layout-panel.component.mjs +64 -0
  67. package/esm2020/lib/ly-line/ly-line.component.mjs +56 -0
  68. package/esm2020/lib/ly-simple-label/ly-simple-label.component.mjs +27 -0
  69. package/esm2020/lib/ly-tab-container/ly-tab-container.component.mjs +43 -0
  70. package/esm2020/lib/ly-tab-page/ly-tab-page.component.mjs +35 -0
  71. package/esm2020/lib/ly-vertical-layout/ly-vertical-layout.component.mjs +49 -0
  72. package/esm2020/lib/manage-filters-report/manage-filters-report.component.mjs +45 -0
  73. package/esm2020/lib/mask/mask.component.mjs +22 -0
  74. package/esm2020/lib/message-strip/message-strip.component.mjs +28 -0
  75. package/esm2020/lib/models/grid-data-provider.mjs +219 -0
  76. package/esm2020/lib/models/grid-view.mjs +2 -0
  77. package/esm2020/lib/models/index.mjs +2 -0
  78. package/esm2020/lib/no-data/no-data.component.mjs +20 -0
  79. package/esm2020/lib/page-with-form-handler-base.mjs +42 -0
  80. package/esm2020/lib/page-with-header/page-with-header.component.mjs +76 -0
  81. package/esm2020/lib/progress-indicator/progress-indicator.component.mjs +18 -0
  82. package/esm2020/lib/report-navigator/report-navigator.component.mjs +62 -0
  83. package/esm2020/lib/report-new-top-form/report-new-top-form.component.mjs +60 -0
  84. package/esm2020/lib/report-search-fields-hidden-settings/report-search-fields-hidden-settings.component.mjs +35 -0
  85. package/esm2020/lib/report-search-fields-manage/report-search-fields-manage.component.mjs +99 -0
  86. package/esm2020/lib/report-search-panel-save/report-search-panel-save.component.mjs +90 -0
  87. package/esm2020/lib/report-tree-base.mjs +405 -0
  88. package/esm2020/lib/report-view-renderer.directive.mjs +248 -0
  89. package/esm2020/lib/responsive-toolbar/responsive-toolbar.component.mjs +50 -0
  90. package/esm2020/lib/responsive-toolbar-renderer/responsive-toolbar-renderer.component.mjs +84 -0
  91. package/esm2020/lib/rich-text-static/rich-text-static.component.mjs +35 -0
  92. package/esm2020/lib/sap-font-class.pipe.mjs +29 -0
  93. package/esm2020/lib/sap-font.pipe.mjs +29 -0
  94. package/esm2020/lib/sap-ui-report-base.component.mjs +689 -0
  95. package/esm2020/lib/search-panel/search-panel.component.mjs +40 -0
  96. package/esm2020/lib/static-text/static-text.component.mjs +15 -0
  97. package/esm2020/lib/title/title.component.mjs +15 -0
  98. package/esm2020/lib/ui-asp-report-viewer/ui-asp-report-viewer.component.mjs +14 -0
  99. package/esm2020/lib/ui-button/ui-button.component.mjs +31 -0
  100. package/esm2020/lib/ui-calendar/ui-calendar.component.mjs +46 -0
  101. package/esm2020/lib/ui-card-view/ui-card-view.component.mjs +60 -0
  102. package/esm2020/lib/ui-card-view-horizontal-group/ui-card-view-horizontal-group.component.mjs +27 -0
  103. package/esm2020/lib/ui-check-box/ui-check-box.component.mjs +29 -0
  104. package/esm2020/lib/ui-color-ui/ui-color-ui.component.mjs +50 -0
  105. package/esm2020/lib/ui-container-with-button/ui-container-with-button.component.mjs +34 -0
  106. package/esm2020/lib/ui-date-range-ex/ui-date-range-ex.component.mjs +194 -0
  107. package/esm2020/lib/ui-date-time/ui-date-time.component.mjs +116 -0
  108. package/esm2020/lib/ui-editable-grid/ui-editable-grid.component.mjs +110 -0
  109. package/esm2020/lib/ui-exception-form/ui-exception-form.component.mjs +61 -0
  110. package/esm2020/lib/ui-file-linear-list-box/ui-file-linear-list-box.component.mjs +181 -0
  111. package/esm2020/lib/ui-form-panel/ui-form-panel.component.mjs +43 -0
  112. package/esm2020/lib/ui-form-panel-toolbar/ui-form-panel-toolbar.component.mjs +26 -0
  113. package/esm2020/lib/ui-gantt-chart/ui-gantt-chart.component.mjs +32 -0
  114. package/esm2020/lib/ui-graph/ui-graph.component.mjs +16 -0
  115. package/esm2020/lib/ui-grid/ui-grid.component.mjs +25 -0
  116. package/esm2020/lib/ui-grid-columns/ui-grid-columns.component.mjs +44 -0
  117. package/esm2020/lib/ui-grid-filter-item/ui-grid-filter-item.component.mjs +67 -0
  118. package/esm2020/lib/ui-grid-filter-settings/ui-grid-filter-settings.component.mjs +76 -0
  119. package/esm2020/lib/ui-grid-sort-item/ui-grid-sort-item.component.mjs +59 -0
  120. package/esm2020/lib/ui-grid-sort-setting/ui-grid-sort-setting.component.mjs +156 -0
  121. package/esm2020/lib/ui-info-bar-panel/ui-info-bar-panel.component.mjs +11 -0
  122. package/esm2020/lib/ui-label/ui-label.component.mjs +12 -0
  123. package/esm2020/lib/ui-linear-list-container-with-button/ui-linear-list-container-with-button.component.mjs +299 -0
  124. package/esm2020/lib/ui-list-view/ui-list-view.component.mjs +44 -0
  125. package/esm2020/lib/ui-matrix-view/ui-matrix-view.component.mjs +125 -0
  126. package/esm2020/lib/ui-mo-info-combo-viewer/ui-mo-info-combo-viewer.component.mjs +19 -0
  127. package/esm2020/lib/ui-mo-info-general-object-ui/ui-mo-info-general-object-ui.component.mjs +13 -0
  128. package/esm2020/lib/ui-mo-info-sub-form-ui/ui-mo-info-sub-form-ui.component.mjs +46 -0
  129. package/esm2020/lib/ui-mo-info-ulv-combo/ui-mo-info-ulv-combo.component.mjs +335 -0
  130. package/esm2020/lib/ui-monaco-editor/ui-monaco-editor.component.mjs +18 -0
  131. package/esm2020/lib/ui-multi-select-combo/ui-multi-select-combo.component.mjs +83 -0
  132. package/esm2020/lib/ui-num-decimal-ui/ui-num-decimal-ui.component.mjs +24 -0
  133. package/esm2020/lib/ui-num-int-ui/ui-num-int-ui.component.mjs +21 -0
  134. package/esm2020/lib/ui-pdf-viewer/ui-pdf-viewer.component.mjs +216 -0
  135. package/esm2020/lib/ui-picture-file/ui-picture-file.component.mjs +95 -0
  136. package/esm2020/lib/ui-pictures-info/ui-pictures-info.component.mjs +215 -0
  137. package/esm2020/lib/ui-radio-group/ui-radio-group.component.mjs +24 -0
  138. package/esm2020/lib/ui-read-only-field/ui-read-only-field.component.mjs +29 -0
  139. package/esm2020/lib/ui-report-container/ui-report-container.component.mjs +46 -0
  140. package/esm2020/lib/ui-search-command-info-ui/ui-search-command-info-ui.component.mjs +24 -0
  141. package/esm2020/lib/ui-simple-combo/ui-simple-combo.component.mjs +29 -0
  142. package/esm2020/lib/ui-single-picture/ui-single-picture.component.mjs +36 -0
  143. package/esm2020/lib/ui-switch-button/ui-switch-button.component.mjs +20 -0
  144. package/esm2020/lib/ui-table-view/ui-table-view.component.mjs +106 -0
  145. package/esm2020/lib/ui-text-area/ui-text-area.component.mjs +44 -0
  146. package/esm2020/lib/ui-text-field/ui-text-field.component.mjs +47 -0
  147. package/esm2020/lib/ui-text-field-auto-complete/ui-text-field-auto-complete.component.mjs +47 -0
  148. package/esm2020/lib/ui-time-span/ui-time-span.component.mjs +24 -0
  149. package/esm2020/lib/ui-tinymce/ui-tinymce.component.mjs +53 -0
  150. package/esm2020/lib/ui-tree/ui-tree.component.mjs +69 -0
  151. package/esm2020/lib/ui-tree-view/ui-tree-view.component.mjs +75 -0
  152. package/esm2020/lib/ui-ulv-form-multi-select-ui/ui-ulv-form-multi-select-ui.component.mjs +24 -0
  153. package/esm2020/lib/ui-ulv-main-ui/ui-ulv-main-ui.component.mjs +276 -0
  154. package/esm2020/lib/ui-workflow-panel-ui/ui-workflow-panel-ui.component.mjs +26 -0
  155. package/esm2020/lib/ul-loading-mask-ui/ul-loading-mask-ui.component.mjs +86 -0
  156. package/esm2020/lib/ul-msg-box-adapter/ul-msg-box-adapter.component.mjs +117 -0
  157. package/esm2020/lib/ul-notify-popup/ul-notify-popup.component.mjs +114 -0
  158. package/esm2020/lib/ul-toast-adapter/ul-toast-adapter.component.mjs +44 -0
  159. package/esm2020/lib/ulv-column-settings/ulv-column-settings.component.mjs +53 -0
  160. package/esm2020/lib/ulv-context-menu/ulv-context-menu.component.mjs +74 -0
  161. package/esm2020/lib/ulv-filter-settings/ulv-filter-settings.component.mjs +43 -0
  162. package/esm2020/lib/ulv-form-multi-select/ulv-form-multi-select.component.mjs +183 -0
  163. package/esm2020/lib/ulv-groupby-settings/ulv-groupby-settings.component.mjs +44 -0
  164. package/esm2020/lib/ulv-paging/ulv-paging.component.mjs +73 -0
  165. package/esm2020/lib/ulv-selection/ulv-selection.component.mjs +66 -0
  166. package/esm2020/lib/ulv-settings/ulv-settings.component.mjs +117 -0
  167. package/esm2020/lib/ulv-sort-settings/ulv-sort-settings.component.mjs +44 -0
  168. package/esm2020/lib/ulv-toolbar/ulv-toolbar.component.mjs +110 -0
  169. package/esm2020/lib/upload-file-status.pipe.mjs +28 -0
  170. package/esm2020/lib/wizard-layout.directive.mjs +102 -0
  171. package/esm2020/public-api.mjs +170 -0
  172. package/fesm2015/barsa-sap-ui.mjs +11437 -0
  173. package/fesm2015/barsa-sap-ui.mjs.map +1 -0
  174. package/fesm2020/barsa-sap-ui.mjs +11427 -0
  175. package/fesm2020/barsa-sap-ui.mjs.map +1 -0
  176. package/index.d.ts +5 -0
  177. package/lib/apply-conditional-formmatings.directive.d.ts +25 -0
  178. package/lib/barsa-asp-viewer/barsa-asp-viewer.component.d.ts +26 -0
  179. package/lib/barsa-base-layout/barsa-base-layout.component.d.ts +18 -0
  180. package/lib/barsa-date-time-picker/barsa-date-time-picker.component.d.ts +18 -0
  181. package/lib/barsa-list-file-linear/barsa-list-file-linear.component.d.ts +8 -0
  182. package/lib/barsa-monaco-editor/barsa-monaco-editor.component.d.ts +18 -0
  183. package/lib/barsa-network-offline/barsa-network-offline.component.d.ts +13 -0
  184. package/lib/barsa-sap-ui-routing.module.d.ts +7 -0
  185. package/lib/barsa-sap-ui.module.d.ts +181 -0
  186. package/lib/barsa-search-form/barsa-search-form.component.d.ts +8 -0
  187. package/lib/barsa-table-header/barsa-table-header.component.d.ts +37 -0
  188. package/lib/barsa-table-row/barsa-table-row.component.d.ts +20 -0
  189. package/lib/barsa-tinyemce/barsa-tinyemce.component.d.ts +43 -0
  190. package/lib/barsa-tree-item/barsa-tree-item.component.d.ts +48 -0
  191. package/lib/barsa-tree-item/node-has-one-depth-level.pipe.d.ts +8 -0
  192. package/lib/barsa-ulv-main/barsa-ulv-main.component.d.ts +52 -0
  193. package/lib/breadcrumb/breadcrumb.component.d.ts +17 -0
  194. package/lib/captcha-field/captcha-field.component.d.ts +10 -0
  195. package/lib/card-item/card-item.component.d.ts +17 -0
  196. package/lib/card-view-content/card-view-content.component.d.ts +8 -0
  197. package/lib/col-renderer.directive.d.ts +12 -0
  198. package/lib/column-matrix-renderer/column-matrix-renderer.component.d.ts +23 -0
  199. package/lib/column-matrix-renderer/matrix-value.pipe.d.ts +8 -0
  200. package/lib/column-renderer/column-renderer.component.d.ts +29 -0
  201. package/lib/constants.d.ts +6 -0
  202. package/lib/custom-date-time/custom-date-time.component.d.ts +26 -0
  203. package/lib/device-info-field-base.d.ts +12 -0
  204. package/lib/dynamic-page-size.pipe.d.ts +8 -0
  205. package/lib/empty-page/empty-page.component.d.ts +11 -0
  206. package/lib/file-in-dialog/file-in-dialog.component.d.ts +16 -0
  207. package/lib/form-dialog/form-dialog.component.d.ts +40 -0
  208. package/lib/form-dialog-less/form-dialog-less.component.d.ts +27 -0
  209. package/lib/form-page/form-page.component.d.ts +17 -0
  210. package/lib/form-page-base.d.ts +26 -0
  211. package/lib/form-toolbar-button/form-toolbar-button.component.d.ts +18 -0
  212. package/lib/form-wizard/form-wizard.component.d.ts +8 -0
  213. package/lib/fullscreen-dialog.directive.d.ts +14 -0
  214. package/lib/fundamental-dynamic-form/fundamental-dynamic-form.component.d.ts +58 -0
  215. package/lib/gantt-dhtml-chart-view/gantt-dhtml-chart-view.component.d.ts +18 -0
  216. package/lib/global-search/global-search.component.d.ts +12 -0
  217. package/lib/global-search-module/global-search-module.component.d.ts +18 -0
  218. package/lib/global-search-panel/global-search-panel.component.d.ts +11 -0
  219. package/lib/header-avatar/header-avatar.component.d.ts +8 -0
  220. package/lib/header-facet-form/header-facet-form.component.d.ts +9 -0
  221. package/lib/header-facet-key-value/header-facet-key-value.component.d.ts +11 -0
  222. package/lib/header-facet-microchart/header-facet-microchart.component.d.ts +8 -0
  223. package/lib/header-facet-plain-text/header-facet-plain-text.component.d.ts +11 -0
  224. package/lib/header-facet-progress/header-facet-progress.component.d.ts +11 -0
  225. package/lib/header-facet-rate/header-facet-rate.component.d.ts +11 -0
  226. package/lib/htree-create-new/htree-create-new.component.d.ts +13 -0
  227. package/lib/hyperlink/hyperlink.component.d.ts +7 -0
  228. package/lib/index.d.ts +85 -0
  229. package/lib/inline-save-and-cancel/inline-save-and-cancel.component.d.ts +11 -0
  230. package/lib/layout-actions/layout-actions.component.d.ts +23 -0
  231. package/lib/layout-control/layout-control.component.d.ts +65 -0
  232. package/lib/layout-wizard/layout-wizard.component.d.ts +27 -0
  233. package/lib/list-item/list-item.component.d.ts +13 -0
  234. package/lib/ly-empty-space/ly-empty-space.component.d.ts +14 -0
  235. package/lib/ly-horizontal-layout/ly-horizontal-layout.component.d.ts +22 -0
  236. package/lib/ly-label/ly-label.component.d.ts +15 -0
  237. package/lib/ly-layout-container/ly-layout-container.component.d.ts +26 -0
  238. package/lib/ly-layout-container-of-root/ly-layout-container-of-root.component.d.ts +8 -0
  239. package/lib/ly-layout-field-label/ly-layout-field-label.component.d.ts +13 -0
  240. package/lib/ly-layout-panel/ly-layout-panel.component.d.ts +25 -0
  241. package/lib/ly-line/ly-line.component.d.ts +17 -0
  242. package/lib/ly-simple-label/ly-simple-label.component.d.ts +11 -0
  243. package/lib/ly-tab-container/ly-tab-container.component.d.ts +16 -0
  244. package/lib/ly-tab-page/ly-tab-page.component.d.ts +18 -0
  245. package/lib/ly-vertical-layout/ly-vertical-layout.component.d.ts +18 -0
  246. package/lib/manage-filters-report/manage-filters-report.component.d.ts +24 -0
  247. package/lib/mask/mask.component.d.ts +9 -0
  248. package/lib/message-strip/message-strip.component.d.ts +11 -0
  249. package/lib/models/grid-data-provider.d.ts +26 -0
  250. package/lib/models/grid-view.d.ts +64 -0
  251. package/lib/models/index.d.ts +1 -0
  252. package/lib/no-data/no-data.component.d.ts +8 -0
  253. package/lib/page-with-form-handler-base.d.ts +10 -0
  254. package/lib/page-with-header/page-with-header.component.d.ts +29 -0
  255. package/lib/progress-indicator/progress-indicator.component.d.ts +8 -0
  256. package/lib/report-navigator/report-navigator.component.d.ts +21 -0
  257. package/lib/report-new-top-form/report-new-top-form.component.d.ts +18 -0
  258. package/lib/report-search-fields-hidden-settings/report-search-fields-hidden-settings.component.d.ts +14 -0
  259. package/lib/report-search-fields-manage/report-search-fields-manage.component.d.ts +20 -0
  260. package/lib/report-search-panel-save/report-search-panel-save.component.d.ts +27 -0
  261. package/lib/report-tree-base.d.ts +61 -0
  262. package/lib/report-view-renderer.directive.d.ts +82 -0
  263. package/lib/responsive-toolbar/responsive-toolbar.component.d.ts +19 -0
  264. package/lib/responsive-toolbar-renderer/responsive-toolbar-renderer.component.d.ts +24 -0
  265. package/lib/rich-text-static/rich-text-static.component.d.ts +24 -0
  266. package/lib/sap-font-class.pipe.d.ts +8 -0
  267. package/lib/sap-font.pipe.d.ts +9 -0
  268. package/lib/sap-ui-report-base.component.d.ts +133 -0
  269. package/lib/search-panel/search-panel.component.d.ts +13 -0
  270. package/lib/static-text/static-text.component.d.ts +7 -0
  271. package/lib/title/title.component.d.ts +7 -0
  272. package/lib/ui-asp-report-viewer/ui-asp-report-viewer.component.d.ts +7 -0
  273. package/lib/ui-button/ui-button.component.d.ts +11 -0
  274. package/lib/ui-calendar/ui-calendar.component.d.ts +16 -0
  275. package/lib/ui-card-view/ui-card-view.component.d.ts +16 -0
  276. package/lib/ui-card-view-horizontal-group/ui-card-view-horizontal-group.component.d.ts +9 -0
  277. package/lib/ui-check-box/ui-check-box.component.d.ts +12 -0
  278. package/lib/ui-color-ui/ui-color-ui.component.d.ts +16 -0
  279. package/lib/ui-container-with-button/ui-container-with-button.component.d.ts +11 -0
  280. package/lib/ui-date-range-ex/ui-date-range-ex.component.d.ts +36 -0
  281. package/lib/ui-date-time/ui-date-time.component.d.ts +24 -0
  282. package/lib/ui-editable-grid/ui-editable-grid.component.d.ts +43 -0
  283. package/lib/ui-exception-form/ui-exception-form.component.d.ts +16 -0
  284. package/lib/ui-file-linear-list-box/ui-file-linear-list-box.component.d.ts +51 -0
  285. package/lib/ui-form-panel/ui-form-panel.component.d.ts +24 -0
  286. package/lib/ui-form-panel-toolbar/ui-form-panel-toolbar.component.d.ts +13 -0
  287. package/lib/ui-gantt-chart/ui-gantt-chart.component.d.ts +15 -0
  288. package/lib/ui-graph/ui-graph.component.d.ts +9 -0
  289. package/lib/ui-grid/ui-grid.component.d.ts +12 -0
  290. package/lib/ui-grid-columns/ui-grid-columns.component.d.ts +14 -0
  291. package/lib/ui-grid-filter-item/ui-grid-filter-item.component.d.ts +19 -0
  292. package/lib/ui-grid-filter-settings/ui-grid-filter-settings.component.d.ts +24 -0
  293. package/lib/ui-grid-sort-item/ui-grid-sort-item.component.d.ts +25 -0
  294. package/lib/ui-grid-sort-setting/ui-grid-sort-setting.component.d.ts +28 -0
  295. package/lib/ui-info-bar-panel/ui-info-bar-panel.component.d.ts +5 -0
  296. package/lib/ui-label/ui-label.component.d.ts +6 -0
  297. package/lib/ui-linear-list-container-with-button/ui-linear-list-container-with-button.component.d.ts +62 -0
  298. package/lib/ui-list-view/ui-list-view.component.d.ts +15 -0
  299. package/lib/ui-matrix-view/ui-matrix-view.component.d.ts +45 -0
  300. package/lib/ui-mo-info-combo-viewer/ui-mo-info-combo-viewer.component.d.ts +7 -0
  301. package/lib/ui-mo-info-general-object-ui/ui-mo-info-general-object-ui.component.d.ts +6 -0
  302. package/lib/ui-mo-info-sub-form-ui/ui-mo-info-sub-form-ui.component.d.ts +13 -0
  303. package/lib/ui-mo-info-ulv-combo/ui-mo-info-ulv-combo.component.d.ts +78 -0
  304. package/lib/ui-monaco-editor/ui-monaco-editor.component.d.ts +7 -0
  305. package/lib/ui-multi-select-combo/ui-multi-select-combo.component.d.ts +21 -0
  306. package/lib/ui-num-decimal-ui/ui-num-decimal-ui.component.d.ts +11 -0
  307. package/lib/ui-num-int-ui/ui-num-int-ui.component.d.ts +10 -0
  308. package/lib/ui-pdf-viewer/ui-pdf-viewer.component.d.ts +63 -0
  309. package/lib/ui-picture-file/ui-picture-file.component.d.ts +27 -0
  310. package/lib/ui-pictures-info/ui-pictures-info.component.d.ts +68 -0
  311. package/lib/ui-radio-group/ui-radio-group.component.d.ts +9 -0
  312. package/lib/ui-read-only-field/ui-read-only-field.component.d.ts +11 -0
  313. package/lib/ui-report-container/ui-report-container.component.d.ts +17 -0
  314. package/lib/ui-search-command-info-ui/ui-search-command-info-ui.component.d.ts +9 -0
  315. package/lib/ui-simple-combo/ui-simple-combo.component.d.ts +13 -0
  316. package/lib/ui-single-picture/ui-single-picture.component.d.ts +13 -0
  317. package/lib/ui-switch-button/ui-switch-button.component.d.ts +11 -0
  318. package/lib/ui-table-view/ui-table-view.component.d.ts +29 -0
  319. package/lib/ui-text-area/ui-text-area.component.d.ts +15 -0
  320. package/lib/ui-text-field/ui-text-field.component.d.ts +14 -0
  321. package/lib/ui-text-field-auto-complete/ui-text-field-auto-complete.component.d.ts +13 -0
  322. package/lib/ui-time-span/ui-time-span.component.d.ts +10 -0
  323. package/lib/ui-tinymce/ui-tinymce.component.d.ts +17 -0
  324. package/lib/ui-tree/ui-tree.component.d.ts +32 -0
  325. package/lib/ui-tree-view/ui-tree-view.component.d.ts +41 -0
  326. package/lib/ui-ulv-form-multi-select-ui/ui-ulv-form-multi-select-ui.component.d.ts +9 -0
  327. package/lib/ui-ulv-main-ui/ui-ulv-main-ui.component.d.ts +67 -0
  328. package/lib/ui-workflow-panel-ui/ui-workflow-panel-ui.component.d.ts +16 -0
  329. package/lib/ul-loading-mask-ui/ul-loading-mask-ui.component.d.ts +20 -0
  330. package/lib/ul-msg-box-adapter/ul-msg-box-adapter.component.d.ts +48 -0
  331. package/lib/ul-notify-popup/ul-notify-popup.component.d.ts +41 -0
  332. package/lib/ul-toast-adapter/ul-toast-adapter.component.d.ts +13 -0
  333. package/lib/ulv-column-settings/ulv-column-settings.component.d.ts +19 -0
  334. package/lib/ulv-context-menu/ulv-context-menu.component.d.ts +24 -0
  335. package/lib/ulv-filter-settings/ulv-filter-settings.component.d.ts +19 -0
  336. package/lib/ulv-form-multi-select/ulv-form-multi-select.component.d.ts +26 -0
  337. package/lib/ulv-groupby-settings/ulv-groupby-settings.component.d.ts +16 -0
  338. package/lib/ulv-paging/ulv-paging.component.d.ts +27 -0
  339. package/lib/ulv-selection/ulv-selection.component.d.ts +43 -0
  340. package/lib/ulv-settings/ulv-settings.component.d.ts +43 -0
  341. package/lib/ulv-sort-settings/ulv-sort-settings.component.d.ts +16 -0
  342. package/lib/ulv-toolbar/ulv-toolbar.component.d.ts +47 -0
  343. package/lib/upload-file-status.pipe.d.ts +9 -0
  344. package/lib/wizard-layout.directive.d.ts +39 -0
  345. package/package.json +31 -0
  346. package/public-api.d.ts +166 -0
@@ -0,0 +1,334 @@
1
+ import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from '@angular/core';
2
+ import { BaseComponent, BarsaApi, getUniqueId, isFunction } from 'barsa-novin-ray-core';
3
+ import * as i0 from "@angular/core";
4
+ export class BarsaTinyemceComponent extends BaseComponent {
5
+ constructor(_el) {
6
+ super();
7
+ this._el = _el;
8
+ this.valueChange = new EventEmitter();
9
+ this.tinyInit = new EventEmitter();
10
+ this.tinyHostId = getUniqueId(2);
11
+ this.tinyMCEConfig = {};
12
+ }
13
+ ngOnChanges(simpleChanges) {
14
+ super.ngOnChanges(simpleChanges);
15
+ if (simpleChanges.value && !simpleChanges.value.firstChange) {
16
+ this.setValue(simpleChanges.value.currentValue);
17
+ }
18
+ if (simpleChanges.disable && !simpleChanges.disable.firstChange) {
19
+ const disbale = simpleChanges.disable.currentValue;
20
+ if (disbale) {
21
+ this.setDisable();
22
+ }
23
+ else {
24
+ this.setEnable();
25
+ }
26
+ }
27
+ if (simpleChanges.readonly && !simpleChanges.readonly.firstChange) {
28
+ this.setReadOnly(simpleChanges.readonly.currentValue);
29
+ }
30
+ }
31
+ ngOnInit() {
32
+ super.ngOnInit();
33
+ this.height = this._el.nativeElement.clientHeight;
34
+ }
35
+ ngAfterViewInit() {
36
+ super.ngAfterViewInit();
37
+ this.loadTinyMce();
38
+ }
39
+ ngOnDestroy() {
40
+ super.ngOnDestroy();
41
+ this.destroyTinymce();
42
+ }
43
+ loadTinyMce() {
44
+ if (!this.Setting.IsHtmlViewer) {
45
+ head.load(['Lib/tinymce/tinymce.min.js'], () => {
46
+ this.prepare();
47
+ });
48
+ }
49
+ }
50
+ initilize() {
51
+ this.tinyMCEConfig.height = '100%';
52
+ this.tinyMCEConfig.width = '100%';
53
+ this.tinyMCEConfig.selector = '#' + this.tinyHostId;
54
+ this.tinyMCEConfig.skin = 'oxide';
55
+ this.tinyMCEConfig.content_css = 'assets/Resources/fonts/Iran.css';
56
+ this.tinyMCEConfig.directionality = 'rtl';
57
+ this.tinyMCEConfig.language = 'fa_IR';
58
+ this.tinyMCEConfig.menubar = false;
59
+ this.tinyMCEConfig.statusbar = false;
60
+ this.tinyMCEConfig.paste_data_images = true;
61
+ this.tinyMCEConfig.defaultFontName = 'BarsaFont';
62
+ this.tinyMCEConfig.defaultFontSize = '12px';
63
+ this.tinyMCEConfig.inline = true;
64
+ this.tinyMCEConfig.theme_advanced_resizing = true;
65
+ this.tinyMCEConfig.images_dataimg_filter = (img) => img.hasAttribute('internal-blob');
66
+ this.tinyMCEConfig.toolbar = true;
67
+ this.tinyMCEConfig.font_formats =
68
+ 'BarsaFont=BarsaFont;Arial=arial,helvetica,sans-serif; Courier New=courier new,courier,monospace;';
69
+ this.tinyMCEConfig.fontsize_formats = '8pt 10pt 12pt 14pt 18pt 24pt 36pt';
70
+ this.tinyMCEConfig.plugins = [
71
+ `print preview importcss searchreplace autolink autoresize autosave save directionality visualblocks visualchars fullscreen
72
+ link media template codesample table charmap hr pagebreak nonbreaking anchor toc insertdatetime advlist lists wordcount
73
+ imagetools textpattern noneditable help charmap quickbars emoticons`
74
+ ];
75
+ this.tinyMCEConfig.toolbar = `defaultVerbs barsaImage | insert | forecolor backcolor fontselect fontsizeselect | undo redo | copy cut paste
76
+ | formatselect | bold italic backcolor | alignleft aligncenter alignright alignjustify ltr rtl | bullist numlist outdent indent | removeformat`;
77
+ const tinymceSettingsGlobal = window.tinymceSettings;
78
+ let tinymceSettings = BarsaApi.Common.Util.TryGetValue(this.Setting, 'JsonExtraProp.tinymceSettings');
79
+ tinymceSettings = BarsaApi.Common.Merger.Merge(tinymceSettingsGlobal, tinymceSettings);
80
+ if (!tinymceSettings && Array.isArray(tinymceSettings)) {
81
+ for (const item of tinymceSettings) {
82
+ this.tinyMCEConfig[item.key] = item.value;
83
+ }
84
+ }
85
+ if (this.isReadonly) {
86
+ this.tinyMCEConfig.menubar = false;
87
+ this.tinyMCEConfig.statusbar = false;
88
+ this.tinyMCEConfig.plugins = ['autoresize'];
89
+ // this.tinyMCEConfig.plugins = [];
90
+ this.tinyMCEConfig.toolbar = false;
91
+ }
92
+ let userSetup;
93
+ if (this.tinyMCEConfig.setup) {
94
+ userSetup = this.tinyMCEConfig.setup;
95
+ }
96
+ const defaultVerbsMenu = [];
97
+ // BEGIN: setup
98
+ this.tinyMCEConfig.setup = (ed) => {
99
+ this.editor = ed;
100
+ if (!this.isReadonly) {
101
+ if (this.defaultVerbs) {
102
+ this.defaultVerbs.forEach((item) => {
103
+ defaultVerbsMenu.push({
104
+ value: item.Html,
105
+ type: 'menuitem',
106
+ text: item.Title || item.Html.replace(/<br\s*\/?>/gi, ' '),
107
+ onAction: () => {
108
+ ed.execCommand('mceInsertRawHTML', false, item.Html);
109
+ }
110
+ });
111
+ });
112
+ }
113
+ ed.ui.registry.addSplitButton('barsaImage', {
114
+ text: 'insert',
115
+ icon: 'image',
116
+ tooltip: 'Insert Image As Base64',
117
+ onAction: () => {
118
+ BarsaApi.Common.Async.Waterfall('Tinemce.EmbedImage', {
119
+ openFileDialog: this.ShowOpenFileDialog.bind(this),
120
+ insertBase64: this.InsertBase64.bind(this)
121
+ }, (err, result) => {
122
+ BarsaApi.Common.Async.Finalize(err, result);
123
+ });
124
+ },
125
+ onItemAction: () => {
126
+ BarsaApi.Common.Async.Waterfall('Tinemce.UploadToDatabase', {
127
+ openFileDialog: this.ShowUploadWindow.bind(this)
128
+ }, (err, result) => {
129
+ BarsaApi.Common.Async.Finalize(err, result);
130
+ });
131
+ },
132
+ fetch: (callback) => {
133
+ const items = [
134
+ {
135
+ type: 'choiceitem',
136
+ text: 'upload',
137
+ icon: 'image',
138
+ tooltip: 'Upload Image',
139
+ value: 'upload'
140
+ }
141
+ ];
142
+ callback(items);
143
+ }
144
+ });
145
+ ed.ui.registry.addMenuButton('defaultVerbs', {
146
+ text: 'عبارتهای پیش فرض',
147
+ fetch: (callback) => {
148
+ callback(defaultVerbsMenu);
149
+ }
150
+ });
151
+ if (isFunction(window.tinymceSetup)) {
152
+ window.tinymceSetup.call(this, this, ed);
153
+ }
154
+ }
155
+ let hasInit = false;
156
+ ed.on('init', () => {
157
+ this.wysiwygIntialized = true;
158
+ this.intializationInProgress = false;
159
+ if (typeof this.value !== 'undefined') {
160
+ this.setValue(this.value);
161
+ }
162
+ if (this.tinyMCEConfig.defaultFontName) {
163
+ ed.execCommand('FontName', false, this.tinyMCEConfig.defaultFontName);
164
+ }
165
+ if (this.tinyMCEConfig.defaultFontSize) {
166
+ ed.execCommand('FontSize', false, this.tinyMCEConfig.defaultFontSize);
167
+ }
168
+ if (this.isReadonly) {
169
+ this.setReadOnly(this.isReadonly);
170
+ }
171
+ // This piece of code solves the problem of change propagation so that
172
+ // there is no need to call triggerSave
173
+ const setContent = ed.setContent;
174
+ ed.setContent = (...args) => {
175
+ setContent.apply(ed, args);
176
+ ed.fire('change', {});
177
+ };
178
+ hasInit = true;
179
+ this.tinyInit.emit();
180
+ const iframEl = ed.iframeElement;
181
+ if (iframEl) {
182
+ iframEl.addEventListener('load', this._onLoadIframe.bind(this));
183
+ }
184
+ });
185
+ // Catch and propagate the change event
186
+ let oldContent = null;
187
+ ed.on('change keyup', () => {
188
+ const newval = ed.getContent();
189
+ if (newval === oldContent) {
190
+ return;
191
+ }
192
+ oldContent = newval;
193
+ if (!hasInit) {
194
+ return;
195
+ }
196
+ ed.save();
197
+ this.editorValue = newval;
198
+ this.valueChange.emit(newval);
199
+ // this.context.fireEvent('change', this, newval, oldval, {});
200
+ });
201
+ ed.on('focus', () => {
202
+ // TODO
203
+ });
204
+ if (userSetup) {
205
+ userSetup(ed);
206
+ }
207
+ };
208
+ }
209
+ ShowUploadWindow() { }
210
+ ShowOpenFileDialog(doReturn) {
211
+ const input = document.createElement('input');
212
+ input.setAttribute('type', 'file');
213
+ input.setAttribute('accept', 'image/*');
214
+ input.onchange = () => {
215
+ const file = input.files[0];
216
+ const reader = new FileReader();
217
+ reader.onload = () => {
218
+ let base64 = reader.result;
219
+ base64 = base64.split(',')[1];
220
+ doReturn(null, base64);
221
+ };
222
+ reader.readAsDataURL(file);
223
+ };
224
+ input.click();
225
+ }
226
+ InsertBase64(base64, doReturn) {
227
+ this.editor.execCommand('mceInsertRawHTML', false, '<img src=data:image/png;base64,' + base64 + ' />');
228
+ doReturn();
229
+ }
230
+ getValue() {
231
+ let res = null;
232
+ if (this.wysiwygIntialized) {
233
+ const ed = tinymce.get(this.tinyHostId);
234
+ if (ed) {
235
+ res = ed.getContent();
236
+ }
237
+ }
238
+ return res;
239
+ }
240
+ setValue(value) {
241
+ this.value = value;
242
+ this.setValueTiny();
243
+ }
244
+ setValueTiny() {
245
+ if (this.wysiwygIntialized) {
246
+ const ed = tinymce.get(this.tinyHostId);
247
+ if (ed) {
248
+ ed.setContent(this.value);
249
+ }
250
+ }
251
+ return this.value;
252
+ }
253
+ focus() {
254
+ if (this.isReadonly) {
255
+ return this;
256
+ }
257
+ if (this.wysiwygIntialized) {
258
+ tinymce.execCommand('mceFocus', false, 'id_of_textarea');
259
+ }
260
+ return this;
261
+ }
262
+ setEnable() {
263
+ if (this.wysiwygIntialized) {
264
+ const ed = tinymce.get(this.tinyHostId);
265
+ ed.getBody().setAttribute('contenteditable', true);
266
+ }
267
+ }
268
+ setDisable() {
269
+ if (this.wysiwygIntialized) {
270
+ const ed = tinymce.get(this.tinyHostId);
271
+ ed.getBody().setAttribute('contenteditable', false);
272
+ }
273
+ }
274
+ setReadOnly(readOnly) {
275
+ if (this.wysiwygIntialized) {
276
+ const ed = tinymce.get(this.tinyHostId);
277
+ ed.getBody().setAttribute('contenteditable', !readOnly);
278
+ if (readOnly) {
279
+ $('.tox-editor-header').hide();
280
+ }
281
+ else {
282
+ $('.tox-editor-header').hide();
283
+ }
284
+ }
285
+ }
286
+ destroyTinymce() {
287
+ if (this.Setting.IsHtmlViewer) {
288
+ return;
289
+ }
290
+ const ed = tinymce.get(this.tinyHostId);
291
+ if (ed) {
292
+ if (ed.iframeElement) {
293
+ ed.iframeElement.removeAllListeners();
294
+ }
295
+ ed.destroy(false);
296
+ }
297
+ }
298
+ prepare() {
299
+ this.initilize();
300
+ tinymce.init(this.tinyMCEConfig);
301
+ this.intializationInProgress = false;
302
+ this.wysiwygIntialized = true;
303
+ }
304
+ _onLoadIframe() {
305
+ this.value = this.editorValue;
306
+ // const ed = tinymce.get(this.tinyHostId);
307
+ // this._removeOverflow(ed);
308
+ // this.destroyTinymce();
309
+ // this.prepare();
310
+ }
311
+ _removeOverflow(ed) {
312
+ const html = ed.iframeElement?.contentDocument?.querySelector('html');
313
+ if (html) {
314
+ html.style.overflow = 'hidden';
315
+ }
316
+ }
317
+ }
318
+ BarsaTinyemceComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: BarsaTinyemceComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
319
+ BarsaTinyemceComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: BarsaTinyemceComponent, selector: "bsu-barsa-tinyemce", inputs: { Setting: "Setting", isReadonly: "isReadonly", value: "value" }, outputs: { valueChange: "valueChange", tinyInit: "tinyInit" }, usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div class=\"fd-input tinywrapper\" [style.min-height.px]=\"height\" [id]=\"tinyHostId\"></div>\n\n<!-- <textarea [id]=\"tinyHostId\" style=\"height: 100%; visibility: hidden\"></textarea> -->\n", styles: [":host{display:block;width:100%;height:100%}.tinywrapper{overflow:auto}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush });
320
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: BarsaTinyemceComponent, decorators: [{
321
+ type: Component,
322
+ args: [{ selector: 'bsu-barsa-tinyemce', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"fd-input tinywrapper\" [style.min-height.px]=\"height\" [id]=\"tinyHostId\"></div>\n\n<!-- <textarea [id]=\"tinyHostId\" style=\"height: 100%; visibility: hidden\"></textarea> -->\n", styles: [":host{display:block;width:100%;height:100%}.tinywrapper{overflow:auto}\n"] }]
323
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: { Setting: [{
324
+ type: Input
325
+ }], isReadonly: [{
326
+ type: Input
327
+ }], value: [{
328
+ type: Input
329
+ }], valueChange: [{
330
+ type: Output
331
+ }], tinyInit: [{
332
+ type: Output
333
+ }] } });
334
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"barsa-tinyemce.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-sap-ui/src/lib/barsa-tinyemce/barsa-tinyemce.component.ts","../../../../../projects/barsa-sap-ui/src/lib/barsa-tinyemce/barsa-tinyemce.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    Component,\n    ElementRef,\n    EventEmitter,\n    Input,\n    OnChanges,\n    OnDestroy,\n    Output,\n    SimpleChanges\n} from '@angular/core';\n\nimport { BaseComponent, BarsaApi, getUniqueId, isFunction } from 'barsa-novin-ray-core';\ndeclare const window: any;\ndeclare const tinymce: any;\ndeclare const head: any;\ndeclare const $: any;\n@Component({\n    selector: 'bsu-barsa-tinyemce',\n    templateUrl: './barsa-tinyemce.component.html',\n    styleUrls: ['./barsa-tinyemce.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class BarsaTinyemceComponent extends BaseComponent implements AfterViewInit, OnDestroy, OnChanges {\n    @Input() Setting: any;\n    @Input() isReadonly: boolean;\n    @Input() value: any;\n    @Output() valueChange = new EventEmitter<any>();\n    @Output() tinyInit = new EventEmitter();\n    tinyHostId = getUniqueId(2);\n    tinyMCEConfig: any = {};\n    editor: any;\n    defaultVerbs: any;\n    wysiwygIntialized: boolean;\n    intializationInProgress: boolean;\n    editorValue: string;\n\n    iframBodyInnerHtml: string;\n    height: number;\n\n    constructor(protected _el: ElementRef) {\n        super();\n    }\n    ngOnChanges(simpleChanges: SimpleChanges): void {\n        super.ngOnChanges(simpleChanges);\n        if (simpleChanges.value && !simpleChanges.value.firstChange) {\n            this.setValue(simpleChanges.value.currentValue);\n        }\n        if (simpleChanges.disable && !simpleChanges.disable.firstChange) {\n            const disbale = simpleChanges.disable.currentValue;\n            if (disbale) {\n                this.setDisable();\n            } else {\n                this.setEnable();\n            }\n        }\n        if (simpleChanges.readonly && !simpleChanges.readonly.firstChange) {\n            this.setReadOnly(simpleChanges.readonly.currentValue);\n        }\n    }\n    ngOnInit(): void {\n        super.ngOnInit();\n        this.height = (this._el.nativeElement as HTMLElement).clientHeight;\n    }\n\n    ngAfterViewInit(): void {\n        super.ngAfterViewInit();\n        this.loadTinyMce();\n    }\n    ngOnDestroy(): void {\n        super.ngOnDestroy();\n        this.destroyTinymce();\n    }\n    loadTinyMce(): void {\n        if (!this.Setting.IsHtmlViewer) {\n            head.load(['Lib/tinymce/tinymce.min.js'], () => {\n                this.prepare();\n            });\n        }\n    }\n\n    initilize(): void {\n        this.tinyMCEConfig.height = '100%';\n        this.tinyMCEConfig.width = '100%';\n        this.tinyMCEConfig.selector = '#' + this.tinyHostId;\n        this.tinyMCEConfig.skin = 'oxide';\n        this.tinyMCEConfig.content_css = 'assets/Resources/fonts/Iran.css';\n        this.tinyMCEConfig.directionality = 'rtl';\n        this.tinyMCEConfig.language = 'fa_IR';\n        this.tinyMCEConfig.menubar = false;\n        this.tinyMCEConfig.statusbar = false;\n        this.tinyMCEConfig.paste_data_images = true;\n        this.tinyMCEConfig.defaultFontName = 'BarsaFont';\n        this.tinyMCEConfig.defaultFontSize = '12px';\n        this.tinyMCEConfig.inline = true;\n        this.tinyMCEConfig.theme_advanced_resizing = true;\n        this.tinyMCEConfig.images_dataimg_filter = (img) => img.hasAttribute('internal-blob');\n        this.tinyMCEConfig.toolbar = true;\n        this.tinyMCEConfig.font_formats =\n            'BarsaFont=BarsaFont;Arial=arial,helvetica,sans-serif; Courier New=courier new,courier,monospace;';\n        this.tinyMCEConfig.fontsize_formats = '8pt 10pt 12pt 14pt 18pt 24pt 36pt';\n        this.tinyMCEConfig.plugins = [\n            `print preview importcss searchreplace autolink autoresize autosave save directionality visualblocks visualchars fullscreen \n            link media template codesample table charmap hr pagebreak nonbreaking anchor toc insertdatetime advlist lists wordcount \n            imagetools textpattern noneditable help charmap quickbars emoticons`\n        ];\n        this.tinyMCEConfig.toolbar = `defaultVerbs barsaImage | insert | forecolor backcolor fontselect fontsizeselect | undo redo | copy cut paste \n            | formatselect | bold italic backcolor  | alignleft aligncenter alignright alignjustify ltr rtl  | bullist numlist outdent indent | removeformat`;\n\n        const tinymceSettingsGlobal = window.tinymceSettings;\n        let tinymceSettings = BarsaApi.Common.Util.TryGetValue(this.Setting, 'JsonExtraProp.tinymceSettings');\n        tinymceSettings = BarsaApi.Common.Merger.Merge(tinymceSettingsGlobal, tinymceSettings);\n        if (!tinymceSettings && Array.isArray(tinymceSettings)) {\n            for (const item of tinymceSettings) {\n                this.tinyMCEConfig[item.key] = item.value;\n            }\n        }\n\n        if (this.isReadonly) {\n            this.tinyMCEConfig.menubar = false;\n            this.tinyMCEConfig.statusbar = false;\n            this.tinyMCEConfig.plugins = ['autoresize'];\n            // this.tinyMCEConfig.plugins = [];\n            this.tinyMCEConfig.toolbar = false;\n        }\n\n        let userSetup: (editor: any) => void;\n\n        if (this.tinyMCEConfig.setup) {\n            userSetup = this.tinyMCEConfig.setup;\n        }\n        const defaultVerbsMenu: any = [];\n        // BEGIN: setup\n        this.tinyMCEConfig.setup = (ed) => {\n            this.editor = ed;\n\n            if (!this.isReadonly) {\n                if (this.defaultVerbs) {\n                    this.defaultVerbs.forEach((item) => {\n                        defaultVerbsMenu.push({\n                            value: item.Html,\n                            type: 'menuitem',\n                            text: item.Title || item.Html.replace(/<br\\s*\\/?>/gi, ' '),\n                            onAction: () => {\n                                ed.execCommand('mceInsertRawHTML', false, item.Html);\n                            }\n                        });\n                    });\n                }\n                ed.ui.registry.addSplitButton('barsaImage', {\n                    text: 'insert',\n                    icon: 'image',\n                    tooltip: 'Insert Image As Base64',\n                    onAction: () => {\n                        BarsaApi.Common.Async.Waterfall(\n                            'Tinemce.EmbedImage',\n                            {\n                                openFileDialog: this.ShowOpenFileDialog.bind(this),\n                                insertBase64: this.InsertBase64.bind(this)\n                            },\n                            (err, result) => {\n                                BarsaApi.Common.Async.Finalize(err, result);\n                            }\n                        );\n                    },\n                    onItemAction: () => {\n                        BarsaApi.Common.Async.Waterfall(\n                            'Tinemce.UploadToDatabase',\n                            {\n                                openFileDialog: this.ShowUploadWindow.bind(this)\n                            },\n                            (err, result) => {\n                                BarsaApi.Common.Async.Finalize(err, result);\n                            }\n                        );\n                    },\n                    fetch: (callback) => {\n                        const items = [\n                            {\n                                type: 'choiceitem',\n                                text: 'upload',\n                                icon: 'image',\n                                tooltip: 'Upload Image',\n                                value: 'upload'\n                            }\n                        ];\n                        callback(items);\n                    }\n                });\n\n                ed.ui.registry.addMenuButton('defaultVerbs', {\n                    text: 'عبارتهای پیش فرض',\n                    fetch: (callback) => {\n                        callback(defaultVerbsMenu);\n                    }\n                });\n                if (isFunction(window.tinymceSetup)) {\n                    window.tinymceSetup.call(this, this, ed);\n                }\n            }\n            let hasInit = false;\n            ed.on('init', () => {\n                this.wysiwygIntialized = true;\n                this.intializationInProgress = false;\n                if (typeof this.value !== 'undefined') {\n                    this.setValue(this.value);\n                }\n                if (this.tinyMCEConfig.defaultFontName) {\n                    ed.execCommand('FontName', false, this.tinyMCEConfig.defaultFontName);\n                }\n                if (this.tinyMCEConfig.defaultFontSize) {\n                    ed.execCommand('FontSize', false, this.tinyMCEConfig.defaultFontSize);\n                }\n                if (this.isReadonly) {\n                    this.setReadOnly(this.isReadonly);\n                }\n                // This piece of code solves the problem of change propagation so that\n                // there is no need to call triggerSave\n                const setContent = ed.setContent;\n                ed.setContent = (...args) => {\n                    setContent.apply(ed, args);\n                    ed.fire('change', {});\n                };\n                hasInit = true;\n                this.tinyInit.emit();\n                const iframEl: HTMLIFrameElement = ed.iframeElement;\n                if (iframEl) {\n                    iframEl.addEventListener('load', this._onLoadIframe.bind(this));\n                }\n            });\n\n            // Catch and propagate the change event\n            let oldContent = null;\n            ed.on('change keyup', () => {\n                const newval = ed.getContent();\n                if (newval === oldContent) {\n                    return;\n                }\n\n                oldContent = newval;\n                if (!hasInit) {\n                    return;\n                }\n\n                ed.save();\n                this.editorValue = newval;\n                this.valueChange.emit(newval);\n                // this.context.fireEvent('change', this, newval, oldval, {});\n            });\n\n            ed.on('focus', () => {\n                // TODO\n            });\n\n            if (userSetup) {\n                userSetup(ed);\n            }\n        };\n    }\n\n    ShowUploadWindow(): void {}\n    ShowOpenFileDialog(doReturn): void {\n        const input: any = document.createElement('input');\n        input.setAttribute('type', 'file');\n        input.setAttribute('accept', 'image/*');\n\n        input.onchange = () => {\n            const file = input.files[0];\n\n            const reader = new FileReader();\n            reader.onload = () => {\n                let base64 = reader.result as string;\n                base64 = base64.split(',')[1];\n                doReturn(null, base64);\n            };\n            reader.readAsDataURL(file);\n        };\n\n        input.click();\n    }\n    InsertBase64(base64, doReturn): void {\n        this.editor.execCommand('mceInsertRawHTML', false, '<img src=data:image/png;base64,' + base64 + ' />');\n        doReturn();\n    }\n    getValue(): string | null {\n        let res = null;\n        if (this.wysiwygIntialized) {\n            const ed = tinymce.get(this.tinyHostId);\n            if (ed) {\n                res = ed.getContent();\n            }\n        }\n\n        return res;\n    }\n    setValue(value): void {\n        this.value = value;\n        this.setValueTiny();\n    }\n    setValueTiny(): string {\n        if (this.wysiwygIntialized) {\n            const ed = tinymce.get(this.tinyHostId);\n            if (ed) {\n                ed.setContent(this.value);\n            }\n        }\n        return this.value;\n    }\n    focus(): any {\n        if (this.isReadonly) {\n            return this;\n        }\n\n        if (this.wysiwygIntialized) {\n            tinymce.execCommand('mceFocus', false, 'id_of_textarea');\n        }\n        return this;\n    }\n\n    setEnable(): void {\n        if (this.wysiwygIntialized) {\n            const ed = tinymce.get(this.tinyHostId);\n            ed.getBody().setAttribute('contenteditable', true);\n        }\n    }\n\n    setDisable(): void {\n        if (this.wysiwygIntialized) {\n            const ed = tinymce.get(this.tinyHostId);\n            ed.getBody().setAttribute('contenteditable', false);\n        }\n    }\n    setReadOnly(readOnly): void {\n        if (this.wysiwygIntialized) {\n            const ed = tinymce.get(this.tinyHostId);\n            ed.getBody().setAttribute('contenteditable', !readOnly);\n            if (readOnly) {\n                $('.tox-editor-header').hide();\n            } else {\n                $('.tox-editor-header').hide();\n            }\n        }\n    }\n\n    destroyTinymce(): void {\n        if (this.Setting.IsHtmlViewer) {\n            return;\n        }\n        const ed = tinymce.get(this.tinyHostId);\n        if (ed) {\n            if (ed.iframeElement) {\n                ed.iframeElement.removeAllListeners();\n            }\n            ed.destroy(false);\n        }\n    }\n    private prepare(): void {\n        this.initilize();\n        tinymce.init(this.tinyMCEConfig);\n        this.intializationInProgress = false;\n        this.wysiwygIntialized = true;\n    }\n    private _onLoadIframe(): void {\n        this.value = this.editorValue;\n        // const ed = tinymce.get(this.tinyHostId);\n        // this._removeOverflow(ed);\n        // this.destroyTinymce();\n        // this.prepare();\n    }\n\n    private _removeOverflow(ed: any): void {\n        const html = ed.iframeElement?.contentDocument?.querySelector('html');\n        if (html) {\n            html.style.overflow = 'hidden';\n        }\n    }\n}\n","<div class=\"fd-input tinywrapper\" [style.min-height.px]=\"height\" [id]=\"tinyHostId\"></div>\n\n<!-- <textarea [id]=\"tinyHostId\" style=\"height: 100%; visibility: hidden\"></textarea> -->\n"]}
@@ -0,0 +1,120 @@
1
+ import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from '@angular/core';
2
+ import { BaseViewItemPropsComponent } from 'barsa-novin-ray-core';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "@angular/common";
5
+ import * as i2 from "@angular/cdk/drag-drop";
6
+ import * as i3 from "@fundamental-ngx/core/busy-indicator";
7
+ import * as i4 from "@fundamental-ngx/core/button";
8
+ import * as i5 from "@fundamental-ngx/core/icon";
9
+ import * as i6 from "@fundamental-ngx/core/list";
10
+ import * as i7 from "@fundamental-ngx/platform/button";
11
+ import * as i8 from "../ulv-context-menu/ulv-context-menu.component";
12
+ import * as i9 from "../htree-create-new/htree-create-new.component";
13
+ import * as i10 from "../apply-conditional-formmatings.directive";
14
+ export class BarsaTreeItemComponent extends BaseViewItemPropsComponent {
15
+ constructor() {
16
+ super(...arguments);
17
+ this.hasArrowIcon = true;
18
+ /* eslint-disable */
19
+ this.createNew = new EventEmitter();
20
+ this.select = new EventEmitter();
21
+ this.viewClick = new EventEmitter();
22
+ this.loadChildren = new EventEmitter();
23
+ this.dragMoved = new EventEmitter();
24
+ this.rowBtns = [
25
+ { Icon: 'add', Action: 'console.log("add btn clicked")' },
26
+ {
27
+ Icon: 'delete',
28
+ Action: 'console.log("delete btn clicked")'
29
+ }
30
+ ];
31
+ }
32
+ ngOnInit() {
33
+ super.ngOnInit();
34
+ if (!this.node.icon.startsWith('http')) {
35
+ this.hideIcon = true;
36
+ }
37
+ }
38
+ onListItemClick(liEl, e) {
39
+ if (e.target === liEl?.elementRef?.nativeElement) {
40
+ this.onRowCheck();
41
+ }
42
+ }
43
+ onRowCheck() {
44
+ this.select.emit({ node: this.node, index: this.index });
45
+ }
46
+ onUlvCommand() {
47
+ this.ulvCommand.emit({ mo: this.node.Data, index: this.index });
48
+ }
49
+ onNodeViewClick() {
50
+ this.viewClick.emit({ node: this.node.Data, index: this.index });
51
+ }
52
+ onLoadChildren(e) {
53
+ this.loadChildren.emit(this.node.Data);
54
+ e.stopPropagation();
55
+ e.preventDefault();
56
+ }
57
+ onExpandDblClick(e) {
58
+ e.stopPropagation();
59
+ e.preventDefault();
60
+ }
61
+ onCreateNew(e) {
62
+ if (!this.isChecked) {
63
+ this.onRowCheck();
64
+ }
65
+ this.createNew.emit(e);
66
+ }
67
+ onRowAction(commandBody) {
68
+ const command = new Function(commandBody);
69
+ command();
70
+ }
71
+ onDragMoved($event) {
72
+ if (this.isHetro) {
73
+ return;
74
+ }
75
+ this.dragMoved.emit($event);
76
+ }
77
+ }
78
+ BarsaTreeItemComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: BarsaTreeItemComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
79
+ BarsaTreeItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: BarsaTreeItemComponent, selector: "bsu-barsa-tree-item", inputs: { node: "node", selectedNode: "selectedNode", relationList: "relationList", hasDragDrop: "hasDragDrop", hasArrowIcon: "hasArrowIcon", collapseIcon: "collapseIcon", loading: "loading", hasChildren: "hasChildren", isExpand: "isExpand", children: "children", parentNode: "parentNode", text: "text", isHetro: "isHetro" }, outputs: { createNew: "createNew", select: "select", viewClick: "viewClick", loadChildren: "loadChildren", dragMoved: "dragMoved" }, usesInheritance: true, ngImport: i0, template: "<li\n fd-list-item\n #liEl\n [applyConditionalFormats]=\"conditionalFormats\"\n [mo]=\"node.Data\"\n [hostEl]=\"liEl\"\n [focusable]=\"true\"\n [attr.level]=\"level\"\n [class.root-group]=\"level === 1\"\n [selected]=\"isChecked\"\n (dblclick)=\"onNodeViewClick()\"\n cdkDrag\n [cdkDragData]=\"node.Data.Id\"\n (cdkDragMoved)=\"onDragMoved($event)\"\n (click)=\"onListItemClick(liEl, $event)\"\n>\n <div (click)=\"onRowCheck()\" class=\"spacer\" [style.width]=\"(level - 1) * 4 + 'rem'\"></div>\n <fd-icon *ngIf=\"hasDragDrop && !isHetro\" glyph=\"grip\" font=\"BusinessSuiteInAppSymbols\" cdkDragHandle></fd-icon>\n\n <div (click)=\"onRowCheck()\" style=\"display: flex; width: 100%; justify-content: space-between\">\n <div style=\"display: flex\">\n <ng-container *ngIf=\"hasArrowIcon\">\n <div class=\"arrow-container\" *ngIf=\"hasChildren; else emptyBtn\">\n <button\n [attr.rtl]=\"rtl\"\n fd-button\n fdType=\"transparent\"\n [glyph]=\"hasChildren ? (isExpand ? 'less' : collapseIcon) : ''\"\n (click)=\"onLoadChildren($event)\"\n (dblclick)=\"onExpandDblClick($event)\"\n ></button>\n </div>\n <fd-busy-indicator\n style=\"display: flex; align-items: center; width: 2rem\"\n *ngIf=\"loading\"\n size=\"s\"\n [loading]=\"true\"\n ></fd-busy-indicator>\n </ng-container>\n <div style=\"display: flex; flex: unset; align-items: center\" fd-list-title [focusable]=\"true\">\n <img\n *ngIf=\"!hideIcon\"\n [src]=\"node.icon\"\n [style.padding-right.px]=\"!rtl ? 5 : null\"\n [style.padding-left.px]=\"rtl ? 5 : null\"\n />\n <span>{{ text }}</span>\n <span *ngIf=\"children\">{{ ' ( ' + children.length + ' )' }}</span>\n </div>\n </div>\n <i\n *ngIf=\"contextMenuItems && contextMenuItems.length > 0\"\n ulvContextMenu\n [allColumns]=\"allColumns\"\n [menuItems]=\"contextMenuItems\"\n [conditionalFormats]=\"conditionalFormats\"\n [disableOverflowContextMenu]=\"disableOverflowContextMenu\"\n [mo]=\"node.Data\"\n [index]=\"index\"\n (commandClick)=\"onUlvCommand()\"\n [deviceName]=\"deviceName\"\n ></i>\n <bsu-htree-create-new\n *ngIf=\"access.Add !== false\"\n [node]=\"node\"\n [relationList]=\"relationList\"\n (createNew)=\"onCreateNew($event)\"\n ></bsu-htree-create-new>\n </div>\n <fdp-button\n *ngIf=\"access?.View && !showOkCancelButtons && deviceName !== 'desktop'\"\n [glyph]=\"navigationArrow\"\n buttonType=\"transparent\"\n (click)=\"onNodeViewClick()\"\n ></fdp-button>\n\n <bsu-barsa-tree-item\n *cdkDragPreview\n [node]=\"node\"\n [rtl]=\"rtl\"\n [selectedNode]=\"selectedNode\"\n [hasArrowIcon]=\"false\"\n ></bsu-barsa-tree-item>\n</li>\n<ng-template #emptyBtn>\n <div class=\"empty-container\" *ngIf=\"!parentNode?.hasOneDepthLevel\" (click)=\"onRowCheck()\">\n <button fd-button></button>\n </div>\n</ng-template>\n", styles: [":host{display:block}li{column-gap:8px}li .cdk-drag-handle{opacity:.5;cursor:move}li .spacer{height:100%}li .arrow-container,li .empty-container{display:flex;width:28px;align-items:center;justify-content:center}li .arrow-container fd-icon,li .empty-container fd-icon{cursor:pointer;width:100%;height:100%;text-align:center}li .arrow-container button[rtl=true],li .empty-container button[rtl=true]{margin-left:5px}li .arrow-container button[rtl=false],li .empty-container button[rtl=false]{margin-right:5px}li .empty-container{visibility:hidden!important}.cdk-drag{cursor:auto}.tree-icon-children{cursor:pointer}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }, { kind: "directive", type: i2.CdkDragHandle, selector: "[cdkDragHandle]", inputs: ["cdkDragHandleDisabled"] }, { kind: "directive", type: i2.CdkDragPreview, selector: "ng-template[cdkDragPreview]", inputs: ["data", "matchSize"] }, { kind: "component", type: i3.BusyIndicatorComponent, selector: "fd-busy-indicator", inputs: ["loading", "size", "block", "ariaLabel", "title", "label", "ariaLive"] }, { kind: "component", type: i4.ButtonComponent, selector: "button[fd-button], a[fd-button]", inputs: ["class"], exportAs: ["fd-button"] }, { kind: "component", type: i5.IconComponent, selector: "fd-icon", inputs: ["glyph", "font", "class", "ariaLabel"] }, { kind: "component", type: i6.ListItemComponent, selector: "[fdListItem] ,[fd-list-item]", inputs: ["selected", "ariaDescribedBy", "noData", "action", "interactive", "growing", "counter", "unread", "selectedListItemScreenReaderText", "navigatedListItemScreenReaderText", "navigatableListItemScreenReaderText"], outputs: ["keyDown"] }, { kind: "directive", type: i6.ListTitleDirective, selector: "[fd-list-title], [fdListTitle]", inputs: ["wrap"] }, { kind: "component", type: i7.ButtonComponent, selector: "fdp-button", inputs: ["glyphPosition", "label", "glyph", "buttonType", "title", "ariaSelected", "ariaDisabled", "ariaExpanded", "ariaControlsId", "ariaPressed", "name", "type", "value"], outputs: ["buttonClicked"] }, { kind: "component", type: i8.UlvContextMenuComponent, selector: "bsu-ulv-context-menu,[ulvContextMenu]", inputs: ["onlyOverflow", "deviceName", "menuItems", "allColumns", "index", "mo", "conditionalFormats", "disableOverflowContextMenu", "footerMode"], outputs: ["commandClick"] }, { kind: "component", type: BarsaTreeItemComponent, selector: "bsu-barsa-tree-item", inputs: ["node", "selectedNode", "relationList", "hasDragDrop", "hasArrowIcon", "collapseIcon", "loading", "hasChildren", "isExpand", "children", "parentNode", "text", "isHetro"], outputs: ["createNew", "select", "viewClick", "loadChildren", "dragMoved"] }, { kind: "component", type: i9.HtreeCreateNewComponent, selector: "bsu-htree-create-new", inputs: ["relationList", "node"], outputs: ["createNew"] }, { kind: "directive", type: i10.ApplyConditionalFormatsDirective, selector: "[applyConditionalFormats]", inputs: ["applyConditionalFormats", "mo", "hostEl", "dbName"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
80
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: BarsaTreeItemComponent, decorators: [{
81
+ type: Component,
82
+ args: [{ selector: 'bsu-barsa-tree-item', changeDetection: ChangeDetectionStrategy.OnPush, template: "<li\n fd-list-item\n #liEl\n [applyConditionalFormats]=\"conditionalFormats\"\n [mo]=\"node.Data\"\n [hostEl]=\"liEl\"\n [focusable]=\"true\"\n [attr.level]=\"level\"\n [class.root-group]=\"level === 1\"\n [selected]=\"isChecked\"\n (dblclick)=\"onNodeViewClick()\"\n cdkDrag\n [cdkDragData]=\"node.Data.Id\"\n (cdkDragMoved)=\"onDragMoved($event)\"\n (click)=\"onListItemClick(liEl, $event)\"\n>\n <div (click)=\"onRowCheck()\" class=\"spacer\" [style.width]=\"(level - 1) * 4 + 'rem'\"></div>\n <fd-icon *ngIf=\"hasDragDrop && !isHetro\" glyph=\"grip\" font=\"BusinessSuiteInAppSymbols\" cdkDragHandle></fd-icon>\n\n <div (click)=\"onRowCheck()\" style=\"display: flex; width: 100%; justify-content: space-between\">\n <div style=\"display: flex\">\n <ng-container *ngIf=\"hasArrowIcon\">\n <div class=\"arrow-container\" *ngIf=\"hasChildren; else emptyBtn\">\n <button\n [attr.rtl]=\"rtl\"\n fd-button\n fdType=\"transparent\"\n [glyph]=\"hasChildren ? (isExpand ? 'less' : collapseIcon) : ''\"\n (click)=\"onLoadChildren($event)\"\n (dblclick)=\"onExpandDblClick($event)\"\n ></button>\n </div>\n <fd-busy-indicator\n style=\"display: flex; align-items: center; width: 2rem\"\n *ngIf=\"loading\"\n size=\"s\"\n [loading]=\"true\"\n ></fd-busy-indicator>\n </ng-container>\n <div style=\"display: flex; flex: unset; align-items: center\" fd-list-title [focusable]=\"true\">\n <img\n *ngIf=\"!hideIcon\"\n [src]=\"node.icon\"\n [style.padding-right.px]=\"!rtl ? 5 : null\"\n [style.padding-left.px]=\"rtl ? 5 : null\"\n />\n <span>{{ text }}</span>\n <span *ngIf=\"children\">{{ ' ( ' + children.length + ' )' }}</span>\n </div>\n </div>\n <i\n *ngIf=\"contextMenuItems && contextMenuItems.length > 0\"\n ulvContextMenu\n [allColumns]=\"allColumns\"\n [menuItems]=\"contextMenuItems\"\n [conditionalFormats]=\"conditionalFormats\"\n [disableOverflowContextMenu]=\"disableOverflowContextMenu\"\n [mo]=\"node.Data\"\n [index]=\"index\"\n (commandClick)=\"onUlvCommand()\"\n [deviceName]=\"deviceName\"\n ></i>\n <bsu-htree-create-new\n *ngIf=\"access.Add !== false\"\n [node]=\"node\"\n [relationList]=\"relationList\"\n (createNew)=\"onCreateNew($event)\"\n ></bsu-htree-create-new>\n </div>\n <fdp-button\n *ngIf=\"access?.View && !showOkCancelButtons && deviceName !== 'desktop'\"\n [glyph]=\"navigationArrow\"\n buttonType=\"transparent\"\n (click)=\"onNodeViewClick()\"\n ></fdp-button>\n\n <bsu-barsa-tree-item\n *cdkDragPreview\n [node]=\"node\"\n [rtl]=\"rtl\"\n [selectedNode]=\"selectedNode\"\n [hasArrowIcon]=\"false\"\n ></bsu-barsa-tree-item>\n</li>\n<ng-template #emptyBtn>\n <div class=\"empty-container\" *ngIf=\"!parentNode?.hasOneDepthLevel\" (click)=\"onRowCheck()\">\n <button fd-button></button>\n </div>\n</ng-template>\n", styles: [":host{display:block}li{column-gap:8px}li .cdk-drag-handle{opacity:.5;cursor:move}li .spacer{height:100%}li .arrow-container,li .empty-container{display:flex;width:28px;align-items:center;justify-content:center}li .arrow-container fd-icon,li .empty-container fd-icon{cursor:pointer;width:100%;height:100%;text-align:center}li .arrow-container button[rtl=true],li .empty-container button[rtl=true]{margin-left:5px}li .arrow-container button[rtl=false],li .empty-container button[rtl=false]{margin-right:5px}li .empty-container{visibility:hidden!important}.cdk-drag{cursor:auto}.tree-icon-children{cursor:pointer}\n"] }]
83
+ }], propDecorators: { node: [{
84
+ type: Input
85
+ }], selectedNode: [{
86
+ type: Input
87
+ }], relationList: [{
88
+ type: Input
89
+ }], hasDragDrop: [{
90
+ type: Input
91
+ }], hasArrowIcon: [{
92
+ type: Input
93
+ }], collapseIcon: [{
94
+ type: Input
95
+ }], loading: [{
96
+ type: Input
97
+ }], hasChildren: [{
98
+ type: Input
99
+ }], isExpand: [{
100
+ type: Input
101
+ }], children: [{
102
+ type: Input
103
+ }], parentNode: [{
104
+ type: Input
105
+ }], text: [{
106
+ type: Input
107
+ }], isHetro: [{
108
+ type: Input
109
+ }], createNew: [{
110
+ type: Output
111
+ }], select: [{
112
+ type: Output
113
+ }], viewClick: [{
114
+ type: Output
115
+ }], loadChildren: [{
116
+ type: Output
117
+ }], dragMoved: [{
118
+ type: Output
119
+ }] } });
120
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"barsa-tree-item.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-sap-ui/src/lib/barsa-tree-item/barsa-tree-item.component.ts","../../../../../projects/barsa-sap-ui/src/lib/barsa-tree-item/barsa-tree-item.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAU,MAAM,EAAE,MAAM,eAAe,CAAC;AAGxG,OAAO,EAAsD,0BAA0B,EAAE,MAAM,sBAAsB,CAAC;;;;;;;;;;;;AAQtH,MAAM,OAAO,sBAAuB,SAAQ,0BAA0B;IANtE;;QAWa,iBAAY,GAAG,IAAI,CAAC;QAU7B,oBAAoB;QACV,cAAS,GAAG,IAAI,YAAY,EAAoB,CAAC;QACjD,WAAM,GAAG,IAAI,YAAY,EAG/B,CAAC;QAEK,cAAS,GAAG,IAAI,YAAY,EAGlC,CAAC;QACK,iBAAY,GAAG,IAAI,YAAY,EAAuB,CAAC;QACvD,cAAS,GAAG,IAAI,YAAY,EAAU,CAAC;QAGjD,YAAO,GAAG;YACN,EAAE,IAAI,EAAE,KAAK,EAAE,MAAM,EAAE,gCAAgC,EAAE;YACzD;gBACI,IAAI,EAAE,QAAQ;gBACd,MAAM,EAAE,mCAAmC;aAC9C;SACJ,CAAC;KAmDL;IAjDG,QAAQ;QACJ,KAAK,CAAC,QAAQ,EAAE,CAAC;QACjB,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,EAAE;YACpC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;SACxB;IACL,CAAC;IACD,eAAe,CAAC,IAAI,EAAE,CAAC;QACnB,IAAI,CAAC,CAAC,MAAM,KAAK,IAAI,EAAE,UAAU,EAAE,aAAa,EAAE;YAC9C,IAAI,CAAC,UAAU,EAAE,CAAC;SACrB;IACL,CAAC;IACD,UAAU;QACN,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,KAAK,EAAE,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC;IAC7D,CAAC;IAED,YAAY;QACR,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,EAAE,EAAE,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,KAAK,EAAE,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC;IACpE,CAAC;IAED,eAAe;QACX,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,KAAK,EAAE,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC;IACrE,CAAC;IAED,cAAc,CAAC,CAAC;QACZ,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACvC,CAAC,CAAC,eAAe,EAAE,CAAC;QACpB,CAAC,CAAC,cAAc,EAAE,CAAC;IACvB,CAAC;IAED,gBAAgB,CAAC,CAAC;QACd,CAAC,CAAC,eAAe,EAAE,CAAC;QACpB,CAAC,CAAC,cAAc,EAAE,CAAC;IACvB,CAAC;IACD,WAAW,CAAC,CAAC;QACT,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE;YACjB,IAAI,CAAC,UAAU,EAAE,CAAC;SACrB;QACD,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAC3B,CAAC;IACD,WAAW,CAAC,WAAmB;QAC3B,MAAM,OAAO,GAAG,IAAI,QAAQ,CAAC,WAAW,CAAC,CAAC;QAC1C,OAAO,EAAE,CAAC;IACd,CAAC;IACD,WAAW,CAAC,MAAM;QACd,IAAI,IAAI,CAAC,OAAO,EAAE;YACd,OAAO;SACV;QACD,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAChC,CAAC;;mHAtFQ,sBAAsB;uGAAtB,sBAAsB,6hBCXnC,u/GAyFA,i0FD9Ea,sBAAsB;2FAAtB,sBAAsB;kBANlC,SAAS;+BACI,qBAAqB,mBAGd,uBAAuB,CAAC,MAAM;8BAGtC,IAAI;sBAAZ,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,OAAO;sBAAf,KAAK;gBAGI,SAAS;sBAAlB,MAAM;gBACG,MAAM;sBAAf,MAAM;gBAKG,SAAS;sBAAlB,MAAM;gBAIG,YAAY;sBAArB,MAAM;gBACG,SAAS;sBAAlB,MAAM","sourcesContent":["import { ChangeDetectionStrategy, Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { Observable } from 'rxjs';\n\nimport { MetaobjectDataModel, TreeNodeObj, RelationItemType, BaseViewItemPropsComponent } from 'barsa-novin-ray-core';\n\n@Component({\n    selector: 'bsu-barsa-tree-item',\n    templateUrl: './barsa-tree-item.component.html',\n    styleUrls: ['./barsa-tree-item.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class BarsaTreeItemComponent extends BaseViewItemPropsComponent implements OnInit {\n    @Input() node: TreeNodeObj;\n    @Input() selectedNode: MetaobjectDataModel | null;\n    @Input() relationList: RelationItemType[];\n    @Input() hasDragDrop: boolean;\n    @Input() hasArrowIcon = true;\n    @Input() collapseIcon: string;\n    @Input() loading: boolean;\n    @Input() hasChildren: boolean;\n    @Input() isExpand: boolean;\n    @Input() children: TreeNodeObj[];\n    @Input() parentNode: TreeNodeObj;\n    @Input() text: string;\n    @Input() isHetro: boolean;\n\n    /* eslint-disable */\n    @Output() createNew = new EventEmitter<RelationItemType>();\n    @Output() select = new EventEmitter<{\n        node: TreeNodeObj;\n        index: number;\n    }>();\n\n    @Output() viewClick = new EventEmitter<{\n        node: MetaobjectDataModel;\n        index: number;\n    }>();\n    @Output() loadChildren = new EventEmitter<MetaobjectDataModel>();\n    @Output() dragMoved = new EventEmitter<string>();\n    icon$: Observable<string>;\n    hideIcon: boolean;\n    rowBtns = [\n        { Icon: 'add', Action: 'console.log(\"add btn clicked\")' },\n        {\n            Icon: 'delete',\n            Action: 'console.log(\"delete btn clicked\")'\n        }\n    ];\n\n    ngOnInit(): void {\n        super.ngOnInit();\n        if (!this.node.icon.startsWith('http')) {\n            this.hideIcon = true;\n        }\n    }\n    onListItemClick(liEl, e) {\n        if (e.target === liEl?.elementRef?.nativeElement) {\n            this.onRowCheck();\n        }\n    }\n    onRowCheck(): void {\n        this.select.emit({ node: this.node, index: this.index });\n    }\n\n    onUlvCommand(): void {\n        this.ulvCommand.emit({ mo: this.node.Data, index: this.index });\n    }\n\n    onNodeViewClick(): void {\n        this.viewClick.emit({ node: this.node.Data, index: this.index });\n    }\n\n    onLoadChildren(e): void {\n        this.loadChildren.emit(this.node.Data);\n        e.stopPropagation();\n        e.preventDefault();\n    }\n\n    onExpandDblClick(e): void {\n        e.stopPropagation();\n        e.preventDefault();\n    }\n    onCreateNew(e) {\n        if (!this.isChecked) {\n            this.onRowCheck();\n        }\n        this.createNew.emit(e);\n    }\n    onRowAction(commandBody: string): void {\n        const command = new Function(commandBody);\n        command();\n    }\n    onDragMoved($event): void {\n        if (this.isHetro) {\n            return;\n        }\n        this.dragMoved.emit($event);\n    }\n}\n","<li\n    fd-list-item\n    #liEl\n    [applyConditionalFormats]=\"conditionalFormats\"\n    [mo]=\"node.Data\"\n    [hostEl]=\"liEl\"\n    [focusable]=\"true\"\n    [attr.level]=\"level\"\n    [class.root-group]=\"level === 1\"\n    [selected]=\"isChecked\"\n    (dblclick)=\"onNodeViewClick()\"\n    cdkDrag\n    [cdkDragData]=\"node.Data.Id\"\n    (cdkDragMoved)=\"onDragMoved($event)\"\n    (click)=\"onListItemClick(liEl, $event)\"\n>\n    <div (click)=\"onRowCheck()\" class=\"spacer\" [style.width]=\"(level - 1) * 4 + 'rem'\"></div>\n    <fd-icon *ngIf=\"hasDragDrop && !isHetro\" glyph=\"grip\" font=\"BusinessSuiteInAppSymbols\" cdkDragHandle></fd-icon>\n\n    <div (click)=\"onRowCheck()\" style=\"display: flex; width: 100%; justify-content: space-between\">\n        <div style=\"display: flex\">\n            <ng-container *ngIf=\"hasArrowIcon\">\n                <div class=\"arrow-container\" *ngIf=\"hasChildren; else emptyBtn\">\n                    <button\n                        [attr.rtl]=\"rtl\"\n                        fd-button\n                        fdType=\"transparent\"\n                        [glyph]=\"hasChildren ? (isExpand ? 'less' : collapseIcon) : ''\"\n                        (click)=\"onLoadChildren($event)\"\n                        (dblclick)=\"onExpandDblClick($event)\"\n                    ></button>\n                </div>\n                <fd-busy-indicator\n                    style=\"display: flex; align-items: center; width: 2rem\"\n                    *ngIf=\"loading\"\n                    size=\"s\"\n                    [loading]=\"true\"\n                ></fd-busy-indicator>\n            </ng-container>\n            <div style=\"display: flex; flex: unset; align-items: center\" fd-list-title [focusable]=\"true\">\n                <img\n                    *ngIf=\"!hideIcon\"\n                    [src]=\"node.icon\"\n                    [style.padding-right.px]=\"!rtl ? 5 : null\"\n                    [style.padding-left.px]=\"rtl ? 5 : null\"\n                />\n                <span>{{ text }}</span>\n                <span *ngIf=\"children\">{{ ' ( ' + children.length + ' )' }}</span>\n            </div>\n        </div>\n        <i\n            *ngIf=\"contextMenuItems && contextMenuItems.length > 0\"\n            ulvContextMenu\n            [allColumns]=\"allColumns\"\n            [menuItems]=\"contextMenuItems\"\n            [conditionalFormats]=\"conditionalFormats\"\n            [disableOverflowContextMenu]=\"disableOverflowContextMenu\"\n            [mo]=\"node.Data\"\n            [index]=\"index\"\n            (commandClick)=\"onUlvCommand()\"\n            [deviceName]=\"deviceName\"\n        ></i>\n        <bsu-htree-create-new\n            *ngIf=\"access.Add !== false\"\n            [node]=\"node\"\n            [relationList]=\"relationList\"\n            (createNew)=\"onCreateNew($event)\"\n        ></bsu-htree-create-new>\n    </div>\n    <fdp-button\n        *ngIf=\"access?.View && !showOkCancelButtons && deviceName !== 'desktop'\"\n        [glyph]=\"navigationArrow\"\n        buttonType=\"transparent\"\n        (click)=\"onNodeViewClick()\"\n    ></fdp-button>\n\n    <bsu-barsa-tree-item\n        *cdkDragPreview\n        [node]=\"node\"\n        [rtl]=\"rtl\"\n        [selectedNode]=\"selectedNode\"\n        [hasArrowIcon]=\"false\"\n    ></bsu-barsa-tree-item>\n</li>\n<ng-template #emptyBtn>\n    <div class=\"empty-container\" *ngIf=\"!parentNode?.hasOneDepthLevel\" (click)=\"onRowCheck()\">\n        <button fd-button></button>\n    </div>\n</ng-template>\n"]}
@@ -0,0 +1,19 @@
1
+ import { Pipe } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class NodeHasOneDepthLevelPipe {
4
+ transform(node) {
5
+ let hasOneDepth = true;
6
+ node.children?.forEach((child) => (hasOneDepth = !(child.Data?.$HasChildren === true)));
7
+ return hasOneDepth;
8
+ }
9
+ }
10
+ NodeHasOneDepthLevelPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: NodeHasOneDepthLevelPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe });
11
+ NodeHasOneDepthLevelPipe.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "14.2.7", ngImport: i0, type: NodeHasOneDepthLevelPipe, name: "nodeHasOneDepthLevel" });
12
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: NodeHasOneDepthLevelPipe, decorators: [{
13
+ type: Pipe,
14
+ args: [{
15
+ name: 'nodeHasOneDepthLevel',
16
+ pure: true
17
+ }]
18
+ }] });
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9kZS1oYXMtb25lLWRlcHRoLWxldmVsLnBpcGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9iYXJzYS1zYXAtdWkvc3JjL2xpYi9iYXJzYS10cmVlLWl0ZW0vbm9kZS1oYXMtb25lLWRlcHRoLWxldmVsLnBpcGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLElBQUksRUFBaUIsTUFBTSxlQUFlLENBQUM7O0FBT3BELE1BQU0sT0FBTyx3QkFBd0I7SUFDakMsU0FBUyxDQUFDLElBQXlCO1FBQy9CLElBQUksV0FBVyxHQUFHLElBQUksQ0FBQztRQUN2QixJQUFJLENBQUMsUUFBUSxFQUFFLE9BQU8sQ0FBQyxDQUFDLEtBQTBCLEVBQUUsRUFBRSxDQUFDLENBQUMsV0FBVyxHQUFHLENBQUMsQ0FBQyxLQUFLLENBQUMsSUFBSSxFQUFFLFlBQVksS0FBSyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDN0csT0FBTyxXQUFXLENBQUM7SUFDdkIsQ0FBQzs7cUhBTFEsd0JBQXdCO21IQUF4Qix3QkFBd0I7MkZBQXhCLHdCQUF3QjtrQkFKcEMsSUFBSTttQkFBQztvQkFDRixJQUFJLEVBQUUsc0JBQXNCO29CQUM1QixJQUFJLEVBQUUsSUFBSTtpQkFDYiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBpcGUsIFBpcGVUcmFuc2Zvcm0gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgTWV0YW9iamVjdERhdGFNb2RlbCB9IGZyb20gJ2JhcnNhLW5vdmluLXJheS1jb3JlJztcclxuXHJcbkBQaXBlKHtcclxuICAgIG5hbWU6ICdub2RlSGFzT25lRGVwdGhMZXZlbCcsXHJcbiAgICBwdXJlOiB0cnVlXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBOb2RlSGFzT25lRGVwdGhMZXZlbFBpcGUgaW1wbGVtZW50cyBQaXBlVHJhbnNmb3JtIHtcclxuICAgIHRyYW5zZm9ybShub2RlOiBNZXRhb2JqZWN0RGF0YU1vZGVsKTogYm9vbGVhbiB7XHJcbiAgICAgICAgbGV0IGhhc09uZURlcHRoID0gdHJ1ZTtcclxuICAgICAgICBub2RlLmNoaWxkcmVuPy5mb3JFYWNoKChjaGlsZDogTWV0YW9iamVjdERhdGFNb2RlbCkgPT4gKGhhc09uZURlcHRoID0gIShjaGlsZC5EYXRhPy4kSGFzQ2hpbGRyZW4gPT09IHRydWUpKSk7XHJcbiAgICAgICAgcmV0dXJuIGhhc09uZURlcHRoO1xyXG4gICAgfVxyXG59XHJcbiJdfQ==