@radix-ng/primitives 0.17.0 → 0.18.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.
Files changed (61) hide show
  1. package/compodoc/documentation.json +5304 -1427
  2. package/esm2022/select/src/select-trigger.directive.mjs +3 -3
  3. package/esm2022/select/src/select-value.directive.mjs +4 -9
  4. package/esm2022/select/src/select.component.mjs +6 -5
  5. package/esm2022/slider/index.mjs +28 -0
  6. package/esm2022/slider/radix-ng-primitives-slider.mjs +5 -0
  7. package/esm2022/slider/src/slider-horizontal.component.mjs +117 -0
  8. package/esm2022/slider/src/slider-impl.directive.mjs +89 -0
  9. package/esm2022/slider/src/slider-orientation-context.service.mjs +28 -0
  10. package/esm2022/slider/src/slider-range.component.mjs +41 -0
  11. package/esm2022/slider/src/slider-root.component.mjs +207 -0
  12. package/esm2022/slider/src/slider-thumb-impl.directive.mjs +106 -0
  13. package/esm2022/slider/src/slider-thumb.component.mjs +22 -0
  14. package/esm2022/slider/src/slider-track.component.mjs +27 -0
  15. package/esm2022/slider/src/slider-vertical.component.mjs +117 -0
  16. package/esm2022/slider/src/utils.mjs +94 -0
  17. package/esm2022/tooltip/index.mjs +41 -0
  18. package/esm2022/tooltip/radix-ng-primitives-tooltip.mjs +5 -0
  19. package/esm2022/tooltip/src/get-content-position.mjs +31 -0
  20. package/esm2022/tooltip/src/tooltip-arrow.directive.mjs +92 -0
  21. package/esm2022/tooltip/src/tooltip-arrow.token.mjs +3 -0
  22. package/esm2022/tooltip/src/tooltip-content-attributes.directive.mjs +24 -0
  23. package/esm2022/tooltip/src/tooltip-content.directive.mjs +48 -0
  24. package/esm2022/tooltip/src/tooltip-content.token.mjs +3 -0
  25. package/esm2022/tooltip/src/tooltip-root.directive.mjs +288 -0
  26. package/esm2022/tooltip/src/tooltip-trigger.directive.mjs +70 -0
  27. package/esm2022/tooltip/src/tooltip.config.mjs +18 -0
  28. package/esm2022/tooltip/src/tooltip.constants.mjs +84 -0
  29. package/esm2022/tooltip/src/tooltip.types.mjs +14 -0
  30. package/fesm2022/radix-ng-primitives-select.mjs +10 -14
  31. package/fesm2022/radix-ng-primitives-select.mjs.map +1 -1
  32. package/fesm2022/radix-ng-primitives-slider.mjs +833 -0
  33. package/fesm2022/radix-ng-primitives-slider.mjs.map +1 -0
  34. package/fesm2022/radix-ng-primitives-tooltip.mjs +684 -0
  35. package/fesm2022/radix-ng-primitives-tooltip.mjs.map +1 -0
  36. package/package.json +13 -1
  37. package/slider/README.md +1 -0
  38. package/slider/index.d.ts +18 -0
  39. package/slider/src/slider-horizontal.component.d.ts +29 -0
  40. package/slider/src/slider-impl.directive.d.ts +18 -0
  41. package/slider/src/slider-orientation-context.service.d.ts +14 -0
  42. package/slider/src/slider-range.component.d.ts +13 -0
  43. package/slider/src/slider-root.component.d.ts +47 -0
  44. package/slider/src/slider-thumb-impl.directive.d.ts +27 -0
  45. package/slider/src/slider-thumb.component.d.ts +6 -0
  46. package/slider/src/slider-track.component.d.ts +7 -0
  47. package/slider/src/slider-vertical.component.d.ts +29 -0
  48. package/slider/src/utils.d.ts +52 -0
  49. package/tooltip/README.md +1 -0
  50. package/tooltip/index.d.ts +17 -0
  51. package/tooltip/src/get-content-position.d.ts +3 -0
  52. package/tooltip/src/tooltip-arrow.directive.d.ts +25 -0
  53. package/tooltip/src/tooltip-arrow.token.d.ts +3 -0
  54. package/tooltip/src/tooltip-content-attributes.directive.d.ts +8 -0
  55. package/tooltip/src/tooltip-content.directive.d.ts +36 -0
  56. package/tooltip/src/tooltip-content.token.d.ts +3 -0
  57. package/tooltip/src/tooltip-root.directive.d.ts +103 -0
  58. package/tooltip/src/tooltip-trigger.directive.d.ts +26 -0
  59. package/tooltip/src/tooltip.config.d.ts +6 -0
  60. package/tooltip/src/tooltip.constants.d.ts +9 -0
  61. package/tooltip/src/tooltip.types.d.ts +18 -0
@@ -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"]}
@@ -0,0 +1,106 @@
1
+ import { isPlatformBrowser } from '@angular/common';
2
+ import { computed, Directive, ElementRef, inject, PLATFORM_ID, signal } from '@angular/core';
3
+ import { RdxSliderRootComponent } from './slider-root.component';
4
+ import { convertValueToPercentage, getThumbInBoundsOffset } from './utils';
5
+ import * as i0 from "@angular/core";
6
+ export class RdxSliderThumbImplDirective {
7
+ constructor() {
8
+ this.rootContext = inject(RdxSliderRootComponent);
9
+ this.elementRef = inject(ElementRef);
10
+ this.platformId = inject(PLATFORM_ID);
11
+ this.isMounted = signal(false);
12
+ this.thumbIndex = computed(() => {
13
+ const thumbElement = this.elementRef.nativeElement;
14
+ const index = this.rootContext.thumbElements.indexOf(thumbElement);
15
+ return index >= 0 ? index : null;
16
+ });
17
+ this.value = computed(() => {
18
+ const index = this.thumbIndex();
19
+ if (index === null)
20
+ return undefined;
21
+ return this.rootContext.modelValue()?.[index];
22
+ });
23
+ this.percent = computed(() => {
24
+ const val = this.value();
25
+ if (val === undefined)
26
+ return 0;
27
+ return convertValueToPercentage(val, this.rootContext.min(), this.rootContext.max());
28
+ });
29
+ this.transform = computed(() => {
30
+ const percent = this.percent();
31
+ const offset = this.thumbInBoundsOffset();
32
+ return `calc(${percent}% + ${offset}px)`;
33
+ });
34
+ this.orientationSize = signal(0);
35
+ this.thumbInBoundsOffset = computed(() => {
36
+ const context = this.rootContext.orientationContext.context;
37
+ const size = this.orientationSize();
38
+ const percent = this.percent();
39
+ const direction = context.direction;
40
+ return size ? getThumbInBoundsOffset(size, percent, direction) : 0;
41
+ });
42
+ this.combinedStyles = computed(() => {
43
+ const context = this.rootContext.orientationContext.context;
44
+ const startEdge = context.startEdge;
45
+ const percent = this.percent();
46
+ const offset = this.thumbInBoundsOffset();
47
+ return {
48
+ position: 'absolute',
49
+ transform: 'var(--rdx-slider-thumb-transform)',
50
+ display: (this.isMounted() && this.value()) === false ? 'none' : undefined,
51
+ [startEdge]: `calc(${percent}% + ${offset}px)`
52
+ };
53
+ });
54
+ }
55
+ onFocus() {
56
+ if (this.thumbIndex() !== null) {
57
+ this.rootContext.valueIndexToChange.set(this.thumbIndex());
58
+ }
59
+ }
60
+ ngOnInit() {
61
+ if (isPlatformBrowser(this.platformId)) {
62
+ const thumbElement = this.elementRef.nativeElement;
63
+ this.rootContext.thumbElements.push(thumbElement);
64
+ this.resizeObserver = new ResizeObserver(() => {
65
+ const rect = thumbElement.getBoundingClientRect();
66
+ const context = this.rootContext.orientationContext.context;
67
+ const size = context.size === 'width' ? rect.width : rect.height;
68
+ this.orientationSize.set(size);
69
+ });
70
+ this.resizeObserver.observe(thumbElement);
71
+ this.isMounted.set(true);
72
+ }
73
+ }
74
+ ngOnDestroy() {
75
+ const thumbElement = this.elementRef.nativeElement;
76
+ const index = this.rootContext.thumbElements.indexOf(thumbElement);
77
+ if (index >= 0)
78
+ this.rootContext.thumbElements.splice(index, 1);
79
+ if (this.resizeObserver) {
80
+ this.resizeObserver.unobserve(thumbElement);
81
+ }
82
+ this.isMounted.set(false);
83
+ }
84
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxSliderThumbImplDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
85
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.11", type: RdxSliderThumbImplDirective, isStandalone: true, selector: "[rdxSliderThumbImpl]", host: { attributes: { "role": "slider" }, listeners: { "focus": "onFocus()" }, properties: { "tabindex": "rootContext.disabled() ? undefined : 0", "attr.aria-valuenow": "rootContext.modelValue()", "attr.aria-valuemin": "rootContext.min()", "attr.aria-valuemax": "rootContext.max()", "attr.aria-orientation": "rootContext.orientation()", "attr.data-orientation": "rootContext.orientation()", "attr.data-disabled": "rootContext.disabled() ? \"\" : undefined", "style": "combinedStyles()" } }, ngImport: i0 }); }
86
+ }
87
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxSliderThumbImplDirective, decorators: [{
88
+ type: Directive,
89
+ args: [{
90
+ selector: '[rdxSliderThumbImpl]',
91
+ standalone: true,
92
+ host: {
93
+ role: 'slider',
94
+ '[tabindex]': 'rootContext.disabled() ? undefined : 0',
95
+ '[attr.aria-valuenow]': 'rootContext.modelValue()',
96
+ '[attr.aria-valuemin]': 'rootContext.min()',
97
+ '[attr.aria-valuemax]': 'rootContext.max()',
98
+ '[attr.aria-orientation]': 'rootContext.orientation()',
99
+ '[attr.data-orientation]': 'rootContext.orientation()',
100
+ '[attr.data-disabled]': 'rootContext.disabled() ? "" : undefined',
101
+ '[style]': 'combinedStyles()',
102
+ '(focus)': 'onFocus()'
103
+ }
104
+ }]
105
+ }] });
106
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"slider-thumb-impl.directive.js","sourceRoot":"","sources":["../../../../../packages/primitives/slider/src/slider-thumb-impl.directive.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,iBAAiB,CAAC;AACpD,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,EAAqB,WAAW,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAChH,OAAO,EAAE,sBAAsB,EAAE,MAAM,yBAAyB,CAAC;AACjE,OAAO,EAAE,wBAAwB,EAAE,sBAAsB,EAAE,MAAM,SAAS,CAAC;;AAsB3E,MAAM,OAAO,2BAA2B;IApBxC;QAqBuB,gBAAW,GAAG,MAAM,CAAC,sBAAsB,CAAC,CAAC;QAC/C,eAAU,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC;QAChC,eAAU,GAAG,MAAM,CAAC,WAAW,CAAC,CAAC;QAGlD,cAAS,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;QAE1B,eAAU,GAAG,QAAQ,CAAC,GAAG,EAAE;YACvB,MAAM,YAAY,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC;YACnD,MAAM,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;YACnE,OAAO,KAAK,IAAI,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC;QACrC,CAAC,CAAC,CAAC;QAEH,UAAK,GAAG,QAAQ,CAAC,GAAG,EAAE;YAClB,MAAM,KAAK,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;YAChC,IAAI,KAAK,KAAK,IAAI;gBAAE,OAAO,SAAS,CAAC;YACrC,OAAO,IAAI,CAAC,WAAW,CAAC,UAAU,EAAE,EAAE,CAAC,KAAK,CAAC,CAAC;QAClD,CAAC,CAAC,CAAC;QAEH,YAAO,GAAG,QAAQ,CAAC,GAAG,EAAE;YACpB,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK,EAAE,CAAC;YACzB,IAAI,GAAG,KAAK,SAAS;gBAAE,OAAO,CAAC,CAAC;YAChC,OAAO,wBAAwB,CAAC,GAAG,EAAE,IAAI,CAAC,WAAW,CAAC,GAAG,EAAE,EAAE,IAAI,CAAC,WAAW,CAAC,GAAG,EAAE,CAAC,CAAC;QACzF,CAAC,CAAC,CAAC;QAEH,cAAS,GAAG,QAAQ,CAAC,GAAG,EAAE;YACtB,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC;YAC/B,MAAM,MAAM,GAAG,IAAI,CAAC,mBAAmB,EAAE,CAAC;YAC1C,OAAO,QAAQ,OAAO,OAAO,MAAM,KAAK,CAAC;QAC7C,CAAC,CAAC,CAAC;QAEH,oBAAe,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QAE5B,wBAAmB,GAAG,QAAQ,CAAC,GAAG,EAAE;YAChC,MAAM,OAAO,GAAG,IAAI,CAAC,WAAW,CAAC,kBAAkB,CAAC,OAAO,CAAC;YAE5D,MAAM,IAAI,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC;YACpC,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC;YAC/B,MAAM,SAAS,GAAG,OAAO,CAAC,SAAS,CAAC;YAEpC,OAAO,IAAI,CAAC,CAAC,CAAC,sBAAsB,CAAC,IAAI,EAAE,OAAO,EAAE,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACvE,CAAC,CAAC,CAAC;QAEH,mBAAc,GAAG,QAAQ,CAAC,GAAG,EAAE;YAC3B,MAAM,OAAO,GAAG,IAAI,CAAC,WAAW,CAAC,kBAAkB,CAAC,OAAO,CAAC;YAE5D,MAAM,SAAS,GAAG,OAAO,CAAC,SAAS,CAAC;YACpC,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC;YAC/B,MAAM,MAAM,GAAG,IAAI,CAAC,mBAAmB,EAAE,CAAC;YAE1C,OAAO;gBACH,QAAQ,EAAE,UAAU;gBACpB,SAAS,EAAE,mCAAmC;gBAC9C,OAAO,EAAE,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC,KAAK,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS;gBAC1E,CAAC,SAAS,CAAC,EAAE,QAAQ,OAAO,OAAO,MAAM,KAAK;aACjD,CAAC;QACN,CAAC,CAAC,CAAC;KAqCN;IAnCG,OAAO;QACH,IAAI,IAAI,CAAC,UAAU,EAAE,KAAK,IAAI,EAAE,CAAC;YAC7B,IAAI,CAAC,WAAW,CAAC,kBAAkB,CAAC,GAAG,CAAC,IAAI,CAAC,UAAU,EAAG,CAAC,CAAC;QAChE,CAAC;IACL,CAAC;IAED,QAAQ;QACJ,IAAI,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC;YACrC,MAAM,YAAY,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC;YACnD,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;YAElD,IAAI,CAAC,cAAc,GAAG,IAAI,cAAc,CAAC,GAAG,EAAE;gBAC1C,MAAM,IAAI,GAAG,YAAY,CAAC,qBAAqB,EAAE,CAAC;gBAClD,MAAM,OAAO,GAAG,IAAI,CAAC,WAAW,CAAC,kBAAkB,CAAC,OAAO,CAAC;gBAC5D,MAAM,IAAI,GAAG,OAAO,CAAC,IAAI,KAAK,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC;gBACjE,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;YACnC,CAAC,CAAC,CAAC;YAEH,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;YAE1C,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QAC7B,CAAC;IACL,CAAC;IAED,WAAW;QACP,MAAM,YAAY,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC;QACnD,MAAM,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;QACnE,IAAI,KAAK,IAAI,CAAC;YAAE,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;QAEhE,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC;YACtB,IAAI,CAAC,cAAc,CAAC,SAAS,CAAC,YAAY,CAAC,CAAC;QAChD,CAAC;QAED,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;IAC9B,CAAC;+GA7FQ,2BAA2B;mGAA3B,2BAA2B;;4FAA3B,2BAA2B;kBApBvC,SAAS;mBAAC;oBACP,QAAQ,EAAE,sBAAsB;oBAChC,UAAU,EAAE,IAAI;oBAChB,IAAI,EAAE;wBACF,IAAI,EAAE,QAAQ;wBACd,YAAY,EAAE,wCAAwC;wBAEtD,sBAAsB,EAAE,0BAA0B;wBAClD,sBAAsB,EAAE,mBAAmB;wBAC3C,sBAAsB,EAAE,mBAAmB;wBAC3C,yBAAyB,EAAE,2BAA2B;wBAEtD,yBAAyB,EAAE,2BAA2B;wBACtD,sBAAsB,EAAE,yCAAyC;wBAEjE,SAAS,EAAE,kBAAkB;wBAE7B,SAAS,EAAE,WAAW;qBACzB;iBACJ","sourcesContent":["import { isPlatformBrowser } from '@angular/common';\nimport { computed, Directive, ElementRef, inject, OnDestroy, OnInit, PLATFORM_ID, signal } from '@angular/core';\nimport { RdxSliderRootComponent } from './slider-root.component';\nimport { convertValueToPercentage, getThumbInBoundsOffset } from './utils';\n\n@Directive({\n    selector: '[rdxSliderThumbImpl]',\n    standalone: true,\n    host: {\n        role: 'slider',\n        '[tabindex]': 'rootContext.disabled() ? undefined : 0',\n\n        '[attr.aria-valuenow]': 'rootContext.modelValue()',\n        '[attr.aria-valuemin]': 'rootContext.min()',\n        '[attr.aria-valuemax]': 'rootContext.max()',\n        '[attr.aria-orientation]': 'rootContext.orientation()',\n\n        '[attr.data-orientation]': 'rootContext.orientation()',\n        '[attr.data-disabled]': 'rootContext.disabled() ? \"\" : undefined',\n\n        '[style]': 'combinedStyles()',\n\n        '(focus)': 'onFocus()'\n    }\n})\nexport class RdxSliderThumbImplDirective implements OnInit, OnDestroy {\n    protected readonly rootContext = inject(RdxSliderRootComponent);\n    private readonly elementRef = inject(ElementRef);\n    private readonly platformId = inject(PLATFORM_ID);\n    private resizeObserver!: ResizeObserver;\n\n    isMounted = signal(false);\n\n    thumbIndex = computed(() => {\n        const thumbElement = this.elementRef.nativeElement;\n        const index = this.rootContext.thumbElements.indexOf(thumbElement);\n        return index >= 0 ? index : null;\n    });\n\n    value = computed(() => {\n        const index = this.thumbIndex();\n        if (index === null) return undefined;\n        return this.rootContext.modelValue()?.[index];\n    });\n\n    percent = computed(() => {\n        const val = this.value();\n        if (val === undefined) return 0;\n        return convertValueToPercentage(val, this.rootContext.min(), this.rootContext.max());\n    });\n\n    transform = computed(() => {\n        const percent = this.percent();\n        const offset = this.thumbInBoundsOffset();\n        return `calc(${percent}% + ${offset}px)`;\n    });\n\n    orientationSize = signal(0);\n\n    thumbInBoundsOffset = computed(() => {\n        const context = this.rootContext.orientationContext.context;\n\n        const size = this.orientationSize();\n        const percent = this.percent();\n        const direction = context.direction;\n\n        return size ? getThumbInBoundsOffset(size, percent, direction) : 0;\n    });\n\n    combinedStyles = computed(() => {\n        const context = this.rootContext.orientationContext.context;\n\n        const startEdge = context.startEdge;\n        const percent = this.percent();\n        const offset = this.thumbInBoundsOffset();\n\n        return {\n            position: 'absolute',\n            transform: 'var(--rdx-slider-thumb-transform)',\n            display: (this.isMounted() && this.value()) === false ? 'none' : undefined,\n            [startEdge]: `calc(${percent}% + ${offset}px)`\n        };\n    });\n\n    onFocus() {\n        if (this.thumbIndex() !== null) {\n            this.rootContext.valueIndexToChange.set(this.thumbIndex()!);\n        }\n    }\n\n    ngOnInit() {\n        if (isPlatformBrowser(this.platformId)) {\n            const thumbElement = this.elementRef.nativeElement;\n            this.rootContext.thumbElements.push(thumbElement);\n\n            this.resizeObserver = new ResizeObserver(() => {\n                const rect = thumbElement.getBoundingClientRect();\n                const context = this.rootContext.orientationContext.context;\n                const size = context.size === 'width' ? rect.width : rect.height;\n                this.orientationSize.set(size);\n            });\n\n            this.resizeObserver.observe(thumbElement);\n\n            this.isMounted.set(true);\n        }\n    }\n\n    ngOnDestroy() {\n        const thumbElement = this.elementRef.nativeElement;\n        const index = this.rootContext.thumbElements.indexOf(thumbElement);\n        if (index >= 0) this.rootContext.thumbElements.splice(index, 1);\n\n        if (this.resizeObserver) {\n            this.resizeObserver.unobserve(thumbElement);\n        }\n\n        this.isMounted.set(false);\n    }\n}\n"]}
@@ -0,0 +1,22 @@
1
+ import { Component } from '@angular/core';
2
+ import { RdxSliderThumbImplDirective } from './slider-thumb-impl.directive';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "./slider-thumb-impl.directive";
5
+ export class RdxSliderThumbComponent {
6
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxSliderThumbComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
7
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.11", type: RdxSliderThumbComponent, isStandalone: true, selector: "rdx-slider-thumb", hostDirectives: [{ directive: i1.RdxSliderThumbImplDirective }], ngImport: i0, template: `
8
+ <ng-content />
9
+ `, isInline: true }); }
10
+ }
11
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxSliderThumbComponent, decorators: [{
12
+ type: Component,
13
+ args: [{
14
+ selector: 'rdx-slider-thumb',
15
+ standalone: true,
16
+ hostDirectives: [RdxSliderThumbImplDirective],
17
+ template: `
18
+ <ng-content />
19
+ `
20
+ }]
21
+ }] });
22
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2xpZGVyLXRodW1iLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3ByaW1pdGl2ZXMvc2xpZGVyL3NyYy9zbGlkZXItdGh1bWIuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDMUMsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sK0JBQStCLENBQUM7OztBQVU1RSxNQUFNLE9BQU8sdUJBQXVCOytHQUF2Qix1QkFBdUI7bUdBQXZCLHVCQUF1Qiw2SUFKdEI7O0tBRVQ7OzRGQUVRLHVCQUF1QjtrQkFSbkMsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUsa0JBQWtCO29CQUM1QixVQUFVLEVBQUUsSUFBSTtvQkFDaEIsY0FBYyxFQUFFLENBQUMsMkJBQTJCLENBQUM7b0JBQzdDLFFBQVEsRUFBRTs7S0FFVDtpQkFDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgUmR4U2xpZGVyVGh1bWJJbXBsRGlyZWN0aXZlIH0gZnJvbSAnLi9zbGlkZXItdGh1bWItaW1wbC5kaXJlY3RpdmUnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ3JkeC1zbGlkZXItdGh1bWInLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgaG9zdERpcmVjdGl2ZXM6IFtSZHhTbGlkZXJUaHVtYkltcGxEaXJlY3RpdmVdLFxuICAgIHRlbXBsYXRlOiBgXG4gICAgICAgIDxuZy1jb250ZW50IC8+XG4gICAgYFxufSlcbmV4cG9ydCBjbGFzcyBSZHhTbGlkZXJUaHVtYkNvbXBvbmVudCB7fVxuIl19
@@ -0,0 +1,27 @@
1
+ import { Component, inject } from '@angular/core';
2
+ import { RdxSliderRootComponent } from './slider-root.component';
3
+ import * as i0 from "@angular/core";
4
+ export class RdxSliderTrackComponent {
5
+ constructor() {
6
+ this.rootContext = inject(RdxSliderRootComponent);
7
+ }
8
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxSliderTrackComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
9
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.11", type: RdxSliderTrackComponent, isStandalone: true, selector: "rdx-slider-track", host: { properties: { "attr.data-disabled": "rootContext.disabled() ? '' : undefined", "attr.data-orientation": "rootContext.orientation()" } }, ngImport: i0, template: `
10
+ <ng-content />
11
+ `, isInline: true }); }
12
+ }
13
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxSliderTrackComponent, decorators: [{
14
+ type: Component,
15
+ args: [{
16
+ selector: 'rdx-slider-track',
17
+ standalone: true,
18
+ host: {
19
+ '[attr.data-disabled]': "rootContext.disabled() ? '' : undefined",
20
+ '[attr.data-orientation]': 'rootContext.orientation()'
21
+ },
22
+ template: `
23
+ <ng-content />
24
+ `
25
+ }]
26
+ }] });
27
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2xpZGVyLXRyYWNrLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3ByaW1pdGl2ZXMvc2xpZGVyL3NyYy9zbGlkZXItdHJhY2suY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2xELE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLHlCQUF5QixDQUFDOztBQWFqRSxNQUFNLE9BQU8sdUJBQXVCO0lBWHBDO1FBWXVCLGdCQUFXLEdBQUcsTUFBTSxDQUFDLHNCQUFzQixDQUFDLENBQUM7S0FDbkU7K0dBRlksdUJBQXVCO21HQUF2Qix1QkFBdUIsNk5BSnRCOztLQUVUOzs0RkFFUSx1QkFBdUI7a0JBWG5DLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLGtCQUFrQjtvQkFDNUIsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLElBQUksRUFBRTt3QkFDRixzQkFBc0IsRUFBRSx5Q0FBeUM7d0JBQ2pFLHlCQUF5QixFQUFFLDJCQUEyQjtxQkFDekQ7b0JBQ0QsUUFBUSxFQUFFOztLQUVUO2lCQUNKIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBpbmplY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFJkeFNsaWRlclJvb3RDb21wb25lbnQgfSBmcm9tICcuL3NsaWRlci1yb290LmNvbXBvbmVudCc7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAncmR4LXNsaWRlci10cmFjaycsXG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICBob3N0OiB7XG4gICAgICAgICdbYXR0ci5kYXRhLWRpc2FibGVkXSc6IFwicm9vdENvbnRleHQuZGlzYWJsZWQoKSA/ICcnIDogdW5kZWZpbmVkXCIsXG4gICAgICAgICdbYXR0ci5kYXRhLW9yaWVudGF0aW9uXSc6ICdyb290Q29udGV4dC5vcmllbnRhdGlvbigpJ1xuICAgIH0sXG4gICAgdGVtcGxhdGU6IGBcbiAgICAgICAgPG5nLWNvbnRlbnQgLz5cbiAgICBgXG59KVxuZXhwb3J0IGNsYXNzIFJkeFNsaWRlclRyYWNrQ29tcG9uZW50IHtcbiAgICBwcm90ZWN0ZWQgcmVhZG9ubHkgcm9vdENvbnRleHQgPSBpbmplY3QoUmR4U2xpZGVyUm9vdENvbXBvbmVudCk7XG59XG4iXX0=
@@ -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 RdxSliderVerticalComponent {
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.clientY);
25
+ this.slideStart.emit(value);
26
+ }
27
+ onSlideMove(event) {
28
+ const value = this.getValueFromPointer(event.clientY);
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.isSlidingFromBottom() ? 'from-bottom' : 'from-top';
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.height];
46
+ const output = this.rootContext.isSlidingFromBottom()
47
+ ? [this.max, this.min]
48
+ : [this.min, this.max];
49
+ const value = linearScale(input, output);
50
+ this.rect.set(rect);
51
+ return value(pointerPosition - rect.top);
52
+ }
53
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxSliderVerticalComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
54
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "18.2.11", type: RdxSliderVerticalComponent, isStandalone: true, selector: "rdx-slider-vertical", 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]="'vertical'"
59
+ [style]="{ '--rdx-slider-thumb-transform': 'translateY(-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: RdxSliderVerticalComponent, decorators: [{
73
+ type: Component,
74
+ args: [{
75
+ selector: 'rdx-slider-vertical',
76
+ standalone: true,
77
+ imports: [RdxSliderImplDirective],
78
+ template: `
79
+ <span
80
+ #sliderElement
81
+ [class]="className"
82
+ [attr.data-orientation]="'vertical'"
83
+ [style]="{ '--rdx-slider-thumb-transform': 'translateY(-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-vertical.component.js","sourceRoot":"","sources":["../../../../../packages/primitives/slider/src/slider-vertical.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-vertical',\n    standalone: true,\n    imports: [RdxSliderImplDirective],\n    template: `\n        <span\n            #sliderElement\n            [class]=\"className\"\n            [attr.data-orientation]=\"'vertical'\"\n            [style]=\"{ '--rdx-slider-thumb-transform': 'translateY(-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 RdxSliderVerticalComponent {\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.clientY);\n        this.slideStart.emit(value);\n    }\n\n    onSlideMove(event: PointerEvent) {\n        const value = this.getValueFromPointer(event.clientY);\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.isSlidingFromBottom() ? 'from-bottom' : 'from-top';\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.height];\n        const output: [number, number] = this.rootContext.isSlidingFromBottom()\n            ? [this.max, this.min]\n            : [this.min, this.max];\n\n        const value = linearScale(input, output);\n        this.rect.set(rect);\n\n        return value(pointerPosition - rect.top);\n    }\n}\n"]}