@skyux/core 6.15.0 → 6.17.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/documentation.json +1042 -892
- package/esm2020/lib/modules/adapter-service/adapter.service.mjs +21 -22
- package/esm2020/lib/modules/affix/affix-offset.mjs +1 -1
- package/esm2020/lib/modules/affix/affix.directive.mjs +38 -23
- package/esm2020/lib/modules/affix/affixer.mjs +266 -260
- package/esm2020/lib/modules/affix/dom-utils.mjs +7 -7
- package/esm2020/lib/modules/dock/dock-dom-adapter.service.mjs +48 -44
- package/esm2020/lib/modules/dock/dock-item.mjs +10 -5
- package/esm2020/lib/modules/dock/dock.component.mjs +55 -31
- package/esm2020/lib/modules/dock/dock.service.mjs +40 -36
- package/esm2020/lib/modules/dynamic-component/dynamic-component.service.mjs +37 -22
- package/esm2020/lib/modules/log/log.service.mjs +37 -37
- package/esm2020/lib/modules/media-query/media-query.service.mjs +50 -47
- package/esm2020/lib/modules/mutation/mutation-observer-service.mjs +3 -1
- package/esm2020/lib/modules/numeric/numeric.pipe.mjs +26 -19
- package/esm2020/lib/modules/numeric/numeric.service.mjs +84 -99
- package/esm2020/lib/modules/overlay/overlay-adapter.service.mjs +23 -17
- package/esm2020/lib/modules/overlay/overlay-instance.mjs +18 -9
- package/esm2020/lib/modules/overlay/overlay.component.mjs +79 -55
- package/esm2020/lib/modules/overlay/overlay.service.mjs +55 -49
- package/esm2020/lib/modules/percent-pipe/percent.pipe.mjs +32 -21
- package/esm2020/lib/modules/resize-observer/resize-observer-media-query.service.mjs +38 -46
- package/esm2020/lib/modules/scrollable-host/scrollable-host.service.mjs +66 -67
- package/esm2020/lib/modules/title/title.service.mjs +8 -4
- package/esm2020/lib/modules/trim/trim.directive.mjs +10 -11
- package/esm2020/lib/modules/viewkeeper/viewkeeper-boundary-info.mjs +1 -1
- package/esm2020/lib/modules/viewkeeper/viewkeeper.directive.mjs +75 -60
- package/esm2020/lib/modules/viewkeeper/viewkeeper.mjs +166 -156
- package/esm2020/lib/modules/viewkeeper/viewkeeper.service.mjs +7 -3
- package/esm2020/testing/core-testing.module.mjs +4 -1
- package/esm2020/testing/mock-media-query.service.mjs +4 -1
- package/esm2020/testing/mock-ui-config.service.mjs +4 -1
- package/esm2020/testing/overlay/overlay-harness-filters.mjs +1 -1
- package/esm2020/testing/overlay/overlay-harness.mjs +2 -1
- package/esm2020/testing/shared/component-harness.mjs +4 -1
- package/esm2020/testing/shared/harness-filters.mjs +1 -1
- package/fesm2015/skyux-core-testing.mjs +13 -0
- package/fesm2015/skyux-core-testing.mjs.map +1 -1
- package/fesm2015/skyux-core.mjs +1276 -1151
- package/fesm2015/skyux-core.mjs.map +1 -1
- package/fesm2020/skyux-core-testing.mjs +13 -0
- package/fesm2020/skyux-core-testing.mjs.map +1 -1
- package/fesm2020/skyux-core.mjs +1278 -1150
- package/fesm2020/skyux-core.mjs.map +1 -1
- package/lib/modules/adapter-service/adapter.service.d.ts +3 -5
- package/lib/modules/affix/affix-offset.d.ts +1 -1
- package/lib/modules/affix/affix.directive.d.ts +12 -13
- package/lib/modules/affix/affixer.d.ts +2 -34
- package/lib/modules/affix/dom-utils.d.ts +3 -3
- package/lib/modules/dock/dock-dom-adapter.service.d.ts +2 -9
- package/lib/modules/dock/dock-item.d.ts +1 -1
- package/lib/modules/dock/dock.component.d.ts +2 -10
- package/lib/modules/dock/dock.service.d.ts +2 -5
- package/lib/modules/dynamic-component/dynamic-component.service.d.ts +2 -7
- package/lib/modules/log/log.service.d.ts +2 -6
- package/lib/modules/media-query/media-query.service.d.ts +1 -8
- package/lib/modules/numeric/numeric.pipe.d.ts +2 -8
- package/lib/modules/numeric/numeric.service.d.ts +3 -36
- package/lib/modules/overlay/overlay-adapter.service.d.ts +1 -3
- package/lib/modules/overlay/overlay-instance.d.ts +1 -2
- package/lib/modules/overlay/overlay.component.d.ts +1 -14
- package/lib/modules/overlay/overlay.service.d.ts +1 -7
- package/lib/modules/percent-pipe/percent.pipe.d.ts +2 -9
- package/lib/modules/resize-observer/resize-observer-media-query.service.d.ts +2 -7
- package/lib/modules/scrollable-host/scrollable-host.service.d.ts +2 -11
- package/lib/modules/title/title.service.d.ts +2 -2
- package/lib/modules/trim/trim.directive.d.ts +0 -2
- package/lib/modules/viewkeeper/viewkeeper-boundary-info.d.ts +1 -1
- package/lib/modules/viewkeeper/viewkeeper.d.ts +2 -24
- package/lib/modules/viewkeeper/viewkeeper.directive.d.ts +4 -16
- package/lib/modules/viewkeeper/viewkeeper.service.d.ts +1 -1
- package/package.json +2 -2
- package/testing/core-testing.module.d.ts +3 -0
- package/testing/mock-media-query.service.d.ts +3 -0
- package/testing/mock-ui-config.service.d.ts +3 -0
- package/testing/overlay/overlay-harness-filters.d.ts +1 -0
- package/testing/overlay/overlay-harness.d.ts +1 -0
- package/testing/shared/component-harness.d.ts +3 -0
- package/testing/shared/harness-filters.d.ts +1 -0
@@ -1,3 +1,5 @@
|
|
1
|
+
var _SkyPercentPipe_instances, _SkyPercentPipe_defaultFormat, _SkyPercentPipe_defaultLocale, _SkyPercentPipe_format, _SkyPercentPipe_formattedValue, _SkyPercentPipe_locale, _SkyPercentPipe_ngUnsubscribe, _SkyPercentPipe_value, _SkyPercentPipe_updateFormattedValue;
|
2
|
+
import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
|
1
3
|
import { Pipe } from '@angular/core';
|
2
4
|
import { SkyAppLocaleProvider, SkyIntlNumberFormatStyle } from '@skyux/i18n';
|
3
5
|
import { Subject } from 'rxjs';
|
@@ -7,35 +9,44 @@ import * as i0 from "@angular/core";
|
|
7
9
|
import * as i1 from "@skyux/i18n";
|
8
10
|
export class SkyPercentPipe {
|
9
11
|
constructor(localeProvider) {
|
10
|
-
this
|
11
|
-
this
|
12
|
-
this
|
13
|
-
this
|
14
|
-
this
|
12
|
+
_SkyPercentPipe_instances.add(this);
|
13
|
+
_SkyPercentPipe_defaultFormat.set(this, '1.0-2');
|
14
|
+
_SkyPercentPipe_defaultLocale.set(this, 'en-US');
|
15
|
+
_SkyPercentPipe_format.set(this, void 0);
|
16
|
+
_SkyPercentPipe_formattedValue.set(this, '');
|
17
|
+
_SkyPercentPipe_locale.set(this, void 0);
|
18
|
+
_SkyPercentPipe_ngUnsubscribe.set(this, new Subject());
|
19
|
+
_SkyPercentPipe_value.set(this, void 0);
|
20
|
+
localeProvider
|
15
21
|
.getLocaleInfo()
|
16
|
-
.pipe(takeUntil(this
|
22
|
+
.pipe(takeUntil(__classPrivateFieldGet(this, _SkyPercentPipe_ngUnsubscribe, "f")))
|
17
23
|
.subscribe((localeInfo) => {
|
18
|
-
this
|
19
|
-
this.
|
24
|
+
__classPrivateFieldSet(this, _SkyPercentPipe_defaultLocale, localeInfo.locale, "f");
|
25
|
+
__classPrivateFieldGet(this, _SkyPercentPipe_instances, "m", _SkyPercentPipe_updateFormattedValue).call(this);
|
20
26
|
});
|
21
27
|
}
|
28
|
+
get defaultLocale() {
|
29
|
+
return __classPrivateFieldGet(this, _SkyPercentPipe_defaultLocale, "f");
|
30
|
+
}
|
22
31
|
ngOnDestroy() {
|
23
|
-
this.
|
24
|
-
this.
|
32
|
+
__classPrivateFieldGet(this, _SkyPercentPipe_ngUnsubscribe, "f").next();
|
33
|
+
__classPrivateFieldGet(this, _SkyPercentPipe_ngUnsubscribe, "f").complete();
|
25
34
|
}
|
26
35
|
transform(value, format, locale) {
|
27
|
-
this
|
28
|
-
this
|
29
|
-
this
|
30
|
-
this.
|
31
|
-
return this
|
32
|
-
}
|
33
|
-
updateFormattedValue() {
|
34
|
-
const locale = this.locale || this.defaultLocale;
|
35
|
-
const format = this.format || this.defaultFormat;
|
36
|
-
this.formattedValue = SkyNumberFormatUtility.formatNumber(locale, this.value, SkyIntlNumberFormatStyle.Percent, format);
|
36
|
+
__classPrivateFieldSet(this, _SkyPercentPipe_value, value, "f");
|
37
|
+
__classPrivateFieldSet(this, _SkyPercentPipe_format, format, "f");
|
38
|
+
__classPrivateFieldSet(this, _SkyPercentPipe_locale, locale, "f");
|
39
|
+
__classPrivateFieldGet(this, _SkyPercentPipe_instances, "m", _SkyPercentPipe_updateFormattedValue).call(this);
|
40
|
+
return __classPrivateFieldGet(this, _SkyPercentPipe_formattedValue, "f");
|
37
41
|
}
|
38
42
|
}
|
43
|
+
_SkyPercentPipe_defaultFormat = new WeakMap(), _SkyPercentPipe_defaultLocale = new WeakMap(), _SkyPercentPipe_format = new WeakMap(), _SkyPercentPipe_formattedValue = new WeakMap(), _SkyPercentPipe_locale = new WeakMap(), _SkyPercentPipe_ngUnsubscribe = new WeakMap(), _SkyPercentPipe_value = new WeakMap(), _SkyPercentPipe_instances = new WeakSet(), _SkyPercentPipe_updateFormattedValue = function _SkyPercentPipe_updateFormattedValue() {
|
44
|
+
const locale = __classPrivateFieldGet(this, _SkyPercentPipe_locale, "f") || __classPrivateFieldGet(this, _SkyPercentPipe_defaultLocale, "f");
|
45
|
+
const format = __classPrivateFieldGet(this, _SkyPercentPipe_format, "f") || __classPrivateFieldGet(this, _SkyPercentPipe_defaultFormat, "f");
|
46
|
+
__classPrivateFieldSet(this, _SkyPercentPipe_formattedValue, __classPrivateFieldGet(this, _SkyPercentPipe_value, "f")
|
47
|
+
? SkyNumberFormatUtility.formatNumber(locale, __classPrivateFieldGet(this, _SkyPercentPipe_value, "f"), SkyIntlNumberFormatStyle.Percent, format)
|
48
|
+
: '', "f");
|
49
|
+
};
|
39
50
|
SkyPercentPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyPercentPipe, deps: [{ token: i1.SkyAppLocaleProvider }], target: i0.ɵɵFactoryTarget.Pipe });
|
40
51
|
SkyPercentPipe.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyPercentPipe, name: "skyPercent", pure: false });
|
41
52
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyPercentPipe, decorators: [{
|
@@ -45,4 +56,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImpor
|
|
45
56
|
pure: false,
|
46
57
|
}]
|
47
58
|
}], ctorParameters: function () { return [{ type: i1.SkyAppLocaleProvider }]; } });
|
48
|
-
//# sourceMappingURL=data:application/json;base64,
|
59
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGVyY2VudC5waXBlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL2NvcmUvc3JjL2xpYi9tb2R1bGVzL3BlcmNlbnQtcGlwZS9wZXJjZW50LnBpcGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSxPQUFPLEVBQWEsSUFBSSxFQUFpQixNQUFNLGVBQWUsQ0FBQztBQUMvRCxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFFN0UsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUMvQixPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFFM0MsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sK0NBQStDLENBQUM7OztBQU12RixNQUFNLE9BQU8sY0FBYztJQW1CekIsWUFBWSxjQUFvQzs7UUFkaEQsd0NBQWlCLE9BQU8sRUFBQztRQUV6Qix3Q0FBaUIsT0FBTyxFQUFDO1FBRXpCLHlDQUE0QjtRQUU1Qix5Q0FBa0IsRUFBRSxFQUFDO1FBRXJCLHlDQUE0QjtRQUU1Qix3Q0FBaUIsSUFBSSxPQUFPLEVBQVEsRUFBQztRQUVyQyx3Q0FBMkI7UUFHekIsY0FBYzthQUNYLGFBQWEsRUFBRTthQUNmLElBQUksQ0FBQyxTQUFTLENBQUMsdUJBQUEsSUFBSSxxQ0FBZSxDQUFDLENBQUM7YUFDcEMsU0FBUyxDQUFDLENBQUMsVUFBVSxFQUFFLEVBQUU7WUFDeEIsdUJBQUEsSUFBSSxpQ0FBa0IsVUFBVSxDQUFDLE1BQU0sTUFBQSxDQUFDO1lBQ3hDLHVCQUFBLElBQUksdUVBQXNCLE1BQTFCLElBQUksQ0FBd0IsQ0FBQztRQUMvQixDQUFDLENBQUMsQ0FBQztJQUNQLENBQUM7SUExQkQsSUFBVyxhQUFhO1FBQ3RCLE9BQU8sdUJBQUEsSUFBSSxxQ0FBZSxDQUFDO0lBQzdCLENBQUM7SUEwQk0sV0FBVztRQUNoQix1QkFBQSxJQUFJLHFDQUFlLENBQUMsSUFBSSxFQUFFLENBQUM7UUFDM0IsdUJBQUEsSUFBSSxxQ0FBZSxDQUFDLFFBQVEsRUFBRSxDQUFDO0lBQ2pDLENBQUM7SUFFTSxTQUFTLENBQUMsS0FBYSxFQUFFLE1BQWUsRUFBRSxNQUFlO1FBQzlELHVCQUFBLElBQUkseUJBQVUsS0FBSyxNQUFBLENBQUM7UUFDcEIsdUJBQUEsSUFBSSwwQkFBVyxNQUFNLE1BQUEsQ0FBQztRQUN0Qix1QkFBQSxJQUFJLDBCQUFXLE1BQU0sTUFBQSxDQUFDO1FBRXRCLHVCQUFBLElBQUksdUVBQXNCLE1BQTFCLElBQUksQ0FBd0IsQ0FBQztRQUU3QixPQUFPLHVCQUFBLElBQUksc0NBQWdCLENBQUM7SUFDOUIsQ0FBQzs7O0lBR0MsTUFBTSxNQUFNLEdBQUcsdUJBQUEsSUFBSSw4QkFBUSxJQUFJLHVCQUFBLElBQUkscUNBQWUsQ0FBQztJQUNuRCxNQUFNLE1BQU0sR0FBRyx1QkFBQSxJQUFJLDhCQUFRLElBQUksdUJBQUEsSUFBSSxxQ0FBZSxDQUFDO0lBRW5ELHVCQUFBLElBQUksa0NBQW1CLHVCQUFBLElBQUksNkJBQU87UUFDaEMsQ0FBQyxDQUFFLHNCQUFzQixDQUFDLFlBQVksQ0FDbEMsTUFBTSxFQUNOLHVCQUFBLElBQUksNkJBQU8sRUFDWCx3QkFBd0IsQ0FBQyxPQUFPLEVBQ2hDLE1BQU0sQ0FDSTtRQUNkLENBQUMsQ0FBQyxFQUFFLE1BQUEsQ0FBQztBQUNULENBQUM7MkdBeERVLGNBQWM7eUdBQWQsY0FBYzsyRkFBZCxjQUFjO2tCQUoxQixJQUFJO21CQUFDO29CQUNKLElBQUksRUFBRSxZQUFZO29CQUNsQixJQUFJLEVBQUUsS0FBSztpQkFDWiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE9uRGVzdHJveSwgUGlwZSwgUGlwZVRyYW5zZm9ybSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgU2t5QXBwTG9jYWxlUHJvdmlkZXIsIFNreUludGxOdW1iZXJGb3JtYXRTdHlsZSB9IGZyb20gJ0Bza3l1eC9pMThuJztcblxuaW1wb3J0IHsgU3ViamVjdCB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgdGFrZVVudGlsIH0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xuXG5pbXBvcnQgeyBTa3lOdW1iZXJGb3JtYXRVdGlsaXR5IH0gZnJvbSAnLi4vc2hhcmVkL251bWJlci1mb3JtYXQvbnVtYmVyLWZvcm1hdC11dGlsaXR5JztcblxuQFBpcGUoe1xuICBuYW1lOiAnc2t5UGVyY2VudCcsXG4gIHB1cmU6IGZhbHNlLFxufSlcbmV4cG9ydCBjbGFzcyBTa3lQZXJjZW50UGlwZSBpbXBsZW1lbnRzIE9uRGVzdHJveSwgUGlwZVRyYW5zZm9ybSB7XG4gIHB1YmxpYyBnZXQgZGVmYXVsdExvY2FsZSgpOiBzdHJpbmcge1xuICAgIHJldHVybiB0aGlzLiNkZWZhdWx0TG9jYWxlO1xuICB9XG5cbiAgI2RlZmF1bHRGb3JtYXQgPSAnMS4wLTInO1xuXG4gICNkZWZhdWx0TG9jYWxlID0gJ2VuLVVTJztcblxuICAjZm9ybWF0OiBzdHJpbmcgfCB1bmRlZmluZWQ7XG5cbiAgI2Zvcm1hdHRlZFZhbHVlID0gJyc7XG5cbiAgI2xvY2FsZTogc3RyaW5nIHwgdW5kZWZpbmVkO1xuXG4gICNuZ1Vuc3Vic2NyaWJlID0gbmV3IFN1YmplY3Q8dm9pZD4oKTtcblxuICAjdmFsdWU6IHN0cmluZyB8IHVuZGVmaW5lZDtcblxuICBjb25zdHJ1Y3Rvcihsb2NhbGVQcm92aWRlcjogU2t5QXBwTG9jYWxlUHJvdmlkZXIpIHtcbiAgICBsb2NhbGVQcm92aWRlclxuICAgICAgLmdldExvY2FsZUluZm8oKVxuICAgICAgLnBpcGUodGFrZVVudGlsKHRoaXMuI25nVW5zdWJzY3JpYmUpKVxuICAgICAgLnN1YnNjcmliZSgobG9jYWxlSW5mbykgPT4ge1xuICAgICAgICB0aGlzLiNkZWZhdWx0TG9jYWxlID0gbG9jYWxlSW5mby5sb2NhbGU7XG4gICAgICAgIHRoaXMuI3VwZGF0ZUZvcm1hdHRlZFZhbHVlKCk7XG4gICAgICB9KTtcbiAgfVxuXG4gIHB1YmxpYyBuZ09uRGVzdHJveSgpOiB2b2lkIHtcbiAgICB0aGlzLiNuZ1Vuc3Vic2NyaWJlLm5leHQoKTtcbiAgICB0aGlzLiNuZ1Vuc3Vic2NyaWJlLmNvbXBsZXRlKCk7XG4gIH1cblxuICBwdWJsaWMgdHJhbnNmb3JtKHZhbHVlOiBzdHJpbmcsIGZvcm1hdD86IHN0cmluZywgbG9jYWxlPzogc3RyaW5nKTogc3RyaW5nIHtcbiAgICB0aGlzLiN2YWx1ZSA9IHZhbHVlO1xuICAgIHRoaXMuI2Zvcm1hdCA9IGZvcm1hdDtcbiAgICB0aGlzLiNsb2NhbGUgPSBsb2NhbGU7XG5cbiAgICB0aGlzLiN1cGRhdGVGb3JtYXR0ZWRWYWx1ZSgpO1xuXG4gICAgcmV0dXJuIHRoaXMuI2Zvcm1hdHRlZFZhbHVlO1xuICB9XG5cbiAgI3VwZGF0ZUZvcm1hdHRlZFZhbHVlKCk6IHZvaWQge1xuICAgIGNvbnN0IGxvY2FsZSA9IHRoaXMuI2xvY2FsZSB8fCB0aGlzLiNkZWZhdWx0TG9jYWxlO1xuICAgIGNvbnN0IGZvcm1hdCA9IHRoaXMuI2Zvcm1hdCB8fCB0aGlzLiNkZWZhdWx0Rm9ybWF0O1xuXG4gICAgdGhpcy4jZm9ybWF0dGVkVmFsdWUgPSB0aGlzLiN2YWx1ZVxuICAgICAgPyAoU2t5TnVtYmVyRm9ybWF0VXRpbGl0eS5mb3JtYXROdW1iZXIoXG4gICAgICAgICAgbG9jYWxlLFxuICAgICAgICAgIHRoaXMuI3ZhbHVlLFxuICAgICAgICAgIFNreUludGxOdW1iZXJGb3JtYXRTdHlsZS5QZXJjZW50LFxuICAgICAgICAgIGZvcm1hdFxuICAgICAgICApIGFzIHN0cmluZylcbiAgICAgIDogJyc7XG4gIH1cbn1cbiJdfQ==
|
@@ -1,4 +1,4 @@
|
|
1
|
-
var _SkyResizeObserverMediaQueryService_breakpoints,
|
1
|
+
var _SkyResizeObserverMediaQueryService_instances, _SkyResizeObserverMediaQueryService_breakpoints, _SkyResizeObserverMediaQueryService_currentBreakpoint, _SkyResizeObserverMediaQueryService_currentBreakpointObs, _SkyResizeObserverMediaQueryService_ngUnsubscribe, _SkyResizeObserverMediaQueryService_resizeObserverSvc, _SkyResizeObserverMediaQueryService_target, _SkyResizeObserverMediaQueryService_updateBreakpoint, _SkyResizeObserverMediaQueryService_checkBreakpoint, _SkyResizeObserverMediaQueryService_checkWidth;
|
2
2
|
import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
|
3
3
|
import { Injectable } from '@angular/core';
|
4
4
|
import { ReplaySubject, Subject } from 'rxjs';
|
@@ -7,12 +7,13 @@ import { SkyMediaBreakpoints } from '../media-query/media-breakpoints';
|
|
7
7
|
import { SkyResizeObserverService } from './resize-observer.service';
|
8
8
|
import * as i0 from "@angular/core";
|
9
9
|
import * as i1 from "./resize-observer.service";
|
10
|
+
const DEFAULT_BREAKPOINT = SkyMediaBreakpoints.md;
|
10
11
|
/**
|
11
12
|
* Acts like `SkyMediaQueryService` for a container element, emitting the same responsive breakpoints.
|
12
13
|
*/
|
13
14
|
export class SkyResizeObserverMediaQueryService {
|
14
|
-
constructor(
|
15
|
-
this
|
15
|
+
constructor(resizeObserverSvc) {
|
16
|
+
_SkyResizeObserverMediaQueryService_instances.add(this);
|
16
17
|
_SkyResizeObserverMediaQueryService_breakpoints.set(this, [
|
17
18
|
{
|
18
19
|
check: (width) => width > 0 && width <= 767,
|
@@ -31,25 +32,23 @@ export class SkyResizeObserverMediaQueryService {
|
|
31
32
|
name: SkyMediaBreakpoints.lg,
|
32
33
|
},
|
33
34
|
]);
|
34
|
-
|
35
|
-
|
35
|
+
_SkyResizeObserverMediaQueryService_currentBreakpoint.set(this, DEFAULT_BREAKPOINT);
|
36
|
+
_SkyResizeObserverMediaQueryService_currentBreakpointObs.set(this, new ReplaySubject(1));
|
37
|
+
_SkyResizeObserverMediaQueryService_ngUnsubscribe.set(this, new Subject());
|
38
|
+
_SkyResizeObserverMediaQueryService_resizeObserverSvc.set(this, void 0);
|
36
39
|
_SkyResizeObserverMediaQueryService_target.set(this, void 0);
|
37
|
-
|
38
|
-
__classPrivateFieldSet(this, _SkyResizeObserverMediaQueryService_target, undefined, "f");
|
39
|
-
this.updateBreakpoint(undefined);
|
40
|
-
});
|
40
|
+
__classPrivateFieldSet(this, _SkyResizeObserverMediaQueryService_resizeObserverSvc, resizeObserverSvc, "f");
|
41
41
|
}
|
42
42
|
/**
|
43
43
|
* Returns the current breakpoint.
|
44
44
|
*/
|
45
45
|
get current() {
|
46
|
-
return this
|
46
|
+
return __classPrivateFieldGet(this, _SkyResizeObserverMediaQueryService_currentBreakpoint, "f");
|
47
47
|
}
|
48
48
|
ngOnDestroy() {
|
49
|
-
|
50
|
-
this
|
51
|
-
__classPrivateFieldGet(this,
|
52
|
-
__classPrivateFieldGet(this, _SkyResizeObserverMediaQueryService_currentBreakpointObservable, "f").complete();
|
49
|
+
this.unobserve();
|
50
|
+
__classPrivateFieldSet(this, _SkyResizeObserverMediaQueryService_target, undefined, "f");
|
51
|
+
__classPrivateFieldGet(this, _SkyResizeObserverMediaQueryService_currentBreakpointObs, "f").complete();
|
53
52
|
}
|
54
53
|
/**
|
55
54
|
* @internal
|
@@ -66,18 +65,17 @@ export class SkyResizeObserverMediaQueryService {
|
|
66
65
|
if (__classPrivateFieldGet(this, _SkyResizeObserverMediaQueryService_target, "f") === element) {
|
67
66
|
return this;
|
68
67
|
}
|
69
|
-
|
68
|
+
this.unobserve();
|
70
69
|
}
|
71
70
|
__classPrivateFieldSet(this, _SkyResizeObserverMediaQueryService_target, element, "f");
|
72
|
-
this.
|
73
|
-
this
|
71
|
+
__classPrivateFieldGet(this, _SkyResizeObserverMediaQueryService_instances, "m", _SkyResizeObserverMediaQueryService_checkWidth).call(this, element);
|
72
|
+
__classPrivateFieldGet(this, _SkyResizeObserverMediaQueryService_resizeObserverSvc, "f")
|
74
73
|
.observe(element)
|
75
|
-
.pipe(takeUntil(__classPrivateFieldGet(this,
|
74
|
+
.pipe(takeUntil(__classPrivateFieldGet(this, _SkyResizeObserverMediaQueryService_ngUnsubscribe, "f")))
|
76
75
|
.subscribe((value) => {
|
77
|
-
const breakpoint = this.
|
78
|
-
|
79
|
-
|
80
|
-
this.updateBreakpoint(breakpoint);
|
76
|
+
const breakpoint = __classPrivateFieldGet(this, _SkyResizeObserverMediaQueryService_instances, "m", _SkyResizeObserverMediaQueryService_checkBreakpoint).call(this, value.contentRect.width);
|
77
|
+
if (breakpoint && breakpoint !== this.current) {
|
78
|
+
__classPrivateFieldGet(this, _SkyResizeObserverMediaQueryService_instances, "m", _SkyResizeObserverMediaQueryService_updateBreakpoint).call(this, breakpoint);
|
81
79
|
}
|
82
80
|
});
|
83
81
|
return this;
|
@@ -86,39 +84,33 @@ export class SkyResizeObserverMediaQueryService {
|
|
86
84
|
* Stop watching the container element.
|
87
85
|
*/
|
88
86
|
unobserve() {
|
89
|
-
__classPrivateFieldGet(this,
|
87
|
+
__classPrivateFieldGet(this, _SkyResizeObserverMediaQueryService_ngUnsubscribe, "f").next();
|
88
|
+
__classPrivateFieldGet(this, _SkyResizeObserverMediaQueryService_ngUnsubscribe, "f").complete();
|
90
89
|
}
|
91
90
|
/**
|
92
91
|
* Subscribes to element size changes that cross breakpoints.
|
93
92
|
*/
|
94
93
|
subscribe(listener) {
|
95
|
-
return __classPrivateFieldGet(this,
|
96
|
-
.pipe(takeUntil(__classPrivateFieldGet(this,
|
94
|
+
return __classPrivateFieldGet(this, _SkyResizeObserverMediaQueryService_currentBreakpointObs, "f")
|
95
|
+
.pipe(takeUntil(__classPrivateFieldGet(this, _SkyResizeObserverMediaQueryService_ngUnsubscribe, "f")))
|
97
96
|
.subscribe((value) => {
|
98
97
|
listener(value);
|
99
98
|
});
|
100
99
|
}
|
101
|
-
updateBreakpoint(breakpoint) {
|
102
|
-
this._currentBreakpoint = breakpoint;
|
103
|
-
__classPrivateFieldGet(this, _SkyResizeObserverMediaQueryService_currentBreakpointObservable, "f").next(breakpoint);
|
104
|
-
}
|
105
|
-
checkBreakpoint(width) {
|
106
|
-
const breakpoint = __classPrivateFieldGet(this, _SkyResizeObserverMediaQueryService_breakpoints, "f").find((breakpoint) => breakpoint.check(width));
|
107
|
-
/* istanbul ignore else */
|
108
|
-
if (breakpoint) {
|
109
|
-
return breakpoint.name;
|
110
|
-
}
|
111
|
-
}
|
112
|
-
checkWidth(element) {
|
113
|
-
const width = element.nativeElement.offsetWidth || 0;
|
114
|
-
const breakpoint = this.checkBreakpoint(width);
|
115
|
-
/* istanbul ignore else */
|
116
|
-
if (breakpoint !== this._currentBreakpoint) {
|
117
|
-
this.updateBreakpoint(breakpoint);
|
118
|
-
}
|
119
|
-
}
|
120
100
|
}
|
121
|
-
_SkyResizeObserverMediaQueryService_breakpoints = new WeakMap(),
|
101
|
+
_SkyResizeObserverMediaQueryService_breakpoints = new WeakMap(), _SkyResizeObserverMediaQueryService_currentBreakpoint = new WeakMap(), _SkyResizeObserverMediaQueryService_currentBreakpointObs = new WeakMap(), _SkyResizeObserverMediaQueryService_ngUnsubscribe = new WeakMap(), _SkyResizeObserverMediaQueryService_resizeObserverSvc = new WeakMap(), _SkyResizeObserverMediaQueryService_target = new WeakMap(), _SkyResizeObserverMediaQueryService_instances = new WeakSet(), _SkyResizeObserverMediaQueryService_updateBreakpoint = function _SkyResizeObserverMediaQueryService_updateBreakpoint(breakpoint) {
|
102
|
+
__classPrivateFieldSet(this, _SkyResizeObserverMediaQueryService_currentBreakpoint, breakpoint, "f");
|
103
|
+
__classPrivateFieldGet(this, _SkyResizeObserverMediaQueryService_currentBreakpointObs, "f").next(breakpoint);
|
104
|
+
}, _SkyResizeObserverMediaQueryService_checkBreakpoint = function _SkyResizeObserverMediaQueryService_checkBreakpoint(width) {
|
105
|
+
const breakpoint = __classPrivateFieldGet(this, _SkyResizeObserverMediaQueryService_breakpoints, "f").find((breakpoint) => breakpoint.check(width));
|
106
|
+
return breakpoint ? breakpoint.name : undefined;
|
107
|
+
}, _SkyResizeObserverMediaQueryService_checkWidth = function _SkyResizeObserverMediaQueryService_checkWidth(el) {
|
108
|
+
const width = el.nativeElement.offsetWidth || 0;
|
109
|
+
const breakpoint = __classPrivateFieldGet(this, _SkyResizeObserverMediaQueryService_instances, "m", _SkyResizeObserverMediaQueryService_checkBreakpoint).call(this, width);
|
110
|
+
if (breakpoint && breakpoint !== __classPrivateFieldGet(this, _SkyResizeObserverMediaQueryService_currentBreakpoint, "f")) {
|
111
|
+
__classPrivateFieldGet(this, _SkyResizeObserverMediaQueryService_instances, "m", _SkyResizeObserverMediaQueryService_updateBreakpoint).call(this, breakpoint);
|
112
|
+
}
|
113
|
+
};
|
122
114
|
SkyResizeObserverMediaQueryService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyResizeObserverMediaQueryService, deps: [{ token: i1.SkyResizeObserverService }], target: i0.ɵɵFactoryTarget.Injectable });
|
123
115
|
SkyResizeObserverMediaQueryService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyResizeObserverMediaQueryService, providedIn: 'any' });
|
124
116
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyResizeObserverMediaQueryService, decorators: [{
|
@@ -127,4 +119,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImpor
|
|
127
119
|
providedIn: 'any',
|
128
120
|
}]
|
129
121
|
}], ctorParameters: function () { return [{ type: i1.SkyResizeObserverService }]; } });
|
130
|
-
//# sourceMappingURL=data:application/json;base64,
|
122
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resize-observer-media-query.service.js","sourceRoot":"","sources":["../../../../../../../../libs/components/core/src/lib/modules/resize-observer/resize-observer-media-query.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { ElementRef, Injectable, OnDestroy } from '@angular/core';\n\nimport { ReplaySubject, Subject, Subscription } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { SkyMediaBreakpoints } from '../media-query/media-breakpoints';\nimport { SkyMediaQueryListener } from '../media-query/media-query-listener';\n\nimport { SkyResizeObserverService } from './resize-observer.service';\n\nconst DEFAULT_BREAKPOINT = SkyMediaBreakpoints.md;\n\n/**\n * Acts like `SkyMediaQueryService` for a container element, emitting the same responsive breakpoints.\n */\n@Injectable({\n  providedIn: 'any',\n})\nexport class SkyResizeObserverMediaQueryService implements OnDestroy {\n  /**\n   * Returns the current breakpoint.\n   */\n  public get current(): SkyMediaBreakpoints {\n    return this.#currentBreakpoint;\n  }\n\n  #breakpoints: {\n    check: (width: number) => boolean;\n    name: SkyMediaBreakpoints;\n  }[] = [\n    {\n      check: (width: number) => width > 0 && width <= 767,\n      name: SkyMediaBreakpoints.xs,\n    },\n    {\n      check: (width: number) => width > 767 && width <= 991,\n      name: SkyMediaBreakpoints.sm,\n    },\n    {\n      check: (width: number) => width > 991 && width <= 1199,\n      name: SkyMediaBreakpoints.md,\n    },\n    {\n      check: (width: number) => width > 1199,\n      name: SkyMediaBreakpoints.lg,\n    },\n  ];\n\n  #currentBreakpoint: SkyMediaBreakpoints = DEFAULT_BREAKPOINT;\n\n  #currentBreakpointObs = new ReplaySubject<SkyMediaBreakpoints>(1);\n\n  #ngUnsubscribe = new Subject<void>();\n\n  #resizeObserverSvc: SkyResizeObserverService;\n\n  #target: ElementRef | undefined;\n\n  constructor(resizeObserverSvc: SkyResizeObserverService) {\n    this.#resizeObserverSvc = resizeObserverSvc;\n  }\n\n  public ngOnDestroy(): void {\n    this.unobserve();\n\n    this.#target = undefined;\n    this.#currentBreakpointObs.complete();\n  }\n\n  /**\n   * @internal\n   */\n  public destroy(): void {\n    this.ngOnDestroy();\n  }\n\n  /**\n   * Sets the container element to watch. The `SkyResizeObserverMediaQueryService` will only observe one element at a\n   * time. Any previous subscriptions will be unsubscribed when a new element is observed.\n   */\n  public observe(element: ElementRef): SkyResizeObserverMediaQueryService {\n    if (this.#target) {\n      if (this.#target === element) {\n        return this;\n      }\n\n      this.unobserve();\n    }\n\n    this.#target = element;\n\n    this.#checkWidth(element);\n\n    this.#resizeObserverSvc\n      .observe(element)\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe((value) => {\n        const breakpoint = this.#checkBreakpoint(value.contentRect.width);\n        if (breakpoint && breakpoint !== this.current) {\n          this.#updateBreakpoint(breakpoint);\n        }\n      });\n    return this;\n  }\n\n  /**\n   * Stop watching the container element.\n   */\n  public unobserve(): void {\n    this.#ngUnsubscribe.next();\n    this.#ngUnsubscribe.complete();\n  }\n\n  /**\n   * Subscribes to element size changes that cross breakpoints.\n   */\n  public subscribe(listener: SkyMediaQueryListener): Subscription {\n    return this.#currentBreakpointObs\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe((value) => {\n        listener(value);\n      });\n  }\n\n  #updateBreakpoint(breakpoint: SkyMediaBreakpoints) {\n    this.#currentBreakpoint = breakpoint;\n    this.#currentBreakpointObs.next(breakpoint);\n  }\n\n  #checkBreakpoint(width: number): SkyMediaBreakpoints | undefined {\n    const breakpoint = this.#breakpoints.find((breakpoint) =>\n      breakpoint.check(width)\n    );\n\n    return breakpoint ? breakpoint.name : undefined;\n  }\n\n  #checkWidth(el: ElementRef): void {\n    const width = (el.nativeElement as HTMLElement).offsetWidth || 0;\n    const breakpoint = this.#checkBreakpoint(width);\n\n    if (breakpoint && breakpoint !== this.#currentBreakpoint) {\n      this.#updateBreakpoint(breakpoint);\n    }\n  }\n}\n"]}
|
@@ -1,3 +1,5 @@
|
|
1
|
+
var _SkyScrollableHostService_instances, _SkyScrollableHostService_mutationObserverSvc, _SkyScrollableHostService_windowRef, _SkyScrollableHostService_findScrollableHost, _SkyScrollableHostService_observeDocumentHiddenElementChanges, _SkyScrollableHostService_observeForScrollableHostChanges, _SkyScrollableHostService_isElementVisible;
|
2
|
+
import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
|
1
3
|
import { Injectable } from '@angular/core';
|
2
4
|
import { Observable, Subject, fromEvent } from 'rxjs';
|
3
5
|
import { takeUntil } from 'rxjs/operators';
|
@@ -13,8 +15,11 @@ function notifySubscribers(subscribers, item) {
|
|
13
15
|
}
|
14
16
|
export class SkyScrollableHostService {
|
15
17
|
constructor(mutationObserverSvc, windowRef) {
|
16
|
-
this
|
17
|
-
this
|
18
|
+
_SkyScrollableHostService_instances.add(this);
|
19
|
+
_SkyScrollableHostService_mutationObserverSvc.set(this, void 0);
|
20
|
+
_SkyScrollableHostService_windowRef.set(this, void 0);
|
21
|
+
__classPrivateFieldSet(this, _SkyScrollableHostService_mutationObserverSvc, mutationObserverSvc, "f");
|
22
|
+
__classPrivateFieldSet(this, _SkyScrollableHostService_windowRef, windowRef, "f");
|
18
23
|
}
|
19
24
|
/**
|
20
25
|
* Returns the given element's current scrollable host
|
@@ -22,7 +27,7 @@ export class SkyScrollableHostService {
|
|
22
27
|
* @returns The current scrollable host
|
23
28
|
*/
|
24
29
|
getScrollableHost(elementRef) {
|
25
|
-
return this.
|
30
|
+
return __classPrivateFieldGet(this, _SkyScrollableHostService_instances, "m", _SkyScrollableHostService_findScrollableHost).call(this, elementRef.nativeElement);
|
26
31
|
}
|
27
32
|
/**
|
28
33
|
* Returns an observable which emits the given element's current scrollable host
|
@@ -36,30 +41,31 @@ export class SkyScrollableHostService {
|
|
36
41
|
let documentHiddenElementMutationObserver;
|
37
42
|
return new Observable((subscriber) => {
|
38
43
|
subscribers.push(subscriber);
|
39
|
-
let scrollableHost = this.
|
44
|
+
let scrollableHost = __classPrivateFieldGet(this, _SkyScrollableHostService_instances, "m", _SkyScrollableHostService_findScrollableHost).call(this, elementRef.nativeElement);
|
40
45
|
// Setup mutation observers only once, for all subscribers.
|
41
46
|
if (subscribers.length === 1) {
|
42
|
-
parentMutationObserver = this.
|
43
|
-
const newScrollableHost = this.
|
47
|
+
parentMutationObserver = __classPrivateFieldGet(this, _SkyScrollableHostService_mutationObserverSvc, "f").create(() => {
|
48
|
+
const newScrollableHost = __classPrivateFieldGet(this, _SkyScrollableHostService_instances, "m", _SkyScrollableHostService_findScrollableHost).call(this, elementRef.nativeElement);
|
44
49
|
// Reset observer if scrollable host changes.
|
45
50
|
if (newScrollableHost !== scrollableHost &&
|
46
|
-
this.
|
51
|
+
__classPrivateFieldGet(this, _SkyScrollableHostService_instances, "m", _SkyScrollableHostService_isElementVisible).call(this, elementRef)) {
|
47
52
|
scrollableHost = newScrollableHost;
|
48
|
-
this.
|
53
|
+
__classPrivateFieldGet(this, _SkyScrollableHostService_instances, "m", _SkyScrollableHostService_observeForScrollableHostChanges).call(this, scrollableHost, parentMutationObserver);
|
49
54
|
notifySubscribers(subscribers, scrollableHost);
|
50
55
|
}
|
51
56
|
});
|
52
|
-
this.
|
53
|
-
documentHiddenElementMutationObserver =
|
54
|
-
|
55
|
-
|
56
|
-
|
57
|
-
|
58
|
-
|
59
|
-
|
60
|
-
|
61
|
-
|
62
|
-
|
57
|
+
__classPrivateFieldGet(this, _SkyScrollableHostService_instances, "m", _SkyScrollableHostService_observeForScrollableHostChanges).call(this, scrollableHost, parentMutationObserver);
|
58
|
+
documentHiddenElementMutationObserver =
|
59
|
+
__classPrivateFieldGet(this, _SkyScrollableHostService_mutationObserverSvc, "f").create(() => {
|
60
|
+
if (scrollableHost && !__classPrivateFieldGet(this, _SkyScrollableHostService_instances, "m", _SkyScrollableHostService_isElementVisible).call(this, elementRef)) {
|
61
|
+
// If the scrollable host is not visible, set it to undefined and unsubscribe from its mutation changes.
|
62
|
+
// Then, observe the document element so that a new scrollable host can be found.
|
63
|
+
scrollableHost = undefined;
|
64
|
+
__classPrivateFieldGet(this, _SkyScrollableHostService_instances, "m", _SkyScrollableHostService_observeForScrollableHostChanges).call(this, scrollableHost, parentMutationObserver);
|
65
|
+
notifySubscribers(subscribers, scrollableHost);
|
66
|
+
}
|
67
|
+
});
|
68
|
+
__classPrivateFieldGet(this, _SkyScrollableHostService_instances, "m", _SkyScrollableHostService_observeDocumentHiddenElementChanges).call(this, documentHiddenElementMutationObserver);
|
63
69
|
}
|
64
70
|
// Emit the scrollable host to the subscriber.
|
65
71
|
subscriber.next(scrollableHost);
|
@@ -126,56 +132,49 @@ export class SkyScrollableHostService {
|
|
126
132
|
});
|
127
133
|
});
|
128
134
|
}
|
129
|
-
|
130
|
-
|
131
|
-
|
132
|
-
|
133
|
-
|
134
|
-
|
135
|
-
|
136
|
-
|
137
|
-
|
138
|
-
|
139
|
-
|
140
|
-
|
141
|
-
|
142
|
-
|
143
|
-
}
|
144
|
-
style = windowObj.getComputedStyle(parent);
|
145
|
-
} while (!regex.test(style.overflow) &&
|
146
|
-
!regex.test(style.overflowY) &&
|
147
|
-
parent !== bodyObj);
|
148
|
-
if (parent === bodyObj) {
|
135
|
+
}
|
136
|
+
_SkyScrollableHostService_mutationObserverSvc = new WeakMap(), _SkyScrollableHostService_windowRef = new WeakMap(), _SkyScrollableHostService_instances = new WeakSet(), _SkyScrollableHostService_findScrollableHost = function _SkyScrollableHostService_findScrollableHost(element) {
|
137
|
+
const regex = /(auto|scroll)/;
|
138
|
+
const windowObj = __classPrivateFieldGet(this, _SkyScrollableHostService_windowRef, "f").nativeWindow;
|
139
|
+
const bodyObj = windowObj.document.body;
|
140
|
+
if (!element) {
|
141
|
+
return windowObj;
|
142
|
+
}
|
143
|
+
let style = windowObj.getComputedStyle(element);
|
144
|
+
let parent = element;
|
145
|
+
do {
|
146
|
+
parent = parent.parentNode;
|
147
|
+
// Return `window` if the parent element has been removed from the DOM.
|
148
|
+
if (!(parent instanceof HTMLElement)) {
|
149
149
|
return windowObj;
|
150
150
|
}
|
151
|
-
|
151
|
+
style = windowObj.getComputedStyle(parent);
|
152
|
+
} while (!regex.test(style.overflow) &&
|
153
|
+
!regex.test(style.overflowY) &&
|
154
|
+
parent !== bodyObj);
|
155
|
+
if (parent === bodyObj) {
|
156
|
+
return windowObj;
|
152
157
|
}
|
153
|
-
|
154
|
-
|
155
|
-
|
156
|
-
|
157
|
-
|
158
|
-
|
159
|
-
|
160
|
-
}
|
161
|
-
|
162
|
-
|
163
|
-
|
164
|
-
|
165
|
-
|
166
|
-
|
167
|
-
|
168
|
-
|
169
|
-
|
170
|
-
|
171
|
-
|
172
|
-
|
173
|
-
* @see https://stackoverflow.com/a/11639664/6178885
|
174
|
-
*/
|
175
|
-
isElementVisible(elementRef) {
|
176
|
-
return elementRef.nativeElement.offsetParent;
|
177
|
-
}
|
178
|
-
}
|
158
|
+
return parent;
|
159
|
+
}, _SkyScrollableHostService_observeDocumentHiddenElementChanges = function _SkyScrollableHostService_observeDocumentHiddenElementChanges(mutationObserver) {
|
160
|
+
mutationObserver.observe(document.documentElement, {
|
161
|
+
attributes: true,
|
162
|
+
attributeFilter: ['class', 'style', 'hidden'],
|
163
|
+
childList: true,
|
164
|
+
subtree: true,
|
165
|
+
});
|
166
|
+
}, _SkyScrollableHostService_observeForScrollableHostChanges = function _SkyScrollableHostService_observeForScrollableHostChanges(element, mutationObserver) {
|
167
|
+
mutationObserver.disconnect();
|
168
|
+
const target = element instanceof HTMLElement ? element : document.documentElement;
|
169
|
+
mutationObserver.observe(target, {
|
170
|
+
attributes: true,
|
171
|
+
attributeFilter: ['class', 'style'],
|
172
|
+
childList: true,
|
173
|
+
subtree: true,
|
174
|
+
});
|
175
|
+
}, _SkyScrollableHostService_isElementVisible = function _SkyScrollableHostService_isElementVisible(elementRef) {
|
176
|
+
return elementRef.nativeElement.offsetParent;
|
177
|
+
};
|
179
178
|
SkyScrollableHostService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyScrollableHostService, deps: [{ token: i1.MutationObserverService }, { token: i2.SkyAppWindowRef }], target: i0.ɵɵFactoryTarget.Injectable });
|
180
179
|
SkyScrollableHostService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyScrollableHostService, providedIn: 'root' });
|
181
180
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyScrollableHostService, decorators: [{
|
@@ -184,4 +183,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImpor
|
|
184
183
|
providedIn: 'root',
|
185
184
|
}]
|
186
185
|
}], ctorParameters: function () { return [{ type: i1.MutationObserverService }, { type: i2.SkyAppWindowRef }]; } });
|
187
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"scrollable-host.service.js","sourceRoot":"","sources":["../../../../../../../../libs/components/core/src/lib/modules/scrollable-host/scrollable-host.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { ElementRef, Injectable } from '@angular/core';\n\nimport { Observable, Subject, Subscriber, Subscription, fromEvent } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { MutationObserverService } from '../mutation/mutation-observer-service';\nimport { SkyAppWindowRef } from '../window/window-ref';\n\nfunction notifySubscribers(subscribers: Subscriber<unknown>[], item?: unknown) {\n  for (const subscriber of subscribers) {\n    subscriber.next(item);\n  }\n}\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class SkyScrollableHostService {\n  constructor(\n    private mutationObserverSvc: MutationObserverService,\n    private windowRef: SkyAppWindowRef\n  ) {}\n\n  /**\n   * Returns the given element's current scrollable host\n   * @param elementRef The element whose scrollable host is being requested\n   * @returns The current scrollable host\n   */\n  public getScrollableHost(elementRef: ElementRef): HTMLElement | Window {\n    return this.findScrollableHost(elementRef.nativeElement);\n  }\n\n  /**\n   * Returns an observable which emits the given element's current scrollable host\n   * @param elementRef The element whose scrollable host is being requested\n   * @returns An observable which emits the current scrollable host element.\n   * @internal\n   */\n  public watchScrollableHost(\n    elementRef: ElementRef\n  ): Observable<HTMLElement | Window | undefined> {\n    const subscribers: Subscriber<HTMLElement | Window>[] = [];\n\n    let parentMutationObserver: MutationObserver;\n    let documentHiddenElementMutationObserver: MutationObserver;\n\n    return new Observable((subscriber) => {\n      subscribers.push(subscriber);\n\n      let scrollableHost = this.findScrollableHost(elementRef.nativeElement);\n\n      // Setup mutation observers only once, for all subscribers.\n      if (subscribers.length === 1) {\n        parentMutationObserver = this.mutationObserverSvc.create(() => {\n          const newScrollableHost = this.findScrollableHost(\n            elementRef.nativeElement\n          );\n\n          // Reset observer if scrollable host changes.\n          if (\n            newScrollableHost !== scrollableHost &&\n            this.isElementVisible(elementRef)\n          ) {\n            scrollableHost = newScrollableHost;\n\n            this.observeForScrollableHostChanges(\n              scrollableHost,\n              parentMutationObserver\n            );\n\n            notifySubscribers(subscribers, scrollableHost);\n          }\n        });\n\n        this.observeForScrollableHostChanges(\n          scrollableHost,\n          parentMutationObserver\n        );\n\n        documentHiddenElementMutationObserver = this.mutationObserverSvc.create(\n          () => {\n            if (scrollableHost && !this.isElementVisible(elementRef)) {\n              // If the scrollable host is not visible, set it to undefined and unsubscribe from its mutation changes.\n              // Then, observe the document element so that a new scrollable host can be found.\n              scrollableHost = undefined;\n\n              this.observeForScrollableHostChanges(\n                scrollableHost,\n                parentMutationObserver\n              );\n\n              notifySubscribers(subscribers, scrollableHost);\n            }\n          }\n        );\n\n        this.observeDocumentHiddenElementChanges(\n          documentHiddenElementMutationObserver\n        );\n      }\n\n      // Emit the scrollable host to the subscriber.\n      subscriber.next(scrollableHost);\n\n      // Teardown callback for the subscription.\n      subscriber.add(() => {\n        const subIndex = subscribers.indexOf(subscriber);\n\n        /* istanbul ignore else */\n        if (subIndex >= 0) {\n          subscribers.splice(subIndex, 1);\n        }\n\n        if (subscribers.length === 0) {\n          documentHiddenElementMutationObserver.disconnect();\n          parentMutationObserver.disconnect();\n        }\n      });\n    });\n  }\n\n  /**\n   * Returns an observable which emits whenever the element's scrollable host emits a scroll event. The observable will always emit the scroll events from the elements current scrollable host and will update based on any scrollable host changes. The observable will also emit once whenever the scrollable host changes.\n   * @param elementRef The element whose scrollable host scroll events are being requested\n   * @returns An observable which emits when the elements scrollable host is scrolled or is changed\n   */\n  public watchScrollableHostScrollEvents(\n    elementRef: ElementRef\n  ): Observable<void> {\n    const subscribers: Subscriber<void>[] = [];\n\n    let scrollableHost: HTMLElement | Window;\n\n    let newScrollableHostObservable = new Subject<void>();\n    let scrollableHostSubscription: Subscription;\n    let scrollEventSubscription: Subscription;\n\n    return new Observable((subscriber) => {\n      subscribers.push(subscriber);\n\n      // Setup mutation observers only once, for all subscribers.\n      if (subscribers.length === 1) {\n        scrollableHostSubscription = this.watchScrollableHost(\n          elementRef\n        ).subscribe((newScrollableHost) => {\n          newScrollableHostObservable.next();\n          newScrollableHostObservable.complete();\n\n          if (scrollableHost && scrollableHost !== newScrollableHost) {\n            notifySubscribers(subscribers);\n          }\n\n          scrollableHost = newScrollableHost;\n          newScrollableHostObservable = new Subject();\n\n          // Only subscribe to scroll events if the host element is defined.\n          /* istanbul ignore else */\n          if (newScrollableHost) {\n            scrollEventSubscription = fromEvent(newScrollableHost, 'scroll')\n              .pipe(takeUntil(newScrollableHostObservable))\n              .subscribe(() => {\n                notifySubscribers(subscribers);\n              });\n          }\n        });\n      }\n\n      // Teardown callback for the subscription.\n      subscriber.add(() => {\n        const subIndex = subscribers.indexOf(subscriber);\n\n        /* istanbul ignore else */\n        if (subIndex >= 0) {\n          subscribers.splice(subIndex, 1);\n        }\n\n        if (subscribers.length === 0) {\n          scrollableHostSubscription.unsubscribe();\n          scrollEventSubscription.unsubscribe();\n          newScrollableHostObservable.complete();\n        }\n      });\n    });\n  }\n\n  private findScrollableHost(\n    element: HTMLElement | undefined\n  ): HTMLElement | Window {\n    const regex = /(auto|scroll)/;\n    const windowObj = this.windowRef.nativeWindow;\n    const bodyObj = windowObj.document.body;\n\n    if (!element) {\n      return windowObj;\n    }\n\n    let style = windowObj.getComputedStyle(element);\n    let parent = element;\n\n    do {\n      parent = parent.parentNode as HTMLElement;\n\n      // Return `window` if the parent element has been removed from the DOM.\n      if (!(parent instanceof HTMLElement)) {\n        return windowObj;\n      }\n\n      style = windowObj.getComputedStyle(parent);\n    } while (\n      !regex.test(style.overflow) &&\n      !regex.test(style.overflowY) &&\n      parent !== bodyObj\n    );\n\n    if (parent === bodyObj) {\n      return windowObj;\n    }\n\n    return parent;\n  }\n\n  private observeDocumentHiddenElementChanges(\n    mutationObserver: MutationObserver\n  ) {\n    mutationObserver.observe(document.documentElement, {\n      attributes: true,\n      attributeFilter: ['class', 'style', 'hidden'],\n      childList: true,\n      subtree: true,\n    });\n  }\n\n  private observeForScrollableHostChanges(\n    element: HTMLElement | Window | undefined,\n    mutationObserver: MutationObserver\n  ) {\n    mutationObserver.disconnect();\n\n    const target =\n      element instanceof HTMLElement ? element : document.documentElement;\n\n    mutationObserver.observe(target, {\n      attributes: true,\n      attributeFilter: ['class', 'style'],\n      childList: true,\n      subtree: true,\n    });\n  }\n\n  /**\n   * Determines if an element is \"visible\" in the DOM.\n   * @see https://stackoverflow.com/a/11639664/6178885\n   */\n  private isElementVisible(elementRef: ElementRef): boolean {\n    return elementRef.nativeElement.offsetParent;\n  }\n}\n"]}
|
186
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"scrollable-host.service.js","sourceRoot":"","sources":["../../../../../../../../libs/components/core/src/lib/modules/scrollable-host/scrollable-host.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { ElementRef, Injectable } from '@angular/core';\n\nimport { Observable, Subject, Subscriber, Subscription, fromEvent } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { MutationObserverService } from '../mutation/mutation-observer-service';\nimport { SkyAppWindowRef } from '../window/window-ref';\n\nfunction notifySubscribers(subscribers: Subscriber<unknown>[], item?: unknown) {\n  for (const subscriber of subscribers) {\n    subscriber.next(item);\n  }\n}\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class SkyScrollableHostService {\n  #mutationObserverSvc: MutationObserverService;\n\n  #windowRef: SkyAppWindowRef;\n\n  constructor(\n    mutationObserverSvc: MutationObserverService,\n    windowRef: SkyAppWindowRef\n  ) {\n    this.#mutationObserverSvc = mutationObserverSvc;\n    this.#windowRef = windowRef;\n  }\n\n  /**\n   * Returns the given element's current scrollable host\n   * @param elementRef The element whose scrollable host is being requested\n   * @returns The current scrollable host\n   */\n  public getScrollableHost(elementRef: ElementRef): HTMLElement | Window {\n    return this.#findScrollableHost(elementRef.nativeElement);\n  }\n\n  /**\n   * Returns an observable which emits the given element's current scrollable host\n   * @param elementRef The element whose scrollable host is being requested\n   * @returns An observable which emits the current scrollable host element.\n   * @internal\n   */\n  public watchScrollableHost(\n    elementRef: ElementRef\n  ): Observable<HTMLElement | Window> {\n    const subscribers: Subscriber<HTMLElement | Window>[] = [];\n\n    let parentMutationObserver: MutationObserver;\n    let documentHiddenElementMutationObserver: MutationObserver;\n\n    return new Observable((subscriber) => {\n      subscribers.push(subscriber);\n\n      let scrollableHost: HTMLElement | Window | undefined =\n        this.#findScrollableHost(elementRef.nativeElement);\n\n      // Setup mutation observers only once, for all subscribers.\n      if (subscribers.length === 1) {\n        parentMutationObserver = this.#mutationObserverSvc.create(() => {\n          const newScrollableHost = this.#findScrollableHost(\n            elementRef.nativeElement\n          );\n\n          // Reset observer if scrollable host changes.\n          if (\n            newScrollableHost !== scrollableHost &&\n            this.#isElementVisible(elementRef)\n          ) {\n            scrollableHost = newScrollableHost;\n\n            this.#observeForScrollableHostChanges(\n              scrollableHost,\n              parentMutationObserver\n            );\n\n            notifySubscribers(subscribers, scrollableHost);\n          }\n        });\n\n        this.#observeForScrollableHostChanges(\n          scrollableHost,\n          parentMutationObserver\n        );\n\n        documentHiddenElementMutationObserver =\n          this.#mutationObserverSvc.create(() => {\n            if (scrollableHost && !this.#isElementVisible(elementRef)) {\n              // If the scrollable host is not visible, set it to undefined and unsubscribe from its mutation changes.\n              // Then, observe the document element so that a new scrollable host can be found.\n              scrollableHost = undefined;\n\n              this.#observeForScrollableHostChanges(\n                scrollableHost,\n                parentMutationObserver\n              );\n\n              notifySubscribers(subscribers, scrollableHost);\n            }\n          });\n\n        this.#observeDocumentHiddenElementChanges(\n          documentHiddenElementMutationObserver\n        );\n      }\n\n      // Emit the scrollable host to the subscriber.\n      subscriber.next(scrollableHost);\n\n      // Teardown callback for the subscription.\n      subscriber.add(() => {\n        const subIndex = subscribers.indexOf(subscriber);\n\n        /* istanbul ignore else */\n        if (subIndex >= 0) {\n          subscribers.splice(subIndex, 1);\n        }\n\n        if (subscribers.length === 0) {\n          documentHiddenElementMutationObserver.disconnect();\n          parentMutationObserver.disconnect();\n        }\n      });\n    });\n  }\n\n  /**\n   * Returns an observable which emits whenever the element's scrollable host emits a scroll event. The observable will always emit the scroll events from the elements current scrollable host and will update based on any scrollable host changes. The observable will also emit once whenever the scrollable host changes.\n   * @param elementRef The element whose scrollable host scroll events are being requested\n   * @returns An observable which emits when the elements scrollable host is scrolled or is changed\n   */\n  public watchScrollableHostScrollEvents(\n    elementRef: ElementRef\n  ): Observable<void> {\n    const subscribers: Subscriber<void>[] = [];\n\n    let scrollableHost: HTMLElement | Window;\n\n    let newScrollableHostObservable = new Subject<void>();\n    let scrollableHostSubscription: Subscription;\n    let scrollEventSubscription: Subscription;\n\n    return new Observable((subscriber) => {\n      subscribers.push(subscriber);\n\n      // Setup mutation observers only once, for all subscribers.\n      if (subscribers.length === 1) {\n        scrollableHostSubscription = this.watchScrollableHost(\n          elementRef\n        ).subscribe((newScrollableHost) => {\n          newScrollableHostObservable.next();\n          newScrollableHostObservable.complete();\n\n          if (scrollableHost && scrollableHost !== newScrollableHost) {\n            notifySubscribers(subscribers);\n          }\n\n          scrollableHost = newScrollableHost;\n          newScrollableHostObservable = new Subject();\n\n          // Only subscribe to scroll events if the host element is defined.\n          /* istanbul ignore else */\n          if (newScrollableHost) {\n            scrollEventSubscription = fromEvent(newScrollableHost, 'scroll')\n              .pipe(takeUntil(newScrollableHostObservable))\n              .subscribe(() => {\n                notifySubscribers(subscribers);\n              });\n          }\n        });\n      }\n\n      // Teardown callback for the subscription.\n      subscriber.add(() => {\n        const subIndex = subscribers.indexOf(subscriber);\n\n        /* istanbul ignore else */\n        if (subIndex >= 0) {\n          subscribers.splice(subIndex, 1);\n        }\n\n        if (subscribers.length === 0) {\n          scrollableHostSubscription.unsubscribe();\n          scrollEventSubscription.unsubscribe();\n          newScrollableHostObservable.complete();\n        }\n      });\n    });\n  }\n\n  #findScrollableHost(element: HTMLElement | undefined): HTMLElement | Window {\n    const regex = /(auto|scroll)/;\n    const windowObj = this.#windowRef.nativeWindow;\n    const bodyObj = windowObj.document.body;\n\n    if (!element) {\n      return windowObj;\n    }\n\n    let style = windowObj.getComputedStyle(element);\n    let parent = element;\n\n    do {\n      parent = parent.parentNode as HTMLElement;\n\n      // Return `window` if the parent element has been removed from the DOM.\n      if (!(parent instanceof HTMLElement)) {\n        return windowObj;\n      }\n\n      style = windowObj.getComputedStyle(parent);\n    } while (\n      !regex.test(style.overflow) &&\n      !regex.test(style.overflowY) &&\n      parent !== bodyObj\n    );\n\n    if (parent === bodyObj) {\n      return windowObj;\n    }\n\n    return parent;\n  }\n\n  #observeDocumentHiddenElementChanges(mutationObserver: MutationObserver) {\n    mutationObserver.observe(document.documentElement, {\n      attributes: true,\n      attributeFilter: ['class', 'style', 'hidden'],\n      childList: true,\n      subtree: true,\n    });\n  }\n\n  #observeForScrollableHostChanges(\n    element: HTMLElement | Window | undefined,\n    mutationObserver: MutationObserver\n  ) {\n    mutationObserver.disconnect();\n\n    const target =\n      element instanceof HTMLElement ? element : document.documentElement;\n\n    mutationObserver.observe(target, {\n      attributes: true,\n      attributeFilter: ['class', 'style'],\n      childList: true,\n      subtree: true,\n    });\n  }\n\n  /**\n   * Determines if an element is \"visible\" in the DOM.\n   * @see https://stackoverflow.com/a/11639664/6178885\n   */\n  #isElementVisible(elementRef: ElementRef): boolean {\n    return elementRef.nativeElement.offsetParent;\n  }\n}\n"]}
|
@@ -1,3 +1,5 @@
|
|
1
|
+
var _SkyAppTitleService_title;
|
2
|
+
import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
|
1
3
|
import { Injectable } from '@angular/core';
|
2
4
|
import { Title } from '@angular/platform-browser';
|
3
5
|
import * as i0 from "@angular/core";
|
@@ -7,7 +9,8 @@ import * as i1 from "@angular/platform-browser";
|
|
7
9
|
*/
|
8
10
|
export class SkyAppTitleService {
|
9
11
|
constructor(title) {
|
10
|
-
this
|
12
|
+
_SkyAppTitleService_title.set(this, void 0);
|
13
|
+
__classPrivateFieldSet(this, _SkyAppTitleService_title, title, "f");
|
11
14
|
}
|
12
15
|
/**
|
13
16
|
* Sets the title on the current window.
|
@@ -15,11 +18,12 @@ export class SkyAppTitleService {
|
|
15
18
|
* each part.
|
16
19
|
*/
|
17
20
|
setTitle(args) {
|
18
|
-
if (args
|
19
|
-
this.
|
21
|
+
if (args?.titleParts) {
|
22
|
+
__classPrivateFieldGet(this, _SkyAppTitleService_title, "f").setTitle(args.titleParts.join(' - '));
|
20
23
|
}
|
21
24
|
}
|
22
25
|
}
|
26
|
+
_SkyAppTitleService_title = new WeakMap();
|
23
27
|
SkyAppTitleService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyAppTitleService, deps: [{ token: i1.Title }], target: i0.ɵɵFactoryTarget.Injectable });
|
24
28
|
SkyAppTitleService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyAppTitleService, providedIn: 'root' });
|
25
29
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyAppTitleService, decorators: [{
|
@@ -28,4 +32,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImpor
|
|
28
32
|
providedIn: 'root',
|
29
33
|
}]
|
30
34
|
}], ctorParameters: function () { return [{ type: i1.Title }]; } });
|
31
|
-
//# sourceMappingURL=data:application/json;base64,
|
35
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGl0bGUuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9jb3JlL3NyYy9saWIvbW9kdWxlcy90aXRsZS90aXRsZS5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMzQyxPQUFPLEVBQUUsS0FBSyxFQUFFLE1BQU0sMkJBQTJCLENBQUM7OztBQUlsRDs7R0FFRztBQUlILE1BQU0sT0FBTyxrQkFBa0I7SUFHN0IsWUFBWSxLQUFZO1FBRnhCLDRDQUFjO1FBR1osdUJBQUEsSUFBSSw2QkFBVSxLQUFLLE1BQUEsQ0FBQztJQUN0QixDQUFDO0lBRUQ7Ozs7T0FJRztJQUNJLFFBQVEsQ0FBQyxJQUFvQztRQUNsRCxJQUFJLElBQUksRUFBRSxVQUFVLEVBQUU7WUFDcEIsdUJBQUEsSUFBSSxpQ0FBTyxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDO1NBQ25EO0lBQ0gsQ0FBQzs7OytHQWhCVSxrQkFBa0I7bUhBQWxCLGtCQUFrQixjQUZqQixNQUFNOzJGQUVQLGtCQUFrQjtrQkFIOUIsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBUaXRsZSB9IGZyb20gJ0Bhbmd1bGFyL3BsYXRmb3JtLWJyb3dzZXInO1xuXG5pbXBvcnQgeyBTa3lBcHBTZXRUaXRsZUFyZ3MgfSBmcm9tICcuL3NldC10aXRsZS1hcmdzJztcblxuLyoqXG4gKiBQcm92aWRlcyBhIG1ldGhvZCBmb3Igc2V0dGluZyBhIGZvcm1hdHRlZCB0aXRsZSBvbiB0aGUgY3VycmVudCB3aW5kb3cuXG4gKi9cbkBJbmplY3RhYmxlKHtcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnLFxufSlcbmV4cG9ydCBjbGFzcyBTa3lBcHBUaXRsZVNlcnZpY2Uge1xuICAjdGl0bGU6IFRpdGxlO1xuXG4gIGNvbnN0cnVjdG9yKHRpdGxlOiBUaXRsZSkge1xuICAgIHRoaXMuI3RpdGxlID0gdGl0bGU7XG4gIH1cblxuICAvKipcbiAgICogU2V0cyB0aGUgdGl0bGUgb24gdGhlIGN1cnJlbnQgd2luZG93LlxuICAgKiBAcGFyYW0gYXJncyBBbiBhcnJheSBvZiB0aXRsZSBwYXJ0cy4gVGhlIHBhcnRzIHdpbGwgYmUgY29uY2F0ZW5hdGVkIHdpdGggYSBoeXBoZW4gYmV0d2VlblxuICAgKiBlYWNoIHBhcnQuXG4gICAqL1xuICBwdWJsaWMgc2V0VGl0bGUoYXJnczogU2t5QXBwU2V0VGl0bGVBcmdzIHwgdW5kZWZpbmVkKTogdm9pZCB7XG4gICAgaWYgKGFyZ3M/LnRpdGxlUGFydHMpIHtcbiAgICAgIHRoaXMuI3RpdGxlLnNldFRpdGxlKGFyZ3MudGl0bGVQYXJ0cy5qb2luKCcgLSAnKSk7XG4gICAgfVxuICB9XG59XG4iXX0=
|