@wavemaker/app-ng-runtime 11.14.2-1.6423 → 11.14.2-2.6435

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (35) hide show
  1. package/components/base/bundles/index.umd.js +6 -12
  2. package/components/base/esm2022/widgets/common/base/base.component.mjs +8 -14
  3. package/components/base/fesm2022/index.mjs +7 -13
  4. package/components/base/fesm2022/index.mjs.map +1 -1
  5. package/components/data/table/bundles/index.umd.js +5 -5
  6. package/components/data/table/esm2022/table.component.mjs +7 -7
  7. package/components/data/table/fesm2022/index.mjs +6 -6
  8. package/components/data/table/fesm2022/index.mjs.map +1 -1
  9. package/components/prefab/bundles/index.umd.js +0 -4
  10. package/components/prefab/esm2022/prefab.directive.mjs +1 -5
  11. package/components/prefab/fesm2022/index.mjs +0 -4
  12. package/components/prefab/fesm2022/index.mjs.map +1 -1
  13. package/core/bundles/index.umd.js +187 -330
  14. package/core/esm2022/public_api.mjs +2 -2
  15. package/core/esm2022/utils/watcher.mjs +191 -327
  16. package/core/fesm2022/index.mjs +194 -330
  17. package/core/fesm2022/index.mjs.map +1 -1
  18. package/core/public_api.d.ts +1 -1
  19. package/core/utils/watcher.d.ts +5 -26
  20. package/npm-shrinkwrap.json +2 -2
  21. package/package-lock.json +2 -2
  22. package/package.json +1 -1
  23. package/runtime/base/bundles/index.umd.js +11 -171
  24. package/runtime/base/components/app-component/app.component.d.ts +0 -4
  25. package/runtime/base/esm2022/components/app-component/app.component.mjs +9 -40
  26. package/runtime/base/esm2022/components/base-page.component.mjs +3 -35
  27. package/runtime/base/esm2022/components/base-partial.component.mjs +3 -37
  28. package/runtime/base/esm2022/components/base-prefab.component.mjs +3 -32
  29. package/runtime/base/esm2022/components/base-spa-page.component.mjs +3 -37
  30. package/runtime/base/fesm2022/index.mjs +12 -172
  31. package/runtime/base/fesm2022/index.mjs.map +1 -1
  32. package/runtime/dynamic/bundles/index.umd.js +4 -0
  33. package/runtime/dynamic/esm2022/app/app.config.mjs +6 -2
  34. package/runtime/dynamic/fesm2022/index.mjs +5 -1
  35. package/runtime/dynamic/fesm2022/index.mjs.map +1 -1
@@ -5,7 +5,7 @@ export * from './enums/enums';
5
5
  export * from './utils/event-notifier';
6
6
  export { ParseExprResult, $parseExpr, $parseEvent, registerFnByExpr, setPipeProvider, getFnByExpr, getFnForBindExpr, getFnForEventExpr } from './utils/expression-parser';
7
7
  export { EVENT_LIFE, isDefined, isObject, toBoolean, isIE, isAndroid, isAndroidTablet, isIphone, isIpod, isIpad, isIos, isSafari, isLargeTabletLandscape, isLargeTabletPortrait, isMobile, getAndroidVersion, isKitkatDevice, encodeUrl, encodeUrlParams, initCaps, spaceSeparate, replaceAt, periodSeparate, prettifyLabel, deHyphenate, prettifyLabels, isInsecureContentRequest, stringStartsWith, getEvaluatedExprValue, isImageFile, isAudioFile, isVideoFile, isValidImageUrl, isValidWebURL, getResourceURL, triggerFn, hasOffsetStr, getFormattedDate, getDateObj, addEventListenerOnElement, getClonedObject, getFiles, generateGUId, validateAccessRoles, getValidJSON, xmlToJson, findValueOf, extractType, isNumberType, isEmptyObject, scrollToElement, isElementInViewport, isPageable, replace, isDateTimeType, getValidDateObject, getNativeDateObject, getBlob, isEqualWithFields, loadStyleSheet, loadStyleSheets, loadScript, loadScripts, _WM_APP_PROJECT, setSessionStorageItem, getSessionStorageItem, noop, convertToBlob, AppConstants, openLink, fetchContent, toPromise, retryIfFails, getAbortableDefer, createCSSRule, getUrlParams, getMomentLocaleObject, getRouteNameFromLink, isAppleProduct, defer, executePromiseChain, isDataSourceEqual, validateDataSourceCtx, processFilterExpBindNode, extendProto, removeExtraSlashes, getDisplayDateTimeFormat, addForIdAttributes, adjustContainerPosition, adjustContainerRightEdges, setTranslation3dPosition, getWebkitTraslationMatrix, closePopover, detectChanges, triggerItemAction, getDatasourceFromExpr, extractCurrentItemExpr, findRootContainer, VALIDATOR, transformFileURI, appendScriptToHead, getAppSetting, setListClass, findParent, getNavClass, getSheetPositionClass } from './utils/utils';
8
- export { FIRST_TIME_WATCH, isFirstTimeChange, debounce, muteWatchers, unMuteWatchers, $watch, $unwatch, $unwatchAll, $unwatchAllByScope, setNgZone, setAppRef, isChangeFromWatch, resetChangeFromWatch, $invokeWatchers, $appDigest } from './utils/watcher';
8
+ export { FIRST_TIME_WATCH, isFirstTimeChange, debounce, muteWatchers, unMuteWatchers, $watch, $unwatch, setNgZone, setAppRef, isChangeFromWatch, resetChangeFromWatch, $invokeWatchers, $appDigest } from './utils/watcher';
9
9
  export * from './utils/id-generator';
10
10
  export * from './types/types';
11
11
  export { Viewport, ViewportEvent } from './services/viewport.service';
@@ -1,34 +1,13 @@
1
- export declare const FIRST_TIME_WATCH: Readonly<{}>;
2
- type ScopeType = 'Page' | 'Prefab' | 'Partial' | 'App';
3
- interface WatchConfig {
4
- arrayType?: boolean;
5
- isList?: boolean;
6
- }
1
+ export declare const FIRST_TIME_WATCH: {};
7
2
  export declare const isFirstTimeChange: (v: any) => boolean;
8
3
  export declare const debounce: (fn: Function, wait?: number) => (...args: any[]) => void;
9
4
  export declare const muteWatchers: () => void;
10
5
  export declare const unMuteWatchers: () => void;
11
- /**
12
- * Main watch function
13
- */
14
- export declare const $watch: (expr: string, $scope: any, $locals: any, listener: any, identifier?: string, doNotClone?: boolean, config?: WatchConfig, isMuted?: () => boolean) => () => void;
15
- /**
16
- * Unwatches a single identifier
17
- */
18
- export declare const $unwatch: (identifier: string) => boolean;
19
- /**
20
- * Unwatches all watchers for a specific widget ID
21
- */
22
- export declare const $unwatchAll: (widgetId: string) => number;
23
- /**
24
- * Unwatches all watchers for a specific scope (Page, Prefab, Partial, or App)
25
- * Now works directly with the main registry instead of separate scoped registries
26
- */
27
- export declare const $unwatchAllByScope: (scopeType: ScopeType, scopeName?: string) => number;
28
- export declare const setNgZone: (zone: any) => void;
6
+ export declare const $watch: (expr: any, $scope: any, $locals: any, listener: any, identifier?: string, doNotClone?: boolean, config?: any, isMuted?: () => boolean) => () => boolean;
7
+ export declare const $unwatch: (identifier: any) => boolean;
8
+ export declare const setNgZone: (zone: any) => any;
29
9
  export declare const setAppRef: (ref: any) => void;
30
10
  export declare const isChangeFromWatch: () => boolean;
31
- export declare const resetChangeFromWatch: () => void;
11
+ export declare const resetChangeFromWatch: () => boolean;
32
12
  export declare const $invokeWatchers: (force?: boolean, ignoreMuted?: boolean) => void;
33
13
  export declare const $appDigest: (force?: boolean) => void;
34
- export {};
@@ -1,12 +1,12 @@
1
1
  {
2
2
  "name": "@wavemaker/app-ng-runtime",
3
- "version": "11.14.2-1.6423",
3
+ "version": "11.14.2-2.6435",
4
4
  "lockfileVersion": 3,
5
5
  "requires": true,
6
6
  "packages": {
7
7
  "": {
8
8
  "name": "@wavemaker/app-ng-runtime",
9
- "version": "11.14.2-1.6423",
9
+ "version": "11.14.2-2.6435",
10
10
  "license": "MIT",
11
11
  "engines": {
12
12
  "node": ">=18.16.1",
package/package-lock.json CHANGED
@@ -1,12 +1,12 @@
1
1
  {
2
2
  "name": "@wavemaker/app-ng-runtime",
3
- "version": "11.14.2-1.6423",
3
+ "version": "11.14.2-2.6435",
4
4
  "lockfileVersion": 3,
5
5
  "requires": true,
6
6
  "packages": {
7
7
  "": {
8
8
  "name": "@wavemaker/app-ng-runtime",
9
- "version": "11.14.2-1.6423",
9
+ "version": "11.14.2-2.6435",
10
10
  "license": "MIT",
11
11
  "engines": {
12
12
  "node": ">=18.16.1",
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@wavemaker/app-ng-runtime",
3
- "version": "11.14.2-1.6423",
3
+ "version": "11.14.2-2.6435",
4
4
  "description": "All modules required for a WaveMaker application.",
5
5
  "main": "index.js",
6
6
  "scripts": {
@@ -890,41 +890,7 @@
890
890
  });
891
891
  }
892
892
  ngOnDestroy() {
893
- // MEMORY LEAK FIX: Unwatch all Partial-scoped watchers for THIS specific partial when partial is destroyed
894
- // Only unwatch watchers for this partial, not all partials (other partials may still be on the page)
895
- if (this.partialName) {
896
- i1.$unwatchAllByScope('Partial', this.partialName);
897
- }
898
- // MEMORY LEAK FIX: Complete Subjects to release subscriptions
899
- if (this.destroy$) {
900
- this.destroy$.complete();
901
- this.destroy$ = null;
902
- }
903
- if (this.viewInit$) {
904
- this.viewInit$.complete();
905
- this.viewInit$ = null;
906
- }
907
- // MEMORY LEAK FIX: Clear references to prevent memory leaks
908
- this.Widgets = null;
909
- this.Variables = null;
910
- this.Actions = null;
911
- this.App = null;
912
- this.containerWidget = null;
913
- this.i18nService = null;
914
- this.appLocale = null;
915
- this.partialDirective = null;
916
- this.pageDirective = null;
917
- this.Prefab = null;
918
- this.scriptLoaderService = null;
919
- this.Viewport = null;
920
- this.route = null;
921
- this.appManager = null;
922
- this.navigationService = null;
923
- this.router = null;
924
- this.pageParams = null;
925
- this.viewParent = null;
926
- // MEMORY LEAK FIX: Cleanup FragmentMonitor resources
927
- this.cleanupFragmentMonitor();
893
+ this.destroy$.complete();
928
894
  }
929
895
  ngOnAttach(refreshData) {
930
896
  this.unmute();
@@ -1370,41 +1336,9 @@
1370
1336
  }
1371
1337
  ngOnDestroy() {
1372
1338
  // MEMORY LEAK FIX: Unwatch all Page-scoped watchers for THIS specific page when page is destroyed
1373
- if (this.pageName) {
1374
- const removedCount = i1.$unwatchAllByScope('Page', this.pageName);
1375
- if (removedCount > 0) {
1376
- console.log(`🧹 Cleaned up ${removedCount} Page-scoped watcher(s) for page ${this.pageName}`);
1377
- }
1378
- }
1379
1339
  //this.captureApplicationThumbnail();
1380
1340
  this.savePageSnapShot();
1381
- // MEMORY LEAK FIX: Complete Subjects to release subscriptions
1382
- if (this.destroy$) {
1383
- this.destroy$.complete();
1384
- this.destroy$ = null;
1385
- }
1386
- if (this.viewInit$) {
1387
- this.viewInit$.complete();
1388
- this.viewInit$ = null;
1389
- }
1390
- // MEMORY LEAK FIX: Clear references to prevent memory leaks
1391
- this.Widgets = null;
1392
- this.Variables = null;
1393
- this.Actions = null;
1394
- this.App = null;
1395
- this.route = null;
1396
- this.appManager = null;
1397
- this.navigationService = null;
1398
- this.router = null;
1399
- this.pageParams = null;
1400
- this.i18nService = null;
1401
- this.appLocale = null;
1402
- this.pageDirective = null;
1403
- this.$page = null;
1404
- this.scriptLoaderService = null;
1405
- this.Viewport = null;
1406
- // MEMORY LEAK FIX: Cleanup FragmentMonitor resources
1407
- this.cleanupFragmentMonitor();
1341
+ this.destroy$.complete();
1408
1342
  }
1409
1343
  captureApplicationThumbnail() {
1410
1344
  const root = this;
@@ -2027,36 +1961,7 @@
2027
1961
  });
2028
1962
  }
2029
1963
  ngOnDestroy() {
2030
- // MEMORY LEAK FIX: Unwatch all Prefab-scoped watchers for THIS specific prefab when prefab is destroyed
2031
- // Only unwatch watchers for this prefab, not all prefabs (other prefabs may still be on the page)
2032
- if (this.prefabName) {
2033
- i1.$unwatchAllByScope('Prefab', this.prefabName);
2034
- }
2035
- // MEMORY LEAK FIX: Complete Subjects to release subscriptions
2036
- if (this.destroy$) {
2037
- this.destroy$.complete();
2038
- this.destroy$ = null;
2039
- }
2040
- if (this.viewInit$) {
2041
- this.viewInit$.complete();
2042
- this.viewInit$ = null;
2043
- }
2044
- // MEMORY LEAK FIX: Clear references to prevent memory leaks
2045
- this.Widgets = null;
2046
- this.Variables = null;
2047
- this.Actions = null;
2048
- this.App = null;
2049
- this.containerWidget = null;
2050
- this.prefabMngr = null;
2051
- this.i18nService = null;
2052
- this.appLocale = null;
2053
- this.prefabContainerDirective = null;
2054
- this.scriptLoaderService = null;
2055
- this.pageDirective = null;
2056
- this.Viewport = null;
2057
- this.viewParent = null;
2058
- // MEMORY LEAK FIX: Cleanup FragmentMonitor resources
2059
- this.cleanupFragmentMonitor();
1964
+ this.destroy$.complete();
2060
1965
  }
2061
1966
  // user overrides this
2062
1967
  onPropertyChange() { }
@@ -2797,42 +2702,8 @@
2797
2702
  });
2798
2703
  }
2799
2704
  ngOnDestroy() {
2800
- // MEMORY LEAK FIX: Unwatch all Page-scoped watchers for THIS specific page when page is destroyed
2801
- if (this.pageName) {
2802
- i1.$unwatchAllByScope('Page', this.pageName);
2803
- // if (removedCount > 0) {
2804
- // console.log(`🧹 Cleaned up ${removedCount} Page-scoped watcher(s) for page ${this.pageName}`);
2805
- // }
2806
- }
2807
2705
  this.savePageSnapShot();
2808
- // MEMORY LEAK FIX: Complete Subjects to release subscriptions
2809
- if (this.destroy$) {
2810
- this.destroy$.complete();
2811
- this.destroy$ = null;
2812
- }
2813
- if (this.viewInit$) {
2814
- this.viewInit$.complete();
2815
- this.viewInit$ = null;
2816
- }
2817
- // MEMORY LEAK FIX: Clear references to prevent memory leaks
2818
- this.Widgets = null;
2819
- this.Variables = null;
2820
- this.Actions = null;
2821
- this.App = null;
2822
- this.route = null;
2823
- this.appManager = null;
2824
- this.navigationService = null;
2825
- this.router = null;
2826
- this.pageParams = null;
2827
- this.i18nService = null;
2828
- this.appLocale = null;
2829
- this.layoutDirective = null;
2830
- this.spaPageDirective = null;
2831
- this.$page = null;
2832
- this.scriptLoaderService = null;
2833
- this.Viewport = null;
2834
- // MEMORY LEAK FIX: Cleanup FragmentMonitor resources
2835
- this.cleanupFragmentMonitor();
2706
+ this.destroy$.complete();
2836
2707
  }
2837
2708
  onReady() { }
2838
2709
  onBeforePageReady() { }
@@ -4590,7 +4461,6 @@
4590
4461
  this.isApplicationType = false;
4591
4462
  this.enableSkipToMainContent = i1.getWmProjectProperties().enableSkipToMainContent === 'true' || i1.getWmProjectProperties().enableSkipToMainContent === true;
4592
4463
  this.retryCount = 0;
4593
- this.appManagerSubscriptions = []; // MEMORY LEAK FIX: Track appManager subscriptions
4594
4464
  this.appLocale = {};
4595
4465
  this.spinner = { show: false, messages: [], arialabel: '' };
4596
4466
  this.isOAuthDialogOpen = false;
@@ -4603,8 +4473,7 @@
4603
4473
  this.customIconsLoaderService.load();
4604
4474
  }
4605
4475
  // subscribe to OAuth changes
4606
- // MEMORY LEAK FIX: Store subscription reference for cleanup
4607
- this.oAuthProvidersSubscription = oAuthService.getOAuthProvidersAsObservable().subscribe((providers) => {
4476
+ oAuthService.getOAuthProvidersAsObservable().subscribe((providers) => {
4608
4477
  this.providersConfig = providers;
4609
4478
  if (providers.length) {
4610
4479
  this.showOAuthDialog();
@@ -4614,8 +4483,7 @@
4614
4483
  }
4615
4484
  });
4616
4485
  // Subscribe to the message source to show/hide app spinner
4617
- // MEMORY LEAK FIX: Store subscription reference for cleanup
4618
- this.spinnerMessageSubscription = this.spinnerService.getMessageSource().asObservable().subscribe((data) => {
4486
+ this.spinnerService.getMessageSource().asObservable().subscribe((data) => {
4619
4487
  // setTimeout is to avoid 'ExpressionChangedAfterItHasBeenCheckedError'
4620
4488
  setTimeout(() => {
4621
4489
  this.spinner.show = data.show;
@@ -4627,8 +4495,7 @@
4627
4495
  utils.setTheme('bs3');
4628
4496
  let spinnerId;
4629
4497
  let onPageRendered = i1.noop;
4630
- // MEMORY LEAK FIX: Store subscription reference for cleanup
4631
- this.routerEventsSubscription = this.router.events.subscribe(e => {
4498
+ this.router.events.subscribe(e => {
4632
4499
  if (e instanceof i1$1.NavigationStart) {
4633
4500
  let page = e.url.split('?')[0];
4634
4501
  page = page.substring(1);
@@ -4663,13 +4530,12 @@
4663
4530
  }, 1000);
4664
4531
  }
4665
4532
  });
4666
- // MEMORY LEAK FIX: Store subscription unsubscribe functions
4667
- this.appManagerSubscriptions.push(this.appManager.subscribe('pageReady', () => {
4533
+ this.appManager.subscribe('pageReady', () => {
4668
4534
  onPageRendered();
4669
- }));
4670
- this.appManagerSubscriptions.push(this.appManager.subscribe('pageAttach', () => {
4535
+ });
4536
+ this.appManager.subscribe('pageAttach', () => {
4671
4537
  onPageRendered();
4672
- }));
4538
+ });
4673
4539
  }
4674
4540
  showOAuthDialog() {
4675
4541
  if (!this.isOAuthDialogOpen) {
@@ -4744,35 +4610,9 @@
4744
4610
  i1.$invokeWatchers();
4745
4611
  }
4746
4612
  ngOnDestroy() {
4747
- // MEMORY LEAK FIX: Unwatch all App-scoped watchers when app is destroyed
4748
- i1.$unwatchAllByScope('App');
4749
- // MEMORY LEAK FIX: Unsubscribe from navigation end subscription
4750
4613
  if (this.navigationEndSubscription) {
4751
4614
  this.navigationEndSubscription.unsubscribe();
4752
- this.navigationEndSubscription = null;
4753
4615
  }
4754
- // MEMORY LEAK FIX: Unsubscribe from OAuth providers subscription
4755
- if (this.oAuthProvidersSubscription) {
4756
- this.oAuthProvidersSubscription.unsubscribe();
4757
- this.oAuthProvidersSubscription = null;
4758
- }
4759
- // MEMORY LEAK FIX: Unsubscribe from spinner message subscription
4760
- if (this.spinnerMessageSubscription) {
4761
- this.spinnerMessageSubscription.unsubscribe();
4762
- this.spinnerMessageSubscription = null;
4763
- }
4764
- // MEMORY LEAK FIX: Unsubscribe from router events subscription
4765
- if (this.routerEventsSubscription) {
4766
- this.routerEventsSubscription.unsubscribe();
4767
- this.routerEventsSubscription = null;
4768
- }
4769
- // MEMORY LEAK FIX: Unsubscribe from appManager subscriptions
4770
- this.appManagerSubscriptions.forEach(unsubscribe => {
4771
- if (unsubscribe) {
4772
- unsubscribe();
4773
- }
4774
- });
4775
- this.appManagerSubscriptions = [];
4776
4616
  }
4777
4617
  static { this.ɵfac = i0__namespace.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0__namespace, type: AppComponent, deps: [{ token: PipeProvider }, { token: i0__namespace.ApplicationRef }, { token: i0__namespace.ElementRef }, { token: i2$2__namespace.OAuthService }, { token: i1__namespace.AbstractDialogService }, { token: i1__namespace.AbstractSpinnerService }, { token: i0__namespace.NgZone }, { token: i1$1__namespace.Router }, { token: i1__namespace.App }, { token: AppManagerService }, { token: i1__namespace.CustomIconsLoaderService }], target: i0__namespace.ɵɵFactoryTarget.Component }); }
4778
4618
  static { this.ɵcmp = i0__namespace.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: AppComponent, isStandalone: true, selector: "app-root", viewQueries: [{ propertyName: "routerOutlet", first: true, predicate: i1$1.RouterOutlet, descendants: true }, { propertyName: "dynamicComponentContainerRef", first: true, predicate: ["dynamicComponent"], descendants: true, read: i0.ViewContainerRef }], ngImport: i0__namespace, template: "@if (startApp) {\n @if(enableSkipToMainContent) {\n <div id=\"app-focus-start\" tabindex=\"-1\"></div>\n <a href=\"javascript:void(0);\" class=\"skip\" (click)=\"skipToAppContent($event)\">{{appLocale.LABEL_SKIP_TO_MAIN_CONTENT || 'Skip to main content'}}</a>\n }\n <router-outlet></router-outlet>\n @if (isApplicationType) {\n <div wmContainer partialContainer content=\"Common\" hidden class=\"ng-hide\"></div>\n }\n <app-spinner name=\"globalspinner\" classname=\"global-spinner\" role=\"alert\" aria-live=\"assertive\" [attr.aria-label]=\"spinner.arialabel || 'Loading'\" [show]=\"spinner.show\" [spinnermessages]=\"spinner.messages\"></app-spinner>\n <div wmDialog name=\"oAuthLoginDialog\" title=\"Application is requesting you to sign in with\"\n close.event=\"closeOAuthDialog()\">\n <ng-template #dialogBody>\n <ul class=\"list-items\">\n @for (provider of providersConfig; track provider) {\n <li class=\"list-item\">\n <button class=\"btn\" (click)=\"provider.invoke()\">{{provider.name}}</button>\n </li>\n }\n </ul>\n </ng-template>\n </div>\n <div wmConfirmDialog name=\"_app-confirm-dialog\" title.bind=\"title\" message.bind=\"message\" oktext.bind=\"oktext\"\n canceltext.bind=\"canceltext\" closable=\"false\" iconclass.bind=\"iconclass\"\n escape.event=\"onEscape()\" ok.event=\"onOk()\" cancel.event=\"onCancel()\" close.event=\"onClose()\" opened.event=\"onOpen()\"></div>\n @if (!isApplicationType) {\n <div wmConfirmDialog name=\"PrefabConfirmDialog\" title.bind=\"title\" message.bind=\"text\" oktext.bind=\"okButtonText\"\n canceltext.bind=\"cancelButtonText\" closable=\"false\" iconclass.bind=\"iconclass\"\n escape.event=\"onEscape()\" ok.event=\"onOk()\" cancel.event=\"onCancel()\" close.event=\"onClose()\" opened.event=\"onOpen()\"></div>\n }\n @if (!isApplicationType) {\n <div wmAlertDialog name=\"PrefabAlertDialog\" title.bind=\"title\" message.bind=\"text\" oktext.bind=\"okButtonText\"\n canceltext.bind=\"cancelButtonText\" closable=\"false\" iconclass.bind=\"iconclass\"\n escape.event=\"onEscape()\" ok.event=\"onOk()\" cancel.event=\"onCancel()\" close.event=\"onClose()\" opened.event=\"onOpen()\"></div>\n }\n <div wmAppExt></div>\n <i id=\"wm-mobile-display\"></i>\n}\n<!--Dummy container to create the component dynamically-->\n<ng-container #dynamicComponent></ng-container>\n", dependencies: [{ kind: "ngmodule", type: i5.CommonModule }, { kind: "directive", type: i1$1.RouterOutlet, selector: "router-outlet", inputs: ["name"], outputs: ["activate", "deactivate", "attach", "detach"], exportAs: ["outlet"] }, { kind: "component", type: alertDialog.AlertDialogComponent, selector: "div[wmAlertDialog]" }, { kind: "component", type: confirmDialog.ConfirmDialogComponent, selector: "div[wmConfirmDialog]" }, { kind: "component", type: designDialog.DialogComponent, selector: "div[wmDialog]" }, { kind: "component", type: AppSpinnerComponent, selector: "app-spinner", inputs: ["show", "spinnermessages", "classname", "arialabel"] }, { kind: "directive", type: base.ContainerDirective, selector: "[wmContainer]" }, { kind: "directive", type: base.PartialParamHandlerDirective, selector: "[partialContainer]" }, { kind: "directive", type: base.PartialContainerDirective, selector: "[partialContainer]" }], encapsulation: i0__namespace.ViewEncapsulation.None }); }
@@ -24,10 +24,6 @@ export declare class AppComponent implements DoCheck, AfterViewInit, OnDestroy {
24
24
  enableSkipToMainContent: boolean;
25
25
  private retryCount;
26
26
  private navigationEndSubscription;
27
- private oAuthProvidersSubscription;
28
- private spinnerMessageSubscription;
29
- private routerEventsSubscription;
30
- private appManagerSubscriptions;
31
27
  appLocale: any;
32
28
  routerOutlet: RouterOutlet;
33
29
  dynamicComponentContainerRef: ViewContainerRef;
@@ -4,7 +4,7 @@ import { ConfirmDialogComponent } from '@wm/components/dialogs/confirm-dialog';
4
4
  import { ApplicationRef, Component, ElementRef, NgZone, ViewChild, ViewContainerRef, ViewEncapsulation } from '@angular/core';
5
5
  import { NavigationCancel, NavigationEnd, NavigationError, NavigationStart, Router, RouterOutlet } from '@angular/router';
6
6
  import { setTheme } from 'ngx-bootstrap/utils';
7
- import { $invokeWatchers, $unwatchAllByScope, AbstractDialogService, AbstractSpinnerService, addClass, App, CustomIconsLoaderService, getWmProjectProperties, noop, removeClass, setAppRef, setNgZone, setPipeProvider } from '@wm/core';
7
+ import { $invokeWatchers, AbstractDialogService, AbstractSpinnerService, addClass, App, CustomIconsLoaderService, getWmProjectProperties, noop, removeClass, setAppRef, setNgZone, setPipeProvider } from '@wm/core';
8
8
  import { OAuthService } from '@wm/oAuth';
9
9
  import { AppManagerService } from '../../services/app.manager.service';
10
10
  import { PipeProvider } from '../../services/pipe-provider.service';
@@ -32,7 +32,6 @@ export class AppComponent {
32
32
  this.isApplicationType = false;
33
33
  this.enableSkipToMainContent = getWmProjectProperties().enableSkipToMainContent === 'true' || getWmProjectProperties().enableSkipToMainContent === true;
34
34
  this.retryCount = 0;
35
- this.appManagerSubscriptions = []; // MEMORY LEAK FIX: Track appManager subscriptions
36
35
  this.appLocale = {};
37
36
  this.spinner = { show: false, messages: [], arialabel: '' };
38
37
  this.isOAuthDialogOpen = false;
@@ -45,8 +44,7 @@ export class AppComponent {
45
44
  this.customIconsLoaderService.load();
46
45
  }
47
46
  // subscribe to OAuth changes
48
- // MEMORY LEAK FIX: Store subscription reference for cleanup
49
- this.oAuthProvidersSubscription = oAuthService.getOAuthProvidersAsObservable().subscribe((providers) => {
47
+ oAuthService.getOAuthProvidersAsObservable().subscribe((providers) => {
50
48
  this.providersConfig = providers;
51
49
  if (providers.length) {
52
50
  this.showOAuthDialog();
@@ -56,8 +54,7 @@ export class AppComponent {
56
54
  }
57
55
  });
58
56
  // Subscribe to the message source to show/hide app spinner
59
- // MEMORY LEAK FIX: Store subscription reference for cleanup
60
- this.spinnerMessageSubscription = this.spinnerService.getMessageSource().asObservable().subscribe((data) => {
57
+ this.spinnerService.getMessageSource().asObservable().subscribe((data) => {
61
58
  // setTimeout is to avoid 'ExpressionChangedAfterItHasBeenCheckedError'
62
59
  setTimeout(() => {
63
60
  this.spinner.show = data.show;
@@ -69,8 +66,7 @@ export class AppComponent {
69
66
  setTheme('bs3');
70
67
  let spinnerId;
71
68
  let onPageRendered = noop;
72
- // MEMORY LEAK FIX: Store subscription reference for cleanup
73
- this.routerEventsSubscription = this.router.events.subscribe(e => {
69
+ this.router.events.subscribe(e => {
74
70
  if (e instanceof NavigationStart) {
75
71
  let page = e.url.split('?')[0];
76
72
  page = page.substring(1);
@@ -105,13 +101,12 @@ export class AppComponent {
105
101
  }, 1000);
106
102
  }
107
103
  });
108
- // MEMORY LEAK FIX: Store subscription unsubscribe functions
109
- this.appManagerSubscriptions.push(this.appManager.subscribe('pageReady', () => {
104
+ this.appManager.subscribe('pageReady', () => {
110
105
  onPageRendered();
111
- }));
112
- this.appManagerSubscriptions.push(this.appManager.subscribe('pageAttach', () => {
106
+ });
107
+ this.appManager.subscribe('pageAttach', () => {
113
108
  onPageRendered();
114
- }));
109
+ });
115
110
  }
116
111
  showOAuthDialog() {
117
112
  if (!this.isOAuthDialogOpen) {
@@ -186,35 +181,9 @@ export class AppComponent {
186
181
  $invokeWatchers();
187
182
  }
188
183
  ngOnDestroy() {
189
- // MEMORY LEAK FIX: Unwatch all App-scoped watchers when app is destroyed
190
- $unwatchAllByScope('App');
191
- // MEMORY LEAK FIX: Unsubscribe from navigation end subscription
192
184
  if (this.navigationEndSubscription) {
193
185
  this.navigationEndSubscription.unsubscribe();
194
- this.navigationEndSubscription = null;
195
- }
196
- // MEMORY LEAK FIX: Unsubscribe from OAuth providers subscription
197
- if (this.oAuthProvidersSubscription) {
198
- this.oAuthProvidersSubscription.unsubscribe();
199
- this.oAuthProvidersSubscription = null;
200
- }
201
- // MEMORY LEAK FIX: Unsubscribe from spinner message subscription
202
- if (this.spinnerMessageSubscription) {
203
- this.spinnerMessageSubscription.unsubscribe();
204
- this.spinnerMessageSubscription = null;
205
186
  }
206
- // MEMORY LEAK FIX: Unsubscribe from router events subscription
207
- if (this.routerEventsSubscription) {
208
- this.routerEventsSubscription.unsubscribe();
209
- this.routerEventsSubscription = null;
210
- }
211
- // MEMORY LEAK FIX: Unsubscribe from appManager subscriptions
212
- this.appManagerSubscriptions.forEach(unsubscribe => {
213
- if (unsubscribe) {
214
- unsubscribe();
215
- }
216
- });
217
- this.appManagerSubscriptions = [];
218
187
  }
219
188
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AppComponent, deps: [{ token: i1.PipeProvider }, { token: i0.ApplicationRef }, { token: i0.ElementRef }, { token: i2.OAuthService }, { token: i3.AbstractDialogService }, { token: i3.AbstractSpinnerService }, { token: i0.NgZone }, { token: i4.Router }, { token: i3.App }, { token: i5.AppManagerService }, { token: i3.CustomIconsLoaderService }], target: i0.ɵɵFactoryTarget.Component }); }
220
189
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: AppComponent, isStandalone: true, selector: "app-root", viewQueries: [{ propertyName: "routerOutlet", first: true, predicate: RouterOutlet, descendants: true }, { propertyName: "dynamicComponentContainerRef", first: true, predicate: ["dynamicComponent"], descendants: true, read: ViewContainerRef }], ngImport: i0, template: "@if (startApp) {\n @if(enableSkipToMainContent) {\n <div id=\"app-focus-start\" tabindex=\"-1\"></div>\n <a href=\"javascript:void(0);\" class=\"skip\" (click)=\"skipToAppContent($event)\">{{appLocale.LABEL_SKIP_TO_MAIN_CONTENT || 'Skip to main content'}}</a>\n }\n <router-outlet></router-outlet>\n @if (isApplicationType) {\n <div wmContainer partialContainer content=\"Common\" hidden class=\"ng-hide\"></div>\n }\n <app-spinner name=\"globalspinner\" classname=\"global-spinner\" role=\"alert\" aria-live=\"assertive\" [attr.aria-label]=\"spinner.arialabel || 'Loading'\" [show]=\"spinner.show\" [spinnermessages]=\"spinner.messages\"></app-spinner>\n <div wmDialog name=\"oAuthLoginDialog\" title=\"Application is requesting you to sign in with\"\n close.event=\"closeOAuthDialog()\">\n <ng-template #dialogBody>\n <ul class=\"list-items\">\n @for (provider of providersConfig; track provider) {\n <li class=\"list-item\">\n <button class=\"btn\" (click)=\"provider.invoke()\">{{provider.name}}</button>\n </li>\n }\n </ul>\n </ng-template>\n </div>\n <div wmConfirmDialog name=\"_app-confirm-dialog\" title.bind=\"title\" message.bind=\"message\" oktext.bind=\"oktext\"\n canceltext.bind=\"canceltext\" closable=\"false\" iconclass.bind=\"iconclass\"\n escape.event=\"onEscape()\" ok.event=\"onOk()\" cancel.event=\"onCancel()\" close.event=\"onClose()\" opened.event=\"onOpen()\"></div>\n @if (!isApplicationType) {\n <div wmConfirmDialog name=\"PrefabConfirmDialog\" title.bind=\"title\" message.bind=\"text\" oktext.bind=\"okButtonText\"\n canceltext.bind=\"cancelButtonText\" closable=\"false\" iconclass.bind=\"iconclass\"\n escape.event=\"onEscape()\" ok.event=\"onOk()\" cancel.event=\"onCancel()\" close.event=\"onClose()\" opened.event=\"onOpen()\"></div>\n }\n @if (!isApplicationType) {\n <div wmAlertDialog name=\"PrefabAlertDialog\" title.bind=\"title\" message.bind=\"text\" oktext.bind=\"okButtonText\"\n canceltext.bind=\"cancelButtonText\" closable=\"false\" iconclass.bind=\"iconclass\"\n escape.event=\"onEscape()\" ok.event=\"onOk()\" cancel.event=\"onCancel()\" close.event=\"onClose()\" opened.event=\"onOpen()\"></div>\n }\n <div wmAppExt></div>\n <i id=\"wm-mobile-display\"></i>\n}\n<!--Dummy container to create the component dynamically-->\n<ng-container #dynamicComponent></ng-container>\n", dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: RouterOutlet, selector: "router-outlet", inputs: ["name"], outputs: ["activate", "deactivate", "attach", "detach"], exportAs: ["outlet"] }, { kind: "component", type: AlertDialogComponent, selector: "div[wmAlertDialog]" }, { kind: "component", type: ConfirmDialogComponent, selector: "div[wmConfirmDialog]" }, { kind: "component", type: DialogComponent, selector: "div[wmDialog]" }, { kind: "component", type: AppSpinnerComponent, selector: "app-spinner", inputs: ["show", "spinnermessages", "classname", "arialabel"] }, { kind: "directive", type: ContainerDirective, selector: "[wmContainer]" }, { kind: "directive", type: PartialParamHandlerDirective, selector: "[partialContainer]" }, { kind: "directive", type: PartialContainerDirective, selector: "[partialContainer]" }], encapsulation: i0.ViewEncapsulation.None }); }
@@ -229,4 +198,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
229
198
  type: ViewChild,
230
199
  args: ['dynamicComponent', { read: ViewContainerRef }]
231
200
  }] } });
232
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"app.component.js","sourceRoot":"","sources":["../../../../../../projects/runtime-base/src/components/app-component/app.component.ts","../../../../../../projects/runtime-base/src/components/app-component/app.component.html"],"names":[],"mappings":"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","sourcesContent":["import {CommonModule} from '@angular/common';\nimport {AlertDialogComponent} from '@wm/components/dialogs/alert-dialog';\nimport {ConfirmDialogComponent} from '@wm/components/dialogs/confirm-dialog';\nimport {\n    AfterViewInit,\n    ApplicationRef,\n    Component,\n    DoCheck,\n    ElementRef,\n    NgZone,\n    OnDestroy,\n    ViewChild,\n    ViewContainerRef,\n    ViewEncapsulation\n} from '@angular/core';\nimport {\n    ActivatedRoute,\n    NavigationCancel,\n    NavigationEnd,\n    NavigationError,\n    NavigationStart,\n    Router,\n    RouterOutlet\n} from '@angular/router';\n\nimport {setTheme} from 'ngx-bootstrap/utils';\n\nimport {\n    $invokeWatchers,\n    $unwatchAllByScope,\n    AbstractDialogService,\n    AbstractSpinnerService,\n    addClass,\n    App,\n    CustomIconsLoaderService,\n    getWmProjectProperties,\n    noop,\n    removeClass,\n    setAppRef,\n    setNgZone,\n    setPipeProvider\n} from '@wm/core';\nimport {OAuthService} from '@wm/oAuth';\nimport {AppManagerService} from '../../services/app.manager.service';\nimport {PipeProvider} from '../../services/pipe-provider.service';\nimport {AppSpinnerComponent} from '../app-spinner.component';\nimport {DialogComponent} from '@wm/components/dialogs/design-dialog';\nimport {ContainerDirective, PartialContainerDirective, PartialParamHandlerDirective} from '@wm/components/base';\nimport {filter} from \"rxjs/operators\";\nimport {Subscription} from \"rxjs\";\n\ninterface SPINNER {\n    show: boolean;\n    messages: Array<string>;\n    arialabel: string;\n}\n@Component({\n    standalone: true,\n    imports: [CommonModule, RouterOutlet, AlertDialogComponent, ConfirmDialogComponent, DialogComponent, AppSpinnerComponent, ContainerDirective, PartialParamHandlerDirective , PartialContainerDirective],\n    selector: 'app-root',\n    templateUrl: './app.component.html',\n    encapsulation: ViewEncapsulation.None\n})\nexport class AppComponent implements DoCheck, AfterViewInit, OnDestroy {\n    public startApp = false;\n    public isApplicationType = false;\n    public enableSkipToMainContent = getWmProjectProperties().enableSkipToMainContent === 'true' || getWmProjectProperties().enableSkipToMainContent === true;\n    private retryCount = 0;\n    private navigationEndSubscription!: Subscription;\n    private oAuthProvidersSubscription!: Subscription;\n    private spinnerMessageSubscription!: Subscription;\n    private routerEventsSubscription!: Subscription;\n    private appManagerSubscriptions: Array<() => void> = []; // MEMORY LEAK FIX: Track appManager subscriptions\n    appLocale: any = {};\n\n    @ViewChild(RouterOutlet) routerOutlet: RouterOutlet;\n\n    @ViewChild('dynamicComponent', { read: ViewContainerRef }) dynamicComponentContainerRef: ViewContainerRef;\n\n    spinner: SPINNER = { show: false, messages: [], arialabel: '' };\n    constructor(\n        _pipeProvider: PipeProvider,\n        _appRef: ApplicationRef,\n        private elRef: ElementRef,\n        private oAuthService: OAuthService,\n        private dialogService: AbstractDialogService,\n        private spinnerService: AbstractSpinnerService,\n        ngZone: NgZone,\n        private router: Router,\n        public app: App,\n        private appManager: AppManagerService,\n        private customIconsLoaderService: CustomIconsLoaderService\n    ) {\n        setPipeProvider(_pipeProvider);\n        setNgZone(ngZone);\n        setAppRef(_appRef);\n\n        this.appLocale = app.appLocale;\n        this.isApplicationType = getWmProjectProperties().type === 'APPLICATION';\n        if (this.isApplicationType) {\n            this.customIconsLoaderService.load();\n        }\n\n        // subscribe to OAuth changes\n        // MEMORY LEAK FIX: Store subscription reference for cleanup\n        this.oAuthProvidersSubscription = oAuthService.getOAuthProvidersAsObservable().subscribe((providers: any) => {\n            this.providersConfig = providers;\n            if (providers.length) {\n                this.showOAuthDialog();\n            } else {\n                this.closeOAuthDialog();\n            }\n        });\n\n        // Subscribe to the message source to show/hide app spinner\n        // MEMORY LEAK FIX: Store subscription reference for cleanup\n        this.spinnerMessageSubscription = this.spinnerService.getMessageSource().asObservable().subscribe((data: any) => {\n            // setTimeout is to avoid 'ExpressionChangedAfterItHasBeenCheckedError'\n            setTimeout(() => {\n                this.spinner.show = data.show;\n                this.spinner.messages = data.messages;\n                this.spinner.arialabel = data.messages.toString();\n            });\n        });\n\n        // set theme to bs3 on ngx-bootstrap. This avoids runtime calculation to determine bs theme. Thus resolves performance.\n        setTheme('bs3');\n\n        let spinnerId;\n\n        let onPageRendered = noop;\n\n        // MEMORY LEAK FIX: Store subscription reference for cleanup\n        this.routerEventsSubscription = this.router.events.subscribe(e => {\n            if (e instanceof NavigationStart) {\n                let page = e.url.split('?')[0];\n                page = page.substring(1);\n\n                if (!page) {\n                    this.app.activeLayoutName = '';\n                    this.app.layoutPages = [];\n                }\n                if (this.app.activeLayoutName && this.app.layoutPages && this.app.layoutPages.length && this.app.layoutPages.includes(page)) {\n                    spinnerId = this.spinnerService.show('', 'wmRouterOutlet', '', 'wmRouterOutlet');\n                } else {\n                    spinnerId = this.spinnerService.show('', 'globalSpinner');\n                }\n\n                const node = document.querySelector('app-page-outlet') as HTMLElement;\n                if (node) {\n                    addClass(node, 'page-load-in-progress');\n                }\n\n                const pageLoadStartTime = Date.now();\n                onPageRendered = () => {\n                    this.spinnerService.hide(spinnerId);\n                    const node = document.querySelector('app-page-outlet') as HTMLElement;\n                    if (node) {\n                        removeClass(node, 'page-load-in-progress');\n                    }\n                    onPageRendered = noop;\n                    this.app.activePageLoadTime = Date.now() - pageLoadStartTime;\n                };\n            } else if (e instanceof NavigationEnd || e instanceof NavigationCancel || e instanceof NavigationError) {\n                setTimeout(() => {\n                    onPageRendered();\n                }, 1000);\n            }\n        });\n        // MEMORY LEAK FIX: Store subscription unsubscribe functions\n        this.appManagerSubscriptions.push(this.appManager.subscribe('pageReady', () => {\n            onPageRendered();\n        }));\n        this.appManagerSubscriptions.push(this.appManager.subscribe('pageAttach', () => {\n            onPageRendered();\n        }));\n    }\n\n    providersConfig;\n    isOAuthDialogOpen = false;\n\n    showOAuthDialog() {\n        if (!this.isOAuthDialogOpen) {\n            this.isOAuthDialogOpen = true;\n            this.dialogService.open('oAuthLoginDialog', this);\n        }\n    }\n\n    closeOAuthDialog() {\n        if (this.isOAuthDialogOpen) {\n            this.isOAuthDialogOpen = false;\n            this.dialogService.close('oAuthLoginDialog', this);\n        }\n    }\n\n    private start() {\n        //to fix the issue that happens only in the development mode\n        //ExpressionChangedAfterItHasBeenCheckedError\n        //fix: https://blog.angular-university.io/angular-debugging/\n        setTimeout(() => {\n            this.startApp = true;\n        });\n        setTimeout(() => {\n            this.app.dynamicComponentContainerRef = this.dynamicComponentContainerRef;\n            this.overrideRouterOutlet();\n        }, 10);\n    }\n\n    private overrideRouterOutlet() {\n        //override the attach/detach methods\n        const oAttach = this.routerOutlet.attach;\n        const oDetach = this.routerOutlet.detach;\n        this.routerOutlet.attach = (componentRef: any, activatedRoute:  ActivatedRoute) => {\n            oAttach.call(this.routerOutlet, componentRef, activatedRoute);\n            componentRef.instance.ngOnAttach();\n        };\n        this.routerOutlet.detach = () => {\n            this.app.activePage.ngOnDetach();\n            const componentRef = oDetach.call(this.routerOutlet);\n            return componentRef;\n        };\n    }\n\n    skipToAppContent(event: Event): void {\n        event.preventDefault();\n        this.retryCount = 0;\n        this.tryFocusContent();\n    }\n\n    private tryFocusContent(): void {\n        const contentEl = document.querySelector('.app-page-content') as HTMLElement;\n\n        if (contentEl) {\n            contentEl.setAttribute('tabindex', '-1'); // Ensure it's focusable\n            contentEl.focus({ preventScroll: false });\n            contentEl.scrollIntoView({ behavior: 'smooth' });\n        } else if (this.retryCount < 10) {\n            this.retryCount++;\n            setTimeout(() => this.tryFocusContent(), 100); // Retry every 100ms\n        }\n    }\n\n    ngAfterViewInit() {\n        document.documentElement.setAttribute('lang', getWmProjectProperties().defaultLanguage);\n        this.start();\n\n        if (this.enableSkipToMainContent) {\n           this.navigationEndSubscription = this.router.events\n                .pipe(filter((e) => e instanceof NavigationEnd))\n                .subscribe(() => {\n                    const el = document.getElementById('app-focus-start');\n                    if (el) {\n                        el.focus();\n                    }\n                });\n        }\n    }\n\n    ngDoCheck() {\n        $invokeWatchers();\n    }\n\n    ngOnDestroy() {\n        // MEMORY LEAK FIX: Unwatch all App-scoped watchers when app is destroyed\n        $unwatchAllByScope('App');\n        \n        // MEMORY LEAK FIX: Unsubscribe from navigation end subscription\n        if (this.navigationEndSubscription){\n            this.navigationEndSubscription.unsubscribe();\n            this.navigationEndSubscription = null;\n        }\n\n        // MEMORY LEAK FIX: Unsubscribe from OAuth providers subscription\n        if (this.oAuthProvidersSubscription) {\n            this.oAuthProvidersSubscription.unsubscribe();\n            this.oAuthProvidersSubscription = null;\n        }\n\n        // MEMORY LEAK FIX: Unsubscribe from spinner message subscription\n        if (this.spinnerMessageSubscription) {\n            this.spinnerMessageSubscription.unsubscribe();\n            this.spinnerMessageSubscription = null;\n        }\n\n        // MEMORY LEAK FIX: Unsubscribe from router events subscription\n        if (this.routerEventsSubscription) {\n            this.routerEventsSubscription.unsubscribe();\n            this.routerEventsSubscription = null;\n        }\n\n        // MEMORY LEAK FIX: Unsubscribe from appManager subscriptions\n        this.appManagerSubscriptions.forEach(unsubscribe => {\n            if (unsubscribe) {\n                unsubscribe();\n            }\n        });\n        this.appManagerSubscriptions = [];\n    }\n}\n","@if (startApp) {\n    @if(enableSkipToMainContent) {\n        <div id=\"app-focus-start\" tabindex=\"-1\"></div>\n        <a href=\"javascript:void(0);\" class=\"skip\" (click)=\"skipToAppContent($event)\">{{appLocale.LABEL_SKIP_TO_MAIN_CONTENT || 'Skip to main content'}}</a>\n    }\n    <router-outlet></router-outlet>\n  @if (isApplicationType) {\n    <div wmContainer partialContainer content=\"Common\" hidden class=\"ng-hide\"></div>\n  }\n  <app-spinner name=\"globalspinner\" classname=\"global-spinner\" role=\"alert\" aria-live=\"assertive\" [attr.aria-label]=\"spinner.arialabel || 'Loading'\" [show]=\"spinner.show\" [spinnermessages]=\"spinner.messages\"></app-spinner>\n  <div wmDialog name=\"oAuthLoginDialog\" title=\"Application is requesting you to sign in with\"\n    close.event=\"closeOAuthDialog()\">\n    <ng-template #dialogBody>\n      <ul class=\"list-items\">\n        @for (provider of providersConfig; track provider) {\n          <li class=\"list-item\">\n            <button class=\"btn\" (click)=\"provider.invoke()\">{{provider.name}}</button>\n          </li>\n        }\n      </ul>\n    </ng-template>\n  </div>\n  <div wmConfirmDialog name=\"_app-confirm-dialog\" title.bind=\"title\" message.bind=\"message\" oktext.bind=\"oktext\"\n    canceltext.bind=\"canceltext\" closable=\"false\" iconclass.bind=\"iconclass\"\n  escape.event=\"onEscape()\" ok.event=\"onOk()\" cancel.event=\"onCancel()\" close.event=\"onClose()\" opened.event=\"onOpen()\"></div>\n  @if (!isApplicationType) {\n    <div  wmConfirmDialog name=\"PrefabConfirmDialog\" title.bind=\"title\" message.bind=\"text\" oktext.bind=\"okButtonText\"\n      canceltext.bind=\"cancelButtonText\" closable=\"false\" iconclass.bind=\"iconclass\"\n    escape.event=\"onEscape()\" ok.event=\"onOk()\" cancel.event=\"onCancel()\" close.event=\"onClose()\" opened.event=\"onOpen()\"></div>\n  }\n  @if (!isApplicationType) {\n    <div  wmAlertDialog name=\"PrefabAlertDialog\" title.bind=\"title\" message.bind=\"text\" oktext.bind=\"okButtonText\"\n      canceltext.bind=\"cancelButtonText\" closable=\"false\" iconclass.bind=\"iconclass\"\n    escape.event=\"onEscape()\" ok.event=\"onOk()\" cancel.event=\"onCancel()\" close.event=\"onClose()\" opened.event=\"onOpen()\"></div>\n  }\n  <div wmAppExt></div>\n  <i id=\"wm-mobile-display\"></i>\n}\n<!--Dummy container to create the component dynamically-->\n<ng-container #dynamicComponent></ng-container>\n"]}
201
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"app.component.js","sourceRoot":"","sources":["../../../../../../projects/runtime-base/src/components/app-component/app.component.ts","../../../../../../projects/runtime-base/src/components/app-component/app.component.html"],"names":[],"mappings":"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","sourcesContent":["import {CommonModule} from '@angular/common';\nimport {AlertDialogComponent} from '@wm/components/dialogs/alert-dialog';\nimport {ConfirmDialogComponent} from '@wm/components/dialogs/confirm-dialog';\nimport {\n    AfterViewInit,\n    ApplicationRef,\n    Component,\n    DoCheck,\n    ElementRef,\n    NgZone,\n    OnDestroy,\n    ViewChild,\n    ViewContainerRef,\n    ViewEncapsulation\n} from '@angular/core';\nimport {\n    ActivatedRoute,\n    NavigationCancel,\n    NavigationEnd,\n    NavigationError,\n    NavigationStart,\n    Router,\n    RouterOutlet\n} from '@angular/router';\n\nimport {setTheme} from 'ngx-bootstrap/utils';\n\nimport {\n    $invokeWatchers,\n    AbstractDialogService,\n    AbstractSpinnerService,\n    addClass,\n    App,\n    CustomIconsLoaderService,\n    getWmProjectProperties,\n    noop,\n    removeClass,\n    setAppRef,\n    setNgZone,\n    setPipeProvider\n} from '@wm/core';\nimport {OAuthService} from '@wm/oAuth';\nimport {AppManagerService} from '../../services/app.manager.service';\nimport {PipeProvider} from '../../services/pipe-provider.service';\nimport {AppSpinnerComponent} from '../app-spinner.component';\nimport {DialogComponent} from '@wm/components/dialogs/design-dialog';\nimport {ContainerDirective, PartialContainerDirective, PartialParamHandlerDirective} from '@wm/components/base';\nimport {filter} from \"rxjs/operators\";\nimport {Subscription} from \"rxjs\";\n\ninterface SPINNER {\n    show: boolean;\n    messages: Array<string>;\n    arialabel: string;\n}\n@Component({\n    standalone: true,\n    imports: [CommonModule, RouterOutlet, AlertDialogComponent, ConfirmDialogComponent, DialogComponent, AppSpinnerComponent, ContainerDirective, PartialParamHandlerDirective , PartialContainerDirective],\n    selector: 'app-root',\n    templateUrl: './app.component.html',\n    encapsulation: ViewEncapsulation.None\n})\nexport class AppComponent implements DoCheck, AfterViewInit, OnDestroy {\n    public startApp = false;\n    public isApplicationType = false;\n    public enableSkipToMainContent = getWmProjectProperties().enableSkipToMainContent === 'true' || getWmProjectProperties().enableSkipToMainContent === true;\n    private retryCount = 0;\n    private navigationEndSubscription!: Subscription;\n    appLocale: any = {};\n\n    @ViewChild(RouterOutlet) routerOutlet: RouterOutlet;\n\n    @ViewChild('dynamicComponent', { read: ViewContainerRef }) dynamicComponentContainerRef: ViewContainerRef;\n\n    spinner: SPINNER = { show: false, messages: [], arialabel: '' };\n    constructor(\n        _pipeProvider: PipeProvider,\n        _appRef: ApplicationRef,\n        private elRef: ElementRef,\n        private oAuthService: OAuthService,\n        private dialogService: AbstractDialogService,\n        private spinnerService: AbstractSpinnerService,\n        ngZone: NgZone,\n        private router: Router,\n        public app: App,\n        private appManager: AppManagerService,\n        private customIconsLoaderService: CustomIconsLoaderService\n    ) {\n        setPipeProvider(_pipeProvider);\n        setNgZone(ngZone);\n        setAppRef(_appRef);\n\n        this.appLocale = app.appLocale;\n        this.isApplicationType = getWmProjectProperties().type === 'APPLICATION';\n        if (this.isApplicationType) {\n            this.customIconsLoaderService.load();\n        }\n\n        // subscribe to OAuth changes\n        oAuthService.getOAuthProvidersAsObservable().subscribe((providers: any) => {\n            this.providersConfig = providers;\n            if (providers.length) {\n                this.showOAuthDialog();\n            } else {\n                this.closeOAuthDialog();\n            }\n        });\n\n        // Subscribe to the message source to show/hide app spinner\n        this.spinnerService.getMessageSource().asObservable().subscribe((data: any) => {\n            // setTimeout is to avoid 'ExpressionChangedAfterItHasBeenCheckedError'\n            setTimeout(() => {\n                this.spinner.show = data.show;\n                this.spinner.messages = data.messages;\n                this.spinner.arialabel = data.messages.toString();\n            });\n        });\n\n        // set theme to bs3 on ngx-bootstrap. This avoids runtime calculation to determine bs theme. Thus resolves performance.\n        setTheme('bs3');\n\n        let spinnerId;\n\n        let onPageRendered = noop;\n\n        this.router.events.subscribe(e => {\n            if (e instanceof NavigationStart) {\n                let page = e.url.split('?')[0];\n                page = page.substring(1);\n\n                if (!page) {\n                    this.app.activeLayoutName = '';\n                    this.app.layoutPages = [];\n                }\n                if (this.app.activeLayoutName && this.app.layoutPages && this.app.layoutPages.length && this.app.layoutPages.includes(page)) {\n                    spinnerId = this.spinnerService.show('', 'wmRouterOutlet', '', 'wmRouterOutlet');\n                } else {\n                    spinnerId = this.spinnerService.show('', 'globalSpinner');\n                }\n\n                const node = document.querySelector('app-page-outlet') as HTMLElement;\n                if (node) {\n                    addClass(node, 'page-load-in-progress');\n                }\n\n                const pageLoadStartTime = Date.now();\n                onPageRendered = () => {\n                    this.spinnerService.hide(spinnerId);\n                    const node = document.querySelector('app-page-outlet') as HTMLElement;\n                    if (node) {\n                        removeClass(node, 'page-load-in-progress');\n                    }\n                    onPageRendered = noop;\n                    this.app.activePageLoadTime = Date.now() - pageLoadStartTime;\n                };\n            } else if (e instanceof NavigationEnd || e instanceof NavigationCancel || e instanceof NavigationError) {\n                setTimeout(() => {\n                    onPageRendered();\n                }, 1000);\n            }\n        });\n        this.appManager.subscribe('pageReady', () => {\n            onPageRendered();\n        });\n        this.appManager.subscribe('pageAttach', () => {\n            onPageRendered();\n        });\n    }\n\n    providersConfig;\n    isOAuthDialogOpen = false;\n\n    showOAuthDialog() {\n        if (!this.isOAuthDialogOpen) {\n            this.isOAuthDialogOpen = true;\n            this.dialogService.open('oAuthLoginDialog', this);\n        }\n    }\n\n    closeOAuthDialog() {\n        if (this.isOAuthDialogOpen) {\n            this.isOAuthDialogOpen = false;\n            this.dialogService.close('oAuthLoginDialog', this);\n        }\n    }\n\n    private start() {\n        //to fix the issue that happens only in the development mode\n        //ExpressionChangedAfterItHasBeenCheckedError\n        //fix: https://blog.angular-university.io/angular-debugging/\n        setTimeout(() => {\n            this.startApp = true;\n        });\n        setTimeout(() => {\n            this.app.dynamicComponentContainerRef = this.dynamicComponentContainerRef;\n            this.overrideRouterOutlet();\n        }, 10);\n    }\n\n    private overrideRouterOutlet() {\n        //override the attach/detach methods\n        const oAttach = this.routerOutlet.attach;\n        const oDetach = this.routerOutlet.detach;\n        this.routerOutlet.attach = (componentRef: any, activatedRoute:  ActivatedRoute) => {\n            oAttach.call(this.routerOutlet, componentRef, activatedRoute);\n            componentRef.instance.ngOnAttach();\n        };\n        this.routerOutlet.detach = () => {\n            this.app.activePage.ngOnDetach();\n            const componentRef = oDetach.call(this.routerOutlet);\n            return componentRef;\n        };\n    }\n\n    skipToAppContent(event: Event): void {\n        event.preventDefault();\n        this.retryCount = 0;\n        this.tryFocusContent();\n    }\n\n    private tryFocusContent(): void {\n        const contentEl = document.querySelector('.app-page-content') as HTMLElement;\n\n        if (contentEl) {\n            contentEl.setAttribute('tabindex', '-1'); // Ensure it's focusable\n            contentEl.focus({ preventScroll: false });\n            contentEl.scrollIntoView({ behavior: 'smooth' });\n        } else if (this.retryCount < 10) {\n            this.retryCount++;\n            setTimeout(() => this.tryFocusContent(), 100); // Retry every 100ms\n        }\n    }\n\n    ngAfterViewInit() {\n        document.documentElement.setAttribute('lang', getWmProjectProperties().defaultLanguage);\n        this.start();\n\n        if (this.enableSkipToMainContent) {\n           this.navigationEndSubscription = this.router.events\n                .pipe(filter((e) => e instanceof NavigationEnd))\n                .subscribe(() => {\n                    const el = document.getElementById('app-focus-start');\n                    if (el) {\n                        el.focus();\n                    }\n                });\n        }\n    }\n\n    ngDoCheck() {\n        $invokeWatchers();\n    }\n\n    ngOnDestroy() {\n        if (this.navigationEndSubscription){\n            this.navigationEndSubscription.unsubscribe();\n        }\n    }\n}\n","@if (startApp) {\n    @if(enableSkipToMainContent) {\n        <div id=\"app-focus-start\" tabindex=\"-1\"></div>\n        <a href=\"javascript:void(0);\" class=\"skip\" (click)=\"skipToAppContent($event)\">{{appLocale.LABEL_SKIP_TO_MAIN_CONTENT || 'Skip to main content'}}</a>\n    }\n    <router-outlet></router-outlet>\n  @if (isApplicationType) {\n    <div wmContainer partialContainer content=\"Common\" hidden class=\"ng-hide\"></div>\n  }\n  <app-spinner name=\"globalspinner\" classname=\"global-spinner\" role=\"alert\" aria-live=\"assertive\" [attr.aria-label]=\"spinner.arialabel || 'Loading'\" [show]=\"spinner.show\" [spinnermessages]=\"spinner.messages\"></app-spinner>\n  <div wmDialog name=\"oAuthLoginDialog\" title=\"Application is requesting you to sign in with\"\n    close.event=\"closeOAuthDialog()\">\n    <ng-template #dialogBody>\n      <ul class=\"list-items\">\n        @for (provider of providersConfig; track provider) {\n          <li class=\"list-item\">\n            <button class=\"btn\" (click)=\"provider.invoke()\">{{provider.name}}</button>\n          </li>\n        }\n      </ul>\n    </ng-template>\n  </div>\n  <div wmConfirmDialog name=\"_app-confirm-dialog\" title.bind=\"title\" message.bind=\"message\" oktext.bind=\"oktext\"\n    canceltext.bind=\"canceltext\" closable=\"false\" iconclass.bind=\"iconclass\"\n  escape.event=\"onEscape()\" ok.event=\"onOk()\" cancel.event=\"onCancel()\" close.event=\"onClose()\" opened.event=\"onOpen()\"></div>\n  @if (!isApplicationType) {\n    <div  wmConfirmDialog name=\"PrefabConfirmDialog\" title.bind=\"title\" message.bind=\"text\" oktext.bind=\"okButtonText\"\n      canceltext.bind=\"cancelButtonText\" closable=\"false\" iconclass.bind=\"iconclass\"\n    escape.event=\"onEscape()\" ok.event=\"onOk()\" cancel.event=\"onCancel()\" close.event=\"onClose()\" opened.event=\"onOpen()\"></div>\n  }\n  @if (!isApplicationType) {\n    <div  wmAlertDialog name=\"PrefabAlertDialog\" title.bind=\"title\" message.bind=\"text\" oktext.bind=\"okButtonText\"\n      canceltext.bind=\"cancelButtonText\" closable=\"false\" iconclass.bind=\"iconclass\"\n    escape.event=\"onEscape()\" ok.event=\"onOk()\" cancel.event=\"onCancel()\" close.event=\"onClose()\" opened.event=\"onOpen()\"></div>\n  }\n  <div wmAppExt></div>\n  <i id=\"wm-mobile-display\"></i>\n}\n<!--Dummy container to create the component dynamically-->\n<ng-container #dynamicComponent></ng-container>\n"]}