@skyux/modals 6.13.0 → 6.16.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/documentation.json +340 -529
- package/esm2020/lib/modules/confirm/confirm-config-token.mjs +6 -0
- package/esm2020/lib/modules/confirm/confirm.component.mjs +103 -97
- package/esm2020/lib/modules/confirm/confirm.service.mjs +9 -5
- package/esm2020/lib/modules/modal/modal-adapter.service.mjs +20 -15
- package/esm2020/lib/modules/modal/modal-close-args.mjs +1 -1
- package/esm2020/lib/modules/modal/modal-component-adapter.service.mjs +17 -13
- package/esm2020/lib/modules/modal/modal-host-context-args.mjs +2 -0
- package/esm2020/lib/modules/modal/modal-host-context.mjs +9 -6
- package/esm2020/lib/modules/modal/modal-host.component.mjs +41 -14
- package/esm2020/lib/modules/modal/modal-host.service.mjs +21 -15
- package/esm2020/lib/modules/modal/modal-instance.mjs +31 -29
- package/esm2020/lib/modules/modal/modal-scroll-shadow.directive.mjs +71 -65
- package/esm2020/lib/modules/modal/modal.component.mjs +59 -74
- package/esm2020/lib/modules/modal/modal.service.mjs +50 -42
- package/esm2020/testing/modal-fixture.mjs +60 -84
- package/fesm2015/skyux-modals-testing.mjs +60 -83
- package/fesm2015/skyux-modals-testing.mjs.map +1 -1
- package/fesm2015/skyux-modals.mjs +412 -368
- package/fesm2015/skyux-modals.mjs.map +1 -1
- package/fesm2020/skyux-modals-testing.mjs +60 -83
- package/fesm2020/skyux-modals-testing.mjs.map +1 -1
- package/fesm2020/skyux-modals.mjs +409 -368
- package/fesm2020/skyux-modals.mjs.map +1 -1
- package/lib/modules/confirm/confirm-config-token.d.ts +6 -0
- package/lib/modules/confirm/confirm.component.d.ts +6 -12
- package/lib/modules/confirm/confirm.service.d.ts +1 -1
- package/lib/modules/modal/modal-adapter.service.d.ts +1 -5
- package/lib/modules/modal/modal-close-args.d.ts +1 -1
- package/lib/modules/modal/modal-component-adapter.service.d.ts +1 -2
- package/lib/modules/modal/modal-host-context-args.d.ts +7 -0
- package/lib/modules/modal/modal-host-context.d.ts +3 -2
- package/lib/modules/modal/modal-host.component.d.ts +1 -6
- package/lib/modules/modal/modal-host.service.d.ts +2 -2
- package/lib/modules/modal/modal-instance.d.ts +1 -5
- package/lib/modules/modal/modal-scroll-shadow.directive.d.ts +1 -13
- package/lib/modules/modal/modal.component.d.ts +12 -23
- package/lib/modules/modal/modal.service.d.ts +1 -3
- package/package.json +5 -6
- package/testing/modal-fixture.d.ts +6 -8
- package/esm2020/lib/modules/confirm/confirm-modal-context.mjs +0 -6
- package/esm2020/lib/modules/modal/modal-state-animation.mjs +0 -8
- package/lib/modules/confirm/confirm-modal-context.d.ts +0 -13
- package/lib/modules/modal/modal-state-animation.d.ts +0 -1
|
@@ -1,3 +1,5 @@
|
|
|
1
|
+
var _SkyModalScrollShadowDirective_instances, _SkyModalScrollShadowDirective_currentShadow, _SkyModalScrollShadowDirective_currentTheme, _SkyModalScrollShadowDirective_mutationObserver, _SkyModalScrollShadowDirective_ngUnsubscribe, _SkyModalScrollShadowDirective_elRef, _SkyModalScrollShadowDirective_mutationObserverSvc, _SkyModalScrollShadowDirective_ngZone, _SkyModalScrollShadowDirective_themeSvc, _SkyModalScrollShadowDirective_initMutationObserver, _SkyModalScrollShadowDirective_destroyMutationObserver, _SkyModalScrollShadowDirective_checkForShadow, _SkyModalScrollShadowDirective_buildShadowStyle, _SkyModalScrollShadowDirective_emitShadow;
|
|
2
|
+
import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
|
|
1
3
|
import { Directive, ElementRef, EventEmitter, HostListener, NgZone, Optional, Output, } from '@angular/core';
|
|
2
4
|
import { MutationObserverService } from '@skyux/core';
|
|
3
5
|
import { SkyTheme, SkyThemeService } from '@skyux/theme';
|
|
@@ -13,94 +15,98 @@ import * as i2 from "@skyux/theme";
|
|
|
13
15
|
*/
|
|
14
16
|
export class SkyModalScrollShadowDirective {
|
|
15
17
|
constructor(elRef, mutationObserverSvc, ngZone, themeSvc) {
|
|
16
|
-
this
|
|
17
|
-
this.mutationObserverSvc = mutationObserverSvc;
|
|
18
|
-
this.ngZone = ngZone;
|
|
19
|
-
this.themeSvc = themeSvc;
|
|
18
|
+
_SkyModalScrollShadowDirective_instances.add(this);
|
|
20
19
|
this.skyModalScrollShadow = new EventEmitter();
|
|
21
|
-
this
|
|
20
|
+
_SkyModalScrollShadowDirective_currentShadow.set(this, void 0);
|
|
21
|
+
_SkyModalScrollShadowDirective_currentTheme.set(this, void 0);
|
|
22
|
+
_SkyModalScrollShadowDirective_mutationObserver.set(this, void 0);
|
|
23
|
+
_SkyModalScrollShadowDirective_ngUnsubscribe.set(this, new Subject());
|
|
24
|
+
_SkyModalScrollShadowDirective_elRef.set(this, void 0);
|
|
25
|
+
_SkyModalScrollShadowDirective_mutationObserverSvc.set(this, void 0);
|
|
26
|
+
_SkyModalScrollShadowDirective_ngZone.set(this, void 0);
|
|
27
|
+
_SkyModalScrollShadowDirective_themeSvc.set(this, void 0);
|
|
28
|
+
__classPrivateFieldSet(this, _SkyModalScrollShadowDirective_elRef, elRef, "f");
|
|
29
|
+
__classPrivateFieldSet(this, _SkyModalScrollShadowDirective_mutationObserverSvc, mutationObserverSvc, "f");
|
|
30
|
+
__classPrivateFieldSet(this, _SkyModalScrollShadowDirective_ngZone, ngZone, "f");
|
|
31
|
+
__classPrivateFieldSet(this, _SkyModalScrollShadowDirective_themeSvc, themeSvc, "f");
|
|
22
32
|
}
|
|
23
33
|
windowResize() {
|
|
24
|
-
this.
|
|
34
|
+
__classPrivateFieldGet(this, _SkyModalScrollShadowDirective_instances, "m", _SkyModalScrollShadowDirective_checkForShadow).call(this);
|
|
25
35
|
}
|
|
26
36
|
scroll() {
|
|
27
|
-
this.
|
|
37
|
+
__classPrivateFieldGet(this, _SkyModalScrollShadowDirective_instances, "m", _SkyModalScrollShadowDirective_checkForShadow).call(this);
|
|
28
38
|
}
|
|
29
39
|
ngOnInit() {
|
|
30
|
-
if (this
|
|
31
|
-
this.
|
|
32
|
-
.pipe(takeUntil(this
|
|
40
|
+
if (__classPrivateFieldGet(this, _SkyModalScrollShadowDirective_themeSvc, "f")) {
|
|
41
|
+
__classPrivateFieldGet(this, _SkyModalScrollShadowDirective_themeSvc, "f").settingsChange
|
|
42
|
+
.pipe(takeUntil(__classPrivateFieldGet(this, _SkyModalScrollShadowDirective_ngUnsubscribe, "f")))
|
|
33
43
|
.subscribe((themeSettings) => {
|
|
34
|
-
this
|
|
35
|
-
if (this
|
|
36
|
-
this.
|
|
44
|
+
__classPrivateFieldSet(this, _SkyModalScrollShadowDirective_currentTheme, themeSettings.currentSettings.theme, "f");
|
|
45
|
+
if (__classPrivateFieldGet(this, _SkyModalScrollShadowDirective_currentTheme, "f") === SkyTheme.presets.modern) {
|
|
46
|
+
__classPrivateFieldGet(this, _SkyModalScrollShadowDirective_instances, "m", _SkyModalScrollShadowDirective_initMutationObserver).call(this);
|
|
37
47
|
}
|
|
38
48
|
else {
|
|
39
|
-
this.
|
|
49
|
+
__classPrivateFieldGet(this, _SkyModalScrollShadowDirective_instances, "m", _SkyModalScrollShadowDirective_emitShadow).call(this, {
|
|
40
50
|
bottomShadow: 'none',
|
|
41
51
|
topShadow: 'none',
|
|
42
52
|
});
|
|
43
|
-
this.
|
|
53
|
+
__classPrivateFieldGet(this, _SkyModalScrollShadowDirective_instances, "m", _SkyModalScrollShadowDirective_destroyMutationObserver).call(this);
|
|
44
54
|
}
|
|
45
55
|
});
|
|
46
56
|
}
|
|
47
57
|
}
|
|
48
58
|
ngOnDestroy() {
|
|
49
|
-
this.
|
|
50
|
-
this.
|
|
51
|
-
this.
|
|
59
|
+
__classPrivateFieldGet(this, _SkyModalScrollShadowDirective_ngUnsubscribe, "f").next();
|
|
60
|
+
__classPrivateFieldGet(this, _SkyModalScrollShadowDirective_ngUnsubscribe, "f").complete();
|
|
61
|
+
__classPrivateFieldGet(this, _SkyModalScrollShadowDirective_instances, "m", _SkyModalScrollShadowDirective_destroyMutationObserver).call(this);
|
|
52
62
|
}
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
63
|
+
}
|
|
64
|
+
_SkyModalScrollShadowDirective_currentShadow = new WeakMap(), _SkyModalScrollShadowDirective_currentTheme = new WeakMap(), _SkyModalScrollShadowDirective_mutationObserver = new WeakMap(), _SkyModalScrollShadowDirective_ngUnsubscribe = new WeakMap(), _SkyModalScrollShadowDirective_elRef = new WeakMap(), _SkyModalScrollShadowDirective_mutationObserverSvc = new WeakMap(), _SkyModalScrollShadowDirective_ngZone = new WeakMap(), _SkyModalScrollShadowDirective_themeSvc = new WeakMap(), _SkyModalScrollShadowDirective_instances = new WeakSet(), _SkyModalScrollShadowDirective_initMutationObserver = function _SkyModalScrollShadowDirective_initMutationObserver() {
|
|
65
|
+
if (!__classPrivateFieldGet(this, _SkyModalScrollShadowDirective_mutationObserver, "f")) {
|
|
66
|
+
const el = __classPrivateFieldGet(this, _SkyModalScrollShadowDirective_elRef, "f").nativeElement;
|
|
67
|
+
// MutationObserver is patched by Zone.js and therefore becomes part of the
|
|
68
|
+
// Angular change detection cycle, but this can lead to infinite loops in some
|
|
69
|
+
// secnarios. This will keep MutationObserver from triggering change detection.
|
|
70
|
+
__classPrivateFieldGet(this, _SkyModalScrollShadowDirective_ngZone, "f").runOutsideAngular(() => {
|
|
71
|
+
__classPrivateFieldSet(this, _SkyModalScrollShadowDirective_mutationObserver, __classPrivateFieldGet(this, _SkyModalScrollShadowDirective_mutationObserverSvc, "f").create(() => {
|
|
72
|
+
__classPrivateFieldGet(this, _SkyModalScrollShadowDirective_instances, "m", _SkyModalScrollShadowDirective_checkForShadow).call(this);
|
|
73
|
+
}), "f");
|
|
74
|
+
__classPrivateFieldGet(this, _SkyModalScrollShadowDirective_mutationObserver, "f").observe(el, {
|
|
75
|
+
attributes: true,
|
|
76
|
+
characterData: true,
|
|
77
|
+
childList: true,
|
|
78
|
+
subtree: true,
|
|
69
79
|
});
|
|
70
|
-
}
|
|
71
|
-
}
|
|
72
|
-
destroyMutationObserver() {
|
|
73
|
-
if (this.mutationObserver) {
|
|
74
|
-
this.mutationObserver.disconnect();
|
|
75
|
-
this.mutationObserver = undefined;
|
|
76
|
-
}
|
|
80
|
+
});
|
|
77
81
|
}
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
const bottomShadow = this.buildShadowStyle(el.scrollHeight - el.scrollTop - el.clientHeight);
|
|
83
|
-
this.emitShadow({
|
|
84
|
-
bottomShadow,
|
|
85
|
-
topShadow,
|
|
86
|
-
});
|
|
87
|
-
}
|
|
82
|
+
}, _SkyModalScrollShadowDirective_destroyMutationObserver = function _SkyModalScrollShadowDirective_destroyMutationObserver() {
|
|
83
|
+
if (__classPrivateFieldGet(this, _SkyModalScrollShadowDirective_mutationObserver, "f")) {
|
|
84
|
+
__classPrivateFieldGet(this, _SkyModalScrollShadowDirective_mutationObserver, "f").disconnect();
|
|
85
|
+
__classPrivateFieldSet(this, _SkyModalScrollShadowDirective_mutationObserver, undefined, "f");
|
|
88
86
|
}
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
const
|
|
93
|
-
|
|
87
|
+
}, _SkyModalScrollShadowDirective_checkForShadow = function _SkyModalScrollShadowDirective_checkForShadow() {
|
|
88
|
+
if (__classPrivateFieldGet(this, _SkyModalScrollShadowDirective_currentTheme, "f") === SkyTheme.presets.modern) {
|
|
89
|
+
const el = __classPrivateFieldGet(this, _SkyModalScrollShadowDirective_elRef, "f").nativeElement;
|
|
90
|
+
const topShadow = __classPrivateFieldGet(this, _SkyModalScrollShadowDirective_instances, "m", _SkyModalScrollShadowDirective_buildShadowStyle).call(this, el.scrollTop);
|
|
91
|
+
const bottomShadow = __classPrivateFieldGet(this, _SkyModalScrollShadowDirective_instances, "m", _SkyModalScrollShadowDirective_buildShadowStyle).call(this, el.scrollHeight - el.scrollTop - el.clientHeight);
|
|
92
|
+
__classPrivateFieldGet(this, _SkyModalScrollShadowDirective_instances, "m", _SkyModalScrollShadowDirective_emitShadow).call(this, {
|
|
93
|
+
bottomShadow,
|
|
94
|
+
topShadow,
|
|
95
|
+
});
|
|
94
96
|
}
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
97
|
+
}, _SkyModalScrollShadowDirective_buildShadowStyle = function _SkyModalScrollShadowDirective_buildShadowStyle(pixelsFromEnd) {
|
|
98
|
+
// Progressively darken the shadow until the user scrolls 30 pixels from the top or bottom
|
|
99
|
+
// of the scrollable element, with a max opacity of 0.3.
|
|
100
|
+
const opacity = Math.min(pixelsFromEnd / 30, 1) * 0.3;
|
|
101
|
+
return opacity > 0 ? `0px 1px 8px 0px rgba(0, 0, 0, ${opacity})` : 'none';
|
|
102
|
+
}, _SkyModalScrollShadowDirective_emitShadow = function _SkyModalScrollShadowDirective_emitShadow(shadow) {
|
|
103
|
+
if (!__classPrivateFieldGet(this, _SkyModalScrollShadowDirective_currentShadow, "f") ||
|
|
104
|
+
__classPrivateFieldGet(this, _SkyModalScrollShadowDirective_currentShadow, "f").bottomShadow !== shadow.bottomShadow ||
|
|
105
|
+
__classPrivateFieldGet(this, _SkyModalScrollShadowDirective_currentShadow, "f").topShadow !== shadow.topShadow) {
|
|
106
|
+
this.skyModalScrollShadow.emit(shadow);
|
|
107
|
+
__classPrivateFieldSet(this, _SkyModalScrollShadowDirective_currentShadow, shadow, "f");
|
|
102
108
|
}
|
|
103
|
-
}
|
|
109
|
+
};
|
|
104
110
|
SkyModalScrollShadowDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyModalScrollShadowDirective, deps: [{ token: i0.ElementRef }, { token: i1.MutationObserverService }, { token: i0.NgZone }, { token: i2.SkyThemeService, optional: true }], target: i0.ɵɵFactoryTarget.Directive });
|
|
105
111
|
SkyModalScrollShadowDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.2", type: SkyModalScrollShadowDirective, selector: "[skyModalScrollShadow]", outputs: { skyModalScrollShadow: "skyModalScrollShadow" }, host: { listeners: { "window:resize": "windowResize()", "scroll": "scroll()" } }, ngImport: i0 });
|
|
106
112
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyModalScrollShadowDirective, decorators: [{
|
|
@@ -119,4 +125,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImpor
|
|
|
119
125
|
type: HostListener,
|
|
120
126
|
args: ['scroll']
|
|
121
127
|
}] } });
|
|
122
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal-scroll-shadow.directive.js","sourceRoot":"","sources":["../../../../../../../../libs/components/modals/src/lib/modules/modal/modal-scroll-shadow.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Directive,\n  ElementRef,\n  EventEmitter,\n  HostListener,\n  NgZone,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n} from '@angular/core';\nimport { MutationObserverService } from '@skyux/core';\nimport { SkyTheme, SkyThemeService } from '@skyux/theme';\n\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { SkyModalScrollShadowEventArgs } from './modal-scroll-shadow-event-args';\n\n/**\n * Raises an event when the box shadow for the modal header or footer should be adjusted\n * based on the scroll position of the host element.\n * @internal\n */\n@Directive({\n  selector: '[skyModalScrollShadow]',\n})\nexport class SkyModalScrollShadowDirective implements OnInit, OnDestroy {\n  @Output()\n  public skyModalScrollShadow = new EventEmitter<SkyModalScrollShadowEventArgs>();\n\n  private currentShadow: SkyModalScrollShadowEventArgs;\n\n  private currentTheme: SkyTheme;\n\n  private mutationObserver: MutationObserver;\n\n  private ngUnsubscribe = new Subject<void>();\n\n  constructor(\n    private elRef: ElementRef,\n    private mutationObserverSvc: MutationObserverService,\n    private ngZone: NgZone,\n    @Optional() private themeSvc?: SkyThemeService\n  ) {}\n\n  @HostListener('window:resize')\n  public windowResize(): void {\n    this.checkForShadow();\n  }\n\n  @HostListener('scroll')\n  public scroll(): void {\n    this.checkForShadow();\n  }\n\n  public ngOnInit(): void {\n    if (this.themeSvc) {\n      this.themeSvc.settingsChange\n        .pipe(takeUntil(this.ngUnsubscribe))\n        .subscribe((themeSettings) => {\n          this.currentTheme = themeSettings.currentSettings.theme;\n\n          if (this.currentTheme === SkyTheme.presets.modern) {\n            this.initMutationObserver();\n          } else {\n            this.emitShadow({\n              bottomShadow: 'none',\n              topShadow: 'none',\n            });\n\n            this.destroyMutationObserver();\n          }\n        });\n    }\n  }\n\n  public ngOnDestroy(): void {\n    this.ngUnsubscribe.next();\n    this.ngUnsubscribe.complete();\n\n    this.destroyMutationObserver();\n  }\n\n  private initMutationObserver(): void {\n    if (!this.mutationObserver) {\n      const el = this.elRef.nativeElement;\n\n      // MutationObserver is patched by Zone.js and therefore becomes part of the\n      // Angular change detection cycle, but this can lead to infinite loops in some\n      // secnarios. This will keep MutationObserver from triggering change detection.\n      this.ngZone.runOutsideAngular(() => {\n        this.mutationObserver = this.mutationObserverSvc.create(() => {\n          this.checkForShadow();\n        });\n\n        this.mutationObserver.observe(el, {\n          attributes: true,\n          characterData: true,\n          childList: true,\n          subtree: true,\n        });\n      });\n    }\n  }\n\n  private destroyMutationObserver(): void {\n    if (this.mutationObserver) {\n      this.mutationObserver.disconnect();\n      this.mutationObserver = undefined;\n    }\n  }\n\n  private checkForShadow(): void {\n    if (this.currentTheme === SkyTheme.presets.modern) {\n      const el = this.elRef.nativeElement;\n\n      const topShadow = this.buildShadowStyle(el.scrollTop);\n\n      const bottomShadow = this.buildShadowStyle(\n        el.scrollHeight - el.scrollTop - el.clientHeight\n      );\n\n      this.emitShadow({\n        bottomShadow,\n        topShadow,\n      });\n    }\n  }\n\n  private buildShadowStyle(pixelsFromEnd: number): string {\n    // Progressively darken the shadow until the user scrolls 30 pixels from the top or bottom\n    // of the scrollable element, with a max opacity of 0.3.\n    const opacity = Math.min(pixelsFromEnd / 30, 1) * 0.3;\n\n    return opacity > 0 ? `0px 1px 8px 0px rgba(0, 0, 0, ${opacity})` : 'none';\n  }\n\n  private emitShadow(shadow: SkyModalScrollShadowEventArgs): void {\n    if (\n      !this.currentShadow ||\n      this.currentShadow.bottomShadow !== shadow.bottomShadow ||\n      this.currentShadow.topShadow !== shadow.topShadow\n    ) {\n      this.skyModalScrollShadow.emit(shadow);\n      this.currentShadow = shadow;\n    }\n  }\n}\n"]}
|
|
128
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal-scroll-shadow.directive.js","sourceRoot":"","sources":["../../../../../../../../libs/components/modals/src/lib/modules/modal/modal-scroll-shadow.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Directive,\n  ElementRef,\n  EventEmitter,\n  HostListener,\n  NgZone,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n} from '@angular/core';\nimport { MutationObserverService } from '@skyux/core';\nimport { SkyTheme, SkyThemeService } from '@skyux/theme';\n\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { SkyModalScrollShadowEventArgs } from './modal-scroll-shadow-event-args';\n\n/**\n * Raises an event when the box shadow for the modal header or footer should be adjusted\n * based on the scroll position of the host element.\n * @internal\n */\n@Directive({\n  selector: '[skyModalScrollShadow]',\n})\nexport class SkyModalScrollShadowDirective implements OnInit, OnDestroy {\n  @Output()\n  public skyModalScrollShadow = new EventEmitter<SkyModalScrollShadowEventArgs>();\n\n  #currentShadow: SkyModalScrollShadowEventArgs | undefined;\n\n  #currentTheme: SkyTheme | undefined;\n\n  #mutationObserver: MutationObserver | undefined;\n\n  #ngUnsubscribe = new Subject<void>();\n\n  #elRef: ElementRef;\n  #mutationObserverSvc: MutationObserverService;\n  #ngZone: NgZone;\n  #themeSvc: SkyThemeService | undefined;\n\n  constructor(\n    elRef: ElementRef,\n    mutationObserverSvc: MutationObserverService,\n    ngZone: NgZone,\n    @Optional() themeSvc?: SkyThemeService\n  ) {\n    this.#elRef = elRef;\n    this.#mutationObserverSvc = mutationObserverSvc;\n    this.#ngZone = ngZone;\n    this.#themeSvc = themeSvc;\n  }\n\n  @HostListener('window:resize')\n  public windowResize(): void {\n    this.#checkForShadow();\n  }\n\n  @HostListener('scroll')\n  public scroll(): void {\n    this.#checkForShadow();\n  }\n\n  public ngOnInit(): void {\n    if (this.#themeSvc) {\n      this.#themeSvc.settingsChange\n        .pipe(takeUntil(this.#ngUnsubscribe))\n        .subscribe((themeSettings) => {\n          this.#currentTheme = themeSettings.currentSettings.theme;\n\n          if (this.#currentTheme === SkyTheme.presets.modern) {\n            this.#initMutationObserver();\n          } else {\n            this.#emitShadow({\n              bottomShadow: 'none',\n              topShadow: 'none',\n            });\n\n            this.#destroyMutationObserver();\n          }\n        });\n    }\n  }\n\n  public ngOnDestroy(): void {\n    this.#ngUnsubscribe.next();\n    this.#ngUnsubscribe.complete();\n\n    this.#destroyMutationObserver();\n  }\n\n  #initMutationObserver(): void {\n    if (!this.#mutationObserver) {\n      const el = this.#elRef.nativeElement;\n\n      // MutationObserver is patched by Zone.js and therefore becomes part of the\n      // Angular change detection cycle, but this can lead to infinite loops in some\n      // secnarios. This will keep MutationObserver from triggering change detection.\n      this.#ngZone.runOutsideAngular(() => {\n        this.#mutationObserver = this.#mutationObserverSvc.create(() => {\n          this.#checkForShadow();\n        });\n\n        this.#mutationObserver.observe(el, {\n          attributes: true,\n          characterData: true,\n          childList: true,\n          subtree: true,\n        });\n      });\n    }\n  }\n\n  #destroyMutationObserver(): void {\n    if (this.#mutationObserver) {\n      this.#mutationObserver.disconnect();\n      this.#mutationObserver = undefined;\n    }\n  }\n\n  #checkForShadow(): void {\n    if (this.#currentTheme === SkyTheme.presets.modern) {\n      const el = this.#elRef.nativeElement;\n\n      const topShadow = this.#buildShadowStyle(el.scrollTop);\n\n      const bottomShadow = this.#buildShadowStyle(\n        el.scrollHeight - el.scrollTop - el.clientHeight\n      );\n\n      this.#emitShadow({\n        bottomShadow,\n        topShadow,\n      });\n    }\n  }\n\n  #buildShadowStyle(pixelsFromEnd: number): string {\n    // Progressively darken the shadow until the user scrolls 30 pixels from the top or bottom\n    // of the scrollable element, with a max opacity of 0.3.\n    const opacity = Math.min(pixelsFromEnd / 30, 1) * 0.3;\n\n    return opacity > 0 ? `0px 1px 8px 0px rgba(0, 0, 0, ${opacity})` : 'none';\n  }\n\n  #emitShadow(shadow: SkyModalScrollShadowEventArgs): void {\n    if (\n      !this.#currentShadow ||\n      this.#currentShadow.bottomShadow !== shadow.bottomShadow ||\n      this.#currentShadow.topShadow !== shadow.topShadow\n    ) {\n      this.skyModalScrollShadow.emit(shadow);\n      this.#currentShadow = shadow;\n    }\n  }\n}\n"]}
|