@wavemaker/app-ng-runtime 12.0.0-next.45032 → 12.0.0-next.45503

Sign up to get free protection for your applications and to get access to all the features.
Files changed (119) hide show
  1. app-ng-runtime/build-task/bundles/index.umd.js +405 -451
  2. app-ng-runtime/build-task/esm2022/data/form/form-field/form-field.build.mjs +2 -3
  3. app-ng-runtime/build-task/esm2022/public_api.mjs +1 -3
  4. app-ng-runtime/build-task/fesm2022/index.mjs +406 -454
  5. app-ng-runtime/build-task/fesm2022/index.mjs.map +1 -1
  6. app-ng-runtime/build-task/public_api.d.ts +0 -2
  7. app-ng-runtime/components/base/bundles/index.umd.js +14 -62
  8. app-ng-runtime/components/base/components.module.d.ts +11 -12
  9. app-ng-runtime/components/base/esm2022/components.module.mjs +1 -5
  10. app-ng-runtime/components/base/esm2022/public_api.mjs +1 -2
  11. app-ng-runtime/components/base/esm2022/widgets/common/base/base.component.mjs +15 -25
  12. app-ng-runtime/components/base/fesm2022/index.mjs +15 -62
  13. app-ng-runtime/components/base/fesm2022/index.mjs.map +1 -1
  14. app-ng-runtime/components/base/public_api.d.ts +0 -1
  15. app-ng-runtime/components/base/widgets/common/base/base.component.d.ts +5 -10
  16. app-ng-runtime/components/containers/wizard/bundles/index.umd.js +17 -0
  17. app-ng-runtime/components/containers/wizard/esm2022/wizard.component.mjs +18 -1
  18. app-ng-runtime/components/containers/wizard/fesm2022/index.mjs +17 -0
  19. app-ng-runtime/components/containers/wizard/fesm2022/index.mjs.map +1 -1
  20. app-ng-runtime/components/containers/wizard/wizard.component.d.ts +1 -0
  21. app-ng-runtime/components/data/form/esm2022/form-field/form-field.directive.mjs +1 -3
  22. app-ng-runtime/components/data/form/fesm2022/index.mjs +0 -2
  23. app-ng-runtime/components/data/form/fesm2022/index.mjs.map +1 -1
  24. app-ng-runtime/components/dialogs/default/bundles/index.umd.js +11 -0
  25. app-ng-runtime/components/dialogs/default/esm2022/base-dialog.mjs +12 -1
  26. app-ng-runtime/components/dialogs/default/fesm2022/index.mjs +11 -0
  27. app-ng-runtime/components/dialogs/default/fesm2022/index.mjs.map +1 -1
  28. app-ng-runtime/components/input/default/bundles/index.umd.js +63 -39
  29. app-ng-runtime/components/input/default/checkboxset/checkboxset.component.d.ts +0 -1
  30. app-ng-runtime/components/input/default/esm2022/checkboxset/checkboxset.component.mjs +5 -8
  31. app-ng-runtime/components/input/default/esm2022/radioset/radioset.component.mjs +5 -8
  32. app-ng-runtime/components/input/default/esm2022/select/select.component.mjs +57 -29
  33. app-ng-runtime/components/input/default/esm2022/text/base/base-input.mjs +1 -4
  34. app-ng-runtime/components/input/default/esm2022/text/locale/number-locale.mjs +2 -2
  35. app-ng-runtime/components/input/default/esm2022/textarea/textarea.component.mjs +4 -1
  36. app-ng-runtime/components/input/default/fesm2022/index.mjs +63 -39
  37. app-ng-runtime/components/input/default/fesm2022/index.mjs.map +1 -1
  38. app-ng-runtime/components/input/default/radioset/radioset.component.d.ts +0 -1
  39. app-ng-runtime/components/input/default/select/select.component.d.ts +2 -4
  40. app-ng-runtime/components/input/default/textarea/textarea.component.d.ts +3 -2
  41. app-ng-runtime/components/input/epoch/bundles/index.umd.js +3 -0
  42. app-ng-runtime/components/input/epoch/esm2022/date-time/date-time.component.mjs +4 -1
  43. app-ng-runtime/components/input/epoch/fesm2022/index.mjs +3 -0
  44. app-ng-runtime/components/input/epoch/fesm2022/index.mjs.map +1 -1
  45. app-ng-runtime/components/input/file-upload/bundles/index.umd.js +31 -5
  46. app-ng-runtime/components/input/file-upload/esm2022/file-upload.component.mjs +34 -8
  47. app-ng-runtime/components/input/file-upload/fesm2022/index.mjs +32 -6
  48. app-ng-runtime/components/input/file-upload/fesm2022/index.mjs.map +1 -1
  49. app-ng-runtime/components/input/file-upload/file-upload.component.d.ts +6 -2
  50. app-ng-runtime/components/navigation/menu/bundles/index.umd.js +2 -2
  51. app-ng-runtime/components/navigation/menu/esm2022/menu.component.mjs +2 -2
  52. app-ng-runtime/components/navigation/menu/esm2022/nav/nav.component.mjs +2 -2
  53. app-ng-runtime/components/navigation/menu/fesm2022/index.mjs +2 -2
  54. app-ng-runtime/components/navigation/menu/fesm2022/index.mjs.map +1 -1
  55. app-ng-runtime/core/bundles/index.umd.js +6 -16
  56. app-ng-runtime/core/enums/enums.d.ts +1 -2
  57. app-ng-runtime/core/esm2022/enums/enums.mjs +1 -2
  58. app-ng-runtime/core/esm2022/types/types.mjs +1 -4
  59. app-ng-runtime/core/esm2022/utils/build-utils.mjs +1 -6
  60. app-ng-runtime/core/esm2022/utils/utils.mjs +4 -3
  61. app-ng-runtime/core/fesm2022/index.mjs +4 -12
  62. app-ng-runtime/core/fesm2022/index.mjs.map +1 -1
  63. app-ng-runtime/core/types/types.d.ts +1 -5
  64. app-ng-runtime/core/utils/utils.d.ts +1 -0
  65. app-ng-runtime/mobile/core/bundles/index.umd.js +18 -2
  66. app-ng-runtime/mobile/core/esm2022/native.xhr.mjs +19 -3
  67. app-ng-runtime/mobile/core/fesm2022/index.mjs +18 -2
  68. app-ng-runtime/mobile/core/fesm2022/index.mjs.map +1 -1
  69. app-ng-runtime/package.json +1 -1
  70. app-ng-runtime/runtime/base/bundles/index.umd.js +5 -288
  71. app-ng-runtime/runtime/base/esm2022/public_api.mjs +1 -2
  72. app-ng-runtime/runtime/base/esm2022/runtime-base.module.mjs +1 -6
  73. app-ng-runtime/runtime/base/esm2022/services/i18n.service.mjs +2 -2
  74. app-ng-runtime/runtime/base/esm2022/types/types.mjs +1 -2
  75. app-ng-runtime/runtime/base/fesm2022/index.mjs +4 -287
  76. app-ng-runtime/runtime/base/fesm2022/index.mjs.map +1 -1
  77. app-ng-runtime/runtime/base/public_api.d.ts +0 -1
  78. app-ng-runtime/runtime/base/runtime-base.module.d.ts +8 -9
  79. app-ng-runtime/runtime/base/types/types.d.ts +1 -2
  80. app-ng-runtime/runtime/dynamic/bundles/index.umd.js +9 -27
  81. app-ng-runtime/runtime/dynamic/esm2022/app/app.module.mjs +2 -5
  82. app-ng-runtime/runtime/dynamic/esm2022/app/services/component-ref-provider.service.mjs +7 -23
  83. app-ng-runtime/runtime/dynamic/fesm2022/index.mjs +7 -26
  84. app-ng-runtime/runtime/dynamic/fesm2022/index.mjs.map +1 -1
  85. app-ng-runtime/scripts/@wavemaker/nvd3/build/nv.d3.min.js +1 -1
  86. app-ng-runtime/scripts/datatable/datatable.js +6 -3
  87. app-ng-runtime/scripts/summernote/dist/summernote-lite.min.js +2 -3
  88. app-ng-runtime/transpiler/bundles/index.umd.js +0 -5
  89. app-ng-runtime/transpiler/esm2022/build.mjs +1 -4
  90. app-ng-runtime/transpiler/esm2022/imports.mjs +1 -3
  91. app-ng-runtime/transpiler/fesm2022/index.mjs +0 -5
  92. app-ng-runtime/transpiler/fesm2022/index.mjs.map +1 -1
  93. app-ng-runtime/build-task/advanced/custom-widget-container/custom-widget-container.build.d.ts +0 -2
  94. app-ng-runtime/build-task/advanced/custom-widget-wrapper/custom-widget-wrapper.build.d.ts +0 -2
  95. app-ng-runtime/build-task/esm2022/advanced/custom-widget-container/custom-widget-container.build.mjs +0 -15
  96. app-ng-runtime/build-task/esm2022/advanced/custom-widget-wrapper/custom-widget-wrapper.build.mjs +0 -26
  97. app-ng-runtime/components/advanced/custom/.npmignore +0 -2
  98. app-ng-runtime/components/advanced/custom/bundles/index.umd.js +0 -232
  99. app-ng-runtime/components/advanced/custom/custom-widget-container/custom-widget-container.directive.d.ts +0 -19
  100. app-ng-runtime/components/advanced/custom/custom-widget-container/custom-widget.props.d.ts +0 -2
  101. app-ng-runtime/components/advanced/custom/custom-widget-prop.d.ts +0 -1
  102. app-ng-runtime/components/advanced/custom/custom-widget.directive.d.ts +0 -19
  103. app-ng-runtime/components/advanced/custom/custom-widget.module.d.ts +0 -10
  104. app-ng-runtime/components/advanced/custom/esm2022/custom-widget-container/custom-widget-container.directive.mjs +0 -102
  105. app-ng-runtime/components/advanced/custom/esm2022/custom-widget-container/custom-widget.props.mjs +0 -12
  106. app-ng-runtime/components/advanced/custom/esm2022/custom-widget-prop.mjs +0 -8
  107. app-ng-runtime/components/advanced/custom/esm2022/custom-widget.directive.mjs +0 -68
  108. app-ng-runtime/components/advanced/custom/esm2022/custom-widget.module.mjs +0 -32
  109. app-ng-runtime/components/advanced/custom/esm2022/index.mjs +0 -5
  110. app-ng-runtime/components/advanced/custom/esm2022/public_api.mjs +0 -4
  111. app-ng-runtime/components/advanced/custom/fesm2022/index.mjs +0 -215
  112. app-ng-runtime/components/advanced/custom/fesm2022/index.mjs.map +0 -1
  113. app-ng-runtime/components/advanced/custom/index.d.ts +0 -5
  114. app-ng-runtime/components/advanced/custom/package.json +0 -23
  115. app-ng-runtime/components/advanced/custom/public_api.d.ts +0 -3
  116. app-ng-runtime/components/base/esm2022/widgets/common/base/custom-widget-container.directive.mjs +0 -39
  117. app-ng-runtime/components/base/widgets/common/base/custom-widget-container.directive.d.ts +0 -14
  118. app-ng-runtime/runtime/base/components/base-custom-widget.component.d.ts +0 -72
  119. app-ng-runtime/runtime/base/esm2022/components/base-custom-widget.component.mjs +0 -288
@@ -1,3 +0,0 @@
1
- export * from './custom-widget.module';
2
- export * from './custom-widget-container/custom-widget-container.directive';
3
- export * from './custom-widget.directive';
@@ -1,39 +0,0 @@
1
- import { Attribute, Directive, ElementRef, Inject, Injector, Self, ViewContainerRef } from '@angular/core';
2
- import { App, ComponentType, CustomWidgetRefProvider } from '@wm/core';
3
- import { WidgetRef } from "../../framework/types";
4
- import * as i0 from "@angular/core";
5
- import * as i1 from "@wm/core";
6
- export class CustomWidgetContainerDirective {
7
- constructor(componentInstance, vcRef, elRef, inj, app, widgetname, customWidgetRefProvider) {
8
- this.componentInstance = componentInstance;
9
- this.vcRef = vcRef;
10
- this.elRef = elRef;
11
- this.inj = inj;
12
- this.app = app;
13
- this.customWidgetRefProvider = customWidgetRefProvider;
14
- const widgetnames = this.componentInstance.widgetname;
15
- this.customWidgetRefProvider.getComponentFactoryRef(widgetname, ComponentType.WIDGET).then((componentFactory) => {
16
- if (componentFactory) {
17
- const instanceRef = this.vcRef.createComponent(componentFactory, 0, this.inj);
18
- this.elRef.nativeElement.appendChild(instanceRef.location.nativeElement);
19
- }
20
- });
21
- }
22
- static { this.ɵfac = function CustomWidgetContainerDirective_Factory(t) { return new (t || CustomWidgetContainerDirective)(i0.ɵɵdirectiveInject(WidgetRef, 2), i0.ɵɵdirectiveInject(i0.ViewContainerRef), i0.ɵɵdirectiveInject(i0.ElementRef), i0.ɵɵdirectiveInject(i0.Injector), i0.ɵɵdirectiveInject(i1.App), i0.ɵɵinjectAttribute('widgetname'), i0.ɵɵdirectiveInject(i1.CustomWidgetRefProvider)); }; }
23
- static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: CustomWidgetContainerDirective, selectors: [["", "customWidgetContainer", "", "widgetname", ""]] }); }
24
- }
25
- (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(CustomWidgetContainerDirective, [{
26
- type: Directive,
27
- args: [{
28
- selector: '[customWidgetContainer][widgetname]'
29
- }]
30
- }], () => [{ type: undefined, decorators: [{
31
- type: Self
32
- }, {
33
- type: Inject,
34
- args: [WidgetRef]
35
- }] }, { type: i0.ViewContainerRef }, { type: i0.ElementRef }, { type: i0.Injector }, { type: i1.App }, { type: undefined, decorators: [{
36
- type: Attribute,
37
- args: ['widgetname']
38
- }] }, { type: i1.CustomWidgetRefProvider }], null); })();
39
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3VzdG9tLXdpZGdldC1jb250YWluZXIuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29tcG9uZW50cy9iYXNlL3NyYy93aWRnZXRzL2NvbW1vbi9iYXNlL2N1c3RvbS13aWRnZXQtY29udGFpbmVyLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUE0QixTQUFTLEVBQUUsVUFBVSxFQUFFLE1BQU0sRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFLGdCQUFnQixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3JJLE9BQU8sRUFBRSxHQUFHLEVBQXlCLGFBQWEsRUFBRSx1QkFBdUIsRUFBRSxNQUFNLFVBQVUsQ0FBQztBQUM5RixPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sdUJBQXVCLENBQUM7OztBQVFsRCxNQUFNLE9BQU8sOEJBQThCO0lBRXZDLFlBQ3NDLGlCQUFpQixFQUM1QyxLQUF1QixFQUN2QixLQUFpQixFQUNqQixHQUFhLEVBQ1osR0FBUSxFQUNTLFVBQWtCLEVBQ25DLHVCQUFnRDtRQU50QixzQkFBaUIsR0FBakIsaUJBQWlCLENBQUE7UUFDNUMsVUFBSyxHQUFMLEtBQUssQ0FBa0I7UUFDdkIsVUFBSyxHQUFMLEtBQUssQ0FBWTtRQUNqQixRQUFHLEdBQUgsR0FBRyxDQUFVO1FBQ1osUUFBRyxHQUFILEdBQUcsQ0FBSztRQUVSLDRCQUF1QixHQUF2Qix1QkFBdUIsQ0FBeUI7UUFFeEQsTUFBTSxXQUFXLEdBQUcsSUFBSSxDQUFDLGlCQUFpQixDQUFDLFVBQVUsQ0FBQztRQUN0RCxJQUFJLENBQUMsdUJBQXVCLENBQUMsc0JBQXNCLENBQUMsVUFBVSxFQUFFLGFBQWEsQ0FBQyxNQUFNLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxnQkFBZ0IsRUFBRSxFQUFFO1lBQzVHLElBQUksZ0JBQWdCLEVBQUUsQ0FBQztnQkFDbkIsTUFBTSxXQUFXLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxlQUFlLENBQUMsZ0JBQWdCLEVBQUUsQ0FBQyxFQUFFLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztnQkFDOUUsSUFBSSxDQUFDLEtBQUssQ0FBQyxhQUFhLENBQUMsV0FBVyxDQUFDLFdBQVcsQ0FBQyxRQUFRLENBQUMsYUFBYSxDQUFDLENBQUM7WUFDN0UsQ0FBQztRQUNMLENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQzsrRkFsQlEsOEJBQThCLHVCQUduQixTQUFTLDRLQUtkLFlBQVk7b0VBUmxCLDhCQUE4Qjs7aUZBQTlCLDhCQUE4QjtjQUgxQyxTQUFTO2VBQUM7Z0JBQ1AsUUFBUSxFQUFFLHFDQUFxQzthQUNsRDs7c0JBSVEsSUFBSTs7c0JBQUksTUFBTTt1QkFBQyxTQUFTOztzQkFLeEIsU0FBUzt1QkFBQyxZQUFZIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQXR0cmlidXRlLCBDb21wb25lbnRGYWN0b3J5UmVzb2x2ZXIsIERpcmVjdGl2ZSwgRWxlbWVudFJlZiwgSW5qZWN0LCBJbmplY3RvciwgU2VsZiwgVmlld0NvbnRhaW5lclJlZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQXBwLCAkaW52b2tlV2F0Y2hlcnMsIG5vb3AsIENvbXBvbmVudFR5cGUsIEN1c3RvbVdpZGdldFJlZlByb3ZpZGVyIH0gZnJvbSAnQHdtL2NvcmUnO1xuaW1wb3J0IHsgV2lkZ2V0UmVmIH0gZnJvbSBcIi4uLy4uL2ZyYW1ld29yay90eXBlc1wiO1xuXG5cbmRlY2xhcmUgY29uc3QgXztcblxuQERpcmVjdGl2ZSh7XG4gICAgc2VsZWN0b3I6ICdbY3VzdG9tV2lkZ2V0Q29udGFpbmVyXVt3aWRnZXRuYW1lXSdcbn0pXG5leHBvcnQgY2xhc3MgQ3VzdG9tV2lkZ2V0Q29udGFpbmVyRGlyZWN0aXZlIHtcblxuICAgIGNvbnN0cnVjdG9yKFxuICAgICAgICBAU2VsZigpIEBJbmplY3QoV2lkZ2V0UmVmKSBwdWJsaWMgY29tcG9uZW50SW5zdGFuY2UsXG4gICAgICAgIHB1YmxpYyB2Y1JlZjogVmlld0NvbnRhaW5lclJlZixcbiAgICAgICAgcHVibGljIGVsUmVmOiBFbGVtZW50UmVmLFxuICAgICAgICBwdWJsaWMgaW5qOiBJbmplY3RvcixcbiAgICAgICAgcHJpdmF0ZSBhcHA6IEFwcCxcbiAgICAgICAgQEF0dHJpYnV0ZSgnd2lkZ2V0bmFtZScpIHdpZGdldG5hbWU6IHN0cmluZyxcbiAgICAgICAgcHJpdmF0ZSBjdXN0b21XaWRnZXRSZWZQcm92aWRlcjogQ3VzdG9tV2lkZ2V0UmVmUHJvdmlkZXJcbiAgICApIHtcbiAgICAgICAgY29uc3Qgd2lkZ2V0bmFtZXMgPSB0aGlzLmNvbXBvbmVudEluc3RhbmNlLndpZGdldG5hbWU7XG4gICAgICAgIHRoaXMuY3VzdG9tV2lkZ2V0UmVmUHJvdmlkZXIuZ2V0Q29tcG9uZW50RmFjdG9yeVJlZih3aWRnZXRuYW1lLCBDb21wb25lbnRUeXBlLldJREdFVCkudGhlbigoY29tcG9uZW50RmFjdG9yeSkgPT4ge1xuICAgICAgICAgICAgaWYgKGNvbXBvbmVudEZhY3RvcnkpIHtcbiAgICAgICAgICAgICAgICBjb25zdCBpbnN0YW5jZVJlZiA9IHRoaXMudmNSZWYuY3JlYXRlQ29tcG9uZW50KGNvbXBvbmVudEZhY3RvcnksIDAsIHRoaXMuaW5qKTtcbiAgICAgICAgICAgICAgICB0aGlzLmVsUmVmLm5hdGl2ZUVsZW1lbnQuYXBwZW5kQ2hpbGQoaW5zdGFuY2VSZWYubG9jYXRpb24ubmF0aXZlRWxlbWVudCk7XG4gICAgICAgICAgICB9XG4gICAgICAgIH0pO1xuICAgIH1cbn0iXX0=
@@ -1,14 +0,0 @@
1
- import { ElementRef, Injector, ViewContainerRef } from '@angular/core';
2
- import { App, CustomWidgetRefProvider } from '@wm/core';
3
- import * as i0 from "@angular/core";
4
- export declare class CustomWidgetContainerDirective {
5
- componentInstance: any;
6
- vcRef: ViewContainerRef;
7
- elRef: ElementRef;
8
- inj: Injector;
9
- private app;
10
- private customWidgetRefProvider;
11
- constructor(componentInstance: any, vcRef: ViewContainerRef, elRef: ElementRef, inj: Injector, app: App, widgetname: string, customWidgetRefProvider: CustomWidgetRefProvider);
12
- static ɵfac: i0.ɵɵFactoryDeclaration<CustomWidgetContainerDirective, [{ self: true; }, null, null, null, null, { attribute: "widgetname"; }, null]>;
13
- static ɵdir: i0.ɵɵDirectiveDeclaration<CustomWidgetContainerDirective, "[customWidgetContainer][widgetname]", never, {}, {}, never, never, false, never>;
14
- }
@@ -1,72 +0,0 @@
1
- import { AfterViewInit, Injector, OnDestroy } from '@angular/core';
2
- import { ActivatedRoute, Router } from '@angular/router';
3
- import { Subject } from 'rxjs';
4
- import { AbstractI18nService, AbstractNavigationService, App, Viewport, ScriptLoaderService } from '@wm/core';
5
- import { PageDirective, SpaPageDirective } from '@wm/components/page';
6
- import { PrefabDirective } from '@wm/components/prefab';
7
- import { FragmentMonitor } from '../util/fragment-monitor';
8
- import { AppManagerService } from '../services/app.manager.service';
9
- import * as i0 from "@angular/core";
10
- export declare abstract class BaseCustomWidgetComponent extends FragmentMonitor implements AfterViewInit, OnDestroy {
11
- Widgets: any;
12
- BaseWidget: any;
13
- Variables: any;
14
- Actions: any;
15
- App: App;
16
- injector: Injector;
17
- customWidgetName: string;
18
- activePageName: string;
19
- route: ActivatedRoute;
20
- appManager: AppManagerService;
21
- navigationService: AbstractNavigationService;
22
- router: Router;
23
- props: any;
24
- containerWidget: any;
25
- i18nService: AbstractI18nService;
26
- appLocale: any;
27
- pageDirective: PageDirective | SpaPageDirective;
28
- Prefab: PrefabDirective;
29
- scriptLoaderService: ScriptLoaderService;
30
- Viewport: Viewport;
31
- compileContent: boolean;
32
- spa: boolean;
33
- events: any;
34
- destroy$: Subject<unknown>;
35
- viewInit$: Subject<unknown>;
36
- private viewParent;
37
- abstract evalUserScript(prefabContext: any, appContext: any, utils: any): any;
38
- abstract getVariables(): any;
39
- abstract getExpressions(): any;
40
- getContainerWidgetInjector(): any;
41
- init(): void;
42
- registerWidgets(): void;
43
- initializeComponentData(children: any): void;
44
- registerBaseWidget(): void;
45
- invokeEvent: (eventName: string) => void;
46
- registerEvents(): void;
47
- registerDestroyListener(fn: Function): void;
48
- registerChangeListeners(): void;
49
- initUserScript(): void;
50
- initVariables(): void;
51
- /**
52
- * function to register bind expressions generated in this partial instance
53
- * getExpressions function is defined in the generated page.comp.ts file
54
- * @param expressions, map of bind expression vs generated function
55
- */
56
- registerExpressions(): void;
57
- registerProps(): void;
58
- defineI18nProps(): void;
59
- invokeOnReady(): void;
60
- private loadScripts;
61
- registerPropsInContainerWidget(resolveFn: Function): void;
62
- mute(): void;
63
- unmute(): void;
64
- ngAfterViewInit(): void;
65
- ngOnDestroy(): void;
66
- ngOnAttach(refreshData: any): void;
67
- ngOnDetach(): void;
68
- onPropertyChange(): void;
69
- onReady(params?: any): void;
70
- static ɵfac: i0.ɵɵFactoryDeclaration<BaseCustomWidgetComponent, never>;
71
- static ɵdir: i0.ɵɵDirectiveDeclaration<BaseCustomWidgetComponent, never, never, {}, {}, never, never, false, never>;
72
- }
@@ -1,288 +0,0 @@
1
- import { Directive, inject } from '@angular/core';
2
- import { Subject } from 'rxjs';
3
- import { $invokeWatchers, AbstractI18nService, App, noop, Viewport, ScriptLoaderService, UtilsService, registerFnByExpr, $watch, isIE } from '@wm/core';
4
- import { WidgetRef } from '@wm/components/base';
5
- import { PageDirective, SpaPageDirective } from '@wm/components/page';
6
- import { VariablesService } from '@wm/variables';
7
- import { FragmentMonitor } from '../util/fragment-monitor';
8
- import { commonPartialWidgets } from "./base-partial.component";
9
- import { capitalize, forEach } from "lodash-es";
10
- import { CheckboxsetComponent, RadiosetComponent } from "@wm/components/input";
11
- import * as i0 from "@angular/core";
12
- // export const commonPartialWidgets = {};
13
- export class BaseCustomWidgetComponent extends FragmentMonitor {
14
- constructor() {
15
- super(...arguments);
16
- this.BaseWidget = {};
17
- this.compileContent = false;
18
- this.destroy$ = new Subject();
19
- this.viewInit$ = new Subject();
20
- this.invokeEvent = (eventName) => {
21
- this.events[eventName]();
22
- };
23
- }
24
- getContainerWidgetInjector() {
25
- return this.containerWidget.inj || this.containerWidget.injector;
26
- }
27
- init() {
28
- let resolveFn;
29
- const promise = new Promise((res) => resolveFn = res);
30
- this.App = this.injector ? this.injector.get(App) : inject(App);
31
- //making the code compatible in both the JIT and AOT modes
32
- this.containerWidget = this.injector ? this.injector.get(WidgetRef) : inject(WidgetRef);
33
- this.i18nService = this.injector ? this.injector.get(AbstractI18nService) : inject(AbstractI18nService);
34
- this.scriptLoaderService = this.injector ? this.injector.get(ScriptLoaderService) : inject(ScriptLoaderService);
35
- this.Viewport = this.injector ? this.injector.get(Viewport) : inject(Viewport);
36
- // this.viewContainerRef = this.getContainerWidgetInjector().get(ViewContainerRef);
37
- // Replacing this.getContainerWidgetInjector().view.component as viewParent
38
- // this.viewParent = (this.viewContainerRef as any).parentInjector._lView[8];
39
- this.viewParent = this.containerWidget.viewParent;
40
- if (this.viewParent.registerFragment) {
41
- this.viewParent.registerFragment();
42
- }
43
- // register functions for binding evaluation
44
- this.registerExpressions();
45
- this.initUserScript();
46
- this.registerPropsInContainerWidget(resolveFn);
47
- // Using promise to make sure the props are registered in the container widget before registering events, Otherwise no events will be registered
48
- promise.then(() => this.registerEvents());
49
- this.registerWidgets();
50
- this.initVariables();
51
- this.activePageName = this.App.activePageName; // Todo: remove this
52
- this.registerProps();
53
- this.defineI18nProps();
54
- this.viewInit$.subscribe(noop, noop, () => {
55
- this.props = this.containerWidget.props;
56
- });
57
- if (this.spa) {
58
- this.pageDirective = this.injector ? this.injector.get(SpaPageDirective) : inject(SpaPageDirective);
59
- }
60
- else {
61
- this.pageDirective = this.injector ? this.injector.get(PageDirective) : inject(PageDirective);
62
- }
63
- if (this.pageDirective) {
64
- this.registerDestroyListener(this.pageDirective.subscribe('attach', data => this.ngOnAttach(data.refreshData)));
65
- this.registerDestroyListener(this.pageDirective.subscribe('detach', () => this.ngOnDetach()));
66
- }
67
- super.init();
68
- }
69
- registerWidgets() {
70
- // common partial widgets should be accessible from page
71
- this.Widgets = Object.create(commonPartialWidgets);
72
- // expose current page widgets on app
73
- this.App.Widgets = Object.create(this.Widgets);
74
- }
75
- initializeComponentData(children) {
76
- Array.from(children).forEach((child) => {
77
- if (!child.hasAttribute('wmcustomwidget'))
78
- this.initializeComponentData(child.children);
79
- else {
80
- let baseWidget, splitArr = child.getAttribute('as').split('-'), modifiedArr = [];
81
- modifiedArr = splitArr.map((item) => {
82
- item = item !== 'wm' ? capitalize(item) : item;
83
- return item;
84
- });
85
- baseWidget = modifiedArr.join('');
86
- switch (baseWidget) {
87
- case 'wmCheckboxset':
88
- this[baseWidget] = new CheckboxsetComponent(this.injector, undefined);
89
- this[baseWidget]["_select"] = (item, $event) => {
90
- const keys = [];
91
- forEach(this[baseWidget].datasetItems, (datasetItem) => {
92
- if (datasetItem.key === item.key)
93
- datasetItem.selected = !datasetItem.selected;
94
- if (datasetItem.selected)
95
- keys.push(datasetItem.key);
96
- });
97
- this[baseWidget].triggerInvokeOnChange(keys, $event);
98
- };
99
- break;
100
- case 'wmRadioset':
101
- this[baseWidget] = new RadiosetComponent(this.injector, undefined);
102
- this[baseWidget]["_select"] = (item, $event) => {
103
- this[baseWidget].triggerInvokeOnChange(item.key, $event);
104
- };
105
- break;
106
- }
107
- for (let [key, value] of this.containerWidget.$attrs) {
108
- if (key.startsWith('base-')) {
109
- let modifiedKey = key.replace('base-', '');
110
- this[baseWidget][modifiedKey] = value;
111
- }
112
- }
113
- this[baseWidget].initDatasetItems();
114
- this.containerWidget[baseWidget] = this[baseWidget];
115
- }
116
- });
117
- }
118
- registerBaseWidget() {
119
- this.initializeComponentData(this.containerWidget.nativeElement.children);
120
- }
121
- registerEvents() {
122
- this.events = {};
123
- this.containerWidget.eventHandlers.forEach((callback, key) => {
124
- this.events[key] = (...args) => {
125
- this.containerWidget.invokeEventCallback(key, { $event: args[0], $data: args[1] });
126
- };
127
- });
128
- }
129
- registerDestroyListener(fn) {
130
- this.destroy$.subscribe(noop, noop, () => fn());
131
- }
132
- registerChangeListeners() {
133
- this.containerWidget.registerPropertyChangeListener(this.onPropertyChange);
134
- this.containerWidget.registerStyleChangeListener(this.onPropertyChange);
135
- }
136
- initUserScript() {
137
- try {
138
- // partials inside prefab should have access to Prefab properties and events
139
- if (this.viewParent.prefabName) {
140
- // for partial within partial within prefabs, just assign the parent partial's prefab object
141
- if (this.viewParent.Prefab) {
142
- this.Prefab = this.viewParent.Prefab;
143
- }
144
- else {
145
- this.Prefab = this.viewParent;
146
- }
147
- }
148
- this.evalUserScript(this, this.App, this.injector ? this.injector.get(UtilsService) : inject(UtilsService));
149
- }
150
- catch (e) {
151
- console.error(`Error in evaluating partial (${this.customWidgetName}) script\n`, e);
152
- }
153
- }
154
- initVariables() {
155
- const variablesService = this.injector ? this.injector.get(VariablesService) : inject(VariablesService);
156
- // get variables and actions instances for the page
157
- const variableCollection = variablesService.register(this.customWidgetName, this.getVariables(), this);
158
- // create namespace for Variables nad Actions on page/partial, which inherits the Variables and Actions from App instance
159
- this.Variables = Object.create(this.App.Variables);
160
- this.Actions = Object.create(this.App.Actions);
161
- this.containerWidget.Variables = this.Variables;
162
- this.containerWidget.Actions = this.Actions;
163
- // assign all the page variables to the pageInstance
164
- Object.entries(variableCollection.Variables).forEach(([name, variable]) => this.Variables[name] = variable);
165
- Object.entries(variableCollection.Actions).forEach(([name, action]) => this.Actions[name] = action);
166
- this.viewInit$.subscribe(noop, noop, () => {
167
- // TEMP: triggering watchers so variables watching over params are updated
168
- $invokeWatchers(true, true);
169
- variableCollection.callback(variableCollection.Variables).catch(noop);
170
- variableCollection.callback(variableCollection.Actions);
171
- });
172
- }
173
- /**
174
- * function to register bind expressions generated in this partial instance
175
- * getExpressions function is defined in the generated page.comp.ts file
176
- * @param expressions, map of bind expression vs generated function
177
- */
178
- registerExpressions() {
179
- const expressions = this.getExpressions();
180
- _.each(expressions, (fn, expr) => {
181
- registerFnByExpr(expr, fn[0], fn[1]);
182
- });
183
- }
184
- registerProps() {
185
- this.props = this.containerWidget.props;
186
- }
187
- defineI18nProps() {
188
- this.appLocale = this.i18nService.getAppLocale();
189
- }
190
- invokeOnReady() {
191
- let params;
192
- if (this.containerWidget.userComponentParams) {
193
- params = this.containerWidget.userComponentParams;
194
- }
195
- this.onReady(params);
196
- if (this.viewParent.resolveFragment) {
197
- this.viewParent.resolveFragment();
198
- }
199
- }
200
- loadScripts() {
201
- // return new Promise<void>((resolve) => {
202
- // const scriptsRequired = this.partialDirective.$element.attr('scripts-to-load');
203
- // if (scriptsRequired) {
204
- // this.scriptLoaderService
205
- // .load(...scriptsRequired.split(','))
206
- // .then(resolve);
207
- // } else {
208
- // resolve();
209
- // }
210
- // });
211
- }
212
- registerPropsInContainerWidget(resolveFn) {
213
- window['resourceCache'].get(`./custom-widgets/${this.customWidgetName}/page.min.json`).then(({ config }) => {
214
- if (config) {
215
- Object.entries((config.properties || {})).forEach(([key, prop]) => {
216
- let expr;
217
- const value = _.trim(prop.value);
218
- if (_.startsWith(value, 'bind:')) {
219
- expr = value.replace('bind:', '');
220
- }
221
- Object.defineProperty(this, key, {
222
- get: () => this.containerWidget[key],
223
- set: nv => this.containerWidget.widget[key] = nv
224
- });
225
- if (expr) {
226
- //[Todo-CSP]: expr will be generated with prefab.comp.expr.ts
227
- this.registerDestroyListener($watch(expr, this, {}, nv => this.containerWidget.widget[key] = nv));
228
- }
229
- });
230
- }
231
- this.containerWidget.setProps(config, resolveFn);
232
- // Reassigning the proxy handler for prefab inbound properties as we
233
- // will get them only after the prefab config call.
234
- if (isIE()) {
235
- this.containerWidget.widget = this.containerWidget.createProxy();
236
- }
237
- });
238
- }
239
- mute() {
240
- const m = o => { o && o.mute && o.mute(); };
241
- _.each(this.Widgets, m);
242
- _.each(this.Variables, m);
243
- _.each(this.Actions, m);
244
- }
245
- unmute() {
246
- const um = o => { o && o.unmute && o.unmute(); };
247
- _.each(this.Widgets, um);
248
- _.each(this.Variables, um);
249
- _.each(this.Actions, um);
250
- }
251
- // ngOnInit() {
252
- // this.init();
253
- // }
254
- ngAfterViewInit() {
255
- this.registerChangeListeners();
256
- this.registerBaseWidget();
257
- setTimeout(() => {
258
- this.viewInit$.complete();
259
- this.fragmentsLoaded$.subscribe(noop, noop, () => this.invokeOnReady());
260
- }, 100);
261
- }
262
- ngOnDestroy() {
263
- this.destroy$.complete();
264
- }
265
- ngOnAttach(refreshData) {
266
- this.unmute();
267
- if (refreshData) {
268
- const refresh = v => { v && v.startUpdate && v.invoke && v.invoke(); };
269
- _.each(this.Variables, refresh);
270
- _.each(this.Actions, refresh);
271
- }
272
- _.each(this.Widgets, w => w && w.ngOnAttach && w.ngOnAttach());
273
- }
274
- ngOnDetach() {
275
- this.mute();
276
- _.each(this.Widgets, w => w && w.ngOnDetach && w.ngOnDetach());
277
- }
278
- // user overrides this
279
- onPropertyChange() { }
280
- onReady(params) {
281
- }
282
- static { this.ɵfac = /*@__PURE__*/ (() => { let ɵBaseCustomWidgetComponent_BaseFactory; return function BaseCustomWidgetComponent_Factory(t) { return (ɵBaseCustomWidgetComponent_BaseFactory || (ɵBaseCustomWidgetComponent_BaseFactory = i0.ɵɵgetInheritedFactory(BaseCustomWidgetComponent)))(t || BaseCustomWidgetComponent); }; })(); }
283
- static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: BaseCustomWidgetComponent, features: [i0.ɵɵInheritDefinitionFeature] }); }
284
- }
285
- (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(BaseCustomWidgetComponent, [{
286
- type: Directive
287
- }], null, null); })();
288
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-custom-widget.component.js","sourceRoot":"","sources":["../../../../../projects/runtime-base/src/components/base-custom-widget.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    Injector,\n    OnDestroy,\n    ViewChild,\n    Directive,\n    inject\n} from '@angular/core';\nimport { ActivatedRoute, Router } from '@angular/router';\n\nimport {Subject} from 'rxjs';\n\nimport {\n    $invokeWatchers,\n    AbstractI18nService,\n    AbstractNavigationService,\n    App,\n    noop,\n    Viewport,\n    ScriptLoaderService,\n    UtilsService,\n    registerFnByExpr,\n    $watch,\n    isIE, isDefined\n} from '@wm/core';\nimport {getWidgetPropsByType, WidgetRef} from '@wm/components/base';\nimport { PageDirective, SpaPageDirective } from '@wm/components/page';\nimport {PrefabDirective} from '@wm/components/prefab';\nimport { VariablesService } from '@wm/variables';\n\nimport { FragmentMonitor } from '../util/fragment-monitor';\nimport { AppManagerService } from '../services/app.manager.service';\nimport {commonPartialWidgets} from \"./base-partial.component\";\nimport {capitalize, forEach} from \"lodash-es\";\nimport {CheckboxsetComponent, RadiosetComponent} from \"@wm/components/input\";\n\ndeclare const _;\n\n// export const commonPartialWidgets = {};\n\n@Directive()\nexport abstract class BaseCustomWidgetComponent extends FragmentMonitor implements AfterViewInit, OnDestroy {\n    Widgets: any;\n    BaseWidget: any = {};\n    Variables: any;\n    Actions: any;\n    App: App;\n    injector: Injector;\n    customWidgetName: string;\n    activePageName: string;\n    route: ActivatedRoute;\n    appManager: AppManagerService;\n    navigationService: AbstractNavigationService;\n    router: Router;\n    props: any;\n    containerWidget: any;\n    i18nService: AbstractI18nService;\n    appLocale: any;\n    // @ViewChild(PartialDirective) partialDirective;\n    pageDirective: PageDirective | SpaPageDirective;\n    Prefab: PrefabDirective;\n    scriptLoaderService: ScriptLoaderService;\n    Viewport: Viewport;\n    compileContent = false;\n    spa: boolean;\n    events: any;\n\n    destroy$ = new Subject();\n    viewInit$ = new Subject();\n    private viewParent: any;\n\n    abstract evalUserScript(prefabContext: any, appContext: any, utils: any);\n\n    abstract getVariables();\n    abstract getExpressions();\n\n    getContainerWidgetInjector() {\n        return this.containerWidget.inj || this.containerWidget.injector;\n    }\n\n    init() {\n        let resolveFn: Function;\n        const promise = new Promise((res)=> resolveFn = res)\n        this.App = this.injector ? this.injector.get(App) : inject(App);\n        //making the code compatible in both the JIT and AOT modes\n        this.containerWidget = this.injector ? this.injector.get(WidgetRef) : inject(WidgetRef);\n        this.i18nService = this.injector ? this.injector.get(AbstractI18nService) : inject(AbstractI18nService);\n        this.scriptLoaderService = this.injector ? this.injector.get(ScriptLoaderService) : inject(ScriptLoaderService);\n        this.Viewport = this.injector ? this.injector.get(Viewport) : inject(Viewport);\n        // this.viewContainerRef = this.getContainerWidgetInjector().get(ViewContainerRef);\n        // Replacing this.getContainerWidgetInjector().view.component as viewParent\n        // this.viewParent = (this.viewContainerRef as any).parentInjector._lView[8];\n        this.viewParent = this.containerWidget.viewParent;\n\n        if (this.viewParent.registerFragment) {\n            this.viewParent.registerFragment();\n        }\n\n        // register functions for binding evaluation\n        this.registerExpressions();\n        this.initUserScript();\n        this.registerPropsInContainerWidget(resolveFn);\n        // Using promise to make sure the props are registered in the container widget before registering events, Otherwise no events will be registered\n        promise.then(() => this.registerEvents());\n\n        this.registerWidgets();\n        this.initVariables();\n\n        this.activePageName = this.App.activePageName; // Todo: remove this\n        this.registerProps();\n        this.defineI18nProps();\n\n        this.viewInit$.subscribe(noop, noop, () => {\n            this.props = this.containerWidget.props;\n        });\n\n        if(this.spa) {\n            this.pageDirective = this.injector ? this.injector.get(SpaPageDirective) : inject(SpaPageDirective);\n        } else {\n            this.pageDirective = this.injector ? this.injector.get(PageDirective) : inject(PageDirective);\n        }\n        if (this.pageDirective) {\n            this.registerDestroyListener(this.pageDirective.subscribe('attach', data => this.ngOnAttach(data.refreshData)));\n            this.registerDestroyListener(this.pageDirective.subscribe('detach', () => this.ngOnDetach()));\n        }\n        super.init();\n    }\n\n    registerWidgets() {\n        // common partial widgets should be accessible from page\n        this.Widgets = Object.create(commonPartialWidgets);\n\n        // expose current page widgets on app\n        (this.App as any).Widgets = Object.create(this.Widgets);\n    }\n\n    initializeComponentData(children) {\n        Array.from(children).forEach((child: any) => {\n            if(!child.hasAttribute('wmcustomwidget'))\n                this.initializeComponentData(child.children);\n            else {\n                let baseWidget, splitArr = child.getAttribute('as').split('-'), modifiedArr = [];\n                modifiedArr = splitArr.map((item: any) => {\n                    item = item !== 'wm' ? capitalize(item) : item;\n                    return item;\n                });\n                baseWidget = modifiedArr.join('');\n                switch (baseWidget) {\n                    case 'wmCheckboxset':\n                        this[baseWidget] = new CheckboxsetComponent(this.injector, undefined);\n                        this[baseWidget][\"_select\"] = (item: any, $event: any) => {\n                            const keys = [];\n                            forEach(this[baseWidget].datasetItems, (datasetItem: any) => {\n                                if(datasetItem.key === item.key)\n                                    datasetItem.selected = !datasetItem.selected;\n\n                                if(datasetItem.selected)\n                                    keys.push(datasetItem.key);\n                            });\n                            this[baseWidget].triggerInvokeOnChange(keys, $event);\n                        }\n                        break;\n                    case 'wmRadioset':\n                        this[baseWidget] = new RadiosetComponent(this.injector, undefined);\n                        this[baseWidget][\"_select\"] = (item: any, $event: any) => {\n                        this[baseWidget].triggerInvokeOnChange(item.key, $event);\n                    }\n                        break;\n                }\n\n                for (let [key, value] of this.containerWidget.$attrs) {\n                    if(key.startsWith('base-')) {\n                        let modifiedKey = key.replace('base-', '');\n                        this[baseWidget][modifiedKey] = value;\n                    }\n                }\n                this[baseWidget].initDatasetItems();\n                this.containerWidget[baseWidget] = this[baseWidget];\n            }\n        });\n    }\n\n    registerBaseWidget() {\n        this.initializeComponentData(this.containerWidget.nativeElement.children);\n    }\n\n    invokeEvent = (eventName: string) => {\n        this.events[eventName]();\n    }\n\n    registerEvents() {\n        this.events = {};\n        this.containerWidget.eventHandlers.forEach((callback: any, key: string) => {\n            this.events[key] = (...args) => {\n                this.containerWidget.invokeEventCallback(key, {$event: args[0], $data: args[1]});\n            };\n        });\n    }\n\n    registerDestroyListener(fn: Function) {\n        this.destroy$.subscribe(noop, noop, () => fn());\n    }\n\n    registerChangeListeners() {\n        this.containerWidget.registerPropertyChangeListener(this.onPropertyChange);\n        this.containerWidget.registerStyleChangeListener(this.onPropertyChange);\n    }\n\n    initUserScript() {\n        try {\n            // partials inside prefab should have access to Prefab properties and events\n            if (this.viewParent.prefabName) {\n                // for partial within partial within prefabs, just assign the parent partial's prefab object\n                if (this.viewParent.Prefab) {\n                    this.Prefab = this.viewParent.Prefab;\n                } else {\n                    this.Prefab = this.viewParent;\n                }\n            }\n            this.evalUserScript(this, this.App, this.injector ? this.injector.get(UtilsService) : inject(UtilsService));\n        } catch (e) {\n            console.error(`Error in evaluating partial (${this.customWidgetName}) script\\n`, e);\n        }\n    }\n\n    initVariables() {\n        const variablesService = this.injector ? this.injector.get(VariablesService) : inject(VariablesService);\n\n        // get variables and actions instances for the page\n        const variableCollection = variablesService.register(this.customWidgetName, this.getVariables(), this);\n\n        // create namespace for Variables nad Actions on page/partial, which inherits the Variables and Actions from App instance\n        this.Variables = Object.create(this.App.Variables);\n        this.Actions = Object.create(this.App.Actions);\n\n        this.containerWidget.Variables = this.Variables;\n        this.containerWidget.Actions = this.Actions;\n\n        // assign all the page variables to the pageInstance\n        Object.entries(variableCollection.Variables).forEach(([name, variable]) => this.Variables[name] = variable);\n        Object.entries(variableCollection.Actions).forEach(([name, action]) => this.Actions[name] = action);\n\n\n        this.viewInit$.subscribe(noop, noop, () => {\n            // TEMP: triggering watchers so variables watching over params are updated\n            $invokeWatchers(true, true);\n            variableCollection.callback(variableCollection.Variables).catch(noop);\n            variableCollection.callback(variableCollection.Actions);\n        });\n    }\n\n    /**\n     * function to register bind expressions generated in this partial instance\n     * getExpressions function is defined in the generated page.comp.ts file\n     * @param expressions, map of bind expression vs generated function\n     */\n    registerExpressions() {\n        const expressions = this.getExpressions();\n        _.each(expressions, (fn, expr)=>{\n            registerFnByExpr(expr, fn[0], fn[1]);\n        });\n    }\n\n    registerProps() {\n        this.props = this.containerWidget.props;\n    }\n\n    defineI18nProps() {\n        this.appLocale = this.i18nService.getAppLocale();\n    }\n\n    invokeOnReady() {\n        let params;\n        if (this.containerWidget.userComponentParams) {\n            params = this.containerWidget.userComponentParams;\n        }\n        this.onReady(params);\n        if (this.viewParent.resolveFragment) {\n            this.viewParent.resolveFragment();\n        }\n    }\n\n    private loadScripts() {\n        // return new Promise<void>((resolve) => {\n        //     const scriptsRequired = this.partialDirective.$element.attr('scripts-to-load');\n        //     if (scriptsRequired) {\n        //         this.scriptLoaderService\n        //             .load(...scriptsRequired.split(','))\n        //             .then(resolve);\n        //     } else {\n        //         resolve();\n        //     }\n        // });\n    }\n    registerPropsInContainerWidget(resolveFn: Function) {\n        window['resourceCache'].get(`./custom-widgets/${this.customWidgetName}/page.min.json`).then(({ config }) => {\n            if (config) {\n                Object.entries((config.properties || {})).forEach(([key, prop]: [string, any]) => {\n                    let expr;\n                    const value = _.trim(prop.value);\n\n                    if (_.startsWith(value, 'bind:')) {\n                        expr = value.replace('bind:', '');\n                    }\n\n                    Object.defineProperty(this, key, {\n                        get: () => this.containerWidget[key],\n                        set: nv => this.containerWidget.widget[key] = nv\n                    });\n\n                    if (expr) {\n                        //[Todo-CSP]: expr will be generated with prefab.comp.expr.ts\n                        this.registerDestroyListener(\n                            $watch(expr, this, {}, nv => this.containerWidget.widget[key] = nv)\n                        );\n                    }\n                })\n            }\n            this.containerWidget.setProps(config, resolveFn);\n            // Reassigning the proxy handler for prefab inbound properties as we\n            // will get them only after the prefab config call.\n            if (isIE()) {\n                this.containerWidget.widget = this.containerWidget.createProxy();\n            }\n        })\n    }\n\n    mute() {\n        const m = o => { o && o.mute && o.mute(); };\n        _.each(this.Widgets, m);\n        _.each(this.Variables, m);\n        _.each(this.Actions, m);\n    }\n\n    unmute() {\n        const um = o => { o && o.unmute && o.unmute(); };\n        _.each(this.Widgets, um);\n        _.each(this.Variables, um);\n        _.each(this.Actions, um);\n    }\n\n    // ngOnInit() {\n    //     this.init();\n    // }\n\n    ngAfterViewInit(): void {\n        this.registerChangeListeners();\n        this.registerBaseWidget();\n            setTimeout(() => {\n                this.viewInit$.complete();\n                this.fragmentsLoaded$.subscribe(noop, noop, () => this.invokeOnReady());\n            }, 100);\n    }\n\n    ngOnDestroy(): void {\n        this.destroy$.complete();\n    }\n\n    ngOnAttach(refreshData) {\n        this.unmute();\n        if (refreshData) {\n            const refresh = v => { v && v.startUpdate && v.invoke && v.invoke(); };\n            _.each(this.Variables, refresh);\n            _.each(this.Actions, refresh);\n        }\n        _.each(this.Widgets, w => w && w.ngOnAttach && w.ngOnAttach());\n    }\n\n    ngOnDetach() {\n        this.mute();\n        _.each(this.Widgets, w => w && w.ngOnDetach && w.ngOnDetach());\n    }\n\n    // user overrides this\n    onPropertyChange() { }\n\n    onReady(params?) {\n    }\n}\n"]}