@ethlete/core 1.1.1 → 1.3.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.
@@ -1,4 +1,4 @@
1
- import { Observable } from 'rxjs';
1
+ import { combineLatest, Observable, Subject } from 'rxjs';
2
2
  export const nextFrame = (cb) => {
3
3
  requestAnimationFrame(() => {
4
4
  requestAnimationFrame(cb);
@@ -15,4 +15,95 @@ export const fromNextFrame = () => {
15
15
  export const forceReflow = (element = document.body) => {
16
16
  return element.offsetHeight;
17
17
  };
18
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5pbWF0aW9uLnV0aWxzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb3JlL3NyYy9saWIvdXRpbHMvYW5pbWF0aW9uLnV0aWxzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFFbEMsTUFBTSxDQUFDLE1BQU0sU0FBUyxHQUFHLENBQUMsRUFBYyxFQUFFLEVBQUU7SUFDMUMscUJBQXFCLENBQUMsR0FBRyxFQUFFO1FBQ3pCLHFCQUFxQixDQUFDLEVBQUUsQ0FBQyxDQUFDO0lBQzVCLENBQUMsQ0FBQyxDQUFDO0FBQ0wsQ0FBQyxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sYUFBYSxHQUFHLEdBQUcsRUFBRTtJQUNoQyxPQUFPLElBQUksVUFBVSxDQUFPLENBQUMsUUFBUSxFQUFFLEVBQUU7UUFDdkMsU0FBUyxDQUFDLEdBQUcsRUFBRTtZQUNiLFFBQVEsQ0FBQyxJQUFJLEVBQUUsQ0FBQztZQUNoQixRQUFRLENBQUMsUUFBUSxFQUFFLENBQUM7UUFDdEIsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDLENBQUMsQ0FBQztBQUNMLENBQUMsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLFdBQVcsR0FBRyxDQUFDLFVBQXVCLFFBQVEsQ0FBQyxJQUFJLEVBQUUsRUFBRTtJQUNsRSxPQUFPLE9BQU8sQ0FBQyxZQUFZLENBQUM7QUFDOUIsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgT2JzZXJ2YWJsZSB9IGZyb20gJ3J4anMnO1xuXG5leHBvcnQgY29uc3QgbmV4dEZyYW1lID0gKGNiOiAoKSA9PiB2b2lkKSA9PiB7XG4gIHJlcXVlc3RBbmltYXRpb25GcmFtZSgoKSA9PiB7XG4gICAgcmVxdWVzdEFuaW1hdGlvbkZyYW1lKGNiKTtcbiAgfSk7XG59O1xuXG5leHBvcnQgY29uc3QgZnJvbU5leHRGcmFtZSA9ICgpID0+IHtcbiAgcmV0dXJuIG5ldyBPYnNlcnZhYmxlPHZvaWQ+KChvYnNlcnZlcikgPT4ge1xuICAgIG5leHRGcmFtZSgoKSA9PiB7XG4gICAgICBvYnNlcnZlci5uZXh0KCk7XG4gICAgICBvYnNlcnZlci5jb21wbGV0ZSgpO1xuICAgIH0pO1xuICB9KTtcbn07XG5cbmV4cG9ydCBjb25zdCBmb3JjZVJlZmxvdyA9IChlbGVtZW50OiBIVE1MRWxlbWVudCA9IGRvY3VtZW50LmJvZHkpID0+IHtcbiAgcmV0dXJuIGVsZW1lbnQub2Zmc2V0SGVpZ2h0O1xufTtcbiJdfQ==
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
+ };
42
+ export const createFlipAnimation = (config) => {
43
+ const { element: el, duration = 250, easing = 'cubic-bezier(0.4, 0, 0.2, 1)' } = config;
44
+ let initialRect = el.getBoundingClientRect();
45
+ let animation = null;
46
+ const onStart$ = new Subject();
47
+ const onFinish$ = new Subject();
48
+ const onCancel$ = new Subject();
49
+ const onAnimationFinish = () => {
50
+ cleanup();
51
+ onFinish$.next();
52
+ };
53
+ const onAnimationCancel = () => {
54
+ cleanup();
55
+ onCancel$.next();
56
+ };
57
+ const cleanup = () => {
58
+ if (!animation) {
59
+ return;
60
+ }
61
+ animation.removeEventListener('finish', onAnimationFinish);
62
+ animation.removeEventListener('cancel', onAnimationCancel);
63
+ };
64
+ const updateInit = () => {
65
+ initialRect = el.getBoundingClientRect();
66
+ };
67
+ const play = () => {
68
+ const lastRect = el.getBoundingClientRect();
69
+ const delta = {
70
+ x: initialRect.left - lastRect.left,
71
+ y: initialRect.top - lastRect.top,
72
+ scaleX: initialRect.width / lastRect.width,
73
+ scaleY: initialRect.height / lastRect.height,
74
+ };
75
+ animation = el.animate([
76
+ {
77
+ transformOrigin: 'top left',
78
+ transform: `
79
+ translate(${delta.x}px, ${delta.y}px)
80
+ scale(${delta.scaleX}, ${delta.scaleY})
81
+ `,
82
+ },
83
+ {
84
+ transformOrigin: 'top left',
85
+ transform: 'none',
86
+ },
87
+ ], {
88
+ duration,
89
+ easing,
90
+ fill: 'both',
91
+ });
92
+ animation.addEventListener('finish', onAnimationFinish);
93
+ animation.addEventListener('cancel', onAnimationCancel);
94
+ onStart$.next();
95
+ };
96
+ const cancel = () => {
97
+ animation?.cancel();
98
+ cleanup();
99
+ };
100
+ return {
101
+ updateInit,
102
+ play,
103
+ cancel,
104
+ onStart$: onStart$.asObservable(),
105
+ onFinish$: onFinish$.asObservable(),
106
+ onCancel$: onCancel$.asObservable(),
107
+ };
108
+ };
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"]}
@@ -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, combineLatest, pairwise, debounceTime, shareReplay, tap, merge, skip, switchMap, take } from 'rxjs';
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,97 @@ 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
+ };
391
+ const createFlipAnimation = (config) => {
392
+ const { element: el, duration = 250, easing = 'cubic-bezier(0.4, 0, 0.2, 1)' } = config;
393
+ let initialRect = el.getBoundingClientRect();
394
+ let animation = null;
395
+ const onStart$ = new Subject();
396
+ const onFinish$ = new Subject();
397
+ const onCancel$ = new Subject();
398
+ const onAnimationFinish = () => {
399
+ cleanup();
400
+ onFinish$.next();
401
+ };
402
+ const onAnimationCancel = () => {
403
+ cleanup();
404
+ onCancel$.next();
405
+ };
406
+ const cleanup = () => {
407
+ if (!animation) {
408
+ return;
409
+ }
410
+ animation.removeEventListener('finish', onAnimationFinish);
411
+ animation.removeEventListener('cancel', onAnimationCancel);
412
+ };
413
+ const updateInit = () => {
414
+ initialRect = el.getBoundingClientRect();
415
+ };
416
+ const play = () => {
417
+ const lastRect = el.getBoundingClientRect();
418
+ const delta = {
419
+ x: initialRect.left - lastRect.left,
420
+ y: initialRect.top - lastRect.top,
421
+ scaleX: initialRect.width / lastRect.width,
422
+ scaleY: initialRect.height / lastRect.height,
423
+ };
424
+ animation = el.animate([
425
+ {
426
+ transformOrigin: 'top left',
427
+ transform: `
428
+ translate(${delta.x}px, ${delta.y}px)
429
+ scale(${delta.scaleX}, ${delta.scaleY})
430
+ `,
431
+ },
432
+ {
433
+ transformOrigin: 'top left',
434
+ transform: 'none',
435
+ },
436
+ ], {
437
+ duration,
438
+ easing,
439
+ fill: 'both',
440
+ });
441
+ animation.addEventListener('finish', onAnimationFinish);
442
+ animation.addEventListener('cancel', onAnimationCancel);
443
+ onStart$.next();
444
+ };
445
+ const cancel = () => {
446
+ animation === null || animation === void 0 ? void 0 : animation.cancel();
447
+ cleanup();
448
+ };
449
+ return {
450
+ updateInit,
451
+ play,
452
+ cancel,
453
+ onStart$: onStart$.asObservable(),
454
+ onFinish$: onFinish$.asObservable(),
455
+ onCancel$: onCancel$.asObservable(),
456
+ };
457
+ };
367
458
 
368
459
  const clamp = (value, min = 0, max = 100) => {
369
460
  return Math.max(min, Math.min(max, value));
@@ -2456,5 +2547,5 @@ const Validators = {
2456
2547
  * Generated bundle index. Do not edit.
2457
2548
  */
2458
2549
 
2459
- 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, 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 };
2550
+ 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, 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 };
2460
2551
  //# sourceMappingURL=ethlete-core.mjs.map