@ethlete/cdk 2.7.0 → 2.7.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +6 -0
- package/esm2022/lib/components/accordion/components/accordion/accordion.component.mjs +10 -21
- package/esm2022/lib/components/accordion/components/accordion-group/accordion-group.component.mjs +6 -12
- package/esm2022/lib/components/button/directives/button/button.directive.mjs +4 -5
- package/esm2022/lib/components/forms/components/input/components/textarea-input/textarea-input.component.mjs +9 -20
- package/esm2022/lib/components/forms/components/label/directives/label-suffix/label-suffix.directive.mjs +6 -12
- package/esm2022/lib/components/forms/components/radio/directives/radio/radio.directive.mjs +3 -4
- package/esm2022/lib/components/forms/components/segmented-button/directives/segmented-button/segmented-button.directive.mjs +3 -4
- package/esm2022/lib/components/forms/components/select/components/combobox/components/combobox/combobox.component.mjs +6 -7
- package/esm2022/lib/components/forms/components/select/components/native-select/directives/native-select-option/native-select-option.directive.mjs +9 -20
- package/esm2022/lib/components/forms/components/select/components/select/directives/select/select.directive.mjs +3 -4
- package/esm2022/lib/components/forms/components/select/components/select/directives/select-option/select-option.directive.mjs +3 -4
- package/esm2022/lib/components/forms/components/slider/components/slider/slider.component.mjs +8 -9
- package/esm2022/lib/components/forms/directives/dynamic-form-field/dynamic-form-field.directive.mjs +3 -4
- package/esm2022/lib/components/forms/directives/dynamic-form-group/dynamic-form-group.directive.mjs +3 -4
- package/esm2022/lib/components/masonry/components/masonry/masonry.component.mjs +5 -6
- package/esm2022/lib/components/overlay/components/toggletip/directives/toggletip/toggletip.directive.mjs +3 -4
- package/esm2022/lib/components/overlay/services/dynamic-overlay.service.mjs +8 -10
- package/esm2022/lib/components/pagination/components/pagination/pagination.component.mjs +7 -7
- package/esm2022/lib/components/picture/picture-data.directive.mjs +6 -12
- package/esm2022/lib/components/progress-spinner/progress-spinner.component.mjs +11 -22
- package/esm2022/lib/components/scrollable/components/scrollable/scrollable.component.mjs +5 -3
- package/esm2022/lib/components/skeleton/components/skeleton/skeleton.component.mjs +6 -12
- package/esm2022/lib/components/sort/components/sort-header/sort-header.component.mjs +23 -48
- package/esm2022/lib/components/sort/partials/sort/sort.directive.mjs +17 -35
- package/esm2022/lib/components/table/components/table/table.component.mjs +4 -5
- package/esm2022/lib/components/table/partials/table-busy/table-busy.directive.mjs +6 -6
- package/esm2022/lib/components/table/partials/table-busy-outlet/table-busy-outlet.directive.mjs +7 -7
- package/esm2022/lib/components/tabs/components/inline-tabs/inline-tabs.component.mjs +40 -69
- package/esm2022/lib/components/tabs/components/nav-tabs/nav-tabs.component.mjs +8 -16
- package/esm2022/lib/components/tabs/partials/inline-tabs/inline-tab/inline-tab.component.mjs +9 -20
- package/esm2022/lib/components/tabs/partials/inline-tabs/inline-tab-body/inline-tab-body.component.mjs +14 -16
- package/esm2022/lib/components/tabs/partials/inline-tabs/inline-tab-content/inline-tab-content.directive.mjs +6 -6
- package/esm2022/lib/components/tabs/partials/inline-tabs/inline-tab-header/inline-tab-header.component.mjs +4 -13
- package/esm2022/lib/components/tabs/partials/inline-tabs/inline-tab-label-wrapper/inline-tab-label-wrapper.directive.mjs +10 -16
- package/esm2022/lib/components/tabs/partials/nav-tabs/nav-tab-link/nav-tab-link.directive.mjs +23 -42
- package/esm2022/lib/components/tabs/utils/active-tab-underline.util.mjs +3 -4
- package/esm2022/lib/components/tabs/utils/paginated-tab-header.directive.mjs +24 -44
- package/fesm2022/ethlete-cdk.mjs +253 -433
- package/fesm2022/ethlete-cdk.mjs.map +1 -1
- package/lib/components/accordion/components/accordion/accordion.component.d.ts +4 -7
- package/lib/components/accordion/components/accordion-group/accordion-group.component.d.ts +2 -4
- package/lib/components/button/directives/button/button.directive.d.ts +2 -3
- package/lib/components/forms/components/input/components/textarea-input/textarea-input.component.d.ts +4 -7
- package/lib/components/forms/components/label/directives/label-suffix/label-suffix.directive.d.ts +2 -4
- package/lib/components/forms/components/radio/directives/radio/radio.directive.d.ts +1 -2
- package/lib/components/forms/components/segmented-button/directives/segmented-button/segmented-button.directive.d.ts +1 -2
- package/lib/components/forms/components/select/components/combobox/components/combobox/combobox.component.d.ts +4 -5
- package/lib/components/forms/components/select/components/native-select/directives/native-select-option/native-select-option.directive.d.ts +4 -7
- package/lib/components/forms/components/select/components/select/directives/select/select.directive.d.ts +1 -2
- package/lib/components/forms/components/select/components/select/directives/select-option/select-option.directive.d.ts +1 -2
- package/lib/components/forms/components/slider/components/slider/slider.component.d.ts +5 -6
- package/lib/components/forms/directives/dynamic-form-field/dynamic-form-field.directive.d.ts +1 -2
- package/lib/components/forms/directives/dynamic-form-group/dynamic-form-group.directive.d.ts +1 -2
- package/lib/components/masonry/components/masonry/masonry.component.d.ts +2 -3
- package/lib/components/overlay/components/toggletip/directives/toggletip/toggletip.directive.d.ts +1 -2
- package/lib/components/overlay/services/dynamic-overlay.service.d.ts +3 -6
- package/lib/components/pagination/components/pagination/pagination.component.d.ts +3 -3
- package/lib/components/picture/picture-data.directive.d.ts +2 -4
- package/lib/components/progress-spinner/progress-spinner.component.d.ts +6 -9
- package/lib/components/skeleton/components/skeleton/skeleton.component.d.ts +2 -4
- package/lib/components/sort/components/sort-header/sort-header.component.d.ts +17 -21
- package/lib/components/sort/partials/sort/sort.directive.d.ts +7 -11
- package/lib/components/table/components/table/table.component.d.ts +1 -2
- package/lib/components/table/partials/table-busy/table-busy.directive.d.ts +1 -2
- package/lib/components/table/partials/table-busy-outlet/table-busy-outlet.directive.d.ts +1 -2
- package/lib/components/tabs/components/inline-tabs/inline-tabs.component.d.ts +14 -23
- package/lib/components/tabs/components/nav-tabs/nav-tabs.component.d.ts +2 -7
- package/lib/components/tabs/partials/inline-tabs/inline-tab/inline-tab.component.d.ts +4 -7
- package/lib/components/tabs/partials/inline-tabs/inline-tab-body/inline-tab-body.component.d.ts +5 -4
- package/lib/components/tabs/partials/inline-tabs/inline-tab-content/inline-tab-content.directive.d.ts +1 -2
- package/lib/components/tabs/partials/inline-tabs/inline-tab-header/inline-tab-header.component.d.ts +2 -5
- package/lib/components/tabs/partials/inline-tabs/inline-tab-label-wrapper/inline-tab-label-wrapper.directive.d.ts +3 -6
- package/lib/components/tabs/partials/nav-tabs/nav-tab-link/nav-tab-link.directive.d.ts +13 -17
- package/lib/components/tabs/utils/active-tab-underline.util.d.ts +1 -2
- package/lib/components/tabs/utils/paginated-tab-header.directive.d.ts +11 -16
- package/package.json +3 -4
|
@@ -181,6 +181,8 @@ export class ScrollableComponent {
|
|
|
181
181
|
?.toArray()
|
|
182
182
|
.map((e) => e?.elementRef.nativeElement)
|
|
183
183
|
.filter((e) => !!e) ?? [];
|
|
184
|
+
if (!elements.length)
|
|
185
|
+
return;
|
|
184
186
|
const states = getElementVisibleStates({
|
|
185
187
|
elements,
|
|
186
188
|
container: scrollElement,
|
|
@@ -204,7 +206,7 @@ export class ScrollableComponent {
|
|
|
204
206
|
};
|
|
205
207
|
return state;
|
|
206
208
|
}));
|
|
207
|
-
if (isSnapping || this._isCursorDragging$.value)
|
|
209
|
+
if (isSnapping || this._isCursorDragging$.value || !this.snap)
|
|
208
210
|
return;
|
|
209
211
|
const isOnlyOnePartialIntersection = states.filter((s) => s[prop] < 100 && s[prop] > 0).length === 1;
|
|
210
212
|
if (isOnlyOnePartialIntersection)
|
|
@@ -237,7 +239,7 @@ export class ScrollableComponent {
|
|
|
237
239
|
.subscribe();
|
|
238
240
|
}
|
|
239
241
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.0", ngImport: i0, type: ScrollableComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
240
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.0", type: ScrollableComponent, isStandalone: true, selector: "et-scrollable", inputs: { itemSize: "itemSize", direction: "direction", scrollableRole: "scrollableRole", scrollableClass: "scrollableClass", 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", snap: ["snap", "snap", booleanAttribute], scrollMargin: ["scrollMargin", "scrollMargin", numberAttribute] }, outputs: { scrollStateChange: "scrollStateChange", intersectionChange: "intersectionChange" }, host: { properties: { "attr.item-size": "this.itemSize", "attr.direction": "this.direction", "attr.render-scrollbars": "this.renderScrollbars", "attr.sticky-buttons": "this.stickyButtons" }, classAttribute: "et-scrollable" }, queries: [{ propertyName: "activeElements", predicate: IS_ACTIVE_ELEMENT, descendants: true }, { propertyName: "elements", predicate: IS_ELEMENT, descendants: true }], viewQueries: [{ propertyName: "scrollable", first: true, predicate: ["scrollable"], descendants: true, static: true }], ngImport: i0, template: "<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", styles: [".et-scrollable{--mask: #121212 0, transparent 100%;--mask-size: 25px;--_auto-size: min-content;--_flow: column;display:grid;position:relative}.et-scrollable[item-size=same]{--auto-size: 1fr}.et-scrollable[render-scrollbars=false] .et-scrollable-container{scrollbar-width:none}.et-scrollable[render-scrollbars=false] .et-scrollable-container::-webkit-scrollbar{display:none}.et-scrollable[direction=horizontal] .et-scrollable-container{grid-auto-columns:var(--_auto-size);overflow-x:auto;overflow-y:hidden}.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=vertical]{--_flow: row}.et-scrollable[direction=vertical] .et-scrollable-container{grid-auto-rows:var(--_auto-size);overflow-x:hidden;overflow-y:auto}.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[at-start=false] .et-scrollable-masks .et-scrollable-mask--start,.et-scrollable[at-start=false] .et-scrollable-buttons .et-scrollable-button--start{opacity:1}.et-scrollable[at-start=false] .et-scrollable-buttons .et-scrollable-button--start{pointer-events:all}.et-scrollable[at-end=false] .et-scrollable-masks .et-scrollable-mask--end,.et-scrollable[at-end=false] .et-scrollable-buttons .et-scrollable-button--end{opacity:1}.et-scrollable[at-end=false] .et-scrollable-buttons .et-scrollable-button--end{pointer-events:all}.et-scrollable .et-scrollable-container{display:grid;grid-auto-flow:var(--_flow);overflow:auto;grid-row:1/1;grid-column:1/1}.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;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] .et-scrollable-buttons{margin-block:10%}.et-scrollable[sticky-buttons=true] .et-scrollable-buttons .et-scrollable-button{position:sticky}\n"], dependencies: [{ kind: "directive", type: CursorDragScrollDirective, selector: "[etCursorDragScroll]", inputs: ["etCursorDragScroll", "allowedDirection"], outputs: ["cursorDragStart", "cursorDragMove", "cursorDragEnd"], exportAs: ["etCursorDragScroll"] }, { kind: "directive", type: ObserveScrollStateDirective, selector: "[etObserveScrollState]", inputs: ["
|
|
242
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.0", type: ScrollableComponent, isStandalone: true, selector: "et-scrollable", inputs: { itemSize: "itemSize", direction: "direction", scrollableRole: "scrollableRole", scrollableClass: "scrollableClass", 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", snap: ["snap", "snap", booleanAttribute], scrollMargin: ["scrollMargin", "scrollMargin", numberAttribute] }, outputs: { scrollStateChange: "scrollStateChange", intersectionChange: "intersectionChange" }, host: { properties: { "attr.item-size": "this.itemSize", "attr.direction": "this.direction", "attr.render-scrollbars": "this.renderScrollbars", "attr.sticky-buttons": "this.stickyButtons" }, classAttribute: "et-scrollable" }, queries: [{ propertyName: "activeElements", predicate: IS_ACTIVE_ELEMENT, descendants: true }, { propertyName: "elements", predicate: IS_ELEMENT, descendants: true }], viewQueries: [{ propertyName: "scrollable", first: true, predicate: ["scrollable"], descendants: true, static: true }], ngImport: i0, template: "<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", styles: [".et-scrollable{--mask: #121212 0, transparent 100%;--mask-size: 25px;--_auto-size: min-content;--_flow: column;display:grid;position:relative}.et-scrollable[item-size=same]{--auto-size: 1fr}.et-scrollable[render-scrollbars=false] .et-scrollable-container{scrollbar-width:none}.et-scrollable[render-scrollbars=false] .et-scrollable-container::-webkit-scrollbar{display:none}.et-scrollable[direction=horizontal] .et-scrollable-container{grid-auto-columns:var(--_auto-size);overflow-x:auto;overflow-y:hidden}.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=vertical]{--_flow: row}.et-scrollable[direction=vertical] .et-scrollable-container{grid-auto-rows:var(--_auto-size);overflow-x:hidden;overflow-y:auto}.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[at-start=false] .et-scrollable-masks .et-scrollable-mask--start,.et-scrollable[at-start=false] .et-scrollable-buttons .et-scrollable-button--start{opacity:1}.et-scrollable[at-start=false] .et-scrollable-buttons .et-scrollable-button--start{pointer-events:all}.et-scrollable[at-end=false] .et-scrollable-masks .et-scrollable-mask--end,.et-scrollable[at-end=false] .et-scrollable-buttons .et-scrollable-button--end{opacity:1}.et-scrollable[at-end=false] .et-scrollable-buttons .et-scrollable-button--end{pointer-events:all}.et-scrollable .et-scrollable-container{display:grid;grid-auto-flow:var(--_flow);overflow:auto;grid-row:1/1;grid-column:1/1}.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;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] .et-scrollable-buttons{margin-block:10%}.et-scrollable[sticky-buttons=true] .et-scrollable-buttons .et-scrollable-button{position:sticky}\n"], dependencies: [{ kind: "directive", type: CursorDragScrollDirective, selector: "[etCursorDragScroll]", inputs: ["etCursorDragScroll", "allowedDirection"], outputs: ["cursorDragStart", "cursorDragMove", "cursorDragEnd"], exportAs: ["etCursorDragScroll"] }, { kind: "directive", type: ObserveScrollStateDirective, selector: "[etObserveScrollState]", inputs: ["rootMargin", "observerThreshold"], outputs: ["etObserveScrollState"], exportAs: ["etObserveScrollState"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: ChevronIconComponent, selector: "et-chevron-icon" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
241
243
|
}
|
|
242
244
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.0", ngImport: i0, type: ScrollableComponent, decorators: [{
|
|
243
245
|
type: Component,
|
|
@@ -304,4 +306,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.0", ngImpor
|
|
|
304
306
|
type: ContentChildren,
|
|
305
307
|
args: [IS_ELEMENT, { descendants: true }]
|
|
306
308
|
}] } });
|
|
307
|
-
//# 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,SAAS,EAAE,SAAS,EAAE,GAAG,EAAE,MAAM,MAAM,CAAC;AAClG,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;QAEnE,uBAAkB,GAAG,IAAI,eAAe,CAAU,KAAK,CAAC,CAAC;QAIjE,aAAQ,GAAoB,MAAM,CAAC;QAInC,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;QAExC,iBAAY,GAAG,IAAI,eAAe,CAAmC,IAAI,CAAC,CAAC;KA0R/F;IAxRC,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;QAEf,IAAI,CAAC,qBAAqB,EAAE,CAAC;IAC/B,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;IACjB,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,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,MAAM,GAAG,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC;QAE9C,MAAM,aAAa,GAAG,IAAI,CAAC,SAAS,KAAK,YAAY,CAAC,CAAC,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC,CAAC,aAAa,CAAC,SAAS,CAAC;QAE3G,MAAM,kBAAkB,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE;YAC/C,IAAI,CAAC,CAAC;gBAAE,OAAO,KAAK,CAAC;YAErB,MAAM,IAAI,GAAG,CAAC,CAAC,UAAU,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC;YAEhE,IAAI,IAAI,CAAC,SAAS,KAAK,YAAY,EAAE;gBACnC,OAAO,SAAS,KAAK,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,GAAG,MAAM,CAAC,WAAW,CAAC;aAChF;iBAAM;gBACL,OAAO,SAAS,KAAK,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC,YAAY,CAAC;aACjF;QACH,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,kBAAkB,CAAC,MAAM,EAAE;YAC9B,OAAO;SACR;QAED,MAAM,oBAAoB,GACxB,SAAS,KAAK,OAAO,CAAC,CAAC,CAAC,kBAAkB,CAAC,kBAAkB,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC,CAAC,CAAC;QAEpG,IAAI,CAAC,oBAAoB,EAAE;YACzB,OAAO;SACR;QAED,MAAM,iBAAiB,GAAG,oBAAoB,CAAC,UAAU,CAAC,aAAa,CAAC;QACxE,MAAM,qBAAqB,GAAG,iBAAiB,CAAC,qBAAqB,EAAE,CAAC;QAExE,MAAM,mBAAmB,GAAG,IAAI,CAAC,SAAS,KAAK,YAAY,CAAC,CAAC,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,CAAC,MAAM,CAAC,YAAY,CAAC;QACvG,MAAM,OAAO,GAAG,IAAI,CAAC,SAAS,KAAK,YAAY,CAAC,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,YAAY,CAAC;QAEzG,MAAM,UAAU,GAAG,OAAO,GAAG,mBAAmB,CAAC;QACjD,MAAM,MAAM,GAAG,UAAU,CAAC,CAAC,CAAC,UAAU,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC/C,MAAM,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,aAAa,GAAG,qBAAqB,CAAC,IAAI,GAAG,MAAM,CAAC,CAAC;QAElF,aAAa,CAAC,QAAQ,CAAC;YACrB,CAAC,IAAI,CAAC,SAAS,KAAK,YAAY,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,EAAE,SAAS;YAC7D,QAAQ,EAAE,QAAQ;SACnB,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,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,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,CAAC,SAAS,CAAC,aAAa,EAAE,QAAQ,CAAC,EAAE,IAAI,CAAC,kBAAkB,CAAC;aAC/D,IAAI,CACH,YAAY,CAAC,EAAE,CAAC,EAChB,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,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,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAC1B,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;gBAClB,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,CACH,CAAC;YAEF,IAAI,UAAU,IAAI,IAAI,CAAC,kBAAkB,CAAC,KAAK;gBAAE,OAAO;YAExD,MAAM,4BAA4B,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,MAAM,KAAK,CAAC,CAAC;YAErG,IAAI,4BAA4B;gBAAE,OAAO;YAEzC,MAAM,mBAAmB,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,OAAO,EAAE,EAAE;gBAC1D,IAAI,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,OAAO,CAAC,IAAI,CAAC,GAAG,GAAG,EAAE;oBACrD,OAAO,OAAO,CAAC;iBAChB;gBAED,OAAO,IAAI,CAAC;YACd,CAAC,CAAC,CAAC;YAEH,MAAM,qBAAqB,GAAG,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC;YACvE,MAAM,wBAAwB,GAAG,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,KAAK,mBAAmB,CAAC,CAAC;YAEpF,MAAM,MAAM,GAAG,wBAAwB,GAAG,qBAAqB,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC;YAElF,IAAI,CAAC,mBAAmB,IAAI,mBAAmB,CAAC,IAAI,CAAC,KAAK,GAAG;gBAAE,OAAO;YAEtE,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;8GA1VU,mBAAmB;kGAAnB,mBAAmB,2NAqBV,gBAAgB,qDAGhB,gBAAgB,8DAGhB,gBAAgB,qDAIhB,gBAAgB,8DAIhB,gBAAgB,qGAGhB,gBAAgB,oDAMhB,gBAAgB,kDAGhB,eAAe,6XAYlB,iBAAiB,8DAGjB,UAAU,wKCnH7B,inCAuCA,6nIDSY,yBAAyB,wNAAE,2BAA2B,+LAAE,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;8BAWD,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, 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 _isCursorDragging$ = new BehaviorSubject<boolean>(false);\n\n  @Input()\n  @HostBinding('attr.item-size')\n  itemSize: 'auto' | 'same' = '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  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.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 parent = this._elementRef.nativeElement;\n\n    const currentScroll = this.direction === 'horizontal' ? scrollElement.scrollLeft : scrollElement.scrollTop;\n\n    const scrollableElements = elements.filter((e) => {\n      if (!e) return false;\n\n      const rect = e.elementRef.nativeElement.getBoundingClientRect();\n\n      if (this.direction === 'horizontal') {\n        return direction === 'start' ? rect.left < 0 : rect.right > parent.clientWidth;\n      } else {\n        return direction === 'start' ? rect.top < 0 : rect.bottom > parent.clientHeight;\n      }\n    });\n\n    if (!scrollableElements.length) {\n      return;\n    }\n\n    const scrollableElementRef =\n      direction === 'start' ? scrollableElements[scrollableElements.length - 1] : scrollableElements[0];\n\n    if (!scrollableElementRef) {\n      return;\n    }\n\n    const scrollableElement = scrollableElementRef.elementRef.nativeElement;\n    const scrollableElementRect = scrollableElement.getBoundingClientRect();\n\n    const scrollContainerSize = this.direction === 'horizontal' ? parent.clientWidth : parent.clientHeight;\n    const docSize = this.direction === 'horizontal' ? document.body.clientWidth : document.body.clientHeight;\n\n    const offsetSize = docSize - scrollContainerSize;\n    const offset = offsetSize ? offsetSize / 2 : 0;\n    const scrollFor = Math.round(currentScroll + scrollableElementRect.left - offset);\n\n    scrollElement.scrollTo({\n      [this.direction === 'horizontal' ? 'left' : 'top']: scrollFor,\n      behavior: 'smooth',\n    });\n  }\n\n  scrollToElement(options: Omit<ScrollToElementOptions, 'container'>) {\n    const scrollElement = this.scrollable.nativeElement;\n\n    scrollToElement({\n      container: scrollElement,\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      ...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$)\n      .pipe(\n        debounceTime(25),\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          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          this.intersectionChange.emit(\n            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\n          if (isSnapping || this._isCursorDragging$.value) return;\n\n          const isOnlyOnePartialIntersection = states.filter((s) => s[prop] < 100 && s[prop] > 0).length === 1;\n\n          if (isOnlyOnePartialIntersection) return;\n\n          const highestIntersecting = states.reduce((prev, current) => {\n            if (current[prop] > prev[prop] && current[prop] < 100) {\n              return current;\n            }\n\n            return prev;\n          });\n\n          const fullIntersectionIndex = states.findIndex((s) => s[prop] === 100);\n          const highestIntersectingIndex = states.findIndex((s) => s === highestIntersecting);\n\n          const origin = highestIntersectingIndex > fullIntersectionIndex ? 'end' : 'start';\n\n          if (!highestIntersecting || highestIntersecting[prop] === 100) return;\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"]}
|
|
309
|
+
//# 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, 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 _isCursorDragging$ = new BehaviorSubject<boolean>(false);\n\n  @Input()\n  @HostBinding('attr.item-size')\n  itemSize: 'auto' | 'same' = '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  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.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 parent = this._elementRef.nativeElement;\n\n    const currentScroll = this.direction === 'horizontal' ? scrollElement.scrollLeft : scrollElement.scrollTop;\n\n    const scrollableElements = elements.filter((e) => {\n      if (!e) return false;\n\n      const rect = e.elementRef.nativeElement.getBoundingClientRect();\n\n      if (this.direction === 'horizontal') {\n        return direction === 'start' ? rect.left < 0 : rect.right > parent.clientWidth;\n      } else {\n        return direction === 'start' ? rect.top < 0 : rect.bottom > parent.clientHeight;\n      }\n    });\n\n    if (!scrollableElements.length) {\n      return;\n    }\n\n    const scrollableElementRef =\n      direction === 'start' ? scrollableElements[scrollableElements.length - 1] : scrollableElements[0];\n\n    if (!scrollableElementRef) {\n      return;\n    }\n\n    const scrollableElement = scrollableElementRef.elementRef.nativeElement;\n    const scrollableElementRect = scrollableElement.getBoundingClientRect();\n\n    const scrollContainerSize = this.direction === 'horizontal' ? parent.clientWidth : parent.clientHeight;\n    const docSize = this.direction === 'horizontal' ? document.body.clientWidth : document.body.clientHeight;\n\n    const offsetSize = docSize - scrollContainerSize;\n    const offset = offsetSize ? offsetSize / 2 : 0;\n    const scrollFor = Math.round(currentScroll + scrollableElementRect.left - offset);\n\n    scrollElement.scrollTo({\n      [this.direction === 'horizontal' ? 'left' : 'top']: scrollFor,\n      behavior: 'smooth',\n    });\n  }\n\n  scrollToElement(options: Omit<ScrollToElementOptions, 'container'>) {\n    const scrollElement = this.scrollable.nativeElement;\n\n    scrollToElement({\n      container: scrollElement,\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      ...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$)\n      .pipe(\n        debounceTime(25),\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) return;\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          this.intersectionChange.emit(\n            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\n          if (isSnapping || this._isCursorDragging$.value || !this.snap) return;\n\n          const isOnlyOnePartialIntersection = states.filter((s) => s[prop] < 100 && s[prop] > 0).length === 1;\n\n          if (isOnlyOnePartialIntersection) return;\n\n          const highestIntersecting = states.reduce((prev, current) => {\n            if (current[prop] > prev[prop] && current[prop] < 100) {\n              return current;\n            }\n\n            return prev;\n          });\n\n          const fullIntersectionIndex = states.findIndex((s) => s[prop] === 100);\n          const highestIntersectingIndex = states.findIndex((s) => s === highestIntersecting);\n\n          const origin = highestIntersectingIndex > fullIntersectionIndex ? 'end' : 'start';\n\n          if (!highestIntersecting || highestIntersecting[prop] === 100) return;\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"]}
|
|
@@ -1,19 +1,12 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { ChangeDetectionStrategy, Component, HostBinding, Input, ViewEncapsulation } from '@angular/core';
|
|
1
|
+
import { ChangeDetectionStrategy, Component, HostBinding, Input, ViewEncapsulation, booleanAttribute, } from '@angular/core';
|
|
3
2
|
import * as i0 from "@angular/core";
|
|
4
3
|
export class SkeletonComponent {
|
|
5
4
|
constructor() {
|
|
6
5
|
this.loadingAllyText = 'Loading...';
|
|
7
|
-
this.
|
|
8
|
-
}
|
|
9
|
-
get animated() {
|
|
10
|
-
return this._animated;
|
|
11
|
-
}
|
|
12
|
-
set animated(value) {
|
|
13
|
-
this._animated = coerceBooleanProperty(value);
|
|
6
|
+
this.animated = true;
|
|
14
7
|
}
|
|
15
8
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.0", ngImport: i0, type: SkeletonComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
16
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.0", type: SkeletonComponent, isStandalone: true, selector: "et-skeleton", inputs: { loadingAllyText: "loadingAllyText", animated: "animated" }, host: { properties: { "class.et-skeleton--animated": "this.animated" }, classAttribute: "et-skeleton" }, ngImport: i0, template: ` <span class="cdk-visually-hidden"> {{ loadingAllyText }} </span> <ng-content />`, isInline: true, styles: [":where(.et-skeleton){--et-skeleton-gradient: linear-gradient( 90deg, rgba(190, 190, 190, 0) 15%, rgba(129, 129, 129, .5) 37%, rgba(190, 190, 190, 0) 63% );--et-skeleton-animation-duration: 3s;--et-skeleton-animation-timing-function: var(--ease-3)}.et-skeleton{display:block;cursor:progress}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
9
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.0", type: SkeletonComponent, isStandalone: true, selector: "et-skeleton", inputs: { loadingAllyText: "loadingAllyText", animated: ["animated", "animated", booleanAttribute] }, host: { properties: { "class.et-skeleton--animated": "this.animated" }, classAttribute: "et-skeleton" }, ngImport: i0, template: ` <span class="cdk-visually-hidden"> {{ loadingAllyText }} </span> <ng-content />`, isInline: true, styles: [":where(.et-skeleton){--et-skeleton-gradient: linear-gradient( 90deg, rgba(190, 190, 190, 0) 15%, rgba(129, 129, 129, .5) 37%, rgba(190, 190, 190, 0) 63% );--et-skeleton-animation-duration: 3s;--et-skeleton-animation-timing-function: var(--ease-3)}.et-skeleton{display:block;cursor:progress}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
17
10
|
}
|
|
18
11
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.0", ngImport: i0, type: SkeletonComponent, decorators: [{
|
|
19
12
|
type: Component,
|
|
@@ -23,9 +16,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.0", ngImpor
|
|
|
23
16
|
}], propDecorators: { loadingAllyText: [{
|
|
24
17
|
type: Input
|
|
25
18
|
}], animated: [{
|
|
26
|
-
type: Input
|
|
19
|
+
type: Input,
|
|
20
|
+
args: [{ transform: booleanAttribute }]
|
|
27
21
|
}, {
|
|
28
22
|
type: HostBinding,
|
|
29
23
|
args: ['class.et-skeleton--animated']
|
|
30
24
|
}] } });
|
|
31
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
25
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2tlbGV0b24uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jZGsvc3JjL2xpYi9jb21wb25lbnRzL3NrZWxldG9uL2NvbXBvbmVudHMvc2tlbGV0b24vc2tlbGV0b24uY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCx1QkFBdUIsRUFDdkIsU0FBUyxFQUNULFdBQVcsRUFDWCxLQUFLLEVBQ0wsaUJBQWlCLEVBQ2pCLGdCQUFnQixHQUNqQixNQUFNLGVBQWUsQ0FBQzs7QUFhdkIsTUFBTSxPQUFPLGlCQUFpQjtJQVg5QjtRQWFFLG9CQUFlLEdBQUcsWUFBWSxDQUFDO1FBSS9CLGFBQVEsR0FBRyxJQUFJLENBQUM7S0FDakI7OEdBUFksaUJBQWlCO2tHQUFqQixpQkFBaUIsZ0lBSVIsZ0JBQWdCLHNJQWIxQixrRkFBa0Y7OzJGQVNqRixpQkFBaUI7a0JBWDdCLFNBQVM7K0JBQ0UsYUFBYSxZQUNiLGtGQUFrRixjQUVoRixJQUFJLG1CQUNDLHVCQUF1QixDQUFDLE1BQU0saUJBQ2hDLGlCQUFpQixDQUFDLElBQUksUUFDL0I7d0JBQ0osS0FBSyxFQUFFLGFBQWE7cUJBQ3JCOzhCQUlELGVBQWU7c0JBRGQsS0FBSztnQkFLTixRQUFRO3NCQUZQLEtBQUs7dUJBQUMsRUFBRSxTQUFTLEVBQUUsZ0JBQWdCLEVBQUU7O3NCQUNyQyxXQUFXO3VCQUFDLDZCQUE2QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxuICBDb21wb25lbnQsXG4gIEhvc3RCaW5kaW5nLFxuICBJbnB1dCxcbiAgVmlld0VuY2Fwc3VsYXRpb24sXG4gIGJvb2xlYW5BdHRyaWJ1dGUsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdldC1za2VsZXRvbicsXG4gIHRlbXBsYXRlOiBgIDxzcGFuIGNsYXNzPVwiY2RrLXZpc3VhbGx5LWhpZGRlblwiPiB7eyBsb2FkaW5nQWxseVRleHQgfX0gPC9zcGFuPiA8bmctY29udGVudCAvPmAsXG4gIHN0eWxlVXJsczogWydza2VsZXRvbi5jb21wb25lbnQuc2NzcyddLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcbiAgaG9zdDoge1xuICAgIGNsYXNzOiAnZXQtc2tlbGV0b24nLFxuICB9LFxufSlcbmV4cG9ydCBjbGFzcyBTa2VsZXRvbkNvbXBvbmVudCB7XG4gIEBJbnB1dCgpXG4gIGxvYWRpbmdBbGx5VGV4dCA9ICdMb2FkaW5nLi4uJztcblxuICBASW5wdXQoeyB0cmFuc2Zvcm06IGJvb2xlYW5BdHRyaWJ1dGUgfSlcbiAgQEhvc3RCaW5kaW5nKCdjbGFzcy5ldC1za2VsZXRvbi0tYW5pbWF0ZWQnKVxuICBhbmltYXRlZCA9IHRydWU7XG59XG4iXX0=
|
|
@@ -1,36 +1,20 @@
|
|
|
1
1
|
import { AriaDescriber, FocusMonitor } from '@angular/cdk/a11y';
|
|
2
|
-
import { coerceBooleanProperty } from '@angular/cdk/coercion';
|
|
3
2
|
import { ENTER, SPACE } from '@angular/cdk/keycodes';
|
|
4
3
|
import { NgIf } from '@angular/common';
|
|
5
|
-
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, HostBinding, HostListener,
|
|
4
|
+
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, HostBinding, HostListener, Input, ViewEncapsulation, booleanAttribute, inject, } from '@angular/core';
|
|
6
5
|
import { merge } from 'rxjs';
|
|
7
6
|
import { ChevronIconComponent } from '../../../icons';
|
|
8
7
|
import { SORT_HEADER_COLUMN_DEF } from '../../../table';
|
|
9
|
-
import { SORT_DEFAULT_OPTIONS, } from '../../partials';
|
|
8
|
+
import { SORT_DEFAULT_OPTIONS, SortDirective } from '../../partials';
|
|
10
9
|
import { SortHeaderIntl } from '../../services';
|
|
11
10
|
import * as i0 from "@angular/core";
|
|
12
|
-
import * as i1 from "../../services";
|
|
13
|
-
import * as i2 from "../../partials";
|
|
14
|
-
import * as i3 from "@angular/cdk/a11y";
|
|
15
11
|
export class SortHeaderComponent {
|
|
16
|
-
get disabled() {
|
|
17
|
-
return this._disabled;
|
|
18
|
-
}
|
|
19
|
-
set disabled(value) {
|
|
20
|
-
this._disabled = coerceBooleanProperty(value);
|
|
21
|
-
}
|
|
22
12
|
get sortActionDescription() {
|
|
23
13
|
return this._sortActionDescription;
|
|
24
14
|
}
|
|
25
15
|
set sortActionDescription(value) {
|
|
26
16
|
this._updateSortActionDescription(value);
|
|
27
17
|
}
|
|
28
|
-
get disableClear() {
|
|
29
|
-
return this._disableClear;
|
|
30
|
-
}
|
|
31
|
-
set disableClear(v) {
|
|
32
|
-
this._disableClear = coerceBooleanProperty(v);
|
|
33
|
-
}
|
|
34
18
|
get _isSorted() {
|
|
35
19
|
if (!this._sort) {
|
|
36
20
|
return false;
|
|
@@ -56,23 +40,24 @@ export class SortHeaderComponent {
|
|
|
56
40
|
}
|
|
57
41
|
return this._sort?.direction == 'asc' ? 'ascending' : 'descending';
|
|
58
42
|
}
|
|
59
|
-
constructor(
|
|
60
|
-
this._intl =
|
|
61
|
-
this._changeDetectorRef =
|
|
62
|
-
this._sort =
|
|
63
|
-
this._columnDef =
|
|
64
|
-
this._focusMonitor =
|
|
65
|
-
this._elementRef =
|
|
66
|
-
this._ariaDescriber =
|
|
43
|
+
constructor() {
|
|
44
|
+
this._intl = inject(SortHeaderIntl);
|
|
45
|
+
this._changeDetectorRef = inject(ChangeDetectorRef);
|
|
46
|
+
this._sort = inject(SortDirective, { optional: true });
|
|
47
|
+
this._columnDef = inject(SORT_HEADER_COLUMN_DEF, { optional: true });
|
|
48
|
+
this._focusMonitor = inject(FocusMonitor);
|
|
49
|
+
this._elementRef = inject(ElementRef);
|
|
50
|
+
this._ariaDescriber = inject(AriaDescriber);
|
|
51
|
+
this._sortDefaultOptions = inject(SORT_DEFAULT_OPTIONS, { optional: true });
|
|
67
52
|
this._showIndicatorHint = false;
|
|
68
53
|
this._viewState = {};
|
|
69
54
|
this._arrowDirection = '';
|
|
70
|
-
this.
|
|
55
|
+
this.disabled = false;
|
|
71
56
|
this.arrowPosition = 'after';
|
|
72
57
|
this._sortActionDescription = 'Sort';
|
|
73
|
-
this.
|
|
74
|
-
if (
|
|
75
|
-
this.arrowPosition =
|
|
58
|
+
this.disableClear = false;
|
|
59
|
+
if (this._sortDefaultOptions?.arrowPosition) {
|
|
60
|
+
this.arrowPosition = this._sortDefaultOptions?.arrowPosition;
|
|
76
61
|
}
|
|
77
62
|
this._handleStateChanges();
|
|
78
63
|
}
|
|
@@ -169,28 +154,17 @@ export class SortHeaderComponent {
|
|
|
169
154
|
this._changeDetectorRef.markForCheck();
|
|
170
155
|
});
|
|
171
156
|
}
|
|
172
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.0", ngImport: i0, type: SortHeaderComponent, deps: [
|
|
173
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.0", type: SortHeaderComponent, isStandalone: true, selector: "[et-sort-header]", inputs: { disabled: "disabled", id: ["et-sort-header", "id"], arrowPosition: "arrowPosition", start: "start", sortActionDescription: "sortActionDescription", disableClear: "disableClear" }, host: { listeners: { "mouseenter": "_handleMouseEnter()", "mouseleave": "_handleMouseLeave()", "click": "_handleClick()", "keydown": "_handleKeydown($event)" }, properties: { "class.et-sort-header-disabled": "this.disabled", "attr.aria-sort": "this._ariaSortAttr" }, classAttribute: "et-sort-header" }, exportAs: ["etSortHeader"], ngImport: i0, template: "<div\n [class.et-sort-header-sorted]=\"_isSorted\"\n [class.et-sort-header-position-before]=\"arrowPosition === 'before'\"\n [attr.tabindex]=\"_isDisabled ? null : 0\"\n [attr.role]=\"_isDisabled ? null : 'button'\"\n class=\"et-sort-header-container\"\n>\n <div class=\"et-sort-header-content\">\n <ng-content />\n </div>\n\n <div *ngIf=\"_renderArrow\" class=\"et-sort-header-arrow {{ _getArrowDirectionState }} {{ _getArrowViewState }}\">\n <et-chevron-icon />\n </div>\n</div>\n", styles: [":where(.et-sort-header){--et-sort-header-arrow-size: 10px;--et-sort-header-gap: 8px}.et-sort-header{cursor:pointer}.et-sort-header.et-sort-header-disabled{cursor:default}.et-sort-header-container{display:flex;align-items:center;letter-spacing:normal;outline:0;gap:var(--et-sort-header-gap)}.et-sort-header-content{text-align:center;display:flex;align-items:center}.et-sort-header-position-before{flex-direction:row-reverse}.et-sort-header:hover .et-sort-header-arrow,.et-sort-header.cdk-keyboard-focused .et-sort-header-arrow{opacity:.5}.et-sort-header .et-sort-header-arrow{transition:opacity .2s var(--ease-out-5)}.et-sort-header .et-sort-header-arrow .et-chevron-icon svg{transition:transform .2s var(--ease-out-5)}.et-sort-header .et-sort-header-arrow{inline-size:var(--et-sort-header-arrow-size);opacity:0}.et-sort-header .et-sort-header-arrow.active-desc,.et-sort-header .et-sort-header-arrow.active-asc{opacity:1}.et-sort-header .et-sort-header-arrow.desc .et-chevron-icon svg,.et-sort-header .et-sort-header-arrow.asc .et-chevron-icon svg,.et-sort-header .et-sort-header-arrow.active-desc .et-chevron-icon svg{transform:rotate(180deg)}.et-sort-header .et-sort-header-arrow.active-asc .et-chevron-icon svg{transform:rotate(0)}\n"], dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: ChevronIconComponent, selector: "et-chevron-icon" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
157
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.0", ngImport: i0, type: SortHeaderComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
158
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.0", type: SortHeaderComponent, isStandalone: true, selector: "[et-sort-header]", inputs: { disabled: ["disabled", "disabled", booleanAttribute], id: ["et-sort-header", "id"], arrowPosition: "arrowPosition", start: "start", sortActionDescription: "sortActionDescription", disableClear: ["disableClear", "disableClear", booleanAttribute] }, host: { listeners: { "mouseenter": "_handleMouseEnter()", "mouseleave": "_handleMouseLeave()", "click": "_handleClick()", "keydown": "_handleKeydown($event)" }, properties: { "class.et-sort-header-disabled": "this.disabled", "attr.aria-sort": "this._ariaSortAttr" }, classAttribute: "et-sort-header" }, exportAs: ["etSortHeader"], ngImport: i0, template: "<div\n [class.et-sort-header-sorted]=\"_isSorted\"\n [class.et-sort-header-position-before]=\"arrowPosition === 'before'\"\n [attr.tabindex]=\"_isDisabled ? null : 0\"\n [attr.role]=\"_isDisabled ? null : 'button'\"\n class=\"et-sort-header-container\"\n>\n <div class=\"et-sort-header-content\">\n <ng-content />\n </div>\n\n <div *ngIf=\"_renderArrow\" class=\"et-sort-header-arrow {{ _getArrowDirectionState }} {{ _getArrowViewState }}\">\n <et-chevron-icon />\n </div>\n</div>\n", styles: [":where(.et-sort-header){--et-sort-header-arrow-size: 10px;--et-sort-header-gap: 8px}.et-sort-header{cursor:pointer}.et-sort-header.et-sort-header-disabled{cursor:default}.et-sort-header-container{display:flex;align-items:center;letter-spacing:normal;outline:0;gap:var(--et-sort-header-gap)}.et-sort-header-content{text-align:center;display:flex;align-items:center}.et-sort-header-position-before{flex-direction:row-reverse}.et-sort-header:hover .et-sort-header-arrow,.et-sort-header.cdk-keyboard-focused .et-sort-header-arrow{opacity:.5}.et-sort-header .et-sort-header-arrow{transition:opacity .2s var(--ease-out-5)}.et-sort-header .et-sort-header-arrow .et-chevron-icon svg{transition:transform .2s var(--ease-out-5)}.et-sort-header .et-sort-header-arrow{inline-size:var(--et-sort-header-arrow-size);opacity:0}.et-sort-header .et-sort-header-arrow.active-desc,.et-sort-header .et-sort-header-arrow.active-asc{opacity:1}.et-sort-header .et-sort-header-arrow.desc .et-chevron-icon svg,.et-sort-header .et-sort-header-arrow.asc .et-chevron-icon svg,.et-sort-header .et-sort-header-arrow.active-desc .et-chevron-icon svg{transform:rotate(180deg)}.et-sort-header .et-sort-header-arrow.active-asc .et-chevron-icon svg{transform:rotate(0)}\n"], dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: ChevronIconComponent, selector: "et-chevron-icon" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
174
159
|
}
|
|
175
160
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.0", ngImport: i0, type: SortHeaderComponent, decorators: [{
|
|
176
161
|
type: Component,
|
|
177
162
|
args: [{ selector: '[et-sort-header]', exportAs: 'etSortHeader', host: {
|
|
178
163
|
class: 'et-sort-header',
|
|
179
164
|
}, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [NgIf, ChevronIconComponent], template: "<div\n [class.et-sort-header-sorted]=\"_isSorted\"\n [class.et-sort-header-position-before]=\"arrowPosition === 'before'\"\n [attr.tabindex]=\"_isDisabled ? null : 0\"\n [attr.role]=\"_isDisabled ? null : 'button'\"\n class=\"et-sort-header-container\"\n>\n <div class=\"et-sort-header-content\">\n <ng-content />\n </div>\n\n <div *ngIf=\"_renderArrow\" class=\"et-sort-header-arrow {{ _getArrowDirectionState }} {{ _getArrowViewState }}\">\n <et-chevron-icon />\n </div>\n</div>\n", styles: [":where(.et-sort-header){--et-sort-header-arrow-size: 10px;--et-sort-header-gap: 8px}.et-sort-header{cursor:pointer}.et-sort-header.et-sort-header-disabled{cursor:default}.et-sort-header-container{display:flex;align-items:center;letter-spacing:normal;outline:0;gap:var(--et-sort-header-gap)}.et-sort-header-content{text-align:center;display:flex;align-items:center}.et-sort-header-position-before{flex-direction:row-reverse}.et-sort-header:hover .et-sort-header-arrow,.et-sort-header.cdk-keyboard-focused .et-sort-header-arrow{opacity:.5}.et-sort-header .et-sort-header-arrow{transition:opacity .2s var(--ease-out-5)}.et-sort-header .et-sort-header-arrow .et-chevron-icon svg{transition:transform .2s var(--ease-out-5)}.et-sort-header .et-sort-header-arrow{inline-size:var(--et-sort-header-arrow-size);opacity:0}.et-sort-header .et-sort-header-arrow.active-desc,.et-sort-header .et-sort-header-arrow.active-asc{opacity:1}.et-sort-header .et-sort-header-arrow.desc .et-chevron-icon svg,.et-sort-header .et-sort-header-arrow.asc .et-chevron-icon svg,.et-sort-header .et-sort-header-arrow.active-desc .et-chevron-icon svg{transform:rotate(180deg)}.et-sort-header .et-sort-header-arrow.active-asc .et-chevron-icon svg{transform:rotate(0)}\n"] }]
|
|
180
|
-
}], ctorParameters: function () { return [
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
type: Inject,
|
|
184
|
-
args: [SORT_HEADER_COLUMN_DEF]
|
|
185
|
-
}, {
|
|
186
|
-
type: Optional
|
|
187
|
-
}] }, { type: i3.FocusMonitor }, { type: i0.ElementRef }, { type: i3.AriaDescriber }, { type: undefined, decorators: [{
|
|
188
|
-
type: Optional
|
|
189
|
-
}, {
|
|
190
|
-
type: Inject,
|
|
191
|
-
args: [SORT_DEFAULT_OPTIONS]
|
|
192
|
-
}] }]; }, propDecorators: { disabled: [{
|
|
193
|
-
type: Input
|
|
165
|
+
}], ctorParameters: function () { return []; }, propDecorators: { disabled: [{
|
|
166
|
+
type: Input,
|
|
167
|
+
args: [{ transform: booleanAttribute }]
|
|
194
168
|
}, {
|
|
195
169
|
type: HostBinding,
|
|
196
170
|
args: ['class.et-sort-header-disabled']
|
|
@@ -204,7 +178,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.0", ngImpor
|
|
|
204
178
|
}], sortActionDescription: [{
|
|
205
179
|
type: Input
|
|
206
180
|
}], disableClear: [{
|
|
207
|
-
type: Input
|
|
181
|
+
type: Input,
|
|
182
|
+
args: [{ transform: booleanAttribute }]
|
|
208
183
|
}], _ariaSortAttr: [{
|
|
209
184
|
type: HostBinding,
|
|
210
185
|
args: ['attr.aria-sort']
|
|
@@ -221,4 +196,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.0", ngImpor
|
|
|
221
196
|
type: HostListener,
|
|
222
197
|
args: ['keydown', ['$event']]
|
|
223
198
|
}] } });
|
|
224
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sort-header.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/cdk/src/lib/components/sort/components/sort-header/sort-header.component.ts","../../../../../../../../../libs/cdk/src/lib/components/sort/components/sort-header/sort-header.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AriaDescriber, FocusMonitor } from '@angular/cdk/a11y';\nimport { BooleanInput, coerceBooleanProperty } from '@angular/cdk/coercion';\nimport { ENTER, SPACE } from '@angular/cdk/keycodes';\nimport { NgIf } from '@angular/common';\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  HostBinding,\n  HostListener,\n  Inject,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { merge, Subscription } from 'rxjs';\nimport { ChevronIconComponent } from '../../../icons';\nimport { SORT_HEADER_COLUMN_DEF } from '../../../table';\nimport {\n  Sortable,\n  SortDefaultOptions,\n  SortDirective,\n  SortHeaderArrowPosition,\n  SORT_DEFAULT_OPTIONS,\n} from '../../partials';\nimport { SortHeaderIntl } from '../../services';\nimport { SortDirection } from '../../types';\nimport { ArrowViewStateTransition, SortHeaderColumnDef } from './sort-header.types';\n\n@Component({\n  selector: '[et-sort-header]',\n  exportAs: 'etSortHeader',\n  templateUrl: 'sort-header.component.html',\n  styleUrls: ['sort-header.component.scss'],\n  host: {\n    class: 'et-sort-header',\n  },\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [NgIf, ChevronIconComponent],\n})\nexport class SortHeaderComponent implements Sortable, OnDestroy, OnInit, AfterViewInit {\n  private _rerenderSubscription?: Subscription;\n  private _sortButton!: HTMLElement;\n\n  _showIndicatorHint = false;\n  _viewState: ArrowViewStateTransition = {};\n  _arrowDirection: SortDirection = '';\n\n  @Input()\n  @HostBinding('class.et-sort-header-disabled')\n  get disabled(): boolean {\n    return this._disabled;\n  }\n  set disabled(value: BooleanInput) {\n    this._disabled = coerceBooleanProperty(value);\n  }\n  private _disabled = false;\n\n  @Input('et-sort-header')\n  id!: string;\n\n  @Input()\n  arrowPosition: SortHeaderArrowPosition = 'after';\n\n  @Input()\n  start!: SortDirection;\n\n  @Input()\n  get sortActionDescription(): string {\n    return this._sortActionDescription;\n  }\n  set sortActionDescription(value: string) {\n    this._updateSortActionDescription(value);\n  }\n  private _sortActionDescription = 'Sort';\n\n  @Input()\n  get disableClear(): boolean {\n    return this._disableClear;\n  }\n  set disableClear(v: BooleanInput) {\n    this._disableClear = coerceBooleanProperty(v);\n  }\n  private _disableClear = false;\n\n  get _isSorted() {\n    if (!this._sort) {\n      return false;\n    }\n\n    return this._sort.active == this.id && (this._sort.direction === 'asc' || this._sort.direction === 'desc');\n  }\n\n  get _getArrowDirectionState() {\n    return `${this._isSorted ? 'active-' : ''}${this._arrowDirection}`;\n  }\n\n  get _getArrowViewState() {\n    const fromState = this._viewState.fromState;\n    return (fromState ? `${fromState}-to-` : '') + this._viewState.toState;\n  }\n\n  get _isDisabled() {\n    return this._sort?.disabled || this.disabled;\n  }\n\n  get _renderArrow() {\n    return !this._isDisabled || this._isSorted;\n  }\n\n  @HostBinding('attr.aria-sort')\n  get _ariaSortAttr() {\n    if (!this._isSorted) {\n      return 'none';\n    }\n\n    return this._sort?.direction == 'asc' ? 'ascending' : 'descending';\n  }\n\n  constructor(\n    public _intl: SortHeaderIntl,\n    private _changeDetectorRef: ChangeDetectorRef,\n    @Optional() public _sort: SortDirective | null,\n    @Inject(SORT_HEADER_COLUMN_DEF)\n    @Optional()\n    public _columnDef: SortHeaderColumnDef | null,\n    private _focusMonitor: FocusMonitor,\n    private _elementRef: ElementRef<HTMLElement>,\n    private _ariaDescriber: AriaDescriber,\n    @Optional() @Inject(SORT_DEFAULT_OPTIONS) defaultOptions?: SortDefaultOptions,\n  ) {\n    if (defaultOptions?.arrowPosition) {\n      this.arrowPosition = defaultOptions?.arrowPosition;\n    }\n\n    this._handleStateChanges();\n  }\n\n  ngOnInit() {\n    if (!this.id && this._columnDef) {\n      this.id = this._columnDef.name;\n    }\n\n    this._updateArrowDirection();\n    this._setAnimationTransitionState({\n      toState: this._isSorted ? 'active' : this._arrowDirection,\n    });\n\n    this._sort?.register(this);\n\n    this._sortButton = this._elementRef.nativeElement.querySelector('.et-sort-header-container') as HTMLElement;\n    this._updateSortActionDescription(this._sortActionDescription);\n  }\n\n  ngAfterViewInit() {\n    this._focusMonitor.monitor(this._elementRef, true).subscribe((origin) => {\n      const newState = !!origin;\n      if (newState !== this._showIndicatorHint) {\n        this._setIndicatorHintVisible(newState);\n        this._changeDetectorRef.markForCheck();\n      }\n    });\n  }\n\n  ngOnDestroy() {\n    this._focusMonitor.stopMonitoring(this._elementRef);\n    this._sort?.deregister(this);\n    this._rerenderSubscription?.unsubscribe();\n  }\n\n  @HostListener('mouseenter')\n  _handleMouseEnter() {\n    this._setIndicatorHintVisible(true);\n  }\n\n  @HostListener('mouseleave')\n  _handleMouseLeave() {\n    this._setIndicatorHintVisible(false);\n  }\n\n  _setIndicatorHintVisible(visible: boolean) {\n    if (this._isDisabled && visible) {\n      return;\n    }\n\n    this._showIndicatorHint = visible;\n\n    if (!this._isSorted) {\n      this._updateArrowDirection();\n      if (this._showIndicatorHint) {\n        this._setAnimationTransitionState({ fromState: this._arrowDirection, toState: 'hint' });\n      } else {\n        this._setAnimationTransitionState({ fromState: 'hint', toState: this._arrowDirection });\n      }\n    }\n  }\n\n  _setAnimationTransitionState(viewState: ArrowViewStateTransition) {\n    this._viewState = viewState || {};\n  }\n\n  _toggleOnInteraction() {\n    this._sort?.sort(this);\n  }\n\n  @HostListener('click')\n  _handleClick() {\n    if (!this._isDisabled) {\n      this._sort?.sort(this);\n    }\n  }\n\n  @HostListener('keydown', ['$event'])\n  _handleKeydown(event: KeyboardEvent) {\n    if (!this._isDisabled && (event.keyCode === SPACE || event.keyCode === ENTER)) {\n      event.preventDefault();\n      this._toggleOnInteraction();\n    }\n  }\n\n  _updateArrowDirection() {\n    if (!this._sort) {\n      return;\n    }\n\n    this._arrowDirection = this._isSorted ? this._sort.direction : this.start || this._sort.start;\n  }\n\n  private _updateSortActionDescription(newDescription: string) {\n    if (this._sortButton) {\n      this._ariaDescriber?.removeDescription(this._sortButton, this._sortActionDescription);\n      this._ariaDescriber?.describe(this._sortButton, newDescription);\n    }\n\n    this._sortActionDescription = newDescription;\n  }\n\n  private _handleStateChanges() {\n    if (!this._sort) {\n      return;\n    }\n\n    this._rerenderSubscription = merge(this._sort.sortChange, this._sort._stateChanges, this._intl.changes).subscribe(\n      () => {\n        if (this._isSorted) {\n          this._updateArrowDirection();\n\n          this._setAnimationTransitionState({ fromState: this._arrowDirection, toState: 'active' });\n          this._showIndicatorHint = false;\n        }\n\n        if (!this._isSorted && this._viewState && this._viewState.toState === 'active') {\n          this._setAnimationTransitionState({ fromState: 'active', toState: this._arrowDirection });\n        }\n\n        this._changeDetectorRef.markForCheck();\n      },\n    );\n  }\n}\n","<div\n  [class.et-sort-header-sorted]=\"_isSorted\"\n  [class.et-sort-header-position-before]=\"arrowPosition === 'before'\"\n  [attr.tabindex]=\"_isDisabled ? null : 0\"\n  [attr.role]=\"_isDisabled ? null : 'button'\"\n  class=\"et-sort-header-container\"\n>\n  <div class=\"et-sort-header-content\">\n    <ng-content />\n  </div>\n\n  <div *ngIf=\"_renderArrow\" class=\"et-sort-header-arrow {{ _getArrowDirectionState }} {{ _getArrowViewState }}\">\n    <et-chevron-icon />\n  </div>\n</div>\n"]}
|
|
199
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sort-header.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/cdk/src/lib/components/sort/components/sort-header/sort-header.component.ts","../../../../../../../../../libs/cdk/src/lib/components/sort/components/sort-header/sort-header.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AriaDescriber, FocusMonitor } from '@angular/cdk/a11y';\nimport { ENTER, SPACE } from '@angular/cdk/keycodes';\nimport { NgIf } from '@angular/common';\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  HostBinding,\n  HostListener,\n  Input,\n  OnDestroy,\n  OnInit,\n  ViewEncapsulation,\n  booleanAttribute,\n  inject,\n} from '@angular/core';\nimport { Subscription, merge } from 'rxjs';\nimport { ChevronIconComponent } from '../../../icons';\nimport { SORT_HEADER_COLUMN_DEF } from '../../../table';\nimport { SORT_DEFAULT_OPTIONS, SortDirective, SortHeaderArrowPosition, Sortable } from '../../partials';\nimport { SortHeaderIntl } from '../../services';\nimport { SortDirection } from '../../types';\nimport { ArrowViewStateTransition } from './sort-header.types';\n\n@Component({\n  selector: '[et-sort-header]',\n  exportAs: 'etSortHeader',\n  templateUrl: 'sort-header.component.html',\n  styleUrls: ['sort-header.component.scss'],\n  host: {\n    class: 'et-sort-header',\n  },\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [NgIf, ChevronIconComponent],\n})\nexport class SortHeaderComponent implements Sortable, OnDestroy, OnInit, AfterViewInit {\n  private readonly _intl = inject(SortHeaderIntl);\n  private readonly _changeDetectorRef = inject(ChangeDetectorRef);\n  private readonly _sort = inject(SortDirective, { optional: true });\n  private readonly _columnDef = inject(SORT_HEADER_COLUMN_DEF, { optional: true });\n  private readonly _focusMonitor = inject(FocusMonitor);\n  private readonly _elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n  private readonly _ariaDescriber = inject(AriaDescriber);\n  private readonly _sortDefaultOptions = inject(SORT_DEFAULT_OPTIONS, { optional: true });\n\n  private _rerenderSubscription?: Subscription;\n  private _sortButton!: HTMLElement;\n\n  _showIndicatorHint = false;\n  _viewState: ArrowViewStateTransition = {};\n  _arrowDirection: SortDirection = '';\n\n  @Input({ transform: booleanAttribute })\n  @HostBinding('class.et-sort-header-disabled')\n  disabled = false;\n\n  @Input('et-sort-header')\n  id!: string;\n\n  @Input()\n  arrowPosition: SortHeaderArrowPosition = 'after';\n\n  @Input()\n  start!: SortDirection;\n\n  @Input()\n  get sortActionDescription(): string {\n    return this._sortActionDescription;\n  }\n  set sortActionDescription(value: string) {\n    this._updateSortActionDescription(value);\n  }\n  private _sortActionDescription = 'Sort';\n\n  @Input({ transform: booleanAttribute })\n  disableClear = false;\n\n  get _isSorted() {\n    if (!this._sort) {\n      return false;\n    }\n\n    return this._sort.active == this.id && (this._sort.direction === 'asc' || this._sort.direction === 'desc');\n  }\n\n  get _getArrowDirectionState() {\n    return `${this._isSorted ? 'active-' : ''}${this._arrowDirection}`;\n  }\n\n  get _getArrowViewState() {\n    const fromState = this._viewState.fromState;\n    return (fromState ? `${fromState}-to-` : '') + this._viewState.toState;\n  }\n\n  get _isDisabled() {\n    return this._sort?.disabled || this.disabled;\n  }\n\n  get _renderArrow() {\n    return !this._isDisabled || this._isSorted;\n  }\n\n  @HostBinding('attr.aria-sort')\n  get _ariaSortAttr() {\n    if (!this._isSorted) {\n      return 'none';\n    }\n\n    return this._sort?.direction == 'asc' ? 'ascending' : 'descending';\n  }\n\n  constructor() {\n    if (this._sortDefaultOptions?.arrowPosition) {\n      this.arrowPosition = this._sortDefaultOptions?.arrowPosition;\n    }\n\n    this._handleStateChanges();\n  }\n\n  ngOnInit() {\n    if (!this.id && this._columnDef) {\n      this.id = this._columnDef.name;\n    }\n\n    this._updateArrowDirection();\n    this._setAnimationTransitionState({\n      toState: this._isSorted ? 'active' : this._arrowDirection,\n    });\n\n    this._sort?.register(this);\n\n    this._sortButton = this._elementRef.nativeElement.querySelector('.et-sort-header-container') as HTMLElement;\n    this._updateSortActionDescription(this._sortActionDescription);\n  }\n\n  ngAfterViewInit() {\n    this._focusMonitor.monitor(this._elementRef, true).subscribe((origin) => {\n      const newState = !!origin;\n      if (newState !== this._showIndicatorHint) {\n        this._setIndicatorHintVisible(newState);\n        this._changeDetectorRef.markForCheck();\n      }\n    });\n  }\n\n  ngOnDestroy() {\n    this._focusMonitor.stopMonitoring(this._elementRef);\n    this._sort?.deregister(this);\n    this._rerenderSubscription?.unsubscribe();\n  }\n\n  @HostListener('mouseenter')\n  _handleMouseEnter() {\n    this._setIndicatorHintVisible(true);\n  }\n\n  @HostListener('mouseleave')\n  _handleMouseLeave() {\n    this._setIndicatorHintVisible(false);\n  }\n\n  _setIndicatorHintVisible(visible: boolean) {\n    if (this._isDisabled && visible) {\n      return;\n    }\n\n    this._showIndicatorHint = visible;\n\n    if (!this._isSorted) {\n      this._updateArrowDirection();\n      if (this._showIndicatorHint) {\n        this._setAnimationTransitionState({ fromState: this._arrowDirection, toState: 'hint' });\n      } else {\n        this._setAnimationTransitionState({ fromState: 'hint', toState: this._arrowDirection });\n      }\n    }\n  }\n\n  _setAnimationTransitionState(viewState: ArrowViewStateTransition) {\n    this._viewState = viewState || {};\n  }\n\n  _toggleOnInteraction() {\n    this._sort?.sort(this);\n  }\n\n  @HostListener('click')\n  _handleClick() {\n    if (!this._isDisabled) {\n      this._sort?.sort(this);\n    }\n  }\n\n  @HostListener('keydown', ['$event'])\n  _handleKeydown(event: KeyboardEvent) {\n    if (!this._isDisabled && (event.keyCode === SPACE || event.keyCode === ENTER)) {\n      event.preventDefault();\n      this._toggleOnInteraction();\n    }\n  }\n\n  _updateArrowDirection() {\n    if (!this._sort) {\n      return;\n    }\n\n    this._arrowDirection = this._isSorted ? this._sort.direction : this.start || this._sort.start;\n  }\n\n  private _updateSortActionDescription(newDescription: string) {\n    if (this._sortButton) {\n      this._ariaDescriber?.removeDescription(this._sortButton, this._sortActionDescription);\n      this._ariaDescriber?.describe(this._sortButton, newDescription);\n    }\n\n    this._sortActionDescription = newDescription;\n  }\n\n  private _handleStateChanges() {\n    if (!this._sort) {\n      return;\n    }\n\n    this._rerenderSubscription = merge(this._sort.sortChange, this._sort._stateChanges, this._intl.changes).subscribe(\n      () => {\n        if (this._isSorted) {\n          this._updateArrowDirection();\n\n          this._setAnimationTransitionState({ fromState: this._arrowDirection, toState: 'active' });\n          this._showIndicatorHint = false;\n        }\n\n        if (!this._isSorted && this._viewState && this._viewState.toState === 'active') {\n          this._setAnimationTransitionState({ fromState: 'active', toState: this._arrowDirection });\n        }\n\n        this._changeDetectorRef.markForCheck();\n      },\n    );\n  }\n}\n","<div\n  [class.et-sort-header-sorted]=\"_isSorted\"\n  [class.et-sort-header-position-before]=\"arrowPosition === 'before'\"\n  [attr.tabindex]=\"_isDisabled ? null : 0\"\n  [attr.role]=\"_isDisabled ? null : 'button'\"\n  class=\"et-sort-header-container\"\n>\n  <div class=\"et-sort-header-content\">\n    <ng-content />\n  </div>\n\n  <div *ngIf=\"_renderArrow\" class=\"et-sort-header-arrow {{ _getArrowDirectionState }} {{ _getArrowViewState }}\">\n    <et-chevron-icon />\n  </div>\n</div>\n"]}
|