@ethlete/core 0.2.0-next.23 → 0.2.0-next.25
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/directives/animatable/animatable.directive.mjs +79 -0
- package/esm2020/lib/directives/animatable/public-api.mjs +2 -0
- package/esm2020/lib/directives/animated-lifecycle/animated-lifecycle.directive.mjs +113 -0
- package/esm2020/lib/directives/animated-lifecycle/public-api.mjs +2 -0
- package/esm2020/lib/directives/public-api.mjs +3 -1
- package/esm2020/lib/public-api.mjs +2 -1
- package/esm2020/lib/utils/animation.utils.mjs +9 -0
- package/esm2020/lib/utils/public-api.mjs +2 -1
- package/esm2020/lib/validators/is-array-not-empty.validator.mjs +9 -0
- package/esm2020/lib/validators/is-email.validator.mjs +10 -0
- package/esm2020/lib/validators/must-match.validator.mjs +19 -0
- package/esm2020/lib/validators/public-api.mjs +12 -0
- package/fesm2015/ethlete-core.mjs +237 -3
- package/fesm2015/ethlete-core.mjs.map +1 -1
- package/fesm2020/ethlete-core.mjs +237 -3
- package/fesm2020/ethlete-core.mjs.map +1 -1
- package/lib/directives/animatable/animatable.directive.d.ts +20 -0
- package/lib/directives/animatable/public-api.d.ts +1 -0
- package/lib/directives/animated-lifecycle/animated-lifecycle.directive.d.ts +22 -0
- package/lib/directives/animated-lifecycle/public-api.d.ts +1 -0
- package/lib/directives/public-api.d.ts +2 -0
- package/lib/public-api.d.ts +1 -0
- package/lib/utils/animation.utils.d.ts +2 -0
- package/lib/utils/public-api.d.ts +1 -0
- package/lib/validators/is-array-not-empty.validator.d.ts +3 -0
- package/lib/validators/is-email.validator.d.ts +3 -0
- package/lib/validators/must-match.validator.d.ts +3 -0
- package/lib/validators/public-api.d.ts +8 -0
- package/package.json +3 -2
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
import { Directive, ElementRef, inject, InjectionToken } from '@angular/core';
|
|
2
|
+
import { BehaviorSubject, debounceTime, fromEvent, map, merge, Subject, takeUntil, tap } from 'rxjs';
|
|
3
|
+
import { DestroyService } from '../../services';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export const ANIMATABLE_TOKEN = new InjectionToken('ANIMATABLE_DIRECTIVE_TOKEN');
|
|
6
|
+
export class AnimatableDirective {
|
|
7
|
+
constructor() {
|
|
8
|
+
this._didEmitStart = false;
|
|
9
|
+
this._parent = inject(ANIMATABLE_TOKEN, { optional: true, skipSelf: true });
|
|
10
|
+
this._destroy$ = inject(DestroyService, { host: true }).destroy$;
|
|
11
|
+
this._elementRef = inject(ElementRef);
|
|
12
|
+
this._animationStart$ = new Subject();
|
|
13
|
+
this._animationEnd$ = new Subject();
|
|
14
|
+
this.animationStart$ = this._animationStart$.asObservable().pipe(debounceTime(0));
|
|
15
|
+
this.animationEnd$ = this._animationEnd$.asObservable().pipe(debounceTime(0));
|
|
16
|
+
this._hostActiveAnimationCount$ = new BehaviorSubject(0);
|
|
17
|
+
this._totalActiveAnimationCount$ = new BehaviorSubject(0);
|
|
18
|
+
this.isAnimating$ = this._totalActiveAnimationCount$.pipe(map((count) => count > 0), debounceTime(0));
|
|
19
|
+
}
|
|
20
|
+
ngOnInit() {
|
|
21
|
+
merge(fromEvent(this._elementRef.nativeElement, 'animationstart'), fromEvent(this._elementRef.nativeElement, 'transitionstart'))
|
|
22
|
+
.pipe(tap(() => {
|
|
23
|
+
const count = this._hostActiveAnimationCount$.value + 1;
|
|
24
|
+
this._hostActiveAnimationCount$.next(count);
|
|
25
|
+
this._totalActiveAnimationCount$.next(count);
|
|
26
|
+
}), takeUntil(this._destroy$))
|
|
27
|
+
.subscribe();
|
|
28
|
+
merge(fromEvent(this._elementRef.nativeElement, 'animationend'), fromEvent(this._elementRef.nativeElement, 'animationcancel'), fromEvent(this._elementRef.nativeElement, 'transitionend'), fromEvent(this._elementRef.nativeElement, 'transitioncancel'))
|
|
29
|
+
.pipe(tap(() => {
|
|
30
|
+
const count = this._hostActiveAnimationCount$.value - 1;
|
|
31
|
+
this._hostActiveAnimationCount$.next(count);
|
|
32
|
+
this._totalActiveAnimationCount$.next(count);
|
|
33
|
+
}), takeUntil(this._destroy$))
|
|
34
|
+
.subscribe();
|
|
35
|
+
this._totalActiveAnimationCount$
|
|
36
|
+
.pipe(tap((count) => {
|
|
37
|
+
if (count > 0 && !this._didEmitStart) {
|
|
38
|
+
this._animationStart$.next();
|
|
39
|
+
this._didEmitStart = true;
|
|
40
|
+
}
|
|
41
|
+
else if (count === 0) {
|
|
42
|
+
this._animationEnd$.next();
|
|
43
|
+
this._didEmitStart = false;
|
|
44
|
+
}
|
|
45
|
+
}), takeUntil(this._destroy$))
|
|
46
|
+
.subscribe();
|
|
47
|
+
if (this._parent) {
|
|
48
|
+
this._parent._hostActiveAnimationCount$
|
|
49
|
+
.pipe(takeUntil(this._destroy$), tap((count) => {
|
|
50
|
+
this._totalActiveAnimationCount$.next(count + this._hostActiveAnimationCount$.value);
|
|
51
|
+
}))
|
|
52
|
+
.subscribe();
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
AnimatableDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.4", ngImport: i0, type: AnimatableDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
|
57
|
+
AnimatableDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.1.4", type: AnimatableDirective, isStandalone: true, selector: "[etAnimatable]", providers: [
|
|
58
|
+
{
|
|
59
|
+
provide: ANIMATABLE_TOKEN,
|
|
60
|
+
useExisting: AnimatableDirective,
|
|
61
|
+
},
|
|
62
|
+
DestroyService,
|
|
63
|
+
], exportAs: ["etAnimatable"], ngImport: i0 });
|
|
64
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.4", ngImport: i0, type: AnimatableDirective, decorators: [{
|
|
65
|
+
type: Directive,
|
|
66
|
+
args: [{
|
|
67
|
+
selector: '[etAnimatable]',
|
|
68
|
+
exportAs: 'etAnimatable',
|
|
69
|
+
standalone: true,
|
|
70
|
+
providers: [
|
|
71
|
+
{
|
|
72
|
+
provide: ANIMATABLE_TOKEN,
|
|
73
|
+
useExisting: AnimatableDirective,
|
|
74
|
+
},
|
|
75
|
+
DestroyService,
|
|
76
|
+
],
|
|
77
|
+
}]
|
|
78
|
+
}] });
|
|
79
|
+
//# 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, OnInit } from '@angular/core';\nimport { BehaviorSubject, debounceTime, fromEvent, map, merge, Observable, Subject, takeUntil, tap } from 'rxjs';\nimport { DestroyService } from '../../services';\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    DestroyService,\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$ = inject(DestroyService, { host: true }).destroy$;\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  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    merge(\n      fromEvent(this._elementRef.nativeElement, 'animationstart'),\n      fromEvent(this._elementRef.nativeElement, 'transitionstart'),\n    )\n      .pipe(\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      )\n      .subscribe();\n\n    merge(\n      fromEvent(this._elementRef.nativeElement, 'animationend'),\n      fromEvent(this._elementRef.nativeElement, 'animationcancel'),\n      fromEvent(this._elementRef.nativeElement, 'transitionend'),\n      fromEvent(this._elementRef.nativeElement, 'transitioncancel'),\n    )\n      .pipe(\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      )\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"]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export * from './animatable.directive';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29yZS9zcmMvbGliL2RpcmVjdGl2ZXMvYW5pbWF0YWJsZS9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsd0JBQXdCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2FuaW1hdGFibGUuZGlyZWN0aXZlJztcbiJdfQ==
|
|
@@ -0,0 +1,113 @@
|
|
|
1
|
+
import { Directive, ElementRef, HostBinding, inject, InjectionToken } from '@angular/core';
|
|
2
|
+
import { BehaviorSubject, take, takeUntil, tap } from 'rxjs';
|
|
3
|
+
import { DestroyService } from '../../services';
|
|
4
|
+
import { forceReflow, nextFrame } from '../../utils';
|
|
5
|
+
import { AnimatableDirective, ANIMATABLE_TOKEN } from '../public-api';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
import * as i1 from "../animatable/animatable.directive";
|
|
8
|
+
export const ANIMATED_LIFECYCLE_TOKEN = new InjectionToken('ANIMATED_LIFECYCLE_DIRECTIVE_TOKEN');
|
|
9
|
+
const ANIMATION_CLASSES = {
|
|
10
|
+
enterFrom: 'et-animation-enter-from',
|
|
11
|
+
enterActive: 'et-animation-enter-active',
|
|
12
|
+
enterTo: 'et-animation-enter-to',
|
|
13
|
+
leaveFrom: 'et-animation-leave-from',
|
|
14
|
+
leaveActive: 'et-animation-leave-active',
|
|
15
|
+
leaveTo: 'et-animation-leave-to',
|
|
16
|
+
};
|
|
17
|
+
export class AnimatedLifecycleDirective {
|
|
18
|
+
constructor() {
|
|
19
|
+
this._destroy$ = inject(DestroyService, { host: true }).destroy$;
|
|
20
|
+
this._elementRef = inject(ElementRef);
|
|
21
|
+
this._animatable = inject(ANIMATABLE_TOKEN);
|
|
22
|
+
this._classList = this._elementRef.nativeElement.classList;
|
|
23
|
+
this._state$ = new BehaviorSubject('init');
|
|
24
|
+
this.state$ = this._state$.asObservable();
|
|
25
|
+
}
|
|
26
|
+
get state() {
|
|
27
|
+
return this._state$.value;
|
|
28
|
+
}
|
|
29
|
+
get _opacity() {
|
|
30
|
+
return this._state$.value === 'init' ? '0 !important' : '';
|
|
31
|
+
}
|
|
32
|
+
enter(config) {
|
|
33
|
+
this._state$.next('entering');
|
|
34
|
+
if (!config?.onlyTransition) {
|
|
35
|
+
this._classList.add(ANIMATION_CLASSES.enterFrom);
|
|
36
|
+
}
|
|
37
|
+
forceReflow();
|
|
38
|
+
this._classList.add(ANIMATION_CLASSES.enterActive);
|
|
39
|
+
nextFrame(() => {
|
|
40
|
+
if (!config?.onlyTransition) {
|
|
41
|
+
this._classList.remove(ANIMATION_CLASSES.enterFrom);
|
|
42
|
+
this._classList.add(ANIMATION_CLASSES.enterTo);
|
|
43
|
+
}
|
|
44
|
+
this._animatable.animationEnd$
|
|
45
|
+
.pipe(takeUntil(this._destroy$), take(1), tap(() => {
|
|
46
|
+
this._state$.next('entered');
|
|
47
|
+
this._classList.remove(ANIMATION_CLASSES.enterActive);
|
|
48
|
+
if (!config?.onlyTransition) {
|
|
49
|
+
this._classList.remove(ANIMATION_CLASSES.enterTo);
|
|
50
|
+
}
|
|
51
|
+
}))
|
|
52
|
+
.subscribe();
|
|
53
|
+
});
|
|
54
|
+
}
|
|
55
|
+
leave(config) {
|
|
56
|
+
if (this._classList.contains(ANIMATION_CLASSES.enterFrom) ||
|
|
57
|
+
this._classList.contains(ANIMATION_CLASSES.enterActive) ||
|
|
58
|
+
this._classList.contains(ANIMATION_CLASSES.enterTo)) {
|
|
59
|
+
this._classList.remove(ANIMATION_CLASSES.enterFrom);
|
|
60
|
+
this._classList.remove(ANIMATION_CLASSES.enterActive);
|
|
61
|
+
this._classList.remove(ANIMATION_CLASSES.enterTo);
|
|
62
|
+
}
|
|
63
|
+
this._state$.next('leaving');
|
|
64
|
+
if (!config?.onlyTransition) {
|
|
65
|
+
this._classList.add(ANIMATION_CLASSES.leaveFrom);
|
|
66
|
+
}
|
|
67
|
+
forceReflow();
|
|
68
|
+
this._classList.add(ANIMATION_CLASSES.leaveActive);
|
|
69
|
+
nextFrame(() => {
|
|
70
|
+
if (!config?.onlyTransition) {
|
|
71
|
+
this._classList.remove(ANIMATION_CLASSES.leaveFrom);
|
|
72
|
+
this._classList.add(ANIMATION_CLASSES.leaveTo);
|
|
73
|
+
}
|
|
74
|
+
this._animatable.animationEnd$
|
|
75
|
+
.pipe(takeUntil(this._destroy$), take(1), tap(() => {
|
|
76
|
+
this._state$.next('left');
|
|
77
|
+
this._classList.remove(ANIMATION_CLASSES.leaveActive);
|
|
78
|
+
if (!config?.onlyTransition) {
|
|
79
|
+
this._classList.remove(ANIMATION_CLASSES.leaveTo);
|
|
80
|
+
}
|
|
81
|
+
}))
|
|
82
|
+
.subscribe();
|
|
83
|
+
});
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
AnimatedLifecycleDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.4", ngImport: i0, type: AnimatedLifecycleDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
|
87
|
+
AnimatedLifecycleDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.1.4", type: AnimatedLifecycleDirective, isStandalone: true, selector: "[etAnimatedLifecycle]", host: { properties: { "style.opacity": "this._opacity" } }, providers: [
|
|
88
|
+
{
|
|
89
|
+
provide: ANIMATED_LIFECYCLE_TOKEN,
|
|
90
|
+
useExisting: AnimatedLifecycleDirective,
|
|
91
|
+
},
|
|
92
|
+
DestroyService,
|
|
93
|
+
], exportAs: ["etAnimatedLifecycle"], hostDirectives: [{ directive: i1.AnimatableDirective }], ngImport: i0 });
|
|
94
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.4", ngImport: i0, type: AnimatedLifecycleDirective, decorators: [{
|
|
95
|
+
type: Directive,
|
|
96
|
+
args: [{
|
|
97
|
+
selector: '[etAnimatedLifecycle]',
|
|
98
|
+
exportAs: 'etAnimatedLifecycle',
|
|
99
|
+
standalone: true,
|
|
100
|
+
providers: [
|
|
101
|
+
{
|
|
102
|
+
provide: ANIMATED_LIFECYCLE_TOKEN,
|
|
103
|
+
useExisting: AnimatedLifecycleDirective,
|
|
104
|
+
},
|
|
105
|
+
DestroyService,
|
|
106
|
+
],
|
|
107
|
+
hostDirectives: [AnimatableDirective],
|
|
108
|
+
}]
|
|
109
|
+
}], propDecorators: { _opacity: [{
|
|
110
|
+
type: HostBinding,
|
|
111
|
+
args: ['style.opacity']
|
|
112
|
+
}] } });
|
|
113
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"animated-lifecycle.directive.js","sourceRoot":"","sources":["../../../../../../../libs/core/src/lib/directives/animated-lifecycle/animated-lifecycle.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, HostBinding, inject, InjectionToken } from '@angular/core';\nimport { BehaviorSubject, take, takeUntil, tap } from 'rxjs';\nimport { DestroyService } from '../../services';\nimport { forceReflow, nextFrame } from '../../utils';\nimport { AnimatableDirective, ANIMATABLE_TOKEN } from '../public-api';\n\nexport const ANIMATED_LIFECYCLE_TOKEN = new InjectionToken<AnimatedLifecycleDirective>(\n  'ANIMATED_LIFECYCLE_DIRECTIVE_TOKEN',\n);\n\nconst ANIMATION_CLASSES = {\n  enterFrom: 'et-animation-enter-from',\n  enterActive: 'et-animation-enter-active',\n  enterTo: 'et-animation-enter-to',\n  leaveFrom: 'et-animation-leave-from',\n  leaveActive: 'et-animation-leave-active',\n  leaveTo: 'et-animation-leave-to',\n} as const;\n\n@Directive({\n  selector: '[etAnimatedLifecycle]',\n  exportAs: 'etAnimatedLifecycle',\n  standalone: true,\n  providers: [\n    {\n      provide: ANIMATED_LIFECYCLE_TOKEN,\n      useExisting: AnimatedLifecycleDirective,\n    },\n    DestroyService,\n  ],\n  hostDirectives: [AnimatableDirective],\n})\nexport class AnimatedLifecycleDirective {\n  private readonly _destroy$ = inject(DestroyService, { host: true }).destroy$;\n  private readonly _elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n  private readonly _animatable = inject(ANIMATABLE_TOKEN);\n  private readonly _classList = this._elementRef.nativeElement.classList;\n\n  private _state$ = new BehaviorSubject<'entering' | 'entered' | 'leaving' | 'left' | 'init'>('init');\n  readonly state$ = this._state$.asObservable();\n\n  get state() {\n    return this._state$.value;\n  }\n\n  @HostBinding('style.opacity')\n  private get _opacity() {\n    return this._state$.value === 'init' ? '0 !important' : '';\n  }\n\n  enter(config?: { onlyTransition?: boolean }) {\n    this._state$.next('entering');\n\n    if (!config?.onlyTransition) {\n      this._classList.add(ANIMATION_CLASSES.enterFrom);\n    }\n\n    forceReflow();\n    this._classList.add(ANIMATION_CLASSES.enterActive);\n\n    nextFrame(() => {\n      if (!config?.onlyTransition) {\n        this._classList.remove(ANIMATION_CLASSES.enterFrom);\n        this._classList.add(ANIMATION_CLASSES.enterTo);\n      }\n\n      this._animatable.animationEnd$\n        .pipe(\n          takeUntil(this._destroy$),\n          take(1),\n          tap(() => {\n            this._state$.next('entered');\n            this._classList.remove(ANIMATION_CLASSES.enterActive);\n\n            if (!config?.onlyTransition) {\n              this._classList.remove(ANIMATION_CLASSES.enterTo);\n            }\n          }),\n        )\n        .subscribe();\n    });\n  }\n\n  leave(config?: { onlyTransition?: boolean }) {\n    if (\n      this._classList.contains(ANIMATION_CLASSES.enterFrom) ||\n      this._classList.contains(ANIMATION_CLASSES.enterActive) ||\n      this._classList.contains(ANIMATION_CLASSES.enterTo)\n    ) {\n      this._classList.remove(ANIMATION_CLASSES.enterFrom);\n      this._classList.remove(ANIMATION_CLASSES.enterActive);\n      this._classList.remove(ANIMATION_CLASSES.enterTo);\n    }\n\n    this._state$.next('leaving');\n\n    if (!config?.onlyTransition) {\n      this._classList.add(ANIMATION_CLASSES.leaveFrom);\n    }\n\n    forceReflow();\n    this._classList.add(ANIMATION_CLASSES.leaveActive);\n\n    nextFrame(() => {\n      if (!config?.onlyTransition) {\n        this._classList.remove(ANIMATION_CLASSES.leaveFrom);\n        this._classList.add(ANIMATION_CLASSES.leaveTo);\n      }\n\n      this._animatable.animationEnd$\n        .pipe(\n          takeUntil(this._destroy$),\n          take(1),\n          tap(() => {\n            this._state$.next('left');\n            this._classList.remove(ANIMATION_CLASSES.leaveActive);\n\n            if (!config?.onlyTransition) {\n              this._classList.remove(ANIMATION_CLASSES.leaveTo);\n            }\n          }),\n        )\n        .subscribe();\n    });\n  }\n}\n"]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export * from './animated-lifecycle.directive';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29yZS9zcmMvbGliL2RpcmVjdGl2ZXMvYW5pbWF0ZWQtbGlmZWN5Y2xlL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxnQ0FBZ0MsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vYW5pbWF0ZWQtbGlmZWN5Y2xlLmRpcmVjdGl2ZSc7XG4iXX0=
|
|
@@ -1,3 +1,5 @@
|
|
|
1
|
+
export * from './animatable/public-api';
|
|
2
|
+
export * from './animated-lifecycle/public-api';
|
|
1
3
|
export * from './click-outside/public-api';
|
|
2
4
|
export * from './cursor-drag-scroll/public-api';
|
|
3
5
|
export * from './let/public-api';
|
|
@@ -9,4 +11,4 @@ export * from './scroll-observer-first-element/public-api';
|
|
|
9
11
|
export * from './scroll-observer-ignore-target/public-api';
|
|
10
12
|
export * from './scroll-observer-last-element/public-api';
|
|
11
13
|
export * from './seo/public-api';
|
|
12
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
14
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29yZS9zcmMvbGliL2RpcmVjdGl2ZXMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYyw0QkFBNEIsQ0FBQztBQUMzQyxjQUFjLGlDQUFpQyxDQUFDO0FBQ2hELGNBQWMsa0JBQWtCLENBQUM7QUFDakMsY0FBYyw4QkFBOEIsQ0FBQztBQUM3QyxjQUFjLDZCQUE2QixDQUFDO0FBQzVDLGNBQWMsbUNBQW1DLENBQUM7QUFDbEQsY0FBYyxxQkFBcUIsQ0FBQztBQUNwQyxjQUFjLDRDQUE0QyxDQUFDO0FBQzNELGNBQWMsNENBQTRDLENBQUM7QUFDM0QsY0FBYywyQ0FBMkMsQ0FBQztBQUMxRCxjQUFjLGtCQUFrQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9hbmltYXRhYmxlL3B1YmxpYy1hcGknO1xuZXhwb3J0ICogZnJvbSAnLi9hbmltYXRlZC1saWZlY3ljbGUvcHVibGljLWFwaSc7XG5leHBvcnQgKiBmcm9tICcuL2NsaWNrLW91dHNpZGUvcHVibGljLWFwaSc7XG5leHBvcnQgKiBmcm9tICcuL2N1cnNvci1kcmFnLXNjcm9sbC9wdWJsaWMtYXBpJztcbmV4cG9ydCAqIGZyb20gJy4vbGV0L3B1YmxpYy1hcGknO1xuZXhwb3J0ICogZnJvbSAnLi9vYnNlcnZlLWNvbnRlbnQvcHVibGljLWFwaSc7XG5leHBvcnQgKiBmcm9tICcuL29ic2VydmUtcmVzaXplL3B1YmxpYy1hcGknO1xuZXhwb3J0ICogZnJvbSAnLi9vYnNlcnZlLXNjcm9sbC1zdGF0ZS9wdWJsaWMtYXBpJztcbmV4cG9ydCAqIGZyb20gJy4vcmVwZWF0L3B1YmxpYy1hcGknO1xuZXhwb3J0ICogZnJvbSAnLi9zY3JvbGwtb2JzZXJ2ZXItZmlyc3QtZWxlbWVudC9wdWJsaWMtYXBpJztcbmV4cG9ydCAqIGZyb20gJy4vc2Nyb2xsLW9ic2VydmVyLWlnbm9yZS10YXJnZXQvcHVibGljLWFwaSc7XG5leHBvcnQgKiBmcm9tICcuL3Njcm9sbC1vYnNlcnZlci1sYXN0LWVsZW1lbnQvcHVibGljLWFwaSc7XG5leHBvcnQgKiBmcm9tICcuL3Nlby9wdWJsaWMtYXBpJztcbiJdfQ==
|
|
@@ -6,4 +6,5 @@ export * from './pipes/public-api';
|
|
|
6
6
|
export * from './services/public-api';
|
|
7
7
|
export * from './types/public-api';
|
|
8
8
|
export * from './utils/public-api';
|
|
9
|
-
|
|
9
|
+
export * from './validators/public-api';
|
|
10
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYnMvY29yZS9zcmMvbGliL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLHdCQUF3QixDQUFDO0FBQ3ZDLGNBQWMseUJBQXlCLENBQUM7QUFDeEMsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLG9CQUFvQixDQUFDO0FBQ25DLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLG9CQUFvQixDQUFDO0FBQ25DLGNBQWMseUJBQXlCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2NvbXBvbmVudHMvcHVibGljLWFwaSc7XG5leHBvcnQgKiBmcm9tICcuL2NvbnN0YW50cy9wdWJsaWMtYXBpJztcbmV4cG9ydCAqIGZyb20gJy4vZGVjb3JhdG9ycy9wdWJsaWMtYXBpJztcbmV4cG9ydCAqIGZyb20gJy4vZGlyZWN0aXZlcy9wdWJsaWMtYXBpJztcbmV4cG9ydCAqIGZyb20gJy4vcGlwZXMvcHVibGljLWFwaSc7XG5leHBvcnQgKiBmcm9tICcuL3NlcnZpY2VzL3B1YmxpYy1hcGknO1xuZXhwb3J0ICogZnJvbSAnLi90eXBlcy9wdWJsaWMtYXBpJztcbmV4cG9ydCAqIGZyb20gJy4vdXRpbHMvcHVibGljLWFwaSc7XG5leHBvcnQgKiBmcm9tICcuL3ZhbGlkYXRvcnMvcHVibGljLWFwaSc7XG4iXX0=
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
export const nextFrame = (cb) => {
|
|
2
|
+
requestAnimationFrame(() => {
|
|
3
|
+
requestAnimationFrame(cb);
|
|
4
|
+
});
|
|
5
|
+
};
|
|
6
|
+
export const forceReflow = (element = document.body) => {
|
|
7
|
+
return element.offsetHeight;
|
|
8
|
+
};
|
|
9
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5pbWF0aW9uLnV0aWxzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb3JlL3NyYy9saWIvdXRpbHMvYW5pbWF0aW9uLnV0aWxzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBQyxNQUFNLFNBQVMsR0FBRyxDQUFDLEVBQWMsRUFBRSxFQUFFO0lBQzFDLHFCQUFxQixDQUFDLEdBQUcsRUFBRTtRQUN6QixxQkFBcUIsQ0FBQyxFQUFFLENBQUMsQ0FBQztJQUM1QixDQUFDLENBQUMsQ0FBQztBQUNMLENBQUMsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLFdBQVcsR0FBRyxDQUFDLFVBQXVCLFFBQVEsQ0FBQyxJQUFJLEVBQUUsRUFBRTtJQUNsRSxPQUFPLE9BQU8sQ0FBQyxZQUFZLENBQUM7QUFDOUIsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNvbnN0IG5leHRGcmFtZSA9IChjYjogKCkgPT4gdm9pZCkgPT4ge1xuICByZXF1ZXN0QW5pbWF0aW9uRnJhbWUoKCkgPT4ge1xuICAgIHJlcXVlc3RBbmltYXRpb25GcmFtZShjYik7XG4gIH0pO1xufTtcblxuZXhwb3J0IGNvbnN0IGZvcmNlUmVmbG93ID0gKGVsZW1lbnQ6IEhUTUxFbGVtZW50ID0gZG9jdW1lbnQuYm9keSkgPT4ge1xuICByZXR1cm4gZWxlbWVudC5vZmZzZXRIZWlnaHQ7XG59O1xuIl19
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
export * from './animation.utils';
|
|
1
2
|
export * from './clamp.util';
|
|
2
3
|
export * from './clone.util';
|
|
3
4
|
export * from './cookie.util';
|
|
@@ -6,4 +7,4 @@ export * from './media-query-observable.util';
|
|
|
6
7
|
export * from './reactive-binding.util';
|
|
7
8
|
export * from './scrollable.utils';
|
|
8
9
|
export * from './viewport.util';
|
|
9
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
10
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29yZS9zcmMvbGliL3V0aWxzL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLGVBQWUsQ0FBQztBQUM5QixjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLCtCQUErQixDQUFDO0FBQzlDLGNBQWMseUJBQXlCLENBQUM7QUFDeEMsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLGlCQUFpQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9hbmltYXRpb24udXRpbHMnO1xuZXhwb3J0ICogZnJvbSAnLi9jbGFtcC51dGlsJztcbmV4cG9ydCAqIGZyb20gJy4vY2xvbmUudXRpbCc7XG5leHBvcnQgKiBmcm9tICcuL2Nvb2tpZS51dGlsJztcbmV4cG9ydCAqIGZyb20gJy4vZXF1YWwudXRpbCc7XG5leHBvcnQgKiBmcm9tICcuL21lZGlhLXF1ZXJ5LW9ic2VydmFibGUudXRpbCc7XG5leHBvcnQgKiBmcm9tICcuL3JlYWN0aXZlLWJpbmRpbmcudXRpbCc7XG5leHBvcnQgKiBmcm9tICcuL3Njcm9sbGFibGUudXRpbHMnO1xuZXhwb3J0ICogZnJvbSAnLi92aWV3cG9ydC51dGlsJztcbiJdfQ==
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
export const IS_ARRAY_NOT_EMPTY = 'isArrayNotEmpty';
|
|
2
|
+
export const IsArrayNotEmpty = (control) => {
|
|
3
|
+
const value = control.value;
|
|
4
|
+
if (!value) {
|
|
5
|
+
return null;
|
|
6
|
+
}
|
|
7
|
+
return value.length > 0 ? null : { [IS_ARRAY_NOT_EMPTY]: true };
|
|
8
|
+
};
|
|
9
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaXMtYXJyYXktbm90LWVtcHR5LnZhbGlkYXRvci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29yZS9zcmMvbGliL3ZhbGlkYXRvcnMvaXMtYXJyYXktbm90LWVtcHR5LnZhbGlkYXRvci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxNQUFNLENBQUMsTUFBTSxrQkFBa0IsR0FBRyxpQkFBaUIsQ0FBQztBQUVwRCxNQUFNLENBQUMsTUFBTSxlQUFlLEdBQUcsQ0FBQyxPQUF3QixFQUEyQixFQUFFO0lBQ25GLE1BQU0sS0FBSyxHQUFHLE9BQU8sQ0FBQyxLQUFLLENBQUM7SUFDNUIsSUFBSSxDQUFDLEtBQUssRUFBRTtRQUNWLE9BQU8sSUFBSSxDQUFDO0tBQ2I7SUFFRCxPQUFPLEtBQUssQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxrQkFBa0IsQ0FBQyxFQUFFLElBQUksRUFBRSxDQUFDO0FBQ2xFLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFic3RyYWN0Q29udHJvbCwgVmFsaWRhdGlvbkVycm9ycyB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcblxuZXhwb3J0IGNvbnN0IElTX0FSUkFZX05PVF9FTVBUWSA9ICdpc0FycmF5Tm90RW1wdHknO1xuXG5leHBvcnQgY29uc3QgSXNBcnJheU5vdEVtcHR5ID0gKGNvbnRyb2w6IEFic3RyYWN0Q29udHJvbCk6IFZhbGlkYXRpb25FcnJvcnMgfCBudWxsID0+IHtcbiAgY29uc3QgdmFsdWUgPSBjb250cm9sLnZhbHVlO1xuICBpZiAoIXZhbHVlKSB7XG4gICAgcmV0dXJuIG51bGw7XG4gIH1cblxuICByZXR1cm4gdmFsdWUubGVuZ3RoID4gMCA/IG51bGwgOiB7IFtJU19BUlJBWV9OT1RfRU1QVFldOiB0cnVlIH07XG59O1xuIl19
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
export const IS_EMAIL = 'isEmail';
|
|
2
|
+
export const IsEmail = (control) => {
|
|
3
|
+
const value = control.value;
|
|
4
|
+
if (!value) {
|
|
5
|
+
return null;
|
|
6
|
+
}
|
|
7
|
+
const regex = /^[a-z0-9._%+-]+@[a-z0-9.-]+\.[a-z]{2,4}$/;
|
|
8
|
+
return regex.test(value) ? null : { [IS_EMAIL]: true };
|
|
9
|
+
};
|
|
10
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaXMtZW1haWwudmFsaWRhdG9yLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb3JlL3NyYy9saWIvdmFsaWRhdG9ycy9pcy1lbWFpbC52YWxpZGF0b3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsTUFBTSxDQUFDLE1BQU0sUUFBUSxHQUFHLFNBQVMsQ0FBQztBQUVsQyxNQUFNLENBQUMsTUFBTSxPQUFPLEdBQUcsQ0FBQyxPQUF3QixFQUEyQixFQUFFO0lBQzNFLE1BQU0sS0FBSyxHQUFHLE9BQU8sQ0FBQyxLQUFLLENBQUM7SUFDNUIsSUFBSSxDQUFDLEtBQUssRUFBRTtRQUNWLE9BQU8sSUFBSSxDQUFDO0tBQ2I7SUFFRCxNQUFNLEtBQUssR0FBRywwQ0FBMEMsQ0FBQztJQUN6RCxPQUFPLEtBQUssQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLFFBQVEsQ0FBQyxFQUFFLElBQUksRUFBRSxDQUFDO0FBQ3pELENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFic3RyYWN0Q29udHJvbCwgVmFsaWRhdGlvbkVycm9ycyB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcblxuZXhwb3J0IGNvbnN0IElTX0VNQUlMID0gJ2lzRW1haWwnO1xuXG5leHBvcnQgY29uc3QgSXNFbWFpbCA9IChjb250cm9sOiBBYnN0cmFjdENvbnRyb2wpOiBWYWxpZGF0aW9uRXJyb3JzIHwgbnVsbCA9PiB7XG4gIGNvbnN0IHZhbHVlID0gY29udHJvbC52YWx1ZTtcbiAgaWYgKCF2YWx1ZSkge1xuICAgIHJldHVybiBudWxsO1xuICB9XG5cbiAgY29uc3QgcmVnZXggPSAvXlthLXowLTkuXyUrLV0rQFthLXowLTkuLV0rXFwuW2Etel17Miw0fSQvO1xuICByZXR1cm4gcmVnZXgudGVzdCh2YWx1ZSkgPyBudWxsIDogeyBbSVNfRU1BSUxdOiB0cnVlIH07XG59O1xuIl19
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
export const MUST_MATCH = 'mustMatch';
|
|
2
|
+
export const MustMatch = (controlName, matchingControlName) => {
|
|
3
|
+
return (formGroup) => {
|
|
4
|
+
const control = formGroup.controls[controlName];
|
|
5
|
+
const matchingControl = formGroup.controls[matchingControlName];
|
|
6
|
+
// set error on matchingControl if validation fails
|
|
7
|
+
if (matchingControl.errors && !matchingControl.errors[MUST_MATCH]) {
|
|
8
|
+
return;
|
|
9
|
+
}
|
|
10
|
+
// set error on matchingControl if validation fails
|
|
11
|
+
if (control.value !== matchingControl.value) {
|
|
12
|
+
matchingControl.setErrors({ [MUST_MATCH]: true });
|
|
13
|
+
}
|
|
14
|
+
else {
|
|
15
|
+
matchingControl.setErrors(null);
|
|
16
|
+
}
|
|
17
|
+
};
|
|
18
|
+
};
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibXVzdC1tYXRjaC52YWxpZGF0b3IuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvcmUvc3JjL2xpYi92YWxpZGF0b3JzL211c3QtbWF0Y2gudmFsaWRhdG9yLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE1BQU0sQ0FBQyxNQUFNLFVBQVUsR0FBRyxXQUFXLENBQUM7QUFFdEMsTUFBTSxDQUFDLE1BQU0sU0FBUyxHQUFHLENBQUMsV0FBbUIsRUFBRSxtQkFBMkIsRUFBRSxFQUFFO0lBQzVFLE9BQU8sQ0FBQyxTQUFvQixFQUFFLEVBQUU7UUFDOUIsTUFBTSxPQUFPLEdBQUcsU0FBUyxDQUFDLFFBQVEsQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUNoRCxNQUFNLGVBQWUsR0FBRyxTQUFTLENBQUMsUUFBUSxDQUFDLG1CQUFtQixDQUFDLENBQUM7UUFFaEUsbURBQW1EO1FBQ25ELElBQUksZUFBZSxDQUFDLE1BQU0sSUFBSSxDQUFDLGVBQWUsQ0FBQyxNQUFNLENBQUMsVUFBVSxDQUFDLEVBQUU7WUFDakUsT0FBTztTQUNSO1FBRUQsbURBQW1EO1FBQ25ELElBQUksT0FBTyxDQUFDLEtBQUssS0FBSyxlQUFlLENBQUMsS0FBSyxFQUFFO1lBQzNDLGVBQWUsQ0FBQyxTQUFTLENBQUMsRUFBRSxDQUFDLFVBQVUsQ0FBQyxFQUFFLElBQUksRUFBRSxDQUFDLENBQUM7U0FDbkQ7YUFBTTtZQUNMLGVBQWUsQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLENBQUM7U0FDakM7SUFDSCxDQUFDLENBQUM7QUFDSixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBGb3JtR3JvdXAgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5cbmV4cG9ydCBjb25zdCBNVVNUX01BVENIID0gJ211c3RNYXRjaCc7XG5cbmV4cG9ydCBjb25zdCBNdXN0TWF0Y2ggPSAoY29udHJvbE5hbWU6IHN0cmluZywgbWF0Y2hpbmdDb250cm9sTmFtZTogc3RyaW5nKSA9PiB7XG4gIHJldHVybiAoZm9ybUdyb3VwOiBGb3JtR3JvdXApID0+IHtcbiAgICBjb25zdCBjb250cm9sID0gZm9ybUdyb3VwLmNvbnRyb2xzW2NvbnRyb2xOYW1lXTtcbiAgICBjb25zdCBtYXRjaGluZ0NvbnRyb2wgPSBmb3JtR3JvdXAuY29udHJvbHNbbWF0Y2hpbmdDb250cm9sTmFtZV07XG5cbiAgICAvLyBzZXQgZXJyb3Igb24gbWF0Y2hpbmdDb250cm9sIGlmIHZhbGlkYXRpb24gZmFpbHNcbiAgICBpZiAobWF0Y2hpbmdDb250cm9sLmVycm9ycyAmJiAhbWF0Y2hpbmdDb250cm9sLmVycm9yc1tNVVNUX01BVENIXSkge1xuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIC8vIHNldCBlcnJvciBvbiBtYXRjaGluZ0NvbnRyb2wgaWYgdmFsaWRhdGlvbiBmYWlsc1xuICAgIGlmIChjb250cm9sLnZhbHVlICE9PSBtYXRjaGluZ0NvbnRyb2wudmFsdWUpIHtcbiAgICAgIG1hdGNoaW5nQ29udHJvbC5zZXRFcnJvcnMoeyBbTVVTVF9NQVRDSF06IHRydWUgfSk7XG4gICAgfSBlbHNlIHtcbiAgICAgIG1hdGNoaW5nQ29udHJvbC5zZXRFcnJvcnMobnVsbCk7XG4gICAgfVxuICB9O1xufTtcbiJdfQ==
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { IsArrayNotEmpty } from './is-array-not-empty.validator';
|
|
2
|
+
import { IsEmail } from './is-email.validator';
|
|
3
|
+
import { MustMatch } from './must-match.validator';
|
|
4
|
+
export * from './is-array-not-empty.validator';
|
|
5
|
+
export * from './is-email.validator';
|
|
6
|
+
export * from './must-match.validator';
|
|
7
|
+
export const Validators = {
|
|
8
|
+
MustMatch,
|
|
9
|
+
IsEmail,
|
|
10
|
+
IsArrayNotEmpty,
|
|
11
|
+
};
|
|
12
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29yZS9zcmMvbGliL3ZhbGlkYXRvcnMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFDakUsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUVuRCxjQUFjLGdDQUFnQyxDQUFDO0FBQy9DLGNBQWMsc0JBQXNCLENBQUM7QUFDckMsY0FBYyx3QkFBd0IsQ0FBQztBQUV2QyxNQUFNLENBQUMsTUFBTSxVQUFVLEdBQUc7SUFDeEIsU0FBUztJQUNULE9BQU87SUFDUCxlQUFlO0NBQ1AsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IElzQXJyYXlOb3RFbXB0eSB9IGZyb20gJy4vaXMtYXJyYXktbm90LWVtcHR5LnZhbGlkYXRvcic7XG5pbXBvcnQgeyBJc0VtYWlsIH0gZnJvbSAnLi9pcy1lbWFpbC52YWxpZGF0b3InO1xuaW1wb3J0IHsgTXVzdE1hdGNoIH0gZnJvbSAnLi9tdXN0LW1hdGNoLnZhbGlkYXRvcic7XG5cbmV4cG9ydCAqIGZyb20gJy4vaXMtYXJyYXktbm90LWVtcHR5LnZhbGlkYXRvcic7XG5leHBvcnQgKiBmcm9tICcuL2lzLWVtYWlsLnZhbGlkYXRvcic7XG5leHBvcnQgKiBmcm9tICcuL211c3QtbWF0Y2gudmFsaWRhdG9yJztcblxuZXhwb3J0IGNvbnN0IFZhbGlkYXRvcnMgPSB7XG4gIE11c3RNYXRjaCxcbiAgSXNFbWFpbCxcbiAgSXNBcnJheU5vdEVtcHR5LFxufSBhcyBjb25zdDtcbiJdfQ==
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import * as i0 from '@angular/core';
|
|
2
|
-
import { inject, Component, ChangeDetectionStrategy, ViewEncapsulation, Input, HostBinding, InjectionToken, Injectable, ElementRef, Inject, Optional,
|
|
2
|
+
import { inject, Component, ChangeDetectionStrategy, ViewEncapsulation, Input, HostBinding, InjectionToken, Injectable, ElementRef, Inject, Optional, 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, merge, tap, take } from 'rxjs';
|
|
4
5
|
import { coerceElement, coerceBooleanProperty, coerceNumberProperty } from '@angular/cdk/coercion';
|
|
5
|
-
import { fromEvent, Observable, Subject, startWith, map, takeUntil, distinctUntilChanged, BehaviorSubject, filter, combineLatest, pairwise, debounceTime, shareReplay, tap, take } from 'rxjs';
|
|
6
6
|
import { DOCUMENT } from '@angular/common';
|
|
7
7
|
import { Router, NavigationEnd } from '@angular/router';
|
|
8
8
|
import { __decorate, __metadata } from 'tslib';
|
|
@@ -348,6 +348,15 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.4", ngImpor
|
|
|
348
348
|
args: [{ providedIn: 'root' }]
|
|
349
349
|
}], ctorParameters: function () { return [{ type: ResizeObserverFactory }]; } });
|
|
350
350
|
|
|
351
|
+
const nextFrame = (cb) => {
|
|
352
|
+
requestAnimationFrame(() => {
|
|
353
|
+
requestAnimationFrame(cb);
|
|
354
|
+
});
|
|
355
|
+
};
|
|
356
|
+
const forceReflow = (element = document.body) => {
|
|
357
|
+
return element.offsetHeight;
|
|
358
|
+
};
|
|
359
|
+
|
|
351
360
|
const clamp = (value, min = 0, max = 100) => {
|
|
352
361
|
return Math.max(min, Math.min(max, value));
|
|
353
362
|
};
|
|
@@ -1005,6 +1014,187 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.4", ngImpor
|
|
|
1005
1014
|
}] }, { type: i1.BreakpointObserver }];
|
|
1006
1015
|
}, propDecorators: { _getViewportSize: [], _buildMediaQuery: [] } });
|
|
1007
1016
|
|
|
1017
|
+
const ANIMATABLE_TOKEN = new InjectionToken('ANIMATABLE_DIRECTIVE_TOKEN');
|
|
1018
|
+
class AnimatableDirective {
|
|
1019
|
+
constructor() {
|
|
1020
|
+
this._didEmitStart = false;
|
|
1021
|
+
this._parent = inject(ANIMATABLE_TOKEN, { optional: true, skipSelf: true });
|
|
1022
|
+
this._destroy$ = inject(DestroyService, { host: true }).destroy$;
|
|
1023
|
+
this._elementRef = inject(ElementRef);
|
|
1024
|
+
this._animationStart$ = new Subject();
|
|
1025
|
+
this._animationEnd$ = new Subject();
|
|
1026
|
+
this.animationStart$ = this._animationStart$.asObservable().pipe(debounceTime(0));
|
|
1027
|
+
this.animationEnd$ = this._animationEnd$.asObservable().pipe(debounceTime(0));
|
|
1028
|
+
this._hostActiveAnimationCount$ = new BehaviorSubject(0);
|
|
1029
|
+
this._totalActiveAnimationCount$ = new BehaviorSubject(0);
|
|
1030
|
+
this.isAnimating$ = this._totalActiveAnimationCount$.pipe(map((count) => count > 0), debounceTime(0));
|
|
1031
|
+
}
|
|
1032
|
+
ngOnInit() {
|
|
1033
|
+
merge(fromEvent(this._elementRef.nativeElement, 'animationstart'), fromEvent(this._elementRef.nativeElement, 'transitionstart'))
|
|
1034
|
+
.pipe(tap(() => {
|
|
1035
|
+
const count = this._hostActiveAnimationCount$.value + 1;
|
|
1036
|
+
this._hostActiveAnimationCount$.next(count);
|
|
1037
|
+
this._totalActiveAnimationCount$.next(count);
|
|
1038
|
+
}), takeUntil(this._destroy$))
|
|
1039
|
+
.subscribe();
|
|
1040
|
+
merge(fromEvent(this._elementRef.nativeElement, 'animationend'), fromEvent(this._elementRef.nativeElement, 'animationcancel'), fromEvent(this._elementRef.nativeElement, 'transitionend'), fromEvent(this._elementRef.nativeElement, 'transitioncancel'))
|
|
1041
|
+
.pipe(tap(() => {
|
|
1042
|
+
const count = this._hostActiveAnimationCount$.value - 1;
|
|
1043
|
+
this._hostActiveAnimationCount$.next(count);
|
|
1044
|
+
this._totalActiveAnimationCount$.next(count);
|
|
1045
|
+
}), takeUntil(this._destroy$))
|
|
1046
|
+
.subscribe();
|
|
1047
|
+
this._totalActiveAnimationCount$
|
|
1048
|
+
.pipe(tap((count) => {
|
|
1049
|
+
if (count > 0 && !this._didEmitStart) {
|
|
1050
|
+
this._animationStart$.next();
|
|
1051
|
+
this._didEmitStart = true;
|
|
1052
|
+
}
|
|
1053
|
+
else if (count === 0) {
|
|
1054
|
+
this._animationEnd$.next();
|
|
1055
|
+
this._didEmitStart = false;
|
|
1056
|
+
}
|
|
1057
|
+
}), takeUntil(this._destroy$))
|
|
1058
|
+
.subscribe();
|
|
1059
|
+
if (this._parent) {
|
|
1060
|
+
this._parent._hostActiveAnimationCount$
|
|
1061
|
+
.pipe(takeUntil(this._destroy$), tap((count) => {
|
|
1062
|
+
this._totalActiveAnimationCount$.next(count + this._hostActiveAnimationCount$.value);
|
|
1063
|
+
}))
|
|
1064
|
+
.subscribe();
|
|
1065
|
+
}
|
|
1066
|
+
}
|
|
1067
|
+
}
|
|
1068
|
+
AnimatableDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.4", ngImport: i0, type: AnimatableDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
|
1069
|
+
AnimatableDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.1.4", type: AnimatableDirective, isStandalone: true, selector: "[etAnimatable]", providers: [
|
|
1070
|
+
{
|
|
1071
|
+
provide: ANIMATABLE_TOKEN,
|
|
1072
|
+
useExisting: AnimatableDirective,
|
|
1073
|
+
},
|
|
1074
|
+
DestroyService,
|
|
1075
|
+
], exportAs: ["etAnimatable"], ngImport: i0 });
|
|
1076
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.4", ngImport: i0, type: AnimatableDirective, decorators: [{
|
|
1077
|
+
type: Directive,
|
|
1078
|
+
args: [{
|
|
1079
|
+
selector: '[etAnimatable]',
|
|
1080
|
+
exportAs: 'etAnimatable',
|
|
1081
|
+
standalone: true,
|
|
1082
|
+
providers: [
|
|
1083
|
+
{
|
|
1084
|
+
provide: ANIMATABLE_TOKEN,
|
|
1085
|
+
useExisting: AnimatableDirective,
|
|
1086
|
+
},
|
|
1087
|
+
DestroyService,
|
|
1088
|
+
],
|
|
1089
|
+
}]
|
|
1090
|
+
}] });
|
|
1091
|
+
|
|
1092
|
+
const ANIMATED_LIFECYCLE_TOKEN = new InjectionToken('ANIMATED_LIFECYCLE_DIRECTIVE_TOKEN');
|
|
1093
|
+
const ANIMATION_CLASSES = {
|
|
1094
|
+
enterFrom: 'et-animation-enter-from',
|
|
1095
|
+
enterActive: 'et-animation-enter-active',
|
|
1096
|
+
enterTo: 'et-animation-enter-to',
|
|
1097
|
+
leaveFrom: 'et-animation-leave-from',
|
|
1098
|
+
leaveActive: 'et-animation-leave-active',
|
|
1099
|
+
leaveTo: 'et-animation-leave-to',
|
|
1100
|
+
};
|
|
1101
|
+
class AnimatedLifecycleDirective {
|
|
1102
|
+
constructor() {
|
|
1103
|
+
this._destroy$ = inject(DestroyService, { host: true }).destroy$;
|
|
1104
|
+
this._elementRef = inject(ElementRef);
|
|
1105
|
+
this._animatable = inject(ANIMATABLE_TOKEN);
|
|
1106
|
+
this._classList = this._elementRef.nativeElement.classList;
|
|
1107
|
+
this._state$ = new BehaviorSubject('init');
|
|
1108
|
+
this.state$ = this._state$.asObservable();
|
|
1109
|
+
}
|
|
1110
|
+
get state() {
|
|
1111
|
+
return this._state$.value;
|
|
1112
|
+
}
|
|
1113
|
+
get _opacity() {
|
|
1114
|
+
return this._state$.value === 'init' ? '0 !important' : '';
|
|
1115
|
+
}
|
|
1116
|
+
enter(config) {
|
|
1117
|
+
this._state$.next('entering');
|
|
1118
|
+
if (!(config === null || config === void 0 ? void 0 : config.onlyTransition)) {
|
|
1119
|
+
this._classList.add(ANIMATION_CLASSES.enterFrom);
|
|
1120
|
+
}
|
|
1121
|
+
forceReflow();
|
|
1122
|
+
this._classList.add(ANIMATION_CLASSES.enterActive);
|
|
1123
|
+
nextFrame(() => {
|
|
1124
|
+
if (!(config === null || config === void 0 ? void 0 : config.onlyTransition)) {
|
|
1125
|
+
this._classList.remove(ANIMATION_CLASSES.enterFrom);
|
|
1126
|
+
this._classList.add(ANIMATION_CLASSES.enterTo);
|
|
1127
|
+
}
|
|
1128
|
+
this._animatable.animationEnd$
|
|
1129
|
+
.pipe(takeUntil(this._destroy$), take(1), tap(() => {
|
|
1130
|
+
this._state$.next('entered');
|
|
1131
|
+
this._classList.remove(ANIMATION_CLASSES.enterActive);
|
|
1132
|
+
if (!(config === null || config === void 0 ? void 0 : config.onlyTransition)) {
|
|
1133
|
+
this._classList.remove(ANIMATION_CLASSES.enterTo);
|
|
1134
|
+
}
|
|
1135
|
+
}))
|
|
1136
|
+
.subscribe();
|
|
1137
|
+
});
|
|
1138
|
+
}
|
|
1139
|
+
leave(config) {
|
|
1140
|
+
if (this._classList.contains(ANIMATION_CLASSES.enterFrom) ||
|
|
1141
|
+
this._classList.contains(ANIMATION_CLASSES.enterActive) ||
|
|
1142
|
+
this._classList.contains(ANIMATION_CLASSES.enterTo)) {
|
|
1143
|
+
this._classList.remove(ANIMATION_CLASSES.enterFrom);
|
|
1144
|
+
this._classList.remove(ANIMATION_CLASSES.enterActive);
|
|
1145
|
+
this._classList.remove(ANIMATION_CLASSES.enterTo);
|
|
1146
|
+
}
|
|
1147
|
+
this._state$.next('leaving');
|
|
1148
|
+
if (!(config === null || config === void 0 ? void 0 : config.onlyTransition)) {
|
|
1149
|
+
this._classList.add(ANIMATION_CLASSES.leaveFrom);
|
|
1150
|
+
}
|
|
1151
|
+
forceReflow();
|
|
1152
|
+
this._classList.add(ANIMATION_CLASSES.leaveActive);
|
|
1153
|
+
nextFrame(() => {
|
|
1154
|
+
if (!(config === null || config === void 0 ? void 0 : config.onlyTransition)) {
|
|
1155
|
+
this._classList.remove(ANIMATION_CLASSES.leaveFrom);
|
|
1156
|
+
this._classList.add(ANIMATION_CLASSES.leaveTo);
|
|
1157
|
+
}
|
|
1158
|
+
this._animatable.animationEnd$
|
|
1159
|
+
.pipe(takeUntil(this._destroy$), take(1), tap(() => {
|
|
1160
|
+
this._state$.next('left');
|
|
1161
|
+
this._classList.remove(ANIMATION_CLASSES.leaveActive);
|
|
1162
|
+
if (!(config === null || config === void 0 ? void 0 : config.onlyTransition)) {
|
|
1163
|
+
this._classList.remove(ANIMATION_CLASSES.leaveTo);
|
|
1164
|
+
}
|
|
1165
|
+
}))
|
|
1166
|
+
.subscribe();
|
|
1167
|
+
});
|
|
1168
|
+
}
|
|
1169
|
+
}
|
|
1170
|
+
AnimatedLifecycleDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.4", ngImport: i0, type: AnimatedLifecycleDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
|
1171
|
+
AnimatedLifecycleDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.1.4", type: AnimatedLifecycleDirective, isStandalone: true, selector: "[etAnimatedLifecycle]", host: { properties: { "style.opacity": "this._opacity" } }, providers: [
|
|
1172
|
+
{
|
|
1173
|
+
provide: ANIMATED_LIFECYCLE_TOKEN,
|
|
1174
|
+
useExisting: AnimatedLifecycleDirective,
|
|
1175
|
+
},
|
|
1176
|
+
DestroyService,
|
|
1177
|
+
], exportAs: ["etAnimatedLifecycle"], hostDirectives: [{ directive: AnimatableDirective }], ngImport: i0 });
|
|
1178
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.4", ngImport: i0, type: AnimatedLifecycleDirective, decorators: [{
|
|
1179
|
+
type: Directive,
|
|
1180
|
+
args: [{
|
|
1181
|
+
selector: '[etAnimatedLifecycle]',
|
|
1182
|
+
exportAs: 'etAnimatedLifecycle',
|
|
1183
|
+
standalone: true,
|
|
1184
|
+
providers: [
|
|
1185
|
+
{
|
|
1186
|
+
provide: ANIMATED_LIFECYCLE_TOKEN,
|
|
1187
|
+
useExisting: AnimatedLifecycleDirective,
|
|
1188
|
+
},
|
|
1189
|
+
DestroyService,
|
|
1190
|
+
],
|
|
1191
|
+
hostDirectives: [AnimatableDirective],
|
|
1192
|
+
}]
|
|
1193
|
+
}], propDecorators: { _opacity: [{
|
|
1194
|
+
type: HostBinding,
|
|
1195
|
+
args: ['style.opacity']
|
|
1196
|
+
}] } });
|
|
1197
|
+
|
|
1008
1198
|
class ClickOutsideDirective {
|
|
1009
1199
|
constructor() {
|
|
1010
1200
|
this._elementRef = inject(ElementRef);
|
|
@@ -2172,9 +2362,53 @@ class TypedQueryList extends QueryList {
|
|
|
2172
2362
|
}
|
|
2173
2363
|
_a = Symbol.iterator;
|
|
2174
2364
|
|
|
2365
|
+
const IS_ARRAY_NOT_EMPTY = 'isArrayNotEmpty';
|
|
2366
|
+
const IsArrayNotEmpty = (control) => {
|
|
2367
|
+
const value = control.value;
|
|
2368
|
+
if (!value) {
|
|
2369
|
+
return null;
|
|
2370
|
+
}
|
|
2371
|
+
return value.length > 0 ? null : { [IS_ARRAY_NOT_EMPTY]: true };
|
|
2372
|
+
};
|
|
2373
|
+
|
|
2374
|
+
const IS_EMAIL = 'isEmail';
|
|
2375
|
+
const IsEmail = (control) => {
|
|
2376
|
+
const value = control.value;
|
|
2377
|
+
if (!value) {
|
|
2378
|
+
return null;
|
|
2379
|
+
}
|
|
2380
|
+
const regex = /^[a-z0-9._%+-]+@[a-z0-9.-]+\.[a-z]{2,4}$/;
|
|
2381
|
+
return regex.test(value) ? null : { [IS_EMAIL]: true };
|
|
2382
|
+
};
|
|
2383
|
+
|
|
2384
|
+
const MUST_MATCH = 'mustMatch';
|
|
2385
|
+
const MustMatch = (controlName, matchingControlName) => {
|
|
2386
|
+
return (formGroup) => {
|
|
2387
|
+
const control = formGroup.controls[controlName];
|
|
2388
|
+
const matchingControl = formGroup.controls[matchingControlName];
|
|
2389
|
+
// set error on matchingControl if validation fails
|
|
2390
|
+
if (matchingControl.errors && !matchingControl.errors[MUST_MATCH]) {
|
|
2391
|
+
return;
|
|
2392
|
+
}
|
|
2393
|
+
// set error on matchingControl if validation fails
|
|
2394
|
+
if (control.value !== matchingControl.value) {
|
|
2395
|
+
matchingControl.setErrors({ [MUST_MATCH]: true });
|
|
2396
|
+
}
|
|
2397
|
+
else {
|
|
2398
|
+
matchingControl.setErrors(null);
|
|
2399
|
+
}
|
|
2400
|
+
};
|
|
2401
|
+
};
|
|
2402
|
+
|
|
2403
|
+
const Validators = {
|
|
2404
|
+
MustMatch,
|
|
2405
|
+
IsEmail,
|
|
2406
|
+
IsArrayNotEmpty,
|
|
2407
|
+
};
|
|
2408
|
+
|
|
2175
2409
|
/**
|
|
2176
2410
|
* Generated bundle index. Do not edit.
|
|
2177
2411
|
*/
|
|
2178
2412
|
|
|
2179
|
-
export { ClickObserverFactory, ClickObserverService, ClickOutsideDirective, ContentObserverService, CursorDragScrollDirective, DEFAULT_VIEWPORT_CONFIG, DestroyService, FocusVisibleService, LetContext, LetDirective, Memo, 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, ViewportService, clamp, clone, createMediaQueryObservable, createReactiveBindings, deleteCookie, elementCanScroll, equal, getCookie, getDomain, getGroupMatchPoints, getGroupMatchScore, getKnockoutMatchScore, getMatchScoreSubLine, hasCookie, isGroupMatch, isKnockoutMatch, mergeSeoConfig, normalizeGameResultType, normalizeMatchParticipant, normalizeMatchParticipants, normalizeMatchScore, normalizeMatchState, normalizeMatchType, provideViewportConfig, routerDisableScrollTop, setCookie, toArray, toArrayTrackByFn };
|
|
2413
|
+
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, getCookie, getDomain, getGroupMatchPoints, getGroupMatchScore, getKnockoutMatchScore, getMatchScoreSubLine, hasCookie, isGroupMatch, isKnockoutMatch, mergeSeoConfig, nextFrame, normalizeGameResultType, normalizeMatchParticipant, normalizeMatchParticipants, normalizeMatchScore, normalizeMatchState, normalizeMatchType, provideViewportConfig, routerDisableScrollTop, setCookie, toArray, toArrayTrackByFn };
|
|
2180
2414
|
//# sourceMappingURL=ethlete-core.mjs.map
|