@ethlete/core 1.2.0 → 1.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.
- package/esm2020/lib/utils/animation.utils.mjs +26 -2
- package/esm2020/lib/utils/public-api.mjs +2 -1
- package/esm2020/lib/utils/rxjs.utils.mjs +27 -0
- package/fesm2015/ethlete-core.mjs +49 -2
- package/fesm2015/ethlete-core.mjs.map +1 -1
- package/fesm2020/ethlete-core.mjs +52 -2
- package/fesm2020/ethlete-core.mjs.map +1 -1
- package/lib/utils/animation.utils.d.ts +12 -0
- package/lib/utils/public-api.d.ts +1 -0
- package/lib/utils/rxjs.utils.d.ts +9 -0
- package/package.json +1 -1
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Observable, Subject } from 'rxjs';
|
|
1
|
+
import { combineLatest, Observable, Subject } from 'rxjs';
|
|
2
2
|
export const nextFrame = (cb) => {
|
|
3
3
|
requestAnimationFrame(() => {
|
|
4
4
|
requestAnimationFrame(cb);
|
|
@@ -15,6 +15,30 @@ export const fromNextFrame = () => {
|
|
|
15
15
|
export const forceReflow = (element = document.body) => {
|
|
16
16
|
return element.offsetHeight;
|
|
17
17
|
};
|
|
18
|
+
export const createFlipAnimationGroup = (config) => {
|
|
19
|
+
const { elements, duration = 250, easing = 'cubic-bezier(0.4, 0, 0.2, 1)' } = config;
|
|
20
|
+
const flips = elements.map((el) => createFlipAnimation({ element: el, duration, easing }));
|
|
21
|
+
const onStart$ = combineLatest(flips.map((animation) => animation.onStart$));
|
|
22
|
+
const onFinish$ = combineLatest(flips.map((animation) => animation.onFinish$));
|
|
23
|
+
const onCancel$ = combineLatest(flips.map((animation) => animation.onCancel$));
|
|
24
|
+
const updateInit = () => {
|
|
25
|
+
flips.forEach((animation) => animation.updateInit());
|
|
26
|
+
};
|
|
27
|
+
const play = () => {
|
|
28
|
+
flips.forEach((animation) => animation.play());
|
|
29
|
+
};
|
|
30
|
+
const cancel = () => {
|
|
31
|
+
flips.forEach((animation) => animation.cancel());
|
|
32
|
+
};
|
|
33
|
+
return {
|
|
34
|
+
updateInit,
|
|
35
|
+
play,
|
|
36
|
+
cancel,
|
|
37
|
+
onStart$,
|
|
38
|
+
onFinish$,
|
|
39
|
+
onCancel$,
|
|
40
|
+
};
|
|
41
|
+
};
|
|
18
42
|
export const createFlipAnimation = (config) => {
|
|
19
43
|
const { element: el, duration = 250, easing = 'cubic-bezier(0.4, 0, 0.2, 1)' } = config;
|
|
20
44
|
let initialRect = el.getBoundingClientRect();
|
|
@@ -82,4 +106,4 @@ export const createFlipAnimation = (config) => {
|
|
|
82
106
|
onCancel$: onCancel$.asObservable(),
|
|
83
107
|
};
|
|
84
108
|
};
|
|
85
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
109
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"animation.utils.js","sourceRoot":"","sources":["../../../../../../libs/core/src/lib/utils/animation.utils.ts"],"names":[],"mappings":"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","sourcesContent":["import { combineLatest, Observable, Subject } from 'rxjs';\n\nexport const nextFrame = (cb: () => void) => {\n  requestAnimationFrame(() => {\n    requestAnimationFrame(cb);\n  });\n};\n\nexport const fromNextFrame = () => {\n  return new Observable<void>((observer) => {\n    nextFrame(() => {\n      observer.next();\n      observer.complete();\n    });\n  });\n};\n\nexport const forceReflow = (element: HTMLElement = document.body) => {\n  return element.offsetHeight;\n};\n\nexport const createFlipAnimationGroup = (config: { elements: HTMLElement[]; duration?: number; easing?: string }) => {\n  const { elements, duration = 250, easing = 'cubic-bezier(0.4, 0, 0.2, 1)' } = config;\n\n  const flips = elements.map((el) => createFlipAnimation({ element: el, duration, easing }));\n\n  const onStart$ = combineLatest(flips.map((animation) => animation.onStart$));\n  const onFinish$ = combineLatest(flips.map((animation) => animation.onFinish$));\n  const onCancel$ = combineLatest(flips.map((animation) => animation.onCancel$));\n\n  const updateInit = () => {\n    flips.forEach((animation) => animation.updateInit());\n  };\n\n  const play = () => {\n    flips.forEach((animation) => animation.play());\n  };\n\n  const cancel = () => {\n    flips.forEach((animation) => animation.cancel());\n  };\n\n  return {\n    updateInit,\n    play,\n    cancel,\n    onStart$,\n    onFinish$,\n    onCancel$,\n  };\n};\n\nexport const createFlipAnimation = (config: { element: HTMLElement; duration?: number; easing?: string }) => {\n  const { element: el, duration = 250, easing = 'cubic-bezier(0.4, 0, 0.2, 1)' } = config;\n\n  let initialRect = el.getBoundingClientRect();\n  let animation: Animation | null = null;\n\n  const onStart$ = new Subject<void>();\n  const onFinish$ = new Subject<void>();\n  const onCancel$ = new Subject<void>();\n\n  const onAnimationFinish = () => {\n    cleanup();\n    onFinish$.next();\n  };\n\n  const onAnimationCancel = () => {\n    cleanup();\n    onCancel$.next();\n  };\n\n  const cleanup = () => {\n    if (!animation) {\n      return;\n    }\n\n    animation.removeEventListener('finish', onAnimationFinish);\n    animation.removeEventListener('cancel', onAnimationCancel);\n  };\n\n  const updateInit = () => {\n    initialRect = el.getBoundingClientRect();\n  };\n\n  const play = () => {\n    const lastRect = el.getBoundingClientRect();\n\n    const delta = {\n      x: initialRect.left - lastRect.left,\n      y: initialRect.top - lastRect.top,\n      scaleX: initialRect.width / lastRect.width,\n      scaleY: initialRect.height / lastRect.height,\n    };\n\n    animation = el.animate(\n      [\n        {\n          transformOrigin: 'top left',\n          transform: `\n          translate(${delta.x}px, ${delta.y}px)\n          scale(${delta.scaleX}, ${delta.scaleY})\n        `,\n        },\n        {\n          transformOrigin: 'top left',\n          transform: 'none',\n        },\n      ],\n      {\n        duration,\n        easing,\n        fill: 'both',\n      },\n    );\n\n    animation.addEventListener('finish', onAnimationFinish);\n    animation.addEventListener('cancel', onAnimationCancel);\n\n    onStart$.next();\n  };\n\n  const cancel = () => {\n    animation?.cancel();\n\n    cleanup();\n  };\n\n  return {\n    updateInit,\n    play,\n    cancel,\n    onStart$: onStart$.asObservable(),\n    onFinish$: onFinish$.asObservable(),\n    onCancel$: onCancel$.asObservable(),\n  };\n};\n"]}
|
|
@@ -5,6 +5,7 @@ export * from './cookie.util';
|
|
|
5
5
|
export * from './equal.util';
|
|
6
6
|
export * from './media-query-observable.util';
|
|
7
7
|
export * from './reactive-binding.util';
|
|
8
|
+
export * from './rxjs.utils';
|
|
8
9
|
export * from './scrollable.utils';
|
|
9
10
|
export * from './viewport.util';
|
|
10
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
11
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29yZS9zcmMvbGliL3V0aWxzL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLGVBQWUsQ0FBQztBQUM5QixjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLCtCQUErQixDQUFDO0FBQzlDLGNBQWMseUJBQXlCLENBQUM7QUFDeEMsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLGlCQUFpQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9hbmltYXRpb24udXRpbHMnO1xuZXhwb3J0ICogZnJvbSAnLi9jbGFtcC51dGlsJztcbmV4cG9ydCAqIGZyb20gJy4vY2xvbmUudXRpbCc7XG5leHBvcnQgKiBmcm9tICcuL2Nvb2tpZS51dGlsJztcbmV4cG9ydCAqIGZyb20gJy4vZXF1YWwudXRpbCc7XG5leHBvcnQgKiBmcm9tICcuL21lZGlhLXF1ZXJ5LW9ic2VydmFibGUudXRpbCc7XG5leHBvcnQgKiBmcm9tICcuL3JlYWN0aXZlLWJpbmRpbmcudXRpbCc7XG5leHBvcnQgKiBmcm9tICcuL3J4anMudXRpbHMnO1xuZXhwb3J0ICogZnJvbSAnLi9zY3JvbGxhYmxlLnV0aWxzJztcbmV4cG9ydCAqIGZyb20gJy4vdmlld3BvcnQudXRpbCc7XG4iXX0=
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
/* eslint-disable @typescript-eslint/no-explicit-any */
|
|
2
|
+
import { BehaviorSubject } from 'rxjs';
|
|
3
|
+
export class BehaviorSubjectWithSubscriberCount extends BehaviorSubject {
|
|
4
|
+
constructor() {
|
|
5
|
+
super(...arguments);
|
|
6
|
+
this._subscriberCount = 0;
|
|
7
|
+
}
|
|
8
|
+
get subscriberCount() {
|
|
9
|
+
return this._subscriberCount;
|
|
10
|
+
}
|
|
11
|
+
subscribe(observerOrNext) {
|
|
12
|
+
this._subscriberCount++;
|
|
13
|
+
const sub = super.subscribe(observerOrNext);
|
|
14
|
+
return {
|
|
15
|
+
...sub,
|
|
16
|
+
unsubscribe: () => {
|
|
17
|
+
sub.unsubscribe();
|
|
18
|
+
this._subscriberCount--;
|
|
19
|
+
},
|
|
20
|
+
};
|
|
21
|
+
}
|
|
22
|
+
unsubscribe() {
|
|
23
|
+
this._subscriberCount--;
|
|
24
|
+
return super.unsubscribe();
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicnhqcy51dGlscy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29yZS9zcmMvbGliL3V0aWxzL3J4anMudXRpbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsdURBQXVEO0FBQ3ZELE9BQU8sRUFBRSxlQUFlLEVBQTBCLE1BQU0sTUFBTSxDQUFDO0FBRS9ELE1BQU0sT0FBTyxrQ0FBc0MsU0FBUSxlQUFrQjtJQUE3RTs7UUFDVSxxQkFBZ0IsR0FBRyxDQUFDLENBQUM7SUFvQy9CLENBQUM7SUFsQ0MsSUFBSSxlQUFlO1FBQ2pCLE9BQU8sSUFBSSxDQUFDLGdCQUFnQixDQUFDO0lBQy9CLENBQUM7SUFhUSxTQUFTLENBQUMsY0FBbUI7UUFDcEMsSUFBSSxDQUFDLGdCQUFnQixFQUFFLENBQUM7UUFFeEIsTUFBTSxHQUFHLEdBQUcsS0FBSyxDQUFDLFNBQVMsQ0FBQyxjQUFjLENBQUMsQ0FBQztRQUU1QyxPQUFPO1lBQ0wsR0FBRyxHQUFHO1lBQ04sV0FBVyxFQUFFLEdBQUcsRUFBRTtnQkFDaEIsR0FBRyxDQUFDLFdBQVcsRUFBRSxDQUFDO2dCQUNsQixJQUFJLENBQUMsZ0JBQWdCLEVBQUUsQ0FBQztZQUMxQixDQUFDO1NBQ0YsQ0FBQztJQUNKLENBQUM7SUFFUSxXQUFXO1FBQ2xCLElBQUksQ0FBQyxnQkFBZ0IsRUFBRSxDQUFDO1FBRXhCLE9BQU8sS0FBSyxDQUFDLFdBQVcsRUFBRSxDQUFDO0lBQzdCLENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIEB0eXBlc2NyaXB0LWVzbGludC9uby1leHBsaWNpdC1hbnkgKi9cbmltcG9ydCB7IEJlaGF2aW9yU3ViamVjdCwgT2JzZXJ2ZXIsIFN1YnNjcmlwdGlvbiB9IGZyb20gJ3J4anMnO1xuXG5leHBvcnQgY2xhc3MgQmVoYXZpb3JTdWJqZWN0V2l0aFN1YnNjcmliZXJDb3VudDxUPiBleHRlbmRzIEJlaGF2aW9yU3ViamVjdDxUPiB7XG4gIHByaXZhdGUgX3N1YnNjcmliZXJDb3VudCA9IDA7XG5cbiAgZ2V0IHN1YnNjcmliZXJDb3VudCgpIHtcbiAgICByZXR1cm4gdGhpcy5fc3Vic2NyaWJlckNvdW50O1xuICB9XG5cbiAgb3ZlcnJpZGUgc3Vic2NyaWJlKFxuICAgIG9ic2VydmVyT3JOZXh0PzogUGFydGlhbDxPYnNlcnZlcjxUPj4gfCAoKHZhbHVlOiBUKSA9PiB2b2lkKSB8IG51bGwsXG4gICAgZXJyb3I/OiAoKGVycm9yOiBhbnkpID0+IHZvaWQpIHwgbnVsbCxcbiAgICBjb21wbGV0ZT86ICgoKSA9PiB2b2lkKSB8IG51bGwsXG4gICk6IFN1YnNjcmlwdGlvbjtcbiAgb3ZlcnJpZGUgc3Vic2NyaWJlKFxuICAgIG5leHQ/OiAoKHZhbHVlOiBUKSA9PiB2b2lkKSB8IG51bGwsXG4gICAgZXJyb3I/OiAoKGVycm9yOiBhbnkpID0+IHZvaWQpIHwgbnVsbCxcbiAgICBjb21wbGV0ZT86ICgoKSA9PiB2b2lkKSB8IG51bGwsXG4gICk6IFN1YnNjcmlwdGlvbjtcbiAgb3ZlcnJpZGUgc3Vic2NyaWJlKG9ic2VydmVyT3JOZXh0PzogUGFydGlhbDxPYnNlcnZlcjxUPj4gfCAoKHZhbHVlOiBUKSA9PiB2b2lkKSB8IHVuZGVmaW5lZCk6IFN1YnNjcmlwdGlvbjtcbiAgb3ZlcnJpZGUgc3Vic2NyaWJlKG9ic2VydmVyT3JOZXh0OiBhbnkpIHtcbiAgICB0aGlzLl9zdWJzY3JpYmVyQ291bnQrKztcblxuICAgIGNvbnN0IHN1YiA9IHN1cGVyLnN1YnNjcmliZShvYnNlcnZlck9yTmV4dCk7XG5cbiAgICByZXR1cm4ge1xuICAgICAgLi4uc3ViLFxuICAgICAgdW5zdWJzY3JpYmU6ICgpID0+IHtcbiAgICAgICAgc3ViLnVuc3Vic2NyaWJlKCk7XG4gICAgICAgIHRoaXMuX3N1YnNjcmliZXJDb3VudC0tO1xuICAgICAgfSxcbiAgICB9O1xuICB9XG5cbiAgb3ZlcnJpZGUgdW5zdWJzY3JpYmUoKSB7XG4gICAgdGhpcy5fc3Vic2NyaWJlckNvdW50LS07XG5cbiAgICByZXR1cm4gc3VwZXIudW5zdWJzY3JpYmUoKTtcbiAgfVxufVxuIl19
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import * as i0 from '@angular/core';
|
|
2
2
|
import { inject, Component, ChangeDetectionStrategy, ViewEncapsulation, Input, HostBinding, InjectionToken, Injectable, ElementRef, Inject, Optional, isDevMode, Directive, EventEmitter, Output, NgZone, Pipe, QueryList } from '@angular/core';
|
|
3
3
|
import { DomSanitizer, Meta, Title } from '@angular/platform-browser';
|
|
4
|
-
import { fromEvent, Observable, Subject, startWith, map, takeUntil, distinctUntilChanged, BehaviorSubject, filter,
|
|
4
|
+
import { fromEvent, Observable, Subject, combineLatest, startWith, map, takeUntil, distinctUntilChanged, BehaviorSubject, filter, pairwise, debounceTime, shareReplay, tap, merge, skip, switchMap, take } from 'rxjs';
|
|
5
5
|
import { coerceElement, coerceBooleanProperty, coerceNumberProperty } from '@angular/cdk/coercion';
|
|
6
6
|
import { DOCUMENT } from '@angular/common';
|
|
7
7
|
import { Router, NavigationEnd } from '@angular/router';
|
|
@@ -364,6 +364,30 @@ const fromNextFrame = () => {
|
|
|
364
364
|
const forceReflow = (element = document.body) => {
|
|
365
365
|
return element.offsetHeight;
|
|
366
366
|
};
|
|
367
|
+
const createFlipAnimationGroup = (config) => {
|
|
368
|
+
const { elements, duration = 250, easing = 'cubic-bezier(0.4, 0, 0.2, 1)' } = config;
|
|
369
|
+
const flips = elements.map((el) => createFlipAnimation({ element: el, duration, easing }));
|
|
370
|
+
const onStart$ = combineLatest(flips.map((animation) => animation.onStart$));
|
|
371
|
+
const onFinish$ = combineLatest(flips.map((animation) => animation.onFinish$));
|
|
372
|
+
const onCancel$ = combineLatest(flips.map((animation) => animation.onCancel$));
|
|
373
|
+
const updateInit = () => {
|
|
374
|
+
flips.forEach((animation) => animation.updateInit());
|
|
375
|
+
};
|
|
376
|
+
const play = () => {
|
|
377
|
+
flips.forEach((animation) => animation.play());
|
|
378
|
+
};
|
|
379
|
+
const cancel = () => {
|
|
380
|
+
flips.forEach((animation) => animation.cancel());
|
|
381
|
+
};
|
|
382
|
+
return {
|
|
383
|
+
updateInit,
|
|
384
|
+
play,
|
|
385
|
+
cancel,
|
|
386
|
+
onStart$,
|
|
387
|
+
onFinish$,
|
|
388
|
+
onCancel$,
|
|
389
|
+
};
|
|
390
|
+
};
|
|
367
391
|
const createFlipAnimation = (config) => {
|
|
368
392
|
const { element: el, duration = 250, easing = 'cubic-bezier(0.4, 0, 0.2, 1)' } = config;
|
|
369
393
|
let initialRect = el.getBoundingClientRect();
|
|
@@ -806,6 +830,29 @@ const createReactiveBindings = (...values) => {
|
|
|
806
830
|
};
|
|
807
831
|
};
|
|
808
832
|
|
|
833
|
+
/* eslint-disable @typescript-eslint/no-explicit-any */
|
|
834
|
+
class BehaviorSubjectWithSubscriberCount extends BehaviorSubject {
|
|
835
|
+
constructor() {
|
|
836
|
+
super(...arguments);
|
|
837
|
+
this._subscriberCount = 0;
|
|
838
|
+
}
|
|
839
|
+
get subscriberCount() {
|
|
840
|
+
return this._subscriberCount;
|
|
841
|
+
}
|
|
842
|
+
subscribe(observerOrNext) {
|
|
843
|
+
this._subscriberCount++;
|
|
844
|
+
const sub = super.subscribe(observerOrNext);
|
|
845
|
+
return Object.assign(Object.assign({}, sub), { unsubscribe: () => {
|
|
846
|
+
sub.unsubscribe();
|
|
847
|
+
this._subscriberCount--;
|
|
848
|
+
} });
|
|
849
|
+
}
|
|
850
|
+
unsubscribe() {
|
|
851
|
+
this._subscriberCount--;
|
|
852
|
+
return super.unsubscribe();
|
|
853
|
+
}
|
|
854
|
+
}
|
|
855
|
+
|
|
809
856
|
const elementCanScroll = (element) => {
|
|
810
857
|
const { scrollHeight, clientHeight, scrollWidth, clientWidth } = element;
|
|
811
858
|
return scrollHeight > clientHeight || scrollWidth > clientWidth;
|
|
@@ -2523,5 +2570,5 @@ const Validators = {
|
|
|
2523
2570
|
* Generated bundle index. Do not edit.
|
|
2524
2571
|
*/
|
|
2525
2572
|
|
|
2526
|
-
export { ANIMATABLE_TOKEN, ANIMATED_LIFECYCLE_TOKEN, AnimatableDirective, AnimatedLifecycleDirective, ClickObserverFactory, ClickObserverService, ClickOutsideDirective, ContentObserverService, CursorDragScrollDirective, DEFAULT_VIEWPORT_CONFIG, DestroyService, FocusVisibleService, IS_ARRAY_NOT_EMPTY, IS_EMAIL, IsArrayNotEmpty, IsEmail, LetContext, LetDirective, MUST_MATCH, Memo, MustMatch, MutationObserverFactory, NormalizeGameResultTypePipe, NormalizeMatchParticipantsPipe, NormalizeMatchScorePipe, NormalizeMatchStatePipe, NormalizeMatchTypePipe, OBSERVE_SCROLL_STATE, ObserveContentDirective, ObserveResizeDirective, ObserveScrollStateDirective, RepeatDirective, ResizeObserverFactory, ResizeObserverService, RouterStateService, SCROLL_OBSERVER_FIRST_ELEMENT_CLASS, SCROLL_OBSERVER_IGNORE_TARGET_CLASS, SCROLL_OBSERVER_LAST_ELEMENT_CLASS, SEO_DIRECTIVE_TOKEN, ScrollObserverFirstElementDirective, ScrollObserverIgnoreTargetDirective, ScrollObserverLastElementDirective, SeoDirective, StructuredDataComponent, ToArrayPipe, TypedQueryList, VIEWPORT_CONFIG, Validators, ViewportService, clamp, clone, createFlipAnimation, createMediaQueryObservable, createReactiveBindings, deleteCookie, elementCanScroll, equal, forceReflow, fromNextFrame, getCookie, getDomain, getGroupMatchPoints, getGroupMatchScore, getKnockoutMatchScore, getMatchScoreSubLine, hasCookie, isGroupMatch, isKnockoutMatch, mergeSeoConfig, nextFrame, normalizeGameResultType, normalizeMatchParticipant, normalizeMatchParticipants, normalizeMatchScore, normalizeMatchState, normalizeMatchType, provideViewportConfig, routerDisableScrollTop, setCookie, toArray, toArrayTrackByFn };
|
|
2573
|
+
export { ANIMATABLE_TOKEN, ANIMATED_LIFECYCLE_TOKEN, AnimatableDirective, AnimatedLifecycleDirective, BehaviorSubjectWithSubscriberCount, ClickObserverFactory, ClickObserverService, ClickOutsideDirective, ContentObserverService, CursorDragScrollDirective, DEFAULT_VIEWPORT_CONFIG, DestroyService, FocusVisibleService, IS_ARRAY_NOT_EMPTY, IS_EMAIL, IsArrayNotEmpty, IsEmail, LetContext, LetDirective, MUST_MATCH, Memo, MustMatch, MutationObserverFactory, NormalizeGameResultTypePipe, NormalizeMatchParticipantsPipe, NormalizeMatchScorePipe, NormalizeMatchStatePipe, NormalizeMatchTypePipe, OBSERVE_SCROLL_STATE, ObserveContentDirective, ObserveResizeDirective, ObserveScrollStateDirective, RepeatDirective, ResizeObserverFactory, ResizeObserverService, RouterStateService, SCROLL_OBSERVER_FIRST_ELEMENT_CLASS, SCROLL_OBSERVER_IGNORE_TARGET_CLASS, SCROLL_OBSERVER_LAST_ELEMENT_CLASS, SEO_DIRECTIVE_TOKEN, ScrollObserverFirstElementDirective, ScrollObserverIgnoreTargetDirective, ScrollObserverLastElementDirective, SeoDirective, StructuredDataComponent, ToArrayPipe, TypedQueryList, VIEWPORT_CONFIG, Validators, ViewportService, clamp, clone, createFlipAnimation, createFlipAnimationGroup, createMediaQueryObservable, createReactiveBindings, deleteCookie, elementCanScroll, equal, forceReflow, fromNextFrame, getCookie, getDomain, getGroupMatchPoints, getGroupMatchScore, getKnockoutMatchScore, getMatchScoreSubLine, hasCookie, isGroupMatch, isKnockoutMatch, mergeSeoConfig, nextFrame, normalizeGameResultType, normalizeMatchParticipant, normalizeMatchParticipants, normalizeMatchScore, normalizeMatchState, normalizeMatchType, provideViewportConfig, routerDisableScrollTop, setCookie, toArray, toArrayTrackByFn };
|
|
2527
2574
|
//# sourceMappingURL=ethlete-core.mjs.map
|