barsa-novin-ray-core 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 (270) hide show
  1. package/README.md +25 -0
  2. package/esm2020/barsa-novin-ray-core.mjs +5 -0
  3. package/esm2020/lib/abstract-classes/application-base.mjs +24 -0
  4. package/esm2020/lib/abstract-classes/barsa-api.mjs +40 -0
  5. package/esm2020/lib/abstract-classes/field-base.mjs +167 -0
  6. package/esm2020/lib/abstract-classes/files-validation-helper.mjs +71 -0
  7. package/esm2020/lib/abstract-classes/form-base.mjs +101 -0
  8. package/esm2020/lib/abstract-classes/form-props.base.mjs +79 -0
  9. package/esm2020/lib/abstract-classes/form-toolbar-base.mjs +45 -0
  10. package/esm2020/lib/abstract-classes/index.mjs +21 -0
  11. package/esm2020/lib/abstract-classes/layout-item-base.mjs +33 -0
  12. package/esm2020/lib/abstract-classes/layout-panel-base.mjs +80 -0
  13. package/esm2020/lib/abstract-classes/models.mjs +172 -0
  14. package/esm2020/lib/abstract-classes/module-with-dynamic-components.mjs +2 -0
  15. package/esm2020/lib/abstract-classes/number-base.mjs +117 -0
  16. package/esm2020/lib/abstract-classes/page-base.mjs +97 -0
  17. package/esm2020/lib/abstract-classes/report-base.mjs +231 -0
  18. package/esm2020/lib/abstract-classes/report-item-base.mjs +53 -0
  19. package/esm2020/lib/abstract-classes/report-view-base.component.mjs +262 -0
  20. package/esm2020/lib/abstract-classes/system-base.mjs +24 -0
  21. package/esm2020/lib/auth-guard.mjs +37 -0
  22. package/esm2020/lib/barsa-novin-ray-core-routing.module.mjs +18 -0
  23. package/esm2020/lib/barsa-novin-ray-core.module.mjs +271 -0
  24. package/esm2020/lib/base-ulv-setting.component.mjs +37 -0
  25. package/esm2020/lib/base.component.mjs +59 -0
  26. package/esm2020/lib/base.module.mjs +28 -0
  27. package/esm2020/lib/constants.mjs +441 -0
  28. package/esm2020/lib/container.component.mjs +76 -0
  29. package/esm2020/lib/custom-route-reuse-strategy.mjs +32 -0
  30. package/esm2020/lib/date-services/date-hijri.service.mjs +127 -0
  31. package/esm2020/lib/date-services/date-info.mjs +2 -0
  32. package/esm2020/lib/date-services/date-miladi.service.mjs +124 -0
  33. package/esm2020/lib/date-services/date-shamsi.service.mjs +129 -0
  34. package/esm2020/lib/date-services/date.service.mjs +139 -0
  35. package/esm2020/lib/date-services/index.mjs +6 -0
  36. package/esm2020/lib/device.mjs +663 -0
  37. package/esm2020/lib/directives/anchor-scroll.directive.mjs +24 -0
  38. package/esm2020/lib/directives/attr-rtl.directive.mjs +35 -0
  39. package/esm2020/lib/directives/base.directive.mjs +51 -0
  40. package/esm2020/lib/directives/column-resizer.directive.mjs +39 -0
  41. package/esm2020/lib/directives/dynamic-command.directive.mjs +43 -0
  42. package/esm2020/lib/directives/ellipsify.directive.mjs +72 -0
  43. package/esm2020/lib/directives/field-binding.directive.mjs +17 -0
  44. package/esm2020/lib/directives/img-lazy.directive.mjs +75 -0
  45. package/esm2020/lib/directives/index.mjs +19 -0
  46. package/esm2020/lib/directives/intersection-observer.directive.mjs +49 -0
  47. package/esm2020/lib/directives/items-renderer.directive.mjs +59 -0
  48. package/esm2020/lib/directives/numbers-only-input.directive.mjs +26 -0
  49. package/esm2020/lib/directives/placeHolder.directive.mjs +15 -0
  50. package/esm2020/lib/directives/render-ulv-paging.directive.mjs +58 -0
  51. package/esm2020/lib/directives/render-ulv-viewer.directive.mjs +60 -0
  52. package/esm2020/lib/directives/table-resizer.directive.mjs +235 -0
  53. package/esm2020/lib/directives/ulv-command.directive.mjs +41 -0
  54. package/esm2020/lib/directives/until-inview.directive.mjs +51 -0
  55. package/esm2020/lib/dynamic-component/base-dynamic.component.mjs +89 -0
  56. package/esm2020/lib/dynamic-component/base-form-toolbaritem-props.mjs +50 -0
  57. package/esm2020/lib/dynamic-component/base-item-content-props.mjs +70 -0
  58. package/esm2020/lib/dynamic-component/base-view-content-props.mjs +26 -0
  59. package/esm2020/lib/dynamic-component/base-view-item-props.mjs +374 -0
  60. package/esm2020/lib/dynamic-component/base-view-props.mjs +127 -0
  61. package/esm2020/lib/dynamic-component/dynamic-form-toolbar-item.component.mjs +36 -0
  62. package/esm2020/lib/dynamic-component/dynamic-form.component.mjs +62 -0
  63. package/esm2020/lib/dynamic-component/dynamic-item.component.mjs +60 -0
  64. package/esm2020/lib/dynamic-component/index.mjs +10 -0
  65. package/esm2020/lib/empty-page-with-router-and-router-outlet/empty-page-with-router-and-router-outlet.component.mjs +16 -0
  66. package/esm2020/lib/field-ui/field-ui.component.mjs +116 -0
  67. package/esm2020/lib/form/form.component.mjs +151 -0
  68. package/esm2020/lib/form-new/form-new.component.mjs +30 -0
  69. package/esm2020/lib/from-intersection-observer.mjs +53 -0
  70. package/esm2020/lib/global-error-handler.mjs +26 -0
  71. package/esm2020/lib/modal-root.component.mjs +31 -0
  72. package/esm2020/lib/not-found/not-found.component.mjs +16 -0
  73. package/esm2020/lib/pipes/barsa-icon-dict.pipe.mjs +18 -0
  74. package/esm2020/lib/pipes/bbb-translate.pipe.mjs +29 -0
  75. package/esm2020/lib/pipes/can-upload.pipe.mjs +30 -0
  76. package/esm2020/lib/pipes/context-menu.pipe.mjs +40 -0
  77. package/esm2020/lib/pipes/control-ui.pipe.mjs +31 -0
  78. package/esm2020/lib/pipes/convert-to-style.pipe.mjs +32 -0
  79. package/esm2020/lib/pipes/date-time-to-caption.pipe.mjs +34 -0
  80. package/esm2020/lib/pipes/fileinfo-count.pipe.mjs +20 -0
  81. package/esm2020/lib/pipes/filter-columns-by-details.pipe.mjs +20 -0
  82. package/esm2020/lib/pipes/filter-string.pipe.mjs +44 -0
  83. package/esm2020/lib/pipes/filter-tab.pipe.mjs +19 -0
  84. package/esm2020/lib/pipes/filter-toolbar-control.pipe.mjs +16 -0
  85. package/esm2020/lib/pipes/filter.pipe.mjs +33 -0
  86. package/esm2020/lib/pipes/find-column-by-db-name.pipe.mjs +17 -0
  87. package/esm2020/lib/pipes/fiori-icon.pipe.mjs +42 -0
  88. package/esm2020/lib/pipes/groupby.pipe.mjs +48 -0
  89. package/esm2020/lib/pipes/header-facet-value.pipe.mjs +22 -0
  90. package/esm2020/lib/pipes/index.mjs +33 -0
  91. package/esm2020/lib/pipes/list-count.pipe.mjs +17 -0
  92. package/esm2020/lib/pipes/merge-fields-to-columns.pipe.mjs +42 -0
  93. package/esm2020/lib/pipes/mo-info-ulv-data.pipe.mjs +24 -0
  94. package/esm2020/lib/pipes/mo-report-value-concat.pipe.mjs +35 -0
  95. package/esm2020/lib/pipes/mo-report-value.pipe.mjs +28 -0
  96. package/esm2020/lib/pipes/mo-value.pipe.mjs +31 -0
  97. package/esm2020/lib/pipes/multiple-groupby.pipe.mjs +97 -0
  98. package/esm2020/lib/pipes/numeral.pipe.mjs +40 -0
  99. package/esm2020/lib/pipes/picture-field-source.pipe.mjs +22 -0
  100. package/esm2020/lib/pipes/remove-newline.pipe.mjs +20 -0
  101. package/esm2020/lib/pipes/seperator-fix.pipe.mjs +23 -0
  102. package/esm2020/lib/pipes/sort.pipe.mjs +48 -0
  103. package/esm2020/lib/pipes/tlbButtons.pipe.mjs +58 -0
  104. package/esm2020/lib/pipes/total-summary.pipe.mjs +16 -0
  105. package/esm2020/lib/pipes/visible-value.pipe.mjs +24 -0
  106. package/esm2020/lib/portal-page/portal-page.component.mjs +13 -0
  107. package/esm2020/lib/redirect-home-guard.mjs +28 -0
  108. package/esm2020/lib/redirect-report-navigator-command/redirect-report-navigator-command.component.mjs +33 -0
  109. package/esm2020/lib/report-container/report-container.component.mjs +52 -0
  110. package/esm2020/lib/resolvers/index.mjs +5 -0
  111. package/esm2020/lib/resolvers/portal-dynamic-page.resolver.mjs +49 -0
  112. package/esm2020/lib/resolvers/portal-form-page.resolver.mjs +18 -0
  113. package/esm2020/lib/resolvers/portal-page.resolver.mjs +30 -0
  114. package/esm2020/lib/resolvers/portal-report-page.resolver.mjs +37 -0
  115. package/esm2020/lib/root-page/root-page.component.mjs +21 -0
  116. package/esm2020/lib/root-portal/root-portal.component.mjs +51 -0
  117. package/esm2020/lib/services/api.service.mjs +60 -0
  118. package/esm2020/lib/services/barsa-dialog.service.mjs +80 -0
  119. package/esm2020/lib/services/breadcrumb.service.mjs +60 -0
  120. package/esm2020/lib/services/container.service.mjs +36 -0
  121. package/esm2020/lib/services/dynamic-component.service.mjs +55 -0
  122. package/esm2020/lib/services/form-panel.service.mjs +235 -0
  123. package/esm2020/lib/services/form.service.mjs +14 -0
  124. package/esm2020/lib/services/horizontal-layout.service.mjs +16 -0
  125. package/esm2020/lib/services/index.mjs +16 -0
  126. package/esm2020/lib/services/layout.service.mjs +42 -0
  127. package/esm2020/lib/services/log.service.mjs +50 -0
  128. package/esm2020/lib/services/network-status.service.mjs +15 -0
  129. package/esm2020/lib/services/portal.service.mjs +638 -0
  130. package/esm2020/lib/services/ui.service.mjs +23 -0
  131. package/esm2020/lib/services/ulvmain.service.mjs +594 -0
  132. package/esm2020/lib/services/upload.service.mjs +75 -0
  133. package/esm2020/public-api.mjs +33 -0
  134. package/fesm2015/barsa-novin-ray-core.mjs +9047 -0
  135. package/fesm2015/barsa-novin-ray-core.mjs.map +1 -0
  136. package/fesm2020/barsa-novin-ray-core.mjs +8945 -0
  137. package/fesm2020/barsa-novin-ray-core.mjs.map +1 -0
  138. package/index.d.ts +5 -0
  139. package/lib/abstract-classes/application-base.d.ts +53 -0
  140. package/lib/abstract-classes/barsa-api.d.ts +28 -0
  141. package/lib/abstract-classes/field-base.d.ts +81 -0
  142. package/lib/abstract-classes/files-validation-helper.d.ts +15 -0
  143. package/lib/abstract-classes/form-base.d.ts +59 -0
  144. package/lib/abstract-classes/form-props.base.d.ts +45 -0
  145. package/lib/abstract-classes/form-toolbar-base.d.ts +17 -0
  146. package/lib/abstract-classes/index.d.ts +20 -0
  147. package/lib/abstract-classes/layout-item-base.d.ts +15 -0
  148. package/lib/abstract-classes/layout-panel-base.d.ts +24 -0
  149. package/lib/abstract-classes/models.d.ts +660 -0
  150. package/lib/abstract-classes/module-with-dynamic-components.d.ts +4 -0
  151. package/lib/abstract-classes/number-base.d.ts +20 -0
  152. package/lib/abstract-classes/page-base.d.ts +31 -0
  153. package/lib/abstract-classes/report-base.d.ts +97 -0
  154. package/lib/abstract-classes/report-item-base.d.ts +33 -0
  155. package/lib/abstract-classes/report-view-base.component.d.ts +130 -0
  156. package/lib/abstract-classes/system-base.d.ts +45 -0
  157. package/lib/auth-guard.d.ts +12 -0
  158. package/lib/barsa-novin-ray-core-routing.module.d.ts +7 -0
  159. package/lib/barsa-novin-ray-core.module.d.ts +88 -0
  160. package/lib/base-ulv-setting.component.d.ts +18 -0
  161. package/lib/base.component.d.ts +15 -0
  162. package/lib/base.module.d.ts +13 -0
  163. package/lib/constants.d.ts +89 -0
  164. package/lib/container.component.d.ts +33 -0
  165. package/lib/custom-route-reuse-strategy.d.ts +11 -0
  166. package/lib/date-services/date-hijri.service.d.ts +40 -0
  167. package/lib/date-services/date-info.d.ts +15 -0
  168. package/lib/date-services/date-miladi.service.d.ts +39 -0
  169. package/lib/date-services/date-shamsi.service.d.ts +40 -0
  170. package/lib/date-services/date.service.d.ts +54 -0
  171. package/lib/date-services/index.d.ts +5 -0
  172. package/lib/device.d.ts +15 -0
  173. package/lib/directives/anchor-scroll.directive.d.ts +7 -0
  174. package/lib/directives/attr-rtl.directive.d.ts +13 -0
  175. package/lib/directives/base.directive.d.ts +13 -0
  176. package/lib/directives/column-resizer.directive.d.ts +13 -0
  177. package/lib/directives/dynamic-command.directive.d.ts +12 -0
  178. package/lib/directives/ellipsify.directive.d.ts +17 -0
  179. package/lib/directives/field-binding.directive.d.ts +7 -0
  180. package/lib/directives/img-lazy.directive.d.ts +20 -0
  181. package/lib/directives/index.d.ts +18 -0
  182. package/lib/directives/intersection-observer.directive.d.ts +17 -0
  183. package/lib/directives/items-renderer.directive.d.ts +17 -0
  184. package/lib/directives/numbers-only-input.directive.d.ts +9 -0
  185. package/lib/directives/placeHolder.directive.d.ts +6 -0
  186. package/lib/directives/render-ulv-paging.directive.d.ts +19 -0
  187. package/lib/directives/render-ulv-viewer.directive.d.ts +19 -0
  188. package/lib/directives/table-resizer.directive.d.ts +47 -0
  189. package/lib/directives/ulv-command.directive.d.ts +11 -0
  190. package/lib/directives/until-inview.directive.d.ts +17 -0
  191. package/lib/dynamic-component/base-dynamic.component.d.ts +26 -0
  192. package/lib/dynamic-component/base-form-toolbaritem-props.d.ts +28 -0
  193. package/lib/dynamic-component/base-item-content-props.d.ts +40 -0
  194. package/lib/dynamic-component/base-view-content-props.d.ts +11 -0
  195. package/lib/dynamic-component/base-view-item-props.d.ts +95 -0
  196. package/lib/dynamic-component/base-view-props.d.ts +65 -0
  197. package/lib/dynamic-component/dynamic-form-toolbar-item.component.d.ts +18 -0
  198. package/lib/dynamic-component/dynamic-form.component.d.ts +33 -0
  199. package/lib/dynamic-component/dynamic-item.component.d.ts +30 -0
  200. package/lib/dynamic-component/index.d.ts +9 -0
  201. package/lib/empty-page-with-router-and-router-outlet/empty-page-with-router-and-router-outlet.component.d.ts +7 -0
  202. package/lib/field-ui/field-ui.component.d.ts +27 -0
  203. package/lib/form/form.component.d.ts +36 -0
  204. package/lib/form-new/form-new.component.d.ts +23 -0
  205. package/lib/from-intersection-observer.d.ts +7 -0
  206. package/lib/global-error-handler.d.ts +8 -0
  207. package/lib/modal-root.component.d.ts +15 -0
  208. package/lib/not-found/not-found.component.d.ts +8 -0
  209. package/lib/pipes/barsa-icon-dict.pipe.d.ts +9 -0
  210. package/lib/pipes/bbb-translate.pipe.d.ts +7 -0
  211. package/lib/pipes/can-upload.pipe.d.ts +8 -0
  212. package/lib/pipes/context-menu.pipe.d.ts +11 -0
  213. package/lib/pipes/control-ui.pipe.d.ts +9 -0
  214. package/lib/pipes/convert-to-style.pipe.d.ts +8 -0
  215. package/lib/pipes/date-time-to-caption.pipe.d.ts +9 -0
  216. package/lib/pipes/fileinfo-count.pipe.d.ts +10 -0
  217. package/lib/pipes/filter-columns-by-details.pipe.d.ts +8 -0
  218. package/lib/pipes/filter-string.pipe.d.ts +11 -0
  219. package/lib/pipes/filter-tab.pipe.d.ts +7 -0
  220. package/lib/pipes/filter-toolbar-control.pipe.d.ts +8 -0
  221. package/lib/pipes/filter.pipe.d.ts +10 -0
  222. package/lib/pipes/find-column-by-db-name.pipe.d.ts +8 -0
  223. package/lib/pipes/fiori-icon.pipe.d.ts +7 -0
  224. package/lib/pipes/groupby.pipe.d.ts +7 -0
  225. package/lib/pipes/header-facet-value.pipe.d.ts +8 -0
  226. package/lib/pipes/index.d.ts +32 -0
  227. package/lib/pipes/list-count.pipe.d.ts +8 -0
  228. package/lib/pipes/merge-fields-to-columns.pipe.d.ts +10 -0
  229. package/lib/pipes/mo-info-ulv-data.pipe.d.ts +7 -0
  230. package/lib/pipes/mo-report-value-concat.pipe.d.ts +9 -0
  231. package/lib/pipes/mo-report-value.pipe.d.ts +12 -0
  232. package/lib/pipes/mo-value.pipe.d.ts +9 -0
  233. package/lib/pipes/multiple-groupby.pipe.d.ts +23 -0
  234. package/lib/pipes/numeral.pipe.d.ts +9 -0
  235. package/lib/pipes/picture-field-source.pipe.d.ts +8 -0
  236. package/lib/pipes/remove-newline.pipe.d.ts +8 -0
  237. package/lib/pipes/seperator-fix.pipe.d.ts +7 -0
  238. package/lib/pipes/sort.pipe.d.ts +9 -0
  239. package/lib/pipes/tlbButtons.pipe.d.ts +9 -0
  240. package/lib/pipes/total-summary.pipe.d.ts +8 -0
  241. package/lib/pipes/visible-value.pipe.d.ts +8 -0
  242. package/lib/portal-page/portal-page.component.d.ts +6 -0
  243. package/lib/redirect-home-guard.d.ts +13 -0
  244. package/lib/redirect-report-navigator-command/redirect-report-navigator-command.component.d.ts +14 -0
  245. package/lib/report-container/report-container.component.d.ts +24 -0
  246. package/lib/resolvers/index.d.ts +4 -0
  247. package/lib/resolvers/portal-dynamic-page.resolver.d.ts +12 -0
  248. package/lib/resolvers/portal-form-page.resolver.d.ts +8 -0
  249. package/lib/resolvers/portal-page.resolver.d.ts +12 -0
  250. package/lib/resolvers/portal-report-page.resolver.d.ts +12 -0
  251. package/lib/root-page/root-page.component.d.ts +10 -0
  252. package/lib/root-portal/root-portal.component.d.ts +14 -0
  253. package/lib/services/api.service.d.ts +18 -0
  254. package/lib/services/barsa-dialog.service.d.ts +31 -0
  255. package/lib/services/breadcrumb.service.d.ts +14 -0
  256. package/lib/services/container.service.d.ts +14 -0
  257. package/lib/services/dynamic-component.service.d.ts +13 -0
  258. package/lib/services/form-panel.service.d.ts +83 -0
  259. package/lib/services/form.service.d.ts +8 -0
  260. package/lib/services/horizontal-layout.service.d.ts +7 -0
  261. package/lib/services/index.d.ts +15 -0
  262. package/lib/services/layout.service.d.ts +23 -0
  263. package/lib/services/log.service.d.ts +17 -0
  264. package/lib/services/network-status.service.d.ts +7 -0
  265. package/lib/services/portal.service.d.ts +130 -0
  266. package/lib/services/ui.service.d.ts +14 -0
  267. package/lib/services/ulvmain.service.d.ts +178 -0
  268. package/lib/services/upload.service.d.ts +18 -0
  269. package/package.json +38 -0
  270. package/public-api.d.ts +29 -0
@@ -0,0 +1,58 @@
1
+ import { Directive, Input } from '@angular/core';
2
+ import { delay, takeUntil, tap } from 'rxjs/operators';
3
+ import { BaseDirective } from './base.directive';
4
+ import { getComponentDefined, getUniqueId } from '../constants';
5
+ import { BarsaApi } from '../abstract-classes';
6
+ import * as i0 from "@angular/core";
7
+ import * as i1 from "../services/portal.service";
8
+ export class RenderUlvPaginDirective extends BaseDirective {
9
+ constructor(_injector, _portalService, _vcr, _cdr) {
10
+ super();
11
+ this._injector = _injector;
12
+ this._portalService = _portalService;
13
+ this._vcr = _vcr;
14
+ this._cdr = _cdr;
15
+ }
16
+ async ngOnInit() {
17
+ super.ngOnInit();
18
+ this._render();
19
+ }
20
+ ngOnDestroy() {
21
+ super.ngOnDestroy();
22
+ this.component.destroy();
23
+ }
24
+ async _render() {
25
+ const context = this.context;
26
+ if (context) {
27
+ const customUiSetting = BarsaApi.Common.Util.TryGetValue(context.Setting, 'ClassNames.CustomUi', null);
28
+ const { moduleName, modulePath
29
+ // componentName,
30
+ // selector
31
+ } = getComponentDefined(context, customUiSetting);
32
+ this._portalService
33
+ .getComponent(moduleName, modulePath, 'UlvPaging', 'bsu-ulv-paging', this._injector)
34
+ .pipe(takeUntil(this._onDestroy$), delay(0), tap((component) => {
35
+ component.instance.id = getUniqueId(4);
36
+ component.instance.context = context;
37
+ this.component = component;
38
+ this._vcr.insert(component.hostView);
39
+ this._cdr.detectChanges();
40
+ }))
41
+ .subscribe();
42
+ }
43
+ }
44
+ }
45
+ RenderUlvPaginDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: RenderUlvPaginDirective, deps: [{ token: i0.Injector }, { token: i1.PortalService }, { token: i0.ViewContainerRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Directive });
46
+ RenderUlvPaginDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.7", type: RenderUlvPaginDirective, selector: "[renderUlvPaging]", inputs: { mask: "mask", context: ["renderUlvPaging", "context"] }, usesInheritance: true, ngImport: i0 });
47
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: RenderUlvPaginDirective, decorators: [{
48
+ type: Directive,
49
+ args: [{
50
+ selector: '[renderUlvPaging]'
51
+ }]
52
+ }], ctorParameters: function () { return [{ type: i0.Injector }, { type: i1.PortalService }, { type: i0.ViewContainerRef }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { mask: [{
53
+ type: Input
54
+ }], context: [{
55
+ type: Input,
56
+ args: ['renderUlvPaging']
57
+ }] } });
58
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVuZGVyLXVsdi1wYWdpbmcuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2Etbm92aW4tcmF5LWNvcmUvc3JjL2xpYi9kaXJlY3RpdmVzL3JlbmRlci11bHYtcGFnaW5nLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBR0gsU0FBUyxFQUVULEtBQUssRUFJUixNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUUsS0FBSyxFQUFFLFNBQVMsRUFBRSxHQUFHLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUV2RCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFDakQsT0FBTyxFQUFFLG1CQUFtQixFQUFFLFdBQVcsRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUVoRSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0scUJBQXFCLENBQUM7OztBQUsvQyxNQUFNLE9BQU8sdUJBQXdCLFNBQVEsYUFBYTtJQUl0RCxZQUNZLFNBQW1CLEVBQ25CLGNBQTZCLEVBQzdCLElBQXNCLEVBQ3RCLElBQXVCO1FBRS9CLEtBQUssRUFBRSxDQUFDO1FBTEEsY0FBUyxHQUFULFNBQVMsQ0FBVTtRQUNuQixtQkFBYyxHQUFkLGNBQWMsQ0FBZTtRQUM3QixTQUFJLEdBQUosSUFBSSxDQUFrQjtRQUN0QixTQUFJLEdBQUosSUFBSSxDQUFtQjtJQUduQyxDQUFDO0lBQ0QsS0FBSyxDQUFDLFFBQVE7UUFDVixLQUFLLENBQUMsUUFBUSxFQUFFLENBQUM7UUFDakIsSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDO0lBQ25CLENBQUM7SUFDRCxXQUFXO1FBQ1AsS0FBSyxDQUFDLFdBQVcsRUFBRSxDQUFDO1FBQ3BCLElBQUksQ0FBQyxTQUFTLENBQUMsT0FBTyxFQUFFLENBQUM7SUFDN0IsQ0FBQztJQUNELEtBQUssQ0FBQyxPQUFPO1FBQ1QsTUFBTSxPQUFPLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQztRQUM3QixJQUFJLE9BQU8sRUFBRTtZQUNULE1BQU0sZUFBZSxHQUFHLFFBQVEsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxPQUFPLENBQUMsT0FBTyxFQUFFLHFCQUFxQixFQUFFLElBQUksQ0FBQyxDQUFDO1lBQ3ZHLE1BQU0sRUFDRixVQUFVLEVBQ1YsVUFBVTtZQUNWLGlCQUFpQjtZQUNqQixXQUFXO2NBQ2QsR0FBRyxtQkFBbUIsQ0FBQyxPQUFPLEVBQUUsZUFBZSxDQUFDLENBQUM7WUFFbEQsSUFBSSxDQUFDLGNBQWM7aUJBQ2QsWUFBWSxDQUFDLFVBQVUsRUFBRSxVQUFVLEVBQUUsV0FBVyxFQUFFLGdCQUFnQixFQUFFLElBQUksQ0FBQyxTQUFTLENBQUM7aUJBQ25GLElBQUksQ0FDRCxTQUFTLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxFQUMzQixLQUFLLENBQUMsQ0FBQyxDQUFDLEVBQ1IsR0FBRyxDQUFDLENBQUMsU0FBUyxFQUFFLEVBQUU7Z0JBQ2QsU0FBUyxDQUFDLFFBQVEsQ0FBQyxFQUFFLEdBQUcsV0FBVyxDQUFDLENBQUMsQ0FBQyxDQUFDO2dCQUN2QyxTQUFTLENBQUMsUUFBUSxDQUFDLE9BQU8sR0FBRyxPQUFPLENBQUM7Z0JBQ3JDLElBQUksQ0FBQyxTQUFTLEdBQUcsU0FBUyxDQUFDO2dCQUMzQixJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxTQUFTLENBQUMsUUFBUSxDQUFDLENBQUM7Z0JBQ3JDLElBQUksQ0FBQyxJQUFJLENBQUMsYUFBYSxFQUFFLENBQUM7WUFDOUIsQ0FBQyxDQUFDLENBQ0w7aUJBQ0EsU0FBUyxFQUFFLENBQUM7U0FDcEI7SUFDTCxDQUFDOztvSEE5Q1EsdUJBQXVCO3dHQUF2Qix1QkFBdUI7MkZBQXZCLHVCQUF1QjtrQkFIbkMsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUsbUJBQW1CO2lCQUNoQzswTEFFWSxJQUFJO3NCQUFaLEtBQUs7Z0JBQ29CLE9BQU87c0JBQWhDLEtBQUs7dUJBQUMsaUJBQWlCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgICBDaGFuZ2VEZXRlY3RvclJlZixcbiAgICBDb21wb25lbnRSZWYsXG4gICAgRGlyZWN0aXZlLFxuICAgIEluamVjdG9yLFxuICAgIElucHV0LFxuICAgIE9uRGVzdHJveSxcbiAgICBPbkluaXQsXG4gICAgVmlld0NvbnRhaW5lclJlZlxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IGRlbGF5LCB0YWtlVW50aWwsIHRhcCB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcblxuaW1wb3J0IHsgQmFzZURpcmVjdGl2ZSB9IGZyb20gJy4vYmFzZS5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgZ2V0Q29tcG9uZW50RGVmaW5lZCwgZ2V0VW5pcXVlSWQgfSBmcm9tICcuLi9jb25zdGFudHMnO1xuaW1wb3J0IHsgUG9ydGFsU2VydmljZSB9IGZyb20gJy4uL3NlcnZpY2VzL3BvcnRhbC5zZXJ2aWNlJztcbmltcG9ydCB7IEJhcnNhQXBpIH0gZnJvbSAnLi4vYWJzdHJhY3QtY2xhc3Nlcyc7XG5cbkBEaXJlY3RpdmUoe1xuICAgIHNlbGVjdG9yOiAnW3JlbmRlclVsdlBhZ2luZ10nXG59KVxuZXhwb3J0IGNsYXNzIFJlbmRlclVsdlBhZ2luRGlyZWN0aXZlIGV4dGVuZHMgQmFzZURpcmVjdGl2ZSBpbXBsZW1lbnRzIE9uSW5pdCwgT25EZXN0cm95IHtcbiAgICBASW5wdXQoKSBtYXNrOiBib29sZWFuO1xuICAgIEBJbnB1dCgncmVuZGVyVWx2UGFnaW5nJykgY29udGV4dDtcbiAgICBjb21wb25lbnQ6IENvbXBvbmVudFJlZjxhbnk+O1xuICAgIGNvbnN0cnVjdG9yKFxuICAgICAgICBwcml2YXRlIF9pbmplY3RvcjogSW5qZWN0b3IsXG4gICAgICAgIHByaXZhdGUgX3BvcnRhbFNlcnZpY2U6IFBvcnRhbFNlcnZpY2UsXG4gICAgICAgIHByaXZhdGUgX3ZjcjogVmlld0NvbnRhaW5lclJlZixcbiAgICAgICAgcHJpdmF0ZSBfY2RyOiBDaGFuZ2VEZXRlY3RvclJlZlxuICAgICkge1xuICAgICAgICBzdXBlcigpO1xuICAgIH1cbiAgICBhc3luYyBuZ09uSW5pdCgpOiBQcm9taXNlPHZvaWQ+IHtcbiAgICAgICAgc3VwZXIubmdPbkluaXQoKTtcbiAgICAgICAgdGhpcy5fcmVuZGVyKCk7XG4gICAgfVxuICAgIG5nT25EZXN0cm95KCk6IHZvaWQge1xuICAgICAgICBzdXBlci5uZ09uRGVzdHJveSgpO1xuICAgICAgICB0aGlzLmNvbXBvbmVudC5kZXN0cm95KCk7XG4gICAgfVxuICAgIGFzeW5jIF9yZW5kZXIoKTogUHJvbWlzZTx2b2lkPiB7XG4gICAgICAgIGNvbnN0IGNvbnRleHQgPSB0aGlzLmNvbnRleHQ7XG4gICAgICAgIGlmIChjb250ZXh0KSB7XG4gICAgICAgICAgICBjb25zdCBjdXN0b21VaVNldHRpbmcgPSBCYXJzYUFwaS5Db21tb24uVXRpbC5UcnlHZXRWYWx1ZShjb250ZXh0LlNldHRpbmcsICdDbGFzc05hbWVzLkN1c3RvbVVpJywgbnVsbCk7XG4gICAgICAgICAgICBjb25zdCB7XG4gICAgICAgICAgICAgICAgbW9kdWxlTmFtZSxcbiAgICAgICAgICAgICAgICBtb2R1bGVQYXRoXG4gICAgICAgICAgICAgICAgLy8gY29tcG9uZW50TmFtZSxcbiAgICAgICAgICAgICAgICAvLyBzZWxlY3RvclxuICAgICAgICAgICAgfSA9IGdldENvbXBvbmVudERlZmluZWQoY29udGV4dCwgY3VzdG9tVWlTZXR0aW5nKTtcblxuICAgICAgICAgICAgdGhpcy5fcG9ydGFsU2VydmljZVxuICAgICAgICAgICAgICAgIC5nZXRDb21wb25lbnQobW9kdWxlTmFtZSwgbW9kdWxlUGF0aCwgJ1VsdlBhZ2luZycsICdic3UtdWx2LXBhZ2luZycsIHRoaXMuX2luamVjdG9yKVxuICAgICAgICAgICAgICAgIC5waXBlKFxuICAgICAgICAgICAgICAgICAgICB0YWtlVW50aWwodGhpcy5fb25EZXN0cm95JCksXG4gICAgICAgICAgICAgICAgICAgIGRlbGF5KDApLFxuICAgICAgICAgICAgICAgICAgICB0YXAoKGNvbXBvbmVudCkgPT4ge1xuICAgICAgICAgICAgICAgICAgICAgICAgY29tcG9uZW50Lmluc3RhbmNlLmlkID0gZ2V0VW5pcXVlSWQoNCk7XG4gICAgICAgICAgICAgICAgICAgICAgICBjb21wb25lbnQuaW5zdGFuY2UuY29udGV4dCA9IGNvbnRleHQ7XG4gICAgICAgICAgICAgICAgICAgICAgICB0aGlzLmNvbXBvbmVudCA9IGNvbXBvbmVudDtcbiAgICAgICAgICAgICAgICAgICAgICAgIHRoaXMuX3Zjci5pbnNlcnQoY29tcG9uZW50Lmhvc3RWaWV3KTtcbiAgICAgICAgICAgICAgICAgICAgICAgIHRoaXMuX2Nkci5kZXRlY3RDaGFuZ2VzKCk7XG4gICAgICAgICAgICAgICAgICAgIH0pXG4gICAgICAgICAgICAgICAgKVxuICAgICAgICAgICAgICAgIC5zdWJzY3JpYmUoKTtcbiAgICAgICAgfVxuICAgIH1cbn1cbiJdfQ==
@@ -0,0 +1,60 @@
1
+ import { Directive, Input } from '@angular/core';
2
+ import { delay, takeUntil, tap } from 'rxjs/operators';
3
+ import { BarsaApi } from '../abstract-classes';
4
+ import { BaseDirective } from './base.directive';
5
+ import { getComponentDefined, getUniqueId } from '../constants';
6
+ import * as i0 from "@angular/core";
7
+ import * as i1 from "../services/portal.service";
8
+ export class RenderUlvViewerDirective extends BaseDirective {
9
+ constructor(_injector, _portalService, _vcr, _cdr) {
10
+ super();
11
+ this._injector = _injector;
12
+ this._portalService = _portalService;
13
+ this._vcr = _vcr;
14
+ this._cdr = _cdr;
15
+ }
16
+ ngAfterViewInit() {
17
+ super.ngAfterViewInit();
18
+ this._render();
19
+ }
20
+ ngOnDestroy() {
21
+ super.ngOnDestroy();
22
+ if (this.component) {
23
+ this.component.destroy();
24
+ }
25
+ }
26
+ _render() {
27
+ const context = this.viewer;
28
+ if (context) {
29
+ const customUiSetting = BarsaApi.Common.Util.TryGetValue(context.Setting, 'ClassNames.CustomUi', null);
30
+ const { moduleName, modulePath, componentName, selector } = getComponentDefined(context, customUiSetting);
31
+ this._portalService
32
+ .getComponent(moduleName, modulePath, componentName, selector, this._injector)
33
+ .pipe(takeUntil(this._onDestroy$), delay(0), tap((component) => {
34
+ component.instance.id = getUniqueId(4);
35
+ component.instance.context = context;
36
+ // component.instance.moDataList=BarsaApi.Common.Util.TryGetValue(context,'moDataList',[]);
37
+ context.controlUi = component.instance;
38
+ // context.viewer = component.instance;
39
+ this.component = component;
40
+ this._vcr.insert(component.hostView);
41
+ this._cdr.detectChanges();
42
+ }))
43
+ .subscribe();
44
+ }
45
+ }
46
+ }
47
+ RenderUlvViewerDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: RenderUlvViewerDirective, deps: [{ token: i0.Injector }, { token: i1.PortalService }, { token: i0.ViewContainerRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Directive });
48
+ RenderUlvViewerDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.7", type: RenderUlvViewerDirective, selector: "[renderUlvViewer]", inputs: { mask: "mask", viewer: ["renderUlvViewer", "viewer"] }, usesInheritance: true, ngImport: i0 });
49
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: RenderUlvViewerDirective, decorators: [{
50
+ type: Directive,
51
+ args: [{
52
+ selector: '[renderUlvViewer]'
53
+ }]
54
+ }], ctorParameters: function () { return [{ type: i0.Injector }, { type: i1.PortalService }, { type: i0.ViewContainerRef }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { mask: [{
55
+ type: Input
56
+ }], viewer: [{
57
+ type: Input,
58
+ args: ['renderUlvViewer']
59
+ }] } });
60
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVuZGVyLXVsdi12aWV3ZXIuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2Etbm92aW4tcmF5LWNvcmUvc3JjL2xpYi9kaXJlY3RpdmVzL3JlbmRlci11bHYtdmlld2VyLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBSUgsU0FBUyxFQUVULEtBQUssRUFHUixNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUUsS0FBSyxFQUFFLFNBQVMsRUFBRSxHQUFHLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUN2RCxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFFL0MsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBQ2pELE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxXQUFXLEVBQUUsTUFBTSxjQUFjLENBQUM7OztBQU1oRSxNQUFNLE9BQU8sd0JBQXlCLFNBQVEsYUFBYTtJQUl2RCxZQUNZLFNBQW1CLEVBQ25CLGNBQTZCLEVBQzdCLElBQXNCLEVBQ3RCLElBQXVCO1FBRS9CLEtBQUssRUFBRSxDQUFDO1FBTEEsY0FBUyxHQUFULFNBQVMsQ0FBVTtRQUNuQixtQkFBYyxHQUFkLGNBQWMsQ0FBZTtRQUM3QixTQUFJLEdBQUosSUFBSSxDQUFrQjtRQUN0QixTQUFJLEdBQUosSUFBSSxDQUFtQjtJQUduQyxDQUFDO0lBQ0QsZUFBZTtRQUNYLEtBQUssQ0FBQyxlQUFlLEVBQUUsQ0FBQztRQUN4QixJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7SUFDbkIsQ0FBQztJQUNELFdBQVc7UUFDUCxLQUFLLENBQUMsV0FBVyxFQUFFLENBQUM7UUFDcEIsSUFBSSxJQUFJLENBQUMsU0FBUyxFQUFFO1lBQ2hCLElBQUksQ0FBQyxTQUFTLENBQUMsT0FBTyxFQUFFLENBQUM7U0FDNUI7SUFDTCxDQUFDO0lBQ0QsT0FBTztRQUNILE1BQU0sT0FBTyxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUM7UUFDNUIsSUFBSSxPQUFPLEVBQUU7WUFDVCxNQUFNLGVBQWUsR0FBRyxRQUFRLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsT0FBTyxDQUFDLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxJQUFJLENBQUMsQ0FBQztZQUN2RyxNQUFNLEVBQUUsVUFBVSxFQUFFLFVBQVUsRUFBRSxhQUFhLEVBQUUsUUFBUSxFQUFFLEdBQUcsbUJBQW1CLENBQUMsT0FBTyxFQUFFLGVBQWUsQ0FBQyxDQUFDO1lBQzFHLElBQUksQ0FBQyxjQUFjO2lCQUNkLFlBQVksQ0FBQyxVQUFVLEVBQUUsVUFBVSxFQUFFLGFBQWEsRUFBRSxRQUFRLEVBQUUsSUFBSSxDQUFDLFNBQVMsQ0FBQztpQkFDN0UsSUFBSSxDQUNELFNBQVMsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLEVBQzNCLEtBQUssQ0FBQyxDQUFDLENBQUMsRUFDUixHQUFHLENBQUMsQ0FBQyxTQUFTLEVBQUUsRUFBRTtnQkFDZCxTQUFTLENBQUMsUUFBUSxDQUFDLEVBQUUsR0FBRyxXQUFXLENBQUMsQ0FBQyxDQUFDLENBQUM7Z0JBQ3ZDLFNBQVMsQ0FBQyxRQUFRLENBQUMsT0FBTyxHQUFHLE9BQU8sQ0FBQztnQkFDckMsMkZBQTJGO2dCQUMzRixPQUFPLENBQUMsU0FBUyxHQUFHLFNBQVMsQ0FBQyxRQUFRLENBQUM7Z0JBQ3ZDLHVDQUF1QztnQkFDdkMsSUFBSSxDQUFDLFNBQVMsR0FBRyxTQUFTLENBQUM7Z0JBQzNCLElBQUksQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLFNBQVMsQ0FBQyxRQUFRLENBQUMsQ0FBQztnQkFDckMsSUFBSSxDQUFDLElBQUksQ0FBQyxhQUFhLEVBQUUsQ0FBQztZQUM5QixDQUFDLENBQUMsQ0FDTDtpQkFDQSxTQUFTLEVBQUUsQ0FBQztTQUNwQjtJQUNMLENBQUM7O3FIQTdDUSx3QkFBd0I7eUdBQXhCLHdCQUF3QjsyRkFBeEIsd0JBQXdCO2tCQUhwQyxTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSxtQkFBbUI7aUJBQ2hDOzBMQUVZLElBQUk7c0JBQVosS0FBSztnQkFDb0IsTUFBTTtzQkFBL0IsS0FBSzt1QkFBQyxpQkFBaUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICAgIEFmdGVyVmlld0luaXQsXG4gICAgQ2hhbmdlRGV0ZWN0b3JSZWYsXG4gICAgQ29tcG9uZW50UmVmLFxuICAgIERpcmVjdGl2ZSxcbiAgICBJbmplY3RvcixcbiAgICBJbnB1dCxcbiAgICBPbkRlc3Ryb3ksXG4gICAgVmlld0NvbnRhaW5lclJlZlxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IGRlbGF5LCB0YWtlVW50aWwsIHRhcCB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcbmltcG9ydCB7IEJhcnNhQXBpIH0gZnJvbSAnLi4vYWJzdHJhY3QtY2xhc3Nlcyc7XG5cbmltcG9ydCB7IEJhc2VEaXJlY3RpdmUgfSBmcm9tICcuL2Jhc2UuZGlyZWN0aXZlJztcbmltcG9ydCB7IGdldENvbXBvbmVudERlZmluZWQsIGdldFVuaXF1ZUlkIH0gZnJvbSAnLi4vY29uc3RhbnRzJztcbmltcG9ydCB7IFBvcnRhbFNlcnZpY2UgfSBmcm9tICcuLi9zZXJ2aWNlcy9wb3J0YWwuc2VydmljZSc7XG5cbkBEaXJlY3RpdmUoe1xuICAgIHNlbGVjdG9yOiAnW3JlbmRlclVsdlZpZXdlcl0nXG59KVxuZXhwb3J0IGNsYXNzIFJlbmRlclVsdlZpZXdlckRpcmVjdGl2ZSBleHRlbmRzIEJhc2VEaXJlY3RpdmUgaW1wbGVtZW50cyBBZnRlclZpZXdJbml0LCBPbkRlc3Ryb3kge1xuICAgIEBJbnB1dCgpIG1hc2s6IGJvb2xlYW47XG4gICAgQElucHV0KCdyZW5kZXJVbHZWaWV3ZXInKSB2aWV3ZXI7XG4gICAgY29tcG9uZW50OiBDb21wb25lbnRSZWY8YW55PjtcbiAgICBjb25zdHJ1Y3RvcihcbiAgICAgICAgcHJpdmF0ZSBfaW5qZWN0b3I6IEluamVjdG9yLFxuICAgICAgICBwcml2YXRlIF9wb3J0YWxTZXJ2aWNlOiBQb3J0YWxTZXJ2aWNlLFxuICAgICAgICBwcml2YXRlIF92Y3I6IFZpZXdDb250YWluZXJSZWYsXG4gICAgICAgIHByaXZhdGUgX2NkcjogQ2hhbmdlRGV0ZWN0b3JSZWZcbiAgICApIHtcbiAgICAgICAgc3VwZXIoKTtcbiAgICB9XG4gICAgbmdBZnRlclZpZXdJbml0KCk6IHZvaWQge1xuICAgICAgICBzdXBlci5uZ0FmdGVyVmlld0luaXQoKTtcbiAgICAgICAgdGhpcy5fcmVuZGVyKCk7XG4gICAgfVxuICAgIG5nT25EZXN0cm95KCk6IHZvaWQge1xuICAgICAgICBzdXBlci5uZ09uRGVzdHJveSgpO1xuICAgICAgICBpZiAodGhpcy5jb21wb25lbnQpIHtcbiAgICAgICAgICAgIHRoaXMuY29tcG9uZW50LmRlc3Ryb3koKTtcbiAgICAgICAgfVxuICAgIH1cbiAgICBfcmVuZGVyKCk6IHZvaWQge1xuICAgICAgICBjb25zdCBjb250ZXh0ID0gdGhpcy52aWV3ZXI7XG4gICAgICAgIGlmIChjb250ZXh0KSB7XG4gICAgICAgICAgICBjb25zdCBjdXN0b21VaVNldHRpbmcgPSBCYXJzYUFwaS5Db21tb24uVXRpbC5UcnlHZXRWYWx1ZShjb250ZXh0LlNldHRpbmcsICdDbGFzc05hbWVzLkN1c3RvbVVpJywgbnVsbCk7XG4gICAgICAgICAgICBjb25zdCB7IG1vZHVsZU5hbWUsIG1vZHVsZVBhdGgsIGNvbXBvbmVudE5hbWUsIHNlbGVjdG9yIH0gPSBnZXRDb21wb25lbnREZWZpbmVkKGNvbnRleHQsIGN1c3RvbVVpU2V0dGluZyk7XG4gICAgICAgICAgICB0aGlzLl9wb3J0YWxTZXJ2aWNlXG4gICAgICAgICAgICAgICAgLmdldENvbXBvbmVudChtb2R1bGVOYW1lLCBtb2R1bGVQYXRoLCBjb21wb25lbnROYW1lLCBzZWxlY3RvciwgdGhpcy5faW5qZWN0b3IpXG4gICAgICAgICAgICAgICAgLnBpcGUoXG4gICAgICAgICAgICAgICAgICAgIHRha2VVbnRpbCh0aGlzLl9vbkRlc3Ryb3kkKSxcbiAgICAgICAgICAgICAgICAgICAgZGVsYXkoMCksXG4gICAgICAgICAgICAgICAgICAgIHRhcCgoY29tcG9uZW50KSA9PiB7XG4gICAgICAgICAgICAgICAgICAgICAgICBjb21wb25lbnQuaW5zdGFuY2UuaWQgPSBnZXRVbmlxdWVJZCg0KTtcbiAgICAgICAgICAgICAgICAgICAgICAgIGNvbXBvbmVudC5pbnN0YW5jZS5jb250ZXh0ID0gY29udGV4dDtcbiAgICAgICAgICAgICAgICAgICAgICAgIC8vIGNvbXBvbmVudC5pbnN0YW5jZS5tb0RhdGFMaXN0PUJhcnNhQXBpLkNvbW1vbi5VdGlsLlRyeUdldFZhbHVlKGNvbnRleHQsJ21vRGF0YUxpc3QnLFtdKTtcbiAgICAgICAgICAgICAgICAgICAgICAgIGNvbnRleHQuY29udHJvbFVpID0gY29tcG9uZW50Lmluc3RhbmNlO1xuICAgICAgICAgICAgICAgICAgICAgICAgLy8gY29udGV4dC52aWV3ZXIgPSBjb21wb25lbnQuaW5zdGFuY2U7XG4gICAgICAgICAgICAgICAgICAgICAgICB0aGlzLmNvbXBvbmVudCA9IGNvbXBvbmVudDtcbiAgICAgICAgICAgICAgICAgICAgICAgIHRoaXMuX3Zjci5pbnNlcnQoY29tcG9uZW50Lmhvc3RWaWV3KTtcbiAgICAgICAgICAgICAgICAgICAgICAgIHRoaXMuX2Nkci5kZXRlY3RDaGFuZ2VzKCk7XG4gICAgICAgICAgICAgICAgICAgIH0pXG4gICAgICAgICAgICAgICAgKVxuICAgICAgICAgICAgICAgIC5zdWJzY3JpYmUoKTtcbiAgICAgICAgfVxuICAgIH1cbn1cbiJdfQ==
@@ -0,0 +1,235 @@
1
+ import { Directive, Input, HostListener, EventEmitter, Output } from '@angular/core';
2
+ import { fromEvent } from 'rxjs';
3
+ import { takeUntil } from 'rxjs/operators';
4
+ import { BaseDirective } from './base.directive';
5
+ import * as i0 from "@angular/core";
6
+ export class TableResizerDirective extends BaseDirective {
7
+ constructor(el, renderer) {
8
+ super();
9
+ this.el = el;
10
+ this.renderer = renderer;
11
+ this.columnResized = new EventEmitter();
12
+ fromEvent(document, 'mouseup')
13
+ .pipe(takeUntil(this._onDestroy$))
14
+ .subscribe(() => {
15
+ this._mouseUp();
16
+ });
17
+ fromEvent(document, 'mousemove')
18
+ .pipe(takeUntil(this._onDestroy$))
19
+ .subscribe((e) => {
20
+ this._mouseMove(e);
21
+ });
22
+ }
23
+ get _table() {
24
+ return this.el.nativeElement;
25
+ }
26
+ moseDown(e) {
27
+ this._mouseDown(e);
28
+ }
29
+ moseMove(e) {
30
+ this._mouseMove(e);
31
+ }
32
+ ngAfterViewInit() {
33
+ if (this.rowResizer) {
34
+ this._putBodyCellsContentIntoDiv();
35
+ }
36
+ if (this.rowResizer) {
37
+ this._addRowsResizer();
38
+ }
39
+ this._setTableMode(this.fitWidth);
40
+ }
41
+ ngOnChanges(changes) {
42
+ super.ngOnChanges(changes);
43
+ const { fitWidth } = changes;
44
+ if (this.enableResizing && fitWidth && !fitWidth.firstChange) {
45
+ const newFitWidth = fitWidth.currentValue;
46
+ this._setTableMode(newFitWidth);
47
+ }
48
+ }
49
+ _initializeTable() {
50
+ this._initTable();
51
+ this._setTableMode(this.fitWidth);
52
+ }
53
+ _resizeRow(event) {
54
+ this._currentResizer = "Row" /* Resizer.Row */;
55
+ const elementFromPoint = document.elementFromPoint(event.pageX, event.pageY);
56
+ this._currentCell = elementFromPoint?.closest('td');
57
+ this._startY = event.pageY;
58
+ this._currentRowHeight = this._currentCell?.clientHeight || 0;
59
+ }
60
+ _resizeColumn(event) {
61
+ if (!this.fitWidth) {
62
+ this._setTableFreeSize();
63
+ }
64
+ this._currentResizer = "Column" /* Resizer.Column */;
65
+ const elementFromPoint = document.elementFromPoint(event.pageX, event.pageY);
66
+ this._currentCell = elementFromPoint?.closest('th');
67
+ this._startX = event.pageX;
68
+ this._currentColumnWidth = this._currentCell?.clientWidth || 0;
69
+ this._sideCell = this._getSideCell(this._currentCell);
70
+ this._sideColumnWidth = this._sideCell?.clientWidth;
71
+ }
72
+ _addRowsResizer() {
73
+ const table = this._table;
74
+ const rowsLabel = table.querySelectorAll('.vertical-label');
75
+ rowsLabel.forEach((cell) => {
76
+ const rowResizer = this.renderer.createElement('div');
77
+ this.renderer.appendChild(cell, rowResizer);
78
+ rowResizer.setAttribute('class', 'row-resizer');
79
+ this.renderer.setStyle(cell, 'height', 'inherit');
80
+ this.renderer.setStyle(cell, 'position', 'relative');
81
+ this.renderer.setAttribute(rowResizer, 'style', 'cursor: row-resize; height:8px; position:absolute;bottom:0;left:0;right:0');
82
+ });
83
+ }
84
+ _putBodyCellsContentIntoDiv() {
85
+ const table = this._table;
86
+ const bodyCells = table.querySelectorAll('body td:not(.vertical-label)');
87
+ bodyCells.forEach((cell) => {
88
+ const contentContainer = this.renderer.createElement('div');
89
+ cell.children.forEach((child) => {
90
+ contentContainer.appendChild(child);
91
+ });
92
+ this.renderer.setStyle(cell, 'overflow', 'hidden');
93
+ this.renderer.setStyle(cell, 'height', 'inherit');
94
+ this.renderer.setStyle(contentContainer, 'height', 'inherit');
95
+ this.renderer.setStyle(contentContainer, 'display', 'block');
96
+ cell.appendChild(contentContainer);
97
+ });
98
+ }
99
+ _getSideCell(currentCell) {
100
+ const currentRow = this._currentCell.parentNode?.children;
101
+ if (currentRow) {
102
+ const cellIndexInRow = Array.from(currentRow).indexOf(currentCell);
103
+ return Array.from(currentRow)[cellIndexInRow + 1];
104
+ }
105
+ return null;
106
+ }
107
+ _changeWidth(fitWidth, sideCell, currentCell, changedCurrentCellWidth, changedSideCellWidth) {
108
+ if (fitWidth) {
109
+ if (sideCell && changedCurrentCellWidth >= this.minWidth && changedSideCellWidth >= this.minWidth) {
110
+ this.renderer.setStyle(sideCell, 'width', changedSideCellWidth + 'px');
111
+ this.renderer.setStyle(sideCell, 'min-width', changedSideCellWidth + 'px');
112
+ this.renderer.setStyle(currentCell, 'width', changedCurrentCellWidth + 'px');
113
+ this.renderer.setStyle(currentCell, 'min-width', changedCurrentCellWidth + 'px');
114
+ }
115
+ }
116
+ else if (changedCurrentCellWidth >= this.minWidth) {
117
+ this.renderer.setStyle(currentCell, 'width', changedCurrentCellWidth + 'px');
118
+ this.renderer.setStyle(currentCell, 'min-width', changedCurrentCellWidth + 'px');
119
+ }
120
+ }
121
+ _changeHeight(currentCell, changedHeight, minHeight) {
122
+ if (changedHeight > minHeight) {
123
+ this.renderer.setStyle(currentCell.closest('tr'), 'height', changedHeight + 'px');
124
+ }
125
+ }
126
+ _initTable() {
127
+ if (this._isInitTable) {
128
+ return;
129
+ }
130
+ this._isInitTable = true;
131
+ const table = this._table;
132
+ const parent = table.parentElement;
133
+ this.renderer.setStyle(parent, 'overflow-x', this.fitWidth ? 'hidden' : 'auto');
134
+ // this.renderer.setStyle(parent, 'overflow-y', 'auto');
135
+ this.renderer.setStyle(parent, 'width', '100%');
136
+ }
137
+ _setTableMode(isFitWidth) {
138
+ if (isFitWidth) {
139
+ this._setTableFitSize();
140
+ }
141
+ }
142
+ _setTableFreeSize() {
143
+ const table = this._table;
144
+ this.renderer.setStyle(table, 'width', this.containerWidth + 'px');
145
+ this.renderer.setStyle(table, 'max-width', 'unset');
146
+ this.renderer.setStyle(table, 'min-width', this.containerWidth + 'px');
147
+ const headCells = table.querySelectorAll('th');
148
+ headCells.forEach((cell) => {
149
+ const width = cell.offsetWidth;
150
+ this.renderer.setStyle(cell, 'width', width + 'px');
151
+ this.renderer.setStyle(cell, 'min-width', width + 'px');
152
+ });
153
+ }
154
+ _setTableFitSize() {
155
+ const table = this._table;
156
+ this.renderer.setStyle(table, 'width', '100%');
157
+ this.renderer.setStyle(table, 'max-width', '100%');
158
+ }
159
+ _mouseDown(e) {
160
+ if (e.srcElement.className === 'row-resizer') {
161
+ this._resizeRow(e);
162
+ this.renderer.setStyle(this.el.nativeElement, 'cursor', 'row-resize');
163
+ }
164
+ else if (e.srcElement.className === 'column-resizer') {
165
+ this._resizeColumn(e);
166
+ this.renderer.setStyle(this.el.nativeElement, 'cursor', 'col-resize');
167
+ }
168
+ }
169
+ _mouseMove(e) {
170
+ if (e.buttons !== 0) {
171
+ if (this._currentResizer === "Column" /* Resizer.Column */) {
172
+ if (!this._isInitTable) {
173
+ this._initializeTable();
174
+ }
175
+ const endX = e.pageX;
176
+ const dx = endX - this._startX;
177
+ const changedCurrentCellWidth = this._currentColumnWidth - dx;
178
+ const changedSideCellWidth = this._sideColumnWidth + dx;
179
+ this._changeWidth(this.fitWidth, this._sideCell, this._currentCell, changedCurrentCellWidth, changedSideCellWidth);
180
+ }
181
+ else if (this._currentResizer === "Row" /* Resizer.Row */) {
182
+ const endY = e.pageY;
183
+ const dy = endY - this._startY;
184
+ const changedCurrentRowHeight = this._currentRowHeight + dy;
185
+ this._changeHeight(this._currentCell, changedCurrentRowHeight, this.minHeight);
186
+ }
187
+ }
188
+ }
189
+ _mouseUp() {
190
+ if (this._currentResizer) {
191
+ const table = this.el.nativeElement;
192
+ const headers = table.querySelectorAll('th');
193
+ const columnResized = [];
194
+ for (let i = 0; i < headers.length; i++) {
195
+ const header = headers[i];
196
+ const columnName = header.attributes['columnname']?.value;
197
+ if (typeof columnName !== 'undefined') {
198
+ columnResized.push({ name: columnName, width: header.offsetWidth });
199
+ }
200
+ }
201
+ this.columnResized.emit(columnResized);
202
+ }
203
+ this._currentResizer = null;
204
+ this.renderer.setStyle(this.el.nativeElement, 'cursor', 'default');
205
+ }
206
+ }
207
+ TableResizerDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: TableResizerDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive });
208
+ TableResizerDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.7", type: TableResizerDirective, selector: "[tableResizer]", inputs: { fitWidth: "fitWidth", minWidth: "minWidth", minHeight: "minHeight", containerWidth: "containerWidth", rowResizer: "rowResizer", enableResizing: "enableResizing" }, outputs: { columnResized: "columnResized" }, host: { listeners: { "mousedown": "moseDown($event)", "mousemove": "moseMove($event)" } }, usesInheritance: true, usesOnChanges: true, ngImport: i0 });
209
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: TableResizerDirective, decorators: [{
210
+ type: Directive,
211
+ args: [{
212
+ selector: '[tableResizer]'
213
+ }]
214
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }]; }, propDecorators: { fitWidth: [{
215
+ type: Input
216
+ }], minWidth: [{
217
+ type: Input
218
+ }], minHeight: [{
219
+ type: Input
220
+ }], containerWidth: [{
221
+ type: Input
222
+ }], rowResizer: [{
223
+ type: Input
224
+ }], enableResizing: [{
225
+ type: Input
226
+ }], columnResized: [{
227
+ type: Output
228
+ }], moseDown: [{
229
+ type: HostListener,
230
+ args: ['mousedown', ['$event']]
231
+ }], moseMove: [{
232
+ type: HostListener,
233
+ args: ['mousemove', ['$event']]
234
+ }] } });
235
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-resizer.directive.js","sourceRoot":"","sources":["../../../../../projects/barsa-novin-ray-core/src/lib/directives/table-resizer.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Directive,\n    ElementRef,\n    Input,\n    Renderer2,\n    HostListener,\n    SimpleChanges,\n    OnInit,\n    OnDestroy,\n    AfterViewInit,\n    OnChanges,\n    EventEmitter,\n    Output\n} from '@angular/core';\nimport { fromEvent } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { ColumnResizedArgs } from '../abstract-classes';\nimport { BaseDirective } from './base.directive';\nconst enum Resizer {\n    Row = 'Row',\n    Column = 'Column'\n}\n\n@Directive({\n    selector: '[tableResizer]'\n})\nexport class TableResizerDirective extends BaseDirective implements OnInit, OnDestroy, AfterViewInit, OnChanges {\n    @Input() fitWidth: boolean;\n    @Input() minWidth;\n    @Input() minHeight;\n    @Input() containerWidth: number;\n    @Input() rowResizer: boolean;\n    @Input() enableResizing: boolean;\n    @Output() columnResized = new EventEmitter<Array<ColumnResizedArgs>>();\n    private _currentCell: HTMLTableCellElement;\n    private _sideCell;\n    private _startX;\n    private _startY;\n    private _currentColumnWidth;\n    private _sideColumnWidth;\n    private _currentRowHeight;\n    private _currentResizer: Resizer | null;\n    private _isInitTable: boolean;\n    constructor(private el: ElementRef, private renderer: Renderer2) {\n        super();\n        fromEvent(document, 'mouseup')\n            .pipe(takeUntil(this._onDestroy$))\n            .subscribe(() => {\n                this._mouseUp();\n            });\n        fromEvent(document, 'mousemove')\n            .pipe(takeUntil(this._onDestroy$))\n            .subscribe((e) => {\n                this._mouseMove(e);\n            });\n    }\n    private get _table(): HTMLTableElement {\n        return this.el.nativeElement as HTMLTableElement;\n    }\n\n    @HostListener('mousedown', ['$event'])\n    moseDown(e): void {\n        this._mouseDown(e);\n    }\n\n    @HostListener('mousemove', ['$event'])\n    moseMove(e): void {\n        this._mouseMove(e);\n    }\n\n    ngAfterViewInit(): void {\n        if (this.rowResizer) {\n            this._putBodyCellsContentIntoDiv();\n        }\n        if (this.rowResizer) {\n            this._addRowsResizer();\n        }\n        this._setTableMode(this.fitWidth);\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        super.ngOnChanges(changes);\n        const { fitWidth } = changes;\n        if (this.enableResizing && fitWidth && !fitWidth.firstChange) {\n            const newFitWidth = fitWidth.currentValue;\n            this._setTableMode(newFitWidth);\n        }\n    }\n    private _initializeTable(): void {\n        this._initTable();\n        this._setTableMode(this.fitWidth);\n    }\n    private _resizeRow(event): void {\n        this._currentResizer = Resizer.Row;\n        const elementFromPoint = document.elementFromPoint(event.pageX, event.pageY);\n        this._currentCell = elementFromPoint?.closest('td') as HTMLTableCellElement;\n        this._startY = event.pageY;\n        this._currentRowHeight = this._currentCell?.clientHeight || 0;\n    }\n\n    private _resizeColumn(event): void {\n        if (!this.fitWidth) {\n            this._setTableFreeSize();\n        }\n        this._currentResizer = Resizer.Column;\n        const elementFromPoint = document.elementFromPoint(event.pageX, event.pageY);\n        this._currentCell = elementFromPoint?.closest('th') as HTMLTableCellElement;\n        this._startX = event.pageX;\n        this._currentColumnWidth = this._currentCell?.clientWidth || 0;\n        this._sideCell = this._getSideCell(this._currentCell);\n        this._sideColumnWidth = this._sideCell?.clientWidth;\n    }\n\n    private _addRowsResizer(): void {\n        const table = this._table;\n        const rowsLabel = table.querySelectorAll('.vertical-label');\n        rowsLabel.forEach((cell) => {\n            const rowResizer = this.renderer.createElement('div');\n\n            this.renderer.appendChild(cell, rowResizer);\n\n            rowResizer.setAttribute('class', 'row-resizer');\n            this.renderer.setStyle(cell, 'height', 'inherit');\n            this.renderer.setStyle(cell, 'position', 'relative');\n            this.renderer.setAttribute(\n                rowResizer,\n                'style',\n                'cursor: row-resize; height:8px; position:absolute;bottom:0;left:0;right:0'\n            );\n        });\n    }\n\n    private _putBodyCellsContentIntoDiv(): void {\n        const table = this._table as any;\n        const bodyCells = table.querySelectorAll('body td:not(.vertical-label)');\n        bodyCells.forEach((cell) => {\n            const contentContainer = this.renderer.createElement('div');\n            cell.children.forEach((child) => {\n                contentContainer.appendChild(child);\n            });\n            this.renderer.setStyle(cell, 'overflow', 'hidden');\n            this.renderer.setStyle(cell, 'height', 'inherit');\n            this.renderer.setStyle(contentContainer, 'height', 'inherit');\n            this.renderer.setStyle(contentContainer, 'display', 'block');\n\n            cell.appendChild(contentContainer);\n        });\n    }\n\n    private _getSideCell(currentCell): Element | null {\n        const currentRow = this._currentCell.parentNode?.children;\n        if (currentRow) {\n            const cellIndexInRow = Array.from(currentRow).indexOf(currentCell);\n            return Array.from(currentRow)[cellIndexInRow + 1];\n        }\n        return null;\n    }\n\n    private _changeWidth(\n        fitWidth: boolean,\n        sideCell,\n        currentCell,\n        changedCurrentCellWidth,\n        changedSideCellWidth\n    ): void {\n        if (fitWidth) {\n            if (sideCell && changedCurrentCellWidth >= this.minWidth && changedSideCellWidth >= this.minWidth) {\n                this.renderer.setStyle(sideCell, 'width', changedSideCellWidth + 'px');\n                this.renderer.setStyle(sideCell, 'min-width', changedSideCellWidth + 'px');\n                this.renderer.setStyle(currentCell, 'width', changedCurrentCellWidth + 'px');\n                this.renderer.setStyle(currentCell, 'min-width', changedCurrentCellWidth + 'px');\n            }\n        } else if (changedCurrentCellWidth >= this.minWidth) {\n            this.renderer.setStyle(currentCell, 'width', changedCurrentCellWidth + 'px');\n            this.renderer.setStyle(currentCell, 'min-width', changedCurrentCellWidth + 'px');\n        }\n    }\n\n    private _changeHeight(currentCell, changedHeight, minHeight): void {\n        if (changedHeight > minHeight) {\n            this.renderer.setStyle(currentCell.closest('tr'), 'height', changedHeight + 'px');\n        }\n    }\n    private _initTable(): void {\n        if (this._isInitTable) {\n            return;\n        }\n        this._isInitTable = true;\n        const table: HTMLTableElement = this._table;\n        const parent = table.parentElement;\n        this.renderer.setStyle(parent, 'overflow-x', this.fitWidth ? 'hidden' : 'auto');\n        // this.renderer.setStyle(parent, 'overflow-y', 'auto');\n        this.renderer.setStyle(parent, 'width', '100%');\n    }\n\n    private _setTableMode(isFitWidth): void {\n        if (isFitWidth) {\n            this._setTableFitSize();\n        }\n    }\n\n    private _setTableFreeSize(): void {\n        const table = this._table;\n        this.renderer.setStyle(table, 'width', this.containerWidth + 'px');\n        this.renderer.setStyle(table, 'max-width', 'unset');\n        this.renderer.setStyle(table, 'min-width', this.containerWidth + 'px');\n        const headCells = table.querySelectorAll('th');\n        headCells.forEach((cell) => {\n            const width = cell.offsetWidth;\n            this.renderer.setStyle(cell, 'width', width + 'px');\n            this.renderer.setStyle(cell, 'min-width', width + 'px');\n        });\n    }\n\n    private _setTableFitSize(): void {\n        const table = this._table;\n        this.renderer.setStyle(table, 'width', '100%');\n        this.renderer.setStyle(table, 'max-width', '100%');\n    }\n\n    private _mouseDown(e): void {\n        if (e.srcElement.className === 'row-resizer') {\n            this._resizeRow(e);\n            this.renderer.setStyle(this.el.nativeElement, 'cursor', 'row-resize');\n        } else if (e.srcElement.className === 'column-resizer') {\n            this._resizeColumn(e);\n            this.renderer.setStyle(this.el.nativeElement, 'cursor', 'col-resize');\n        }\n    }\n\n    private _mouseMove(e): void {\n        if (e.buttons !== 0) {\n            if (this._currentResizer === Resizer.Column) {\n                if (!this._isInitTable) {\n                    this._initializeTable();\n                }\n                const endX = e.pageX;\n                const dx = endX - this._startX;\n                const changedCurrentCellWidth = this._currentColumnWidth - dx;\n                const changedSideCellWidth = this._sideColumnWidth + dx;\n                this._changeWidth(\n                    this.fitWidth,\n                    this._sideCell,\n                    this._currentCell,\n                    changedCurrentCellWidth,\n                    changedSideCellWidth\n                );\n            } else if (this._currentResizer === Resizer.Row) {\n                const endY = e.pageY;\n                const dy = endY - this._startY;\n                const changedCurrentRowHeight = this._currentRowHeight + dy;\n                this._changeHeight(this._currentCell, changedCurrentRowHeight, this.minHeight);\n            }\n        }\n    }\n\n    private _mouseUp(): void {\n        if (this._currentResizer) {\n            const table = this.el.nativeElement;\n            const headers = table.querySelectorAll('th');\n            const columnResized: ColumnResizedArgs[] = [];\n            for (let i = 0; i < headers.length; i++) {\n                const header = headers[i];\n                const columnName = header.attributes['columnname']?.value;\n                if (typeof columnName !== 'undefined') {\n                    columnResized.push({ name: columnName, width: header.offsetWidth });\n                }\n            }\n            this.columnResized.emit(columnResized);\n        }\n        this._currentResizer = null;\n        this.renderer.setStyle(this.el.nativeElement, 'cursor', 'default');\n    }\n}\n"]}
@@ -0,0 +1,41 @@
1
+ import { Directive, EventEmitter, HostListener, Input, Output } from '@angular/core';
2
+ import { BaseDirective } from './base.directive';
3
+ import * as i0 from "@angular/core";
4
+ export class UlvCommandDirective extends BaseDirective {
5
+ constructor() {
6
+ super();
7
+ this.commandClick = new EventEmitter();
8
+ }
9
+ onClick(event) {
10
+ const button = this.ulvCommandHandler;
11
+ event.stopPropagation();
12
+ event.preventDefault();
13
+ this.commandClick.emit(button);
14
+ setTimeout(() => {
15
+ // add settimeout because we need select row before execute row
16
+ if (button.Command && button.Command.Handler) {
17
+ button.Command.Handler(button);
18
+ }
19
+ else if (button.handler) {
20
+ button.handler.bind(button.scope)(button);
21
+ }
22
+ });
23
+ return false;
24
+ }
25
+ }
26
+ UlvCommandDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: UlvCommandDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
27
+ UlvCommandDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.7", type: UlvCommandDirective, selector: "[ulvCommandHandler]", inputs: { ulvCommandHandler: "ulvCommandHandler" }, outputs: { commandClick: "commandClick" }, host: { listeners: { "click": "onClick($event)" } }, usesInheritance: true, ngImport: i0 });
28
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: UlvCommandDirective, decorators: [{
29
+ type: Directive,
30
+ args: [{
31
+ selector: '[ulvCommandHandler]'
32
+ }]
33
+ }], ctorParameters: function () { return []; }, propDecorators: { ulvCommandHandler: [{
34
+ type: Input
35
+ }], commandClick: [{
36
+ type: Output
37
+ }], onClick: [{
38
+ type: HostListener,
39
+ args: ['click', ['$event']]
40
+ }] } });
41
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidWx2LWNvbW1hbmQuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2Etbm92aW4tcmF5LWNvcmUvc3JjL2xpYi9kaXJlY3RpdmVzL3Vsdi1jb21tYW5kLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNyRixPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sa0JBQWtCLENBQUM7O0FBS2pELE1BQU0sT0FBTyxtQkFBb0IsU0FBUSxhQUFhO0lBR2xEO1FBQ0ksS0FBSyxFQUFFLENBQUM7UUFGRixpQkFBWSxHQUFHLElBQUksWUFBWSxFQUFFLENBQUM7SUFHNUMsQ0FBQztJQUVELE9BQU8sQ0FBQyxLQUFVO1FBQ2QsTUFBTSxNQUFNLEdBQUcsSUFBSSxDQUFDLGlCQUFpQixDQUFDO1FBQ3RDLEtBQUssQ0FBQyxlQUFlLEVBQUUsQ0FBQztRQUN4QixLQUFLLENBQUMsY0FBYyxFQUFFLENBQUM7UUFDdkIsSUFBSSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDL0IsVUFBVSxDQUFDLEdBQUcsRUFBRTtZQUNaLCtEQUErRDtZQUMvRCxJQUFJLE1BQU0sQ0FBQyxPQUFPLElBQUksTUFBTSxDQUFDLE9BQU8sQ0FBQyxPQUFPLEVBQUU7Z0JBQzFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQyxDQUFDO2FBQ2xDO2lCQUFNLElBQUksTUFBTSxDQUFDLE9BQU8sRUFBRTtnQkFDdkIsTUFBTSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxDQUFDLE1BQU0sQ0FBQyxDQUFDO2FBQzdDO1FBQ0wsQ0FBQyxDQUFDLENBQUM7UUFFSCxPQUFPLEtBQUssQ0FBQztJQUNqQixDQUFDOztnSEF0QlEsbUJBQW1CO29HQUFuQixtQkFBbUI7MkZBQW5CLG1CQUFtQjtrQkFIL0IsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUscUJBQXFCO2lCQUNsQzswRUFFWSxpQkFBaUI7c0JBQXpCLEtBQUs7Z0JBQ0ksWUFBWTtzQkFBckIsTUFBTTtnQkFLUCxPQUFPO3NCQUROLFlBQVk7dUJBQUMsT0FBTyxFQUFFLENBQUMsUUFBUSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBFdmVudEVtaXR0ZXIsIEhvc3RMaXN0ZW5lciwgSW5wdXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQmFzZURpcmVjdGl2ZSB9IGZyb20gJy4vYmFzZS5kaXJlY3RpdmUnO1xuXG5ARGlyZWN0aXZlKHtcbiAgICBzZWxlY3RvcjogJ1t1bHZDb21tYW5kSGFuZGxlcl0nXG59KVxuZXhwb3J0IGNsYXNzIFVsdkNvbW1hbmREaXJlY3RpdmUgZXh0ZW5kcyBCYXNlRGlyZWN0aXZlIHtcbiAgICBASW5wdXQoKSB1bHZDb21tYW5kSGFuZGxlcjogYW55O1xuICAgIEBPdXRwdXQoKSBjb21tYW5kQ2xpY2sgPSBuZXcgRXZlbnRFbWl0dGVyKCk7XG4gICAgY29uc3RydWN0b3IoKSB7XG4gICAgICAgIHN1cGVyKCk7XG4gICAgfVxuICAgIEBIb3N0TGlzdGVuZXIoJ2NsaWNrJywgWyckZXZlbnQnXSlcbiAgICBvbkNsaWNrKGV2ZW50OiBhbnkpOiBib29sZWFuIHtcbiAgICAgICAgY29uc3QgYnV0dG9uID0gdGhpcy51bHZDb21tYW5kSGFuZGxlcjtcbiAgICAgICAgZXZlbnQuc3RvcFByb3BhZ2F0aW9uKCk7XG4gICAgICAgIGV2ZW50LnByZXZlbnREZWZhdWx0KCk7XG4gICAgICAgIHRoaXMuY29tbWFuZENsaWNrLmVtaXQoYnV0dG9uKTtcbiAgICAgICAgc2V0VGltZW91dCgoKSA9PiB7XG4gICAgICAgICAgICAvLyBhZGQgc2V0dGltZW91dCBiZWNhdXNlIHdlIG5lZWQgc2VsZWN0IHJvdyBiZWZvcmUgZXhlY3V0ZSByb3dcbiAgICAgICAgICAgIGlmIChidXR0b24uQ29tbWFuZCAmJiBidXR0b24uQ29tbWFuZC5IYW5kbGVyKSB7XG4gICAgICAgICAgICAgICAgYnV0dG9uLkNvbW1hbmQuSGFuZGxlcihidXR0b24pO1xuICAgICAgICAgICAgfSBlbHNlIGlmIChidXR0b24uaGFuZGxlcikge1xuICAgICAgICAgICAgICAgIGJ1dHRvbi5oYW5kbGVyLmJpbmQoYnV0dG9uLnNjb3BlKShidXR0b24pO1xuICAgICAgICAgICAgfVxuICAgICAgICB9KTtcblxuICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgfVxufVxuIl19
@@ -0,0 +1,51 @@
1
+ import { Directive, Input } from '@angular/core';
2
+ import { Subject } from 'rxjs';
3
+ import { takeUntil } from 'rxjs/operators';
4
+ import { BaseDirective } from './base.directive';
5
+ import { fromIntersectionObserver } from '../from-intersection-observer';
6
+ import * as i0 from "@angular/core";
7
+ export class UntilInViewDirective extends BaseDirective {
8
+ constructor(_templateRef, _vcr, _cdr) {
9
+ super();
10
+ this._templateRef = _templateRef;
11
+ this._vcr = _vcr;
12
+ this._cdr = _cdr;
13
+ this.intersectionDebounce = 100;
14
+ this.viewed$ = new Subject();
15
+ }
16
+ viewed() {
17
+ this.viewed$.next();
18
+ this._vcr.createEmbeddedView(this._templateRef);
19
+ this._cdr.detectChanges();
20
+ }
21
+ ngOnInit() {
22
+ super.ngOnInit();
23
+ const element = this.untilInView.nativeElement;
24
+ const config = {
25
+ root: null,
26
+ rootMargin: '0px',
27
+ threshold: 0
28
+ };
29
+ fromIntersectionObserver(element, config, this.intersectionDebounce)
30
+ .pipe(takeUntil(this.viewed$), takeUntil(this._onDestroy$))
31
+ .subscribe(() => {
32
+ this.viewed();
33
+ });
34
+ }
35
+ ngOnDestroy() {
36
+ this._onDestroy$.next();
37
+ }
38
+ }
39
+ UntilInViewDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: UntilInViewDirective, deps: [{ token: i0.TemplateRef }, { token: i0.ViewContainerRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Directive });
40
+ UntilInViewDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.7", type: UntilInViewDirective, selector: "[untilInView]", inputs: { untilInView: "untilInView", intersectionDebounce: "intersectionDebounce" }, usesInheritance: true, ngImport: i0 });
41
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: UntilInViewDirective, decorators: [{
42
+ type: Directive,
43
+ args: [{
44
+ selector: '[untilInView]'
45
+ }]
46
+ }], ctorParameters: function () { return [{ type: i0.TemplateRef }, { type: i0.ViewContainerRef }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { untilInView: [{
47
+ type: Input
48
+ }], intersectionDebounce: [{
49
+ type: Input
50
+ }] } });
51
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidW50aWwtaW52aWV3LmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2JhcnNhLW5vdmluLXJheS1jb3JlL3NyYy9saWIvZGlyZWN0aXZlcy91bnRpbC1pbnZpZXcuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFFSCxTQUFTLEVBRVQsS0FBSyxFQUtSLE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDL0IsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBRTNDLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUNqRCxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQzs7QUFLekUsTUFBTSxPQUFPLG9CQUFxQixTQUFRLGFBQWE7SUFJbkQsWUFDWSxZQUE4QixFQUM5QixJQUFzQixFQUN0QixJQUF1QjtRQUUvQixLQUFLLEVBQUUsQ0FBQztRQUpBLGlCQUFZLEdBQVosWUFBWSxDQUFrQjtRQUM5QixTQUFJLEdBQUosSUFBSSxDQUFrQjtRQUN0QixTQUFJLEdBQUosSUFBSSxDQUFtQjtRQUwxQix5QkFBb0IsR0FBRyxHQUFHLENBQUM7UUFDNUIsWUFBTyxHQUFHLElBQUksT0FBTyxFQUFRLENBQUM7SUFPdEMsQ0FBQztJQUVNLE1BQU07UUFDVCxJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksRUFBRSxDQUFDO1FBQ3BCLElBQUksQ0FBQyxJQUFJLENBQUMsa0JBQWtCLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxDQUFDO1FBQ2hELElBQUksQ0FBQyxJQUFJLENBQUMsYUFBYSxFQUFFLENBQUM7SUFDOUIsQ0FBQztJQUVELFFBQVE7UUFDSixLQUFLLENBQUMsUUFBUSxFQUFFLENBQUM7UUFDakIsTUFBTSxPQUFPLEdBQUcsSUFBSSxDQUFDLFdBQVcsQ0FBQyxhQUFhLENBQUM7UUFDL0MsTUFBTSxNQUFNLEdBQUc7WUFDWCxJQUFJLEVBQUUsSUFBSTtZQUNWLFVBQVUsRUFBRSxLQUFLO1lBQ2pCLFNBQVMsRUFBRSxDQUFDO1NBQ2YsQ0FBQztRQUNGLHdCQUF3QixDQUFDLE9BQU8sRUFBRSxNQUFNLEVBQUUsSUFBSSxDQUFDLG9CQUFvQixDQUFDO2FBQy9ELElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxFQUFFLFNBQVMsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLENBQUM7YUFDMUQsU0FBUyxDQUFDLEdBQUcsRUFBRTtZQUNaLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQztRQUNsQixDQUFDLENBQUMsQ0FBQztJQUNYLENBQUM7SUFFRCxXQUFXO1FBQ1AsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUM1QixDQUFDOztpSEFuQ1Esb0JBQW9CO3FHQUFwQixvQkFBb0I7MkZBQXBCLG9CQUFvQjtrQkFIaEMsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUsZUFBZTtpQkFDNUI7aUtBRVksV0FBVztzQkFBbkIsS0FBSztnQkFDRyxvQkFBb0I7c0JBQTVCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICAgIENoYW5nZURldGVjdG9yUmVmLFxuICAgIERpcmVjdGl2ZSxcbiAgICBFbGVtZW50UmVmLFxuICAgIElucHV0LFxuICAgIE9uRGVzdHJveSxcbiAgICBPbkluaXQsXG4gICAgVGVtcGxhdGVSZWYsXG4gICAgVmlld0NvbnRhaW5lclJlZlxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFN1YmplY3QgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IHRha2VVbnRpbCB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcblxuaW1wb3J0IHsgQmFzZURpcmVjdGl2ZSB9IGZyb20gJy4vYmFzZS5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgZnJvbUludGVyc2VjdGlvbk9ic2VydmVyIH0gZnJvbSAnLi4vZnJvbS1pbnRlcnNlY3Rpb24tb2JzZXJ2ZXInO1xuXG5ARGlyZWN0aXZlKHtcbiAgICBzZWxlY3RvcjogJ1t1bnRpbEluVmlld10nXG59KVxuZXhwb3J0IGNsYXNzIFVudGlsSW5WaWV3RGlyZWN0aXZlIGV4dGVuZHMgQmFzZURpcmVjdGl2ZSBpbXBsZW1lbnRzIE9uSW5pdCwgT25EZXN0cm95IHtcbiAgICBASW5wdXQoKSB1bnRpbEluVmlldzogRWxlbWVudFJlZjtcbiAgICBASW5wdXQoKSBpbnRlcnNlY3Rpb25EZWJvdW5jZSA9IDEwMDtcbiAgICBwcml2YXRlIHZpZXdlZCQgPSBuZXcgU3ViamVjdDx2b2lkPigpO1xuICAgIGNvbnN0cnVjdG9yKFxuICAgICAgICBwcml2YXRlIF90ZW1wbGF0ZVJlZjogVGVtcGxhdGVSZWY8YW55PixcbiAgICAgICAgcHJpdmF0ZSBfdmNyOiBWaWV3Q29udGFpbmVyUmVmLFxuICAgICAgICBwcml2YXRlIF9jZHI6IENoYW5nZURldGVjdG9yUmVmXG4gICAgKSB7XG4gICAgICAgIHN1cGVyKCk7XG4gICAgfVxuXG4gICAgcHVibGljIHZpZXdlZCgpOiB2b2lkIHtcbiAgICAgICAgdGhpcy52aWV3ZWQkLm5leHQoKTtcbiAgICAgICAgdGhpcy5fdmNyLmNyZWF0ZUVtYmVkZGVkVmlldyh0aGlzLl90ZW1wbGF0ZVJlZik7XG4gICAgICAgIHRoaXMuX2Nkci5kZXRlY3RDaGFuZ2VzKCk7XG4gICAgfVxuXG4gICAgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgICAgIHN1cGVyLm5nT25Jbml0KCk7XG4gICAgICAgIGNvbnN0IGVsZW1lbnQgPSB0aGlzLnVudGlsSW5WaWV3Lm5hdGl2ZUVsZW1lbnQ7XG4gICAgICAgIGNvbnN0IGNvbmZpZyA9IHtcbiAgICAgICAgICAgIHJvb3Q6IG51bGwsXG4gICAgICAgICAgICByb290TWFyZ2luOiAnMHB4JyxcbiAgICAgICAgICAgIHRocmVzaG9sZDogMFxuICAgICAgICB9O1xuICAgICAgICBmcm9tSW50ZXJzZWN0aW9uT2JzZXJ2ZXIoZWxlbWVudCwgY29uZmlnLCB0aGlzLmludGVyc2VjdGlvbkRlYm91bmNlKVxuICAgICAgICAgICAgLnBpcGUodGFrZVVudGlsKHRoaXMudmlld2VkJCksIHRha2VVbnRpbCh0aGlzLl9vbkRlc3Ryb3kkKSlcbiAgICAgICAgICAgIC5zdWJzY3JpYmUoKCkgPT4ge1xuICAgICAgICAgICAgICAgIHRoaXMudmlld2VkKCk7XG4gICAgICAgICAgICB9KTtcbiAgICB9XG5cbiAgICBuZ09uRGVzdHJveSgpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5fb25EZXN0cm95JC5uZXh0KCk7XG4gICAgfVxufVxuIl19
@@ -0,0 +1,89 @@
1
+ import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, ViewChild, ViewContainerRef } from '@angular/core';
2
+ import { takeUntil, tap } from 'rxjs';
3
+ import { BaseComponent } from '../base.component';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "../services";
6
+ export class BaseDynamicComponent extends BaseComponent {
7
+ constructor(_portalService, _injector) {
8
+ super();
9
+ this._portalService = _portalService;
10
+ this._injector = _injector;
11
+ this.events = new EventEmitter();
12
+ }
13
+ async ngOnInit() {
14
+ super.ngOnInit();
15
+ this._renderComponentInstance();
16
+ }
17
+ ngOnChanges(changes) {
18
+ if (!this._component?.instance) {
19
+ return;
20
+ }
21
+ // const changesKey = Object.keys(changes);
22
+ // changesKey
23
+ // .filter((c) => !changes[c].firstChange)
24
+ // .forEach((c) => (this._component.instance[c] = changes[c].currentValue));
25
+ this._component.instance.ngOnChanges(changes);
26
+ }
27
+ ngOnDestroy() {
28
+ this._destroyComponentInstance();
29
+ }
30
+ async _renderComponentInstance() {
31
+ this._destroyComponentInstance();
32
+ if (!this.component) {
33
+ return;
34
+ }
35
+ const { Module, ModuleFileName, Name, Selector } = this.component;
36
+ this._portalService
37
+ .getComponent(Module, ModuleFileName, Name, Selector, this._injector)
38
+ .pipe(takeUntil(this._onDestroy$))
39
+ .subscribe((componentRef) => {
40
+ this._container.insert(componentRef.hostView);
41
+ this._component = componentRef;
42
+ if (this.component.Parameters) {
43
+ this._component.instance.parameters = this.component.Parameters;
44
+ }
45
+ if (this.value) {
46
+ this._component.instance.value = this.value;
47
+ }
48
+ this.setComponentInputs();
49
+ const events = this._component.instance.events;
50
+ if (events) {
51
+ events
52
+ .pipe(takeUntil(this._onDestroy$), tap((c) => this.events.emit(c)))
53
+ .subscribe();
54
+ }
55
+ });
56
+ this.setComponentInputs();
57
+ }
58
+ setComponentInputs() {
59
+ const inputProperties = Object.keys(this).filter((c) => !c.startsWith('_') && c !== 'events');
60
+ inputProperties.forEach((c) => {
61
+ this._component.instance[c] = this[c];
62
+ });
63
+ }
64
+ _destroyComponentInstance() {
65
+ if (this._component) {
66
+ this._component.destroy();
67
+ }
68
+ }
69
+ }
70
+ BaseDynamicComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: BaseDynamicComponent, deps: [{ token: i1.PortalService }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Component });
71
+ BaseDynamicComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: BaseDynamicComponent, selector: "bnrc-dynamic-component", inputs: { component: "component", value: "value" }, outputs: { events: "events" }, viewQueries: [{ propertyName: "_container", first: true, predicate: ["componentContainer"], descendants: true, read: ViewContainerRef, static: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: `<ng-container #componentContainer></ng-container>`, isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush });
72
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: BaseDynamicComponent, decorators: [{
73
+ type: Component,
74
+ args: [{
75
+ selector: 'bnrc-dynamic-component',
76
+ template: `<ng-container #componentContainer></ng-container>`,
77
+ changeDetection: ChangeDetectionStrategy.OnPush
78
+ }]
79
+ }], ctorParameters: function () { return [{ type: i1.PortalService }, { type: i0.Injector }]; }, propDecorators: { _container: [{
80
+ type: ViewChild,
81
+ args: ['componentContainer', { read: ViewContainerRef, static: true }]
82
+ }], component: [{
83
+ type: Input
84
+ }], value: [{
85
+ type: Input
86
+ }], events: [{
87
+ type: Output
88
+ }] } });
89
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-dynamic.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-novin-ray-core/src/lib/dynamic-component/base-dynamic.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    ComponentRef,\n    EventEmitter,\n    Injector,\n    Input,\n    OnChanges,\n    OnDestroy,\n    OnInit,\n    Output,\n    SimpleChanges,\n    ViewChild,\n    ViewContainerRef\n} from '@angular/core';\nimport { takeUntil, tap } from 'rxjs';\nimport { EjrayOlgo } from '../abstract-classes';\nimport { BaseComponent } from '../base.component';\nimport { PortalService } from '../services';\n\n@Component({\n    selector: 'bnrc-dynamic-component',\n    template: `<ng-container #componentContainer></ng-container>`,\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class BaseDynamicComponent extends BaseComponent implements OnInit, OnDestroy, OnChanges {\n    @ViewChild('componentContainer', { read: ViewContainerRef, static: true })\n    _container: ViewContainerRef;\n    @Input() component: EjrayOlgo;\n    @Input() value: any;\n    @Output() events = new EventEmitter<{ title: string; data?: any }>();\n    public _component: ComponentRef<any>;\n    constructor(protected _portalService: PortalService, protected _injector: Injector) {\n        super();\n    }\n    async ngOnInit(): Promise<void> {\n        super.ngOnInit();\n        this._renderComponentInstance();\n    }\n    ngOnChanges(changes: SimpleChanges): void {\n        if (!this._component?.instance) {\n            return;\n        }\n        // const changesKey = Object.keys(changes);\n        // changesKey\n        //     .filter((c) => !changes[c].firstChange)\n        //     .forEach((c) => (this._component.instance[c] = changes[c].currentValue));\n\n        this._component.instance.ngOnChanges(changes);\n    }\n    ngOnDestroy(): void {\n        this._destroyComponentInstance();\n    }\n\n    protected async _renderComponentInstance(): Promise<void> {\n        this._destroyComponentInstance();\n        if (!this.component) {\n            return;\n        }\n        const { Module, ModuleFileName, Name, Selector } = this.component;\n        this._portalService\n            .getComponent(Module, ModuleFileName, Name, Selector, this._injector)\n            .pipe(takeUntil(this._onDestroy$))\n            .subscribe((componentRef: ComponentRef<any>) => {\n                this._container.insert(componentRef.hostView);\n                this._component = componentRef;\n                if (this.component.Parameters) {\n                    this._component.instance.parameters = this.component.Parameters;\n                }\n                if (this.value) {\n                    this._component.instance.value = this.value;\n                }\n                this.setComponentInputs();\n                const events = this._component.instance.events as EventEmitter<{ title: string; data?: any }>;\n                if (events) {\n                    events\n                        .pipe(\n                            takeUntil(this._onDestroy$),\n                            tap((c) => this.events.emit(c))\n                        )\n                        .subscribe();\n                }\n            });\n        this.setComponentInputs();\n    }\n\n    protected setComponentInputs(): void {\n        const inputProperties = Object.keys(this).filter((c) => !c.startsWith('_') && c !== 'events');\n        inputProperties.forEach((c) => {\n            this._component.instance[c] = this[c];\n        });\n    }\n\n    protected _destroyComponentInstance(): void {\n        if (this._component) {\n            this._component.destroy();\n        }\n    }\n}\n"]}