@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.
Files changed (79) hide show
  1. package/documentation.json +1042 -892
  2. package/esm2020/lib/modules/adapter-service/adapter.service.mjs +21 -22
  3. package/esm2020/lib/modules/affix/affix-offset.mjs +1 -1
  4. package/esm2020/lib/modules/affix/affix.directive.mjs +38 -23
  5. package/esm2020/lib/modules/affix/affixer.mjs +266 -260
  6. package/esm2020/lib/modules/affix/dom-utils.mjs +7 -7
  7. package/esm2020/lib/modules/dock/dock-dom-adapter.service.mjs +48 -44
  8. package/esm2020/lib/modules/dock/dock-item.mjs +10 -5
  9. package/esm2020/lib/modules/dock/dock.component.mjs +55 -31
  10. package/esm2020/lib/modules/dock/dock.service.mjs +40 -36
  11. package/esm2020/lib/modules/dynamic-component/dynamic-component.service.mjs +37 -22
  12. package/esm2020/lib/modules/log/log.service.mjs +37 -37
  13. package/esm2020/lib/modules/media-query/media-query.service.mjs +50 -47
  14. package/esm2020/lib/modules/mutation/mutation-observer-service.mjs +3 -1
  15. package/esm2020/lib/modules/numeric/numeric.pipe.mjs +26 -19
  16. package/esm2020/lib/modules/numeric/numeric.service.mjs +84 -99
  17. package/esm2020/lib/modules/overlay/overlay-adapter.service.mjs +23 -17
  18. package/esm2020/lib/modules/overlay/overlay-instance.mjs +18 -9
  19. package/esm2020/lib/modules/overlay/overlay.component.mjs +79 -55
  20. package/esm2020/lib/modules/overlay/overlay.service.mjs +55 -49
  21. package/esm2020/lib/modules/percent-pipe/percent.pipe.mjs +32 -21
  22. package/esm2020/lib/modules/resize-observer/resize-observer-media-query.service.mjs +38 -46
  23. package/esm2020/lib/modules/scrollable-host/scrollable-host.service.mjs +66 -67
  24. package/esm2020/lib/modules/title/title.service.mjs +8 -4
  25. package/esm2020/lib/modules/trim/trim.directive.mjs +10 -11
  26. package/esm2020/lib/modules/viewkeeper/viewkeeper-boundary-info.mjs +1 -1
  27. package/esm2020/lib/modules/viewkeeper/viewkeeper.directive.mjs +75 -60
  28. package/esm2020/lib/modules/viewkeeper/viewkeeper.mjs +166 -156
  29. package/esm2020/lib/modules/viewkeeper/viewkeeper.service.mjs +7 -3
  30. package/esm2020/testing/core-testing.module.mjs +4 -1
  31. package/esm2020/testing/mock-media-query.service.mjs +4 -1
  32. package/esm2020/testing/mock-ui-config.service.mjs +4 -1
  33. package/esm2020/testing/overlay/overlay-harness-filters.mjs +1 -1
  34. package/esm2020/testing/overlay/overlay-harness.mjs +2 -1
  35. package/esm2020/testing/shared/component-harness.mjs +4 -1
  36. package/esm2020/testing/shared/harness-filters.mjs +1 -1
  37. package/fesm2015/skyux-core-testing.mjs +13 -0
  38. package/fesm2015/skyux-core-testing.mjs.map +1 -1
  39. package/fesm2015/skyux-core.mjs +1276 -1151
  40. package/fesm2015/skyux-core.mjs.map +1 -1
  41. package/fesm2020/skyux-core-testing.mjs +13 -0
  42. package/fesm2020/skyux-core-testing.mjs.map +1 -1
  43. package/fesm2020/skyux-core.mjs +1278 -1150
  44. package/fesm2020/skyux-core.mjs.map +1 -1
  45. package/lib/modules/adapter-service/adapter.service.d.ts +3 -5
  46. package/lib/modules/affix/affix-offset.d.ts +1 -1
  47. package/lib/modules/affix/affix.directive.d.ts +12 -13
  48. package/lib/modules/affix/affixer.d.ts +2 -34
  49. package/lib/modules/affix/dom-utils.d.ts +3 -3
  50. package/lib/modules/dock/dock-dom-adapter.service.d.ts +2 -9
  51. package/lib/modules/dock/dock-item.d.ts +1 -1
  52. package/lib/modules/dock/dock.component.d.ts +2 -10
  53. package/lib/modules/dock/dock.service.d.ts +2 -5
  54. package/lib/modules/dynamic-component/dynamic-component.service.d.ts +2 -7
  55. package/lib/modules/log/log.service.d.ts +2 -6
  56. package/lib/modules/media-query/media-query.service.d.ts +1 -8
  57. package/lib/modules/numeric/numeric.pipe.d.ts +2 -8
  58. package/lib/modules/numeric/numeric.service.d.ts +3 -36
  59. package/lib/modules/overlay/overlay-adapter.service.d.ts +1 -3
  60. package/lib/modules/overlay/overlay-instance.d.ts +1 -2
  61. package/lib/modules/overlay/overlay.component.d.ts +1 -14
  62. package/lib/modules/overlay/overlay.service.d.ts +1 -7
  63. package/lib/modules/percent-pipe/percent.pipe.d.ts +2 -9
  64. package/lib/modules/resize-observer/resize-observer-media-query.service.d.ts +2 -7
  65. package/lib/modules/scrollable-host/scrollable-host.service.d.ts +2 -11
  66. package/lib/modules/title/title.service.d.ts +2 -2
  67. package/lib/modules/trim/trim.directive.d.ts +0 -2
  68. package/lib/modules/viewkeeper/viewkeeper-boundary-info.d.ts +1 -1
  69. package/lib/modules/viewkeeper/viewkeeper.d.ts +2 -24
  70. package/lib/modules/viewkeeper/viewkeeper.directive.d.ts +4 -16
  71. package/lib/modules/viewkeeper/viewkeeper.service.d.ts +1 -1
  72. package/package.json +2 -2
  73. package/testing/core-testing.module.d.ts +3 -0
  74. package/testing/mock-media-query.service.d.ts +3 -0
  75. package/testing/mock-ui-config.service.d.ts +3 -0
  76. package/testing/overlay/overlay-harness-filters.d.ts +1 -0
  77. package/testing/overlay/overlay-harness.d.ts +1 -0
  78. package/testing/shared/component-harness.d.ts +3 -0
  79. package/testing/shared/harness-filters.d.ts +1 -0
@@ -1,4 +1,4 @@
1
- var _SkyTrimDirective_instances, _SkyTrimDirective_obs, _SkyTrimDirective_observe, _SkyTrimDirective_disconnect, _SkyTrimDirective_trim;
1
+ var _SkyTrimDirective_instances, _SkyTrimDirective_elRef, _SkyTrimDirective_obs, _SkyTrimDirective_observe, _SkyTrimDirective_disconnect, _SkyTrimDirective_trim;
2
2
  import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
3
3
  import { Directive, ElementRef } from '@angular/core';
4
4
  import { MutationObserverService } from '../mutation/mutation-observer-service';
@@ -9,15 +9,15 @@ import * as i1 from "../mutation/mutation-observer-service";
9
9
  */
10
10
  export class SkyTrimDirective {
11
11
  constructor(elRef, mutationObs) {
12
- this.elRef = elRef;
13
- this.mutationObs = mutationObs;
14
12
  _SkyTrimDirective_instances.add(this);
13
+ _SkyTrimDirective_elRef.set(this, void 0);
15
14
  _SkyTrimDirective_obs.set(this, void 0);
16
- __classPrivateFieldSet(this, _SkyTrimDirective_obs, this.mutationObs.create((mutations) => {
15
+ __classPrivateFieldSet(this, _SkyTrimDirective_elRef, elRef, "f");
16
+ __classPrivateFieldSet(this, _SkyTrimDirective_obs, mutationObs.create((mutations) => {
17
17
  const nodes = [];
18
18
  // Only trim white space inside direct descendents of the current element.
19
19
  for (const mutation of mutations) {
20
- if (mutation.target.parentNode === this.elRef.nativeElement) {
20
+ if (mutation.target.parentNode === elRef.nativeElement) {
21
21
  nodes.push(mutation.target);
22
22
  }
23
23
  }
@@ -26,16 +26,15 @@ export class SkyTrimDirective {
26
26
  __classPrivateFieldGet(this, _SkyTrimDirective_instances, "m", _SkyTrimDirective_observe).call(this);
27
27
  }
28
28
  ngOnInit() {
29
- const el = this.elRef.nativeElement;
29
+ const el = __classPrivateFieldGet(this, _SkyTrimDirective_elRef, "f").nativeElement;
30
30
  __classPrivateFieldGet(this, _SkyTrimDirective_instances, "m", _SkyTrimDirective_trim).call(this, Array.from(el.childNodes));
31
31
  }
32
32
  ngOnDestroy() {
33
33
  __classPrivateFieldGet(this, _SkyTrimDirective_instances, "m", _SkyTrimDirective_disconnect).call(this);
34
- __classPrivateFieldSet(this, _SkyTrimDirective_obs, undefined, "f");
35
34
  }
36
35
  }
37
- _SkyTrimDirective_obs = new WeakMap(), _SkyTrimDirective_instances = new WeakSet(), _SkyTrimDirective_observe = function _SkyTrimDirective_observe() {
38
- __classPrivateFieldGet(this, _SkyTrimDirective_obs, "f").observe(this.elRef.nativeElement, {
36
+ _SkyTrimDirective_elRef = new WeakMap(), _SkyTrimDirective_obs = new WeakMap(), _SkyTrimDirective_instances = new WeakSet(), _SkyTrimDirective_observe = function _SkyTrimDirective_observe() {
37
+ __classPrivateFieldGet(this, _SkyTrimDirective_obs, "f").observe(__classPrivateFieldGet(this, _SkyTrimDirective_elRef, "f").nativeElement, {
39
38
  characterData: true,
40
39
  subtree: true,
41
40
  });
@@ -46,7 +45,7 @@ _SkyTrimDirective_obs = new WeakMap(), _SkyTrimDirective_instances = new WeakSet
46
45
  // doesn't retrigger the observe callback.
47
46
  __classPrivateFieldGet(this, _SkyTrimDirective_instances, "m", _SkyTrimDirective_disconnect).call(this);
48
47
  for (const node of nodes) {
49
- if (node.nodeType === Node.TEXT_NODE) {
48
+ if (node.nodeType === Node.TEXT_NODE && node.textContent) {
50
49
  const textContent = node.textContent;
51
50
  const textContentTrimmed = textContent.trim();
52
51
  if (textContent !== textContentTrimmed) {
@@ -64,4 +63,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImpor
64
63
  selector: '[skyTrim]',
65
64
  }]
66
65
  }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.MutationObserverService }]; } });
67
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJpbS5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvY29yZS9zcmMvbGliL21vZHVsZXMvdHJpbS90cmltLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsVUFBVSxFQUFxQixNQUFNLGVBQWUsQ0FBQztBQUV6RSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSx1Q0FBdUMsQ0FBQzs7O0FBRWhGOztHQUVHO0FBSUgsTUFBTSxPQUFPLGdCQUFnQjtJQUczQixZQUNVLEtBQWlCLEVBQ2pCLFdBQW9DO1FBRHBDLFVBQUssR0FBTCxLQUFLLENBQVk7UUFDakIsZ0JBQVcsR0FBWCxXQUFXLENBQXlCOztRQUo5Qyx3Q0FBdUI7UUFNckIsdUJBQUEsSUFBSSx5QkFBUSxJQUFJLENBQUMsV0FBVyxDQUFDLE1BQU0sQ0FBQyxDQUFDLFNBQTJCLEVBQUUsRUFBRTtZQUNsRSxNQUFNLEtBQUssR0FBVyxFQUFFLENBQUM7WUFFekIsMEVBQTBFO1lBQzFFLEtBQUssTUFBTSxRQUFRLElBQUksU0FBUyxFQUFFO2dCQUNoQyxJQUFJLFFBQVEsQ0FBQyxNQUFNLENBQUMsVUFBVSxLQUFLLElBQUksQ0FBQyxLQUFLLENBQUMsYUFBYSxFQUFFO29CQUMzRCxLQUFLLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUMsQ0FBQztpQkFDN0I7YUFDRjtZQUVELHVCQUFBLElBQUksMkRBQU0sTUFBVixJQUFJLEVBQU8sS0FBSyxDQUFDLENBQUM7UUFDcEIsQ0FBQyxDQUFDLE1BQUEsQ0FBQztRQUVILHVCQUFBLElBQUksOERBQVMsTUFBYixJQUFJLENBQVcsQ0FBQztJQUNsQixDQUFDO0lBRU0sUUFBUTtRQUNiLE1BQU0sRUFBRSxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsYUFBd0IsQ0FBQztRQUMvQyx1QkFBQSxJQUFJLDJEQUFNLE1BQVYsSUFBSSxFQUFPLEtBQUssQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUM7SUFDeEMsQ0FBQztJQUVNLFdBQVc7UUFDaEIsdUJBQUEsSUFBSSxpRUFBWSxNQUFoQixJQUFJLENBQWMsQ0FBQztRQUNuQix1QkFBQSxJQUFJLHlCQUFRLFNBQVMsTUFBQSxDQUFDO0lBQ3hCLENBQUM7OztJQUdDLHVCQUFBLElBQUksNkJBQUssQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxhQUFhLEVBQUU7UUFDMUMsYUFBYSxFQUFFLElBQUk7UUFDbkIsT0FBTyxFQUFFLElBQUk7S0FDZCxDQUFDLENBQUM7QUFDTCxDQUFDO0lBR0MsdUJBQUEsSUFBSSw2QkFBSyxDQUFDLFVBQVUsRUFBRSxDQUFDO0FBQ3pCLENBQUMsMkRBRUssS0FBYTtJQUNqQix5RUFBeUU7SUFDekUsMENBQTBDO0lBQzFDLHVCQUFBLElBQUksaUVBQVksTUFBaEIsSUFBSSxDQUFjLENBQUM7SUFFbkIsS0FBSyxNQUFNLElBQUksSUFBSSxLQUFLLEVBQUU7UUFDeEIsSUFBSSxJQUFJLENBQUMsUUFBUSxLQUFLLElBQUksQ0FBQyxTQUFTLEVBQUU7WUFDcEMsTUFBTSxXQUFXLEdBQUcsSUFBSSxDQUFDLFdBQVcsQ0FBQztZQUNyQyxNQUFNLGtCQUFrQixHQUFHLFdBQVcsQ0FBQyxJQUFJLEVBQUUsQ0FBQztZQUU5QyxJQUFJLFdBQVcsS0FBSyxrQkFBa0IsRUFBRTtnQkFDdEMsSUFBSSxDQUFDLFdBQVcsR0FBRyxrQkFBa0IsQ0FBQzthQUN2QztTQUNGO0tBQ0Y7SUFFRCx1QkFBQSxJQUFJLDhEQUFTLE1BQWIsSUFBSSxDQUFXLENBQUM7QUFDbEIsQ0FBQzs2R0E3RFUsZ0JBQWdCO2lHQUFoQixnQkFBZ0I7MkZBQWhCLGdCQUFnQjtrQkFINUIsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsV0FBVztpQkFDdEIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIEVsZW1lbnRSZWYsIE9uRGVzdHJveSwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IE11dGF0aW9uT2JzZXJ2ZXJTZXJ2aWNlIH0gZnJvbSAnLi4vbXV0YXRpb24vbXV0YXRpb24tb2JzZXJ2ZXItc2VydmljZSc7XG5cbi8qKlxuICogVHJpbXMgd2hpdGVzcGFjZSBpbiBlYWNoIHRleHQgbm9kZSB0aGF0IGlzIGEgZGlyZWN0IGRlc2NlbmRlbnQgb2YgdGhlIGN1cnJlbnQgZWxlbWVudC5cbiAqL1xuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnW3NreVRyaW1dJyxcbn0pXG5leHBvcnQgY2xhc3MgU2t5VHJpbURpcmVjdGl2ZSBpbXBsZW1lbnRzIE9uSW5pdCwgT25EZXN0cm95IHtcbiAgI29iczogTXV0YXRpb25PYnNlcnZlcjtcblxuICBjb25zdHJ1Y3RvcihcbiAgICBwcml2YXRlIGVsUmVmOiBFbGVtZW50UmVmLFxuICAgIHByaXZhdGUgbXV0YXRpb25PYnM6IE11dGF0aW9uT2JzZXJ2ZXJTZXJ2aWNlXG4gICkge1xuICAgIHRoaXMuI29icyA9IHRoaXMubXV0YXRpb25PYnMuY3JlYXRlKChtdXRhdGlvbnM6IE11dGF0aW9uUmVjb3JkW10pID0+IHtcbiAgICAgIGNvbnN0IG5vZGVzOiBOb2RlW10gPSBbXTtcblxuICAgICAgLy8gT25seSB0cmltIHdoaXRlIHNwYWNlIGluc2lkZSBkaXJlY3QgZGVzY2VuZGVudHMgb2YgdGhlIGN1cnJlbnQgZWxlbWVudC5cbiAgICAgIGZvciAoY29uc3QgbXV0YXRpb24gb2YgbXV0YXRpb25zKSB7XG4gICAgICAgIGlmIChtdXRhdGlvbi50YXJnZXQucGFyZW50Tm9kZSA9PT0gdGhpcy5lbFJlZi5uYXRpdmVFbGVtZW50KSB7XG4gICAgICAgICAgbm9kZXMucHVzaChtdXRhdGlvbi50YXJnZXQpO1xuICAgICAgICB9XG4gICAgICB9XG5cbiAgICAgIHRoaXMuI3RyaW0obm9kZXMpO1xuICAgIH0pO1xuXG4gICAgdGhpcy4jb2JzZXJ2ZSgpO1xuICB9XG5cbiAgcHVibGljIG5nT25Jbml0KCk6IHZvaWQge1xuICAgIGNvbnN0IGVsID0gdGhpcy5lbFJlZi5uYXRpdmVFbGVtZW50IGFzIEVsZW1lbnQ7XG4gICAgdGhpcy4jdHJpbShBcnJheS5mcm9tKGVsLmNoaWxkTm9kZXMpKTtcbiAgfVxuXG4gIHB1YmxpYyBuZ09uRGVzdHJveSgpOiB2b2lkIHtcbiAgICB0aGlzLiNkaXNjb25uZWN0KCk7XG4gICAgdGhpcy4jb2JzID0gdW5kZWZpbmVkO1xuICB9XG5cbiAgI29ic2VydmUoKTogdm9pZCB7XG4gICAgdGhpcy4jb2JzLm9ic2VydmUodGhpcy5lbFJlZi5uYXRpdmVFbGVtZW50LCB7XG4gICAgICBjaGFyYWN0ZXJEYXRhOiB0cnVlLFxuICAgICAgc3VidHJlZTogdHJ1ZSxcbiAgICB9KTtcbiAgfVxuXG4gICNkaXNjb25uZWN0KCk6IHZvaWQge1xuICAgIHRoaXMuI29icy5kaXNjb25uZWN0KCk7XG4gIH1cblxuICAjdHJpbShub2RlczogTm9kZVtdKTogdm9pZCB7XG4gICAgLy8gU3VzcGVuZCB0aGUgTXV0YXRpb25PYnNlcnZlciBzbyBhbHRlcmluZyB0aGUgdGV4dCBjb250ZW50IG9mIGVhY2ggbm9kZVxuICAgIC8vIGRvZXNuJ3QgcmV0cmlnZ2VyIHRoZSBvYnNlcnZlIGNhbGxiYWNrLlxuICAgIHRoaXMuI2Rpc2Nvbm5lY3QoKTtcblxuICAgIGZvciAoY29uc3Qgbm9kZSBvZiBub2Rlcykge1xuICAgICAgaWYgKG5vZGUubm9kZVR5cGUgPT09IE5vZGUuVEVYVF9OT0RFKSB7XG4gICAgICAgIGNvbnN0IHRleHRDb250ZW50ID0gbm9kZS50ZXh0Q29udGVudDtcbiAgICAgICAgY29uc3QgdGV4dENvbnRlbnRUcmltbWVkID0gdGV4dENvbnRlbnQudHJpbSgpO1xuXG4gICAgICAgIGlmICh0ZXh0Q29udGVudCAhPT0gdGV4dENvbnRlbnRUcmltbWVkKSB7XG4gICAgICAgICAgbm9kZS50ZXh0Q29udGVudCA9IHRleHRDb250ZW50VHJpbW1lZDtcbiAgICAgICAgfVxuICAgICAgfVxuICAgIH1cblxuICAgIHRoaXMuI29ic2VydmUoKTtcbiAgfVxufVxuIl19
66
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJpbS5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvY29yZS9zcmMvbGliL21vZHVsZXMvdHJpbS90cmltLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsVUFBVSxFQUFxQixNQUFNLGVBQWUsQ0FBQztBQUV6RSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSx1Q0FBdUMsQ0FBQzs7O0FBRWhGOztHQUVHO0FBSUgsTUFBTSxPQUFPLGdCQUFnQjtJQUszQixZQUFZLEtBQWlCLEVBQUUsV0FBb0M7O1FBSm5FLDBDQUFtQjtRQUVuQix3Q0FBdUI7UUFHckIsdUJBQUEsSUFBSSwyQkFBVSxLQUFLLE1BQUEsQ0FBQztRQUVwQix1QkFBQSxJQUFJLHlCQUFRLFdBQVcsQ0FBQyxNQUFNLENBQUMsQ0FBQyxTQUEyQixFQUFFLEVBQUU7WUFDN0QsTUFBTSxLQUFLLEdBQVcsRUFBRSxDQUFDO1lBRXpCLDBFQUEwRTtZQUMxRSxLQUFLLE1BQU0sUUFBUSxJQUFJLFNBQVMsRUFBRTtnQkFDaEMsSUFBSSxRQUFRLENBQUMsTUFBTSxDQUFDLFVBQVUsS0FBSyxLQUFLLENBQUMsYUFBYSxFQUFFO29CQUN0RCxLQUFLLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUMsQ0FBQztpQkFDN0I7YUFDRjtZQUVELHVCQUFBLElBQUksMkRBQU0sTUFBVixJQUFJLEVBQU8sS0FBSyxDQUFDLENBQUM7UUFDcEIsQ0FBQyxDQUFDLE1BQUEsQ0FBQztRQUVILHVCQUFBLElBQUksOERBQVMsTUFBYixJQUFJLENBQVcsQ0FBQztJQUNsQixDQUFDO0lBRU0sUUFBUTtRQUNiLE1BQU0sRUFBRSxHQUFHLHVCQUFBLElBQUksK0JBQU8sQ0FBQyxhQUF3QixDQUFDO1FBQ2hELHVCQUFBLElBQUksMkRBQU0sTUFBVixJQUFJLEVBQU8sS0FBSyxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQztJQUN4QyxDQUFDO0lBRU0sV0FBVztRQUNoQix1QkFBQSxJQUFJLGlFQUFZLE1BQWhCLElBQUksQ0FBYyxDQUFDO0lBQ3JCLENBQUM7OztJQUdDLHVCQUFBLElBQUksNkJBQUssQ0FBQyxPQUFPLENBQUMsdUJBQUEsSUFBSSwrQkFBTyxDQUFDLGFBQWEsRUFBRTtRQUMzQyxhQUFhLEVBQUUsSUFBSTtRQUNuQixPQUFPLEVBQUUsSUFBSTtLQUNkLENBQUMsQ0FBQztBQUNMLENBQUM7SUFHQyx1QkFBQSxJQUFJLDZCQUFLLENBQUMsVUFBVSxFQUFFLENBQUM7QUFDekIsQ0FBQywyREFFSyxLQUFhO0lBQ2pCLHlFQUF5RTtJQUN6RSwwQ0FBMEM7SUFDMUMsdUJBQUEsSUFBSSxpRUFBWSxNQUFoQixJQUFJLENBQWMsQ0FBQztJQUVuQixLQUFLLE1BQU0sSUFBSSxJQUFJLEtBQUssRUFBRTtRQUN4QixJQUFJLElBQUksQ0FBQyxRQUFRLEtBQUssSUFBSSxDQUFDLFNBQVMsSUFBSSxJQUFJLENBQUMsV0FBVyxFQUFFO1lBQ3hELE1BQU0sV0FBVyxHQUFHLElBQUksQ0FBQyxXQUFXLENBQUM7WUFDckMsTUFBTSxrQkFBa0IsR0FBRyxXQUFXLENBQUMsSUFBSSxFQUFFLENBQUM7WUFFOUMsSUFBSSxXQUFXLEtBQUssa0JBQWtCLEVBQUU7Z0JBQ3RDLElBQUksQ0FBQyxXQUFXLEdBQUcsa0JBQWtCLENBQUM7YUFDdkM7U0FDRjtLQUNGO0lBRUQsdUJBQUEsSUFBSSw4REFBUyxNQUFiLElBQUksQ0FBVyxDQUFDO0FBQ2xCLENBQUM7NkdBN0RVLGdCQUFnQjtpR0FBaEIsZ0JBQWdCOzJGQUFoQixnQkFBZ0I7a0JBSDVCLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLFdBQVc7aUJBQ3RCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBFbGVtZW50UmVmLCBPbkRlc3Ryb3ksIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBNdXRhdGlvbk9ic2VydmVyU2VydmljZSB9IGZyb20gJy4uL211dGF0aW9uL211dGF0aW9uLW9ic2VydmVyLXNlcnZpY2UnO1xuXG4vKipcbiAqIFRyaW1zIHdoaXRlc3BhY2UgaW4gZWFjaCB0ZXh0IG5vZGUgdGhhdCBpcyBhIGRpcmVjdCBkZXNjZW5kZW50IG9mIHRoZSBjdXJyZW50IGVsZW1lbnQuXG4gKi9cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ1tza3lUcmltXScsXG59KVxuZXhwb3J0IGNsYXNzIFNreVRyaW1EaXJlY3RpdmUgaW1wbGVtZW50cyBPbkluaXQsIE9uRGVzdHJveSB7XG4gICNlbFJlZjogRWxlbWVudFJlZjtcblxuICAjb2JzOiBNdXRhdGlvbk9ic2VydmVyO1xuXG4gIGNvbnN0cnVjdG9yKGVsUmVmOiBFbGVtZW50UmVmLCBtdXRhdGlvbk9iczogTXV0YXRpb25PYnNlcnZlclNlcnZpY2UpIHtcbiAgICB0aGlzLiNlbFJlZiA9IGVsUmVmO1xuXG4gICAgdGhpcy4jb2JzID0gbXV0YXRpb25PYnMuY3JlYXRlKChtdXRhdGlvbnM6IE11dGF0aW9uUmVjb3JkW10pID0+IHtcbiAgICAgIGNvbnN0IG5vZGVzOiBOb2RlW10gPSBbXTtcblxuICAgICAgLy8gT25seSB0cmltIHdoaXRlIHNwYWNlIGluc2lkZSBkaXJlY3QgZGVzY2VuZGVudHMgb2YgdGhlIGN1cnJlbnQgZWxlbWVudC5cbiAgICAgIGZvciAoY29uc3QgbXV0YXRpb24gb2YgbXV0YXRpb25zKSB7XG4gICAgICAgIGlmIChtdXRhdGlvbi50YXJnZXQucGFyZW50Tm9kZSA9PT0gZWxSZWYubmF0aXZlRWxlbWVudCkge1xuICAgICAgICAgIG5vZGVzLnB1c2gobXV0YXRpb24udGFyZ2V0KTtcbiAgICAgICAgfVxuICAgICAgfVxuXG4gICAgICB0aGlzLiN0cmltKG5vZGVzKTtcbiAgICB9KTtcblxuICAgIHRoaXMuI29ic2VydmUoKTtcbiAgfVxuXG4gIHB1YmxpYyBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICBjb25zdCBlbCA9IHRoaXMuI2VsUmVmLm5hdGl2ZUVsZW1lbnQgYXMgRWxlbWVudDtcbiAgICB0aGlzLiN0cmltKEFycmF5LmZyb20oZWwuY2hpbGROb2RlcykpO1xuICB9XG5cbiAgcHVibGljIG5nT25EZXN0cm95KCk6IHZvaWQge1xuICAgIHRoaXMuI2Rpc2Nvbm5lY3QoKTtcbiAgfVxuXG4gICNvYnNlcnZlKCk6IHZvaWQge1xuICAgIHRoaXMuI29icy5vYnNlcnZlKHRoaXMuI2VsUmVmLm5hdGl2ZUVsZW1lbnQsIHtcbiAgICAgIGNoYXJhY3RlckRhdGE6IHRydWUsXG4gICAgICBzdWJ0cmVlOiB0cnVlLFxuICAgIH0pO1xuICB9XG5cbiAgI2Rpc2Nvbm5lY3QoKTogdm9pZCB7XG4gICAgdGhpcy4jb2JzLmRpc2Nvbm5lY3QoKTtcbiAgfVxuXG4gICN0cmltKG5vZGVzOiBOb2RlW10pOiB2b2lkIHtcbiAgICAvLyBTdXNwZW5kIHRoZSBNdXRhdGlvbk9ic2VydmVyIHNvIGFsdGVyaW5nIHRoZSB0ZXh0IGNvbnRlbnQgb2YgZWFjaCBub2RlXG4gICAgLy8gZG9lc24ndCByZXRyaWdnZXIgdGhlIG9ic2VydmUgY2FsbGJhY2suXG4gICAgdGhpcy4jZGlzY29ubmVjdCgpO1xuXG4gICAgZm9yIChjb25zdCBub2RlIG9mIG5vZGVzKSB7XG4gICAgICBpZiAobm9kZS5ub2RlVHlwZSA9PT0gTm9kZS5URVhUX05PREUgJiYgbm9kZS50ZXh0Q29udGVudCkge1xuICAgICAgICBjb25zdCB0ZXh0Q29udGVudCA9IG5vZGUudGV4dENvbnRlbnQ7XG4gICAgICAgIGNvbnN0IHRleHRDb250ZW50VHJpbW1lZCA9IHRleHRDb250ZW50LnRyaW0oKTtcblxuICAgICAgICBpZiAodGV4dENvbnRlbnQgIT09IHRleHRDb250ZW50VHJpbW1lZCkge1xuICAgICAgICAgIG5vZGUudGV4dENvbnRlbnQgPSB0ZXh0Q29udGVudFRyaW1tZWQ7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9XG5cbiAgICB0aGlzLiNvYnNlcnZlKCk7XG4gIH1cbn1cbiJdfQ==
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmlld2tlZXBlci1ib3VuZGFyeS1pbmZvLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL2NvcmUvc3JjL2xpYi9tb2R1bGVzL3ZpZXdrZWVwZXIvdmlld2tlZXBlci1ib3VuZGFyeS1pbmZvLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTa3lWaWV3a2VlcGVyT2Zmc2V0IH0gZnJvbSAnLi92aWV3a2VlcGVyLW9mZnNldCc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgU2t5Vmlld2tlZXBlckJvdW5kYXJ5SW5mbyB7XG4gIGVsSGVpZ2h0OiBudW1iZXI7XG5cbiAgc3BhY2VyRWw6IEhUTUxFbGVtZW50O1xuXG4gIHNwYWNlcklkOiBzdHJpbmc7XG5cbiAgYm91bmRhcnlCb3R0b206IG51bWJlcjtcblxuICBib3VuZGFyeU9mZnNldDogU2t5Vmlld2tlZXBlck9mZnNldDtcblxuICBib3VuZGFyeUVsOiBIVE1MRWxlbWVudDtcblxuICBzY3JvbGxMZWZ0OiBudW1iZXI7XG5cbiAgc2Nyb2xsVG9wOiBudW1iZXI7XG59XG4iXX0=
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmlld2tlZXBlci1ib3VuZGFyeS1pbmZvLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL2NvcmUvc3JjL2xpYi9tb2R1bGVzL3ZpZXdrZWVwZXIvdmlld2tlZXBlci1ib3VuZGFyeS1pbmZvLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTa3lWaWV3a2VlcGVyT2Zmc2V0IH0gZnJvbSAnLi92aWV3a2VlcGVyLW9mZnNldCc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgU2t5Vmlld2tlZXBlckJvdW5kYXJ5SW5mbyB7XG4gIGVsSGVpZ2h0OiBudW1iZXI7XG5cbiAgc3BhY2VyRWw6IEhUTUxFbGVtZW50IHwgbnVsbDtcblxuICBzcGFjZXJJZDogc3RyaW5nO1xuXG4gIGJvdW5kYXJ5Qm90dG9tOiBudW1iZXI7XG5cbiAgYm91bmRhcnlPZmZzZXQ6IFNreVZpZXdrZWVwZXJPZmZzZXQ7XG5cbiAgYm91bmRhcnlFbDogSFRNTEVsZW1lbnQ7XG5cbiAgc2Nyb2xsTGVmdDogbnVtYmVyO1xuXG4gIHNjcm9sbFRvcDogbnVtYmVyO1xufVxuIl19
@@ -1,3 +1,5 @@
1
+ var _SkyViewkeeperDirective_instances, _SkyViewkeeperDirective__skyViewkeeper, _SkyViewkeeperDirective_currentViewkeeperEls, _SkyViewkeeperDirective_el, _SkyViewkeeperDirective_mutationObserverSvc, _SkyViewkeeperDirective_observer, _SkyViewkeeperDirective_scrollableHostSvc, _SkyViewkeeperDirective_scrollableHostWatchUnsubscribe, _SkyViewkeeperDirective_viewkeepers, _SkyViewkeeperDirective_viewkeeperSvc, _SkyViewkeeperDirective_destroyViewkeepers, _SkyViewkeeperDirective_getViewkeeperEls, _SkyViewkeeperDirective_viewkeeperElsChanged, _SkyViewkeeperDirective_detectElements;
2
+ import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
1
3
  import { Directive, ElementRef, Input, Optional, } from '@angular/core';
2
4
  import { Subject } from 'rxjs';
3
5
  import { takeUntil } from 'rxjs/operators';
@@ -9,87 +11,100 @@ import * as i1 from "../mutation/mutation-observer-service";
9
11
  import * as i2 from "./viewkeeper.service";
10
12
  import * as i3 from "../scrollable-host/scrollable-host.service";
11
13
  export class SkyViewkeeperDirective {
12
- constructor(el, mutationObserverSvc, viewkeeperSvc, scrollableHostService) {
13
- this.el = el;
14
- this.mutationObserverSvc = mutationObserverSvc;
15
- this.viewkeeperSvc = viewkeeperSvc;
16
- this.scrollableHostService = scrollableHostService;
17
- this.viewkeepers = [];
18
- this.scrollableHostWatchUnsubscribe = undefined;
14
+ constructor(el, mutationObserverSvc, viewkeeperSvc, scrollableHostSvc) {
15
+ _SkyViewkeeperDirective_instances.add(this);
16
+ _SkyViewkeeperDirective__skyViewkeeper.set(this, void 0);
17
+ _SkyViewkeeperDirective_currentViewkeeperEls.set(this, void 0);
18
+ _SkyViewkeeperDirective_el.set(this, void 0);
19
+ _SkyViewkeeperDirective_mutationObserverSvc.set(this, void 0);
20
+ _SkyViewkeeperDirective_observer.set(this, void 0);
21
+ _SkyViewkeeperDirective_scrollableHostSvc.set(this, void 0);
22
+ _SkyViewkeeperDirective_scrollableHostWatchUnsubscribe.set(this, void 0);
23
+ _SkyViewkeeperDirective_viewkeepers.set(this, []);
24
+ _SkyViewkeeperDirective_viewkeeperSvc.set(this, void 0);
25
+ __classPrivateFieldSet(this, _SkyViewkeeperDirective_el, el, "f");
26
+ __classPrivateFieldSet(this, _SkyViewkeeperDirective_mutationObserverSvc, mutationObserverSvc, "f");
27
+ __classPrivateFieldSet(this, _SkyViewkeeperDirective_viewkeeperSvc, viewkeeperSvc, "f");
28
+ __classPrivateFieldSet(this, _SkyViewkeeperDirective_scrollableHostSvc, scrollableHostSvc, "f");
19
29
  }
20
30
  set skyViewkeeper(value) {
21
- this._skyViewkeeper = value;
22
- this.detectElements();
31
+ __classPrivateFieldSet(this, _SkyViewkeeperDirective__skyViewkeeper, value, "f");
32
+ __classPrivateFieldGet(this, _SkyViewkeeperDirective_instances, "m", _SkyViewkeeperDirective_detectElements).call(this);
23
33
  }
24
34
  get skyViewkeeper() {
25
- return this._skyViewkeeper;
35
+ return __classPrivateFieldGet(this, _SkyViewkeeperDirective__skyViewkeeper, "f");
26
36
  }
27
37
  ngOnInit() {
28
- this.observer = this.mutationObserverSvc.create(() => this.detectElements());
29
- this.observer.observe(this.el.nativeElement, {
38
+ __classPrivateFieldSet(this, _SkyViewkeeperDirective_observer, __classPrivateFieldGet(this, _SkyViewkeeperDirective_mutationObserverSvc, "f").create(() => __classPrivateFieldGet(this, _SkyViewkeeperDirective_instances, "m", _SkyViewkeeperDirective_detectElements).call(this)), "f");
39
+ __classPrivateFieldGet(this, _SkyViewkeeperDirective_observer, "f").observe(__classPrivateFieldGet(this, _SkyViewkeeperDirective_el, "f").nativeElement, {
30
40
  childList: true,
31
41
  subtree: true,
32
42
  });
33
43
  }
34
44
  ngOnDestroy() {
35
- this.observer.disconnect();
36
- this.scrollableHostWatchUnsubscribe?.next();
37
- this.scrollableHostWatchUnsubscribe?.complete();
38
- this.destroyViewkeepers();
39
- }
40
- destroyViewkeepers() {
41
- for (const viewkeeper of this.viewkeepers) {
42
- this.viewkeeperSvc.destroy(viewkeeper);
45
+ /*istanbul ignore else*/
46
+ if (__classPrivateFieldGet(this, _SkyViewkeeperDirective_observer, "f")) {
47
+ __classPrivateFieldGet(this, _SkyViewkeeperDirective_observer, "f").disconnect();
48
+ }
49
+ /*istanbul ignore else*/
50
+ if (__classPrivateFieldGet(this, _SkyViewkeeperDirective_scrollableHostWatchUnsubscribe, "f")) {
51
+ __classPrivateFieldGet(this, _SkyViewkeeperDirective_scrollableHostWatchUnsubscribe, "f").next();
52
+ __classPrivateFieldGet(this, _SkyViewkeeperDirective_scrollableHostWatchUnsubscribe, "f").complete();
43
53
  }
44
- this.viewkeepers = [];
54
+ __classPrivateFieldGet(this, _SkyViewkeeperDirective_instances, "m", _SkyViewkeeperDirective_destroyViewkeepers).call(this);
45
55
  }
46
- getViewkeeperEls() {
47
- let viewkeeperEls;
48
- if (this.skyViewkeeper) {
49
- viewkeeperEls = [];
50
- for (const item of this.skyViewkeeper) {
51
- const matchingEls = Array.from(this.el.nativeElement.querySelectorAll(item));
52
- viewkeeperEls = [...viewkeeperEls, ...matchingEls];
53
- }
56
+ }
57
+ _SkyViewkeeperDirective__skyViewkeeper = new WeakMap(), _SkyViewkeeperDirective_currentViewkeeperEls = new WeakMap(), _SkyViewkeeperDirective_el = new WeakMap(), _SkyViewkeeperDirective_mutationObserverSvc = new WeakMap(), _SkyViewkeeperDirective_observer = new WeakMap(), _SkyViewkeeperDirective_scrollableHostSvc = new WeakMap(), _SkyViewkeeperDirective_scrollableHostWatchUnsubscribe = new WeakMap(), _SkyViewkeeperDirective_viewkeepers = new WeakMap(), _SkyViewkeeperDirective_viewkeeperSvc = new WeakMap(), _SkyViewkeeperDirective_instances = new WeakSet(), _SkyViewkeeperDirective_destroyViewkeepers = function _SkyViewkeeperDirective_destroyViewkeepers() {
58
+ for (const viewkeeper of __classPrivateFieldGet(this, _SkyViewkeeperDirective_viewkeepers, "f")) {
59
+ __classPrivateFieldGet(this, _SkyViewkeeperDirective_viewkeeperSvc, "f").destroy(viewkeeper);
60
+ }
61
+ __classPrivateFieldSet(this, _SkyViewkeeperDirective_viewkeepers, [], "f");
62
+ }, _SkyViewkeeperDirective_getViewkeeperEls = function _SkyViewkeeperDirective_getViewkeeperEls() {
63
+ let viewkeeperEls = [];
64
+ if (this.skyViewkeeper) {
65
+ viewkeeperEls = [];
66
+ for (const item of this.skyViewkeeper) {
67
+ const matchingEls = Array.from(__classPrivateFieldGet(this, _SkyViewkeeperDirective_el, "f").nativeElement.querySelectorAll(item));
68
+ viewkeeperEls = [...viewkeeperEls, ...matchingEls];
54
69
  }
55
- return viewkeeperEls;
56
70
  }
57
- viewkeeperElsChanged(viewkeeperEls) {
58
- if (!viewkeeperEls !== !this.currentViewkeeperEls) {
71
+ return viewkeeperEls;
72
+ }, _SkyViewkeeperDirective_viewkeeperElsChanged = function _SkyViewkeeperDirective_viewkeeperElsChanged(viewkeeperEls) {
73
+ if (!viewkeeperEls !== !__classPrivateFieldGet(this, _SkyViewkeeperDirective_currentViewkeeperEls, "f")) {
74
+ return true;
75
+ }
76
+ if (viewkeeperEls && __classPrivateFieldGet(this, _SkyViewkeeperDirective_currentViewkeeperEls, "f")) {
77
+ if (viewkeeperEls.length !== __classPrivateFieldGet(this, _SkyViewkeeperDirective_currentViewkeeperEls, "f").length) {
59
78
  return true;
60
79
  }
61
- if (viewkeeperEls && this.currentViewkeeperEls) {
62
- if (viewkeeperEls.length !== this.currentViewkeeperEls.length) {
80
+ for (let i = 0, n = viewkeeperEls.length; i < n; i++) {
81
+ if (viewkeeperEls[i] !== __classPrivateFieldGet(this, _SkyViewkeeperDirective_currentViewkeeperEls, "f")[i]) {
63
82
  return true;
64
83
  }
65
- for (let i = 0, n = viewkeeperEls.length; i < n; i++) {
66
- if (viewkeeperEls[i] !== this.currentViewkeeperEls[i]) {
67
- return true;
68
- }
69
- }
70
84
  }
71
- return false;
72
85
  }
73
- detectElements() {
74
- const viewkeeperEls = this.getViewkeeperEls();
75
- if (this.viewkeeperElsChanged(viewkeeperEls)) {
76
- if (this.scrollableHostWatchUnsubscribe) {
77
- this.scrollableHostWatchUnsubscribe.next();
78
- this.scrollableHostWatchUnsubscribe.complete();
79
- this.scrollableHostWatchUnsubscribe = new Subject();
80
- }
81
- else {
82
- this.scrollableHostWatchUnsubscribe = new Subject();
83
- }
84
- this.scrollableHostService
85
- .watchScrollableHost(this.el)
86
- .pipe(takeUntil(this.scrollableHostWatchUnsubscribe))
86
+ return false;
87
+ }, _SkyViewkeeperDirective_detectElements = function _SkyViewkeeperDirective_detectElements() {
88
+ const viewkeeperEls = __classPrivateFieldGet(this, _SkyViewkeeperDirective_instances, "m", _SkyViewkeeperDirective_getViewkeeperEls).call(this);
89
+ if (__classPrivateFieldGet(this, _SkyViewkeeperDirective_instances, "m", _SkyViewkeeperDirective_viewkeeperElsChanged).call(this, viewkeeperEls)) {
90
+ if (__classPrivateFieldGet(this, _SkyViewkeeperDirective_scrollableHostWatchUnsubscribe, "f")) {
91
+ __classPrivateFieldGet(this, _SkyViewkeeperDirective_scrollableHostWatchUnsubscribe, "f").next();
92
+ __classPrivateFieldGet(this, _SkyViewkeeperDirective_scrollableHostWatchUnsubscribe, "f").complete();
93
+ __classPrivateFieldSet(this, _SkyViewkeeperDirective_scrollableHostWatchUnsubscribe, new Subject(), "f");
94
+ }
95
+ else {
96
+ __classPrivateFieldSet(this, _SkyViewkeeperDirective_scrollableHostWatchUnsubscribe, new Subject(), "f");
97
+ }
98
+ if (__classPrivateFieldGet(this, _SkyViewkeeperDirective_scrollableHostSvc, "f")) {
99
+ __classPrivateFieldGet(this, _SkyViewkeeperDirective_scrollableHostSvc, "f")
100
+ .watchScrollableHost(__classPrivateFieldGet(this, _SkyViewkeeperDirective_el, "f"))
101
+ .pipe(takeUntil(__classPrivateFieldGet(this, _SkyViewkeeperDirective_scrollableHostWatchUnsubscribe, "f")))
87
102
  .subscribe((scrollableHost) => {
88
- this.destroyViewkeepers();
103
+ __classPrivateFieldGet(this, _SkyViewkeeperDirective_instances, "m", _SkyViewkeeperDirective_destroyViewkeepers).call(this);
89
104
  let previousViewkeeperEl;
90
105
  for (const viewkeeperEl of viewkeeperEls) {
91
- this.viewkeepers.push(this.viewkeeperSvc.create({
92
- boundaryEl: this.el.nativeElement,
106
+ __classPrivateFieldGet(this, _SkyViewkeeperDirective_viewkeepers, "f").push(__classPrivateFieldGet(this, _SkyViewkeeperDirective_viewkeeperSvc, "f").create({
107
+ boundaryEl: __classPrivateFieldGet(this, _SkyViewkeeperDirective_el, "f").nativeElement,
93
108
  scrollableHost: scrollableHost instanceof HTMLElement
94
109
  ? scrollableHost
95
110
  : undefined,
@@ -100,10 +115,10 @@ export class SkyViewkeeperDirective {
100
115
  previousViewkeeperEl = viewkeeperEl;
101
116
  }
102
117
  });
103
- this.currentViewkeeperEls = viewkeeperEls;
104
118
  }
119
+ __classPrivateFieldSet(this, _SkyViewkeeperDirective_currentViewkeeperEls, viewkeeperEls, "f");
105
120
  }
106
- }
121
+ };
107
122
  SkyViewkeeperDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyViewkeeperDirective, deps: [{ token: i0.ElementRef }, { token: i1.MutationObserverService }, { token: i2.SkyViewkeeperService }, { token: i3.SkyScrollableHostService, optional: true }], target: i0.ɵɵFactoryTarget.Directive });
108
123
  SkyViewkeeperDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.2", type: SkyViewkeeperDirective, selector: "[skyViewkeeper]", inputs: { skyViewkeeper: "skyViewkeeper" }, ngImport: i0 });
109
124
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyViewkeeperDirective, decorators: [{
@@ -116,4 +131,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImpor
116
131
  }] }]; }, propDecorators: { skyViewkeeper: [{
117
132
  type: Input
118
133
  }] } });
119
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"viewkeeper.directive.js","sourceRoot":"","sources":["../../../../../../../../libs/components/core/src/lib/modules/viewkeeper/viewkeeper.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Directive,\n  ElementRef,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n} from '@angular/core';\n\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { MutationObserverService } from '../mutation/mutation-observer-service';\nimport { SkyScrollableHostService } from '../scrollable-host/scrollable-host.service';\n\nimport { SkyViewkeeper } from './viewkeeper';\nimport { SkyViewkeeperService } from './viewkeeper.service';\n\n@Directive({\n  selector: '[skyViewkeeper]',\n})\nexport class SkyViewkeeperDirective implements OnInit, OnDestroy {\n  @Input()\n  public set skyViewkeeper(value: string[]) {\n    this._skyViewkeeper = value;\n\n    this.detectElements();\n  }\n\n  public get skyViewkeeper(): string[] {\n    return this._skyViewkeeper;\n  }\n\n  private _skyViewkeeper: string[];\n\n  private viewkeepers: SkyViewkeeper[] = [];\n\n  private observer: MutationObserver;\n\n  private currentViewkeeperEls: HTMLElement[];\n\n  private scrollableHostWatchUnsubscribe: Subject<void> | undefined = undefined;\n\n  constructor(\n    private el: ElementRef,\n    private mutationObserverSvc: MutationObserverService,\n    private viewkeeperSvc: SkyViewkeeperService,\n    @Optional() private scrollableHostService: SkyScrollableHostService\n  ) {}\n\n  public ngOnInit(): void {\n    this.observer = this.mutationObserverSvc.create(() =>\n      this.detectElements()\n    );\n\n    this.observer.observe(this.el.nativeElement, {\n      childList: true,\n      subtree: true,\n    });\n  }\n\n  public ngOnDestroy(): void {\n    this.observer.disconnect();\n    this.scrollableHostWatchUnsubscribe?.next();\n    this.scrollableHostWatchUnsubscribe?.complete();\n    this.destroyViewkeepers();\n  }\n\n  private destroyViewkeepers(): void {\n    for (const viewkeeper of this.viewkeepers) {\n      this.viewkeeperSvc.destroy(viewkeeper);\n    }\n\n    this.viewkeepers = [];\n  }\n\n  private getViewkeeperEls(): HTMLElement[] {\n    let viewkeeperEls: HTMLElement[];\n\n    if (this.skyViewkeeper) {\n      viewkeeperEls = [];\n\n      for (const item of this.skyViewkeeper) {\n        const matchingEls = Array.from(\n          (this.el.nativeElement as HTMLElement).querySelectorAll(item)\n        ) as HTMLElement[];\n\n        viewkeeperEls = [...viewkeeperEls, ...matchingEls];\n      }\n    }\n\n    return viewkeeperEls;\n  }\n\n  private viewkeeperElsChanged(viewkeeperEls: HTMLElement[]): boolean {\n    if (!viewkeeperEls !== !this.currentViewkeeperEls) {\n      return true;\n    }\n\n    if (viewkeeperEls && this.currentViewkeeperEls) {\n      if (viewkeeperEls.length !== this.currentViewkeeperEls.length) {\n        return true;\n      }\n\n      for (let i = 0, n = viewkeeperEls.length; i < n; i++) {\n        if (viewkeeperEls[i] !== this.currentViewkeeperEls[i]) {\n          return true;\n        }\n      }\n    }\n\n    return false;\n  }\n\n  private detectElements(): void {\n    const viewkeeperEls = this.getViewkeeperEls();\n\n    if (this.viewkeeperElsChanged(viewkeeperEls)) {\n      if (this.scrollableHostWatchUnsubscribe) {\n        this.scrollableHostWatchUnsubscribe.next();\n        this.scrollableHostWatchUnsubscribe.complete();\n        this.scrollableHostWatchUnsubscribe = new Subject();\n      } else {\n        this.scrollableHostWatchUnsubscribe = new Subject();\n      }\n\n      this.scrollableHostService\n        .watchScrollableHost(this.el)\n        .pipe(takeUntil(this.scrollableHostWatchUnsubscribe))\n        .subscribe((scrollableHost) => {\n          this.destroyViewkeepers();\n\n          let previousViewkeeperEl: HTMLElement;\n\n          for (const viewkeeperEl of viewkeeperEls) {\n            this.viewkeepers.push(\n              this.viewkeeperSvc.create({\n                boundaryEl: this.el.nativeElement,\n                scrollableHost:\n                  scrollableHost instanceof HTMLElement\n                    ? scrollableHost\n                    : undefined,\n                el: viewkeeperEl,\n                setWidth: true,\n                verticalOffsetEl: previousViewkeeperEl,\n              })\n            );\n\n            previousViewkeeperEl = viewkeeperEl;\n          }\n        });\n\n      this.currentViewkeeperEls = viewkeeperEls;\n    }\n  }\n}\n"]}
134
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"viewkeeper.directive.js","sourceRoot":"","sources":["../../../../../../../../libs/components/core/src/lib/modules/viewkeeper/viewkeeper.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Directive,\n  ElementRef,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n} from '@angular/core';\n\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { MutationObserverService } from '../mutation/mutation-observer-service';\nimport { SkyScrollableHostService } from '../scrollable-host/scrollable-host.service';\n\nimport { SkyViewkeeper } from './viewkeeper';\nimport { SkyViewkeeperService } from './viewkeeper.service';\n\n@Directive({\n  selector: '[skyViewkeeper]',\n})\nexport class SkyViewkeeperDirective implements OnInit, OnDestroy {\n  @Input()\n  public set skyViewkeeper(value: string[] | undefined) {\n    this.#_skyViewkeeper = value;\n\n    this.#detectElements();\n  }\n\n  public get skyViewkeeper(): string[] | undefined {\n    return this.#_skyViewkeeper;\n  }\n\n  #_skyViewkeeper: string[] | undefined;\n\n  #currentViewkeeperEls: HTMLElement[] | undefined;\n\n  #el: ElementRef;\n\n  #mutationObserverSvc: MutationObserverService;\n\n  #observer: MutationObserver | undefined;\n\n  #scrollableHostSvc: SkyScrollableHostService | undefined;\n\n  #scrollableHostWatchUnsubscribe: Subject<void> | undefined;\n\n  #viewkeepers: SkyViewkeeper[] = [];\n\n  #viewkeeperSvc: SkyViewkeeperService;\n\n  constructor(\n    el: ElementRef,\n    mutationObserverSvc: MutationObserverService,\n    viewkeeperSvc: SkyViewkeeperService,\n    @Optional() scrollableHostSvc?: SkyScrollableHostService\n  ) {\n    this.#el = el;\n    this.#mutationObserverSvc = mutationObserverSvc;\n    this.#viewkeeperSvc = viewkeeperSvc;\n    this.#scrollableHostSvc = scrollableHostSvc;\n  }\n\n  public ngOnInit(): void {\n    this.#observer = this.#mutationObserverSvc.create(() =>\n      this.#detectElements()\n    );\n\n    this.#observer.observe(this.#el.nativeElement, {\n      childList: true,\n      subtree: true,\n    });\n  }\n\n  public ngOnDestroy(): void {\n    /*istanbul ignore else*/\n    if (this.#observer) {\n      this.#observer.disconnect();\n    }\n\n    /*istanbul ignore else*/\n    if (this.#scrollableHostWatchUnsubscribe) {\n      this.#scrollableHostWatchUnsubscribe.next();\n      this.#scrollableHostWatchUnsubscribe.complete();\n    }\n\n    this.#destroyViewkeepers();\n  }\n\n  #destroyViewkeepers(): void {\n    for (const viewkeeper of this.#viewkeepers) {\n      this.#viewkeeperSvc.destroy(viewkeeper);\n    }\n\n    this.#viewkeepers = [];\n  }\n\n  #getViewkeeperEls(): HTMLElement[] {\n    let viewkeeperEls: HTMLElement[] = [];\n\n    if (this.skyViewkeeper) {\n      viewkeeperEls = [];\n\n      for (const item of this.skyViewkeeper) {\n        const matchingEls = Array.from(\n          (this.#el.nativeElement as HTMLElement).querySelectorAll(item)\n        ) as HTMLElement[];\n\n        viewkeeperEls = [...viewkeeperEls, ...matchingEls];\n      }\n    }\n\n    return viewkeeperEls;\n  }\n\n  #viewkeeperElsChanged(viewkeeperEls: HTMLElement[]): boolean {\n    if (!viewkeeperEls !== !this.#currentViewkeeperEls) {\n      return true;\n    }\n\n    if (viewkeeperEls && this.#currentViewkeeperEls) {\n      if (viewkeeperEls.length !== this.#currentViewkeeperEls.length) {\n        return true;\n      }\n\n      for (let i = 0, n = viewkeeperEls.length; i < n; i++) {\n        if (viewkeeperEls[i] !== this.#currentViewkeeperEls[i]) {\n          return true;\n        }\n      }\n    }\n\n    return false;\n  }\n\n  #detectElements(): void {\n    const viewkeeperEls = this.#getViewkeeperEls();\n\n    if (this.#viewkeeperElsChanged(viewkeeperEls)) {\n      if (this.#scrollableHostWatchUnsubscribe) {\n        this.#scrollableHostWatchUnsubscribe.next();\n        this.#scrollableHostWatchUnsubscribe.complete();\n        this.#scrollableHostWatchUnsubscribe = new Subject();\n      } else {\n        this.#scrollableHostWatchUnsubscribe = new Subject();\n      }\n\n      if (this.#scrollableHostSvc) {\n        this.#scrollableHostSvc\n          .watchScrollableHost(this.#el)\n          .pipe(takeUntil(this.#scrollableHostWatchUnsubscribe))\n          .subscribe((scrollableHost) => {\n            this.#destroyViewkeepers();\n\n            let previousViewkeeperEl: HTMLElement | undefined;\n\n            for (const viewkeeperEl of viewkeeperEls) {\n              this.#viewkeepers.push(\n                this.#viewkeeperSvc.create({\n                  boundaryEl: this.#el.nativeElement,\n                  scrollableHost:\n                    scrollableHost instanceof HTMLElement\n                      ? scrollableHost\n                      : undefined,\n                  el: viewkeeperEl,\n                  setWidth: true,\n                  verticalOffsetEl: previousViewkeeperEl,\n                })\n              );\n\n              previousViewkeeperEl = viewkeeperEl;\n            }\n          });\n      }\n\n      this.#currentViewkeeperEls = viewkeeperEls;\n    }\n  }\n}\n"]}