@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.
- package/components/base/bundles/index.umd.js +6 -12
- package/components/base/esm2022/widgets/common/base/base.component.mjs +8 -14
- package/components/base/fesm2022/index.mjs +7 -13
- package/components/base/fesm2022/index.mjs.map +1 -1
- package/components/data/table/bundles/index.umd.js +5 -5
- package/components/data/table/esm2022/table.component.mjs +7 -7
- package/components/data/table/fesm2022/index.mjs +6 -6
- package/components/data/table/fesm2022/index.mjs.map +1 -1
- package/components/prefab/bundles/index.umd.js +0 -4
- package/components/prefab/esm2022/prefab.directive.mjs +1 -5
- package/components/prefab/fesm2022/index.mjs +0 -4
- package/components/prefab/fesm2022/index.mjs.map +1 -1
- package/core/bundles/index.umd.js +187 -330
- package/core/esm2022/public_api.mjs +2 -2
- package/core/esm2022/utils/watcher.mjs +191 -327
- package/core/fesm2022/index.mjs +194 -330
- package/core/fesm2022/index.mjs.map +1 -1
- package/core/public_api.d.ts +1 -1
- package/core/utils/watcher.d.ts +5 -26
- package/npm-shrinkwrap.json +2 -2
- package/package-lock.json +2 -2
- package/package.json +1 -1
- package/runtime/base/bundles/index.umd.js +11 -171
- package/runtime/base/components/app-component/app.component.d.ts +0 -4
- package/runtime/base/esm2022/components/app-component/app.component.mjs +9 -40
- package/runtime/base/esm2022/components/base-page.component.mjs +3 -35
- package/runtime/base/esm2022/components/base-partial.component.mjs +3 -37
- package/runtime/base/esm2022/components/base-prefab.component.mjs +3 -32
- package/runtime/base/esm2022/components/base-spa-page.component.mjs +3 -37
- package/runtime/base/fesm2022/index.mjs +12 -172
- package/runtime/base/fesm2022/index.mjs.map +1 -1
- package/runtime/dynamic/bundles/index.umd.js +4 -0
- package/runtime/dynamic/esm2022/app/app.config.mjs +6 -2
- package/runtime/dynamic/fesm2022/index.mjs +5 -1
- package/runtime/dynamic/fesm2022/index.mjs.map +1 -1
package/core/public_api.d.ts
CHANGED
|
@@ -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,
|
|
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';
|
package/core/utils/watcher.d.ts
CHANGED
|
@@ -1,34 +1,13 @@
|
|
|
1
|
-
export declare const FIRST_TIME_WATCH:
|
|
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
|
-
|
|
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: () =>
|
|
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 {};
|
package/npm-shrinkwrap.json
CHANGED
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@wavemaker/app-ng-runtime",
|
|
3
|
-
"version": "11.14.2-
|
|
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-
|
|
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-
|
|
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-
|
|
9
|
+
"version": "11.14.2-2.6435",
|
|
10
10
|
"license": "MIT",
|
|
11
11
|
"engines": {
|
|
12
12
|
"node": ">=18.16.1",
|
package/package.json
CHANGED
|
@@ -890,41 +890,7 @@
|
|
|
890
890
|
});
|
|
891
891
|
}
|
|
892
892
|
ngOnDestroy() {
|
|
893
|
-
|
|
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
|
-
|
|
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
|
-
|
|
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
|
-
|
|
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
|
-
|
|
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
|
-
|
|
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
|
-
|
|
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
|
-
|
|
4667
|
-
this.appManagerSubscriptions.push(this.appManager.subscribe('pageReady', () => {
|
|
4533
|
+
this.appManager.subscribe('pageReady', () => {
|
|
4668
4534
|
onPageRendered();
|
|
4669
|
-
})
|
|
4670
|
-
this.
|
|
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,
|
|
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
|
-
|
|
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
|
-
|
|
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
|
-
|
|
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
|
-
|
|
109
|
-
this.appManagerSubscriptions.push(this.appManager.subscribe('pageReady', () => {
|
|
104
|
+
this.appManager.subscribe('pageReady', () => {
|
|
110
105
|
onPageRendered();
|
|
111
|
-
})
|
|
112
|
-
this.
|
|
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"]}
|