@acorex/cdk 20.6.23 → 20.6.25

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.
@@ -1,27 +1,20 @@
1
1
  import * as i0 from '@angular/core';
2
- import { inject, ElementRef, Renderer2, NgZone, ChangeDetectorRef, EventEmitter, Input, Output, Directive } from '@angular/core';
2
+ import { EventEmitter, inject, ElementRef, Renderer2, NgZone, ChangeDetectorRef, Output, Input, Directive } from '@angular/core';
3
3
 
4
4
  class AXStickyDirective {
5
5
  constructor() {
6
- this.element = inject(ElementRef);
6
+ this.stickyOffset = 100;
7
+ this.isStickyChange = new EventEmitter();
8
+ this.element = inject((ElementRef));
7
9
  this.renderer = inject(Renderer2);
8
10
  this.zone = inject(NgZone);
9
11
  this.cdr = inject(ChangeDetectorRef);
10
- this.stickyOffset = 100;
11
- this.isStickyChange = new EventEmitter();
12
12
  this._isSticky = false;
13
+ this.onWindowResize = () => {
14
+ this.applyStickyStateFromScrollPosition();
15
+ };
13
16
  this.onParentScroll = () => {
14
- this.zone.runOutsideAngular(() => {
15
- const scrollTop = this.parentElement === window ? window.scrollY : this.parentElement.scrollTop;
16
- const shouldStick = scrollTop + this.stickyOffset >= this.topOffset;
17
- if (shouldStick !== this.isSticky) {
18
- this.zone.run(() => {
19
- this.isSticky = shouldStick;
20
- this.toggleStickyClasses(shouldStick);
21
- this.cdr.markForCheck();
22
- });
23
- }
24
- });
17
+ this.applyStickyStateFromScrollPosition();
25
18
  };
26
19
  }
27
20
  get isSticky() {
@@ -37,14 +30,13 @@ class AXStickyDirective {
37
30
  this.initSticky();
38
31
  // Add mutation observer for dynamic content
39
32
  this.mutationObserver = new MutationObserver(() => {
40
- this.updateTopOffset();
33
+ this.applyStickyStateFromScrollPosition();
41
34
  });
42
35
  this.mutationObserver.observe(this.element.nativeElement, {
43
36
  childList: true,
44
37
  subtree: true,
45
38
  });
46
- // Add resize event listener
47
- window.addEventListener('resize', this.updateTopOffset.bind(this));
39
+ window.addEventListener('resize', this.onWindowResize);
48
40
  }
49
41
  initSticky() {
50
42
  if (this.stickyParent instanceof HTMLElement) {
@@ -54,13 +46,42 @@ class AXStickyDirective {
54
46
  this.parentElement = document.querySelector(this.stickyParent) || window;
55
47
  }
56
48
  this.targetElement = document.querySelector(this.stickyTarget) || this.element.nativeElement;
57
- this.updateTopOffset();
58
49
  this.parentElement.addEventListener('scroll', this.onParentScroll);
50
+ this.applyStickyStateFromScrollPosition();
51
+ }
52
+ getScrollTop() {
53
+ return this.parentElement === window ? window.scrollY : this.parentElement.scrollTop;
54
+ }
55
+ /**
56
+ * Toggle stuck styling only while this element is visually pinned (matches `position: sticky; top: 0`).
57
+ * Scroll-offset thresholds would stay true for every section already passed, so multiple stacked stickies
58
+ * would all keep `--stuck`; geometry fixes that.
59
+ */
60
+ computeShouldStick() {
61
+ if (this.getScrollTop() <= 0) {
62
+ return false;
63
+ }
64
+ const tRect = this.targetElement.getBoundingClientRect();
65
+ const epsilon = 3;
66
+ let limitY;
67
+ if (this.parentElement === window) {
68
+ limitY = this.stickyOffset;
69
+ }
70
+ else {
71
+ limitY = this.parentElement.getBoundingClientRect().top;
72
+ }
73
+ return tRect.top <= limitY + epsilon && tRect.top >= limitY - epsilon;
59
74
  }
60
- updateTopOffset() {
75
+ applyStickyStateFromScrollPosition() {
61
76
  this.zone.runOutsideAngular(() => {
62
- const rect = this.targetElement.getBoundingClientRect();
63
- this.topOffset = rect.top + (window.scrollY || 0);
77
+ const shouldStick = this.computeShouldStick();
78
+ if (shouldStick !== this.isSticky) {
79
+ this.zone.run(() => {
80
+ this.isSticky = shouldStick;
81
+ this.toggleStickyClasses(shouldStick);
82
+ this.cdr.markForCheck();
83
+ });
84
+ }
64
85
  });
65
86
  }
66
87
  toggleStickyClasses(isSticky) {
@@ -76,13 +97,13 @@ class AXStickyDirective {
76
97
  }
77
98
  ngOnDestroy() {
78
99
  this.parentElement.removeEventListener('scroll', this.onParentScroll);
79
- window.removeEventListener('resize', this.updateTopOffset.bind(this));
100
+ window.removeEventListener('resize', this.onWindowResize);
80
101
  if (this.mutationObserver) {
81
102
  this.mutationObserver.disconnect();
82
103
  }
83
104
  }
84
105
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.3", ngImport: i0, type: AXStickyDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
85
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "20.3.3", type: AXStickyDirective, isStandalone: true, selector: "[axSticky]", inputs: { stickyClass: ["axSticky", "stickyClass"], stickyOffset: "stickyOffset", stickyParent: "stickyParent", stickyTarget: "stickyTarget" }, outputs: { isStickyChange: "isStickyChange" }, exportAs: ["axpSticky"], ngImport: i0 }); }
106
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "20.3.3", type: AXStickyDirective, isStandalone: true, selector: "[axSticky]", inputs: { stickyClass: ["axpSticky", "stickyClass"], stickyOffset: "stickyOffset", stickyParent: "stickyParent", stickyTarget: "stickyTarget" }, outputs: { isStickyChange: "isStickyChange" }, exportAs: ["axpSticky"], ngImport: i0 }); }
86
107
  }
87
108
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.3", ngImport: i0, type: AXStickyDirective, decorators: [{
88
109
  type: Directive,
@@ -92,16 +113,16 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.3", ngImpor
92
113
  }]
93
114
  }], propDecorators: { stickyClass: [{
94
115
  type: Input,
95
- args: ['axSticky']
116
+ args: ['axpSticky']
96
117
  }], stickyOffset: [{
97
118
  type: Input,
98
119
  args: ['stickyOffset']
99
- }], isStickyChange: [{
100
- type: Output
101
120
  }], stickyParent: [{
102
121
  type: Input
103
122
  }], stickyTarget: [{
104
123
  type: Input
124
+ }], isStickyChange: [{
125
+ type: Output
105
126
  }] } });
106
127
 
107
128
  /**
@@ -1 +1 @@
1
- {"version":3,"file":"acorex-cdk-sticky.mjs","sources":["../tmp-esm2022/sticky/lib/sticky.directive.js","../tmp-esm2022/sticky/acorex-cdk-sticky.js"],"sourcesContent":["import { ChangeDetectorRef, Directive, ElementRef, EventEmitter, Input, NgZone, Output, Renderer2, inject, } from '@angular/core';\nimport * as i0 from \"@angular/core\";\nexport class AXStickyDirective {\n constructor() {\n this.element = inject(ElementRef);\n this.renderer = inject(Renderer2);\n this.zone = inject(NgZone);\n this.cdr = inject(ChangeDetectorRef);\n this.stickyOffset = 100;\n this.isStickyChange = new EventEmitter();\n this._isSticky = false;\n this.onParentScroll = () => {\n this.zone.runOutsideAngular(() => {\n const scrollTop = this.parentElement === window ? window.scrollY : this.parentElement.scrollTop;\n const shouldStick = scrollTop + this.stickyOffset >= this.topOffset;\n if (shouldStick !== this.isSticky) {\n this.zone.run(() => {\n this.isSticky = shouldStick;\n this.toggleStickyClasses(shouldStick);\n this.cdr.markForCheck();\n });\n }\n });\n };\n }\n get isSticky() {\n return this._isSticky;\n }\n set isSticky(value) {\n if (this._isSticky !== value) {\n this._isSticky = value;\n this.isStickyChange.emit(value);\n }\n }\n ngAfterViewInit() {\n this.initSticky();\n // Add mutation observer for dynamic content\n this.mutationObserver = new MutationObserver(() => {\n this.updateTopOffset();\n });\n this.mutationObserver.observe(this.element.nativeElement, {\n childList: true,\n subtree: true,\n });\n // Add resize event listener\n window.addEventListener('resize', this.updateTopOffset.bind(this));\n }\n initSticky() {\n if (this.stickyParent instanceof HTMLElement) {\n this.parentElement = this.stickyParent;\n }\n else {\n this.parentElement = document.querySelector(this.stickyParent) || window;\n }\n this.targetElement = document.querySelector(this.stickyTarget) || this.element.nativeElement;\n this.updateTopOffset();\n this.parentElement.addEventListener('scroll', this.onParentScroll);\n }\n updateTopOffset() {\n this.zone.runOutsideAngular(() => {\n const rect = this.targetElement.getBoundingClientRect();\n this.topOffset = rect.top + (window.scrollY || 0);\n });\n }\n toggleStickyClasses(isSticky) {\n const classes = this.stickyClass.split(' ').filter(Boolean);\n classes.forEach((className) => {\n if (isSticky) {\n this.renderer.addClass(this.targetElement, className);\n }\n else {\n this.renderer.removeClass(this.targetElement, className);\n }\n });\n }\n ngOnDestroy() {\n this.parentElement.removeEventListener('scroll', this.onParentScroll);\n window.removeEventListener('resize', this.updateTopOffset.bind(this));\n if (this.mutationObserver) {\n this.mutationObserver.disconnect();\n }\n }\n static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: \"12.0.0\", version: \"20.3.3\", ngImport: i0, type: AXStickyDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }\n static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: \"14.0.0\", version: \"20.3.3\", type: AXStickyDirective, isStandalone: true, selector: \"[axSticky]\", inputs: { stickyClass: [\"axSticky\", \"stickyClass\"], stickyOffset: \"stickyOffset\", stickyParent: \"stickyParent\", stickyTarget: \"stickyTarget\" }, outputs: { isStickyChange: \"isStickyChange\" }, exportAs: [\"axpSticky\"], ngImport: i0 }); }\n}\ni0.ɵɵngDeclareClassMetadata({ minVersion: \"12.0.0\", version: \"20.3.3\", ngImport: i0, type: AXStickyDirective, decorators: [{\n type: Directive,\n args: [{\n selector: '[axSticky]',\n exportAs: 'axpSticky',\n }]\n }], propDecorators: { stickyClass: [{\n type: Input,\n args: ['axSticky']\n }], stickyOffset: [{\n type: Input,\n args: ['stickyOffset']\n }], isStickyChange: [{\n type: Output\n }], stickyParent: [{\n type: Input\n }], stickyTarget: [{\n type: Input\n }] } });\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sticky.directive.js","sourceRoot":"","sources":["../../../../../../packages/cdk/sticky/src/lib/sticky.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  Input,\n  NgZone,\n  OnDestroy,\n  Output,\n  Renderer2,\n  inject,\n} from '@angular/core';\n\n@Directive({\n  selector: '[axSticky]',\n  exportAs: 'axpSticky',\n})\nexport class AXStickyDirective implements AfterViewInit, OnDestroy {\n  private element = inject<ElementRef<HTMLDivElement>>(ElementRef);\n  private renderer = inject(Renderer2);\n  private zone = inject(NgZone);\n  private cdr = inject(ChangeDetectorRef);\n\n  @Input('axSticky') stickyClass!: string;\n  @Input('stickyOffset') stickyOffset = 100;\n  @Output() isStickyChange: EventEmitter<boolean> = new EventEmitter<boolean>();\n\n  private _isSticky = false;\n  public get isSticky(): boolean {\n    return this._isSticky;\n  }\n  public set isSticky(value: boolean) {\n    if (this._isSticky !== value) {\n      this._isSticky = value;\n      this.isStickyChange.emit(value);\n    }\n  }\n\n  private topOffset!: number;\n  private parentElement!: HTMLElement | Window;\n  private targetElement!: HTMLElement;\n  private mutationObserver!: MutationObserver;\n\n  @Input() stickyParent!: string | HTMLElement;\n  @Input() stickyTarget!: string;\n\n  ngAfterViewInit() {\n    this.initSticky();\n\n    // Add mutation observer for dynamic content\n    this.mutationObserver = new MutationObserver(() => {\n      this.updateTopOffset();\n    });\n\n    this.mutationObserver.observe(this.element.nativeElement, {\n      childList: true,\n      subtree: true,\n    });\n\n    // Add resize event listener\n    window.addEventListener('resize', this.updateTopOffset.bind(this));\n  }\n\n  private initSticky() {\n    if (this.stickyParent instanceof HTMLElement) {\n      this.parentElement = this.stickyParent;\n    } else {\n      this.parentElement = (document.querySelector(this.stickyParent) as HTMLElement) || window;\n    }\n\n    this.targetElement = (document.querySelector(this.stickyTarget) as HTMLElement) || this.element.nativeElement;\n\n    this.updateTopOffset();\n    this.parentElement.addEventListener('scroll', this.onParentScroll);\n  }\n\n  private updateTopOffset(): void {\n    this.zone.runOutsideAngular(() => {\n      const rect = this.targetElement.getBoundingClientRect();\n      this.topOffset = rect.top + (window.scrollY || 0);\n    });\n  }\n\n  private onParentScroll = (): void => {\n    this.zone.runOutsideAngular(() => {\n      const scrollTop = this.parentElement === window ? window.scrollY : (this.parentElement as HTMLElement).scrollTop;\n\n      const shouldStick = scrollTop + this.stickyOffset >= this.topOffset;\n\n      if (shouldStick !== this.isSticky) {\n        this.zone.run(() => {\n          this.isSticky = shouldStick;\n          this.toggleStickyClasses(shouldStick);\n          this.cdr.markForCheck();\n        });\n      }\n    });\n  };\n\n  private toggleStickyClasses(isSticky: boolean): void {\n    const classes = this.stickyClass.split(' ').filter(Boolean);\n    classes.forEach((className) => {\n      if (isSticky) {\n        this.renderer.addClass(this.targetElement, className);\n      } else {\n        this.renderer.removeClass(this.targetElement, className);\n      }\n    });\n  }\n\n  ngOnDestroy() {\n    this.parentElement.removeEventListener('scroll', this.onParentScroll);\n    window.removeEventListener('resize', this.updateTopOffset.bind(this));\n\n    if (this.mutationObserver) {\n      this.mutationObserver.disconnect();\n    }\n  }\n}\n"]}","/**\n * Generated bundle index. Do not edit.\n */\nexport * from './index';\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWNvcmV4LWNkay1zdGlja3kuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9jZGsvc3RpY2t5L3NyYy9hY29yZXgtY2RrLXN0aWNreS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2luZGV4JztcbiJdfQ=="],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"acorex-cdk-sticky.mjs","sources":["../tmp-esm2022/sticky/lib/sticky.directive.js","../tmp-esm2022/sticky/acorex-cdk-sticky.js"],"sourcesContent":["import { ChangeDetectorRef, Directive, ElementRef, EventEmitter, inject, Input, NgZone, Output, Renderer2, } from '@angular/core';\nimport * as i0 from \"@angular/core\";\nexport class AXStickyDirective {\n constructor() {\n this.stickyOffset = 100;\n this.isStickyChange = new EventEmitter();\n this.element = inject((ElementRef));\n this.renderer = inject(Renderer2);\n this.zone = inject(NgZone);\n this.cdr = inject(ChangeDetectorRef);\n this._isSticky = false;\n this.onWindowResize = () => {\n this.applyStickyStateFromScrollPosition();\n };\n this.onParentScroll = () => {\n this.applyStickyStateFromScrollPosition();\n };\n }\n get isSticky() {\n return this._isSticky;\n }\n set isSticky(value) {\n if (this._isSticky !== value) {\n this._isSticky = value;\n this.isStickyChange.emit(value);\n }\n }\n ngAfterViewInit() {\n this.initSticky();\n // Add mutation observer for dynamic content\n this.mutationObserver = new MutationObserver(() => {\n this.applyStickyStateFromScrollPosition();\n });\n this.mutationObserver.observe(this.element.nativeElement, {\n childList: true,\n subtree: true,\n });\n window.addEventListener('resize', this.onWindowResize);\n }\n initSticky() {\n if (this.stickyParent instanceof HTMLElement) {\n this.parentElement = this.stickyParent;\n }\n else {\n this.parentElement = document.querySelector(this.stickyParent) || window;\n }\n this.targetElement = document.querySelector(this.stickyTarget) || this.element.nativeElement;\n this.parentElement.addEventListener('scroll', this.onParentScroll);\n this.applyStickyStateFromScrollPosition();\n }\n getScrollTop() {\n return this.parentElement === window ? window.scrollY : this.parentElement.scrollTop;\n }\n /**\n * Toggle stuck styling only while this element is visually pinned (matches `position: sticky; top: 0`).\n * Scroll-offset thresholds would stay true for every section already passed, so multiple stacked stickies\n * would all keep `--stuck`; geometry fixes that.\n */\n computeShouldStick() {\n if (this.getScrollTop() <= 0) {\n return false;\n }\n const tRect = this.targetElement.getBoundingClientRect();\n const epsilon = 3;\n let limitY;\n if (this.parentElement === window) {\n limitY = this.stickyOffset;\n }\n else {\n limitY = this.parentElement.getBoundingClientRect().top;\n }\n return tRect.top <= limitY + epsilon && tRect.top >= limitY - epsilon;\n }\n applyStickyStateFromScrollPosition() {\n this.zone.runOutsideAngular(() => {\n const shouldStick = this.computeShouldStick();\n if (shouldStick !== this.isSticky) {\n this.zone.run(() => {\n this.isSticky = shouldStick;\n this.toggleStickyClasses(shouldStick);\n this.cdr.markForCheck();\n });\n }\n });\n }\n toggleStickyClasses(isSticky) {\n const classes = this.stickyClass.split(' ').filter(Boolean);\n classes.forEach((className) => {\n if (isSticky) {\n this.renderer.addClass(this.targetElement, className);\n }\n else {\n this.renderer.removeClass(this.targetElement, className);\n }\n });\n }\n ngOnDestroy() {\n this.parentElement.removeEventListener('scroll', this.onParentScroll);\n window.removeEventListener('resize', this.onWindowResize);\n if (this.mutationObserver) {\n this.mutationObserver.disconnect();\n }\n }\n static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: \"12.0.0\", version: \"20.3.3\", ngImport: i0, type: AXStickyDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }\n static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: \"14.0.0\", version: \"20.3.3\", type: AXStickyDirective, isStandalone: true, selector: \"[axSticky]\", inputs: { stickyClass: [\"axpSticky\", \"stickyClass\"], stickyOffset: \"stickyOffset\", stickyParent: \"stickyParent\", stickyTarget: \"stickyTarget\" }, outputs: { isStickyChange: \"isStickyChange\" }, exportAs: [\"axpSticky\"], ngImport: i0 }); }\n}\ni0.ɵɵngDeclareClassMetadata({ minVersion: \"12.0.0\", version: \"20.3.3\", ngImport: i0, type: AXStickyDirective, decorators: [{\n type: Directive,\n args: [{\n selector: '[axSticky]',\n exportAs: 'axpSticky',\n }]\n }], propDecorators: { stickyClass: [{\n type: Input,\n args: ['axpSticky']\n }], stickyOffset: [{\n type: Input,\n args: ['stickyOffset']\n }], stickyParent: [{\n type: Input\n }], stickyTarget: [{\n type: Input\n }], isStickyChange: [{\n type: Output\n }] } });\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sticky.directive.js","sourceRoot":"","sources":["../../../../../../packages/cdk/sticky/src/lib/sticky.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  inject,\n  Input,\n  NgZone,\n  OnDestroy,\n  Output,\n  Renderer2,\n} from '@angular/core';\n\n@Directive({\n  selector: '[axSticky]',\n  exportAs: 'axpSticky',\n})\nexport class AXStickyDirective implements AfterViewInit, OnDestroy {\n  @Input('axpSticky') stickyClass!: string;\n  @Input('stickyOffset') stickyOffset = 100;\n  @Input() stickyParent!: string | HTMLElement;\n  @Input() stickyTarget!: string;\n  @Output() isStickyChange: EventEmitter<boolean> = new EventEmitter<boolean>();\n\n  private element = inject(ElementRef<HTMLDivElement>);\n  private renderer = inject(Renderer2);\n  private zone = inject(NgZone);\n  private cdr = inject(ChangeDetectorRef);\n\n  private parentElement!: HTMLElement | Window;\n  private targetElement!: HTMLElement;\n  private mutationObserver!: MutationObserver;\n  private _isSticky = false;\n\n  public get isSticky(): boolean {\n    return this._isSticky;\n  }\n  public set isSticky(value: boolean) {\n    if (this._isSticky !== value) {\n      this._isSticky = value;\n      this.isStickyChange.emit(value);\n    }\n  }\n\n  private readonly onWindowResize = (): void => {\n    this.applyStickyStateFromScrollPosition();\n  };\n\n  ngAfterViewInit() {\n    this.initSticky();\n\n    // Add mutation observer for dynamic content\n    this.mutationObserver = new MutationObserver(() => {\n      this.applyStickyStateFromScrollPosition();\n    });\n\n    this.mutationObserver.observe(this.element.nativeElement, {\n      childList: true,\n      subtree: true,\n    });\n\n    window.addEventListener('resize', this.onWindowResize);\n  }\n\n  private initSticky() {\n    if (this.stickyParent instanceof HTMLElement) {\n      this.parentElement = this.stickyParent;\n    } else {\n      this.parentElement = (document.querySelector(this.stickyParent) as HTMLElement) || window;\n    }\n\n    this.targetElement = (document.querySelector(this.stickyTarget) as HTMLElement) || this.element.nativeElement;\n\n    this.parentElement.addEventListener('scroll', this.onParentScroll);\n    this.applyStickyStateFromScrollPosition();\n  }\n\n  private getScrollTop(): number {\n    return this.parentElement === window ? window.scrollY : (this.parentElement as HTMLElement).scrollTop;\n  }\n\n  /**\n   * Toggle stuck styling only while this element is visually pinned (matches `position: sticky; top: 0`).\n   * Scroll-offset thresholds would stay true for every section already passed, so multiple stacked stickies\n   * would all keep `--stuck`; geometry fixes that.\n   */\n  private computeShouldStick(): boolean {\n    if (this.getScrollTop() <= 0) {\n      return false;\n    }\n    const tRect = this.targetElement.getBoundingClientRect();\n    const epsilon = 3;\n    let limitY: number;\n    if (this.parentElement === window) {\n      limitY = this.stickyOffset;\n    } else {\n      limitY = (this.parentElement as HTMLElement).getBoundingClientRect().top;\n    }\n    return tRect.top <= limitY + epsilon && tRect.top >= limitY - epsilon;\n  }\n\n  private applyStickyStateFromScrollPosition(): void {\n    this.zone.runOutsideAngular(() => {\n      const shouldStick = this.computeShouldStick();\n\n      if (shouldStick !== this.isSticky) {\n        this.zone.run(() => {\n          this.isSticky = shouldStick;\n          this.toggleStickyClasses(shouldStick);\n          this.cdr.markForCheck();\n        });\n      }\n    });\n  }\n\n  private onParentScroll = (): void => {\n    this.applyStickyStateFromScrollPosition();\n  };\n\n  private toggleStickyClasses(isSticky: boolean): void {\n    const classes = this.stickyClass.split(' ').filter(Boolean);\n    classes.forEach((className) => {\n      if (isSticky) {\n        this.renderer.addClass(this.targetElement, className);\n      } else {\n        this.renderer.removeClass(this.targetElement, className);\n      }\n    });\n  }\n\n  ngOnDestroy() {\n    this.parentElement.removeEventListener('scroll', this.onParentScroll);\n    window.removeEventListener('resize', this.onWindowResize);\n\n    if (this.mutationObserver) {\n      this.mutationObserver.disconnect();\n    }\n  }\n}\n"]}","/**\n * Generated bundle index. Do not edit.\n */\nexport * from './index';\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWNvcmV4LWNkay1zdGlja3kuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9jZGsvc3RpY2t5L3NyYy9hY29yZXgtY2RrLXN0aWNreS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2luZGV4JztcbiJdfQ=="],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,8 +1,8 @@
1
1
  {
2
2
  "name": "@acorex/cdk",
3
- "version": "20.6.23",
3
+ "version": "20.6.25",
4
4
  "peerDependencies": {
5
- "@acorex/core": "20.6.23",
5
+ "@acorex/core": "20.6.25",
6
6
  "quill": ">=2.0.2",
7
7
  "qrcode": ">=1.5.4",
8
8
  "swiper": ">=11.1.15",
package/sticky/index.d.ts CHANGED
@@ -2,30 +2,37 @@ import * as i0 from '@angular/core';
2
2
  import { AfterViewInit, OnDestroy, EventEmitter } from '@angular/core';
3
3
 
4
4
  declare class AXStickyDirective implements AfterViewInit, OnDestroy {
5
+ stickyClass: string;
6
+ stickyOffset: number;
7
+ stickyParent: string | HTMLElement;
8
+ stickyTarget: string;
9
+ isStickyChange: EventEmitter<boolean>;
5
10
  private element;
6
11
  private renderer;
7
12
  private zone;
8
13
  private cdr;
9
- stickyClass: string;
10
- stickyOffset: number;
11
- isStickyChange: EventEmitter<boolean>;
12
- private _isSticky;
13
- get isSticky(): boolean;
14
- set isSticky(value: boolean);
15
- private topOffset;
16
14
  private parentElement;
17
15
  private targetElement;
18
16
  private mutationObserver;
19
- stickyParent: string | HTMLElement;
20
- stickyTarget: string;
17
+ private _isSticky;
18
+ get isSticky(): boolean;
19
+ set isSticky(value: boolean);
20
+ private readonly onWindowResize;
21
21
  ngAfterViewInit(): void;
22
22
  private initSticky;
23
- private updateTopOffset;
23
+ private getScrollTop;
24
+ /**
25
+ * Toggle stuck styling only while this element is visually pinned (matches `position: sticky; top: 0`).
26
+ * Scroll-offset thresholds would stay true for every section already passed, so multiple stacked stickies
27
+ * would all keep `--stuck`; geometry fixes that.
28
+ */
29
+ private computeShouldStick;
30
+ private applyStickyStateFromScrollPosition;
24
31
  private onParentScroll;
25
32
  private toggleStickyClasses;
26
33
  ngOnDestroy(): void;
27
34
  static ɵfac: i0.ɵɵFactoryDeclaration<AXStickyDirective, never>;
28
- static ɵdir: i0.ɵɵDirectiveDeclaration<AXStickyDirective, "[axSticky]", ["axpSticky"], { "stickyClass": { "alias": "axSticky"; "required": false; }; "stickyOffset": { "alias": "stickyOffset"; "required": false; }; "stickyParent": { "alias": "stickyParent"; "required": false; }; "stickyTarget": { "alias": "stickyTarget"; "required": false; }; }, { "isStickyChange": "isStickyChange"; }, never, never, true, never>;
35
+ static ɵdir: i0.ɵɵDirectiveDeclaration<AXStickyDirective, "[axSticky]", ["axpSticky"], { "stickyClass": { "alias": "axpSticky"; "required": false; }; "stickyOffset": { "alias": "stickyOffset"; "required": false; }; "stickyParent": { "alias": "stickyParent"; "required": false; }; "stickyTarget": { "alias": "stickyTarget"; "required": false; }; }, { "isStickyChange": "isStickyChange"; }, never, never, true, never>;
29
36
  }
30
37
 
31
38
  export { AXStickyDirective };