@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.
Files changed (44) hide show
  1. package/documentation.json +340 -529
  2. package/esm2020/lib/modules/confirm/confirm-config-token.mjs +6 -0
  3. package/esm2020/lib/modules/confirm/confirm.component.mjs +103 -97
  4. package/esm2020/lib/modules/confirm/confirm.service.mjs +9 -5
  5. package/esm2020/lib/modules/modal/modal-adapter.service.mjs +20 -15
  6. package/esm2020/lib/modules/modal/modal-close-args.mjs +1 -1
  7. package/esm2020/lib/modules/modal/modal-component-adapter.service.mjs +17 -13
  8. package/esm2020/lib/modules/modal/modal-host-context-args.mjs +2 -0
  9. package/esm2020/lib/modules/modal/modal-host-context.mjs +9 -6
  10. package/esm2020/lib/modules/modal/modal-host.component.mjs +41 -14
  11. package/esm2020/lib/modules/modal/modal-host.service.mjs +21 -15
  12. package/esm2020/lib/modules/modal/modal-instance.mjs +31 -29
  13. package/esm2020/lib/modules/modal/modal-scroll-shadow.directive.mjs +71 -65
  14. package/esm2020/lib/modules/modal/modal.component.mjs +59 -74
  15. package/esm2020/lib/modules/modal/modal.service.mjs +50 -42
  16. package/esm2020/testing/modal-fixture.mjs +60 -84
  17. package/fesm2015/skyux-modals-testing.mjs +60 -83
  18. package/fesm2015/skyux-modals-testing.mjs.map +1 -1
  19. package/fesm2015/skyux-modals.mjs +412 -368
  20. package/fesm2015/skyux-modals.mjs.map +1 -1
  21. package/fesm2020/skyux-modals-testing.mjs +60 -83
  22. package/fesm2020/skyux-modals-testing.mjs.map +1 -1
  23. package/fesm2020/skyux-modals.mjs +409 -368
  24. package/fesm2020/skyux-modals.mjs.map +1 -1
  25. package/lib/modules/confirm/confirm-config-token.d.ts +6 -0
  26. package/lib/modules/confirm/confirm.component.d.ts +6 -12
  27. package/lib/modules/confirm/confirm.service.d.ts +1 -1
  28. package/lib/modules/modal/modal-adapter.service.d.ts +1 -5
  29. package/lib/modules/modal/modal-close-args.d.ts +1 -1
  30. package/lib/modules/modal/modal-component-adapter.service.d.ts +1 -2
  31. package/lib/modules/modal/modal-host-context-args.d.ts +7 -0
  32. package/lib/modules/modal/modal-host-context.d.ts +3 -2
  33. package/lib/modules/modal/modal-host.component.d.ts +1 -6
  34. package/lib/modules/modal/modal-host.service.d.ts +2 -2
  35. package/lib/modules/modal/modal-instance.d.ts +1 -5
  36. package/lib/modules/modal/modal-scroll-shadow.directive.d.ts +1 -13
  37. package/lib/modules/modal/modal.component.d.ts +12 -23
  38. package/lib/modules/modal/modal.service.d.ts +1 -3
  39. package/package.json +5 -6
  40. package/testing/modal-fixture.d.ts +6 -8
  41. package/esm2020/lib/modules/confirm/confirm-modal-context.mjs +0 -6
  42. package/esm2020/lib/modules/modal/modal-state-animation.mjs +0 -8
  43. package/lib/modules/confirm/confirm-modal-context.d.ts +0 -13
  44. 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.elRef = elRef;
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.ngUnsubscribe = new Subject();
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.checkForShadow();
34
+ __classPrivateFieldGet(this, _SkyModalScrollShadowDirective_instances, "m", _SkyModalScrollShadowDirective_checkForShadow).call(this);
25
35
  }
26
36
  scroll() {
27
- this.checkForShadow();
37
+ __classPrivateFieldGet(this, _SkyModalScrollShadowDirective_instances, "m", _SkyModalScrollShadowDirective_checkForShadow).call(this);
28
38
  }
29
39
  ngOnInit() {
30
- if (this.themeSvc) {
31
- this.themeSvc.settingsChange
32
- .pipe(takeUntil(this.ngUnsubscribe))
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.currentTheme = themeSettings.currentSettings.theme;
35
- if (this.currentTheme === SkyTheme.presets.modern) {
36
- this.initMutationObserver();
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.emitShadow({
49
+ __classPrivateFieldGet(this, _SkyModalScrollShadowDirective_instances, "m", _SkyModalScrollShadowDirective_emitShadow).call(this, {
40
50
  bottomShadow: 'none',
41
51
  topShadow: 'none',
42
52
  });
43
- this.destroyMutationObserver();
53
+ __classPrivateFieldGet(this, _SkyModalScrollShadowDirective_instances, "m", _SkyModalScrollShadowDirective_destroyMutationObserver).call(this);
44
54
  }
45
55
  });
46
56
  }
47
57
  }
48
58
  ngOnDestroy() {
49
- this.ngUnsubscribe.next();
50
- this.ngUnsubscribe.complete();
51
- this.destroyMutationObserver();
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
- initMutationObserver() {
54
- if (!this.mutationObserver) {
55
- const el = this.elRef.nativeElement;
56
- // MutationObserver is patched by Zone.js and therefore becomes part of the
57
- // Angular change detection cycle, but this can lead to infinite loops in some
58
- // secnarios. This will keep MutationObserver from triggering change detection.
59
- this.ngZone.runOutsideAngular(() => {
60
- this.mutationObserver = this.mutationObserverSvc.create(() => {
61
- this.checkForShadow();
62
- });
63
- this.mutationObserver.observe(el, {
64
- attributes: true,
65
- characterData: true,
66
- childList: true,
67
- subtree: true,
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
- checkForShadow() {
79
- if (this.currentTheme === SkyTheme.presets.modern) {
80
- const el = this.elRef.nativeElement;
81
- const topShadow = this.buildShadowStyle(el.scrollTop);
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
- buildShadowStyle(pixelsFromEnd) {
90
- // Progressively darken the shadow until the user scrolls 30 pixels from the top or bottom
91
- // of the scrollable element, with a max opacity of 0.3.
92
- const opacity = Math.min(pixelsFromEnd / 30, 1) * 0.3;
93
- return opacity > 0 ? `0px 1px 8px 0px rgba(0, 0, 0, ${opacity})` : 'none';
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
- emitShadow(shadow) {
96
- if (!this.currentShadow ||
97
- this.currentShadow.bottomShadow !== shadow.bottomShadow ||
98
- this.currentShadow.topShadow !== shadow.topShadow) {
99
- this.skyModalScrollShadow.emit(shadow);
100
- this.currentShadow = shadow;
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":"AAAA,OAAO,EACL,SAAS,EACT,UAAU,EACV,YAAY,EACZ,YAAY,EACZ,MAAM,EAGN,QAAQ,EACR,MAAM,GACP,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,uBAAuB,EAAE,MAAM,aAAa,CAAC;AACtD,OAAO,EAAE,QAAQ,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;AAEzD,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAC/B,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;;;;AAI3C;;;;GAIG;AAIH,MAAM,OAAO,6BAA6B;IAYxC,YACU,KAAiB,EACjB,mBAA4C,EAC5C,MAAc,EACF,QAA0B;QAHtC,UAAK,GAAL,KAAK,CAAY;QACjB,wBAAmB,GAAnB,mBAAmB,CAAyB;QAC5C,WAAM,GAAN,MAAM,CAAQ;QACF,aAAQ,GAAR,QAAQ,CAAkB;QAdzC,yBAAoB,GAAG,IAAI,YAAY,EAAiC,CAAC;QAQxE,kBAAa,GAAG,IAAI,OAAO,EAAQ,CAAC;IAOzC,CAAC;IAGG,YAAY;QACjB,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;IAGM,MAAM;QACX,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;IAEM,QAAQ;QACb,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,IAAI,CAAC,QAAQ,CAAC,cAAc;iBACzB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;iBACnC,SAAS,CAAC,CAAC,aAAa,EAAE,EAAE;gBAC3B,IAAI,CAAC,YAAY,GAAG,aAAa,CAAC,eAAe,CAAC,KAAK,CAAC;gBAExD,IAAI,IAAI,CAAC,YAAY,KAAK,QAAQ,CAAC,OAAO,CAAC,MAAM,EAAE;oBACjD,IAAI,CAAC,oBAAoB,EAAE,CAAC;iBAC7B;qBAAM;oBACL,IAAI,CAAC,UAAU,CAAC;wBACd,YAAY,EAAE,MAAM;wBACpB,SAAS,EAAE,MAAM;qBAClB,CAAC,CAAC;oBAEH,IAAI,CAAC,uBAAuB,EAAE,CAAC;iBAChC;YACH,CAAC,CAAC,CAAC;SACN;IACH,CAAC;IAEM,WAAW;QAChB,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC;QAC1B,IAAI,CAAC,aAAa,CAAC,QAAQ,EAAE,CAAC;QAE9B,IAAI,CAAC,uBAAuB,EAAE,CAAC;IACjC,CAAC;IAEO,oBAAoB;QAC1B,IAAI,CAAC,IAAI,CAAC,gBAAgB,EAAE;YAC1B,MAAM,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC;YAEpC,2EAA2E;YAC3E,8EAA8E;YAC9E,+EAA+E;YAC/E,IAAI,CAAC,MAAM,CAAC,iBAAiB,CAAC,GAAG,EAAE;gBACjC,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAAC,GAAG,EAAE;oBAC3D,IAAI,CAAC,cAAc,EAAE,CAAC;gBACxB,CAAC,CAAC,CAAC;gBAEH,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,EAAE,EAAE;oBAChC,UAAU,EAAE,IAAI;oBAChB,aAAa,EAAE,IAAI;oBACnB,SAAS,EAAE,IAAI;oBACf,OAAO,EAAE,IAAI;iBACd,CAAC,CAAC;YACL,CAAC,CAAC,CAAC;SACJ;IACH,CAAC;IAEO,uBAAuB;QAC7B,IAAI,IAAI,CAAC,gBAAgB,EAAE;YACzB,IAAI,CAAC,gBAAgB,CAAC,UAAU,EAAE,CAAC;YACnC,IAAI,CAAC,gBAAgB,GAAG,SAAS,CAAC;SACnC;IACH,CAAC;IAEO,cAAc;QACpB,IAAI,IAAI,CAAC,YAAY,KAAK,QAAQ,CAAC,OAAO,CAAC,MAAM,EAAE;YACjD,MAAM,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC;YAEpC,MAAM,SAAS,GAAG,IAAI,CAAC,gBAAgB,CAAC,EAAE,CAAC,SAAS,CAAC,CAAC;YAEtD,MAAM,YAAY,GAAG,IAAI,CAAC,gBAAgB,CACxC,EAAE,CAAC,YAAY,GAAG,EAAE,CAAC,SAAS,GAAG,EAAE,CAAC,YAAY,CACjD,CAAC;YAEF,IAAI,CAAC,UAAU,CAAC;gBACd,YAAY;gBACZ,SAAS;aACV,CAAC,CAAC;SACJ;IACH,CAAC;IAEO,gBAAgB,CAAC,aAAqB;QAC5C,0FAA0F;QAC1F,wDAAwD;QACxD,MAAM,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,aAAa,GAAG,EAAE,EAAE,CAAC,CAAC,GAAG,GAAG,CAAC;QAEtD,OAAO,OAAO,GAAG,CAAC,CAAC,CAAC,CAAC,iCAAiC,OAAO,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC;IAC5E,CAAC;IAEO,UAAU,CAAC,MAAqC;QACtD,IACE,CAAC,IAAI,CAAC,aAAa;YACnB,IAAI,CAAC,aAAa,CAAC,YAAY,KAAK,MAAM,CAAC,YAAY;YACvD,IAAI,CAAC,aAAa,CAAC,SAAS,KAAK,MAAM,CAAC,SAAS,EACjD;YACA,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YACvC,IAAI,CAAC,aAAa,GAAG,MAAM,CAAC;SAC7B;IACH,CAAC;;0HAxHU,6BAA6B;8GAA7B,6BAA6B;2FAA7B,6BAA6B;kBAHzC,SAAS;mBAAC;oBACT,QAAQ,EAAE,wBAAwB;iBACnC;;0BAiBI,QAAQ;4CAdJ,oBAAoB;sBAD1B,MAAM;gBAmBA,YAAY;sBADlB,YAAY;uBAAC,eAAe;gBAMtB,MAAM;sBADZ,YAAY;uBAAC,QAAQ","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"]}