barsa-sap-ui 2.2.2 → 2.2.3

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 (241) hide show
  1. package/esm2022/barsa-sap-ui.mjs +5 -0
  2. package/esm2022/lib/apply-conditional-formmatings.directive.mjs +90 -0
  3. package/esm2022/lib/avatar-size.pipe.mjs +41 -0
  4. package/esm2022/lib/barsa-answer-card/barsa-answer-card.component.mjs +41 -0
  5. package/esm2022/lib/barsa-asp-viewer/barsa-asp-viewer.component.mjs +145 -0
  6. package/esm2022/lib/barsa-bar-download-file/barsa-bar-download-file.component.mjs +23 -0
  7. package/esm2022/lib/barsa-bar-panel/barsa-bar-panel.component.mjs +23 -0
  8. package/esm2022/lib/barsa-base-panel/barsa-base-layout-panel.component.mjs +29 -0
  9. package/esm2022/lib/barsa-breadcrumbs/barsa-breadcrumbs.component.mjs +24 -0
  10. package/esm2022/lib/barsa-card-layout-panel/barsa-card-layout-panel.component.mjs +24 -0
  11. package/esm2022/lib/barsa-card-row-payam/barsa-card-row-payam.component.mjs +31 -0
  12. package/esm2022/lib/barsa-cartable-form/barsa-cartable-form.component.mjs +41 -0
  13. package/esm2022/lib/barsa-cartable-template/barsa-cartable-template.component.mjs +24 -0
  14. package/esm2022/lib/barsa-chat/barsa-chat.component.mjs +242 -0
  15. package/esm2022/lib/barsa-chat/chat.model.mjs +8 -0
  16. package/esm2022/lib/barsa-chat-content/barsa-chat-content.component.mjs +13 -0
  17. package/esm2022/lib/barsa-chat-content-toolbar/barsa-chat-content-toolbar.component.mjs +22 -0
  18. package/esm2022/lib/barsa-chat-list/barsa-chat-list.component.mjs +66 -0
  19. package/esm2022/lib/barsa-chat-message/barsa-chat-message.component.mjs +78 -0
  20. package/esm2022/lib/barsa-chat-thread/barsa-chat-thread.component.mjs +22 -0
  21. package/esm2022/lib/barsa-chat-threads-list/barsa-chat-threads-list.component.mjs +13 -0
  22. package/esm2022/lib/barsa-chat-threads-list-toolbar/barsa-chat-threads-list-toolbar.component.mjs +15 -0
  23. package/esm2022/lib/barsa-chip/barsa-chip.component.mjs +72 -0
  24. package/esm2022/lib/barsa-column-indicator/barsa-column-indicator.component.mjs +23 -0
  25. package/esm2022/lib/barsa-column-rownumber/barsa-column-rownumber.component.mjs +14 -0
  26. package/esm2022/lib/barsa-custom-inline-edit/barsa-custom-inline-edit.component.mjs +14 -0
  27. package/esm2022/lib/barsa-custom-inline-edit-row/barsa-custom-inline-edit-row.component.mjs +26 -0
  28. package/esm2022/lib/barsa-date-time-picker/barsa-date-time-picker.component.mjs +71 -0
  29. package/esm2022/lib/barsa-dynamic-field/barsa-dynamic-field.component.mjs +40 -0
  30. package/esm2022/lib/barsa-enum-menu-button/barsa-enum-menu-button.component.mjs +61 -0
  31. package/esm2022/lib/barsa-field-key-value/barsa-field-key-value.component.mjs +45 -0
  32. package/esm2022/lib/barsa-form-side-content/barsa-form-side-content.component.mjs +58 -0
  33. package/esm2022/lib/barsa-grid-layout-panel/barsa-grid-layout-panel.component.mjs +27 -0
  34. package/esm2022/lib/barsa-group-cartable/barsa-cartable-group.component.mjs +94 -0
  35. package/esm2022/lib/barsa-horizontal-flex-panel/barsa-horizontal-flex-panel.component.mjs +22 -0
  36. package/esm2022/lib/barsa-linkable-items-panel/barsa-linkable-items-panel.component.mjs +37 -0
  37. package/esm2022/lib/barsa-list-file-linear/barsa-list-file-linear.component.mjs +41 -0
  38. package/esm2022/lib/barsa-list-file-linear-gmail/barsa-list-file-linear-gmail.component.mjs +29 -0
  39. package/esm2022/lib/barsa-list-layout-panel/barsa-list-layout-panel.component.mjs +23 -0
  40. package/esm2022/lib/barsa-modal/barsa-modal.component.mjs +43 -0
  41. package/esm2022/lib/barsa-monaco-editor/barsa-monaco-editor.component.mjs +83 -0
  42. package/esm2022/lib/barsa-network-offline/barsa-network-offline.component.mjs +57 -0
  43. package/esm2022/lib/barsa-pishnamayesh-payam/barsa-pishnamayesh-payam.component.mjs +159 -0
  44. package/esm2022/lib/barsa-question-answer-comments-section/barsa-question-answer-comments-section.component.mjs +17 -0
  45. package/esm2022/lib/barsa-question-answer-content-actions-section/barsa-question-answer-content-actions-section.component.mjs +30 -0
  46. package/esm2022/lib/barsa-question-answer-creator-time-section/barsa-question-answer-creator-time-section.component.mjs +14 -0
  47. package/esm2022/lib/barsa-question-answer-form/barsa-question-answer-form.component.mjs +34 -0
  48. package/esm2022/lib/barsa-question-answer-form-add-comment/barsa-question-answer-form-add-comment.component.mjs +46 -0
  49. package/esm2022/lib/barsa-question-answer-vote-section/barsa-question-answer-vote-section.component.mjs +79 -0
  50. package/esm2022/lib/barsa-question-post/barsa-question-post.component.mjs +30 -0
  51. package/esm2022/lib/barsa-report-card-flex-view/barsa-report-card-flex-view.component.mjs +31 -0
  52. package/esm2022/lib/barsa-report-checkbox-switch-button/barsa-report-checkbox-switch-button.component.mjs +28 -0
  53. package/esm2022/lib/barsa-report-one-of-list/barsa-report-one-of-list.component.mjs +102 -0
  54. package/esm2022/lib/barsa-row-inline-actionlist/barsa-row-inline-actionlist.component.mjs +26 -0
  55. package/esm2022/lib/barsa-sap-ui-routing.module.mjs +18 -0
  56. package/esm2022/lib/barsa-sap-ui.module.mjs +377 -0
  57. package/esm2022/lib/barsa-search-form/barsa-search-form.component.mjs +29 -0
  58. package/esm2022/lib/barsa-simple-form/barsa-simple-form.component.mjs +170 -0
  59. package/esm2022/lib/barsa-tab-route-manager/barsa-tab-route-manager.component.mjs +18 -0
  60. package/esm2022/lib/barsa-table-column/barsa-table-column.component.mjs +29 -0
  61. package/esm2022/lib/barsa-table-header/barsa-table-header.component.mjs +222 -0
  62. package/esm2022/lib/barsa-table-row/barsa-table-row.component.mjs +87 -0
  63. package/esm2022/lib/barsa-tag-categories/barsa-tag-categories.component.mjs +60 -0
  64. package/esm2022/lib/barsa-tag-chip/barsa-tag-chip.component.mjs +26 -0
  65. package/esm2022/lib/barsa-tags-category-row/barsa-tags-category-row.component.mjs +23 -0
  66. package/esm2022/lib/barsa-text-ellipsis/barsa-text-ellipsis.component.mjs +37 -0
  67. package/esm2022/lib/barsa-tinyemce/barsa-tinyemce.component.mjs +418 -0
  68. package/esm2022/lib/barsa-toolbaritem-search/barsa-toolbaritem-search.component.mjs +36 -0
  69. package/esm2022/lib/barsa-tree-item/barsa-tree-item.component.mjs +153 -0
  70. package/esm2022/lib/barsa-tree-item/node-has-one-depth-level.pipe.mjs +20 -0
  71. package/esm2022/lib/barsa-ulv-main/barsa-ulv-main.component.mjs +216 -0
  72. package/esm2022/lib/blob-viewer/blob-viewer.component.mjs +74 -0
  73. package/esm2022/lib/breadcrumb/breadcrumb.component.mjs +50 -0
  74. package/esm2022/lib/captcha-field/captcha-field.component.mjs +28 -0
  75. package/esm2022/lib/card-item/card-item.component.mjs +74 -0
  76. package/esm2022/lib/card-view-content/card-view-content.component.mjs +46 -0
  77. package/esm2022/lib/col-renderer.directive.mjs +47 -0
  78. package/esm2022/lib/column-matrix-renderer/column-matrix-renderer.component.mjs +56 -0
  79. package/esm2022/lib/column-matrix-renderer/matrix-value.pipe.mjs +61 -0
  80. package/esm2022/lib/column-renderer/column-renderer.component.mjs +97 -0
  81. package/esm2022/lib/constants.mjs +450 -0
  82. package/esm2022/lib/custom-date-time/custom-date-time.component.mjs +41 -0
  83. package/esm2022/lib/device-info-field-base.mjs +24 -0
  84. package/esm2022/lib/dialog-handler.directive.mjs +29 -0
  85. package/esm2022/lib/download-files.directive.mjs +34 -0
  86. package/esm2022/lib/dynamic-page-size.pipe.mjs +27 -0
  87. package/esm2022/lib/file-in-dialog/file-in-dialog.component.mjs +44 -0
  88. package/esm2022/lib/file-viewer/file-viewer.component.mjs +47 -0
  89. package/esm2022/lib/file-viewer-content/file-viewer-content.component.mjs +71 -0
  90. package/esm2022/lib/file-viewer-popover/file-viewer-popover.component.mjs +37 -0
  91. package/esm2022/lib/form-dialog/form-dialog.component.mjs +171 -0
  92. package/esm2022/lib/form-dialog-less/form-dialog-less.component.mjs +50 -0
  93. package/esm2022/lib/form-toolbar/form-toolbar.component.mjs +62 -0
  94. package/esm2022/lib/form-toolbar-button/form-toolbar-button.component.mjs +45 -0
  95. package/esm2022/lib/form-wizard/form-wizard.component.mjs +21 -0
  96. package/esm2022/lib/fullscreen-dialog.directive.mjs +60 -0
  97. package/esm2022/lib/fullscreen-files.directive.mjs +43 -0
  98. package/esm2022/lib/fundamental-dynamic-form/fundamental-dynamic-form.component.mjs +217 -0
  99. package/esm2022/lib/gantt-dhtml-chart-view/gantt-dhtml-chart-view.component.mjs +215 -0
  100. package/esm2022/lib/global-search/global-search.component.mjs +27 -0
  101. package/esm2022/lib/global-search-module/global-search-module.component.mjs +29 -0
  102. package/esm2022/lib/global-search-panel/global-search-panel.component.mjs +25 -0
  103. package/esm2022/lib/header-avatar/header-avatar.component.mjs +18 -0
  104. package/esm2022/lib/htree-create-new/htree-create-new.component.mjs +48 -0
  105. package/esm2022/lib/hyperlink/hyperlink.component.mjs +23 -0
  106. package/esm2022/lib/index.mjs +549 -0
  107. package/esm2022/lib/inline-save-and-cancel/inline-save-and-cancel.component.mjs +32 -0
  108. package/esm2022/lib/layout-actions/layout-actions.component.mjs +70 -0
  109. package/esm2022/lib/layout-control/layout-control.component.mjs +302 -0
  110. package/esm2022/lib/layout-wizard/layout-wizard.component.mjs +180 -0
  111. package/esm2022/lib/list-item/list-item.component.mjs +34 -0
  112. package/esm2022/lib/ly-empty-space/ly-empty-space.component.mjs +42 -0
  113. package/esm2022/lib/ly-horizontal-layout/ly-horizontal-layout.component.mjs +82 -0
  114. package/esm2022/lib/ly-label/ly-label.component.mjs +37 -0
  115. package/esm2022/lib/ly-layout-container/ly-layout-container.component.mjs +83 -0
  116. package/esm2022/lib/ly-layout-container-of-root/ly-layout-container-of-root.component.mjs +17 -0
  117. package/esm2022/lib/ly-layout-field-label/ly-layout-field-label.component.mjs +24 -0
  118. package/esm2022/lib/ly-layout-panel/ly-layout-panel.component.mjs +83 -0
  119. package/esm2022/lib/ly-line/ly-line.component.mjs +56 -0
  120. package/esm2022/lib/ly-simple-label/ly-simple-label.component.mjs +22 -0
  121. package/esm2022/lib/ly-tab-container/ly-tab-container.component.mjs +44 -0
  122. package/esm2022/lib/ly-tab-page/ly-tab-page.component.mjs +44 -0
  123. package/esm2022/lib/ly-vertical-layout/ly-vertical-layout.component.mjs +51 -0
  124. package/esm2022/lib/manage-filters-report/manage-filters-report.component.mjs +43 -0
  125. package/esm2022/lib/mask/mask.component.mjs +22 -0
  126. package/esm2022/lib/message-strip/message-strip.component.mjs +28 -0
  127. package/esm2022/lib/models/grid-data-provider.mjs +114 -0
  128. package/esm2022/lib/models/grid-view.mjs +2 -0
  129. package/esm2022/lib/models/index.mjs +2 -0
  130. package/esm2022/lib/no-data/no-data.component.mjs +31 -0
  131. package/esm2022/lib/notification-item/notification-item.component.mjs +57 -0
  132. package/esm2022/lib/notification-item-actions/notification-item-actions.component.mjs +79 -0
  133. package/esm2022/lib/notification-popup.service.mjs +92 -0
  134. package/esm2022/lib/object-status-icon.pipe.mjs +27 -0
  135. package/esm2022/lib/progress-indicator/progress-indicator.component.mjs +18 -0
  136. package/esm2022/lib/report-navigator/report-navigator.component.mjs +68 -0
  137. package/esm2022/lib/report-new-top-form/report-new-top-form.component.mjs +60 -0
  138. package/esm2022/lib/report-search-fields-hidden-settings/report-search-fields-hidden-settings.component.mjs +35 -0
  139. package/esm2022/lib/report-search-fields-manage/report-search-fields-manage.component.mjs +97 -0
  140. package/esm2022/lib/report-search-panel-save/report-search-panel-save.component.mjs +88 -0
  141. package/esm2022/lib/report-tree-base.mjs +387 -0
  142. package/esm2022/lib/report-view-renderer.directive.mjs +392 -0
  143. package/esm2022/lib/responsive-toolbar/responsive-toolbar.component.mjs +50 -0
  144. package/esm2022/lib/responsive-toolbar-renderer/responsive-toolbar-renderer.component.mjs +84 -0
  145. package/esm2022/lib/rich-text-static/rich-text-static.component.mjs +72 -0
  146. package/esm2022/lib/sap-font-class.pipe.mjs +30 -0
  147. package/esm2022/lib/sap-font.pipe.mjs +30 -0
  148. package/esm2022/lib/sap-size.pipe.mjs +28 -0
  149. package/esm2022/lib/sap-ui-report-base.component.mjs +809 -0
  150. package/esm2022/lib/search-panel/search-panel.component.mjs +63 -0
  151. package/esm2022/lib/static-text/static-text.component.mjs +15 -0
  152. package/esm2022/lib/table-th.directive.mjs +87 -0
  153. package/esm2022/lib/title/title.component.mjs +15 -0
  154. package/esm2022/lib/ui-asp-report-viewer/ui-asp-report-viewer.component.mjs +34 -0
  155. package/esm2022/lib/ui-bpmn-viewer/ui-bpmn-viewer.component.mjs +33 -0
  156. package/esm2022/lib/ui-button/ui-button.component.mjs +32 -0
  157. package/esm2022/lib/ui-calendar/ui-calendar.component.mjs +53 -0
  158. package/esm2022/lib/ui-card-view/ui-card-view.component.mjs +58 -0
  159. package/esm2022/lib/ui-card-view-horizontal-group/ui-card-view-horizontal-group.component.mjs +42 -0
  160. package/esm2022/lib/ui-check-box/ui-check-box.component.mjs +39 -0
  161. package/esm2022/lib/ui-color-ui/ui-color-ui.component.mjs +50 -0
  162. package/esm2022/lib/ui-container-with-button/ui-container-with-button.component.mjs +38 -0
  163. package/esm2022/lib/ui-date-range-ex/ui-date-range-ex.component.mjs +191 -0
  164. package/esm2022/lib/ui-date-time/ui-date-time.component.mjs +150 -0
  165. package/esm2022/lib/ui-editable-grid/ui-editable-grid.component.mjs +108 -0
  166. package/esm2022/lib/ui-exception-form/ui-exception-form.component.mjs +53 -0
  167. package/esm2022/lib/ui-file-linear-list-box/ui-file-linear-list-box.component.mjs +124 -0
  168. package/esm2022/lib/ui-form-panel/ui-form-panel.component.mjs +103 -0
  169. package/esm2022/lib/ui-gantt-chart/ui-gantt-chart.component.mjs +32 -0
  170. package/esm2022/lib/ui-graph/ui-graph.component.mjs +17 -0
  171. package/esm2022/lib/ui-grid/ui-grid.component.mjs +25 -0
  172. package/esm2022/lib/ui-grid-columns/ui-grid-columns.component.mjs +43 -0
  173. package/esm2022/lib/ui-grid-filter-item/ui-grid-filter-item.component.mjs +66 -0
  174. package/esm2022/lib/ui-grid-filter-settings/ui-grid-filter-settings.component.mjs +75 -0
  175. package/esm2022/lib/ui-grid-sort-item/ui-grid-sort-item.component.mjs +58 -0
  176. package/esm2022/lib/ui-grid-sort-setting/ui-grid-sort-setting.component.mjs +123 -0
  177. package/esm2022/lib/ui-html-viewer/ui-html-viewer.component.mjs +16 -0
  178. package/esm2022/lib/ui-info-bar-panel/ui-info-bar-panel.component.mjs +11 -0
  179. package/esm2022/lib/ui-label/ui-label.component.mjs +12 -0
  180. package/esm2022/lib/ui-linear-list-container-with-button/ui-linear-list-container-with-button.component.mjs +379 -0
  181. package/esm2022/lib/ui-list-view/ui-list-view.component.mjs +84 -0
  182. package/esm2022/lib/ui-map/ui-map.component.mjs +68 -0
  183. package/esm2022/lib/ui-matrix-view/ui-matrix-view.component.mjs +124 -0
  184. package/esm2022/lib/ui-mo-info-combo-viewer/ui-mo-info-combo-viewer.component.mjs +19 -0
  185. package/esm2022/lib/ui-mo-info-general-object-ui/ui-mo-info-general-object-ui.component.mjs +14 -0
  186. package/esm2022/lib/ui-mo-info-sub-form-ui/ui-mo-info-sub-form-ui.component.mjs +55 -0
  187. package/esm2022/lib/ui-mo-info-ulv-combo/ui-mo-info-ulv-combo.component.mjs +429 -0
  188. package/esm2022/lib/ui-monaco-editor/ui-monaco-editor.component.mjs +28 -0
  189. package/esm2022/lib/ui-multi-select-card/ui-multi-select-card.component.mjs +37 -0
  190. package/esm2022/lib/ui-multi-select-checkbox/ui-multi-select-checkbox.component.mjs +59 -0
  191. package/esm2022/lib/ui-multi-select-combo/ui-multi-select-combo.component.mjs +93 -0
  192. package/esm2022/lib/ui-multi-select-radio/ui-multi-select-radio.component.mjs +36 -0
  193. package/esm2022/lib/ui-multi-select-slider/ui-multi-select-slider.component.mjs +56 -0
  194. package/esm2022/lib/ui-multi-select-smile/ui-multi-select-smile.component.mjs +28 -0
  195. package/esm2022/lib/ui-notification-view/ui-notification-view.component.mjs +47 -0
  196. package/esm2022/lib/ui-num-decimal-ui/ui-num-decimal-ui.component.mjs +33 -0
  197. package/esm2022/lib/ui-num-int-slider/ui-num-int-slider.component.mjs +27 -0
  198. package/esm2022/lib/ui-num-int-ui/ui-num-int-ui.component.mjs +21 -0
  199. package/esm2022/lib/ui-pdf-viewer/ui-pdf-viewer.component.mjs +268 -0
  200. package/esm2022/lib/ui-picture-file/ui-picture-file.component.mjs +101 -0
  201. package/esm2022/lib/ui-pictures-info/ui-pictures-info.component.mjs +261 -0
  202. package/esm2022/lib/ui-radio-group/ui-radio-group.component.mjs +48 -0
  203. package/esm2022/lib/ui-read-only-field/ui-read-only-field.component.mjs +36 -0
  204. package/esm2022/lib/ui-report-container/ui-report-container.component.mjs +46 -0
  205. package/esm2022/lib/ui-search-command-info-ui/ui-search-command-info-ui.component.mjs +24 -0
  206. package/esm2022/lib/ui-simple-combo/ui-simple-combo.component.mjs +55 -0
  207. package/esm2022/lib/ui-single-picture/ui-single-picture.component.mjs +36 -0
  208. package/esm2022/lib/ui-switch-button/ui-switch-button.component.mjs +20 -0
  209. package/esm2022/lib/ui-table-view/ui-table-view.component.mjs +296 -0
  210. package/esm2022/lib/ui-text-area/ui-text-area.component.mjs +49 -0
  211. package/esm2022/lib/ui-text-field/ui-text-field.component.mjs +52 -0
  212. package/esm2022/lib/ui-text-field-auto-complete/ui-text-field-auto-complete.component.mjs +48 -0
  213. package/esm2022/lib/ui-time-span/ui-time-span.component.mjs +24 -0
  214. package/esm2022/lib/ui-tinymce/ui-tinymce.component.mjs +53 -0
  215. package/esm2022/lib/ui-tree/ui-tree.component.mjs +114 -0
  216. package/esm2022/lib/ui-tree-view/ui-tree-view.component.mjs +100 -0
  217. package/esm2022/lib/ui-ulv-form-multi-select-ui/ui-ulv-form-multi-select-ui.component.mjs +23 -0
  218. package/esm2022/lib/ui-ulv-main-ui/ui-ulv-main-ui.component.mjs +310 -0
  219. package/esm2022/lib/ui-workflow-panel-ui/ui-workflow-panel-ui.component.mjs +25 -0
  220. package/esm2022/lib/ul-loading-mask-ui/ul-loading-mask-ui.component.mjs +93 -0
  221. package/esm2022/lib/ul-msg-box-adapter/ul-msg-box-adapter.component.mjs +119 -0
  222. package/esm2022/lib/ul-notify-popup/ul-notify-popup.component.mjs +32 -0
  223. package/esm2022/lib/ul-toast-adapter/ul-toast-adapter.component.mjs +48 -0
  224. package/esm2022/lib/ulv-column-settings/ulv-column-settings.component.mjs +53 -0
  225. package/esm2022/lib/ulv-context-menu/ulv-context-menu.component.mjs +116 -0
  226. package/esm2022/lib/ulv-filter-settings/ulv-filter-settings.component.mjs +43 -0
  227. package/esm2022/lib/ulv-form-multi-select/ulv-form-multi-select.component.mjs +196 -0
  228. package/esm2022/lib/ulv-groupby-settings/ulv-groupby-settings.component.mjs +44 -0
  229. package/esm2022/lib/ulv-paging/ulv-paging.component.mjs +84 -0
  230. package/esm2022/lib/ulv-selection/ulv-selection.component.mjs +65 -0
  231. package/esm2022/lib/ulv-settings/ulv-settings.component.mjs +116 -0
  232. package/esm2022/lib/ulv-sort-settings/ulv-sort-settings.component.mjs +54 -0
  233. package/esm2022/lib/ulv-toolbar/ulv-toolbar.component.mjs +177 -0
  234. package/esm2022/lib/upload-file-status.pipe.mjs +29 -0
  235. package/esm2022/lib/util-chat-time-badge.pipe.mjs +18 -0
  236. package/esm2022/lib/util-date-to-hh-mm.pipe.mjs +23 -0
  237. package/esm2022/lib/wizard-layout.directive.mjs +104 -0
  238. package/esm2022/public-api.mjs +236 -0
  239. package/fesm2022/barsa-sap-ui.mjs +4 -4
  240. package/fesm2022/barsa-sap-ui.mjs.map +1 -1
  241. package/package.json +3 -1
@@ -0,0 +1,418 @@
1
+ import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
2
+ import { concatMap, takeUntil, tap } from 'rxjs';
3
+ import { BaseComponent, BarsaApi, getUniqueId, isFunction, UploadService } from 'barsa-novin-ray-core';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "barsa-novin-ray-core";
6
+ import * as i2 from "@fundamental-ngx/core/file-uploader";
7
+ export class BarsaTinyemceComponent extends BaseComponent {
8
+ constructor(_uploadService, _el) {
9
+ super();
10
+ this._uploadService = _uploadService;
11
+ this._el = _el;
12
+ this.valueChange = new EventEmitter();
13
+ this.tinyInit = new EventEmitter();
14
+ this.tinyHostId = this._generateTinyHostId();
15
+ this.tinyMCEConfig = {};
16
+ this._onLoadIframe = () => {
17
+ this.value = this.editorValue;
18
+ // const ed = tinymce.get(this.tinyHostId);
19
+ // ed.execCommand('mceInsertContent', false, this.value);
20
+ // ed.insertContent(this.value, { format: 'raw' });
21
+ // this._removeOverflow(ed);
22
+ this.destroyTinymce();
23
+ this.prepare();
24
+ };
25
+ }
26
+ ngOnChanges(simpleChanges) {
27
+ super.ngOnChanges(simpleChanges);
28
+ if (simpleChanges.value && !simpleChanges.value.firstChange) {
29
+ this.setValue(simpleChanges.value.currentValue);
30
+ }
31
+ if (simpleChanges.disable && !simpleChanges.disable.firstChange) {
32
+ const disbale = simpleChanges.disable.currentValue;
33
+ if (disbale) {
34
+ this.setDisable();
35
+ }
36
+ else {
37
+ this.setEnable();
38
+ }
39
+ }
40
+ if (simpleChanges.readonly && !simpleChanges.readonly.firstChange) {
41
+ this.setReadOnly(simpleChanges.readonly.currentValue);
42
+ }
43
+ }
44
+ ngOnInit() {
45
+ super.ngOnInit();
46
+ this.height = this._el.nativeElement.clientHeight;
47
+ }
48
+ ngOnDestroy() {
49
+ super.ngOnDestroy();
50
+ this.destroyTinymce();
51
+ }
52
+ onFileSelection(files) {
53
+ this.uploadFile(files).pipe(takeUntil(this._onDestroy$)).subscribe();
54
+ }
55
+ loadTinyMce() {
56
+ if (!this.Setting.IsHtmlViewer) {
57
+ head.load(['Lib/tinymce/tinymce.min.js'], () => {
58
+ setTimeout(() => {
59
+ this.prepare();
60
+ });
61
+ });
62
+ }
63
+ }
64
+ onVisibilityChange(e) {
65
+ if (e === 'Visible') {
66
+ this.loadTinyMce();
67
+ }
68
+ }
69
+ initilize() {
70
+ if (this.tinyMCEConfig.setup) {
71
+ return;
72
+ }
73
+ this.tinyMCEConfig.height = '100%';
74
+ this.tinyMCEConfig.width = '100%';
75
+ this.tinyMCEConfig.selector = '#' + this.tinyHostId;
76
+ this.tinyMCEConfig.placeholder = this.Setting.ControlFieldCaptionTranslated;
77
+ this.tinyMCEConfig.content_css = 'assets/Resources/fonts/Iran.css';
78
+ this.tinyMCEConfig.directionality = 'rtl';
79
+ this.tinyMCEConfig.language = 'fa_IR';
80
+ this.tinyMCEConfig.promotion = false;
81
+ this.tinyMCEConfig.skin = 'oxide';
82
+ this.tinyMCEConfig.paste_data_images = true;
83
+ this.tinyMCEConfig.defaultFontName = 'BarsaFont';
84
+ this.tinyMCEConfig.defaultFontSize = '12px';
85
+ this.tinyMCEConfig.statusbar = false;
86
+ this.tinyMCEConfig.resize = false;
87
+ this.tinyMCEConfig.inline = false;
88
+ this.tinyMCEConfig.menubar = false;
89
+ this.tinyMCEConfig.toolbar_location = 'top';
90
+ this.tinyMCEConfig.toolbar_mode = 'floating';
91
+ // this.tinyMCEConfig.toolbar_sticky = true;
92
+ // this.tinyMCEConfig.toolbar_sticky_offset = 100;
93
+ this.tinyMCEConfig.font_family_formats =
94
+ 'BarsaFont=BarsaFont;Arial=arial,helvetica,sans-serif; Courier New=courier new,courier,monospace;';
95
+ this.tinyMCEConfig.font_size_formats = '8pt 10pt 12pt 14pt 18pt 24pt 36pt';
96
+ this.tinyMCEConfig.plugins = [
97
+ 'advlist',
98
+ 'anchor',
99
+ 'autolink',
100
+ 'autosave',
101
+ 'charmap',
102
+ 'code',
103
+ 'codesample',
104
+ 'directionality',
105
+ 'emoticons',
106
+ 'fullscreen',
107
+ 'help',
108
+ 'image',
109
+ 'importcss',
110
+ 'insertdatetime',
111
+ 'link',
112
+ 'lists',
113
+ 'media',
114
+ 'nonbreaking',
115
+ 'pagebreak',
116
+ 'preview',
117
+ 'quickbars',
118
+ 'save',
119
+ 'searchreplace',
120
+ 'table',
121
+ 'template',
122
+ 'visualblocks',
123
+ 'visualchars',
124
+ 'wordcount',
125
+ 'autoresize'
126
+ ];
127
+ this.tinyMCEConfig.toolbar =
128
+ `defaultVerbs barsaImage | insert | forecolor backcolor fontfamily fontsize | bullist numlist outdent indent | removeformat` +
129
+ ` | undo redo | copy cut paste | blocks | bold italic | alignleft aligncenter alignright alignjustify ltr rtl`;
130
+ this.tinyMCEConfig.quickbars_selection_toolbar =
131
+ 'bold italic fontsize | forecolor backcolor|defaultVerbs barsaImage';
132
+ const tinymceSettingsGlobal = window.tinymceSettings;
133
+ let tinymceSettings = BarsaApi.Common.Util.TryGetValue(this.Setting, 'JsonExtraProp.tinymceSettings');
134
+ tinymceSettings = BarsaApi.Common.Merger.Merge(tinymceSettingsGlobal, tinymceSettings);
135
+ if (!tinymceSettings && Array.isArray(tinymceSettings)) {
136
+ for (const item of tinymceSettings) {
137
+ this.tinyMCEConfig[item.key] = item.value;
138
+ }
139
+ }
140
+ if (this.isReadonly) {
141
+ this.tinyMCEConfig.menubar = false;
142
+ this.tinyMCEConfig.statusbar = false;
143
+ this.tinyMCEConfig.plugins = ['autoresize'];
144
+ // this.tinyMCEConfig.plugins = [];
145
+ this.tinyMCEConfig.toolbar = false;
146
+ }
147
+ let userSetup;
148
+ if (this.tinyMCEConfig.setup) {
149
+ userSetup = this.tinyMCEConfig.setup;
150
+ }
151
+ let defaultVerbsMenu = [];
152
+ // BEGIN: setup
153
+ this.tinyMCEConfig.setup = (ed) => {
154
+ this.editor = ed;
155
+ if (!this.isReadonly) {
156
+ if (this.defaultVerbs) {
157
+ defaultVerbsMenu = [];
158
+ this.defaultVerbs.forEach((item) => {
159
+ defaultVerbsMenu.push({
160
+ value: item.Html,
161
+ type: 'menuitem',
162
+ text: item.Title || item.Html.replace(/<br\s*\/?>/gi, ' '),
163
+ onAction: () => {
164
+ // ed.execCommand('mceInsertRawHTML', false, item.Html);
165
+ ed.insertContent(item.Html, { format: 'raw' });
166
+ }
167
+ });
168
+ });
169
+ }
170
+ ed.ui.registry.addSplitButton('barsaImage', {
171
+ text: 'insert',
172
+ icon: 'image',
173
+ tooltip: 'Insert Image As Base64',
174
+ onAction: () => {
175
+ BarsaApi.Common.Async.Waterfall('Tinemce.EmbedImage', {
176
+ openFileDialog: this.ShowOpenFileDialog.bind(this),
177
+ insertBase64: this.InsertBase64.bind(this)
178
+ }, (err, result) => {
179
+ BarsaApi.Common.Async.Finalize(err, result);
180
+ });
181
+ },
182
+ onItemAction: () => {
183
+ BarsaApi.Common.Async.Waterfall('Tinemce.UploadToDatabase', {
184
+ openFileDialog: this.ShowUploadWindow.bind(this)
185
+ }, (err, result) => {
186
+ BarsaApi.Common.Async.Finalize(err, result);
187
+ });
188
+ },
189
+ fetch: (callback) => {
190
+ const items = [
191
+ {
192
+ type: 'choiceitem',
193
+ text: 'upload',
194
+ icon: 'image',
195
+ tooltip: 'Upload Image',
196
+ value: 'upload'
197
+ }
198
+ ];
199
+ callback(items);
200
+ }
201
+ });
202
+ ed.ui.registry.addMenuButton('defaultVerbs', {
203
+ text: 'عبارتهای پیش فرض',
204
+ fetch: (callback) => {
205
+ callback(defaultVerbsMenu);
206
+ }
207
+ });
208
+ if (isFunction(window.tinymceSetup)) {
209
+ window.tinymceSetup.call(this, this, ed);
210
+ }
211
+ }
212
+ let hasInit = false;
213
+ ed.on('init', () => {
214
+ this.wysiwygIntialized = true;
215
+ this.intializationInProgress = false;
216
+ if (typeof this.value !== 'undefined') {
217
+ this.setValue(this.value);
218
+ }
219
+ if (this.tinyMCEConfig.defaultFontName) {
220
+ ed.execCommand('FontName', false, this.tinyMCEConfig.defaultFontName);
221
+ }
222
+ if (this.tinyMCEConfig.defaultFontSize) {
223
+ ed.execCommand('FontSize', false, this.tinyMCEConfig.defaultFontSize);
224
+ }
225
+ if (this.isReadonly) {
226
+ this.setReadOnly(this.isReadonly);
227
+ }
228
+ // This piece of code solves the problem of change propagation so that
229
+ // there is no need to call triggerSave
230
+ const setContent = ed.setContent;
231
+ ed.setContent = (...args) => {
232
+ setContent.apply(ed, args);
233
+ ed.dispatch('change', {});
234
+ };
235
+ hasInit = true;
236
+ this.tinyInit.emit();
237
+ const iframEl = ed.iframeElement;
238
+ if (iframEl) {
239
+ iframEl.addEventListener('load', this._onLoadIframe);
240
+ }
241
+ });
242
+ // Catch and propagate the change event
243
+ let oldContent = null;
244
+ ed.on('change keyup', () => {
245
+ const newval = ed.getContent();
246
+ if (newval === oldContent) {
247
+ return;
248
+ }
249
+ oldContent = newval;
250
+ if (!hasInit) {
251
+ return;
252
+ }
253
+ ed.save();
254
+ this.editorValue = newval;
255
+ this.valueChange.emit(newval);
256
+ // this.context.fireEvent('change', this, newval, oldval, {});
257
+ });
258
+ ed.on('focus', () => {
259
+ // TODO
260
+ });
261
+ if (userSetup) {
262
+ userSetup(ed);
263
+ }
264
+ };
265
+ }
266
+ ShowUploadWindow() {
267
+ this._uploader.open();
268
+ }
269
+ ShowOpenFileDialog(doReturn) {
270
+ const input = document.createElement('input');
271
+ input.setAttribute('type', 'file');
272
+ input.setAttribute('accept', 'image/*');
273
+ input.onchange = () => {
274
+ const file = input.files[0];
275
+ const reader = new FileReader();
276
+ reader.onload = () => {
277
+ let base64 = reader.result;
278
+ base64 = base64.split(',')[1];
279
+ doReturn(null, base64);
280
+ };
281
+ reader.readAsDataURL(file);
282
+ };
283
+ input.click();
284
+ }
285
+ InsertBase64(base64, doReturn) {
286
+ this.editor.execCommand('mceInsertContent', false, '<img src=data:image/png;base64,' + base64 + ' />');
287
+ doReturn();
288
+ }
289
+ getValue() {
290
+ let res = null;
291
+ if (this.wysiwygIntialized) {
292
+ const ed = tinymce.get(this.tinyHostId);
293
+ if (ed) {
294
+ res = ed.getContent();
295
+ }
296
+ }
297
+ return res;
298
+ }
299
+ setValue(value) {
300
+ this.value = value;
301
+ this.setValueTiny();
302
+ }
303
+ setValueTiny() {
304
+ if (this.wysiwygIntialized) {
305
+ const ed = tinymce.get(this.tinyHostId);
306
+ if (ed) {
307
+ ed.setContent(this.value);
308
+ }
309
+ }
310
+ return this.value;
311
+ }
312
+ focus() {
313
+ if (this.isReadonly) {
314
+ return this;
315
+ }
316
+ if (this.wysiwygIntialized) {
317
+ tinymce.execCommand('mceFocus', false, 'id_of_textarea');
318
+ }
319
+ return this;
320
+ }
321
+ setEnable() {
322
+ if (this.wysiwygIntialized) {
323
+ const ed = tinymce.get(this.tinyHostId);
324
+ ed.getBody().setAttribute('contenteditable', true);
325
+ }
326
+ }
327
+ setDisable() {
328
+ if (this.wysiwygIntialized) {
329
+ const ed = tinymce.get(this.tinyHostId);
330
+ ed.getBody().setAttribute('contenteditable', false);
331
+ }
332
+ }
333
+ setReadOnly(readOnly) {
334
+ if (this.wysiwygIntialized) {
335
+ const ed = tinymce.get(this.tinyHostId);
336
+ ed.getBody().setAttribute('contenteditable', !readOnly);
337
+ if (readOnly) {
338
+ $('.tox-editor-header').hide();
339
+ }
340
+ else {
341
+ $('.tox-editor-header').hide();
342
+ }
343
+ }
344
+ }
345
+ destroyTinymce() {
346
+ if (this.Setting.IsHtmlViewer || !this.wysiwygIntialized) {
347
+ return;
348
+ }
349
+ const ed = tinymce.get(this.tinyHostId);
350
+ if (ed) {
351
+ // tinymce.execCommand('mceRemoveControl', true, this.tinyHostId);
352
+ if (ed.iframeElement) {
353
+ ed.iframeElement.removeEventListener('load', this._onLoadIframe);
354
+ }
355
+ ed.destroy(false);
356
+ }
357
+ }
358
+ uploadFile(files) {
359
+ return this._uploadService.compressFiles$(files).pipe(concatMap((formData) => this._uploadService.upload(formData, this.Setting.StorageFileFieldId).pipe(tap((res) => {
360
+ if (Array.isArray(res)) {
361
+ const picture = res[0];
362
+ if (picture.ErrorMsg) {
363
+ BarsaApi.Bw.Msg.Error(picture.ErrorMsg);
364
+ return;
365
+ }
366
+ const value = {
367
+ ...picture,
368
+ FileId: picture.FileId
369
+ };
370
+ this._addImages(value);
371
+ }
372
+ }))));
373
+ }
374
+ _addImages(file) {
375
+ const url = '/IH.ashx?ty=StorageFile&key=' + file.FileId;
376
+ const html = '<img src=' + url + ' />';
377
+ this.editor.execCommand('mceInsertContent', false, html);
378
+ }
379
+ prepare() {
380
+ this.initilize();
381
+ tinymce.init(this.tinyMCEConfig);
382
+ this.intializationInProgress = false;
383
+ this.wysiwygIntialized = true;
384
+ }
385
+ _generateTinyHostId() {
386
+ return `a_${getUniqueId(2)}`;
387
+ }
388
+ _removeOverflow(ed) {
389
+ const html = ed.iframeElement?.contentDocument?.querySelector('html');
390
+ if (html) {
391
+ html.style.overflow = 'hidden';
392
+ }
393
+ }
394
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: BarsaTinyemceComponent, deps: [{ token: i1.UploadService }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
395
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: BarsaTinyemceComponent, selector: "bsu-barsa-tinyemce", inputs: { Setting: "Setting", isReadonly: "isReadonly", value: "value", IsInline: "IsInline", defaultVerbs: "defaultVerbs" }, outputs: { valueChange: "valueChange", tinyInit: "tinyInit" }, providers: [UploadService], viewQueries: [{ propertyName: "_uploader", first: true, predicate: ["uploader"], descendants: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div\r\n class=\"fd-input tinywrapper\"\r\n [style.min-height.px]=\"height\"\r\n [id]=\"tinyHostId\"\r\n intersectionObserver\r\n [intersectionThreshold]=\"0.1\"\r\n (visibilityChange)=\"onVisibilityChange($event)\"\r\n></div>\r\n<fd-file-uploader\r\n #uploader\r\n [style.display]=\"'none'\"\r\n [accept]=\"''\"\r\n [multiple]=\"false\"\r\n (selectedFilesChanged)=\"onFileSelection($event)\"\r\n></fd-file-uploader>\r\n<!-- <textarea [id]=\"tinyHostId\" style=\"height: 100%; visibility: hidden\"></textarea> -->\r\n", styles: [":host{display:block;width:100%;height:100%}.tinywrapper{overflow:auto}\n"], dependencies: [{ kind: "directive", type: i1.IntersectionObserverDirective, selector: "[intersectionObserver]", inputs: ["intersectionDebounce", "intersectionRootMargin", "intersectionRoot", "intersectionThreshold"], outputs: ["visibilityChange"] }, { kind: "component", type: i2.FileUploaderComponent, selector: "fd-file-uploader", inputs: ["disabled", "required", "multiple", "accept", "dragndrop", "maxFileSize", "minFileSize", "id", "ariaLabel", "ariaLabelledBy", "placeholder", "buttonLabel", "buttonAriaLabel", "state", "fileLimit", "inputHidden", "width"], outputs: ["selectedFilesChanged", "selectedInvalidFiles", "onDragEnter", "onDragLeave"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
396
+ }
397
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: BarsaTinyemceComponent, decorators: [{
398
+ type: Component,
399
+ args: [{ selector: 'bsu-barsa-tinyemce', changeDetection: ChangeDetectionStrategy.OnPush, providers: [UploadService], standalone: false, template: "<div\r\n class=\"fd-input tinywrapper\"\r\n [style.min-height.px]=\"height\"\r\n [id]=\"tinyHostId\"\r\n intersectionObserver\r\n [intersectionThreshold]=\"0.1\"\r\n (visibilityChange)=\"onVisibilityChange($event)\"\r\n></div>\r\n<fd-file-uploader\r\n #uploader\r\n [style.display]=\"'none'\"\r\n [accept]=\"''\"\r\n [multiple]=\"false\"\r\n (selectedFilesChanged)=\"onFileSelection($event)\"\r\n></fd-file-uploader>\r\n<!-- <textarea [id]=\"tinyHostId\" style=\"height: 100%; visibility: hidden\"></textarea> -->\r\n", styles: [":host{display:block;width:100%;height:100%}.tinywrapper{overflow:auto}\n"] }]
400
+ }], ctorParameters: () => [{ type: i1.UploadService }, { type: i0.ElementRef }], propDecorators: { _uploader: [{
401
+ type: ViewChild,
402
+ args: ['uploader']
403
+ }], Setting: [{
404
+ type: Input
405
+ }], isReadonly: [{
406
+ type: Input
407
+ }], value: [{
408
+ type: Input
409
+ }], IsInline: [{
410
+ type: Input
411
+ }], defaultVerbs: [{
412
+ type: Input
413
+ }], valueChange: [{
414
+ type: Output
415
+ }], tinyInit: [{
416
+ type: Output
417
+ }] } });
418
+ //# 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 {\r\n    AfterViewInit,\r\n    ChangeDetectionStrategy,\r\n    Component,\r\n    ElementRef,\r\n    EventEmitter,\r\n    Input,\r\n    OnChanges,\r\n    OnDestroy,\r\n    Output,\r\n    SimpleChanges,\r\n    ViewChild\r\n} from '@angular/core';\r\nimport { FileUploaderComponent } from '@fundamental-ngx/core';\r\nimport { Observable, concatMap, takeUntil, tap } from 'rxjs';\r\n\r\nimport {\r\n    BaseComponent,\r\n    BarsaApi,\r\n    getUniqueId,\r\n    isFunction,\r\n    UploadService,\r\n    GeneralControlInfoModel\r\n} from 'barsa-novin-ray-core';\r\n\r\ndeclare const window: any;\r\ndeclare const tinymce: any;\r\ndeclare const head: any;\r\ndeclare const $: any;\r\n@Component({\r\n    selector: 'bsu-barsa-tinyemce',\r\n    templateUrl: './barsa-tinyemce.component.html',\r\n    styleUrls: ['./barsa-tinyemce.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    providers: [UploadService],\r\n    standalone: false\r\n})\r\nexport class BarsaTinyemceComponent extends BaseComponent implements AfterViewInit, OnDestroy, OnChanges {\r\n    @ViewChild('uploader') _uploader: FileUploaderComponent;\r\n    @Input() Setting: GeneralControlInfoModel;\r\n    @Input() isReadonly: boolean;\r\n    @Input() value: any;\r\n    @Input() IsInline: boolean;\r\n    @Input() defaultVerbs: { Title: string; Html: string }[];\r\n    @Output() valueChange = new EventEmitter<any>();\r\n    @Output() tinyInit = new EventEmitter();\r\n    tinyHostId = this._generateTinyHostId();\r\n    tinyMCEConfig: any = {};\r\n    editor: any;\r\n    wysiwygIntialized: boolean;\r\n    intializationInProgress: boolean;\r\n    editorValue: string;\r\n\r\n    iframBodyInnerHtml: string;\r\n    height: number;\r\n\r\n    constructor(protected _uploadService: UploadService, protected _el: ElementRef) {\r\n        super();\r\n    }\r\n    ngOnChanges(simpleChanges: SimpleChanges): void {\r\n        super.ngOnChanges(simpleChanges);\r\n        if (simpleChanges.value && !simpleChanges.value.firstChange) {\r\n            this.setValue(simpleChanges.value.currentValue);\r\n        }\r\n        if (simpleChanges.disable && !simpleChanges.disable.firstChange) {\r\n            const disbale = simpleChanges.disable.currentValue;\r\n            if (disbale) {\r\n                this.setDisable();\r\n            } else {\r\n                this.setEnable();\r\n            }\r\n        }\r\n        if (simpleChanges.readonly && !simpleChanges.readonly.firstChange) {\r\n            this.setReadOnly(simpleChanges.readonly.currentValue);\r\n        }\r\n    }\r\n    ngOnInit(): void {\r\n        super.ngOnInit();\r\n        this.height = (this._el.nativeElement as HTMLElement).clientHeight;\r\n    }\r\n\r\n    ngOnDestroy(): void {\r\n        super.ngOnDestroy();\r\n        this.destroyTinymce();\r\n    }\r\n\r\n    onFileSelection(files: File[]): void {\r\n        this.uploadFile(files).pipe(takeUntil(this._onDestroy$)).subscribe();\r\n    }\r\n    loadTinyMce(): void {\r\n        if (!this.Setting.IsHtmlViewer) {\r\n            head.load(['Lib/tinymce/tinymce.min.js'], () => {\r\n                setTimeout(() => {\r\n                    this.prepare();\r\n                });\r\n            });\r\n        }\r\n    }\r\n    onVisibilityChange(e): void {\r\n        if (e === 'Visible') {\r\n            this.loadTinyMce();\r\n        }\r\n    }\r\n    initilize(): void {\r\n        if (this.tinyMCEConfig.setup) {\r\n            return;\r\n        }\r\n        this.tinyMCEConfig.height = '100%';\r\n        this.tinyMCEConfig.width = '100%';\r\n        this.tinyMCEConfig.selector = '#' + this.tinyHostId;\r\n        this.tinyMCEConfig.placeholder = this.Setting.ControlFieldCaptionTranslated;\r\n        this.tinyMCEConfig.content_css = 'assets/Resources/fonts/Iran.css';\r\n        this.tinyMCEConfig.directionality = 'rtl';\r\n        this.tinyMCEConfig.language = 'fa_IR';\r\n        this.tinyMCEConfig.promotion = false;\r\n        this.tinyMCEConfig.skin = 'oxide';\r\n        this.tinyMCEConfig.paste_data_images = true;\r\n        this.tinyMCEConfig.defaultFontName = 'BarsaFont';\r\n        this.tinyMCEConfig.defaultFontSize = '12px';\r\n        this.tinyMCEConfig.statusbar = false;\r\n        this.tinyMCEConfig.resize = false;\r\n\r\n        this.tinyMCEConfig.inline = false;\r\n        this.tinyMCEConfig.menubar = false;\r\n        this.tinyMCEConfig.toolbar_location = 'top';\r\n\r\n        this.tinyMCEConfig.toolbar_mode = 'floating';\r\n        // this.tinyMCEConfig.toolbar_sticky = true;\r\n        // this.tinyMCEConfig.toolbar_sticky_offset = 100;\r\n        this.tinyMCEConfig.font_family_formats =\r\n            'BarsaFont=BarsaFont;Arial=arial,helvetica,sans-serif; Courier New=courier new,courier,monospace;';\r\n        this.tinyMCEConfig.font_size_formats = '8pt 10pt 12pt 14pt 18pt 24pt 36pt';\r\n\r\n        this.tinyMCEConfig.plugins = [\r\n            'advlist',\r\n            'anchor',\r\n            'autolink',\r\n            'autosave',\r\n            'charmap',\r\n            'code',\r\n            'codesample',\r\n            'directionality',\r\n            'emoticons',\r\n            'fullscreen',\r\n            'help',\r\n            'image',\r\n            'importcss',\r\n            'insertdatetime',\r\n            'link',\r\n            'lists',\r\n            'media',\r\n            'nonbreaking',\r\n            'pagebreak',\r\n            'preview',\r\n            'quickbars',\r\n            'save',\r\n            'searchreplace',\r\n            'table',\r\n            'template',\r\n            'visualblocks',\r\n            'visualchars',\r\n            'wordcount',\r\n            'autoresize'\r\n        ];\r\n        this.tinyMCEConfig.toolbar =\r\n            `defaultVerbs barsaImage | insert | forecolor backcolor fontfamily fontsize | bullist numlist outdent indent | removeformat` +\r\n            ` | undo redo | copy cut paste | blocks | bold italic | alignleft aligncenter alignright alignjustify ltr rtl`;\r\n\r\n        this.tinyMCEConfig.quickbars_selection_toolbar =\r\n            'bold italic fontsize | forecolor backcolor|defaultVerbs barsaImage';\r\n        const tinymceSettingsGlobal = window.tinymceSettings;\r\n        let tinymceSettings = BarsaApi.Common.Util.TryGetValue(this.Setting, 'JsonExtraProp.tinymceSettings');\r\n        tinymceSettings = BarsaApi.Common.Merger.Merge(tinymceSettingsGlobal, tinymceSettings);\r\n        if (!tinymceSettings && Array.isArray(tinymceSettings)) {\r\n            for (const item of tinymceSettings) {\r\n                this.tinyMCEConfig[item.key] = item.value;\r\n            }\r\n        }\r\n\r\n        if (this.isReadonly) {\r\n            this.tinyMCEConfig.menubar = false;\r\n            this.tinyMCEConfig.statusbar = false;\r\n            this.tinyMCEConfig.plugins = ['autoresize'];\r\n            // this.tinyMCEConfig.plugins = [];\r\n            this.tinyMCEConfig.toolbar = false;\r\n        }\r\n\r\n        let userSetup: (editor: any) => void;\r\n\r\n        if (this.tinyMCEConfig.setup) {\r\n            userSetup = this.tinyMCEConfig.setup;\r\n        }\r\n        let defaultVerbsMenu: any = [];\r\n\r\n        // BEGIN: setup\r\n        this.tinyMCEConfig.setup = (ed) => {\r\n            this.editor = ed;\r\n            if (!this.isReadonly) {\r\n                if (this.defaultVerbs) {\r\n                    defaultVerbsMenu = [];\r\n                    this.defaultVerbs.forEach((item) => {\r\n                        defaultVerbsMenu.push({\r\n                            value: item.Html,\r\n                            type: 'menuitem',\r\n                            text: item.Title || item.Html.replace(/<br\\s*\\/?>/gi, ' '),\r\n                            onAction: () => {\r\n                                // ed.execCommand('mceInsertRawHTML', false, item.Html);\r\n                                ed.insertContent(item.Html, { format: 'raw' });\r\n                            }\r\n                        });\r\n                    });\r\n                }\r\n                ed.ui.registry.addSplitButton('barsaImage', {\r\n                    text: 'insert',\r\n                    icon: 'image',\r\n                    tooltip: 'Insert Image As Base64',\r\n                    onAction: () => {\r\n                        BarsaApi.Common.Async.Waterfall(\r\n                            'Tinemce.EmbedImage',\r\n                            {\r\n                                openFileDialog: this.ShowOpenFileDialog.bind(this),\r\n                                insertBase64: this.InsertBase64.bind(this)\r\n                            },\r\n                            (err, result) => {\r\n                                BarsaApi.Common.Async.Finalize(err, result);\r\n                            }\r\n                        );\r\n                    },\r\n                    onItemAction: () => {\r\n                        BarsaApi.Common.Async.Waterfall(\r\n                            'Tinemce.UploadToDatabase',\r\n                            {\r\n                                openFileDialog: this.ShowUploadWindow.bind(this)\r\n                            },\r\n                            (err, result) => {\r\n                                BarsaApi.Common.Async.Finalize(err, result);\r\n                            }\r\n                        );\r\n                    },\r\n                    fetch: (callback) => {\r\n                        const items = [\r\n                            {\r\n                                type: 'choiceitem',\r\n                                text: 'upload',\r\n                                icon: 'image',\r\n                                tooltip: 'Upload Image',\r\n                                value: 'upload'\r\n                            }\r\n                        ];\r\n                        callback(items);\r\n                    }\r\n                });\r\n\r\n                ed.ui.registry.addMenuButton('defaultVerbs', {\r\n                    text: 'عبارتهای پیش فرض',\r\n                    fetch: (callback) => {\r\n                        callback(defaultVerbsMenu);\r\n                    }\r\n                });\r\n                if (isFunction(window.tinymceSetup)) {\r\n                    window.tinymceSetup.call(this, this, ed);\r\n                }\r\n            }\r\n            let hasInit = false;\r\n            ed.on('init', () => {\r\n                this.wysiwygIntialized = true;\r\n                this.intializationInProgress = false;\r\n                if (typeof this.value !== 'undefined') {\r\n                    this.setValue(this.value);\r\n                }\r\n                if (this.tinyMCEConfig.defaultFontName) {\r\n                    ed.execCommand('FontName', false, this.tinyMCEConfig.defaultFontName);\r\n                }\r\n                if (this.tinyMCEConfig.defaultFontSize) {\r\n                    ed.execCommand('FontSize', false, this.tinyMCEConfig.defaultFontSize);\r\n                }\r\n                if (this.isReadonly) {\r\n                    this.setReadOnly(this.isReadonly);\r\n                }\r\n                // This piece of code solves the problem of change propagation so that\r\n                // there is no need to call triggerSave\r\n                const setContent = ed.setContent;\r\n                ed.setContent = (...args) => {\r\n                    setContent.apply(ed, args);\r\n                    ed.dispatch('change', {});\r\n                };\r\n                hasInit = true;\r\n                this.tinyInit.emit();\r\n                const iframEl: HTMLIFrameElement = ed.iframeElement;\r\n                if (iframEl) {\r\n                    iframEl.addEventListener('load', this._onLoadIframe);\r\n                }\r\n            });\r\n\r\n            // Catch and propagate the change event\r\n            let oldContent = null;\r\n            ed.on('change keyup', () => {\r\n                const newval = ed.getContent();\r\n                if (newval === oldContent) {\r\n                    return;\r\n                }\r\n\r\n                oldContent = newval;\r\n                if (!hasInit) {\r\n                    return;\r\n                }\r\n\r\n                ed.save();\r\n                this.editorValue = newval;\r\n                this.valueChange.emit(newval);\r\n                // this.context.fireEvent('change', this, newval, oldval, {});\r\n            });\r\n\r\n            ed.on('focus', () => {\r\n                // TODO\r\n            });\r\n\r\n            if (userSetup) {\r\n                userSetup(ed);\r\n            }\r\n        };\r\n    }\r\n\r\n    ShowUploadWindow(): void {\r\n        this._uploader.open();\r\n    }\r\n    ShowOpenFileDialog(doReturn): void {\r\n        const input: any = document.createElement('input');\r\n        input.setAttribute('type', 'file');\r\n        input.setAttribute('accept', 'image/*');\r\n\r\n        input.onchange = () => {\r\n            const file = input.files[0];\r\n\r\n            const reader = new FileReader();\r\n            reader.onload = () => {\r\n                let base64 = reader.result as string;\r\n                base64 = base64.split(',')[1];\r\n                doReturn(null, base64);\r\n            };\r\n            reader.readAsDataURL(file);\r\n        };\r\n\r\n        input.click();\r\n    }\r\n    InsertBase64(base64, doReturn): void {\r\n        this.editor.execCommand('mceInsertContent', false, '<img src=data:image/png;base64,' + base64 + ' />');\r\n        doReturn();\r\n    }\r\n    getValue(): string | null {\r\n        let res = null;\r\n        if (this.wysiwygIntialized) {\r\n            const ed = tinymce.get(this.tinyHostId);\r\n            if (ed) {\r\n                res = ed.getContent();\r\n            }\r\n        }\r\n\r\n        return res;\r\n    }\r\n    setValue(value): void {\r\n        this.value = value;\r\n        this.setValueTiny();\r\n    }\r\n    setValueTiny(): string {\r\n        if (this.wysiwygIntialized) {\r\n            const ed = tinymce.get(this.tinyHostId);\r\n            if (ed) {\r\n                ed.setContent(this.value);\r\n            }\r\n        }\r\n        return this.value;\r\n    }\r\n    focus(): any {\r\n        if (this.isReadonly) {\r\n            return this;\r\n        }\r\n\r\n        if (this.wysiwygIntialized) {\r\n            tinymce.execCommand('mceFocus', false, 'id_of_textarea');\r\n        }\r\n        return this;\r\n    }\r\n\r\n    setEnable(): void {\r\n        if (this.wysiwygIntialized) {\r\n            const ed = tinymce.get(this.tinyHostId);\r\n            ed.getBody().setAttribute('contenteditable', true);\r\n        }\r\n    }\r\n\r\n    setDisable(): void {\r\n        if (this.wysiwygIntialized) {\r\n            const ed = tinymce.get(this.tinyHostId);\r\n            ed.getBody().setAttribute('contenteditable', false);\r\n        }\r\n    }\r\n    setReadOnly(readOnly): void {\r\n        if (this.wysiwygIntialized) {\r\n            const ed = tinymce.get(this.tinyHostId);\r\n            ed.getBody().setAttribute('contenteditable', !readOnly);\r\n            if (readOnly) {\r\n                $('.tox-editor-header').hide();\r\n            } else {\r\n                $('.tox-editor-header').hide();\r\n            }\r\n        }\r\n    }\r\n\r\n    destroyTinymce(): void {\r\n        if (this.Setting.IsHtmlViewer || !this.wysiwygIntialized) {\r\n            return;\r\n        }\r\n        const ed = tinymce.get(this.tinyHostId);\r\n        if (ed) {\r\n            // tinymce.execCommand('mceRemoveControl', true, this.tinyHostId);\r\n            if (ed.iframeElement) {\r\n                ed.iframeElement.removeEventListener('load', this._onLoadIframe);\r\n            }\r\n            ed.destroy(false);\r\n        }\r\n    }\r\n    private uploadFile(files: File[]): Observable<any> {\r\n        return this._uploadService.compressFiles$(files).pipe(\r\n            concatMap((formData: FormData) =>\r\n                this._uploadService.upload(formData, this.Setting.StorageFileFieldId).pipe(\r\n                    tap((res) => {\r\n                        if (Array.isArray(res)) {\r\n                            const picture = res[0];\r\n                            if (picture.ErrorMsg) {\r\n                                BarsaApi.Bw.Msg.Error(picture.ErrorMsg);\r\n                                return;\r\n                            }\r\n                            const value = {\r\n                                ...picture,\r\n                                FileId: picture.FileId\r\n                            };\r\n                            this._addImages(value);\r\n                        }\r\n                    })\r\n                )\r\n            )\r\n        );\r\n    }\r\n    private _addImages(file: { FileId: string }): void {\r\n        const url = '/IH.ashx?ty=StorageFile&key=' + file.FileId;\r\n        const html = '<img src=' + url + ' />';\r\n\r\n        this.editor.execCommand('mceInsertContent', false, html);\r\n    }\r\n    private prepare(): void {\r\n        this.initilize();\r\n        tinymce.init(this.tinyMCEConfig);\r\n        this.intializationInProgress = false;\r\n        this.wysiwygIntialized = true;\r\n    }\r\n    private _onLoadIframe = (): void => {\r\n        this.value = this.editorValue;\r\n        // const ed = tinymce.get(this.tinyHostId);\r\n        // ed.execCommand('mceInsertContent', false, this.value);\r\n\r\n        // ed.insertContent(this.value, { format: 'raw' });\r\n        // this._removeOverflow(ed);\r\n        this.destroyTinymce();\r\n        this.prepare();\r\n    };\r\n    private _generateTinyHostId(): string {\r\n        return `a_${getUniqueId(2)}`;\r\n    }\r\n\r\n    private _removeOverflow(ed: any): void {\r\n        const html = ed.iframeElement?.contentDocument?.querySelector('html');\r\n        if (html) {\r\n            html.style.overflow = 'hidden';\r\n        }\r\n    }\r\n}\r\n","<div\r\n    class=\"fd-input tinywrapper\"\r\n    [style.min-height.px]=\"height\"\r\n    [id]=\"tinyHostId\"\r\n    intersectionObserver\r\n    [intersectionThreshold]=\"0.1\"\r\n    (visibilityChange)=\"onVisibilityChange($event)\"\r\n></div>\r\n<fd-file-uploader\r\n    #uploader\r\n    [style.display]=\"'none'\"\r\n    [accept]=\"''\"\r\n    [multiple]=\"false\"\r\n    (selectedFilesChanged)=\"onFileSelection($event)\"\r\n></fd-file-uploader>\r\n<!-- <textarea [id]=\"tinyHostId\" style=\"height: 100%; visibility: hidden\"></textarea> -->\r\n"]}
@@ -0,0 +1,36 @@
1
+ import { ChangeDetectionStrategy, Component, HostListener } from '@angular/core';
2
+ import { PreventDefaulEvent, BaseFormToolbaritemPropsComponent, executeUlvCommandHandler } 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/forms";
6
+ import * as i3 from "@fundamental-ngx/core/button";
7
+ import * as i4 from "@fundamental-ngx/core/input-group";
8
+ import * as i5 from "@fundamental-ngx/core/toolbar";
9
+ import * as i6 from "barsa-novin-ray-core";
10
+ export class BarsaToolbaritemSearchComponent extends BaseFormToolbaritemPropsComponent {
11
+ constructor() {
12
+ super(...arguments);
13
+ this.searchMode = false;
14
+ this.searchTerm = '';
15
+ }
16
+ onClick(e) {
17
+ PreventDefaulEvent(e);
18
+ }
19
+ onSearchSubmit() {
20
+ executeUlvCommandHandler(this.context, { searchText: this.searchTerm });
21
+ }
22
+ onSearchModeChange() {
23
+ this.searchMode = !this.searchMode;
24
+ this._cdr.detectChanges();
25
+ }
26
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: BarsaToolbaritemSearchComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
27
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: BarsaToolbaritemSearchComponent, selector: "bsu-barsa-toolbaritem-search", host: { listeners: { "click": "onClick($event)" } }, usesInheritance: true, ngImport: i0, template: "<ng-container *ngTemplateOutlet=\"searchTpl\"> </ng-container>\r\n<!-- <ng-container *ngTemplateOutlet=\"deviceSize !== 's' ? searchTpl : btnTpl\"> </ng-container> -->\r\n\r\n<ng-template #btnTpl>\r\n <button fd-button glyph=\"search\" fdType=\"transparent\" (click)=\"onSearchModeChange()\"></button>\r\n @if (searchMode) {\r\n <div style=\"z-index: 1; position: absolute; left: 0; top: 0; bottom: 0; right: 0\">\r\n <ng-container *ngTemplateOutlet=\"searchTpl\"></ng-container>\r\n </div>\r\n }\r\n</ng-template>\r\n<ng-template #searchTpl>\r\n <!-- <button fd-button glyph=\"arrow-right\" fdType=\"transparent\"></button> -->\r\n <!-- <fd-input-group placement=\"before\" glyph=\"arrow-right\" glyphAriaLabel=\"search\" placeholder=\"Search\">\r\n</fd-input-group> -->\r\n <fd-input-group\r\n [style.width]=\"deviceSize === 's' ? '100%' : '220px'\"\r\n fd-toolbar-item\r\n type=\"search\"\r\n glyph=\"search\"\r\n [glyphAriaLabel]=\"'Search' | bbbTranslate\"\r\n [placeholder]=\"'Search' | bbbTranslate\"\r\n [button]=\"true\"\r\n [disabled]=\"false\"\r\n [(ngModel)]=\"searchTerm\"\r\n (addOnButtonClicked)=\"onSearchSubmit()\"\r\n (keydown.enter)=\"onSearchSubmit()\"\r\n >\r\n </fd-input-group>\r\n</ng-template>\r\n", styles: [":host{display:block;width:100%;height:100%;min-width:180px}\n"], dependencies: [{ kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3.ButtonComponent, selector: "button[fd-button], a[fd-button], span[fd-button]", inputs: ["class"], exportAs: ["fd-button"] }, { kind: "component", type: i4.InputGroupComponent, selector: "fd-input-group", inputs: ["placement", "required", "inline", "addOnText", "buttonFocusable", "type", "glyph", "glyphFont", "button", "isControl", "showFocus", "isExpanded", "glyphAriaLabel", "addonButtonAriaHidden", "iconTitle", "ariaLabelledBy", "ariaLabel"], outputs: ["addOnButtonClicked", "search"] }, { kind: "directive", type: i5.ToolbarItemDirective, selector: "[fd-toolbar-item], [fdOverflowGroup], [fdOverflowPriority]", inputs: ["fdOverflowPriority", "fdOverflowGroup"] }, { kind: "pipe", type: i6.BbbTranslatePipe, name: "bbbTranslate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
28
+ }
29
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: BarsaToolbaritemSearchComponent, decorators: [{
30
+ type: Component,
31
+ args: [{ selector: 'bsu-barsa-toolbaritem-search', changeDetection: ChangeDetectionStrategy.OnPush, standalone: false, template: "<ng-container *ngTemplateOutlet=\"searchTpl\"> </ng-container>\r\n<!-- <ng-container *ngTemplateOutlet=\"deviceSize !== 's' ? searchTpl : btnTpl\"> </ng-container> -->\r\n\r\n<ng-template #btnTpl>\r\n <button fd-button glyph=\"search\" fdType=\"transparent\" (click)=\"onSearchModeChange()\"></button>\r\n @if (searchMode) {\r\n <div style=\"z-index: 1; position: absolute; left: 0; top: 0; bottom: 0; right: 0\">\r\n <ng-container *ngTemplateOutlet=\"searchTpl\"></ng-container>\r\n </div>\r\n }\r\n</ng-template>\r\n<ng-template #searchTpl>\r\n <!-- <button fd-button glyph=\"arrow-right\" fdType=\"transparent\"></button> -->\r\n <!-- <fd-input-group placement=\"before\" glyph=\"arrow-right\" glyphAriaLabel=\"search\" placeholder=\"Search\">\r\n</fd-input-group> -->\r\n <fd-input-group\r\n [style.width]=\"deviceSize === 's' ? '100%' : '220px'\"\r\n fd-toolbar-item\r\n type=\"search\"\r\n glyph=\"search\"\r\n [glyphAriaLabel]=\"'Search' | bbbTranslate\"\r\n [placeholder]=\"'Search' | bbbTranslate\"\r\n [button]=\"true\"\r\n [disabled]=\"false\"\r\n [(ngModel)]=\"searchTerm\"\r\n (addOnButtonClicked)=\"onSearchSubmit()\"\r\n (keydown.enter)=\"onSearchSubmit()\"\r\n >\r\n </fd-input-group>\r\n</ng-template>\r\n", styles: [":host{display:block;width:100%;height:100%;min-width:180px}\n"] }]
32
+ }], propDecorators: { onClick: [{
33
+ type: HostListener,
34
+ args: ['click', ['$event']]
35
+ }] } });
36
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFyc2EtdG9vbGJhcml0ZW0tc2VhcmNoLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2JhcnNhLXNhcC11aS9zcmMvbGliL2JhcnNhLXRvb2xiYXJpdGVtLXNlYXJjaC9iYXJzYS10b29sYmFyaXRlbS1zZWFyY2guY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2Etc2FwLXVpL3NyYy9saWIvYmFyc2EtdG9vbGJhcml0ZW0tc2VhcmNoL2JhcnNhLXRvb2xiYXJpdGVtLXNlYXJjaC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUN6RixPQUFPLEVBQUUsa0JBQWtCLEVBQUUsaUNBQWlDLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQzs7Ozs7Ozs7QUFTdkgsTUFBTSxPQUFPLCtCQUFnQyxTQUFRLGlDQUFpQztJQVB0Rjs7UUFRSSxlQUFVLEdBQUcsS0FBSyxDQUFDO1FBQ25CLGVBQVUsR0FBRyxFQUFFLENBQUM7S0FZbkI7SUFWRyxPQUFPLENBQUMsQ0FBQztRQUNMLGtCQUFrQixDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQzFCLENBQUM7SUFDRCxjQUFjO1FBQ1Ysd0JBQXdCLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRSxFQUFFLFVBQVUsRUFBRSxJQUFJLENBQUMsVUFBVSxFQUFFLENBQUMsQ0FBQztJQUM1RSxDQUFDO0lBQ0Qsa0JBQWtCO1FBQ2QsSUFBSSxDQUFDLFVBQVUsR0FBRyxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUM7UUFDbkMsSUFBSSxDQUFDLElBQUksQ0FBQyxhQUFhLEVBQUUsQ0FBQztJQUM5QixDQUFDOytHQWJRLCtCQUErQjttR0FBL0IsK0JBQStCLGdKQ1Y1QywwekNBOEJBOzs0RkRwQmEsK0JBQStCO2tCQVAzQyxTQUFTOytCQUNJLDhCQUE4QixtQkFHdkIsdUJBQXVCLENBQUMsTUFBTSxjQUNuQyxLQUFLOzhCQU1qQixPQUFPO3NCQUROLFlBQVk7dUJBQUMsT0FBTyxFQUFFLENBQUMsUUFBUSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgSG9zdExpc3RlbmVyLCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgUHJldmVudERlZmF1bEV2ZW50LCBCYXNlRm9ybVRvb2xiYXJpdGVtUHJvcHNDb21wb25lbnQsIGV4ZWN1dGVVbHZDb21tYW5kSGFuZGxlciB9IGZyb20gJ2JhcnNhLW5vdmluLXJheS1jb3JlJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gICAgc2VsZWN0b3I6ICdic3UtYmFyc2EtdG9vbGJhcml0ZW0tc2VhcmNoJyxcclxuICAgIHRlbXBsYXRlVXJsOiAnLi9iYXJzYS10b29sYmFyaXRlbS1zZWFyY2guY29tcG9uZW50Lmh0bWwnLFxyXG4gICAgc3R5bGVVcmxzOiBbJy4vYmFyc2EtdG9vbGJhcml0ZW0tc2VhcmNoLmNvbXBvbmVudC5zY3NzJ10sXHJcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcclxuICAgIHN0YW5kYWxvbmU6IGZhbHNlXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBCYXJzYVRvb2xiYXJpdGVtU2VhcmNoQ29tcG9uZW50IGV4dGVuZHMgQmFzZUZvcm1Ub29sYmFyaXRlbVByb3BzQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcclxuICAgIHNlYXJjaE1vZGUgPSBmYWxzZTtcclxuICAgIHNlYXJjaFRlcm0gPSAnJztcclxuICAgIEBIb3N0TGlzdGVuZXIoJ2NsaWNrJywgWyckZXZlbnQnXSlcclxuICAgIG9uQ2xpY2soZSk6IHZvaWQge1xyXG4gICAgICAgIFByZXZlbnREZWZhdWxFdmVudChlKTtcclxuICAgIH1cclxuICAgIG9uU2VhcmNoU3VibWl0KCk6IHZvaWQge1xyXG4gICAgICAgIGV4ZWN1dGVVbHZDb21tYW5kSGFuZGxlcih0aGlzLmNvbnRleHQsIHsgc2VhcmNoVGV4dDogdGhpcy5zZWFyY2hUZXJtIH0pO1xyXG4gICAgfVxyXG4gICAgb25TZWFyY2hNb2RlQ2hhbmdlKCk6IHZvaWQge1xyXG4gICAgICAgIHRoaXMuc2VhcmNoTW9kZSA9ICF0aGlzLnNlYXJjaE1vZGU7XHJcbiAgICAgICAgdGhpcy5fY2RyLmRldGVjdENoYW5nZXMoKTtcclxuICAgIH1cclxufVxyXG4iLCI8bmctY29udGFpbmVyICpuZ1RlbXBsYXRlT3V0bGV0PVwic2VhcmNoVHBsXCI+IDwvbmctY29udGFpbmVyPlxyXG48IS0tIDxuZy1jb250YWluZXIgKm5nVGVtcGxhdGVPdXRsZXQ9XCJkZXZpY2VTaXplICE9PSAncycgPyBzZWFyY2hUcGwgOiBidG5UcGxcIj4gPC9uZy1jb250YWluZXI+IC0tPlxyXG5cclxuPG5nLXRlbXBsYXRlICNidG5UcGw+XHJcbiAgICA8YnV0dG9uIGZkLWJ1dHRvbiBnbHlwaD1cInNlYXJjaFwiIGZkVHlwZT1cInRyYW5zcGFyZW50XCIgKGNsaWNrKT1cIm9uU2VhcmNoTW9kZUNoYW5nZSgpXCI+PC9idXR0b24+XHJcbiAgICBAaWYgKHNlYXJjaE1vZGUpIHtcclxuICAgIDxkaXYgc3R5bGU9XCJ6LWluZGV4OiAxOyBwb3NpdGlvbjogYWJzb2x1dGU7IGxlZnQ6IDA7IHRvcDogMDsgYm90dG9tOiAwOyByaWdodDogMFwiPlxyXG4gICAgICAgIDxuZy1jb250YWluZXIgKm5nVGVtcGxhdGVPdXRsZXQ9XCJzZWFyY2hUcGxcIj48L25nLWNvbnRhaW5lcj5cclxuICAgIDwvZGl2PlxyXG4gICAgfVxyXG48L25nLXRlbXBsYXRlPlxyXG48bmctdGVtcGxhdGUgI3NlYXJjaFRwbD5cclxuICAgIDwhLS0gPGJ1dHRvbiBmZC1idXR0b24gZ2x5cGg9XCJhcnJvdy1yaWdodFwiIGZkVHlwZT1cInRyYW5zcGFyZW50XCI+PC9idXR0b24+IC0tPlxyXG4gICAgPCEtLSA8ZmQtaW5wdXQtZ3JvdXAgcGxhY2VtZW50PVwiYmVmb3JlXCIgZ2x5cGg9XCJhcnJvdy1yaWdodFwiIGdseXBoQXJpYUxhYmVsPVwic2VhcmNoXCIgcGxhY2Vob2xkZXI9XCJTZWFyY2hcIj5cclxuPC9mZC1pbnB1dC1ncm91cD4gLS0+XHJcbiAgICA8ZmQtaW5wdXQtZ3JvdXBcclxuICAgICAgICBbc3R5bGUud2lkdGhdPVwiZGV2aWNlU2l6ZSA9PT0gJ3MnID8gJzEwMCUnIDogJzIyMHB4J1wiXHJcbiAgICAgICAgZmQtdG9vbGJhci1pdGVtXHJcbiAgICAgICAgdHlwZT1cInNlYXJjaFwiXHJcbiAgICAgICAgZ2x5cGg9XCJzZWFyY2hcIlxyXG4gICAgICAgIFtnbHlwaEFyaWFMYWJlbF09XCInU2VhcmNoJyB8IGJiYlRyYW5zbGF0ZVwiXHJcbiAgICAgICAgW3BsYWNlaG9sZGVyXT1cIidTZWFyY2gnIHwgYmJiVHJhbnNsYXRlXCJcclxuICAgICAgICBbYnV0dG9uXT1cInRydWVcIlxyXG4gICAgICAgIFtkaXNhYmxlZF09XCJmYWxzZVwiXHJcbiAgICAgICAgWyhuZ01vZGVsKV09XCJzZWFyY2hUZXJtXCJcclxuICAgICAgICAoYWRkT25CdXR0b25DbGlja2VkKT1cIm9uU2VhcmNoU3VibWl0KClcIlxyXG4gICAgICAgIChrZXlkb3duLmVudGVyKT1cIm9uU2VhcmNoU3VibWl0KClcIlxyXG4gICAgPlxyXG4gICAgPC9mZC1pbnB1dC1ncm91cD5cclxuPC9uZy10ZW1wbGF0ZT5cclxuIl19