@ethlete/cdk 4.19.5 → 4.20.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,8 +1,8 @@
1
- import { NgClass } from '@angular/common';
2
- import { ChangeDetectionStrategy, Component, ContentChildren, ElementRef, EventEmitter, Input, Output, ViewChild, ViewEncapsulation, booleanAttribute, computed, effect, inject, isDevMode, numberAttribute, signal, } from '@angular/core';
1
+ import { NgClass, NgTemplateOutlet } from '@angular/common';
2
+ import { ChangeDetectionStrategy, Component, ContentChildren, ElementRef, EventEmitter, Input, Output, ViewChild, ViewEncapsulation, booleanAttribute, computed, effect, inject, isDevMode, numberAttribute, signal, viewChild, } from '@angular/core';
3
3
  import { takeUntilDestroyed, toObservable } from '@angular/core/rxjs-interop';
4
- import { CursorDragScrollDirective, LetDirective, ObserveScrollStateDirective, TypedQueryList, getFirstAndLastPartialIntersection, isElementVisible, nextFrame, scrollToElement, signalElementChildren, signalElementIntersection, signalElementScrollState, signalHostAttributes, signalHostClasses, signalHostElementDimensions, signalHostStyles, } from '@ethlete/core';
5
- import { BehaviorSubject, Subject, combineLatest, debounceTime, filter, fromEvent, map, take, takeUntil, tap, } from 'rxjs';
4
+ import { CursorDragScrollDirective, LetDirective, ObserveScrollStateDirective, TypedQueryList, getIntersectionInfo, isElementVisible, nextFrame, scrollToElement, signalElementChildren, signalElementDimensions, signalElementIntersection, signalElementScrollState, signalHostAttributes, signalHostClasses, signalHostElementDimensions, signalHostStyles, } from '@ethlete/core';
5
+ import { BehaviorSubject, Subject, combineLatest, debounceTime, filter, fromEvent, map, of, switchMap, takeUntil, tap, } from 'rxjs';
6
6
  import { ChevronIconComponent } from '../../../icons/chevron-icon';
7
7
  import { ScrollableIgnoreChildDirective, isScrollableChildIgnored } from '../../directives/scrollable-ignore-child';
8
8
  import { SCROLLABLE_IS_ACTIVE_CHILD_TOKEN, ScrollableIsActiveChildDirective, } from '../../directives/scrollable-is-active-child';
@@ -41,6 +41,9 @@ export class ScrollableComponent {
41
41
  set _renderButtons(v) {
42
42
  this.renderButtons.set(v);
43
43
  }
44
+ set _buttonPosition(v) {
45
+ this.buttonPosition.set(v);
46
+ }
44
47
  set _renderScrollbars(v) {
45
48
  this.renderScrollbars.set(v);
46
49
  }
@@ -62,6 +65,9 @@ export class ScrollableComponent {
62
65
  set _scrollMargin(v) {
63
66
  this.scrollMargin.set(v);
64
67
  }
68
+ set _scrollOrigin(v) {
69
+ this.scrollOrigin.set(v);
70
+ }
65
71
  set _scrollable(e) {
66
72
  this.scrollable.set(e);
67
73
  }
@@ -87,6 +93,9 @@ export class ScrollableComponent {
87
93
  this.renderNavigation = signal(false);
88
94
  this.renderMasks = signal(true);
89
95
  this.renderButtons = signal(true);
96
+ this.renderButtonsInside = computed(() => this.buttonPosition() === 'inside' && this.renderButtons());
97
+ this.renderButtonsInFooter = computed(() => this.buttonPosition() === 'footer' && this.renderButtons());
98
+ this.buttonPosition = signal('inside');
90
99
  this.renderScrollbars = signal(false);
91
100
  this.stickyButtons = signal(false);
92
101
  this.cursorDragScroll = signal(true);
@@ -94,6 +103,7 @@ export class ScrollableComponent {
94
103
  this.scrollMode = signal('container');
95
104
  this.snap = signal(false);
96
105
  this.scrollMargin = signal(0);
106
+ this.scrollOrigin = signal('auto');
97
107
  this.scrollStateChange = new EventEmitter();
98
108
  this.intersectionChange = new EventEmitter();
99
109
  this.scrollable = signal(null);
@@ -101,6 +111,9 @@ export class ScrollableComponent {
101
111
  this.firstElement = signal(null);
102
112
  this.lastElement = signal(null);
103
113
  this.activeElementList = signal(null);
114
+ this.navigationDotsContainer = viewChild('navigationDotsContainer');
115
+ this.firstNavigationDot = viewChild('navigationDot');
116
+ this.navigationDotDimensions = signalElementDimensions(this.firstNavigationDot);
104
117
  this.containerScrollState = signalElementScrollState(this.scrollable);
105
118
  this.firstElementIntersection = signalElementIntersection(this.firstElement, { root: this.scrollable });
106
119
  this.firstElementVisibility = signal(null);
@@ -172,19 +185,28 @@ export class ScrollableComponent {
172
185
  if (!highestIntersection) {
173
186
  return [];
174
187
  }
188
+ const activeIndex = manualActiveNavigationIndex !== null
189
+ ? manualActiveNavigationIndex
190
+ : allIntersections.findIndex((i) => i === highestIntersection);
175
191
  return allIntersections.map((i, index) => ({
176
192
  isActive: manualActiveNavigationIndex !== null
177
193
  ? manualActiveNavigationIndex === index
178
194
  : i === highestIntersection && highestIntersection.intersectionRatio > 0,
195
+ activeOffset: index === activeIndex ? 0 : Math.abs(index - activeIndex),
179
196
  element: i.target,
180
197
  }));
181
198
  });
199
+ this.activeIndex = computed(() => {
200
+ const scrollableNavigation = this.scrollableNavigation();
201
+ const activeIndex = scrollableNavigation.findIndex((element) => element.isActive);
202
+ return activeIndex;
203
+ });
182
204
  this.hostAttributeBindings = signalHostAttributes({
183
205
  'item-size': this.itemSize,
184
206
  'actual-item-size': this._actualItemSize,
185
207
  direction: this.direction,
186
208
  'render-scrollbars': this.renderScrollbars,
187
- 'sticky-buttons': this.stickyButtons,
209
+ 'sticky-buttons': computed(() => this.stickyButtons() && this.renderButtonsInside()),
188
210
  });
189
211
  this.hostClassBindings = signalHostClasses({
190
212
  'et-scrollable--can-scroll': computed(() => this.canScroll() && !this.isAtStart() && !this.isAtEnd()),
@@ -195,6 +217,16 @@ export class ScrollableComponent {
195
217
  this.hostStyleBindings = signalHostStyles({
196
218
  '--actual-item-size': computed(() => (this._actualItemSize() !== null ? `${this._actualItemSize()}px` : undefined)),
197
219
  });
220
+ effect(() => {
221
+ // Responsible for centering the active dot in navigation bar by using 'translate'
222
+ const scrollableDotsContainer = this.navigationDotsContainer();
223
+ const activeIndex = this.activeIndex();
224
+ const childCount = this.scrollableContentIntersections().length;
225
+ const offset = this.getNavigationDotsContainerTranslate(childCount, activeIndex);
226
+ if (!scrollableDotsContainer)
227
+ return;
228
+ scrollableDotsContainer.nativeElement.style.transform = `translateX(${offset})`;
229
+ });
198
230
  effect(() => {
199
231
  const scrollable = this.scrollable()?.nativeElement;
200
232
  const firstElement = this.firstElement()?.nativeElement;
@@ -225,18 +257,21 @@ export class ScrollableComponent {
225
257
  const elementList = this.scrollableChildren();
226
258
  const scrollable = this.scrollable()?.nativeElement;
227
259
  const renderNavigation = this.renderNavigation();
228
- if (!elementList || !scrollable || !renderNavigation) {
260
+ const renderButtonsInFooter = this.renderButtonsInFooter();
261
+ if (!elementList || !scrollable || (!renderNavigation && !renderButtonsInFooter)) {
229
262
  return;
230
263
  }
231
264
  const firstVisibleElement = elementList.find((e) => isElementVisible({ container: scrollable, element: e }));
232
265
  if (!firstVisibleElement) {
233
266
  return;
234
267
  }
235
- const initialNavigationItems = elementList.map((e) => ({
268
+ const firstVisibleElementIndex = elementList.indexOf(firstVisibleElement);
269
+ const initialNavigationItems = elementList.map((e, i) => ({
236
270
  isActive: e === firstVisibleElement,
237
271
  element: e,
272
+ activeOffset: Math.abs(i - firstVisibleElementIndex),
238
273
  }));
239
- this._initialScrollableNavigation.set(initialNavigationItems);
274
+ this._initialScrollableNavigation.set(initialNavigationItems ?? []);
240
275
  }, { allowSignalWrites: true });
241
276
  effect(() => {
242
277
  const isAtStart = this.isAtStart();
@@ -267,6 +302,31 @@ export class ScrollableComponent {
267
302
  })));
268
303
  }))
269
304
  .subscribe();
305
+ toObservable(this.manualActiveNavigationIndex)
306
+ .pipe(filter((i) => i !== null), takeUntilDestroyed(), switchMap(() => {
307
+ const scrollable = this.scrollable()?.nativeElement;
308
+ if (!scrollable) {
309
+ return of(null);
310
+ }
311
+ return fromEvent(scrollable, 'scroll');
312
+ }), debounceTime(50), tap(() => this.manualActiveNavigationIndex.set(null)))
313
+ .subscribe();
314
+ }
315
+ getNavigationDotsContainerTranslate(navigationDotCount, activeIndex) {
316
+ if (navigationDotCount <= 5) {
317
+ return '0px';
318
+ }
319
+ else {
320
+ const dotContainerWidth = this.navigationDotDimensions().rect?.width ?? 20;
321
+ let offset = -(activeIndex - 2);
322
+ if (activeIndex < 3) {
323
+ offset = 0;
324
+ }
325
+ else if (activeIndex >= navigationDotCount - 3) {
326
+ offset = 5 - navigationDotCount;
327
+ }
328
+ return `${offset * dotContainerWidth}px`;
329
+ }
270
330
  }
271
331
  scrollOneContainerSize(direction) {
272
332
  const scrollElement = this.scrollable()?.nativeElement;
@@ -278,8 +338,8 @@ export class ScrollableComponent {
278
338
  if (isSnappingEnabled) {
279
339
  // If snapping is enabled we want to scroll to a position where no further snapping will happen after the scroll.
280
340
  const allIntersections = this.scrollableContentIntersections();
281
- const intersections = getFirstAndLastPartialIntersection(allIntersections);
282
- const relevantIntersection = direction === 'start' ? intersections?.first : intersections?.last;
341
+ const intersections = getIntersectionInfo(allIntersections);
342
+ const relevantIntersection = direction === 'start' ? intersections?.partial.first : intersections?.partial.last;
283
343
  if (!relevantIntersection)
284
344
  return;
285
345
  const nextIndex = relevantIntersection.intersection.intersectionRatio !== 1
@@ -313,16 +373,16 @@ export class ScrollableComponent {
313
373
  }
314
374
  return;
315
375
  }
316
- const intersections = getFirstAndLastPartialIntersection(allIntersections);
376
+ const intersections = getIntersectionInfo(allIntersections);
317
377
  if (!intersections || !scrollElement)
318
378
  return;
319
379
  // Means the current element is bigger than the scrollable container.
320
380
  // In this case we should scroll to the start of the current element. If we are already there we should scroll to the end of the previous element.
321
381
  // This applies to the other direction as well.
322
- const isFirstAndLastIntersectionEqual = intersections.first.intersection === intersections.last.intersection;
382
+ const isFirstAndLastIntersectionEqual = intersections.partial.first.intersection === intersections.partial.last.intersection;
323
383
  const scrollableRect = scrollElement.getBoundingClientRect();
324
384
  if (isFirstAndLastIntersectionEqual) {
325
- const intersection = intersections.first.intersection.target.getBoundingClientRect();
385
+ const intersection = intersections.partial.first.intersection.target.getBoundingClientRect();
326
386
  const isStartOfElementVisible = this.direction() === 'horizontal'
327
387
  ? Math.round(intersection.left) >= Math.round(scrollableRect.left)
328
388
  : Math.round(intersection.top) >= Math.round(scrollableRect.top);
@@ -333,7 +393,7 @@ export class ScrollableComponent {
333
393
  if (direction === 'start') {
334
394
  if (isStartOfElementVisible) {
335
395
  // to the end of the previous element
336
- const previousIndex = intersections.first.index - 1;
396
+ const previousIndex = intersections.partial.first.index - 1;
337
397
  const elementToScrollTo = allIntersections[previousIndex]?.target;
338
398
  if (!elementToScrollTo)
339
399
  return;
@@ -341,19 +401,21 @@ export class ScrollableComponent {
341
401
  element: elementToScrollTo,
342
402
  origin: 'end',
343
403
  });
404
+ this.manualActiveNavigationIndex.set(previousIndex);
344
405
  }
345
406
  else {
346
407
  // to the start of the current element
347
408
  this.scrollToElement({
348
- element: intersections.first.intersection.target,
409
+ element: intersections.partial.first.intersection.target,
349
410
  origin: 'start',
350
411
  });
412
+ this.manualActiveNavigationIndex.set(intersections.partial.first.index);
351
413
  }
352
414
  }
353
415
  else {
354
416
  if (isEndOfElementVisible) {
355
417
  // to the start of the next element
356
- const nextIndex = intersections.last.index + 1;
418
+ const nextIndex = intersections.partial.last.index + 1;
357
419
  const elementToScrollTo = allIntersections[nextIndex]?.target;
358
420
  if (!elementToScrollTo)
359
421
  return;
@@ -361,20 +423,34 @@ export class ScrollableComponent {
361
423
  element: elementToScrollTo,
362
424
  origin: 'start',
363
425
  });
426
+ this.manualActiveNavigationIndex.set(nextIndex);
364
427
  }
365
428
  else {
366
429
  // to the end of the current element
367
430
  this.scrollToElement({
368
- element: intersections.last.intersection.target,
431
+ element: intersections.partial.last.intersection.target,
369
432
  origin: 'end',
370
433
  });
434
+ this.manualActiveNavigationIndex.set(intersections.partial.last.index);
371
435
  }
372
436
  }
373
437
  return;
374
438
  }
375
439
  }
376
- const data = direction === 'start' ? intersections.first : intersections.last;
440
+ else if (this.scrollOrigin() === 'center') {
441
+ // If the scroll origin is forced to be center we should always snap to the center of the next partial intersection in the scroll direction.
442
+ const nextPartialIntersection = direction === 'start' ? intersections.partial.first : intersections.partial.last;
443
+ const nextIndex = nextPartialIntersection.index;
444
+ this.scrollToElement({
445
+ element: nextPartialIntersection.intersection.target,
446
+ origin: 'center',
447
+ });
448
+ this.manualActiveNavigationIndex.set(nextIndex);
449
+ return;
450
+ }
451
+ const data = direction === 'start' ? intersections.partial.first : intersections.partial.last;
377
452
  let elementToScrollTo = data.intersection.target;
453
+ let nextIndex = data.index;
378
454
  if (Math.round(data.intersection.intersectionRatio) === 1) {
379
455
  if (direction === 'start' && data.index === 0) {
380
456
  return;
@@ -382,18 +458,21 @@ export class ScrollableComponent {
382
458
  if (direction === 'end' && data.index === allIntersections.length - 1) {
383
459
  return;
384
460
  }
385
- const nextIndex = direction === 'start' ? data.index - 1 : data.index + 1;
461
+ nextIndex = direction === 'start' ? data.index - 1 : data.index + 1;
386
462
  elementToScrollTo = allIntersections[nextIndex]?.target;
463
+ if (!elementToScrollTo)
464
+ return;
387
465
  }
388
- if (!elementToScrollTo)
389
- return;
390
466
  this.scrollToElement({
391
467
  element: elementToScrollTo,
392
468
  origin: direction,
393
469
  });
470
+ this.manualActiveNavigationIndex.set(nextIndex);
394
471
  }
395
472
  scrollToElement(options) {
396
473
  const scrollElement = this.scrollable()?.nativeElement;
474
+ const { origin } = options;
475
+ const forcedOrigin = this.scrollOrigin();
397
476
  scrollToElement({
398
477
  container: scrollElement,
399
478
  direction: this.direction() === 'horizontal' ? 'inline' : 'block',
@@ -401,13 +480,16 @@ export class ScrollableComponent {
401
480
  ? { scrollInlineMargin: this.scrollMargin() }
402
481
  : { scrollBlockMargin: this.scrollMargin() }),
403
482
  ...options,
483
+ ...(forcedOrigin === 'auto' || options.ignoreForcedOrigin ? { origin } : { origin: forcedOrigin }),
404
484
  });
405
485
  }
406
486
  scrollToElementByIndex(options) {
407
487
  const elements = this.scrollableChildren();
488
+ const { origin } = options;
489
+ const forcedOrigin = this.scrollOrigin();
408
490
  if (!elements.length) {
409
491
  if (isDevMode()) {
410
- console.warn('No elements found to scroll to. Make sure to apply the isElement directive to the elements you want to scroll to.');
492
+ console.warn('No elements found to scroll to.');
411
493
  }
412
494
  return;
413
495
  }
@@ -420,19 +502,15 @@ export class ScrollableComponent {
420
502
  ? { scrollInlineMargin: this.scrollMargin() }
421
503
  : { scrollBlockMargin: this.scrollMargin() }),
422
504
  ...options,
505
+ ...(forcedOrigin === 'auto' || options.ignoreForcedOrigin ? { origin } : { origin: forcedOrigin }),
423
506
  });
424
507
  }
425
- scrollToElementViaNavigation(elementIndex, element) {
508
+ scrollToElementViaNavigation(elementIndex) {
509
+ const element = this.scrollableChildren()[elementIndex];
426
510
  this.manualActiveNavigationIndex.set(elementIndex);
427
511
  this.scrollToElement({
428
512
  element,
429
513
  });
430
- const scrollElement = this.scrollable()?.nativeElement;
431
- if (!scrollElement)
432
- return;
433
- fromEvent(scrollElement, 'scroll')
434
- .pipe(debounceTime(50), take(1), tap(() => this.manualActiveNavigationIndex.set(null)))
435
- .subscribe();
436
514
  }
437
515
  setIsCursorDragging(isDragging) {
438
516
  this._isCursorDragging$.next(isDragging);
@@ -459,13 +537,25 @@ export class ScrollableComponent {
459
537
  const scrollElement = this.scrollable()?.nativeElement;
460
538
  if (!scrollElement)
461
539
  return;
462
- const intersections = getFirstAndLastPartialIntersection(allIntersections);
540
+ const intersections = getIntersectionInfo(allIntersections);
463
541
  if (!intersections)
464
542
  return;
465
- const isFirstAndLastIntersectionEqual = intersections.first.intersection === intersections.last.intersection;
543
+ const isFirstAndLastIntersectionEqual = intersections.partial.first.intersection === intersections.partial.last.intersection;
466
544
  const scrollableRect = scrollElement.getBoundingClientRect();
467
- if (isFirstAndLastIntersectionEqual) {
468
- const intersection = intersections.first.intersection.target.getBoundingClientRect();
545
+ if (this.scrollOrigin() === 'center' && intersections.full.hasMultiple) {
546
+ // If there is more than one fully visible element we should not snap at all.
547
+ return;
548
+ }
549
+ else if (this.scrollOrigin() === 'center' && intersections.full.first.intersection) {
550
+ // If there is already a fully visible element we should snap it to the center.
551
+ this.scrollToElement({
552
+ element: intersections.full.first.intersection.target,
553
+ origin: 'center',
554
+ });
555
+ return;
556
+ }
557
+ else if (isFirstAndLastIntersectionEqual) {
558
+ const intersection = intersections.partial.first.intersection.target.getBoundingClientRect();
469
559
  const isStartOfElementVisible = this.direction() === 'horizontal'
470
560
  ? intersection.left >= scrollableRect.left
471
561
  : intersection.top >= scrollableRect.top;
@@ -479,7 +569,7 @@ export class ScrollableComponent {
479
569
  // If the start of the element is visible we should snap to the start.
480
570
  if (isStartOfElementVisible) {
481
571
  this.scrollToElement({
482
- element: intersections.first.intersection.target,
572
+ element: intersections.partial.first.intersection.target,
483
573
  origin: 'start',
484
574
  });
485
575
  return;
@@ -487,28 +577,29 @@ export class ScrollableComponent {
487
577
  // If the end of the element is visible we should snap to the end.
488
578
  if (isEndOfElementVisible) {
489
579
  this.scrollToElement({
490
- element: intersections.last.intersection.target,
580
+ element: intersections.partial.last.intersection.target,
491
581
  origin: 'end',
492
582
  });
493
583
  return;
494
584
  }
495
585
  }
496
586
  else if ((this.direction() === 'horizontal' &&
497
- intersections.biggest.intersection.boundingClientRect.width > scrollableRect.width) ||
587
+ intersections.partial.biggest.intersection.boundingClientRect.width > scrollableRect.width) ||
498
588
  (this.direction() === 'vertical' &&
499
- intersections.biggest.intersection.boundingClientRect.height > scrollableRect.height)) {
589
+ intersections.partial.biggest.intersection.boundingClientRect.height > scrollableRect.height)) {
500
590
  // If the current element is bigger than the scrollable container we should snap to the start of the current element if the scroll direction is forward
501
591
  // and to the end of the current element if the scroll direction is backwards.
502
- const origin = intersections.biggest.index === intersections.first.index ? 'end' : 'start';
592
+ const origin = intersections.partial.biggest.index === intersections.partial.first.index ? 'end' : 'start';
503
593
  this.scrollToElement({
504
- element: intersections.biggest.intersection.target,
594
+ element: intersections.partial.biggest.intersection.target,
505
595
  origin,
596
+ ignoreForcedOrigin: true,
506
597
  });
507
598
  }
508
599
  else {
509
600
  // No special case. Just snap to the biggest intersection.
510
601
  this.scrollToElement({
511
- element: intersections.biggest.intersection.target,
602
+ element: intersections.partial.biggest.intersection.target,
512
603
  });
513
604
  }
514
605
  }), takeUntil(this._disableSnapping$))
@@ -518,7 +609,7 @@ export class ScrollableComponent {
518
609
  this._disableSnapping$.next();
519
610
  }
520
611
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: ScrollableComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
521
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.5", type: ScrollableComponent, isStandalone: true, selector: "et-scrollable", inputs: { _itemSize: ["itemSize", "_itemSize"], _direction: ["direction", "_direction"], _scrollableRole: ["scrollableRole", "_scrollableRole"], _scrollableClass: ["scrollableClass", "_scrollableClass"], _renderNavigation: ["renderNavigation", "_renderNavigation", booleanAttribute], _renderMasks: ["renderMasks", "_renderMasks", booleanAttribute], _renderButtons: ["renderButtons", "_renderButtons", booleanAttribute], _renderScrollbars: ["renderScrollbars", "_renderScrollbars", booleanAttribute], _stickyButtons: ["stickyButtons", "_stickyButtons", booleanAttribute], _cursorDragScroll: ["cursorDragScroll", "_cursorDragScroll", booleanAttribute], _disableActiveElementScrolling: ["disableActiveElementScrolling", "_disableActiveElementScrolling", booleanAttribute], _scrollMode: ["scrollMode", "_scrollMode"], _snap: ["snap", "_snap", booleanAttribute], _scrollMargin: ["scrollMargin", "_scrollMargin", numberAttribute] }, outputs: { scrollStateChange: "scrollStateChange", intersectionChange: "intersectionChange" }, host: { classAttribute: "et-scrollable" }, queries: [{ propertyName: "_activeElementList", predicate: SCROLLABLE_IS_ACTIVE_CHILD_TOKEN, descendants: true }], viewQueries: [{ propertyName: "_scrollable", first: true, predicate: ["scrollable"], descendants: true, static: true }, { propertyName: "_scrollableContainer", first: true, predicate: ["scrollableContainer"], descendants: true, static: true }, { propertyName: "_firstElement", first: true, predicate: ["firstElement"], descendants: true, static: true }, { propertyName: "_lastElement", first: true, predicate: ["lastElement"], descendants: true, static: true }], ngImport: i0, template: "<div class=\"et-scrollable-wrapper\">\n <div\n #scrollable\n [attr.role]=\"scrollableRole() ?? undefined\"\n [etCursorDragScroll]=\"cursorDragScroll() && (!isAtStart() || !isAtEnd())\"\n [allowedDirection]=\"direction()\"\n (cursorDragStart)=\"setIsCursorDragging(true)\"\n (cursorDragEnd)=\"setIsCursorDragging(false)\"\n class=\"et-scrollable-container-outer\"\n >\n <div #scrollableContainer [ngClass]=\"scrollableClass()\" class=\"et-scrollable-container\">\n <div #firstElement class=\"et-scroll-observer-first-element\" etScrollableIgnoreChild></div>\n <ng-content />\n <div #lastElement class=\"et-scroll-observer-last-element\" etScrollableIgnoreChild></div>\n </div>\n </div>\n\n @if (renderMasks()) {\n <div class=\"et-scrollable-masks\">\n <div class=\"et-scrollable-mask et-scrollable-mask--start\"></div>\n <div class=\"et-scrollable-mask et-scrollable-mask--end\"></div>\n </div>\n }\n\n @if (renderButtons()) {\n <div class=\"et-scrollable-buttons\">\n <button\n (click)=\"scrollToStartDirection()\"\n class=\"et-scrollable-button et-scrollable-button--start\"\n aria-hidden=\"true\"\n type=\"button\"\n tabindex=\"-1\"\n >\n <et-chevron-icon />\n </button>\n <button\n (click)=\"scrollToEndDirection()\"\n class=\"et-scrollable-button et-scrollable-button--end\"\n aria-hidden=\"true\"\n type=\"button\"\n tabindex=\"-1\"\n >\n <et-chevron-icon />\n </button>\n </div>\n }\n</div>\n\n@if (renderNavigation() && scrollableNavigation().length > 1) {\n <div class=\"et-scrollable-navigation\" aria-hidden=\"true\">\n @for (item of scrollableNavigation(); track i; let i = $index) {\n <button\n [class.et-scrollable-navigation-item--active]=\"item.isActive\"\n (click)=\"scrollToElementViaNavigation(i, item.element)\"\n class=\"et-scrollable-navigation-item\"\n tabindex=\"-1\"\n aria-hidden=\"true\"\n ></button>\n }\n </div>\n}\n", styles: [".et-scrollable{--mask: #121212 0, transparent 100%;--mask-size: 25px;--_auto-size: min-content;--_flow: column;display:block}.et-scrollable .et-scrollable-wrapper{display:grid;position:relative}.et-scrollable[item-size=same]{--_auto-size: 1fr}.et-scrollable[item-size=full]{--_auto-size: var(--actual-item-size)}.et-scrollable[render-scrollbars=false] .et-scrollable-container-outer{scrollbar-width:none}.et-scrollable[render-scrollbars=false] .et-scrollable-container-outer::-webkit-scrollbar{display:none}.et-scrollable[direction=horizontal] .et-scrollable-container-outer{overflow-x:auto;overflow-y:hidden}.et-scrollable[direction=horizontal] .et-scrollable-container{grid-auto-columns:var(--_auto-size)}.et-scrollable[direction=horizontal] .et-scrollable-mask,.et-scrollable[direction=horizontal] .et-scrollable-button{inline-size:var(--mask-size);block-size:100%}.et-scrollable[direction=horizontal] .et-scrollable-mask--start,.et-scrollable[direction=horizontal] .et-scrollable-button--start{inset-block-start:0;inset-inline:0 0}.et-scrollable[direction=horizontal] .et-scrollable-mask--end,.et-scrollable[direction=horizontal] .et-scrollable-button--end{inset-block-start:0;inset-inline:calc(100% - 40px) 0}.et-scrollable[direction=horizontal] .et-scrollable-mask--start{background:linear-gradient(to right,var(--mask))}.et-scrollable[direction=horizontal] .et-scrollable-mask--end{background:linear-gradient(to left,var(--mask));inset-inline:calc(100% - var(--mask-size)) 100%}.et-scrollable[direction=horizontal] .et-scrollable-button--start{inset-block-start:calc(50% - 20px);transform:rotate(-90deg)}.et-scrollable[direction=horizontal] .et-scrollable-button--end{inset-block-start:calc(50% - 20px);transform:rotate(90deg)}.et-scrollable[direction=horizontal] .et-scroll-observer-first-element,.et-scrollable[direction=horizontal] .et-scroll-observer-last-element{block-size:100%;inline-size:1px}.et-scrollable[direction=horizontal] .et-scroll-observer-first-element{inset-inline-start:1px}.et-scrollable[direction=horizontal] .et-scroll-observer-last-element{inset-inline-end:1px}.et-scrollable[direction=vertical]{--_flow: row}.et-scrollable[direction=vertical] .et-scrollable-container-outer{overflow-x:hidden;overflow-y:auto}.et-scrollable[direction=vertical] .et-scrollable-container{grid-auto-rows:var(--_auto-size)}.et-scrollable[direction=vertical] .et-scrollable-mask,.et-scrollable[direction=vertical] .et-scrollable-button{block-size:var(--mask-size);inline-size:100%}.et-scrollable[direction=vertical] .et-scrollable-mask--start,.et-scrollable[direction=vertical] .et-scrollable-button--start{inset-block-start:0;inset-inline-start:0}.et-scrollable[direction=vertical] .et-scrollable-mask--end,.et-scrollable[direction=vertical] .et-scrollable-button--end{inset-block-end:0;inset-inline-start:0}.et-scrollable[direction=vertical] .et-scrollable-mask--start{background:linear-gradient(to bottom,var(--mask))}.et-scrollable[direction=vertical] .et-scrollable-mask--end{background:linear-gradient(to top,var(--mask))}.et-scrollable[direction=vertical] .et-scrollable-button--start{inset-inline-start:calc(50% - 20px);transform:rotate(0)}.et-scrollable[direction=vertical] .et-scrollable-button--end{inset-inline-start:calc(50% - 20px);transform:rotate(180deg)}.et-scrollable[direction=vertical] .et-scroll-observer-first-element,.et-scrollable[direction=vertical] .et-scroll-observer-last-element{inline-size:100%;block-size:1px}.et-scrollable[direction=vertical] .et-scroll-observer-first-element{inset-block-start:1px}.et-scrollable[direction=vertical] .et-scroll-observer-last-element{inset-block-end:1px}.et-scrollable:not(.et-scrollable--is-at-start) .et-scrollable-masks .et-scrollable-mask--start,.et-scrollable:not(.et-scrollable--is-at-start) .et-scrollable-buttons .et-scrollable-button--start{opacity:1}.et-scrollable:not(.et-scrollable--is-at-start) .et-scrollable-buttons .et-scrollable-button--start{pointer-events:all}.et-scrollable:not(.et-scrollable--is-at-end) .et-scrollable-masks .et-scrollable-mask--end,.et-scrollable:not(.et-scrollable--is-at-end) .et-scrollable-buttons .et-scrollable-button--end{opacity:1}.et-scrollable:not(.et-scrollable--is-at-end) .et-scrollable-buttons .et-scrollable-button--end{pointer-events:all}.et-scrollable .et-scrollable-container-outer{overflow:auto;display:grid;position:relative;grid-row:1/1;grid-column:1/1}.et-scrollable .et-scroll-observer-first-element,.et-scrollable .et-scroll-observer-last-element{position:absolute;pointer-events:none}.et-scrollable .et-scrollable-container{display:grid;grid-auto-flow:var(--_flow);position:relative}.et-scrollable .et-scrollable-masks,.et-scrollable .et-scrollable-buttons{grid-row:1/1;grid-column:1/1;pointer-events:none}.et-scrollable .et-scrollable-masks .et-scrollable-mask,.et-scrollable .et-scrollable-masks .et-scrollable-button,.et-scrollable .et-scrollable-buttons .et-scrollable-mask,.et-scrollable .et-scrollable-buttons .et-scrollable-button{position:absolute;opacity:0}.et-scrollable.et-scrollable--can-scroll.et-scrollable--enable-overlay-animations .et-scrollable-mask,.et-scrollable.et-scrollable--can-scroll.et-scrollable--enable-overlay-animations .et-scrollable-button{transition:opacity .3s var(--ease-5)}.et-scrollable .et-scrollable-buttons .et-scrollable-button{background:transparent;border:none;padding:12px;inline-size:40px;block-size:40px;border-radius:4px;cursor:pointer}.et-scrollable .et-scrollable-buttons .et-scrollable-button .et-chevron-icon{pointer-events:none}.et-scrollable .et-scrollable-buttons .et-scrollable-button .et-scrollable-button--start{inset-inline:0 0}.et-scrollable .et-scrollable-buttons .et-scrollable-button .et-scrollable-button--end{inset-inline:calc(100% - 40px) 0}.et-scrollable[sticky-buttons=true]{--_sticky-margin: 10%}.et-scrollable[sticky-buttons=true] .et-scrollable-button{position:sticky}.et-scrollable[sticky-buttons=true][direction=horizontal] .et-scrollable-buttons{margin-block:var(--_sticky-margin)}.et-scrollable[sticky-buttons=true][direction=vertical] .et-scrollable-buttons{margin-inline:var(--_sticky-margin)}.et-scrollable[sticky-buttons=true][direction=vertical] .et-scrollable-buttons .et-scrollable-button--end{inset-block-start:100%}.et-scrollable .et-scrollable-navigation{display:flex;justify-content:center;gap:10px;margin-block-start:10px}.et-scrollable .et-scrollable-navigation .et-scrollable-navigation-item{all:unset;inline-size:10px;block-size:10px;display:block;background-color:#4b4b4b;border-radius:50%;cursor:pointer}.et-scrollable .et-scrollable-navigation .et-scrollable-navigation-item.et-scrollable-navigation-item--active{background-color:#c6c6c6}\n"], dependencies: [{ kind: "directive", type: CursorDragScrollDirective, selector: "[etCursorDragScroll]", inputs: ["etCursorDragScroll", "allowedDirection"], outputs: ["cursorDragStart", "cursorDragMove", "cursorDragEnd"], exportAs: ["etCursorDragScroll"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: ChevronIconComponent, selector: "et-chevron-icon" }, { kind: "directive", type: ScrollableIgnoreChildDirective, selector: "[etScrollableIgnoreChild]", inputs: ["etScrollableIgnoreChild"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
612
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.5", type: ScrollableComponent, isStandalone: true, selector: "et-scrollable", inputs: { _itemSize: ["itemSize", "_itemSize"], _direction: ["direction", "_direction"], _scrollableRole: ["scrollableRole", "_scrollableRole"], _scrollableClass: ["scrollableClass", "_scrollableClass"], _renderNavigation: ["renderNavigation", "_renderNavigation", booleanAttribute], _renderMasks: ["renderMasks", "_renderMasks", booleanAttribute], _renderButtons: ["renderButtons", "_renderButtons", booleanAttribute], _buttonPosition: ["buttonPosition", "_buttonPosition"], _renderScrollbars: ["renderScrollbars", "_renderScrollbars", booleanAttribute], _stickyButtons: ["stickyButtons", "_stickyButtons", booleanAttribute], _cursorDragScroll: ["cursorDragScroll", "_cursorDragScroll", booleanAttribute], _disableActiveElementScrolling: ["disableActiveElementScrolling", "_disableActiveElementScrolling", booleanAttribute], _scrollMode: ["scrollMode", "_scrollMode"], _snap: ["snap", "_snap", booleanAttribute], _scrollMargin: ["scrollMargin", "_scrollMargin", numberAttribute], _scrollOrigin: ["scrollOrigin", "_scrollOrigin"] }, outputs: { scrollStateChange: "scrollStateChange", intersectionChange: "intersectionChange" }, host: { classAttribute: "et-scrollable" }, queries: [{ propertyName: "_activeElementList", predicate: SCROLLABLE_IS_ACTIVE_CHILD_TOKEN, descendants: true }], viewQueries: [{ propertyName: "navigationDotsContainer", first: true, predicate: ["navigationDotsContainer"], descendants: true, isSignal: true }, { propertyName: "firstNavigationDot", first: true, predicate: ["navigationDot"], descendants: true, isSignal: true }, { propertyName: "_scrollable", first: true, predicate: ["scrollable"], descendants: true, static: true }, { propertyName: "_scrollableContainer", first: true, predicate: ["scrollableContainer"], descendants: true, static: true }, { propertyName: "_firstElement", first: true, predicate: ["firstElement"], descendants: true, static: true }, { propertyName: "_lastElement", first: true, predicate: ["lastElement"], descendants: true, static: true }], ngImport: i0, template: "<div class=\"et-scrollable-wrapper\">\n <div\n #scrollable\n [attr.role]=\"scrollableRole() ?? undefined\"\n [etCursorDragScroll]=\"cursorDragScroll() && (!isAtStart() || !isAtEnd())\"\n [allowedDirection]=\"direction()\"\n (cursorDragStart)=\"setIsCursorDragging(true)\"\n (cursorDragEnd)=\"setIsCursorDragging(false)\"\n class=\"et-scrollable-container-outer\"\n >\n <div #scrollableContainer [ngClass]=\"scrollableClass()\" class=\"et-scrollable-container\">\n <div #firstElement class=\"et-scroll-observer-first-element\" etScrollableIgnoreChild></div>\n <ng-content />\n <div #lastElement class=\"et-scroll-observer-last-element\" etScrollableIgnoreChild></div>\n </div>\n </div>\n\n @if (renderMasks()) {\n <div class=\"et-scrollable-masks\">\n <div class=\"et-scrollable-mask et-scrollable-mask--start\"></div>\n <div class=\"et-scrollable-mask et-scrollable-mask--end\"></div>\n </div>\n }\n\n @if (renderButtonsInside()) {\n <div class=\"et-scrollable-buttons\">\n <ng-container *ngTemplateOutlet=\"forwardButtonTpl\" />\n <ng-container *ngTemplateOutlet=\"backwardButtonTpl\" />\n </div>\n }\n</div>\n\n@if (renderButtonsInFooter() || (renderNavigation() && scrollableNavigation().length > 1)) {\n <div\n [ngClass]=\"{\n 'et-scrollable-footer--with-navigation': renderNavigation(),\n 'et-scrollable-footer--with-buttons': renderButtonsInFooter()\n }\"\n class=\"et-scrollable-footer\"\n aria-hidden=\"true\"\n >\n @if (renderButtonsInFooter()) {\n <ng-container *ngTemplateOutlet=\"forwardButtonTpl\" />\n }\n\n @if (renderNavigation()) {\n <div class=\"et-scrollable-progress-bar\">\n <div #navigationDotsContainer class=\"et-scrollable-dots-container\">\n @for (item of scrollableNavigation(); track i; let i = $index) {\n <button\n #navigationDot\n [class.et-scrollable-navigation-item--active]=\"item.isActive\"\n [class.et-scrollable-navigation-item--close]=\"\n scrollableNavigation()[i + 1]?.isActive || scrollableNavigation()[i - 1]?.isActive\n \"\n [class.et-scrollable-navigation-item--far]=\"\n !scrollableNavigation()[i + 1]?.isActive && !scrollableNavigation()[i - 1]?.isActive && !item.isActive\n \"\n [attr.active-offset]=\"item.activeOffset\"\n (click)=\"scrollToElementViaNavigation(i)\"\n class=\"et-scrollable-navigation-item\"\n type=\"button\"\n tabindex=\"-1\"\n aria-hidden=\"true\"\n ></button>\n }\n </div>\n </div>\n }\n\n @if (renderButtonsInFooter()) {\n <ng-container *ngTemplateOutlet=\"backwardButtonTpl\" />\n }\n </div>\n}\n\n<ng-template #forwardButtonTpl>\n <button\n [disabled]=\"isAtStart()\"\n (click)=\"scrollToStartDirection()\"\n class=\"et-scrollable-button et-scrollable-button--start\"\n aria-hidden=\"true\"\n type=\"button\"\n tabindex=\"-1\"\n >\n <et-chevron-icon />\n </button>\n</ng-template>\n\n<ng-template #backwardButtonTpl>\n <button\n [disabled]=\"isAtEnd()\"\n (click)=\"scrollToEndDirection()\"\n class=\"et-scrollable-button et-scrollable-button--end\"\n aria-hidden=\"true\"\n type=\"button\"\n tabindex=\"-1\"\n >\n <et-chevron-icon />\n </button>\n</ng-template>\n", styles: [".et-scrollable{--mask: #121212 0, transparent 100%;--mask-size: 25px;--_auto-size: min-content;--_flow: column;display:block}.et-scrollable .et-scrollable-wrapper{display:grid;position:relative}.et-scrollable[item-size=same]{--_auto-size: 1fr}.et-scrollable[item-size=full]{--_auto-size: var(--actual-item-size)}.et-scrollable[render-scrollbars=false] .et-scrollable-container-outer{scrollbar-width:none}.et-scrollable[render-scrollbars=false] .et-scrollable-container-outer::-webkit-scrollbar{display:none}.et-scrollable[direction=horizontal] .et-scrollable-container-outer{overflow-x:auto;overflow-y:hidden}.et-scrollable[direction=horizontal] .et-scrollable-container{grid-auto-columns:var(--_auto-size)}.et-scrollable[direction=horizontal] .et-scrollable-mask,.et-scrollable[direction=horizontal] .et-scrollable-button{inline-size:var(--mask-size);block-size:100%}.et-scrollable[direction=horizontal] .et-scrollable-mask--start,.et-scrollable[direction=horizontal] .et-scrollable-button--start{inset-block-start:0;inset-inline:0 0}.et-scrollable[direction=horizontal] .et-scrollable-mask--end,.et-scrollable[direction=horizontal] .et-scrollable-button--end{inset-block-start:0;inset-inline:calc(100% - 40px) 0}.et-scrollable[direction=horizontal] .et-scrollable-mask--start{background:linear-gradient(to right,var(--mask))}.et-scrollable[direction=horizontal] .et-scrollable-mask--end{background:linear-gradient(to left,var(--mask));inset-inline:calc(100% - var(--mask-size)) 100%}.et-scrollable[direction=horizontal] .et-scrollable-button--start{inset-block-start:calc(50% - 20px);transform:rotate(-90deg)}.et-scrollable[direction=horizontal] .et-scrollable-button--end{inset-block-start:calc(50% - 20px);transform:rotate(90deg)}.et-scrollable[direction=horizontal] .et-scroll-observer-first-element,.et-scrollable[direction=horizontal] .et-scroll-observer-last-element{block-size:100%;inline-size:1px}.et-scrollable[direction=horizontal] .et-scroll-observer-first-element{inset-inline-start:1px}.et-scrollable[direction=horizontal] .et-scroll-observer-last-element{inset-inline-end:1px}.et-scrollable[direction=vertical]{--_flow: row}.et-scrollable[direction=vertical] .et-scrollable-container-outer{overflow-x:hidden;overflow-y:auto}.et-scrollable[direction=vertical] .et-scrollable-container{grid-auto-rows:var(--_auto-size)}.et-scrollable[direction=vertical] .et-scrollable-mask,.et-scrollable[direction=vertical] .et-scrollable-button{block-size:var(--mask-size);inline-size:100%}.et-scrollable[direction=vertical] .et-scrollable-mask--start,.et-scrollable[direction=vertical] .et-scrollable-button--start{inset-block-start:0;inset-inline-start:0}.et-scrollable[direction=vertical] .et-scrollable-mask--end,.et-scrollable[direction=vertical] .et-scrollable-button--end{inset-block-end:0;inset-inline-start:0}.et-scrollable[direction=vertical] .et-scrollable-mask--start{background:linear-gradient(to bottom,var(--mask))}.et-scrollable[direction=vertical] .et-scrollable-mask--end{background:linear-gradient(to top,var(--mask))}.et-scrollable[direction=vertical] .et-scrollable-button--start{inset-inline-start:calc(50% - 20px);transform:rotate(0)}.et-scrollable[direction=vertical] .et-scrollable-button--end{inset-inline-start:calc(50% - 20px);transform:rotate(180deg)}.et-scrollable[direction=vertical] .et-scroll-observer-first-element,.et-scrollable[direction=vertical] .et-scroll-observer-last-element{inline-size:100%;block-size:1px}.et-scrollable[direction=vertical] .et-scroll-observer-first-element{inset-block-start:1px}.et-scrollable[direction=vertical] .et-scroll-observer-last-element{inset-block-end:1px}.et-scrollable:not(.et-scrollable--is-at-start) .et-scrollable-masks .et-scrollable-mask--start,.et-scrollable:not(.et-scrollable--is-at-start) .et-scrollable-buttons .et-scrollable-button--start{opacity:1}.et-scrollable:not(.et-scrollable--is-at-start) .et-scrollable-buttons .et-scrollable-button--start{pointer-events:all}.et-scrollable:not(.et-scrollable--is-at-end) .et-scrollable-masks .et-scrollable-mask--end,.et-scrollable:not(.et-scrollable--is-at-end) .et-scrollable-buttons .et-scrollable-button--end{opacity:1}.et-scrollable:not(.et-scrollable--is-at-end) .et-scrollable-buttons .et-scrollable-button--end{pointer-events:all}.et-scrollable .et-scrollable-container-outer{overflow:auto;display:grid;position:relative;grid-row:1/1;grid-column:1/1}.et-scrollable .et-scroll-observer-first-element,.et-scrollable .et-scroll-observer-last-element{position:absolute;pointer-events:none}.et-scrollable .et-scrollable-container{display:grid;grid-auto-flow:var(--_flow);position:relative}.et-scrollable .et-scrollable-masks,.et-scrollable .et-scrollable-buttons{grid-row:1/1;grid-column:1/1;pointer-events:none}.et-scrollable .et-scrollable-masks .et-scrollable-mask,.et-scrollable .et-scrollable-masks .et-scrollable-button,.et-scrollable .et-scrollable-buttons .et-scrollable-mask,.et-scrollable .et-scrollable-buttons .et-scrollable-button{position:absolute;opacity:0}.et-scrollable.et-scrollable--can-scroll.et-scrollable--enable-overlay-animations .et-scrollable-mask,.et-scrollable.et-scrollable--can-scroll.et-scrollable--enable-overlay-animations .et-scrollable-button{transition:opacity .3s var(--ease-5)}.et-scrollable .et-scrollable-buttons .et-scrollable-button{background:transparent;border:none;padding:12px;inline-size:40px;block-size:40px;border-radius:4px;cursor:pointer}.et-scrollable .et-scrollable-buttons .et-scrollable-button .et-chevron-icon{pointer-events:none}.et-scrollable .et-scrollable-buttons .et-scrollable-button .et-scrollable-button--start{inset-inline:0 0}.et-scrollable .et-scrollable-buttons .et-scrollable-button .et-scrollable-button--end{inset-inline:calc(100% - 40px) 0}.et-scrollable[sticky-buttons=true]{--_sticky-margin: 10%}.et-scrollable[sticky-buttons=true] .et-scrollable-button{position:sticky}.et-scrollable[sticky-buttons=true][direction=horizontal] .et-scrollable-buttons{margin-block:var(--_sticky-margin)}.et-scrollable[sticky-buttons=true][direction=vertical] .et-scrollable-buttons{margin-inline:var(--_sticky-margin)}.et-scrollable[sticky-buttons=true][direction=vertical] .et-scrollable-buttons .et-scrollable-button--end{inset-block-start:100%}.et-scrollable .et-scrollable-footer{display:flex;justify-content:center;gap:10px;margin-block-start:10px}.et-scrollable .et-scrollable-navigation-item{display:flex;justify-content:center;align-items:center;border:none;padding:0;inline-size:20px;block-size:20px;border-radius:50%;cursor:pointer;background-color:transparent}.et-scrollable .et-scrollable-navigation-item.et-scrollable-navigation-item--active:after{background-color:#c6c6c6}.et-scrollable .et-scrollable-navigation-item:after{content:\"\";display:block;inline-size:50%;block-size:50%;border-radius:50%;background-color:#4b4b4b;transform:scale(0);transition:background-color .2s linear,transform .2s linear}.et-scrollable .et-scrollable-navigation-item[active-offset=\"0\"]:after{transform:scale(1)}.et-scrollable .et-scrollable-navigation-item[active-offset=\"1\"]:after{transform:scale(.75)}.et-scrollable .et-scrollable-navigation-item[active-offset=\"2\"]:after{transform:scale(.6)}.et-scrollable .et-scrollable-navigation-item[active-offset=\"3\"]:after{transform:scale(.5)}.et-scrollable .et-scrollable-navigation-item[active-offset=\"4\"]:after{transform:scale(.4)}.et-scrollable .et-scrollable-progress-bar{overflow:hidden;max-inline-size:100px;display:flex;align-items:center}.et-scrollable .et-scrollable-progress-bar .et-scrollable-dots-container{display:flex;flex-wrap:nowrap;transition:transform .3s var(--ease-5)}\n"], dependencies: [{ kind: "directive", type: CursorDragScrollDirective, selector: "[etCursorDragScroll]", inputs: ["etCursorDragScroll", "allowedDirection"], outputs: ["cursorDragStart", "cursorDragMove", "cursorDragEnd"], exportAs: ["etCursorDragScroll"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: ChevronIconComponent, selector: "et-chevron-icon" }, { kind: "directive", type: ScrollableIgnoreChildDirective, selector: "[etScrollableIgnoreChild]", inputs: ["etScrollableIgnoreChild"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
522
613
  }
523
614
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: ScrollableComponent, decorators: [{
524
615
  type: Component,
@@ -530,9 +621,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImpor
530
621
  ChevronIconComponent,
531
622
  ScrollableIsActiveChildDirective,
532
623
  ScrollableIgnoreChildDirective,
624
+ NgTemplateOutlet,
533
625
  ], host: {
534
626
  class: 'et-scrollable',
535
- }, template: "<div class=\"et-scrollable-wrapper\">\n <div\n #scrollable\n [attr.role]=\"scrollableRole() ?? undefined\"\n [etCursorDragScroll]=\"cursorDragScroll() && (!isAtStart() || !isAtEnd())\"\n [allowedDirection]=\"direction()\"\n (cursorDragStart)=\"setIsCursorDragging(true)\"\n (cursorDragEnd)=\"setIsCursorDragging(false)\"\n class=\"et-scrollable-container-outer\"\n >\n <div #scrollableContainer [ngClass]=\"scrollableClass()\" class=\"et-scrollable-container\">\n <div #firstElement class=\"et-scroll-observer-first-element\" etScrollableIgnoreChild></div>\n <ng-content />\n <div #lastElement class=\"et-scroll-observer-last-element\" etScrollableIgnoreChild></div>\n </div>\n </div>\n\n @if (renderMasks()) {\n <div class=\"et-scrollable-masks\">\n <div class=\"et-scrollable-mask et-scrollable-mask--start\"></div>\n <div class=\"et-scrollable-mask et-scrollable-mask--end\"></div>\n </div>\n }\n\n @if (renderButtons()) {\n <div class=\"et-scrollable-buttons\">\n <button\n (click)=\"scrollToStartDirection()\"\n class=\"et-scrollable-button et-scrollable-button--start\"\n aria-hidden=\"true\"\n type=\"button\"\n tabindex=\"-1\"\n >\n <et-chevron-icon />\n </button>\n <button\n (click)=\"scrollToEndDirection()\"\n class=\"et-scrollable-button et-scrollable-button--end\"\n aria-hidden=\"true\"\n type=\"button\"\n tabindex=\"-1\"\n >\n <et-chevron-icon />\n </button>\n </div>\n }\n</div>\n\n@if (renderNavigation() && scrollableNavigation().length > 1) {\n <div class=\"et-scrollable-navigation\" aria-hidden=\"true\">\n @for (item of scrollableNavigation(); track i; let i = $index) {\n <button\n [class.et-scrollable-navigation-item--active]=\"item.isActive\"\n (click)=\"scrollToElementViaNavigation(i, item.element)\"\n class=\"et-scrollable-navigation-item\"\n tabindex=\"-1\"\n aria-hidden=\"true\"\n ></button>\n }\n </div>\n}\n", styles: [".et-scrollable{--mask: #121212 0, transparent 100%;--mask-size: 25px;--_auto-size: min-content;--_flow: column;display:block}.et-scrollable .et-scrollable-wrapper{display:grid;position:relative}.et-scrollable[item-size=same]{--_auto-size: 1fr}.et-scrollable[item-size=full]{--_auto-size: var(--actual-item-size)}.et-scrollable[render-scrollbars=false] .et-scrollable-container-outer{scrollbar-width:none}.et-scrollable[render-scrollbars=false] .et-scrollable-container-outer::-webkit-scrollbar{display:none}.et-scrollable[direction=horizontal] .et-scrollable-container-outer{overflow-x:auto;overflow-y:hidden}.et-scrollable[direction=horizontal] .et-scrollable-container{grid-auto-columns:var(--_auto-size)}.et-scrollable[direction=horizontal] .et-scrollable-mask,.et-scrollable[direction=horizontal] .et-scrollable-button{inline-size:var(--mask-size);block-size:100%}.et-scrollable[direction=horizontal] .et-scrollable-mask--start,.et-scrollable[direction=horizontal] .et-scrollable-button--start{inset-block-start:0;inset-inline:0 0}.et-scrollable[direction=horizontal] .et-scrollable-mask--end,.et-scrollable[direction=horizontal] .et-scrollable-button--end{inset-block-start:0;inset-inline:calc(100% - 40px) 0}.et-scrollable[direction=horizontal] .et-scrollable-mask--start{background:linear-gradient(to right,var(--mask))}.et-scrollable[direction=horizontal] .et-scrollable-mask--end{background:linear-gradient(to left,var(--mask));inset-inline:calc(100% - var(--mask-size)) 100%}.et-scrollable[direction=horizontal] .et-scrollable-button--start{inset-block-start:calc(50% - 20px);transform:rotate(-90deg)}.et-scrollable[direction=horizontal] .et-scrollable-button--end{inset-block-start:calc(50% - 20px);transform:rotate(90deg)}.et-scrollable[direction=horizontal] .et-scroll-observer-first-element,.et-scrollable[direction=horizontal] .et-scroll-observer-last-element{block-size:100%;inline-size:1px}.et-scrollable[direction=horizontal] .et-scroll-observer-first-element{inset-inline-start:1px}.et-scrollable[direction=horizontal] .et-scroll-observer-last-element{inset-inline-end:1px}.et-scrollable[direction=vertical]{--_flow: row}.et-scrollable[direction=vertical] .et-scrollable-container-outer{overflow-x:hidden;overflow-y:auto}.et-scrollable[direction=vertical] .et-scrollable-container{grid-auto-rows:var(--_auto-size)}.et-scrollable[direction=vertical] .et-scrollable-mask,.et-scrollable[direction=vertical] .et-scrollable-button{block-size:var(--mask-size);inline-size:100%}.et-scrollable[direction=vertical] .et-scrollable-mask--start,.et-scrollable[direction=vertical] .et-scrollable-button--start{inset-block-start:0;inset-inline-start:0}.et-scrollable[direction=vertical] .et-scrollable-mask--end,.et-scrollable[direction=vertical] .et-scrollable-button--end{inset-block-end:0;inset-inline-start:0}.et-scrollable[direction=vertical] .et-scrollable-mask--start{background:linear-gradient(to bottom,var(--mask))}.et-scrollable[direction=vertical] .et-scrollable-mask--end{background:linear-gradient(to top,var(--mask))}.et-scrollable[direction=vertical] .et-scrollable-button--start{inset-inline-start:calc(50% - 20px);transform:rotate(0)}.et-scrollable[direction=vertical] .et-scrollable-button--end{inset-inline-start:calc(50% - 20px);transform:rotate(180deg)}.et-scrollable[direction=vertical] .et-scroll-observer-first-element,.et-scrollable[direction=vertical] .et-scroll-observer-last-element{inline-size:100%;block-size:1px}.et-scrollable[direction=vertical] .et-scroll-observer-first-element{inset-block-start:1px}.et-scrollable[direction=vertical] .et-scroll-observer-last-element{inset-block-end:1px}.et-scrollable:not(.et-scrollable--is-at-start) .et-scrollable-masks .et-scrollable-mask--start,.et-scrollable:not(.et-scrollable--is-at-start) .et-scrollable-buttons .et-scrollable-button--start{opacity:1}.et-scrollable:not(.et-scrollable--is-at-start) .et-scrollable-buttons .et-scrollable-button--start{pointer-events:all}.et-scrollable:not(.et-scrollable--is-at-end) .et-scrollable-masks .et-scrollable-mask--end,.et-scrollable:not(.et-scrollable--is-at-end) .et-scrollable-buttons .et-scrollable-button--end{opacity:1}.et-scrollable:not(.et-scrollable--is-at-end) .et-scrollable-buttons .et-scrollable-button--end{pointer-events:all}.et-scrollable .et-scrollable-container-outer{overflow:auto;display:grid;position:relative;grid-row:1/1;grid-column:1/1}.et-scrollable .et-scroll-observer-first-element,.et-scrollable .et-scroll-observer-last-element{position:absolute;pointer-events:none}.et-scrollable .et-scrollable-container{display:grid;grid-auto-flow:var(--_flow);position:relative}.et-scrollable .et-scrollable-masks,.et-scrollable .et-scrollable-buttons{grid-row:1/1;grid-column:1/1;pointer-events:none}.et-scrollable .et-scrollable-masks .et-scrollable-mask,.et-scrollable .et-scrollable-masks .et-scrollable-button,.et-scrollable .et-scrollable-buttons .et-scrollable-mask,.et-scrollable .et-scrollable-buttons .et-scrollable-button{position:absolute;opacity:0}.et-scrollable.et-scrollable--can-scroll.et-scrollable--enable-overlay-animations .et-scrollable-mask,.et-scrollable.et-scrollable--can-scroll.et-scrollable--enable-overlay-animations .et-scrollable-button{transition:opacity .3s var(--ease-5)}.et-scrollable .et-scrollable-buttons .et-scrollable-button{background:transparent;border:none;padding:12px;inline-size:40px;block-size:40px;border-radius:4px;cursor:pointer}.et-scrollable .et-scrollable-buttons .et-scrollable-button .et-chevron-icon{pointer-events:none}.et-scrollable .et-scrollable-buttons .et-scrollable-button .et-scrollable-button--start{inset-inline:0 0}.et-scrollable .et-scrollable-buttons .et-scrollable-button .et-scrollable-button--end{inset-inline:calc(100% - 40px) 0}.et-scrollable[sticky-buttons=true]{--_sticky-margin: 10%}.et-scrollable[sticky-buttons=true] .et-scrollable-button{position:sticky}.et-scrollable[sticky-buttons=true][direction=horizontal] .et-scrollable-buttons{margin-block:var(--_sticky-margin)}.et-scrollable[sticky-buttons=true][direction=vertical] .et-scrollable-buttons{margin-inline:var(--_sticky-margin)}.et-scrollable[sticky-buttons=true][direction=vertical] .et-scrollable-buttons .et-scrollable-button--end{inset-block-start:100%}.et-scrollable .et-scrollable-navigation{display:flex;justify-content:center;gap:10px;margin-block-start:10px}.et-scrollable .et-scrollable-navigation .et-scrollable-navigation-item{all:unset;inline-size:10px;block-size:10px;display:block;background-color:#4b4b4b;border-radius:50%;cursor:pointer}.et-scrollable .et-scrollable-navigation .et-scrollable-navigation-item.et-scrollable-navigation-item--active{background-color:#c6c6c6}\n"] }]
627
+ }, template: "<div class=\"et-scrollable-wrapper\">\n <div\n #scrollable\n [attr.role]=\"scrollableRole() ?? undefined\"\n [etCursorDragScroll]=\"cursorDragScroll() && (!isAtStart() || !isAtEnd())\"\n [allowedDirection]=\"direction()\"\n (cursorDragStart)=\"setIsCursorDragging(true)\"\n (cursorDragEnd)=\"setIsCursorDragging(false)\"\n class=\"et-scrollable-container-outer\"\n >\n <div #scrollableContainer [ngClass]=\"scrollableClass()\" class=\"et-scrollable-container\">\n <div #firstElement class=\"et-scroll-observer-first-element\" etScrollableIgnoreChild></div>\n <ng-content />\n <div #lastElement class=\"et-scroll-observer-last-element\" etScrollableIgnoreChild></div>\n </div>\n </div>\n\n @if (renderMasks()) {\n <div class=\"et-scrollable-masks\">\n <div class=\"et-scrollable-mask et-scrollable-mask--start\"></div>\n <div class=\"et-scrollable-mask et-scrollable-mask--end\"></div>\n </div>\n }\n\n @if (renderButtonsInside()) {\n <div class=\"et-scrollable-buttons\">\n <ng-container *ngTemplateOutlet=\"forwardButtonTpl\" />\n <ng-container *ngTemplateOutlet=\"backwardButtonTpl\" />\n </div>\n }\n</div>\n\n@if (renderButtonsInFooter() || (renderNavigation() && scrollableNavigation().length > 1)) {\n <div\n [ngClass]=\"{\n 'et-scrollable-footer--with-navigation': renderNavigation(),\n 'et-scrollable-footer--with-buttons': renderButtonsInFooter()\n }\"\n class=\"et-scrollable-footer\"\n aria-hidden=\"true\"\n >\n @if (renderButtonsInFooter()) {\n <ng-container *ngTemplateOutlet=\"forwardButtonTpl\" />\n }\n\n @if (renderNavigation()) {\n <div class=\"et-scrollable-progress-bar\">\n <div #navigationDotsContainer class=\"et-scrollable-dots-container\">\n @for (item of scrollableNavigation(); track i; let i = $index) {\n <button\n #navigationDot\n [class.et-scrollable-navigation-item--active]=\"item.isActive\"\n [class.et-scrollable-navigation-item--close]=\"\n scrollableNavigation()[i + 1]?.isActive || scrollableNavigation()[i - 1]?.isActive\n \"\n [class.et-scrollable-navigation-item--far]=\"\n !scrollableNavigation()[i + 1]?.isActive && !scrollableNavigation()[i - 1]?.isActive && !item.isActive\n \"\n [attr.active-offset]=\"item.activeOffset\"\n (click)=\"scrollToElementViaNavigation(i)\"\n class=\"et-scrollable-navigation-item\"\n type=\"button\"\n tabindex=\"-1\"\n aria-hidden=\"true\"\n ></button>\n }\n </div>\n </div>\n }\n\n @if (renderButtonsInFooter()) {\n <ng-container *ngTemplateOutlet=\"backwardButtonTpl\" />\n }\n </div>\n}\n\n<ng-template #forwardButtonTpl>\n <button\n [disabled]=\"isAtStart()\"\n (click)=\"scrollToStartDirection()\"\n class=\"et-scrollable-button et-scrollable-button--start\"\n aria-hidden=\"true\"\n type=\"button\"\n tabindex=\"-1\"\n >\n <et-chevron-icon />\n </button>\n</ng-template>\n\n<ng-template #backwardButtonTpl>\n <button\n [disabled]=\"isAtEnd()\"\n (click)=\"scrollToEndDirection()\"\n class=\"et-scrollable-button et-scrollable-button--end\"\n aria-hidden=\"true\"\n type=\"button\"\n tabindex=\"-1\"\n >\n <et-chevron-icon />\n </button>\n</ng-template>\n", styles: [".et-scrollable{--mask: #121212 0, transparent 100%;--mask-size: 25px;--_auto-size: min-content;--_flow: column;display:block}.et-scrollable .et-scrollable-wrapper{display:grid;position:relative}.et-scrollable[item-size=same]{--_auto-size: 1fr}.et-scrollable[item-size=full]{--_auto-size: var(--actual-item-size)}.et-scrollable[render-scrollbars=false] .et-scrollable-container-outer{scrollbar-width:none}.et-scrollable[render-scrollbars=false] .et-scrollable-container-outer::-webkit-scrollbar{display:none}.et-scrollable[direction=horizontal] .et-scrollable-container-outer{overflow-x:auto;overflow-y:hidden}.et-scrollable[direction=horizontal] .et-scrollable-container{grid-auto-columns:var(--_auto-size)}.et-scrollable[direction=horizontal] .et-scrollable-mask,.et-scrollable[direction=horizontal] .et-scrollable-button{inline-size:var(--mask-size);block-size:100%}.et-scrollable[direction=horizontal] .et-scrollable-mask--start,.et-scrollable[direction=horizontal] .et-scrollable-button--start{inset-block-start:0;inset-inline:0 0}.et-scrollable[direction=horizontal] .et-scrollable-mask--end,.et-scrollable[direction=horizontal] .et-scrollable-button--end{inset-block-start:0;inset-inline:calc(100% - 40px) 0}.et-scrollable[direction=horizontal] .et-scrollable-mask--start{background:linear-gradient(to right,var(--mask))}.et-scrollable[direction=horizontal] .et-scrollable-mask--end{background:linear-gradient(to left,var(--mask));inset-inline:calc(100% - var(--mask-size)) 100%}.et-scrollable[direction=horizontal] .et-scrollable-button--start{inset-block-start:calc(50% - 20px);transform:rotate(-90deg)}.et-scrollable[direction=horizontal] .et-scrollable-button--end{inset-block-start:calc(50% - 20px);transform:rotate(90deg)}.et-scrollable[direction=horizontal] .et-scroll-observer-first-element,.et-scrollable[direction=horizontal] .et-scroll-observer-last-element{block-size:100%;inline-size:1px}.et-scrollable[direction=horizontal] .et-scroll-observer-first-element{inset-inline-start:1px}.et-scrollable[direction=horizontal] .et-scroll-observer-last-element{inset-inline-end:1px}.et-scrollable[direction=vertical]{--_flow: row}.et-scrollable[direction=vertical] .et-scrollable-container-outer{overflow-x:hidden;overflow-y:auto}.et-scrollable[direction=vertical] .et-scrollable-container{grid-auto-rows:var(--_auto-size)}.et-scrollable[direction=vertical] .et-scrollable-mask,.et-scrollable[direction=vertical] .et-scrollable-button{block-size:var(--mask-size);inline-size:100%}.et-scrollable[direction=vertical] .et-scrollable-mask--start,.et-scrollable[direction=vertical] .et-scrollable-button--start{inset-block-start:0;inset-inline-start:0}.et-scrollable[direction=vertical] .et-scrollable-mask--end,.et-scrollable[direction=vertical] .et-scrollable-button--end{inset-block-end:0;inset-inline-start:0}.et-scrollable[direction=vertical] .et-scrollable-mask--start{background:linear-gradient(to bottom,var(--mask))}.et-scrollable[direction=vertical] .et-scrollable-mask--end{background:linear-gradient(to top,var(--mask))}.et-scrollable[direction=vertical] .et-scrollable-button--start{inset-inline-start:calc(50% - 20px);transform:rotate(0)}.et-scrollable[direction=vertical] .et-scrollable-button--end{inset-inline-start:calc(50% - 20px);transform:rotate(180deg)}.et-scrollable[direction=vertical] .et-scroll-observer-first-element,.et-scrollable[direction=vertical] .et-scroll-observer-last-element{inline-size:100%;block-size:1px}.et-scrollable[direction=vertical] .et-scroll-observer-first-element{inset-block-start:1px}.et-scrollable[direction=vertical] .et-scroll-observer-last-element{inset-block-end:1px}.et-scrollable:not(.et-scrollable--is-at-start) .et-scrollable-masks .et-scrollable-mask--start,.et-scrollable:not(.et-scrollable--is-at-start) .et-scrollable-buttons .et-scrollable-button--start{opacity:1}.et-scrollable:not(.et-scrollable--is-at-start) .et-scrollable-buttons .et-scrollable-button--start{pointer-events:all}.et-scrollable:not(.et-scrollable--is-at-end) .et-scrollable-masks .et-scrollable-mask--end,.et-scrollable:not(.et-scrollable--is-at-end) .et-scrollable-buttons .et-scrollable-button--end{opacity:1}.et-scrollable:not(.et-scrollable--is-at-end) .et-scrollable-buttons .et-scrollable-button--end{pointer-events:all}.et-scrollable .et-scrollable-container-outer{overflow:auto;display:grid;position:relative;grid-row:1/1;grid-column:1/1}.et-scrollable .et-scroll-observer-first-element,.et-scrollable .et-scroll-observer-last-element{position:absolute;pointer-events:none}.et-scrollable .et-scrollable-container{display:grid;grid-auto-flow:var(--_flow);position:relative}.et-scrollable .et-scrollable-masks,.et-scrollable .et-scrollable-buttons{grid-row:1/1;grid-column:1/1;pointer-events:none}.et-scrollable .et-scrollable-masks .et-scrollable-mask,.et-scrollable .et-scrollable-masks .et-scrollable-button,.et-scrollable .et-scrollable-buttons .et-scrollable-mask,.et-scrollable .et-scrollable-buttons .et-scrollable-button{position:absolute;opacity:0}.et-scrollable.et-scrollable--can-scroll.et-scrollable--enable-overlay-animations .et-scrollable-mask,.et-scrollable.et-scrollable--can-scroll.et-scrollable--enable-overlay-animations .et-scrollable-button{transition:opacity .3s var(--ease-5)}.et-scrollable .et-scrollable-buttons .et-scrollable-button{background:transparent;border:none;padding:12px;inline-size:40px;block-size:40px;border-radius:4px;cursor:pointer}.et-scrollable .et-scrollable-buttons .et-scrollable-button .et-chevron-icon{pointer-events:none}.et-scrollable .et-scrollable-buttons .et-scrollable-button .et-scrollable-button--start{inset-inline:0 0}.et-scrollable .et-scrollable-buttons .et-scrollable-button .et-scrollable-button--end{inset-inline:calc(100% - 40px) 0}.et-scrollable[sticky-buttons=true]{--_sticky-margin: 10%}.et-scrollable[sticky-buttons=true] .et-scrollable-button{position:sticky}.et-scrollable[sticky-buttons=true][direction=horizontal] .et-scrollable-buttons{margin-block:var(--_sticky-margin)}.et-scrollable[sticky-buttons=true][direction=vertical] .et-scrollable-buttons{margin-inline:var(--_sticky-margin)}.et-scrollable[sticky-buttons=true][direction=vertical] .et-scrollable-buttons .et-scrollable-button--end{inset-block-start:100%}.et-scrollable .et-scrollable-footer{display:flex;justify-content:center;gap:10px;margin-block-start:10px}.et-scrollable .et-scrollable-navigation-item{display:flex;justify-content:center;align-items:center;border:none;padding:0;inline-size:20px;block-size:20px;border-radius:50%;cursor:pointer;background-color:transparent}.et-scrollable .et-scrollable-navigation-item.et-scrollable-navigation-item--active:after{background-color:#c6c6c6}.et-scrollable .et-scrollable-navigation-item:after{content:\"\";display:block;inline-size:50%;block-size:50%;border-radius:50%;background-color:#4b4b4b;transform:scale(0);transition:background-color .2s linear,transform .2s linear}.et-scrollable .et-scrollable-navigation-item[active-offset=\"0\"]:after{transform:scale(1)}.et-scrollable .et-scrollable-navigation-item[active-offset=\"1\"]:after{transform:scale(.75)}.et-scrollable .et-scrollable-navigation-item[active-offset=\"2\"]:after{transform:scale(.6)}.et-scrollable .et-scrollable-navigation-item[active-offset=\"3\"]:after{transform:scale(.5)}.et-scrollable .et-scrollable-navigation-item[active-offset=\"4\"]:after{transform:scale(.4)}.et-scrollable .et-scrollable-progress-bar{overflow:hidden;max-inline-size:100px;display:flex;align-items:center}.et-scrollable .et-scrollable-progress-bar .et-scrollable-dots-container{display:flex;flex-wrap:nowrap;transition:transform .3s var(--ease-5)}\n"] }]
536
628
  }], ctorParameters: () => [], propDecorators: { _itemSize: [{
537
629
  type: Input,
538
630
  args: [{ alias: 'itemSize' }]
@@ -554,6 +646,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImpor
554
646
  }], _renderButtons: [{
555
647
  type: Input,
556
648
  args: [{ transform: booleanAttribute, alias: 'renderButtons' }]
649
+ }], _buttonPosition: [{
650
+ type: Input,
651
+ args: [{ alias: 'buttonPosition' }]
557
652
  }], _renderScrollbars: [{
558
653
  type: Input,
559
654
  args: [{ transform: booleanAttribute, alias: 'renderScrollbars' }]
@@ -575,6 +670,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImpor
575
670
  }], _scrollMargin: [{
576
671
  type: Input,
577
672
  args: [{ transform: numberAttribute, alias: 'scrollMargin' }]
673
+ }], _scrollOrigin: [{
674
+ type: Input,
675
+ args: [{ alias: 'scrollOrigin' }]
578
676
  }], scrollStateChange: [{
579
677
  type: Output
580
678
  }], intersectionChange: [{
@@ -595,4 +693,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImpor
595
693
  type: ContentChildren,
596
694
  args: [SCROLLABLE_IS_ACTIVE_CHILD_TOKEN, { descendants: true }]
597
695
  }] } });
598
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"scrollable.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/cdk/src/lib/components/scrollable/components/scrollable/scrollable.component.ts","../../../../../../../../../libs/cdk/src/lib/components/scrollable/components/scrollable/scrollable.component.html"],"names":[],"mappings":"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","sourcesContent":["import { NgClass } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  ContentChildren,\n  ElementRef,\n  EventEmitter,\n  Input,\n  Output,\n  ViewChild,\n  ViewEncapsulation,\n  booleanAttribute,\n  computed,\n  effect,\n  inject,\n  isDevMode,\n  numberAttribute,\n  signal,\n} from '@angular/core';\nimport { takeUntilDestroyed, toObservable } from '@angular/core/rxjs-interop';\nimport {\n  CurrentElementVisibility,\n  CursorDragScrollDirective,\n  LetDirective,\n  NgClassType,\n  ObserveScrollStateDirective,\n  ScrollObserverScrollState,\n  ScrollToElementOptions,\n  TypedQueryList,\n  getFirstAndLastPartialIntersection,\n  isElementVisible,\n  nextFrame,\n  scrollToElement,\n  signalElementChildren,\n  signalElementIntersection,\n  signalElementScrollState,\n  signalHostAttributes,\n  signalHostClasses,\n  signalHostElementDimensions,\n  signalHostStyles,\n} from '@ethlete/core';\nimport {\n  BehaviorSubject,\n  Subject,\n  combineLatest,\n  debounceTime,\n  filter,\n  fromEvent,\n  map,\n  take,\n  takeUntil,\n  tap,\n} from 'rxjs';\nimport { ChevronIconComponent } from '../../../icons/chevron-icon';\nimport { ScrollableIgnoreChildDirective, isScrollableChildIgnored } from '../../directives/scrollable-ignore-child';\nimport {\n  SCROLLABLE_IS_ACTIVE_CHILD_TOKEN,\n  ScrollableIsActiveChildDirective,\n} from '../../directives/scrollable-is-active-child';\nimport { ScrollableIntersectionChange, ScrollableScrollMode } from '../../types';\n\n// Thresholds for the intersection observer.\nconst ELEMENT_INTERSECTION_THRESHOLD = [\n  // We use 51 steps to get a 2% step size.\n  ...Array.from({ length: 51 }, (_, i) => i / 50),\n\n  // Additional steps needed since display scaling can cause the intersection ratio to be slightly off.\n  0.01,\n  0.005,\n  0.001,\n  0.99,\n  0.995,\n  0.999,\n];\n\ninterface ScrollableNavigationItem {\n  isActive: boolean;\n  element: HTMLElement;\n}\n\n@Component({\n  selector: 'et-scrollable',\n  templateUrl: './scrollable.component.html',\n  styleUrls: ['./scrollable.component.scss'],\n  standalone: true,\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [\n    CursorDragScrollDirective,\n    ObserveScrollStateDirective,\n    NgClass,\n    LetDirective,\n    ChevronIconComponent,\n    ScrollableIsActiveChildDirective,\n    ScrollableIgnoreChildDirective,\n  ],\n  host: {\n    class: 'et-scrollable',\n  },\n})\nexport class ScrollableComponent {\n  private readonly _elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n  private readonly _isCursorDragging$ = new BehaviorSubject<boolean>(false);\n\n  @Input({ alias: 'itemSize' })\n  set _itemSize(v: 'auto' | 'same' | 'full') {\n    this.itemSize.set(v);\n  }\n  readonly itemSize = signal<'auto' | 'same' | 'full'>('auto');\n\n  @Input({ alias: 'direction' })\n  set _direction(v: 'horizontal' | 'vertical') {\n    this.direction.set(v);\n  }\n  readonly direction = signal<'horizontal' | 'vertical'>('horizontal');\n\n  @Input({ alias: 'scrollableRole' })\n  set _scrollableRole(v: string | null) {\n    this.scrollableRole.set(v);\n  }\n  readonly scrollableRole = signal<string | null>(null);\n\n  @Input({ alias: 'scrollableClass' })\n  set _scrollableClass(v: NgClassType | null) {\n    this.scrollableClass.set(v);\n  }\n  readonly scrollableClass = signal<NgClassType | null>(null);\n\n  @Input({ transform: booleanAttribute, alias: 'renderNavigation' })\n  set _renderNavigation(v: boolean) {\n    this.renderNavigation.set(v);\n  }\n  readonly renderNavigation = signal(false);\n\n  @Input({ transform: booleanAttribute, alias: 'renderMasks' })\n  set _renderMasks(v: boolean) {\n    this.renderMasks.set(v);\n  }\n  readonly renderMasks = signal(true);\n\n  @Input({ transform: booleanAttribute, alias: 'renderButtons' })\n  set _renderButtons(v: boolean) {\n    this.renderButtons.set(v);\n  }\n  readonly renderButtons = signal(true);\n\n  @Input({ transform: booleanAttribute, alias: 'renderScrollbars' })\n  set _renderScrollbars(v: boolean) {\n    this.renderScrollbars.set(v);\n  }\n  readonly renderScrollbars = signal(false);\n\n  @Input({ transform: booleanAttribute, alias: 'stickyButtons' })\n  set _stickyButtons(v: boolean) {\n    this.stickyButtons.set(v);\n  }\n  readonly stickyButtons = signal(false);\n\n  @Input({ transform: booleanAttribute, alias: 'cursorDragScroll' })\n  set _cursorDragScroll(v: boolean) {\n    this.cursorDragScroll.set(v);\n  }\n  readonly cursorDragScroll = signal(true);\n\n  @Input({ transform: booleanAttribute, alias: 'disableActiveElementScrolling' })\n  set _disableActiveElementScrolling(v: boolean) {\n    this.disableActiveElementScrolling.set(v);\n  }\n  readonly disableActiveElementScrolling = signal(false);\n\n  @Input({ alias: 'scrollMode' })\n  set _scrollMode(v: ScrollableScrollMode) {\n    this.scrollMode.set(v);\n  }\n  readonly scrollMode = signal<ScrollableScrollMode>('container');\n\n  @Input({ transform: booleanAttribute, alias: 'snap' })\n  set _snap(v: boolean) {\n    this.snap.set(v);\n  }\n  readonly snap = signal(false);\n\n  @Input({ transform: numberAttribute, alias: 'scrollMargin' })\n  set _scrollMargin(v: number) {\n    this.scrollMargin.set(v);\n  }\n  readonly scrollMargin = signal(0);\n\n  @Output()\n  readonly scrollStateChange = new EventEmitter<ScrollObserverScrollState>();\n\n  @Output()\n  readonly intersectionChange = new EventEmitter<ScrollableIntersectionChange[]>();\n\n  @ViewChild('scrollable', { static: true })\n  private set _scrollable(e: ElementRef<HTMLElement>) {\n    this.scrollable.set(e);\n  }\n  readonly scrollable = signal<ElementRef<HTMLElement> | null>(null);\n\n  @ViewChild('scrollableContainer', { static: true })\n  private set _scrollableContainer(e: ElementRef<HTMLElement>) {\n    this.scrollableContainer.set(e);\n  }\n  readonly scrollableContainer = signal<ElementRef<HTMLElement> | null>(null);\n\n  @ViewChild('firstElement', { static: true })\n  private set _firstElement(e: ElementRef<HTMLElement>) {\n    this.firstElement.set(e);\n  }\n  readonly firstElement = signal<ElementRef<HTMLElement> | null>(null);\n\n  @ViewChild('lastElement', { static: true })\n  private set _lastElement(e: ElementRef<HTMLElement>) {\n    this.lastElement.set(e);\n  }\n  readonly lastElement = signal<ElementRef<HTMLElement> | null>(null);\n\n  @ContentChildren(SCROLLABLE_IS_ACTIVE_CHILD_TOKEN, { descendants: true })\n  private set _activeElementList(e: TypedQueryList<ScrollableIsActiveChildDirective>) {\n    this.activeElementList.set(e);\n  }\n  readonly activeElementList = signal<TypedQueryList<ScrollableIsActiveChildDirective> | null>(null);\n\n  private readonly containerScrollState = signalElementScrollState(this.scrollable);\n  private readonly firstElementIntersection = signalElementIntersection(this.firstElement, { root: this.scrollable });\n  private readonly firstElementVisibility = signal<CurrentElementVisibility | null>(null);\n  private readonly lastElementIntersection = signalElementIntersection(this.lastElement, { root: this.scrollable });\n  private readonly lastElementVisibility = signal<CurrentElementVisibility | null>(null);\n\n  private readonly allScrollableChildren = signalElementChildren(this.scrollableContainer);\n  private readonly scrollableDimensions = signalHostElementDimensions();\n  private readonly scrollableChildren = computed(() =>\n    this.allScrollableChildren().filter((c) => !isScrollableChildIgnored(c)),\n  );\n\n  private readonly _disableSnapping$ = new Subject<void>();\n\n  private readonly scrollableContentIntersections = signalElementIntersection(this.scrollableChildren, {\n    root: this.scrollable,\n    threshold: ELEMENT_INTERSECTION_THRESHOLD,\n  });\n\n  private readonly scrollableContentIntersections$ = toObservable(this.scrollableContentIntersections);\n\n  private readonly manualActiveNavigationIndex = signal<number | null>(null);\n\n  private readonly canScroll = computed(() => {\n    const dir = this.direction();\n\n    if (dir === 'horizontal') {\n      return this.containerScrollState().canScrollHorizontally;\n    }\n\n    return this.containerScrollState().canScrollVertically;\n  });\n\n  readonly isAtStart = computed(() => {\n    if (!this.canScroll()) {\n      return true;\n    }\n\n    const intersection = this.firstElementIntersection()[0];\n\n    if (!intersection) {\n      return this.firstElementVisibility()?.inline ?? true;\n    }\n\n    return intersection.isIntersecting;\n  });\n  readonly isAtEnd = computed(() => {\n    if (!this.canScroll()) {\n      return true;\n    }\n\n    const intersection = this.lastElementIntersection()[0];\n\n    if (!intersection) {\n      return this.lastElementVisibility()?.inline ?? true;\n    }\n\n    return intersection.isIntersecting;\n  });\n\n  private readonly _actualItemSize = computed(() => {\n    if (this.itemSize() !== 'full') return null;\n\n    const dimensions = this.scrollableDimensions();\n\n    if (this.direction() === 'horizontal') {\n      return dimensions.rect?.width ?? null;\n    } else {\n      return dimensions.rect?.height ?? null;\n    }\n  });\n\n  private readonly enableOverlayAnimations = signal(false);\n\n  private readonly _initialScrollableNavigation = signal<ScrollableNavigationItem[]>([]);\n\n  protected readonly scrollableNavigation = computed<ScrollableNavigationItem[]>(() => {\n    const allIntersections = this.scrollableContentIntersections();\n    const manualActiveNavigationIndex = this.manualActiveNavigationIndex();\n    const initialScrollableNavigation = this._initialScrollableNavigation();\n\n    if (!allIntersections.length) {\n      return initialScrollableNavigation;\n    }\n\n    const highestIntersection = allIntersections.reduce((prev, curr) => {\n      if (prev && prev.intersectionRatio > curr.intersectionRatio) {\n        return prev;\n      }\n\n      return curr;\n    }, allIntersections[0]);\n\n    if (!highestIntersection) {\n      return [];\n    }\n\n    return allIntersections.map((i, index) => ({\n      isActive:\n        manualActiveNavigationIndex !== null\n          ? manualActiveNavigationIndex === index\n          : i === highestIntersection && highestIntersection.intersectionRatio > 0,\n      element: i.target as HTMLElement,\n    }));\n  });\n\n  readonly hostAttributeBindings = signalHostAttributes({\n    'item-size': this.itemSize,\n    'actual-item-size': this._actualItemSize,\n    direction: this.direction,\n    'render-scrollbars': this.renderScrollbars,\n    'sticky-buttons': this.stickyButtons,\n  });\n\n  readonly hostClassBindings = signalHostClasses({\n    'et-scrollable--can-scroll': computed(() => this.canScroll() && !this.isAtStart() && !this.isAtEnd()),\n    'et-scrollable--is-at-start': this.isAtStart,\n    'et-scrollable--is-at-end': this.isAtEnd,\n    'et-scrollable--enable-overlay-animations': this.enableOverlayAnimations,\n  });\n\n  readonly hostStyleBindings = signalHostStyles({\n    '--actual-item-size': computed(() => (this._actualItemSize() !== null ? `${this._actualItemSize()}px` : undefined)),\n  });\n\n  constructor() {\n    effect(\n      () => {\n        const scrollable = this.scrollable()?.nativeElement;\n        const firstElement = this.firstElement()?.nativeElement;\n        const lastElement = this.lastElement()?.nativeElement;\n        const activeElementList = this.activeElementList()?.toArray();\n\n        if (!scrollable || !firstElement || !lastElement || !activeElementList) {\n          return;\n        }\n\n        const firstActive = activeElementList.find((a) => a.isActiveChildEnabled());\n\n        if (firstActive && !this.disableActiveElementScrolling()) {\n          const offsetTop = firstActive.elementRef.nativeElement.offsetTop - scrollable.offsetTop;\n          const offsetLeft = firstActive.elementRef.nativeElement.offsetLeft - scrollable.offsetLeft;\n          scrollable.scrollLeft = offsetLeft - this.scrollMargin();\n          scrollable.scrollTop = offsetTop - this.scrollMargin();\n        }\n\n        this.firstElementVisibility.set(\n          isElementVisible({\n            container: scrollable,\n            element: firstElement,\n          }),\n        );\n\n        this.lastElementVisibility.set(\n          isElementVisible({\n            container: scrollable,\n            element: lastElement,\n          }),\n        );\n\n        // We need to wait one frame before enabling animations to prevent a animation from playing during initial render.\n        nextFrame(() => this.enableOverlayAnimations.set(true));\n      },\n      { allowSignalWrites: true },\n    );\n\n    effect(\n      () => {\n        const elementList = this.scrollableChildren();\n        const scrollable = this.scrollable()?.nativeElement;\n        const renderNavigation = this.renderNavigation();\n\n        if (!elementList || !scrollable || !renderNavigation) {\n          return;\n        }\n\n        const firstVisibleElement = elementList.find((e) => isElementVisible({ container: scrollable, element: e }));\n\n        if (!firstVisibleElement) {\n          return;\n        }\n\n        const initialNavigationItems: ScrollableNavigationItem[] = elementList.map((e) => ({\n          isActive: e === firstVisibleElement,\n          element: e,\n        }));\n\n        this._initialScrollableNavigation.set(initialNavigationItems);\n      },\n      { allowSignalWrites: true },\n    );\n\n    effect(() => {\n      const isAtStart = this.isAtStart();\n      const isAtEnd = this.isAtEnd();\n      const canScroll = this.canScroll();\n\n      this.scrollStateChange.emit({\n        canScroll,\n        isAtEnd: !!isAtEnd,\n        isAtStart: !!isAtStart,\n      });\n    });\n\n    effect(() => {\n      const enableSnapping = this.snap();\n\n      if (enableSnapping) {\n        this._enableSnapping();\n      } else {\n        this._disableSnapping();\n      }\n    });\n\n    this.scrollableContentIntersections$\n      .pipe(\n        takeUntilDestroyed(),\n        debounceTime(10),\n        tap((entries) => {\n          this.intersectionChange.emit(\n            entries.map((i, index) => ({\n              index,\n              element: i.target as HTMLElement,\n              intersectionRatio: i.intersectionRatio,\n              isIntersecting: i.isIntersecting,\n            })),\n          );\n        }),\n      )\n      .subscribe();\n  }\n\n  scrollOneContainerSize(direction: 'start' | 'end') {\n    const scrollElement = this.scrollable()?.nativeElement;\n\n    if (!scrollElement) {\n      return;\n    }\n\n    const parent = this._elementRef.nativeElement;\n\n    const isSnappingEnabled = this.snap();\n\n    if (isSnappingEnabled) {\n      // If snapping is enabled we want to scroll to a position where no further snapping will happen after the scroll.\n      const allIntersections = this.scrollableContentIntersections();\n      const intersections = getFirstAndLastPartialIntersection(allIntersections);\n      const relevantIntersection = direction === 'start' ? intersections?.first : intersections?.last;\n\n      if (!relevantIntersection) return;\n\n      const nextIndex =\n        relevantIntersection.intersection.intersectionRatio !== 1\n          ? relevantIntersection.index\n          : direction === 'start'\n            ? relevantIntersection.index - 1\n            : relevantIntersection.index + 1;\n\n      const element =\n        (allIntersections[nextIndex]?.target as HTMLElement) ||\n        (relevantIntersection.intersection.target as HTMLElement);\n\n      this.scrollToElement({\n        element: element,\n        origin: direction === 'end' ? 'start' : 'end',\n      });\n    } else {\n      // Just scroll one size of the scrollable container.\n      const scrollableSize = this.direction() === 'horizontal' ? parent.clientWidth : parent.clientHeight;\n      const currentScroll = this.direction() === 'horizontal' ? scrollElement.scrollLeft : scrollElement.scrollTop;\n\n      scrollElement.scrollTo({\n        [this.direction() === 'horizontal' ? 'left' : 'top']:\n          currentScroll + (direction === 'start' ? -scrollableSize : scrollableSize),\n        behavior: 'smooth',\n      });\n    }\n  }\n\n  scrollOneItemSize(direction: 'start' | 'end') {\n    const allIntersections = this.scrollableContentIntersections();\n    const scrollElement = this.scrollable()?.nativeElement;\n\n    if (!allIntersections.length) {\n      if (isDevMode()) {\n        console.warn(\n          'No elements found to scroll to. Make sure to apply the isElement directive to the elements you want to scroll to.',\n        );\n      }\n      return;\n    }\n\n    const intersections = getFirstAndLastPartialIntersection(allIntersections);\n\n    if (!intersections || !scrollElement) return;\n\n    // Means the current element is bigger than the scrollable container.\n    // In this case we should scroll to the start of the current element. If we are already there we should scroll to the end of the previous element.\n    // This applies to the other direction as well.\n    const isFirstAndLastIntersectionEqual = intersections.first.intersection === intersections.last.intersection;\n    const scrollableRect = scrollElement.getBoundingClientRect();\n\n    if (isFirstAndLastIntersectionEqual) {\n      const intersection = intersections.first.intersection.target.getBoundingClientRect();\n      const isStartOfElementVisible =\n        this.direction() === 'horizontal'\n          ? Math.round(intersection.left) >= Math.round(scrollableRect.left)\n          : Math.round(intersection.top) >= Math.round(scrollableRect.top);\n\n      const isEndOfElementVisible =\n        this.direction() === 'horizontal'\n          ? Math.round(intersection.right) <= Math.round(scrollableRect.right)\n          : Math.round(intersection.bottom) <= Math.round(scrollableRect.bottom);\n\n      if (!isStartOfElementVisible || !isEndOfElementVisible) {\n        if (direction === 'start') {\n          if (isStartOfElementVisible) {\n            // to the end of the previous element\n            const previousIndex = intersections.first.index - 1;\n            const elementToScrollTo = allIntersections[previousIndex]?.target as HTMLElement;\n\n            if (!elementToScrollTo) return;\n\n            this.scrollToElement({\n              element: elementToScrollTo,\n              origin: 'end',\n            });\n          } else {\n            // to the start of the current element\n            this.scrollToElement({\n              element: intersections.first.intersection.target as HTMLElement,\n              origin: 'start',\n            });\n          }\n        } else {\n          if (isEndOfElementVisible) {\n            // to the start of the next element\n            const nextIndex = intersections.last.index + 1;\n            const elementToScrollTo = allIntersections[nextIndex]?.target as HTMLElement;\n\n            if (!elementToScrollTo) return;\n\n            this.scrollToElement({\n              element: elementToScrollTo,\n              origin: 'start',\n            });\n          } else {\n            // to the end of the current element\n            this.scrollToElement({\n              element: intersections.last.intersection.target as HTMLElement,\n              origin: 'end',\n            });\n          }\n        }\n\n        return;\n      }\n    }\n\n    const data = direction === 'start' ? intersections.first : intersections.last;\n    let elementToScrollTo = data.intersection.target as HTMLElement;\n\n    if (Math.round(data.intersection.intersectionRatio) === 1) {\n      if (direction === 'start' && data.index === 0) {\n        return;\n      }\n\n      if (direction === 'end' && data.index === allIntersections.length - 1) {\n        return;\n      }\n\n      const nextIndex = direction === 'start' ? data.index - 1 : data.index + 1;\n\n      elementToScrollTo = allIntersections[nextIndex]?.target as HTMLElement;\n    }\n\n    if (!elementToScrollTo) return;\n\n    this.scrollToElement({\n      element: elementToScrollTo,\n      origin: direction,\n    });\n  }\n\n  scrollToElement(options: Omit<ScrollToElementOptions, 'container'>) {\n    const scrollElement = this.scrollable()?.nativeElement;\n\n    scrollToElement({\n      container: scrollElement,\n      direction: this.direction() === 'horizontal' ? 'inline' : 'block',\n      ...(this.direction() === 'horizontal'\n        ? { scrollInlineMargin: this.scrollMargin() }\n        : { scrollBlockMargin: this.scrollMargin() }),\n      ...options,\n    });\n  }\n\n  scrollToElementByIndex(options: Omit<ScrollToElementOptions, 'container'> & { index: number }) {\n    const elements = this.scrollableChildren();\n\n    if (!elements.length) {\n      if (isDevMode()) {\n        console.warn(\n          'No elements found to scroll to. Make sure to apply the isElement directive to the elements you want to scroll to.',\n        );\n      }\n      return;\n    }\n\n    const scrollElement = this.scrollable()?.nativeElement;\n    const element = elements[options.index];\n\n    scrollToElement({\n      container: scrollElement,\n      element,\n      ...(this.direction() === 'horizontal'\n        ? { scrollInlineMargin: this.scrollMargin() }\n        : { scrollBlockMargin: this.scrollMargin() }),\n      ...options,\n    });\n  }\n\n  protected scrollToElementViaNavigation(elementIndex: number, element: HTMLElement) {\n    this.manualActiveNavigationIndex.set(elementIndex);\n\n    this.scrollToElement({\n      element,\n    });\n\n    const scrollElement = this.scrollable()?.nativeElement;\n\n    if (!scrollElement) return;\n\n    fromEvent(scrollElement, 'scroll')\n      .pipe(\n        debounceTime(50),\n        take(1),\n        tap(() => this.manualActiveNavigationIndex.set(null)),\n      )\n      .subscribe();\n  }\n\n  protected setIsCursorDragging(isDragging: boolean) {\n    this._isCursorDragging$.next(isDragging);\n  }\n\n  protected scrollToStartDirection() {\n    if (this.scrollMode() === 'container') {\n      this.scrollOneContainerSize('start');\n    } else {\n      this.scrollOneItemSize('start');\n    }\n  }\n\n  protected scrollToEndDirection() {\n    if (this.scrollMode() === 'container') {\n      this.scrollOneContainerSize('end');\n    } else {\n      this.scrollOneItemSize('end');\n    }\n  }\n\n  private _enableSnapping() {\n    combineLatest([this.scrollableContentIntersections$, this._isCursorDragging$])\n      .pipe(\n        filter(([, isDragging]) => !isDragging),\n        map(([intersections]) => intersections),\n        debounceTime(150),\n        tap((allIntersections) => {\n          const scrollElement = this.scrollable()?.nativeElement;\n\n          if (!scrollElement) return;\n\n          const intersections = getFirstAndLastPartialIntersection(allIntersections);\n\n          if (!intersections) return;\n\n          const isFirstAndLastIntersectionEqual = intersections.first.intersection === intersections.last.intersection;\n          const scrollableRect = scrollElement.getBoundingClientRect();\n\n          if (isFirstAndLastIntersectionEqual) {\n            const intersection = intersections.first.intersection.target.getBoundingClientRect();\n            const isStartOfElementVisible =\n              this.direction() === 'horizontal'\n                ? intersection.left >= scrollableRect.left\n                : intersection.top >= scrollableRect.top;\n\n            const isEndOfElementVisible =\n              this.direction() === 'horizontal'\n                ? intersection.right <= scrollableRect.right\n                : intersection.bottom <= scrollableRect.bottom;\n\n            // Don't snap if neither the start nor the end of the current element is visible.\n            // Otherwise this would result in parts of the element being inaccessible.\n            if (!isStartOfElementVisible && !isEndOfElementVisible) return;\n\n            // If the start of the element is visible we should snap to the start.\n            if (isStartOfElementVisible) {\n              this.scrollToElement({\n                element: intersections.first.intersection.target as HTMLElement,\n                origin: 'start',\n              });\n              return;\n            }\n\n            // If the end of the element is visible we should snap to the end.\n            if (isEndOfElementVisible) {\n              this.scrollToElement({\n                element: intersections.last.intersection.target as HTMLElement,\n                origin: 'end',\n              });\n              return;\n            }\n          } else if (\n            (this.direction() === 'horizontal' &&\n              intersections.biggest.intersection.boundingClientRect.width > scrollableRect.width) ||\n            (this.direction() === 'vertical' &&\n              intersections.biggest.intersection.boundingClientRect.height > scrollableRect.height)\n          ) {\n            // If the current element is bigger than the scrollable container we should snap to the start of the current element if the scroll direction is forward\n            // and to the end of the current element if the scroll direction is backwards.\n            const origin = intersections.biggest.index === intersections.first.index ? 'end' : 'start';\n\n            this.scrollToElement({\n              element: intersections.biggest.intersection.target as HTMLElement,\n              origin,\n            });\n          } else {\n            // No special case. Just snap to the biggest intersection.\n            this.scrollToElement({\n              element: intersections.biggest.intersection.target as HTMLElement,\n            });\n          }\n        }),\n        takeUntil(this._disableSnapping$),\n      )\n      .subscribe();\n  }\n\n  private _disableSnapping() {\n    this._disableSnapping$.next();\n  }\n}\n","<div class=\"et-scrollable-wrapper\">\n  <div\n    #scrollable\n    [attr.role]=\"scrollableRole() ?? undefined\"\n    [etCursorDragScroll]=\"cursorDragScroll() && (!isAtStart() || !isAtEnd())\"\n    [allowedDirection]=\"direction()\"\n    (cursorDragStart)=\"setIsCursorDragging(true)\"\n    (cursorDragEnd)=\"setIsCursorDragging(false)\"\n    class=\"et-scrollable-container-outer\"\n  >\n    <div #scrollableContainer [ngClass]=\"scrollableClass()\" class=\"et-scrollable-container\">\n      <div #firstElement class=\"et-scroll-observer-first-element\" etScrollableIgnoreChild></div>\n      <ng-content />\n      <div #lastElement class=\"et-scroll-observer-last-element\" etScrollableIgnoreChild></div>\n    </div>\n  </div>\n\n  @if (renderMasks()) {\n    <div class=\"et-scrollable-masks\">\n      <div class=\"et-scrollable-mask et-scrollable-mask--start\"></div>\n      <div class=\"et-scrollable-mask et-scrollable-mask--end\"></div>\n    </div>\n  }\n\n  @if (renderButtons()) {\n    <div class=\"et-scrollable-buttons\">\n      <button\n        (click)=\"scrollToStartDirection()\"\n        class=\"et-scrollable-button et-scrollable-button--start\"\n        aria-hidden=\"true\"\n        type=\"button\"\n        tabindex=\"-1\"\n      >\n        <et-chevron-icon />\n      </button>\n      <button\n        (click)=\"scrollToEndDirection()\"\n        class=\"et-scrollable-button et-scrollable-button--end\"\n        aria-hidden=\"true\"\n        type=\"button\"\n        tabindex=\"-1\"\n      >\n        <et-chevron-icon />\n      </button>\n    </div>\n  }\n</div>\n\n@if (renderNavigation() && scrollableNavigation().length > 1) {\n  <div class=\"et-scrollable-navigation\" aria-hidden=\"true\">\n    @for (item of scrollableNavigation(); track i; let i = $index) {\n      <button\n        [class.et-scrollable-navigation-item--active]=\"item.isActive\"\n        (click)=\"scrollToElementViaNavigation(i, item.element)\"\n        class=\"et-scrollable-navigation-item\"\n        tabindex=\"-1\"\n        aria-hidden=\"true\"\n      ></button>\n    }\n  </div>\n}\n"]}
696
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"scrollable.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/cdk/src/lib/components/scrollable/components/scrollable/scrollable.component.ts","../../../../../../../../../libs/cdk/src/lib/components/scrollable/components/scrollable/scrollable.component.html"],"names":[],"mappings":"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","sourcesContent":["import { NgClass, NgTemplateOutlet } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  ContentChildren,\n  ElementRef,\n  EventEmitter,\n  Input,\n  Output,\n  ViewChild,\n  ViewEncapsulation,\n  booleanAttribute,\n  computed,\n  effect,\n  inject,\n  isDevMode,\n  numberAttribute,\n  signal,\n  viewChild,\n} from '@angular/core';\nimport { takeUntilDestroyed, toObservable } from '@angular/core/rxjs-interop';\nimport {\n  CurrentElementVisibility,\n  CursorDragScrollDirective,\n  LetDirective,\n  NgClassType,\n  ObserveScrollStateDirective,\n  ScrollObserverScrollState,\n  ScrollToElementOptions,\n  TypedQueryList,\n  getIntersectionInfo,\n  isElementVisible,\n  nextFrame,\n  scrollToElement,\n  signalElementChildren,\n  signalElementDimensions,\n  signalElementIntersection,\n  signalElementScrollState,\n  signalHostAttributes,\n  signalHostClasses,\n  signalHostElementDimensions,\n  signalHostStyles,\n} from '@ethlete/core';\nimport {\n  BehaviorSubject,\n  Subject,\n  combineLatest,\n  debounceTime,\n  filter,\n  fromEvent,\n  map,\n  of,\n  switchMap,\n  takeUntil,\n  tap,\n} from 'rxjs';\nimport { ChevronIconComponent } from '../../../icons/chevron-icon';\nimport { ScrollableIgnoreChildDirective, isScrollableChildIgnored } from '../../directives/scrollable-ignore-child';\nimport {\n  SCROLLABLE_IS_ACTIVE_CHILD_TOKEN,\n  ScrollableIsActiveChildDirective,\n} from '../../directives/scrollable-is-active-child';\nimport { ScrollableIntersectionChange, ScrollableScrollMode } from '../../types';\n\n// Thresholds for the intersection observer.\nconst ELEMENT_INTERSECTION_THRESHOLD = [\n  // We use 51 steps to get a 2% step size.\n  ...Array.from({ length: 51 }, (_, i) => i / 50),\n\n  // Additional steps needed since display scaling can cause the intersection ratio to be slightly off.\n  0.01,\n  0.005,\n  0.001,\n  0.99,\n  0.995,\n  0.999,\n];\n\ninterface ScrollableNavigationItem {\n  isActive: boolean;\n  activeOffset: number;\n  element: HTMLElement;\n}\n\nexport type ScrollableButtonPosition = 'inside' | 'footer';\nexport type ScrollableScrollOrigin = 'auto' | 'center' | 'start' | 'end';\n\n@Component({\n  selector: 'et-scrollable',\n  templateUrl: './scrollable.component.html',\n  styleUrls: ['./scrollable.component.scss'],\n  standalone: true,\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [\n    CursorDragScrollDirective,\n    ObserveScrollStateDirective,\n    NgClass,\n    LetDirective,\n    ChevronIconComponent,\n    ScrollableIsActiveChildDirective,\n    ScrollableIgnoreChildDirective,\n    NgTemplateOutlet,\n  ],\n  host: {\n    class: 'et-scrollable',\n  },\n})\nexport class ScrollableComponent {\n  private readonly _elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n  private readonly _isCursorDragging$ = new BehaviorSubject<boolean>(false);\n\n  @Input({ alias: 'itemSize' })\n  set _itemSize(v: 'auto' | 'same' | 'full') {\n    this.itemSize.set(v);\n  }\n  readonly itemSize = signal<'auto' | 'same' | 'full'>('auto');\n\n  @Input({ alias: 'direction' })\n  set _direction(v: 'horizontal' | 'vertical') {\n    this.direction.set(v);\n  }\n  readonly direction = signal<'horizontal' | 'vertical'>('horizontal');\n\n  @Input({ alias: 'scrollableRole' })\n  set _scrollableRole(v: string | null) {\n    this.scrollableRole.set(v);\n  }\n  readonly scrollableRole = signal<string | null>(null);\n\n  @Input({ alias: 'scrollableClass' })\n  set _scrollableClass(v: NgClassType | null) {\n    this.scrollableClass.set(v);\n  }\n  readonly scrollableClass = signal<NgClassType | null>(null);\n\n  @Input({ transform: booleanAttribute, alias: 'renderNavigation' })\n  set _renderNavigation(v: boolean) {\n    this.renderNavigation.set(v);\n  }\n  readonly renderNavigation = signal(false);\n\n  @Input({ transform: booleanAttribute, alias: 'renderMasks' })\n  set _renderMasks(v: boolean) {\n    this.renderMasks.set(v);\n  }\n  readonly renderMasks = signal(true);\n\n  @Input({ transform: booleanAttribute, alias: 'renderButtons' })\n  set _renderButtons(v: boolean) {\n    this.renderButtons.set(v);\n  }\n  readonly renderButtons = signal(true);\n\n  renderButtonsInside = computed(() => this.buttonPosition() === 'inside' && this.renderButtons());\n  renderButtonsInFooter = computed(() => this.buttonPosition() === 'footer' && this.renderButtons());\n\n  @Input({ alias: 'buttonPosition' })\n  set _buttonPosition(v: ScrollableButtonPosition) {\n    this.buttonPosition.set(v);\n  }\n  readonly buttonPosition = signal<ScrollableButtonPosition>('inside');\n\n  @Input({ transform: booleanAttribute, alias: 'renderScrollbars' })\n  set _renderScrollbars(v: boolean) {\n    this.renderScrollbars.set(v);\n  }\n  readonly renderScrollbars = signal(false);\n\n  @Input({ transform: booleanAttribute, alias: 'stickyButtons' })\n  set _stickyButtons(v: boolean) {\n    this.stickyButtons.set(v);\n  }\n  readonly stickyButtons = signal(false);\n\n  @Input({ transform: booleanAttribute, alias: 'cursorDragScroll' })\n  set _cursorDragScroll(v: boolean) {\n    this.cursorDragScroll.set(v);\n  }\n  readonly cursorDragScroll = signal(true);\n\n  @Input({ transform: booleanAttribute, alias: 'disableActiveElementScrolling' })\n  set _disableActiveElementScrolling(v: boolean) {\n    this.disableActiveElementScrolling.set(v);\n  }\n  readonly disableActiveElementScrolling = signal(false);\n\n  @Input({ alias: 'scrollMode' })\n  set _scrollMode(v: ScrollableScrollMode) {\n    this.scrollMode.set(v);\n  }\n  readonly scrollMode = signal<ScrollableScrollMode>('container');\n\n  @Input({ transform: booleanAttribute, alias: 'snap' })\n  set _snap(v: boolean) {\n    this.snap.set(v);\n  }\n  readonly snap = signal(false);\n\n  @Input({ transform: numberAttribute, alias: 'scrollMargin' })\n  set _scrollMargin(v: number) {\n    this.scrollMargin.set(v);\n  }\n  readonly scrollMargin = signal(0);\n\n  @Input({ alias: 'scrollOrigin' })\n  set _scrollOrigin(v: ScrollableScrollOrigin) {\n    this.scrollOrigin.set(v);\n  }\n  readonly scrollOrigin = signal<ScrollableScrollOrigin>('auto');\n\n  @Output()\n  readonly scrollStateChange = new EventEmitter<ScrollObserverScrollState>();\n\n  @Output()\n  readonly intersectionChange = new EventEmitter<ScrollableIntersectionChange[]>();\n\n  @ViewChild('scrollable', { static: true })\n  private set _scrollable(e: ElementRef<HTMLElement>) {\n    this.scrollable.set(e);\n  }\n  readonly scrollable = signal<ElementRef<HTMLElement> | null>(null);\n\n  @ViewChild('scrollableContainer', { static: true })\n  private set _scrollableContainer(e: ElementRef<HTMLElement>) {\n    this.scrollableContainer.set(e);\n  }\n  readonly scrollableContainer = signal<ElementRef<HTMLElement> | null>(null);\n\n  @ViewChild('firstElement', { static: true })\n  private set _firstElement(e: ElementRef<HTMLElement>) {\n    this.firstElement.set(e);\n  }\n  readonly firstElement = signal<ElementRef<HTMLElement> | null>(null);\n\n  @ViewChild('lastElement', { static: true })\n  private set _lastElement(e: ElementRef<HTMLElement>) {\n    this.lastElement.set(e);\n  }\n  readonly lastElement = signal<ElementRef<HTMLElement> | null>(null);\n\n  @ContentChildren(SCROLLABLE_IS_ACTIVE_CHILD_TOKEN, { descendants: true })\n  private set _activeElementList(e: TypedQueryList<ScrollableIsActiveChildDirective>) {\n    this.activeElementList.set(e);\n  }\n  readonly activeElementList = signal<TypedQueryList<ScrollableIsActiveChildDirective> | null>(null);\n\n  navigationDotsContainer = viewChild<ElementRef<HTMLElement>>('navigationDotsContainer');\n  firstNavigationDot = viewChild<ElementRef<HTMLButtonElement>>('navigationDot');\n  navigationDotDimensions = signalElementDimensions(this.firstNavigationDot);\n\n  private readonly containerScrollState = signalElementScrollState(this.scrollable);\n  private readonly firstElementIntersection = signalElementIntersection(this.firstElement, { root: this.scrollable });\n  private readonly firstElementVisibility = signal<CurrentElementVisibility | null>(null);\n  private readonly lastElementIntersection = signalElementIntersection(this.lastElement, { root: this.scrollable });\n  private readonly lastElementVisibility = signal<CurrentElementVisibility | null>(null);\n\n  private readonly allScrollableChildren = signalElementChildren(this.scrollableContainer);\n  private readonly scrollableDimensions = signalHostElementDimensions();\n  private readonly scrollableChildren = computed(() =>\n    this.allScrollableChildren().filter((c) => !isScrollableChildIgnored(c)),\n  );\n\n  private readonly _disableSnapping$ = new Subject<void>();\n\n  private readonly scrollableContentIntersections = signalElementIntersection(this.scrollableChildren, {\n    root: this.scrollable,\n    threshold: ELEMENT_INTERSECTION_THRESHOLD,\n  });\n\n  private readonly scrollableContentIntersections$ = toObservable(this.scrollableContentIntersections);\n\n  private readonly manualActiveNavigationIndex = signal<number | null>(null);\n\n  private readonly canScroll = computed(() => {\n    const dir = this.direction();\n\n    if (dir === 'horizontal') {\n      return this.containerScrollState().canScrollHorizontally;\n    }\n\n    return this.containerScrollState().canScrollVertically;\n  });\n\n  readonly isAtStart = computed(() => {\n    if (!this.canScroll()) {\n      return true;\n    }\n\n    const intersection = this.firstElementIntersection()[0];\n\n    if (!intersection) {\n      return this.firstElementVisibility()?.inline ?? true;\n    }\n\n    return intersection.isIntersecting;\n  });\n  readonly isAtEnd = computed(() => {\n    if (!this.canScroll()) {\n      return true;\n    }\n\n    const intersection = this.lastElementIntersection()[0];\n\n    if (!intersection) {\n      return this.lastElementVisibility()?.inline ?? true;\n    }\n\n    return intersection.isIntersecting;\n  });\n\n  private readonly _actualItemSize = computed(() => {\n    if (this.itemSize() !== 'full') return null;\n\n    const dimensions = this.scrollableDimensions();\n\n    if (this.direction() === 'horizontal') {\n      return dimensions.rect?.width ?? null;\n    } else {\n      return dimensions.rect?.height ?? null;\n    }\n  });\n\n  private readonly enableOverlayAnimations = signal(false);\n\n  private readonly _initialScrollableNavigation = signal<ScrollableNavigationItem[]>([]);\n\n  protected readonly scrollableNavigation = computed<ScrollableNavigationItem[]>(() => {\n    const allIntersections = this.scrollableContentIntersections();\n    const manualActiveNavigationIndex = this.manualActiveNavigationIndex();\n    const initialScrollableNavigation = this._initialScrollableNavigation();\n\n    if (!allIntersections.length) {\n      return initialScrollableNavigation;\n    }\n\n    const highestIntersection = allIntersections.reduce((prev, curr) => {\n      if (prev && prev.intersectionRatio > curr.intersectionRatio) {\n        return prev;\n      }\n\n      return curr;\n    }, allIntersections[0]);\n\n    if (!highestIntersection) {\n      return [];\n    }\n\n    const activeIndex =\n      manualActiveNavigationIndex !== null\n        ? manualActiveNavigationIndex\n        : allIntersections.findIndex((i) => i === highestIntersection);\n\n    return allIntersections.map((i, index) => ({\n      isActive:\n        manualActiveNavigationIndex !== null\n          ? manualActiveNavigationIndex === index\n          : i === highestIntersection && highestIntersection.intersectionRatio > 0,\n      activeOffset: index === activeIndex ? 0 : Math.abs(index - activeIndex),\n      element: i.target as HTMLElement,\n    }));\n  });\n\n  private readonly activeIndex = computed(() => {\n    const scrollableNavigation = this.scrollableNavigation();\n    const activeIndex = scrollableNavigation.findIndex((element) => element.isActive);\n\n    return activeIndex;\n  });\n\n  readonly hostAttributeBindings = signalHostAttributes({\n    'item-size': this.itemSize,\n    'actual-item-size': this._actualItemSize,\n    direction: this.direction,\n    'render-scrollbars': this.renderScrollbars,\n    'sticky-buttons': computed(() => this.stickyButtons() && this.renderButtonsInside()),\n  });\n\n  readonly hostClassBindings = signalHostClasses({\n    'et-scrollable--can-scroll': computed(() => this.canScroll() && !this.isAtStart() && !this.isAtEnd()),\n    'et-scrollable--is-at-start': this.isAtStart,\n    'et-scrollable--is-at-end': this.isAtEnd,\n    'et-scrollable--enable-overlay-animations': this.enableOverlayAnimations,\n  });\n\n  readonly hostStyleBindings = signalHostStyles({\n    '--actual-item-size': computed(() => (this._actualItemSize() !== null ? `${this._actualItemSize()}px` : undefined)),\n  });\n\n  constructor() {\n    effect(() => {\n      // Responsible for centering the active dot in navigation bar by using 'translate'\n      const scrollableDotsContainer = this.navigationDotsContainer();\n      const activeIndex = this.activeIndex();\n      const childCount = this.scrollableContentIntersections().length;\n\n      const offset = this.getNavigationDotsContainerTranslate(childCount, activeIndex);\n\n      if (!scrollableDotsContainer) return;\n\n      scrollableDotsContainer.nativeElement.style.transform = `translateX(${offset})`;\n    });\n\n    effect(\n      () => {\n        const scrollable = this.scrollable()?.nativeElement;\n        const firstElement = this.firstElement()?.nativeElement;\n        const lastElement = this.lastElement()?.nativeElement;\n        const activeElementList = this.activeElementList()?.toArray();\n\n        if (!scrollable || !firstElement || !lastElement || !activeElementList) {\n          return;\n        }\n\n        const firstActive = activeElementList.find((a) => a.isActiveChildEnabled());\n\n        if (firstActive && !this.disableActiveElementScrolling()) {\n          const offsetTop = firstActive.elementRef.nativeElement.offsetTop - scrollable.offsetTop;\n          const offsetLeft = firstActive.elementRef.nativeElement.offsetLeft - scrollable.offsetLeft;\n          scrollable.scrollLeft = offsetLeft - this.scrollMargin();\n          scrollable.scrollTop = offsetTop - this.scrollMargin();\n        }\n\n        this.firstElementVisibility.set(\n          isElementVisible({\n            container: scrollable,\n            element: firstElement,\n          }),\n        );\n\n        this.lastElementVisibility.set(\n          isElementVisible({\n            container: scrollable,\n            element: lastElement,\n          }),\n        );\n\n        // We need to wait one frame before enabling animations to prevent a animation from playing during initial render.\n        nextFrame(() => this.enableOverlayAnimations.set(true));\n      },\n      { allowSignalWrites: true },\n    );\n\n    effect(\n      () => {\n        const elementList = this.scrollableChildren();\n        const scrollable = this.scrollable()?.nativeElement;\n        const renderNavigation = this.renderNavigation();\n        const renderButtonsInFooter = this.renderButtonsInFooter();\n\n        if (!elementList || !scrollable || (!renderNavigation && !renderButtonsInFooter)) {\n          return;\n        }\n\n        const firstVisibleElement = elementList.find((e) => isElementVisible({ container: scrollable, element: e }));\n\n        if (!firstVisibleElement) {\n          return;\n        }\n\n        const firstVisibleElementIndex = elementList.indexOf(firstVisibleElement);\n\n        const initialNavigationItems: ScrollableNavigationItem[] = elementList.map((e, i) => ({\n          isActive: e === firstVisibleElement,\n          element: e,\n          activeOffset: Math.abs(i - firstVisibleElementIndex),\n        }));\n\n        this._initialScrollableNavigation.set(initialNavigationItems ?? []);\n      },\n      { allowSignalWrites: true },\n    );\n\n    effect(() => {\n      const isAtStart = this.isAtStart();\n      const isAtEnd = this.isAtEnd();\n      const canScroll = this.canScroll();\n\n      this.scrollStateChange.emit({\n        canScroll,\n        isAtEnd: !!isAtEnd,\n        isAtStart: !!isAtStart,\n      });\n    });\n\n    effect(() => {\n      const enableSnapping = this.snap();\n\n      if (enableSnapping) {\n        this._enableSnapping();\n      } else {\n        this._disableSnapping();\n      }\n    });\n\n    this.scrollableContentIntersections$\n      .pipe(\n        takeUntilDestroyed(),\n        debounceTime(10),\n        tap((entries) => {\n          this.intersectionChange.emit(\n            entries.map((i, index) => ({\n              index,\n              element: i.target as HTMLElement,\n              intersectionRatio: i.intersectionRatio,\n              isIntersecting: i.isIntersecting,\n            })),\n          );\n        }),\n      )\n      .subscribe();\n\n    toObservable(this.manualActiveNavigationIndex)\n      .pipe(\n        filter((i) => i !== null),\n        takeUntilDestroyed(),\n        switchMap(() => {\n          const scrollable = this.scrollable()?.nativeElement;\n\n          if (!scrollable) {\n            return of(null);\n          }\n\n          return fromEvent(scrollable, 'scroll');\n        }),\n        debounceTime(50),\n        tap(() => this.manualActiveNavigationIndex.set(null)),\n      )\n      .subscribe();\n  }\n\n  getNavigationDotsContainerTranslate(navigationDotCount: number, activeIndex: number) {\n    if (navigationDotCount <= 5) {\n      return '0px';\n    } else {\n      const dotContainerWidth = this.navigationDotDimensions().rect?.width ?? 20;\n      let offset = -(activeIndex - 2);\n      if (activeIndex < 3) {\n        offset = 0;\n      } else if (activeIndex >= navigationDotCount - 3) {\n        offset = 5 - navigationDotCount;\n      }\n      return `${offset * dotContainerWidth}px`;\n    }\n  }\n\n  scrollOneContainerSize(direction: 'start' | 'end') {\n    const scrollElement = this.scrollable()?.nativeElement;\n\n    if (!scrollElement) {\n      return;\n    }\n\n    const parent = this._elementRef.nativeElement;\n\n    const isSnappingEnabled = this.snap();\n\n    if (isSnappingEnabled) {\n      // If snapping is enabled we want to scroll to a position where no further snapping will happen after the scroll.\n      const allIntersections = this.scrollableContentIntersections();\n      const intersections = getIntersectionInfo(allIntersections);\n      const relevantIntersection = direction === 'start' ? intersections?.partial.first : intersections?.partial.last;\n\n      if (!relevantIntersection) return;\n\n      const nextIndex =\n        relevantIntersection.intersection.intersectionRatio !== 1\n          ? relevantIntersection.index\n          : direction === 'start'\n            ? relevantIntersection.index - 1\n            : relevantIntersection.index + 1;\n\n      const element =\n        (allIntersections[nextIndex]?.target as HTMLElement) ||\n        (relevantIntersection.intersection.target as HTMLElement);\n\n      this.scrollToElement({\n        element: element,\n        origin: direction === 'end' ? 'start' : 'end',\n      });\n    } else {\n      // Just scroll one size of the scrollable container.\n      const scrollableSize = this.direction() === 'horizontal' ? parent.clientWidth : parent.clientHeight;\n      const currentScroll = this.direction() === 'horizontal' ? scrollElement.scrollLeft : scrollElement.scrollTop;\n\n      scrollElement.scrollTo({\n        [this.direction() === 'horizontal' ? 'left' : 'top']:\n          currentScroll + (direction === 'start' ? -scrollableSize : scrollableSize),\n        behavior: 'smooth',\n      });\n    }\n  }\n\n  scrollOneItemSize(direction: 'start' | 'end') {\n    const allIntersections = this.scrollableContentIntersections();\n    const scrollElement = this.scrollable()?.nativeElement;\n\n    if (!allIntersections.length) {\n      if (isDevMode()) {\n        console.warn(\n          'No elements found to scroll to. Make sure to apply the isElement directive to the elements you want to scroll to.',\n        );\n      }\n      return;\n    }\n\n    const intersections = getIntersectionInfo(allIntersections);\n\n    if (!intersections || !scrollElement) return;\n\n    // Means the current element is bigger than the scrollable container.\n    // In this case we should scroll to the start of the current element. If we are already there we should scroll to the end of the previous element.\n    // This applies to the other direction as well.\n    const isFirstAndLastIntersectionEqual =\n      intersections.partial.first.intersection === intersections.partial.last.intersection;\n    const scrollableRect = scrollElement.getBoundingClientRect();\n\n    if (isFirstAndLastIntersectionEqual) {\n      const intersection = intersections.partial.first.intersection.target.getBoundingClientRect();\n      const isStartOfElementVisible =\n        this.direction() === 'horizontal'\n          ? Math.round(intersection.left) >= Math.round(scrollableRect.left)\n          : Math.round(intersection.top) >= Math.round(scrollableRect.top);\n\n      const isEndOfElementVisible =\n        this.direction() === 'horizontal'\n          ? Math.round(intersection.right) <= Math.round(scrollableRect.right)\n          : Math.round(intersection.bottom) <= Math.round(scrollableRect.bottom);\n\n      if (!isStartOfElementVisible || !isEndOfElementVisible) {\n        if (direction === 'start') {\n          if (isStartOfElementVisible) {\n            // to the end of the previous element\n            const previousIndex = intersections.partial.first.index - 1;\n            const elementToScrollTo = allIntersections[previousIndex]?.target as HTMLElement;\n\n            if (!elementToScrollTo) return;\n            this.scrollToElement({\n              element: elementToScrollTo,\n              origin: 'end',\n            });\n            this.manualActiveNavigationIndex.set(previousIndex);\n          } else {\n            // to the start of the current element\n            this.scrollToElement({\n              element: intersections.partial.first.intersection.target as HTMLElement,\n              origin: 'start',\n            });\n            this.manualActiveNavigationIndex.set(intersections.partial.first.index);\n          }\n        } else {\n          if (isEndOfElementVisible) {\n            // to the start of the next element\n            const nextIndex = intersections.partial.last.index + 1;\n            const elementToScrollTo = allIntersections[nextIndex]?.target as HTMLElement;\n\n            if (!elementToScrollTo) return;\n            this.scrollToElement({\n              element: elementToScrollTo,\n              origin: 'start',\n            });\n            this.manualActiveNavigationIndex.set(nextIndex);\n          } else {\n            // to the end of the current element\n            this.scrollToElement({\n              element: intersections.partial.last.intersection.target as HTMLElement,\n              origin: 'end',\n            });\n\n            this.manualActiveNavigationIndex.set(intersections.partial.last.index);\n          }\n        }\n\n        return;\n      }\n    } else if (this.scrollOrigin() === 'center') {\n      // If the scroll origin is forced to be center we should always snap to the center of the next partial intersection in the scroll direction.\n      const nextPartialIntersection = direction === 'start' ? intersections.partial.first : intersections.partial.last;\n      const nextIndex = nextPartialIntersection.index;\n\n      this.scrollToElement({\n        element: nextPartialIntersection.intersection.target as HTMLElement,\n        origin: 'center',\n      });\n      this.manualActiveNavigationIndex.set(nextIndex);\n\n      return;\n    }\n\n    const data = direction === 'start' ? intersections.partial.first : intersections.partial.last;\n    let elementToScrollTo = data.intersection.target as HTMLElement;\n    let nextIndex = data.index;\n\n    if (Math.round(data.intersection.intersectionRatio) === 1) {\n      if (direction === 'start' && data.index === 0) {\n        return;\n      }\n\n      if (direction === 'end' && data.index === allIntersections.length - 1) {\n        return;\n      }\n\n      nextIndex = direction === 'start' ? data.index - 1 : data.index + 1;\n\n      elementToScrollTo = allIntersections[nextIndex]?.target as HTMLElement;\n\n      if (!elementToScrollTo) return;\n    }\n\n    this.scrollToElement({\n      element: elementToScrollTo,\n      origin: direction,\n    });\n\n    this.manualActiveNavigationIndex.set(nextIndex);\n  }\n\n  scrollToElement(options: Omit<ScrollToElementOptions, 'container'> & { ignoreForcedOrigin?: boolean }) {\n    const scrollElement = this.scrollable()?.nativeElement;\n    const { origin } = options;\n    const forcedOrigin = this.scrollOrigin();\n\n    scrollToElement({\n      container: scrollElement,\n      direction: this.direction() === 'horizontal' ? 'inline' : 'block',\n      ...(this.direction() === 'horizontal'\n        ? { scrollInlineMargin: this.scrollMargin() }\n        : { scrollBlockMargin: this.scrollMargin() }),\n      ...options,\n      ...(forcedOrigin === 'auto' || options.ignoreForcedOrigin ? { origin } : { origin: forcedOrigin }),\n    });\n  }\n\n  scrollToElementByIndex(\n    options: Omit<ScrollToElementOptions, 'container'> & { index: number; ignoreForcedOrigin?: boolean },\n  ) {\n    const elements = this.scrollableChildren();\n    const { origin } = options;\n    const forcedOrigin = this.scrollOrigin();\n\n    if (!elements.length) {\n      if (isDevMode()) {\n        console.warn('No elements found to scroll to.');\n      }\n      return;\n    }\n\n    const scrollElement = this.scrollable()?.nativeElement;\n    const element = elements[options.index];\n\n    scrollToElement({\n      container: scrollElement,\n      element,\n      ...(this.direction() === 'horizontal'\n        ? { scrollInlineMargin: this.scrollMargin() }\n        : { scrollBlockMargin: this.scrollMargin() }),\n      ...options,\n      ...(forcedOrigin === 'auto' || options.ignoreForcedOrigin ? { origin } : { origin: forcedOrigin }),\n    });\n  }\n\n  protected scrollToElementViaNavigation(elementIndex: number) {\n    const element = this.scrollableChildren()[elementIndex];\n    this.manualActiveNavigationIndex.set(elementIndex);\n\n    this.scrollToElement({\n      element,\n    });\n  }\n\n  protected setIsCursorDragging(isDragging: boolean) {\n    this._isCursorDragging$.next(isDragging);\n  }\n\n  protected scrollToStartDirection() {\n    if (this.scrollMode() === 'container') {\n      this.scrollOneContainerSize('start');\n    } else {\n      this.scrollOneItemSize('start');\n    }\n  }\n\n  protected scrollToEndDirection() {\n    if (this.scrollMode() === 'container') {\n      this.scrollOneContainerSize('end');\n    } else {\n      this.scrollOneItemSize('end');\n    }\n  }\n\n  private _enableSnapping() {\n    combineLatest([this.scrollableContentIntersections$, this._isCursorDragging$])\n      .pipe(\n        filter(([, isDragging]) => !isDragging),\n        map(([intersections]) => intersections),\n        debounceTime(150),\n        tap((allIntersections) => {\n          const scrollElement = this.scrollable()?.nativeElement;\n\n          if (!scrollElement) return;\n\n          const intersections = getIntersectionInfo(allIntersections);\n\n          if (!intersections) return;\n\n          const isFirstAndLastIntersectionEqual =\n            intersections.partial.first.intersection === intersections.partial.last.intersection;\n          const scrollableRect = scrollElement.getBoundingClientRect();\n\n          if (this.scrollOrigin() === 'center' && intersections.full.hasMultiple) {\n            // If there is more than one fully visible element we should not snap at all.\n            return;\n          } else if (this.scrollOrigin() === 'center' && intersections.full.first.intersection) {\n            // If there is already a fully visible element we should snap it to the center.\n            this.scrollToElement({\n              element: intersections.full.first.intersection.target as HTMLElement,\n              origin: 'center',\n            });\n            return;\n          } else if (isFirstAndLastIntersectionEqual) {\n            const intersection = intersections.partial.first.intersection.target.getBoundingClientRect();\n            const isStartOfElementVisible =\n              this.direction() === 'horizontal'\n                ? intersection.left >= scrollableRect.left\n                : intersection.top >= scrollableRect.top;\n\n            const isEndOfElementVisible =\n              this.direction() === 'horizontal'\n                ? intersection.right <= scrollableRect.right\n                : intersection.bottom <= scrollableRect.bottom;\n\n            // Don't snap if neither the start nor the end of the current element is visible.\n            // Otherwise this would result in parts of the element being inaccessible.\n            if (!isStartOfElementVisible && !isEndOfElementVisible) return;\n\n            // If the start of the element is visible we should snap to the start.\n            if (isStartOfElementVisible) {\n              this.scrollToElement({\n                element: intersections.partial.first.intersection.target as HTMLElement,\n                origin: 'start',\n              });\n              return;\n            }\n\n            // If the end of the element is visible we should snap to the end.\n            if (isEndOfElementVisible) {\n              this.scrollToElement({\n                element: intersections.partial.last.intersection.target as HTMLElement,\n                origin: 'end',\n              });\n              return;\n            }\n          } else if (\n            (this.direction() === 'horizontal' &&\n              intersections.partial.biggest.intersection.boundingClientRect.width > scrollableRect.width) ||\n            (this.direction() === 'vertical' &&\n              intersections.partial.biggest.intersection.boundingClientRect.height > scrollableRect.height)\n          ) {\n            // If the current element is bigger than the scrollable container we should snap to the start of the current element if the scroll direction is forward\n            // and to the end of the current element if the scroll direction is backwards.\n            const origin = intersections.partial.biggest.index === intersections.partial.first.index ? 'end' : 'start';\n\n            this.scrollToElement({\n              element: intersections.partial.biggest.intersection.target as HTMLElement,\n              origin,\n              ignoreForcedOrigin: true,\n            });\n          } else {\n            // No special case. Just snap to the biggest intersection.\n            this.scrollToElement({\n              element: intersections.partial.biggest.intersection.target as HTMLElement,\n            });\n          }\n        }),\n        takeUntil(this._disableSnapping$),\n      )\n      .subscribe();\n  }\n\n  private _disableSnapping() {\n    this._disableSnapping$.next();\n  }\n}\n","<div class=\"et-scrollable-wrapper\">\n  <div\n    #scrollable\n    [attr.role]=\"scrollableRole() ?? undefined\"\n    [etCursorDragScroll]=\"cursorDragScroll() && (!isAtStart() || !isAtEnd())\"\n    [allowedDirection]=\"direction()\"\n    (cursorDragStart)=\"setIsCursorDragging(true)\"\n    (cursorDragEnd)=\"setIsCursorDragging(false)\"\n    class=\"et-scrollable-container-outer\"\n  >\n    <div #scrollableContainer [ngClass]=\"scrollableClass()\" class=\"et-scrollable-container\">\n      <div #firstElement class=\"et-scroll-observer-first-element\" etScrollableIgnoreChild></div>\n      <ng-content />\n      <div #lastElement class=\"et-scroll-observer-last-element\" etScrollableIgnoreChild></div>\n    </div>\n  </div>\n\n  @if (renderMasks()) {\n    <div class=\"et-scrollable-masks\">\n      <div class=\"et-scrollable-mask et-scrollable-mask--start\"></div>\n      <div class=\"et-scrollable-mask et-scrollable-mask--end\"></div>\n    </div>\n  }\n\n  @if (renderButtonsInside()) {\n    <div class=\"et-scrollable-buttons\">\n      <ng-container *ngTemplateOutlet=\"forwardButtonTpl\" />\n      <ng-container *ngTemplateOutlet=\"backwardButtonTpl\" />\n    </div>\n  }\n</div>\n\n@if (renderButtonsInFooter() || (renderNavigation() && scrollableNavigation().length > 1)) {\n  <div\n    [ngClass]=\"{\n      'et-scrollable-footer--with-navigation': renderNavigation(),\n      'et-scrollable-footer--with-buttons': renderButtonsInFooter()\n    }\"\n    class=\"et-scrollable-footer\"\n    aria-hidden=\"true\"\n  >\n    @if (renderButtonsInFooter()) {\n      <ng-container *ngTemplateOutlet=\"forwardButtonTpl\" />\n    }\n\n    @if (renderNavigation()) {\n      <div class=\"et-scrollable-progress-bar\">\n        <div #navigationDotsContainer class=\"et-scrollable-dots-container\">\n          @for (item of scrollableNavigation(); track i; let i = $index) {\n            <button\n              #navigationDot\n              [class.et-scrollable-navigation-item--active]=\"item.isActive\"\n              [class.et-scrollable-navigation-item--close]=\"\n                scrollableNavigation()[i + 1]?.isActive || scrollableNavigation()[i - 1]?.isActive\n              \"\n              [class.et-scrollable-navigation-item--far]=\"\n                !scrollableNavigation()[i + 1]?.isActive && !scrollableNavigation()[i - 1]?.isActive && !item.isActive\n              \"\n              [attr.active-offset]=\"item.activeOffset\"\n              (click)=\"scrollToElementViaNavigation(i)\"\n              class=\"et-scrollable-navigation-item\"\n              type=\"button\"\n              tabindex=\"-1\"\n              aria-hidden=\"true\"\n            ></button>\n          }\n        </div>\n      </div>\n    }\n\n    @if (renderButtonsInFooter()) {\n      <ng-container *ngTemplateOutlet=\"backwardButtonTpl\" />\n    }\n  </div>\n}\n\n<ng-template #forwardButtonTpl>\n  <button\n    [disabled]=\"isAtStart()\"\n    (click)=\"scrollToStartDirection()\"\n    class=\"et-scrollable-button et-scrollable-button--start\"\n    aria-hidden=\"true\"\n    type=\"button\"\n    tabindex=\"-1\"\n  >\n    <et-chevron-icon />\n  </button>\n</ng-template>\n\n<ng-template #backwardButtonTpl>\n  <button\n    [disabled]=\"isAtEnd()\"\n    (click)=\"scrollToEndDirection()\"\n    class=\"et-scrollable-button et-scrollable-button--end\"\n    aria-hidden=\"true\"\n    type=\"button\"\n    tabindex=\"-1\"\n  >\n    <et-chevron-icon />\n  </button>\n</ng-template>\n"]}