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.
- package/README.md +25 -0
- package/esm2020/barsa-novin-ray-core.mjs +5 -0
- package/esm2020/lib/abstract-classes/application-base.mjs +24 -0
- package/esm2020/lib/abstract-classes/barsa-api.mjs +40 -0
- package/esm2020/lib/abstract-classes/field-base.mjs +167 -0
- package/esm2020/lib/abstract-classes/files-validation-helper.mjs +71 -0
- package/esm2020/lib/abstract-classes/form-base.mjs +101 -0
- package/esm2020/lib/abstract-classes/form-props.base.mjs +79 -0
- package/esm2020/lib/abstract-classes/form-toolbar-base.mjs +45 -0
- package/esm2020/lib/abstract-classes/index.mjs +21 -0
- package/esm2020/lib/abstract-classes/layout-item-base.mjs +33 -0
- package/esm2020/lib/abstract-classes/layout-panel-base.mjs +80 -0
- package/esm2020/lib/abstract-classes/models.mjs +172 -0
- package/esm2020/lib/abstract-classes/module-with-dynamic-components.mjs +2 -0
- package/esm2020/lib/abstract-classes/number-base.mjs +117 -0
- package/esm2020/lib/abstract-classes/page-base.mjs +97 -0
- package/esm2020/lib/abstract-classes/report-base.mjs +231 -0
- package/esm2020/lib/abstract-classes/report-item-base.mjs +53 -0
- package/esm2020/lib/abstract-classes/report-view-base.component.mjs +262 -0
- package/esm2020/lib/abstract-classes/system-base.mjs +24 -0
- package/esm2020/lib/auth-guard.mjs +37 -0
- package/esm2020/lib/barsa-novin-ray-core-routing.module.mjs +18 -0
- package/esm2020/lib/barsa-novin-ray-core.module.mjs +271 -0
- package/esm2020/lib/base-ulv-setting.component.mjs +37 -0
- package/esm2020/lib/base.component.mjs +59 -0
- package/esm2020/lib/base.module.mjs +28 -0
- package/esm2020/lib/constants.mjs +441 -0
- package/esm2020/lib/container.component.mjs +76 -0
- package/esm2020/lib/custom-route-reuse-strategy.mjs +32 -0
- package/esm2020/lib/date-services/date-hijri.service.mjs +127 -0
- package/esm2020/lib/date-services/date-info.mjs +2 -0
- package/esm2020/lib/date-services/date-miladi.service.mjs +124 -0
- package/esm2020/lib/date-services/date-shamsi.service.mjs +129 -0
- package/esm2020/lib/date-services/date.service.mjs +139 -0
- package/esm2020/lib/date-services/index.mjs +6 -0
- package/esm2020/lib/device.mjs +663 -0
- package/esm2020/lib/directives/anchor-scroll.directive.mjs +24 -0
- package/esm2020/lib/directives/attr-rtl.directive.mjs +35 -0
- package/esm2020/lib/directives/base.directive.mjs +51 -0
- package/esm2020/lib/directives/column-resizer.directive.mjs +39 -0
- package/esm2020/lib/directives/dynamic-command.directive.mjs +43 -0
- package/esm2020/lib/directives/ellipsify.directive.mjs +72 -0
- package/esm2020/lib/directives/field-binding.directive.mjs +17 -0
- package/esm2020/lib/directives/img-lazy.directive.mjs +75 -0
- package/esm2020/lib/directives/index.mjs +19 -0
- package/esm2020/lib/directives/intersection-observer.directive.mjs +49 -0
- package/esm2020/lib/directives/items-renderer.directive.mjs +59 -0
- package/esm2020/lib/directives/numbers-only-input.directive.mjs +26 -0
- package/esm2020/lib/directives/placeHolder.directive.mjs +15 -0
- package/esm2020/lib/directives/render-ulv-paging.directive.mjs +58 -0
- package/esm2020/lib/directives/render-ulv-viewer.directive.mjs +60 -0
- package/esm2020/lib/directives/table-resizer.directive.mjs +235 -0
- package/esm2020/lib/directives/ulv-command.directive.mjs +41 -0
- package/esm2020/lib/directives/until-inview.directive.mjs +51 -0
- package/esm2020/lib/dynamic-component/base-dynamic.component.mjs +89 -0
- package/esm2020/lib/dynamic-component/base-form-toolbaritem-props.mjs +50 -0
- package/esm2020/lib/dynamic-component/base-item-content-props.mjs +70 -0
- package/esm2020/lib/dynamic-component/base-view-content-props.mjs +26 -0
- package/esm2020/lib/dynamic-component/base-view-item-props.mjs +374 -0
- package/esm2020/lib/dynamic-component/base-view-props.mjs +127 -0
- package/esm2020/lib/dynamic-component/dynamic-form-toolbar-item.component.mjs +36 -0
- package/esm2020/lib/dynamic-component/dynamic-form.component.mjs +62 -0
- package/esm2020/lib/dynamic-component/dynamic-item.component.mjs +60 -0
- package/esm2020/lib/dynamic-component/index.mjs +10 -0
- package/esm2020/lib/empty-page-with-router-and-router-outlet/empty-page-with-router-and-router-outlet.component.mjs +16 -0
- package/esm2020/lib/field-ui/field-ui.component.mjs +116 -0
- package/esm2020/lib/form/form.component.mjs +151 -0
- package/esm2020/lib/form-new/form-new.component.mjs +30 -0
- package/esm2020/lib/from-intersection-observer.mjs +53 -0
- package/esm2020/lib/global-error-handler.mjs +26 -0
- package/esm2020/lib/modal-root.component.mjs +31 -0
- package/esm2020/lib/not-found/not-found.component.mjs +16 -0
- package/esm2020/lib/pipes/barsa-icon-dict.pipe.mjs +18 -0
- package/esm2020/lib/pipes/bbb-translate.pipe.mjs +29 -0
- package/esm2020/lib/pipes/can-upload.pipe.mjs +30 -0
- package/esm2020/lib/pipes/context-menu.pipe.mjs +40 -0
- package/esm2020/lib/pipes/control-ui.pipe.mjs +31 -0
- package/esm2020/lib/pipes/convert-to-style.pipe.mjs +32 -0
- package/esm2020/lib/pipes/date-time-to-caption.pipe.mjs +34 -0
- package/esm2020/lib/pipes/fileinfo-count.pipe.mjs +20 -0
- package/esm2020/lib/pipes/filter-columns-by-details.pipe.mjs +20 -0
- package/esm2020/lib/pipes/filter-string.pipe.mjs +44 -0
- package/esm2020/lib/pipes/filter-tab.pipe.mjs +19 -0
- package/esm2020/lib/pipes/filter-toolbar-control.pipe.mjs +16 -0
- package/esm2020/lib/pipes/filter.pipe.mjs +33 -0
- package/esm2020/lib/pipes/find-column-by-db-name.pipe.mjs +17 -0
- package/esm2020/lib/pipes/fiori-icon.pipe.mjs +42 -0
- package/esm2020/lib/pipes/groupby.pipe.mjs +48 -0
- package/esm2020/lib/pipes/header-facet-value.pipe.mjs +22 -0
- package/esm2020/lib/pipes/index.mjs +33 -0
- package/esm2020/lib/pipes/list-count.pipe.mjs +17 -0
- package/esm2020/lib/pipes/merge-fields-to-columns.pipe.mjs +42 -0
- package/esm2020/lib/pipes/mo-info-ulv-data.pipe.mjs +24 -0
- package/esm2020/lib/pipes/mo-report-value-concat.pipe.mjs +35 -0
- package/esm2020/lib/pipes/mo-report-value.pipe.mjs +28 -0
- package/esm2020/lib/pipes/mo-value.pipe.mjs +31 -0
- package/esm2020/lib/pipes/multiple-groupby.pipe.mjs +97 -0
- package/esm2020/lib/pipes/numeral.pipe.mjs +40 -0
- package/esm2020/lib/pipes/picture-field-source.pipe.mjs +22 -0
- package/esm2020/lib/pipes/remove-newline.pipe.mjs +20 -0
- package/esm2020/lib/pipes/seperator-fix.pipe.mjs +23 -0
- package/esm2020/lib/pipes/sort.pipe.mjs +48 -0
- package/esm2020/lib/pipes/tlbButtons.pipe.mjs +58 -0
- package/esm2020/lib/pipes/total-summary.pipe.mjs +16 -0
- package/esm2020/lib/pipes/visible-value.pipe.mjs +24 -0
- package/esm2020/lib/portal-page/portal-page.component.mjs +13 -0
- package/esm2020/lib/redirect-home-guard.mjs +28 -0
- package/esm2020/lib/redirect-report-navigator-command/redirect-report-navigator-command.component.mjs +33 -0
- package/esm2020/lib/report-container/report-container.component.mjs +52 -0
- package/esm2020/lib/resolvers/index.mjs +5 -0
- package/esm2020/lib/resolvers/portal-dynamic-page.resolver.mjs +49 -0
- package/esm2020/lib/resolvers/portal-form-page.resolver.mjs +18 -0
- package/esm2020/lib/resolvers/portal-page.resolver.mjs +30 -0
- package/esm2020/lib/resolvers/portal-report-page.resolver.mjs +37 -0
- package/esm2020/lib/root-page/root-page.component.mjs +21 -0
- package/esm2020/lib/root-portal/root-portal.component.mjs +51 -0
- package/esm2020/lib/services/api.service.mjs +60 -0
- package/esm2020/lib/services/barsa-dialog.service.mjs +80 -0
- package/esm2020/lib/services/breadcrumb.service.mjs +60 -0
- package/esm2020/lib/services/container.service.mjs +36 -0
- package/esm2020/lib/services/dynamic-component.service.mjs +55 -0
- package/esm2020/lib/services/form-panel.service.mjs +235 -0
- package/esm2020/lib/services/form.service.mjs +14 -0
- package/esm2020/lib/services/horizontal-layout.service.mjs +16 -0
- package/esm2020/lib/services/index.mjs +16 -0
- package/esm2020/lib/services/layout.service.mjs +42 -0
- package/esm2020/lib/services/log.service.mjs +50 -0
- package/esm2020/lib/services/network-status.service.mjs +15 -0
- package/esm2020/lib/services/portal.service.mjs +638 -0
- package/esm2020/lib/services/ui.service.mjs +23 -0
- package/esm2020/lib/services/ulvmain.service.mjs +594 -0
- package/esm2020/lib/services/upload.service.mjs +75 -0
- package/esm2020/public-api.mjs +33 -0
- package/fesm2015/barsa-novin-ray-core.mjs +9047 -0
- package/fesm2015/barsa-novin-ray-core.mjs.map +1 -0
- package/fesm2020/barsa-novin-ray-core.mjs +8945 -0
- package/fesm2020/barsa-novin-ray-core.mjs.map +1 -0
- package/index.d.ts +5 -0
- package/lib/abstract-classes/application-base.d.ts +53 -0
- package/lib/abstract-classes/barsa-api.d.ts +28 -0
- package/lib/abstract-classes/field-base.d.ts +81 -0
- package/lib/abstract-classes/files-validation-helper.d.ts +15 -0
- package/lib/abstract-classes/form-base.d.ts +59 -0
- package/lib/abstract-classes/form-props.base.d.ts +45 -0
- package/lib/abstract-classes/form-toolbar-base.d.ts +17 -0
- package/lib/abstract-classes/index.d.ts +20 -0
- package/lib/abstract-classes/layout-item-base.d.ts +15 -0
- package/lib/abstract-classes/layout-panel-base.d.ts +24 -0
- package/lib/abstract-classes/models.d.ts +660 -0
- package/lib/abstract-classes/module-with-dynamic-components.d.ts +4 -0
- package/lib/abstract-classes/number-base.d.ts +20 -0
- package/lib/abstract-classes/page-base.d.ts +31 -0
- package/lib/abstract-classes/report-base.d.ts +97 -0
- package/lib/abstract-classes/report-item-base.d.ts +33 -0
- package/lib/abstract-classes/report-view-base.component.d.ts +130 -0
- package/lib/abstract-classes/system-base.d.ts +45 -0
- package/lib/auth-guard.d.ts +12 -0
- package/lib/barsa-novin-ray-core-routing.module.d.ts +7 -0
- package/lib/barsa-novin-ray-core.module.d.ts +88 -0
- package/lib/base-ulv-setting.component.d.ts +18 -0
- package/lib/base.component.d.ts +15 -0
- package/lib/base.module.d.ts +13 -0
- package/lib/constants.d.ts +89 -0
- package/lib/container.component.d.ts +33 -0
- package/lib/custom-route-reuse-strategy.d.ts +11 -0
- package/lib/date-services/date-hijri.service.d.ts +40 -0
- package/lib/date-services/date-info.d.ts +15 -0
- package/lib/date-services/date-miladi.service.d.ts +39 -0
- package/lib/date-services/date-shamsi.service.d.ts +40 -0
- package/lib/date-services/date.service.d.ts +54 -0
- package/lib/date-services/index.d.ts +5 -0
- package/lib/device.d.ts +15 -0
- package/lib/directives/anchor-scroll.directive.d.ts +7 -0
- package/lib/directives/attr-rtl.directive.d.ts +13 -0
- package/lib/directives/base.directive.d.ts +13 -0
- package/lib/directives/column-resizer.directive.d.ts +13 -0
- package/lib/directives/dynamic-command.directive.d.ts +12 -0
- package/lib/directives/ellipsify.directive.d.ts +17 -0
- package/lib/directives/field-binding.directive.d.ts +7 -0
- package/lib/directives/img-lazy.directive.d.ts +20 -0
- package/lib/directives/index.d.ts +18 -0
- package/lib/directives/intersection-observer.directive.d.ts +17 -0
- package/lib/directives/items-renderer.directive.d.ts +17 -0
- package/lib/directives/numbers-only-input.directive.d.ts +9 -0
- package/lib/directives/placeHolder.directive.d.ts +6 -0
- package/lib/directives/render-ulv-paging.directive.d.ts +19 -0
- package/lib/directives/render-ulv-viewer.directive.d.ts +19 -0
- package/lib/directives/table-resizer.directive.d.ts +47 -0
- package/lib/directives/ulv-command.directive.d.ts +11 -0
- package/lib/directives/until-inview.directive.d.ts +17 -0
- package/lib/dynamic-component/base-dynamic.component.d.ts +26 -0
- package/lib/dynamic-component/base-form-toolbaritem-props.d.ts +28 -0
- package/lib/dynamic-component/base-item-content-props.d.ts +40 -0
- package/lib/dynamic-component/base-view-content-props.d.ts +11 -0
- package/lib/dynamic-component/base-view-item-props.d.ts +95 -0
- package/lib/dynamic-component/base-view-props.d.ts +65 -0
- package/lib/dynamic-component/dynamic-form-toolbar-item.component.d.ts +18 -0
- package/lib/dynamic-component/dynamic-form.component.d.ts +33 -0
- package/lib/dynamic-component/dynamic-item.component.d.ts +30 -0
- package/lib/dynamic-component/index.d.ts +9 -0
- package/lib/empty-page-with-router-and-router-outlet/empty-page-with-router-and-router-outlet.component.d.ts +7 -0
- package/lib/field-ui/field-ui.component.d.ts +27 -0
- package/lib/form/form.component.d.ts +36 -0
- package/lib/form-new/form-new.component.d.ts +23 -0
- package/lib/from-intersection-observer.d.ts +7 -0
- package/lib/global-error-handler.d.ts +8 -0
- package/lib/modal-root.component.d.ts +15 -0
- package/lib/not-found/not-found.component.d.ts +8 -0
- package/lib/pipes/barsa-icon-dict.pipe.d.ts +9 -0
- package/lib/pipes/bbb-translate.pipe.d.ts +7 -0
- package/lib/pipes/can-upload.pipe.d.ts +8 -0
- package/lib/pipes/context-menu.pipe.d.ts +11 -0
- package/lib/pipes/control-ui.pipe.d.ts +9 -0
- package/lib/pipes/convert-to-style.pipe.d.ts +8 -0
- package/lib/pipes/date-time-to-caption.pipe.d.ts +9 -0
- package/lib/pipes/fileinfo-count.pipe.d.ts +10 -0
- package/lib/pipes/filter-columns-by-details.pipe.d.ts +8 -0
- package/lib/pipes/filter-string.pipe.d.ts +11 -0
- package/lib/pipes/filter-tab.pipe.d.ts +7 -0
- package/lib/pipes/filter-toolbar-control.pipe.d.ts +8 -0
- package/lib/pipes/filter.pipe.d.ts +10 -0
- package/lib/pipes/find-column-by-db-name.pipe.d.ts +8 -0
- package/lib/pipes/fiori-icon.pipe.d.ts +7 -0
- package/lib/pipes/groupby.pipe.d.ts +7 -0
- package/lib/pipes/header-facet-value.pipe.d.ts +8 -0
- package/lib/pipes/index.d.ts +32 -0
- package/lib/pipes/list-count.pipe.d.ts +8 -0
- package/lib/pipes/merge-fields-to-columns.pipe.d.ts +10 -0
- package/lib/pipes/mo-info-ulv-data.pipe.d.ts +7 -0
- package/lib/pipes/mo-report-value-concat.pipe.d.ts +9 -0
- package/lib/pipes/mo-report-value.pipe.d.ts +12 -0
- package/lib/pipes/mo-value.pipe.d.ts +9 -0
- package/lib/pipes/multiple-groupby.pipe.d.ts +23 -0
- package/lib/pipes/numeral.pipe.d.ts +9 -0
- package/lib/pipes/picture-field-source.pipe.d.ts +8 -0
- package/lib/pipes/remove-newline.pipe.d.ts +8 -0
- package/lib/pipes/seperator-fix.pipe.d.ts +7 -0
- package/lib/pipes/sort.pipe.d.ts +9 -0
- package/lib/pipes/tlbButtons.pipe.d.ts +9 -0
- package/lib/pipes/total-summary.pipe.d.ts +8 -0
- package/lib/pipes/visible-value.pipe.d.ts +8 -0
- package/lib/portal-page/portal-page.component.d.ts +6 -0
- package/lib/redirect-home-guard.d.ts +13 -0
- package/lib/redirect-report-navigator-command/redirect-report-navigator-command.component.d.ts +14 -0
- package/lib/report-container/report-container.component.d.ts +24 -0
- package/lib/resolvers/index.d.ts +4 -0
- package/lib/resolvers/portal-dynamic-page.resolver.d.ts +12 -0
- package/lib/resolvers/portal-form-page.resolver.d.ts +8 -0
- package/lib/resolvers/portal-page.resolver.d.ts +12 -0
- package/lib/resolvers/portal-report-page.resolver.d.ts +12 -0
- package/lib/root-page/root-page.component.d.ts +10 -0
- package/lib/root-portal/root-portal.component.d.ts +14 -0
- package/lib/services/api.service.d.ts +18 -0
- package/lib/services/barsa-dialog.service.d.ts +31 -0
- package/lib/services/breadcrumb.service.d.ts +14 -0
- package/lib/services/container.service.d.ts +14 -0
- package/lib/services/dynamic-component.service.d.ts +13 -0
- package/lib/services/form-panel.service.d.ts +83 -0
- package/lib/services/form.service.d.ts +8 -0
- package/lib/services/horizontal-layout.service.d.ts +7 -0
- package/lib/services/index.d.ts +15 -0
- package/lib/services/layout.service.d.ts +23 -0
- package/lib/services/log.service.d.ts +17 -0
- package/lib/services/network-status.service.d.ts +7 -0
- package/lib/services/portal.service.d.ts +130 -0
- package/lib/services/ui.service.d.ts +14 -0
- package/lib/services/ulvmain.service.d.ts +178 -0
- package/lib/services/upload.service.d.ts +18 -0
- package/package.json +38 -0
- 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":"AAAA,OAAO,EACH,uBAAuB,EACvB,SAAS,EAET,YAAY,EAEZ,KAAK,EAIL,MAAM,EAEN,SAAS,EACT,gBAAgB,EACnB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,SAAS,EAAE,GAAG,EAAE,MAAM,MAAM,CAAC;AAEtC,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;;;AAQlD,MAAM,OAAO,oBAAqB,SAAQ,aAAa;IAOnD,YAAsB,cAA6B,EAAY,SAAmB;QAC9E,KAAK,EAAE,CAAC;QADU,mBAAc,GAAd,cAAc,CAAe;QAAY,cAAS,GAAT,SAAS,CAAU;QAFxE,WAAM,GAAG,IAAI,YAAY,EAAiC,CAAC;IAIrE,CAAC;IACD,KAAK,CAAC,QAAQ;QACV,KAAK,CAAC,QAAQ,EAAE,CAAC;QACjB,IAAI,CAAC,wBAAwB,EAAE,CAAC;IACpC,CAAC;IACD,WAAW,CAAC,OAAsB;QAC9B,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,QAAQ,EAAE;YAC5B,OAAO;SACV;QACD,2CAA2C;QAC3C,aAAa;QACb,8CAA8C;QAC9C,gFAAgF;QAEhF,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;IAClD,CAAC;IACD,WAAW;QACP,IAAI,CAAC,yBAAyB,EAAE,CAAC;IACrC,CAAC;IAES,KAAK,CAAC,wBAAwB;QACpC,IAAI,CAAC,yBAAyB,EAAE,CAAC;QACjC,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE;YACjB,OAAO;SACV;QACD,MAAM,EAAE,MAAM,EAAE,cAAc,EAAE,IAAI,EAAE,QAAQ,EAAE,GAAG,IAAI,CAAC,SAAS,CAAC;QAClE,IAAI,CAAC,cAAc;aACd,YAAY,CAAC,MAAM,EAAE,cAAc,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,CAAC,SAAS,CAAC;aACpE,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;aACjC,SAAS,CAAC,CAAC,YAA+B,EAAE,EAAE;YAC3C,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;YAC9C,IAAI,CAAC,UAAU,GAAG,YAAY,CAAC;YAC/B,IAAI,IAAI,CAAC,SAAS,CAAC,UAAU,EAAE;gBAC3B,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,UAAU,GAAG,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC;aACnE;YACD,IAAI,IAAI,CAAC,KAAK,EAAE;gBACZ,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC;aAC/C;YACD,IAAI,CAAC,kBAAkB,EAAE,CAAC;YAC1B,MAAM,MAAM,GAAG,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,MAAqD,CAAC;YAC9F,IAAI,MAAM,EAAE;gBACR,MAAM;qBACD,IAAI,CACD,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,EAC3B,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAClC;qBACA,SAAS,EAAE,CAAC;aACpB;QACL,CAAC,CAAC,CAAC;QACP,IAAI,CAAC,kBAAkB,EAAE,CAAC;IAC9B,CAAC;IAES,kBAAkB;QACxB,MAAM,eAAe,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,QAAQ,CAAC,CAAC;QAC9F,eAAe,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE;YAC1B,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;QAC1C,CAAC,CAAC,CAAC;IACP,CAAC;IAES,yBAAyB;QAC/B,IAAI,IAAI,CAAC,UAAU,EAAE;YACjB,IAAI,CAAC,UAAU,CAAC,OAAO,EAAE,CAAC;SAC7B;IACL,CAAC;;iHAxEQ,oBAAoB;qGAApB,oBAAoB,8OACY,gBAAgB,uFAJ/C,mDAAmD;2FAGpD,oBAAoB;kBALhC,SAAS;mBAAC;oBACP,QAAQ,EAAE,wBAAwB;oBAClC,QAAQ,EAAE,mDAAmD;oBAC7D,eAAe,EAAE,uBAAuB,CAAC,MAAM;iBAClD;2HAGG,UAAU;sBADT,SAAS;uBAAC,oBAAoB,EAAE,EAAE,IAAI,EAAE,gBAAgB,EAAE,MAAM,EAAE,IAAI,EAAE;gBAEhE,SAAS;sBAAjB,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACI,MAAM;sBAAf,MAAM","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"]}
|