@ethlete/core 0.2.0-next.2 → 0.2.0-next.21
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/components/public-api.mjs +2 -0
- package/esm2020/lib/components/structured-data/public-api.mjs +2 -0
- package/esm2020/lib/components/structured-data/structured-data.component.mjs +37 -0
- package/esm2020/lib/directives/click-outside/click-outside.directive.mjs +37 -0
- package/esm2020/lib/directives/click-outside/public-api.mjs +2 -0
- package/esm2020/lib/directives/cursor-drag-scroll/cursor-drag-scroll.constants.mjs +3 -0
- package/esm2020/lib/directives/cursor-drag-scroll/cursor-drag-scroll.directive.mjs +147 -0
- package/esm2020/lib/directives/cursor-drag-scroll/public-api.mjs +2 -0
- package/esm2020/lib/directives/let/let.directive.mjs +8 -8
- package/esm2020/lib/directives/observe-content/observe-content.directive.mjs +11 -11
- package/esm2020/lib/directives/observe-resize/observe-resize.directive.mjs +11 -12
- package/esm2020/lib/directives/observe-scroll-state/observe-scroll-state.constants.mjs +3 -0
- package/esm2020/lib/directives/observe-scroll-state/observe-scroll-state.directive.mjs +171 -0
- package/esm2020/lib/directives/observe-scroll-state/observe-scroll-state.types.mjs +2 -0
- package/esm2020/lib/directives/observe-scroll-state/public-api.mjs +3 -0
- package/esm2020/lib/directives/public-api.mjs +10 -3
- package/esm2020/lib/directives/repeat/repeat.directive.mjs +10 -11
- package/esm2020/lib/directives/scroll-observer-first-element/index.mjs +2 -0
- package/esm2020/lib/directives/scroll-observer-first-element/public-api.mjs +2 -0
- package/esm2020/lib/directives/scroll-observer-first-element/scroll-observer-first-element.directive.mjs +31 -0
- package/esm2020/lib/directives/scroll-observer-ignore-target/index.mjs +2 -0
- package/esm2020/lib/directives/scroll-observer-ignore-target/public-api.mjs +2 -0
- package/esm2020/lib/directives/scroll-observer-ignore-target/scroll-observer-ignore-target.directive.mjs +18 -0
- package/esm2020/lib/directives/scroll-observer-last-element/index.mjs +2 -0
- package/esm2020/lib/directives/scroll-observer-last-element/public-api.mjs +2 -0
- package/esm2020/lib/directives/scroll-observer-last-element/scroll-observer-last-element.directive.mjs +34 -0
- package/esm2020/lib/directives/seo/public-api.mjs +5 -0
- package/esm2020/lib/directives/seo/seo.directive.constants.mjs +3 -0
- package/esm2020/lib/directives/seo/seo.directive.mjs +166 -0
- package/esm2020/lib/directives/seo/seo.directive.types.mjs +2 -0
- package/esm2020/lib/directives/seo/seo.directive.utils.mjs +7 -0
- package/esm2020/lib/pipes/normalize-game-result-type/normalize-game-result-type.pipe.mjs +15 -0
- package/esm2020/lib/pipes/normalize-game-result-type/normalize-game-result-type.types.mjs +2 -0
- package/esm2020/lib/pipes/normalize-game-result-type/normalize-game-result-type.util.mjs +34 -0
- package/esm2020/lib/pipes/normalize-game-result-type/public-api.mjs +4 -0
- package/esm2020/lib/pipes/normalize-match-participants/normalize-match-participants.pipe.mjs +15 -0
- package/esm2020/lib/pipes/normalize-match-participants/normalize-match-participants.types.mjs +2 -0
- package/esm2020/lib/pipes/normalize-match-participants/normalize-match-participants.util.mjs +47 -0
- package/esm2020/lib/pipes/normalize-match-participants/public-api.mjs +4 -0
- package/esm2020/lib/pipes/normalize-match-score/normalize-match-score.pipe.mjs +15 -0
- package/esm2020/lib/pipes/normalize-match-score/normalize-match-score.types.mjs +2 -0
- package/esm2020/lib/pipes/normalize-match-score/normalize-match-score.util.mjs +126 -0
- package/esm2020/lib/pipes/normalize-match-score/public-api.mjs +4 -0
- package/esm2020/lib/pipes/normalize-match-state/index.mjs +2 -0
- package/esm2020/lib/pipes/normalize-match-state/normalize-match-state.constants.mjs +2 -0
- package/esm2020/lib/pipes/normalize-match-state/normalize-match-state.pipe.mjs +15 -0
- package/esm2020/lib/pipes/normalize-match-state/normalize-match-state.util.mjs +19 -0
- package/esm2020/lib/pipes/normalize-match-state/public-api.mjs +4 -0
- package/esm2020/lib/pipes/normalize-match-type/normalize-match-type.pipe.mjs +15 -0
- package/esm2020/lib/pipes/normalize-match-type/normalize-match-type.util.mjs +38 -0
- package/esm2020/lib/pipes/normalize-match-type/public-api.mjs +3 -0
- package/esm2020/lib/pipes/public-api.mjs +6 -1
- package/esm2020/lib/pipes/to-array/to-array.pipe.mjs +3 -3
- package/esm2020/lib/public-api.mjs +2 -1
- package/esm2020/lib/services/click-observer.service.mjs +73 -0
- package/esm2020/lib/services/content-observer.service.mjs +6 -6
- package/esm2020/lib/services/destroy.service.mjs +19 -0
- package/esm2020/lib/services/focus-visible.service.mjs +7 -7
- package/esm2020/lib/services/public-api.mjs +7 -4
- package/esm2020/lib/services/resize-observer.service.mjs +6 -6
- package/esm2020/lib/services/router-state.service.mjs +115 -0
- package/esm2020/lib/services/viewport.service.mjs +16 -16
- package/esm2020/lib/types/angular.types.mjs +36 -2
- package/esm2020/lib/types/i18n.types.mjs +2 -0
- package/esm2020/lib/types/public-api.mjs +3 -2
- package/esm2020/lib/utils/clone.util.mjs +78 -0
- package/esm2020/lib/utils/cookie.util.mjs +48 -0
- package/esm2020/lib/utils/equal.util.mjs +118 -0
- package/esm2020/lib/utils/index.mjs +2 -0
- package/esm2020/lib/utils/public-api.mjs +7 -2
- package/esm2020/lib/utils/reactive-binding.util.mjs +111 -0
- package/esm2020/lib/utils/scrollable.utils.mjs +5 -0
- package/fesm2015/ethlete-core.mjs +1821 -289
- package/fesm2015/ethlete-core.mjs.map +1 -1
- package/fesm2020/ethlete-core.mjs +1818 -289
- package/fesm2020/ethlete-core.mjs.map +1 -1
- package/lib/components/public-api.d.ts +1 -0
- package/lib/components/structured-data/public-api.d.ts +1 -0
- package/lib/components/structured-data/structured-data.component.d.ts +11 -0
- package/lib/directives/click-outside/click-outside.directive.d.ts +12 -0
- package/lib/directives/click-outside/public-api.d.ts +1 -0
- package/lib/directives/cursor-drag-scroll/cursor-drag-scroll.constants.d.ts +2 -0
- package/lib/directives/cursor-drag-scroll/cursor-drag-scroll.directive.d.ts +27 -0
- package/lib/directives/cursor-drag-scroll/public-api.d.ts +1 -0
- package/lib/directives/let/let.directive.d.ts +1 -1
- package/lib/directives/observe-content/observe-content.directive.d.ts +2 -4
- package/lib/directives/observe-resize/observe-resize.directive.d.ts +3 -5
- package/lib/directives/observe-scroll-state/observe-scroll-state.constants.d.ts +3 -0
- package/lib/directives/observe-scroll-state/observe-scroll-state.directive.d.ts +31 -0
- package/lib/directives/observe-scroll-state/observe-scroll-state.types.d.ts +6 -0
- package/lib/directives/observe-scroll-state/public-api.d.ts +3 -0
- package/lib/directives/public-api.d.ts +9 -2
- package/lib/directives/repeat/repeat.directive.d.ts +3 -4
- package/lib/directives/scroll-observer-first-element/index.d.ts +1 -0
- package/lib/directives/scroll-observer-first-element/public-api.d.ts +1 -0
- package/lib/directives/scroll-observer-first-element/scroll-observer-first-element.directive.d.ts +10 -0
- package/lib/directives/scroll-observer-ignore-target/index.d.ts +1 -0
- package/lib/directives/scroll-observer-ignore-target/public-api.d.ts +1 -0
- package/lib/directives/scroll-observer-ignore-target/scroll-observer-ignore-target.directive.d.ts +6 -0
- package/lib/directives/scroll-observer-last-element/index.d.ts +1 -0
- package/lib/directives/scroll-observer-last-element/public-api.d.ts +1 -0
- package/lib/directives/scroll-observer-last-element/scroll-observer-last-element.directive.d.ts +10 -0
- package/lib/directives/seo/public-api.d.ts +4 -0
- package/lib/directives/seo/seo.directive.constants.d.ts +3 -0
- package/lib/directives/seo/seo.directive.d.ts +21 -0
- package/lib/directives/seo/seo.directive.types.d.ts +51 -0
- package/lib/directives/seo/seo.directive.utils.d.ts +2 -0
- package/lib/pipes/normalize-game-result-type/normalize-game-result-type.pipe.d.ts +7 -0
- package/lib/pipes/normalize-game-result-type/normalize-game-result-type.types.d.ts +4 -0
- package/lib/pipes/normalize-game-result-type/normalize-game-result-type.util.d.ts +2 -0
- package/lib/pipes/normalize-game-result-type/public-api.d.ts +3 -0
- package/lib/pipes/normalize-match-participants/normalize-match-participants.pipe.d.ts +7 -0
- package/lib/pipes/normalize-match-participants/normalize-match-participants.types.d.ts +21 -0
- package/lib/pipes/normalize-match-participants/normalize-match-participants.util.d.ts +4 -0
- package/lib/pipes/normalize-match-participants/public-api.d.ts +3 -0
- package/lib/pipes/normalize-match-score/normalize-match-score.pipe.d.ts +7 -0
- package/lib/pipes/normalize-match-score/normalize-match-score.types.d.ts +12 -0
- package/lib/pipes/normalize-match-score/normalize-match-score.util.d.ts +27 -0
- package/lib/pipes/normalize-match-score/public-api.d.ts +3 -0
- package/lib/pipes/normalize-match-state/index.d.ts +1 -0
- package/lib/pipes/normalize-match-state/normalize-match-state.constants.d.ts +7 -0
- package/lib/pipes/normalize-match-state/normalize-match-state.pipe.d.ts +7 -0
- package/lib/pipes/normalize-match-state/normalize-match-state.util.d.ts +3 -0
- package/lib/pipes/normalize-match-state/public-api.d.ts +3 -0
- package/lib/pipes/normalize-match-type/normalize-match-type.pipe.d.ts +7 -0
- package/lib/pipes/normalize-match-type/normalize-match-type.util.d.ts +3 -0
- package/lib/pipes/normalize-match-type/public-api.d.ts +2 -0
- package/lib/pipes/public-api.d.ts +5 -0
- package/lib/public-api.d.ts +1 -0
- package/lib/services/click-observer.service.d.ts +21 -0
- package/lib/services/destroy.service.d.ts +9 -0
- package/lib/services/public-api.d.ts +6 -3
- package/lib/services/router-state.service.d.ts +40 -0
- package/lib/services/viewport.types.d.ts +1 -1
- package/lib/types/angular.types.d.ts +14 -1
- package/lib/types/i18n.types.d.ts +4 -0
- package/lib/types/public-api.d.ts +2 -1
- package/lib/types/viewport.types.d.ts +2 -2
- package/lib/utils/clone.util.d.ts +15 -0
- package/lib/utils/cookie.util.d.ts +5 -0
- package/lib/utils/equal.util.d.ts +27 -0
- package/lib/utils/index.d.ts +1 -0
- package/lib/utils/public-api.d.ts +6 -1
- package/lib/utils/reactive-binding.util.d.ts +19 -0
- package/lib/utils/scrollable.utils.d.ts +1 -0
- package/package.json +9 -5
|
@@ -0,0 +1,171 @@
|
|
|
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, DestroyService, ResizeObserverService } from '../../services';
|
|
5
|
+
import { 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
|
+
export class ObserveScrollStateDirective {
|
|
12
|
+
constructor() {
|
|
13
|
+
this._destroy$ = inject(DestroyService, { host: true }).destroy$;
|
|
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 = 1;
|
|
23
|
+
this._intersectionObserver = null;
|
|
24
|
+
this.etObserveScrollState = 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
|
+
this._threshold = coerceNumberProperty(value);
|
|
53
|
+
}
|
|
54
|
+
ngOnInit() {
|
|
55
|
+
this._contentObserverService
|
|
56
|
+
.observe(this._elementRef.nativeElement)
|
|
57
|
+
.pipe(tap(() => this._checkChildren()), takeUntil(this._destroy$))
|
|
58
|
+
.subscribe();
|
|
59
|
+
this._resizeObserverService
|
|
60
|
+
.observe(this._elementRef.nativeElement)
|
|
61
|
+
.pipe(debounceTime(25), tap(() => {
|
|
62
|
+
const canScroll = elementCanScroll(this._elementRef.nativeElement);
|
|
63
|
+
if ((!this._intersectionObserver && canScroll) || (this._intersectionObserver && !canScroll)) {
|
|
64
|
+
this._checkChildren();
|
|
65
|
+
}
|
|
66
|
+
}), takeUntil(this._destroy$))
|
|
67
|
+
.subscribe();
|
|
68
|
+
this._checkChildren();
|
|
69
|
+
}
|
|
70
|
+
ngOnDestroy() {
|
|
71
|
+
this._clearIntersectionObserver();
|
|
72
|
+
}
|
|
73
|
+
_checkChildren() {
|
|
74
|
+
this._clearIntersectionObserver();
|
|
75
|
+
if (this._firstCurrentChild === this._lastCurrentChild ||
|
|
76
|
+
!this._firstCurrentChild ||
|
|
77
|
+
!this._lastCurrentChild ||
|
|
78
|
+
!elementCanScroll(this._elementRef.nativeElement)) {
|
|
79
|
+
this._unobserveChild('first');
|
|
80
|
+
this._unobserveChild('last');
|
|
81
|
+
this.etObserveScrollState.emit({
|
|
82
|
+
isAtStart: true,
|
|
83
|
+
isAtEnd: true,
|
|
84
|
+
canScroll: false,
|
|
85
|
+
});
|
|
86
|
+
}
|
|
87
|
+
else {
|
|
88
|
+
this._intersectionObserver = this._initiateIntersectionObserver();
|
|
89
|
+
this._observeChild('first', this._firstCurrentChild);
|
|
90
|
+
this._observeChild('last', this._lastCurrentChild);
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
_initiateIntersectionObserver() {
|
|
94
|
+
const observer = new IntersectionObserver((entries) => {
|
|
95
|
+
const { first, last } = this._observedChildren;
|
|
96
|
+
const isAtStart = entries.find((entry) => entry.target === first)?.isIntersecting ?? false;
|
|
97
|
+
const isAtEnd = entries.find((entry) => entry.target === last)?.isIntersecting ?? false;
|
|
98
|
+
this.etObserveScrollState.emit({
|
|
99
|
+
isAtStart,
|
|
100
|
+
isAtEnd,
|
|
101
|
+
canScroll: !isAtStart || !isAtEnd,
|
|
102
|
+
});
|
|
103
|
+
}, {
|
|
104
|
+
root: this._elementRef.nativeElement,
|
|
105
|
+
rootMargin: `${this._rootMargin}px`,
|
|
106
|
+
threshold: this._threshold,
|
|
107
|
+
});
|
|
108
|
+
return observer;
|
|
109
|
+
}
|
|
110
|
+
_observeChild(child, element) {
|
|
111
|
+
this._intersectionObserver?.observe(element);
|
|
112
|
+
this._observedChildren[child] = element;
|
|
113
|
+
element.classList.add(`et-scroll-observer-observing-${child}-element`);
|
|
114
|
+
}
|
|
115
|
+
_unobserveChild(child) {
|
|
116
|
+
const observedChild = this._observedChildren[child];
|
|
117
|
+
if (!observedChild) {
|
|
118
|
+
return;
|
|
119
|
+
}
|
|
120
|
+
observedChild.classList.remove('et-scroll-observer-observing-first-element', 'et-scroll-observer-observing-last-element');
|
|
121
|
+
this._intersectionObserver?.unobserve(observedChild);
|
|
122
|
+
this._observedChildren[child] = null;
|
|
123
|
+
}
|
|
124
|
+
_clearIntersectionObserver() {
|
|
125
|
+
this._intersectionObserver?.disconnect();
|
|
126
|
+
this._intersectionObserver = null;
|
|
127
|
+
}
|
|
128
|
+
_getNonIgnoredChild(element, direction) {
|
|
129
|
+
if (!element) {
|
|
130
|
+
return null;
|
|
131
|
+
}
|
|
132
|
+
if (element?.classList.contains(SCROLL_OBSERVER_IGNORE_TARGET_CLASS)) {
|
|
133
|
+
const nextElement = element[`${direction}ElementSibling`];
|
|
134
|
+
if (!nextElement) {
|
|
135
|
+
return null;
|
|
136
|
+
}
|
|
137
|
+
return this._getNonIgnoredChild(nextElement, direction);
|
|
138
|
+
}
|
|
139
|
+
return element;
|
|
140
|
+
}
|
|
141
|
+
}
|
|
142
|
+
ObserveScrollStateDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.4", ngImport: i0, type: ObserveScrollStateDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
|
143
|
+
ObserveScrollStateDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.1.4", type: ObserveScrollStateDirective, isStandalone: true, selector: "[etObserveScrollState]", inputs: { observerRootMargin: "observerRootMargin", observerThreshold: "observerThreshold" }, outputs: { etObserveScrollState: "etObserveScrollState" }, providers: [
|
|
144
|
+
{
|
|
145
|
+
provide: OBSERVE_SCROLL_STATE,
|
|
146
|
+
useExisting: ObserveScrollStateDirective,
|
|
147
|
+
},
|
|
148
|
+
DestroyService,
|
|
149
|
+
], exportAs: ["etObserveScrollState"], ngImport: i0 });
|
|
150
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.4", ngImport: i0, type: ObserveScrollStateDirective, decorators: [{
|
|
151
|
+
type: Directive,
|
|
152
|
+
args: [{
|
|
153
|
+
selector: '[etObserveScrollState]',
|
|
154
|
+
exportAs: 'etObserveScrollState',
|
|
155
|
+
standalone: true,
|
|
156
|
+
providers: [
|
|
157
|
+
{
|
|
158
|
+
provide: OBSERVE_SCROLL_STATE,
|
|
159
|
+
useExisting: ObserveScrollStateDirective,
|
|
160
|
+
},
|
|
161
|
+
DestroyService,
|
|
162
|
+
],
|
|
163
|
+
}]
|
|
164
|
+
}], propDecorators: { observerRootMargin: [{
|
|
165
|
+
type: Input
|
|
166
|
+
}], observerThreshold: [{
|
|
167
|
+
type: Input
|
|
168
|
+
}], etObserveScrollState: [{
|
|
169
|
+
type: Output
|
|
170
|
+
}] } });
|
|
171
|
+
//# 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, DestroyService, ResizeObserverService } from '../../services';\nimport { 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    DestroyService,\n  ],\n})\nexport class ObserveScrollStateDirective implements OnInit, OnDestroy {\n  private readonly _destroy$ = inject(DestroyService, { host: true }).destroy$;\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 {\n    return this._threshold;\n  }\n  set observerThreshold(value: NumberInput) {\n    this._threshold = coerceNumberProperty(value);\n  }\n  private _threshold = 1;\n\n  private _intersectionObserver: IntersectionObserver | null = null;\n\n  @Output()\n  etObserveScrollState = new EventEmitter<ScrollObserverScrollState>();\n\n  ngOnInit(): void {\n    this._contentObserverService\n      .observe(this._elementRef.nativeElement)\n      .pipe(\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.etObserveScrollState.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.etObserveScrollState.emit({\n          isAtStart,\n          isAtEnd,\n          canScroll: !isAtStart || !isAtEnd,\n        });\n      },\n      {\n        root: this._elementRef.nativeElement,\n        rootMargin: `${this._rootMargin}px`,\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,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib2JzZXJ2ZS1zY3JvbGwtc3RhdGUudHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvcmUvc3JjL2xpYi9kaXJlY3RpdmVzL29ic2VydmUtc2Nyb2xsLXN0YXRlL29ic2VydmUtc2Nyb2xsLXN0YXRlLnR5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgaW50ZXJmYWNlIFNjcm9sbE9ic2VydmVyU2Nyb2xsU3RhdGUge1xuICBpc0F0U3RhcnQ6IGJvb2xlYW47XG4gIGlzQXRFbmQ6IGJvb2xlYW47XG4gIGNhblNjcm9sbDogYm9vbGVhbjtcbn1cblxuZXhwb3J0IHR5cGUgT2JzZXJ2ZWRTY3JvbGxhYmxlQ2hpbGQgPSAnZmlyc3QnIHwgJ2xhc3QnO1xuIl19
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
export * from './observe-scroll-state.directive';
|
|
2
|
+
export * from './observe-scroll-state.constants';
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29yZS9zcmMvbGliL2RpcmVjdGl2ZXMvb2JzZXJ2ZS1zY3JvbGwtc3RhdGUvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGtDQUFrQyxDQUFDO0FBRWpELGNBQWMsa0NBQWtDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL29ic2VydmUtc2Nyb2xsLXN0YXRlLmRpcmVjdGl2ZSc7XG5leHBvcnQgeyBTY3JvbGxPYnNlcnZlclNjcm9sbFN0YXRlIH0gZnJvbSAnLi9vYnNlcnZlLXNjcm9sbC1zdGF0ZS50eXBlcyc7XG5leHBvcnQgKiBmcm9tICcuL29ic2VydmUtc2Nyb2xsLXN0YXRlLmNvbnN0YW50cyc7XG4iXX0=
|
|
@@ -1,5 +1,12 @@
|
|
|
1
|
+
export * from './click-outside/public-api';
|
|
2
|
+
export * from './cursor-drag-scroll/public-api';
|
|
1
3
|
export * from './let/public-api';
|
|
2
|
-
export * from './repeat/public-api';
|
|
3
|
-
export * from './observe-resize/public-api';
|
|
4
4
|
export * from './observe-content/public-api';
|
|
5
|
-
|
|
5
|
+
export * from './observe-resize/public-api';
|
|
6
|
+
export * from './observe-scroll-state/public-api';
|
|
7
|
+
export * from './repeat/public-api';
|
|
8
|
+
export * from './scroll-observer-first-element/public-api';
|
|
9
|
+
export * from './scroll-observer-ignore-target/public-api';
|
|
10
|
+
export * from './scroll-observer-last-element/public-api';
|
|
11
|
+
export * from './seo/public-api';
|
|
12
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29yZS9zcmMvbGliL2RpcmVjdGl2ZXMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDRCQUE0QixDQUFDO0FBQzNDLGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYyxrQkFBa0IsQ0FBQztBQUNqQyxjQUFjLDhCQUE4QixDQUFDO0FBQzdDLGNBQWMsNkJBQTZCLENBQUM7QUFDNUMsY0FBYyxtQ0FBbUMsQ0FBQztBQUNsRCxjQUFjLHFCQUFxQixDQUFDO0FBQ3BDLGNBQWMsNENBQTRDLENBQUM7QUFDM0QsY0FBYyw0Q0FBNEMsQ0FBQztBQUMzRCxjQUFjLDJDQUEyQyxDQUFDO0FBQzFELGNBQWMsa0JBQWtCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2NsaWNrLW91dHNpZGUvcHVibGljLWFwaSc7XG5leHBvcnQgKiBmcm9tICcuL2N1cnNvci1kcmFnLXNjcm9sbC9wdWJsaWMtYXBpJztcbmV4cG9ydCAqIGZyb20gJy4vbGV0L3B1YmxpYy1hcGknO1xuZXhwb3J0ICogZnJvbSAnLi9vYnNlcnZlLWNvbnRlbnQvcHVibGljLWFwaSc7XG5leHBvcnQgKiBmcm9tICcuL29ic2VydmUtcmVzaXplL3B1YmxpYy1hcGknO1xuZXhwb3J0ICogZnJvbSAnLi9vYnNlcnZlLXNjcm9sbC1zdGF0ZS9wdWJsaWMtYXBpJztcbmV4cG9ydCAqIGZyb20gJy4vcmVwZWF0L3B1YmxpYy1hcGknO1xuZXhwb3J0ICogZnJvbSAnLi9zY3JvbGwtb2JzZXJ2ZXItZmlyc3QtZWxlbWVudC9wdWJsaWMtYXBpJztcbmV4cG9ydCAqIGZyb20gJy4vc2Nyb2xsLW9ic2VydmVyLWlnbm9yZS10YXJnZXQvcHVibGljLWFwaSc7XG5leHBvcnQgKiBmcm9tICcuL3Njcm9sbC1vYnNlcnZlci1sYXN0LWVsZW1lbnQvcHVibGljLWFwaSc7XG5leHBvcnQgKiBmcm9tICcuL3Nlby9wdWJsaWMtYXBpJztcbiJdfQ==
|
|
@@ -2,29 +2,28 @@ import { coerceNumberProperty } from '@angular/cdk/coercion';
|
|
|
2
2
|
import { Directive, Input, TemplateRef, ViewContainerRef } from '@angular/core';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
export class RepeatDirective {
|
|
5
|
-
constructor(_mainTemplateRef, _viewContainerRef) {
|
|
6
|
-
this._mainTemplateRef = _mainTemplateRef;
|
|
7
|
-
this._viewContainerRef = _viewContainerRef;
|
|
8
|
-
this._repeatCount = 2;
|
|
9
|
-
}
|
|
10
5
|
get repeatCount() {
|
|
11
6
|
return this._repeatCount;
|
|
12
7
|
}
|
|
13
8
|
set repeatCount(value) {
|
|
14
9
|
this._repeatCount = coerceNumberProperty(value);
|
|
15
|
-
}
|
|
16
|
-
ngOnInit() {
|
|
17
10
|
this._render();
|
|
18
11
|
}
|
|
12
|
+
constructor(_mainTemplateRef, _viewContainerRef) {
|
|
13
|
+
this._mainTemplateRef = _mainTemplateRef;
|
|
14
|
+
this._viewContainerRef = _viewContainerRef;
|
|
15
|
+
this._repeatCount = 2;
|
|
16
|
+
}
|
|
19
17
|
_render() {
|
|
18
|
+
this._viewContainerRef.clear();
|
|
20
19
|
for (let i = 0; i < this.repeatCount; i++) {
|
|
21
20
|
this._viewContainerRef.createEmbeddedView(this._mainTemplateRef);
|
|
22
21
|
}
|
|
23
22
|
}
|
|
24
23
|
}
|
|
25
|
-
RepeatDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
26
|
-
RepeatDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "
|
|
27
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
24
|
+
RepeatDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.4", ngImport: i0, type: RepeatDirective, deps: [{ token: i0.TemplateRef }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
25
|
+
RepeatDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.1.4", type: RepeatDirective, isStandalone: true, selector: "[etRepeat]", inputs: { repeatCount: ["etRepeat", "repeatCount"] }, ngImport: i0 });
|
|
26
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.4", ngImport: i0, type: RepeatDirective, decorators: [{
|
|
28
27
|
type: Directive,
|
|
29
28
|
args: [{
|
|
30
29
|
selector: '[etRepeat]',
|
|
@@ -34,4 +33,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImpor
|
|
|
34
33
|
type: Input,
|
|
35
34
|
args: ['etRepeat']
|
|
36
35
|
}] } });
|
|
37
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
36
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVwZWF0LmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29yZS9zcmMvbGliL2RpcmVjdGl2ZXMvcmVwZWF0L3JlcGVhdC5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLG9CQUFvQixFQUFlLE1BQU0sdUJBQXVCLENBQUM7QUFDMUUsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsV0FBVyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sZUFBZSxDQUFDOztBQU1oRixNQUFNLE9BQU8sZUFBZTtJQUMxQixJQUNJLFdBQVc7UUFDYixPQUFPLElBQUksQ0FBQyxZQUFZLENBQUM7SUFDM0IsQ0FBQztJQUNELElBQUksV0FBVyxDQUFDLEtBQWtCO1FBQ2hDLElBQUksQ0FBQyxZQUFZLEdBQUcsb0JBQW9CLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDaEQsSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDO0lBQ2pCLENBQUM7SUFHRCxZQUFvQixnQkFBc0MsRUFBVSxpQkFBbUM7UUFBbkYscUJBQWdCLEdBQWhCLGdCQUFnQixDQUFzQjtRQUFVLHNCQUFpQixHQUFqQixpQkFBaUIsQ0FBa0I7UUFGL0YsaUJBQVksR0FBRyxDQUFDLENBQUM7SUFFaUYsQ0FBQztJQUVuRyxPQUFPO1FBQ2IsSUFBSSxDQUFDLGlCQUFpQixDQUFDLEtBQUssRUFBRSxDQUFDO1FBRS9CLEtBQUssSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FBRyxJQUFJLENBQUMsV0FBVyxFQUFFLENBQUMsRUFBRSxFQUFFO1lBQ3pDLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxrQkFBa0IsQ0FBQyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztTQUNsRTtJQUNILENBQUM7OzRHQW5CVSxlQUFlO2dHQUFmLGVBQWU7MkZBQWYsZUFBZTtrQkFKM0IsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsWUFBWTtvQkFDdEIsVUFBVSxFQUFFLElBQUk7aUJBQ2pCO2lJQUdLLFdBQVc7c0JBRGQsS0FBSzt1QkFBQyxVQUFVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY29lcmNlTnVtYmVyUHJvcGVydHksIE51bWJlcklucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY2RrL2NvZXJjaW9uJztcbmltcG9ydCB7IERpcmVjdGl2ZSwgSW5wdXQsIFRlbXBsYXRlUmVmLCBWaWV3Q29udGFpbmVyUmVmIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ1tldFJlcGVhdF0nLFxuICBzdGFuZGFsb25lOiB0cnVlLFxufSlcbmV4cG9ydCBjbGFzcyBSZXBlYXREaXJlY3RpdmUge1xuICBASW5wdXQoJ2V0UmVwZWF0JylcbiAgZ2V0IHJlcGVhdENvdW50KCk6IG51bWJlciB7XG4gICAgcmV0dXJuIHRoaXMuX3JlcGVhdENvdW50O1xuICB9XG4gIHNldCByZXBlYXRDb3VudCh2YWx1ZTogTnVtYmVySW5wdXQpIHtcbiAgICB0aGlzLl9yZXBlYXRDb3VudCA9IGNvZXJjZU51bWJlclByb3BlcnR5KHZhbHVlKTtcbiAgICB0aGlzLl9yZW5kZXIoKTtcbiAgfVxuICBwcml2YXRlIF9yZXBlYXRDb3VudCA9IDI7XG5cbiAgY29uc3RydWN0b3IocHJpdmF0ZSBfbWFpblRlbXBsYXRlUmVmOiBUZW1wbGF0ZVJlZjx1bmtub3duPiwgcHJpdmF0ZSBfdmlld0NvbnRhaW5lclJlZjogVmlld0NvbnRhaW5lclJlZikge31cblxuICBwcml2YXRlIF9yZW5kZXIoKSB7XG4gICAgdGhpcy5fdmlld0NvbnRhaW5lclJlZi5jbGVhcigpO1xuXG4gICAgZm9yIChsZXQgaSA9IDA7IGkgPCB0aGlzLnJlcGVhdENvdW50OyBpKyspIHtcbiAgICAgIHRoaXMuX3ZpZXdDb250YWluZXJSZWYuY3JlYXRlRW1iZWRkZWRWaWV3KHRoaXMuX21haW5UZW1wbGF0ZVJlZik7XG4gICAgfVxuICB9XG59XG4iXX0=
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export * from './public-api';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvcmUvc3JjL2xpYi9kaXJlY3RpdmVzL3Njcm9sbC1vYnNlcnZlci1maXJzdC1lbGVtZW50L2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsY0FBYyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9wdWJsaWMtYXBpJztcbiJdfQ==
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export * from './scroll-observer-first-element.directive';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29yZS9zcmMvbGliL2RpcmVjdGl2ZXMvc2Nyb2xsLW9ic2VydmVyLWZpcnN0LWVsZW1lbnQvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDJDQUEyQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9zY3JvbGwtb2JzZXJ2ZXItZmlyc3QtZWxlbWVudC5kaXJlY3RpdmUnO1xuIl19
|
|
@@ -0,0 +1,31 @@
|
|
|
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
|
+
export 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
|
+
}
|
|
16
|
+
ScrollObserverFirstElementDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.4", ngImport: i0, type: ScrollObserverFirstElementDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
|
17
|
+
ScrollObserverFirstElementDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.1.4", type: ScrollObserverFirstElementDirective, isStandalone: true, selector: "[etScrollObserverFirstElement]", inputs: { isFirstElement: ["etScrollObserverFirstElement", "isFirstElement"] }, host: { properties: { "class.et-scroll-observer-first-element": "this.isFirstElement" } }, ngImport: i0 });
|
|
18
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.4", ngImport: i0, type: ScrollObserverFirstElementDirective, decorators: [{
|
|
19
|
+
type: Directive,
|
|
20
|
+
args: [{
|
|
21
|
+
selector: '[etScrollObserverFirstElement]',
|
|
22
|
+
standalone: true,
|
|
23
|
+
}]
|
|
24
|
+
}], propDecorators: { isFirstElement: [{
|
|
25
|
+
type: Input,
|
|
26
|
+
args: ['etScrollObserverFirstElement']
|
|
27
|
+
}, {
|
|
28
|
+
type: HostBinding,
|
|
29
|
+
args: [`class.${SCROLL_OBSERVER_FIRST_ELEMENT_CLASS}`]
|
|
30
|
+
}] } });
|
|
31
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2Nyb2xsLW9ic2VydmVyLWZpcnN0LWVsZW1lbnQuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb3JlL3NyYy9saWIvZGlyZWN0aXZlcy9zY3JvbGwtb2JzZXJ2ZXItZmlyc3QtZWxlbWVudC9zY3JvbGwtb2JzZXJ2ZXItZmlyc3QtZWxlbWVudC5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFnQixxQkFBcUIsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQzVFLE9BQU8sRUFBRSxTQUFTLEVBQUUsV0FBVyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFFOUQsTUFBTSxDQUFDLE1BQU0sbUNBQW1DLEdBQUcsa0NBQWtDLENBQUM7QUFNdEYsTUFBTSxPQUFPLG1DQUFtQztJQUpoRDtRQWFVLG9CQUFlLEdBQUcsS0FBSyxDQUFDO0tBQ2pDO0lBVEMsSUFFSSxjQUFjO1FBQ2hCLE9BQU8sSUFBSSxDQUFDLGVBQWUsQ0FBQztJQUM5QixDQUFDO0lBQ0QsSUFBSSxjQUFjLENBQUMsS0FBbUI7UUFDcEMsSUFBSSxDQUFDLGVBQWUsR0FBRyxxQkFBcUIsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUN0RCxDQUFDOztnSUFSVSxtQ0FBbUM7b0hBQW5DLG1DQUFtQzsyRkFBbkMsbUNBQW1DO2tCQUovQyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxnQ0FBZ0M7b0JBQzFDLFVBQVUsRUFBRSxJQUFJO2lCQUNqQjs4QkFJSyxjQUFjO3NCQUZqQixLQUFLO3VCQUFDLDhCQUE4Qjs7c0JBQ3BDLFdBQVc7dUJBQUMsU0FBUyxtQ0FBbUMsRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEJvb2xlYW5JbnB1dCwgY29lcmNlQm9vbGVhblByb3BlcnR5IH0gZnJvbSAnQGFuZ3VsYXIvY2RrL2NvZXJjaW9uJztcbmltcG9ydCB7IERpcmVjdGl2ZSwgSG9zdEJpbmRpbmcsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmV4cG9ydCBjb25zdCBTQ1JPTExfT0JTRVJWRVJfRklSU1RfRUxFTUVOVF9DTEFTUyA9ICdldC1zY3JvbGwtb2JzZXJ2ZXItZmlyc3QtZWxlbWVudCc7XG5cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ1tldFNjcm9sbE9ic2VydmVyRmlyc3RFbGVtZW50XScsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG59KVxuZXhwb3J0IGNsYXNzIFNjcm9sbE9ic2VydmVyRmlyc3RFbGVtZW50RGlyZWN0aXZlIHtcbiAgQElucHV0KCdldFNjcm9sbE9ic2VydmVyRmlyc3RFbGVtZW50JylcbiAgQEhvc3RCaW5kaW5nKGBjbGFzcy4ke1NDUk9MTF9PQlNFUlZFUl9GSVJTVF9FTEVNRU5UX0NMQVNTfWApXG4gIGdldCBpc0ZpcnN0RWxlbWVudCgpOiBib29sZWFuIHtcbiAgICByZXR1cm4gdGhpcy5faXNGaXJzdEVsZW1lbnQ7XG4gIH1cbiAgc2V0IGlzRmlyc3RFbGVtZW50KHZhbHVlOiBCb29sZWFuSW5wdXQpIHtcbiAgICB0aGlzLl9pc0ZpcnN0RWxlbWVudCA9IGNvZXJjZUJvb2xlYW5Qcm9wZXJ0eSh2YWx1ZSk7XG4gIH1cbiAgcHJpdmF0ZSBfaXNGaXJzdEVsZW1lbnQgPSBmYWxzZTtcbn1cbiJdfQ==
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export * from './public-api';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvcmUvc3JjL2xpYi9kaXJlY3RpdmVzL3Njcm9sbC1vYnNlcnZlci1pZ25vcmUtdGFyZ2V0L2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsY0FBYyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9wdWJsaWMtYXBpJztcbiJdfQ==
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export * from './scroll-observer-ignore-target.directive';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29yZS9zcmMvbGliL2RpcmVjdGl2ZXMvc2Nyb2xsLW9ic2VydmVyLWlnbm9yZS10YXJnZXQvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDJDQUEyQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9zY3JvbGwtb2JzZXJ2ZXItaWdub3JlLXRhcmdldC5kaXJlY3RpdmUnO1xuIl19
|
|
@@ -0,0 +1,18 @@
|
|
|
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
|
+
export class ScrollObserverIgnoreTargetDirective {
|
|
5
|
+
}
|
|
6
|
+
ScrollObserverIgnoreTargetDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.4", ngImport: i0, type: ScrollObserverIgnoreTargetDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
|
7
|
+
ScrollObserverIgnoreTargetDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.1.4", type: ScrollObserverIgnoreTargetDirective, isStandalone: true, selector: "[etScrollObserverIgnoreTarget]", host: { classAttribute: "et-scroll-observer-ignore-target" }, ngImport: i0 });
|
|
8
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.4", ngImport: i0, type: ScrollObserverIgnoreTargetDirective, decorators: [{
|
|
9
|
+
type: Directive,
|
|
10
|
+
args: [{
|
|
11
|
+
selector: '[etScrollObserverIgnoreTarget]',
|
|
12
|
+
standalone: true,
|
|
13
|
+
host: {
|
|
14
|
+
class: SCROLL_OBSERVER_IGNORE_TARGET_CLASS,
|
|
15
|
+
},
|
|
16
|
+
}]
|
|
17
|
+
}] });
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2Nyb2xsLW9ic2VydmVyLWlnbm9yZS10YXJnZXQuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb3JlL3NyYy9saWIvZGlyZWN0aXZlcy9zY3JvbGwtb2JzZXJ2ZXItaWdub3JlLXRhcmdldC9zY3JvbGwtb2JzZXJ2ZXItaWdub3JlLXRhcmdldC5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFFMUMsTUFBTSxDQUFDLE1BQU0sbUNBQW1DLEdBQUcsa0NBQWtDLENBQUM7QUFTdEYsTUFBTSxPQUFPLG1DQUFtQzs7Z0lBQW5DLG1DQUFtQztvSEFBbkMsbUNBQW1DOzJGQUFuQyxtQ0FBbUM7a0JBUC9DLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLGdDQUFnQztvQkFDMUMsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLElBQUksRUFBRTt3QkFDSixLQUFLLEVBQUUsbUNBQW1DO3FCQUMzQztpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5leHBvcnQgY29uc3QgU0NST0xMX09CU0VSVkVSX0lHTk9SRV9UQVJHRVRfQ0xBU1MgPSAnZXQtc2Nyb2xsLW9ic2VydmVyLWlnbm9yZS10YXJnZXQnO1xuXG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6ICdbZXRTY3JvbGxPYnNlcnZlcklnbm9yZVRhcmdldF0nLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBob3N0OiB7XG4gICAgY2xhc3M6IFNDUk9MTF9PQlNFUlZFUl9JR05PUkVfVEFSR0VUX0NMQVNTLFxuICB9LFxufSlcbmV4cG9ydCBjbGFzcyBTY3JvbGxPYnNlcnZlcklnbm9yZVRhcmdldERpcmVjdGl2ZSB7fVxuIl19
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export * from './public-api';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvcmUvc3JjL2xpYi9kaXJlY3RpdmVzL3Njcm9sbC1vYnNlcnZlci1sYXN0LWVsZW1lbnQvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxjQUFjLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL3B1YmxpYy1hcGknO1xuIl19
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export * from './scroll-observer-last-element.directive';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29yZS9zcmMvbGliL2RpcmVjdGl2ZXMvc2Nyb2xsLW9ic2VydmVyLWxhc3QtZWxlbWVudC9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsMENBQTBDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL3Njcm9sbC1vYnNlcnZlci1sYXN0LWVsZW1lbnQuZGlyZWN0aXZlJztcbiJdfQ==
|
|
@@ -0,0 +1,34 @@
|
|
|
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
|
+
export 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
|
+
}
|
|
16
|
+
ScrollObserverLastElementDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.4", ngImport: i0, type: ScrollObserverLastElementDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
|
17
|
+
ScrollObserverLastElementDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.1.4", 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 });
|
|
18
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.4", ngImport: i0, type: ScrollObserverLastElementDirective, decorators: [{
|
|
19
|
+
type: Directive,
|
|
20
|
+
args: [{
|
|
21
|
+
selector: '[etScrollObserverLastElement]',
|
|
22
|
+
standalone: true,
|
|
23
|
+
host: {
|
|
24
|
+
class: SCROLL_OBSERVER_LAST_ELEMENT_CLASS,
|
|
25
|
+
},
|
|
26
|
+
}]
|
|
27
|
+
}], propDecorators: { isLastElement: [{
|
|
28
|
+
type: Input,
|
|
29
|
+
args: ['etScrollObserverLastElement']
|
|
30
|
+
}, {
|
|
31
|
+
type: HostBinding,
|
|
32
|
+
args: [`class.${SCROLL_OBSERVER_LAST_ELEMENT_CLASS}`]
|
|
33
|
+
}] } });
|
|
34
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2Nyb2xsLW9ic2VydmVyLWxhc3QtZWxlbWVudC5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvcmUvc3JjL2xpYi9kaXJlY3RpdmVzL3Njcm9sbC1vYnNlcnZlci1sYXN0LWVsZW1lbnQvc2Nyb2xsLW9ic2VydmVyLWxhc3QtZWxlbWVudC5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFnQixxQkFBcUIsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQzVFLE9BQU8sRUFBRSxTQUFTLEVBQUUsV0FBVyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFFOUQsTUFBTSxDQUFDLE1BQU0sa0NBQWtDLEdBQUcsaUNBQWlDLENBQUM7QUFTcEYsTUFBTSxPQUFPLGtDQUFrQztJQVAvQztRQWdCVSxtQkFBYyxHQUFHLEtBQUssQ0FBQztLQUNoQztJQVRDLElBRUksYUFBYTtRQUNmLE9BQU8sSUFBSSxDQUFDLGNBQWMsQ0FBQztJQUM3QixDQUFDO0lBQ0QsSUFBSSxhQUFhLENBQUMsS0FBbUI7UUFDbkMsSUFBSSxDQUFDLGNBQWMsR0FBRyxxQkFBcUIsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUNyRCxDQUFDOzsrSEFSVSxrQ0FBa0M7bUhBQWxDLGtDQUFrQzsyRkFBbEMsa0NBQWtDO2tCQVA5QyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSwrQkFBK0I7b0JBQ3pDLFVBQVUsRUFBRSxJQUFJO29CQUNoQixJQUFJLEVBQUU7d0JBQ0osS0FBSyxFQUFFLGtDQUFrQztxQkFDMUM7aUJBQ0Y7OEJBSUssYUFBYTtzQkFGaEIsS0FBSzt1QkFBQyw2QkFBNkI7O3NCQUNuQyxXQUFXO3VCQUFDLFNBQVMsa0NBQWtDLEVBQUUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBCb29sZWFuSW5wdXQsIGNvZXJjZUJvb2xlYW5Qcm9wZXJ0eSB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9jb2VyY2lvbic7XG5pbXBvcnQgeyBEaXJlY3RpdmUsIEhvc3RCaW5kaW5nLCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5leHBvcnQgY29uc3QgU0NST0xMX09CU0VSVkVSX0xBU1RfRUxFTUVOVF9DTEFTUyA9ICdldC1zY3JvbGwtb2JzZXJ2ZXItbGFzdC1lbGVtZW50JztcblxuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnW2V0U2Nyb2xsT2JzZXJ2ZXJMYXN0RWxlbWVudF0nLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBob3N0OiB7XG4gICAgY2xhc3M6IFNDUk9MTF9PQlNFUlZFUl9MQVNUX0VMRU1FTlRfQ0xBU1MsXG4gIH0sXG59KVxuZXhwb3J0IGNsYXNzIFNjcm9sbE9ic2VydmVyTGFzdEVsZW1lbnREaXJlY3RpdmUge1xuICBASW5wdXQoJ2V0U2Nyb2xsT2JzZXJ2ZXJMYXN0RWxlbWVudCcpXG4gIEBIb3N0QmluZGluZyhgY2xhc3MuJHtTQ1JPTExfT0JTRVJWRVJfTEFTVF9FTEVNRU5UX0NMQVNTfWApXG4gIGdldCBpc0xhc3RFbGVtZW50KCk6IGJvb2xlYW4ge1xuICAgIHJldHVybiB0aGlzLl9pc0xhc3RFbGVtZW50O1xuICB9XG4gIHNldCBpc0xhc3RFbGVtZW50KHZhbHVlOiBCb29sZWFuSW5wdXQpIHtcbiAgICB0aGlzLl9pc0xhc3RFbGVtZW50ID0gY29lcmNlQm9vbGVhblByb3BlcnR5KHZhbHVlKTtcbiAgfVxuICBwcml2YXRlIF9pc0xhc3RFbGVtZW50ID0gZmFsc2U7XG59XG4iXX0=
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
export * from './seo.directive';
|
|
2
|
+
export * from './seo.directive.constants';
|
|
3
|
+
export * from './seo.directive.types';
|
|
4
|
+
export * from './seo.directive.utils';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29yZS9zcmMvbGliL2RpcmVjdGl2ZXMvc2VvL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxpQkFBaUIsQ0FBQztBQUNoQyxjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYyx1QkFBdUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vc2VvLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL3Nlby5kaXJlY3RpdmUuY29uc3RhbnRzJztcbmV4cG9ydCAqIGZyb20gJy4vc2VvLmRpcmVjdGl2ZS50eXBlcyc7XG5leHBvcnQgKiBmcm9tICcuL3Nlby5kaXJlY3RpdmUudXRpbHMnO1xuIl19
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
import { InjectionToken } from '@angular/core';
|
|
2
|
+
export const SEO_DIRECTIVE_TOKEN = new InjectionToken('SEO_DIRECTIVE_TOKEN');
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VvLmRpcmVjdGl2ZS5jb25zdGFudHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvcmUvc3JjL2xpYi9kaXJlY3RpdmVzL3Nlby9zZW8uZGlyZWN0aXZlLmNvbnN0YW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRy9DLE1BQU0sQ0FBQyxNQUFNLG1CQUFtQixHQUFHLElBQUksY0FBYyxDQUFlLHFCQUFxQixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3Rpb25Ub2tlbiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgU2VvRGlyZWN0aXZlIH0gZnJvbSAnLi9zZW8uZGlyZWN0aXZlJztcblxuZXhwb3J0IGNvbnN0IFNFT19ESVJFQ1RJVkVfVE9LRU4gPSBuZXcgSW5qZWN0aW9uVG9rZW48U2VvRGlyZWN0aXZlPignU0VPX0RJUkVDVElWRV9UT0tFTicpO1xuIl19
|
|
@@ -0,0 +1,166 @@
|
|
|
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
|
+
export 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
|
+
}
|
|
157
|
+
SeoDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.4", ngImport: i0, type: SeoDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
|
158
|
+
SeoDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.1.4", type: SeoDirective, isStandalone: true, providers: [{ provide: SEO_DIRECTIVE_TOKEN, useExisting: SeoDirective }], ngImport: i0 });
|
|
159
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.4", ngImport: i0, type: SeoDirective, decorators: [{
|
|
160
|
+
type: Directive,
|
|
161
|
+
args: [{
|
|
162
|
+
standalone: true,
|
|
163
|
+
providers: [{ provide: SEO_DIRECTIVE_TOKEN, useExisting: SeoDirective }],
|
|
164
|
+
}]
|
|
165
|
+
}] });
|
|
166
|
+
//# 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"]}
|