@ethlete/core 1.10.0 → 2.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/components/structured-data/structured-data.component.mjs +38 -0
- package/esm2022/lib/directives/animatable/animatable.directive.mjs +114 -0
- package/esm2022/lib/directives/animated-lifecycle/animated-lifecycle.directive.mjs +113 -0
- package/esm2022/lib/directives/animated-lifecycle/index.mjs +2 -0
- package/esm2022/lib/directives/animated-overlay/animated-overlay.directive.mjs +181 -0
- package/esm2022/lib/directives/animated-overlay/public-api.mjs +2 -0
- package/esm2022/lib/directives/click-outside/click-outside.directive.mjs +38 -0
- package/esm2022/lib/directives/cursor-drag-scroll/cursor-drag-scroll.directive.mjs +147 -0
- package/esm2022/lib/directives/delayable/delayable.directive.mjs +56 -0
- package/esm2022/lib/directives/let/let.directive.mjs +41 -0
- package/esm2022/lib/directives/observe-content/observe-content.directive.mjs +69 -0
- package/esm2022/lib/directives/observe-resize/observe-resize.directive.mjs +69 -0
- package/esm2022/lib/directives/observe-scroll-state/observe-scroll-state.directive.mjs +175 -0
- package/esm2022/lib/directives/public-api.mjs +16 -0
- package/esm2022/lib/directives/repeat/repeat.directive.mjs +37 -0
- package/esm2022/lib/directives/scroll-observer-first-element/scroll-observer-first-element.directive.mjs +32 -0
- package/esm2022/lib/directives/scroll-observer-ignore-target/scroll-observer-ignore-target.directive.mjs +19 -0
- package/esm2022/lib/directives/scroll-observer-last-element/scroll-observer-last-element.directive.mjs +35 -0
- package/esm2022/lib/directives/seo/seo.directive.mjs +167 -0
- package/esm2022/lib/pipes/normalize-game-result-type/normalize-game-result-type.pipe.mjs +16 -0
- package/esm2022/lib/pipes/normalize-match-participants/normalize-match-participants.pipe.mjs +16 -0
- package/esm2022/lib/pipes/normalize-match-score/normalize-match-score.pipe.mjs +16 -0
- package/esm2022/lib/pipes/normalize-match-state/normalize-match-state.pipe.mjs +16 -0
- package/esm2022/lib/pipes/normalize-match-type/normalize-match-type.pipe.mjs +16 -0
- package/esm2022/lib/pipes/to-array/to-array.pipe.mjs +16 -0
- package/esm2022/lib/services/click-observer.service.mjs +75 -0
- package/esm2022/lib/services/content-observer.service.mjs +81 -0
- package/esm2022/lib/services/focus-visible.service.mjs +35 -0
- package/esm2022/lib/services/public-api.mjs +8 -0
- package/esm2022/lib/services/resize-observer.service.mjs +77 -0
- package/esm2022/lib/services/router-state.service.mjs +116 -0
- package/esm2022/lib/services/viewport.service.mjs +169 -0
- package/esm2022/lib/types/angular.types.mjs +15 -0
- package/esm2022/lib/utils/destroy.utils.mjs +13 -0
- package/esm2022/lib/utils/public-api.mjs +13 -0
- package/esm2022/lib/utils/reactive-binding.util.mjs +112 -0
- package/esm2022/lib/utils/scrollable.utils.mjs +85 -0
- package/{fesm2020 → fesm2022}/ethlete-core.mjs +745 -605
- package/fesm2022/ethlete-core.mjs.map +1 -0
- package/lib/components/structured-data/structured-data.component.d.ts +1 -1
- package/lib/directives/animatable/animatable.directive.d.ts +1 -1
- package/lib/directives/animated-lifecycle/index.d.ts +1 -0
- package/lib/directives/animated-overlay/animated-overlay.directive.d.ts +62 -0
- package/lib/directives/animated-overlay/public-api.d.ts +1 -0
- package/lib/directives/cursor-drag-scroll/cursor-drag-scroll.directive.d.ts +1 -1
- package/lib/directives/let/let.directive.d.ts +1 -1
- package/lib/directives/observe-content/observe-content.directive.d.ts +1 -1
- package/lib/directives/observe-resize/observe-resize.directive.d.ts +1 -1
- package/lib/directives/observe-scroll-state/observe-scroll-state.directive.d.ts +1 -1
- package/lib/directives/public-api.d.ts +1 -0
- package/lib/directives/repeat/repeat.directive.d.ts +1 -1
- package/lib/directives/scroll-observer-first-element/scroll-observer-first-element.directive.d.ts +1 -1
- package/lib/directives/scroll-observer-last-element/scroll-observer-last-element.directive.d.ts +1 -1
- package/lib/services/public-api.d.ts +0 -1
- package/lib/types/angular.types.d.ts +0 -7
- package/lib/utils/destroy.utils.d.ts +1 -0
- package/lib/utils/public-api.d.ts +1 -0
- package/package.json +14 -19
- package/esm2020/lib/components/structured-data/structured-data.component.mjs +0 -37
- package/esm2020/lib/directives/animatable/animatable.directive.mjs +0 -115
- package/esm2020/lib/directives/animated-lifecycle/animated-lifecycle.directive.mjs +0 -115
- package/esm2020/lib/directives/click-outside/click-outside.directive.mjs +0 -37
- package/esm2020/lib/directives/cursor-drag-scroll/cursor-drag-scroll.directive.mjs +0 -147
- package/esm2020/lib/directives/delayable/delayable.directive.mjs +0 -55
- package/esm2020/lib/directives/let/let.directive.mjs +0 -40
- package/esm2020/lib/directives/observe-content/observe-content.directive.mjs +0 -68
- package/esm2020/lib/directives/observe-resize/observe-resize.directive.mjs +0 -68
- package/esm2020/lib/directives/observe-scroll-state/observe-scroll-state.directive.mjs +0 -176
- package/esm2020/lib/directives/public-api.mjs +0 -15
- package/esm2020/lib/directives/repeat/repeat.directive.mjs +0 -36
- package/esm2020/lib/directives/scroll-observer-first-element/scroll-observer-first-element.directive.mjs +0 -31
- package/esm2020/lib/directives/scroll-observer-ignore-target/scroll-observer-ignore-target.directive.mjs +0 -18
- package/esm2020/lib/directives/scroll-observer-last-element/scroll-observer-last-element.directive.mjs +0 -34
- package/esm2020/lib/directives/seo/seo.directive.mjs +0 -166
- package/esm2020/lib/pipes/normalize-game-result-type/normalize-game-result-type.pipe.mjs +0 -15
- package/esm2020/lib/pipes/normalize-match-participants/normalize-match-participants.pipe.mjs +0 -15
- package/esm2020/lib/pipes/normalize-match-score/normalize-match-score.pipe.mjs +0 -15
- package/esm2020/lib/pipes/normalize-match-state/normalize-match-state.pipe.mjs +0 -15
- package/esm2020/lib/pipes/normalize-match-type/normalize-match-type.pipe.mjs +0 -15
- package/esm2020/lib/pipes/to-array/to-array.pipe.mjs +0 -15
- package/esm2020/lib/services/click-observer.service.mjs +0 -73
- package/esm2020/lib/services/content-observer.service.mjs +0 -79
- package/esm2020/lib/services/destroy.service.mjs +0 -23
- package/esm2020/lib/services/focus-visible.service.mjs +0 -34
- package/esm2020/lib/services/public-api.mjs +0 -9
- package/esm2020/lib/services/resize-observer.service.mjs +0 -75
- package/esm2020/lib/services/router-state.service.mjs +0 -115
- package/esm2020/lib/services/viewport.service.mjs +0 -168
- package/esm2020/lib/types/angular.types.mjs +0 -36
- package/esm2020/lib/utils/public-api.mjs +0 -12
- package/esm2020/lib/utils/reactive-binding.util.mjs +0 -111
- package/esm2020/lib/utils/scrollable.utils.mjs +0 -85
- package/fesm2015/ethlete-core.mjs +0 -2787
- package/fesm2015/ethlete-core.mjs.map +0 -1
- package/fesm2020/ethlete-core.mjs.map +0 -1
- package/lib/services/destroy.service.d.ts +0 -12
- /package/{esm2020 → esm2022}/ethlete-core.mjs +0 -0
- /package/{esm2020 → esm2022}/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/structured-data/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/constants/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/constants/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/constants/viewport.constants.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/decorators/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/decorators/memo/memo.decorator.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/decorators/memo/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/decorators/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/animatable/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/animatable/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/animated-lifecycle/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/click-outside/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/cursor-drag-scroll/cursor-drag-scroll.constants.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/cursor-drag-scroll/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/delayable/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/let/let.types.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/let/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/observe-content/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/observe-resize/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/observe-scroll-state/observe-scroll-state.constants.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/observe-scroll-state/observe-scroll-state.types.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/observe-scroll-state/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/repeat/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/scroll-observer-first-element/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/scroll-observer-first-element/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/scroll-observer-ignore-target/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/scroll-observer-ignore-target/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/scroll-observer-last-element/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/scroll-observer-last-element/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/seo/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/seo/seo.directive.constants.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/seo/seo.directive.types.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/seo/seo.directive.utils.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/pipes/normalize-game-result-type/normalize-game-result-type.types.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/pipes/normalize-game-result-type/normalize-game-result-type.util.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/pipes/normalize-game-result-type/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/pipes/normalize-match-participants/normalize-match-participants.types.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/pipes/normalize-match-participants/normalize-match-participants.util.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/pipes/normalize-match-participants/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/pipes/normalize-match-score/normalize-match-score.types.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/pipes/normalize-match-score/normalize-match-score.util.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/pipes/normalize-match-score/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/pipes/normalize-match-state/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/pipes/normalize-match-state/normalize-match-state.constants.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/pipes/normalize-match-state/normalize-match-state.util.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/pipes/normalize-match-state/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/pipes/normalize-match-type/normalize-match-type.util.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/pipes/normalize-match-type/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/pipes/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/pipes/to-array/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/pipes/to-array/to-array.util.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/services/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/services/viewport.types.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/types/i18n.types.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/types/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/types/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/types/viewport.types.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/utils/animation.utils.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/utils/clamp.util.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/utils/clone.util.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/utils/cookie.util.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/utils/equal.util.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/utils/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/utils/media-query-observable.util.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/utils/rxjs.utils.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/utils/smart-block-scroll-strategy.utils.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/utils/viewport.util.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/validators/is-array-not-empty.validator.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/validators/is-email.validator.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/validators/must-match.validator.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/validators/public-api.mjs +0 -0
|
@@ -0,0 +1,175 @@
|
|
|
1
|
+
import { coerceNumberProperty } from '@angular/cdk/coercion';
|
|
2
|
+
import { Directive, ElementRef, EventEmitter, inject, Input, Output } from '@angular/core';
|
|
3
|
+
import { debounceTime, takeUntil, tap } from 'rxjs';
|
|
4
|
+
import { ContentObserverService, ResizeObserverService } from '../../services';
|
|
5
|
+
import { createDestroy, elementCanScroll } from '../../utils';
|
|
6
|
+
import { SCROLL_OBSERVER_FIRST_ELEMENT_CLASS } from '../scroll-observer-first-element';
|
|
7
|
+
import { SCROLL_OBSERVER_IGNORE_TARGET_CLASS } from '../scroll-observer-ignore-target';
|
|
8
|
+
import { SCROLL_OBSERVER_LAST_ELEMENT_CLASS } from '../scroll-observer-last-element';
|
|
9
|
+
import { OBSERVE_SCROLL_STATE } from './observe-scroll-state.constants';
|
|
10
|
+
import * as i0 from "@angular/core";
|
|
11
|
+
class ObserveScrollStateDirective {
|
|
12
|
+
constructor() {
|
|
13
|
+
this._destroy$ = createDestroy();
|
|
14
|
+
this._elementRef = inject(ElementRef);
|
|
15
|
+
this._contentObserverService = inject(ContentObserverService);
|
|
16
|
+
this._resizeObserverService = inject(ResizeObserverService);
|
|
17
|
+
this._observedChildren = {
|
|
18
|
+
first: this._firstCurrentChild,
|
|
19
|
+
last: this._lastCurrentChild,
|
|
20
|
+
};
|
|
21
|
+
this._rootMargin = 0;
|
|
22
|
+
this._threshold = [0.99999, 0.9999, 0.999, 0.99, 1];
|
|
23
|
+
this._intersectionObserver = null;
|
|
24
|
+
this.valueChange = new EventEmitter();
|
|
25
|
+
}
|
|
26
|
+
get _firstCurrentChild() {
|
|
27
|
+
const explicitFirstElement = this._elementRef.nativeElement.querySelector(`.${SCROLL_OBSERVER_FIRST_ELEMENT_CLASS}`);
|
|
28
|
+
if (explicitFirstElement) {
|
|
29
|
+
return explicitFirstElement;
|
|
30
|
+
}
|
|
31
|
+
const element = this._elementRef.nativeElement.children[0];
|
|
32
|
+
return this._getNonIgnoredChild(element, 'next');
|
|
33
|
+
}
|
|
34
|
+
get _lastCurrentChild() {
|
|
35
|
+
const explicitLastElement = this._elementRef.nativeElement.querySelector(`.${SCROLL_OBSERVER_LAST_ELEMENT_CLASS}`);
|
|
36
|
+
if (explicitLastElement) {
|
|
37
|
+
return explicitLastElement;
|
|
38
|
+
}
|
|
39
|
+
const element = this._elementRef.nativeElement.children[this._elementRef.nativeElement.children.length - 1];
|
|
40
|
+
return this._getNonIgnoredChild(element, 'previous');
|
|
41
|
+
}
|
|
42
|
+
get observerRootMargin() {
|
|
43
|
+
return this._rootMargin;
|
|
44
|
+
}
|
|
45
|
+
set observerRootMargin(value) {
|
|
46
|
+
this._rootMargin = coerceNumberProperty(value);
|
|
47
|
+
}
|
|
48
|
+
get observerThreshold() {
|
|
49
|
+
return this._threshold;
|
|
50
|
+
}
|
|
51
|
+
set observerThreshold(value) {
|
|
52
|
+
if (Array.isArray(value)) {
|
|
53
|
+
this._threshold = value;
|
|
54
|
+
return;
|
|
55
|
+
}
|
|
56
|
+
this._threshold = coerceNumberProperty(value);
|
|
57
|
+
}
|
|
58
|
+
ngOnInit() {
|
|
59
|
+
this._contentObserverService
|
|
60
|
+
.observe(this._elementRef.nativeElement)
|
|
61
|
+
.pipe(debounceTime(25), tap(() => this._checkChildren()), takeUntil(this._destroy$))
|
|
62
|
+
.subscribe();
|
|
63
|
+
this._resizeObserverService
|
|
64
|
+
.observe(this._elementRef.nativeElement)
|
|
65
|
+
.pipe(debounceTime(25), tap(() => {
|
|
66
|
+
const canScroll = elementCanScroll(this._elementRef.nativeElement);
|
|
67
|
+
if ((!this._intersectionObserver && canScroll) || (this._intersectionObserver && !canScroll)) {
|
|
68
|
+
this._checkChildren();
|
|
69
|
+
}
|
|
70
|
+
}), takeUntil(this._destroy$))
|
|
71
|
+
.subscribe();
|
|
72
|
+
this._checkChildren();
|
|
73
|
+
}
|
|
74
|
+
ngOnDestroy() {
|
|
75
|
+
this._clearIntersectionObserver();
|
|
76
|
+
}
|
|
77
|
+
_checkChildren() {
|
|
78
|
+
this._clearIntersectionObserver();
|
|
79
|
+
if (this._firstCurrentChild === this._lastCurrentChild ||
|
|
80
|
+
!this._firstCurrentChild ||
|
|
81
|
+
!this._lastCurrentChild ||
|
|
82
|
+
!elementCanScroll(this._elementRef.nativeElement)) {
|
|
83
|
+
this._unobserveChild('first');
|
|
84
|
+
this._unobserveChild('last');
|
|
85
|
+
this.valueChange.emit({
|
|
86
|
+
isAtStart: true,
|
|
87
|
+
isAtEnd: true,
|
|
88
|
+
canScroll: false,
|
|
89
|
+
});
|
|
90
|
+
}
|
|
91
|
+
else {
|
|
92
|
+
this._intersectionObserver = this._initiateIntersectionObserver();
|
|
93
|
+
this._observeChild('first', this._firstCurrentChild);
|
|
94
|
+
this._observeChild('last', this._lastCurrentChild);
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
_initiateIntersectionObserver() {
|
|
98
|
+
const observer = new IntersectionObserver((entries) => {
|
|
99
|
+
const { first, last } = this._observedChildren;
|
|
100
|
+
const isAtStart = entries.find((entry) => entry.target === first)?.isIntersecting ?? false;
|
|
101
|
+
const isAtEnd = entries.find((entry) => entry.target === last)?.isIntersecting ?? false;
|
|
102
|
+
this.valueChange.emit({
|
|
103
|
+
isAtStart,
|
|
104
|
+
isAtEnd,
|
|
105
|
+
canScroll: !isAtStart || !isAtEnd,
|
|
106
|
+
});
|
|
107
|
+
}, {
|
|
108
|
+
root: this._elementRef.nativeElement,
|
|
109
|
+
rootMargin: this._rootMargin ? `${this._rootMargin}px` : undefined,
|
|
110
|
+
threshold: this._threshold,
|
|
111
|
+
});
|
|
112
|
+
return observer;
|
|
113
|
+
}
|
|
114
|
+
_observeChild(child, element) {
|
|
115
|
+
this._intersectionObserver?.observe(element);
|
|
116
|
+
this._observedChildren[child] = element;
|
|
117
|
+
element.classList.add(`et-scroll-observer-observing-${child}-element`);
|
|
118
|
+
}
|
|
119
|
+
_unobserveChild(child) {
|
|
120
|
+
const observedChild = this._observedChildren[child];
|
|
121
|
+
if (!observedChild) {
|
|
122
|
+
return;
|
|
123
|
+
}
|
|
124
|
+
observedChild.classList.remove('et-scroll-observer-observing-first-element', 'et-scroll-observer-observing-last-element');
|
|
125
|
+
this._intersectionObserver?.unobserve(observedChild);
|
|
126
|
+
this._observedChildren[child] = null;
|
|
127
|
+
}
|
|
128
|
+
_clearIntersectionObserver() {
|
|
129
|
+
this._intersectionObserver?.disconnect();
|
|
130
|
+
this._intersectionObserver = null;
|
|
131
|
+
}
|
|
132
|
+
_getNonIgnoredChild(element, direction) {
|
|
133
|
+
if (!element) {
|
|
134
|
+
return null;
|
|
135
|
+
}
|
|
136
|
+
if (element?.classList.contains(SCROLL_OBSERVER_IGNORE_TARGET_CLASS)) {
|
|
137
|
+
const nextElement = element[`${direction}ElementSibling`];
|
|
138
|
+
if (!nextElement) {
|
|
139
|
+
return null;
|
|
140
|
+
}
|
|
141
|
+
return this._getNonIgnoredChild(nextElement, direction);
|
|
142
|
+
}
|
|
143
|
+
return element;
|
|
144
|
+
}
|
|
145
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: ObserveScrollStateDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
146
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.0", type: ObserveScrollStateDirective, isStandalone: true, selector: "[etObserveScrollState]", inputs: { observerRootMargin: "observerRootMargin", observerThreshold: "observerThreshold" }, outputs: { valueChange: "etObserveScrollState" }, providers: [
|
|
147
|
+
{
|
|
148
|
+
provide: OBSERVE_SCROLL_STATE,
|
|
149
|
+
useExisting: ObserveScrollStateDirective,
|
|
150
|
+
},
|
|
151
|
+
], exportAs: ["etObserveScrollState"], ngImport: i0 }); }
|
|
152
|
+
}
|
|
153
|
+
export { ObserveScrollStateDirective };
|
|
154
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: ObserveScrollStateDirective, decorators: [{
|
|
155
|
+
type: Directive,
|
|
156
|
+
args: [{
|
|
157
|
+
selector: '[etObserveScrollState]',
|
|
158
|
+
exportAs: 'etObserveScrollState',
|
|
159
|
+
standalone: true,
|
|
160
|
+
providers: [
|
|
161
|
+
{
|
|
162
|
+
provide: OBSERVE_SCROLL_STATE,
|
|
163
|
+
useExisting: ObserveScrollStateDirective,
|
|
164
|
+
},
|
|
165
|
+
],
|
|
166
|
+
}]
|
|
167
|
+
}], propDecorators: { observerRootMargin: [{
|
|
168
|
+
type: Input
|
|
169
|
+
}], observerThreshold: [{
|
|
170
|
+
type: Input
|
|
171
|
+
}], valueChange: [{
|
|
172
|
+
type: Output,
|
|
173
|
+
args: ['etObserveScrollState']
|
|
174
|
+
}] } });
|
|
175
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"observe-scroll-state.directive.js","sourceRoot":"","sources":["../../../../../../../libs/core/src/lib/directives/observe-scroll-state/observe-scroll-state.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { coerceNumberProperty, NumberInput } from '@angular/cdk/coercion';\nimport { Directive, ElementRef, EventEmitter, inject, Input, OnDestroy, OnInit, Output } from '@angular/core';\nimport { debounceTime, takeUntil, tap } from 'rxjs';\nimport { ContentObserverService, ResizeObserverService } from '../../services';\nimport { createDestroy, elementCanScroll } from '../../utils';\nimport { SCROLL_OBSERVER_FIRST_ELEMENT_CLASS } from '../scroll-observer-first-element';\nimport { SCROLL_OBSERVER_IGNORE_TARGET_CLASS } from '../scroll-observer-ignore-target';\nimport { SCROLL_OBSERVER_LAST_ELEMENT_CLASS } from '../scroll-observer-last-element';\nimport { OBSERVE_SCROLL_STATE } from './observe-scroll-state.constants';\nimport { ObservedScrollableChild, ScrollObserverScrollState } from './observe-scroll-state.types';\n\n@Directive({\n  selector: '[etObserveScrollState]',\n  exportAs: 'etObserveScrollState',\n  standalone: true,\n  providers: [\n    {\n      provide: OBSERVE_SCROLL_STATE,\n      useExisting: ObserveScrollStateDirective,\n    },\n  ],\n})\nexport class ObserveScrollStateDirective implements OnInit, OnDestroy {\n  private readonly _destroy$ = createDestroy();\n\n  private readonly _elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n  private readonly _contentObserverService = inject(ContentObserverService);\n  private readonly _resizeObserverService = inject(ResizeObserverService);\n\n  private readonly _observedChildren = {\n    first: this._firstCurrentChild,\n    last: this._lastCurrentChild,\n  };\n\n  private get _firstCurrentChild() {\n    const explicitFirstElement = this._elementRef.nativeElement.querySelector(\n      `.${SCROLL_OBSERVER_FIRST_ELEMENT_CLASS}`,\n    ) as HTMLElement | null;\n\n    if (explicitFirstElement) {\n      return explicitFirstElement;\n    }\n\n    const element = this._elementRef.nativeElement.children[0] as HTMLElement | null;\n\n    return this._getNonIgnoredChild(element, 'next');\n  }\n\n  private get _lastCurrentChild() {\n    const explicitLastElement = this._elementRef.nativeElement.querySelector(\n      `.${SCROLL_OBSERVER_LAST_ELEMENT_CLASS}`,\n    ) as HTMLElement | null;\n\n    if (explicitLastElement) {\n      return explicitLastElement;\n    }\n\n    const element = this._elementRef.nativeElement.children[\n      this._elementRef.nativeElement.children.length - 1\n    ] as HTMLElement | null;\n\n    return this._getNonIgnoredChild(element, 'previous');\n  }\n\n  @Input()\n  get observerRootMargin(): number {\n    return this._rootMargin;\n  }\n  set observerRootMargin(value: NumberInput) {\n    this._rootMargin = coerceNumberProperty(value);\n  }\n  private _rootMargin = 0;\n\n  @Input()\n  get observerThreshold(): number | number[] {\n    return this._threshold;\n  }\n  set observerThreshold(value: NumberInput | number[]) {\n    if (Array.isArray(value)) {\n      this._threshold = value;\n      return;\n    }\n\n    this._threshold = coerceNumberProperty(value);\n  }\n  private _threshold: number | number[] = [0.99999, 0.9999, 0.999, 0.99, 1];\n\n  private _intersectionObserver: IntersectionObserver | null = null;\n\n  @Output('etObserveScrollState')\n  valueChange = new EventEmitter<ScrollObserverScrollState>();\n\n  ngOnInit(): void {\n    this._contentObserverService\n      .observe(this._elementRef.nativeElement)\n      .pipe(\n        debounceTime(25),\n        tap(() => this._checkChildren()),\n        takeUntil(this._destroy$),\n      )\n      .subscribe();\n\n    this._resizeObserverService\n      .observe(this._elementRef.nativeElement)\n      .pipe(\n        debounceTime(25),\n        tap(() => {\n          const canScroll = elementCanScroll(this._elementRef.nativeElement);\n          if ((!this._intersectionObserver && canScroll) || (this._intersectionObserver && !canScroll)) {\n            this._checkChildren();\n          }\n        }),\n        takeUntil(this._destroy$),\n      )\n      .subscribe();\n\n    this._checkChildren();\n  }\n\n  ngOnDestroy(): void {\n    this._clearIntersectionObserver();\n  }\n\n  private _checkChildren() {\n    this._clearIntersectionObserver();\n\n    if (\n      this._firstCurrentChild === this._lastCurrentChild ||\n      !this._firstCurrentChild ||\n      !this._lastCurrentChild ||\n      !elementCanScroll(this._elementRef.nativeElement)\n    ) {\n      this._unobserveChild('first');\n      this._unobserveChild('last');\n\n      this.valueChange.emit({\n        isAtStart: true,\n        isAtEnd: true,\n        canScroll: false,\n      });\n    } else {\n      this._intersectionObserver = this._initiateIntersectionObserver();\n\n      this._observeChild('first', this._firstCurrentChild);\n      this._observeChild('last', this._lastCurrentChild);\n    }\n  }\n\n  private _initiateIntersectionObserver() {\n    const observer = new IntersectionObserver(\n      (entries) => {\n        const { first, last } = this._observedChildren;\n\n        const isAtStart = entries.find((entry) => entry.target === first)?.isIntersecting ?? false;\n        const isAtEnd = entries.find((entry) => entry.target === last)?.isIntersecting ?? false;\n\n        this.valueChange.emit({\n          isAtStart,\n          isAtEnd,\n          canScroll: !isAtStart || !isAtEnd,\n        });\n      },\n      {\n        root: this._elementRef.nativeElement,\n        rootMargin: this._rootMargin ? `${this._rootMargin}px` : undefined,\n        threshold: this._threshold,\n      },\n    );\n\n    return observer;\n  }\n\n  private _observeChild(child: ObservedScrollableChild, element: HTMLElement) {\n    this._intersectionObserver?.observe(element);\n    this._observedChildren[child] = element;\n\n    element.classList.add(`et-scroll-observer-observing-${child}-element`);\n  }\n\n  private _unobserveChild(child: ObservedScrollableChild) {\n    const observedChild = this._observedChildren[child];\n\n    if (!observedChild) {\n      return;\n    }\n\n    observedChild.classList.remove(\n      'et-scroll-observer-observing-first-element',\n      'et-scroll-observer-observing-last-element',\n    );\n\n    this._intersectionObserver?.unobserve(observedChild);\n    this._observedChildren[child] = null;\n  }\n\n  private _clearIntersectionObserver() {\n    this._intersectionObserver?.disconnect();\n    this._intersectionObserver = null;\n  }\n\n  private _getNonIgnoredChild(element: HTMLElement | null, direction: 'previous' | 'next'): HTMLElement | null {\n    if (!element) {\n      return null;\n    }\n\n    if (element?.classList.contains(SCROLL_OBSERVER_IGNORE_TARGET_CLASS)) {\n      const nextElement = element[`${direction}ElementSibling`] as HTMLElement | null;\n\n      if (!nextElement) {\n        return null;\n      }\n\n      return this._getNonIgnoredChild(nextElement, direction);\n    }\n\n    return element;\n  }\n}\n"]}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
export * from './animatable/public-api';
|
|
2
|
+
export * from './animated-lifecycle/public-api';
|
|
3
|
+
export * from './animated-overlay/public-api';
|
|
4
|
+
export * from './click-outside/public-api';
|
|
5
|
+
export * from './cursor-drag-scroll/public-api';
|
|
6
|
+
export * from './delayable/public-api';
|
|
7
|
+
export * from './let/public-api';
|
|
8
|
+
export * from './observe-content/public-api';
|
|
9
|
+
export * from './observe-resize/public-api';
|
|
10
|
+
export * from './observe-scroll-state/public-api';
|
|
11
|
+
export * from './repeat/public-api';
|
|
12
|
+
export * from './scroll-observer-first-element/public-api';
|
|
13
|
+
export * from './scroll-observer-ignore-target/public-api';
|
|
14
|
+
export * from './scroll-observer-last-element/public-api';
|
|
15
|
+
export * from './seo/public-api';
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29yZS9zcmMvbGliL2RpcmVjdGl2ZXMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYywrQkFBK0IsQ0FBQztBQUM5QyxjQUFjLDRCQUE0QixDQUFDO0FBQzNDLGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYyx3QkFBd0IsQ0FBQztBQUN2QyxjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsOEJBQThCLENBQUM7QUFDN0MsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLG1DQUFtQyxDQUFDO0FBQ2xELGNBQWMscUJBQXFCLENBQUM7QUFDcEMsY0FBYyw0Q0FBNEMsQ0FBQztBQUMzRCxjQUFjLDRDQUE0QyxDQUFDO0FBQzNELGNBQWMsMkNBQTJDLENBQUM7QUFDMUQsY0FBYyxrQkFBa0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vYW5pbWF0YWJsZS9wdWJsaWMtYXBpJztcbmV4cG9ydCAqIGZyb20gJy4vYW5pbWF0ZWQtbGlmZWN5Y2xlL3B1YmxpYy1hcGknO1xuZXhwb3J0ICogZnJvbSAnLi9hbmltYXRlZC1vdmVybGF5L3B1YmxpYy1hcGknO1xuZXhwb3J0ICogZnJvbSAnLi9jbGljay1vdXRzaWRlL3B1YmxpYy1hcGknO1xuZXhwb3J0ICogZnJvbSAnLi9jdXJzb3ItZHJhZy1zY3JvbGwvcHVibGljLWFwaSc7XG5leHBvcnQgKiBmcm9tICcuL2RlbGF5YWJsZS9wdWJsaWMtYXBpJztcbmV4cG9ydCAqIGZyb20gJy4vbGV0L3B1YmxpYy1hcGknO1xuZXhwb3J0ICogZnJvbSAnLi9vYnNlcnZlLWNvbnRlbnQvcHVibGljLWFwaSc7XG5leHBvcnQgKiBmcm9tICcuL29ic2VydmUtcmVzaXplL3B1YmxpYy1hcGknO1xuZXhwb3J0ICogZnJvbSAnLi9vYnNlcnZlLXNjcm9sbC1zdGF0ZS9wdWJsaWMtYXBpJztcbmV4cG9ydCAqIGZyb20gJy4vcmVwZWF0L3B1YmxpYy1hcGknO1xuZXhwb3J0ICogZnJvbSAnLi9zY3JvbGwtb2JzZXJ2ZXItZmlyc3QtZWxlbWVudC9wdWJsaWMtYXBpJztcbmV4cG9ydCAqIGZyb20gJy4vc2Nyb2xsLW9ic2VydmVyLWlnbm9yZS10YXJnZXQvcHVibGljLWFwaSc7XG5leHBvcnQgKiBmcm9tICcuL3Njcm9sbC1vYnNlcnZlci1sYXN0LWVsZW1lbnQvcHVibGljLWFwaSc7XG5leHBvcnQgKiBmcm9tICcuL3Nlby9wdWJsaWMtYXBpJztcbiJdfQ==
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { coerceNumberProperty } from '@angular/cdk/coercion';
|
|
2
|
+
import { Directive, Input, TemplateRef, ViewContainerRef } from '@angular/core';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
class RepeatDirective {
|
|
5
|
+
get repeatCount() {
|
|
6
|
+
return this._repeatCount;
|
|
7
|
+
}
|
|
8
|
+
set repeatCount(value) {
|
|
9
|
+
this._repeatCount = coerceNumberProperty(value);
|
|
10
|
+
this._render();
|
|
11
|
+
}
|
|
12
|
+
constructor(_mainTemplateRef, _viewContainerRef) {
|
|
13
|
+
this._mainTemplateRef = _mainTemplateRef;
|
|
14
|
+
this._viewContainerRef = _viewContainerRef;
|
|
15
|
+
this._repeatCount = 2;
|
|
16
|
+
}
|
|
17
|
+
_render() {
|
|
18
|
+
this._viewContainerRef.clear();
|
|
19
|
+
for (let i = 0; i < this.repeatCount; i++) {
|
|
20
|
+
this._viewContainerRef.createEmbeddedView(this._mainTemplateRef);
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: RepeatDirective, deps: [{ token: i0.TemplateRef }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
24
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.0", type: RepeatDirective, isStandalone: true, selector: "[etRepeat]", inputs: { repeatCount: ["etRepeat", "repeatCount"] }, ngImport: i0 }); }
|
|
25
|
+
}
|
|
26
|
+
export { RepeatDirective };
|
|
27
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: RepeatDirective, decorators: [{
|
|
28
|
+
type: Directive,
|
|
29
|
+
args: [{
|
|
30
|
+
selector: '[etRepeat]',
|
|
31
|
+
standalone: true,
|
|
32
|
+
}]
|
|
33
|
+
}], ctorParameters: function () { return [{ type: i0.TemplateRef }, { type: i0.ViewContainerRef }]; }, propDecorators: { repeatCount: [{
|
|
34
|
+
type: Input,
|
|
35
|
+
args: ['etRepeat']
|
|
36
|
+
}] } });
|
|
37
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVwZWF0LmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29yZS9zcmMvbGliL2RpcmVjdGl2ZXMvcmVwZWF0L3JlcGVhdC5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLG9CQUFvQixFQUFlLE1BQU0sdUJBQXVCLENBQUM7QUFDMUUsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsV0FBVyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUVoRixNQUlhLGVBQWU7SUFDMUIsSUFDSSxXQUFXO1FBQ2IsT0FBTyxJQUFJLENBQUMsWUFBWSxDQUFDO0lBQzNCLENBQUM7SUFDRCxJQUFJLFdBQVcsQ0FBQyxLQUFrQjtRQUNoQyxJQUFJLENBQUMsWUFBWSxHQUFHLG9CQUFvQixDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQ2hELElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQztJQUNqQixDQUFDO0lBR0QsWUFBb0IsZ0JBQXNDLEVBQVUsaUJBQW1DO1FBQW5GLHFCQUFnQixHQUFoQixnQkFBZ0IsQ0FBc0I7UUFBVSxzQkFBaUIsR0FBakIsaUJBQWlCLENBQWtCO1FBRi9GLGlCQUFZLEdBQUcsQ0FBQyxDQUFDO0lBRWlGLENBQUM7SUFFbkcsT0FBTztRQUNiLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxLQUFLLEVBQUUsQ0FBQztRQUUvQixLQUFLLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUcsSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDLEVBQUUsRUFBRTtZQUN6QyxJQUFJLENBQUMsaUJBQWlCLENBQUMsa0JBQWtCLENBQUMsSUFBSSxDQUFDLGdCQUFnQixDQUFDLENBQUM7U0FDbEU7SUFDSCxDQUFDOzhHQW5CVSxlQUFlO2tHQUFmLGVBQWU7O1NBQWYsZUFBZTsyRkFBZixlQUFlO2tCQUozQixTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxZQUFZO29CQUN0QixVQUFVLEVBQUUsSUFBSTtpQkFDakI7aUlBR0ssV0FBVztzQkFEZCxLQUFLO3VCQUFDLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjb2VyY2VOdW1iZXJQcm9wZXJ0eSwgTnVtYmVySW5wdXQgfSBmcm9tICdAYW5ndWxhci9jZGsvY29lcmNpb24nO1xuaW1wb3J0IHsgRGlyZWN0aXZlLCBJbnB1dCwgVGVtcGxhdGVSZWYsIFZpZXdDb250YWluZXJSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnW2V0UmVwZWF0XScsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG59KVxuZXhwb3J0IGNsYXNzIFJlcGVhdERpcmVjdGl2ZSB7XG4gIEBJbnB1dCgnZXRSZXBlYXQnKVxuICBnZXQgcmVwZWF0Q291bnQoKTogbnVtYmVyIHtcbiAgICByZXR1cm4gdGhpcy5fcmVwZWF0Q291bnQ7XG4gIH1cbiAgc2V0IHJlcGVhdENvdW50KHZhbHVlOiBOdW1iZXJJbnB1dCkge1xuICAgIHRoaXMuX3JlcGVhdENvdW50ID0gY29lcmNlTnVtYmVyUHJvcGVydHkodmFsdWUpO1xuICAgIHRoaXMuX3JlbmRlcigpO1xuICB9XG4gIHByaXZhdGUgX3JlcGVhdENvdW50ID0gMjtcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIF9tYWluVGVtcGxhdGVSZWY6IFRlbXBsYXRlUmVmPHVua25vd24+LCBwcml2YXRlIF92aWV3Q29udGFpbmVyUmVmOiBWaWV3Q29udGFpbmVyUmVmKSB7fVxuXG4gIHByaXZhdGUgX3JlbmRlcigpIHtcbiAgICB0aGlzLl92aWV3Q29udGFpbmVyUmVmLmNsZWFyKCk7XG5cbiAgICBmb3IgKGxldCBpID0gMDsgaSA8IHRoaXMucmVwZWF0Q291bnQ7IGkrKykge1xuICAgICAgdGhpcy5fdmlld0NvbnRhaW5lclJlZi5jcmVhdGVFbWJlZGRlZFZpZXcodGhpcy5fbWFpblRlbXBsYXRlUmVmKTtcbiAgICB9XG4gIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { coerceBooleanProperty } from '@angular/cdk/coercion';
|
|
2
|
+
import { Directive, HostBinding, Input } from '@angular/core';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export const SCROLL_OBSERVER_FIRST_ELEMENT_CLASS = 'et-scroll-observer-first-element';
|
|
5
|
+
class ScrollObserverFirstElementDirective {
|
|
6
|
+
constructor() {
|
|
7
|
+
this._isFirstElement = false;
|
|
8
|
+
}
|
|
9
|
+
get isFirstElement() {
|
|
10
|
+
return this._isFirstElement;
|
|
11
|
+
}
|
|
12
|
+
set isFirstElement(value) {
|
|
13
|
+
this._isFirstElement = coerceBooleanProperty(value);
|
|
14
|
+
}
|
|
15
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: ScrollObserverFirstElementDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
16
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.0", type: ScrollObserverFirstElementDirective, isStandalone: true, selector: "[etScrollObserverFirstElement]", inputs: { isFirstElement: ["etScrollObserverFirstElement", "isFirstElement"] }, host: { properties: { "class.et-scroll-observer-first-element": "this.isFirstElement" } }, ngImport: i0 }); }
|
|
17
|
+
}
|
|
18
|
+
export { ScrollObserverFirstElementDirective };
|
|
19
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: ScrollObserverFirstElementDirective, decorators: [{
|
|
20
|
+
type: Directive,
|
|
21
|
+
args: [{
|
|
22
|
+
selector: '[etScrollObserverFirstElement]',
|
|
23
|
+
standalone: true,
|
|
24
|
+
}]
|
|
25
|
+
}], propDecorators: { isFirstElement: [{
|
|
26
|
+
type: Input,
|
|
27
|
+
args: ['etScrollObserverFirstElement']
|
|
28
|
+
}, {
|
|
29
|
+
type: HostBinding,
|
|
30
|
+
args: [`class.${SCROLL_OBSERVER_FIRST_ELEMENT_CLASS}`]
|
|
31
|
+
}] } });
|
|
32
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2Nyb2xsLW9ic2VydmVyLWZpcnN0LWVsZW1lbnQuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb3JlL3NyYy9saWIvZGlyZWN0aXZlcy9zY3JvbGwtb2JzZXJ2ZXItZmlyc3QtZWxlbWVudC9zY3JvbGwtb2JzZXJ2ZXItZmlyc3QtZWxlbWVudC5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFnQixxQkFBcUIsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQzVFLE9BQU8sRUFBRSxTQUFTLEVBQUUsV0FBVyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFFOUQsTUFBTSxDQUFDLE1BQU0sbUNBQW1DLEdBQUcsa0NBQWtDLENBQUM7QUFFdEYsTUFJYSxtQ0FBbUM7SUFKaEQ7UUFhVSxvQkFBZSxHQUFHLEtBQUssQ0FBQztLQUNqQztJQVRDLElBRUksY0FBYztRQUNoQixPQUFPLElBQUksQ0FBQyxlQUFlLENBQUM7SUFDOUIsQ0FBQztJQUNELElBQUksY0FBYyxDQUFDLEtBQW1CO1FBQ3BDLElBQUksQ0FBQyxlQUFlLEdBQUcscUJBQXFCLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDdEQsQ0FBQzs4R0FSVSxtQ0FBbUM7a0dBQW5DLG1DQUFtQzs7U0FBbkMsbUNBQW1DOzJGQUFuQyxtQ0FBbUM7a0JBSi9DLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLGdDQUFnQztvQkFDMUMsVUFBVSxFQUFFLElBQUk7aUJBQ2pCOzhCQUlLLGNBQWM7c0JBRmpCLEtBQUs7dUJBQUMsOEJBQThCOztzQkFDcEMsV0FBVzt1QkFBQyxTQUFTLG1DQUFtQyxFQUFFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQm9vbGVhbklucHV0LCBjb2VyY2VCb29sZWFuUHJvcGVydHkgfSBmcm9tICdAYW5ndWxhci9jZGsvY29lcmNpb24nO1xuaW1wb3J0IHsgRGlyZWN0aXZlLCBIb3N0QmluZGluZywgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuZXhwb3J0IGNvbnN0IFNDUk9MTF9PQlNFUlZFUl9GSVJTVF9FTEVNRU5UX0NMQVNTID0gJ2V0LXNjcm9sbC1vYnNlcnZlci1maXJzdC1lbGVtZW50JztcblxuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnW2V0U2Nyb2xsT2JzZXJ2ZXJGaXJzdEVsZW1lbnRdJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbn0pXG5leHBvcnQgY2xhc3MgU2Nyb2xsT2JzZXJ2ZXJGaXJzdEVsZW1lbnREaXJlY3RpdmUge1xuICBASW5wdXQoJ2V0U2Nyb2xsT2JzZXJ2ZXJGaXJzdEVsZW1lbnQnKVxuICBASG9zdEJpbmRpbmcoYGNsYXNzLiR7U0NST0xMX09CU0VSVkVSX0ZJUlNUX0VMRU1FTlRfQ0xBU1N9YClcbiAgZ2V0IGlzRmlyc3RFbGVtZW50KCk6IGJvb2xlYW4ge1xuICAgIHJldHVybiB0aGlzLl9pc0ZpcnN0RWxlbWVudDtcbiAgfVxuICBzZXQgaXNGaXJzdEVsZW1lbnQodmFsdWU6IEJvb2xlYW5JbnB1dCkge1xuICAgIHRoaXMuX2lzRmlyc3RFbGVtZW50ID0gY29lcmNlQm9vbGVhblByb3BlcnR5KHZhbHVlKTtcbiAgfVxuICBwcml2YXRlIF9pc0ZpcnN0RWxlbWVudCA9IGZhbHNlO1xufVxuIl19
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { Directive } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export const SCROLL_OBSERVER_IGNORE_TARGET_CLASS = 'et-scroll-observer-ignore-target';
|
|
4
|
+
class ScrollObserverIgnoreTargetDirective {
|
|
5
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: ScrollObserverIgnoreTargetDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
6
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.0", type: ScrollObserverIgnoreTargetDirective, isStandalone: true, selector: "[etScrollObserverIgnoreTarget]", host: { classAttribute: "et-scroll-observer-ignore-target" }, ngImport: i0 }); }
|
|
7
|
+
}
|
|
8
|
+
export { ScrollObserverIgnoreTargetDirective };
|
|
9
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: ScrollObserverIgnoreTargetDirective, decorators: [{
|
|
10
|
+
type: Directive,
|
|
11
|
+
args: [{
|
|
12
|
+
selector: '[etScrollObserverIgnoreTarget]',
|
|
13
|
+
standalone: true,
|
|
14
|
+
host: {
|
|
15
|
+
class: SCROLL_OBSERVER_IGNORE_TARGET_CLASS,
|
|
16
|
+
},
|
|
17
|
+
}]
|
|
18
|
+
}] });
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2Nyb2xsLW9ic2VydmVyLWlnbm9yZS10YXJnZXQuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb3JlL3NyYy9saWIvZGlyZWN0aXZlcy9zY3JvbGwtb2JzZXJ2ZXItaWdub3JlLXRhcmdldC9zY3JvbGwtb2JzZXJ2ZXItaWdub3JlLXRhcmdldC5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFFMUMsTUFBTSxDQUFDLE1BQU0sbUNBQW1DLEdBQUcsa0NBQWtDLENBQUM7QUFFdEYsTUFPYSxtQ0FBbUM7OEdBQW5DLG1DQUFtQztrR0FBbkMsbUNBQW1DOztTQUFuQyxtQ0FBbUM7MkZBQW5DLG1DQUFtQztrQkFQL0MsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsZ0NBQWdDO29CQUMxQyxVQUFVLEVBQUUsSUFBSTtvQkFDaEIsSUFBSSxFQUFFO3dCQUNKLEtBQUssRUFBRSxtQ0FBbUM7cUJBQzNDO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmV4cG9ydCBjb25zdCBTQ1JPTExfT0JTRVJWRVJfSUdOT1JFX1RBUkdFVF9DTEFTUyA9ICdldC1zY3JvbGwtb2JzZXJ2ZXItaWdub3JlLXRhcmdldCc7XG5cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ1tldFNjcm9sbE9ic2VydmVySWdub3JlVGFyZ2V0XScsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGhvc3Q6IHtcbiAgICBjbGFzczogU0NST0xMX09CU0VSVkVSX0lHTk9SRV9UQVJHRVRfQ0xBU1MsXG4gIH0sXG59KVxuZXhwb3J0IGNsYXNzIFNjcm9sbE9ic2VydmVySWdub3JlVGFyZ2V0RGlyZWN0aXZlIHt9XG4iXX0=
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { coerceBooleanProperty } from '@angular/cdk/coercion';
|
|
2
|
+
import { Directive, HostBinding, Input } from '@angular/core';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export const SCROLL_OBSERVER_LAST_ELEMENT_CLASS = 'et-scroll-observer-last-element';
|
|
5
|
+
class ScrollObserverLastElementDirective {
|
|
6
|
+
constructor() {
|
|
7
|
+
this._isLastElement = false;
|
|
8
|
+
}
|
|
9
|
+
get isLastElement() {
|
|
10
|
+
return this._isLastElement;
|
|
11
|
+
}
|
|
12
|
+
set isLastElement(value) {
|
|
13
|
+
this._isLastElement = coerceBooleanProperty(value);
|
|
14
|
+
}
|
|
15
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: ScrollObserverLastElementDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
16
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.0", type: ScrollObserverLastElementDirective, isStandalone: true, selector: "[etScrollObserverLastElement]", inputs: { isLastElement: ["etScrollObserverLastElement", "isLastElement"] }, host: { properties: { "class.et-scroll-observer-last-element": "this.isLastElement" }, classAttribute: "et-scroll-observer-last-element" }, ngImport: i0 }); }
|
|
17
|
+
}
|
|
18
|
+
export { ScrollObserverLastElementDirective };
|
|
19
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: ScrollObserverLastElementDirective, decorators: [{
|
|
20
|
+
type: Directive,
|
|
21
|
+
args: [{
|
|
22
|
+
selector: '[etScrollObserverLastElement]',
|
|
23
|
+
standalone: true,
|
|
24
|
+
host: {
|
|
25
|
+
class: SCROLL_OBSERVER_LAST_ELEMENT_CLASS,
|
|
26
|
+
},
|
|
27
|
+
}]
|
|
28
|
+
}], propDecorators: { isLastElement: [{
|
|
29
|
+
type: Input,
|
|
30
|
+
args: ['etScrollObserverLastElement']
|
|
31
|
+
}, {
|
|
32
|
+
type: HostBinding,
|
|
33
|
+
args: [`class.${SCROLL_OBSERVER_LAST_ELEMENT_CLASS}`]
|
|
34
|
+
}] } });
|
|
35
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2Nyb2xsLW9ic2VydmVyLWxhc3QtZWxlbWVudC5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvcmUvc3JjL2xpYi9kaXJlY3RpdmVzL3Njcm9sbC1vYnNlcnZlci1sYXN0LWVsZW1lbnQvc2Nyb2xsLW9ic2VydmVyLWxhc3QtZWxlbWVudC5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFnQixxQkFBcUIsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQzVFLE9BQU8sRUFBRSxTQUFTLEVBQUUsV0FBVyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFFOUQsTUFBTSxDQUFDLE1BQU0sa0NBQWtDLEdBQUcsaUNBQWlDLENBQUM7QUFFcEYsTUFPYSxrQ0FBa0M7SUFQL0M7UUFnQlUsbUJBQWMsR0FBRyxLQUFLLENBQUM7S0FDaEM7SUFUQyxJQUVJLGFBQWE7UUFDZixPQUFPLElBQUksQ0FBQyxjQUFjLENBQUM7SUFDN0IsQ0FBQztJQUNELElBQUksYUFBYSxDQUFDLEtBQW1CO1FBQ25DLElBQUksQ0FBQyxjQUFjLEdBQUcscUJBQXFCLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDckQsQ0FBQzs4R0FSVSxrQ0FBa0M7a0dBQWxDLGtDQUFrQzs7U0FBbEMsa0NBQWtDOzJGQUFsQyxrQ0FBa0M7a0JBUDlDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLCtCQUErQjtvQkFDekMsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLElBQUksRUFBRTt3QkFDSixLQUFLLEVBQUUsa0NBQWtDO3FCQUMxQztpQkFDRjs4QkFJSyxhQUFhO3NCQUZoQixLQUFLO3VCQUFDLDZCQUE2Qjs7c0JBQ25DLFdBQVc7dUJBQUMsU0FBUyxrQ0FBa0MsRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEJvb2xlYW5JbnB1dCwgY29lcmNlQm9vbGVhblByb3BlcnR5IH0gZnJvbSAnQGFuZ3VsYXIvY2RrL2NvZXJjaW9uJztcbmltcG9ydCB7IERpcmVjdGl2ZSwgSG9zdEJpbmRpbmcsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmV4cG9ydCBjb25zdCBTQ1JPTExfT0JTRVJWRVJfTEFTVF9FTEVNRU5UX0NMQVNTID0gJ2V0LXNjcm9sbC1vYnNlcnZlci1sYXN0LWVsZW1lbnQnO1xuXG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6ICdbZXRTY3JvbGxPYnNlcnZlckxhc3RFbGVtZW50XScsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGhvc3Q6IHtcbiAgICBjbGFzczogU0NST0xMX09CU0VSVkVSX0xBU1RfRUxFTUVOVF9DTEFTUyxcbiAgfSxcbn0pXG5leHBvcnQgY2xhc3MgU2Nyb2xsT2JzZXJ2ZXJMYXN0RWxlbWVudERpcmVjdGl2ZSB7XG4gIEBJbnB1dCgnZXRTY3JvbGxPYnNlcnZlckxhc3RFbGVtZW50JylcbiAgQEhvc3RCaW5kaW5nKGBjbGFzcy4ke1NDUk9MTF9PQlNFUlZFUl9MQVNUX0VMRU1FTlRfQ0xBU1N9YClcbiAgZ2V0IGlzTGFzdEVsZW1lbnQoKTogYm9vbGVhbiB7XG4gICAgcmV0dXJuIHRoaXMuX2lzTGFzdEVsZW1lbnQ7XG4gIH1cbiAgc2V0IGlzTGFzdEVsZW1lbnQodmFsdWU6IEJvb2xlYW5JbnB1dCkge1xuICAgIHRoaXMuX2lzTGFzdEVsZW1lbnQgPSBjb2VyY2VCb29sZWFuUHJvcGVydHkodmFsdWUpO1xuICB9XG4gIHByaXZhdGUgX2lzTGFzdEVsZW1lbnQgPSBmYWxzZTtcbn1cbiJdfQ==
|
|
@@ -0,0 +1,167 @@
|
|
|
1
|
+
import { Directive, inject } from '@angular/core';
|
|
2
|
+
import { Meta, Title } from '@angular/platform-browser';
|
|
3
|
+
import { Observable, Subject, takeUntil } from 'rxjs';
|
|
4
|
+
import { SEO_DIRECTIVE_TOKEN } from './seo.directive.constants';
|
|
5
|
+
import { mergeSeoConfig } from './seo.directive.utils';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
class SeoDirective {
|
|
8
|
+
constructor() {
|
|
9
|
+
this._metaService = inject(Meta);
|
|
10
|
+
this._titleService = inject(Title);
|
|
11
|
+
this._onDeactivate$ = new Subject();
|
|
12
|
+
this._isDeactivated = false;
|
|
13
|
+
this.parent = inject(SEO_DIRECTIVE_TOKEN, { optional: true, skipSelf: true });
|
|
14
|
+
this._config = {};
|
|
15
|
+
}
|
|
16
|
+
get config() {
|
|
17
|
+
return this._config;
|
|
18
|
+
}
|
|
19
|
+
ngOnInit() {
|
|
20
|
+
this.parent?._deactivate();
|
|
21
|
+
}
|
|
22
|
+
ngOnDestroy() {
|
|
23
|
+
this._deactivate();
|
|
24
|
+
this._cleanUp();
|
|
25
|
+
this.parent?._activate();
|
|
26
|
+
}
|
|
27
|
+
// TODO(TRB): This should get split up into multiple methods to make it more readable
|
|
28
|
+
// - updateTitle
|
|
29
|
+
// - updateMeta
|
|
30
|
+
// - updateLink
|
|
31
|
+
updateConfig(config) {
|
|
32
|
+
this._config = mergeSeoConfig(config, this.parent?.config || {});
|
|
33
|
+
if (this._isDeactivated) {
|
|
34
|
+
return;
|
|
35
|
+
}
|
|
36
|
+
this._deactivate();
|
|
37
|
+
this._activate();
|
|
38
|
+
}
|
|
39
|
+
_activate() {
|
|
40
|
+
this._onDeactivate$.next(false);
|
|
41
|
+
this._isDeactivated = false;
|
|
42
|
+
for (const [key, value] of Object.entries(this._config)) {
|
|
43
|
+
if (value instanceof Observable) {
|
|
44
|
+
value.pipe(takeUntil(this._onDeactivate$)).subscribe((value) => this._update(key, value));
|
|
45
|
+
}
|
|
46
|
+
else if (Array.isArray(value)) {
|
|
47
|
+
value.forEach((value) => {
|
|
48
|
+
if (value instanceof Observable) {
|
|
49
|
+
value.pipe(takeUntil(this._onDeactivate$)).subscribe((value) => this._update(key, value));
|
|
50
|
+
}
|
|
51
|
+
else {
|
|
52
|
+
this._update(key, value);
|
|
53
|
+
}
|
|
54
|
+
});
|
|
55
|
+
}
|
|
56
|
+
else if (typeof value === 'object' && value !== null) {
|
|
57
|
+
for (const [subKey, subValue] of Object.entries(value)) {
|
|
58
|
+
if (subValue instanceof Observable) {
|
|
59
|
+
subValue.pipe(takeUntil(this._onDeactivate$)).subscribe((value) => this._update(`${key}:${subKey}`, value));
|
|
60
|
+
}
|
|
61
|
+
else {
|
|
62
|
+
this._update(`${key}:${subKey}`, subValue);
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
else {
|
|
67
|
+
this._update(key, value);
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
_deactivate() {
|
|
72
|
+
this._onDeactivate$.next(true);
|
|
73
|
+
this._isDeactivated = true;
|
|
74
|
+
}
|
|
75
|
+
_update(key, value) {
|
|
76
|
+
switch (key) {
|
|
77
|
+
case 'title':
|
|
78
|
+
if (value && typeof value === 'string') {
|
|
79
|
+
this._titleService.setTitle(value);
|
|
80
|
+
}
|
|
81
|
+
break;
|
|
82
|
+
case 'canonical':
|
|
83
|
+
{
|
|
84
|
+
const link = document.querySelector(`link[rel="${key}"]`);
|
|
85
|
+
if (link) {
|
|
86
|
+
link.setAttribute('href', value);
|
|
87
|
+
}
|
|
88
|
+
else {
|
|
89
|
+
const newLink = document.createElement('link');
|
|
90
|
+
newLink.setAttribute('rel', key);
|
|
91
|
+
newLink.setAttribute('href', value);
|
|
92
|
+
document.head.appendChild(newLink);
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
break;
|
|
96
|
+
case 'alternate':
|
|
97
|
+
{
|
|
98
|
+
const link = document.querySelector(`link[rel="${key}"][hreflang="${value.hreflang}"]`);
|
|
99
|
+
if (link) {
|
|
100
|
+
link.setAttribute('href', value.href);
|
|
101
|
+
}
|
|
102
|
+
else {
|
|
103
|
+
const newLink = document.createElement('link');
|
|
104
|
+
newLink.setAttribute('rel', key);
|
|
105
|
+
newLink.setAttribute('hreflang', value.hreflang);
|
|
106
|
+
newLink.setAttribute('href', value.href);
|
|
107
|
+
document.head.appendChild(newLink);
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
break;
|
|
111
|
+
default:
|
|
112
|
+
if (value !== undefined && value !== null) {
|
|
113
|
+
const val = Array.isArray(value) ? value.join(', ') : value;
|
|
114
|
+
this._metaService.updateTag({ name: key, content: val });
|
|
115
|
+
}
|
|
116
|
+
else {
|
|
117
|
+
this._metaService.removeTag(`name="${key}"`);
|
|
118
|
+
}
|
|
119
|
+
break;
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
_cleanUp() {
|
|
123
|
+
for (const key in this._config) {
|
|
124
|
+
if (key === 'alternate') {
|
|
125
|
+
const links = document.querySelectorAll(`link[rel="${key}"]`);
|
|
126
|
+
links.forEach((link) => {
|
|
127
|
+
link.remove();
|
|
128
|
+
});
|
|
129
|
+
continue;
|
|
130
|
+
}
|
|
131
|
+
if (key === 'canonical') {
|
|
132
|
+
const link = document.querySelector(`link[rel="${key}"]`);
|
|
133
|
+
if (link) {
|
|
134
|
+
link.remove();
|
|
135
|
+
}
|
|
136
|
+
continue;
|
|
137
|
+
}
|
|
138
|
+
if (typeof this._config[key] === 'object' &&
|
|
139
|
+
this._config[key] !== null &&
|
|
140
|
+
!(this._config[key] instanceof Observable)) {
|
|
141
|
+
for (const subKey in this._config[key]) {
|
|
142
|
+
const parentValue = this.parent?.config?.[key]?.[subKey];
|
|
143
|
+
if (parentValue === undefined) {
|
|
144
|
+
this._update(`${key}:${subKey}`, undefined);
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
else {
|
|
149
|
+
const parentValue = this.parent?.config?.[key];
|
|
150
|
+
if (parentValue === undefined) {
|
|
151
|
+
this._update(key, null);
|
|
152
|
+
}
|
|
153
|
+
}
|
|
154
|
+
}
|
|
155
|
+
}
|
|
156
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: SeoDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
157
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.0", type: SeoDirective, isStandalone: true, providers: [{ provide: SEO_DIRECTIVE_TOKEN, useExisting: SeoDirective }], ngImport: i0 }); }
|
|
158
|
+
}
|
|
159
|
+
export { SeoDirective };
|
|
160
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: SeoDirective, decorators: [{
|
|
161
|
+
type: Directive,
|
|
162
|
+
args: [{
|
|
163
|
+
standalone: true,
|
|
164
|
+
providers: [{ provide: SEO_DIRECTIVE_TOKEN, useExisting: SeoDirective }],
|
|
165
|
+
}]
|
|
166
|
+
}] });
|
|
167
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"seo.directive.js","sourceRoot":"","sources":["../../../../../../../libs/core/src/lib/directives/seo/seo.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, inject, OnDestroy, OnInit } from '@angular/core';\nimport { Meta, Title } from '@angular/platform-browser';\nimport { Observable, Subject, takeUntil } from 'rxjs';\nimport { SEO_DIRECTIVE_TOKEN } from './seo.directive.constants';\nimport { AlternateLink, SeoConfig } from './seo.directive.types';\nimport { mergeSeoConfig } from './seo.directive.utils';\n\n@Directive({\n  standalone: true,\n  providers: [{ provide: SEO_DIRECTIVE_TOKEN, useExisting: SeoDirective }],\n})\nexport class SeoDirective implements OnInit, OnDestroy {\n  private readonly _metaService = inject(Meta);\n  private readonly _titleService = inject(Title);\n  private readonly _onDeactivate$ = new Subject<boolean>();\n\n  private _isDeactivated = false;\n\n  readonly parent = inject(SEO_DIRECTIVE_TOKEN, { optional: true, skipSelf: true });\n\n  get config(): SeoConfig {\n    return this._config;\n  }\n  private _config: SeoConfig = {};\n\n  ngOnInit(): void {\n    this.parent?._deactivate();\n  }\n\n  ngOnDestroy(): void {\n    this._deactivate();\n    this._cleanUp();\n    this.parent?._activate();\n  }\n\n  // TODO(TRB): This should get split up into multiple methods to make it more readable\n  // - updateTitle\n  // - updateMeta\n  // - updateLink\n  updateConfig(config: SeoConfig) {\n    this._config = mergeSeoConfig(config, this.parent?.config || {});\n\n    if (this._isDeactivated) {\n      return;\n    }\n\n    this._deactivate();\n    this._activate();\n  }\n\n  _activate() {\n    this._onDeactivate$.next(false);\n    this._isDeactivated = false;\n\n    for (const [key, value] of Object.entries(this._config)) {\n      if (value instanceof Observable) {\n        value.pipe(takeUntil(this._onDeactivate$)).subscribe((value) => this._update(key, value));\n      } else if (Array.isArray(value)) {\n        value.forEach((value) => {\n          if (value instanceof Observable) {\n            value.pipe(takeUntil(this._onDeactivate$)).subscribe((value) => this._update(key, value));\n          } else {\n            this._update(key, value);\n          }\n        });\n      } else if (typeof value === 'object' && value !== null) {\n        for (const [subKey, subValue] of Object.entries(value)) {\n          if (subValue instanceof Observable) {\n            subValue.pipe(takeUntil(this._onDeactivate$)).subscribe((value) => this._update(`${key}:${subKey}`, value));\n          } else {\n            this._update(`${key}:${subKey}`, subValue);\n          }\n        }\n      } else {\n        this._update(key, value);\n      }\n    }\n  }\n\n  _deactivate() {\n    this._onDeactivate$.next(true);\n    this._isDeactivated = true;\n  }\n\n  private _update(key: string, value: unknown) {\n    switch (key) {\n      case 'title':\n        if (value && typeof value === 'string') {\n          this._titleService.setTitle(value);\n        }\n        break;\n\n      case 'canonical':\n        {\n          const link = document.querySelector(`link[rel=\"${key}\"]`);\n\n          if (link) {\n            link.setAttribute('href', value as string);\n          } else {\n            const newLink = document.createElement('link');\n            newLink.setAttribute('rel', key);\n            newLink.setAttribute('href', value as string);\n            document.head.appendChild(newLink);\n          }\n        }\n\n        break;\n\n      case 'alternate':\n        {\n          const link = document.querySelector(`link[rel=\"${key}\"][hreflang=\"${(value as AlternateLink).hreflang}\"]`);\n\n          if (link) {\n            link.setAttribute('href', (value as AlternateLink).href);\n          } else {\n            const newLink = document.createElement('link');\n            newLink.setAttribute('rel', key);\n            newLink.setAttribute('hreflang', (value as AlternateLink).hreflang);\n            newLink.setAttribute('href', (value as AlternateLink).href);\n            document.head.appendChild(newLink);\n          }\n        }\n\n        break;\n\n      default:\n        if (value !== undefined && value !== null) {\n          const val = Array.isArray(value) ? value.join(', ') : (value as string);\n\n          this._metaService.updateTag({ name: key, content: val });\n        } else {\n          this._metaService.removeTag(`name=\"${key}\"`);\n        }\n        break;\n    }\n  }\n\n  private _cleanUp() {\n    for (const key in this._config) {\n      if (key === 'alternate') {\n        const links = document.querySelectorAll(`link[rel=\"${key}\"]`);\n\n        links.forEach((link) => {\n          link.remove();\n        });\n\n        continue;\n      }\n\n      if (key === 'canonical') {\n        const link = document.querySelector(`link[rel=\"${key}\"]`);\n\n        if (link) {\n          link.remove();\n        }\n\n        continue;\n      }\n\n      if (\n        typeof this._config[key] === 'object' &&\n        this._config[key] !== null &&\n        !(this._config[key] instanceof Observable)\n      ) {\n        for (const subKey in this._config[key] as Record<string, unknown>) {\n          const parentValue =\n            this.parent?.config?.[key as keyof SeoConfig]?.[subKey as keyof SeoConfig[keyof SeoConfig]];\n\n          if (parentValue === undefined) {\n            this._update(`${key}:${subKey}`, undefined);\n          }\n        }\n      } else {\n        const parentValue = this.parent?.config?.[key as keyof SeoConfig];\n\n        if (parentValue === undefined) {\n          this._update(key, null);\n        }\n      }\n    }\n  }\n}\n"]}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { Pipe } from '@angular/core';
|
|
2
|
+
import { normalizeGameResultType } from './normalize-game-result-type.util';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
class NormalizeGameResultTypePipe {
|
|
5
|
+
constructor() {
|
|
6
|
+
this.transform = normalizeGameResultType;
|
|
7
|
+
}
|
|
8
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NormalizeGameResultTypePipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
|
|
9
|
+
static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "16.0.0", ngImport: i0, type: NormalizeGameResultTypePipe, isStandalone: true, name: "etNormalizeGameResultType" }); }
|
|
10
|
+
}
|
|
11
|
+
export { NormalizeGameResultTypePipe };
|
|
12
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NormalizeGameResultTypePipe, decorators: [{
|
|
13
|
+
type: Pipe,
|
|
14
|
+
args: [{ name: 'etNormalizeGameResultType', standalone: true }]
|
|
15
|
+
}] });
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9ybWFsaXplLWdhbWUtcmVzdWx0LXR5cGUucGlwZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29yZS9zcmMvbGliL3BpcGVzL25vcm1hbGl6ZS1nYW1lLXJlc3VsdC10eXBlL25vcm1hbGl6ZS1nYW1lLXJlc3VsdC10eXBlLnBpcGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLElBQUksRUFBaUIsTUFBTSxlQUFlLENBQUM7QUFDcEQsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sbUNBQW1DLENBQUM7O0FBRTVFLE1BQ2EsMkJBQTJCO0lBRHhDO1FBRUUsY0FBUyxHQUFHLHVCQUF1QixDQUFDO0tBQ3JDOzhHQUZZLDJCQUEyQjs0R0FBM0IsMkJBQTJCOztTQUEzQiwyQkFBMkI7MkZBQTNCLDJCQUEyQjtrQkFEdkMsSUFBSTttQkFBQyxFQUFFLElBQUksRUFBRSwyQkFBMkIsRUFBRSxVQUFVLEVBQUUsSUFBSSxFQUFFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUGlwZSwgUGlwZVRyYW5zZm9ybSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgbm9ybWFsaXplR2FtZVJlc3VsdFR5cGUgfSBmcm9tICcuL25vcm1hbGl6ZS1nYW1lLXJlc3VsdC10eXBlLnV0aWwnO1xuXG5AUGlwZSh7IG5hbWU6ICdldE5vcm1hbGl6ZUdhbWVSZXN1bHRUeXBlJywgc3RhbmRhbG9uZTogdHJ1ZSB9KVxuZXhwb3J0IGNsYXNzIE5vcm1hbGl6ZUdhbWVSZXN1bHRUeXBlUGlwZSBpbXBsZW1lbnRzIFBpcGVUcmFuc2Zvcm0ge1xuICB0cmFuc2Zvcm0gPSBub3JtYWxpemVHYW1lUmVzdWx0VHlwZTtcbn1cbiJdfQ==
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { Pipe } from '@angular/core';
|
|
2
|
+
import { normalizeMatchParticipants } from './normalize-match-participants.util';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
class NormalizeMatchParticipantsPipe {
|
|
5
|
+
constructor() {
|
|
6
|
+
this.transform = normalizeMatchParticipants;
|
|
7
|
+
}
|
|
8
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NormalizeMatchParticipantsPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
|
|
9
|
+
static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "16.0.0", ngImport: i0, type: NormalizeMatchParticipantsPipe, isStandalone: true, name: "etNormalizeMatchParticipants" }); }
|
|
10
|
+
}
|
|
11
|
+
export { NormalizeMatchParticipantsPipe };
|
|
12
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NormalizeMatchParticipantsPipe, decorators: [{
|
|
13
|
+
type: Pipe,
|
|
14
|
+
args: [{ name: 'etNormalizeMatchParticipants', standalone: true }]
|
|
15
|
+
}] });
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9ybWFsaXplLW1hdGNoLXBhcnRpY2lwYW50cy5waXBlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb3JlL3NyYy9saWIvcGlwZXMvbm9ybWFsaXplLW1hdGNoLXBhcnRpY2lwYW50cy9ub3JtYWxpemUtbWF0Y2gtcGFydGljaXBhbnRzLnBpcGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLElBQUksRUFBaUIsTUFBTSxlQUFlLENBQUM7QUFDcEQsT0FBTyxFQUFFLDBCQUEwQixFQUFFLE1BQU0scUNBQXFDLENBQUM7O0FBRWpGLE1BQ2EsOEJBQThCO0lBRDNDO1FBRUUsY0FBUyxHQUFHLDBCQUEwQixDQUFDO0tBQ3hDOzhHQUZZLDhCQUE4Qjs0R0FBOUIsOEJBQThCOztTQUE5Qiw4QkFBOEI7MkZBQTlCLDhCQUE4QjtrQkFEMUMsSUFBSTttQkFBQyxFQUFFLElBQUksRUFBRSw4QkFBOEIsRUFBRSxVQUFVLEVBQUUsSUFBSSxFQUFFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUGlwZSwgUGlwZVRyYW5zZm9ybSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgbm9ybWFsaXplTWF0Y2hQYXJ0aWNpcGFudHMgfSBmcm9tICcuL25vcm1hbGl6ZS1tYXRjaC1wYXJ0aWNpcGFudHMudXRpbCc7XG5cbkBQaXBlKHsgbmFtZTogJ2V0Tm9ybWFsaXplTWF0Y2hQYXJ0aWNpcGFudHMnLCBzdGFuZGFsb25lOiB0cnVlIH0pXG5leHBvcnQgY2xhc3MgTm9ybWFsaXplTWF0Y2hQYXJ0aWNpcGFudHNQaXBlIGltcGxlbWVudHMgUGlwZVRyYW5zZm9ybSB7XG4gIHRyYW5zZm9ybSA9IG5vcm1hbGl6ZU1hdGNoUGFydGljaXBhbnRzO1xufVxuIl19
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { Pipe } from '@angular/core';
|
|
2
|
+
import { normalizeMatchScore } from './normalize-match-score.util';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
class NormalizeMatchScorePipe {
|
|
5
|
+
constructor() {
|
|
6
|
+
this.transform = normalizeMatchScore;
|
|
7
|
+
}
|
|
8
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NormalizeMatchScorePipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
|
|
9
|
+
static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "16.0.0", ngImport: i0, type: NormalizeMatchScorePipe, isStandalone: true, name: "etNormalizeMatchScore" }); }
|
|
10
|
+
}
|
|
11
|
+
export { NormalizeMatchScorePipe };
|
|
12
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NormalizeMatchScorePipe, decorators: [{
|
|
13
|
+
type: Pipe,
|
|
14
|
+
args: [{ name: 'etNormalizeMatchScore', standalone: true }]
|
|
15
|
+
}] });
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9ybWFsaXplLW1hdGNoLXNjb3JlLnBpcGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvcmUvc3JjL2xpYi9waXBlcy9ub3JtYWxpemUtbWF0Y2gtc2NvcmUvbm9ybWFsaXplLW1hdGNoLXNjb3JlLnBpcGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLElBQUksRUFBaUIsTUFBTSxlQUFlLENBQUM7QUFDcEQsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sOEJBQThCLENBQUM7O0FBRW5FLE1BQ2EsdUJBQXVCO0lBRHBDO1FBRUUsY0FBUyxHQUFHLG1CQUFtQixDQUFDO0tBQ2pDOzhHQUZZLHVCQUF1Qjs0R0FBdkIsdUJBQXVCOztTQUF2Qix1QkFBdUI7MkZBQXZCLHVCQUF1QjtrQkFEbkMsSUFBSTttQkFBQyxFQUFFLElBQUksRUFBRSx1QkFBdUIsRUFBRSxVQUFVLEVBQUUsSUFBSSxFQUFFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUGlwZSwgUGlwZVRyYW5zZm9ybSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgbm9ybWFsaXplTWF0Y2hTY29yZSB9IGZyb20gJy4vbm9ybWFsaXplLW1hdGNoLXNjb3JlLnV0aWwnO1xuXG5AUGlwZSh7IG5hbWU6ICdldE5vcm1hbGl6ZU1hdGNoU2NvcmUnLCBzdGFuZGFsb25lOiB0cnVlIH0pXG5leHBvcnQgY2xhc3MgTm9ybWFsaXplTWF0Y2hTY29yZVBpcGUgaW1wbGVtZW50cyBQaXBlVHJhbnNmb3JtIHtcbiAgdHJhbnNmb3JtID0gbm9ybWFsaXplTWF0Y2hTY29yZTtcbn1cbiJdfQ==
|