@radix-ng/primitives 0.16.0 → 0.18.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/checkbox/src/checkbox-input.directive.d.ts +2 -1
- package/compodoc/documentation.json +7419 -2200
- package/esm2022/accordion/index.mjs +4 -4
- package/esm2022/accordion/src/accordion-content.directive.mjs +3 -3
- package/esm2022/accordion/src/accordion-header.directive.mjs +3 -3
- package/esm2022/accordion/src/accordion-item.directive.mjs +3 -3
- package/esm2022/accordion/src/accordion-root.directive.mjs +3 -3
- package/esm2022/accordion/src/accordion-trigger.directive.mjs +3 -3
- package/esm2022/alert-dialog/index.mjs +4 -4
- package/esm2022/alert-dialog/src/alert-dialog-cancel.directive.mjs +3 -3
- package/esm2022/alert-dialog/src/alert-dialog-content.directive.mjs +3 -3
- package/esm2022/alert-dialog/src/alert-dialog-root.directive.mjs +3 -3
- package/esm2022/alert-dialog/src/alert-dialog-title.directive.mjs +3 -3
- package/esm2022/alert-dialog/src/alert-dialog-trigger.directive.mjs +3 -3
- package/esm2022/alert-dialog/src/alert-dialog.service.mjs +3 -3
- package/esm2022/aspect-ratio/src/aspect-ratio.directive.mjs +3 -3
- package/esm2022/avatar/src/avatar-fallback.directive.mjs +3 -3
- package/esm2022/avatar/src/avatar-image.directive.mjs +3 -3
- package/esm2022/avatar/src/avatar-root.directive.mjs +3 -3
- package/esm2022/checkbox/src/checkbox-button.directive.mjs +3 -3
- package/esm2022/checkbox/src/checkbox-indicator.directive.mjs +3 -3
- package/esm2022/checkbox/src/checkbox-input.directive.mjs +7 -4
- package/esm2022/checkbox/src/checkbox.directive.mjs +3 -3
- package/esm2022/collapsible/src/collapsible-content.directive.mjs +3 -3
- package/esm2022/collapsible/src/collapsible-root.directive.mjs +3 -3
- package/esm2022/collapsible/src/collapsible-trigger.directive.mjs +3 -3
- package/esm2022/context-menu/index.mjs +4 -4
- package/esm2022/context-menu/src/context-menu-content.directive.mjs +3 -3
- package/esm2022/context-menu/src/context-menu-item-checkbox.directive.mjs +3 -3
- package/esm2022/context-menu/src/context-menu-item-indicator.directive.mjs +3 -3
- package/esm2022/context-menu/src/context-menu-item-radio-group.directive.mjs +3 -3
- package/esm2022/context-menu/src/context-menu-item-radio.directive.mjs +3 -3
- package/esm2022/context-menu/src/context-menu-item-selectable.mjs +3 -3
- package/esm2022/context-menu/src/context-menu-item.directive.mjs +3 -3
- package/esm2022/context-menu/src/context-menu-label.directive.mjs +3 -3
- package/esm2022/context-menu/src/context-menu-separator.directive.mjs +3 -3
- package/esm2022/context-menu/src/context-menu-trigger.directive.mjs +3 -3
- package/esm2022/core/src/auto-focus.directive.mjs +3 -3
- package/esm2022/dialog/index.mjs +4 -4
- package/esm2022/dialog/src/dialog-close.directive.mjs +3 -3
- package/esm2022/dialog/src/dialog-content.directive.mjs +3 -3
- package/esm2022/dialog/src/dialog-description.directive.mjs +3 -3
- package/esm2022/dialog/src/dialog-dismiss.directive.mjs +3 -3
- package/esm2022/dialog/src/dialog-title.directive.mjs +3 -3
- package/esm2022/dialog/src/dialog-trigger.directive.mjs +3 -3
- package/esm2022/dialog/src/dialog.service.mjs +3 -3
- package/esm2022/dropdown-menu/index.mjs +4 -4
- package/esm2022/dropdown-menu/src/dropdown-menu-content.directive.mjs +3 -3
- package/esm2022/dropdown-menu/src/dropdown-menu-item-checkbox.directive.mjs +3 -3
- package/esm2022/dropdown-menu/src/dropdown-menu-item-indicator.directive.mjs +3 -3
- package/esm2022/dropdown-menu/src/dropdown-menu-item-radio-group.directive.mjs +3 -3
- package/esm2022/dropdown-menu/src/dropdown-menu-item-radio.directive.mjs +3 -3
- package/esm2022/dropdown-menu/src/dropdown-menu-item-selectable.mjs +3 -3
- package/esm2022/dropdown-menu/src/dropdown-menu-item.directive.mjs +3 -3
- package/esm2022/dropdown-menu/src/dropdown-menu-label.directive.mjs +3 -3
- package/esm2022/dropdown-menu/src/dropdown-menu-separator.directive.mjs +3 -3
- package/esm2022/dropdown-menu/src/dropdown-menu-trigger.directive.mjs +3 -3
- package/esm2022/label/src/label.directive.mjs +3 -3
- package/esm2022/menu/index.mjs +4 -4
- package/esm2022/menu/src/menu-content.directive.mjs +3 -3
- package/esm2022/menu/src/menu-directive.mjs +3 -3
- package/esm2022/menu/src/menu-group.directive.mjs +3 -3
- package/esm2022/menu/src/menu-item.directive.mjs +3 -3
- package/esm2022/menu/src/menu-label.directive.mjs +3 -3
- package/esm2022/menu/src/menu-separator.directive.mjs +3 -3
- package/esm2022/menubar/index.mjs +4 -4
- package/esm2022/menubar/src/menubar-content.directive.mjs +3 -3
- package/esm2022/menubar/src/menubar-item-checkbox.directive.mjs +3 -3
- package/esm2022/menubar/src/menubar-item-indicator.directive.mjs +3 -3
- package/esm2022/menubar/src/menubar-item-radio.directive.mjs +3 -3
- package/esm2022/menubar/src/menubar-item.directive.mjs +3 -3
- package/esm2022/menubar/src/menubar-radio-group.directive.mjs +3 -3
- package/esm2022/menubar/src/menubar-root.directive.mjs +3 -3
- package/esm2022/menubar/src/menubar-separator.directive.mjs +3 -3
- package/esm2022/menubar/src/menubar-trigger.directive.mjs +3 -3
- package/esm2022/progress/index.mjs +4 -4
- package/esm2022/progress/src/progress-indicator.directive.mjs +3 -3
- package/esm2022/progress/src/progress-root.directive.mjs +3 -3
- package/esm2022/radio/src/radio-indicator.directive.mjs +3 -3
- package/esm2022/radio/src/radio-item.directive.mjs +3 -3
- package/esm2022/radio/src/radio-root.directive.mjs +3 -3
- package/esm2022/select/index.mjs +65 -0
- package/esm2022/select/radix-ng-primitives-select.mjs +5 -0
- package/esm2022/select/src/select-content.directive.mjs +53 -0
- package/esm2022/select/src/select-group.directive.mjs +18 -0
- package/esm2022/select/src/select-icon.directive.mjs +18 -0
- package/esm2022/select/src/select-item-indicator.directive.mjs +23 -0
- package/esm2022/select/src/select-item.directive.mjs +116 -0
- package/esm2022/select/src/select-label.directive.mjs +15 -0
- package/esm2022/select/src/select-separator.directive.mjs +18 -0
- package/esm2022/select/src/select-trigger.directive.mjs +38 -0
- package/esm2022/select/src/select-value.directive.mjs +21 -0
- package/esm2022/select/src/select.component.mjs +234 -0
- package/esm2022/separator/src/separator.directive.mjs +3 -3
- package/esm2022/slider/index.mjs +28 -0
- package/esm2022/slider/radix-ng-primitives-slider.mjs +5 -0
- package/esm2022/slider/src/slider-horizontal.component.mjs +117 -0
- package/esm2022/slider/src/slider-impl.directive.mjs +89 -0
- package/esm2022/slider/src/slider-orientation-context.service.mjs +28 -0
- package/esm2022/slider/src/slider-range.component.mjs +41 -0
- package/esm2022/slider/src/slider-root.component.mjs +207 -0
- package/esm2022/slider/src/slider-thumb-impl.directive.mjs +102 -0
- package/esm2022/slider/src/slider-thumb.component.mjs +22 -0
- package/esm2022/slider/src/slider-track.component.mjs +27 -0
- package/esm2022/slider/src/slider-vertical.component.mjs +117 -0
- package/esm2022/slider/src/utils.mjs +94 -0
- package/esm2022/switch/index.mjs +4 -4
- package/esm2022/switch/src/switch-input.directive.mjs +3 -3
- package/esm2022/switch/src/switch-root.directive.mjs +3 -3
- package/esm2022/switch/src/switch-thumb.directive.mjs +3 -3
- package/esm2022/tabs/index.mjs +4 -4
- package/esm2022/tabs/src/tabs-content.directive.mjs +3 -3
- package/esm2022/tabs/src/tabs-context.service.mjs +3 -3
- package/esm2022/tabs/src/tabs-list.directive.mjs +3 -3
- package/esm2022/tabs/src/tabs-root.directive.mjs +3 -3
- package/esm2022/tabs/src/tabs-trigger.directive.mjs +3 -3
- package/esm2022/toggle/src/toggle-input.directive.mjs +3 -3
- package/esm2022/toggle/src/toggle.directive.mjs +3 -3
- package/esm2022/toggle-group/src/toggle-group-item.directive.mjs +3 -3
- package/esm2022/toggle-group/src/toggle-group-multiple.directive.mjs +3 -3
- package/esm2022/toggle-group/src/toggle-group.directive.mjs +3 -3
- package/esm2022/tooltip/index.mjs +41 -0
- package/esm2022/tooltip/radix-ng-primitives-tooltip.mjs +5 -0
- package/esm2022/tooltip/src/get-content-position.mjs +31 -0
- package/esm2022/tooltip/src/tooltip-arrow.directive.mjs +92 -0
- package/esm2022/tooltip/src/tooltip-arrow.token.mjs +3 -0
- package/esm2022/tooltip/src/tooltip-content-attributes.directive.mjs +24 -0
- package/esm2022/tooltip/src/tooltip-content.directive.mjs +48 -0
- package/esm2022/tooltip/src/tooltip-content.token.mjs +3 -0
- package/esm2022/tooltip/src/tooltip-root.directive.mjs +288 -0
- package/esm2022/tooltip/src/tooltip-trigger.directive.mjs +70 -0
- package/esm2022/tooltip/src/tooltip.config.mjs +18 -0
- package/esm2022/tooltip/src/tooltip.constants.mjs +84 -0
- package/esm2022/tooltip/src/tooltip.types.mjs +14 -0
- package/esm2022/visually-hidden/src/visually-hidden-input-bubble.directive.mjs +3 -3
- package/esm2022/visually-hidden/src/visually-hidden-input.directive.mjs +3 -3
- package/esm2022/visually-hidden/src/visually-hidden.directive.mjs +3 -3
- package/fesm2022/radix-ng-primitives-accordion.mjs +19 -19
- package/fesm2022/radix-ng-primitives-alert-dialog.mjs +22 -22
- package/fesm2022/radix-ng-primitives-aspect-ratio.mjs +3 -3
- package/fesm2022/radix-ng-primitives-avatar.mjs +9 -9
- package/fesm2022/radix-ng-primitives-checkbox.mjs +15 -12
- package/fesm2022/radix-ng-primitives-checkbox.mjs.map +1 -1
- package/fesm2022/radix-ng-primitives-collapsible.mjs +9 -9
- package/fesm2022/radix-ng-primitives-context-menu.mjs +34 -34
- package/fesm2022/radix-ng-primitives-core.mjs +3 -3
- package/fesm2022/radix-ng-primitives-dialog.mjs +25 -25
- package/fesm2022/radix-ng-primitives-dropdown-menu.mjs +34 -34
- package/fesm2022/radix-ng-primitives-label.mjs +3 -3
- package/fesm2022/radix-ng-primitives-menu.mjs +22 -22
- package/fesm2022/radix-ng-primitives-menubar.mjs +31 -31
- package/fesm2022/radix-ng-primitives-progress.mjs +10 -10
- package/fesm2022/radix-ng-primitives-radio.mjs +9 -9
- package/fesm2022/radix-ng-primitives-select.mjs +572 -0
- package/fesm2022/radix-ng-primitives-select.mjs.map +1 -0
- package/fesm2022/radix-ng-primitives-separator.mjs +3 -3
- package/fesm2022/radix-ng-primitives-slider.mjs +830 -0
- package/fesm2022/radix-ng-primitives-slider.mjs.map +1 -0
- package/fesm2022/radix-ng-primitives-switch.mjs +13 -13
- package/fesm2022/radix-ng-primitives-tabs.mjs +19 -19
- package/fesm2022/radix-ng-primitives-toggle-group.mjs +9 -9
- package/fesm2022/radix-ng-primitives-toggle.mjs +6 -6
- package/fesm2022/radix-ng-primitives-tooltip.mjs +684 -0
- package/fesm2022/radix-ng-primitives-tooltip.mjs.map +1 -0
- package/fesm2022/radix-ng-primitives-visually-hidden.mjs +9 -9
- package/package.json +19 -1
- package/select/README.md +1 -0
- package/select/index.d.ts +26 -0
- package/select/src/select-content.directive.d.ts +20 -0
- package/select/src/select-group.directive.d.ts +5 -0
- package/select/src/select-icon.directive.d.ts +5 -0
- package/select/src/select-item-indicator.directive.d.ts +7 -0
- package/select/src/select-item.directive.d.ts +47 -0
- package/select/src/select-label.directive.d.ts +5 -0
- package/select/src/select-separator.directive.d.ts +5 -0
- package/select/src/select-trigger.directive.d.ts +11 -0
- package/select/src/select-value.directive.d.ts +8 -0
- package/select/src/select.component.d.ts +81 -0
- package/slider/README.md +1 -0
- package/slider/index.d.ts +18 -0
- package/slider/src/slider-horizontal.component.d.ts +29 -0
- package/slider/src/slider-impl.directive.d.ts +18 -0
- package/slider/src/slider-orientation-context.service.d.ts +14 -0
- package/slider/src/slider-range.component.d.ts +13 -0
- package/slider/src/slider-root.component.d.ts +47 -0
- package/slider/src/slider-thumb-impl.directive.d.ts +26 -0
- package/slider/src/slider-thumb.component.d.ts +6 -0
- package/slider/src/slider-track.component.d.ts +7 -0
- package/slider/src/slider-vertical.component.d.ts +29 -0
- package/slider/src/utils.d.ts +52 -0
- package/tooltip/README.md +1 -0
- package/tooltip/index.d.ts +17 -0
- package/tooltip/src/get-content-position.d.ts +3 -0
- package/tooltip/src/tooltip-arrow.directive.d.ts +25 -0
- package/tooltip/src/tooltip-arrow.token.d.ts +3 -0
- package/tooltip/src/tooltip-content-attributes.directive.d.ts +8 -0
- package/tooltip/src/tooltip-content.directive.d.ts +36 -0
- package/tooltip/src/tooltip-content.token.d.ts +3 -0
- package/tooltip/src/tooltip-root.directive.d.ts +103 -0
- package/tooltip/src/tooltip-trigger.directive.d.ts +26 -0
- package/tooltip/src/tooltip.config.d.ts +6 -0
- package/tooltip/src/tooltip.constants.d.ts +9 -0
- package/tooltip/src/tooltip.types.d.ts +18 -0
@@ -0,0 +1,117 @@
|
|
1
|
+
import { booleanAttribute, Component, EventEmitter, inject, input, Input, Output, signal, viewChild } from '@angular/core';
|
2
|
+
import { RdxSliderImplDirective } from './slider-impl.directive';
|
3
|
+
import { RdxSliderRootComponent } from './slider-root.component';
|
4
|
+
import { BACK_KEYS, linearScale } from './utils';
|
5
|
+
import * as i0 from "@angular/core";
|
6
|
+
export class RdxSliderHorizontalComponent {
|
7
|
+
constructor() {
|
8
|
+
this.rootContext = inject(RdxSliderRootComponent);
|
9
|
+
this.dir = 'ltr';
|
10
|
+
this.inverted = input(false, { transform: booleanAttribute });
|
11
|
+
this.min = 0;
|
12
|
+
this.max = 100;
|
13
|
+
this.className = '';
|
14
|
+
this.slideStart = new EventEmitter();
|
15
|
+
this.slideMove = new EventEmitter();
|
16
|
+
this.slideEnd = new EventEmitter();
|
17
|
+
this.stepKeyDown = new EventEmitter();
|
18
|
+
this.endKeyDown = new EventEmitter();
|
19
|
+
this.homeKeyDown = new EventEmitter();
|
20
|
+
this.sliderElement = viewChild('sliderElement');
|
21
|
+
this.rect = signal(undefined);
|
22
|
+
}
|
23
|
+
onSlideStart(event) {
|
24
|
+
const value = this.getValueFromPointer(event.clientX);
|
25
|
+
this.slideStart.emit(value);
|
26
|
+
}
|
27
|
+
onSlideMove(event) {
|
28
|
+
const value = this.getValueFromPointer(event.clientX);
|
29
|
+
this.slideMove.emit(value);
|
30
|
+
}
|
31
|
+
onSlideEnd() {
|
32
|
+
this.rect.set(undefined);
|
33
|
+
this.slideEnd.emit();
|
34
|
+
}
|
35
|
+
onStepKeyDown(event) {
|
36
|
+
const slideDirection = this.rootContext.isSlidingFromLeft() ? 'from-left' : 'from-right';
|
37
|
+
const isBackKey = BACK_KEYS[slideDirection].includes(event.key);
|
38
|
+
this.stepKeyDown.emit({ event, direction: isBackKey ? -1 : 1 });
|
39
|
+
}
|
40
|
+
getValueFromPointer(pointerPosition) {
|
41
|
+
this.rect.set(this.sliderElement()?.nativeElement.getBoundingClientRect());
|
42
|
+
const rect = this.rect();
|
43
|
+
if (!rect)
|
44
|
+
return 0;
|
45
|
+
const input = [0, rect.width];
|
46
|
+
const output = this.rootContext.isSlidingFromLeft()
|
47
|
+
? [this.min, this.max]
|
48
|
+
: [this.max, this.min];
|
49
|
+
const value = linearScale(input, output);
|
50
|
+
this.rect.set(rect);
|
51
|
+
return value(pointerPosition - rect.left);
|
52
|
+
}
|
53
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxSliderHorizontalComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
54
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "18.2.11", type: RdxSliderHorizontalComponent, isStandalone: true, selector: "rdx-slider-horizontal", inputs: { dir: { classPropertyName: "dir", publicName: "dir", isSignal: false, isRequired: false, transformFunction: null }, inverted: { classPropertyName: "inverted", publicName: "inverted", isSignal: true, isRequired: false, transformFunction: null }, min: { classPropertyName: "min", publicName: "min", isSignal: false, isRequired: false, transformFunction: null }, max: { classPropertyName: "max", publicName: "max", isSignal: false, isRequired: false, transformFunction: null }, className: { classPropertyName: "className", publicName: "className", isSignal: false, isRequired: false, transformFunction: null } }, outputs: { slideStart: "slideStart", slideMove: "slideMove", slideEnd: "slideEnd", stepKeyDown: "stepKeyDown", endKeyDown: "endKeyDown", homeKeyDown: "homeKeyDown" }, viewQueries: [{ propertyName: "sliderElement", first: true, predicate: ["sliderElement"], descendants: true, isSignal: true }], ngImport: i0, template: `
|
55
|
+
<span
|
56
|
+
#sliderElement
|
57
|
+
[class]="className"
|
58
|
+
[attr.data-orientation]="'horizontal'"
|
59
|
+
[style]="{ '--rdx-slider-thumb-transform': 'translateX(-50%)' }"
|
60
|
+
(slideStart)="onSlideStart($event)"
|
61
|
+
(slideMove)="onSlideMove($event)"
|
62
|
+
(slideEnd)="onSlideEnd()"
|
63
|
+
(stepKeyDown)="onStepKeyDown($event)"
|
64
|
+
(endKeyDown)="endKeyDown.emit($event)"
|
65
|
+
(homeKeyDown)="homeKeyDown.emit($event)"
|
66
|
+
rdxSliderImpl
|
67
|
+
>
|
68
|
+
<ng-content />
|
69
|
+
</span>
|
70
|
+
`, isInline: true, dependencies: [{ kind: "directive", type: RdxSliderImplDirective, selector: "[rdxSliderImpl]", outputs: ["slideStart", "slideMove", "slideEnd", "homeKeyDown", "endKeyDown", "stepKeyDown"] }] }); }
|
71
|
+
}
|
72
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxSliderHorizontalComponent, decorators: [{
|
73
|
+
type: Component,
|
74
|
+
args: [{
|
75
|
+
selector: 'rdx-slider-horizontal',
|
76
|
+
standalone: true,
|
77
|
+
imports: [RdxSliderImplDirective],
|
78
|
+
template: `
|
79
|
+
<span
|
80
|
+
#sliderElement
|
81
|
+
[class]="className"
|
82
|
+
[attr.data-orientation]="'horizontal'"
|
83
|
+
[style]="{ '--rdx-slider-thumb-transform': 'translateX(-50%)' }"
|
84
|
+
(slideStart)="onSlideStart($event)"
|
85
|
+
(slideMove)="onSlideMove($event)"
|
86
|
+
(slideEnd)="onSlideEnd()"
|
87
|
+
(stepKeyDown)="onStepKeyDown($event)"
|
88
|
+
(endKeyDown)="endKeyDown.emit($event)"
|
89
|
+
(homeKeyDown)="homeKeyDown.emit($event)"
|
90
|
+
rdxSliderImpl
|
91
|
+
>
|
92
|
+
<ng-content />
|
93
|
+
</span>
|
94
|
+
`
|
95
|
+
}]
|
96
|
+
}], propDecorators: { dir: [{
|
97
|
+
type: Input
|
98
|
+
}], min: [{
|
99
|
+
type: Input
|
100
|
+
}], max: [{
|
101
|
+
type: Input
|
102
|
+
}], className: [{
|
103
|
+
type: Input
|
104
|
+
}], slideStart: [{
|
105
|
+
type: Output
|
106
|
+
}], slideMove: [{
|
107
|
+
type: Output
|
108
|
+
}], slideEnd: [{
|
109
|
+
type: Output
|
110
|
+
}], stepKeyDown: [{
|
111
|
+
type: Output
|
112
|
+
}], endKeyDown: [{
|
113
|
+
type: Output
|
114
|
+
}], homeKeyDown: [{
|
115
|
+
type: Output
|
116
|
+
}] } });
|
117
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"slider-horizontal.component.js","sourceRoot":"","sources":["../../../../../packages/primitives/slider/src/slider-horizontal.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { BooleanInput } from '@angular/cdk/coercion';\nimport {\n    booleanAttribute,\n    Component,\n    ElementRef,\n    EventEmitter,\n    inject,\n    input,\n    Input,\n    Output,\n    signal,\n    viewChild\n} from '@angular/core';\nimport { RdxSliderImplDirective } from './slider-impl.directive';\nimport { RdxSliderRootComponent } from './slider-root.component';\nimport { BACK_KEYS, linearScale } from './utils';\n\n@Component({\n    selector: 'rdx-slider-horizontal',\n    standalone: true,\n    imports: [RdxSliderImplDirective],\n    template: `\n        <span\n            #sliderElement\n            [class]=\"className\"\n            [attr.data-orientation]=\"'horizontal'\"\n            [style]=\"{ '--rdx-slider-thumb-transform': 'translateX(-50%)' }\"\n            (slideStart)=\"onSlideStart($event)\"\n            (slideMove)=\"onSlideMove($event)\"\n            (slideEnd)=\"onSlideEnd()\"\n            (stepKeyDown)=\"onStepKeyDown($event)\"\n            (endKeyDown)=\"endKeyDown.emit($event)\"\n            (homeKeyDown)=\"homeKeyDown.emit($event)\"\n            rdxSliderImpl\n        >\n            <ng-content />\n        </span>\n    `\n})\nexport class RdxSliderHorizontalComponent {\n    private readonly rootContext = inject(RdxSliderRootComponent);\n\n    @Input() dir: 'ltr' | 'rtl' = 'ltr';\n\n    readonly inverted = input<boolean, BooleanInput>(false, { transform: booleanAttribute });\n\n    @Input() min = 0;\n    @Input() max = 100;\n\n    @Input() className = '';\n\n    @Output() slideStart = new EventEmitter<number>();\n    @Output() slideMove = new EventEmitter<number>();\n    @Output() slideEnd = new EventEmitter<void>();\n    @Output() stepKeyDown = new EventEmitter<{ event: KeyboardEvent; direction: number }>();\n    @Output() endKeyDown = new EventEmitter<KeyboardEvent>();\n    @Output() homeKeyDown = new EventEmitter<KeyboardEvent>();\n\n    private readonly sliderElement = viewChild<ElementRef>('sliderElement');\n\n    private readonly rect = signal<DOMRect | undefined>(undefined);\n\n    onSlideStart(event: PointerEvent) {\n        const value = this.getValueFromPointer(event.clientX);\n        this.slideStart.emit(value);\n    }\n\n    onSlideMove(event: PointerEvent) {\n        const value = this.getValueFromPointer(event.clientX);\n        this.slideMove.emit(value);\n    }\n\n    onSlideEnd() {\n        this.rect.set(undefined);\n        this.slideEnd.emit();\n    }\n\n    onStepKeyDown(event: KeyboardEvent) {\n        const slideDirection = this.rootContext.isSlidingFromLeft() ? 'from-left' : 'from-right';\n        const isBackKey = BACK_KEYS[slideDirection].includes(event.key);\n\n        this.stepKeyDown.emit({ event, direction: isBackKey ? -1 : 1 });\n    }\n\n    private getValueFromPointer(pointerPosition: number): number {\n        this.rect.set(this.sliderElement()?.nativeElement.getBoundingClientRect());\n        const rect = this.rect();\n        if (!rect) return 0;\n\n        const input: [number, number] = [0, rect.width];\n        const output: [number, number] = this.rootContext.isSlidingFromLeft()\n            ? [this.min, this.max]\n            : [this.max, this.min];\n\n        const value = linearScale(input, output);\n        this.rect.set(rect);\n\n        return value(pointerPosition - rect.left);\n    }\n}\n"]}
|
@@ -0,0 +1,89 @@
|
|
1
|
+
import { Directive, EventEmitter, inject, Output } from '@angular/core';
|
2
|
+
import { RdxSliderRootComponent } from './slider-root.component';
|
3
|
+
import { ARROW_KEYS, PAGE_KEYS } from './utils';
|
4
|
+
import * as i0 from "@angular/core";
|
5
|
+
export class RdxSliderImplDirective {
|
6
|
+
constructor() {
|
7
|
+
this.rootContext = inject(RdxSliderRootComponent);
|
8
|
+
this.slideStart = new EventEmitter();
|
9
|
+
this.slideMove = new EventEmitter();
|
10
|
+
this.slideEnd = new EventEmitter();
|
11
|
+
this.homeKeyDown = new EventEmitter();
|
12
|
+
this.endKeyDown = new EventEmitter();
|
13
|
+
this.stepKeyDown = new EventEmitter();
|
14
|
+
}
|
15
|
+
onKeyDown(event) {
|
16
|
+
if (event.key === 'Home') {
|
17
|
+
this.homeKeyDown.emit(event);
|
18
|
+
// Prevent scrolling to page start
|
19
|
+
event.preventDefault();
|
20
|
+
}
|
21
|
+
else if (event.key === 'End') {
|
22
|
+
this.endKeyDown.emit(event);
|
23
|
+
// Prevent scrolling to page end
|
24
|
+
event.preventDefault();
|
25
|
+
}
|
26
|
+
else if (PAGE_KEYS.concat(ARROW_KEYS).includes(event.key)) {
|
27
|
+
this.stepKeyDown.emit(event);
|
28
|
+
// Prevent scrolling for directional key presses
|
29
|
+
event.preventDefault();
|
30
|
+
}
|
31
|
+
}
|
32
|
+
onPointerDown(event) {
|
33
|
+
const target = event.target;
|
34
|
+
target.setPointerCapture(event.pointerId);
|
35
|
+
// Prevent browser focus behaviour because we focus a thumb manually when values change.
|
36
|
+
event.preventDefault();
|
37
|
+
// Touch devices have a delay before focusing so won't focus if touch immediately moves
|
38
|
+
// away from target (sliding). We want thumb to focus regardless.
|
39
|
+
if (this.rootContext.thumbElements.includes(target)) {
|
40
|
+
target.focus();
|
41
|
+
}
|
42
|
+
else {
|
43
|
+
this.slideStart.emit(event);
|
44
|
+
}
|
45
|
+
}
|
46
|
+
onPointerMove(event) {
|
47
|
+
const target = event.target;
|
48
|
+
if (target.hasPointerCapture(event.pointerId)) {
|
49
|
+
this.slideMove.emit(event);
|
50
|
+
}
|
51
|
+
}
|
52
|
+
onPointerUp(event) {
|
53
|
+
const target = event.target;
|
54
|
+
if (target.hasPointerCapture(event.pointerId)) {
|
55
|
+
target.releasePointerCapture(event.pointerId);
|
56
|
+
this.slideEnd.emit(event);
|
57
|
+
}
|
58
|
+
}
|
59
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxSliderImplDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
60
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.11", type: RdxSliderImplDirective, isStandalone: true, selector: "[rdxSliderImpl]", outputs: { slideStart: "slideStart", slideMove: "slideMove", slideEnd: "slideEnd", homeKeyDown: "homeKeyDown", endKeyDown: "endKeyDown", stepKeyDown: "stepKeyDown" }, host: { attributes: { "role": "slider", "tabindex": "0" }, listeners: { "keydown": "onKeyDown($event)", "pointerdown": "onPointerDown($event)", "pointermove": "onPointerMove($event)", "pointerup": "onPointerUp($event)" } }, ngImport: i0 }); }
|
61
|
+
}
|
62
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxSliderImplDirective, decorators: [{
|
63
|
+
type: Directive,
|
64
|
+
args: [{
|
65
|
+
selector: '[rdxSliderImpl]',
|
66
|
+
standalone: true,
|
67
|
+
host: {
|
68
|
+
role: 'slider',
|
69
|
+
tabindex: '0',
|
70
|
+
'(keydown)': 'onKeyDown($event)',
|
71
|
+
'(pointerdown)': 'onPointerDown($event)',
|
72
|
+
'(pointermove)': 'onPointerMove($event)',
|
73
|
+
'(pointerup)': 'onPointerUp($event)'
|
74
|
+
}
|
75
|
+
}]
|
76
|
+
}], propDecorators: { slideStart: [{
|
77
|
+
type: Output
|
78
|
+
}], slideMove: [{
|
79
|
+
type: Output
|
80
|
+
}], slideEnd: [{
|
81
|
+
type: Output
|
82
|
+
}], homeKeyDown: [{
|
83
|
+
type: Output
|
84
|
+
}], endKeyDown: [{
|
85
|
+
type: Output
|
86
|
+
}], stepKeyDown: [{
|
87
|
+
type: Output
|
88
|
+
}] } });
|
89
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2xpZGVyLWltcGwuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvcHJpbWl0aXZlcy9zbGlkZXIvc3JjL3NsaWRlci1pbXBsLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxNQUFNLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3hFLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ2pFLE9BQU8sRUFBRSxVQUFVLEVBQUUsU0FBUyxFQUFFLE1BQU0sU0FBUyxDQUFDOztBQWNoRCxNQUFNLE9BQU8sc0JBQXNCO0lBWm5DO1FBYXVCLGdCQUFXLEdBQUcsTUFBTSxDQUFDLHNCQUFzQixDQUFDLENBQUM7UUFFdEQsZUFBVSxHQUFHLElBQUksWUFBWSxFQUFnQixDQUFDO1FBQzlDLGNBQVMsR0FBRyxJQUFJLFlBQVksRUFBZ0IsQ0FBQztRQUM3QyxhQUFRLEdBQUcsSUFBSSxZQUFZLEVBQWdCLENBQUM7UUFDNUMsZ0JBQVcsR0FBRyxJQUFJLFlBQVksRUFBaUIsQ0FBQztRQUNoRCxlQUFVLEdBQUcsSUFBSSxZQUFZLEVBQWlCLENBQUM7UUFDL0MsZ0JBQVcsR0FBRyxJQUFJLFlBQVksRUFBaUIsQ0FBQztLQWdEN0Q7SUE5Q0csU0FBUyxDQUFDLEtBQW9CO1FBQzFCLElBQUksS0FBSyxDQUFDLEdBQUcsS0FBSyxNQUFNLEVBQUUsQ0FBQztZQUN2QixJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztZQUM3QixrQ0FBa0M7WUFDbEMsS0FBSyxDQUFDLGNBQWMsRUFBRSxDQUFDO1FBQzNCLENBQUM7YUFBTSxJQUFJLEtBQUssQ0FBQyxHQUFHLEtBQUssS0FBSyxFQUFFLENBQUM7WUFDN0IsSUFBSSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7WUFDNUIsZ0NBQWdDO1lBQ2hDLEtBQUssQ0FBQyxjQUFjLEVBQUUsQ0FBQztRQUMzQixDQUFDO2FBQU0sSUFBSSxTQUFTLENBQUMsTUFBTSxDQUFDLFVBQVUsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQztZQUMxRCxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztZQUM3QixnREFBZ0Q7WUFDaEQsS0FBSyxDQUFDLGNBQWMsRUFBRSxDQUFDO1FBQzNCLENBQUM7SUFDTCxDQUFDO0lBRUQsYUFBYSxDQUFDLEtBQW1CO1FBQzdCLE1BQU0sTUFBTSxHQUFHLEtBQUssQ0FBQyxNQUFxQixDQUFDO1FBQzNDLE1BQU0sQ0FBQyxpQkFBaUIsQ0FBQyxLQUFLLENBQUMsU0FBUyxDQUFDLENBQUM7UUFFMUMsd0ZBQXdGO1FBQ3hGLEtBQUssQ0FBQyxjQUFjLEVBQUUsQ0FBQztRQUV2Qix1RkFBdUY7UUFDdkYsaUVBQWlFO1FBQ2pFLElBQUksSUFBSSxDQUFDLFdBQVcsQ0FBQyxhQUFhLENBQUMsUUFBUSxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUM7WUFDbEQsTUFBTSxDQUFDLEtBQUssRUFBRSxDQUFDO1FBQ25CLENBQUM7YUFBTSxDQUFDO1lBQ0osSUFBSSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDaEMsQ0FBQztJQUNMLENBQUM7SUFFRCxhQUFhLENBQUMsS0FBbUI7UUFDN0IsTUFBTSxNQUFNLEdBQUcsS0FBSyxDQUFDLE1BQXFCLENBQUM7UUFDM0MsSUFBSSxNQUFNLENBQUMsaUJBQWlCLENBQUMsS0FBSyxDQUFDLFNBQVMsQ0FBQyxFQUFFLENBQUM7WUFDNUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDL0IsQ0FBQztJQUNMLENBQUM7SUFFRCxXQUFXLENBQUMsS0FBbUI7UUFDM0IsTUFBTSxNQUFNLEdBQUcsS0FBSyxDQUFDLE1BQXFCLENBQUM7UUFDM0MsSUFBSSxNQUFNLENBQUMsaUJBQWlCLENBQUMsS0FBSyxDQUFDLFNBQVMsQ0FBQyxFQUFFLENBQUM7WUFDNUMsTUFBTSxDQUFDLHFCQUFxQixDQUFDLEtBQUssQ0FBQyxTQUFTLENBQUMsQ0FBQztZQUM5QyxJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUM5QixDQUFDO0lBQ0wsQ0FBQzsrR0F2RFEsc0JBQXNCO21HQUF0QixzQkFBc0I7OzRGQUF0QixzQkFBc0I7a0JBWmxDLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLGlCQUFpQjtvQkFDM0IsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLElBQUksRUFBRTt3QkFDRixJQUFJLEVBQUUsUUFBUTt3QkFDZCxRQUFRLEVBQUUsR0FBRzt3QkFDYixXQUFXLEVBQUUsbUJBQW1CO3dCQUNoQyxlQUFlLEVBQUUsdUJBQXVCO3dCQUN4QyxlQUFlLEVBQUUsdUJBQXVCO3dCQUN4QyxhQUFhLEVBQUUscUJBQXFCO3FCQUN2QztpQkFDSjs4QkFJYSxVQUFVO3NCQUFuQixNQUFNO2dCQUNHLFNBQVM7c0JBQWxCLE1BQU07Z0JBQ0csUUFBUTtzQkFBakIsTUFBTTtnQkFDRyxXQUFXO3NCQUFwQixNQUFNO2dCQUNHLFVBQVU7c0JBQW5CLE1BQU07Z0JBQ0csV0FBVztzQkFBcEIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgRXZlbnRFbWl0dGVyLCBpbmplY3QsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgUmR4U2xpZGVyUm9vdENvbXBvbmVudCB9IGZyb20gJy4vc2xpZGVyLXJvb3QuY29tcG9uZW50JztcbmltcG9ydCB7IEFSUk9XX0tFWVMsIFBBR0VfS0VZUyB9IGZyb20gJy4vdXRpbHMnO1xuXG5ARGlyZWN0aXZlKHtcbiAgICBzZWxlY3RvcjogJ1tyZHhTbGlkZXJJbXBsXScsXG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICBob3N0OiB7XG4gICAgICAgIHJvbGU6ICdzbGlkZXInLFxuICAgICAgICB0YWJpbmRleDogJzAnLFxuICAgICAgICAnKGtleWRvd24pJzogJ29uS2V5RG93bigkZXZlbnQpJyxcbiAgICAgICAgJyhwb2ludGVyZG93biknOiAnb25Qb2ludGVyRG93bigkZXZlbnQpJyxcbiAgICAgICAgJyhwb2ludGVybW92ZSknOiAnb25Qb2ludGVyTW92ZSgkZXZlbnQpJyxcbiAgICAgICAgJyhwb2ludGVydXApJzogJ29uUG9pbnRlclVwKCRldmVudCknXG4gICAgfVxufSlcbmV4cG9ydCBjbGFzcyBSZHhTbGlkZXJJbXBsRGlyZWN0aXZlIHtcbiAgICBwcm90ZWN0ZWQgcmVhZG9ubHkgcm9vdENvbnRleHQgPSBpbmplY3QoUmR4U2xpZGVyUm9vdENvbXBvbmVudCk7XG5cbiAgICBAT3V0cHV0KCkgc2xpZGVTdGFydCA9IG5ldyBFdmVudEVtaXR0ZXI8UG9pbnRlckV2ZW50PigpO1xuICAgIEBPdXRwdXQoKSBzbGlkZU1vdmUgPSBuZXcgRXZlbnRFbWl0dGVyPFBvaW50ZXJFdmVudD4oKTtcbiAgICBAT3V0cHV0KCkgc2xpZGVFbmQgPSBuZXcgRXZlbnRFbWl0dGVyPFBvaW50ZXJFdmVudD4oKTtcbiAgICBAT3V0cHV0KCkgaG9tZUtleURvd24gPSBuZXcgRXZlbnRFbWl0dGVyPEtleWJvYXJkRXZlbnQ+KCk7XG4gICAgQE91dHB1dCgpIGVuZEtleURvd24gPSBuZXcgRXZlbnRFbWl0dGVyPEtleWJvYXJkRXZlbnQ+KCk7XG4gICAgQE91dHB1dCgpIHN0ZXBLZXlEb3duID0gbmV3IEV2ZW50RW1pdHRlcjxLZXlib2FyZEV2ZW50PigpO1xuXG4gICAgb25LZXlEb3duKGV2ZW50OiBLZXlib2FyZEV2ZW50KSB7XG4gICAgICAgIGlmIChldmVudC5rZXkgPT09ICdIb21lJykge1xuICAgICAgICAgICAgdGhpcy5ob21lS2V5RG93bi5lbWl0KGV2ZW50KTtcbiAgICAgICAgICAgIC8vIFByZXZlbnQgc2Nyb2xsaW5nIHRvIHBhZ2Ugc3RhcnRcbiAgICAgICAgICAgIGV2ZW50LnByZXZlbnREZWZhdWx0KCk7XG4gICAgICAgIH0gZWxzZSBpZiAoZXZlbnQua2V5ID09PSAnRW5kJykge1xuICAgICAgICAgICAgdGhpcy5lbmRLZXlEb3duLmVtaXQoZXZlbnQpO1xuICAgICAgICAgICAgLy8gUHJldmVudCBzY3JvbGxpbmcgdG8gcGFnZSBlbmRcbiAgICAgICAgICAgIGV2ZW50LnByZXZlbnREZWZhdWx0KCk7XG4gICAgICAgIH0gZWxzZSBpZiAoUEFHRV9LRVlTLmNvbmNhdChBUlJPV19LRVlTKS5pbmNsdWRlcyhldmVudC5rZXkpKSB7XG4gICAgICAgICAgICB0aGlzLnN0ZXBLZXlEb3duLmVtaXQoZXZlbnQpO1xuICAgICAgICAgICAgLy8gUHJldmVudCBzY3JvbGxpbmcgZm9yIGRpcmVjdGlvbmFsIGtleSBwcmVzc2VzXG4gICAgICAgICAgICBldmVudC5wcmV2ZW50RGVmYXVsdCgpO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgb25Qb2ludGVyRG93bihldmVudDogUG9pbnRlckV2ZW50KSB7XG4gICAgICAgIGNvbnN0IHRhcmdldCA9IGV2ZW50LnRhcmdldCBhcyBIVE1MRWxlbWVudDtcbiAgICAgICAgdGFyZ2V0LnNldFBvaW50ZXJDYXB0dXJlKGV2ZW50LnBvaW50ZXJJZCk7XG5cbiAgICAgICAgLy8gUHJldmVudCBicm93c2VyIGZvY3VzIGJlaGF2aW91ciBiZWNhdXNlIHdlIGZvY3VzIGEgdGh1bWIgbWFudWFsbHkgd2hlbiB2YWx1ZXMgY2hhbmdlLlxuICAgICAgICBldmVudC5wcmV2ZW50RGVmYXVsdCgpO1xuXG4gICAgICAgIC8vIFRvdWNoIGRldmljZXMgaGF2ZSBhIGRlbGF5IGJlZm9yZSBmb2N1c2luZyBzbyB3b24ndCBmb2N1cyBpZiB0b3VjaCBpbW1lZGlhdGVseSBtb3Zlc1xuICAgICAgICAvLyBhd2F5IGZyb20gdGFyZ2V0IChzbGlkaW5nKS4gV2Ugd2FudCB0aHVtYiB0byBmb2N1cyByZWdhcmRsZXNzLlxuICAgICAgICBpZiAodGhpcy5yb290Q29udGV4dC50aHVtYkVsZW1lbnRzLmluY2x1ZGVzKHRhcmdldCkpIHtcbiAgICAgICAgICAgIHRhcmdldC5mb2N1cygpO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgdGhpcy5zbGlkZVN0YXJ0LmVtaXQoZXZlbnQpO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgb25Qb2ludGVyTW92ZShldmVudDogUG9pbnRlckV2ZW50KSB7XG4gICAgICAgIGNvbnN0IHRhcmdldCA9IGV2ZW50LnRhcmdldCBhcyBIVE1MRWxlbWVudDtcbiAgICAgICAgaWYgKHRhcmdldC5oYXNQb2ludGVyQ2FwdHVyZShldmVudC5wb2ludGVySWQpKSB7XG4gICAgICAgICAgICB0aGlzLnNsaWRlTW92ZS5lbWl0KGV2ZW50KTtcbiAgICAgICAgfVxuICAgIH1cblxuICAgIG9uUG9pbnRlclVwKGV2ZW50OiBQb2ludGVyRXZlbnQpIHtcbiAgICAgICAgY29uc3QgdGFyZ2V0ID0gZXZlbnQudGFyZ2V0IGFzIEhUTUxFbGVtZW50O1xuICAgICAgICBpZiAodGFyZ2V0Lmhhc1BvaW50ZXJDYXB0dXJlKGV2ZW50LnBvaW50ZXJJZCkpIHtcbiAgICAgICAgICAgIHRhcmdldC5yZWxlYXNlUG9pbnRlckNhcHR1cmUoZXZlbnQucG9pbnRlcklkKTtcbiAgICAgICAgICAgIHRoaXMuc2xpZGVFbmQuZW1pdChldmVudCk7XG4gICAgICAgIH1cbiAgICB9XG59XG4iXX0=
|
@@ -0,0 +1,28 @@
|
|
1
|
+
import { Injectable, signal } from '@angular/core';
|
2
|
+
import * as i0 from "@angular/core";
|
3
|
+
export class RdxSliderOrientationContextService {
|
4
|
+
constructor() {
|
5
|
+
this.contextSignal = signal({
|
6
|
+
startEdge: 'left',
|
7
|
+
endEdge: 'right',
|
8
|
+
direction: 1,
|
9
|
+
size: 'width'
|
10
|
+
});
|
11
|
+
}
|
12
|
+
get context() {
|
13
|
+
return this.contextSignal();
|
14
|
+
}
|
15
|
+
updateContext(context) {
|
16
|
+
this.contextSignal.update((current) => ({
|
17
|
+
...current,
|
18
|
+
...context
|
19
|
+
}));
|
20
|
+
}
|
21
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxSliderOrientationContextService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
22
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxSliderOrientationContextService, providedIn: 'root' }); }
|
23
|
+
}
|
24
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxSliderOrientationContextService, decorators: [{
|
25
|
+
type: Injectable,
|
26
|
+
args: [{ providedIn: 'root' }]
|
27
|
+
}] });
|
28
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2xpZGVyLW9yaWVudGF0aW9uLWNvbnRleHQuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3ByaW1pdGl2ZXMvc2xpZGVyL3NyYy9zbGlkZXItb3JpZW50YXRpb24tY29udGV4dC5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQVVuRCxNQUFNLE9BQU8sa0NBQWtDO0lBRC9DO1FBRVksa0JBQWEsR0FBRyxNQUFNLENBQXFCO1lBQy9DLFNBQVMsRUFBRSxNQUFNO1lBQ2pCLE9BQU8sRUFBRSxPQUFPO1lBQ2hCLFNBQVMsRUFBRSxDQUFDO1lBQ1osSUFBSSxFQUFFLE9BQU87U0FDaEIsQ0FBQyxDQUFDO0tBWU47SUFWRyxJQUFJLE9BQU87UUFDUCxPQUFPLElBQUksQ0FBQyxhQUFhLEVBQUUsQ0FBQztJQUNoQyxDQUFDO0lBRUQsYUFBYSxDQUFDLE9BQW9DO1FBQzlDLElBQUksQ0FBQyxhQUFhLENBQUMsTUFBTSxDQUFDLENBQUMsT0FBTyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1lBQ3BDLEdBQUcsT0FBTztZQUNWLEdBQUcsT0FBTztTQUNiLENBQUMsQ0FBQyxDQUFDO0lBQ1IsQ0FBQzsrR0FqQlEsa0NBQWtDO21IQUFsQyxrQ0FBa0MsY0FEckIsTUFBTTs7NEZBQ25CLGtDQUFrQztrQkFEOUMsVUFBVTttQkFBQyxFQUFFLFVBQVUsRUFBRSxNQUFNLEVBQUUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlLCBzaWduYWwgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuZXhwb3J0IGludGVyZmFjZSBPcmllbnRhdGlvbkNvbnRleHQge1xuICAgIHN0YXJ0RWRnZTogc3RyaW5nO1xuICAgIGVuZEVkZ2U6IHN0cmluZztcbiAgICBkaXJlY3Rpb246IG51bWJlcjtcbiAgICBzaXplOiBzdHJpbmc7XG59XG5cbkBJbmplY3RhYmxlKHsgcHJvdmlkZWRJbjogJ3Jvb3QnIH0pXG5leHBvcnQgY2xhc3MgUmR4U2xpZGVyT3JpZW50YXRpb25Db250ZXh0U2VydmljZSB7XG4gICAgcHJpdmF0ZSBjb250ZXh0U2lnbmFsID0gc2lnbmFsPE9yaWVudGF0aW9uQ29udGV4dD4oe1xuICAgICAgICBzdGFydEVkZ2U6ICdsZWZ0JyxcbiAgICAgICAgZW5kRWRnZTogJ3JpZ2h0JyxcbiAgICAgICAgZGlyZWN0aW9uOiAxLFxuICAgICAgICBzaXplOiAnd2lkdGgnXG4gICAgfSk7XG5cbiAgICBnZXQgY29udGV4dCgpIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuY29udGV4dFNpZ25hbCgpO1xuICAgIH1cblxuICAgIHVwZGF0ZUNvbnRleHQoY29udGV4dDogUGFydGlhbDxPcmllbnRhdGlvbkNvbnRleHQ+KSB7XG4gICAgICAgIHRoaXMuY29udGV4dFNpZ25hbC51cGRhdGUoKGN1cnJlbnQpID0+ICh7XG4gICAgICAgICAgICAuLi5jdXJyZW50LFxuICAgICAgICAgICAgLi4uY29udGV4dFxuICAgICAgICB9KSk7XG4gICAgfVxufVxuIl19
|
@@ -0,0 +1,41 @@
|
|
1
|
+
import { Component, computed, inject } from '@angular/core';
|
2
|
+
import { RdxSliderRootComponent } from './slider-root.component';
|
3
|
+
import { convertValueToPercentage } from './utils';
|
4
|
+
import * as i0 from "@angular/core";
|
5
|
+
export class RdxSliderRangeComponent {
|
6
|
+
constructor() {
|
7
|
+
this.rootContext = inject(RdxSliderRootComponent);
|
8
|
+
this.percentages = computed(() => this.rootContext
|
9
|
+
.modelValue()
|
10
|
+
?.map((value) => convertValueToPercentage(value, this.rootContext.min(), this.rootContext.max())));
|
11
|
+
this.offsetStart = computed(() => (this.rootContext.modelValue().length > 1 ? Math.min(...this.percentages()) : 0));
|
12
|
+
this.offsetEnd = computed(() => 100 - Math.max(...this.percentages()));
|
13
|
+
this.rangeStyles = computed(() => {
|
14
|
+
const context = this.rootContext.orientationContext.context;
|
15
|
+
return {
|
16
|
+
[context.startEdge]: `${this.offsetStart()}%`,
|
17
|
+
[context.endEdge]: `${this.offsetEnd()}%`
|
18
|
+
};
|
19
|
+
});
|
20
|
+
}
|
21
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxSliderRangeComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
22
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.11", type: RdxSliderRangeComponent, isStandalone: true, selector: "rdx-slider-range", host: { properties: { "attr.data-disabled": "rootContext.disabled() ? \"\" : undefined", "attr.data-orientation": "rootContext.orientation()", "style": "rangeStyles()" } }, ngImport: i0, template: `
|
23
|
+
<ng-content />
|
24
|
+
`, isInline: true }); }
|
25
|
+
}
|
26
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxSliderRangeComponent, decorators: [{
|
27
|
+
type: Component,
|
28
|
+
args: [{
|
29
|
+
selector: 'rdx-slider-range',
|
30
|
+
standalone: true,
|
31
|
+
host: {
|
32
|
+
'[attr.data-disabled]': 'rootContext.disabled() ? "" : undefined',
|
33
|
+
'[attr.data-orientation]': 'rootContext.orientation()',
|
34
|
+
'[style]': 'rangeStyles()'
|
35
|
+
},
|
36
|
+
template: `
|
37
|
+
<ng-content />
|
38
|
+
`
|
39
|
+
}]
|
40
|
+
}] });
|
41
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2xpZGVyLXJhbmdlLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3ByaW1pdGl2ZXMvc2xpZGVyL3NyYy9zbGlkZXItcmFuZ2UuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsUUFBUSxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUM1RCxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUNqRSxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSxTQUFTLENBQUM7O0FBY25ELE1BQU0sT0FBTyx1QkFBdUI7SUFacEM7UUFhdUIsZ0JBQVcsR0FBRyxNQUFNLENBQUMsc0JBQXNCLENBQUMsQ0FBQztRQUVoRSxnQkFBVyxHQUFHLFFBQVEsQ0FBQyxHQUFHLEVBQUUsQ0FDeEIsSUFBSSxDQUFDLFdBQVc7YUFDWCxVQUFVLEVBQUU7WUFDYixFQUFFLEdBQUcsQ0FBQyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsd0JBQXdCLENBQUMsS0FBSyxFQUFFLElBQUksQ0FBQyxXQUFXLENBQUMsR0FBRyxFQUFFLEVBQUUsSUFBSSxDQUFDLFdBQVcsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxDQUFDLENBQ3hHLENBQUM7UUFFRixnQkFBVyxHQUFHLFFBQVEsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsVUFBVSxFQUFHLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxHQUFHLElBQUksQ0FBQyxXQUFXLEVBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQ2pILGNBQVMsR0FBRyxRQUFRLENBQUMsR0FBRyxFQUFFLENBQUMsR0FBRyxHQUFHLElBQUksQ0FBQyxHQUFHLENBQUMsR0FBRyxJQUFJLENBQUMsV0FBVyxFQUFHLENBQUMsQ0FBQyxDQUFDO1FBRW5FLGdCQUFXLEdBQUcsUUFBUSxDQUFDLEdBQUcsRUFBRTtZQUN4QixNQUFNLE9BQU8sR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLGtCQUFrQixDQUFDLE9BQU8sQ0FBQztZQUU1RCxPQUFPO2dCQUNILENBQUMsT0FBTyxDQUFDLFNBQVMsQ0FBQyxFQUFFLEdBQUcsSUFBSSxDQUFDLFdBQVcsRUFBRSxHQUFHO2dCQUM3QyxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsRUFBRSxHQUFHLElBQUksQ0FBQyxTQUFTLEVBQUUsR0FBRzthQUM1QyxDQUFDO1FBQ04sQ0FBQyxDQUFDLENBQUM7S0FDTjsrR0FwQlksdUJBQXVCO21HQUF2Qix1QkFBdUIseVBBSnRCOztLQUVUOzs0RkFFUSx1QkFBdUI7a0JBWm5DLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLGtCQUFrQjtvQkFDNUIsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLElBQUksRUFBRTt3QkFDRixzQkFBc0IsRUFBRSx5Q0FBeUM7d0JBQ2pFLHlCQUF5QixFQUFFLDJCQUEyQjt3QkFDdEQsU0FBUyxFQUFFLGVBQWU7cUJBQzdCO29CQUNELFFBQVEsRUFBRTs7S0FFVDtpQkFDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgY29tcHV0ZWQsIGluamVjdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgUmR4U2xpZGVyUm9vdENvbXBvbmVudCB9IGZyb20gJy4vc2xpZGVyLXJvb3QuY29tcG9uZW50JztcbmltcG9ydCB7IGNvbnZlcnRWYWx1ZVRvUGVyY2VudGFnZSB9IGZyb20gJy4vdXRpbHMnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ3JkeC1zbGlkZXItcmFuZ2UnLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgaG9zdDoge1xuICAgICAgICAnW2F0dHIuZGF0YS1kaXNhYmxlZF0nOiAncm9vdENvbnRleHQuZGlzYWJsZWQoKSA/IFwiXCIgOiB1bmRlZmluZWQnLFxuICAgICAgICAnW2F0dHIuZGF0YS1vcmllbnRhdGlvbl0nOiAncm9vdENvbnRleHQub3JpZW50YXRpb24oKScsXG4gICAgICAgICdbc3R5bGVdJzogJ3JhbmdlU3R5bGVzKCknXG4gICAgfSxcbiAgICB0ZW1wbGF0ZTogYFxuICAgICAgICA8bmctY29udGVudCAvPlxuICAgIGBcbn0pXG5leHBvcnQgY2xhc3MgUmR4U2xpZGVyUmFuZ2VDb21wb25lbnQge1xuICAgIHByb3RlY3RlZCByZWFkb25seSByb290Q29udGV4dCA9IGluamVjdChSZHhTbGlkZXJSb290Q29tcG9uZW50KTtcblxuICAgIHBlcmNlbnRhZ2VzID0gY29tcHV0ZWQoKCkgPT5cbiAgICAgICAgdGhpcy5yb290Q29udGV4dFxuICAgICAgICAgICAgLm1vZGVsVmFsdWUoKVxuICAgICAgICAgICAgPy5tYXAoKHZhbHVlKSA9PiBjb252ZXJ0VmFsdWVUb1BlcmNlbnRhZ2UodmFsdWUsIHRoaXMucm9vdENvbnRleHQubWluKCksIHRoaXMucm9vdENvbnRleHQubWF4KCkpKVxuICAgICk7XG5cbiAgICBvZmZzZXRTdGFydCA9IGNvbXB1dGVkKCgpID0+ICh0aGlzLnJvb3RDb250ZXh0Lm1vZGVsVmFsdWUoKSEubGVuZ3RoID4gMSA/IE1hdGgubWluKC4uLnRoaXMucGVyY2VudGFnZXMoKSEpIDogMCkpO1xuICAgIG9mZnNldEVuZCA9IGNvbXB1dGVkKCgpID0+IDEwMCAtIE1hdGgubWF4KC4uLnRoaXMucGVyY2VudGFnZXMoKSEpKTtcblxuICAgIHJhbmdlU3R5bGVzID0gY29tcHV0ZWQoKCkgPT4ge1xuICAgICAgICBjb25zdCBjb250ZXh0ID0gdGhpcy5yb290Q29udGV4dC5vcmllbnRhdGlvbkNvbnRleHQuY29udGV4dDtcblxuICAgICAgICByZXR1cm4ge1xuICAgICAgICAgICAgW2NvbnRleHQuc3RhcnRFZGdlXTogYCR7dGhpcy5vZmZzZXRTdGFydCgpfSVgLFxuICAgICAgICAgICAgW2NvbnRleHQuZW5kRWRnZV06IGAke3RoaXMub2Zmc2V0RW5kKCl9JWBcbiAgICAgICAgfTtcbiAgICB9KTtcbn1cbiJdfQ==
|
@@ -0,0 +1,207 @@
|
|
1
|
+
import { NgIf, NgTemplateOutlet } from '@angular/common';
|
2
|
+
import { booleanAttribute, Component, computed, EventEmitter, inject, input, Input, model, numberAttribute, Output } from '@angular/core';
|
3
|
+
import { RdxSliderHorizontalComponent } from './slider-horizontal.component';
|
4
|
+
import { RdxSliderOrientationContextService } from './slider-orientation-context.service';
|
5
|
+
import { RdxSliderVerticalComponent } from './slider-vertical.component';
|
6
|
+
import { clamp, getClosestValueIndex, getDecimalCount, getNextSortedValues, hasMinStepsBetweenValues, roundValue } from './utils';
|
7
|
+
import * as i0 from "@angular/core";
|
8
|
+
export class RdxSliderRootComponent {
|
9
|
+
constructor() {
|
10
|
+
/** @ignore */
|
11
|
+
this.orientationContext = inject(RdxSliderOrientationContextService);
|
12
|
+
this.min = input(0, { transform: numberAttribute });
|
13
|
+
this.max = input(100, { transform: numberAttribute });
|
14
|
+
this.step = input(1, { transform: numberAttribute });
|
15
|
+
this.minStepsBetweenThumbs = input(0, { transform: numberAttribute });
|
16
|
+
this.orientation = input('horizontal');
|
17
|
+
this.disabled = input(false, { transform: booleanAttribute });
|
18
|
+
this.inverted = input(false, { transform: booleanAttribute });
|
19
|
+
this.dir = input('ltr');
|
20
|
+
this.className = '';
|
21
|
+
this.valueChange = new EventEmitter();
|
22
|
+
this.valueCommit = new EventEmitter();
|
23
|
+
this.modelValue = model([0]);
|
24
|
+
/** @ignore */
|
25
|
+
this.valueIndexToChange = model(0);
|
26
|
+
/** @ignore */
|
27
|
+
this.valuesBeforeSlideStart = model([]);
|
28
|
+
this.isSlidingFromLeft = computed(() => (this.dir() === 'ltr' && !this.inverted()) || (this.dir() !== 'ltr' && this.inverted()));
|
29
|
+
this.isSlidingFromBottom = computed(() => !this.inverted());
|
30
|
+
/** @ignore */
|
31
|
+
this.thumbElements = [];
|
32
|
+
}
|
33
|
+
/** @ignore */
|
34
|
+
ngOnInit() {
|
35
|
+
const isHorizontal = this.orientation() === 'horizontal';
|
36
|
+
if (isHorizontal) {
|
37
|
+
this.orientationContext.updateContext({
|
38
|
+
direction: this.isSlidingFromLeft() ? 1 : -1,
|
39
|
+
size: 'width',
|
40
|
+
startEdge: this.isSlidingFromLeft() ? 'left' : 'right',
|
41
|
+
endEdge: this.isSlidingFromLeft() ? 'right' : 'left'
|
42
|
+
});
|
43
|
+
}
|
44
|
+
else {
|
45
|
+
this.orientationContext.updateContext({
|
46
|
+
direction: this.isSlidingFromBottom() ? -1 : 1,
|
47
|
+
size: 'height',
|
48
|
+
startEdge: this.isSlidingFromBottom() ? 'bottom' : 'top',
|
49
|
+
endEdge: this.isSlidingFromBottom() ? 'top' : 'bottom'
|
50
|
+
});
|
51
|
+
}
|
52
|
+
}
|
53
|
+
/** @ignore */
|
54
|
+
onPointerDown() {
|
55
|
+
this.valuesBeforeSlideStart.set([...this.modelValue()]);
|
56
|
+
}
|
57
|
+
/** @ignore */
|
58
|
+
handleSlideStart(value) {
|
59
|
+
const closestIndex = getClosestValueIndex(this.modelValue(), value);
|
60
|
+
this.updateValues(value, closestIndex);
|
61
|
+
}
|
62
|
+
/** @ignore */
|
63
|
+
handleSlideMove(value) {
|
64
|
+
this.updateValues(value, this.valueIndexToChange());
|
65
|
+
}
|
66
|
+
/** @ignore */
|
67
|
+
handleSlideEnd() {
|
68
|
+
const prevValue = this.valuesBeforeSlideStart()[this.valueIndexToChange()];
|
69
|
+
const nextValue = this.modelValue()[this.valueIndexToChange()];
|
70
|
+
const hasChanged = nextValue !== prevValue;
|
71
|
+
if (hasChanged) {
|
72
|
+
this.valueCommit.emit([...this.modelValue()]);
|
73
|
+
}
|
74
|
+
}
|
75
|
+
/** @ignore */
|
76
|
+
handleStepKeyDown(event) {
|
77
|
+
const stepInDirection = this.step() * event.direction;
|
78
|
+
const atIndex = this.valueIndexToChange();
|
79
|
+
const currentValue = this.modelValue()[atIndex];
|
80
|
+
this.updateValues(currentValue + stepInDirection, atIndex, true);
|
81
|
+
}
|
82
|
+
/** @ignore */
|
83
|
+
updateValues(value, atIndex, commit = false) {
|
84
|
+
const decimalCount = getDecimalCount(this.step());
|
85
|
+
const snapToStep = roundValue(Math.round((value - this.min()) / this.step()) * this.step() + this.min(), decimalCount);
|
86
|
+
const nextValue = clamp(snapToStep, this.min(), this.max());
|
87
|
+
const nextValues = getNextSortedValues(this.modelValue(), nextValue, atIndex);
|
88
|
+
if (hasMinStepsBetweenValues(nextValues, this.minStepsBetweenThumbs() * this.step())) {
|
89
|
+
this.valueIndexToChange.set(nextValues.indexOf(nextValue));
|
90
|
+
const hasChanged = String(nextValues) !== String(this.modelValue());
|
91
|
+
if (hasChanged) {
|
92
|
+
this.modelValue.set(nextValues);
|
93
|
+
this.valueChange.emit([...this.modelValue()]);
|
94
|
+
this.thumbElements[this.valueIndexToChange()]?.focus();
|
95
|
+
if (commit) {
|
96
|
+
this.valueCommit.emit([...this.modelValue()]);
|
97
|
+
}
|
98
|
+
}
|
99
|
+
}
|
100
|
+
}
|
101
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxSliderRootComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
102
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.11", type: RdxSliderRootComponent, isStandalone: true, selector: "rdx-slider", inputs: { min: { classPropertyName: "min", publicName: "min", isSignal: true, isRequired: false, transformFunction: null }, max: { classPropertyName: "max", publicName: "max", isSignal: true, isRequired: false, transformFunction: null }, step: { classPropertyName: "step", publicName: "step", isSignal: true, isRequired: false, transformFunction: null }, minStepsBetweenThumbs: { classPropertyName: "minStepsBetweenThumbs", publicName: "minStepsBetweenThumbs", isSignal: true, isRequired: false, transformFunction: null }, orientation: { classPropertyName: "orientation", publicName: "orientation", isSignal: true, isRequired: false, transformFunction: null }, disabled: { classPropertyName: "disabled", publicName: "disabled", isSignal: true, isRequired: false, transformFunction: null }, inverted: { classPropertyName: "inverted", publicName: "inverted", isSignal: true, isRequired: false, transformFunction: null }, dir: { classPropertyName: "dir", publicName: "dir", isSignal: true, isRequired: false, transformFunction: null }, className: { classPropertyName: "className", publicName: "className", isSignal: false, isRequired: false, transformFunction: null }, modelValue: { classPropertyName: "modelValue", publicName: "modelValue", isSignal: true, isRequired: false, transformFunction: null }, valueIndexToChange: { classPropertyName: "valueIndexToChange", publicName: "valueIndexToChange", isSignal: true, isRequired: false, transformFunction: null }, valuesBeforeSlideStart: { classPropertyName: "valuesBeforeSlideStart", publicName: "valuesBeforeSlideStart", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { valueChange: "valueChange", valueCommit: "valueCommit", modelValue: "modelValueChange", valueIndexToChange: "valueIndexToChangeChange", valuesBeforeSlideStart: "valuesBeforeSlideStartChange" }, ngImport: i0, template: `
|
103
|
+
<ng-template #transclude><ng-content /></ng-template>
|
104
|
+
|
105
|
+
<ng-container *ngIf="orientation() === 'horizontal'">
|
106
|
+
<rdx-slider-horizontal
|
107
|
+
[className]="className"
|
108
|
+
[min]="min()"
|
109
|
+
[max]="max()"
|
110
|
+
[dir]="dir()"
|
111
|
+
[inverted]="inverted()"
|
112
|
+
[attr.aria-disabled]="disabled()"
|
113
|
+
[attr.data-disabled]="disabled() ? '' : undefined"
|
114
|
+
(pointerdown)="onPointerDown()"
|
115
|
+
(slideStart)="handleSlideStart($event)"
|
116
|
+
(slideMove)="handleSlideMove($event)"
|
117
|
+
(slideEnd)="handleSlideEnd()"
|
118
|
+
(homeKeyDown)="updateValues(min(), 0, true)"
|
119
|
+
(endKeyDown)="updateValues(max(), modelValue().length - 1, true)"
|
120
|
+
(stepKeyDown)="handleStepKeyDown($event)"
|
121
|
+
>
|
122
|
+
<ng-container *ngTemplateOutlet="transclude" />
|
123
|
+
</rdx-slider-horizontal>
|
124
|
+
</ng-container>
|
125
|
+
|
126
|
+
<ng-container *ngIf="orientation() === 'vertical'">
|
127
|
+
<rdx-slider-vertical
|
128
|
+
[className]="className"
|
129
|
+
[min]="min()"
|
130
|
+
[max]="max()"
|
131
|
+
[dir]="dir()"
|
132
|
+
[inverted]="inverted()"
|
133
|
+
[attr.aria-disabled]="disabled()"
|
134
|
+
[attr.data-disabled]="disabled() ? '' : undefined"
|
135
|
+
(pointerdown)="onPointerDown()"
|
136
|
+
(slideStart)="handleSlideStart($event)"
|
137
|
+
(slideMove)="handleSlideMove($event)"
|
138
|
+
(slideEnd)="handleSlideEnd()"
|
139
|
+
(homeKeyDown)="updateValues(min(), 0, true)"
|
140
|
+
(endKeyDown)="updateValues(max(), modelValue().length - 1, true)"
|
141
|
+
(stepKeyDown)="handleStepKeyDown($event)"
|
142
|
+
>
|
143
|
+
<ng-container *ngTemplateOutlet="transclude" />
|
144
|
+
</rdx-slider-vertical>
|
145
|
+
</ng-container>
|
146
|
+
`, isInline: true, dependencies: [{ kind: "component", type: RdxSliderHorizontalComponent, selector: "rdx-slider-horizontal", inputs: ["dir", "inverted", "min", "max", "className"], outputs: ["slideStart", "slideMove", "slideEnd", "stepKeyDown", "endKeyDown", "homeKeyDown"] }, { kind: "component", type: RdxSliderVerticalComponent, selector: "rdx-slider-vertical", inputs: ["dir", "inverted", "min", "max", "className"], outputs: ["slideStart", "slideMove", "slideEnd", "stepKeyDown", "endKeyDown", "homeKeyDown"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }] }); }
|
147
|
+
}
|
148
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxSliderRootComponent, decorators: [{
|
149
|
+
type: Component,
|
150
|
+
args: [{
|
151
|
+
selector: 'rdx-slider',
|
152
|
+
standalone: true,
|
153
|
+
imports: [RdxSliderHorizontalComponent, RdxSliderVerticalComponent, NgIf, NgTemplateOutlet],
|
154
|
+
template: `
|
155
|
+
<ng-template #transclude><ng-content /></ng-template>
|
156
|
+
|
157
|
+
<ng-container *ngIf="orientation() === 'horizontal'">
|
158
|
+
<rdx-slider-horizontal
|
159
|
+
[className]="className"
|
160
|
+
[min]="min()"
|
161
|
+
[max]="max()"
|
162
|
+
[dir]="dir()"
|
163
|
+
[inverted]="inverted()"
|
164
|
+
[attr.aria-disabled]="disabled()"
|
165
|
+
[attr.data-disabled]="disabled() ? '' : undefined"
|
166
|
+
(pointerdown)="onPointerDown()"
|
167
|
+
(slideStart)="handleSlideStart($event)"
|
168
|
+
(slideMove)="handleSlideMove($event)"
|
169
|
+
(slideEnd)="handleSlideEnd()"
|
170
|
+
(homeKeyDown)="updateValues(min(), 0, true)"
|
171
|
+
(endKeyDown)="updateValues(max(), modelValue().length - 1, true)"
|
172
|
+
(stepKeyDown)="handleStepKeyDown($event)"
|
173
|
+
>
|
174
|
+
<ng-container *ngTemplateOutlet="transclude" />
|
175
|
+
</rdx-slider-horizontal>
|
176
|
+
</ng-container>
|
177
|
+
|
178
|
+
<ng-container *ngIf="orientation() === 'vertical'">
|
179
|
+
<rdx-slider-vertical
|
180
|
+
[className]="className"
|
181
|
+
[min]="min()"
|
182
|
+
[max]="max()"
|
183
|
+
[dir]="dir()"
|
184
|
+
[inverted]="inverted()"
|
185
|
+
[attr.aria-disabled]="disabled()"
|
186
|
+
[attr.data-disabled]="disabled() ? '' : undefined"
|
187
|
+
(pointerdown)="onPointerDown()"
|
188
|
+
(slideStart)="handleSlideStart($event)"
|
189
|
+
(slideMove)="handleSlideMove($event)"
|
190
|
+
(slideEnd)="handleSlideEnd()"
|
191
|
+
(homeKeyDown)="updateValues(min(), 0, true)"
|
192
|
+
(endKeyDown)="updateValues(max(), modelValue().length - 1, true)"
|
193
|
+
(stepKeyDown)="handleStepKeyDown($event)"
|
194
|
+
>
|
195
|
+
<ng-container *ngTemplateOutlet="transclude" />
|
196
|
+
</rdx-slider-vertical>
|
197
|
+
</ng-container>
|
198
|
+
`
|
199
|
+
}]
|
200
|
+
}], propDecorators: { className: [{
|
201
|
+
type: Input
|
202
|
+
}], valueChange: [{
|
203
|
+
type: Output
|
204
|
+
}], valueCommit: [{
|
205
|
+
type: Output
|
206
|
+
}] } });
|
207
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"slider-root.component.js","sourceRoot":"","sources":["../../../../../packages/primitives/slider/src/slider-root.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { BooleanInput, NumberInput } from '@angular/cdk/coercion';\nimport { NgIf, NgTemplateOutlet } from '@angular/common';\nimport {\n    booleanAttribute,\n    Component,\n    computed,\n    EventEmitter,\n    inject,\n    input,\n    Input,\n    model,\n    numberAttribute,\n    OnInit,\n    Output\n} from '@angular/core';\nimport { RdxSliderHorizontalComponent } from './slider-horizontal.component';\nimport { RdxSliderOrientationContextService } from './slider-orientation-context.service';\nimport { RdxSliderVerticalComponent } from './slider-vertical.component';\nimport {\n    clamp,\n    getClosestValueIndex,\n    getDecimalCount,\n    getNextSortedValues,\n    hasMinStepsBetweenValues,\n    roundValue\n} from './utils';\n\n@Component({\n    selector: 'rdx-slider',\n    standalone: true,\n    imports: [RdxSliderHorizontalComponent, RdxSliderVerticalComponent, NgIf, NgTemplateOutlet],\n    template: `\n        <ng-template #transclude><ng-content /></ng-template>\n\n        <ng-container *ngIf=\"orientation() === 'horizontal'\">\n            <rdx-slider-horizontal\n                [className]=\"className\"\n                [min]=\"min()\"\n                [max]=\"max()\"\n                [dir]=\"dir()\"\n                [inverted]=\"inverted()\"\n                [attr.aria-disabled]=\"disabled()\"\n                [attr.data-disabled]=\"disabled() ? '' : undefined\"\n                (pointerdown)=\"onPointerDown()\"\n                (slideStart)=\"handleSlideStart($event)\"\n                (slideMove)=\"handleSlideMove($event)\"\n                (slideEnd)=\"handleSlideEnd()\"\n                (homeKeyDown)=\"updateValues(min(), 0, true)\"\n                (endKeyDown)=\"updateValues(max(), modelValue().length - 1, true)\"\n                (stepKeyDown)=\"handleStepKeyDown($event)\"\n            >\n                <ng-container *ngTemplateOutlet=\"transclude\" />\n            </rdx-slider-horizontal>\n        </ng-container>\n\n        <ng-container *ngIf=\"orientation() === 'vertical'\">\n            <rdx-slider-vertical\n                [className]=\"className\"\n                [min]=\"min()\"\n                [max]=\"max()\"\n                [dir]=\"dir()\"\n                [inverted]=\"inverted()\"\n                [attr.aria-disabled]=\"disabled()\"\n                [attr.data-disabled]=\"disabled() ? '' : undefined\"\n                (pointerdown)=\"onPointerDown()\"\n                (slideStart)=\"handleSlideStart($event)\"\n                (slideMove)=\"handleSlideMove($event)\"\n                (slideEnd)=\"handleSlideEnd()\"\n                (homeKeyDown)=\"updateValues(min(), 0, true)\"\n                (endKeyDown)=\"updateValues(max(), modelValue().length - 1, true)\"\n                (stepKeyDown)=\"handleStepKeyDown($event)\"\n            >\n                <ng-container *ngTemplateOutlet=\"transclude\" />\n            </rdx-slider-vertical>\n        </ng-container>\n    `\n})\nexport class RdxSliderRootComponent implements OnInit {\n    /** @ignore */\n    readonly orientationContext = inject(RdxSliderOrientationContextService);\n\n    readonly min = input<number, NumberInput>(0, { transform: numberAttribute });\n\n    readonly max = input<number, NumberInput>(100, { transform: numberAttribute });\n\n    readonly step = input<number, NumberInput>(1, { transform: numberAttribute });\n\n    readonly minStepsBetweenThumbs = input<number, NumberInput>(0, { transform: numberAttribute });\n\n    readonly orientation = input<'horizontal' | 'vertical'>('horizontal');\n\n    readonly disabled = input<boolean, BooleanInput>(false, { transform: booleanAttribute });\n\n    readonly inverted = input<boolean, BooleanInput>(false, { transform: booleanAttribute });\n\n    readonly dir = input<'ltr' | 'rtl'>('ltr');\n\n    @Input() className: string = '';\n\n    @Output() valueChange = new EventEmitter<number[]>();\n    @Output() valueCommit = new EventEmitter<number[]>();\n\n    readonly modelValue = model<number[]>([0]);\n\n    /** @ignore */\n    readonly valueIndexToChange = model(0);\n\n    /** @ignore */\n    readonly valuesBeforeSlideStart = model<number[]>([]);\n\n    readonly isSlidingFromLeft = computed(\n        () => (this.dir() === 'ltr' && !this.inverted()) || (this.dir() !== 'ltr' && this.inverted())\n    );\n\n    readonly isSlidingFromBottom = computed(() => !this.inverted());\n\n    /** @ignore */\n    thumbElements: HTMLElement[] = [];\n\n    /** @ignore */\n    ngOnInit() {\n        const isHorizontal = this.orientation() === 'horizontal';\n\n        if (isHorizontal) {\n            this.orientationContext.updateContext({\n                direction: this.isSlidingFromLeft() ? 1 : -1,\n                size: 'width',\n                startEdge: this.isSlidingFromLeft() ? 'left' : 'right',\n                endEdge: this.isSlidingFromLeft() ? 'right' : 'left'\n            });\n        } else {\n            this.orientationContext.updateContext({\n                direction: this.isSlidingFromBottom() ? -1 : 1,\n                size: 'height',\n                startEdge: this.isSlidingFromBottom() ? 'bottom' : 'top',\n                endEdge: this.isSlidingFromBottom() ? 'top' : 'bottom'\n            });\n        }\n    }\n\n    /** @ignore */\n    onPointerDown() {\n        this.valuesBeforeSlideStart.set([...this.modelValue()]);\n    }\n\n    /** @ignore */\n    handleSlideStart(value: number): void {\n        const closestIndex = getClosestValueIndex(this.modelValue(), value);\n        this.updateValues(value, closestIndex);\n    }\n\n    /** @ignore */\n    handleSlideMove(value: number): void {\n        this.updateValues(value, this.valueIndexToChange());\n    }\n\n    /** @ignore */\n    handleSlideEnd(): void {\n        const prevValue = this.valuesBeforeSlideStart()[this.valueIndexToChange()];\n        const nextValue = this.modelValue()[this.valueIndexToChange()];\n        const hasChanged = nextValue !== prevValue;\n\n        if (hasChanged) {\n            this.valueCommit.emit([...this.modelValue()]);\n        }\n    }\n\n    /** @ignore */\n    handleStepKeyDown(event: { event: KeyboardEvent; direction: number }): void {\n        const stepInDirection = this.step() * event.direction;\n        const atIndex = this.valueIndexToChange();\n        const currentValue = this.modelValue()[atIndex];\n        this.updateValues(currentValue + stepInDirection, atIndex, true);\n    }\n\n    /** @ignore */\n    updateValues(value: number, atIndex: number, commit = false): void {\n        const decimalCount = getDecimalCount(this.step());\n        const snapToStep = roundValue(\n            Math.round((value - this.min()) / this.step()) * this.step() + this.min(),\n            decimalCount\n        );\n        const nextValue = clamp(snapToStep, this.min(), this.max());\n\n        const nextValues = getNextSortedValues(this.modelValue(), nextValue, atIndex);\n\n        if (hasMinStepsBetweenValues(nextValues, this.minStepsBetweenThumbs() * this.step())) {\n            this.valueIndexToChange.set(nextValues.indexOf(nextValue));\n            const hasChanged = String(nextValues) !== String(this.modelValue());\n\n            if (hasChanged) {\n                this.modelValue.set(nextValues);\n                this.valueChange.emit([...this.modelValue()]);\n                this.thumbElements[this.valueIndexToChange()]?.focus();\n\n                if (commit) {\n                    this.valueCommit.emit([...this.modelValue()]);\n                }\n            }\n        }\n    }\n}\n"]}
|