@libs-ui/components-scroll-overlay 0.2.356-24 → 0.2.356-26

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,82 +1,106 @@
1
- /* eslint-disable @typescript-eslint/no-explicit-any */
2
1
  import { DestroyRef, Directive, ElementRef, Renderer2, computed, effect, inject, input, output, signal, untracked } from '@angular/core';
3
2
  import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
4
3
  import { checkMouseOverInContainer, getDragEventByElement } from '@libs-ui/utils';
5
4
  import { Subscription, fromEvent, interval, switchMap, takeUntil, tap } from 'rxjs';
6
5
  import * as i0 from "@angular/core";
6
+ const STYLE_TAG_ID = 'libs-ui-scroll-overlay-style-tag';
7
+ const SCROLL_BOTTOM_TOLERANCE = 3;
8
+ const MIN_THUMB_SIZE = 20;
9
+ const MOUSE_UP_RESET_DELAY = 250;
10
+ const DEFAULT_SCROLLBAR_HOVER_COLOR = '#CDD0D640';
11
+ const DEFAULT_SCROLL_THUMB_COLOR = '#CDD0D6';
12
+ const DEFAULT_SCROLL_THUMB_HOVER_COLOR = '#9CA2AD';
13
+ /**
14
+ * CSS chia sẻ cho mọi instance. Màu/padding lấy qua CSS variables để mỗi
15
+ * directive instance có thể custom độc lập mà không phải re-write style tag.
16
+ */
17
+ const STYLE_CONTENT = `
18
+ .libs-ui-scroll-overlay-container .scrollbar-track {
19
+ background-color: var(--libs-ui-sb-track-color, transparent);
20
+ }
21
+ .libs-ui-scroll-overlay-container .scrollbar-track:hover {
22
+ background-color: var(--libs-ui-sb-track-hover-color, ${DEFAULT_SCROLLBAR_HOVER_COLOR});
23
+ }
24
+ .libs-ui-scroll-overlay-container .scrollbar-track-X {
25
+ width: 100%;
26
+ position: absolute;
27
+ bottom: 0;
28
+ left: 0;
29
+ visibility: hidden;
30
+ cursor: pointer;
31
+ opacity: 0;
32
+ z-index: 1;
33
+ transition: opacity 0.3s ease, visibility 0.3s ease;
34
+ }
35
+ .libs-ui-scroll-overlay-container .scrollbar-track-Y {
36
+ height: 100%;
37
+ position: absolute;
38
+ top: 0;
39
+ right: 0;
40
+ visibility: hidden;
41
+ cursor: pointer;
42
+ opacity: 0;
43
+ z-index: 1;
44
+ transition: opacity 0.3s ease, visibility 0.3s ease;
45
+ }
46
+ .libs-ui-scroll-overlay-container .scrollbar-thumb {
47
+ background-color: var(--libs-ui-sb-thumb-color, ${DEFAULT_SCROLL_THUMB_COLOR});
48
+ }
49
+ .libs-ui-scroll-overlay-container .scrollbar-thumb:hover {
50
+ background-color: var(--libs-ui-sb-thumb-hover-color, ${DEFAULT_SCROLL_THUMB_HOVER_COLOR});
51
+ }
52
+ .libs-ui-scroll-overlay-container .scrollbar-thumb-X {
53
+ height: calc(100% - var(--libs-ui-sb-padding-double, 4px));
54
+ bottom: var(--libs-ui-sb-padding, 2px);
55
+ border-radius: 4px;
56
+ cursor: grabbing;
57
+ transition: background-color 0.3s;
58
+ position: absolute;
59
+ }
60
+ .libs-ui-scroll-overlay-container .scrollbar-thumb-Y {
61
+ width: calc(100% - var(--libs-ui-sb-padding-double, 4px));
62
+ right: var(--libs-ui-sb-padding, 2px);
63
+ border-radius: 4px;
64
+ cursor: grabbing;
65
+ transition: background-color 0.3s;
66
+ position: absolute;
67
+ }
68
+ .libs-ui-scroll-overlay-container .libs-ui-scroll-overlay-element::-webkit-scrollbar {
69
+ width: 0 !important;
70
+ height: 0 !important;
71
+ }
72
+ `;
73
+ const ensureStyleTag = () => {
74
+ if (document.getElementById(STYLE_TAG_ID)) {
75
+ return;
76
+ }
77
+ const styleEl = document.createElement('style');
78
+ styleEl.id = STYLE_TAG_ID;
79
+ styleEl.textContent = STYLE_CONTENT;
80
+ document.head.append(styleEl);
81
+ };
7
82
  export class LibsUiComponentsScrollOverlayDirective {
8
83
  // #region PROPERTY
9
- styles = computed(() => `
10
- .scrollbar-track{
11
- background-color:${this.scrollbarColor()};
12
- }
13
- .scrollbar-track:hover{
14
- background-color:${this.scrollbarHoverColor()};
15
- }
16
- .scrollbar-track-X {
17
- width:100%;
18
- position: absolute;
19
- bottom: 0;
20
- left: 0;
21
- visibility: hidden;
22
- cursor: pointer;
23
- opacity: 0;
24
- z-index: 1;
25
- transition: opacity 0.3s ease, visibility 0.3s ease;
26
- }
27
-
28
- .scrollbar-track-Y {
29
- height:100%;
30
- position: absolute;
31
- top: 0;
32
- right: 0;
33
- visibility: hidden;
34
- cursor: pointer;
35
- opacity: 0;
36
- z-index: 1;
37
- transition: opacity 0.3s ease, visibility 0.3s ease;
38
- }
39
-
40
- .scrollbar-thumb{
41
- background-color:${this.scrollThumbColor()};
42
- }
43
- .scrollbar-thumb:hover{
44
- background-color:${this.scrollThumbHoverColor()};
45
- }
46
-
47
- .scrollbar-thumb-X {
48
- height: calc(100% - ${this.scrollbarPadding() * 2}px);
49
- bottom: ${this.scrollbarPadding()}px;
50
- border-radius: 4px;
51
- cursor: grabbing;
52
- transition: background-color 0.3s;
53
- position: absolute;
54
- }
55
-
56
- .scrollbar-thumb-Y {
57
- width: calc(100% - ${this.scrollbarPadding() * 2}px);
58
- right: ${this.scrollbarPadding()}px;
59
- border-radius: 4px;
60
- cursor: grabbing;
61
- transition: background-color 0.3s;
62
- position: absolute;
63
- }
64
-
65
- .lib-ui-scroll-overlay-container .lib-ui-scroll-overlay-element::-webkit-scrollbar {
66
- width: 0 !important;
67
- height: 0 !important;
68
- }
69
- `, {});
70
84
  isScrollThumb = signal(false);
71
85
  keepDisplayThumb = signal(false);
72
86
  subsX = new Subscription();
73
87
  subsY = new Subscription();
74
- scrollbarWidth = computed(() => this.options()?.scrollbarWidth ?? 10); // Chiều rộng thanh cuộn
75
- scrollbarPadding = computed(() => this.options()?.scrollbarPadding ?? 2); // Chiều rộng thanh cuộn
88
+ /** Timer reset isScrollThumb sau drag end phải clear khi destroy để tránh set signal trên instance đã teardown. */
89
+ mouseUpTimer;
90
+ /** rAF throttle cho scroll handler — gom multiple scroll events về 1 lần update DOM mỗi frame. */
91
+ scrollRafX;
92
+ scrollRafY;
93
+ /** Cache dimensions — skip DOM write nếu kích thước không đổi giữa 2 lần poll. */
94
+ lastContentWidth = 0;
95
+ lastContentHeight = 0;
96
+ lastContainerWidth = 0;
97
+ lastContainerHeight = 0;
98
+ scrollbarWidth = computed(() => this.options()?.scrollbarWidth ?? 10);
99
+ scrollbarPadding = computed(() => this.options()?.scrollbarPadding ?? 2);
76
100
  scrollbarColor = computed(() => this.options()?.scrollbarColor ?? '');
77
- scrollbarHoverColor = computed(() => this.options()?.scrollbarColor ?? '#CDD0D640');
78
- scrollThumbColor = computed(() => this.options()?.scrollThumbColor ?? '#CDD0D6');
79
- scrollThumbHoverColor = computed(() => this.options()?.scrollThumbHoverColor ?? '#9CA2AD');
101
+ scrollbarHoverColor = computed(() => this.options()?.scrollbarHoverColor ?? DEFAULT_SCROLLBAR_HOVER_COLOR);
102
+ scrollThumbColor = computed(() => this.options()?.scrollThumbColor ?? DEFAULT_SCROLL_THUMB_COLOR);
103
+ scrollThumbHoverColor = computed(() => this.options()?.scrollThumbHoverColor ?? DEFAULT_SCROLL_THUMB_HOVER_COLOR);
80
104
  divContainer = document.createElement('div');
81
105
  trackX = document.createElement('div');
82
106
  thumbX = document.createElement('div');
@@ -101,58 +125,88 @@ export class LibsUiComponentsScrollOverlayDirective {
101
125
  render2 = inject(Renderer2);
102
126
  destroyRef = inject(DestroyRef);
103
127
  constructor() {
128
+ // Setup scrollbars khi options/classContainer đổi.
104
129
  effect(() => {
105
130
  if (this.ignoreInit()) {
106
131
  return;
107
132
  }
108
133
  const options = this.options();
109
- this.divContainer.className = '';
110
- this.classContainer()
111
- ?.split(' ')
112
- .forEach((className) => {
113
- if (!className) {
114
- return;
115
- }
116
- this.divContainer.classList.add(className);
117
- });
134
+ const classContainer = this.classContainer();
118
135
  untracked(() => {
136
+ this.syncContainerExtraClasses(classContainer);
119
137
  this.Element.classList.toggle('overflow-hidden', options?.scrollX === 'hidden' && options?.scrollY === 'hidden');
120
138
  if (options?.scrollX !== 'hidden') {
121
139
  this.subsX.unsubscribe();
140
+ this.subsX = new Subscription();
122
141
  this.trackX.className = '';
123
142
  this.thumbX.className = '';
124
143
  this.trackX.style.height = `${this.scrollbarWidth()}px`;
125
144
  this.createScrollbar('X', this.trackX, this.thumbX);
126
- this.bindEventsScrollBar('X', this.trackX);
127
- this.handlerDragAndDropThumb('X');
128
- this.handlerClickTrack('X');
145
+ this.bindEventsScrollBar('X', this.trackX, this.subsX);
146
+ this.handlerDragAndDropThumb('X', this.subsX);
147
+ this.handlerClickTrack('X', this.subsX);
129
148
  }
130
149
  if (options?.scrollY !== 'hidden') {
150
+ this.subsY.unsubscribe();
151
+ this.subsY = new Subscription();
131
152
  this.trackY.className = '';
132
153
  this.thumbY.className = '';
133
154
  this.trackY.style.width = `${this.scrollbarWidth()}px`;
134
- this.subsY.unsubscribe();
135
155
  this.createScrollbar('Y', this.trackY, this.thumbY);
136
- this.bindEventsScrollBar('Y', this.trackY);
137
- this.handlerDragAndDropThumb('Y');
138
- this.handlerClickTrack('Y');
156
+ this.bindEventsScrollBar('Y', this.trackY, this.subsY);
157
+ this.handlerDragAndDropThumb('Y', this.subsY);
158
+ this.handlerClickTrack('Y', this.subsY);
139
159
  }
140
160
  });
141
161
  });
162
+ // Sync CSS variables per-instance — không đụng style tag chia sẻ giữa các instance.
163
+ effect(() => {
164
+ const sbColor = this.scrollbarColor();
165
+ const sbHover = this.scrollbarHoverColor();
166
+ const thColor = this.scrollThumbColor();
167
+ const thHover = this.scrollThumbHoverColor();
168
+ const padding = this.scrollbarPadding();
169
+ untracked(() => {
170
+ const divStyle = this.divContainer.style;
171
+ divStyle.setProperty('--libs-ui-sb-track-color', sbColor);
172
+ divStyle.setProperty('--libs-ui-sb-track-hover-color', sbHover);
173
+ divStyle.setProperty('--libs-ui-sb-thumb-color', thColor);
174
+ divStyle.setProperty('--libs-ui-sb-thumb-hover-color', thHover);
175
+ divStyle.setProperty('--libs-ui-sb-padding', `${padding}px`);
176
+ divStyle.setProperty('--libs-ui-sb-padding-double', `${padding * 2}px`);
177
+ });
178
+ });
179
+ // Window resize → re-measure thumb size cho cả 2 trục.
180
+ fromEvent(window, 'resize')
181
+ .pipe(takeUntilDestroyed(this.destroyRef))
182
+ .subscribe(() => {
183
+ this.updateScrollbarSize('X');
184
+ this.updateScrollbarSize('Y');
185
+ });
186
+ this.destroyRef.onDestroy(() => {
187
+ clearTimeout(this.mouseUpTimer);
188
+ if (this.scrollRafX)
189
+ cancelAnimationFrame(this.scrollRafX);
190
+ if (this.scrollRafY)
191
+ cancelAnimationFrame(this.scrollRafY);
192
+ this.divContainer.remove();
193
+ this.subsX.unsubscribe();
194
+ this.subsY.unsubscribe();
195
+ });
142
196
  }
143
197
  // #region FUNCTIONS
144
198
  get Element() {
145
199
  return this.elementScroll() || this.element.nativeElement;
146
200
  }
201
+ /** Thêm các class consumer truyền qua [classContainer] mà không xóa class hệ thống đã set. */
202
+ syncContainerExtraClasses(classStr) {
203
+ classStr
204
+ .split(' ')
205
+ .filter(Boolean)
206
+ .forEach((className) => this.divContainer.classList.add(className));
207
+ }
147
208
  createScrollbar(scrollDirection, trackEl, thumbEl) {
148
- const idStyleTag = '#id-style-tag-custom-scroll-overlay';
149
- const styleElCustomScrollOverlay = document.getElementById(idStyleTag);
150
- if (!styleElCustomScrollOverlay) {
151
- const styleEl = document.createElement('style');
152
- styleEl.setAttribute('id', idStyleTag);
153
- styleEl.innerHTML = this.styles();
154
- document.head.append(styleEl);
155
- }
209
+ ensureStyleTag();
156
210
  const stylesProperty = {
157
211
  'box-sizing': 'border-box',
158
212
  'scrollbar-width': 'none',
@@ -161,12 +215,10 @@ export class LibsUiComponentsScrollOverlayDirective {
161
215
  'overflow-x': `${this.options()?.scrollX || 'scroll'}`,
162
216
  'overflow-y': `${this.options()?.scrollY || 'scroll'}`,
163
217
  };
164
- Object.keys(stylesProperty).forEach((key) => {
165
- this.render2.setStyle(this.Element, key, stylesProperty[key], 1);
166
- });
167
- trackEl.classList.add(`scrollbar-track`);
218
+ Object.keys(stylesProperty).forEach((key) => this.render2.setStyle(this.Element, key, stylesProperty[key], 1));
219
+ trackEl.classList.add('scrollbar-track');
168
220
  trackEl.classList.add(`scrollbar-track-${scrollDirection}`);
169
- thumbEl.classList.add(`scrollbar-thumb`);
221
+ thumbEl.classList.add('scrollbar-thumb');
170
222
  thumbEl.classList.add(`scrollbar-thumb-${scrollDirection}`);
171
223
  trackEl.appendChild(thumbEl);
172
224
  if (this.Element.className) {
@@ -183,12 +235,12 @@ export class LibsUiComponentsScrollOverlayDirective {
183
235
  if (!this.Element.className.includes('min-w-')) {
184
236
  this.divContainer.classList.add('min-w-0');
185
237
  }
186
- if (!this.Element.className.includes('lib-ui-scroll-overlay-element')) {
187
- this.Element.classList.add('lib-ui-scroll-overlay-element');
238
+ if (!this.Element.className.includes('libs-ui-scroll-overlay-element')) {
239
+ this.Element.classList.add('libs-ui-scroll-overlay-element');
188
240
  }
189
241
  }
190
- if (!this.divContainer.classList.contains('lib-ui-scroll-overlay-container')) {
191
- this.divContainer.classList.add('lib-ui-scroll-overlay-container');
242
+ if (!this.divContainer.classList.contains('libs-ui-scroll-overlay-container')) {
243
+ this.divContainer.classList.add('libs-ui-scroll-overlay-container');
192
244
  }
193
245
  this.divContainer.appendChild(trackEl);
194
246
  if (!this.divContainer.style.position) {
@@ -198,11 +250,11 @@ export class LibsUiComponentsScrollOverlayDirective {
198
250
  this.divContainer.append(this.Element);
199
251
  this.updateScrollbarSize(scrollDirection);
200
252
  }
201
- bindEventsScrollBar(scrollDirection, trackEl) {
253
+ bindEventsScrollBar(scrollDirection, trackEl, subs) {
202
254
  let scrollLeft = this.Element.scrollLeft;
203
255
  let scrollTop = this.Element.scrollTop;
204
- const subs = fromEvent(this.Element, 'scroll')
205
- .pipe(tap((event) => {
256
+ subs.add(fromEvent(this.Element, 'scroll')
257
+ .pipe(tap((event) => this.scheduleScrollHandle(scrollDirection, () => {
206
258
  const target = this.Element;
207
259
  this.outScroll.emit(event);
208
260
  if (scrollDirection === 'X') {
@@ -223,26 +275,26 @@ export class LibsUiComponentsScrollOverlayDirective {
223
275
  scrollTop = target.scrollTop;
224
276
  this.outScrollY.emit(event);
225
277
  if (target.scrollTop === 0) {
226
- return this.outScrollTop.emit(event);
278
+ this.outScrollTop.emit(event);
279
+ return;
227
280
  }
228
- if (target.scrollHeight <= target.scrollTop + target.offsetHeight + 3) {
229
- return this.outScrollBottom.emit(event);
281
+ if (target.scrollHeight <= target.scrollTop + target.offsetHeight + SCROLL_BOTTOM_TOLERANCE) {
282
+ this.outScrollBottom.emit(event);
230
283
  }
231
- }), takeUntilDestroyed(this.destroyRef))
232
- .subscribe();
233
- subs.add(fromEvent(document, 'resize')
234
- .pipe(tap(this.updateScrollbarSize.bind(this, scrollDirection)), takeUntilDestroyed(this.destroyRef))
284
+ })), takeUntilDestroyed(this.destroyRef))
235
285
  .subscribe());
236
286
  const mouseLeave = fromEvent(this.divContainer, 'mouseleave');
237
- const mouseenter = fromEvent(this.divContainer, 'mouseenter');
238
- subs.add(mouseenter
287
+ const mouseEnter = fromEvent(this.divContainer, 'mouseenter');
288
+ subs.add(mouseEnter
239
289
  .pipe(tap(() => {
240
290
  if ((scrollDirection === 'X' && !this.options()?.scrollXOpacity0) || (scrollDirection === 'Y' && !this.options()?.scrollYOpacity0)) {
241
291
  trackEl.style.visibility = 'visible';
242
292
  trackEl.style.opacity = '1';
243
293
  }
244
294
  this.updateScrollbarSize(scrollDirection);
245
- }), switchMap(() => interval(1000).pipe(takeUntil(mouseLeave))), tap(this.updateScrollbarSize.bind(this, scrollDirection)), takeUntilDestroyed(this.destroyRef))
295
+ }), switchMap(() => interval(1000).pipe(takeUntil(mouseLeave))), tap(() => {
296
+ this.updateScrollbarSize(scrollDirection);
297
+ }), takeUntilDestroyed(this.destroyRef))
246
298
  .subscribe());
247
299
  subs.add(mouseLeave
248
300
  .pipe(tap(() => {
@@ -253,20 +305,31 @@ export class LibsUiComponentsScrollOverlayDirective {
253
305
  trackEl.style.opacity = '0';
254
306
  }), takeUntilDestroyed(this.destroyRef))
255
307
  .subscribe());
308
+ }
309
+ /** Throttle scroll handler theo frame — gom nhiều scroll event vào 1 lần update DOM. */
310
+ scheduleScrollHandle(scrollDirection, handle) {
256
311
  if (scrollDirection === 'X') {
257
- this.subsX = subs;
312
+ if (this.scrollRafX)
313
+ return;
314
+ this.scrollRafX = requestAnimationFrame(() => {
315
+ this.scrollRafX = undefined;
316
+ handle();
317
+ });
258
318
  return;
259
319
  }
260
- if (scrollDirection === 'Y') {
261
- this.subsY = subs;
320
+ if (this.scrollRafY)
262
321
  return;
263
- }
322
+ this.scrollRafY = requestAnimationFrame(() => {
323
+ this.scrollRafY = undefined;
324
+ handle();
325
+ });
264
326
  }
265
- handlerClickTrack(scrollDirection) {
327
+ handlerClickTrack(scrollDirection, subs) {
266
328
  const elementTrack = scrollDirection === 'X' ? this.trackX : this.trackY;
267
329
  const elementThumb = scrollDirection === 'X' ? this.thumbX : this.thumbY;
268
- const subs = scrollDirection === 'X' ? this.subsX : this.subsY;
269
- subs.add(fromEvent(elementTrack, 'click').subscribe((e) => {
330
+ subs.add(fromEvent(elementTrack, 'click')
331
+ .pipe(takeUntilDestroyed(this.destroyRef))
332
+ .subscribe((e) => {
270
333
  if (this.isScrollThumb()) {
271
334
  return;
272
335
  }
@@ -281,10 +344,9 @@ export class LibsUiComponentsScrollOverlayDirective {
281
344
  this.updateScrollPositionByUserAction(scrollDirection, e, 'smooth', -1 * elementThumb.getBoundingClientRect().height);
282
345
  }));
283
346
  }
284
- handlerDragAndDropThumb(scrollDirection) {
347
+ handlerDragAndDropThumb(scrollDirection, subs) {
285
348
  const elementTrack = scrollDirection === 'X' ? this.trackX : this.trackY;
286
349
  const elementThumb = scrollDirection === 'X' ? this.thumbX : this.thumbY;
287
- const subs = scrollDirection === 'X' ? this.subsX : this.subsY;
288
350
  let lengthThumbToPointClick = 0;
289
351
  subs.add(getDragEventByElement({
290
352
  elementMouseDown: elementThumb,
@@ -304,9 +366,10 @@ export class LibsUiComponentsScrollOverlayDirective {
304
366
  elementTrack.style.visibility = 'hidden';
305
367
  elementTrack.style.opacity = '0';
306
368
  }
307
- setTimeout(() => {
369
+ clearTimeout(this.mouseUpTimer);
370
+ this.mouseUpTimer = setTimeout(() => {
308
371
  this.isScrollThumb.set(false);
309
- }, 250);
372
+ }, MOUSE_UP_RESET_DELAY);
310
373
  },
311
374
  destroyRef: this.destroyRef,
312
375
  }).subscribe((mouseEvent) => {
@@ -333,45 +396,48 @@ export class LibsUiComponentsScrollOverlayDirective {
333
396
  if (scrollDirection === 'X') {
334
397
  const containerWidth = this.Element.offsetWidth;
335
398
  const contentWidth = (this.elementCheckScrollX() || this.Element).scrollWidth;
399
+ if (containerWidth === this.lastContainerWidth && contentWidth === this.lastContentWidth)
400
+ return;
401
+ this.lastContainerWidth = containerWidth;
402
+ this.lastContentWidth = contentWidth;
336
403
  const thumbWidth = (containerWidth / contentWidth) * containerWidth;
337
- this.thumbX.style.width = `${Math.max(20, thumbWidth)}px`;
338
- this.trackX.style.display = 'none';
339
- if (contentWidth > containerWidth) {
340
- this.trackX.style.display = 'block';
341
- }
404
+ this.thumbX.style.width = `${Math.max(MIN_THUMB_SIZE, thumbWidth)}px`;
405
+ this.trackX.style.display = contentWidth > containerWidth ? 'block' : 'none';
342
406
  this.updateScrollbarPosition(scrollDirection);
343
407
  return;
344
408
  }
345
409
  const containerHeight = this.Element.offsetHeight;
346
410
  const contentHeight = (this.elementCheckScrollY() || this.Element).scrollHeight;
411
+ if (containerHeight === this.lastContainerHeight && contentHeight === this.lastContentHeight)
412
+ return;
413
+ this.lastContainerHeight = containerHeight;
414
+ this.lastContentHeight = contentHeight;
347
415
  const thumbHeight = (containerHeight / contentHeight) * containerHeight;
348
- this.thumbY.style.height = `${Math.max(20, thumbHeight)}px`;
349
- this.trackY.style.display = 'none';
350
- if (contentHeight > containerHeight) {
351
- this.trackY.style.display = 'block';
352
- }
416
+ this.thumbY.style.height = `${Math.max(MIN_THUMB_SIZE, thumbHeight)}px`;
417
+ this.trackY.style.display = contentHeight > containerHeight ? 'block' : 'none';
353
418
  this.updateScrollbarPosition('Y');
354
419
  }
355
420
  updateScrollbarPosition(scrollDirection) {
356
421
  if (scrollDirection === 'X') {
357
422
  const containerWidth = this.Element.offsetWidth;
358
423
  const contentWidth = (this.elementCheckScrollX() || this.Element).scrollWidth;
359
- const scrollLeft = this.Element.scrollLeft;
360
- const thumbPosition = (scrollLeft / (contentWidth - containerWidth)) * (containerWidth - this.thumbX.offsetWidth);
424
+ const denominatorScroll = contentWidth - containerWidth;
425
+ if (denominatorScroll <= 0)
426
+ return;
427
+ const denominatorThumb = containerWidth - this.thumbX.offsetWidth;
428
+ const thumbPosition = (this.Element.scrollLeft / denominatorScroll) * denominatorThumb;
361
429
  this.thumbX.style.left = `${thumbPosition}px`;
362
430
  return;
363
431
  }
364
432
  const containerHeight = this.Element.offsetHeight;
365
433
  const contentHeight = (this.elementCheckScrollY() || this.Element).scrollHeight;
366
- const scrollTop = this.Element.scrollTop;
367
- const thumbPosition = (scrollTop / (contentHeight - containerHeight)) * (containerHeight - this.thumbY.offsetHeight);
434
+ const denominatorScroll = contentHeight - containerHeight;
435
+ if (denominatorScroll <= 0)
436
+ return;
437
+ const denominatorThumb = containerHeight - this.thumbY.offsetHeight;
438
+ const thumbPosition = (this.Element.scrollTop / denominatorScroll) * denominatorThumb;
368
439
  this.thumbY.style.top = `${thumbPosition}px`;
369
440
  }
370
- ngOnDestroy() {
371
- this.divContainer.remove();
372
- this.subsX.unsubscribe();
373
- this.subsY.unsubscribe();
374
- }
375
441
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: LibsUiComponentsScrollOverlayDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
376
442
  static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.2.14", type: LibsUiComponentsScrollOverlayDirective, isStandalone: true, selector: "[LibsUiComponentsScrollOverlayDirective]", inputs: { debugMode: { classPropertyName: "debugMode", publicName: "debugMode", isSignal: true, isRequired: false, transformFunction: null }, ignoreInit: { classPropertyName: "ignoreInit", publicName: "ignoreInit", isSignal: true, isRequired: false, transformFunction: null }, classContainer: { classPropertyName: "classContainer", publicName: "classContainer", isSignal: true, isRequired: false, transformFunction: null }, options: { classPropertyName: "options", publicName: "options", isSignal: true, isRequired: false, transformFunction: null }, elementCheckScrollX: { classPropertyName: "elementCheckScrollX", publicName: "elementCheckScrollX", isSignal: true, isRequired: false, transformFunction: null }, elementCheckScrollY: { classPropertyName: "elementCheckScrollY", publicName: "elementCheckScrollY", isSignal: true, isRequired: false, transformFunction: null }, elementScroll: { classPropertyName: "elementScroll", publicName: "elementScroll", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { outScroll: "outScroll", outScrollX: "outScrollX", outScrollY: "outScrollY", outScrollTop: "outScrollTop", outScrollBottom: "outScrollBottom" }, ngImport: i0 });
377
443
  }
@@ -383,4 +449,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
383
449
  standalone: true,
384
450
  }]
385
451
  }], ctorParameters: () => [] });
386
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"scroll-overlay.directive.js","sourceRoot":"","sources":["../../../../../libs-ui/components/scroll-overlay/src/scroll-overlay.directive.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { DestroyRef, Directive, ElementRef, OnDestroy, Renderer2, computed, effect, inject, input, output, signal, untracked } from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { checkMouseOverInContainer, getDragEventByElement } from '@libs-ui/utils';\nimport { Subscription, fromEvent, interval, switchMap, takeUntil, tap } from 'rxjs';\nimport { IScrollOverlayOptions, TYPE_SCROLL_DIRECTION } from './scroll.interface';\n@Directive({\n  // eslint-disable-next-line @angular-eslint/directive-selector\n  selector: '[LibsUiComponentsScrollOverlayDirective]',\n  standalone: true,\n})\nexport class LibsUiComponentsScrollOverlayDirective implements OnDestroy {\n  // #region PROPERTY\n  private readonly styles = computed(\n    () => `\n      .scrollbar-track{\n         background-color:${this.scrollbarColor()};\n      }\n      .scrollbar-track:hover{\n        background-color:${this.scrollbarHoverColor()};\n      }\n      .scrollbar-track-X {\n        width:100%;\n        position: absolute;\n        bottom: 0;\n        left: 0;\n        visibility: hidden;\n        cursor: pointer;\n        opacity: 0;\n        z-index: 1;\n        transition: opacity 0.3s ease, visibility 0.3s ease;\n      }\n\n      .scrollbar-track-Y {\n        height:100%;\n        position: absolute;\n        top: 0;\n        right: 0;\n        visibility: hidden;\n        cursor: pointer;\n        opacity: 0;\n        z-index: 1;\n        transition: opacity 0.3s ease, visibility 0.3s ease;\n      }\n\n      .scrollbar-thumb{\n        background-color:${this.scrollThumbColor()};\n      }\n      .scrollbar-thumb:hover{\n        background-color:${this.scrollThumbHoverColor()};\n      }\n\n      .scrollbar-thumb-X {\n        height: calc(100% - ${this.scrollbarPadding() * 2}px);\n        bottom: ${this.scrollbarPadding()}px;\n        border-radius: 4px;\n        cursor: grabbing;\n        transition: background-color 0.3s;\n        position: absolute;\n      }\n\n      .scrollbar-thumb-Y {\n        width: calc(100% - ${this.scrollbarPadding() * 2}px);\n        right: ${this.scrollbarPadding()}px;\n        border-radius: 4px;\n        cursor: grabbing;\n        transition: background-color 0.3s;\n        position: absolute;\n      }\n\n      .lib-ui-scroll-overlay-container .lib-ui-scroll-overlay-element::-webkit-scrollbar {\n        width: 0 !important;\n        height: 0 !important;\n      }\n  `,\n    {}\n  );\n  private isScrollThumb = signal<boolean>(false);\n  private keepDisplayThumb = signal<boolean>(false);\n  private subsX = new Subscription();\n  private subsY = new Subscription();\n  private scrollbarWidth = computed(() => this.options()?.scrollbarWidth ?? 10); // Chiều rộng thanh cuộn\n  private scrollbarPadding = computed(() => this.options()?.scrollbarPadding ?? 2); // Chiều rộng thanh cuộn\n  private scrollbarColor = computed(() => this.options()?.scrollbarColor ?? '');\n  private scrollbarHoverColor = computed(() => this.options()?.scrollbarColor ?? '#CDD0D640');\n  private scrollThumbColor = computed(() => this.options()?.scrollThumbColor ?? '#CDD0D6');\n  private scrollThumbHoverColor = computed(() => this.options()?.scrollThumbHoverColor ?? '#9CA2AD');\n  private readonly divContainer = document.createElement('div');\n  private readonly trackX: HTMLElement = document.createElement('div');\n  private readonly thumbX: HTMLElement = document.createElement('div');\n  private readonly trackY: HTMLElement = document.createElement('div');\n  private readonly thumbY: HTMLElement = document.createElement('div');\n\n  // #region INPUT\n  readonly debugMode = input<boolean>(false);\n  readonly ignoreInit = input<boolean>(false);\n  readonly classContainer = input<string, string | undefined>('', { transform: (value) => value ?? '' });\n  readonly options = input<IScrollOverlayOptions | undefined>(Object.assign({}));\n  readonly elementCheckScrollX = input<HTMLElement>();\n  readonly elementCheckScrollY = input<HTMLElement>();\n  readonly elementScroll = input<HTMLElement>();\n\n  // #region OUTPUT\n  readonly outScroll = output<Event>();\n  readonly outScrollX = output<Event>();\n  readonly outScrollY = output<Event>();\n  readonly outScrollTop = output<Event>();\n  readonly outScrollBottom = output<Event>();\n\n  // #region INJECT\n  private element = inject(ElementRef);\n  private render2 = inject(Renderer2);\n  private destroyRef = inject(DestroyRef);\n\n  constructor() {\n    effect(() => {\n      if (this.ignoreInit()) {\n        return;\n      }\n      const options = this.options();\n      this.divContainer.className = '';\n      this.classContainer()\n        ?.split(' ')\n        .forEach((className) => {\n          if (!className) {\n            return;\n          }\n          this.divContainer.classList.add(className);\n        });\n\n      untracked(() => {\n        this.Element.classList.toggle('overflow-hidden', options?.scrollX === 'hidden' && options?.scrollY === 'hidden');\n        if (options?.scrollX !== 'hidden') {\n          this.subsX.unsubscribe();\n          this.trackX.className = '';\n          this.thumbX.className = '';\n          this.trackX.style.height = `${this.scrollbarWidth()}px`;\n          this.createScrollbar('X', this.trackX, this.thumbX);\n          this.bindEventsScrollBar('X', this.trackX);\n\n          this.handlerDragAndDropThumb('X');\n          this.handlerClickTrack('X');\n        }\n\n        if (options?.scrollY !== 'hidden') {\n          this.trackY.className = '';\n          this.thumbY.className = '';\n          this.trackY.style.width = `${this.scrollbarWidth()}px`;\n          this.subsY.unsubscribe();\n          this.createScrollbar('Y', this.trackY, this.thumbY);\n          this.bindEventsScrollBar('Y', this.trackY);\n\n          this.handlerDragAndDropThumb('Y');\n          this.handlerClickTrack('Y');\n        }\n      });\n    });\n  }\n\n  // #region FUNCTIONS\n  private get Element(): HTMLElement {\n    return this.elementScroll() || this.element.nativeElement;\n  }\n\n  private createScrollbar(scrollDirection: TYPE_SCROLL_DIRECTION, trackEl: HTMLElement, thumbEl: HTMLElement) {\n    const idStyleTag = '#id-style-tag-custom-scroll-overlay';\n    const styleElCustomScrollOverlay = document.getElementById(idStyleTag);\n\n    if (!styleElCustomScrollOverlay) {\n      const styleEl = document.createElement('style');\n      styleEl.setAttribute('id', idStyleTag);\n      styleEl.innerHTML = this.styles();\n      document.head.append(styleEl);\n    }\n\n    const stylesProperty = {\n      'box-sizing': 'border-box',\n      'scrollbar-width': 'none',\n      'scrollbar-color': this.options()?.ignoreTransparentScrollBarColorDefault ? 'auto' : 'transparent transparent',\n      overflow: 'hidden',\n      'overflow-x': `${this.options()?.scrollX || 'scroll'}`,\n      'overflow-y': `${this.options()?.scrollY || 'scroll'}`,\n    } as any;\n\n    Object.keys(stylesProperty).forEach((key) => {\n      this.render2.setStyle(this.Element, key, stylesProperty[key], 1);\n    });\n\n    trackEl.classList.add(`scrollbar-track`);\n    trackEl.classList.add(`scrollbar-track-${scrollDirection}`);\n\n    thumbEl.classList.add(`scrollbar-thumb`);\n    thumbEl.classList.add(`scrollbar-thumb-${scrollDirection}`);\n    trackEl.appendChild(thumbEl);\n    if (this.Element.className) {\n      this.Element.className.split(' ').forEach((className: string) => {\n        if (\n          className &&\n          (['w-full', 'w-screen', 'h-full', 'h-screen', 'shrink-0'].includes(className) || className.includes('min-h-') || className.includes('min-w-') || /^(!?)(h|w)-\\[[0-9]+px\\]$/.test(className)) &&\n          !this.divContainer.classList.contains(className)\n        ) {\n          this.divContainer.classList.add(className);\n        }\n      });\n      if (!this.Element.className.includes('min-h-')) {\n        this.divContainer.classList.add('min-h-0');\n      }\n      if (!this.Element.className.includes('min-w-')) {\n        this.divContainer.classList.add('min-w-0');\n      }\n      if (!this.Element.className.includes('lib-ui-scroll-overlay-element')) {\n        this.Element.classList.add('lib-ui-scroll-overlay-element');\n      }\n    }\n    if (!this.divContainer.classList.contains('lib-ui-scroll-overlay-container')) {\n      this.divContainer.classList.add('lib-ui-scroll-overlay-container');\n    }\n    this.divContainer.appendChild(trackEl);\n\n    if (!this.divContainer.style.position) {\n      this.Element.parentElement?.insertBefore(this.divContainer, this.Element);\n      this.divContainer.style.position = 'relative';\n    }\n    this.divContainer.append(this.Element);\n    this.updateScrollbarSize(scrollDirection);\n  }\n\n  private bindEventsScrollBar(scrollDirection: TYPE_SCROLL_DIRECTION, trackEl: HTMLElement) {\n    let scrollLeft = this.Element.scrollLeft;\n    let scrollTop = this.Element.scrollTop;\n    const subs: Subscription = fromEvent<Event>(this.Element, 'scroll')\n      .pipe(\n        tap((event) => {\n          const target = this.Element;\n\n          this.outScroll.emit(event);\n          if (scrollDirection === 'X') {\n            if (target.scrollLeft && target.scrollLeft + target.offsetWidth >= target.scrollWidth) {\n              target.scrollLeft = target.scrollWidth - target.offsetWidth - (target.offsetWidth - target.clientWidth);\n            }\n\n            if (target.scrollLeft !== scrollLeft) {\n              this.outScrollX.emit(event);\n            }\n            scrollLeft = target.scrollLeft;\n            this.updateScrollbarPosition(scrollDirection);\n\n            return;\n          }\n\n          if (target.scrollTop === scrollTop) {\n            return;\n          }\n          this.updateScrollbarPosition(scrollDirection);\n          scrollTop = target.scrollTop;\n          this.outScrollY.emit(event);\n\n          if (target.scrollTop === 0) {\n            return this.outScrollTop.emit(event);\n          }\n\n          if (target.scrollHeight <= target.scrollTop + target.offsetHeight + 3) {\n            return this.outScrollBottom.emit(event);\n          }\n        }),\n        takeUntilDestroyed(this.destroyRef)\n      )\n      .subscribe();\n\n    subs.add(\n      fromEvent(document, 'resize')\n        .pipe(tap(this.updateScrollbarSize.bind(this, scrollDirection)), takeUntilDestroyed(this.destroyRef))\n        .subscribe()\n    );\n\n    const mouseLeave = fromEvent(this.divContainer, 'mouseleave');\n    const mouseenter = fromEvent(this.divContainer, 'mouseenter');\n\n    subs.add(\n      mouseenter\n        .pipe(\n          tap(() => {\n            if ((scrollDirection === 'X' && !this.options()?.scrollXOpacity0) || (scrollDirection === 'Y' && !this.options()?.scrollYOpacity0)) {\n              trackEl.style.visibility = 'visible';\n              trackEl.style.opacity = '1';\n            }\n            this.updateScrollbarSize(scrollDirection);\n          }),\n          switchMap(() => interval(1000).pipe(takeUntil(mouseLeave))),\n          tap(this.updateScrollbarSize.bind(this, scrollDirection)),\n          takeUntilDestroyed(this.destroyRef)\n        )\n        .subscribe()\n    );\n\n    subs.add(\n      mouseLeave\n        .pipe(\n          tap(() => {\n            if (this.keepDisplayThumb()) {\n              return;\n            }\n            trackEl.style.visibility = 'hidden';\n            trackEl.style.opacity = '0';\n          }),\n          takeUntilDestroyed(this.destroyRef)\n        )\n        .subscribe()\n    );\n\n    if (scrollDirection === 'X') {\n      this.subsX = subs;\n\n      return;\n    }\n\n    if (scrollDirection === 'Y') {\n      this.subsY = subs;\n\n      return;\n    }\n  }\n\n  protected handlerClickTrack(scrollDirection: TYPE_SCROLL_DIRECTION) {\n    const elementTrack = scrollDirection === 'X' ? this.trackX : this.trackY;\n    const elementThumb = scrollDirection === 'X' ? this.thumbX : this.thumbY;\n    const subs = scrollDirection === 'X' ? this.subsX : this.subsY;\n\n    subs.add(\n      fromEvent<MouseEvent>(elementTrack, 'click').subscribe((e) => {\n        if (this.isScrollThumb()) {\n          return;\n        }\n        if ((scrollDirection === 'X' && e.clientX < elementThumb.getBoundingClientRect().left) || (scrollDirection === 'Y' && e.clientY < elementThumb.getBoundingClientRect().top)) {\n          this.updateScrollPositionByUserAction(scrollDirection, e, 'smooth', 0);\n          return;\n        }\n\n        if (scrollDirection === 'X') {\n          this.updateScrollPositionByUserAction(scrollDirection, e, 'smooth', -1 * elementThumb.getBoundingClientRect().width);\n          return;\n        }\n        this.updateScrollPositionByUserAction(scrollDirection, e, 'smooth', -1 * elementThumb.getBoundingClientRect().height);\n      })\n    );\n  }\n\n  protected handlerDragAndDropThumb(scrollDirection: TYPE_SCROLL_DIRECTION) {\n    const elementTrack = scrollDirection === 'X' ? this.trackX : this.trackY;\n    const elementThumb = scrollDirection === 'X' ? this.thumbX : this.thumbY;\n    const subs = scrollDirection === 'X' ? this.subsX : this.subsY;\n    let lengthThumbToPointClick = 0;\n\n    subs.add(\n      getDragEventByElement({\n        elementMouseDown: elementThumb,\n        functionMouseDown: (mouseEvent: MouseEvent) => {\n          this.isScrollThumb.set(true);\n          this.keepDisplayThumb.set(true);\n          if (scrollDirection === 'X') {\n            lengthThumbToPointClick = elementThumb.getBoundingClientRect().left - mouseEvent.clientX;\n            return;\n          }\n          lengthThumbToPointClick = elementThumb.getBoundingClientRect().top - mouseEvent.clientY;\n        },\n        functionMouseUp: (mouseEvent: MouseEvent) => {\n          this.keepDisplayThumb.set(false);\n          lengthThumbToPointClick = 0;\n          if (!checkMouseOverInContainer(mouseEvent, this.Element)) {\n            elementTrack.style.visibility = 'hidden';\n            elementTrack.style.opacity = '0';\n          }\n          setTimeout(() => {\n            this.isScrollThumb.set(false);\n          }, 250);\n        },\n        destroyRef: this.destroyRef,\n      }).subscribe((mouseEvent: MouseEvent) => {\n        this.updateScrollPositionByUserAction(scrollDirection, mouseEvent, 'auto', lengthThumbToPointClick);\n      })\n    );\n  }\n\n  private updateScrollPositionByUserAction(scrollDirection: TYPE_SCROLL_DIRECTION, e: MouseEvent, behavior: 'auto' | 'smooth', lengthThumbToPointClick = 0) {\n    e.stopPropagation();\n    if (scrollDirection === 'X') {\n      const containerWidth = this.Element.offsetWidth;\n      const contentWidth = (this.elementCheckScrollX() || this.Element).scrollWidth;\n      const thumbPosition = e.clientX - this.Element.getBoundingClientRect().left + lengthThumbToPointClick;\n      const scrollLeft = (thumbPosition / (containerWidth - this.thumbX.offsetWidth)) * (contentWidth - containerWidth);\n\n      this.Element.scroll({ left: scrollLeft, behavior });\n      return;\n    }\n    const containerHeight = this.Element.offsetHeight;\n    const contentHeight = (this.elementCheckScrollY() || this.Element).scrollHeight;\n    const thumbPosition = e.clientY - this.Element.getBoundingClientRect().top + lengthThumbToPointClick;\n    const scrollTop = (thumbPosition / (containerHeight - this.thumbY.offsetHeight)) * (contentHeight - containerHeight);\n\n    this.Element.scroll({ top: scrollTop, behavior });\n  }\n\n  private updateScrollbarSize(scrollDirection: TYPE_SCROLL_DIRECTION) {\n    if (scrollDirection === 'X') {\n      const containerWidth = this.Element.offsetWidth;\n      const contentWidth = (this.elementCheckScrollX() || this.Element).scrollWidth;\n      const thumbWidth = (containerWidth / contentWidth) * containerWidth;\n\n      this.thumbX.style.width = `${Math.max(20, thumbWidth)}px`;\n      this.trackX.style.display = 'none';\n      if (contentWidth > containerWidth) {\n        this.trackX.style.display = 'block';\n      }\n      this.updateScrollbarPosition(scrollDirection);\n\n      return;\n    }\n\n    const containerHeight = this.Element.offsetHeight;\n    const contentHeight = (this.elementCheckScrollY() || this.Element).scrollHeight;\n    const thumbHeight = (containerHeight / contentHeight) * containerHeight;\n\n    this.thumbY.style.height = `${Math.max(20, thumbHeight)}px`;\n    this.trackY.style.display = 'none';\n    if (contentHeight > containerHeight) {\n      this.trackY.style.display = 'block';\n    }\n\n    this.updateScrollbarPosition('Y');\n  }\n\n  private updateScrollbarPosition(scrollDirection: TYPE_SCROLL_DIRECTION) {\n    if (scrollDirection === 'X') {\n      const containerWidth = this.Element.offsetWidth;\n      const contentWidth = (this.elementCheckScrollX() || this.Element).scrollWidth;\n      const scrollLeft = this.Element.scrollLeft;\n      const thumbPosition = (scrollLeft / (contentWidth - containerWidth)) * (containerWidth - this.thumbX.offsetWidth);\n\n      this.thumbX.style.left = `${thumbPosition}px`;\n\n      return;\n    }\n    const containerHeight = this.Element.offsetHeight;\n    const contentHeight = (this.elementCheckScrollY() || this.Element).scrollHeight;\n    const scrollTop = this.Element.scrollTop;\n    const thumbPosition = (scrollTop / (contentHeight - containerHeight)) * (containerHeight - this.thumbY.offsetHeight);\n\n    this.thumbY.style.top = `${thumbPosition}px`;\n  }\n\n  ngOnDestroy(): void {\n    this.divContainer.remove();\n    this.subsX.unsubscribe();\n    this.subsY.unsubscribe();\n  }\n}\n"]}
452
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"scroll-overlay.directive.js","sourceRoot":"","sources":["../../../../../libs-ui/components/scroll-overlay/src/scroll-overlay.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { DestroyRef, Directive, ElementRef, Renderer2, computed, effect, inject, input, output, signal, untracked } from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { checkMouseOverInContainer, getDragEventByElement } from '@libs-ui/utils';\nimport { Subscription, fromEvent, interval, switchMap, takeUntil, tap } from 'rxjs';\nimport { IScrollOverlayOptions, TYPE_SCROLL_DIRECTION } from './scroll.interface';\n\nconst STYLE_TAG_ID = 'libs-ui-scroll-overlay-style-tag';\nconst SCROLL_BOTTOM_TOLERANCE = 3;\nconst MIN_THUMB_SIZE = 20;\nconst MOUSE_UP_RESET_DELAY = 250;\nconst DEFAULT_SCROLLBAR_HOVER_COLOR = '#CDD0D640';\nconst DEFAULT_SCROLL_THUMB_COLOR = '#CDD0D6';\nconst DEFAULT_SCROLL_THUMB_HOVER_COLOR = '#9CA2AD';\n\n/**\n * CSS chia sẻ cho mọi instance. Màu/padding lấy qua CSS variables để mỗi\n * directive instance có thể custom độc lập mà không phải re-write style tag.\n */\nconst STYLE_CONTENT = `\n  .libs-ui-scroll-overlay-container .scrollbar-track {\n    background-color: var(--libs-ui-sb-track-color, transparent);\n  }\n  .libs-ui-scroll-overlay-container .scrollbar-track:hover {\n    background-color: var(--libs-ui-sb-track-hover-color, ${DEFAULT_SCROLLBAR_HOVER_COLOR});\n  }\n  .libs-ui-scroll-overlay-container .scrollbar-track-X {\n    width: 100%;\n    position: absolute;\n    bottom: 0;\n    left: 0;\n    visibility: hidden;\n    cursor: pointer;\n    opacity: 0;\n    z-index: 1;\n    transition: opacity 0.3s ease, visibility 0.3s ease;\n  }\n  .libs-ui-scroll-overlay-container .scrollbar-track-Y {\n    height: 100%;\n    position: absolute;\n    top: 0;\n    right: 0;\n    visibility: hidden;\n    cursor: pointer;\n    opacity: 0;\n    z-index: 1;\n    transition: opacity 0.3s ease, visibility 0.3s ease;\n  }\n  .libs-ui-scroll-overlay-container .scrollbar-thumb {\n    background-color: var(--libs-ui-sb-thumb-color, ${DEFAULT_SCROLL_THUMB_COLOR});\n  }\n  .libs-ui-scroll-overlay-container .scrollbar-thumb:hover {\n    background-color: var(--libs-ui-sb-thumb-hover-color, ${DEFAULT_SCROLL_THUMB_HOVER_COLOR});\n  }\n  .libs-ui-scroll-overlay-container .scrollbar-thumb-X {\n    height: calc(100% - var(--libs-ui-sb-padding-double, 4px));\n    bottom: var(--libs-ui-sb-padding, 2px);\n    border-radius: 4px;\n    cursor: grabbing;\n    transition: background-color 0.3s;\n    position: absolute;\n  }\n  .libs-ui-scroll-overlay-container .scrollbar-thumb-Y {\n    width: calc(100% - var(--libs-ui-sb-padding-double, 4px));\n    right: var(--libs-ui-sb-padding, 2px);\n    border-radius: 4px;\n    cursor: grabbing;\n    transition: background-color 0.3s;\n    position: absolute;\n  }\n  .libs-ui-scroll-overlay-container .libs-ui-scroll-overlay-element::-webkit-scrollbar {\n    width: 0 !important;\n    height: 0 !important;\n  }\n`;\n\nconst ensureStyleTag = () => {\n  if (document.getElementById(STYLE_TAG_ID)) {\n    return;\n  }\n  const styleEl = document.createElement('style');\n  styleEl.id = STYLE_TAG_ID;\n  styleEl.textContent = STYLE_CONTENT;\n  document.head.append(styleEl);\n};\n\n@Directive({\n  // eslint-disable-next-line @angular-eslint/directive-selector\n  selector: '[LibsUiComponentsScrollOverlayDirective]',\n  standalone: true,\n})\nexport class LibsUiComponentsScrollOverlayDirective {\n  // #region PROPERTY\n  private isScrollThumb = signal<boolean>(false);\n  private keepDisplayThumb = signal<boolean>(false);\n  private subsX = new Subscription();\n  private subsY = new Subscription();\n  /** Timer reset isScrollThumb sau drag end — phải clear khi destroy để tránh set signal trên instance đã teardown. */\n  private mouseUpTimer?: ReturnType<typeof setTimeout>;\n  /** rAF throttle cho scroll handler — gom multiple scroll events về 1 lần update DOM mỗi frame. */\n  private scrollRafX?: number;\n  private scrollRafY?: number;\n  /** Cache dimensions — skip DOM write nếu kích thước không đổi giữa 2 lần poll. */\n  private lastContentWidth = 0;\n  private lastContentHeight = 0;\n  private lastContainerWidth = 0;\n  private lastContainerHeight = 0;\n\n  private scrollbarWidth = computed(() => this.options()?.scrollbarWidth ?? 10);\n  private scrollbarPadding = computed(() => this.options()?.scrollbarPadding ?? 2);\n  private scrollbarColor = computed(() => this.options()?.scrollbarColor ?? '');\n  private scrollbarHoverColor = computed(() => this.options()?.scrollbarHoverColor ?? DEFAULT_SCROLLBAR_HOVER_COLOR);\n  private scrollThumbColor = computed(() => this.options()?.scrollThumbColor ?? DEFAULT_SCROLL_THUMB_COLOR);\n  private scrollThumbHoverColor = computed(() => this.options()?.scrollThumbHoverColor ?? DEFAULT_SCROLL_THUMB_HOVER_COLOR);\n\n  private readonly divContainer = document.createElement('div');\n  private readonly trackX: HTMLElement = document.createElement('div');\n  private readonly thumbX: HTMLElement = document.createElement('div');\n  private readonly trackY: HTMLElement = document.createElement('div');\n  private readonly thumbY: HTMLElement = document.createElement('div');\n\n  // #region INPUT\n  readonly debugMode = input<boolean>(false);\n  readonly ignoreInit = input<boolean>(false);\n  readonly classContainer = input<string, string | undefined>('', { transform: (value) => value ?? '' });\n  readonly options = input<IScrollOverlayOptions | undefined>(Object.assign({}));\n  readonly elementCheckScrollX = input<HTMLElement>();\n  readonly elementCheckScrollY = input<HTMLElement>();\n  readonly elementScroll = input<HTMLElement>();\n\n  // #region OUTPUT\n  readonly outScroll = output<Event>();\n  readonly outScrollX = output<Event>();\n  readonly outScrollY = output<Event>();\n  readonly outScrollTop = output<Event>();\n  readonly outScrollBottom = output<Event>();\n\n  // #region INJECT\n  private element = inject(ElementRef);\n  private render2 = inject(Renderer2);\n  private destroyRef = inject(DestroyRef);\n\n  constructor() {\n    // Setup scrollbars khi options/classContainer đổi.\n    effect(() => {\n      if (this.ignoreInit()) {\n        return;\n      }\n      const options = this.options();\n      const classContainer = this.classContainer();\n\n      untracked(() => {\n        this.syncContainerExtraClasses(classContainer);\n        this.Element.classList.toggle('overflow-hidden', options?.scrollX === 'hidden' && options?.scrollY === 'hidden');\n\n        if (options?.scrollX !== 'hidden') {\n          this.subsX.unsubscribe();\n          this.subsX = new Subscription();\n          this.trackX.className = '';\n          this.thumbX.className = '';\n          this.trackX.style.height = `${this.scrollbarWidth()}px`;\n          this.createScrollbar('X', this.trackX, this.thumbX);\n          this.bindEventsScrollBar('X', this.trackX, this.subsX);\n          this.handlerDragAndDropThumb('X', this.subsX);\n          this.handlerClickTrack('X', this.subsX);\n        }\n\n        if (options?.scrollY !== 'hidden') {\n          this.subsY.unsubscribe();\n          this.subsY = new Subscription();\n          this.trackY.className = '';\n          this.thumbY.className = '';\n          this.trackY.style.width = `${this.scrollbarWidth()}px`;\n          this.createScrollbar('Y', this.trackY, this.thumbY);\n          this.bindEventsScrollBar('Y', this.trackY, this.subsY);\n          this.handlerDragAndDropThumb('Y', this.subsY);\n          this.handlerClickTrack('Y', this.subsY);\n        }\n      });\n    });\n\n    // Sync CSS variables per-instance — không đụng style tag chia sẻ giữa các instance.\n    effect(() => {\n      const sbColor = this.scrollbarColor();\n      const sbHover = this.scrollbarHoverColor();\n      const thColor = this.scrollThumbColor();\n      const thHover = this.scrollThumbHoverColor();\n      const padding = this.scrollbarPadding();\n      untracked(() => {\n        const divStyle = this.divContainer.style;\n        divStyle.setProperty('--libs-ui-sb-track-color', sbColor);\n        divStyle.setProperty('--libs-ui-sb-track-hover-color', sbHover);\n        divStyle.setProperty('--libs-ui-sb-thumb-color', thColor);\n        divStyle.setProperty('--libs-ui-sb-thumb-hover-color', thHover);\n        divStyle.setProperty('--libs-ui-sb-padding', `${padding}px`);\n        divStyle.setProperty('--libs-ui-sb-padding-double', `${padding * 2}px`);\n      });\n    });\n\n    // Window resize → re-measure thumb size cho cả 2 trục.\n    fromEvent(window, 'resize')\n      .pipe(takeUntilDestroyed(this.destroyRef))\n      .subscribe(() => {\n        this.updateScrollbarSize('X');\n        this.updateScrollbarSize('Y');\n      });\n\n    this.destroyRef.onDestroy(() => {\n      clearTimeout(this.mouseUpTimer);\n      if (this.scrollRafX) cancelAnimationFrame(this.scrollRafX);\n      if (this.scrollRafY) cancelAnimationFrame(this.scrollRafY);\n      this.divContainer.remove();\n      this.subsX.unsubscribe();\n      this.subsY.unsubscribe();\n    });\n  }\n\n  // #region FUNCTIONS\n  private get Element(): HTMLElement {\n    return this.elementScroll() || this.element.nativeElement;\n  }\n\n  /** Thêm các class consumer truyền qua [classContainer] mà không xóa class hệ thống đã set. */\n  private syncContainerExtraClasses(classStr: string) {\n    classStr\n      .split(' ')\n      .filter(Boolean)\n      .forEach((className) => this.divContainer.classList.add(className));\n  }\n\n  private createScrollbar(scrollDirection: TYPE_SCROLL_DIRECTION, trackEl: HTMLElement, thumbEl: HTMLElement) {\n    ensureStyleTag();\n\n    const stylesProperty = {\n      'box-sizing': 'border-box',\n      'scrollbar-width': 'none',\n      'scrollbar-color': this.options()?.ignoreTransparentScrollBarColorDefault ? 'auto' : 'transparent transparent',\n      overflow: 'hidden',\n      'overflow-x': `${this.options()?.scrollX || 'scroll'}`,\n      'overflow-y': `${this.options()?.scrollY || 'scroll'}`,\n    } as Record<string, string>;\n    Object.keys(stylesProperty).forEach((key) => this.render2.setStyle(this.Element, key, stylesProperty[key], 1));\n\n    trackEl.classList.add('scrollbar-track');\n    trackEl.classList.add(`scrollbar-track-${scrollDirection}`);\n    thumbEl.classList.add('scrollbar-thumb');\n    thumbEl.classList.add(`scrollbar-thumb-${scrollDirection}`);\n    trackEl.appendChild(thumbEl);\n\n    if (this.Element.className) {\n      this.Element.className.split(' ').forEach((className: string) => {\n        if (\n          className &&\n          (['w-full', 'w-screen', 'h-full', 'h-screen', 'shrink-0'].includes(className) || className.includes('min-h-') || className.includes('min-w-') || /^(!?)(h|w)-\\[[0-9]+px\\]$/.test(className)) &&\n          !this.divContainer.classList.contains(className)\n        ) {\n          this.divContainer.classList.add(className);\n        }\n      });\n      if (!this.Element.className.includes('min-h-')) {\n        this.divContainer.classList.add('min-h-0');\n      }\n      if (!this.Element.className.includes('min-w-')) {\n        this.divContainer.classList.add('min-w-0');\n      }\n      if (!this.Element.className.includes('libs-ui-scroll-overlay-element')) {\n        this.Element.classList.add('libs-ui-scroll-overlay-element');\n      }\n    }\n    if (!this.divContainer.classList.contains('libs-ui-scroll-overlay-container')) {\n      this.divContainer.classList.add('libs-ui-scroll-overlay-container');\n    }\n    this.divContainer.appendChild(trackEl);\n\n    if (!this.divContainer.style.position) {\n      this.Element.parentElement?.insertBefore(this.divContainer, this.Element);\n      this.divContainer.style.position = 'relative';\n    }\n    this.divContainer.append(this.Element);\n    this.updateScrollbarSize(scrollDirection);\n  }\n\n  private bindEventsScrollBar(scrollDirection: TYPE_SCROLL_DIRECTION, trackEl: HTMLElement, subs: Subscription) {\n    let scrollLeft = this.Element.scrollLeft;\n    let scrollTop = this.Element.scrollTop;\n    subs.add(\n      fromEvent<Event>(this.Element, 'scroll')\n        .pipe(\n          tap((event) =>\n            this.scheduleScrollHandle(scrollDirection, () => {\n              const target = this.Element;\n              this.outScroll.emit(event);\n              if (scrollDirection === 'X') {\n                if (target.scrollLeft && target.scrollLeft + target.offsetWidth >= target.scrollWidth) {\n                  target.scrollLeft = target.scrollWidth - target.offsetWidth - (target.offsetWidth - target.clientWidth);\n                }\n                if (target.scrollLeft !== scrollLeft) {\n                  this.outScrollX.emit(event);\n                }\n                scrollLeft = target.scrollLeft;\n                this.updateScrollbarPosition(scrollDirection);\n                return;\n              }\n              if (target.scrollTop === scrollTop) {\n                return;\n              }\n              this.updateScrollbarPosition(scrollDirection);\n              scrollTop = target.scrollTop;\n              this.outScrollY.emit(event);\n              if (target.scrollTop === 0) {\n                this.outScrollTop.emit(event);\n                return;\n              }\n              if (target.scrollHeight <= target.scrollTop + target.offsetHeight + SCROLL_BOTTOM_TOLERANCE) {\n                this.outScrollBottom.emit(event);\n              }\n            })\n          ),\n          takeUntilDestroyed(this.destroyRef)\n        )\n        .subscribe()\n    );\n\n    const mouseLeave = fromEvent(this.divContainer, 'mouseleave');\n    const mouseEnter = fromEvent(this.divContainer, 'mouseenter');\n    subs.add(\n      mouseEnter\n        .pipe(\n          tap(() => {\n            if ((scrollDirection === 'X' && !this.options()?.scrollXOpacity0) || (scrollDirection === 'Y' && !this.options()?.scrollYOpacity0)) {\n              trackEl.style.visibility = 'visible';\n              trackEl.style.opacity = '1';\n            }\n            this.updateScrollbarSize(scrollDirection);\n          }),\n          switchMap(() => interval(1000).pipe(takeUntil(mouseLeave))),\n          tap(() => {\n            this.updateScrollbarSize(scrollDirection);\n          }),\n          takeUntilDestroyed(this.destroyRef)\n        )\n        .subscribe()\n    );\n\n    subs.add(\n      mouseLeave\n        .pipe(\n          tap(() => {\n            if (this.keepDisplayThumb()) {\n              return;\n            }\n            trackEl.style.visibility = 'hidden';\n            trackEl.style.opacity = '0';\n          }),\n          takeUntilDestroyed(this.destroyRef)\n        )\n        .subscribe()\n    );\n  }\n\n  /** Throttle scroll handler theo frame — gom nhiều scroll event vào 1 lần update DOM. */\n  private scheduleScrollHandle(scrollDirection: TYPE_SCROLL_DIRECTION, handle: () => void) {\n    if (scrollDirection === 'X') {\n      if (this.scrollRafX) return;\n      this.scrollRafX = requestAnimationFrame(() => {\n        this.scrollRafX = undefined;\n        handle();\n      });\n      return;\n    }\n    if (this.scrollRafY) return;\n    this.scrollRafY = requestAnimationFrame(() => {\n      this.scrollRafY = undefined;\n      handle();\n    });\n  }\n\n  protected handlerClickTrack(scrollDirection: TYPE_SCROLL_DIRECTION, subs: Subscription) {\n    const elementTrack = scrollDirection === 'X' ? this.trackX : this.trackY;\n    const elementThumb = scrollDirection === 'X' ? this.thumbX : this.thumbY;\n\n    subs.add(\n      fromEvent<MouseEvent>(elementTrack, 'click')\n        .pipe(takeUntilDestroyed(this.destroyRef))\n        .subscribe((e) => {\n          if (this.isScrollThumb()) {\n            return;\n          }\n          if ((scrollDirection === 'X' && e.clientX < elementThumb.getBoundingClientRect().left) || (scrollDirection === 'Y' && e.clientY < elementThumb.getBoundingClientRect().top)) {\n            this.updateScrollPositionByUserAction(scrollDirection, e, 'smooth', 0);\n            return;\n          }\n          if (scrollDirection === 'X') {\n            this.updateScrollPositionByUserAction(scrollDirection, e, 'smooth', -1 * elementThumb.getBoundingClientRect().width);\n            return;\n          }\n          this.updateScrollPositionByUserAction(scrollDirection, e, 'smooth', -1 * elementThumb.getBoundingClientRect().height);\n        })\n    );\n  }\n\n  protected handlerDragAndDropThumb(scrollDirection: TYPE_SCROLL_DIRECTION, subs: Subscription) {\n    const elementTrack = scrollDirection === 'X' ? this.trackX : this.trackY;\n    const elementThumb = scrollDirection === 'X' ? this.thumbX : this.thumbY;\n    let lengthThumbToPointClick = 0;\n\n    subs.add(\n      getDragEventByElement({\n        elementMouseDown: elementThumb,\n        functionMouseDown: (mouseEvent: MouseEvent) => {\n          this.isScrollThumb.set(true);\n          this.keepDisplayThumb.set(true);\n          if (scrollDirection === 'X') {\n            lengthThumbToPointClick = elementThumb.getBoundingClientRect().left - mouseEvent.clientX;\n            return;\n          }\n          lengthThumbToPointClick = elementThumb.getBoundingClientRect().top - mouseEvent.clientY;\n        },\n        functionMouseUp: (mouseEvent: MouseEvent) => {\n          this.keepDisplayThumb.set(false);\n          lengthThumbToPointClick = 0;\n          if (!checkMouseOverInContainer(mouseEvent, this.Element)) {\n            elementTrack.style.visibility = 'hidden';\n            elementTrack.style.opacity = '0';\n          }\n          clearTimeout(this.mouseUpTimer);\n          this.mouseUpTimer = setTimeout(() => {\n            this.isScrollThumb.set(false);\n          }, MOUSE_UP_RESET_DELAY);\n        },\n        destroyRef: this.destroyRef,\n      }).subscribe((mouseEvent: MouseEvent) => {\n        this.updateScrollPositionByUserAction(scrollDirection, mouseEvent, 'auto', lengthThumbToPointClick);\n      })\n    );\n  }\n\n  private updateScrollPositionByUserAction(scrollDirection: TYPE_SCROLL_DIRECTION, e: MouseEvent, behavior: 'auto' | 'smooth', lengthThumbToPointClick = 0) {\n    e.stopPropagation();\n    if (scrollDirection === 'X') {\n      const containerWidth = this.Element.offsetWidth;\n      const contentWidth = (this.elementCheckScrollX() || this.Element).scrollWidth;\n      const thumbPosition = e.clientX - this.Element.getBoundingClientRect().left + lengthThumbToPointClick;\n      const scrollLeft = (thumbPosition / (containerWidth - this.thumbX.offsetWidth)) * (contentWidth - containerWidth);\n      this.Element.scroll({ left: scrollLeft, behavior });\n      return;\n    }\n    const containerHeight = this.Element.offsetHeight;\n    const contentHeight = (this.elementCheckScrollY() || this.Element).scrollHeight;\n    const thumbPosition = e.clientY - this.Element.getBoundingClientRect().top + lengthThumbToPointClick;\n    const scrollTop = (thumbPosition / (containerHeight - this.thumbY.offsetHeight)) * (contentHeight - containerHeight);\n    this.Element.scroll({ top: scrollTop, behavior });\n  }\n\n  private updateScrollbarSize(scrollDirection: TYPE_SCROLL_DIRECTION) {\n    if (scrollDirection === 'X') {\n      const containerWidth = this.Element.offsetWidth;\n      const contentWidth = (this.elementCheckScrollX() || this.Element).scrollWidth;\n      if (containerWidth === this.lastContainerWidth && contentWidth === this.lastContentWidth) return;\n      this.lastContainerWidth = containerWidth;\n      this.lastContentWidth = contentWidth;\n      const thumbWidth = (containerWidth / contentWidth) * containerWidth;\n      this.thumbX.style.width = `${Math.max(MIN_THUMB_SIZE, thumbWidth)}px`;\n      this.trackX.style.display = contentWidth > containerWidth ? 'block' : 'none';\n      this.updateScrollbarPosition(scrollDirection);\n      return;\n    }\n    const containerHeight = this.Element.offsetHeight;\n    const contentHeight = (this.elementCheckScrollY() || this.Element).scrollHeight;\n    if (containerHeight === this.lastContainerHeight && contentHeight === this.lastContentHeight) return;\n    this.lastContainerHeight = containerHeight;\n    this.lastContentHeight = contentHeight;\n    const thumbHeight = (containerHeight / contentHeight) * containerHeight;\n    this.thumbY.style.height = `${Math.max(MIN_THUMB_SIZE, thumbHeight)}px`;\n    this.trackY.style.display = contentHeight > containerHeight ? 'block' : 'none';\n    this.updateScrollbarPosition('Y');\n  }\n\n  private updateScrollbarPosition(scrollDirection: TYPE_SCROLL_DIRECTION) {\n    if (scrollDirection === 'X') {\n      const containerWidth = this.Element.offsetWidth;\n      const contentWidth = (this.elementCheckScrollX() || this.Element).scrollWidth;\n      const denominatorScroll = contentWidth - containerWidth;\n      if (denominatorScroll <= 0) return;\n      const denominatorThumb = containerWidth - this.thumbX.offsetWidth;\n      const thumbPosition = (this.Element.scrollLeft / denominatorScroll) * denominatorThumb;\n      this.thumbX.style.left = `${thumbPosition}px`;\n      return;\n    }\n    const containerHeight = this.Element.offsetHeight;\n    const contentHeight = (this.elementCheckScrollY() || this.Element).scrollHeight;\n    const denominatorScroll = contentHeight - containerHeight;\n    if (denominatorScroll <= 0) return;\n    const denominatorThumb = containerHeight - this.thumbY.offsetHeight;\n    const thumbPosition = (this.Element.scrollTop / denominatorScroll) * denominatorThumb;\n    this.thumbY.style.top = `${thumbPosition}px`;\n  }\n}\n"]}