@skyux/core 8.10.1 → 8.10.3
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/documentation.json +529 -546
- package/esm2020/lib/modules/affix/affix.service.mjs +13 -11
- package/esm2020/lib/modules/affix/affixer.mjs +48 -36
- package/fesm2015/skyux-core.mjs +59 -44
- package/fesm2015/skyux-core.mjs.map +1 -1
- package/fesm2020/skyux-core.mjs +58 -44
- package/fesm2020/skyux-core.mjs.map +1 -1
- package/lib/modules/affix/affix.service.d.ts +1 -2
- package/lib/modules/affix/affixer.d.ts +3 -2
- package/package.json +2 -2
@@ -1,28 +1,30 @@
|
|
1
|
-
var _SkyAffixService_renderer;
|
2
|
-
import { __classPrivateFieldGet
|
3
|
-
import {
|
1
|
+
var _SkyAffixService_renderer, _SkyAffixService_viewportRuler, _SkyAffixService_zone;
|
2
|
+
import { __classPrivateFieldGet } from "tslib";
|
3
|
+
import { ViewportRuler } from '@angular/cdk/overlay';
|
4
|
+
import { Injectable, NgZone, RendererFactory2, inject, } from '@angular/core';
|
4
5
|
import { SkyAffixer } from './affixer';
|
5
6
|
import * as i0 from "@angular/core";
|
6
7
|
export class SkyAffixService {
|
7
|
-
constructor(
|
8
|
-
_SkyAffixService_renderer.set(this,
|
9
|
-
|
8
|
+
constructor() {
|
9
|
+
_SkyAffixService_renderer.set(this, inject(RendererFactory2).createRenderer(undefined, null));
|
10
|
+
_SkyAffixService_viewportRuler.set(this, inject(ViewportRuler));
|
11
|
+
_SkyAffixService_zone.set(this, inject(NgZone));
|
10
12
|
}
|
11
13
|
/**
|
12
14
|
* Creates an instance of [[SkyAffixer]].
|
13
15
|
* @param affixed The element to be affixed.
|
14
16
|
*/
|
15
17
|
createAffixer(affixed) {
|
16
|
-
return new SkyAffixer(affixed.nativeElement, __classPrivateFieldGet(this, _SkyAffixService_renderer, "f"));
|
18
|
+
return new SkyAffixer(affixed.nativeElement, __classPrivateFieldGet(this, _SkyAffixService_renderer, "f"), __classPrivateFieldGet(this, _SkyAffixService_viewportRuler, "f"), __classPrivateFieldGet(this, _SkyAffixService_zone, "f"));
|
17
19
|
}
|
18
20
|
}
|
19
|
-
_SkyAffixService_renderer = new WeakMap();
|
20
|
-
SkyAffixService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SkyAffixService, deps: [
|
21
|
+
_SkyAffixService_renderer = new WeakMap(), _SkyAffixService_viewportRuler = new WeakMap(), _SkyAffixService_zone = new WeakMap();
|
22
|
+
SkyAffixService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SkyAffixService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
21
23
|
SkyAffixService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SkyAffixService, providedIn: 'root' });
|
22
24
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SkyAffixService, decorators: [{
|
23
25
|
type: Injectable,
|
24
26
|
args: [{
|
25
27
|
providedIn: 'root',
|
26
28
|
}]
|
27
|
-
}]
|
28
|
-
//# sourceMappingURL=data:application/json;base64,
|
29
|
+
}] });
|
30
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWZmaXguc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9jb3JlL3NyYy9saWIvbW9kdWxlcy9hZmZpeC9hZmZpeC5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ3JELE9BQU8sRUFFTCxVQUFVLEVBQ1YsTUFBTSxFQUNOLGdCQUFnQixFQUNoQixNQUFNLEdBQ1AsTUFBTSxlQUFlLENBQUM7QUFFdkIsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLFdBQVcsQ0FBQzs7QUFLdkMsTUFBTSxPQUFPLGVBQWU7SUFINUI7UUFJRSxvQ0FBcUIsTUFBTSxDQUFDLGdCQUFnQixDQUFDLENBQUMsY0FBYyxDQUFDLFNBQVMsRUFBRSxJQUFJLENBQUMsRUFBQztRQUU5RSx5Q0FBMEIsTUFBTSxDQUFDLGFBQWEsQ0FBQyxFQUFDO1FBRWhELGdDQUFpQixNQUFNLENBQUMsTUFBTSxDQUFDLEVBQUM7S0FjakM7SUFaQzs7O09BR0c7SUFDSSxhQUFhLENBQUMsT0FBbUI7UUFDdEMsT0FBTyxJQUFJLFVBQVUsQ0FDbkIsT0FBTyxDQUFDLGFBQWEsRUFDckIsdUJBQUEsSUFBSSxpQ0FBVSxFQUNkLHVCQUFBLElBQUksc0NBQWUsRUFDbkIsdUJBQUEsSUFBSSw2QkFBTSxDQUNYLENBQUM7SUFDSixDQUFDOzs7NEdBbEJVLGVBQWU7Z0hBQWYsZUFBZSxjQUZkLE1BQU07MkZBRVAsZUFBZTtrQkFIM0IsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBWaWV3cG9ydFJ1bGVyIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL292ZXJsYXknO1xuaW1wb3J0IHtcbiAgRWxlbWVudFJlZixcbiAgSW5qZWN0YWJsZSxcbiAgTmdab25lLFxuICBSZW5kZXJlckZhY3RvcnkyLFxuICBpbmplY3QsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBTa3lBZmZpeGVyIH0gZnJvbSAnLi9hZmZpeGVyJztcblxuQEluamVjdGFibGUoe1xuICBwcm92aWRlZEluOiAncm9vdCcsXG59KVxuZXhwb3J0IGNsYXNzIFNreUFmZml4U2VydmljZSB7XG4gIHJlYWRvbmx5ICNyZW5kZXJlciA9IGluamVjdChSZW5kZXJlckZhY3RvcnkyKS5jcmVhdGVSZW5kZXJlcih1bmRlZmluZWQsIG51bGwpO1xuXG4gIHJlYWRvbmx5ICN2aWV3cG9ydFJ1bGVyID0gaW5qZWN0KFZpZXdwb3J0UnVsZXIpO1xuXG4gIHJlYWRvbmx5ICN6b25lID0gaW5qZWN0KE5nWm9uZSk7XG5cbiAgLyoqXG4gICAqIENyZWF0ZXMgYW4gaW5zdGFuY2Ugb2YgW1tTa3lBZmZpeGVyXV0uXG4gICAqIEBwYXJhbSBhZmZpeGVkIFRoZSBlbGVtZW50IHRvIGJlIGFmZml4ZWQuXG4gICAqL1xuICBwdWJsaWMgY3JlYXRlQWZmaXhlcihhZmZpeGVkOiBFbGVtZW50UmVmKTogU2t5QWZmaXhlciB7XG4gICAgcmV0dXJuIG5ldyBTa3lBZmZpeGVyKFxuICAgICAgYWZmaXhlZC5uYXRpdmVFbGVtZW50LFxuICAgICAgdGhpcy4jcmVuZGVyZXIsXG4gICAgICB0aGlzLiN2aWV3cG9ydFJ1bGVyLFxuICAgICAgdGhpcy4jem9uZVxuICAgICk7XG4gIH1cbn1cbiJdfQ==
|
@@ -1,6 +1,6 @@
|
|
1
|
-
var _SkyAffixer_instances, _SkyAffixer_config_get, _SkyAffixer_config_set, _SkyAffixer_affixedElement, _SkyAffixer_baseElement, _SkyAffixer_currentOffset, _SkyAffixer_currentPlacement, _SkyAffixer_offsetChange, _SkyAffixer_offsetChangeObs, _SkyAffixer_overflowParents, _SkyAffixer_overflowScroll, _SkyAffixer_overflowScrollObs, _SkyAffixer_placementChange, _SkyAffixer_placementChangeObs, _SkyAffixer_renderer,
|
1
|
+
var _SkyAffixer_instances, _SkyAffixer_config_get, _SkyAffixer_config_set, _SkyAffixer_affixedElement, _SkyAffixer_baseElement, _SkyAffixer_currentOffset, _SkyAffixer_currentPlacement, _SkyAffixer_offsetChange, _SkyAffixer_offsetChangeObs, _SkyAffixer_overflowParents, _SkyAffixer_overflowScroll, _SkyAffixer_overflowScrollObs, _SkyAffixer_placementChange, _SkyAffixer_placementChangeObs, _SkyAffixer_renderer, _SkyAffixer_scrollChange, _SkyAffixer_viewportListeners, _SkyAffixer_viewportRuler, _SkyAffixer_zone, _SkyAffixer__config, _SkyAffixer_scrollChangeListener, _SkyAffixer_affix, _SkyAffixer_getOffset, _SkyAffixer_getRect, _SkyAffixer_getPreferredOffset, _SkyAffixer_adjustOffsetToOverflowParent, _SkyAffixer_getImmediateOverflowParent, _SkyAffixer_getAutoFitContextParent, _SkyAffixer_notifyPlacementChange, _SkyAffixer_reset, _SkyAffixer_isNewOffset, _SkyAffixer_isBaseElementVisible, _SkyAffixer_addViewportListeners, _SkyAffixer_removeViewportListeners;
|
2
2
|
import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
|
3
|
-
import { Subject,
|
3
|
+
import { Subject, Subscription } from 'rxjs';
|
4
4
|
import { SkyAffixAutoFitContext } from './affix-auto-fit-context';
|
5
5
|
import { getInversePlacement, getNextPlacement } from './affix-utils';
|
6
6
|
import { getElementOffset, getOverflowParents, isOffsetFullyVisibleWithinParent, isOffsetPartiallyVisibleWithinParent, } from './dom-utils';
|
@@ -33,7 +33,7 @@ export class SkyAffixer {
|
|
33
33
|
get placementChange() {
|
34
34
|
return __classPrivateFieldGet(this, _SkyAffixer_placementChangeObs, "f");
|
35
35
|
}
|
36
|
-
constructor(affixedElement, renderer) {
|
36
|
+
constructor(affixedElement, renderer, viewportRuler, zone) {
|
37
37
|
_SkyAffixer_instances.add(this);
|
38
38
|
_SkyAffixer_affixedElement.set(this, void 0);
|
39
39
|
_SkyAffixer_baseElement.set(this, void 0);
|
@@ -47,11 +47,16 @@ export class SkyAffixer {
|
|
47
47
|
_SkyAffixer_placementChange.set(this, void 0);
|
48
48
|
_SkyAffixer_placementChangeObs.set(this, void 0);
|
49
49
|
_SkyAffixer_renderer.set(this, void 0);
|
50
|
-
|
51
|
-
|
50
|
+
_SkyAffixer_scrollChange.set(this, new Subject());
|
51
|
+
_SkyAffixer_viewportListeners.set(this, void 0);
|
52
|
+
_SkyAffixer_viewportRuler.set(this, void 0);
|
53
|
+
_SkyAffixer_zone.set(this, void 0);
|
52
54
|
_SkyAffixer__config.set(this, DEFAULT_AFFIX_CONFIG);
|
55
|
+
_SkyAffixer_scrollChangeListener.set(this, () => __classPrivateFieldGet(this, _SkyAffixer_scrollChange, "f").next());
|
53
56
|
__classPrivateFieldSet(this, _SkyAffixer_affixedElement, affixedElement, "f");
|
54
57
|
__classPrivateFieldSet(this, _SkyAffixer_renderer, renderer, "f");
|
58
|
+
__classPrivateFieldSet(this, _SkyAffixer_viewportRuler, viewportRuler, "f");
|
59
|
+
__classPrivateFieldSet(this, _SkyAffixer_zone, zone, "f");
|
55
60
|
__classPrivateFieldSet(this, _SkyAffixer_offsetChange, new Subject(), "f");
|
56
61
|
__classPrivateFieldSet(this, _SkyAffixer_overflowScroll, new Subject(), "f");
|
57
62
|
__classPrivateFieldSet(this, _SkyAffixer_placementChange, new Subject(), "f");
|
@@ -71,8 +76,7 @@ export class SkyAffixer {
|
|
71
76
|
__classPrivateFieldSet(this, _SkyAffixer_overflowParents, getOverflowParents(baseElement), "f");
|
72
77
|
__classPrivateFieldGet(this, _SkyAffixer_instances, "m", _SkyAffixer_affix).call(this);
|
73
78
|
if (__classPrivateFieldGet(this, _SkyAffixer_instances, "a", _SkyAffixer_config_get).isSticky) {
|
74
|
-
__classPrivateFieldGet(this, _SkyAffixer_instances, "m",
|
75
|
-
__classPrivateFieldGet(this, _SkyAffixer_instances, "m", _SkyAffixer_addResizeListener).call(this);
|
79
|
+
__classPrivateFieldGet(this, _SkyAffixer_instances, "m", _SkyAffixer_addViewportListeners).call(this);
|
76
80
|
}
|
77
81
|
}
|
78
82
|
getConfig() {
|
@@ -94,9 +98,10 @@ export class SkyAffixer {
|
|
94
98
|
__classPrivateFieldGet(this, _SkyAffixer_placementChange, "f").complete();
|
95
99
|
__classPrivateFieldGet(this, _SkyAffixer_offsetChange, "f").complete();
|
96
100
|
__classPrivateFieldGet(this, _SkyAffixer_overflowScroll, "f").complete();
|
101
|
+
__classPrivateFieldGet(this, _SkyAffixer_scrollChange, "f").complete();
|
97
102
|
}
|
98
103
|
}
|
99
|
-
_SkyAffixer_affixedElement = new WeakMap(), _SkyAffixer_baseElement = new WeakMap(), _SkyAffixer_currentOffset = new WeakMap(), _SkyAffixer_currentPlacement = new WeakMap(), _SkyAffixer_offsetChange = new WeakMap(), _SkyAffixer_offsetChangeObs = new WeakMap(), _SkyAffixer_overflowParents = new WeakMap(), _SkyAffixer_overflowScroll = new WeakMap(), _SkyAffixer_overflowScrollObs = new WeakMap(), _SkyAffixer_placementChange = new WeakMap(), _SkyAffixer_placementChangeObs = new WeakMap(), _SkyAffixer_renderer = new WeakMap(),
|
104
|
+
_SkyAffixer_affixedElement = new WeakMap(), _SkyAffixer_baseElement = new WeakMap(), _SkyAffixer_currentOffset = new WeakMap(), _SkyAffixer_currentPlacement = new WeakMap(), _SkyAffixer_offsetChange = new WeakMap(), _SkyAffixer_offsetChangeObs = new WeakMap(), _SkyAffixer_overflowParents = new WeakMap(), _SkyAffixer_overflowScroll = new WeakMap(), _SkyAffixer_overflowScrollObs = new WeakMap(), _SkyAffixer_placementChange = new WeakMap(), _SkyAffixer_placementChangeObs = new WeakMap(), _SkyAffixer_renderer = new WeakMap(), _SkyAffixer_scrollChange = new WeakMap(), _SkyAffixer_viewportListeners = new WeakMap(), _SkyAffixer_viewportRuler = new WeakMap(), _SkyAffixer_zone = new WeakMap(), _SkyAffixer__config = new WeakMap(), _SkyAffixer_scrollChangeListener = new WeakMap(), _SkyAffixer_instances = new WeakSet(), _SkyAffixer_config_get = function _SkyAffixer_config_get() {
|
100
105
|
return __classPrivateFieldGet(this, _SkyAffixer__config, "f");
|
101
106
|
}, _SkyAffixer_config_set = function _SkyAffixer_config_set(value) {
|
102
107
|
const merged = {
|
@@ -132,8 +137,11 @@ _SkyAffixer_affixedElement = new WeakMap(), _SkyAffixer_baseElement = new WeakMa
|
|
132
137
|
top: 0,
|
133
138
|
};
|
134
139
|
if (__classPrivateFieldGet(this, _SkyAffixer_instances, "a", _SkyAffixer_config_get).position === 'absolute') {
|
135
|
-
|
136
|
-
|
140
|
+
const { top, left } = __classPrivateFieldGet(this, _SkyAffixer_viewportRuler, "f").getViewportScrollPosition();
|
141
|
+
autoFitOverflowOffset.top = (autoFitOverflowOffset.top || 0) + top;
|
142
|
+
autoFitOverflowOffset.left = (autoFitOverflowOffset.left || 0) + left;
|
143
|
+
autoFitOverflowOffset.bottom = (autoFitOverflowOffset.bottom || 0) + top;
|
144
|
+
autoFitOverflowOffset.right = (autoFitOverflowOffset.right || 0) + left;
|
137
145
|
}
|
138
146
|
do {
|
139
147
|
offset = __classPrivateFieldGet(this, _SkyAffixer_instances, "m", _SkyAffixer_getPreferredOffset).call(this, placement);
|
@@ -174,8 +182,11 @@ _SkyAffixer_affixedElement = new WeakMap(), _SkyAffixer_baseElement = new WeakMa
|
|
174
182
|
height: baseDomRect.height,
|
175
183
|
};
|
176
184
|
if (__classPrivateFieldGet(this, _SkyAffixer_instances, "a", _SkyAffixer_config_get).position === 'absolute') {
|
177
|
-
|
178
|
-
baseRect.
|
185
|
+
const { left, top } = __classPrivateFieldGet(this, _SkyAffixer_viewportRuler, "f").getViewportScrollPosition();
|
186
|
+
baseRect.top += top;
|
187
|
+
baseRect.left += left;
|
188
|
+
baseRect.bottom += top;
|
189
|
+
baseRect.right += left;
|
179
190
|
}
|
180
191
|
return baseRect;
|
181
192
|
}, _SkyAffixer_getPreferredOffset = function _SkyAffixer_getPreferredOffset(placement) {
|
@@ -325,8 +336,7 @@ _SkyAffixer_affixedElement = new WeakMap(), _SkyAffixer_baseElement = new WeakMa
|
|
325
336
|
});
|
326
337
|
}
|
327
338
|
}, _SkyAffixer_reset = function _SkyAffixer_reset() {
|
328
|
-
__classPrivateFieldGet(this, _SkyAffixer_instances, "m",
|
329
|
-
__classPrivateFieldGet(this, _SkyAffixer_instances, "m", _SkyAffixer_removeResizeListener).call(this);
|
339
|
+
__classPrivateFieldGet(this, _SkyAffixer_instances, "m", _SkyAffixer_removeViewportListeners).call(this);
|
330
340
|
__classPrivateFieldSet(this, _SkyAffixer_overflowParents, [], "f");
|
331
341
|
__classPrivateFieldSet(this, _SkyAffixer_instances, __classPrivateFieldSet(this, _SkyAffixer_baseElement, __classPrivateFieldSet(this, _SkyAffixer_currentPlacement, __classPrivateFieldSet(this, _SkyAffixer_currentOffset, undefined, "f"), "f"), "f"), "a", _SkyAffixer_config_set);
|
332
342
|
}, _SkyAffixer_isNewOffset = function _SkyAffixer_isNewOffset(offset) {
|
@@ -351,27 +361,29 @@ _SkyAffixer_affixedElement = new WeakMap(), _SkyAffixer_baseElement = new WeakMa
|
|
351
361
|
right: baseRect.right,
|
352
362
|
bottom: baseRect.bottom,
|
353
363
|
}, __classPrivateFieldGet(this, _SkyAffixer_instances, "a", _SkyAffixer_config_get).autoFitOverflowOffset);
|
354
|
-
},
|
355
|
-
__classPrivateFieldSet(this,
|
356
|
-
|
357
|
-
|
358
|
-
|
359
|
-
|
364
|
+
}, _SkyAffixer_addViewportListeners = function _SkyAffixer_addViewportListeners() {
|
365
|
+
__classPrivateFieldSet(this, _SkyAffixer_viewportListeners, new Subscription(), "f");
|
366
|
+
// Resize and orientation changes.
|
367
|
+
__classPrivateFieldGet(this, _SkyAffixer_viewportListeners, "f").add(__classPrivateFieldGet(this, _SkyAffixer_viewportRuler, "f").change().subscribe(() => {
|
368
|
+
__classPrivateFieldGet(this, _SkyAffixer_instances, "m", _SkyAffixer_affix).call(this);
|
369
|
+
}));
|
370
|
+
__classPrivateFieldGet(this, _SkyAffixer_viewportListeners, "f").add(__classPrivateFieldGet(this, _SkyAffixer_scrollChange, "f").subscribe(() => {
|
371
|
+
__classPrivateFieldGet(this, _SkyAffixer_instances, "m", _SkyAffixer_affix).call(this);
|
372
|
+
__classPrivateFieldGet(this, _SkyAffixer_overflowScroll, "f").next();
|
373
|
+
}));
|
374
|
+
// Listen for scroll events on the window, visual viewport, and any overflow parents.
|
375
|
+
// https://developer.chrome.com/blog/visual-viewport-api/#events-only-fire-when-the-visual-viewport-changes
|
376
|
+
__classPrivateFieldGet(this, _SkyAffixer_zone, "f").runOutsideAngular(() => {
|
377
|
+
[window, window.visualViewport, ...__classPrivateFieldGet(this, _SkyAffixer_overflowParents, "f")].forEach((parentElement) => {
|
378
|
+
parentElement?.addEventListener('scroll', __classPrivateFieldGet(this, _SkyAffixer_scrollChangeListener, "f"));
|
360
379
|
});
|
361
|
-
})
|
362
|
-
},
|
363
|
-
|
364
|
-
|
365
|
-
|
366
|
-
|
367
|
-
|
368
|
-
}
|
369
|
-
}, _SkyAffixer_removeScrollListeners = function _SkyAffixer_removeScrollListeners() {
|
370
|
-
if (__classPrivateFieldGet(this, _SkyAffixer_scrollListeners, "f")) {
|
371
|
-
// Remove renderer-generated listeners by calling the listener itself.
|
372
|
-
// https://github.com/angular/angular/issues/9368#issuecomment-227199778
|
373
|
-
__classPrivateFieldGet(this, _SkyAffixer_scrollListeners, "f").forEach((listener) => listener());
|
374
|
-
__classPrivateFieldSet(this, _SkyAffixer_scrollListeners, undefined, "f");
|
375
|
-
}
|
380
|
+
});
|
381
|
+
}, _SkyAffixer_removeViewportListeners = function _SkyAffixer_removeViewportListeners() {
|
382
|
+
__classPrivateFieldGet(this, _SkyAffixer_viewportListeners, "f")?.unsubscribe();
|
383
|
+
__classPrivateFieldGet(this, _SkyAffixer_zone, "f").runOutsideAngular(() => {
|
384
|
+
[window, window.visualViewport, ...__classPrivateFieldGet(this, _SkyAffixer_overflowParents, "f")].forEach((parentElement) => {
|
385
|
+
parentElement?.removeEventListener('scroll', __classPrivateFieldGet(this, _SkyAffixer_scrollChangeListener, "f"));
|
386
|
+
});
|
387
|
+
});
|
376
388
|
};
|
377
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"affixer.js","sourceRoot":"","sources":["../../../../../../../../libs/components/core/src/lib/modules/affix/affixer.ts"],"names":[],"mappings":"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","sourcesContent":["import { Renderer2 } from '@angular/core';\n\nimport { Observable, Subject, Subscription, fromEvent } from 'rxjs';\n\nimport { SkyAffixAutoFitContext } from './affix-auto-fit-context';\nimport { SkyAffixConfig } from './affix-config';\nimport { SkyAffixOffset } from './affix-offset';\nimport { SkyAffixOffsetChange } from './affix-offset-change';\nimport { SkyAffixPlacement } from './affix-placement';\nimport { SkyAffixPlacementChange } from './affix-placement-change';\nimport { AffixRect } from './affix-rect';\nimport { getInversePlacement, getNextPlacement } from './affix-utils';\nimport {\n  getElementOffset,\n  getOverflowParents,\n  isOffsetFullyVisibleWithinParent,\n  isOffsetPartiallyVisibleWithinParent,\n} from './dom-utils';\n\n/**\n * Make specific properties required, so that we don't have to\n * do null checks throughout this file.\n */\ntype AffixConfigOrDefaults = SkyAffixConfig &\n  Required<\n    Pick<\n      SkyAffixConfig,\n      | 'autoFitContext'\n      | 'enableAutoFit'\n      | 'horizontalAlignment'\n      | 'isSticky'\n      | 'placement'\n    >\n  >;\n\nconst DEFAULT_AFFIX_CONFIG: AffixConfigOrDefaults = {\n  autoFitContext: SkyAffixAutoFitContext.OverflowParent,\n  enableAutoFit: false,\n  horizontalAlignment: 'center',\n  isSticky: false,\n  placement: 'above',\n};\n\nexport class SkyAffixer {\n  /**\n   * Fires when the affixed element's offset changes.\n   */\n  public get offsetChange(): Observable<SkyAffixOffsetChange> {\n    return this.#offsetChangeObs;\n  }\n\n  /**\n   * Fires when the base element's nearest overflow parent is scrolling. This is useful if you need\n   * to perform an additional action during the scroll event but don't want to generate another\n   * event listener.\n   */\n  public get overflowScroll(): Observable<void> {\n    return this.#overflowScrollObs;\n  }\n\n  /**\n   * Fires when the placement value changes. A `null` value indicates that a suitable\n   * placement could not be found.\n   */\n  public get placementChange(): Observable<SkyAffixPlacementChange> {\n    return this.#placementChangeObs;\n  }\n\n  get #config(): AffixConfigOrDefaults {\n    return this.#_config;\n  }\n\n  set #config(value: SkyAffixConfig | undefined) {\n    const merged: AffixConfigOrDefaults = {\n      ...DEFAULT_AFFIX_CONFIG,\n      ...value,\n    };\n\n    // Make sure none of the values are undefined.\n    let key: keyof typeof merged;\n    for (key in merged) {\n      if (merged[key] === undefined) {\n        (merged as any)[key] = DEFAULT_AFFIX_CONFIG[key];\n      }\n    }\n\n    this.#_config = merged;\n  }\n\n  #affixedElement: HTMLElement;\n\n  #baseElement: HTMLElement | undefined;\n\n  #currentOffset: SkyAffixOffset | undefined;\n\n  #currentPlacement: SkyAffixPlacement | undefined;\n\n  #offsetChange: Subject<SkyAffixOffsetChange>;\n\n  #offsetChangeObs: Observable<SkyAffixOffsetChange>;\n\n  #overflowParents: HTMLElement[] = [];\n\n  #overflowScroll: Subject<void>;\n\n  #overflowScrollObs: Observable<void>;\n\n  #placementChange: Subject<SkyAffixPlacementChange>;\n\n  #placementChangeObs: Observable<SkyAffixPlacementChange>;\n\n  #renderer: Renderer2;\n\n  #resizeListener: Subscription | undefined;\n\n  #scrollListeners: (() => void)[] | undefined;\n\n  #_config: AffixConfigOrDefaults = DEFAULT_AFFIX_CONFIG;\n\n  constructor(affixedElement: HTMLElement, renderer: Renderer2) {\n    this.#affixedElement = affixedElement;\n    this.#renderer = renderer;\n\n    this.#offsetChange = new Subject<SkyAffixOffsetChange>();\n    this.#overflowScroll = new Subject<void>();\n    this.#placementChange = new Subject<SkyAffixPlacementChange>();\n\n    this.#offsetChangeObs = this.#offsetChange.asObservable();\n    this.#overflowScrollObs = this.#overflowScroll.asObservable();\n    this.#placementChangeObs = this.#placementChange.asObservable();\n  }\n\n  /**\n   * Affixes an element to a base element.\n   * @param baseElement The base element.\n   * @param config Configuration for the affix action.\n   */\n  public affixTo(baseElement: HTMLElement, config?: SkyAffixConfig): void {\n    this.#reset();\n\n    this.#config = config;\n    this.#baseElement = baseElement;\n    this.#overflowParents = getOverflowParents(baseElement);\n\n    this.#affix();\n\n    if (this.#config.isSticky) {\n      this.#addScrollListeners();\n      this.#addResizeListener();\n    }\n  }\n\n  public getConfig(): SkyAffixConfig {\n    return this.#config;\n  }\n\n  /**\n   * Re-runs the affix calculation.\n   */\n  public reaffix(): void {\n    // Reset current placement to preferred placement.\n    this.#currentPlacement = this.#config.placement;\n    this.#affix();\n  }\n\n  /**\n   * Destroys the affixer.\n   */\n  public destroy(): void {\n    this.#reset();\n    this.#placementChange.complete();\n    this.#offsetChange.complete();\n    this.#overflowScroll.complete();\n  }\n\n  #affix(): void {\n    const offset = this.#getOffset();\n\n    if (this.#isNewOffset(offset)) {\n      this.#renderer.setStyle(this.#affixedElement, 'top', `${offset.top}px`);\n      this.#renderer.setStyle(this.#affixedElement, 'left', `${offset.left}px`);\n\n      this.#offsetChange.next({ offset });\n    }\n  }\n\n  #getOffset(): SkyAffixOffset {\n    const parent = this.#getAutoFitContextParent();\n\n    const maxAttempts = 4;\n    let attempts = 0;\n\n    let isAffixedElementFullyVisible = false;\n    let offset: Required<SkyAffixOffset>;\n    let placement = this.#config.placement;\n\n    const autoFitOverflowOffset = this.#config.autoFitOverflowOffset || {\n      bottom: 0,\n      left: 0,\n      right: 0,\n      top: 0,\n    };\n\n    if (this.#config.position === 'absolute') {\n      autoFitOverflowOffset.top =\n        (autoFitOverflowOffset.top || 0) + window.scrollY;\n    }\n\n    do {\n      offset = this.#getPreferredOffset(placement);\n      isAffixedElementFullyVisible = isOffsetFullyVisibleWithinParent(\n        parent,\n        offset,\n        autoFitOverflowOffset\n      );\n\n      if (!this.#config.enableAutoFit) {\n        break;\n      }\n\n      if (!isAffixedElementFullyVisible) {\n        placement =\n          attempts % 2 === 0\n            ? getInversePlacement(placement)\n            : getNextPlacement(placement);\n      }\n\n      attempts++;\n    } while (!isAffixedElementFullyVisible && attempts < maxAttempts);\n\n    if (isAffixedElementFullyVisible) {\n      if (this.#isBaseElementVisible()) {\n        this.#notifyPlacementChange(placement);\n      } else {\n        this.#notifyPlacementChange(null);\n      }\n\n      return offset;\n    }\n\n    if (this.#config.enableAutoFit) {\n      this.#notifyPlacementChange(null);\n    }\n\n    // No suitable placement was found, so revert to preferred placement.\n    return this.#getPreferredOffset(this.#config.placement);\n  }\n\n  #getRect(baseElement: HTMLElement): AffixRect {\n    const baseDomRect = baseElement.getBoundingClientRect();\n\n    const baseRect: AffixRect = {\n      top: baseDomRect.top,\n      bottom: baseDomRect.bottom,\n      left: baseDomRect.left,\n      right: baseDomRect.right,\n      width: baseDomRect.width,\n      height: baseDomRect.height,\n    };\n\n    if (this.#config.position === 'absolute') {\n      baseRect.top += window.scrollY;\n      baseRect.bottom = baseRect.top + baseDomRect.height;\n    }\n\n    return baseRect;\n  }\n\n  #getPreferredOffset(placement: SkyAffixPlacement): Required<SkyAffixOffset> {\n    if (!this.#baseElement) {\n      return { top: 0, left: 0, bottom: 0, right: 0 };\n    }\n\n    const affixedRect = this.#getRect(this.#affixedElement);\n    const baseRect = this.#getRect(this.#baseElement);\n\n    const horizontalAlignment = this.#config.horizontalAlignment;\n    const verticalAlignment = this.#config.verticalAlignment;\n    const enableAutoFit = this.#config.enableAutoFit;\n\n    let top: number;\n    let left: number;\n\n    if (placement === 'above' || placement === 'below') {\n      if (placement === 'above') {\n        top = baseRect.top - affixedRect.height;\n\n        switch (verticalAlignment) {\n          case 'top':\n            top = top + affixedRect.height;\n            break;\n          case 'middle':\n            top = top + affixedRect.height / 2;\n            break;\n          case 'bottom':\n          default:\n            break;\n        }\n      } else {\n        top = baseRect.bottom;\n\n        switch (verticalAlignment) {\n          case 'top':\n          default:\n            break;\n          case 'middle':\n            top = top - affixedRect.height / 2;\n            break;\n          case 'bottom':\n            top = top - affixedRect.height;\n            break;\n        }\n      }\n\n      switch (horizontalAlignment) {\n        case 'left':\n          left = baseRect.left;\n          break;\n\n        case 'center':\n        default:\n          left = baseRect.left + baseRect.width / 2 - affixedRect.width / 2;\n          break;\n\n        case 'right':\n          left = baseRect.right - affixedRect.width;\n          break;\n      }\n    } else {\n      if (placement === 'left') {\n        left = baseRect.left - affixedRect.width;\n      } else {\n        left = baseRect.right;\n      }\n\n      switch (verticalAlignment) {\n        case 'top':\n          top = baseRect.top;\n          break;\n\n        case 'middle':\n        default:\n          top = baseRect.top + baseRect.height / 2 - affixedRect.height / 2;\n          break;\n\n        case 'bottom':\n          top = baseRect.bottom - affixedRect.height;\n          break;\n      }\n    }\n\n    const offset: Required<SkyAffixOffset> = { top, left, bottom: 0, right: 0 };\n\n    if (enableAutoFit) {\n      const adjustments = this.#adjustOffsetToOverflowParent(\n        { top, left },\n        placement,\n        this.#baseElement\n      );\n      offset.top = adjustments.top;\n      offset.left = adjustments.left;\n    }\n\n    offset.bottom = offset.top + affixedRect.height;\n    offset.right = offset.left + affixedRect.width;\n\n    return offset;\n  }\n\n  /**\n   * Slightly adjust the offset to fit within the scroll parent's boundaries if\n   * the affixed element would otherwise be clipped.\n   */\n  #adjustOffsetToOverflowParent(\n    offset: { top: number; left: number },\n    placement: SkyAffixPlacement,\n    baseElement: HTMLElement\n  ): { top: number; left: number } {\n    const parent = this.#getAutoFitContextParent();\n    const parentOffset = getElementOffset(\n      parent,\n      this.#config.autoFitOverflowOffset\n    );\n\n    const affixedRect = this.#getRect(this.#affixedElement);\n    const baseRect = this.#getRect(baseElement);\n\n    // A pixel value representing the leeway between the edge of the overflow parent and the edge\n    // of the base element before it disappears from view.\n    // If the visible portion of the base element is less than this pixel value, the auto-fit\n    // functionality attempts to find another placement.\n    const defaultPixelTolerance = 40;\n    let pixelTolerance: number;\n\n    const originalOffsetTop = offset.top;\n    const originalOffsetLeft = offset.left;\n\n    switch (placement) {\n      case 'above':\n      case 'below':\n        // Keep the affixed element within the overflow parent.\n        if (offset.left < parentOffset.left) {\n          offset.left = parentOffset.left;\n        } else if (offset.left + affixedRect.width > parentOffset.right) {\n          offset.left = parentOffset.right - affixedRect.width;\n        }\n\n        // Use a smaller pixel tolerance if the base element width is less than the default.\n        pixelTolerance = Math.min(defaultPixelTolerance, baseRect.width);\n\n        // Make sure the affixed element never detaches from the base element.\n        if (\n          offset.left + pixelTolerance > baseRect.right ||\n          offset.left + affixedRect.width - pixelTolerance < baseRect.left\n        ) {\n          offset.left = originalOffsetLeft;\n        }\n\n        break;\n\n      case 'left':\n      case 'right':\n        // Keep the affixed element within the overflow parent.\n        if (offset.top < parentOffset.top) {\n          offset.top = parentOffset.top;\n        } else if (offset.top + affixedRect.height > parentOffset.bottom) {\n          offset.top = parentOffset.bottom - affixedRect.height;\n        }\n\n        // Use a smaller pixel tolerance if the base element height is less than the default.\n        pixelTolerance = Math.min(defaultPixelTolerance, baseRect.height);\n\n        // Make sure the affixed element never detaches from the base element.\n        if (\n          offset.top + pixelTolerance > baseRect.bottom ||\n          offset.top + affixedRect.height - pixelTolerance < baseRect.top\n        ) {\n          offset.top = originalOffsetTop;\n        }\n\n        break;\n    }\n\n    return offset;\n  }\n\n  #getImmediateOverflowParent(): HTMLElement {\n    return this.#overflowParents[this.#overflowParents.length - 1];\n  }\n\n  #getAutoFitContextParent(): HTMLElement {\n    const bodyElement = this.#overflowParents[0];\n\n    return this.#config.autoFitContext === SkyAffixAutoFitContext.OverflowParent\n      ? this.#getImmediateOverflowParent()\n      : bodyElement;\n  }\n\n  #notifyPlacementChange(placement: SkyAffixPlacement | null): void {\n    if (this.#currentPlacement !== placement) {\n      this.#currentPlacement = placement ?? undefined;\n      this.#placementChange.next({\n        placement,\n      });\n    }\n  }\n\n  #reset(): void {\n    this.#removeScrollListeners();\n    this.#removeResizeListener();\n\n    this.#overflowParents = [];\n\n    this.#config =\n      this.#baseElement =\n      this.#currentPlacement =\n      this.#currentOffset =\n        undefined;\n  }\n\n  #isNewOffset(offset: SkyAffixOffset): boolean {\n    if (this.#currentOffset === undefined) {\n      this.#currentOffset = offset;\n      return true;\n    }\n\n    if (\n      this.#currentOffset.top === offset.top &&\n      this.#currentOffset.left === offset.left\n    ) {\n      return false;\n    }\n\n    this.#currentOffset = offset;\n\n    return true;\n  }\n\n  #isBaseElementVisible(): boolean {\n    if (!this.#baseElement) {\n      return false;\n    }\n\n    const baseRect = this.#baseElement.getBoundingClientRect();\n\n    return isOffsetPartiallyVisibleWithinParent(\n      this.#getImmediateOverflowParent(),\n      {\n        top: baseRect.top,\n        left: baseRect.left,\n        right: baseRect.right,\n        bottom: baseRect.bottom,\n      },\n      this.#config.autoFitOverflowOffset\n    );\n  }\n\n  #addScrollListeners(): void {\n    this.#scrollListeners = this.#overflowParents.map((parentElement) => {\n      const overflow =\n        parentElement === document.body ? 'window' : parentElement;\n      return this.#renderer.listen(overflow, 'scroll', () => {\n        this.#affix();\n        this.#overflowScroll.next();\n      });\n    });\n  }\n\n  #addResizeListener(): void {\n    this.#resizeListener = fromEvent(window, 'resize').subscribe(() =>\n      this.#affix()\n    );\n  }\n\n  #removeResizeListener(): void {\n    if (this.#resizeListener) {\n      this.#resizeListener.unsubscribe();\n      this.#resizeListener = undefined;\n    }\n  }\n\n  #removeScrollListeners(): void {\n    if (this.#scrollListeners) {\n      // Remove renderer-generated listeners by calling the listener itself.\n      // https://github.com/angular/angular/issues/9368#issuecomment-227199778\n      this.#scrollListeners.forEach((listener) => listener());\n      this.#scrollListeners = undefined;\n    }\n  }\n}\n"]}
|
389
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"affixer.js","sourceRoot":"","sources":["../../../../../../../../libs/components/core/src/lib/modules/affix/affixer.ts"],"names":[],"mappings":"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","sourcesContent":["import { ViewportRuler } from '@angular/cdk/overlay';\nimport { NgZone, Renderer2 } from '@angular/core';\n\nimport { Observable, Subject, Subscription } from 'rxjs';\n\nimport { SkyAffixAutoFitContext } from './affix-auto-fit-context';\nimport { SkyAffixConfig } from './affix-config';\nimport { SkyAffixOffset } from './affix-offset';\nimport { SkyAffixOffsetChange } from './affix-offset-change';\nimport { SkyAffixPlacement } from './affix-placement';\nimport { SkyAffixPlacementChange } from './affix-placement-change';\nimport { AffixRect } from './affix-rect';\nimport { getInversePlacement, getNextPlacement } from './affix-utils';\nimport {\n  getElementOffset,\n  getOverflowParents,\n  isOffsetFullyVisibleWithinParent,\n  isOffsetPartiallyVisibleWithinParent,\n} from './dom-utils';\n\n/**\n * Make specific properties required, so that we don't have to\n * do null checks throughout this file.\n */\ntype AffixConfigOrDefaults = SkyAffixConfig &\n  Required<\n    Pick<\n      SkyAffixConfig,\n      | 'autoFitContext'\n      | 'enableAutoFit'\n      | 'horizontalAlignment'\n      | 'isSticky'\n      | 'placement'\n    >\n  >;\n\nconst DEFAULT_AFFIX_CONFIG: AffixConfigOrDefaults = {\n  autoFitContext: SkyAffixAutoFitContext.OverflowParent,\n  enableAutoFit: false,\n  horizontalAlignment: 'center',\n  isSticky: false,\n  placement: 'above',\n};\n\nexport class SkyAffixer {\n  /**\n   * Fires when the affixed element's offset changes.\n   */\n  public get offsetChange(): Observable<SkyAffixOffsetChange> {\n    return this.#offsetChangeObs;\n  }\n\n  /**\n   * Fires when the base element's nearest overflow parent is scrolling. This is useful if you need\n   * to perform an additional action during the scroll event but don't want to generate another\n   * event listener.\n   */\n  public get overflowScroll(): Observable<void> {\n    return this.#overflowScrollObs;\n  }\n\n  /**\n   * Fires when the placement value changes. A `null` value indicates that a suitable\n   * placement could not be found.\n   */\n  public get placementChange(): Observable<SkyAffixPlacementChange> {\n    return this.#placementChangeObs;\n  }\n\n  get #config(): AffixConfigOrDefaults {\n    return this.#_config;\n  }\n\n  set #config(value: SkyAffixConfig | undefined) {\n    const merged: AffixConfigOrDefaults = {\n      ...DEFAULT_AFFIX_CONFIG,\n      ...value,\n    };\n\n    // Make sure none of the values are undefined.\n    let key: keyof typeof merged;\n    for (key in merged) {\n      if (merged[key] === undefined) {\n        (merged as any)[key] = DEFAULT_AFFIX_CONFIG[key];\n      }\n    }\n\n    this.#_config = merged;\n  }\n\n  #affixedElement: HTMLElement;\n\n  #baseElement: HTMLElement | undefined;\n\n  #currentOffset: SkyAffixOffset | undefined;\n\n  #currentPlacement: SkyAffixPlacement | undefined;\n\n  #offsetChange: Subject<SkyAffixOffsetChange>;\n\n  #offsetChangeObs: Observable<SkyAffixOffsetChange>;\n\n  #overflowParents: HTMLElement[] = [];\n\n  #overflowScroll: Subject<void>;\n\n  #overflowScrollObs: Observable<void>;\n\n  #placementChange: Subject<SkyAffixPlacementChange>;\n\n  #placementChangeObs: Observable<SkyAffixPlacementChange>;\n\n  #renderer: Renderer2;\n\n  #scrollChange = new Subject<void>();\n\n  #viewportListeners: Subscription | undefined;\n\n  #viewportRuler: ViewportRuler;\n\n  #zone: NgZone;\n\n  #_config: AffixConfigOrDefaults = DEFAULT_AFFIX_CONFIG;\n\n  #scrollChangeListener: () => void = () => this.#scrollChange.next();\n\n  constructor(\n    affixedElement: HTMLElement,\n    renderer: Renderer2,\n    viewportRuler: ViewportRuler,\n    zone: NgZone\n  ) {\n    this.#affixedElement = affixedElement;\n    this.#renderer = renderer;\n    this.#viewportRuler = viewportRuler;\n    this.#zone = zone;\n\n    this.#offsetChange = new Subject<SkyAffixOffsetChange>();\n    this.#overflowScroll = new Subject<void>();\n    this.#placementChange = new Subject<SkyAffixPlacementChange>();\n\n    this.#offsetChangeObs = this.#offsetChange.asObservable();\n    this.#overflowScrollObs = this.#overflowScroll.asObservable();\n    this.#placementChangeObs = this.#placementChange.asObservable();\n  }\n\n  /**\n   * Affixes an element to a base element.\n   * @param baseElement The base element.\n   * @param config Configuration for the affix action.\n   */\n  public affixTo(baseElement: HTMLElement, config?: SkyAffixConfig): void {\n    this.#reset();\n\n    this.#config = config;\n    this.#baseElement = baseElement;\n    this.#overflowParents = getOverflowParents(baseElement);\n\n    this.#affix();\n\n    if (this.#config.isSticky) {\n      this.#addViewportListeners();\n    }\n  }\n\n  public getConfig(): SkyAffixConfig {\n    return this.#config;\n  }\n\n  /**\n   * Re-runs the affix calculation.\n   */\n  public reaffix(): void {\n    // Reset current placement to preferred placement.\n    this.#currentPlacement = this.#config.placement;\n    this.#affix();\n  }\n\n  /**\n   * Destroys the affixer.\n   */\n  public destroy(): void {\n    this.#reset();\n    this.#placementChange.complete();\n    this.#offsetChange.complete();\n    this.#overflowScroll.complete();\n    this.#scrollChange.complete();\n  }\n\n  #affix(): void {\n    const offset = this.#getOffset();\n\n    if (this.#isNewOffset(offset)) {\n      this.#renderer.setStyle(this.#affixedElement, 'top', `${offset.top}px`);\n      this.#renderer.setStyle(this.#affixedElement, 'left', `${offset.left}px`);\n\n      this.#offsetChange.next({ offset });\n    }\n  }\n\n  #getOffset(): SkyAffixOffset {\n    const parent = this.#getAutoFitContextParent();\n\n    const maxAttempts = 4;\n    let attempts = 0;\n\n    let isAffixedElementFullyVisible = false;\n    let offset: Required<SkyAffixOffset>;\n    let placement = this.#config.placement;\n\n    const autoFitOverflowOffset = this.#config.autoFitOverflowOffset || {\n      bottom: 0,\n      left: 0,\n      right: 0,\n      top: 0,\n    };\n\n    if (this.#config.position === 'absolute') {\n      const { top, left } = this.#viewportRuler.getViewportScrollPosition();\n      autoFitOverflowOffset.top = (autoFitOverflowOffset.top || 0) + top;\n      autoFitOverflowOffset.left = (autoFitOverflowOffset.left || 0) + left;\n      autoFitOverflowOffset.bottom = (autoFitOverflowOffset.bottom || 0) + top;\n      autoFitOverflowOffset.right = (autoFitOverflowOffset.right || 0) + left;\n    }\n\n    do {\n      offset = this.#getPreferredOffset(placement);\n      isAffixedElementFullyVisible = isOffsetFullyVisibleWithinParent(\n        parent,\n        offset,\n        autoFitOverflowOffset\n      );\n\n      if (!this.#config.enableAutoFit) {\n        break;\n      }\n\n      if (!isAffixedElementFullyVisible) {\n        placement =\n          attempts % 2 === 0\n            ? getInversePlacement(placement)\n            : getNextPlacement(placement);\n      }\n\n      attempts++;\n    } while (!isAffixedElementFullyVisible && attempts < maxAttempts);\n\n    if (isAffixedElementFullyVisible) {\n      if (this.#isBaseElementVisible()) {\n        this.#notifyPlacementChange(placement);\n      } else {\n        this.#notifyPlacementChange(null);\n      }\n\n      return offset;\n    }\n\n    if (this.#config.enableAutoFit) {\n      this.#notifyPlacementChange(null);\n    }\n\n    // No suitable placement was found, so revert to preferred placement.\n    return this.#getPreferredOffset(this.#config.placement);\n  }\n\n  #getRect(baseElement: HTMLElement): AffixRect {\n    const baseDomRect = baseElement.getBoundingClientRect();\n\n    const baseRect: AffixRect = {\n      top: baseDomRect.top,\n      bottom: baseDomRect.bottom,\n      left: baseDomRect.left,\n      right: baseDomRect.right,\n      width: baseDomRect.width,\n      height: baseDomRect.height,\n    };\n\n    if (this.#config.position === 'absolute') {\n      const { left, top } = this.#viewportRuler.getViewportScrollPosition();\n      baseRect.top += top;\n      baseRect.left += left;\n      baseRect.bottom += top;\n      baseRect.right += left;\n    }\n\n    return baseRect;\n  }\n\n  #getPreferredOffset(placement: SkyAffixPlacement): Required<SkyAffixOffset> {\n    if (!this.#baseElement) {\n      return { top: 0, left: 0, bottom: 0, right: 0 };\n    }\n\n    const affixedRect = this.#getRect(this.#affixedElement);\n    const baseRect = this.#getRect(this.#baseElement);\n\n    const horizontalAlignment = this.#config.horizontalAlignment;\n    const verticalAlignment = this.#config.verticalAlignment;\n    const enableAutoFit = this.#config.enableAutoFit;\n\n    let top: number;\n    let left: number;\n\n    if (placement === 'above' || placement === 'below') {\n      if (placement === 'above') {\n        top = baseRect.top - affixedRect.height;\n\n        switch (verticalAlignment) {\n          case 'top':\n            top = top + affixedRect.height;\n            break;\n          case 'middle':\n            top = top + affixedRect.height / 2;\n            break;\n          case 'bottom':\n          default:\n            break;\n        }\n      } else {\n        top = baseRect.bottom;\n\n        switch (verticalAlignment) {\n          case 'top':\n          default:\n            break;\n          case 'middle':\n            top = top - affixedRect.height / 2;\n            break;\n          case 'bottom':\n            top = top - affixedRect.height;\n            break;\n        }\n      }\n\n      switch (horizontalAlignment) {\n        case 'left':\n          left = baseRect.left;\n          break;\n\n        case 'center':\n        default:\n          left = baseRect.left + baseRect.width / 2 - affixedRect.width / 2;\n          break;\n\n        case 'right':\n          left = baseRect.right - affixedRect.width;\n          break;\n      }\n    } else {\n      if (placement === 'left') {\n        left = baseRect.left - affixedRect.width;\n      } else {\n        left = baseRect.right;\n      }\n\n      switch (verticalAlignment) {\n        case 'top':\n          top = baseRect.top;\n          break;\n\n        case 'middle':\n        default:\n          top = baseRect.top + baseRect.height / 2 - affixedRect.height / 2;\n          break;\n\n        case 'bottom':\n          top = baseRect.bottom - affixedRect.height;\n          break;\n      }\n    }\n\n    const offset: Required<SkyAffixOffset> = { top, left, bottom: 0, right: 0 };\n\n    if (enableAutoFit) {\n      const adjustments = this.#adjustOffsetToOverflowParent(\n        { top, left },\n        placement,\n        this.#baseElement\n      );\n      offset.top = adjustments.top;\n      offset.left = adjustments.left;\n    }\n\n    offset.bottom = offset.top + affixedRect.height;\n    offset.right = offset.left + affixedRect.width;\n\n    return offset;\n  }\n\n  /**\n   * Slightly adjust the offset to fit within the scroll parent's boundaries if\n   * the affixed element would otherwise be clipped.\n   */\n  #adjustOffsetToOverflowParent(\n    offset: { top: number; left: number },\n    placement: SkyAffixPlacement,\n    baseElement: HTMLElement\n  ): { top: number; left: number } {\n    const parent = this.#getAutoFitContextParent();\n    const parentOffset = getElementOffset(\n      parent,\n      this.#config.autoFitOverflowOffset\n    );\n\n    const affixedRect = this.#getRect(this.#affixedElement);\n    const baseRect = this.#getRect(baseElement);\n\n    // A pixel value representing the leeway between the edge of the overflow parent and the edge\n    // of the base element before it disappears from view.\n    // If the visible portion of the base element is less than this pixel value, the auto-fit\n    // functionality attempts to find another placement.\n    const defaultPixelTolerance = 40;\n    let pixelTolerance: number;\n\n    const originalOffsetTop = offset.top;\n    const originalOffsetLeft = offset.left;\n\n    switch (placement) {\n      case 'above':\n      case 'below':\n        // Keep the affixed element within the overflow parent.\n        if (offset.left < parentOffset.left) {\n          offset.left = parentOffset.left;\n        } else if (offset.left + affixedRect.width > parentOffset.right) {\n          offset.left = parentOffset.right - affixedRect.width;\n        }\n\n        // Use a smaller pixel tolerance if the base element width is less than the default.\n        pixelTolerance = Math.min(defaultPixelTolerance, baseRect.width);\n\n        // Make sure the affixed element never detaches from the base element.\n        if (\n          offset.left + pixelTolerance > baseRect.right ||\n          offset.left + affixedRect.width - pixelTolerance < baseRect.left\n        ) {\n          offset.left = originalOffsetLeft;\n        }\n\n        break;\n\n      case 'left':\n      case 'right':\n        // Keep the affixed element within the overflow parent.\n        if (offset.top < parentOffset.top) {\n          offset.top = parentOffset.top;\n        } else if (offset.top + affixedRect.height > parentOffset.bottom) {\n          offset.top = parentOffset.bottom - affixedRect.height;\n        }\n\n        // Use a smaller pixel tolerance if the base element height is less than the default.\n        pixelTolerance = Math.min(defaultPixelTolerance, baseRect.height);\n\n        // Make sure the affixed element never detaches from the base element.\n        if (\n          offset.top + pixelTolerance > baseRect.bottom ||\n          offset.top + affixedRect.height - pixelTolerance < baseRect.top\n        ) {\n          offset.top = originalOffsetTop;\n        }\n\n        break;\n    }\n\n    return offset;\n  }\n\n  #getImmediateOverflowParent(): HTMLElement {\n    return this.#overflowParents[this.#overflowParents.length - 1];\n  }\n\n  #getAutoFitContextParent(): HTMLElement {\n    const bodyElement = this.#overflowParents[0];\n\n    return this.#config.autoFitContext === SkyAffixAutoFitContext.OverflowParent\n      ? this.#getImmediateOverflowParent()\n      : bodyElement;\n  }\n\n  #notifyPlacementChange(placement: SkyAffixPlacement | null): void {\n    if (this.#currentPlacement !== placement) {\n      this.#currentPlacement = placement ?? undefined;\n      this.#placementChange.next({\n        placement,\n      });\n    }\n  }\n\n  #reset(): void {\n    this.#removeViewportListeners();\n\n    this.#overflowParents = [];\n\n    this.#config =\n      this.#baseElement =\n      this.#currentPlacement =\n      this.#currentOffset =\n        undefined;\n  }\n\n  #isNewOffset(offset: SkyAffixOffset): boolean {\n    if (this.#currentOffset === undefined) {\n      this.#currentOffset = offset;\n      return true;\n    }\n\n    if (\n      this.#currentOffset.top === offset.top &&\n      this.#currentOffset.left === offset.left\n    ) {\n      return false;\n    }\n\n    this.#currentOffset = offset;\n\n    return true;\n  }\n\n  #isBaseElementVisible(): boolean {\n    if (!this.#baseElement) {\n      return false;\n    }\n\n    const baseRect = this.#baseElement.getBoundingClientRect();\n\n    return isOffsetPartiallyVisibleWithinParent(\n      this.#getImmediateOverflowParent(),\n      {\n        top: baseRect.top,\n        left: baseRect.left,\n        right: baseRect.right,\n        bottom: baseRect.bottom,\n      },\n      this.#config.autoFitOverflowOffset\n    );\n  }\n\n  #addViewportListeners(): void {\n    this.#viewportListeners = new Subscription();\n\n    // Resize and orientation changes.\n    this.#viewportListeners.add(\n      this.#viewportRuler.change().subscribe(() => {\n        this.#affix();\n      })\n    );\n\n    this.#viewportListeners.add(\n      this.#scrollChange.subscribe(() => {\n        this.#affix();\n        this.#overflowScroll.next();\n      })\n    );\n\n    // Listen for scroll events on the window, visual viewport, and any overflow parents.\n    // https://developer.chrome.com/blog/visual-viewport-api/#events-only-fire-when-the-visual-viewport-changes\n    this.#zone.runOutsideAngular(() => {\n      [window, window.visualViewport, ...this.#overflowParents].forEach(\n        (parentElement) => {\n          parentElement?.addEventListener('scroll', this.#scrollChangeListener);\n        }\n      );\n    });\n  }\n\n  #removeViewportListeners(): void {\n    this.#viewportListeners?.unsubscribe();\n\n    this.#zone.runOutsideAngular(() => {\n      [window, window.visualViewport, ...this.#overflowParents].forEach(\n        (parentElement) => {\n          parentElement?.removeEventListener(\n            'scroll',\n            this.#scrollChangeListener\n          );\n        }\n      );\n    });\n  }\n}\n"]}
|
package/fesm2015/skyux-core.mjs
CHANGED
@@ -1,10 +1,11 @@
|
|
1
1
|
import * as i0 from '@angular/core';
|
2
|
-
import { NgModule, Injectable, EventEmitter, Directive, Input, Output, Injector, ViewContainerRef, Component, ChangeDetectionStrategy, ViewChild, createComponent,
|
2
|
+
import { NgModule, Injectable, inject, RendererFactory2, NgZone, EventEmitter, Directive, Input, Output, Injector, ViewContainerRef, Component, ChangeDetectionStrategy, ViewChild, createComponent, InjectionToken, Optional, Inject, Pipe, ElementRef, HostBinding } from '@angular/core';
|
3
3
|
import { __classPrivateFieldSet, __classPrivateFieldGet, __awaiter } from 'tslib';
|
4
4
|
import * as i5 from '@angular/common';
|
5
5
|
import { CommonModule, DOCUMENT } from '@angular/common';
|
6
|
-
import { Subject,
|
6
|
+
import { Subject, Subscription, ReplaySubject, fromEvent, BehaviorSubject, Observable, of, concat, animationFrameScheduler } from 'rxjs';
|
7
7
|
import { takeUntil, debounceTime, finalize, switchMap, map } from 'rxjs/operators';
|
8
|
+
import { ViewportRuler } from '@angular/cdk/overlay';
|
8
9
|
import * as i1 from '@skyux/i18n';
|
9
10
|
import { getLibStringForLocale, SkyI18nModule, SKY_LIB_RESOURCES_PROVIDERS, SkyIntlNumberFormatStyle, SkyIntlNumberFormatter } from '@skyux/i18n';
|
10
11
|
import * as i4 from '@angular/router';
|
@@ -375,7 +376,7 @@ function isOffsetPartiallyVisibleWithinParent(parent, offset, bufferOffset) {
|
|
375
376
|
parentOffset.left >= offset.right);
|
376
377
|
}
|
377
378
|
|
378
|
-
var _SkyAffixer_instances, _SkyAffixer_config_get, _SkyAffixer_config_set, _SkyAffixer_affixedElement, _SkyAffixer_baseElement, _SkyAffixer_currentOffset, _SkyAffixer_currentPlacement, _SkyAffixer_offsetChange, _SkyAffixer_offsetChangeObs, _SkyAffixer_overflowParents, _SkyAffixer_overflowScroll, _SkyAffixer_overflowScrollObs, _SkyAffixer_placementChange, _SkyAffixer_placementChangeObs, _SkyAffixer_renderer,
|
379
|
+
var _SkyAffixer_instances, _SkyAffixer_config_get, _SkyAffixer_config_set, _SkyAffixer_affixedElement, _SkyAffixer_baseElement, _SkyAffixer_currentOffset, _SkyAffixer_currentPlacement, _SkyAffixer_offsetChange, _SkyAffixer_offsetChangeObs, _SkyAffixer_overflowParents, _SkyAffixer_overflowScroll, _SkyAffixer_overflowScrollObs, _SkyAffixer_placementChange, _SkyAffixer_placementChangeObs, _SkyAffixer_renderer, _SkyAffixer_scrollChange, _SkyAffixer_viewportListeners, _SkyAffixer_viewportRuler, _SkyAffixer_zone, _SkyAffixer__config, _SkyAffixer_scrollChangeListener, _SkyAffixer_affix, _SkyAffixer_getOffset, _SkyAffixer_getRect, _SkyAffixer_getPreferredOffset, _SkyAffixer_adjustOffsetToOverflowParent, _SkyAffixer_getImmediateOverflowParent, _SkyAffixer_getAutoFitContextParent, _SkyAffixer_notifyPlacementChange, _SkyAffixer_reset, _SkyAffixer_isNewOffset, _SkyAffixer_isBaseElementVisible, _SkyAffixer_addViewportListeners, _SkyAffixer_removeViewportListeners;
|
379
380
|
const DEFAULT_AFFIX_CONFIG = {
|
380
381
|
autoFitContext: SkyAffixAutoFitContext.OverflowParent,
|
381
382
|
enableAutoFit: false,
|
@@ -405,7 +406,7 @@ class SkyAffixer {
|
|
405
406
|
get placementChange() {
|
406
407
|
return __classPrivateFieldGet(this, _SkyAffixer_placementChangeObs, "f");
|
407
408
|
}
|
408
|
-
constructor(affixedElement, renderer) {
|
409
|
+
constructor(affixedElement, renderer, viewportRuler, zone) {
|
409
410
|
_SkyAffixer_instances.add(this);
|
410
411
|
_SkyAffixer_affixedElement.set(this, void 0);
|
411
412
|
_SkyAffixer_baseElement.set(this, void 0);
|
@@ -419,11 +420,16 @@ class SkyAffixer {
|
|
419
420
|
_SkyAffixer_placementChange.set(this, void 0);
|
420
421
|
_SkyAffixer_placementChangeObs.set(this, void 0);
|
421
422
|
_SkyAffixer_renderer.set(this, void 0);
|
422
|
-
|
423
|
-
|
423
|
+
_SkyAffixer_scrollChange.set(this, new Subject());
|
424
|
+
_SkyAffixer_viewportListeners.set(this, void 0);
|
425
|
+
_SkyAffixer_viewportRuler.set(this, void 0);
|
426
|
+
_SkyAffixer_zone.set(this, void 0);
|
424
427
|
_SkyAffixer__config.set(this, DEFAULT_AFFIX_CONFIG);
|
428
|
+
_SkyAffixer_scrollChangeListener.set(this, () => __classPrivateFieldGet(this, _SkyAffixer_scrollChange, "f").next());
|
425
429
|
__classPrivateFieldSet(this, _SkyAffixer_affixedElement, affixedElement, "f");
|
426
430
|
__classPrivateFieldSet(this, _SkyAffixer_renderer, renderer, "f");
|
431
|
+
__classPrivateFieldSet(this, _SkyAffixer_viewportRuler, viewportRuler, "f");
|
432
|
+
__classPrivateFieldSet(this, _SkyAffixer_zone, zone, "f");
|
427
433
|
__classPrivateFieldSet(this, _SkyAffixer_offsetChange, new Subject(), "f");
|
428
434
|
__classPrivateFieldSet(this, _SkyAffixer_overflowScroll, new Subject(), "f");
|
429
435
|
__classPrivateFieldSet(this, _SkyAffixer_placementChange, new Subject(), "f");
|
@@ -443,8 +449,7 @@ class SkyAffixer {
|
|
443
449
|
__classPrivateFieldSet(this, _SkyAffixer_overflowParents, getOverflowParents(baseElement), "f");
|
444
450
|
__classPrivateFieldGet(this, _SkyAffixer_instances, "m", _SkyAffixer_affix).call(this);
|
445
451
|
if (__classPrivateFieldGet(this, _SkyAffixer_instances, "a", _SkyAffixer_config_get).isSticky) {
|
446
|
-
__classPrivateFieldGet(this, _SkyAffixer_instances, "m",
|
447
|
-
__classPrivateFieldGet(this, _SkyAffixer_instances, "m", _SkyAffixer_addResizeListener).call(this);
|
452
|
+
__classPrivateFieldGet(this, _SkyAffixer_instances, "m", _SkyAffixer_addViewportListeners).call(this);
|
448
453
|
}
|
449
454
|
}
|
450
455
|
getConfig() {
|
@@ -466,9 +471,10 @@ class SkyAffixer {
|
|
466
471
|
__classPrivateFieldGet(this, _SkyAffixer_placementChange, "f").complete();
|
467
472
|
__classPrivateFieldGet(this, _SkyAffixer_offsetChange, "f").complete();
|
468
473
|
__classPrivateFieldGet(this, _SkyAffixer_overflowScroll, "f").complete();
|
474
|
+
__classPrivateFieldGet(this, _SkyAffixer_scrollChange, "f").complete();
|
469
475
|
}
|
470
476
|
}
|
471
|
-
_SkyAffixer_affixedElement = new WeakMap(), _SkyAffixer_baseElement = new WeakMap(), _SkyAffixer_currentOffset = new WeakMap(), _SkyAffixer_currentPlacement = new WeakMap(), _SkyAffixer_offsetChange = new WeakMap(), _SkyAffixer_offsetChangeObs = new WeakMap(), _SkyAffixer_overflowParents = new WeakMap(), _SkyAffixer_overflowScroll = new WeakMap(), _SkyAffixer_overflowScrollObs = new WeakMap(), _SkyAffixer_placementChange = new WeakMap(), _SkyAffixer_placementChangeObs = new WeakMap(), _SkyAffixer_renderer = new WeakMap(),
|
477
|
+
_SkyAffixer_affixedElement = new WeakMap(), _SkyAffixer_baseElement = new WeakMap(), _SkyAffixer_currentOffset = new WeakMap(), _SkyAffixer_currentPlacement = new WeakMap(), _SkyAffixer_offsetChange = new WeakMap(), _SkyAffixer_offsetChangeObs = new WeakMap(), _SkyAffixer_overflowParents = new WeakMap(), _SkyAffixer_overflowScroll = new WeakMap(), _SkyAffixer_overflowScrollObs = new WeakMap(), _SkyAffixer_placementChange = new WeakMap(), _SkyAffixer_placementChangeObs = new WeakMap(), _SkyAffixer_renderer = new WeakMap(), _SkyAffixer_scrollChange = new WeakMap(), _SkyAffixer_viewportListeners = new WeakMap(), _SkyAffixer_viewportRuler = new WeakMap(), _SkyAffixer_zone = new WeakMap(), _SkyAffixer__config = new WeakMap(), _SkyAffixer_scrollChangeListener = new WeakMap(), _SkyAffixer_instances = new WeakSet(), _SkyAffixer_config_get = function _SkyAffixer_config_get() {
|
472
478
|
return __classPrivateFieldGet(this, _SkyAffixer__config, "f");
|
473
479
|
}, _SkyAffixer_config_set = function _SkyAffixer_config_set(value) {
|
474
480
|
const merged = Object.assign(Object.assign({}, DEFAULT_AFFIX_CONFIG), value);
|
@@ -501,8 +507,11 @@ _SkyAffixer_affixedElement = new WeakMap(), _SkyAffixer_baseElement = new WeakMa
|
|
501
507
|
top: 0,
|
502
508
|
};
|
503
509
|
if (__classPrivateFieldGet(this, _SkyAffixer_instances, "a", _SkyAffixer_config_get).position === 'absolute') {
|
504
|
-
|
505
|
-
|
510
|
+
const { top, left } = __classPrivateFieldGet(this, _SkyAffixer_viewportRuler, "f").getViewportScrollPosition();
|
511
|
+
autoFitOverflowOffset.top = (autoFitOverflowOffset.top || 0) + top;
|
512
|
+
autoFitOverflowOffset.left = (autoFitOverflowOffset.left || 0) + left;
|
513
|
+
autoFitOverflowOffset.bottom = (autoFitOverflowOffset.bottom || 0) + top;
|
514
|
+
autoFitOverflowOffset.right = (autoFitOverflowOffset.right || 0) + left;
|
506
515
|
}
|
507
516
|
do {
|
508
517
|
offset = __classPrivateFieldGet(this, _SkyAffixer_instances, "m", _SkyAffixer_getPreferredOffset).call(this, placement);
|
@@ -543,8 +552,11 @@ _SkyAffixer_affixedElement = new WeakMap(), _SkyAffixer_baseElement = new WeakMa
|
|
543
552
|
height: baseDomRect.height,
|
544
553
|
};
|
545
554
|
if (__classPrivateFieldGet(this, _SkyAffixer_instances, "a", _SkyAffixer_config_get).position === 'absolute') {
|
546
|
-
|
547
|
-
baseRect.
|
555
|
+
const { left, top } = __classPrivateFieldGet(this, _SkyAffixer_viewportRuler, "f").getViewportScrollPosition();
|
556
|
+
baseRect.top += top;
|
557
|
+
baseRect.left += left;
|
558
|
+
baseRect.bottom += top;
|
559
|
+
baseRect.right += left;
|
548
560
|
}
|
549
561
|
return baseRect;
|
550
562
|
}, _SkyAffixer_getPreferredOffset = function _SkyAffixer_getPreferredOffset(placement) {
|
@@ -694,8 +706,7 @@ _SkyAffixer_affixedElement = new WeakMap(), _SkyAffixer_baseElement = new WeakMa
|
|
694
706
|
});
|
695
707
|
}
|
696
708
|
}, _SkyAffixer_reset = function _SkyAffixer_reset() {
|
697
|
-
__classPrivateFieldGet(this, _SkyAffixer_instances, "m",
|
698
|
-
__classPrivateFieldGet(this, _SkyAffixer_instances, "m", _SkyAffixer_removeResizeListener).call(this);
|
709
|
+
__classPrivateFieldGet(this, _SkyAffixer_instances, "m", _SkyAffixer_removeViewportListeners).call(this);
|
699
710
|
__classPrivateFieldSet(this, _SkyAffixer_overflowParents, [], "f");
|
700
711
|
__classPrivateFieldSet(this, _SkyAffixer_instances, __classPrivateFieldSet(this, _SkyAffixer_baseElement, __classPrivateFieldSet(this, _SkyAffixer_currentPlacement, __classPrivateFieldSet(this, _SkyAffixer_currentOffset, undefined, "f"), "f"), "f"), "a", _SkyAffixer_config_set);
|
701
712
|
}, _SkyAffixer_isNewOffset = function _SkyAffixer_isNewOffset(offset) {
|
@@ -720,53 +731,57 @@ _SkyAffixer_affixedElement = new WeakMap(), _SkyAffixer_baseElement = new WeakMa
|
|
720
731
|
right: baseRect.right,
|
721
732
|
bottom: baseRect.bottom,
|
722
733
|
}, __classPrivateFieldGet(this, _SkyAffixer_instances, "a", _SkyAffixer_config_get).autoFitOverflowOffset);
|
723
|
-
},
|
724
|
-
__classPrivateFieldSet(this,
|
725
|
-
|
726
|
-
|
727
|
-
|
728
|
-
|
734
|
+
}, _SkyAffixer_addViewportListeners = function _SkyAffixer_addViewportListeners() {
|
735
|
+
__classPrivateFieldSet(this, _SkyAffixer_viewportListeners, new Subscription(), "f");
|
736
|
+
// Resize and orientation changes.
|
737
|
+
__classPrivateFieldGet(this, _SkyAffixer_viewportListeners, "f").add(__classPrivateFieldGet(this, _SkyAffixer_viewportRuler, "f").change().subscribe(() => {
|
738
|
+
__classPrivateFieldGet(this, _SkyAffixer_instances, "m", _SkyAffixer_affix).call(this);
|
739
|
+
}));
|
740
|
+
__classPrivateFieldGet(this, _SkyAffixer_viewportListeners, "f").add(__classPrivateFieldGet(this, _SkyAffixer_scrollChange, "f").subscribe(() => {
|
741
|
+
__classPrivateFieldGet(this, _SkyAffixer_instances, "m", _SkyAffixer_affix).call(this);
|
742
|
+
__classPrivateFieldGet(this, _SkyAffixer_overflowScroll, "f").next();
|
743
|
+
}));
|
744
|
+
// Listen for scroll events on the window, visual viewport, and any overflow parents.
|
745
|
+
// https://developer.chrome.com/blog/visual-viewport-api/#events-only-fire-when-the-visual-viewport-changes
|
746
|
+
__classPrivateFieldGet(this, _SkyAffixer_zone, "f").runOutsideAngular(() => {
|
747
|
+
[window, window.visualViewport, ...__classPrivateFieldGet(this, _SkyAffixer_overflowParents, "f")].forEach((parentElement) => {
|
748
|
+
parentElement === null || parentElement === void 0 ? void 0 : parentElement.addEventListener('scroll', __classPrivateFieldGet(this, _SkyAffixer_scrollChangeListener, "f"));
|
729
749
|
});
|
730
|
-
})
|
731
|
-
},
|
732
|
-
|
733
|
-
|
734
|
-
|
735
|
-
__classPrivateFieldGet(this,
|
736
|
-
|
737
|
-
|
738
|
-
}
|
739
|
-
if (__classPrivateFieldGet(this, _SkyAffixer_scrollListeners, "f")) {
|
740
|
-
// Remove renderer-generated listeners by calling the listener itself.
|
741
|
-
// https://github.com/angular/angular/issues/9368#issuecomment-227199778
|
742
|
-
__classPrivateFieldGet(this, _SkyAffixer_scrollListeners, "f").forEach((listener) => listener());
|
743
|
-
__classPrivateFieldSet(this, _SkyAffixer_scrollListeners, undefined, "f");
|
744
|
-
}
|
750
|
+
});
|
751
|
+
}, _SkyAffixer_removeViewportListeners = function _SkyAffixer_removeViewportListeners() {
|
752
|
+
var _a;
|
753
|
+
(_a = __classPrivateFieldGet(this, _SkyAffixer_viewportListeners, "f")) === null || _a === void 0 ? void 0 : _a.unsubscribe();
|
754
|
+
__classPrivateFieldGet(this, _SkyAffixer_zone, "f").runOutsideAngular(() => {
|
755
|
+
[window, window.visualViewport, ...__classPrivateFieldGet(this, _SkyAffixer_overflowParents, "f")].forEach((parentElement) => {
|
756
|
+
parentElement === null || parentElement === void 0 ? void 0 : parentElement.removeEventListener('scroll', __classPrivateFieldGet(this, _SkyAffixer_scrollChangeListener, "f"));
|
757
|
+
});
|
758
|
+
});
|
745
759
|
};
|
746
760
|
|
747
|
-
var _SkyAffixService_renderer;
|
761
|
+
var _SkyAffixService_renderer, _SkyAffixService_viewportRuler, _SkyAffixService_zone;
|
748
762
|
class SkyAffixService {
|
749
|
-
constructor(
|
750
|
-
_SkyAffixService_renderer.set(this,
|
751
|
-
|
763
|
+
constructor() {
|
764
|
+
_SkyAffixService_renderer.set(this, inject(RendererFactory2).createRenderer(undefined, null));
|
765
|
+
_SkyAffixService_viewportRuler.set(this, inject(ViewportRuler));
|
766
|
+
_SkyAffixService_zone.set(this, inject(NgZone));
|
752
767
|
}
|
753
768
|
/**
|
754
769
|
* Creates an instance of [[SkyAffixer]].
|
755
770
|
* @param affixed The element to be affixed.
|
756
771
|
*/
|
757
772
|
createAffixer(affixed) {
|
758
|
-
return new SkyAffixer(affixed.nativeElement, __classPrivateFieldGet(this, _SkyAffixService_renderer, "f"));
|
773
|
+
return new SkyAffixer(affixed.nativeElement, __classPrivateFieldGet(this, _SkyAffixService_renderer, "f"), __classPrivateFieldGet(this, _SkyAffixService_viewportRuler, "f"), __classPrivateFieldGet(this, _SkyAffixService_zone, "f"));
|
759
774
|
}
|
760
775
|
}
|
761
|
-
_SkyAffixService_renderer = new WeakMap();
|
762
|
-
SkyAffixService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SkyAffixService, deps: [
|
776
|
+
_SkyAffixService_renderer = new WeakMap(), _SkyAffixService_viewportRuler = new WeakMap(), _SkyAffixService_zone = new WeakMap();
|
777
|
+
SkyAffixService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SkyAffixService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
763
778
|
SkyAffixService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SkyAffixService, providedIn: 'root' });
|
764
779
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SkyAffixService, decorators: [{
|
765
780
|
type: Injectable,
|
766
781
|
args: [{
|
767
782
|
providedIn: 'root',
|
768
783
|
}]
|
769
|
-
}]
|
784
|
+
}] });
|
770
785
|
|
771
786
|
var _SkyAffixDirective_instances, _SkyAffixDirective_affixer, _SkyAffixDirective_affixService, _SkyAffixDirective_elementRef, _SkyAffixDirective_ngUnsubscribe, _SkyAffixDirective_updateAlignment;
|
772
787
|
/**
|