@ethlete/core 4.0.0 → 4.0.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { inject, Injectable } from '@angular/core';
|
|
2
2
|
import { NavigationEnd, Router } from '@angular/router';
|
|
3
|
-
import { BehaviorSubject, combineLatest, debounceTime, distinctUntilChanged, filter, map, pairwise, shareReplay, } from 'rxjs';
|
|
3
|
+
import { BehaviorSubject, combineLatest, debounceTime, distinctUntilChanged, filter, map, pairwise, shareReplay, tap, } from 'rxjs';
|
|
4
4
|
import { equal } from '../utils';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
const ET_DISABLE_SCROLL_TOP = Symbol('ET_DISABLE_SCROLL_TOP');
|
|
@@ -68,38 +68,40 @@ export class RouterStateService {
|
|
|
68
68
|
constructor() {
|
|
69
69
|
this._isScrollTopOnNavigationEnabled = false;
|
|
70
70
|
this._router = inject(Router);
|
|
71
|
-
this._route$ = new BehaviorSubject(
|
|
72
|
-
this._state$ = new BehaviorSubject(
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
data: {},
|
|
76
|
-
pathParams: {},
|
|
77
|
-
queryParams: {},
|
|
78
|
-
});
|
|
71
|
+
this._route$ = new BehaviorSubject(window.location.pathname);
|
|
72
|
+
this._state$ = new BehaviorSubject(this._getInitialState());
|
|
73
|
+
this._afterInitialize$ = new BehaviorSubject(false);
|
|
74
|
+
this.afterInitialize$ = this._afterInitialize$.pipe(filter((v) => v));
|
|
79
75
|
this._router.events
|
|
80
76
|
.pipe(filter((event) => event instanceof NavigationEnd), distinctUntilChanged((a, b) => a.url === b.url), map((event) => {
|
|
81
77
|
const { url } = event;
|
|
82
78
|
const urlWithoutQueryParams = url.split('?')[0] ?? '';
|
|
83
79
|
const withoutFragment = urlWithoutQueryParams.split('#')[0] ?? '';
|
|
84
80
|
return withoutFragment;
|
|
81
|
+
}), tap(() => {
|
|
82
|
+
if (!this._afterInitialize$.getValue()) {
|
|
83
|
+
this._afterInitialize$.next(true);
|
|
84
|
+
}
|
|
85
85
|
}))
|
|
86
86
|
.subscribe(this._route$);
|
|
87
|
-
this._route$
|
|
88
|
-
.pipe(
|
|
87
|
+
combineLatest([this._route$, this._afterInitialize$])
|
|
88
|
+
.pipe(tap(([, afterInitialize]) => {
|
|
89
|
+
if (!afterInitialize)
|
|
90
|
+
return;
|
|
89
91
|
let route = this._router.routerState.snapshot.root;
|
|
90
92
|
while (route.firstChild) {
|
|
91
93
|
route = route.firstChild;
|
|
92
94
|
}
|
|
93
95
|
const { data, params, queryParams, title, fragment } = route;
|
|
94
|
-
|
|
96
|
+
this._state$.next({
|
|
95
97
|
data,
|
|
96
98
|
pathParams: params,
|
|
97
99
|
queryParams,
|
|
98
100
|
title: title ?? null,
|
|
99
101
|
fragment,
|
|
100
|
-
};
|
|
102
|
+
});
|
|
101
103
|
}))
|
|
102
|
-
.subscribe(
|
|
104
|
+
.subscribe();
|
|
103
105
|
}
|
|
104
106
|
enableScrollEnhancements(config = {}) {
|
|
105
107
|
if (this._isScrollTopOnNavigationEnabled) {
|
|
@@ -166,6 +168,31 @@ export class RouterStateService {
|
|
|
166
168
|
}
|
|
167
169
|
return changes;
|
|
168
170
|
}
|
|
171
|
+
_getInitialState() {
|
|
172
|
+
const data = {};
|
|
173
|
+
const pathParams = {};
|
|
174
|
+
const queryParams = {};
|
|
175
|
+
const title = null;
|
|
176
|
+
let fragment = null;
|
|
177
|
+
const currentQueryParams = window.location.search;
|
|
178
|
+
const currentFragment = window.location.hash;
|
|
179
|
+
if (currentQueryParams) {
|
|
180
|
+
const params = new URLSearchParams(currentQueryParams);
|
|
181
|
+
params.forEach((value, key) => {
|
|
182
|
+
queryParams[key] = value;
|
|
183
|
+
});
|
|
184
|
+
}
|
|
185
|
+
if (currentFragment) {
|
|
186
|
+
fragment = currentFragment.slice(1);
|
|
187
|
+
}
|
|
188
|
+
return {
|
|
189
|
+
data,
|
|
190
|
+
pathParams,
|
|
191
|
+
queryParams,
|
|
192
|
+
title,
|
|
193
|
+
fragment,
|
|
194
|
+
};
|
|
195
|
+
}
|
|
169
196
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.11", ngImport: i0, type: RouterStateService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
170
197
|
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.11", ngImport: i0, type: RouterStateService, providedIn: 'root' }); }
|
|
171
198
|
}
|
|
@@ -175,4 +202,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.11", ngImpo
|
|
|
175
202
|
providedIn: 'root',
|
|
176
203
|
}]
|
|
177
204
|
}], ctorParameters: function () { return []; } });
|
|
178
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"router-state.service.js","sourceRoot":"","sources":["../../../../../../libs/core/src/lib/services/router-state.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AACnD,OAAO,EAAQ,aAAa,EAAU,MAAM,EAAE,MAAM,iBAAiB,CAAC;AACtE,OAAO,EACL,eAAe,EACf,aAAa,EACb,YAAY,EACZ,oBAAoB,EACpB,MAAM,EACN,GAAG,EAEH,QAAQ,EACR,WAAW,GACZ,MAAM,MAAM,CAAC;AACd,OAAO,EAAE,KAAK,EAAE,MAAM,UAAU,CAAC;;AAEjC,MAAM,qBAAqB,GAAG,MAAM,CAAC,uBAAuB,CAAC,CAAC;AAC9D,MAAM,qCAAqC,GAAG,MAAM,CAAC,uCAAuC,CAAC,CAAC;AAC9F,MAAM,0CAA0C,GAAG,MAAM,CAAC,4CAA4C,CAAC,CAAC;AAgBxG,MAAM,CAAC,MAAM,sBAAsB,GAAG,CAAC,SAAuC,EAAE,EAAE,EAAE;IAClF,OAAO;QACL,GAAG,CAAC,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC,CAAC,EAAE,CAAC,qBAAqB,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,qCAAqC,CAAC,EAAE,IAAI,EAAE,CAAC;QAClH,GAAG,CAAC,MAAM,CAAC,iBAAiB,CAAC,CAAC,CAAC,EAAE,CAAC,0CAA0C,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;KAC5F,CAAC;AACJ,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,mBAAmB,GAAG,MAAM,CAAC,qBAAqB,CAAC,CAAC;AAkCjE,MAAM,OAAO,kBAAkB;IAoB7B,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,OAAO,CAAC,YAAY,EAAE,CAAC,IAAI,CAAC,oBAAoB,EAAE,CAAC,CAAC;IAClE,CAAC;IAED,IAAI,KAAK;QACP,OAAO,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC;IACjC,CAAC;IAED,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,OAAO,CAAC,YAAY,EAAE,CAAC;IACrC,CAAC;IAED,IAAI,KAAK;QACP,OAAO,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC;IACjC,CAAC;IAED,IAAI,KAAK;QACP,OAAO,IAAI,CAAC,OAAO,CAAC,IAAI,CACtB,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,EAC1B,oBAAoB,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAC5C,CAAC;IACJ,CAAC;IAED,IAAI,IAAI;QACN,OAAO,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC,IAAI,CAAC;IACtC,CAAC;IAED,IAAI,WAAW;QACb,OAAO,IAAI,CAAC,OAAO,CAAC,IAAI,CACtB,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,UAAU,CAAC,EAChC,oBAAoB,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAC5C,CAAC;IACJ,CAAC;IAED,IAAI,UAAU;QACZ,OAAO,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC,UAAU,CAAC;IAC5C,CAAC;IAED,IAAI,YAAY;QACd,OAAO,IAAI,CAAC,OAAO,CAAC,IAAI,CACtB,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,WAAW,CAAC,EACjC,oBAAoB,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAC5C,CAAC;IACJ,CAAC;IAED,IAAI,WAAW;QACb,OAAO,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC,WAAW,CAAC;IAC7C,CAAC;IAED,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,OAAO,CAAC,IAAI,CACtB,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,EAC3B,oBAAoB,EAAE,CACvB,CAAC;IACJ,CAAC;IAED,IAAI,KAAK;QACP,OAAO,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC,KAAK,CAAC;IACvC,CAAC;IAED,IAAI,SAAS;QACX,OAAO,IAAI,CAAC,OAAO,CAAC,IAAI,CACtB,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,QAAQ,CAAC,EAC9B,oBAAoB,EAAE,CACvB,CAAC;IACJ,CAAC;IAED,IAAI,QAAQ;QACV,OAAO,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC;IAC1C,CAAC;IAED,IAAI,YAAY;QACd,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CACpB,QAAQ,EAAE,EACV,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,EAChC,WAAW,CAAC,EAAE,UAAU,EAAE,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CAC/C,CAAC;IACJ,CAAC;IAED,IAAI,kBAAkB;QACpB,OAAO,IAAI,CAAC,YAAY,CAAC,IAAI,CAC3B,QAAQ,EAAE,EACV,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,EAChC,WAAW,CAAC,EAAE,UAAU,EAAE,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CAC/C,CAAC;IACJ,CAAC;IAED,IAAI,iBAAiB;QACnB,OAAO,IAAI,CAAC,WAAW,CAAC,IAAI,CAC1B,QAAQ,EAAE,EACV,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,EAChC,WAAW,CAAC,EAAE,UAAU,EAAE,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CAC/C,CAAC;IACJ,CAAC;IAED;QAlHQ,oCAA+B,GAAG,KAAK,CAAC;QAC/B,YAAO,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC;QAEzB,YAAO,GAAG,IAAI,eAAe,CAAC,GAAG,CAAC,CAAC;QAEnC,YAAO,GAAG,IAAI,eAAe,CAM3C;YACD,KAAK,EAAE,IAAI;YACX,QAAQ,EAAE,IAAI;YACd,IAAI,EAAE,EAAE;YACR,UAAU,EAAE,EAAE;YACd,WAAW,EAAE,EAAE;SAChB,CAAC,CAAC;QAkGD,IAAI,CAAC,OAAO,CAAC,MAAM;aAChB,IAAI,CACH,MAAM,CAAC,CAAC,KAAK,EAA0B,EAAE,CAAC,KAAK,YAAY,aAAa,CAAC,EACzE,oBAAoB,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,GAAG,CAAC,EAC/C,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE;YACZ,MAAM,EAAE,GAAG,EAAE,GAAG,KAAK,CAAC;YAEtB,MAAM,qBAAqB,GAAG,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC;YACtD,MAAM,eAAe,GAAG,qBAAqB,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC;YAElE,OAAO,eAAe,CAAC;QACzB,CAAC,CAAC,CACH;aACA,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAE3B,IAAI,CAAC,OAAO;aACT,IAAI,CACH,GAAG,CAAC,GAAG,EAAE;YACP,IAAI,KAAK,GAAG,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,QAAQ,CAAC,IAAI,CAAC;YAEnD,OAAO,KAAK,CAAC,UAAU,EAAE;gBACvB,KAAK,GAAG,KAAK,CAAC,UAAU,CAAC;aAC1B;YAED,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,WAAW,EAAE,KAAK,EAAE,QAAQ,EAAE,GAAG,KAAK,CAAC;YAE7D,OAAO;gBACL,IAAI;gBACJ,UAAU,EAAE,MAAM;gBAClB,WAAW;gBACX,KAAK,EAAE,KAAK,IAAI,IAAI;gBACpB,QAAQ;aACT,CAAC;QACJ,CAAC,CAAC,CACH;aACA,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IAC7B,CAAC;IAED,wBAAwB,CAAC,SAAmC,EAAE;QAC5D,IAAI,IAAI,CAAC,+BAA+B,EAAE;YACxC,OAAO;SACR;QAED,IAAI,CAAC,+BAA+B,GAAG,IAAI,CAAC;QAE5C,aAAa,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,EAAE,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC;aAC1E,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;aACrB,SAAS,CAAC,CAAC,CAAC,CAAC,SAAS,EAAE,SAAS,CAAC,EAAE,CAAC,SAAS,EAAE,SAAS,CAAC,CAAC,EAAE,EAAE;YAC9D,MAAM,iBAAiB,GAAG,SAAS,KAAK,SAAS,CAAC;YAClD,MAAM,iBAAiB,GAAG,SAAS,CAAC,QAAQ,KAAK,SAAS,CAAC,QAAQ,CAAC;YAEpE,IAAI,iBAAiB,EAAE;gBACrB,MAAM,cAAc,GAAG;oBACrB,GAAG,IAAI,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC,CAAC;iBAC1F,CAAC;gBAEF,MAAM,kBAAkB,GAAG,cAAc,CAAC,MAAM,CAC9C,CAAC,GAAG,EAAE,EAAE,CAAC,SAAS,CAAC,WAAW,CAAC,GAAG,CAAC,KAAK,SAAS,CAAC,WAAW,CAAC,GAAG,CAAC,CACnE,CAAC;gBAEF,IAAI,CAAC,MAAM,CAAC,qBAAqB,EAAE,MAAM,IAAI,CAAC,iBAAiB,EAAE;oBAC/D,OAAO;iBACR;gBAED,MAAM,eAAe,GAAG,kBAAkB,CAAC,IAAI,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,MAAM,CAAC,qBAAqB,EAAE,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC;gBACtG,MAAM,YAAY,GAAG,iBAAiB,IAAI,MAAM,CAAC,QAAQ,EAAE,OAAO,CAAC;gBAEnE,IAAI,eAAe,EAAE;oBACnB,CAAC,MAAM,CAAC,aAAa,IAAI,QAAQ,CAAC,eAAe,CAAC,CAAC,SAAS,GAAG,CAAC,CAAC;iBAClE;qBAAM,IAAI,YAAY,EAAE;oBACvB,MAAM,eAAe,GAAG,QAAQ,CAAC,cAAc,CAAC,SAAS,CAAC,QAAQ,IAAI,EAAE,CAAC,CAAC;oBAE1E,IAAI,eAAe,EAAE;wBACnB,eAAe,CAAC,cAAc,CAAC,EAAE,QAAQ,EAAE,MAAM,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC;qBAC3F;iBACF;aACF;iBAAM;gBACL,MAAM,cAAc,GAClB,SAAS,CAAC,IAAI,CAAC,qCAAqC,CAAC,IAAI,SAAS,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAC;gBACjG,MAAM,UAAU,GAAG,SAAS,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAC;gBACzD,MAAM,gBAAgB,GAAG,SAAS,CAAC,IAAI,CAAC,0CAA0C,CAAC,CAAC;gBAEpF,IAAI,cAAc,IAAI,UAAU,IAAI,gBAAgB,EAAE;oBACpD,OAAO;iBACR;gBAED,MAAM,EAAE,GAAG,MAAM,CAAC,aAAa,IAAI,QAAQ,CAAC,eAAe,CAAC;gBAC5D,EAAE,CAAC,SAAS,GAAG,CAAC,CAAC;aAClB;QACH,CAAC,CAAC,CAAC;IACP,CAAC;IAED,gBAAgB,CAAyB,GAAW;QAClD,OAAO,IAAI,CAAC,OAAO,CAAC,IAAI,CACtB,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,EACtC,oBAAoB,EAAE,CACvB,CAAC;IACJ,CAAC;IAED,eAAe,CAAyB,GAAW;QACjD,OAAO,IAAI,CAAC,OAAO,CAAC,IAAI,CACtB,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,EACrC,oBAAoB,EAAE,CACvB,CAAC;IACJ,CAAC;IAED,UAAU,CAAc,GAAW;QACjC,OAAO,IAAI,CAAC,OAAO,CAAC,IAAI,CACtB,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAC/B,oBAAoB,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAC5C,CAAC;IACJ,CAAC;IAEO,YAAY,CAA6F,CAC/G,QAAQ,EACR,OAAO,EACL;QACF,MAAM,OAAO,GAA4B,EAAE,CAAC;QAE5C,MAAM,OAAO,GAAG,IAAI,GAAG,CAA+C;YACpE,GAAG,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC;YACxB,GAAG,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC;SACxB,CAAC,CAAC;QAEH,KAAK,MAAM,GAAG,IAAI,OAAO,EAAE;YACzB,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,OAAO,CAAC,GAAG,CAAC,CAAC,EAAE;gBACvC,MAAM,GAAG,GAAG,OAAO,CAAC,GAAG,CAAC,KAAK,SAAS,CAAC,CAAC,CAAC,mBAAmB,CAAC,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;gBAE5E,OAAO,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC;aACpB;SACF;QAED,OAAO,OAAY,CAAC;IACtB,CAAC;+GAzPU,kBAAkB;mHAAlB,kBAAkB,cAFjB,MAAM;;4FAEP,kBAAkB;kBAH9B,UAAU;mBAAC;oBACV,UAAU,EAAE,MAAM;iBACnB","sourcesContent":["import { inject, Injectable } from '@angular/core';\nimport { Data, NavigationEnd, Params, Router } from '@angular/router';\nimport {\n  BehaviorSubject,\n  combineLatest,\n  debounceTime,\n  distinctUntilChanged,\n  filter,\n  map,\n  Observable,\n  pairwise,\n  shareReplay,\n} from 'rxjs';\nimport { equal } from '../utils';\n\nconst ET_DISABLE_SCROLL_TOP = Symbol('ET_DISABLE_SCROLL_TOP');\nconst ET_DISABLE_SCROLL_TOP_AS_RETURN_ROUTE = Symbol('ET_DISABLE_SCROLL_TOP_AS_RETURN_ROUTE');\nconst ET_DISABLE_SCROLL_TOP_ON_PATH_PARAM_CHANGE = Symbol('ET_DISABLE_SCROLL_TOP_ON_PATH_PARAM_CHANGE');\n\nexport interface RouterDisableScrollTopConfig {\n  /**\n   * Whether to disable scroll to top ONLY when navigating back to this route.\n   * @default false\n   */\n  asReturnRoute?: boolean;\n\n  /**\n   * Whether to disable scroll to top when a path param changes.\n   * @default false\n   */\n  onPathParamChange?: boolean;\n}\n\nexport const routerDisableScrollTop = (config: RouterDisableScrollTopConfig = {}) => {\n  return {\n    ...(!config.asReturnRoute ? { [ET_DISABLE_SCROLL_TOP]: true } : { [ET_DISABLE_SCROLL_TOP_AS_RETURN_ROUTE]: true }),\n    ...(config.onPathParamChange ? { [ET_DISABLE_SCROLL_TOP_ON_PATH_PARAM_CHANGE]: true } : {}),\n  };\n};\n\nexport const ET_PROPERTY_REMOVED = Symbol('ET_PROPERTY_REMOVED');\n\nexport interface ScrollEnhancementsConfig {\n  /**\n   * The scrollable container.\n   * @default document.documentElement\n   */\n  scrollElement?: HTMLElement;\n  /**\n   * A list of query params that should trigger a scroll to top.\n   * @default []\n   * @example ['page'] // will scroll to top when the page query param changes\n   */\n  queryParamTriggerList?: string[];\n  /**\n   * Config for fragment scrolling.\n   */\n  fragment?: {\n    /**\n     * Enable fragment scrolling (scroll to element with id)\n     * @default false\n     */\n    enabled?: boolean;\n    /**\n     * Whether to use smooth scrolling or not.\n     * @default false\n     */\n    smooth?: boolean;\n  };\n}\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class RouterStateService {\n  private _isScrollTopOnNavigationEnabled = false;\n  private readonly _router = inject(Router);\n\n  private readonly _route$ = new BehaviorSubject('/');\n\n  private readonly _state$ = new BehaviorSubject<{\n    data: Data;\n    pathParams: Params;\n    queryParams: Params;\n    title: string | null;\n    fragment: string | null;\n  }>({\n    title: null,\n    fragment: null,\n    data: {},\n    pathParams: {},\n    queryParams: {},\n  });\n\n  get route$() {\n    return this._route$.asObservable().pipe(distinctUntilChanged());\n  }\n\n  get route() {\n    return this._route$.getValue();\n  }\n\n  get state$() {\n    return this._state$.asObservable();\n  }\n\n  get state() {\n    return this._state$.getValue();\n  }\n\n  get data$() {\n    return this._state$.pipe(\n      map((state) => state.data),\n      distinctUntilChanged((a, b) => equal(a, b)),\n    );\n  }\n\n  get data() {\n    return this._state$.getValue().data;\n  }\n\n  get pathParams$() {\n    return this._state$.pipe(\n      map((state) => state.pathParams),\n      distinctUntilChanged((a, b) => equal(a, b)),\n    );\n  }\n\n  get pathParams() {\n    return this._state$.getValue().pathParams;\n  }\n\n  get queryParams$() {\n    return this._state$.pipe(\n      map((state) => state.queryParams),\n      distinctUntilChanged((a, b) => equal(a, b)),\n    );\n  }\n\n  get queryParams() {\n    return this._state$.getValue().queryParams;\n  }\n\n  get title$() {\n    return this._state$.pipe(\n      map((state) => state.title),\n      distinctUntilChanged(),\n    );\n  }\n\n  get title() {\n    return this._state$.getValue().title;\n  }\n\n  get fragment$() {\n    return this._state$.pipe(\n      map((state) => state.fragment),\n      distinctUntilChanged(),\n    );\n  }\n\n  get fragment() {\n    return this._state$.getValue().fragment;\n  }\n\n  get dataChanges$() {\n    return this.data$.pipe(\n      pairwise(),\n      map((v) => this._findChanges(v)),\n      shareReplay({ bufferSize: 1, refCount: true }),\n    );\n  }\n\n  get queryParamChanges$() {\n    return this.queryParams$.pipe(\n      pairwise(),\n      map((v) => this._findChanges(v)),\n      shareReplay({ bufferSize: 1, refCount: true }),\n    );\n  }\n\n  get pathParamChanges$() {\n    return this.pathParams$.pipe(\n      pairwise(),\n      map((v) => this._findChanges(v)),\n      shareReplay({ bufferSize: 1, refCount: true }),\n    );\n  }\n\n  constructor() {\n    this._router.events\n      .pipe(\n        filter((event): event is NavigationEnd => event instanceof NavigationEnd),\n        distinctUntilChanged((a, b) => a.url === b.url),\n        map((event) => {\n          const { url } = event;\n\n          const urlWithoutQueryParams = url.split('?')[0] ?? '';\n          const withoutFragment = urlWithoutQueryParams.split('#')[0] ?? '';\n\n          return withoutFragment;\n        }),\n      )\n      .subscribe(this._route$);\n\n    this._route$\n      .pipe(\n        map(() => {\n          let route = this._router.routerState.snapshot.root;\n\n          while (route.firstChild) {\n            route = route.firstChild;\n          }\n\n          const { data, params, queryParams, title, fragment } = route;\n\n          return {\n            data,\n            pathParams: params,\n            queryParams,\n            title: title ?? null,\n            fragment,\n          };\n        }),\n      )\n      .subscribe(this._state$);\n  }\n\n  enableScrollEnhancements(config: ScrollEnhancementsConfig = {}) {\n    if (this._isScrollTopOnNavigationEnabled) {\n      return;\n    }\n\n    this._isScrollTopOnNavigationEnabled = true;\n\n    combineLatest([this._state$.pipe(pairwise()), this._route$.pipe(pairwise())])\n      .pipe(debounceTime(1))\n      .subscribe(([[prevState, currState], [prevRoute, currRoute]]) => {\n        const sameUrlNavigation = prevRoute === currRoute;\n        const didFragmentChange = prevState.fragment !== currState.fragment;\n\n        if (sameUrlNavigation) {\n          const allQueryParams = [\n            ...new Set(Object.keys(prevState.queryParams).concat(Object.keys(currState.queryParams))),\n          ];\n\n          const changedQueryParams = allQueryParams.filter(\n            (key) => currState.queryParams[key] !== prevState.queryParams[key],\n          );\n\n          if (!config.queryParamTriggerList?.length && !didFragmentChange) {\n            return;\n          }\n\n          const caseQueryParams = changedQueryParams.some((key) => config.queryParamTriggerList?.includes(key));\n          const caseFragment = didFragmentChange && config.fragment?.enabled;\n\n          if (caseQueryParams) {\n            (config.scrollElement ?? document.documentElement).scrollTop = 0;\n          } else if (caseFragment) {\n            const fragmentElement = document.getElementById(currState.fragment ?? '');\n\n            if (fragmentElement) {\n              fragmentElement.scrollIntoView({ behavior: config.fragment?.smooth ? 'smooth' : 'auto' });\n            }\n          }\n        } else {\n          const viaReturnRoute =\n            currState.data[ET_DISABLE_SCROLL_TOP_AS_RETURN_ROUTE] && prevState.data[ET_DISABLE_SCROLL_TOP];\n          const explicitly = currState.data[ET_DISABLE_SCROLL_TOP];\n          const pathParamsChange = currState.data[ET_DISABLE_SCROLL_TOP_ON_PATH_PARAM_CHANGE];\n\n          if (viaReturnRoute || explicitly || pathParamsChange) {\n            return;\n          }\n\n          const el = config.scrollElement ?? document.documentElement;\n          el.scrollTop = 0;\n        }\n      });\n  }\n\n  selectQueryParam<T = string | undefined>(key: string): Observable<T> {\n    return this._state$.pipe(\n      map((state) => state.queryParams[key]),\n      distinctUntilChanged(),\n    );\n  }\n\n  selectPathParam<T = string | undefined>(key: string): Observable<T> {\n    return this._state$.pipe(\n      map((state) => state.pathParams[key]),\n      distinctUntilChanged(),\n    );\n  }\n\n  selectData<T = unknown>(key: string): Observable<T> {\n    return this._state$.pipe(\n      map((state) => state.data[key]),\n      distinctUntilChanged((a, b) => equal(a, b)),\n    );\n  }\n\n  private _findChanges<T extends [Record<string, unknown>, Record<string, unknown>], J extends Partial<T[number]>>([\n    previous,\n    current,\n  ]: T) {\n    const changes: Record<string, unknown> = {};\n\n    const allKeys = new Set<keyof typeof previous & keyof typeof current>([\n      ...Object.keys(previous),\n      ...Object.keys(current),\n    ]);\n\n    for (const key of allKeys) {\n      if (!equal(previous[key], current[key])) {\n        const val = current[key] === undefined ? ET_PROPERTY_REMOVED : current[key];\n\n        changes[key] = val;\n      }\n    }\n\n    return changes as J;\n  }\n}\n"]}
|
|
205
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"router-state.service.js","sourceRoot":"","sources":["../../../../../../libs/core/src/lib/services/router-state.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { inject, Injectable } from '@angular/core';\nimport { Data, NavigationEnd, Params, Router } from '@angular/router';\nimport {\n  BehaviorSubject,\n  combineLatest,\n  debounceTime,\n  distinctUntilChanged,\n  filter,\n  map,\n  Observable,\n  pairwise,\n  shareReplay,\n  tap,\n} from 'rxjs';\nimport { equal } from '../utils';\n\nconst ET_DISABLE_SCROLL_TOP = Symbol('ET_DISABLE_SCROLL_TOP');\nconst ET_DISABLE_SCROLL_TOP_AS_RETURN_ROUTE = Symbol('ET_DISABLE_SCROLL_TOP_AS_RETURN_ROUTE');\nconst ET_DISABLE_SCROLL_TOP_ON_PATH_PARAM_CHANGE = Symbol('ET_DISABLE_SCROLL_TOP_ON_PATH_PARAM_CHANGE');\n\nexport interface RouterDisableScrollTopConfig {\n  /**\n   * Whether to disable scroll to top ONLY when navigating back to this route.\n   * @default false\n   */\n  asReturnRoute?: boolean;\n\n  /**\n   * Whether to disable scroll to top when a path param changes.\n   * @default false\n   */\n  onPathParamChange?: boolean;\n}\n\nexport const routerDisableScrollTop = (config: RouterDisableScrollTopConfig = {}) => {\n  return {\n    ...(!config.asReturnRoute ? { [ET_DISABLE_SCROLL_TOP]: true } : { [ET_DISABLE_SCROLL_TOP_AS_RETURN_ROUTE]: true }),\n    ...(config.onPathParamChange ? { [ET_DISABLE_SCROLL_TOP_ON_PATH_PARAM_CHANGE]: true } : {}),\n  };\n};\n\nexport const ET_PROPERTY_REMOVED = Symbol('ET_PROPERTY_REMOVED');\n\nexport interface ScrollEnhancementsConfig {\n  /**\n   * The scrollable container.\n   * @default document.documentElement\n   */\n  scrollElement?: HTMLElement;\n  /**\n   * A list of query params that should trigger a scroll to top.\n   * @default []\n   * @example ['page'] // will scroll to top when the page query param changes\n   */\n  queryParamTriggerList?: string[];\n  /**\n   * Config for fragment scrolling.\n   */\n  fragment?: {\n    /**\n     * Enable fragment scrolling (scroll to element with id)\n     * @default false\n     */\n    enabled?: boolean;\n    /**\n     * Whether to use smooth scrolling or not.\n     * @default false\n     */\n    smooth?: boolean;\n  };\n}\n\nexport interface RouterState {\n  data: Data;\n  pathParams: Params;\n  queryParams: Params;\n  title: string | null;\n  fragment: string | null;\n}\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class RouterStateService {\n  private _isScrollTopOnNavigationEnabled = false;\n  private readonly _router = inject(Router);\n\n  private readonly _route$ = new BehaviorSubject(window.location.pathname);\n  private readonly _state$ = new BehaviorSubject<RouterState>(this._getInitialState());\n\n  private readonly _afterInitialize$ = new BehaviorSubject<boolean>(false);\n  readonly afterInitialize$ = this._afterInitialize$.pipe(filter((v) => v));\n\n  get route$() {\n    return this._route$.asObservable().pipe(distinctUntilChanged());\n  }\n\n  get route() {\n    return this._route$.getValue();\n  }\n\n  get state$() {\n    return this._state$.asObservable();\n  }\n\n  get state() {\n    return this._state$.getValue();\n  }\n\n  get data$() {\n    return this._state$.pipe(\n      map((state) => state.data),\n      distinctUntilChanged((a, b) => equal(a, b)),\n    );\n  }\n\n  get data() {\n    return this._state$.getValue().data;\n  }\n\n  get pathParams$() {\n    return this._state$.pipe(\n      map((state) => state.pathParams),\n      distinctUntilChanged((a, b) => equal(a, b)),\n    );\n  }\n\n  get pathParams() {\n    return this._state$.getValue().pathParams;\n  }\n\n  get queryParams$() {\n    return this._state$.pipe(\n      map((state) => state.queryParams),\n      distinctUntilChanged((a, b) => equal(a, b)),\n    );\n  }\n\n  get queryParams() {\n    return this._state$.getValue().queryParams;\n  }\n\n  get title$() {\n    return this._state$.pipe(\n      map((state) => state.title),\n      distinctUntilChanged(),\n    );\n  }\n\n  get title() {\n    return this._state$.getValue().title;\n  }\n\n  get fragment$() {\n    return this._state$.pipe(\n      map((state) => state.fragment),\n      distinctUntilChanged(),\n    );\n  }\n\n  get fragment() {\n    return this._state$.getValue().fragment;\n  }\n\n  get dataChanges$() {\n    return this.data$.pipe(\n      pairwise(),\n      map((v) => this._findChanges(v)),\n      shareReplay({ bufferSize: 1, refCount: true }),\n    );\n  }\n\n  get queryParamChanges$() {\n    return this.queryParams$.pipe(\n      pairwise(),\n      map((v) => this._findChanges(v)),\n      shareReplay({ bufferSize: 1, refCount: true }),\n    );\n  }\n\n  get pathParamChanges$() {\n    return this.pathParams$.pipe(\n      pairwise(),\n      map((v) => this._findChanges(v)),\n      shareReplay({ bufferSize: 1, refCount: true }),\n    );\n  }\n\n  constructor() {\n    this._router.events\n      .pipe(\n        filter((event): event is NavigationEnd => event instanceof NavigationEnd),\n        distinctUntilChanged((a, b) => a.url === b.url),\n        map((event) => {\n          const { url } = event;\n\n          const urlWithoutQueryParams = url.split('?')[0] ?? '';\n          const withoutFragment = urlWithoutQueryParams.split('#')[0] ?? '';\n\n          return withoutFragment;\n        }),\n        tap(() => {\n          if (!this._afterInitialize$.getValue()) {\n            this._afterInitialize$.next(true);\n          }\n        }),\n      )\n      .subscribe(this._route$);\n\n    combineLatest([this._route$, this._afterInitialize$])\n      .pipe(\n        tap(([, afterInitialize]) => {\n          if (!afterInitialize) return;\n\n          let route = this._router.routerState.snapshot.root;\n\n          while (route.firstChild) {\n            route = route.firstChild;\n          }\n\n          const { data, params, queryParams, title, fragment } = route;\n\n          this._state$.next({\n            data,\n            pathParams: params,\n            queryParams,\n            title: title ?? null,\n            fragment,\n          });\n        }),\n      )\n      .subscribe();\n  }\n\n  enableScrollEnhancements(config: ScrollEnhancementsConfig = {}) {\n    if (this._isScrollTopOnNavigationEnabled) {\n      return;\n    }\n\n    this._isScrollTopOnNavigationEnabled = true;\n\n    combineLatest([this._state$.pipe(pairwise()), this._route$.pipe(pairwise())])\n      .pipe(debounceTime(1))\n      .subscribe(([[prevState, currState], [prevRoute, currRoute]]) => {\n        const sameUrlNavigation = prevRoute === currRoute;\n        const didFragmentChange = prevState.fragment !== currState.fragment;\n\n        if (sameUrlNavigation) {\n          const allQueryParams = [\n            ...new Set(Object.keys(prevState.queryParams).concat(Object.keys(currState.queryParams))),\n          ];\n\n          const changedQueryParams = allQueryParams.filter(\n            (key) => currState.queryParams[key] !== prevState.queryParams[key],\n          );\n\n          if (!config.queryParamTriggerList?.length && !didFragmentChange) {\n            return;\n          }\n\n          const caseQueryParams = changedQueryParams.some((key) => config.queryParamTriggerList?.includes(key));\n          const caseFragment = didFragmentChange && config.fragment?.enabled;\n\n          if (caseQueryParams) {\n            (config.scrollElement ?? document.documentElement).scrollTop = 0;\n          } else if (caseFragment) {\n            const fragmentElement = document.getElementById(currState.fragment ?? '');\n\n            if (fragmentElement) {\n              fragmentElement.scrollIntoView({ behavior: config.fragment?.smooth ? 'smooth' : 'auto' });\n            }\n          }\n        } else {\n          const viaReturnRoute =\n            currState.data[ET_DISABLE_SCROLL_TOP_AS_RETURN_ROUTE] && prevState.data[ET_DISABLE_SCROLL_TOP];\n          const explicitly = currState.data[ET_DISABLE_SCROLL_TOP];\n          const pathParamsChange = currState.data[ET_DISABLE_SCROLL_TOP_ON_PATH_PARAM_CHANGE];\n\n          if (viaReturnRoute || explicitly || pathParamsChange) {\n            return;\n          }\n\n          const el = config.scrollElement ?? document.documentElement;\n          el.scrollTop = 0;\n        }\n      });\n  }\n\n  selectQueryParam<T = string | undefined>(key: string): Observable<T> {\n    return this._state$.pipe(\n      map((state) => state.queryParams[key]),\n      distinctUntilChanged(),\n    );\n  }\n\n  selectPathParam<T = string | undefined>(key: string): Observable<T> {\n    return this._state$.pipe(\n      map((state) => state.pathParams[key]),\n      distinctUntilChanged(),\n    );\n  }\n\n  selectData<T = unknown>(key: string): Observable<T> {\n    return this._state$.pipe(\n      map((state) => state.data[key]),\n      distinctUntilChanged((a, b) => equal(a, b)),\n    );\n  }\n\n  private _findChanges<T extends [Record<string, unknown>, Record<string, unknown>], J extends Partial<T[number]>>([\n    previous,\n    current,\n  ]: T) {\n    const changes: Record<string, unknown> = {};\n\n    const allKeys = new Set<keyof typeof previous & keyof typeof current>([\n      ...Object.keys(previous),\n      ...Object.keys(current),\n    ]);\n\n    for (const key of allKeys) {\n      if (!equal(previous[key], current[key])) {\n        const val = current[key] === undefined ? ET_PROPERTY_REMOVED : current[key];\n\n        changes[key] = val;\n      }\n    }\n\n    return changes as J;\n  }\n\n  private _getInitialState(): RouterState {\n    const data = {};\n    const pathParams = {};\n    const queryParams: Params = {};\n    const title = null;\n    let fragment = null;\n\n    const currentQueryParams = window.location.search;\n    const currentFragment = window.location.hash;\n\n    if (currentQueryParams) {\n      const params = new URLSearchParams(currentQueryParams);\n\n      params.forEach((value, key) => {\n        queryParams[key] = value;\n      });\n    }\n\n    if (currentFragment) {\n      fragment = currentFragment.slice(1);\n    }\n\n    return {\n      data,\n      pathParams,\n      queryParams,\n      title,\n      fragment,\n    };\n  }\n}\n"]}
|
|
@@ -2249,38 +2249,40 @@ class RouterStateService {
|
|
|
2249
2249
|
constructor() {
|
|
2250
2250
|
this._isScrollTopOnNavigationEnabled = false;
|
|
2251
2251
|
this._router = inject(Router);
|
|
2252
|
-
this._route$ = new BehaviorSubject(
|
|
2253
|
-
this._state$ = new BehaviorSubject(
|
|
2254
|
-
|
|
2255
|
-
|
|
2256
|
-
data: {},
|
|
2257
|
-
pathParams: {},
|
|
2258
|
-
queryParams: {},
|
|
2259
|
-
});
|
|
2252
|
+
this._route$ = new BehaviorSubject(window.location.pathname);
|
|
2253
|
+
this._state$ = new BehaviorSubject(this._getInitialState());
|
|
2254
|
+
this._afterInitialize$ = new BehaviorSubject(false);
|
|
2255
|
+
this.afterInitialize$ = this._afterInitialize$.pipe(filter((v) => v));
|
|
2260
2256
|
this._router.events
|
|
2261
2257
|
.pipe(filter((event) => event instanceof NavigationEnd), distinctUntilChanged((a, b) => a.url === b.url), map((event) => {
|
|
2262
2258
|
const { url } = event;
|
|
2263
2259
|
const urlWithoutQueryParams = url.split('?')[0] ?? '';
|
|
2264
2260
|
const withoutFragment = urlWithoutQueryParams.split('#')[0] ?? '';
|
|
2265
2261
|
return withoutFragment;
|
|
2262
|
+
}), tap(() => {
|
|
2263
|
+
if (!this._afterInitialize$.getValue()) {
|
|
2264
|
+
this._afterInitialize$.next(true);
|
|
2265
|
+
}
|
|
2266
2266
|
}))
|
|
2267
2267
|
.subscribe(this._route$);
|
|
2268
|
-
this._route$
|
|
2269
|
-
.pipe(
|
|
2268
|
+
combineLatest([this._route$, this._afterInitialize$])
|
|
2269
|
+
.pipe(tap(([, afterInitialize]) => {
|
|
2270
|
+
if (!afterInitialize)
|
|
2271
|
+
return;
|
|
2270
2272
|
let route = this._router.routerState.snapshot.root;
|
|
2271
2273
|
while (route.firstChild) {
|
|
2272
2274
|
route = route.firstChild;
|
|
2273
2275
|
}
|
|
2274
2276
|
const { data, params, queryParams, title, fragment } = route;
|
|
2275
|
-
|
|
2277
|
+
this._state$.next({
|
|
2276
2278
|
data,
|
|
2277
2279
|
pathParams: params,
|
|
2278
2280
|
queryParams,
|
|
2279
2281
|
title: title ?? null,
|
|
2280
2282
|
fragment,
|
|
2281
|
-
};
|
|
2283
|
+
});
|
|
2282
2284
|
}))
|
|
2283
|
-
.subscribe(
|
|
2285
|
+
.subscribe();
|
|
2284
2286
|
}
|
|
2285
2287
|
enableScrollEnhancements(config = {}) {
|
|
2286
2288
|
if (this._isScrollTopOnNavigationEnabled) {
|
|
@@ -2347,6 +2349,31 @@ class RouterStateService {
|
|
|
2347
2349
|
}
|
|
2348
2350
|
return changes;
|
|
2349
2351
|
}
|
|
2352
|
+
_getInitialState() {
|
|
2353
|
+
const data = {};
|
|
2354
|
+
const pathParams = {};
|
|
2355
|
+
const queryParams = {};
|
|
2356
|
+
const title = null;
|
|
2357
|
+
let fragment = null;
|
|
2358
|
+
const currentQueryParams = window.location.search;
|
|
2359
|
+
const currentFragment = window.location.hash;
|
|
2360
|
+
if (currentQueryParams) {
|
|
2361
|
+
const params = new URLSearchParams(currentQueryParams);
|
|
2362
|
+
params.forEach((value, key) => {
|
|
2363
|
+
queryParams[key] = value;
|
|
2364
|
+
});
|
|
2365
|
+
}
|
|
2366
|
+
if (currentFragment) {
|
|
2367
|
+
fragment = currentFragment.slice(1);
|
|
2368
|
+
}
|
|
2369
|
+
return {
|
|
2370
|
+
data,
|
|
2371
|
+
pathParams,
|
|
2372
|
+
queryParams,
|
|
2373
|
+
title,
|
|
2374
|
+
fragment,
|
|
2375
|
+
};
|
|
2376
|
+
}
|
|
2350
2377
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.11", ngImport: i0, type: RouterStateService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
2351
2378
|
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.11", ngImport: i0, type: RouterStateService, providedIn: 'root' }); }
|
|
2352
2379
|
}
|