@ethlete/core 4.23.8 → 4.24.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +12 -0
- package/fesm2022/ethlete-core.mjs +131 -139
- package/fesm2022/ethlete-core.mjs.map +1 -1
- package/lib/types/angular.types.d.ts +0 -1
- package/lib/utils/signal.utils.d.ts +5 -0
- package/package.json +7 -9
- package/esm2022/ethlete-core.mjs +0 -5
- package/esm2022/index.mjs +0 -38
- package/esm2022/lib/components/structured-data/index.mjs +0 -2
- package/esm2022/lib/components/structured-data/structured-data.component.mjs +0 -37
- package/esm2022/lib/constants/index.mjs +0 -2
- package/esm2022/lib/constants/viewport.constants.mjs +0 -17
- package/esm2022/lib/decorators/memo/index.mjs +0 -2
- package/esm2022/lib/decorators/memo/memo.decorator.mjs +0 -25
- package/esm2022/lib/directives/animatable/animatable.directive.mjs +0 -121
- package/esm2022/lib/directives/animatable/index.mjs +0 -2
- package/esm2022/lib/directives/animated-if/animated-if.directive.mjs +0 -54
- package/esm2022/lib/directives/animated-if/index.mjs +0 -2
- package/esm2022/lib/directives/animated-lifecycle/animated-lifecycle.directive.mjs +0 -136
- package/esm2022/lib/directives/animated-lifecycle/index.mjs +0 -2
- package/esm2022/lib/directives/animated-overlay/animated-overlay.directive.mjs +0 -344
- package/esm2022/lib/directives/animated-overlay/index.mjs +0 -2
- package/esm2022/lib/directives/click-outside/click-outside.directive.mjs +0 -37
- package/esm2022/lib/directives/click-outside/index.mjs +0 -2
- package/esm2022/lib/directives/cursor-drag-scroll/cursor-drag-scroll.constants.mjs +0 -3
- package/esm2022/lib/directives/cursor-drag-scroll/cursor-drag-scroll.directive.mjs +0 -170
- package/esm2022/lib/directives/cursor-drag-scroll/index.mjs +0 -3
- package/esm2022/lib/directives/debug/debug.directive.mjs +0 -44
- package/esm2022/lib/directives/debug/index.mjs +0 -2
- package/esm2022/lib/directives/delayable/delayable.directive.mjs +0 -55
- package/esm2022/lib/directives/delayable/index.mjs +0 -2
- package/esm2022/lib/directives/is-active-element/index.mjs +0 -2
- package/esm2022/lib/directives/is-active-element/is-active-element.directive.mjs +0 -33
- package/esm2022/lib/directives/is-element/index.mjs +0 -2
- package/esm2022/lib/directives/is-element/is-element.directive.mjs +0 -33
- package/esm2022/lib/directives/let/index.mjs +0 -3
- package/esm2022/lib/directives/let/let.directive.mjs +0 -40
- package/esm2022/lib/directives/let/let.types.mjs +0 -9
- package/esm2022/lib/directives/observe-content/index.mjs +0 -2
- package/esm2022/lib/directives/observe-content/observe-content.directive.mjs +0 -72
- package/esm2022/lib/directives/observe-resize/index.mjs +0 -2
- package/esm2022/lib/directives/observe-resize/observe-resize.directive.mjs +0 -72
- package/esm2022/lib/directives/observe-scroll-state/index.mjs +0 -4
- package/esm2022/lib/directives/observe-scroll-state/observe-scroll-state.constants.mjs +0 -3
- package/esm2022/lib/directives/observe-scroll-state/observe-scroll-state.directive.mjs +0 -180
- package/esm2022/lib/directives/observe-scroll-state/observe-scroll-state.types.mjs +0 -2
- package/esm2022/lib/directives/observe-visibility/index.mjs +0 -2
- package/esm2022/lib/directives/observe-visibility/observe-visibility.directive.mjs +0 -80
- package/esm2022/lib/directives/repeat/index.mjs +0 -2
- package/esm2022/lib/directives/repeat/repeat.directive.mjs +0 -35
- package/esm2022/lib/directives/root-boundary/index.mjs +0 -2
- package/esm2022/lib/directives/root-boundary/root-boundary.directive.mjs +0 -36
- package/esm2022/lib/directives/scroll-observer-first-element/index.mjs +0 -2
- package/esm2022/lib/directives/scroll-observer-first-element/scroll-observer-first-element.directive.mjs +0 -24
- package/esm2022/lib/directives/scroll-observer-ignore-target/index.mjs +0 -2
- package/esm2022/lib/directives/scroll-observer-ignore-target/scroll-observer-ignore-target.directive.mjs +0 -18
- package/esm2022/lib/directives/scroll-observer-last-element/index.mjs +0 -2
- package/esm2022/lib/directives/scroll-observer-last-element/scroll-observer-last-element.directive.mjs +0 -27
- package/esm2022/lib/directives/seo/index.mjs +0 -5
- package/esm2022/lib/directives/seo/seo.directive.constants.mjs +0 -3
- package/esm2022/lib/directives/seo/seo.directive.mjs +0 -166
- package/esm2022/lib/directives/seo/seo.directive.types.mjs +0 -2
- package/esm2022/lib/directives/seo/seo.directive.utils.mjs +0 -7
- package/esm2022/lib/pipes/infer-mime-type/index.mjs +0 -3
- package/esm2022/lib/pipes/infer-mime-type/infer-mime-type.pipe.mjs +0 -18
- package/esm2022/lib/pipes/infer-mime-type/infer-mime-type.util.mjs +0 -196
- package/esm2022/lib/pipes/normalize-game-result-type/index.mjs +0 -4
- package/esm2022/lib/pipes/normalize-game-result-type/normalize-game-result-type.pipe.mjs +0 -15
- package/esm2022/lib/pipes/normalize-game-result-type/normalize-game-result-type.types.mjs +0 -2
- package/esm2022/lib/pipes/normalize-game-result-type/normalize-game-result-type.util.mjs +0 -34
- package/esm2022/lib/pipes/normalize-match-participants/index.mjs +0 -4
- package/esm2022/lib/pipes/normalize-match-participants/normalize-match-participants.pipe.mjs +0 -15
- package/esm2022/lib/pipes/normalize-match-participants/normalize-match-participants.types.mjs +0 -2
- package/esm2022/lib/pipes/normalize-match-participants/normalize-match-participants.util.mjs +0 -47
- package/esm2022/lib/pipes/normalize-match-score/index.mjs +0 -4
- package/esm2022/lib/pipes/normalize-match-score/normalize-match-score.pipe.mjs +0 -15
- package/esm2022/lib/pipes/normalize-match-score/normalize-match-score.types.mjs +0 -2
- package/esm2022/lib/pipes/normalize-match-score/normalize-match-score.util.mjs +0 -126
- package/esm2022/lib/pipes/normalize-match-state/index.mjs +0 -4
- package/esm2022/lib/pipes/normalize-match-state/normalize-match-state.constants.mjs +0 -2
- package/esm2022/lib/pipes/normalize-match-state/normalize-match-state.pipe.mjs +0 -15
- package/esm2022/lib/pipes/normalize-match-state/normalize-match-state.util.mjs +0 -19
- package/esm2022/lib/pipes/normalize-match-type/index.mjs +0 -3
- package/esm2022/lib/pipes/normalize-match-type/normalize-match-type.pipe.mjs +0 -15
- package/esm2022/lib/pipes/normalize-match-type/normalize-match-type.util.mjs +0 -38
- package/esm2022/lib/pipes/to-array/index.mjs +0 -3
- package/esm2022/lib/pipes/to-array/to-array.pipe.mjs +0 -15
- package/esm2022/lib/pipes/to-array/to-array.util.mjs +0 -5
- package/esm2022/lib/props/create-prop-handlers.mjs +0 -17
- package/esm2022/lib/props/create-props.mjs +0 -53
- package/esm2022/lib/props/create-setup.mjs +0 -19
- package/esm2022/lib/props/dependency-stash.mjs +0 -20
- package/esm2022/lib/props/element-dictionary.mjs +0 -44
- package/esm2022/lib/props/index.mjs +0 -9
- package/esm2022/lib/props/props-binding.mjs +0 -53
- package/esm2022/lib/props/props.directive.mjs +0 -35
- package/esm2022/lib/props/template-input.mjs +0 -41
- package/esm2022/lib/services/click-observer.service.mjs +0 -73
- package/esm2022/lib/services/content-observer.service.mjs +0 -79
- package/esm2022/lib/services/focus-visible.service.mjs +0 -34
- package/esm2022/lib/services/index.mjs +0 -9
- package/esm2022/lib/services/intersection-observer.service.mjs +0 -75
- package/esm2022/lib/services/resize-observer.service.mjs +0 -75
- package/esm2022/lib/services/router-state.service.mjs +0 -205
- package/esm2022/lib/services/viewport.service.mjs +0 -244
- package/esm2022/lib/services/viewport.types.mjs +0 -2
- package/esm2022/lib/types/angular.types.mjs +0 -15
- package/esm2022/lib/types/i18n.types.mjs +0 -2
- package/esm2022/lib/types/index.mjs +0 -5
- package/esm2022/lib/types/value.types.mjs +0 -2
- package/esm2022/lib/types/viewport.types.mjs +0 -2
- package/esm2022/lib/utils/active-selection-model.utils.mjs +0 -91
- package/esm2022/lib/utils/angular.utils.mjs +0 -7
- package/esm2022/lib/utils/animation.utils.mjs +0 -113
- package/esm2022/lib/utils/clamp.util.mjs +0 -4
- package/esm2022/lib/utils/clone.util.mjs +0 -78
- package/esm2022/lib/utils/component-id.utils.mjs +0 -7
- package/esm2022/lib/utils/cookie.util.mjs +0 -53
- package/esm2022/lib/utils/destroy.utils.mjs +0 -13
- package/esm2022/lib/utils/equal.util.mjs +0 -118
- package/esm2022/lib/utils/form.utils.mjs +0 -63
- package/esm2022/lib/utils/index.mjs +0 -27
- package/esm2022/lib/utils/inject.utils.mjs +0 -4
- package/esm2022/lib/utils/intersection-observer.utils.mjs +0 -65
- package/esm2022/lib/utils/key-press-manager.utils.mjs +0 -30
- package/esm2022/lib/utils/media-query-observable.util.mjs +0 -18
- package/esm2022/lib/utils/mutation-observable.util.mjs +0 -42
- package/esm2022/lib/utils/object.utils.mjs +0 -30
- package/esm2022/lib/utils/reactive-binding.util.mjs +0 -124
- package/esm2022/lib/utils/resize-observable.util.mjs +0 -12
- package/esm2022/lib/utils/round.utils.mjs +0 -5
- package/esm2022/lib/utils/runtime-error.utils.mjs +0 -31
- package/esm2022/lib/utils/scrollable.utils.mjs +0 -157
- package/esm2022/lib/utils/selection-model.utils.mjs +0 -376
- package/esm2022/lib/utils/signal.utils.mjs +0 -1004
- package/esm2022/lib/utils/smart-block-scroll-strategy.utils.mjs +0 -96
- package/esm2022/lib/utils/value.utils.mjs +0 -22
- package/esm2022/lib/utils/viewport.util.mjs +0 -5
- package/esm2022/lib/validators/at-least-one-required.validator.mjs +0 -20
- package/esm2022/lib/validators/index.mjs +0 -15
- package/esm2022/lib/validators/is-array-not-empty.validator.mjs +0 -9
- package/esm2022/lib/validators/is-email.validator.mjs +0 -10
- package/esm2022/lib/validators/must-match.validator.mjs +0 -19
|
@@ -1,344 +0,0 @@
|
|
|
1
|
-
import { Overlay } from '@angular/cdk/overlay';
|
|
2
|
-
import { ComponentPortal } from '@angular/cdk/portal';
|
|
3
|
-
import { Directive, ElementRef, Injector, Input, NgZone, ViewContainerRef, booleanAttribute, inject, isDevMode, } from '@angular/core';
|
|
4
|
-
import { arrow, autoUpdate, computePosition, flip, hide, limitShift, offset, shift, size, } from '@floating-ui/dom';
|
|
5
|
-
import { BehaviorSubject, Subject, filter, take, takeUntil, tap } from 'rxjs';
|
|
6
|
-
import { ResizeObserverService } from '../../services';
|
|
7
|
-
import { createDestroy, nextFrame } from '../../utils';
|
|
8
|
-
import { RootBoundaryDirective } from '../root-boundary';
|
|
9
|
-
import * as i0 from "@angular/core";
|
|
10
|
-
export class AnimatedOverlayDirective {
|
|
11
|
-
constructor() {
|
|
12
|
-
this._destroy$ = createDestroy();
|
|
13
|
-
this._overlayService = inject(Overlay);
|
|
14
|
-
this._injector = inject(Injector);
|
|
15
|
-
this._viewContainerRef = inject(ViewContainerRef);
|
|
16
|
-
this._zone = inject(NgZone);
|
|
17
|
-
this._elementRef = inject(ElementRef);
|
|
18
|
-
this._resizeObserverService = inject(ResizeObserverService);
|
|
19
|
-
this._rootBoundary = inject(RootBoundaryDirective, { optional: true });
|
|
20
|
-
this._portal = null;
|
|
21
|
-
this._overlayRef = null;
|
|
22
|
-
this._componentRef = null;
|
|
23
|
-
this._floatingElCleanupFn = null;
|
|
24
|
-
this._beforeOpened = null;
|
|
25
|
-
this._afterOpened = null;
|
|
26
|
-
this._beforeClosed = null;
|
|
27
|
-
this._afterClosed = null;
|
|
28
|
-
this._isMounted$ = new BehaviorSubject(false);
|
|
29
|
-
this._isMounting$ = new BehaviorSubject(false);
|
|
30
|
-
this._isUnmounting$ = new BehaviorSubject(false);
|
|
31
|
-
this._isHidden$ = new BehaviorSubject(false);
|
|
32
|
-
/**
|
|
33
|
-
* The placement of the animated overlay.
|
|
34
|
-
* @default undefined
|
|
35
|
-
*/
|
|
36
|
-
this.placement = 'bottom';
|
|
37
|
-
/**
|
|
38
|
-
* The offset of the animated overlay.
|
|
39
|
-
* @see https://floating-ui.com/docs/offset
|
|
40
|
-
*/
|
|
41
|
-
this.offset = null;
|
|
42
|
-
/**
|
|
43
|
-
* The arrow padding.
|
|
44
|
-
* @see https://floating-ui.com/docs/arrow#padding
|
|
45
|
-
* @default 4
|
|
46
|
-
*/
|
|
47
|
-
this.arrowPadding = 4;
|
|
48
|
-
/**
|
|
49
|
-
* The viewport padding.
|
|
50
|
-
* @default 8
|
|
51
|
-
*/
|
|
52
|
-
this.viewportPadding = 8;
|
|
53
|
-
/**
|
|
54
|
-
* Whether the animated overlay should auto resize to fit the available space.
|
|
55
|
-
* Useful for things like selects where the list of options might be longer than the available space.
|
|
56
|
-
* @default false
|
|
57
|
-
*/
|
|
58
|
-
this.autoResize = false;
|
|
59
|
-
/**
|
|
60
|
-
* Whether the animated overlay should shift when it is near the viewport boundary.
|
|
61
|
-
*/
|
|
62
|
-
this.shift = true;
|
|
63
|
-
/**
|
|
64
|
-
* Whether the animated overlay should auto hide when the reference element is hidden.
|
|
65
|
-
* @default false
|
|
66
|
-
*/
|
|
67
|
-
this.autoHide = false;
|
|
68
|
-
/**
|
|
69
|
-
* Whether the animated overlay should auto close if the reference element is hidden.
|
|
70
|
-
* @default false
|
|
71
|
-
*/
|
|
72
|
-
this.autoCloseIfReferenceHidden = false;
|
|
73
|
-
/**
|
|
74
|
-
* The reference element for the animated overlay.
|
|
75
|
-
* @default this._elementRef.nativeElement
|
|
76
|
-
*/
|
|
77
|
-
this.referenceElement = this._elementRef.nativeElement;
|
|
78
|
-
}
|
|
79
|
-
get isMounted() {
|
|
80
|
-
return this._isMounted$.value;
|
|
81
|
-
}
|
|
82
|
-
get isMounted$() {
|
|
83
|
-
return this._isMounted$.asObservable();
|
|
84
|
-
}
|
|
85
|
-
get isMounting() {
|
|
86
|
-
return this._isMounting$.value;
|
|
87
|
-
}
|
|
88
|
-
get isMounting$() {
|
|
89
|
-
return this._isMounting$.asObservable();
|
|
90
|
-
}
|
|
91
|
-
get isUnmounting() {
|
|
92
|
-
return this._isUnmounting$.value;
|
|
93
|
-
}
|
|
94
|
-
get isHidden$() {
|
|
95
|
-
return this._isHidden$.asObservable();
|
|
96
|
-
}
|
|
97
|
-
get isHidden() {
|
|
98
|
-
return this._isHidden$.value;
|
|
99
|
-
}
|
|
100
|
-
get canMount() {
|
|
101
|
-
return !this.isMounted && !this.isMounting;
|
|
102
|
-
}
|
|
103
|
-
get canUnmount() {
|
|
104
|
-
return this.isMounted && !this.isUnmounting;
|
|
105
|
-
}
|
|
106
|
-
get portal() {
|
|
107
|
-
return this._portal;
|
|
108
|
-
}
|
|
109
|
-
get overlayRef() {
|
|
110
|
-
return this._overlayRef;
|
|
111
|
-
}
|
|
112
|
-
get componentRef() {
|
|
113
|
-
return this._componentRef;
|
|
114
|
-
}
|
|
115
|
-
mount(config) {
|
|
116
|
-
if (this.isMounted || this.isMounting) {
|
|
117
|
-
if (isDevMode()) {
|
|
118
|
-
if (this.isMounted) {
|
|
119
|
-
console.warn('AnimatedOverlayDirective: The component is currently mounted. Please unmount the component before mounting again.');
|
|
120
|
-
}
|
|
121
|
-
if (this.isMounting) {
|
|
122
|
-
console.warn('AnimatedOverlayDirective: The component is already mounting. Please unmount the component before mounting again.');
|
|
123
|
-
}
|
|
124
|
-
}
|
|
125
|
-
return;
|
|
126
|
-
}
|
|
127
|
-
this._isMounting$.next(true);
|
|
128
|
-
const { component, providers, data, mirrorWidth, themeProvider } = config;
|
|
129
|
-
this._beforeOpened?.next();
|
|
130
|
-
const injector = Injector.create({
|
|
131
|
-
parent: this._injector,
|
|
132
|
-
providers: providers ?? [],
|
|
133
|
-
});
|
|
134
|
-
this._overlayRef = this._overlayService.create();
|
|
135
|
-
this._portal = new ComponentPortal(component, this._viewContainerRef, injector);
|
|
136
|
-
this._componentRef = this._overlayRef.attach(this._portal);
|
|
137
|
-
if (data) {
|
|
138
|
-
Object.assign(this._componentRef.instance, data);
|
|
139
|
-
}
|
|
140
|
-
this._componentRef.instance._markForCheck?.();
|
|
141
|
-
if (themeProvider) {
|
|
142
|
-
this._componentRef.instance._setThemeFromProvider?.(themeProvider);
|
|
143
|
-
}
|
|
144
|
-
if (mirrorWidth) {
|
|
145
|
-
this._overlayRef.updateSize({
|
|
146
|
-
width: this._elementRef.nativeElement.offsetWidth,
|
|
147
|
-
});
|
|
148
|
-
this._resizeObserverService
|
|
149
|
-
.observe(this.referenceElement)
|
|
150
|
-
.pipe(tap(() => {
|
|
151
|
-
this._overlayRef?.updateSize({
|
|
152
|
-
width: this._elementRef.nativeElement.offsetWidth,
|
|
153
|
-
});
|
|
154
|
-
}), takeUntil(this._destroy$), takeUntil(this.afterClosed()))
|
|
155
|
-
.subscribe();
|
|
156
|
-
}
|
|
157
|
-
this._zone.runOutsideAngular(() => {
|
|
158
|
-
if (!this._componentRef) {
|
|
159
|
-
return;
|
|
160
|
-
}
|
|
161
|
-
const floatingEl = this._componentRef.location.nativeElement;
|
|
162
|
-
const floatingElArrow = this._componentRef.instance._elementRef?.nativeElement.querySelector('[et-floating-arrow]');
|
|
163
|
-
floatingEl.classList.add('et-floating-element');
|
|
164
|
-
const refEl = this.referenceElement;
|
|
165
|
-
const boundary = this._rootBoundary?.boundaryElement ?? undefined;
|
|
166
|
-
this._floatingElCleanupFn = autoUpdate(refEl, floatingEl, () => {
|
|
167
|
-
if (!this._componentRef)
|
|
168
|
-
return;
|
|
169
|
-
computePosition(refEl, floatingEl, {
|
|
170
|
-
placement: this.placement,
|
|
171
|
-
middleware: [
|
|
172
|
-
...(this.offset ? [offset(this.offset)] : []),
|
|
173
|
-
flip({
|
|
174
|
-
fallbackPlacements: this.fallbackPlacements ?? undefined,
|
|
175
|
-
fallbackAxisSideDirection: 'start',
|
|
176
|
-
boundary,
|
|
177
|
-
}),
|
|
178
|
-
...(this.autoResize
|
|
179
|
-
? [
|
|
180
|
-
size({
|
|
181
|
-
padding: this.viewportPadding ?? undefined,
|
|
182
|
-
apply({ availableHeight, availableWidth }) {
|
|
183
|
-
floatingEl.style.setProperty('--et-floating-max-width', `${availableWidth}px`);
|
|
184
|
-
floatingEl.style.setProperty('--et-floating-max-height', `${availableHeight}px`);
|
|
185
|
-
},
|
|
186
|
-
}),
|
|
187
|
-
]
|
|
188
|
-
: []),
|
|
189
|
-
...(this.shift
|
|
190
|
-
? [shift({ limiter: limitShift(), padding: this.viewportPadding ?? undefined, boundary })]
|
|
191
|
-
: []),
|
|
192
|
-
...(floatingElArrow ? [arrow({ element: floatingElArrow, padding: this.arrowPadding ?? undefined })] : []),
|
|
193
|
-
...(this.autoHide || this.autoCloseIfReferenceHidden
|
|
194
|
-
? [hide({ strategy: 'referenceHidden', boundary })]
|
|
195
|
-
: []),
|
|
196
|
-
],
|
|
197
|
-
}).then(({ x, y, placement, middlewareData }) => {
|
|
198
|
-
floatingEl.style.setProperty('--et-floating-translate', `translate3d(${x}px, ${y}px, 0)`);
|
|
199
|
-
floatingEl.setAttribute('et-floating-placement', placement);
|
|
200
|
-
if (middlewareData.arrow && floatingElArrow) {
|
|
201
|
-
const { x: arrowX, y: arrowY } = middlewareData.arrow;
|
|
202
|
-
floatingEl.style.setProperty('--et-floating-arrow-translate', `translate3d(${arrowX ?? 0}px, ${arrowY ?? 0}px, 0)`);
|
|
203
|
-
}
|
|
204
|
-
if (middlewareData.hide?.referenceHidden) {
|
|
205
|
-
if (this.autoCloseIfReferenceHidden) {
|
|
206
|
-
this.unmount();
|
|
207
|
-
}
|
|
208
|
-
else {
|
|
209
|
-
floatingEl.classList.add('et-floating-element--hidden');
|
|
210
|
-
this._isHidden$.next(true);
|
|
211
|
-
}
|
|
212
|
-
}
|
|
213
|
-
else {
|
|
214
|
-
if (this.autoHide) {
|
|
215
|
-
floatingEl.classList.remove('et-floating-element--hidden');
|
|
216
|
-
this._isHidden$.next(false);
|
|
217
|
-
}
|
|
218
|
-
}
|
|
219
|
-
});
|
|
220
|
-
});
|
|
221
|
-
// We need to wait for the content to be rendered
|
|
222
|
-
nextFrame(() => {
|
|
223
|
-
if (!this._componentRef) {
|
|
224
|
-
return;
|
|
225
|
-
}
|
|
226
|
-
if (!this._componentRef.instance._animatedLifecycle) {
|
|
227
|
-
console.error('AnimatedOverlayDirective: The component does not have an AnimatedLifecycleDirective. Please add one to the component.');
|
|
228
|
-
}
|
|
229
|
-
this._componentRef.instance._animatedLifecycle?.enter();
|
|
230
|
-
this._componentRef.instance._animatedLifecycle?.state$
|
|
231
|
-
.pipe(tap((s) => {
|
|
232
|
-
if (s === 'entered') {
|
|
233
|
-
this._afterOpened?.next();
|
|
234
|
-
}
|
|
235
|
-
}), take(1), takeUntil(this._destroy$))
|
|
236
|
-
.subscribe();
|
|
237
|
-
this._isMounted$.next(true);
|
|
238
|
-
this._isMounting$.next(false);
|
|
239
|
-
});
|
|
240
|
-
});
|
|
241
|
-
return this._componentRef.instance;
|
|
242
|
-
}
|
|
243
|
-
unmount() {
|
|
244
|
-
if (!this.isMounted || this.isUnmounting) {
|
|
245
|
-
if (isDevMode()) {
|
|
246
|
-
if (!this.isMounted) {
|
|
247
|
-
console.warn(`AnimatedOverlayDirective: The component is currently not mounted. Please call "mount" before calling "unmount" again.`);
|
|
248
|
-
}
|
|
249
|
-
if (this.isUnmounting) {
|
|
250
|
-
console.warn(`AnimatedOverlayDirective: The component is already unmounting. Please call "mount" before calling "unmount" again.`);
|
|
251
|
-
}
|
|
252
|
-
}
|
|
253
|
-
return;
|
|
254
|
-
}
|
|
255
|
-
if (!this._componentRef) {
|
|
256
|
-
return;
|
|
257
|
-
}
|
|
258
|
-
if (this.isHidden) {
|
|
259
|
-
return;
|
|
260
|
-
}
|
|
261
|
-
this._isUnmounting$.next(true);
|
|
262
|
-
this._beforeClosed?.next();
|
|
263
|
-
this._componentRef.instance._animatedLifecycle?.leave();
|
|
264
|
-
this._componentRef.instance._animatedLifecycle?.state$
|
|
265
|
-
.pipe(filter((s) => s === 'left'), take(1))
|
|
266
|
-
.subscribe(() => this._destroy());
|
|
267
|
-
}
|
|
268
|
-
beforeOpened() {
|
|
269
|
-
if (!this._beforeOpened) {
|
|
270
|
-
this._beforeOpened = new Subject();
|
|
271
|
-
}
|
|
272
|
-
return this._beforeOpened;
|
|
273
|
-
}
|
|
274
|
-
afterOpened() {
|
|
275
|
-
if (!this._afterOpened) {
|
|
276
|
-
this._afterOpened = new Subject();
|
|
277
|
-
}
|
|
278
|
-
return this._afterOpened;
|
|
279
|
-
}
|
|
280
|
-
beforeClosed() {
|
|
281
|
-
if (!this._beforeClosed) {
|
|
282
|
-
this._beforeClosed = new Subject();
|
|
283
|
-
}
|
|
284
|
-
return this._beforeClosed;
|
|
285
|
-
}
|
|
286
|
-
afterClosed() {
|
|
287
|
-
if (!this._afterClosed) {
|
|
288
|
-
this._afterClosed = new Subject();
|
|
289
|
-
}
|
|
290
|
-
return this._afterClosed;
|
|
291
|
-
}
|
|
292
|
-
_destroy() {
|
|
293
|
-
this._zone.runOutsideAngular(() => {
|
|
294
|
-
this._floatingElCleanupFn?.();
|
|
295
|
-
});
|
|
296
|
-
if (this._overlayRef) {
|
|
297
|
-
this._overlayRef.dispose();
|
|
298
|
-
this._overlayRef = null;
|
|
299
|
-
}
|
|
300
|
-
if (this._componentRef) {
|
|
301
|
-
this._componentRef.destroy();
|
|
302
|
-
this._componentRef = null;
|
|
303
|
-
}
|
|
304
|
-
this._isMounted$.next(false);
|
|
305
|
-
this._isUnmounting$.next(false);
|
|
306
|
-
this._afterClosed?.next();
|
|
307
|
-
}
|
|
308
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: AnimatedOverlayDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
309
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "18.2.12", type: AnimatedOverlayDirective, isStandalone: true, inputs: { placement: "placement", fallbackPlacements: "fallbackPlacements", offset: "offset", arrowPadding: "arrowPadding", viewportPadding: "viewportPadding", autoResize: ["autoResize", "autoResize", booleanAttribute], shift: ["shift", "shift", booleanAttribute], autoHide: ["autoHide", "autoHide", booleanAttribute], autoCloseIfReferenceHidden: ["autoCloseIfReferenceHidden", "autoCloseIfReferenceHidden", booleanAttribute], referenceElement: "referenceElement" }, host: { classAttribute: "et-animated-overlay" }, ngImport: i0 }); }
|
|
310
|
-
}
|
|
311
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: AnimatedOverlayDirective, decorators: [{
|
|
312
|
-
type: Directive,
|
|
313
|
-
args: [{
|
|
314
|
-
standalone: true,
|
|
315
|
-
host: {
|
|
316
|
-
class: 'et-animated-overlay',
|
|
317
|
-
},
|
|
318
|
-
}]
|
|
319
|
-
}], propDecorators: { placement: [{
|
|
320
|
-
type: Input
|
|
321
|
-
}], fallbackPlacements: [{
|
|
322
|
-
type: Input
|
|
323
|
-
}], offset: [{
|
|
324
|
-
type: Input
|
|
325
|
-
}], arrowPadding: [{
|
|
326
|
-
type: Input
|
|
327
|
-
}], viewportPadding: [{
|
|
328
|
-
type: Input
|
|
329
|
-
}], autoResize: [{
|
|
330
|
-
type: Input,
|
|
331
|
-
args: [{ transform: booleanAttribute }]
|
|
332
|
-
}], shift: [{
|
|
333
|
-
type: Input,
|
|
334
|
-
args: [{ transform: booleanAttribute }]
|
|
335
|
-
}], autoHide: [{
|
|
336
|
-
type: Input,
|
|
337
|
-
args: [{ transform: booleanAttribute }]
|
|
338
|
-
}], autoCloseIfReferenceHidden: [{
|
|
339
|
-
type: Input,
|
|
340
|
-
args: [{ transform: booleanAttribute }]
|
|
341
|
-
}], referenceElement: [{
|
|
342
|
-
type: Input
|
|
343
|
-
}] } });
|
|
344
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"animated-overlay.directive.js","sourceRoot":"","sources":["../../../../../../../libs/core/src/lib/directives/animated-overlay/animated-overlay.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Overlay, OverlayRef } from '@angular/cdk/overlay';\nimport { ComponentPortal, ComponentType } from '@angular/cdk/portal';\nimport {\n  ComponentRef,\n  Directive,\n  ElementRef,\n  Injector,\n  Input,\n  NgZone,\n  StaticProvider,\n  ViewContainerRef,\n  booleanAttribute,\n  inject,\n  isDevMode,\n} from '@angular/core';\nimport { ProvideThemeDirective } from '@ethlete/theming';\nimport {\n  OffsetOptions,\n  Padding,\n  Placement,\n  arrow,\n  autoUpdate,\n  computePosition,\n  flip,\n  hide,\n  limitShift,\n  offset,\n  shift,\n  size,\n} from '@floating-ui/dom';\nimport { BehaviorSubject, Subject, filter, take, takeUntil, tap } from 'rxjs';\nimport { ResizeObserverService } from '../../services';\nimport { createDestroy, nextFrame } from '../../utils';\nimport { AnimatedLifecycleDirective } from '../animated-lifecycle';\nimport { RootBoundaryDirective } from '../root-boundary';\n\nexport interface AnimatedOverlayComponentBase {\n  _elementRef?: ElementRef<HTMLElement>;\n  _animatedLifecycle?: AnimatedLifecycleDirective;\n  _markForCheck?: () => void;\n  _setThemeFromProvider?: (provider: ProvideThemeDirective) => void;\n}\n\n@Directive({\n  standalone: true,\n  host: {\n    class: 'et-animated-overlay',\n  },\n})\nexport class AnimatedOverlayDirective<T extends AnimatedOverlayComponentBase> {\n  private readonly _destroy$ = createDestroy();\n  private readonly _overlayService = inject(Overlay);\n  private readonly _injector = inject(Injector);\n  private readonly _viewContainerRef = inject(ViewContainerRef);\n  private readonly _zone = inject(NgZone);\n  private readonly _elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n  private readonly _resizeObserverService = inject(ResizeObserverService);\n  private readonly _rootBoundary = inject(RootBoundaryDirective, { optional: true });\n\n  private _portal: ComponentPortal<T> | null = null;\n  private _overlayRef: OverlayRef | null = null;\n  private _componentRef: ComponentRef<T> | null = null;\n  private _floatingElCleanupFn: (() => void) | null = null;\n\n  private _beforeOpened: Subject<void> | null = null;\n  private _afterOpened: Subject<void> | null = null;\n  private _beforeClosed: Subject<void> | null = null;\n  private _afterClosed: Subject<void> | null = null;\n\n  private readonly _isMounted$ = new BehaviorSubject<boolean>(false);\n  private readonly _isMounting$ = new BehaviorSubject<boolean>(false);\n  private readonly _isUnmounting$ = new BehaviorSubject<boolean>(false);\n  private readonly _isHidden$ = new BehaviorSubject<boolean>(false);\n\n  /**\n   * The placement of the animated overlay.\n   * @default undefined\n   */\n  @Input()\n  placement?: Placement = 'bottom';\n\n  /**\n   * The allowed auto placements of the animated overlay.\n   * @see https://floating-ui.com/docs/flip#fallbackplacements\n   */\n  @Input()\n  fallbackPlacements?: Placement[];\n\n  /**\n   * The offset of the animated overlay.\n   * @see https://floating-ui.com/docs/offset\n   */\n  @Input()\n  offset: OffsetOptions | null = null;\n\n  /**\n   * The arrow padding.\n   * @see https://floating-ui.com/docs/arrow#padding\n   * @default 4\n   */\n  @Input()\n  arrowPadding: Padding | null = 4;\n\n  /**\n   * The viewport padding.\n   * @default 8\n   */\n  @Input()\n  viewportPadding: Padding | null = 8;\n\n  /**\n   * Whether the animated overlay should auto resize to fit the available space.\n   * Useful for things like selects where the list of options might be longer than the available space.\n   * @default false\n   */\n  @Input({ transform: booleanAttribute })\n  autoResize = false;\n\n  /**\n   * Whether the animated overlay should shift when it is near the viewport boundary.\n   */\n  @Input({ transform: booleanAttribute })\n  shift = true;\n\n  /**\n   * Whether the animated overlay should auto hide when the reference element is hidden.\n   * @default false\n   */\n  @Input({ transform: booleanAttribute })\n  autoHide = false;\n\n  /**\n   * Whether the animated overlay should auto close if the reference element is hidden.\n   * @default false\n   */\n  @Input({ transform: booleanAttribute })\n  autoCloseIfReferenceHidden = false;\n\n  /**\n   * The reference element for the animated overlay.\n   * @default this._elementRef.nativeElement\n   */\n  @Input()\n  referenceElement = this._elementRef.nativeElement;\n\n  get isMounted() {\n    return this._isMounted$.value;\n  }\n\n  get isMounted$() {\n    return this._isMounted$.asObservable();\n  }\n\n  get isMounting() {\n    return this._isMounting$.value;\n  }\n\n  get isMounting$() {\n    return this._isMounting$.asObservable();\n  }\n\n  get isUnmounting() {\n    return this._isUnmounting$.value;\n  }\n\n  get isHidden$() {\n    return this._isHidden$.asObservable();\n  }\n\n  get isHidden() {\n    return this._isHidden$.value;\n  }\n\n  get canMount() {\n    return !this.isMounted && !this.isMounting;\n  }\n\n  get canUnmount() {\n    return this.isMounted && !this.isUnmounting;\n  }\n\n  get portal() {\n    return this._portal;\n  }\n\n  get overlayRef() {\n    return this._overlayRef;\n  }\n\n  get componentRef() {\n    return this._componentRef;\n  }\n\n  mount(config: {\n    component: ComponentType<T>;\n    providers?: StaticProvider[];\n    data?: Partial<T>;\n    mirrorWidth?: boolean;\n    themeProvider?: ProvideThemeDirective | null;\n  }) {\n    if (this.isMounted || this.isMounting) {\n      if (isDevMode()) {\n        if (this.isMounted) {\n          console.warn(\n            'AnimatedOverlayDirective: The component is currently mounted. Please unmount the component before mounting again.',\n          );\n        }\n\n        if (this.isMounting) {\n          console.warn(\n            'AnimatedOverlayDirective: The component is already mounting. Please unmount the component before mounting again.',\n          );\n        }\n      }\n\n      return;\n    }\n\n    this._isMounting$.next(true);\n\n    const { component, providers, data, mirrorWidth, themeProvider } = config;\n\n    this._beforeOpened?.next();\n\n    const injector = Injector.create({\n      parent: this._injector,\n      providers: providers ?? [],\n    });\n\n    this._overlayRef = this._overlayService.create();\n\n    this._portal = new ComponentPortal(component, this._viewContainerRef, injector);\n    this._componentRef = this._overlayRef.attach(this._portal);\n\n    if (data) {\n      Object.assign(this._componentRef.instance, data);\n    }\n\n    this._componentRef.instance._markForCheck?.();\n\n    if (themeProvider) {\n      this._componentRef.instance._setThemeFromProvider?.(themeProvider);\n    }\n\n    if (mirrorWidth) {\n      this._overlayRef.updateSize({\n        width: this._elementRef.nativeElement.offsetWidth,\n      });\n\n      this._resizeObserverService\n        .observe(this.referenceElement)\n        .pipe(\n          tap(() => {\n            this._overlayRef?.updateSize({\n              width: this._elementRef.nativeElement.offsetWidth,\n            });\n          }),\n          takeUntil(this._destroy$),\n          takeUntil(this.afterClosed()),\n        )\n        .subscribe();\n    }\n\n    this._zone.runOutsideAngular(() => {\n      if (!this._componentRef) {\n        return;\n      }\n\n      const floatingEl = this._componentRef.location.nativeElement as HTMLElement;\n      const floatingElArrow = this._componentRef.instance._elementRef?.nativeElement.querySelector(\n        '[et-floating-arrow]',\n      ) as HTMLElement | null;\n\n      floatingEl.classList.add('et-floating-element');\n\n      const refEl = this.referenceElement;\n      const boundary = this._rootBoundary?.boundaryElement ?? undefined;\n\n      this._floatingElCleanupFn = autoUpdate(refEl, floatingEl, () => {\n        if (!this._componentRef) return;\n\n        computePosition(refEl, floatingEl, {\n          placement: this.placement,\n\n          middleware: [\n            ...(this.offset ? [offset(this.offset)] : []),\n            flip({\n              fallbackPlacements: this.fallbackPlacements ?? undefined,\n              fallbackAxisSideDirection: 'start',\n              boundary,\n            }),\n            ...(this.autoResize\n              ? [\n                  size({\n                    padding: this.viewportPadding ?? undefined,\n                    apply({ availableHeight, availableWidth }) {\n                      floatingEl.style.setProperty('--et-floating-max-width', `${availableWidth}px`);\n                      floatingEl.style.setProperty('--et-floating-max-height', `${availableHeight}px`);\n                    },\n                  }),\n                ]\n              : []),\n            ...(this.shift\n              ? [shift({ limiter: limitShift(), padding: this.viewportPadding ?? undefined, boundary })]\n              : []),\n            ...(floatingElArrow ? [arrow({ element: floatingElArrow, padding: this.arrowPadding ?? undefined })] : []),\n            ...(this.autoHide || this.autoCloseIfReferenceHidden\n              ? [hide({ strategy: 'referenceHidden', boundary })]\n              : []),\n          ],\n        }).then(({ x, y, placement, middlewareData }) => {\n          floatingEl.style.setProperty('--et-floating-translate', `translate3d(${x}px, ${y}px, 0)`);\n          floatingEl.setAttribute('et-floating-placement', placement);\n\n          if (middlewareData.arrow && floatingElArrow) {\n            const { x: arrowX, y: arrowY } = middlewareData.arrow;\n\n            floatingEl.style.setProperty(\n              '--et-floating-arrow-translate',\n              `translate3d(${arrowX ?? 0}px, ${arrowY ?? 0}px, 0)`,\n            );\n          }\n\n          if (middlewareData.hide?.referenceHidden) {\n            if (this.autoCloseIfReferenceHidden) {\n              this.unmount();\n            } else {\n              floatingEl.classList.add('et-floating-element--hidden');\n              this._isHidden$.next(true);\n            }\n          } else {\n            if (this.autoHide) {\n              floatingEl.classList.remove('et-floating-element--hidden');\n              this._isHidden$.next(false);\n            }\n          }\n        });\n      });\n\n      // We need to wait for the  content to be rendered\n      nextFrame(() => {\n        if (!this._componentRef) {\n          return;\n        }\n\n        if (!this._componentRef.instance._animatedLifecycle) {\n          console.error(\n            'AnimatedOverlayDirective: The component does not have an AnimatedLifecycleDirective. Please add one to the component.',\n          );\n        }\n\n        this._componentRef.instance._animatedLifecycle?.enter();\n\n        this._componentRef.instance._animatedLifecycle?.state$\n          .pipe(\n            tap((s) => {\n              if (s === 'entered') {\n                this._afterOpened?.next();\n              }\n            }),\n            take(1),\n            takeUntil(this._destroy$),\n          )\n          .subscribe();\n\n        this._isMounted$.next(true);\n        this._isMounting$.next(false);\n      });\n    });\n\n    return this._componentRef.instance;\n  }\n\n  unmount() {\n    if (!this.isMounted || this.isUnmounting) {\n      if (isDevMode()) {\n        if (!this.isMounted) {\n          console.warn(\n            `AnimatedOverlayDirective: The component is currently not mounted. Please call \"mount\" before calling \"unmount\" again.`,\n          );\n        }\n\n        if (this.isUnmounting) {\n          console.warn(\n            `AnimatedOverlayDirective: The component is already unmounting. Please call \"mount\" before calling \"unmount\" again.`,\n          );\n        }\n      }\n\n      return;\n    }\n\n    if (!this._componentRef) {\n      return;\n    }\n\n    if (this.isHidden) {\n      return;\n    }\n\n    this._isUnmounting$.next(true);\n\n    this._beforeClosed?.next();\n\n    this._componentRef.instance._animatedLifecycle?.leave();\n\n    this._componentRef.instance._animatedLifecycle?.state$\n      .pipe(\n        filter((s) => s === 'left'),\n        take(1),\n      )\n      .subscribe(() => this._destroy());\n  }\n\n  beforeOpened() {\n    if (!this._beforeOpened) {\n      this._beforeOpened = new Subject();\n    }\n\n    return this._beforeOpened;\n  }\n\n  afterOpened() {\n    if (!this._afterOpened) {\n      this._afterOpened = new Subject();\n    }\n\n    return this._afterOpened;\n  }\n\n  beforeClosed() {\n    if (!this._beforeClosed) {\n      this._beforeClosed = new Subject();\n    }\n\n    return this._beforeClosed;\n  }\n\n  afterClosed() {\n    if (!this._afterClosed) {\n      this._afterClosed = new Subject();\n    }\n\n    return this._afterClosed;\n  }\n\n  _destroy() {\n    this._zone.runOutsideAngular(() => {\n      this._floatingElCleanupFn?.();\n    });\n\n    if (this._overlayRef) {\n      this._overlayRef.dispose();\n      this._overlayRef = null;\n    }\n\n    if (this._componentRef) {\n      this._componentRef.destroy();\n      this._componentRef = null;\n    }\n\n    this._isMounted$.next(false);\n    this._isUnmounting$.next(false);\n\n    this._afterClosed?.next();\n  }\n}\n"]}
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
export * from './animated-overlay.directive';
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvcmUvc3JjL2xpYi9kaXJlY3RpdmVzL2FuaW1hdGVkLW92ZXJsYXkvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyw4QkFBOEIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vYW5pbWF0ZWQtb3ZlcmxheS5kaXJlY3RpdmUnO1xuIl19
|
|
@@ -1,37 +0,0 @@
|
|
|
1
|
-
import { Directive, ElementRef, EventEmitter, inject, Output } from '@angular/core';
|
|
2
|
-
import { ClickObserverService } from '../../services';
|
|
3
|
-
import * as i0 from "@angular/core";
|
|
4
|
-
export class ClickOutsideDirective {
|
|
5
|
-
constructor() {
|
|
6
|
-
this._elementRef = inject(ElementRef);
|
|
7
|
-
this._clickObserverService = inject(ClickObserverService);
|
|
8
|
-
this._subscription = null;
|
|
9
|
-
this.etClickOutside = new EventEmitter();
|
|
10
|
-
}
|
|
11
|
-
ngOnInit() {
|
|
12
|
-
setTimeout(() => {
|
|
13
|
-
this._subscription = this._clickObserverService.observe(this._elementRef.nativeElement).subscribe((event) => {
|
|
14
|
-
const activeElement = event.target;
|
|
15
|
-
const isInside = this._elementRef.nativeElement.contains(activeElement);
|
|
16
|
-
if (!isInside) {
|
|
17
|
-
this.etClickOutside.emit(event);
|
|
18
|
-
}
|
|
19
|
-
});
|
|
20
|
-
});
|
|
21
|
-
}
|
|
22
|
-
ngOnDestroy() {
|
|
23
|
-
this._subscription?.unsubscribe();
|
|
24
|
-
}
|
|
25
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: ClickOutsideDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
26
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.12", type: ClickOutsideDirective, isStandalone: true, selector: "[etClickOutside]", outputs: { etClickOutside: "etClickOutside" }, ngImport: i0 }); }
|
|
27
|
-
}
|
|
28
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: ClickOutsideDirective, decorators: [{
|
|
29
|
-
type: Directive,
|
|
30
|
-
args: [{
|
|
31
|
-
selector: '[etClickOutside]',
|
|
32
|
-
standalone: true,
|
|
33
|
-
}]
|
|
34
|
-
}], propDecorators: { etClickOutside: [{
|
|
35
|
-
type: Output
|
|
36
|
-
}] } });
|
|
37
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2xpY2stb3V0c2lkZS5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvcmUvc3JjL2xpYi9kaXJlY3RpdmVzL2NsaWNrLW91dHNpZGUvY2xpY2stb3V0c2lkZS5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxVQUFVLEVBQUUsWUFBWSxFQUFFLE1BQU0sRUFBcUIsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRXZHLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLGdCQUFnQixDQUFDOztBQU10RCxNQUFNLE9BQU8scUJBQXFCO0lBSmxDO1FBS1UsZ0JBQVcsR0FBRyxNQUFNLENBQUMsVUFBVSxDQUFDLENBQUM7UUFDakMsMEJBQXFCLEdBQUcsTUFBTSxDQUFDLG9CQUFvQixDQUFDLENBQUM7UUFFckQsa0JBQWEsR0FBd0IsSUFBSSxDQUFDO1FBR2xELG1CQUFjLEdBQUcsSUFBSSxZQUFZLEVBQWMsQ0FBQztLQWtCakQ7SUFoQkMsUUFBUTtRQUNOLFVBQVUsQ0FBQyxHQUFHLEVBQUU7WUFDZCxJQUFJLENBQUMsYUFBYSxHQUFHLElBQUksQ0FBQyxxQkFBcUIsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxhQUFhLENBQUMsQ0FBQyxTQUFTLENBQUMsQ0FBQyxLQUFLLEVBQUUsRUFBRTtnQkFDMUcsTUFBTSxhQUFhLEdBQUcsS0FBSyxDQUFDLE1BQXFCLENBQUM7Z0JBQ2xELE1BQU0sUUFBUSxHQUFHLElBQUksQ0FBQyxXQUFXLENBQUMsYUFBYSxDQUFDLFFBQVEsQ0FBQyxhQUFhLENBQUMsQ0FBQztnQkFFeEUsSUFBSSxDQUFDLFFBQVEsRUFBRSxDQUFDO29CQUNkLElBQUksQ0FBQyxjQUFjLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO2dCQUNsQyxDQUFDO1lBQ0gsQ0FBQyxDQUFDLENBQUM7UUFDTCxDQUFDLENBQUMsQ0FBQztJQUNMLENBQUM7SUFFRCxXQUFXO1FBQ1QsSUFBSSxDQUFDLGFBQWEsRUFBRSxXQUFXLEVBQUUsQ0FBQztJQUNwQyxDQUFDOytHQXhCVSxxQkFBcUI7bUdBQXJCLHFCQUFxQjs7NEZBQXJCLHFCQUFxQjtrQkFKakMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsa0JBQWtCO29CQUM1QixVQUFVLEVBQUUsSUFBSTtpQkFDakI7OEJBUUMsY0FBYztzQkFEYixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBFbGVtZW50UmVmLCBFdmVudEVtaXR0ZXIsIGluamVjdCwgT25EZXN0cm95LCBPbkluaXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgU3Vic2NyaXB0aW9uIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBDbGlja09ic2VydmVyU2VydmljZSB9IGZyb20gJy4uLy4uL3NlcnZpY2VzJztcblxuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnW2V0Q2xpY2tPdXRzaWRlXScsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG59KVxuZXhwb3J0IGNsYXNzIENsaWNrT3V0c2lkZURpcmVjdGl2ZSBpbXBsZW1lbnRzIE9uSW5pdCwgT25EZXN0cm95IHtcbiAgcHJpdmF0ZSBfZWxlbWVudFJlZiA9IGluamVjdChFbGVtZW50UmVmKTtcbiAgcHJpdmF0ZSBfY2xpY2tPYnNlcnZlclNlcnZpY2UgPSBpbmplY3QoQ2xpY2tPYnNlcnZlclNlcnZpY2UpO1xuXG4gIHByaXZhdGUgX3N1YnNjcmlwdGlvbjogU3Vic2NyaXB0aW9uIHwgbnVsbCA9IG51bGw7XG5cbiAgQE91dHB1dCgpXG4gIGV0Q2xpY2tPdXRzaWRlID0gbmV3IEV2ZW50RW1pdHRlcjxNb3VzZUV2ZW50PigpO1xuXG4gIG5nT25Jbml0KCk6IHZvaWQge1xuICAgIHNldFRpbWVvdXQoKCkgPT4ge1xuICAgICAgdGhpcy5fc3Vic2NyaXB0aW9uID0gdGhpcy5fY2xpY2tPYnNlcnZlclNlcnZpY2Uub2JzZXJ2ZSh0aGlzLl9lbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQpLnN1YnNjcmliZSgoZXZlbnQpID0+IHtcbiAgICAgICAgY29uc3QgYWN0aXZlRWxlbWVudCA9IGV2ZW50LnRhcmdldCBhcyBIVE1MRWxlbWVudDtcbiAgICAgICAgY29uc3QgaXNJbnNpZGUgPSB0aGlzLl9lbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQuY29udGFpbnMoYWN0aXZlRWxlbWVudCk7XG5cbiAgICAgICAgaWYgKCFpc0luc2lkZSkge1xuICAgICAgICAgIHRoaXMuZXRDbGlja091dHNpZGUuZW1pdChldmVudCk7XG4gICAgICAgIH1cbiAgICAgIH0pO1xuICAgIH0pO1xuICB9XG5cbiAgbmdPbkRlc3Ryb3koKTogdm9pZCB7XG4gICAgdGhpcy5fc3Vic2NyaXB0aW9uPy51bnN1YnNjcmliZSgpO1xuICB9XG59XG4iXX0=
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
export * from './click-outside.directive';
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvcmUvc3JjL2xpYi9kaXJlY3RpdmVzL2NsaWNrLW91dHNpZGUvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYywyQkFBMkIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vY2xpY2stb3V0c2lkZS5kaXJlY3RpdmUnO1xuIl19
|
|
@@ -1,3 +0,0 @@
|
|
|
1
|
-
export const CURSOR_DRAG_SCROLLING_CLASS = 'et-cursor-drag-scroll--scrolling';
|
|
2
|
-
export const CURSOR_DRAG_SCROLLING_PREPARED_CLASS = 'et-cursor-drag-scroll--prepared';
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3Vyc29yLWRyYWctc2Nyb2xsLmNvbnN0YW50cy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29yZS9zcmMvbGliL2RpcmVjdGl2ZXMvY3Vyc29yLWRyYWctc2Nyb2xsL2N1cnNvci1kcmFnLXNjcm9sbC5jb25zdGFudHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFDLE1BQU0sMkJBQTJCLEdBQUcsa0NBQWtDLENBQUM7QUFDOUUsTUFBTSxDQUFDLE1BQU0sb0NBQW9DLEdBQUcsaUNBQWlDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY29uc3QgQ1VSU09SX0RSQUdfU0NST0xMSU5HX0NMQVNTID0gJ2V0LWN1cnNvci1kcmFnLXNjcm9sbC0tc2Nyb2xsaW5nJztcbmV4cG9ydCBjb25zdCBDVVJTT1JfRFJBR19TQ1JPTExJTkdfUFJFUEFSRURfQ0xBU1MgPSAnZXQtY3Vyc29yLWRyYWctc2Nyb2xsLS1wcmVwYXJlZCc7XG4iXX0=
|