@ethlete/core 4.3.0 → 4.4.1

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 (42) hide show
  1. package/esm2022/lib/components/structured-data/structured-data.component.mjs +3 -3
  2. package/esm2022/lib/directives/animatable/animatable.directive.mjs +3 -3
  3. package/esm2022/lib/directives/animated-if/animated-if.directive.mjs +7 -5
  4. package/esm2022/lib/directives/animated-lifecycle/animated-lifecycle.directive.mjs +3 -3
  5. package/esm2022/lib/directives/animated-overlay/animated-overlay.directive.mjs +35 -9
  6. package/esm2022/lib/directives/click-outside/click-outside.directive.mjs +3 -3
  7. package/esm2022/lib/directives/cursor-drag-scroll/cursor-drag-scroll.directive.mjs +3 -3
  8. package/esm2022/lib/directives/debug/debug.directive.mjs +3 -3
  9. package/esm2022/lib/directives/delayable/delayable.directive.mjs +3 -3
  10. package/esm2022/lib/directives/is-active-element/is-active-element.directive.mjs +3 -3
  11. package/esm2022/lib/directives/is-element/is-element.directive.mjs +3 -3
  12. package/esm2022/lib/directives/let/let.directive.mjs +3 -3
  13. package/esm2022/lib/directives/observe-content/observe-content.directive.mjs +3 -3
  14. package/esm2022/lib/directives/observe-resize/observe-resize.directive.mjs +3 -3
  15. package/esm2022/lib/directives/observe-scroll-state/observe-scroll-state.directive.mjs +3 -3
  16. package/esm2022/lib/directives/observe-visibility/observe-visibility.directive.mjs +3 -3
  17. package/esm2022/lib/directives/repeat/repeat.directive.mjs +3 -3
  18. package/esm2022/lib/directives/root-boundary/root-boundary.directive.mjs +3 -3
  19. package/esm2022/lib/directives/scroll-observer-first-element/scroll-observer-first-element.directive.mjs +3 -3
  20. package/esm2022/lib/directives/scroll-observer-ignore-target/scroll-observer-ignore-target.directive.mjs +3 -3
  21. package/esm2022/lib/directives/scroll-observer-last-element/scroll-observer-last-element.directive.mjs +3 -3
  22. package/esm2022/lib/directives/seo/seo.directive.mjs +3 -3
  23. package/esm2022/lib/pipes/infer-mime-type/infer-mime-type.pipe.mjs +3 -3
  24. package/esm2022/lib/pipes/normalize-game-result-type/normalize-game-result-type.pipe.mjs +3 -3
  25. package/esm2022/lib/pipes/normalize-match-participants/normalize-match-participants.pipe.mjs +3 -3
  26. package/esm2022/lib/pipes/normalize-match-score/normalize-match-score.pipe.mjs +3 -3
  27. package/esm2022/lib/pipes/normalize-match-state/normalize-match-state.pipe.mjs +3 -3
  28. package/esm2022/lib/pipes/normalize-match-type/normalize-match-type.pipe.mjs +3 -3
  29. package/esm2022/lib/pipes/to-array/to-array.pipe.mjs +3 -3
  30. package/esm2022/lib/services/click-observer.service.mjs +6 -6
  31. package/esm2022/lib/services/content-observer.service.mjs +6 -6
  32. package/esm2022/lib/services/focus-visible.service.mjs +3 -3
  33. package/esm2022/lib/services/intersection-observer.service.mjs +6 -6
  34. package/esm2022/lib/services/resize-observer.service.mjs +6 -6
  35. package/esm2022/lib/services/router-state.service.mjs +3 -3
  36. package/esm2022/lib/services/viewport.service.mjs +3 -3
  37. package/esm2022/lib/utils/signal.utils.mjs +8 -3
  38. package/fesm2022/ethlete-core.mjs +161 -128
  39. package/fesm2022/ethlete-core.mjs.map +1 -1
  40. package/lib/directives/animated-if/animated-if.directive.d.ts +2 -1
  41. package/lib/directives/animated-overlay/animated-overlay.directive.d.ts +7 -1
  42. package/package.json +7 -7
@@ -13,10 +13,10 @@ export class StructuredDataComponent {
13
13
  const html = `<script type="application/ld+json">${json}</script>`;
14
14
  return this._sanitizer.bypassSecurityTrustHtml(html);
15
15
  }
16
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: StructuredDataComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
17
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.3", type: StructuredDataComponent, isStandalone: true, selector: "et-structured-data", inputs: { data: "data" }, host: { properties: { "innerHTML": "this.jsonLD" }, styleAttribute: "display: none" }, ngImport: i0, template: '', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
16
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: StructuredDataComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
17
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.8", type: StructuredDataComponent, isStandalone: true, selector: "et-structured-data", inputs: { data: "data" }, host: { properties: { "innerHTML": "this.jsonLD" }, styleAttribute: "display: none" }, ngImport: i0, template: '', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
18
18
  }
19
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: StructuredDataComponent, decorators: [{
19
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: StructuredDataComponent, decorators: [{
20
20
  type: Component,
21
21
  args: [{
22
22
  selector: 'et-structured-data',
@@ -93,15 +93,15 @@ export class AnimatableDirective {
93
93
  .subscribe();
94
94
  }
95
95
  }
96
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: AnimatableDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
97
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.3", type: AnimatableDirective, isStandalone: true, selector: "[etAnimatable]", inputs: { animatedElement: ["etAnimatable", "animatedElement"] }, providers: [
96
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: AnimatableDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
97
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.8", type: AnimatableDirective, isStandalone: true, selector: "[etAnimatable]", inputs: { animatedElement: ["etAnimatable", "animatedElement"] }, providers: [
98
98
  {
99
99
  provide: ANIMATABLE_TOKEN,
100
100
  useExisting: AnimatableDirective,
101
101
  },
102
102
  ], exportAs: ["etAnimatable"], ngImport: i0 }); }
103
103
  }
104
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: AnimatableDirective, decorators: [{
104
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: AnimatableDirective, decorators: [{
105
105
  type: Directive,
106
106
  args: [{
107
107
  selector: '[etAnimatable]',
@@ -4,6 +4,7 @@ import { filter, takeUntil, takeWhile, tap } from 'rxjs';
4
4
  import { createDestroy } from '../../utils';
5
5
  import { ANIMATED_LIFECYCLE_TOKEN } from '../animated-lifecycle';
6
6
  import * as i0 from "@angular/core";
7
+ import * as i1 from "@angular/common";
7
8
  export const ANIMATED_IF_TOKEN = new InjectionToken('ANIMATED_IF_TOKEN');
8
9
  export class AnimatedIfDirective {
9
10
  constructor() {
@@ -25,15 +26,15 @@ export class AnimatedIfDirective {
25
26
  .subscribe();
26
27
  }
27
28
  }
28
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: AnimatedIfDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
29
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.3", type: AnimatedIfDirective, isStandalone: true, selector: "[etAnimatedIf]", inputs: { shouldRender: ["etAnimatedIf", "shouldRender"] }, providers: [
29
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: AnimatedIfDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
30
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.8", type: AnimatedIfDirective, isStandalone: true, selector: "[etAnimatedIf]", inputs: { shouldRender: ["etAnimatedIf", "shouldRender"] }, providers: [
30
31
  {
31
32
  provide: ANIMATED_IF_TOKEN,
32
33
  useExisting: AnimatedIfDirective,
33
34
  },
34
- ], ngImport: i0 }); }
35
+ ], hostDirectives: [{ directive: i1.NgIf }], ngImport: i0 }); }
35
36
  }
36
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: AnimatedIfDirective, decorators: [{
37
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: AnimatedIfDirective, decorators: [{
37
38
  type: Directive,
38
39
  args: [{
39
40
  selector: '[etAnimatedIf]',
@@ -44,9 +45,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.3", ngImpor
44
45
  useExisting: AnimatedIfDirective,
45
46
  },
46
47
  ],
48
+ hostDirectives: [NgIf],
47
49
  }]
48
50
  }], propDecorators: { shouldRender: [{
49
51
  type: Input,
50
52
  args: ['etAnimatedIf']
51
53
  }] } });
52
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5pbWF0ZWQtaWYuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb3JlL3NyYy9saWIvZGlyZWN0aXZlcy9hbmltYXRlZC1pZi9hbmltYXRlZC1pZi5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLElBQUksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQ3ZDLE9BQU8sRUFBRSxTQUFTLEVBQUUsY0FBYyxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekUsT0FBTyxFQUFFLE1BQU0sRUFBRSxTQUFTLEVBQUUsU0FBUyxFQUFFLEdBQUcsRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUN6RCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sYUFBYSxDQUFDO0FBQzVDLE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLHVCQUF1QixDQUFDOztBQUVqRSxNQUFNLENBQUMsTUFBTSxpQkFBaUIsR0FBRyxJQUFJLGNBQWMsQ0FBc0IsbUJBQW1CLENBQUMsQ0FBQztBQVk5RixNQUFNLE9BQU8sbUJBQW1CO0lBVmhDO1FBV21CLGNBQVMsR0FBRyxhQUFhLEVBQUUsQ0FBQztRQUM1QixVQUFLLEdBQUcsTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ3JCLHVCQUFrQixHQUFHLE1BQU0sQ0FBQyx3QkFBd0IsQ0FBQyxDQUFDO0tBdUJ4RTtJQXJCQyxJQUNJLFlBQVksQ0FBQyxLQUFjO1FBQzdCLElBQUksS0FBSyxFQUFFO1lBQ1QsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLEdBQUcsS0FBSyxDQUFDO1lBRXhCLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxLQUFLLEVBQUUsQ0FBQztTQUNqQzthQUFNO1lBQ0wsSUFBSSxDQUFDLGtCQUFrQixDQUFDLEtBQUssRUFBRSxDQUFDO1lBRWhDLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxNQUFNO2lCQUMzQixJQUFJLENBQ0gsU0FBUyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsRUFDekIsU0FBUyxDQUFDLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxLQUFLLEtBQUssTUFBTSxFQUFFLElBQUksQ0FBQyxFQUM1QyxNQUFNLENBQUMsQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLEtBQUssS0FBSyxNQUFNLENBQUMsRUFDbkMsR0FBRyxDQUFDLEdBQUcsRUFBRTtnQkFDUCxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksR0FBRyxLQUFLLENBQUM7WUFDMUIsQ0FBQyxDQUFDLENBQ0g7aUJBQ0EsU0FBUyxFQUFFLENBQUM7U0FDaEI7SUFDSCxDQUFDOzhHQXpCVSxtQkFBbUI7a0dBQW5CLG1CQUFtQix5SEFQbkI7WUFDVDtnQkFDRSxPQUFPLEVBQUUsaUJBQWlCO2dCQUMxQixXQUFXLEVBQUUsbUJBQW1CO2FBQ2pDO1NBQ0Y7OzJGQUVVLG1CQUFtQjtrQkFWL0IsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsZ0JBQWdCO29CQUMxQixVQUFVLEVBQUUsSUFBSTtvQkFDaEIsU0FBUyxFQUFFO3dCQUNUOzRCQUNFLE9BQU8sRUFBRSxpQkFBaUI7NEJBQzFCLFdBQVcscUJBQXFCO3lCQUNqQztxQkFDRjtpQkFDRjs4QkFPSyxZQUFZO3NCQURmLEtBQUs7dUJBQUMsY0FBYyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nSWYgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgRGlyZWN0aXZlLCBJbmplY3Rpb25Ub2tlbiwgSW5wdXQsIGluamVjdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgZmlsdGVyLCB0YWtlVW50aWwsIHRha2VXaGlsZSwgdGFwIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBjcmVhdGVEZXN0cm95IH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xuaW1wb3J0IHsgQU5JTUFURURfTElGRUNZQ0xFX1RPS0VOIH0gZnJvbSAnLi4vYW5pbWF0ZWQtbGlmZWN5Y2xlJztcblxuZXhwb3J0IGNvbnN0IEFOSU1BVEVEX0lGX1RPS0VOID0gbmV3IEluamVjdGlvblRva2VuPEFuaW1hdGVkSWZEaXJlY3RpdmU+KCdBTklNQVRFRF9JRl9UT0tFTicpO1xuXG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6ICdbZXRBbmltYXRlZElmXScsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIHByb3ZpZGVyczogW1xuICAgIHtcbiAgICAgIHByb3ZpZGU6IEFOSU1BVEVEX0lGX1RPS0VOLFxuICAgICAgdXNlRXhpc3Rpbmc6IEFuaW1hdGVkSWZEaXJlY3RpdmUsXG4gICAgfSxcbiAgXSxcbn0pXG5leHBvcnQgY2xhc3MgQW5pbWF0ZWRJZkRpcmVjdGl2ZSB7XG4gIHByaXZhdGUgcmVhZG9ubHkgX2Rlc3Ryb3kkID0gY3JlYXRlRGVzdHJveSgpO1xuICBwcml2YXRlIHJlYWRvbmx5IF9uZ0lmID0gaW5qZWN0KE5nSWYpO1xuICBwcml2YXRlIHJlYWRvbmx5IF9hbmltYXRlZExpZmVjeWNsZSA9IGluamVjdChBTklNQVRFRF9MSUZFQ1lDTEVfVE9LRU4pO1xuXG4gIEBJbnB1dCgnZXRBbmltYXRlZElmJylcbiAgc2V0IHNob3VsZFJlbmRlcih2YWx1ZTogdW5rbm93bikge1xuICAgIGlmICh2YWx1ZSkge1xuICAgICAgdGhpcy5fbmdJZi5uZ0lmID0gdmFsdWU7XG5cbiAgICAgIHRoaXMuX2FuaW1hdGVkTGlmZWN5Y2xlLmVudGVyKCk7XG4gICAgfSBlbHNlIHtcbiAgICAgIHRoaXMuX2FuaW1hdGVkTGlmZWN5Y2xlLmxlYXZlKCk7XG5cbiAgICAgIHRoaXMuX2FuaW1hdGVkTGlmZWN5Y2xlLnN0YXRlJFxuICAgICAgICAucGlwZShcbiAgICAgICAgICB0YWtlVW50aWwodGhpcy5fZGVzdHJveSQpLFxuICAgICAgICAgIHRha2VXaGlsZSgoc3RhdGUpID0+IHN0YXRlICE9PSAnbGVmdCcsIHRydWUpLFxuICAgICAgICAgIGZpbHRlcigoc3RhdGUpID0+IHN0YXRlID09PSAnbGVmdCcpLFxuICAgICAgICAgIHRhcCgoKSA9PiB7XG4gICAgICAgICAgICB0aGlzLl9uZ0lmLm5nSWYgPSB2YWx1ZTtcbiAgICAgICAgICB9KSxcbiAgICAgICAgKVxuICAgICAgICAuc3Vic2NyaWJlKCk7XG4gICAgfVxuICB9XG59XG4iXX0=
54
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5pbWF0ZWQtaWYuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb3JlL3NyYy9saWIvZGlyZWN0aXZlcy9hbmltYXRlZC1pZi9hbmltYXRlZC1pZi5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLElBQUksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQ3ZDLE9BQU8sRUFBRSxTQUFTLEVBQUUsY0FBYyxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekUsT0FBTyxFQUFFLE1BQU0sRUFBRSxTQUFTLEVBQUUsU0FBUyxFQUFFLEdBQUcsRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUN6RCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sYUFBYSxDQUFDO0FBQzVDLE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLHVCQUF1QixDQUFDOzs7QUFFakUsTUFBTSxDQUFDLE1BQU0saUJBQWlCLEdBQUcsSUFBSSxjQUFjLENBQXNCLG1CQUFtQixDQUFDLENBQUM7QUFhOUYsTUFBTSxPQUFPLG1CQUFtQjtJQVhoQztRQVltQixjQUFTLEdBQUcsYUFBYSxFQUFFLENBQUM7UUFDNUIsVUFBSyxHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUNyQix1QkFBa0IsR0FBRyxNQUFNLENBQUMsd0JBQXdCLENBQUMsQ0FBQztLQXVCeEU7SUFyQkMsSUFDSSxZQUFZLENBQUMsS0FBYztRQUM3QixJQUFJLEtBQUssRUFBRTtZQUNULElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxHQUFHLEtBQUssQ0FBQztZQUV4QixJQUFJLENBQUMsa0JBQWtCLENBQUMsS0FBSyxFQUFFLENBQUM7U0FDakM7YUFBTTtZQUNMLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxLQUFLLEVBQUUsQ0FBQztZQUVoQyxJQUFJLENBQUMsa0JBQWtCLENBQUMsTUFBTTtpQkFDM0IsSUFBSSxDQUNILFNBQVMsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLEVBQ3pCLFNBQVMsQ0FBQyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsS0FBSyxLQUFLLE1BQU0sRUFBRSxJQUFJLENBQUMsRUFDNUMsTUFBTSxDQUFDLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxLQUFLLEtBQUssTUFBTSxDQUFDLEVBQ25DLEdBQUcsQ0FBQyxHQUFHLEVBQUU7Z0JBQ1AsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLEdBQUcsS0FBSyxDQUFDO1lBQzFCLENBQUMsQ0FBQyxDQUNIO2lCQUNBLFNBQVMsRUFBRSxDQUFDO1NBQ2hCO0lBQ0gsQ0FBQzs4R0F6QlUsbUJBQW1CO2tHQUFuQixtQkFBbUIseUhBUm5CO1lBQ1Q7Z0JBQ0UsT0FBTyxFQUFFLGlCQUFpQjtnQkFDMUIsV0FBVyxFQUFFLG1CQUFtQjthQUNqQztTQUNGOzsyRkFHVSxtQkFBbUI7a0JBWC9CLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLGdCQUFnQjtvQkFDMUIsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLFNBQVMsRUFBRTt3QkFDVDs0QkFDRSxPQUFPLEVBQUUsaUJBQWlCOzRCQUMxQixXQUFXLHFCQUFxQjt5QkFDakM7cUJBQ0Y7b0JBQ0QsY0FBYyxFQUFFLENBQUMsSUFBSSxDQUFDO2lCQUN2Qjs4QkFPSyxZQUFZO3NCQURmLEtBQUs7dUJBQUMsY0FBYyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nSWYgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgRGlyZWN0aXZlLCBJbmplY3Rpb25Ub2tlbiwgSW5wdXQsIGluamVjdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgZmlsdGVyLCB0YWtlVW50aWwsIHRha2VXaGlsZSwgdGFwIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBjcmVhdGVEZXN0cm95IH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xuaW1wb3J0IHsgQU5JTUFURURfTElGRUNZQ0xFX1RPS0VOIH0gZnJvbSAnLi4vYW5pbWF0ZWQtbGlmZWN5Y2xlJztcblxuZXhwb3J0IGNvbnN0IEFOSU1BVEVEX0lGX1RPS0VOID0gbmV3IEluamVjdGlvblRva2VuPEFuaW1hdGVkSWZEaXJlY3RpdmU+KCdBTklNQVRFRF9JRl9UT0tFTicpO1xuXG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6ICdbZXRBbmltYXRlZElmXScsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIHByb3ZpZGVyczogW1xuICAgIHtcbiAgICAgIHByb3ZpZGU6IEFOSU1BVEVEX0lGX1RPS0VOLFxuICAgICAgdXNlRXhpc3Rpbmc6IEFuaW1hdGVkSWZEaXJlY3RpdmUsXG4gICAgfSxcbiAgXSxcbiAgaG9zdERpcmVjdGl2ZXM6IFtOZ0lmXSxcbn0pXG5leHBvcnQgY2xhc3MgQW5pbWF0ZWRJZkRpcmVjdGl2ZSB7XG4gIHByaXZhdGUgcmVhZG9ubHkgX2Rlc3Ryb3kkID0gY3JlYXRlRGVzdHJveSgpO1xuICBwcml2YXRlIHJlYWRvbmx5IF9uZ0lmID0gaW5qZWN0KE5nSWYpO1xuICBwcml2YXRlIHJlYWRvbmx5IF9hbmltYXRlZExpZmVjeWNsZSA9IGluamVjdChBTklNQVRFRF9MSUZFQ1lDTEVfVE9LRU4pO1xuXG4gIEBJbnB1dCgnZXRBbmltYXRlZElmJylcbiAgc2V0IHNob3VsZFJlbmRlcih2YWx1ZTogdW5rbm93bikge1xuICAgIGlmICh2YWx1ZSkge1xuICAgICAgdGhpcy5fbmdJZi5uZ0lmID0gdmFsdWU7XG5cbiAgICAgIHRoaXMuX2FuaW1hdGVkTGlmZWN5Y2xlLmVudGVyKCk7XG4gICAgfSBlbHNlIHtcbiAgICAgIHRoaXMuX2FuaW1hdGVkTGlmZWN5Y2xlLmxlYXZlKCk7XG5cbiAgICAgIHRoaXMuX2FuaW1hdGVkTGlmZWN5Y2xlLnN0YXRlJFxuICAgICAgICAucGlwZShcbiAgICAgICAgICB0YWtlVW50aWwodGhpcy5fZGVzdHJveSQpLFxuICAgICAgICAgIHRha2VXaGlsZSgoc3RhdGUpID0+IHN0YXRlICE9PSAnbGVmdCcsIHRydWUpLFxuICAgICAgICAgIGZpbHRlcigoc3RhdGUpID0+IHN0YXRlID09PSAnbGVmdCcpLFxuICAgICAgICAgIHRhcCgoKSA9PiB7XG4gICAgICAgICAgICB0aGlzLl9uZ0lmLm5nSWYgPSB2YWx1ZTtcbiAgICAgICAgICB9KSxcbiAgICAgICAgKVxuICAgICAgICAuc3Vic2NyaWJlKCk7XG4gICAgfVxuICB9XG59XG4iXX0=
@@ -107,15 +107,15 @@ export class AnimatedLifecycleDirective {
107
107
  _forceState(state) {
108
108
  this._state$.next(state);
109
109
  }
110
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: AnimatedLifecycleDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
111
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.3", type: AnimatedLifecycleDirective, isStandalone: true, selector: "[etAnimatedLifecycle]", providers: [
110
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: AnimatedLifecycleDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
111
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.8", type: AnimatedLifecycleDirective, isStandalone: true, selector: "[etAnimatedLifecycle]", providers: [
112
112
  {
113
113
  provide: ANIMATED_LIFECYCLE_TOKEN,
114
114
  useExisting: AnimatedLifecycleDirective,
115
115
  },
116
116
  ], exportAs: ["etAnimatedLifecycle"], hostDirectives: [{ directive: i1.AnimatableDirective }], ngImport: i0 }); }
117
117
  }
118
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: AnimatedLifecycleDirective, decorators: [{
118
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: AnimatedLifecycleDirective, decorators: [{
119
119
  type: Directive,
120
120
  args: [{
121
121
  selector: '[etAnimatedLifecycle]',
@@ -57,6 +57,10 @@ export class AnimatedOverlayDirective {
57
57
  * @default false
58
58
  */
59
59
  this.autoResize = false;
60
+ /**
61
+ * Whether the animated overlay should shift when it is near the viewport boundary.
62
+ */
63
+ this.shift = true;
60
64
  /**
61
65
  * Whether the animated overlay should auto hide when the reference element is hidden.
62
66
  * @default false
@@ -84,6 +88,12 @@ export class AnimatedOverlayDirective {
84
88
  get isHidden() {
85
89
  return this._isHidden$.value;
86
90
  }
91
+ get canMount() {
92
+ return !this.isMounted && !this.isMounting;
93
+ }
94
+ get canUnmount() {
95
+ return this.isMounted && !this.isUnmounting;
96
+ }
87
97
  get portal() {
88
98
  return this._portal;
89
99
  }
@@ -96,7 +106,12 @@ export class AnimatedOverlayDirective {
96
106
  mount(config) {
97
107
  if (this.isMounted || this.isMounting) {
98
108
  if (isDevMode()) {
99
- console.warn('AnimatedOverlayDirective: The component is already mounted or mounting. Please unmount the component before mounting again.');
109
+ if (this.isMounted) {
110
+ console.warn('AnimatedOverlayDirective: The component is currently mounted. Please unmount the component before mounting again.');
111
+ }
112
+ if (this.isMounting) {
113
+ console.warn('AnimatedOverlayDirective: The component is already mounting. Please unmount the component before mounting again.');
114
+ }
100
115
  }
101
116
  return;
102
117
  }
@@ -108,7 +123,7 @@ export class AnimatedOverlayDirective {
108
123
  providers: providers ?? [],
109
124
  });
110
125
  this._overlayRef = this._overlayService.create();
111
- this._portal = this._portal ?? new ComponentPortal(component, this._viewContainerRef, injector);
126
+ this._portal = new ComponentPortal(component, this._viewContainerRef, injector);
112
127
  this._componentRef = this._overlayRef.attach(this._portal);
113
128
  if (data) {
114
129
  Object.assign(this._componentRef.instance, data);
@@ -148,7 +163,6 @@ export class AnimatedOverlayDirective {
148
163
  flip({
149
164
  fallbackPlacements: this.fallbackPlacements ?? undefined,
150
165
  fallbackAxisSideDirection: 'start',
151
- crossAxis: false,
152
166
  boundary,
153
167
  }),
154
168
  ...(this.autoResize
@@ -162,7 +176,9 @@ export class AnimatedOverlayDirective {
162
176
  }),
163
177
  ]
164
178
  : []),
165
- shift({ limiter: limitShift(), padding: this.viewportPadding ?? undefined, boundary }),
179
+ ...(this.shift
180
+ ? [shift({ limiter: limitShift(), padding: this.viewportPadding ?? undefined, boundary })]
181
+ : []),
166
182
  ...(floatingElArrow ? [arrow({ element: floatingElArrow, padding: this.arrowPadding ?? undefined })] : []),
167
183
  ...(this.autoHide ? [hide({ strategy: 'referenceHidden', boundary })] : []),
168
184
  ],
@@ -188,6 +204,9 @@ export class AnimatedOverlayDirective {
188
204
  if (!this._componentRef) {
189
205
  return;
190
206
  }
207
+ if (!this._componentRef.instance._animatedLifecycle) {
208
+ console.error('AnimatedOverlayDirective: The component does not have an AnimatedLifecycleDirective. Please add one to the component.');
209
+ }
191
210
  this._componentRef.instance._animatedLifecycle?.enter();
192
211
  this._componentRef.instance._animatedLifecycle?.state$
193
212
  .pipe(tap((s) => {
@@ -205,7 +224,12 @@ export class AnimatedOverlayDirective {
205
224
  unmount() {
206
225
  if (!this.isMounted || this.isUnmounting) {
207
226
  if (isDevMode()) {
208
- console.warn('AnimatedOverlayDirective: The component is not mounted or is already unmounting. Please call `mount` before calling `unmount` again.');
227
+ if (!this.isMounted) {
228
+ console.warn(`AnimatedOverlayDirective: The component is currently not mounted. Please call "mount" before calling "unmount" again.`);
229
+ }
230
+ if (this.isUnmounting) {
231
+ console.warn(`AnimatedOverlayDirective: The component is already unmounting. Please call "mount" before calling "unmount" again.`);
232
+ }
209
233
  }
210
234
  return;
211
235
  }
@@ -262,10 +286,10 @@ export class AnimatedOverlayDirective {
262
286
  this._isUnmounting$.next(false);
263
287
  this._afterClosed?.next();
264
288
  }
265
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: AnimatedOverlayDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
266
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.3", type: AnimatedOverlayDirective, isStandalone: true, inputs: { placement: "placement", fallbackPlacements: "fallbackPlacements", offset: "offset", arrowPadding: "arrowPadding", viewportPadding: "viewportPadding", autoResize: "autoResize", autoHide: "autoHide" }, host: { classAttribute: "et-animated-overlay" }, hostDirectives: [{ directive: i1.ObserveResizeDirective }], ngImport: i0 }); }
289
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: AnimatedOverlayDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
290
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.8", type: AnimatedOverlayDirective, isStandalone: true, inputs: { placement: "placement", fallbackPlacements: "fallbackPlacements", offset: "offset", arrowPadding: "arrowPadding", viewportPadding: "viewportPadding", autoResize: "autoResize", shift: "shift", autoHide: "autoHide" }, host: { classAttribute: "et-animated-overlay" }, hostDirectives: [{ directive: i1.ObserveResizeDirective }], ngImport: i0 }); }
267
291
  }
268
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: AnimatedOverlayDirective, decorators: [{
292
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: AnimatedOverlayDirective, decorators: [{
269
293
  type: Directive,
270
294
  args: [{
271
295
  standalone: true,
@@ -286,7 +310,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.3", ngImpor
286
310
  type: Input
287
311
  }], autoResize: [{
288
312
  type: Input
313
+ }], shift: [{
314
+ type: Input
289
315
  }], autoHide: [{
290
316
  type: Input
291
317
  }] } });
292
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"animated-overlay.directive.js","sourceRoot":"","sources":["../../../../../../../libs/core/src/lib/directives/animated-overlay/animated-overlay.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Overlay, OverlayRef } from '@angular/cdk/overlay';\nimport { ComponentPortal, ComponentType } from '@angular/cdk/portal';\nimport {\n  ComponentRef,\n  Directive,\n  ElementRef,\n  Injector,\n  Input,\n  NgZone,\n  StaticProvider,\n  ViewContainerRef,\n  inject,\n  isDevMode,\n} from '@angular/core';\nimport { ProvideThemeDirective } from '@ethlete/theming';\nimport {\n  OffsetOptions,\n  Padding,\n  Placement,\n  arrow,\n  autoUpdate,\n  computePosition,\n  flip,\n  hide,\n  limitShift,\n  offset,\n  shift,\n  size,\n} from '@floating-ui/dom';\nimport { BehaviorSubject, Subject, filter, take, takeUntil, tap } from 'rxjs';\nimport { createDestroy, nextFrame } from '../../utils';\nimport { AnimatedLifecycleDirective } from '../animated-lifecycle';\nimport { ObserveResizeDirective } from '../observe-resize';\nimport { RootBoundaryDirective } from '../root-boundary';\n\nexport interface AnimatedOverlayComponentBase {\n  _elementRef?: ElementRef<HTMLElement>;\n  _animatedLifecycle?: AnimatedLifecycleDirective;\n  _markForCheck?: () => void;\n  _setThemeFromProvider?: (provider: ProvideThemeDirective) => void;\n}\n\n@Directive({\n  standalone: true,\n  hostDirectives: [ObserveResizeDirective],\n  host: {\n    class: 'et-animated-overlay',\n  },\n})\nexport class AnimatedOverlayDirective<T extends AnimatedOverlayComponentBase> {\n  private readonly _destroy$ = createDestroy();\n  private readonly _overlayService = inject(Overlay);\n  private readonly _injector = inject(Injector);\n  private readonly _viewContainerRef = inject(ViewContainerRef);\n  private readonly _zone = inject(NgZone);\n  private readonly _elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n  private readonly _observeResize = inject(ObserveResizeDirective);\n  private readonly _rootBoundary = inject(RootBoundaryDirective, { optional: true });\n\n  private _portal: ComponentPortal<T> | null = null;\n  private _overlayRef: OverlayRef | null = null;\n  private _componentRef: ComponentRef<T> | null = null;\n  private _floatingElCleanupFn: (() => void) | null = null;\n\n  private _beforeOpened: Subject<void> | null = null;\n  private _afterOpened: Subject<void> | null = null;\n  private _beforeClosed: Subject<void> | null = null;\n  private _afterClosed: Subject<void> | null = null;\n\n  private readonly _isMounted$ = new BehaviorSubject<boolean>(false);\n  private readonly _isMounting$ = new BehaviorSubject<boolean>(false);\n  private readonly _isUnmounting$ = new BehaviorSubject<boolean>(false);\n  private readonly _isHidden$ = new BehaviorSubject<boolean>(false);\n\n  /**\n   * The placement of the animated overlay.\n   * @default undefined\n   */\n  @Input()\n  placement?: Placement = 'bottom';\n\n  /**\n   * The allowed auto placements of the animated overlay.\n   * @see https://floating-ui.com/docs/flip#fallbackplacements\n   */\n  @Input()\n  fallbackPlacements?: Placement[];\n\n  /**\n   * The offset of the animated overlay.\n   * @see https://floating-ui.com/docs/offset\n   */\n  @Input()\n  offset: OffsetOptions | null = null;\n\n  /**\n   * The arrow padding.\n   * @see https://floating-ui.com/docs/arrow#padding\n   * @default 4\n   */\n  @Input()\n  arrowPadding: Padding | null = 4;\n\n  /**\n   * The viewport padding.\n   * @default 8\n   */\n  @Input()\n  viewportPadding: Padding | null = 8;\n\n  /**\n   * Whether the animated overlay should auto resize to fit the available space.\n   * Useful for things like selects where the list of options might be longer than the available space.\n   * @default false\n   */\n  @Input()\n  autoResize = false;\n\n  /**\n   * Whether the animated overlay should auto hide when the reference element is hidden.\n   * @default false\n   */\n  @Input()\n  autoHide = false;\n\n  get isMounted() {\n    return this._isMounted$.value;\n  }\n\n  get isMounted$() {\n    return this._isMounted$.asObservable();\n  }\n\n  get isMounting() {\n    return this._isMounting$.value;\n  }\n\n  get isMounting$() {\n    return this._isMounting$.asObservable();\n  }\n\n  get isUnmounting() {\n    return this._isUnmounting$.value;\n  }\n\n  get isHidden$() {\n    return this._isHidden$.asObservable();\n  }\n\n  get isHidden() {\n    return this._isHidden$.value;\n  }\n\n  get portal() {\n    return this._portal;\n  }\n\n  get overlayRef() {\n    return this._overlayRef;\n  }\n\n  get componentRef() {\n    return this._componentRef;\n  }\n\n  mount(config: {\n    component: ComponentType<T>;\n    providers?: StaticProvider[];\n    data?: Partial<T>;\n    mirrorWidth?: boolean;\n    themeProvider?: ProvideThemeDirective | null;\n  }) {\n    if (this.isMounted || this.isMounting) {\n      if (isDevMode()) {\n        console.warn(\n          'AnimatedOverlayDirective: The component is already mounted or mounting. Please unmount the component before mounting again.',\n        );\n      }\n\n      return;\n    }\n\n    this._isMounting$.next(true);\n\n    const { component, providers, data, mirrorWidth, themeProvider } = config;\n\n    this._beforeOpened?.next();\n\n    const injector = Injector.create({\n      parent: this._injector,\n      providers: providers ?? [],\n    });\n\n    this._overlayRef = this._overlayService.create();\n\n    this._portal = this._portal ?? new ComponentPortal(component, this._viewContainerRef, injector);\n    this._componentRef = this._overlayRef.attach(this._portal);\n\n    if (data) {\n      Object.assign(this._componentRef.instance, data);\n    }\n\n    this._componentRef.instance._markForCheck?.();\n\n    if (themeProvider) {\n      this._componentRef.instance._setThemeFromProvider?.(themeProvider);\n    }\n\n    if (mirrorWidth) {\n      this._overlayRef.updateSize({\n        width: this._elementRef.nativeElement.offsetWidth,\n      });\n\n      this._observeResize.valueChange\n        .pipe(\n          tap(() => {\n            this._overlayRef?.updateSize({\n              width: this._elementRef.nativeElement.offsetWidth,\n            });\n          }),\n          takeUntil(this._destroy$),\n          takeUntil(this.afterClosed()),\n        )\n        .subscribe();\n    }\n\n    this._zone.runOutsideAngular(() => {\n      if (!this._componentRef) {\n        return;\n      }\n\n      const floatingEl = this._componentRef.location.nativeElement as HTMLElement;\n      const floatingElArrow = this._componentRef.instance._elementRef?.nativeElement.querySelector(\n        '[et-floating-arrow]',\n      ) as HTMLElement | null;\n\n      floatingEl.classList.add('et-floating-element');\n\n      const refEl = this._elementRef.nativeElement;\n      const boundary = this._rootBoundary?.boundaryElement ?? undefined;\n\n      this._floatingElCleanupFn = autoUpdate(refEl, floatingEl, () => {\n        if (!this._componentRef) return;\n\n        computePosition(refEl, floatingEl, {\n          placement: this.placement,\n\n          middleware: [\n            ...(this.offset ? [offset(this.offset)] : []),\n            flip({\n              fallbackPlacements: this.fallbackPlacements ?? undefined,\n              fallbackAxisSideDirection: 'start',\n              crossAxis: false,\n              boundary,\n            }),\n            ...(this.autoResize\n              ? [\n                  size({\n                    padding: this.viewportPadding ?? undefined,\n                    apply({ availableHeight, availableWidth }) {\n                      floatingEl.style.setProperty('--et-floating-max-width', `${availableWidth}px`);\n                      floatingEl.style.setProperty('--et-floating-max-height', `${availableHeight}px`);\n                    },\n                  }),\n                ]\n              : []),\n            shift({ limiter: limitShift(), padding: this.viewportPadding ?? undefined, boundary }),\n            ...(floatingElArrow ? [arrow({ element: floatingElArrow, padding: this.arrowPadding ?? undefined })] : []),\n            ...(this.autoHide ? [hide({ strategy: 'referenceHidden', boundary })] : []),\n          ],\n        }).then(({ x, y, placement, middlewareData }) => {\n          floatingEl.style.setProperty('--et-floating-translate', `translate3d(${x}px, ${y}px, 0)`);\n          floatingEl.setAttribute('et-floating-placement', placement);\n\n          if (middlewareData.arrow && floatingElArrow) {\n            const { x: arrowX, y: arrowY } = middlewareData.arrow;\n\n            floatingEl.style.setProperty(\n              '--et-floating-arrow-translate',\n              `translate3d(${arrowX ?? 0}px, ${arrowY ?? 0}px, 0)`,\n            );\n          }\n\n          if (middlewareData.hide?.referenceHidden) {\n            floatingEl.classList.add('et-floating-element--hidden');\n            this._isHidden$.next(true);\n          } else {\n            floatingEl.classList.remove('et-floating-element--hidden');\n            this._isHidden$.next(false);\n          }\n        });\n      });\n\n      // We need to wait for the  content to be rendered\n      nextFrame(() => {\n        if (!this._componentRef) {\n          return;\n        }\n\n        this._componentRef.instance._animatedLifecycle?.enter();\n\n        this._componentRef.instance._animatedLifecycle?.state$\n          .pipe(\n            tap((s) => {\n              if (s === 'entered') {\n                this._afterOpened?.next();\n              }\n            }),\n            take(1),\n            takeUntil(this._destroy$),\n          )\n          .subscribe();\n\n        this._isMounted$.next(true);\n        this._isMounting$.next(false);\n      });\n    });\n\n    return this._componentRef.instance;\n  }\n\n  unmount() {\n    if (!this.isMounted || this.isUnmounting) {\n      if (isDevMode()) {\n        console.warn(\n          'AnimatedOverlayDirective: The component is not mounted or is already unmounting. Please call `mount` before calling `unmount` again.',\n        );\n      }\n\n      return;\n    }\n\n    if (!this._componentRef) {\n      return;\n    }\n\n    if (this.isHidden) {\n      return;\n    }\n\n    this._isUnmounting$.next(true);\n\n    this._beforeClosed?.next();\n\n    this._componentRef.instance._animatedLifecycle?.leave();\n\n    this._componentRef.instance._animatedLifecycle?.state$\n      .pipe(\n        filter((s) => s === 'left'),\n        take(1),\n      )\n      .subscribe(() => this._destroy());\n  }\n\n  beforeOpened() {\n    if (!this._beforeOpened) {\n      this._beforeOpened = new Subject();\n    }\n\n    return this._beforeOpened;\n  }\n\n  afterOpened() {\n    if (!this._afterOpened) {\n      this._afterOpened = new Subject();\n    }\n\n    return this._afterOpened;\n  }\n\n  beforeClosed() {\n    if (!this._beforeClosed) {\n      this._beforeClosed = new Subject();\n    }\n\n    return this._beforeClosed;\n  }\n\n  afterClosed() {\n    if (!this._afterClosed) {\n      this._afterClosed = new Subject();\n    }\n\n    return this._afterClosed;\n  }\n\n  _destroy() {\n    this._zone.runOutsideAngular(() => {\n      this._floatingElCleanupFn?.();\n    });\n\n    if (this._overlayRef) {\n      this._overlayRef.dispose();\n      this._overlayRef = null;\n    }\n\n    if (this._componentRef) {\n      this._componentRef.destroy();\n      this._componentRef = null;\n    }\n\n    this._isMounted$.next(false);\n    this._isUnmounting$.next(false);\n\n    this._afterClosed?.next();\n  }\n}\n"]}
318
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"animated-overlay.directive.js","sourceRoot":"","sources":["../../../../../../../libs/core/src/lib/directives/animated-overlay/animated-overlay.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Overlay, OverlayRef } from '@angular/cdk/overlay';\nimport { ComponentPortal, ComponentType } from '@angular/cdk/portal';\nimport {\n  ComponentRef,\n  Directive,\n  ElementRef,\n  Injector,\n  Input,\n  NgZone,\n  StaticProvider,\n  ViewContainerRef,\n  inject,\n  isDevMode,\n} from '@angular/core';\nimport { ProvideThemeDirective } from '@ethlete/theming';\nimport {\n  OffsetOptions,\n  Padding,\n  Placement,\n  arrow,\n  autoUpdate,\n  computePosition,\n  flip,\n  hide,\n  limitShift,\n  offset,\n  shift,\n  size,\n} from '@floating-ui/dom';\nimport { BehaviorSubject, Subject, filter, take, takeUntil, tap } from 'rxjs';\nimport { createDestroy, nextFrame } from '../../utils';\nimport { AnimatedLifecycleDirective } from '../animated-lifecycle';\nimport { ObserveResizeDirective } from '../observe-resize';\nimport { RootBoundaryDirective } from '../root-boundary';\n\nexport interface AnimatedOverlayComponentBase {\n  _elementRef?: ElementRef<HTMLElement>;\n  _animatedLifecycle?: AnimatedLifecycleDirective;\n  _markForCheck?: () => void;\n  _setThemeFromProvider?: (provider: ProvideThemeDirective) => void;\n}\n\n@Directive({\n  standalone: true,\n  hostDirectives: [ObserveResizeDirective],\n  host: {\n    class: 'et-animated-overlay',\n  },\n})\nexport class AnimatedOverlayDirective<T extends AnimatedOverlayComponentBase> {\n  private readonly _destroy$ = createDestroy();\n  private readonly _overlayService = inject(Overlay);\n  private readonly _injector = inject(Injector);\n  private readonly _viewContainerRef = inject(ViewContainerRef);\n  private readonly _zone = inject(NgZone);\n  private readonly _elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n  private readonly _observeResize = inject(ObserveResizeDirective);\n  private readonly _rootBoundary = inject(RootBoundaryDirective, { optional: true });\n\n  private _portal: ComponentPortal<T> | null = null;\n  private _overlayRef: OverlayRef | null = null;\n  private _componentRef: ComponentRef<T> | null = null;\n  private _floatingElCleanupFn: (() => void) | null = null;\n\n  private _beforeOpened: Subject<void> | null = null;\n  private _afterOpened: Subject<void> | null = null;\n  private _beforeClosed: Subject<void> | null = null;\n  private _afterClosed: Subject<void> | null = null;\n\n  private readonly _isMounted$ = new BehaviorSubject<boolean>(false);\n  private readonly _isMounting$ = new BehaviorSubject<boolean>(false);\n  private readonly _isUnmounting$ = new BehaviorSubject<boolean>(false);\n  private readonly _isHidden$ = new BehaviorSubject<boolean>(false);\n\n  /**\n   * The placement of the animated overlay.\n   * @default undefined\n   */\n  @Input()\n  placement?: Placement = 'bottom';\n\n  /**\n   * The allowed auto placements of the animated overlay.\n   * @see https://floating-ui.com/docs/flip#fallbackplacements\n   */\n  @Input()\n  fallbackPlacements?: Placement[];\n\n  /**\n   * The offset of the animated overlay.\n   * @see https://floating-ui.com/docs/offset\n   */\n  @Input()\n  offset: OffsetOptions | null = null;\n\n  /**\n   * The arrow padding.\n   * @see https://floating-ui.com/docs/arrow#padding\n   * @default 4\n   */\n  @Input()\n  arrowPadding: Padding | null = 4;\n\n  /**\n   * The viewport padding.\n   * @default 8\n   */\n  @Input()\n  viewportPadding: Padding | null = 8;\n\n  /**\n   * Whether the animated overlay should auto resize to fit the available space.\n   * Useful for things like selects where the list of options might be longer than the available space.\n   * @default false\n   */\n  @Input()\n  autoResize = false;\n\n  /**\n   * Whether the animated overlay should shift when it is near the viewport boundary.\n   */\n  @Input()\n  shift = true;\n\n  /**\n   * Whether the animated overlay should auto hide when the reference element is hidden.\n   * @default false\n   */\n  @Input()\n  autoHide = false;\n\n  get isMounted() {\n    return this._isMounted$.value;\n  }\n\n  get isMounted$() {\n    return this._isMounted$.asObservable();\n  }\n\n  get isMounting() {\n    return this._isMounting$.value;\n  }\n\n  get isMounting$() {\n    return this._isMounting$.asObservable();\n  }\n\n  get isUnmounting() {\n    return this._isUnmounting$.value;\n  }\n\n  get isHidden$() {\n    return this._isHidden$.asObservable();\n  }\n\n  get isHidden() {\n    return this._isHidden$.value;\n  }\n\n  get canMount() {\n    return !this.isMounted && !this.isMounting;\n  }\n\n  get canUnmount() {\n    return this.isMounted && !this.isUnmounting;\n  }\n\n  get portal() {\n    return this._portal;\n  }\n\n  get overlayRef() {\n    return this._overlayRef;\n  }\n\n  get componentRef() {\n    return this._componentRef;\n  }\n\n  mount(config: {\n    component: ComponentType<T>;\n    providers?: StaticProvider[];\n    data?: Partial<T>;\n    mirrorWidth?: boolean;\n    themeProvider?: ProvideThemeDirective | null;\n  }) {\n    if (this.isMounted || this.isMounting) {\n      if (isDevMode()) {\n        if (this.isMounted) {\n          console.warn(\n            'AnimatedOverlayDirective: The component is currently mounted. Please unmount the component before mounting again.',\n          );\n        }\n\n        if (this.isMounting) {\n          console.warn(\n            'AnimatedOverlayDirective: The component is already mounting. Please unmount the component before mounting again.',\n          );\n        }\n      }\n\n      return;\n    }\n\n    this._isMounting$.next(true);\n\n    const { component, providers, data, mirrorWidth, themeProvider } = config;\n\n    this._beforeOpened?.next();\n\n    const injector = Injector.create({\n      parent: this._injector,\n      providers: providers ?? [],\n    });\n\n    this._overlayRef = this._overlayService.create();\n\n    this._portal = new ComponentPortal(component, this._viewContainerRef, injector);\n    this._componentRef = this._overlayRef.attach(this._portal);\n\n    if (data) {\n      Object.assign(this._componentRef.instance, data);\n    }\n\n    this._componentRef.instance._markForCheck?.();\n\n    if (themeProvider) {\n      this._componentRef.instance._setThemeFromProvider?.(themeProvider);\n    }\n\n    if (mirrorWidth) {\n      this._overlayRef.updateSize({\n        width: this._elementRef.nativeElement.offsetWidth,\n      });\n\n      this._observeResize.valueChange\n        .pipe(\n          tap(() => {\n            this._overlayRef?.updateSize({\n              width: this._elementRef.nativeElement.offsetWidth,\n            });\n          }),\n          takeUntil(this._destroy$),\n          takeUntil(this.afterClosed()),\n        )\n        .subscribe();\n    }\n\n    this._zone.runOutsideAngular(() => {\n      if (!this._componentRef) {\n        return;\n      }\n\n      const floatingEl = this._componentRef.location.nativeElement as HTMLElement;\n      const floatingElArrow = this._componentRef.instance._elementRef?.nativeElement.querySelector(\n        '[et-floating-arrow]',\n      ) as HTMLElement | null;\n\n      floatingEl.classList.add('et-floating-element');\n\n      const refEl = this._elementRef.nativeElement;\n      const boundary = this._rootBoundary?.boundaryElement ?? undefined;\n\n      this._floatingElCleanupFn = autoUpdate(refEl, floatingEl, () => {\n        if (!this._componentRef) return;\n\n        computePosition(refEl, floatingEl, {\n          placement: this.placement,\n\n          middleware: [\n            ...(this.offset ? [offset(this.offset)] : []),\n            flip({\n              fallbackPlacements: this.fallbackPlacements ?? undefined,\n              fallbackAxisSideDirection: 'start',\n              boundary,\n            }),\n            ...(this.autoResize\n              ? [\n                  size({\n                    padding: this.viewportPadding ?? undefined,\n                    apply({ availableHeight, availableWidth }) {\n                      floatingEl.style.setProperty('--et-floating-max-width', `${availableWidth}px`);\n                      floatingEl.style.setProperty('--et-floating-max-height', `${availableHeight}px`);\n                    },\n                  }),\n                ]\n              : []),\n            ...(this.shift\n              ? [shift({ limiter: limitShift(), padding: this.viewportPadding ?? undefined, boundary })]\n              : []),\n            ...(floatingElArrow ? [arrow({ element: floatingElArrow, padding: this.arrowPadding ?? undefined })] : []),\n            ...(this.autoHide ? [hide({ strategy: 'referenceHidden', boundary })] : []),\n          ],\n        }).then(({ x, y, placement, middlewareData }) => {\n          floatingEl.style.setProperty('--et-floating-translate', `translate3d(${x}px, ${y}px, 0)`);\n          floatingEl.setAttribute('et-floating-placement', placement);\n\n          if (middlewareData.arrow && floatingElArrow) {\n            const { x: arrowX, y: arrowY } = middlewareData.arrow;\n\n            floatingEl.style.setProperty(\n              '--et-floating-arrow-translate',\n              `translate3d(${arrowX ?? 0}px, ${arrowY ?? 0}px, 0)`,\n            );\n          }\n\n          if (middlewareData.hide?.referenceHidden) {\n            floatingEl.classList.add('et-floating-element--hidden');\n            this._isHidden$.next(true);\n          } else {\n            floatingEl.classList.remove('et-floating-element--hidden');\n            this._isHidden$.next(false);\n          }\n        });\n      });\n\n      // We need to wait for the  content to be rendered\n      nextFrame(() => {\n        if (!this._componentRef) {\n          return;\n        }\n\n        if (!this._componentRef.instance._animatedLifecycle) {\n          console.error(\n            'AnimatedOverlayDirective: The component does not have an AnimatedLifecycleDirective. Please add one to the component.',\n          );\n        }\n\n        this._componentRef.instance._animatedLifecycle?.enter();\n\n        this._componentRef.instance._animatedLifecycle?.state$\n          .pipe(\n            tap((s) => {\n              if (s === 'entered') {\n                this._afterOpened?.next();\n              }\n            }),\n            take(1),\n            takeUntil(this._destroy$),\n          )\n          .subscribe();\n\n        this._isMounted$.next(true);\n        this._isMounting$.next(false);\n      });\n    });\n\n    return this._componentRef.instance;\n  }\n\n  unmount() {\n    if (!this.isMounted || this.isUnmounting) {\n      if (isDevMode()) {\n        if (!this.isMounted) {\n          console.warn(\n            `AnimatedOverlayDirective: The component is currently not mounted. Please call \"mount\" before calling \"unmount\" again.`,\n          );\n        }\n\n        if (this.isUnmounting) {\n          console.warn(\n            `AnimatedOverlayDirective: The component is already unmounting. Please call \"mount\" before calling \"unmount\" again.`,\n          );\n        }\n      }\n\n      return;\n    }\n\n    if (!this._componentRef) {\n      return;\n    }\n\n    if (this.isHidden) {\n      return;\n    }\n\n    this._isUnmounting$.next(true);\n\n    this._beforeClosed?.next();\n\n    this._componentRef.instance._animatedLifecycle?.leave();\n\n    this._componentRef.instance._animatedLifecycle?.state$\n      .pipe(\n        filter((s) => s === 'left'),\n        take(1),\n      )\n      .subscribe(() => this._destroy());\n  }\n\n  beforeOpened() {\n    if (!this._beforeOpened) {\n      this._beforeOpened = new Subject();\n    }\n\n    return this._beforeOpened;\n  }\n\n  afterOpened() {\n    if (!this._afterOpened) {\n      this._afterOpened = new Subject();\n    }\n\n    return this._afterOpened;\n  }\n\n  beforeClosed() {\n    if (!this._beforeClosed) {\n      this._beforeClosed = new Subject();\n    }\n\n    return this._beforeClosed;\n  }\n\n  afterClosed() {\n    if (!this._afterClosed) {\n      this._afterClosed = new Subject();\n    }\n\n    return this._afterClosed;\n  }\n\n  _destroy() {\n    this._zone.runOutsideAngular(() => {\n      this._floatingElCleanupFn?.();\n    });\n\n    if (this._overlayRef) {\n      this._overlayRef.dispose();\n      this._overlayRef = null;\n    }\n\n    if (this._componentRef) {\n      this._componentRef.destroy();\n      this._componentRef = null;\n    }\n\n    this._isMounted$.next(false);\n    this._isUnmounting$.next(false);\n\n    this._afterClosed?.next();\n  }\n}\n"]}
@@ -22,10 +22,10 @@ export class ClickOutsideDirective {
22
22
  ngOnDestroy() {
23
23
  this._subscription?.unsubscribe();
24
24
  }
25
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: ClickOutsideDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
26
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.3", type: ClickOutsideDirective, isStandalone: true, selector: "[etClickOutside]", outputs: { etClickOutside: "etClickOutside" }, ngImport: i0 }); }
25
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: ClickOutsideDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
26
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.8", type: ClickOutsideDirective, isStandalone: true, selector: "[etClickOutside]", outputs: { etClickOutside: "etClickOutside" }, ngImport: i0 }); }
27
27
  }
28
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: ClickOutsideDirective, decorators: [{
28
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: ClickOutsideDirective, decorators: [{
29
29
  type: Directive,
30
30
  args: [{
31
31
  selector: '[etClickOutside]',
@@ -145,10 +145,10 @@ export class CursorDragScrollDirective {
145
145
  this._elementRef.nativeElement.style.cursor = 'default';
146
146
  }
147
147
  }
148
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: CursorDragScrollDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
149
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.3", type: CursorDragScrollDirective, isStandalone: true, selector: "[etCursorDragScroll]", inputs: { enabled: ["etCursorDragScroll", "enabled"], allowedDirection: "allowedDirection" }, outputs: { cursorDragStart: "cursorDragStart", cursorDragMove: "cursorDragMove", cursorDragEnd: "cursorDragEnd" }, exportAs: ["etCursorDragScroll"], ngImport: i0 }); }
148
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: CursorDragScrollDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
149
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.8", type: CursorDragScrollDirective, isStandalone: true, selector: "[etCursorDragScroll]", inputs: { enabled: ["etCursorDragScroll", "enabled"], allowedDirection: "allowedDirection" }, outputs: { cursorDragStart: "cursorDragStart", cursorDragMove: "cursorDragMove", cursorDragEnd: "cursorDragEnd" }, exportAs: ["etCursorDragScroll"], ngImport: i0 }); }
150
150
  }
151
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: CursorDragScrollDirective, decorators: [{
151
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: CursorDragScrollDirective, decorators: [{
152
152
  type: Directive,
153
153
  args: [{
154
154
  selector: '[etCursorDragScroll]',
@@ -16,15 +16,15 @@ export class DebugDirective {
16
16
  set sDebug(value) {
17
17
  this._debug.set(value);
18
18
  }
19
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: DebugDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
20
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "17.0.3", type: DebugDirective, isStandalone: true, selector: "[etDebug]", inputs: { sDebug: ["etDebug", "sDebug", booleanAttribute] }, providers: [
19
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: DebugDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
20
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "17.0.8", type: DebugDirective, isStandalone: true, selector: "[etDebug]", inputs: { sDebug: ["etDebug", "sDebug", booleanAttribute] }, providers: [
21
21
  {
22
22
  provide: DEBUG_TOKEN,
23
23
  useExisting: DebugDirective,
24
24
  },
25
25
  ], exportAs: ["etDebug"], ngImport: i0 }); }
26
26
  }
27
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: DebugDirective, decorators: [{
27
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: DebugDirective, decorators: [{
28
28
  type: Directive,
29
29
  args: [{
30
30
  selector: '[etDebug]',
@@ -30,15 +30,15 @@ export class DelayableDirective {
30
30
  }
31
31
  this._isDelayed$.next(val);
32
32
  }
33
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: DelayableDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
34
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.3", type: DelayableDirective, isStandalone: true, selector: "[etDelayable]", providers: [
33
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: DelayableDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
34
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.8", type: DelayableDirective, isStandalone: true, selector: "[etDelayable]", providers: [
35
35
  {
36
36
  provide: DELAYABLE_TOKEN,
37
37
  useExisting: DelayableDirective,
38
38
  },
39
39
  ], exportAs: ["etDelayable"], ngImport: i0 }); }
40
40
  }
41
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: DelayableDirective, decorators: [{
41
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: DelayableDirective, decorators: [{
42
42
  type: Directive,
43
43
  args: [{
44
44
  selector: '[etDelayable]',
@@ -6,15 +6,15 @@ export class IsActiveElementDirective {
6
6
  this.elementRef = inject(ElementRef);
7
7
  this.isActiveElement = false;
8
8
  }
9
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: IsActiveElementDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
10
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "17.0.3", type: IsActiveElementDirective, isStandalone: true, selector: "[etIsActiveElement]", inputs: { isActiveElement: ["etIsActiveElement", "isActiveElement", booleanAttribute] }, providers: [
9
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: IsActiveElementDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
10
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "17.0.8", type: IsActiveElementDirective, isStandalone: true, selector: "[etIsActiveElement]", inputs: { isActiveElement: ["etIsActiveElement", "isActiveElement", booleanAttribute] }, providers: [
11
11
  {
12
12
  provide: IS_ACTIVE_ELEMENT,
13
13
  useExisting: IsActiveElementDirective,
14
14
  },
15
15
  ], ngImport: i0 }); }
16
16
  }
17
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: IsActiveElementDirective, decorators: [{
17
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: IsActiveElementDirective, decorators: [{
18
18
  type: Directive,
19
19
  args: [{
20
20
  selector: '[etIsActiveElement]',
@@ -6,15 +6,15 @@ export class IsElementDirective {
6
6
  this.elementRef = inject(ElementRef);
7
7
  this.isElement = false;
8
8
  }
9
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: IsElementDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
10
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "17.0.3", type: IsElementDirective, isStandalone: true, selector: "[etIsElement]", inputs: { isElement: ["etIsElement", "isElement", booleanAttribute] }, providers: [
9
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: IsElementDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
10
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "17.0.8", type: IsElementDirective, isStandalone: true, selector: "[etIsElement]", inputs: { isElement: ["etIsElement", "isElement", booleanAttribute] }, providers: [
11
11
  {
12
12
  provide: IS_ELEMENT,
13
13
  useExisting: IsElementDirective,
14
14
  },
15
15
  ], ngImport: i0 }); }
16
16
  }
17
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: IsElementDirective, decorators: [{
17
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: IsElementDirective, decorators: [{
18
18
  type: Directive,
19
19
  args: [{
20
20
  selector: '[etIsElement]',
@@ -24,10 +24,10 @@ export class LetDirective {
24
24
  }
25
25
  }
26
26
  }
27
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: LetDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
28
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.3", type: LetDirective, isStandalone: true, selector: "[etLet]", inputs: { etLet: "etLet" }, ngImport: i0 }); }
27
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: LetDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
28
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.8", type: LetDirective, isStandalone: true, selector: "[etLet]", inputs: { etLet: "etLet" }, ngImport: i0 }); }
29
29
  }
30
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: LetDirective, decorators: [{
30
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: LetDirective, decorators: [{
31
31
  type: Directive,
32
32
  args: [{
33
33
  selector: '[etLet]',
@@ -44,10 +44,10 @@ export class ObserveContentDirective {
44
44
  _unsubscribe() {
45
45
  this._currentSubscription?.unsubscribe();
46
46
  }
47
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: ObserveContentDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
48
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.3", type: ObserveContentDirective, isStandalone: true, selector: "[etObserveContent]", inputs: { disabled: ["etObserveContentDisabled", "disabled"], debounce: ["etObserveContentDebounce", "debounce"] }, outputs: { valueChange: "etObserveContent" }, exportAs: ["etObserveContent"], ngImport: i0 }); }
47
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: ObserveContentDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
48
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.8", type: ObserveContentDirective, isStandalone: true, selector: "[etObserveContent]", inputs: { disabled: ["etObserveContentDisabled", "disabled"], debounce: ["etObserveContentDebounce", "debounce"] }, outputs: { valueChange: "etObserveContent" }, exportAs: ["etObserveContent"], ngImport: i0 }); }
49
49
  }
50
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: ObserveContentDirective, decorators: [{
50
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: ObserveContentDirective, decorators: [{
51
51
  type: Directive,
52
52
  args: [{
53
53
  selector: '[etObserveContent]',
@@ -44,10 +44,10 @@ export class ObserveResizeDirective {
44
44
  _unsubscribe() {
45
45
  this._currentSubscription?.unsubscribe();
46
46
  }
47
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: ObserveResizeDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
48
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.3", type: ObserveResizeDirective, isStandalone: true, selector: "[etObserveResize]", inputs: { disabled: ["etObserveResizeDisabled", "disabled"], debounce: ["etObserveResizeDebounce", "debounce"] }, outputs: { valueChange: "etObserveResize" }, exportAs: ["etObserveResize"], ngImport: i0 }); }
47
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: ObserveResizeDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
48
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.8", type: ObserveResizeDirective, isStandalone: true, selector: "[etObserveResize]", inputs: { disabled: ["etObserveResizeDisabled", "disabled"], debounce: ["etObserveResizeDebounce", "debounce"] }, outputs: { valueChange: "etObserveResize" }, exportAs: ["etObserveResize"], ngImport: i0 }); }
49
49
  }
50
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: ObserveResizeDirective, decorators: [{
50
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: ObserveResizeDirective, decorators: [{
51
51
  type: Directive,
52
52
  args: [{
53
53
  selector: '[etObserveResize]',
@@ -147,15 +147,15 @@ export class ObserveScrollStateDirective {
147
147
  }
148
148
  return element;
149
149
  }
150
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: ObserveScrollStateDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
151
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "17.0.3", type: ObserveScrollStateDirective, isStandalone: true, selector: "[etObserveScrollState]", inputs: { rootMargin: ["rootMargin", "rootMargin", numberAttribute], observerThreshold: "observerThreshold" }, outputs: { valueChange: "etObserveScrollState" }, providers: [
150
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: ObserveScrollStateDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
151
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "17.0.8", type: ObserveScrollStateDirective, isStandalone: true, selector: "[etObserveScrollState]", inputs: { rootMargin: ["rootMargin", "rootMargin", numberAttribute], observerThreshold: "observerThreshold" }, outputs: { valueChange: "etObserveScrollState" }, providers: [
152
152
  {
153
153
  provide: OBSERVE_SCROLL_STATE,
154
154
  useExisting: ObserveScrollStateDirective,
155
155
  },
156
156
  ], exportAs: ["etObserveScrollState"], ngImport: i0 }); }
157
157
  }
158
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: ObserveScrollStateDirective, decorators: [{
158
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: ObserveScrollStateDirective, decorators: [{
159
159
  type: Directive,
160
160
  args: [{
161
161
  selector: '[etObserveScrollState]',
@@ -51,15 +51,15 @@ export class ObserveVisibilityDirective {
51
51
  }))
52
52
  .subscribe();
53
53
  }
54
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: ObserveVisibilityDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
55
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.3", type: ObserveVisibilityDirective, isStandalone: true, selector: "[etObserveVisibility]", outputs: { etObserveVisibility: "etObserveVisibility" }, host: { classAttribute: "et-observe-visibility" }, providers: [
54
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: ObserveVisibilityDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
55
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.8", type: ObserveVisibilityDirective, isStandalone: true, selector: "[etObserveVisibility]", outputs: { etObserveVisibility: "etObserveVisibility" }, host: { classAttribute: "et-observe-visibility" }, providers: [
56
56
  {
57
57
  provide: OBSERVE_VISIBILITY_TOKEN,
58
58
  useExisting: ObserveVisibilityDirective,
59
59
  },
60
60
  ], ngImport: i0 }); }
61
61
  }
62
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: ObserveVisibilityDirective, decorators: [{
62
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: ObserveVisibilityDirective, decorators: [{
63
63
  type: Directive,
64
64
  args: [{
65
65
  selector: '[etObserveVisibility]',
@@ -19,10 +19,10 @@ export class RepeatDirective {
19
19
  this._viewContainerRef.createEmbeddedView(this._mainTemplateRef);
20
20
  }
21
21
  }
22
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: RepeatDirective, deps: [{ token: i0.TemplateRef }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Directive }); }
23
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.3", type: RepeatDirective, isStandalone: true, selector: "[etRepeat]", inputs: { repeatCount: ["etRepeat", "repeatCount"] }, ngImport: i0 }); }
22
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: RepeatDirective, deps: [{ token: i0.TemplateRef }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Directive }); }
23
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.8", type: RepeatDirective, isStandalone: true, selector: "[etRepeat]", inputs: { repeatCount: ["etRepeat", "repeatCount"] }, ngImport: i0 }); }
24
24
  }
25
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: RepeatDirective, decorators: [{
25
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: RepeatDirective, decorators: [{
26
26
  type: Directive,
27
27
  args: [{
28
28
  selector: '[etRepeat]',
@@ -12,15 +12,15 @@ export class RootBoundaryDirective {
12
12
  set boundaryElement(v) {
13
13
  this._boundaryElement = v;
14
14
  }
15
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: RootBoundaryDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
16
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.3", type: RootBoundaryDirective, isStandalone: true, selector: "[etRootBoundary]", providers: [
15
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: RootBoundaryDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
16
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.8", type: RootBoundaryDirective, isStandalone: true, selector: "[etRootBoundary]", providers: [
17
17
  {
18
18
  provide: ROOT_BOUNDARY_TOKEN,
19
19
  useExisting: RootBoundaryDirective,
20
20
  },
21
21
  ], ngImport: i0 }); }
22
22
  }
23
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: RootBoundaryDirective, decorators: [{
23
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: RootBoundaryDirective, decorators: [{
24
24
  type: Directive,
25
25
  args: [{
26
26
  selector: '[etRootBoundary]',