@ethlete/core 2.3.0 → 2.4.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.
@@ -20,7 +20,7 @@ class AnimatableDirective {
20
20
  }
21
21
  set animatedElement(value) {
22
22
  let newElement = null;
23
- if (value === null || value === undefined) {
23
+ if (value === null || value === undefined || value === '') {
24
24
  newElement = this._elementRef.nativeElement;
25
25
  }
26
26
  else if (typeof value === 'string') {
@@ -111,4 +111,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImpor
111
111
  type: Input,
112
112
  args: ['etAnimatable']
113
113
  }] } });
114
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"animatable.directive.js","sourceRoot":"","sources":["../../../../../../../libs/core/src/lib/directives/animatable/animatable.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, inject, InjectionToken, Input, isDevMode, OnInit } from '@angular/core';\nimport {\n  BehaviorSubject,\n  debounceTime,\n  filter,\n  fromEvent,\n  map,\n  merge,\n  Observable,\n  skip,\n  Subject,\n  takeUntil,\n  tap,\n} from 'rxjs';\nimport { createDestroy } from '../../utils';\n\nexport const ANIMATABLE_TOKEN = new InjectionToken<AnimatableDirective>('ANIMATABLE_DIRECTIVE_TOKEN');\n\n@Directive({\n  selector: '[etAnimatable]',\n  exportAs: 'etAnimatable',\n  standalone: true,\n  providers: [\n    {\n      provide: ANIMATABLE_TOKEN,\n      useExisting: AnimatableDirective,\n    },\n  ],\n})\nexport class AnimatableDirective implements OnInit {\n  private _didEmitStart = false;\n\n  private readonly _parent = inject(ANIMATABLE_TOKEN, { optional: true, skipSelf: true });\n  private readonly _destroy$ = createDestroy();\n  private readonly _elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n\n  private readonly _animationStart$ = new Subject<void>();\n  private readonly _animationEnd$ = new Subject<void>();\n\n  @Input('etAnimatable')\n  set animatedElement(value: string | HTMLElement | null | undefined) {\n    let newElement: HTMLElement | null = null;\n    if (value === null || value === undefined) {\n      newElement = this._elementRef.nativeElement;\n    } else if (typeof value === 'string') {\n      const el = document.querySelector(value) as HTMLElement;\n\n      if (el) {\n        newElement = el;\n      } else {\n        if (isDevMode()) {\n          console.warn(`Element with selector ${value} not found. Animatable directive will use host element.`);\n        }\n\n        newElement = this._elementRef.nativeElement;\n      }\n    } else {\n      newElement = value;\n    }\n\n    if (this._animatedElement$.value !== newElement) {\n      this._animatedElement$.next(newElement);\n    }\n  }\n  private _animatedElement$ = new BehaviorSubject<HTMLElement>(this._elementRef.nativeElement);\n\n  readonly animationStart$ = this._animationStart$.asObservable().pipe(debounceTime(0));\n  readonly animationEnd$ = this._animationEnd$.asObservable().pipe(debounceTime(0));\n\n  private readonly _hostActiveAnimationCount$ = new BehaviorSubject<number>(0);\n  private readonly _totalActiveAnimationCount$ = new BehaviorSubject<number>(0);\n\n  readonly isAnimating$: Observable<boolean> = this._totalActiveAnimationCount$.pipe(\n    map((count) => count > 0),\n    debounceTime(0),\n  );\n\n  ngOnInit(): void {\n    this._animatedElement$\n      .pipe(\n        tap((el) => {\n          this._totalActiveAnimationCount$.next(\n            this._totalActiveAnimationCount$.value - this._hostActiveAnimationCount$.value,\n          );\n          this._hostActiveAnimationCount$.next(0);\n\n          merge(fromEvent<AnimationEvent>(el, 'animationstart'), fromEvent<TransitionEvent>(el, 'transitionstart'))\n            .pipe(\n              filter((e) => e.target === el), // skip events from children\n              tap(() => {\n                const count = this._hostActiveAnimationCount$.value + 1;\n                this._hostActiveAnimationCount$.next(count);\n                this._totalActiveAnimationCount$.next(count);\n              }),\n              takeUntil(this._destroy$),\n              takeUntil(this._animatedElement$.pipe(skip(1))),\n            )\n            .subscribe();\n\n          merge(\n            fromEvent<AnimationEvent>(el, 'animationend'),\n            fromEvent<AnimationEvent>(el, 'animationcancel'),\n            fromEvent<TransitionEvent>(el, 'transitionend'),\n            fromEvent<TransitionEvent>(el, 'transitioncancel'),\n          )\n            .pipe(\n              filter((e) => e.target === el), // skip events from children\n              tap(() => {\n                const count = this._hostActiveAnimationCount$.value - 1;\n                this._hostActiveAnimationCount$.next(count);\n                this._totalActiveAnimationCount$.next(count);\n              }),\n              takeUntil(this._destroy$),\n              takeUntil(this._animatedElement$.pipe(skip(1))),\n            )\n            .subscribe();\n        }),\n        takeUntil(this._destroy$),\n      )\n      .subscribe();\n\n    this._totalActiveAnimationCount$\n      .pipe(\n        tap((count) => {\n          if (count > 0 && !this._didEmitStart) {\n            this._animationStart$.next();\n            this._didEmitStart = true;\n          } else if (count === 0) {\n            this._animationEnd$.next();\n            this._didEmitStart = false;\n          }\n        }),\n        takeUntil(this._destroy$),\n      )\n      .subscribe();\n\n    if (this._parent) {\n      this._parent._hostActiveAnimationCount$\n        .pipe(\n          takeUntil(this._destroy$),\n          tap((count) => {\n            this._totalActiveAnimationCount$.next(count + this._hostActiveAnimationCount$.value);\n          }),\n        )\n        .subscribe();\n    }\n  }\n}\n"]}
114
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"animatable.directive.js","sourceRoot":"","sources":["../../../../../../../libs/core/src/lib/directives/animatable/animatable.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, inject, InjectionToken, Input, isDevMode, OnInit } from '@angular/core';\nimport {\n  BehaviorSubject,\n  debounceTime,\n  filter,\n  fromEvent,\n  map,\n  merge,\n  Observable,\n  skip,\n  Subject,\n  takeUntil,\n  tap,\n} from 'rxjs';\nimport { createDestroy } from '../../utils';\n\nexport const ANIMATABLE_TOKEN = new InjectionToken<AnimatableDirective>('ANIMATABLE_DIRECTIVE_TOKEN');\n\n@Directive({\n  selector: '[etAnimatable]',\n  exportAs: 'etAnimatable',\n  standalone: true,\n  providers: [\n    {\n      provide: ANIMATABLE_TOKEN,\n      useExisting: AnimatableDirective,\n    },\n  ],\n})\nexport class AnimatableDirective implements OnInit {\n  private _didEmitStart = false;\n\n  private readonly _parent = inject(ANIMATABLE_TOKEN, { optional: true, skipSelf: true });\n  private readonly _destroy$ = createDestroy();\n  private readonly _elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n\n  private readonly _animationStart$ = new Subject<void>();\n  private readonly _animationEnd$ = new Subject<void>();\n\n  @Input('etAnimatable')\n  set animatedElement(value: string | HTMLElement | null | undefined) {\n    let newElement: HTMLElement | null = null;\n    if (value === null || value === undefined || value === '') {\n      newElement = this._elementRef.nativeElement;\n    } else if (typeof value === 'string') {\n      const el = document.querySelector(value) as HTMLElement;\n\n      if (el) {\n        newElement = el;\n      } else {\n        if (isDevMode()) {\n          console.warn(`Element with selector ${value} not found. Animatable directive will use host element.`);\n        }\n\n        newElement = this._elementRef.nativeElement;\n      }\n    } else {\n      newElement = value;\n    }\n\n    if (this._animatedElement$.value !== newElement) {\n      this._animatedElement$.next(newElement);\n    }\n  }\n  private _animatedElement$ = new BehaviorSubject<HTMLElement>(this._elementRef.nativeElement);\n\n  readonly animationStart$ = this._animationStart$.asObservable().pipe(debounceTime(0));\n  readonly animationEnd$ = this._animationEnd$.asObservable().pipe(debounceTime(0));\n\n  private readonly _hostActiveAnimationCount$ = new BehaviorSubject<number>(0);\n  private readonly _totalActiveAnimationCount$ = new BehaviorSubject<number>(0);\n\n  readonly isAnimating$: Observable<boolean> = this._totalActiveAnimationCount$.pipe(\n    map((count) => count > 0),\n    debounceTime(0),\n  );\n\n  ngOnInit(): void {\n    this._animatedElement$\n      .pipe(\n        tap((el) => {\n          this._totalActiveAnimationCount$.next(\n            this._totalActiveAnimationCount$.value - this._hostActiveAnimationCount$.value,\n          );\n          this._hostActiveAnimationCount$.next(0);\n\n          merge(fromEvent<AnimationEvent>(el, 'animationstart'), fromEvent<TransitionEvent>(el, 'transitionstart'))\n            .pipe(\n              filter((e) => e.target === el), // skip events from children\n              tap(() => {\n                const count = this._hostActiveAnimationCount$.value + 1;\n                this._hostActiveAnimationCount$.next(count);\n                this._totalActiveAnimationCount$.next(count);\n              }),\n              takeUntil(this._destroy$),\n              takeUntil(this._animatedElement$.pipe(skip(1))),\n            )\n            .subscribe();\n\n          merge(\n            fromEvent<AnimationEvent>(el, 'animationend'),\n            fromEvent<AnimationEvent>(el, 'animationcancel'),\n            fromEvent<TransitionEvent>(el, 'transitionend'),\n            fromEvent<TransitionEvent>(el, 'transitioncancel'),\n          )\n            .pipe(\n              filter((e) => e.target === el), // skip events from children\n              tap(() => {\n                const count = this._hostActiveAnimationCount$.value - 1;\n                this._hostActiveAnimationCount$.next(count);\n                this._totalActiveAnimationCount$.next(count);\n              }),\n              takeUntil(this._destroy$),\n              takeUntil(this._animatedElement$.pipe(skip(1))),\n            )\n            .subscribe();\n        }),\n        takeUntil(this._destroy$),\n      )\n      .subscribe();\n\n    this._totalActiveAnimationCount$\n      .pipe(\n        tap((count) => {\n          if (count > 0 && !this._didEmitStart) {\n            this._animationStart$.next();\n            this._didEmitStart = true;\n          } else if (count === 0) {\n            this._animationEnd$.next();\n            this._didEmitStart = false;\n          }\n        }),\n        takeUntil(this._destroy$),\n      )\n      .subscribe();\n\n    if (this._parent) {\n      this._parent._hostActiveAnimationCount$\n        .pipe(\n          takeUntil(this._destroy$),\n          tap((count) => {\n            this._totalActiveAnimationCount$.next(count + this._hostActiveAnimationCount$.value);\n          }),\n        )\n        .subscribe();\n    }\n  }\n}\n"]}
@@ -18,6 +18,9 @@ class RouterStateService {
18
18
  get route$() {
19
19
  return this._route$.asObservable().pipe(distinctUntilChanged());
20
20
  }
21
+ get route() {
22
+ return this._route$.getValue();
23
+ }
21
24
  get state$() {
22
25
  return this._state$.asObservable();
23
26
  }
@@ -170,4 +173,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImpor
170
173
  providedIn: 'root',
171
174
  }]
172
175
  }], ctorParameters: function () { return []; } });
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"]}
176
+ //# 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 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(\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"]}
@@ -1,9 +1,10 @@
1
1
  import { __decorate, __metadata } from "tslib";
2
2
  import { BreakpointObserver } from '@angular/cdk/layout';
3
- import { Inject, Injectable, Optional } from '@angular/core';
4
- import { BehaviorSubject, combineLatest, map, shareReplay } from 'rxjs';
3
+ import { Inject, Injectable, Optional, inject } from '@angular/core';
4
+ import { BehaviorSubject, Subject, combineLatest, finalize, map, shareReplay, takeUntil, tap } from 'rxjs';
5
5
  import { DEFAULT_VIEWPORT_CONFIG, VIEWPORT_CONFIG } from '../constants';
6
6
  import { Memo } from '../decorators';
7
+ import { ResizeObserverService } from './resize-observer.service';
7
8
  import * as i0 from "@angular/core";
8
9
  import * as i1 from "@angular/cdk/layout";
9
10
  class ViewportService {
@@ -43,17 +44,34 @@ class ViewportService {
43
44
  get is2Xl() {
44
45
  return this._is2Xl$.value;
45
46
  }
47
+ get viewportSize$() {
48
+ return this._viewportSize$.asObservable();
49
+ }
50
+ get viewportSize() {
51
+ return this._viewportSize$.value;
52
+ }
53
+ get scrollbarSize$() {
54
+ return this._scrollbarSize$.asObservable();
55
+ }
56
+ get scrollbarSize() {
57
+ return this._scrollbarSize$.value;
58
+ }
46
59
  get currentViewport() {
47
60
  return this.getCurrentViewport([this.isXs, this.isSm, this.isMd, this.isLg, this.isXl, this.is2Xl]);
48
61
  }
49
62
  constructor(_viewportConfig, _breakpointObserver) {
50
63
  this._breakpointObserver = _breakpointObserver;
64
+ this._resizeObserverService = inject(ResizeObserverService);
65
+ this._viewportMonitorStop$ = new Subject();
66
+ this._isViewportMonitorEnabled = false;
51
67
  this._isXs$ = new BehaviorSubject(false);
52
68
  this._isSm$ = new BehaviorSubject(false);
53
69
  this._isMd$ = new BehaviorSubject(false);
54
70
  this._isLg$ = new BehaviorSubject(false);
55
71
  this._isXl$ = new BehaviorSubject(false);
56
72
  this._is2Xl$ = new BehaviorSubject(false);
73
+ this._viewportSize$ = new BehaviorSubject(null);
74
+ this._scrollbarSize$ = new BehaviorSubject(null);
57
75
  this.currentViewport$ = combineLatest([this.isXs$, this.isSm$, this.isMd$, this.isLg$, this.isXl$, this.is2Xl$]).pipe(map((val) => this.getCurrentViewport(val)), shareReplay(1));
58
76
  this._viewportConfig = _viewportConfig || DEFAULT_VIEWPORT_CONFIG;
59
77
  this._observeDefaultBreakpoints();
@@ -66,6 +84,57 @@ class ViewportService {
66
84
  const mediaQuery = this._buildMediaQuery(options);
67
85
  return this._breakpointObserver.isMatched(mediaQuery);
68
86
  }
87
+ /**
88
+ * Applies size CSS variables to the documentElement in pixels.
89
+ * - `--et-vw`: viewport width excluding scrollbar width
90
+ * - `--et-vh`: viewport height excluding scrollbar height
91
+ * - `--et-sw`: scrollbar width
92
+ * - `--et-sh`: scrollbar height
93
+ */
94
+ monitorViewport() {
95
+ if (this._isViewportMonitorEnabled)
96
+ return;
97
+ this._isViewportMonitorEnabled = true;
98
+ this._resizeObserverService
99
+ .observe(document.documentElement)
100
+ .pipe(tap((e) => {
101
+ const width = e[0].contentRect.width;
102
+ const height = e[0].contentRect.height;
103
+ document.documentElement.style.setProperty('--et-vw', `${width}px`);
104
+ document.documentElement.style.setProperty('--et-vh', `${height}px`);
105
+ this._viewportSize$.next({ width, height });
106
+ }), finalize(() => {
107
+ document.documentElement.style.removeProperty('--et-vw');
108
+ document.documentElement.style.removeProperty('--et-vh');
109
+ this._viewportSize$.next(null);
110
+ }), takeUntil(this._viewportMonitorStop$))
111
+ .subscribe();
112
+ const scrollbarRuler = document.createElement('div');
113
+ scrollbarRuler.style.width = '100px';
114
+ scrollbarRuler.style.height = '100px';
115
+ scrollbarRuler.style.overflow = 'scroll';
116
+ scrollbarRuler.style.position = 'absolute';
117
+ scrollbarRuler.style.top = '-9999px';
118
+ document.body.appendChild(scrollbarRuler);
119
+ this._resizeObserverService
120
+ .observe(scrollbarRuler)
121
+ .pipe(tap((e) => {
122
+ const size = e[0].contentRect.width;
123
+ document.documentElement.style.setProperty('--et-sw', `${100 - size}px`);
124
+ document.documentElement.style.setProperty('--et-sh', `${100 - size}px`);
125
+ this._scrollbarSize$.next({ width: 100 - size, height: 100 - size });
126
+ }), finalize(() => {
127
+ document.body.removeChild(scrollbarRuler);
128
+ document.documentElement.style.removeProperty('--et-vw');
129
+ document.documentElement.style.removeProperty('--et-vh');
130
+ this._scrollbarSize$.next(null);
131
+ }), takeUntil(this._viewportMonitorStop$))
132
+ .subscribe();
133
+ }
134
+ unmonitorViewport() {
135
+ this._viewportMonitorStop$.next();
136
+ this._isViewportMonitorEnabled = false;
137
+ }
69
138
  _observeDefaultBreakpoints() {
70
139
  this.observe({ max: 'xs' }).subscribe(this._isXs$);
71
140
  this.observe({ min: 'sm', max: 'sm' }).subscribe(this._isSm$);
@@ -166,4 +235,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImpor
166
235
  }, {
167
236
  type: Optional
168
237
  }] }, { type: i1.BreakpointObserver }]; }, propDecorators: { _getViewportSize: [], _buildMediaQuery: [] } });
169
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"viewport.service.js","sourceRoot":"","sources":["../../../../../../libs/core/src/lib/services/viewport.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { BreakpointObserver } from '@angular/cdk/layout';\nimport { Inject, Injectable, Optional } from '@angular/core';\nimport { BehaviorSubject, combineLatest, map, Observable, shareReplay } from 'rxjs';\nimport { DEFAULT_VIEWPORT_CONFIG, VIEWPORT_CONFIG } from '../constants';\nimport { Memo } from '../decorators';\nimport { Breakpoint, ViewportConfig } from '../types';\nimport { BuildMediaQueryOptions } from './viewport.types';\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class ViewportService {\n  private _viewportConfig: ViewportConfig;\n\n  private _isXs$ = new BehaviorSubject(false);\n  private _isSm$ = new BehaviorSubject(false);\n  private _isMd$ = new BehaviorSubject(false);\n  private _isLg$ = new BehaviorSubject(false);\n  private _isXl$ = new BehaviorSubject(false);\n  private _is2Xl$ = new BehaviorSubject(false);\n\n  get isXs$() {\n    return this._isXs$.asObservable();\n  }\n\n  get isXs() {\n    return this._isXs$.value;\n  }\n\n  get isSm$() {\n    return this._isSm$.asObservable();\n  }\n\n  get isSm() {\n    return this._isSm$.value;\n  }\n\n  get isMd$() {\n    return this._isMd$.asObservable();\n  }\n\n  get isMd() {\n    return this._isMd$.value;\n  }\n\n  get isLg$() {\n    return this._isLg$.asObservable();\n  }\n\n  get isLg() {\n    return this._isLg$.value;\n  }\n\n  get isXl$() {\n    return this._isXl$.asObservable();\n  }\n\n  get isXl() {\n    return this._isXl$.value;\n  }\n\n  get is2Xl$() {\n    return this._is2Xl$.asObservable();\n  }\n\n  get is2Xl() {\n    return this._is2Xl$.value;\n  }\n\n  currentViewport$ = combineLatest([this.isXs$, this.isSm$, this.isMd$, this.isLg$, this.isXl$, this.is2Xl$]).pipe(\n    map((val) => this.getCurrentViewport(val)),\n    shareReplay(1),\n  );\n\n  get currentViewport() {\n    return this.getCurrentViewport([this.isXs, this.isSm, this.isMd, this.isLg, this.isXl, this.is2Xl]);\n  }\n\n  constructor(\n    @Inject(VIEWPORT_CONFIG) @Optional() _viewportConfig: ViewportConfig | null,\n    private _breakpointObserver: BreakpointObserver,\n  ) {\n    this._viewportConfig = _viewportConfig || DEFAULT_VIEWPORT_CONFIG;\n    this._observeDefaultBreakpoints();\n  }\n\n  observe(options: { min?: number | Breakpoint; max?: number | Breakpoint }): Observable<boolean> {\n    const mediaQuery = this._buildMediaQuery(options);\n\n    return this._breakpointObserver.observe(mediaQuery).pipe(\n      map((x) => x.matches),\n      shareReplay(1),\n    );\n  }\n\n  isMatched(options: { min?: number | Breakpoint; max?: number | Breakpoint }): boolean {\n    const mediaQuery = this._buildMediaQuery(options);\n\n    return this._breakpointObserver.isMatched(mediaQuery);\n  }\n\n  private _observeDefaultBreakpoints() {\n    this.observe({ max: 'xs' }).subscribe(this._isXs$);\n    this.observe({ min: 'sm', max: 'sm' }).subscribe(this._isSm$);\n    this.observe({ min: 'md', max: 'md' }).subscribe(this._isMd$);\n    this.observe({ min: 'lg', max: 'lg' }).subscribe(this._isLg$);\n    this.observe({ min: 'xl', max: 'xl' }).subscribe(this._isXl$);\n    this.observe({ min: '2xl' }).subscribe(this._is2Xl$);\n  }\n\n  @Memo()\n  private _getViewportSize(type: Breakpoint, option: 'min' | 'max') {\n    const index = option === 'min' ? 0 : 1;\n    const size = this._viewportConfig.breakpoints[type][index];\n\n    if (size === Infinity || size === 0) {\n      return size;\n    }\n\n    if (option === 'min') {\n      return size;\n    }\n\n    // Due to scaling, the actual size of the viewport may be a decimal number.\n    // Eg. on Windows 11 with 150% scaling, the viewport size may be 1535.33px\n    // and thus not matching any of the default breakpoints.\n    return size + 0.9;\n  }\n\n  @Memo({\n    resolver: (v: BuildMediaQueryOptions) => {\n      return `${v.min ?? ''}-${v.max ?? ''}`;\n    },\n  })\n  private _buildMediaQuery(options: BuildMediaQueryOptions) {\n    if (!options.min && !options.max) {\n      throw new Error('At least one of min or max must be defined');\n    }\n\n    const mediaQueryParts: string[] = [];\n\n    if (options.min) {\n      if (typeof options.min === 'number') {\n        mediaQueryParts.push(`(min-width: ${options.min}px)`);\n      } else {\n        mediaQueryParts.push(`(min-width: ${this._getViewportSize(options.min, 'min')}px)`);\n      }\n    }\n\n    if (options.min && options.max) {\n      mediaQueryParts.push('and');\n    }\n\n    if (options.max) {\n      if (typeof options.max === 'number') {\n        mediaQueryParts.push(`(max-width: ${options.max}px)`);\n      } else {\n        mediaQueryParts.push(`(max-width: ${this._getViewportSize(options.max, 'max')}px)`);\n      }\n    }\n\n    return mediaQueryParts.join(' ');\n  }\n\n  private getCurrentViewport([isXs, isSm, isMd, isLg, isXl, is2Xl]: [\n    boolean,\n    boolean,\n    boolean,\n    boolean,\n    boolean,\n    boolean,\n  ]): Breakpoint {\n    if (isXs) {\n      return 'xs';\n    } else if (isSm) {\n      return 'sm';\n    } else if (isMd) {\n      return 'md';\n    } else if (isLg) {\n      return 'lg';\n    } else if (isXl) {\n      return 'xl';\n    } else if (is2Xl) {\n      return '2xl';\n    }\n\n    return 'xs';\n  }\n}\n"]}
238
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"viewport.service.js","sourceRoot":"","sources":["../../../../../../libs/core/src/lib/services/viewport.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { BreakpointObserver } from '@angular/cdk/layout';\nimport { Inject, Injectable, Optional, inject } from '@angular/core';\nimport { BehaviorSubject, Observable, Subject, combineLatest, finalize, map, shareReplay, takeUntil, tap } from 'rxjs';\nimport { DEFAULT_VIEWPORT_CONFIG, VIEWPORT_CONFIG } from '../constants';\nimport { Memo } from '../decorators';\nimport { Breakpoint, ViewportConfig } from '../types';\nimport { ResizeObserverService } from './resize-observer.service';\nimport { BuildMediaQueryOptions } from './viewport.types';\n\ninterface Size {\n  width: number;\n  height: number;\n}\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class ViewportService {\n  private readonly _resizeObserverService = inject(ResizeObserverService);\n\n  private readonly _viewportMonitorStop$ = new Subject<void>();\n  private _isViewportMonitorEnabled = false;\n\n  private _viewportConfig: ViewportConfig;\n\n  private _isXs$ = new BehaviorSubject(false);\n  private _isSm$ = new BehaviorSubject(false);\n  private _isMd$ = new BehaviorSubject(false);\n  private _isLg$ = new BehaviorSubject(false);\n  private _isXl$ = new BehaviorSubject(false);\n  private _is2Xl$ = new BehaviorSubject(false);\n\n  private _viewportSize$ = new BehaviorSubject<Size | null>(null);\n  private _scrollbarSize$ = new BehaviorSubject<Size | null>(null);\n\n  get isXs$() {\n    return this._isXs$.asObservable();\n  }\n\n  get isXs() {\n    return this._isXs$.value;\n  }\n\n  get isSm$() {\n    return this._isSm$.asObservable();\n  }\n\n  get isSm() {\n    return this._isSm$.value;\n  }\n\n  get isMd$() {\n    return this._isMd$.asObservable();\n  }\n\n  get isMd() {\n    return this._isMd$.value;\n  }\n\n  get isLg$() {\n    return this._isLg$.asObservable();\n  }\n\n  get isLg() {\n    return this._isLg$.value;\n  }\n\n  get isXl$() {\n    return this._isXl$.asObservable();\n  }\n\n  get isXl() {\n    return this._isXl$.value;\n  }\n\n  get is2Xl$() {\n    return this._is2Xl$.asObservable();\n  }\n\n  get is2Xl() {\n    return this._is2Xl$.value;\n  }\n\n  get viewportSize$() {\n    return this._viewportSize$.asObservable();\n  }\n\n  get viewportSize() {\n    return this._viewportSize$.value;\n  }\n\n  get scrollbarSize$() {\n    return this._scrollbarSize$.asObservable();\n  }\n\n  get scrollbarSize() {\n    return this._scrollbarSize$.value;\n  }\n\n  currentViewport$ = combineLatest([this.isXs$, this.isSm$, this.isMd$, this.isLg$, this.isXl$, this.is2Xl$]).pipe(\n    map((val) => this.getCurrentViewport(val)),\n    shareReplay(1),\n  );\n\n  get currentViewport() {\n    return this.getCurrentViewport([this.isXs, this.isSm, this.isMd, this.isLg, this.isXl, this.is2Xl]);\n  }\n\n  constructor(\n    @Inject(VIEWPORT_CONFIG) @Optional() _viewportConfig: ViewportConfig | null,\n    private _breakpointObserver: BreakpointObserver,\n  ) {\n    this._viewportConfig = _viewportConfig || DEFAULT_VIEWPORT_CONFIG;\n    this._observeDefaultBreakpoints();\n  }\n\n  observe(options: { min?: number | Breakpoint; max?: number | Breakpoint }): Observable<boolean> {\n    const mediaQuery = this._buildMediaQuery(options);\n\n    return this._breakpointObserver.observe(mediaQuery).pipe(\n      map((x) => x.matches),\n      shareReplay(1),\n    );\n  }\n\n  isMatched(options: { min?: number | Breakpoint; max?: number | Breakpoint }): boolean {\n    const mediaQuery = this._buildMediaQuery(options);\n\n    return this._breakpointObserver.isMatched(mediaQuery);\n  }\n\n  /**\n   * Applies size CSS variables to the documentElement in pixels.\n   * - `--et-vw`: viewport width excluding scrollbar width\n   * - `--et-vh`: viewport height excluding scrollbar height\n   * - `--et-sw`: scrollbar width\n   * - `--et-sh`: scrollbar height\n   */\n  monitorViewport() {\n    if (this._isViewportMonitorEnabled) return;\n\n    this._isViewportMonitorEnabled = true;\n\n    this._resizeObserverService\n      .observe(document.documentElement)\n      .pipe(\n        tap((e) => {\n          const width = e[0].contentRect.width;\n          const height = e[0].contentRect.height;\n          document.documentElement.style.setProperty('--et-vw', `${width}px`);\n          document.documentElement.style.setProperty('--et-vh', `${height}px`);\n\n          this._viewportSize$.next({ width, height });\n        }),\n        finalize(() => {\n          document.documentElement.style.removeProperty('--et-vw');\n          document.documentElement.style.removeProperty('--et-vh');\n\n          this._viewportSize$.next(null);\n        }),\n        takeUntil(this._viewportMonitorStop$),\n      )\n      .subscribe();\n\n    const scrollbarRuler = document.createElement('div');\n    scrollbarRuler.style.width = '100px';\n    scrollbarRuler.style.height = '100px';\n    scrollbarRuler.style.overflow = 'scroll';\n    scrollbarRuler.style.position = 'absolute';\n    scrollbarRuler.style.top = '-9999px';\n    document.body.appendChild(scrollbarRuler);\n\n    this._resizeObserverService\n      .observe(scrollbarRuler)\n      .pipe(\n        tap((e) => {\n          const size = e[0].contentRect.width;\n          document.documentElement.style.setProperty('--et-sw', `${100 - size}px`);\n          document.documentElement.style.setProperty('--et-sh', `${100 - size}px`);\n\n          this._scrollbarSize$.next({ width: 100 - size, height: 100 - size });\n        }),\n        finalize(() => {\n          document.body.removeChild(scrollbarRuler);\n          document.documentElement.style.removeProperty('--et-vw');\n          document.documentElement.style.removeProperty('--et-vh');\n\n          this._scrollbarSize$.next(null);\n        }),\n        takeUntil(this._viewportMonitorStop$),\n      )\n      .subscribe();\n  }\n\n  unmonitorViewport() {\n    this._viewportMonitorStop$.next();\n    this._isViewportMonitorEnabled = false;\n  }\n\n  private _observeDefaultBreakpoints() {\n    this.observe({ max: 'xs' }).subscribe(this._isXs$);\n    this.observe({ min: 'sm', max: 'sm' }).subscribe(this._isSm$);\n    this.observe({ min: 'md', max: 'md' }).subscribe(this._isMd$);\n    this.observe({ min: 'lg', max: 'lg' }).subscribe(this._isLg$);\n    this.observe({ min: 'xl', max: 'xl' }).subscribe(this._isXl$);\n    this.observe({ min: '2xl' }).subscribe(this._is2Xl$);\n  }\n\n  @Memo()\n  private _getViewportSize(type: Breakpoint, option: 'min' | 'max') {\n    const index = option === 'min' ? 0 : 1;\n    const size = this._viewportConfig.breakpoints[type][index];\n\n    if (size === Infinity || size === 0) {\n      return size;\n    }\n\n    if (option === 'min') {\n      return size;\n    }\n\n    // Due to scaling, the actual size of the viewport may be a decimal number.\n    // Eg. on Windows 11 with 150% scaling, the viewport size may be 1535.33px\n    // and thus not matching any of the default breakpoints.\n    return size + 0.9;\n  }\n\n  @Memo({\n    resolver: (v: BuildMediaQueryOptions) => {\n      return `${v.min ?? ''}-${v.max ?? ''}`;\n    },\n  })\n  private _buildMediaQuery(options: BuildMediaQueryOptions) {\n    if (!options.min && !options.max) {\n      throw new Error('At least one of min or max must be defined');\n    }\n\n    const mediaQueryParts: string[] = [];\n\n    if (options.min) {\n      if (typeof options.min === 'number') {\n        mediaQueryParts.push(`(min-width: ${options.min}px)`);\n      } else {\n        mediaQueryParts.push(`(min-width: ${this._getViewportSize(options.min, 'min')}px)`);\n      }\n    }\n\n    if (options.min && options.max) {\n      mediaQueryParts.push('and');\n    }\n\n    if (options.max) {\n      if (typeof options.max === 'number') {\n        mediaQueryParts.push(`(max-width: ${options.max}px)`);\n      } else {\n        mediaQueryParts.push(`(max-width: ${this._getViewportSize(options.max, 'max')}px)`);\n      }\n    }\n\n    return mediaQueryParts.join(' ');\n  }\n\n  private getCurrentViewport([isXs, isSm, isMd, isLg, isXl, is2Xl]: [\n    boolean,\n    boolean,\n    boolean,\n    boolean,\n    boolean,\n    boolean,\n  ]): Breakpoint {\n    if (isXs) {\n      return 'xs';\n    } else if (isSm) {\n      return 'sm';\n    } else if (isMd) {\n      return 'md';\n    } else if (isLg) {\n      return 'lg';\n    } else if (isXl) {\n      return 'xl';\n    } else if (is2Xl) {\n      return '2xl';\n    }\n\n    return 'xs';\n  }\n}\n"]}
@@ -1,7 +1,7 @@
1
1
  import * as i0 from '@angular/core';
2
2
  import { inject, Component, ChangeDetectionStrategy, ViewEncapsulation, Input, HostBinding, InjectionToken, assertInInjectionContext, DestroyRef, ElementRef, isDevMode, Directive, Injectable, Inject, Optional, NgZone, EventEmitter, Output, Injector, ViewContainerRef, Pipe, QueryList } from '@angular/core';
3
3
  import { DomSanitizer, Meta, Title } from '@angular/platform-browser';
4
- import { Observable, combineLatest, Subject, startWith, map, takeUntil, distinctUntilChanged, BehaviorSubject, shareReplay, skip, take, tap, debounceTime, merge, fromEvent, filter, switchMap, pairwise } from 'rxjs';
4
+ import { Observable, combineLatest, Subject, startWith, map, takeUntil, distinctUntilChanged, BehaviorSubject, shareReplay, skip, take, tap, debounceTime, merge, fromEvent, filter, switchMap, pairwise, finalize } from 'rxjs';
5
5
  import { coerceCssPixelValue, coerceElement, coerceBooleanProperty, coerceNumberProperty } from '@angular/cdk/coercion';
6
6
  import { supportsScrollBehavior } from '@angular/cdk/platform';
7
7
  import { Overlay } from '@angular/cdk/overlay';
@@ -1103,7 +1103,7 @@ class AnimatableDirective {
1103
1103
  }
1104
1104
  set animatedElement(value) {
1105
1105
  let newElement = null;
1106
- if (value === null || value === undefined) {
1106
+ if (value === null || value === undefined || value === '') {
1107
1107
  newElement = this._elementRef.nativeElement;
1108
1108
  }
1109
1109
  else if (typeof value === 'string') {
@@ -1561,6 +1561,9 @@ class RouterStateService {
1561
1561
  get route$() {
1562
1562
  return this._route$.asObservable().pipe(distinctUntilChanged());
1563
1563
  }
1564
+ get route() {
1565
+ return this._route$.getValue();
1566
+ }
1564
1567
  get state$() {
1565
1568
  return this._state$.asObservable();
1566
1569
  }
@@ -1750,17 +1753,34 @@ class ViewportService {
1750
1753
  get is2Xl() {
1751
1754
  return this._is2Xl$.value;
1752
1755
  }
1756
+ get viewportSize$() {
1757
+ return this._viewportSize$.asObservable();
1758
+ }
1759
+ get viewportSize() {
1760
+ return this._viewportSize$.value;
1761
+ }
1762
+ get scrollbarSize$() {
1763
+ return this._scrollbarSize$.asObservable();
1764
+ }
1765
+ get scrollbarSize() {
1766
+ return this._scrollbarSize$.value;
1767
+ }
1753
1768
  get currentViewport() {
1754
1769
  return this.getCurrentViewport([this.isXs, this.isSm, this.isMd, this.isLg, this.isXl, this.is2Xl]);
1755
1770
  }
1756
1771
  constructor(_viewportConfig, _breakpointObserver) {
1757
1772
  this._breakpointObserver = _breakpointObserver;
1773
+ this._resizeObserverService = inject(ResizeObserverService);
1774
+ this._viewportMonitorStop$ = new Subject();
1775
+ this._isViewportMonitorEnabled = false;
1758
1776
  this._isXs$ = new BehaviorSubject(false);
1759
1777
  this._isSm$ = new BehaviorSubject(false);
1760
1778
  this._isMd$ = new BehaviorSubject(false);
1761
1779
  this._isLg$ = new BehaviorSubject(false);
1762
1780
  this._isXl$ = new BehaviorSubject(false);
1763
1781
  this._is2Xl$ = new BehaviorSubject(false);
1782
+ this._viewportSize$ = new BehaviorSubject(null);
1783
+ this._scrollbarSize$ = new BehaviorSubject(null);
1764
1784
  this.currentViewport$ = combineLatest([this.isXs$, this.isSm$, this.isMd$, this.isLg$, this.isXl$, this.is2Xl$]).pipe(map((val) => this.getCurrentViewport(val)), shareReplay(1));
1765
1785
  this._viewportConfig = _viewportConfig || DEFAULT_VIEWPORT_CONFIG;
1766
1786
  this._observeDefaultBreakpoints();
@@ -1773,6 +1793,57 @@ class ViewportService {
1773
1793
  const mediaQuery = this._buildMediaQuery(options);
1774
1794
  return this._breakpointObserver.isMatched(mediaQuery);
1775
1795
  }
1796
+ /**
1797
+ * Applies size CSS variables to the documentElement in pixels.
1798
+ * - `--et-vw`: viewport width excluding scrollbar width
1799
+ * - `--et-vh`: viewport height excluding scrollbar height
1800
+ * - `--et-sw`: scrollbar width
1801
+ * - `--et-sh`: scrollbar height
1802
+ */
1803
+ monitorViewport() {
1804
+ if (this._isViewportMonitorEnabled)
1805
+ return;
1806
+ this._isViewportMonitorEnabled = true;
1807
+ this._resizeObserverService
1808
+ .observe(document.documentElement)
1809
+ .pipe(tap((e) => {
1810
+ const width = e[0].contentRect.width;
1811
+ const height = e[0].contentRect.height;
1812
+ document.documentElement.style.setProperty('--et-vw', `${width}px`);
1813
+ document.documentElement.style.setProperty('--et-vh', `${height}px`);
1814
+ this._viewportSize$.next({ width, height });
1815
+ }), finalize(() => {
1816
+ document.documentElement.style.removeProperty('--et-vw');
1817
+ document.documentElement.style.removeProperty('--et-vh');
1818
+ this._viewportSize$.next(null);
1819
+ }), takeUntil(this._viewportMonitorStop$))
1820
+ .subscribe();
1821
+ const scrollbarRuler = document.createElement('div');
1822
+ scrollbarRuler.style.width = '100px';
1823
+ scrollbarRuler.style.height = '100px';
1824
+ scrollbarRuler.style.overflow = 'scroll';
1825
+ scrollbarRuler.style.position = 'absolute';
1826
+ scrollbarRuler.style.top = '-9999px';
1827
+ document.body.appendChild(scrollbarRuler);
1828
+ this._resizeObserverService
1829
+ .observe(scrollbarRuler)
1830
+ .pipe(tap((e) => {
1831
+ const size = e[0].contentRect.width;
1832
+ document.documentElement.style.setProperty('--et-sw', `${100 - size}px`);
1833
+ document.documentElement.style.setProperty('--et-sh', `${100 - size}px`);
1834
+ this._scrollbarSize$.next({ width: 100 - size, height: 100 - size });
1835
+ }), finalize(() => {
1836
+ document.body.removeChild(scrollbarRuler);
1837
+ document.documentElement.style.removeProperty('--et-vw');
1838
+ document.documentElement.style.removeProperty('--et-vh');
1839
+ this._scrollbarSize$.next(null);
1840
+ }), takeUntil(this._viewportMonitorStop$))
1841
+ .subscribe();
1842
+ }
1843
+ unmonitorViewport() {
1844
+ this._viewportMonitorStop$.next();
1845
+ this._isViewportMonitorEnabled = false;
1846
+ }
1776
1847
  _observeDefaultBreakpoints() {
1777
1848
  this.observe({ max: 'xs' }).subscribe(this._isXs$);
1778
1849
  this.observe({ min: 'sm', max: 'sm' }).subscribe(this._isSm$);