@ethlete/core 2.0.0 → 2.2.0
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/esm2022/lib/directives/animated-overlay/animated-overlay.directive.mjs +28 -4
- package/esm2022/lib/directives/is-active-element/is-active-element.directive.mjs +41 -0
- package/esm2022/lib/directives/is-active-element/public-api.mjs +2 -0
- package/esm2022/lib/directives/observe-resize/index.mjs +2 -0
- package/esm2022/lib/directives/public-api.mjs +2 -1
- package/esm2022/lib/services/router-state.service.mjs +59 -2
- package/fesm2022/ethlete-core.mjs +354 -238
- package/fesm2022/ethlete-core.mjs.map +1 -1
- package/lib/directives/animated-overlay/animated-overlay.directive.d.ts +8 -4
- package/lib/directives/is-active-element/is-active-element.directive.d.ts +12 -0
- package/lib/directives/is-active-element/public-api.d.ts +1 -0
- package/lib/directives/observe-resize/index.d.ts +1 -0
- package/lib/directives/public-api.d.ts +1 -0
- package/lib/services/router-state.service.d.ts +22 -0
- package/package.json +1 -1
|
@@ -1,10 +1,12 @@
|
|
|
1
1
|
import { Overlay } from '@angular/cdk/overlay';
|
|
2
2
|
import { ComponentPortal } from '@angular/cdk/portal';
|
|
3
|
-
import { Directive, ElementRef, Injector, Input, NgZone, ViewContainerRef, inject, } from '@angular/core';
|
|
3
|
+
import { Directive, ElementRef, Injector, Input, NgZone, ViewContainerRef, inject, isDevMode, } from '@angular/core';
|
|
4
4
|
import { createPopper } from '@popperjs/core';
|
|
5
5
|
import { Subject, filter, take, takeUntil, tap } from 'rxjs';
|
|
6
6
|
import { createDestroy, nextFrame } from '../../utils';
|
|
7
|
+
import { ObserveResizeDirective } from '../observe-resize';
|
|
7
8
|
import * as i0 from "@angular/core";
|
|
9
|
+
import * as i1 from "../observe-resize/observe-resize.directive";
|
|
8
10
|
class AnimatedOverlayDirective {
|
|
9
11
|
constructor() {
|
|
10
12
|
this._destroy$ = createDestroy();
|
|
@@ -13,6 +15,7 @@ class AnimatedOverlayDirective {
|
|
|
13
15
|
this._viewContainerRef = inject(ViewContainerRef);
|
|
14
16
|
this._zone = inject(NgZone);
|
|
15
17
|
this._elementRef = inject(ElementRef);
|
|
18
|
+
this._observeResize = inject(ObserveResizeDirective);
|
|
16
19
|
this._portal = null;
|
|
17
20
|
this._overlayRef = null;
|
|
18
21
|
this._componentRef = null;
|
|
@@ -54,7 +57,13 @@ class AnimatedOverlayDirective {
|
|
|
54
57
|
return this._popper;
|
|
55
58
|
}
|
|
56
59
|
mount(config) {
|
|
57
|
-
|
|
60
|
+
if (this.isMounted) {
|
|
61
|
+
if (isDevMode()) {
|
|
62
|
+
console.warn('AnimatedOverlayDirective: There is already a component mounted. Please call `unmount` before calling `mount` again.');
|
|
63
|
+
}
|
|
64
|
+
return;
|
|
65
|
+
}
|
|
66
|
+
const { component, providers, data, mirrorWidth } = config;
|
|
58
67
|
this._beforeOpened?.next();
|
|
59
68
|
const injector = Injector.create({
|
|
60
69
|
parent: this._injector,
|
|
@@ -67,6 +76,19 @@ class AnimatedOverlayDirective {
|
|
|
67
76
|
Object.assign(this._componentRef.instance, data);
|
|
68
77
|
}
|
|
69
78
|
this._componentRef.instance._markForCheck?.();
|
|
79
|
+
if (mirrorWidth) {
|
|
80
|
+
this._overlayRef.updateSize({
|
|
81
|
+
width: this._elementRef.nativeElement.offsetWidth,
|
|
82
|
+
});
|
|
83
|
+
this._observeResize.valueChange
|
|
84
|
+
.pipe(tap(() => {
|
|
85
|
+
this._overlayRef?.updateSize({
|
|
86
|
+
width: this._elementRef.nativeElement.offsetWidth,
|
|
87
|
+
});
|
|
88
|
+
this._popper?.update();
|
|
89
|
+
}), takeUntil(this._destroy$), takeUntil(this.afterClosed()))
|
|
90
|
+
.subscribe();
|
|
91
|
+
}
|
|
70
92
|
this._zone.runOutsideAngular(() => {
|
|
71
93
|
if (!this._componentRef) {
|
|
72
94
|
return;
|
|
@@ -112,6 +134,7 @@ class AnimatedOverlayDirective {
|
|
|
112
134
|
.subscribe();
|
|
113
135
|
});
|
|
114
136
|
});
|
|
137
|
+
return this._componentRef.instance;
|
|
115
138
|
}
|
|
116
139
|
unmount() {
|
|
117
140
|
if (!this._componentRef) {
|
|
@@ -163,13 +186,14 @@ class AnimatedOverlayDirective {
|
|
|
163
186
|
this._afterClosed?.next();
|
|
164
187
|
}
|
|
165
188
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: AnimatedOverlayDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
166
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.0", type: AnimatedOverlayDirective, isStandalone: true, inputs: { placement: "placement", offset: "offset", arrowPadding: "arrowPadding" }, ngImport: i0 }); }
|
|
189
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.0", type: AnimatedOverlayDirective, isStandalone: true, inputs: { placement: "placement", offset: "offset", arrowPadding: "arrowPadding" }, hostDirectives: [{ directive: i1.ObserveResizeDirective }], ngImport: i0 }); }
|
|
167
190
|
}
|
|
168
191
|
export { AnimatedOverlayDirective };
|
|
169
192
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: AnimatedOverlayDirective, decorators: [{
|
|
170
193
|
type: Directive,
|
|
171
194
|
args: [{
|
|
172
195
|
standalone: true,
|
|
196
|
+
hostDirectives: [ObserveResizeDirective],
|
|
173
197
|
}]
|
|
174
198
|
}], propDecorators: { placement: [{
|
|
175
199
|
type: Input
|
|
@@ -178,4 +202,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImpor
|
|
|
178
202
|
}], arrowPadding: [{
|
|
179
203
|
type: Input
|
|
180
204
|
}] } });
|
|
181
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"animated-overlay.directive.js","sourceRoot":"","sources":["../../../../../../../libs/core/src/lib/directives/animated-overlay/animated-overlay.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Overlay, OverlayRef } from '@angular/cdk/overlay';\nimport { ComponentPortal, ComponentType } from '@angular/cdk/portal';\nimport {\n  ComponentRef,\n  Directive,\n  ElementRef,\n  Injector,\n  Input,\n  NgZone,\n  StaticProvider,\n  ViewContainerRef,\n  inject,\n} from '@angular/core';\nimport { Instance as PopperInstance, Placement as PopperPlacement, createPopper } from '@popperjs/core';\nimport { Options as ArrowOptions } from '@popperjs/core/lib/modifiers/arrow';\nimport { Options as OffsetOptions } from '@popperjs/core/lib/modifiers/offset';\nimport { Subject, filter, take, takeUntil, tap } from 'rxjs';\nimport { createDestroy, nextFrame } from '../../utils';\nimport { AnimatedLifecycleDirective } from '../animated-lifecycle';\n\n@Directive({\n  standalone: true,\n})\nexport class AnimatedOverlayDirective<\n  T extends { _animatedLifecycle?: AnimatedLifecycleDirective; _markForCheck?: () => void },\n> {\n  private readonly _destroy$ = createDestroy();\n  private readonly _overlayService = inject(Overlay);\n  private readonly _injector = inject(Injector);\n  private readonly _viewContainerRef = inject(ViewContainerRef);\n  private readonly _zone = inject(NgZone);\n  private readonly _elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n\n  private _portal: ComponentPortal<T> | null = null;\n  private _overlayRef: OverlayRef | null = null;\n  private _componentRef: ComponentRef<T> | null = null;\n  private _popper: PopperInstance | null = null;\n\n  private _beforeOpened: Subject<void> | null = null;\n  private _afterOpened: Subject<void> | null = null;\n  private _beforeClosed: Subject<void> | null = null;\n  private _afterClosed: Subject<void> | null = null;\n\n  /**\n   * The placement of the tooltip.\n   * @default 'auto'\n   */\n  @Input()\n  placement: PopperPlacement = 'auto';\n\n  /**\n   * The offset of the tooltip.\n   * @see https://popper.js.org/docs/v2/modifiers/offset/#offset-1\n   */\n  @Input()\n  offset: OffsetOptions['offset'] | Readonly<OffsetOptions['offset']> | null = null;\n\n  /**\n   * The arrow padding.\n   * @see https://popper.js.org/docs/v2/modifiers/arrow/#padding\n   * @default 4\n   */\n  @Input()\n  arrowPadding: ArrowOptions['padding'] | null = null;\n\n  get isMounted() {\n    return !!this._componentRef;\n  }\n\n  get portal() {\n    return this._portal;\n  }\n\n  get overlayRef() {\n    return this._overlayRef;\n  }\n\n  get componentRef() {\n    return this._componentRef;\n  }\n\n  get popper() {\n    return this._popper;\n  }\n\n  mount(config: { component: ComponentType<T>; providers?: StaticProvider[]; data?: Partial<T> }) {\n    const { component, providers, data } = config;\n\n    this._beforeOpened?.next();\n\n    const injector = Injector.create({\n      parent: this._injector,\n      providers: providers ?? [],\n    });\n\n    this._overlayRef = this._overlayService.create();\n\n    this._portal = this._portal ?? new ComponentPortal(component, this._viewContainerRef, injector);\n    this._componentRef = this._overlayRef.attach(this._portal);\n\n    if (data) {\n      Object.assign(this._componentRef.instance, data);\n    }\n\n    this._componentRef.instance._markForCheck?.();\n\n    this._zone.runOutsideAngular(() => {\n      if (!this._componentRef) {\n        return;\n      }\n      this._popper = createPopper(this._elementRef.nativeElement, this._componentRef.location.nativeElement, {\n        placement: this.placement,\n        modifiers: [\n          ...(this.offset\n            ? [\n                {\n                  name: 'offset',\n                  options: {\n                    offset: this.offset,\n                  },\n                },\n              ]\n            : []),\n          ...(this.arrowPadding\n            ? [\n                {\n                  name: 'arrow',\n                  options: {\n                    padding: this.arrowPadding,\n                  },\n                },\n              ]\n            : []),\n        ],\n      });\n\n      // We need to wait for the tooltip content to be rendered\n      nextFrame(() => {\n        if (!this._componentRef) {\n          return;\n        }\n\n        this._popper?.update();\n        this._componentRef.instance._animatedLifecycle?.enter();\n\n        this._componentRef.instance._animatedLifecycle?.state$\n          .pipe(\n            tap((s) => {\n              if (s === 'entered') {\n                this._afterOpened?.next();\n              }\n            }),\n            take(1),\n            takeUntil(this._destroy$),\n          )\n          .subscribe();\n      });\n    });\n  }\n\n  unmount() {\n    if (!this._componentRef) {\n      return;\n    }\n\n    this._beforeClosed?.next();\n\n    this._componentRef.instance._animatedLifecycle?.leave();\n\n    this._componentRef.instance._animatedLifecycle?.state$\n      .pipe(\n        filter((s) => s === 'left'),\n        take(1),\n      )\n      .subscribe(() => this._destroy());\n  }\n\n  beforeOpened() {\n    if (!this._beforeOpened) {\n      this._beforeOpened = new Subject();\n    }\n\n    return this._beforeOpened;\n  }\n\n  afterOpened() {\n    if (!this._afterOpened) {\n      this._afterOpened = new Subject();\n    }\n\n    return this._afterOpened;\n  }\n\n  beforeClosed() {\n    if (!this._beforeClosed) {\n      this._beforeClosed = new Subject();\n    }\n\n    return this._beforeClosed;\n  }\n\n  afterClosed() {\n    if (!this._afterClosed) {\n      this._afterClosed = new Subject();\n    }\n\n    return this._afterClosed;\n  }\n\n  _destroy() {\n    this._zone.runOutsideAngular(() => {\n      this._popper?.destroy();\n      this._popper = null;\n    });\n\n    if (this._overlayRef) {\n      this._overlayRef.dispose();\n      this._overlayRef = null;\n    }\n\n    if (this._componentRef) {\n      this._componentRef.destroy();\n      this._componentRef = null;\n    }\n\n    this._afterClosed?.next();\n  }\n}\n"]}
|
|
205
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"animated-overlay.directive.js","sourceRoot":"","sources":["../../../../../../../libs/core/src/lib/directives/animated-overlay/animated-overlay.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Overlay, OverlayRef } from '@angular/cdk/overlay';\nimport { ComponentPortal, ComponentType } from '@angular/cdk/portal';\nimport {\n  ComponentRef,\n  Directive,\n  ElementRef,\n  Injector,\n  Input,\n  NgZone,\n  StaticProvider,\n  ViewContainerRef,\n  inject,\n  isDevMode,\n} from '@angular/core';\nimport { Instance as PopperInstance, Placement as PopperPlacement, createPopper } from '@popperjs/core';\nimport { Options as ArrowOptions } from '@popperjs/core/lib/modifiers/arrow';\nimport { Options as OffsetOptions } from '@popperjs/core/lib/modifiers/offset';\nimport { Subject, filter, take, takeUntil, tap } from 'rxjs';\nimport { createDestroy, nextFrame } from '../../utils';\nimport { AnimatedLifecycleDirective } from '../animated-lifecycle';\nimport { ObserveResizeDirective } from '../observe-resize';\n\nexport interface AnimatedOverlayComponentBase {\n  _animatedLifecycle?: AnimatedLifecycleDirective;\n  _markForCheck?: () => void;\n}\n\n@Directive({\n  standalone: true,\n  hostDirectives: [ObserveResizeDirective],\n})\nexport class AnimatedOverlayDirective<T extends AnimatedOverlayComponentBase> {\n  private readonly _destroy$ = createDestroy();\n  private readonly _overlayService = inject(Overlay);\n  private readonly _injector = inject(Injector);\n  private readonly _viewContainerRef = inject(ViewContainerRef);\n  private readonly _zone = inject(NgZone);\n  private readonly _elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n  private readonly _observeResize = inject(ObserveResizeDirective);\n\n  private _portal: ComponentPortal<T> | null = null;\n  private _overlayRef: OverlayRef | null = null;\n  private _componentRef: ComponentRef<T> | null = null;\n  private _popper: PopperInstance | null = null;\n\n  private _beforeOpened: Subject<void> | null = null;\n  private _afterOpened: Subject<void> | null = null;\n  private _beforeClosed: Subject<void> | null = null;\n  private _afterClosed: Subject<void> | null = null;\n\n  /**\n   * The placement of the tooltip.\n   * @default 'auto'\n   */\n  @Input()\n  placement: PopperPlacement = 'auto';\n\n  /**\n   * The offset of the tooltip.\n   * @see https://popper.js.org/docs/v2/modifiers/offset/#offset-1\n   */\n  @Input()\n  offset: OffsetOptions['offset'] | Readonly<OffsetOptions['offset']> | null = null;\n\n  /**\n   * The arrow padding.\n   * @see https://popper.js.org/docs/v2/modifiers/arrow/#padding\n   * @default 4\n   */\n  @Input()\n  arrowPadding: ArrowOptions['padding'] | null = null;\n\n  get isMounted() {\n    return !!this._componentRef;\n  }\n\n  get portal() {\n    return this._portal;\n  }\n\n  get overlayRef() {\n    return this._overlayRef;\n  }\n\n  get componentRef() {\n    return this._componentRef;\n  }\n\n  get popper() {\n    return this._popper;\n  }\n\n  mount(config: {\n    component: ComponentType<T>;\n    providers?: StaticProvider[];\n    data?: Partial<T>;\n    mirrorWidth?: boolean;\n  }) {\n    if (this.isMounted) {\n      if (isDevMode()) {\n        console.warn(\n          'AnimatedOverlayDirective: There is already a component mounted. Please call `unmount` before calling `mount` again.',\n        );\n      }\n\n      return;\n    }\n\n    const { component, providers, data, mirrorWidth } = config;\n\n    this._beforeOpened?.next();\n\n    const injector = Injector.create({\n      parent: this._injector,\n      providers: providers ?? [],\n    });\n\n    this._overlayRef = this._overlayService.create();\n\n    this._portal = this._portal ?? new ComponentPortal(component, this._viewContainerRef, injector);\n    this._componentRef = this._overlayRef.attach(this._portal);\n\n    if (data) {\n      Object.assign(this._componentRef.instance, data);\n    }\n\n    this._componentRef.instance._markForCheck?.();\n\n    if (mirrorWidth) {\n      this._overlayRef.updateSize({\n        width: this._elementRef.nativeElement.offsetWidth,\n      });\n\n      this._observeResize.valueChange\n        .pipe(\n          tap(() => {\n            this._overlayRef?.updateSize({\n              width: this._elementRef.nativeElement.offsetWidth,\n            });\n\n            this._popper?.update();\n          }),\n          takeUntil(this._destroy$),\n          takeUntil(this.afterClosed()),\n        )\n        .subscribe();\n    }\n\n    this._zone.runOutsideAngular(() => {\n      if (!this._componentRef) {\n        return;\n      }\n      this._popper = createPopper(this._elementRef.nativeElement, this._componentRef.location.nativeElement, {\n        placement: this.placement,\n        modifiers: [\n          ...(this.offset\n            ? [\n                {\n                  name: 'offset',\n                  options: {\n                    offset: this.offset,\n                  },\n                },\n              ]\n            : []),\n          ...(this.arrowPadding\n            ? [\n                {\n                  name: 'arrow',\n                  options: {\n                    padding: this.arrowPadding,\n                  },\n                },\n              ]\n            : []),\n        ],\n      });\n\n      // We need to wait for the tooltip content to be rendered\n      nextFrame(() => {\n        if (!this._componentRef) {\n          return;\n        }\n\n        this._popper?.update();\n        this._componentRef.instance._animatedLifecycle?.enter();\n\n        this._componentRef.instance._animatedLifecycle?.state$\n          .pipe(\n            tap((s) => {\n              if (s === 'entered') {\n                this._afterOpened?.next();\n              }\n            }),\n            take(1),\n            takeUntil(this._destroy$),\n          )\n          .subscribe();\n      });\n    });\n\n    return this._componentRef.instance;\n  }\n\n  unmount() {\n    if (!this._componentRef) {\n      return;\n    }\n\n    this._beforeClosed?.next();\n\n    this._componentRef.instance._animatedLifecycle?.leave();\n\n    this._componentRef.instance._animatedLifecycle?.state$\n      .pipe(\n        filter((s) => s === 'left'),\n        take(1),\n      )\n      .subscribe(() => this._destroy());\n  }\n\n  beforeOpened() {\n    if (!this._beforeOpened) {\n      this._beforeOpened = new Subject();\n    }\n\n    return this._beforeOpened;\n  }\n\n  afterOpened() {\n    if (!this._afterOpened) {\n      this._afterOpened = new Subject();\n    }\n\n    return this._afterOpened;\n  }\n\n  beforeClosed() {\n    if (!this._beforeClosed) {\n      this._beforeClosed = new Subject();\n    }\n\n    return this._beforeClosed;\n  }\n\n  afterClosed() {\n    if (!this._afterClosed) {\n      this._afterClosed = new Subject();\n    }\n\n    return this._afterClosed;\n  }\n\n  _destroy() {\n    this._zone.runOutsideAngular(() => {\n      this._popper?.destroy();\n      this._popper = null;\n    });\n\n    if (this._overlayRef) {\n      this._overlayRef.dispose();\n      this._overlayRef = null;\n    }\n\n    if (this._componentRef) {\n      this._componentRef.destroy();\n      this._componentRef = null;\n    }\n\n    this._afterClosed?.next();\n  }\n}\n"]}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import { coerceBooleanProperty } from '@angular/cdk/coercion';
|
|
2
|
+
import { Directive, ElementRef, InjectionToken, Input, inject } from '@angular/core';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export const IS_ACTIVE_ELEMENT = new InjectionToken('ET_IS_ACTIVE_ELEMENT');
|
|
5
|
+
class IsActiveElementDirective {
|
|
6
|
+
constructor() {
|
|
7
|
+
this.elementRef = inject(ElementRef);
|
|
8
|
+
this._isActiveElement = false;
|
|
9
|
+
}
|
|
10
|
+
get isActiveElement() {
|
|
11
|
+
return this._isActiveElement;
|
|
12
|
+
}
|
|
13
|
+
set isActiveElement(value) {
|
|
14
|
+
this._isActiveElement = coerceBooleanProperty(value);
|
|
15
|
+
}
|
|
16
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: IsActiveElementDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
17
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.0", type: IsActiveElementDirective, isStandalone: true, selector: "[etIsActiveElement]", inputs: { isActiveElement: ["etIsActiveElement", "isActiveElement"] }, providers: [
|
|
18
|
+
{
|
|
19
|
+
provide: IS_ACTIVE_ELEMENT,
|
|
20
|
+
useExisting: IsActiveElementDirective,
|
|
21
|
+
},
|
|
22
|
+
], ngImport: i0 }); }
|
|
23
|
+
}
|
|
24
|
+
export { IsActiveElementDirective };
|
|
25
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: IsActiveElementDirective, decorators: [{
|
|
26
|
+
type: Directive,
|
|
27
|
+
args: [{
|
|
28
|
+
selector: '[etIsActiveElement]',
|
|
29
|
+
standalone: true,
|
|
30
|
+
providers: [
|
|
31
|
+
{
|
|
32
|
+
provide: IS_ACTIVE_ELEMENT,
|
|
33
|
+
useExisting: IsActiveElementDirective,
|
|
34
|
+
},
|
|
35
|
+
],
|
|
36
|
+
}]
|
|
37
|
+
}], propDecorators: { isActiveElement: [{
|
|
38
|
+
type: Input,
|
|
39
|
+
args: ['etIsActiveElement']
|
|
40
|
+
}] } });
|
|
41
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaXMtYWN0aXZlLWVsZW1lbnQuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb3JlL3NyYy9saWIvZGlyZWN0aXZlcy9pcy1hY3RpdmUtZWxlbWVudC9pcy1hY3RpdmUtZWxlbWVudC5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFnQixxQkFBcUIsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQzVFLE9BQU8sRUFBRSxTQUFTLEVBQUUsVUFBVSxFQUFFLGNBQWMsRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUVyRixNQUFNLENBQUMsTUFBTSxpQkFBaUIsR0FBRyxJQUFJLGNBQWMsQ0FBMkIsc0JBQXNCLENBQUMsQ0FBQztBQUV0RyxNQVVhLHdCQUF3QjtJQVZyQztRQVdXLGVBQVUsR0FBRyxNQUFNLENBQTBCLFVBQVUsQ0FBQyxDQUFDO1FBUzFELHFCQUFnQixHQUFHLEtBQUssQ0FBQztLQUNsQztJQVJDLElBQ0ksZUFBZTtRQUNqQixPQUFPLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQztJQUMvQixDQUFDO0lBQ0QsSUFBSSxlQUFlLENBQUMsS0FBbUI7UUFDckMsSUFBSSxDQUFDLGdCQUFnQixHQUFHLHFCQUFxQixDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ3ZELENBQUM7OEdBVFUsd0JBQXdCO2tHQUF4Qix3QkFBd0IseUlBUHhCO1lBQ1Q7Z0JBQ0UsT0FBTyxFQUFFLGlCQUFpQjtnQkFDMUIsV0FBVyxFQUFFLHdCQUF3QjthQUN0QztTQUNGOztTQUVVLHdCQUF3QjsyRkFBeEIsd0JBQXdCO2tCQVZwQyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxxQkFBcUI7b0JBQy9CLFVBQVUsRUFBRSxJQUFJO29CQUNoQixTQUFTLEVBQUU7d0JBQ1Q7NEJBQ0UsT0FBTyxFQUFFLGlCQUFpQjs0QkFDMUIsV0FBVywwQkFBMEI7eUJBQ3RDO3FCQUNGO2lCQUNGOzhCQUtLLGVBQWU7c0JBRGxCLEtBQUs7dUJBQUMsbUJBQW1CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQm9vbGVhbklucHV0LCBjb2VyY2VCb29sZWFuUHJvcGVydHkgfSBmcm9tICdAYW5ndWxhci9jZGsvY29lcmNpb24nO1xuaW1wb3J0IHsgRGlyZWN0aXZlLCBFbGVtZW50UmVmLCBJbmplY3Rpb25Ub2tlbiwgSW5wdXQsIGluamVjdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5leHBvcnQgY29uc3QgSVNfQUNUSVZFX0VMRU1FTlQgPSBuZXcgSW5qZWN0aW9uVG9rZW48SXNBY3RpdmVFbGVtZW50RGlyZWN0aXZlPignRVRfSVNfQUNUSVZFX0VMRU1FTlQnKTtcblxuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnW2V0SXNBY3RpdmVFbGVtZW50XScsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIHByb3ZpZGVyczogW1xuICAgIHtcbiAgICAgIHByb3ZpZGU6IElTX0FDVElWRV9FTEVNRU5ULFxuICAgICAgdXNlRXhpc3Rpbmc6IElzQWN0aXZlRWxlbWVudERpcmVjdGl2ZSxcbiAgICB9LFxuICBdLFxufSlcbmV4cG9ydCBjbGFzcyBJc0FjdGl2ZUVsZW1lbnREaXJlY3RpdmUge1xuICByZWFkb25seSBlbGVtZW50UmVmID0gaW5qZWN0PEVsZW1lbnRSZWY8SFRNTEVsZW1lbnQ+PihFbGVtZW50UmVmKTtcblxuICBASW5wdXQoJ2V0SXNBY3RpdmVFbGVtZW50JylcbiAgZ2V0IGlzQWN0aXZlRWxlbWVudCgpOiBib29sZWFuIHtcbiAgICByZXR1cm4gdGhpcy5faXNBY3RpdmVFbGVtZW50O1xuICB9XG4gIHNldCBpc0FjdGl2ZUVsZW1lbnQodmFsdWU6IEJvb2xlYW5JbnB1dCkge1xuICAgIHRoaXMuX2lzQWN0aXZlRWxlbWVudCA9IGNvZXJjZUJvb2xlYW5Qcm9wZXJ0eSh2YWx1ZSk7XG4gIH1cbiAgcHJpdmF0ZSBfaXNBY3RpdmVFbGVtZW50ID0gZmFsc2U7XG59XG4iXX0=
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export * from './is-active-element.directive';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29yZS9zcmMvbGliL2RpcmVjdGl2ZXMvaXMtYWN0aXZlLWVsZW1lbnQvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLCtCQUErQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9pcy1hY3RpdmUtZWxlbWVudC5kaXJlY3RpdmUnO1xuIl19
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export * from './public-api';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvcmUvc3JjL2xpYi9kaXJlY3RpdmVzL29ic2VydmUtcmVzaXplL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsY0FBYyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9wdWJsaWMtYXBpJztcbiJdfQ==
|
|
@@ -4,6 +4,7 @@ export * from './animated-overlay/public-api';
|
|
|
4
4
|
export * from './click-outside/public-api';
|
|
5
5
|
export * from './cursor-drag-scroll/public-api';
|
|
6
6
|
export * from './delayable/public-api';
|
|
7
|
+
export * from './is-active-element/public-api';
|
|
7
8
|
export * from './let/public-api';
|
|
8
9
|
export * from './observe-content/public-api';
|
|
9
10
|
export * from './observe-resize/public-api';
|
|
@@ -13,4 +14,4 @@ export * from './scroll-observer-first-element/public-api';
|
|
|
13
14
|
export * from './scroll-observer-ignore-target/public-api';
|
|
14
15
|
export * from './scroll-observer-last-element/public-api';
|
|
15
16
|
export * from './seo/public-api';
|
|
16
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29yZS9zcmMvbGliL2RpcmVjdGl2ZXMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYywrQkFBK0IsQ0FBQztBQUM5QyxjQUFjLDRCQUE0QixDQUFDO0FBQzNDLGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYyx3QkFBd0IsQ0FBQztBQUN2QyxjQUFjLGdDQUFnQyxDQUFDO0FBQy9DLGNBQWMsa0JBQWtCLENBQUM7QUFDakMsY0FBYyw4QkFBOEIsQ0FBQztBQUM3QyxjQUFjLDZCQUE2QixDQUFDO0FBQzVDLGNBQWMsbUNBQW1DLENBQUM7QUFDbEQsY0FBYyxxQkFBcUIsQ0FBQztBQUNwQyxjQUFjLDRDQUE0QyxDQUFDO0FBQzNELGNBQWMsNENBQTRDLENBQUM7QUFDM0QsY0FBYywyQ0FBMkMsQ0FBQztBQUMxRCxjQUFjLGtCQUFrQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9hbmltYXRhYmxlL3B1YmxpYy1hcGknO1xuZXhwb3J0ICogZnJvbSAnLi9hbmltYXRlZC1saWZlY3ljbGUvcHVibGljLWFwaSc7XG5leHBvcnQgKiBmcm9tICcuL2FuaW1hdGVkLW92ZXJsYXkvcHVibGljLWFwaSc7XG5leHBvcnQgKiBmcm9tICcuL2NsaWNrLW91dHNpZGUvcHVibGljLWFwaSc7XG5leHBvcnQgKiBmcm9tICcuL2N1cnNvci1kcmFnLXNjcm9sbC9wdWJsaWMtYXBpJztcbmV4cG9ydCAqIGZyb20gJy4vZGVsYXlhYmxlL3B1YmxpYy1hcGknO1xuZXhwb3J0ICogZnJvbSAnLi9pcy1hY3RpdmUtZWxlbWVudC9wdWJsaWMtYXBpJztcbmV4cG9ydCAqIGZyb20gJy4vbGV0L3B1YmxpYy1hcGknO1xuZXhwb3J0ICogZnJvbSAnLi9vYnNlcnZlLWNvbnRlbnQvcHVibGljLWFwaSc7XG5leHBvcnQgKiBmcm9tICcuL29ic2VydmUtcmVzaXplL3B1YmxpYy1hcGknO1xuZXhwb3J0ICogZnJvbSAnLi9vYnNlcnZlLXNjcm9sbC1zdGF0ZS9wdWJsaWMtYXBpJztcbmV4cG9ydCAqIGZyb20gJy4vcmVwZWF0L3B1YmxpYy1hcGknO1xuZXhwb3J0ICogZnJvbSAnLi9zY3JvbGwtb2JzZXJ2ZXItZmlyc3QtZWxlbWVudC9wdWJsaWMtYXBpJztcbmV4cG9ydCAqIGZyb20gJy4vc2Nyb2xsLW9ic2VydmVyLWlnbm9yZS10YXJnZXQvcHVibGljLWFwaSc7XG5leHBvcnQgKiBmcm9tICcuL3Njcm9sbC1vYnNlcnZlci1sYXN0LWVsZW1lbnQvcHVibGljLWFwaSc7XG5leHBvcnQgKiBmcm9tICcuL3Nlby9wdWJsaWMtYXBpJztcbiJdfQ==
|
|
@@ -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, } from 'rxjs';
|
|
3
|
+
import { BehaviorSubject, combineLatest, debounceTime, distinctUntilChanged, filter, map, pairwise, shareReplay, } from 'rxjs';
|
|
4
4
|
import { equal } from '../utils';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
export const routerDisableScrollTop = (config = {}) => {
|
|
@@ -13,6 +13,7 @@ export const routerDisableScrollTop = (config = {}) => {
|
|
|
13
13
|
disableScrollTopAsReturnRoute: true,
|
|
14
14
|
};
|
|
15
15
|
};
|
|
16
|
+
export const ET_PROPERTY_REMOVED = Symbol('ET_PROPERTY_REMOVED');
|
|
16
17
|
class RouterStateService {
|
|
17
18
|
get route$() {
|
|
18
19
|
return this._route$.asObservable().pipe(distinctUntilChanged());
|
|
@@ -20,6 +21,48 @@ class RouterStateService {
|
|
|
20
21
|
get state$() {
|
|
21
22
|
return this._state$.asObservable();
|
|
22
23
|
}
|
|
24
|
+
get state() {
|
|
25
|
+
return this._state$.getValue();
|
|
26
|
+
}
|
|
27
|
+
get data$() {
|
|
28
|
+
return this._state$.pipe(map((state) => state.data), distinctUntilChanged((a, b) => equal(a, b)));
|
|
29
|
+
}
|
|
30
|
+
get data() {
|
|
31
|
+
return this._state$.getValue().data;
|
|
32
|
+
}
|
|
33
|
+
get pathParams$() {
|
|
34
|
+
return this._state$.pipe(map((state) => state.pathParams), distinctUntilChanged((a, b) => equal(a, b)));
|
|
35
|
+
}
|
|
36
|
+
get pathParams() {
|
|
37
|
+
return this._state$.getValue().pathParams;
|
|
38
|
+
}
|
|
39
|
+
get queryParams$() {
|
|
40
|
+
return this._state$.pipe(map((state) => state.queryParams), distinctUntilChanged((a, b) => equal(a, b)));
|
|
41
|
+
}
|
|
42
|
+
get queryParams() {
|
|
43
|
+
return this._state$.getValue().queryParams;
|
|
44
|
+
}
|
|
45
|
+
get title$() {
|
|
46
|
+
return this._state$.pipe(map((state) => state.title), distinctUntilChanged());
|
|
47
|
+
}
|
|
48
|
+
get title() {
|
|
49
|
+
return this._state$.getValue().title;
|
|
50
|
+
}
|
|
51
|
+
get fragment$() {
|
|
52
|
+
return this._state$.pipe(map((state) => state.fragment), distinctUntilChanged());
|
|
53
|
+
}
|
|
54
|
+
get fragment() {
|
|
55
|
+
return this._state$.getValue().fragment;
|
|
56
|
+
}
|
|
57
|
+
get dataChanges$() {
|
|
58
|
+
return this.data$.pipe(pairwise(), map((v) => this._findChanges(v)), shareReplay({ bufferSize: 1, refCount: true }));
|
|
59
|
+
}
|
|
60
|
+
get queryParamChanges$() {
|
|
61
|
+
return this.queryParams$.pipe(pairwise(), map((v) => this._findChanges(v)), shareReplay({ bufferSize: 1, refCount: true }));
|
|
62
|
+
}
|
|
63
|
+
get pathParamChanges$() {
|
|
64
|
+
return this.pathParams$.pipe(pairwise(), map((v) => this._findChanges(v)), shareReplay({ bufferSize: 1, refCount: true }));
|
|
65
|
+
}
|
|
23
66
|
constructor() {
|
|
24
67
|
this._isScrollTopOnNavigationEnabled = false;
|
|
25
68
|
this._router = inject(Router);
|
|
@@ -103,6 +146,20 @@ class RouterStateService {
|
|
|
103
146
|
selectData(key) {
|
|
104
147
|
return this._state$.pipe(map((state) => state.data[key]), distinctUntilChanged((a, b) => equal(a, b)));
|
|
105
148
|
}
|
|
149
|
+
_findChanges([previous, current,]) {
|
|
150
|
+
const changes = {};
|
|
151
|
+
const allKeys = new Set([
|
|
152
|
+
...Object.keys(previous),
|
|
153
|
+
...Object.keys(current),
|
|
154
|
+
]);
|
|
155
|
+
for (const key of allKeys) {
|
|
156
|
+
if (!equal(previous[key], current[key])) {
|
|
157
|
+
const val = current[key] === undefined ? ET_PROPERTY_REMOVED : current[key];
|
|
158
|
+
changes[key] = val;
|
|
159
|
+
}
|
|
160
|
+
}
|
|
161
|
+
return changes;
|
|
162
|
+
}
|
|
106
163
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: RouterStateService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
107
164
|
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: RouterStateService, providedIn: 'root' }); }
|
|
108
165
|
}
|
|
@@ -113,4 +170,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImpor
|
|
|
113
170
|
providedIn: 'root',
|
|
114
171
|
}]
|
|
115
172
|
}], ctorParameters: function () { return []; } });
|
|
116
|
-
//# 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} from 'rxjs';\nimport { equal } from '../utils';\n\nexport const routerDisableScrollTop = (config: { asReturnRoute?: boolean } = {}) => {\n  if (!config.asReturnRoute) {\n    return {\n      disableScrollTop: true,\n    };\n  }\n\n  return {\n    disableScrollTopAsReturnRoute: true,\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 state$() {\n    return this._state$.asObservable();\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(\n    config: {\n      scrollElement?: HTMLElement;\n      queryParamTriggerList?: string[];\n      fragment?: {\n        enabled?: boolean;\n        smooth?: boolean;\n      };\n    } = {},\n  ) {\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 && equal(prevState.pathParams, currState.pathParams);\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          if (\n            !(currState.data['disableScrollTopAsReturnRoute'] && prevState.data['disableScrollTop']) &&\n            !currState.data['disableScrollTop']\n          ) {\n            (config.scrollElement ?? document.documentElement).scrollTop = 0;\n          }\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"]}
|
|
173
|
+
//# 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} from 'rxjs';\nimport { equal } from '../utils';\n\nexport const routerDisableScrollTop = (config: { asReturnRoute?: boolean } = {}) => {\n  if (!config.asReturnRoute) {\n    return {\n      disableScrollTop: true,\n    };\n  }\n\n  return {\n    disableScrollTopAsReturnRoute: true,\n  };\n};\n\nexport const ET_PROPERTY_REMOVED = Symbol('ET_PROPERTY_REMOVED');\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 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(\n    config: {\n      scrollElement?: HTMLElement;\n      queryParamTriggerList?: string[];\n      fragment?: {\n        enabled?: boolean;\n        smooth?: boolean;\n      };\n    } = {},\n  ) {\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 && equal(prevState.pathParams, currState.pathParams);\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          if (\n            !(currState.data['disableScrollTopAsReturnRoute'] && prevState.data['disableScrollTop']) &&\n            !currState.data['disableScrollTop']\n          ) {\n            (config.scrollElement ?? document.documentElement).scrollTop = 0;\n          }\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"]}
|