@ethlete/cdk 2.8.1 → 2.9.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.
- package/CHANGELOG.md +10 -0
- package/esm2022/lib/components/overlay/components/menu/context-menu-trigger.mjs +163 -0
- package/esm2022/lib/components/overlay/components/menu/menu-aim.mjs +140 -0
- package/esm2022/lib/components/overlay/components/menu/menu-bar.mjs +113 -0
- package/esm2022/lib/components/overlay/components/menu/menu-base.mjs +154 -0
- package/esm2022/lib/components/overlay/components/menu/menu-errors.mjs +7 -0
- package/esm2022/lib/components/overlay/components/menu/menu-group.mjs +26 -0
- package/esm2022/lib/components/overlay/components/menu/menu-interface.mjs +3 -0
- package/esm2022/lib/components/overlay/components/menu/menu-item-checkbox.mjs +39 -0
- package/esm2022/lib/components/overlay/components/menu/menu-item-radio.mjs +56 -0
- package/esm2022/lib/components/overlay/components/menu/menu-item-selectable.mjs +32 -0
- package/esm2022/lib/components/overlay/components/menu/menu-item.mjs +210 -0
- package/esm2022/lib/components/overlay/components/menu/menu-module.mjs +52 -0
- package/esm2022/lib/components/overlay/components/menu/menu-stack.mjs +101 -0
- package/esm2022/lib/components/overlay/components/menu/menu-trigger-base.mjs +77 -0
- package/esm2022/lib/components/overlay/components/menu/menu-trigger.mjs +240 -0
- package/esm2022/lib/components/overlay/components/menu/menu.mjs +116 -0
- package/esm2022/lib/components/overlay/components/menu/pointer-focus-tracker.mjs +26 -0
- package/esm2022/lib/components/overlay/components/menu/public-api.mjs +17 -0
- package/esm2022/lib/components/overlay/components/public-api.mjs +2 -1
- package/esm2022/lib/components/scrollable/components/scrollable/scrollable.component.mjs +3 -3
- package/fesm2022/ethlete-cdk.mjs +1561 -157
- package/fesm2022/ethlete-cdk.mjs.map +1 -1
- package/lib/components/overlay/components/menu/context-menu-trigger.d.ts +33 -0
- package/lib/components/overlay/components/menu/menu-aim.d.ts +34 -0
- package/lib/components/overlay/components/menu/menu-bar.d.ts +13 -0
- package/lib/components/overlay/components/menu/menu-base.d.ts +41 -0
- package/lib/components/overlay/components/menu/menu-errors.d.ts +2 -0
- package/lib/components/overlay/components/menu/menu-group.d.ts +5 -0
- package/lib/components/overlay/components/menu/menu-interface.d.ts +11 -0
- package/lib/components/overlay/components/menu/menu-item-checkbox.d.ts +9 -0
- package/lib/components/overlay/components/menu/menu-item-radio.d.ts +16 -0
- package/lib/components/overlay/components/menu/menu-item-selectable.d.ts +11 -0
- package/lib/components/overlay/components/menu/menu-item.d.ts +52 -0
- package/lib/components/overlay/components/menu/menu-module.d.ts +16 -0
- package/lib/components/overlay/components/menu/menu-stack.d.ts +54 -0
- package/lib/components/overlay/components/menu/menu-trigger-base.d.ts +33 -0
- package/lib/components/overlay/components/menu/menu-trigger.d.ts +34 -0
- package/lib/components/overlay/components/menu/menu.d.ts +17 -0
- package/lib/components/overlay/components/menu/pointer-focus-tracker.d.ts +17 -0
- package/lib/components/overlay/components/menu/public-api.d.ts +16 -0
- package/lib/components/overlay/components/public-api.d.ts +1 -0
- package/package.json +2 -2
|
@@ -0,0 +1,116 @@
|
|
|
1
|
+
/* eslint-disable @angular-eslint/directive-class-suffix */
|
|
2
|
+
/* eslint-disable @angular-eslint/no-output-rename */
|
|
3
|
+
/* eslint-disable @angular-eslint/no-outputs-metadata-property */
|
|
4
|
+
/* eslint-disable @angular-eslint/no-input-rename */
|
|
5
|
+
/* eslint-disable @angular-eslint/no-inputs-metadata-property */
|
|
6
|
+
import { ESCAPE, hasModifierKey, LEFT_ARROW, RIGHT_ARROW, TAB } from '@angular/cdk/keycodes';
|
|
7
|
+
import { Directive, EventEmitter, inject, Output } from '@angular/core';
|
|
8
|
+
import { takeUntil } from 'rxjs/operators';
|
|
9
|
+
import { CdkMenuBase } from './menu-base';
|
|
10
|
+
import { CdkMenuGroup } from './menu-group';
|
|
11
|
+
import { CDK_MENU } from './menu-interface';
|
|
12
|
+
import { PARENT_OR_NEW_INLINE_MENU_STACK_PROVIDER } from './menu-stack';
|
|
13
|
+
import { MENU_TRIGGER } from './menu-trigger-base';
|
|
14
|
+
import * as i0 from "@angular/core";
|
|
15
|
+
export class CdkMenu extends CdkMenuBase {
|
|
16
|
+
constructor() {
|
|
17
|
+
super();
|
|
18
|
+
this._parentTrigger = inject(MENU_TRIGGER, { optional: true });
|
|
19
|
+
this.closed = new EventEmitter();
|
|
20
|
+
this.orientation = 'vertical';
|
|
21
|
+
this.isInline = !this._parentTrigger;
|
|
22
|
+
this.destroyed.subscribe(this.closed);
|
|
23
|
+
this._parentTrigger?.registerChildMenu(this);
|
|
24
|
+
}
|
|
25
|
+
ngAfterContentInit() {
|
|
26
|
+
super.ngAfterContentInit();
|
|
27
|
+
this._subscribeToMenuStackEmptied();
|
|
28
|
+
}
|
|
29
|
+
ngOnDestroy() {
|
|
30
|
+
super.ngOnDestroy();
|
|
31
|
+
this.closed.complete();
|
|
32
|
+
}
|
|
33
|
+
_handleKeyEvent(event) {
|
|
34
|
+
const keyManager = this.keyManager;
|
|
35
|
+
if (!keyManager)
|
|
36
|
+
return;
|
|
37
|
+
switch (event.keyCode) {
|
|
38
|
+
case LEFT_ARROW:
|
|
39
|
+
case RIGHT_ARROW:
|
|
40
|
+
if (!hasModifierKey(event)) {
|
|
41
|
+
event.preventDefault();
|
|
42
|
+
keyManager.setFocusOrigin('keyboard');
|
|
43
|
+
keyManager.onKeydown(event);
|
|
44
|
+
}
|
|
45
|
+
break;
|
|
46
|
+
case ESCAPE:
|
|
47
|
+
if (!hasModifierKey(event)) {
|
|
48
|
+
event.preventDefault();
|
|
49
|
+
this.menuStack.close(this, {
|
|
50
|
+
focusNextOnEmpty: 2 /* FocusNext.currentItem */,
|
|
51
|
+
focusParentTrigger: true,
|
|
52
|
+
});
|
|
53
|
+
}
|
|
54
|
+
break;
|
|
55
|
+
case TAB:
|
|
56
|
+
if (!hasModifierKey(event, 'altKey', 'metaKey', 'ctrlKey')) {
|
|
57
|
+
this.menuStack.closeAll({ focusParentTrigger: true });
|
|
58
|
+
}
|
|
59
|
+
break;
|
|
60
|
+
default:
|
|
61
|
+
keyManager.onKeydown(event);
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
_toggleMenuFocus(focusNext) {
|
|
65
|
+
const keyManager = this.keyManager;
|
|
66
|
+
if (!keyManager)
|
|
67
|
+
return;
|
|
68
|
+
switch (focusNext) {
|
|
69
|
+
case 0 /* FocusNext.nextItem */:
|
|
70
|
+
keyManager.setFocusOrigin('keyboard');
|
|
71
|
+
keyManager.setNextItemActive();
|
|
72
|
+
break;
|
|
73
|
+
case 1 /* FocusNext.previousItem */:
|
|
74
|
+
keyManager.setFocusOrigin('keyboard');
|
|
75
|
+
keyManager.setPreviousItemActive();
|
|
76
|
+
break;
|
|
77
|
+
case 2 /* FocusNext.currentItem */:
|
|
78
|
+
if (keyManager.activeItem) {
|
|
79
|
+
keyManager.setFocusOrigin('keyboard');
|
|
80
|
+
keyManager.setActiveItem(keyManager.activeItem);
|
|
81
|
+
}
|
|
82
|
+
break;
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
_subscribeToMenuStackEmptied() {
|
|
86
|
+
this.menuStack.emptied.pipe(takeUntil(this.destroyed)).subscribe((event) => this._toggleMenuFocus(event));
|
|
87
|
+
}
|
|
88
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.1", ngImport: i0, type: CdkMenu, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
89
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.1.1", type: CdkMenu, isStandalone: true, selector: "[cdkMenu]", outputs: { closed: "closed" }, host: { attributes: { "role": "menu" }, listeners: { "keydown": "_handleKeyEvent($event)" }, properties: { "class.cdk-menu-inline": "isInline" }, classAttribute: "cdk-menu" }, providers: [
|
|
90
|
+
{ provide: CdkMenuGroup, useExisting: CdkMenu },
|
|
91
|
+
{ provide: CDK_MENU, useExisting: CdkMenu },
|
|
92
|
+
PARENT_OR_NEW_INLINE_MENU_STACK_PROVIDER('vertical'),
|
|
93
|
+
], exportAs: ["cdkMenu"], usesInheritance: true, ngImport: i0 }); }
|
|
94
|
+
}
|
|
95
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.1", ngImport: i0, type: CdkMenu, decorators: [{
|
|
96
|
+
type: Directive,
|
|
97
|
+
args: [{
|
|
98
|
+
selector: '[cdkMenu]',
|
|
99
|
+
exportAs: 'cdkMenu',
|
|
100
|
+
standalone: true,
|
|
101
|
+
host: {
|
|
102
|
+
role: 'menu',
|
|
103
|
+
class: 'cdk-menu',
|
|
104
|
+
'[class.cdk-menu-inline]': 'isInline',
|
|
105
|
+
'(keydown)': '_handleKeyEvent($event)',
|
|
106
|
+
},
|
|
107
|
+
providers: [
|
|
108
|
+
{ provide: CdkMenuGroup, useExisting: CdkMenu },
|
|
109
|
+
{ provide: CDK_MENU, useExisting: CdkMenu },
|
|
110
|
+
PARENT_OR_NEW_INLINE_MENU_STACK_PROVIDER('vertical'),
|
|
111
|
+
],
|
|
112
|
+
}]
|
|
113
|
+
}], ctorParameters: function () { return []; }, propDecorators: { closed: [{
|
|
114
|
+
type: Output
|
|
115
|
+
}] } });
|
|
116
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"menu.js","sourceRoot":"","sources":["../../../../../../../../../libs/cdk/src/lib/components/overlay/components/menu/menu.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @angular-eslint/directive-class-suffix */\n/* eslint-disable @angular-eslint/no-output-rename */\n/* eslint-disable @angular-eslint/no-outputs-metadata-property */\n/* eslint-disable @angular-eslint/no-input-rename */\n/* eslint-disable @angular-eslint/no-inputs-metadata-property */\n\nimport { ESCAPE, hasModifierKey, LEFT_ARROW, RIGHT_ARROW, TAB } from '@angular/cdk/keycodes';\nimport { AfterContentInit, Directive, EventEmitter, inject, OnDestroy, Output } from '@angular/core';\nimport { takeUntil } from 'rxjs/operators';\nimport { CdkMenuBase } from './menu-base';\nimport { CdkMenuGroup } from './menu-group';\nimport { CDK_MENU } from './menu-interface';\nimport { FocusNext, PARENT_OR_NEW_INLINE_MENU_STACK_PROVIDER } from './menu-stack';\nimport { MENU_TRIGGER } from './menu-trigger-base';\n\n@Directive({\n  selector: '[cdkMenu]',\n  exportAs: 'cdkMenu',\n  standalone: true,\n  host: {\n    role: 'menu',\n    class: 'cdk-menu',\n    '[class.cdk-menu-inline]': 'isInline',\n    '(keydown)': '_handleKeyEvent($event)',\n  },\n  providers: [\n    { provide: CdkMenuGroup, useExisting: CdkMenu },\n    { provide: CDK_MENU, useExisting: CdkMenu },\n    PARENT_OR_NEW_INLINE_MENU_STACK_PROVIDER('vertical'),\n  ],\n})\nexport class CdkMenu extends CdkMenuBase implements AfterContentInit, OnDestroy {\n  private _parentTrigger = inject(MENU_TRIGGER, { optional: true });\n\n  @Output() readonly closed: EventEmitter<void> = new EventEmitter();\n\n  override readonly orientation = 'vertical';\n\n  override readonly isInline = !this._parentTrigger;\n\n  constructor() {\n    super();\n    this.destroyed.subscribe(this.closed);\n    this._parentTrigger?.registerChildMenu(this);\n  }\n\n  override ngAfterContentInit() {\n    super.ngAfterContentInit();\n    this._subscribeToMenuStackEmptied();\n  }\n\n  override ngOnDestroy() {\n    super.ngOnDestroy();\n    this.closed.complete();\n  }\n\n  _handleKeyEvent(event: KeyboardEvent) {\n    const keyManager = this.keyManager;\n\n    if (!keyManager) return;\n\n    switch (event.keyCode) {\n      case LEFT_ARROW:\n      case RIGHT_ARROW:\n        if (!hasModifierKey(event)) {\n          event.preventDefault();\n          keyManager.setFocusOrigin('keyboard');\n          keyManager.onKeydown(event);\n        }\n        break;\n\n      case ESCAPE:\n        if (!hasModifierKey(event)) {\n          event.preventDefault();\n          this.menuStack.close(this, {\n            focusNextOnEmpty: FocusNext.currentItem,\n            focusParentTrigger: true,\n          });\n        }\n        break;\n\n      case TAB:\n        if (!hasModifierKey(event, 'altKey', 'metaKey', 'ctrlKey')) {\n          this.menuStack.closeAll({ focusParentTrigger: true });\n        }\n        break;\n\n      default:\n        keyManager.onKeydown(event);\n    }\n  }\n\n  private _toggleMenuFocus(focusNext: FocusNext | undefined) {\n    const keyManager = this.keyManager;\n\n    if (!keyManager) return;\n\n    switch (focusNext) {\n      case FocusNext.nextItem:\n        keyManager.setFocusOrigin('keyboard');\n        keyManager.setNextItemActive();\n        break;\n\n      case FocusNext.previousItem:\n        keyManager.setFocusOrigin('keyboard');\n        keyManager.setPreviousItemActive();\n        break;\n\n      case FocusNext.currentItem:\n        if (keyManager.activeItem) {\n          keyManager.setFocusOrigin('keyboard');\n          keyManager.setActiveItem(keyManager.activeItem);\n        }\n        break;\n    }\n  }\n\n  private _subscribeToMenuStackEmptied() {\n    this.menuStack.emptied.pipe(takeUntil(this.destroyed)).subscribe((event) => this._toggleMenuFocus(event));\n  }\n}\n"]}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { Subject, defer, fromEvent } from 'rxjs';
|
|
2
|
+
import { mapTo, mergeAll, mergeMap, startWith, takeUntil } from 'rxjs/operators';
|
|
3
|
+
export class PointerFocusTracker {
|
|
4
|
+
constructor(_items) {
|
|
5
|
+
this._items = _items;
|
|
6
|
+
this.entered = this._getItemPointerEntries();
|
|
7
|
+
this.exited = this._getItemPointerExits();
|
|
8
|
+
this._destroyed = new Subject();
|
|
9
|
+
this.entered.subscribe((element) => (this.activeElement = element));
|
|
10
|
+
this.exited.subscribe(() => {
|
|
11
|
+
this.previousElement = this.activeElement;
|
|
12
|
+
this.activeElement = undefined;
|
|
13
|
+
});
|
|
14
|
+
}
|
|
15
|
+
destroy() {
|
|
16
|
+
this._destroyed.next();
|
|
17
|
+
this._destroyed.complete();
|
|
18
|
+
}
|
|
19
|
+
_getItemPointerEntries() {
|
|
20
|
+
return defer(() => this._items.changes.pipe(startWith(this._items), mergeMap((list) => list.map((element) => fromEvent(element._elementRef.nativeElement, 'mouseenter').pipe(mapTo(element), takeUntil(this._items.changes)))), mergeAll()));
|
|
21
|
+
}
|
|
22
|
+
_getItemPointerExits() {
|
|
23
|
+
return defer(() => this._items.changes.pipe(startWith(this._items), mergeMap((list) => list.map((element) => fromEvent(element._elementRef.nativeElement, 'mouseout').pipe(mapTo(element), takeUntil(this._items.changes)))), mergeAll()));
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG9pbnRlci1mb2N1cy10cmFja2VyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jZGsvc3JjL2xpYi9jb21wb25lbnRzL292ZXJsYXkvY29tcG9uZW50cy9tZW51L3BvaW50ZXItZm9jdXMtdHJhY2tlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQWMsT0FBTyxFQUFFLEtBQUssRUFBRSxTQUFTLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDN0QsT0FBTyxFQUFFLEtBQUssRUFBRSxRQUFRLEVBQUUsUUFBUSxFQUFFLFNBQVMsRUFBRSxTQUFTLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQU1qRixNQUFNLE9BQU8sbUJBQW1CO0lBVzlCLFlBQTZCLE1BQW9CO1FBQXBCLFdBQU0sR0FBTixNQUFNLENBQWM7UUFWeEMsWUFBTyxHQUFrQixJQUFJLENBQUMsc0JBQXNCLEVBQUUsQ0FBQztRQUV2RCxXQUFNLEdBQWtCLElBQUksQ0FBQyxvQkFBb0IsRUFBRSxDQUFDO1FBTTVDLGVBQVUsR0FBa0IsSUFBSSxPQUFPLEVBQUUsQ0FBQztRQUd6RCxJQUFJLENBQUMsT0FBTyxDQUFDLFNBQVMsQ0FBQyxDQUFDLE9BQU8sRUFBRSxFQUFFLENBQUMsQ0FBQyxJQUFJLENBQUMsYUFBYSxHQUFHLE9BQU8sQ0FBQyxDQUFDLENBQUM7UUFDcEUsSUFBSSxDQUFDLE1BQU0sQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFO1lBQ3pCLElBQUksQ0FBQyxlQUFlLEdBQUcsSUFBSSxDQUFDLGFBQWEsQ0FBQztZQUMxQyxJQUFJLENBQUMsYUFBYSxHQUFHLFNBQVMsQ0FBQztRQUNqQyxDQUFDLENBQUMsQ0FBQztJQUNMLENBQUM7SUFFRCxPQUFPO1FBQ0wsSUFBSSxDQUFDLFVBQVUsQ0FBQyxJQUFJLEVBQUUsQ0FBQztRQUN2QixJQUFJLENBQUMsVUFBVSxDQUFDLFFBQVEsRUFBRSxDQUFDO0lBQzdCLENBQUM7SUFFTyxzQkFBc0I7UUFDNUIsT0FBTyxLQUFLLENBQUMsR0FBRyxFQUFFLENBQ2hCLElBQUksQ0FBQyxNQUFNLENBQUMsT0FBTyxDQUFDLElBQUksQ0FDdEIsU0FBUyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsRUFDdEIsUUFBUSxDQUFDLENBQUMsSUFBa0IsRUFBRSxFQUFFLENBQzlCLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQyxPQUFPLEVBQUUsRUFBRSxDQUNuQixTQUFTLENBQUMsT0FBTyxDQUFDLFdBQVcsQ0FBQyxhQUFhLEVBQUUsWUFBWSxDQUFDLENBQUMsSUFBSSxDQUM3RCxLQUFLLENBQUMsT0FBTyxDQUFDLEVBQ2QsU0FBUyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsT0FBTyxDQUFDLENBQy9CLENBQ0YsQ0FDRixFQUNELFFBQVEsRUFBRSxDQUNYLENBQ0YsQ0FBQztJQUNKLENBQUM7SUFFTyxvQkFBb0I7UUFDMUIsT0FBTyxLQUFLLENBQUMsR0FBRyxFQUFFLENBQ2hCLElBQUksQ0FBQyxNQUFNLENBQUMsT0FBTyxDQUFDLElBQUksQ0FDdEIsU0FBUyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsRUFDdEIsUUFBUSxDQUFDLENBQUMsSUFBa0IsRUFBRSxFQUFFLENBQzlCLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQyxPQUFPLEVBQUUsRUFBRSxDQUNuQixTQUFTLENBQUMsT0FBTyxDQUFDLFdBQVcsQ0FBQyxhQUFhLEVBQUUsVUFBVSxDQUFDLENBQUMsSUFBSSxDQUMzRCxLQUFLLENBQUMsT0FBTyxDQUFDLEVBQ2QsU0FBUyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsT0FBTyxDQUFDLENBQy9CLENBQ0YsQ0FDRixFQUNELFFBQVEsRUFBRSxDQUNYLENBQ0YsQ0FBQztJQUNKLENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEVsZW1lbnRSZWYsIFF1ZXJ5TGlzdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgT2JzZXJ2YWJsZSwgU3ViamVjdCwgZGVmZXIsIGZyb21FdmVudCB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgbWFwVG8sIG1lcmdlQWxsLCBtZXJnZU1hcCwgc3RhcnRXaXRoLCB0YWtlVW50aWwgfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgRm9jdXNhYmxlRWxlbWVudCB7XG4gIF9lbGVtZW50UmVmOiBFbGVtZW50UmVmPEhUTUxFbGVtZW50Pjtcbn1cblxuZXhwb3J0IGNsYXNzIFBvaW50ZXJGb2N1c1RyYWNrZXI8VCBleHRlbmRzIEZvY3VzYWJsZUVsZW1lbnQ+IHtcbiAgcmVhZG9ubHkgZW50ZXJlZDogT2JzZXJ2YWJsZTxUPiA9IHRoaXMuX2dldEl0ZW1Qb2ludGVyRW50cmllcygpO1xuXG4gIHJlYWRvbmx5IGV4aXRlZDogT2JzZXJ2YWJsZTxUPiA9IHRoaXMuX2dldEl0ZW1Qb2ludGVyRXhpdHMoKTtcblxuICBhY3RpdmVFbGVtZW50PzogVDtcblxuICBwcmV2aW91c0VsZW1lbnQ/OiBUO1xuXG4gIHByaXZhdGUgcmVhZG9ubHkgX2Rlc3Ryb3llZDogU3ViamVjdDx2b2lkPiA9IG5ldyBTdWJqZWN0KCk7XG5cbiAgY29uc3RydWN0b3IocHJpdmF0ZSByZWFkb25seSBfaXRlbXM6IFF1ZXJ5TGlzdDxUPikge1xuICAgIHRoaXMuZW50ZXJlZC5zdWJzY3JpYmUoKGVsZW1lbnQpID0+ICh0aGlzLmFjdGl2ZUVsZW1lbnQgPSBlbGVtZW50KSk7XG4gICAgdGhpcy5leGl0ZWQuc3Vic2NyaWJlKCgpID0+IHtcbiAgICAgIHRoaXMucHJldmlvdXNFbGVtZW50ID0gdGhpcy5hY3RpdmVFbGVtZW50O1xuICAgICAgdGhpcy5hY3RpdmVFbGVtZW50ID0gdW5kZWZpbmVkO1xuICAgIH0pO1xuICB9XG5cbiAgZGVzdHJveSgpIHtcbiAgICB0aGlzLl9kZXN0cm95ZWQubmV4dCgpO1xuICAgIHRoaXMuX2Rlc3Ryb3llZC5jb21wbGV0ZSgpO1xuICB9XG5cbiAgcHJpdmF0ZSBfZ2V0SXRlbVBvaW50ZXJFbnRyaWVzKCk6IE9ic2VydmFibGU8VD4ge1xuICAgIHJldHVybiBkZWZlcigoKSA9PlxuICAgICAgdGhpcy5faXRlbXMuY2hhbmdlcy5waXBlKFxuICAgICAgICBzdGFydFdpdGgodGhpcy5faXRlbXMpLFxuICAgICAgICBtZXJnZU1hcCgobGlzdDogUXVlcnlMaXN0PFQ+KSA9PlxuICAgICAgICAgIGxpc3QubWFwKChlbGVtZW50KSA9PlxuICAgICAgICAgICAgZnJvbUV2ZW50KGVsZW1lbnQuX2VsZW1lbnRSZWYubmF0aXZlRWxlbWVudCwgJ21vdXNlZW50ZXInKS5waXBlKFxuICAgICAgICAgICAgICBtYXBUbyhlbGVtZW50KSxcbiAgICAgICAgICAgICAgdGFrZVVudGlsKHRoaXMuX2l0ZW1zLmNoYW5nZXMpLFxuICAgICAgICAgICAgKSxcbiAgICAgICAgICApLFxuICAgICAgICApLFxuICAgICAgICBtZXJnZUFsbCgpLFxuICAgICAgKSxcbiAgICApO1xuICB9XG5cbiAgcHJpdmF0ZSBfZ2V0SXRlbVBvaW50ZXJFeGl0cygpIHtcbiAgICByZXR1cm4gZGVmZXIoKCkgPT5cbiAgICAgIHRoaXMuX2l0ZW1zLmNoYW5nZXMucGlwZShcbiAgICAgICAgc3RhcnRXaXRoKHRoaXMuX2l0ZW1zKSxcbiAgICAgICAgbWVyZ2VNYXAoKGxpc3Q6IFF1ZXJ5TGlzdDxUPikgPT5cbiAgICAgICAgICBsaXN0Lm1hcCgoZWxlbWVudCkgPT5cbiAgICAgICAgICAgIGZyb21FdmVudChlbGVtZW50Ll9lbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQsICdtb3VzZW91dCcpLnBpcGUoXG4gICAgICAgICAgICAgIG1hcFRvKGVsZW1lbnQpLFxuICAgICAgICAgICAgICB0YWtlVW50aWwodGhpcy5faXRlbXMuY2hhbmdlcyksXG4gICAgICAgICAgICApLFxuICAgICAgICAgICksXG4gICAgICAgICksXG4gICAgICAgIG1lcmdlQWxsKCksXG4gICAgICApLFxuICAgICk7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
export * from './context-menu-trigger';
|
|
2
|
+
export * from './menu';
|
|
3
|
+
export * from './menu-aim';
|
|
4
|
+
export * from './menu-bar';
|
|
5
|
+
export * from './menu-base';
|
|
6
|
+
export * from './menu-group';
|
|
7
|
+
export * from './menu-interface';
|
|
8
|
+
export * from './menu-item';
|
|
9
|
+
export * from './menu-item-checkbox';
|
|
10
|
+
export * from './menu-item-radio';
|
|
11
|
+
export * from './menu-item-selectable';
|
|
12
|
+
export * from './menu-module';
|
|
13
|
+
export * from './menu-stack';
|
|
14
|
+
export * from './menu-trigger';
|
|
15
|
+
export * from './menu-trigger-base';
|
|
16
|
+
export * from './pointer-focus-tracker';
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY2RrL3NyYy9saWIvY29tcG9uZW50cy9vdmVybGF5L2NvbXBvbmVudHMvbWVudS9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsd0JBQXdCLENBQUM7QUFDdkMsY0FBYyxRQUFRLENBQUM7QUFDdkIsY0FBYyxZQUFZLENBQUM7QUFDM0IsY0FBYyxZQUFZLENBQUM7QUFDM0IsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxrQkFBa0IsQ0FBQztBQUNqQyxjQUFjLGFBQWEsQ0FBQztBQUM1QixjQUFjLHNCQUFzQixDQUFDO0FBQ3JDLGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsY0FBYyx3QkFBd0IsQ0FBQztBQUN2QyxjQUFjLGVBQWUsQ0FBQztBQUM5QixjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLGdCQUFnQixDQUFDO0FBQy9CLGNBQWMscUJBQXFCLENBQUM7QUFDcEMsY0FBYyx5QkFBeUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vY29udGV4dC1tZW51LXRyaWdnZXInO1xuZXhwb3J0ICogZnJvbSAnLi9tZW51JztcbmV4cG9ydCAqIGZyb20gJy4vbWVudS1haW0nO1xuZXhwb3J0ICogZnJvbSAnLi9tZW51LWJhcic7XG5leHBvcnQgKiBmcm9tICcuL21lbnUtYmFzZSc7XG5leHBvcnQgKiBmcm9tICcuL21lbnUtZ3JvdXAnO1xuZXhwb3J0ICogZnJvbSAnLi9tZW51LWludGVyZmFjZSc7XG5leHBvcnQgKiBmcm9tICcuL21lbnUtaXRlbSc7XG5leHBvcnQgKiBmcm9tICcuL21lbnUtaXRlbS1jaGVja2JveCc7XG5leHBvcnQgKiBmcm9tICcuL21lbnUtaXRlbS1yYWRpbyc7XG5leHBvcnQgKiBmcm9tICcuL21lbnUtaXRlbS1zZWxlY3RhYmxlJztcbmV4cG9ydCAqIGZyb20gJy4vbWVudS1tb2R1bGUnO1xuZXhwb3J0ICogZnJvbSAnLi9tZW51LXN0YWNrJztcbmV4cG9ydCAqIGZyb20gJy4vbWVudS10cmlnZ2VyJztcbmV4cG9ydCAqIGZyb20gJy4vbWVudS10cmlnZ2VyLWJhc2UnO1xuZXhwb3J0ICogZnJvbSAnLi9wb2ludGVyLWZvY3VzLXRyYWNrZXInO1xuIl19
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
export * from './bottom-sheet/public-api';
|
|
2
2
|
export * from './dialog/public-api';
|
|
3
|
+
export * from './menu/public-api';
|
|
3
4
|
export * from './toggletip/public-api';
|
|
4
5
|
export * from './tooltip/public-api';
|
|
5
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY2RrL3NyYy9saWIvY29tcG9uZW50cy9vdmVybGF5L2NvbXBvbmVudHMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMscUJBQXFCLENBQUM7QUFDcEMsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLHdCQUF3QixDQUFDO0FBQ3ZDLGNBQWMsc0JBQXNCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2JvdHRvbS1zaGVldC9wdWJsaWMtYXBpJztcbmV4cG9ydCAqIGZyb20gJy4vZGlhbG9nL3B1YmxpYy1hcGknO1xuZXhwb3J0ICogZnJvbSAnLi9tZW51L3B1YmxpYy1hcGknO1xuZXhwb3J0ICogZnJvbSAnLi90b2dnbGV0aXAvcHVibGljLWFwaSc7XG5leHBvcnQgKiBmcm9tICcuL3Rvb2x0aXAvcHVibGljLWFwaSc7XG4iXX0=
|
|
@@ -87,7 +87,6 @@ export class ScrollableComponent {
|
|
|
87
87
|
this._renderer.setAttribute(element, 'can-scroll', state.canScroll.toString());
|
|
88
88
|
}), takeUntil(this._destroy$))
|
|
89
89
|
.subscribe();
|
|
90
|
-
this._setupScrollListening();
|
|
91
90
|
}
|
|
92
91
|
ngAfterContentInit() {
|
|
93
92
|
if (!this.activeElements || !this.elements) {
|
|
@@ -113,6 +112,7 @@ export class ScrollableComponent {
|
|
|
113
112
|
});
|
|
114
113
|
}), takeUntil(this._destroy$))
|
|
115
114
|
.subscribe();
|
|
115
|
+
this._setupScrollListening();
|
|
116
116
|
}
|
|
117
117
|
scrollOneContainerSize(direction) {
|
|
118
118
|
const scrollElement = this.scrollable.nativeElement;
|
|
@@ -209,7 +209,7 @@ export class ScrollableComponent {
|
|
|
209
209
|
isSnapping = false;
|
|
210
210
|
}))
|
|
211
211
|
.subscribe();
|
|
212
|
-
merge(fromEvent(scrollElement, 'scroll'), this._isCursorDragging$, of(
|
|
212
|
+
merge(fromEvent(scrollElement, 'scroll'), this._isCursorDragging$, this.elements?.changes.pipe(startWith(this.elements)) ?? of(null))
|
|
213
213
|
.pipe(debounceTime(300), takeUntil(this._destroy$), tap(() => {
|
|
214
214
|
const elements = this.elements
|
|
215
215
|
?.toArray()
|
|
@@ -345,4 +345,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.1", ngImpor
|
|
|
345
345
|
type: ContentChildren,
|
|
346
346
|
args: [IS_ELEMENT, { descendants: true }]
|
|
347
347
|
}] } });
|
|
348
|
-
//# 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, NgIf } from '@angular/common';\nimport {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  Component,\n  ContentChildren,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  Input,\n  OnInit,\n  Output,\n  Renderer2,\n  ViewChild,\n  ViewEncapsulation,\n  booleanAttribute,\n  inject,\n  isDevMode,\n  numberAttribute,\n} from '@angular/core';\nimport {\n  CursorDragScrollDirective,\n  IS_ACTIVE_ELEMENT,\n  IS_ELEMENT,\n  IsActiveElementDirective,\n  IsElementDirective,\n  LetDirective,\n  NgClassType,\n  ObserveScrollStateDirective,\n  ScrollObserverScrollState,\n  ScrollToElementOptions,\n  TypedQueryList,\n  createDestroy,\n  equal,\n  getElementVisibleStates,\n  scrollToElement,\n} from '@ethlete/core';\nimport { BehaviorSubject, debounceTime, fromEvent, merge, of, startWith, takeUntil, tap } from 'rxjs';\nimport { ChevronIconComponent } from '../../../icons';\nimport { ScrollableIntersectionChange, ScrollableScrollMode } from '../../types';\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: [CursorDragScrollDirective, ObserveScrollStateDirective, NgClass, NgIf, LetDirective, ChevronIconComponent],\n  host: {\n    class: 'et-scrollable',\n  },\n})\nexport class ScrollableComponent implements OnInit, AfterContentInit {\n  private readonly _destroy$ = createDestroy();\n  private readonly _renderer = inject(Renderer2);\n  private readonly _elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n\n  private readonly _isCursorDragging$ = new BehaviorSubject<boolean>(false);\n  private readonly _latestVisibilityStates$ = new BehaviorSubject<ScrollableIntersectionChange[]>([]);\n\n  @Input()\n  @HostBinding('attr.item-size')\n  itemSize: 'auto' | 'same' | 'full' = 'auto';\n\n  @Input()\n  @HostBinding('attr.direction')\n  direction: 'horizontal' | 'vertical' = 'horizontal';\n\n  @Input()\n  scrollableRole?: string;\n\n  @Input()\n  scrollableClass?: NgClassType;\n\n  @Input({ transform: booleanAttribute })\n  renderMasks = true;\n\n  @Input({ transform: booleanAttribute })\n  renderButtons = true;\n\n  @Input({ transform: booleanAttribute })\n  @HostBinding('attr.render-scrollbars')\n  renderScrollbars = false;\n\n  @Input({ transform: booleanAttribute })\n  @HostBinding('attr.sticky-buttons')\n  stickyButtons = false;\n\n  @Input({ transform: booleanAttribute })\n  cursorDragScroll = true;\n\n  @Input({ transform: booleanAttribute })\n  disableActiveElementScrolling = false;\n\n  @Input()\n  scrollMode: ScrollableScrollMode = 'container';\n\n  @Input({ transform: booleanAttribute })\n  snap = false;\n\n  @Input({ transform: numberAttribute })\n  scrollMargin = 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  scrollable!: ElementRef<HTMLElement>;\n\n  @ContentChildren(IS_ACTIVE_ELEMENT, { descendants: true })\n  activeElements: TypedQueryList<IsActiveElementDirective> | null = null;\n\n  @ContentChildren(IS_ELEMENT, { descendants: true })\n  elements: TypedQueryList<IsElementDirective> | null = null;\n\n  get highestVisibleIntersection() {\n    const elements = this._latestVisibilityStates$.value;\n\n    if (!elements.length) {\n      return null;\n    }\n\n    return elements.reduce((prev, curr) => {\n      if (!prev) {\n        return curr;\n      }\n\n      return curr.intersectionRatio > prev.intersectionRatio ? curr : prev;\n    });\n  }\n\n  get nextPartialIntersection() {\n    const elements = this._latestVisibilityStates$.value;\n\n    if (!elements.length) {\n      return null;\n    }\n\n    const highestVisibleIntersection = this.highestVisibleIntersection;\n\n    if (!highestVisibleIntersection) {\n      return null;\n    }\n\n    const nextIndex = elements.slice(highestVisibleIntersection.index).findIndex((e) => !e.isIntersecting);\n\n    if (nextIndex === -1) {\n      return null;\n    }\n\n    const nextElement = elements[highestVisibleIntersection.index + nextIndex];\n\n    return nextElement || null;\n  }\n\n  get previousPartialIntersection() {\n    const elements = this._latestVisibilityStates$.value;\n\n    if (!elements.length) {\n      return null;\n    }\n\n    const highestVisibleIntersection = this.highestVisibleIntersection;\n\n    if (!highestVisibleIntersection) {\n      return null;\n    }\n\n    const previousIndex = elements\n      .slice(0, highestVisibleIntersection.index)\n      .reverse()\n      .findIndex((e) => !e.isIntersecting);\n\n    if (previousIndex === -1) {\n      return null;\n    }\n\n    const previousElement = elements[highestVisibleIntersection.index - previousIndex - 1];\n\n    return previousElement || null;\n  }\n\n  protected readonly scrollState$ = new BehaviorSubject<ScrollObserverScrollState | null>(null);\n\n  ngOnInit(): void {\n    this.scrollState$\n      .pipe(\n        tap((state) => {\n          if (!state) {\n            return;\n          }\n\n          const element = this._elementRef.nativeElement;\n\n          this._renderer.setAttribute(element, 'at-start', state.isAtStart.toString());\n          this._renderer.setAttribute(element, 'at-end', state.isAtEnd.toString());\n          this._renderer.setAttribute(element, 'can-scroll', state.canScroll.toString());\n        }),\n        takeUntil(this._destroy$),\n      )\n      .subscribe();\n\n    this._setupScrollListening();\n  }\n\n  ngAfterContentInit(): void {\n    if (!this.activeElements || !this.elements) {\n      return;\n    }\n\n    this.activeElements.changes\n      .pipe(\n        startWith(this.activeElements),\n        tap((activeElements) => {\n          if (this.disableActiveElementScrolling) {\n            return;\n          }\n\n          const firstActive = activeElements\n            .filter((a): a is IsActiveElementDirective => !!a)\n            .find((a) => a.isActiveElement);\n\n          if (!firstActive) {\n            return;\n          }\n\n          scrollToElement({\n            behavior: 'auto',\n            container: this.scrollable.nativeElement,\n            element: firstActive.elementRef.nativeElement,\n            scrollInlineMargin: this.direction === 'horizontal' ? this.scrollMargin : 0,\n            scrollBlockMargin: this.direction === 'horizontal' ? 0 : this.scrollMargin,\n          });\n        }),\n        takeUntil(this._destroy$),\n      )\n      .subscribe();\n  }\n\n  scrollOneContainerSize(direction: 'start' | 'end') {\n    const scrollElement = this.scrollable.nativeElement;\n    const parent = this._elementRef.nativeElement;\n\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  scrollOneItemSize(direction: 'start' | 'end') {\n    const elements = this._latestVisibilityStates$.value;\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 el = direction === 'start' ? this.previousPartialIntersection : this.nextPartialIntersection;\n\n    if (!el) {\n      return;\n    }\n\n    this.scrollToElement({\n      element: el?.element,\n      direction: this.direction === 'horizontal' ? 'inline' : 'block',\n      origin: direction,\n      ...(this.direction === 'horizontal'\n        ? { scrollInlineMargin: this.scrollMargin }\n        : { scrollBlockMargin: this.scrollMargin }),\n    });\n  }\n\n  scrollToElement(options: Omit<ScrollToElementOptions, 'container'>) {\n    const scrollElement = this.scrollable.nativeElement;\n\n    scrollToElement({\n      container: scrollElement,\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.elements?.toArray() ?? [];\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]?.elementRef.nativeElement;\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 setIsCursorDragging(isDragging: boolean) {\n    this._isCursorDragging$.next(isDragging);\n  }\n\n  protected _scrollStateChanged(scrollState: ScrollObserverScrollState) {\n    if (equal(this.scrollState$.value, scrollState)) {\n      return;\n    }\n\n    this.scrollState$.next(scrollState);\n    this.scrollStateChange.emit(scrollState);\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 scrollToStartEnd() {\n    if (this.scrollMode === 'container') {\n      this.scrollOneContainerSize('end');\n    } else {\n      this.scrollOneItemSize('end');\n    }\n  }\n\n  private _setupScrollListening() {\n    const scrollElement = this.scrollable.nativeElement;\n    let isSnapping = false;\n    let snapTimeout = 0;\n\n    merge(fromEvent<WheelEvent>(scrollElement, 'wheel'), fromEvent<TouchEvent>(scrollElement, 'touchstart'))\n      .pipe(\n        takeUntil(this._destroy$),\n        tap(() => {\n          isSnapping = false;\n        }),\n      )\n      .subscribe();\n\n    merge(fromEvent(scrollElement, 'scroll'), this._isCursorDragging$, of(true))\n      .pipe(\n        debounceTime(300),\n        takeUntil(this._destroy$),\n        tap(() => {\n          const elements =\n            this.elements\n              ?.toArray()\n              .map((e) => e?.elementRef.nativeElement)\n              .filter((e): e is HTMLElement => !!e) ?? [];\n\n          if (!elements.length) {\n            this._latestVisibilityStates$.next([]);\n\n            return;\n          }\n\n          const states = getElementVisibleStates({\n            elements,\n            container: scrollElement,\n          });\n\n          const prop = this.direction === 'horizontal' ? 'inlineIntersection' : 'blockIntersection';\n          const stateClass = `et-element--is-intersecting`;\n\n          for (const state of states) {\n            if (state[prop] === 100) {\n              state.element.classList.add(stateClass);\n            } else {\n              state.element.classList.remove(stateClass);\n            }\n          }\n\n          const intersectionChanges = states.map((s, i) => {\n            const state: ScrollableIntersectionChange = {\n              element: s.element,\n              intersectionRatio: s[prop] / 100,\n              isIntersecting: s[prop] === 100,\n              index: i,\n            };\n\n            return state;\n          });\n\n          this.intersectionChange.emit(intersectionChanges);\n\n          this._latestVisibilityStates$.next(intersectionChanges);\n\n          if (isSnapping || this._isCursorDragging$.value || !this.snap) return;\n\n          const prev = this.previousPartialIntersection;\n          const next = this.nextPartialIntersection;\n          const skipSnap =\n            !prev ||\n            !next ||\n            prev.intersectionRatio === 0 ||\n            next.intersectionRatio === 0 ||\n            prev.intersectionRatio === next.intersectionRatio;\n\n          if (skipSnap) return;\n\n          const highestIntersecting = prev.intersectionRatio > next.intersectionRatio ? prev : next;\n          const fullIntersectionIndex = this.highestVisibleIntersection?.index;\n\n          if (fullIntersectionIndex === undefined) return;\n\n          const highestIntersectingIndex = highestIntersecting.index;\n          const origin = highestIntersectingIndex > fullIntersectionIndex ? 'end' : 'start';\n\n          scrollToElement({\n            container: scrollElement,\n            element: highestIntersecting.element,\n            direction: this.direction === 'horizontal' ? 'inline' : 'block',\n            origin,\n            scrollBlockMargin: this.direction === 'horizontal' ? 0 : this.scrollMargin,\n            scrollInlineMargin: this.direction === 'horizontal' ? this.scrollMargin : 0,\n          });\n\n          isSnapping = true;\n\n          window.clearTimeout(snapTimeout);\n\n          snapTimeout = window.setTimeout(() => {\n            isSnapping = false;\n          }, 1000);\n        }),\n      )\n      .subscribe();\n  }\n}\n","<div\n  #scrollable\n  [attr.role]=\"scrollableRole ?? undefined\"\n  [ngClass]=\"scrollableClass\"\n  [etCursorDragScroll]=\"cursorDragScroll\"\n  [allowedDirection]=\"direction\"\n  (etObserveScrollState)=\"_scrollStateChanged($event)\"\n  (cursorDragStart)=\"setIsCursorDragging(true)\"\n  (cursorDragEnd)=\"setIsCursorDragging(false)\"\n  class=\"et-scrollable-container\"\n>\n  <ng-content />\n</div>\n\n<div *ngIf=\"renderMasks\" 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<div *ngIf=\"renderButtons\" 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)=\"scrollToStartEnd()\"\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"]}
|
|
348
|
+
//# 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":"AAAA,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,iBAAiB,CAAC;AAChD,OAAO,EAEL,uBAAuB,EACvB,SAAS,EACT,eAAe,EACf,UAAU,EACV,YAAY,EACZ,WAAW,EACX,KAAK,EAEL,MAAM,EACN,SAAS,EACT,SAAS,EACT,iBAAiB,EACjB,gBAAgB,EAChB,MAAM,EACN,SAAS,EACT,eAAe,GAChB,MAAM,eAAe,CAAC;AACvB,OAAO,EACL,yBAAyB,EACzB,iBAAiB,EACjB,UAAU,EAGV,YAAY,EAEZ,2BAA2B,EAI3B,aAAa,EACb,KAAK,EACL,uBAAuB,EACvB,eAAe,GAChB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,eAAe,EAAE,YAAY,EAAE,SAAS,EAAE,KAAK,EAAE,EAAE,EAAE,SAAS,EAAE,SAAS,EAAE,GAAG,EAAE,MAAM,MAAM,CAAC;AACtG,OAAO,EAAE,oBAAoB,EAAE,MAAM,gBAAgB,CAAC;;AAetD,MAAM,OAAO,mBAAmB;IAZhC;QAamB,cAAS,GAAG,aAAa,EAAE,CAAC;QAC5B,cAAS,GAAG,MAAM,CAAC,SAAS,CAAC,CAAC;QAC9B,gBAAW,GAAG,MAAM,CAA0B,UAAU,CAAC,CAAC;QAE1D,uBAAkB,GAAG,IAAI,eAAe,CAAU,KAAK,CAAC,CAAC;QACzD,6BAAwB,GAAG,IAAI,eAAe,CAAiC,EAAE,CAAC,CAAC;QAIpG,aAAQ,GAA6B,MAAM,CAAC;QAI5C,cAAS,GAA8B,YAAY,CAAC;QASpD,gBAAW,GAAG,IAAI,CAAC;QAGnB,kBAAa,GAAG,IAAI,CAAC;QAIrB,qBAAgB,GAAG,KAAK,CAAC;QAIzB,kBAAa,GAAG,KAAK,CAAC;QAGtB,qBAAgB,GAAG,IAAI,CAAC;QAGxB,kCAA6B,GAAG,KAAK,CAAC;QAGtC,eAAU,GAAyB,WAAW,CAAC;QAG/C,SAAI,GAAG,KAAK,CAAC;QAGb,iBAAY,GAAG,CAAC,CAAC;QAGR,sBAAiB,GAAG,IAAI,YAAY,EAA6B,CAAC;QAGlE,uBAAkB,GAAG,IAAI,YAAY,EAAkC,CAAC;QAMjF,mBAAc,GAAoD,IAAI,CAAC;QAGvE,aAAQ,GAA8C,IAAI,CAAC;QAqExC,iBAAY,GAAG,IAAI,eAAe,CAAmC,IAAI,CAAC,CAAC;KAgR/F;IAnVC,IAAI,0BAA0B;QAC5B,MAAM,QAAQ,GAAG,IAAI,CAAC,wBAAwB,CAAC,KAAK,CAAC;QAErD,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE;YACpB,OAAO,IAAI,CAAC;SACb;QAED,OAAO,QAAQ,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,EAAE;YACpC,IAAI,CAAC,IAAI,EAAE;gBACT,OAAO,IAAI,CAAC;aACb;YAED,OAAO,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC;QACvE,CAAC,CAAC,CAAC;IACL,CAAC;IAED,IAAI,uBAAuB;QACzB,MAAM,QAAQ,GAAG,IAAI,CAAC,wBAAwB,CAAC,KAAK,CAAC;QAErD,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE;YACpB,OAAO,IAAI,CAAC;SACb;QAED,MAAM,0BAA0B,GAAG,IAAI,CAAC,0BAA0B,CAAC;QAEnE,IAAI,CAAC,0BAA0B,EAAE;YAC/B,OAAO,IAAI,CAAC;SACb;QAED,MAAM,SAAS,GAAG,QAAQ,CAAC,KAAK,CAAC,0BAA0B,CAAC,KAAK,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC;QAEvG,IAAI,SAAS,KAAK,CAAC,CAAC,EAAE;YACpB,OAAO,IAAI,CAAC;SACb;QAED,MAAM,WAAW,GAAG,QAAQ,CAAC,0BAA0B,CAAC,KAAK,GAAG,SAAS,CAAC,CAAC;QAE3E,OAAO,WAAW,IAAI,IAAI,CAAC;IAC7B,CAAC;IAED,IAAI,2BAA2B;QAC7B,MAAM,QAAQ,GAAG,IAAI,CAAC,wBAAwB,CAAC,KAAK,CAAC;QAErD,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE;YACpB,OAAO,IAAI,CAAC;SACb;QAED,MAAM,0BAA0B,GAAG,IAAI,CAAC,0BAA0B,CAAC;QAEnE,IAAI,CAAC,0BAA0B,EAAE;YAC/B,OAAO,IAAI,CAAC;SACb;QAED,MAAM,aAAa,GAAG,QAAQ;aAC3B,KAAK,CAAC,CAAC,EAAE,0BAA0B,CAAC,KAAK,CAAC;aAC1C,OAAO,EAAE;aACT,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC;QAEvC,IAAI,aAAa,KAAK,CAAC,CAAC,EAAE;YACxB,OAAO,IAAI,CAAC;SACb;QAED,MAAM,eAAe,GAAG,QAAQ,CAAC,0BAA0B,CAAC,KAAK,GAAG,aAAa,GAAG,CAAC,CAAC,CAAC;QAEvF,OAAO,eAAe,IAAI,IAAI,CAAC;IACjC,CAAC;IAID,QAAQ;QACN,IAAI,CAAC,YAAY;aACd,IAAI,CACH,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE;YACZ,IAAI,CAAC,KAAK,EAAE;gBACV,OAAO;aACR;YAED,MAAM,OAAO,GAAG,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC;YAE/C,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,OAAO,EAAE,UAAU,EAAE,KAAK,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC,CAAC;YAC7E,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,OAAO,EAAE,QAAQ,EAAE,KAAK,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC,CAAC;YACzE,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,OAAO,EAAE,YAAY,EAAE,KAAK,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC,CAAC;QACjF,CAAC,CAAC,EACF,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAC1B;aACA,SAAS,EAAE,CAAC;IACjB,CAAC;IAED,kBAAkB;QAChB,IAAI,CAAC,IAAI,CAAC,cAAc,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAC1C,OAAO;SACR;QAED,IAAI,CAAC,cAAc,CAAC,OAAO;aACxB,IAAI,CACH,SAAS,CAAC,IAAI,CAAC,cAAc,CAAC,EAC9B,GAAG,CAAC,CAAC,cAAc,EAAE,EAAE;YACrB,IAAI,IAAI,CAAC,6BAA6B,EAAE;gBACtC,OAAO;aACR;YAED,MAAM,WAAW,GAAG,cAAc;iBAC/B,MAAM,CAAC,CAAC,CAAC,EAAiC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;iBACjD,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC;YAElC,IAAI,CAAC,WAAW,EAAE;gBAChB,OAAO;aACR;YAED,eAAe,CAAC;gBACd,QAAQ,EAAE,MAAM;gBAChB,SAAS,EAAE,IAAI,CAAC,UAAU,CAAC,aAAa;gBACxC,OAAO,EAAE,WAAW,CAAC,UAAU,CAAC,aAAa;gBAC7C,kBAAkB,EAAE,IAAI,CAAC,SAAS,KAAK,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;gBAC3E,iBAAiB,EAAE,IAAI,CAAC,SAAS,KAAK,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY;aAC3E,CAAC,CAAC;QACL,CAAC,CAAC,EACF,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAC1B;aACA,SAAS,EAAE,CAAC;QAEf,IAAI,CAAC,qBAAqB,EAAE,CAAC;IAC/B,CAAC;IAED,sBAAsB,CAAC,SAA0B;QAC/C,MAAM,aAAa,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC;QACpD,MAAM,MAAM,GAAG,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC;QAE9C,MAAM,cAAc,GAAG,IAAI,CAAC,SAAS,KAAK,YAAY,CAAC,CAAC,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,CAAC,MAAM,CAAC,YAAY,CAAC;QAClG,MAAM,aAAa,GAAG,IAAI,CAAC,SAAS,KAAK,YAAY,CAAC,CAAC,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC,CAAC,aAAa,CAAC,SAAS,CAAC;QAE3G,aAAa,CAAC,QAAQ,CAAC;YACrB,CAAC,IAAI,CAAC,SAAS,KAAK,YAAY,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,EAChD,aAAa,GAAG,CAAC,SAAS,KAAK,OAAO,CAAC,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC,cAAc,CAAC;YAC5E,QAAQ,EAAE,QAAQ;SACnB,CAAC,CAAC;IACL,CAAC;IAED,iBAAiB,CAAC,SAA0B;QAC1C,MAAM,QAAQ,GAAG,IAAI,CAAC,wBAAwB,CAAC,KAAK,CAAC;QAErD,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE;YACpB,IAAI,SAAS,EAAE,EAAE;gBACf,OAAO,CAAC,IAAI,CACV,mHAAmH,CACpH,CAAC;aACH;YACD,OAAO;SACR;QAED,MAAM,EAAE,GAAG,SAAS,KAAK,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,2BAA2B,CAAC,CAAC,CAAC,IAAI,CAAC,uBAAuB,CAAC;QAEnG,IAAI,CAAC,EAAE,EAAE;YACP,OAAO;SACR;QAED,IAAI,CAAC,eAAe,CAAC;YACnB,OAAO,EAAE,EAAE,EAAE,OAAO;YACpB,SAAS,EAAE,IAAI,CAAC,SAAS,KAAK,YAAY,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,OAAO;YAC/D,MAAM,EAAE,SAAS;YACjB,GAAG,CAAC,IAAI,CAAC,SAAS,KAAK,YAAY;gBACjC,CAAC,CAAC,EAAE,kBAAkB,EAAE,IAAI,CAAC,YAAY,EAAE;gBAC3C,CAAC,CAAC,EAAE,iBAAiB,EAAE,IAAI,CAAC,YAAY,EAAE,CAAC;SAC9C,CAAC,CAAC;IACL,CAAC;IAED,eAAe,CAAC,OAAkD;QAChE,MAAM,aAAa,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC;QAEpD,eAAe,CAAC;YACd,SAAS,EAAE,aAAa;YACxB,GAAG,CAAC,IAAI,CAAC,SAAS,KAAK,YAAY;gBACjC,CAAC,CAAC,EAAE,kBAAkB,EAAE,IAAI,CAAC,YAAY,EAAE;gBAC3C,CAAC,CAAC,EAAE,iBAAiB,EAAE,IAAI,CAAC,YAAY,EAAE,CAAC;YAC7C,GAAG,OAAO;SACX,CAAC,CAAC;IACL,CAAC;IAED,sBAAsB,CAAC,OAAsE;QAC3F,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;QAEhD,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE;YACpB,IAAI,SAAS,EAAE,EAAE;gBACf,OAAO,CAAC,IAAI,CACV,mHAAmH,CACpH,CAAC;aACH;YACD,OAAO;SACR;QAED,MAAM,aAAa,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC;QACpD,MAAM,OAAO,GAAG,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,UAAU,CAAC,aAAa,CAAC;QAElE,eAAe,CAAC;YACd,SAAS,EAAE,aAAa;YACxB,OAAO;YACP,GAAG,CAAC,IAAI,CAAC,SAAS,KAAK,YAAY;gBACjC,CAAC,CAAC,EAAE,kBAAkB,EAAE,IAAI,CAAC,YAAY,EAAE;gBAC3C,CAAC,CAAC,EAAE,iBAAiB,EAAE,IAAI,CAAC,YAAY,EAAE,CAAC;YAC7C,GAAG,OAAO;SACX,CAAC,CAAC;IACL,CAAC;IAES,mBAAmB,CAAC,UAAmB;QAC/C,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IAC3C,CAAC;IAES,mBAAmB,CAAC,WAAsC;QAClE,IAAI,KAAK,CAAC,IAAI,CAAC,YAAY,CAAC,KAAK,EAAE,WAAW,CAAC,EAAE;YAC/C,OAAO;SACR;QAED,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QACpC,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;IAC3C,CAAC;IAES,sBAAsB;QAC9B,IAAI,IAAI,CAAC,UAAU,KAAK,WAAW,EAAE;YACnC,IAAI,CAAC,sBAAsB,CAAC,OAAO,CAAC,CAAC;SACtC;aAAM;YACL,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAC,CAAC;SACjC;IACH,CAAC;IAES,gBAAgB;QACxB,IAAI,IAAI,CAAC,UAAU,KAAK,WAAW,EAAE;YACnC,IAAI,CAAC,sBAAsB,CAAC,KAAK,CAAC,CAAC;SACpC;aAAM;YACL,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC;SAC/B;IACH,CAAC;IAEO,qBAAqB;QAC3B,MAAM,aAAa,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC;QACpD,IAAI,UAAU,GAAG,KAAK,CAAC;QACvB,IAAI,WAAW,GAAG,CAAC,CAAC;QAEpB,KAAK,CAAC,SAAS,CAAa,aAAa,EAAE,OAAO,CAAC,EAAE,SAAS,CAAa,aAAa,EAAE,YAAY,CAAC,CAAC;aACrG,IAAI,CACH,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,EACzB,GAAG,CAAC,GAAG,EAAE;YACP,UAAU,GAAG,KAAK,CAAC;QACrB,CAAC,CAAC,CACH;aACA,SAAS,EAAE,CAAC;QAEf,KAAK,CACH,SAAS,CAAC,aAAa,EAAE,QAAQ,CAAC,EAClC,IAAI,CAAC,kBAAkB,EACvB,IAAI,CAAC,QAAQ,EAAE,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,IAAI,EAAE,CAAC,IAAI,CAAC,CAClE;aACE,IAAI,CACH,YAAY,CAAC,GAAG,CAAC,EACjB,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,EACzB,GAAG,CAAC,GAAG,EAAE;YACP,MAAM,QAAQ,GACZ,IAAI,CAAC,QAAQ;gBACX,EAAE,OAAO,EAAE;iBACV,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,UAAU,CAAC,aAAa,CAAC;iBACvC,MAAM,CAAC,CAAC,CAAC,EAAoB,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC;YAEhD,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE;gBACpB,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;gBAEvC,OAAO;aACR;YAED,MAAM,MAAM,GAAG,uBAAuB,CAAC;gBACrC,QAAQ;gBACR,SAAS,EAAE,aAAa;aACzB,CAAC,CAAC;YAEH,MAAM,IAAI,GAAG,IAAI,CAAC,SAAS,KAAK,YAAY,CAAC,CAAC,CAAC,oBAAoB,CAAC,CAAC,CAAC,mBAAmB,CAAC;YAC1F,MAAM,UAAU,GAAG,6BAA6B,CAAC;YAEjD,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE;gBAC1B,IAAI,KAAK,CAAC,IAAI,CAAC,KAAK,GAAG,EAAE;oBACvB,KAAK,CAAC,OAAO,CAAC,SAAS,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;iBACzC;qBAAM;oBACL,KAAK,CAAC,OAAO,CAAC,SAAS,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;iBAC5C;aACF;YAED,MAAM,mBAAmB,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;gBAC9C,MAAM,KAAK,GAAiC;oBAC1C,OAAO,EAAE,CAAC,CAAC,OAAO;oBAClB,iBAAiB,EAAE,CAAC,CAAC,IAAI,CAAC,GAAG,GAAG;oBAChC,cAAc,EAAE,CAAC,CAAC,IAAI,CAAC,KAAK,GAAG;oBAC/B,KAAK,EAAE,CAAC;iBACT,CAAC;gBAEF,OAAO,KAAK,CAAC;YACf,CAAC,CAAC,CAAC;YAEH,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;YAElD,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;YAExD,IAAI,UAAU,IAAI,IAAI,CAAC,kBAAkB,CAAC,KAAK,IAAI,CAAC,IAAI,CAAC,IAAI;gBAAE,OAAO;YAEtE,MAAM,IAAI,GAAG,IAAI,CAAC,2BAA2B,CAAC;YAC9C,MAAM,IAAI,GAAG,IAAI,CAAC,uBAAuB,CAAC;YAC1C,MAAM,QAAQ,GACZ,CAAC,IAAI;gBACL,CAAC,IAAI;gBACL,IAAI,CAAC,iBAAiB,KAAK,CAAC;gBAC5B,IAAI,CAAC,iBAAiB,KAAK,CAAC;gBAC5B,IAAI,CAAC,iBAAiB,KAAK,IAAI,CAAC,iBAAiB,CAAC;YAEpD,IAAI,QAAQ;gBAAE,OAAO;YAErB,MAAM,mBAAmB,GAAG,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC;YAC1F,MAAM,qBAAqB,GAAG,IAAI,CAAC,0BAA0B,EAAE,KAAK,CAAC;YAErE,IAAI,qBAAqB,KAAK,SAAS;gBAAE,OAAO;YAEhD,MAAM,wBAAwB,GAAG,mBAAmB,CAAC,KAAK,CAAC;YAC3D,MAAM,MAAM,GAAG,wBAAwB,GAAG,qBAAqB,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC;YAElF,eAAe,CAAC;gBACd,SAAS,EAAE,aAAa;gBACxB,OAAO,EAAE,mBAAmB,CAAC,OAAO;gBACpC,SAAS,EAAE,IAAI,CAAC,SAAS,KAAK,YAAY,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,OAAO;gBAC/D,MAAM;gBACN,iBAAiB,EAAE,IAAI,CAAC,SAAS,KAAK,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY;gBAC1E,kBAAkB,EAAE,IAAI,CAAC,SAAS,KAAK,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;aAC5E,CAAC,CAAC;YAEH,UAAU,GAAG,IAAI,CAAC;YAElB,MAAM,CAAC,YAAY,CAAC,WAAW,CAAC,CAAC;YAEjC,WAAW,GAAG,MAAM,CAAC,UAAU,CAAC,GAAG,EAAE;gBACnC,UAAU,GAAG,KAAK,CAAC;YACrB,CAAC,EAAE,IAAI,CAAC,CAAC;QACX,CAAC,CAAC,CACH;aACA,SAAS,EAAE,CAAC;IACjB,CAAC;8GApZU,mBAAmB;kGAAnB,mBAAmB,2NAsBV,gBAAgB,qDAGhB,gBAAgB,8DAGhB,gBAAgB,qDAIhB,gBAAgB,8DAIhB,gBAAgB,qGAGhB,gBAAgB,oDAMhB,gBAAgB,kDAGhB,eAAe,6XAYlB,iBAAiB,8DAGjB,UAAU,wKCpH7B,inCAuCA,guJDSY,yBAAyB,wNAAE,2BAA2B,uLAAE,OAAO,oFAAE,IAAI,6FAAgB,oBAAoB;;2FAKxG,mBAAmB;kBAZ/B,SAAS;+BACE,eAAe,cAGb,IAAI,iBACD,iBAAiB,CAAC,IAAI,mBACpB,uBAAuB,CAAC,MAAM,WACtC,CAAC,yBAAyB,EAAE,2BAA2B,EAAE,OAAO,EAAE,IAAI,EAAE,YAAY,EAAE,oBAAoB,CAAC,QAC9G;wBACJ,KAAK,EAAE,eAAe;qBACvB;8BAYD,QAAQ;sBAFP,KAAK;;sBACL,WAAW;uBAAC,gBAAgB;gBAK7B,SAAS;sBAFR,KAAK;;sBACL,WAAW;uBAAC,gBAAgB;gBAI7B,cAAc;sBADb,KAAK;gBAIN,eAAe;sBADd,KAAK;gBAIN,WAAW;sBADV,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE;gBAItC,aAAa;sBADZ,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE;gBAKtC,gBAAgB;sBAFf,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE;;sBACrC,WAAW;uBAAC,wBAAwB;gBAKrC,aAAa;sBAFZ,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE;;sBACrC,WAAW;uBAAC,qBAAqB;gBAIlC,gBAAgB;sBADf,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE;gBAItC,6BAA6B;sBAD5B,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE;gBAItC,UAAU;sBADT,KAAK;gBAIN,IAAI;sBADH,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE;gBAItC,YAAY;sBADX,KAAK;uBAAC,EAAE,SAAS,EAAE,eAAe,EAAE;gBAI5B,iBAAiB;sBADzB,MAAM;gBAIE,kBAAkB;sBAD1B,MAAM;gBAIP,UAAU;sBADT,SAAS;uBAAC,YAAY,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBAIzC,cAAc;sBADb,eAAe;uBAAC,iBAAiB,EAAE,EAAE,WAAW,EAAE,IAAI,EAAE;gBAIzD,QAAQ;sBADP,eAAe;uBAAC,UAAU,EAAE,EAAE,WAAW,EAAE,IAAI,EAAE","sourcesContent":["import { NgClass, NgIf } from '@angular/common';\nimport {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  Component,\n  ContentChildren,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  Input,\n  OnInit,\n  Output,\n  Renderer2,\n  ViewChild,\n  ViewEncapsulation,\n  booleanAttribute,\n  inject,\n  isDevMode,\n  numberAttribute,\n} from '@angular/core';\nimport {\n  CursorDragScrollDirective,\n  IS_ACTIVE_ELEMENT,\n  IS_ELEMENT,\n  IsActiveElementDirective,\n  IsElementDirective,\n  LetDirective,\n  NgClassType,\n  ObserveScrollStateDirective,\n  ScrollObserverScrollState,\n  ScrollToElementOptions,\n  TypedQueryList,\n  createDestroy,\n  equal,\n  getElementVisibleStates,\n  scrollToElement,\n} from '@ethlete/core';\nimport { BehaviorSubject, debounceTime, fromEvent, merge, of, startWith, takeUntil, tap } from 'rxjs';\nimport { ChevronIconComponent } from '../../../icons';\nimport { ScrollableIntersectionChange, ScrollableScrollMode } from '../../types';\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: [CursorDragScrollDirective, ObserveScrollStateDirective, NgClass, NgIf, LetDirective, ChevronIconComponent],\n  host: {\n    class: 'et-scrollable',\n  },\n})\nexport class ScrollableComponent implements OnInit, AfterContentInit {\n  private readonly _destroy$ = createDestroy();\n  private readonly _renderer = inject(Renderer2);\n  private readonly _elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n\n  private readonly _isCursorDragging$ = new BehaviorSubject<boolean>(false);\n  private readonly _latestVisibilityStates$ = new BehaviorSubject<ScrollableIntersectionChange[]>([]);\n\n  @Input()\n  @HostBinding('attr.item-size')\n  itemSize: 'auto' | 'same' | 'full' = 'auto';\n\n  @Input()\n  @HostBinding('attr.direction')\n  direction: 'horizontal' | 'vertical' = 'horizontal';\n\n  @Input()\n  scrollableRole?: string;\n\n  @Input()\n  scrollableClass?: NgClassType;\n\n  @Input({ transform: booleanAttribute })\n  renderMasks = true;\n\n  @Input({ transform: booleanAttribute })\n  renderButtons = true;\n\n  @Input({ transform: booleanAttribute })\n  @HostBinding('attr.render-scrollbars')\n  renderScrollbars = false;\n\n  @Input({ transform: booleanAttribute })\n  @HostBinding('attr.sticky-buttons')\n  stickyButtons = false;\n\n  @Input({ transform: booleanAttribute })\n  cursorDragScroll = true;\n\n  @Input({ transform: booleanAttribute })\n  disableActiveElementScrolling = false;\n\n  @Input()\n  scrollMode: ScrollableScrollMode = 'container';\n\n  @Input({ transform: booleanAttribute })\n  snap = false;\n\n  @Input({ transform: numberAttribute })\n  scrollMargin = 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  scrollable!: ElementRef<HTMLElement>;\n\n  @ContentChildren(IS_ACTIVE_ELEMENT, { descendants: true })\n  activeElements: TypedQueryList<IsActiveElementDirective> | null = null;\n\n  @ContentChildren(IS_ELEMENT, { descendants: true })\n  elements: TypedQueryList<IsElementDirective> | null = null;\n\n  get highestVisibleIntersection() {\n    const elements = this._latestVisibilityStates$.value;\n\n    if (!elements.length) {\n      return null;\n    }\n\n    return elements.reduce((prev, curr) => {\n      if (!prev) {\n        return curr;\n      }\n\n      return curr.intersectionRatio > prev.intersectionRatio ? curr : prev;\n    });\n  }\n\n  get nextPartialIntersection() {\n    const elements = this._latestVisibilityStates$.value;\n\n    if (!elements.length) {\n      return null;\n    }\n\n    const highestVisibleIntersection = this.highestVisibleIntersection;\n\n    if (!highestVisibleIntersection) {\n      return null;\n    }\n\n    const nextIndex = elements.slice(highestVisibleIntersection.index).findIndex((e) => !e.isIntersecting);\n\n    if (nextIndex === -1) {\n      return null;\n    }\n\n    const nextElement = elements[highestVisibleIntersection.index + nextIndex];\n\n    return nextElement || null;\n  }\n\n  get previousPartialIntersection() {\n    const elements = this._latestVisibilityStates$.value;\n\n    if (!elements.length) {\n      return null;\n    }\n\n    const highestVisibleIntersection = this.highestVisibleIntersection;\n\n    if (!highestVisibleIntersection) {\n      return null;\n    }\n\n    const previousIndex = elements\n      .slice(0, highestVisibleIntersection.index)\n      .reverse()\n      .findIndex((e) => !e.isIntersecting);\n\n    if (previousIndex === -1) {\n      return null;\n    }\n\n    const previousElement = elements[highestVisibleIntersection.index - previousIndex - 1];\n\n    return previousElement || null;\n  }\n\n  protected readonly scrollState$ = new BehaviorSubject<ScrollObserverScrollState | null>(null);\n\n  ngOnInit(): void {\n    this.scrollState$\n      .pipe(\n        tap((state) => {\n          if (!state) {\n            return;\n          }\n\n          const element = this._elementRef.nativeElement;\n\n          this._renderer.setAttribute(element, 'at-start', state.isAtStart.toString());\n          this._renderer.setAttribute(element, 'at-end', state.isAtEnd.toString());\n          this._renderer.setAttribute(element, 'can-scroll', state.canScroll.toString());\n        }),\n        takeUntil(this._destroy$),\n      )\n      .subscribe();\n  }\n\n  ngAfterContentInit(): void {\n    if (!this.activeElements || !this.elements) {\n      return;\n    }\n\n    this.activeElements.changes\n      .pipe(\n        startWith(this.activeElements),\n        tap((activeElements) => {\n          if (this.disableActiveElementScrolling) {\n            return;\n          }\n\n          const firstActive = activeElements\n            .filter((a): a is IsActiveElementDirective => !!a)\n            .find((a) => a.isActiveElement);\n\n          if (!firstActive) {\n            return;\n          }\n\n          scrollToElement({\n            behavior: 'auto',\n            container: this.scrollable.nativeElement,\n            element: firstActive.elementRef.nativeElement,\n            scrollInlineMargin: this.direction === 'horizontal' ? this.scrollMargin : 0,\n            scrollBlockMargin: this.direction === 'horizontal' ? 0 : this.scrollMargin,\n          });\n        }),\n        takeUntil(this._destroy$),\n      )\n      .subscribe();\n\n    this._setupScrollListening();\n  }\n\n  scrollOneContainerSize(direction: 'start' | 'end') {\n    const scrollElement = this.scrollable.nativeElement;\n    const parent = this._elementRef.nativeElement;\n\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  scrollOneItemSize(direction: 'start' | 'end') {\n    const elements = this._latestVisibilityStates$.value;\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 el = direction === 'start' ? this.previousPartialIntersection : this.nextPartialIntersection;\n\n    if (!el) {\n      return;\n    }\n\n    this.scrollToElement({\n      element: el?.element,\n      direction: this.direction === 'horizontal' ? 'inline' : 'block',\n      origin: direction,\n      ...(this.direction === 'horizontal'\n        ? { scrollInlineMargin: this.scrollMargin }\n        : { scrollBlockMargin: this.scrollMargin }),\n    });\n  }\n\n  scrollToElement(options: Omit<ScrollToElementOptions, 'container'>) {\n    const scrollElement = this.scrollable.nativeElement;\n\n    scrollToElement({\n      container: scrollElement,\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.elements?.toArray() ?? [];\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]?.elementRef.nativeElement;\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 setIsCursorDragging(isDragging: boolean) {\n    this._isCursorDragging$.next(isDragging);\n  }\n\n  protected _scrollStateChanged(scrollState: ScrollObserverScrollState) {\n    if (equal(this.scrollState$.value, scrollState)) {\n      return;\n    }\n\n    this.scrollState$.next(scrollState);\n    this.scrollStateChange.emit(scrollState);\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 scrollToStartEnd() {\n    if (this.scrollMode === 'container') {\n      this.scrollOneContainerSize('end');\n    } else {\n      this.scrollOneItemSize('end');\n    }\n  }\n\n  private _setupScrollListening() {\n    const scrollElement = this.scrollable.nativeElement;\n    let isSnapping = false;\n    let snapTimeout = 0;\n\n    merge(fromEvent<WheelEvent>(scrollElement, 'wheel'), fromEvent<TouchEvent>(scrollElement, 'touchstart'))\n      .pipe(\n        takeUntil(this._destroy$),\n        tap(() => {\n          isSnapping = false;\n        }),\n      )\n      .subscribe();\n\n    merge(\n      fromEvent(scrollElement, 'scroll'),\n      this._isCursorDragging$,\n      this.elements?.changes.pipe(startWith(this.elements)) ?? of(null),\n    )\n      .pipe(\n        debounceTime(300),\n        takeUntil(this._destroy$),\n        tap(() => {\n          const elements =\n            this.elements\n              ?.toArray()\n              .map((e) => e?.elementRef.nativeElement)\n              .filter((e): e is HTMLElement => !!e) ?? [];\n\n          if (!elements.length) {\n            this._latestVisibilityStates$.next([]);\n\n            return;\n          }\n\n          const states = getElementVisibleStates({\n            elements,\n            container: scrollElement,\n          });\n\n          const prop = this.direction === 'horizontal' ? 'inlineIntersection' : 'blockIntersection';\n          const stateClass = `et-element--is-intersecting`;\n\n          for (const state of states) {\n            if (state[prop] === 100) {\n              state.element.classList.add(stateClass);\n            } else {\n              state.element.classList.remove(stateClass);\n            }\n          }\n\n          const intersectionChanges = states.map((s, i) => {\n            const state: ScrollableIntersectionChange = {\n              element: s.element,\n              intersectionRatio: s[prop] / 100,\n              isIntersecting: s[prop] === 100,\n              index: i,\n            };\n\n            return state;\n          });\n\n          this.intersectionChange.emit(intersectionChanges);\n\n          this._latestVisibilityStates$.next(intersectionChanges);\n\n          if (isSnapping || this._isCursorDragging$.value || !this.snap) return;\n\n          const prev = this.previousPartialIntersection;\n          const next = this.nextPartialIntersection;\n          const skipSnap =\n            !prev ||\n            !next ||\n            prev.intersectionRatio === 0 ||\n            next.intersectionRatio === 0 ||\n            prev.intersectionRatio === next.intersectionRatio;\n\n          if (skipSnap) return;\n\n          const highestIntersecting = prev.intersectionRatio > next.intersectionRatio ? prev : next;\n          const fullIntersectionIndex = this.highestVisibleIntersection?.index;\n\n          if (fullIntersectionIndex === undefined) return;\n\n          const highestIntersectingIndex = highestIntersecting.index;\n          const origin = highestIntersectingIndex > fullIntersectionIndex ? 'end' : 'start';\n\n          scrollToElement({\n            container: scrollElement,\n            element: highestIntersecting.element,\n            direction: this.direction === 'horizontal' ? 'inline' : 'block',\n            origin,\n            scrollBlockMargin: this.direction === 'horizontal' ? 0 : this.scrollMargin,\n            scrollInlineMargin: this.direction === 'horizontal' ? this.scrollMargin : 0,\n          });\n\n          isSnapping = true;\n\n          window.clearTimeout(snapTimeout);\n\n          snapTimeout = window.setTimeout(() => {\n            isSnapping = false;\n          }, 1000);\n        }),\n      )\n      .subscribe();\n  }\n}\n","<div\n  #scrollable\n  [attr.role]=\"scrollableRole ?? undefined\"\n  [ngClass]=\"scrollableClass\"\n  [etCursorDragScroll]=\"cursorDragScroll\"\n  [allowedDirection]=\"direction\"\n  (etObserveScrollState)=\"_scrollStateChanged($event)\"\n  (cursorDragStart)=\"setIsCursorDragging(true)\"\n  (cursorDragEnd)=\"setIsCursorDragging(false)\"\n  class=\"et-scrollable-container\"\n>\n  <ng-content />\n</div>\n\n<div *ngIf=\"renderMasks\" 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<div *ngIf=\"renderButtons\" 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)=\"scrollToStartEnd()\"\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"]}
|