@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.
Files changed (29) hide show
  1. package/esm2020/lib/directives/animatable/animatable.directive.mjs +79 -0
  2. package/esm2020/lib/directives/animatable/public-api.mjs +2 -0
  3. package/esm2020/lib/directives/animated-lifecycle/animated-lifecycle.directive.mjs +113 -0
  4. package/esm2020/lib/directives/animated-lifecycle/public-api.mjs +2 -0
  5. package/esm2020/lib/directives/public-api.mjs +3 -1
  6. package/esm2020/lib/public-api.mjs +2 -1
  7. package/esm2020/lib/utils/animation.utils.mjs +9 -0
  8. package/esm2020/lib/utils/public-api.mjs +2 -1
  9. package/esm2020/lib/validators/is-array-not-empty.validator.mjs +9 -0
  10. package/esm2020/lib/validators/is-email.validator.mjs +10 -0
  11. package/esm2020/lib/validators/must-match.validator.mjs +19 -0
  12. package/esm2020/lib/validators/public-api.mjs +12 -0
  13. package/fesm2015/ethlete-core.mjs +237 -3
  14. package/fesm2015/ethlete-core.mjs.map +1 -1
  15. package/fesm2020/ethlete-core.mjs +237 -3
  16. package/fesm2020/ethlete-core.mjs.map +1 -1
  17. package/lib/directives/animatable/animatable.directive.d.ts +20 -0
  18. package/lib/directives/animatable/public-api.d.ts +1 -0
  19. package/lib/directives/animated-lifecycle/animated-lifecycle.directive.d.ts +22 -0
  20. package/lib/directives/animated-lifecycle/public-api.d.ts +1 -0
  21. package/lib/directives/public-api.d.ts +2 -0
  22. package/lib/public-api.d.ts +1 -0
  23. package/lib/utils/animation.utils.d.ts +2 -0
  24. package/lib/utils/public-api.d.ts +1 -0
  25. package/lib/validators/is-array-not-empty.validator.d.ts +3 -0
  26. package/lib/validators/is-email.validator.d.ts +3 -0
  27. package/lib/validators/must-match.validator.d.ts +3 -0
  28. package/lib/validators/public-api.d.ts +8 -0
  29. 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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29yZS9zcmMvbGliL2RpcmVjdGl2ZXMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDRCQUE0QixDQUFDO0FBQzNDLGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYyxrQkFBa0IsQ0FBQztBQUNqQyxjQUFjLDhCQUE4QixDQUFDO0FBQzdDLGNBQWMsNkJBQTZCLENBQUM7QUFDNUMsY0FBYyxtQ0FBbUMsQ0FBQztBQUNsRCxjQUFjLHFCQUFxQixDQUFDO0FBQ3BDLGNBQWMsNENBQTRDLENBQUM7QUFDM0QsY0FBYyw0Q0FBNEMsQ0FBQztBQUMzRCxjQUFjLDJDQUEyQyxDQUFDO0FBQzFELGNBQWMsa0JBQWtCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2NsaWNrLW91dHNpZGUvcHVibGljLWFwaSc7XG5leHBvcnQgKiBmcm9tICcuL2N1cnNvci1kcmFnLXNjcm9sbC9wdWJsaWMtYXBpJztcbmV4cG9ydCAqIGZyb20gJy4vbGV0L3B1YmxpYy1hcGknO1xuZXhwb3J0ICogZnJvbSAnLi9vYnNlcnZlLWNvbnRlbnQvcHVibGljLWFwaSc7XG5leHBvcnQgKiBmcm9tICcuL29ic2VydmUtcmVzaXplL3B1YmxpYy1hcGknO1xuZXhwb3J0ICogZnJvbSAnLi9vYnNlcnZlLXNjcm9sbC1zdGF0ZS9wdWJsaWMtYXBpJztcbmV4cG9ydCAqIGZyb20gJy4vcmVwZWF0L3B1YmxpYy1hcGknO1xuZXhwb3J0ICogZnJvbSAnLi9zY3JvbGwtb2JzZXJ2ZXItZmlyc3QtZWxlbWVudC9wdWJsaWMtYXBpJztcbmV4cG9ydCAqIGZyb20gJy4vc2Nyb2xsLW9ic2VydmVyLWlnbm9yZS10YXJnZXQvcHVibGljLWFwaSc7XG5leHBvcnQgKiBmcm9tICcuL3Njcm9sbC1vYnNlcnZlci1sYXN0LWVsZW1lbnQvcHVibGljLWFwaSc7XG5leHBvcnQgKiBmcm9tICcuL3Nlby9wdWJsaWMtYXBpJztcbiJdfQ==
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
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYnMvY29yZS9zcmMvbGliL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLHdCQUF3QixDQUFDO0FBQ3ZDLGNBQWMseUJBQXlCLENBQUM7QUFDeEMsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLG9CQUFvQixDQUFDO0FBQ25DLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLG9CQUFvQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9jb21wb25lbnRzL3B1YmxpYy1hcGknO1xuZXhwb3J0ICogZnJvbSAnLi9jb25zdGFudHMvcHVibGljLWFwaSc7XG5leHBvcnQgKiBmcm9tICcuL2RlY29yYXRvcnMvcHVibGljLWFwaSc7XG5leHBvcnQgKiBmcm9tICcuL2RpcmVjdGl2ZXMvcHVibGljLWFwaSc7XG5leHBvcnQgKiBmcm9tICcuL3BpcGVzL3B1YmxpYy1hcGknO1xuZXhwb3J0ICogZnJvbSAnLi9zZXJ2aWNlcy9wdWJsaWMtYXBpJztcbmV4cG9ydCAqIGZyb20gJy4vdHlwZXMvcHVibGljLWFwaSc7XG5leHBvcnQgKiBmcm9tICcuL3V0aWxzL3B1YmxpYy1hcGknO1xuIl19
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29yZS9zcmMvbGliL3V0aWxzL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxlQUFlLENBQUM7QUFDOUIsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYywrQkFBK0IsQ0FBQztBQUM5QyxjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMsb0JBQW9CLENBQUM7QUFDbkMsY0FBYyxpQkFBaUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vY2xhbXAudXRpbCc7XG5leHBvcnQgKiBmcm9tICcuL2Nsb25lLnV0aWwnO1xuZXhwb3J0ICogZnJvbSAnLi9jb29raWUudXRpbCc7XG5leHBvcnQgKiBmcm9tICcuL2VxdWFsLnV0aWwnO1xuZXhwb3J0ICogZnJvbSAnLi9tZWRpYS1xdWVyeS1vYnNlcnZhYmxlLnV0aWwnO1xuZXhwb3J0ICogZnJvbSAnLi9yZWFjdGl2ZS1iaW5kaW5nLnV0aWwnO1xuZXhwb3J0ICogZnJvbSAnLi9zY3JvbGxhYmxlLnV0aWxzJztcbmV4cG9ydCAqIGZyb20gJy4vdmlld3BvcnQudXRpbCc7XG4iXX0=
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, EventEmitter, Directive, Output, NgZone, Pipe, QueryList } from '@angular/core';
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