@radix-ng/primitives 0.18.1 → 0.19.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.
Files changed (73) hide show
  1. package/avatar/index.d.ts +1 -2
  2. package/avatar/src/avatar-fallback.directive.d.ts +11 -23
  3. package/avatar/src/avatar-image.directive.d.ts +10 -14
  4. package/avatar/src/avatar-root.directive.d.ts +5 -15
  5. package/checkbox/index.d.ts +11 -0
  6. package/checkbox/src/checkbox-button.directive.d.ts +1 -1
  7. package/checkbox/src/checkbox-indicator.directive.d.ts +1 -1
  8. package/checkbox/src/checkbox-input.directive.d.ts +1 -1
  9. package/checkbox/src/checkbox.directive.d.ts +1 -1
  10. package/compodoc/documentation.json +4895 -2139
  11. package/core/index.d.ts +2 -0
  12. package/core/src/control-value-accessor/index.d.ts +75 -0
  13. package/core/src/create-inject-context/assert-injector.d.ts +51 -0
  14. package/core/src/create-inject-context/index.d.ts +68 -0
  15. package/core/src/types.d.ts +23 -0
  16. package/esm2022/avatar/index.mjs +1 -1
  17. package/esm2022/avatar/src/avatar-fallback.directive.mjs +38 -40
  18. package/esm2022/avatar/src/avatar-image.directive.mjs +25 -26
  19. package/esm2022/avatar/src/avatar-root.directive.mjs +13 -25
  20. package/esm2022/checkbox/index.mjs +31 -1
  21. package/esm2022/checkbox/src/checkbox-button.directive.mjs +3 -3
  22. package/esm2022/checkbox/src/checkbox-indicator.directive.mjs +3 -3
  23. package/esm2022/checkbox/src/checkbox-input.directive.mjs +3 -3
  24. package/esm2022/checkbox/src/checkbox.directive.mjs +3 -3
  25. package/esm2022/core/index.mjs +3 -1
  26. package/esm2022/core/src/control-value-accessor/index.mjs +103 -0
  27. package/esm2022/core/src/create-inject-context/assert-injector.mjs +15 -0
  28. package/esm2022/core/src/create-inject-context/index.mjs +116 -0
  29. package/esm2022/core/src/types.mjs +2 -0
  30. package/esm2022/radio/index.mjs +2 -1
  31. package/esm2022/radio/src/radio-item-input.directive.mjs +37 -0
  32. package/esm2022/radio/src/radio-item.directive.mjs +55 -36
  33. package/esm2022/radio/src/radio-root.directive.mjs +24 -110
  34. package/esm2022/radio/src/radio-tokens.mjs +1 -1
  35. package/esm2022/roving-focus/index.mjs +3 -0
  36. package/esm2022/roving-focus/radix-ng-primitives-roving-focus.mjs +5 -0
  37. package/esm2022/roving-focus/src/roving-focus-group.directive.mjs +138 -0
  38. package/esm2022/roving-focus/src/roving-focus-item.directive.mjs +133 -0
  39. package/esm2022/roving-focus/src/utils.mjs +47 -0
  40. package/esm2022/select/src/select-item.directive.mjs +8 -2
  41. package/esm2022/slider/src/slider-orientation-context.service.mjs +3 -4
  42. package/esm2022/slider/src/slider-root.component.mjs +5 -2
  43. package/esm2022/toggle/src/toggle-input.directive.mjs +4 -3
  44. package/fesm2022/radix-ng-primitives-avatar.mjs +70 -85
  45. package/fesm2022/radix-ng-primitives-avatar.mjs.map +1 -1
  46. package/fesm2022/radix-ng-primitives-checkbox.mjs +35 -10
  47. package/fesm2022/radix-ng-primitives-checkbox.mjs.map +1 -1
  48. package/fesm2022/radix-ng-primitives-core.mjs +230 -3
  49. package/fesm2022/radix-ng-primitives-core.mjs.map +1 -1
  50. package/fesm2022/radix-ng-primitives-radio.mjs +142 -176
  51. package/fesm2022/radix-ng-primitives-radio.mjs.map +1 -1
  52. package/fesm2022/radix-ng-primitives-roving-focus.mjs +320 -0
  53. package/fesm2022/radix-ng-primitives-roving-focus.mjs.map +1 -0
  54. package/fesm2022/radix-ng-primitives-select.mjs +7 -1
  55. package/fesm2022/radix-ng-primitives-select.mjs.map +1 -1
  56. package/fesm2022/radix-ng-primitives-slider.mjs +6 -4
  57. package/fesm2022/radix-ng-primitives-slider.mjs.map +1 -1
  58. package/fesm2022/radix-ng-primitives-toggle.mjs +3 -2
  59. package/fesm2022/radix-ng-primitives-toggle.mjs.map +1 -1
  60. package/package.json +7 -1
  61. package/radio/index.d.ts +1 -0
  62. package/radio/src/radio-item-input.directive.d.ts +12 -0
  63. package/radio/src/radio-item.directive.d.ts +23 -14
  64. package/radio/src/radio-root.directive.d.ts +15 -31
  65. package/radio/src/radio-tokens.d.ts +3 -3
  66. package/roving-focus/README.md +3 -0
  67. package/roving-focus/index.d.ts +3 -0
  68. package/roving-focus/src/roving-focus-group.directive.d.ts +50 -0
  69. package/roving-focus/src/roving-focus-item.directive.d.ts +50 -0
  70. package/roving-focus/src/utils.d.ts +19 -0
  71. package/select/src/select-item.directive.d.ts +7 -1
  72. package/slider/src/slider-root.component.d.ts +2 -0
  73. package/toggle/src/toggle-input.directive.d.ts +1 -1
@@ -0,0 +1,133 @@
1
+ import { booleanAttribute, computed, Directive, ElementRef, inject, Input, NgZone } from '@angular/core';
2
+ import { RdxRovingFocusGroupDirective } from './roving-focus-group.directive';
3
+ import { focusFirst, generateId, getFocusIntent, wrapArray } from './utils';
4
+ import * as i0 from "@angular/core";
5
+ export class RdxRovingFocusItemDirective {
6
+ constructor() {
7
+ this.elementRef = inject(ElementRef);
8
+ this.ngZone = inject(NgZone);
9
+ this.parent = inject(RdxRovingFocusGroupDirective);
10
+ this.focusable = true;
11
+ this.active = true;
12
+ this.allowShiftKey = false;
13
+ this.id = computed(() => this.tabStopId || generateId());
14
+ /** @ignore */
15
+ this.isCurrentTabStop = computed(() => this.parent.currentTabStopId() === this.id());
16
+ }
17
+ /**
18
+ * Lifecycle hook triggered on initialization.
19
+ * Registers the element with the parent roving focus group if it is focusable.
20
+ * @ignore
21
+ */
22
+ ngOnInit() {
23
+ if (this.focusable) {
24
+ this.parent.registerItem(this.elementRef.nativeElement);
25
+ this.parent.onFocusableItemAdd();
26
+ }
27
+ }
28
+ /**
29
+ * Lifecycle hook triggered on destruction.
30
+ * Unregisters the element from the parent roving focus group if it is focusable.
31
+ * @ignore
32
+ */
33
+ ngOnDestroy() {
34
+ if (this.focusable) {
35
+ this.parent.unregisterItem(this.elementRef.nativeElement);
36
+ this.parent.onFocusableItemRemove();
37
+ }
38
+ }
39
+ /**
40
+ * Determines the `tabIndex` of the element.
41
+ * Returns `0` if the element is the current tab stop; otherwise, returns `-1`.
42
+ * @ignore
43
+ */
44
+ get tabIndex() {
45
+ return this.isCurrentTabStop() ? 0 : -1;
46
+ }
47
+ /** @ignore */
48
+ handleMouseDown(event) {
49
+ if (!this.focusable) {
50
+ // We prevent focusing non-focusable items on `mousedown`.
51
+ // Even though the item has tabIndex={-1}, that only means take it out of the tab order.
52
+ event.preventDefault();
53
+ }
54
+ else {
55
+ // Safari doesn't focus a button when clicked so we run our logic on mousedown also
56
+ this.parent.onItemFocus(this.id());
57
+ }
58
+ }
59
+ /** @ignore */
60
+ onFocus() {
61
+ this.parent.onItemFocus(this.id());
62
+ }
63
+ /**
64
+ * Handles the `keydown` event for keyboard navigation within the roving focus group.
65
+ * Supports navigation based on orientation and direction, and focuses appropriate elements.
66
+ *
67
+ * @param event The `KeyboardEvent` object.
68
+ * @ignore
69
+ */
70
+ handleKeydown(event) {
71
+ if (event.key === 'Tab' && event.shiftKey) {
72
+ this.parent.onItemShiftTab();
73
+ return;
74
+ }
75
+ if (event.target !== this.elementRef.nativeElement)
76
+ return;
77
+ const focusIntent = getFocusIntent(event, this.parent.orientation, this.parent.dir);
78
+ if (focusIntent !== undefined) {
79
+ if (event.metaKey || event.ctrlKey || event.altKey || (this.allowShiftKey ? false : event.shiftKey)) {
80
+ return;
81
+ }
82
+ event.preventDefault();
83
+ let candidateNodes = this.parent.focusableItems().filter((item) => item.dataset['disabled'] !== '');
84
+ if (focusIntent === 'last') {
85
+ candidateNodes.reverse();
86
+ }
87
+ else if (focusIntent === 'prev' || focusIntent === 'next') {
88
+ if (focusIntent === 'prev')
89
+ candidateNodes.reverse();
90
+ const currentIndex = candidateNodes.indexOf(this.elementRef.nativeElement);
91
+ candidateNodes = this.parent.loop
92
+ ? wrapArray(candidateNodes, currentIndex + 1)
93
+ : candidateNodes.slice(currentIndex + 1);
94
+ }
95
+ this.ngZone.runOutsideAngular(() => {
96
+ // eslint-disable-next-line promise/always-return,promise/catch-or-return
97
+ Promise.resolve().then(() => {
98
+ focusFirst(candidateNodes, false, this.elementRef.nativeElement);
99
+ });
100
+ });
101
+ }
102
+ }
103
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxRovingFocusItemDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
104
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "18.2.11", type: RdxRovingFocusItemDirective, isStandalone: true, selector: "[rdxRovingFocusItem]", inputs: { focusable: ["focusable", "focusable", booleanAttribute], active: ["active", "active", booleanAttribute], tabStopId: "tabStopId", allowShiftKey: ["allowShiftKey", "allowShiftKey", booleanAttribute] }, host: { listeners: { "mousedown": "handleMouseDown($event)", "keydown": "handleKeydown($event)", "focus": "onFocus()" }, properties: { "attr.tabindex": "tabIndex", "attr.data-orientation": "parent.orientation", "attr.data-active": "active", "attr.data-disabled": "!focusable ? \"\" : undefined" } }, ngImport: i0 }); }
105
+ }
106
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxRovingFocusItemDirective, decorators: [{
107
+ type: Directive,
108
+ args: [{
109
+ selector: '[rdxRovingFocusItem]',
110
+ standalone: true,
111
+ host: {
112
+ '[attr.tabindex]': 'tabIndex',
113
+ '[attr.data-orientation]': 'parent.orientation',
114
+ '[attr.data-active]': 'active',
115
+ '[attr.data-disabled]': '!focusable ? "" : undefined',
116
+ '(mousedown)': 'handleMouseDown($event)',
117
+ '(keydown)': 'handleKeydown($event)',
118
+ '(focus)': 'onFocus()'
119
+ }
120
+ }]
121
+ }], propDecorators: { focusable: [{
122
+ type: Input,
123
+ args: [{ transform: booleanAttribute }]
124
+ }], active: [{
125
+ type: Input,
126
+ args: [{ transform: booleanAttribute }]
127
+ }], tabStopId: [{
128
+ type: Input
129
+ }], allowShiftKey: [{
130
+ type: Input,
131
+ args: [{ transform: booleanAttribute }]
132
+ }] } });
133
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"roving-focus-item.directive.js","sourceRoot":"","sources":["../../../../../packages/primitives/roving-focus/src/roving-focus-item.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    booleanAttribute,\n    computed,\n    Directive,\n    ElementRef,\n    inject,\n    Input,\n    NgZone,\n    OnDestroy,\n    OnInit\n} from '@angular/core';\nimport { RdxRovingFocusGroupDirective } from './roving-focus-group.directive';\nimport { focusFirst, generateId, getFocusIntent, wrapArray } from './utils';\n\n@Directive({\n    selector: '[rdxRovingFocusItem]',\n    standalone: true,\n    host: {\n        '[attr.tabindex]': 'tabIndex',\n        '[attr.data-orientation]': 'parent.orientation',\n        '[attr.data-active]': 'active',\n        '[attr.data-disabled]': '!focusable ? \"\" : undefined',\n        '(mousedown)': 'handleMouseDown($event)',\n        '(keydown)': 'handleKeydown($event)',\n        '(focus)': 'onFocus()'\n    }\n})\nexport class RdxRovingFocusItemDirective implements OnInit, OnDestroy {\n    private readonly elementRef = inject(ElementRef);\n    private readonly ngZone = inject(NgZone);\n    protected readonly parent = inject(RdxRovingFocusGroupDirective);\n\n    @Input({ transform: booleanAttribute }) focusable: boolean = true;\n    @Input({ transform: booleanAttribute }) active: boolean = true;\n    @Input() tabStopId: string;\n    @Input({ transform: booleanAttribute }) allowShiftKey: boolean = false;\n\n    private readonly id = computed(() => this.tabStopId || generateId());\n\n    /** @ignore */\n    readonly isCurrentTabStop = computed(() => this.parent.currentTabStopId() === this.id());\n\n    /**\n     * Lifecycle hook triggered on initialization.\n     * Registers the element with the parent roving focus group if it is focusable.\n     * @ignore\n     */\n    ngOnInit() {\n        if (this.focusable) {\n            this.parent.registerItem(this.elementRef.nativeElement);\n            this.parent.onFocusableItemAdd();\n        }\n    }\n\n    /**\n     * Lifecycle hook triggered on destruction.\n     * Unregisters the element from the parent roving focus group if it is focusable.\n     * @ignore\n     */\n    ngOnDestroy() {\n        if (this.focusable) {\n            this.parent.unregisterItem(this.elementRef.nativeElement);\n            this.parent.onFocusableItemRemove();\n        }\n    }\n\n    /**\n     * Determines the `tabIndex` of the element.\n     * Returns `0` if the element is the current tab stop; otherwise, returns `-1`.\n     * @ignore\n     */\n    get tabIndex() {\n        return this.isCurrentTabStop() ? 0 : -1;\n    }\n\n    /** @ignore */\n    handleMouseDown(event: MouseEvent) {\n        if (!this.focusable) {\n            // We prevent focusing non-focusable items on `mousedown`.\n            // Even though the item has tabIndex={-1}, that only means take it out of the tab order.\n            event.preventDefault();\n        } else {\n            // Safari doesn't focus a button when clicked so we run our logic on mousedown also\n            this.parent.onItemFocus(this.id());\n        }\n    }\n\n    /** @ignore */\n    onFocus() {\n        this.parent.onItemFocus(this.id());\n    }\n\n    /**\n     * Handles the `keydown` event for keyboard navigation within the roving focus group.\n     * Supports navigation based on orientation and direction, and focuses appropriate elements.\n     *\n     * @param event The `KeyboardEvent` object.\n     * @ignore\n     */\n    handleKeydown(event: KeyboardEvent) {\n        if (event.key === 'Tab' && event.shiftKey) {\n            this.parent.onItemShiftTab();\n            return;\n        }\n\n        if (event.target !== this.elementRef.nativeElement) return;\n\n        const focusIntent = getFocusIntent(event, this.parent.orientation, this.parent.dir);\n\n        if (focusIntent !== undefined) {\n            if (event.metaKey || event.ctrlKey || event.altKey || (this.allowShiftKey ? false : event.shiftKey)) {\n                return;\n            }\n\n            event.preventDefault();\n\n            let candidateNodes = this.parent.focusableItems().filter((item) => item.dataset['disabled'] !== '');\n\n            if (focusIntent === 'last') {\n                candidateNodes.reverse();\n            } else if (focusIntent === 'prev' || focusIntent === 'next') {\n                if (focusIntent === 'prev') candidateNodes.reverse();\n                const currentIndex = candidateNodes.indexOf(this.elementRef.nativeElement);\n\n                candidateNodes = this.parent.loop\n                    ? wrapArray(candidateNodes, currentIndex + 1)\n                    : candidateNodes.slice(currentIndex + 1);\n            }\n\n            this.ngZone.runOutsideAngular(() => {\n                // eslint-disable-next-line promise/always-return,promise/catch-or-return\n                Promise.resolve().then(() => {\n                    focusFirst(candidateNodes, false, this.elementRef.nativeElement);\n                });\n            });\n        }\n    }\n}\n"]}
@@ -0,0 +1,47 @@
1
+ export const ENTRY_FOCUS = 'rovingFocusGroup.onEntryFocus';
2
+ export const EVENT_OPTIONS = { bubbles: false, cancelable: true };
3
+ export const MAP_KEY_TO_FOCUS_INTENT = {
4
+ ArrowLeft: 'prev',
5
+ ArrowUp: 'prev',
6
+ ArrowRight: 'next',
7
+ ArrowDown: 'next',
8
+ PageUp: 'first',
9
+ Home: 'first',
10
+ PageDown: 'last',
11
+ End: 'last'
12
+ };
13
+ export function getDirectionAwareKey(key, dir) {
14
+ if (dir !== 'rtl')
15
+ return key;
16
+ return key === 'ArrowLeft' ? 'ArrowRight' : key === 'ArrowRight' ? 'ArrowLeft' : key;
17
+ }
18
+ export function getFocusIntent(event, orientation, dir) {
19
+ const key = getDirectionAwareKey(event.key, dir);
20
+ if (orientation === 'vertical' && ['ArrowLeft', 'ArrowRight'].includes(key))
21
+ return undefined;
22
+ if (orientation === 'horizontal' && ['ArrowUp', 'ArrowDown'].includes(key))
23
+ return undefined;
24
+ return MAP_KEY_TO_FOCUS_INTENT[key];
25
+ }
26
+ export function focusFirst(candidates, preventScroll = false, rootNode) {
27
+ const PREVIOUSLY_FOCUSED_ELEMENT = rootNode?.activeElement ?? document.activeElement;
28
+ for (const candidate of candidates) {
29
+ // if focus is already where we want to go, we don't want to keep going through the candidates
30
+ if (candidate === PREVIOUSLY_FOCUSED_ELEMENT)
31
+ return;
32
+ candidate.focus({ preventScroll });
33
+ if (document.activeElement !== PREVIOUSLY_FOCUSED_ELEMENT)
34
+ return;
35
+ }
36
+ }
37
+ /**
38
+ * Wraps an array around itself at a given start index
39
+ * Example: `wrapArray(['a', 'b', 'c', 'd'], 2) === ['c', 'd', 'a', 'b']`
40
+ */
41
+ export function wrapArray(array, startIndex) {
42
+ return array.map((_, index) => array[(startIndex + index) % array.length]);
43
+ }
44
+ export function generateId() {
45
+ return `rf-item-${Math.random().toString(36).slice(2, 11)}`;
46
+ }
47
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9wcmltaXRpdmVzL3JvdmluZy1mb2N1cy9zcmMvdXRpbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBR0EsTUFBTSxDQUFDLE1BQU0sV0FBVyxHQUFHLCtCQUErQixDQUFDO0FBQzNELE1BQU0sQ0FBQyxNQUFNLGFBQWEsR0FBRyxFQUFFLE9BQU8sRUFBRSxLQUFLLEVBQUUsVUFBVSxFQUFFLElBQUksRUFBRSxDQUFDO0FBSWxFLE1BQU0sQ0FBQyxNQUFNLHVCQUF1QixHQUFnQztJQUNoRSxTQUFTLEVBQUUsTUFBTTtJQUNqQixPQUFPLEVBQUUsTUFBTTtJQUNmLFVBQVUsRUFBRSxNQUFNO0lBQ2xCLFNBQVMsRUFBRSxNQUFNO0lBQ2pCLE1BQU0sRUFBRSxPQUFPO0lBQ2YsSUFBSSxFQUFFLE9BQU87SUFDYixRQUFRLEVBQUUsTUFBTTtJQUNoQixHQUFHLEVBQUUsTUFBTTtDQUNkLENBQUM7QUFFRixNQUFNLFVBQVUsb0JBQW9CLENBQUMsR0FBVyxFQUFFLEdBQWU7SUFDN0QsSUFBSSxHQUFHLEtBQUssS0FBSztRQUFFLE9BQU8sR0FBRyxDQUFDO0lBQzlCLE9BQU8sR0FBRyxLQUFLLFdBQVcsQ0FBQyxDQUFDLENBQUMsWUFBWSxDQUFDLENBQUMsQ0FBQyxHQUFHLEtBQUssWUFBWSxDQUFDLENBQUMsQ0FBQyxXQUFXLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQztBQUN6RixDQUFDO0FBRUQsTUFBTSxVQUFVLGNBQWMsQ0FBQyxLQUFvQixFQUFFLFdBQXlCLEVBQUUsR0FBZTtJQUMzRixNQUFNLEdBQUcsR0FBRyxvQkFBb0IsQ0FBQyxLQUFLLENBQUMsR0FBRyxFQUFFLEdBQUcsQ0FBQyxDQUFDO0lBQ2pELElBQUksV0FBVyxLQUFLLFVBQVUsSUFBSSxDQUFDLFdBQVcsRUFBRSxZQUFZLENBQUMsQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDO1FBQUUsT0FBTyxTQUFTLENBQUM7SUFDOUYsSUFBSSxXQUFXLEtBQUssWUFBWSxJQUFJLENBQUMsU0FBUyxFQUFFLFdBQVcsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUM7UUFBRSxPQUFPLFNBQVMsQ0FBQztJQUM3RixPQUFPLHVCQUF1QixDQUFDLEdBQUcsQ0FBQyxDQUFDO0FBQ3hDLENBQUM7QUFFRCxNQUFNLFVBQVUsVUFBVSxDQUFDLFVBQXlCLEVBQUUsYUFBYSxHQUFHLEtBQUssRUFBRSxRQUFnQztJQUN6RyxNQUFNLDBCQUEwQixHQUFHLFFBQVEsRUFBRSxhQUFhLElBQUksUUFBUSxDQUFDLGFBQWEsQ0FBQztJQUNyRixLQUFLLE1BQU0sU0FBUyxJQUFJLFVBQVUsRUFBRSxDQUFDO1FBQ2pDLDhGQUE4RjtRQUM5RixJQUFJLFNBQVMsS0FBSywwQkFBMEI7WUFBRSxPQUFPO1FBQ3JELFNBQVMsQ0FBQyxLQUFLLENBQUMsRUFBRSxhQUFhLEVBQUUsQ0FBQyxDQUFDO1FBQ25DLElBQUksUUFBUSxDQUFDLGFBQWEsS0FBSywwQkFBMEI7WUFBRSxPQUFPO0lBQ3RFLENBQUM7QUFDTCxDQUFDO0FBRUQ7OztHQUdHO0FBQ0gsTUFBTSxVQUFVLFNBQVMsQ0FBSSxLQUFVLEVBQUUsVUFBa0I7SUFDdkQsT0FBTyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLEtBQUssRUFBRSxFQUFFLENBQUMsS0FBSyxDQUFDLENBQUMsVUFBVSxHQUFHLEtBQUssQ0FBQyxHQUFHLEtBQUssQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDO0FBQy9FLENBQUM7QUFFRCxNQUFNLFVBQVUsVUFBVTtJQUN0QixPQUFPLFdBQVcsSUFBSSxDQUFDLE1BQU0sRUFBRSxDQUFDLFFBQVEsQ0FBQyxFQUFFLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxFQUFFLENBQUM7QUFDaEUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB0eXBlIE9yaWVudGF0aW9uID0gJ2hvcml6b250YWwnIHwgJ3ZlcnRpY2FsJztcbmV4cG9ydCB0eXBlIERpcmVjdGlvbiA9ICdsdHInIHwgJ3J0bCc7XG5cbmV4cG9ydCBjb25zdCBFTlRSWV9GT0NVUyA9ICdyb3ZpbmdGb2N1c0dyb3VwLm9uRW50cnlGb2N1cyc7XG5leHBvcnQgY29uc3QgRVZFTlRfT1BUSU9OUyA9IHsgYnViYmxlczogZmFsc2UsIGNhbmNlbGFibGU6IHRydWUgfTtcblxudHlwZSBGb2N1c0ludGVudCA9ICdmaXJzdCcgfCAnbGFzdCcgfCAncHJldicgfCAnbmV4dCc7XG5cbmV4cG9ydCBjb25zdCBNQVBfS0VZX1RPX0ZPQ1VTX0lOVEVOVDogUmVjb3JkPHN0cmluZywgRm9jdXNJbnRlbnQ+ID0ge1xuICAgIEFycm93TGVmdDogJ3ByZXYnLFxuICAgIEFycm93VXA6ICdwcmV2JyxcbiAgICBBcnJvd1JpZ2h0OiAnbmV4dCcsXG4gICAgQXJyb3dEb3duOiAnbmV4dCcsXG4gICAgUGFnZVVwOiAnZmlyc3QnLFxuICAgIEhvbWU6ICdmaXJzdCcsXG4gICAgUGFnZURvd246ICdsYXN0JyxcbiAgICBFbmQ6ICdsYXN0J1xufTtcblxuZXhwb3J0IGZ1bmN0aW9uIGdldERpcmVjdGlvbkF3YXJlS2V5KGtleTogc3RyaW5nLCBkaXI/OiBEaXJlY3Rpb24pIHtcbiAgICBpZiAoZGlyICE9PSAncnRsJykgcmV0dXJuIGtleTtcbiAgICByZXR1cm4ga2V5ID09PSAnQXJyb3dMZWZ0JyA/ICdBcnJvd1JpZ2h0JyA6IGtleSA9PT0gJ0Fycm93UmlnaHQnID8gJ0Fycm93TGVmdCcgOiBrZXk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXRGb2N1c0ludGVudChldmVudDogS2V5Ym9hcmRFdmVudCwgb3JpZW50YXRpb24/OiBPcmllbnRhdGlvbiwgZGlyPzogRGlyZWN0aW9uKSB7XG4gICAgY29uc3Qga2V5ID0gZ2V0RGlyZWN0aW9uQXdhcmVLZXkoZXZlbnQua2V5LCBkaXIpO1xuICAgIGlmIChvcmllbnRhdGlvbiA9PT0gJ3ZlcnRpY2FsJyAmJiBbJ0Fycm93TGVmdCcsICdBcnJvd1JpZ2h0J10uaW5jbHVkZXMoa2V5KSkgcmV0dXJuIHVuZGVmaW5lZDtcbiAgICBpZiAob3JpZW50YXRpb24gPT09ICdob3Jpem9udGFsJyAmJiBbJ0Fycm93VXAnLCAnQXJyb3dEb3duJ10uaW5jbHVkZXMoa2V5KSkgcmV0dXJuIHVuZGVmaW5lZDtcbiAgICByZXR1cm4gTUFQX0tFWV9UT19GT0NVU19JTlRFTlRba2V5XTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGZvY3VzRmlyc3QoY2FuZGlkYXRlczogSFRNTEVsZW1lbnRbXSwgcHJldmVudFNjcm9sbCA9IGZhbHNlLCByb290Tm9kZT86IERvY3VtZW50IHwgU2hhZG93Um9vdCkge1xuICAgIGNvbnN0IFBSRVZJT1VTTFlfRk9DVVNFRF9FTEVNRU5UID0gcm9vdE5vZGU/LmFjdGl2ZUVsZW1lbnQgPz8gZG9jdW1lbnQuYWN0aXZlRWxlbWVudDtcbiAgICBmb3IgKGNvbnN0IGNhbmRpZGF0ZSBvZiBjYW5kaWRhdGVzKSB7XG4gICAgICAgIC8vIGlmIGZvY3VzIGlzIGFscmVhZHkgd2hlcmUgd2Ugd2FudCB0byBnbywgd2UgZG9uJ3Qgd2FudCB0byBrZWVwIGdvaW5nIHRocm91Z2ggdGhlIGNhbmRpZGF0ZXNcbiAgICAgICAgaWYgKGNhbmRpZGF0ZSA9PT0gUFJFVklPVVNMWV9GT0NVU0VEX0VMRU1FTlQpIHJldHVybjtcbiAgICAgICAgY2FuZGlkYXRlLmZvY3VzKHsgcHJldmVudFNjcm9sbCB9KTtcbiAgICAgICAgaWYgKGRvY3VtZW50LmFjdGl2ZUVsZW1lbnQgIT09IFBSRVZJT1VTTFlfRk9DVVNFRF9FTEVNRU5UKSByZXR1cm47XG4gICAgfVxufVxuXG4vKipcbiAqIFdyYXBzIGFuIGFycmF5IGFyb3VuZCBpdHNlbGYgYXQgYSBnaXZlbiBzdGFydCBpbmRleFxuICogRXhhbXBsZTogYHdyYXBBcnJheShbJ2EnLCAnYicsICdjJywgJ2QnXSwgMikgPT09IFsnYycsICdkJywgJ2EnLCAnYiddYFxuICovXG5leHBvcnQgZnVuY3Rpb24gd3JhcEFycmF5PFQ+KGFycmF5OiBUW10sIHN0YXJ0SW5kZXg6IG51bWJlcikge1xuICAgIHJldHVybiBhcnJheS5tYXAoKF8sIGluZGV4KSA9PiBhcnJheVsoc3RhcnRJbmRleCArIGluZGV4KSAlIGFycmF5Lmxlbmd0aF0pO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gZ2VuZXJhdGVJZCgpOiBzdHJpbmcge1xuICAgIHJldHVybiBgcmYtaXRlbS0ke01hdGgucmFuZG9tKCkudG9TdHJpbmcoMzYpLnNsaWNlKDIsIDExKX1gO1xufVxuIl19
@@ -48,13 +48,16 @@ export class RdxSelectItemDirective {
48
48
  }
49
49
  });
50
50
  }
51
- /** Gets the label to be used when determining whether the option should be focused. */
51
+ /** Gets the label to be used when determining whether the option should be focused.
52
+ * @ignore
53
+ */
52
54
  getLabel() {
53
55
  return this.viewValue;
54
56
  }
55
57
  /**
56
58
  * `Selects the option while indicating the selection came from the user. Used to
57
59
  * determine if the select's view -> model callback should be invoked.`
60
+ * @ignore
58
61
  */
59
62
  selectViaInteraction() {
60
63
  if (!this.disabled) {
@@ -62,6 +65,7 @@ export class RdxSelectItemDirective {
62
65
  this.onSelectionChange.emit(new RdxSelectItemChange(this));
63
66
  }
64
67
  }
68
+ /** @ignore */
65
69
  handleKeydown(event) {
66
70
  if (event.keyCode === ENTER || event.keyCode === SPACE) {
67
71
  this.selectViaInteraction();
@@ -70,10 +74,12 @@ export class RdxSelectItemDirective {
70
74
  event.stopPropagation();
71
75
  }
72
76
  }
77
+ /** @ignore */
73
78
  setActiveStyles() {
74
79
  this.highlighted = true;
75
80
  this.nativeElement.focus({ preventScroll: true });
76
81
  }
82
+ /** @ignore */
77
83
  setInactiveStyles() {
78
84
  this.highlighted = false;
79
85
  }
@@ -113,4 +119,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImpo
113
119
  type: Input,
114
120
  args: [{ transform: booleanAttribute }]
115
121
  }] } });
116
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-item.directive.js","sourceRoot":"","sources":["../../../../../packages/primitives/select/src/select-item.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Highlightable } from '@angular/cdk/a11y';\nimport { ENTER, SPACE } from '@angular/cdk/keycodes';\nimport { booleanAttribute, Directive, ElementRef, EventEmitter, inject, Input } from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { RdxSelectContentDirective } from './select-content.directive';\nimport { RdxSelectComponent } from './select.component';\n\nlet nextId = 0;\n\nexport class RdxSelectItemChange<T = RdxSelectItemDirective> {\n    constructor(public source: T) {}\n}\n\n@Directive({\n    selector: '[rdxSelectItem]',\n    standalone: true,\n    exportAs: 'rdxSelectItem',\n    host: {\n        '[attr.role]': '\"option\"',\n        '[attr.data-state]': 'dataState',\n        '[attr.aria-selected]': 'selected',\n        '[attr.data-disabled]': 'disabled || null',\n        '[attr.data-highlighted]': 'highlighted || null',\n        '[attr.tabindex]': '-1',\n        '(focus)': 'content.highlighted.next(this)',\n        '(click)': 'selectViaInteraction()',\n        '(keydown)': 'handleKeydown($event)',\n        '(pointermove)': 'onPointerMove()'\n    }\n})\nexport class RdxSelectItemDirective implements Highlightable {\n    protected readonly select = inject(RdxSelectComponent);\n    protected readonly content = inject(RdxSelectContentDirective);\n    readonly onSelectionChange = new EventEmitter<RdxSelectItemChange>();\n    protected readonly nativeElement = inject(ElementRef).nativeElement;\n\n    highlighted: boolean = false;\n\n    selected: boolean;\n\n    get dataState(): string {\n        return this.selected ? 'checked' : 'unchecked';\n    }\n\n    /**\n     * The unique SelectItem id.\n     * @ignore\n     */\n    readonly id: string = `rdx-select-item-${nextId++}`;\n\n    @Input()\n    set value(value: string) {\n        this._value = value;\n    }\n\n    get value(): string {\n        return this._value || this.id;\n    }\n\n    private _value?: string;\n\n    @Input() textValue: string | null = null;\n\n    /** Whether the SelectItem is disabled. */\n    @Input({ transform: booleanAttribute })\n    set disabled(value: boolean) {\n        this._disabled = value;\n    }\n\n    get disabled(): boolean {\n        return this._disabled;\n    }\n\n    private _disabled: boolean;\n\n    get viewValue(): string {\n        return this.textValue ?? this.nativeElement.textContent;\n    }\n\n    constructor() {\n        this.content.highlighted.pipe(takeUntilDestroyed()).subscribe((value) => {\n            if (value !== this) {\n                this.highlighted = false;\n            }\n        });\n    }\n\n    /** Gets the label to be used when determining whether the option should be focused. */\n    getLabel(): string {\n        return this.viewValue;\n    }\n\n    /**\n     * `Selects the option while indicating the selection came from the user. Used to\n     * determine if the select's view -> model callback should be invoked.`\n     */\n    selectViaInteraction(): void {\n        if (!this.disabled) {\n            this.selected = true;\n\n            this.onSelectionChange.emit(new RdxSelectItemChange(this));\n        }\n    }\n\n    handleKeydown(event: KeyboardEvent): void {\n        if (event.keyCode === ENTER || event.keyCode === SPACE) {\n            this.selectViaInteraction();\n\n            // Prevent the page from scrolling down and form submits.\n            event.preventDefault();\n            event.stopPropagation();\n        }\n    }\n\n    setActiveStyles(): void {\n        this.highlighted = true;\n        this.nativeElement.focus({ preventScroll: true });\n    }\n\n    setInactiveStyles(): void {\n        this.highlighted = false;\n    }\n\n    protected onPointerMove(): void {\n        if (!this.highlighted) {\n            this.nativeElement.focus({ preventScroll: true });\n            this.select.updateActiveItem(this);\n        }\n    }\n}\n"]}
122
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-item.directive.js","sourceRoot":"","sources":["../../../../../packages/primitives/select/src/select-item.directive.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,uBAAuB,CAAC;AACrD,OAAO,EAAE,gBAAgB,EAAE,SAAS,EAAE,UAAU,EAAE,YAAY,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AACrG,OAAO,EAAE,kBAAkB,EAAE,MAAM,4BAA4B,CAAC;AAChE,OAAO,EAAE,yBAAyB,EAAE,MAAM,4BAA4B,CAAC;AACvE,OAAO,EAAE,kBAAkB,EAAE,MAAM,oBAAoB,CAAC;;AAExD,IAAI,MAAM,GAAG,CAAC,CAAC;AAEf,MAAM,OAAO,mBAAmB;IAC5B,YAAmB,MAAS;QAAT,WAAM,GAAN,MAAM,CAAG;IAAG,CAAC;CACnC;AAmBD,MAAM,OAAO,sBAAsB;IAU/B,IAAI,SAAS;QACT,OAAO,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,WAAW,CAAC;IACnD,CAAC;IAQD,IACI,KAAK,CAAC,KAAa;QACnB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;IACxB,CAAC;IAED,IAAI,KAAK;QACL,OAAO,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,EAAE,CAAC;IAClC,CAAC;IAMD,0CAA0C;IAC1C,IACI,QAAQ,CAAC,KAAc;QACvB,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;IAC3B,CAAC;IAED,IAAI,QAAQ;QACR,OAAO,IAAI,CAAC,SAAS,CAAC;IAC1B,CAAC;IAID,IAAI,SAAS;QACT,OAAO,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,aAAa,CAAC,WAAW,CAAC;IAC5D,CAAC;IAED;QAhDmB,WAAM,GAAG,MAAM,CAAC,kBAAkB,CAAC,CAAC;QACpC,YAAO,GAAG,MAAM,CAAC,yBAAyB,CAAC,CAAC;QACtD,sBAAiB,GAAG,IAAI,YAAY,EAAuB,CAAC;QAClD,kBAAa,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC,aAAa,CAAC;QAEpE,gBAAW,GAAY,KAAK,CAAC;QAQ7B;;;WAGG;QACM,OAAE,GAAW,mBAAmB,MAAM,EAAE,EAAE,CAAC;QAa3C,cAAS,GAAkB,IAAI,CAAC;QAmBrC,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,IAAI,CAAC,kBAAkB,EAAE,CAAC,CAAC,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE;YACpE,IAAI,KAAK,KAAK,IAAI,EAAE,CAAC;gBACjB,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;YAC7B,CAAC;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IAED;;OAEG;IACH,QAAQ;QACJ,OAAO,IAAI,CAAC,SAAS,CAAC;IAC1B,CAAC;IAED;;;;OAIG;IACH,oBAAoB;QAChB,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;YACjB,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;YAErB,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,IAAI,mBAAmB,CAAC,IAAI,CAAC,CAAC,CAAC;QAC/D,CAAC;IACL,CAAC;IAED,cAAc;IACd,aAAa,CAAC,KAAoB;QAC9B,IAAI,KAAK,CAAC,OAAO,KAAK,KAAK,IAAI,KAAK,CAAC,OAAO,KAAK,KAAK,EAAE,CAAC;YACrD,IAAI,CAAC,oBAAoB,EAAE,CAAC;YAE5B,yDAAyD;YACzD,KAAK,CAAC,cAAc,EAAE,CAAC;YACvB,KAAK,CAAC,eAAe,EAAE,CAAC;QAC5B,CAAC;IACL,CAAC;IAED,cAAc;IACd,eAAe;QACX,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;QACxB,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,EAAE,aAAa,EAAE,IAAI,EAAE,CAAC,CAAC;IACtD,CAAC;IAED,cAAc;IACd,iBAAiB;QACb,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;IAC7B,CAAC;IAES,aAAa;QACnB,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;YACpB,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,EAAE,aAAa,EAAE,IAAI,EAAE,CAAC,CAAC;YAClD,IAAI,CAAC,MAAM,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC;QACvC,CAAC;IACL,CAAC;+GAxGQ,sBAAsB;mGAAtB,sBAAsB,wIAkCX,gBAAgB;;4FAlC3B,sBAAsB;kBAjBlC,SAAS;mBAAC;oBACP,QAAQ,EAAE,iBAAiB;oBAC3B,UAAU,EAAE,IAAI;oBAChB,QAAQ,EAAE,eAAe;oBACzB,IAAI,EAAE;wBACF,aAAa,EAAE,UAAU;wBACzB,mBAAmB,EAAE,WAAW;wBAChC,sBAAsB,EAAE,UAAU;wBAClC,sBAAsB,EAAE,kBAAkB;wBAC1C,yBAAyB,EAAE,qBAAqB;wBAChD,iBAAiB,EAAE,IAAI;wBACvB,SAAS,EAAE,gCAAgC;wBAC3C,SAAS,EAAE,wBAAwB;wBACnC,WAAW,EAAE,uBAAuB;wBACpC,eAAe,EAAE,iBAAiB;qBACrC;iBACJ;wDAsBO,KAAK;sBADR,KAAK;gBAWG,SAAS;sBAAjB,KAAK;gBAIF,QAAQ;sBADX,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE","sourcesContent":["import { Highlightable } from '@angular/cdk/a11y';\nimport { ENTER, SPACE } from '@angular/cdk/keycodes';\nimport { booleanAttribute, Directive, ElementRef, EventEmitter, inject, Input } from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { RdxSelectContentDirective } from './select-content.directive';\nimport { RdxSelectComponent } from './select.component';\n\nlet nextId = 0;\n\nexport class RdxSelectItemChange<T = RdxSelectItemDirective> {\n    constructor(public source: T) {}\n}\n\n@Directive({\n    selector: '[rdxSelectItem]',\n    standalone: true,\n    exportAs: 'rdxSelectItem',\n    host: {\n        '[attr.role]': '\"option\"',\n        '[attr.data-state]': 'dataState',\n        '[attr.aria-selected]': 'selected',\n        '[attr.data-disabled]': 'disabled || null',\n        '[attr.data-highlighted]': 'highlighted || null',\n        '[attr.tabindex]': '-1',\n        '(focus)': 'content.highlighted.next(this)',\n        '(click)': 'selectViaInteraction()',\n        '(keydown)': 'handleKeydown($event)',\n        '(pointermove)': 'onPointerMove()'\n    }\n})\nexport class RdxSelectItemDirective implements Highlightable {\n    protected readonly select = inject(RdxSelectComponent);\n    protected readonly content = inject(RdxSelectContentDirective);\n    readonly onSelectionChange = new EventEmitter<RdxSelectItemChange>();\n    protected readonly nativeElement = inject(ElementRef).nativeElement;\n\n    highlighted: boolean = false;\n\n    selected: boolean;\n\n    get dataState(): string {\n        return this.selected ? 'checked' : 'unchecked';\n    }\n\n    /**\n     * The unique SelectItem id.\n     * @ignore\n     */\n    readonly id: string = `rdx-select-item-${nextId++}`;\n\n    @Input()\n    set value(value: string) {\n        this._value = value;\n    }\n\n    get value(): string {\n        return this._value || this.id;\n    }\n\n    private _value?: string;\n\n    @Input() textValue: string | null = null;\n\n    /** Whether the SelectItem is disabled. */\n    @Input({ transform: booleanAttribute })\n    set disabled(value: boolean) {\n        this._disabled = value;\n    }\n\n    get disabled(): boolean {\n        return this._disabled;\n    }\n\n    private _disabled: boolean;\n\n    get viewValue(): string {\n        return this.textValue ?? this.nativeElement.textContent;\n    }\n\n    constructor() {\n        this.content.highlighted.pipe(takeUntilDestroyed()).subscribe((value) => {\n            if (value !== this) {\n                this.highlighted = false;\n            }\n        });\n    }\n\n    /** Gets the label to be used when determining whether the option should be focused.\n     * @ignore\n     */\n    getLabel(): string {\n        return this.viewValue;\n    }\n\n    /**\n     * `Selects the option while indicating the selection came from the user. Used to\n     * determine if the select's view -> model callback should be invoked.`\n     * @ignore\n     */\n    selectViaInteraction(): void {\n        if (!this.disabled) {\n            this.selected = true;\n\n            this.onSelectionChange.emit(new RdxSelectItemChange(this));\n        }\n    }\n\n    /** @ignore */\n    handleKeydown(event: KeyboardEvent): void {\n        if (event.keyCode === ENTER || event.keyCode === SPACE) {\n            this.selectViaInteraction();\n\n            // Prevent the page from scrolling down and form submits.\n            event.preventDefault();\n            event.stopPropagation();\n        }\n    }\n\n    /** @ignore */\n    setActiveStyles(): void {\n        this.highlighted = true;\n        this.nativeElement.focus({ preventScroll: true });\n    }\n\n    /** @ignore */\n    setInactiveStyles(): void {\n        this.highlighted = false;\n    }\n\n    protected onPointerMove(): void {\n        if (!this.highlighted) {\n            this.nativeElement.focus({ preventScroll: true });\n            this.select.updateActiveItem(this);\n        }\n    }\n}\n"]}
@@ -19,10 +19,9 @@ export class RdxSliderOrientationContextService {
19
19
  }));
20
20
  }
21
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' }); }
22
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxSliderOrientationContextService }); }
23
23
  }
24
24
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxSliderOrientationContextService, decorators: [{
25
- type: Injectable,
26
- args: [{ providedIn: 'root' }]
25
+ type: Injectable
27
26
  }] });
28
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2xpZGVyLW9yaWVudGF0aW9uLWNvbnRleHQuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3ByaW1pdGl2ZXMvc2xpZGVyL3NyYy9zbGlkZXItb3JpZW50YXRpb24tY29udGV4dC5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQVVuRCxNQUFNLE9BQU8sa0NBQWtDO0lBRC9DO1FBRVksa0JBQWEsR0FBRyxNQUFNLENBQXFCO1lBQy9DLFNBQVMsRUFBRSxNQUFNO1lBQ2pCLE9BQU8sRUFBRSxPQUFPO1lBQ2hCLFNBQVMsRUFBRSxDQUFDO1lBQ1osSUFBSSxFQUFFLE9BQU87U0FDaEIsQ0FBQyxDQUFDO0tBWU47SUFWRyxJQUFJLE9BQU87UUFDUCxPQUFPLElBQUksQ0FBQyxhQUFhLEVBQUUsQ0FBQztJQUNoQyxDQUFDO0lBRUQsYUFBYSxDQUFDLE9BQW9DO1FBQzlDLElBQUksQ0FBQyxhQUFhLENBQUMsTUFBTSxDQUFDLENBQUMsT0FBTyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1lBQ3BDLEdBQUcsT0FBTztZQUNWLEdBQUcsT0FBTztTQUNiLENBQUMsQ0FBQyxDQUFDO0lBQ1IsQ0FBQzsrR0FqQlEsa0NBQWtDO21IQUFsQyxrQ0FBa0MsY0FEckIsTUFBTTs7NEZBQ25CLGtDQUFrQztrQkFEOUMsVUFBVTttQkFBQyxFQUFFLFVBQVUsRUFBRSxNQUFNLEVBQUUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlLCBzaWduYWwgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuZXhwb3J0IGludGVyZmFjZSBPcmllbnRhdGlvbkNvbnRleHQge1xuICAgIHN0YXJ0RWRnZTogc3RyaW5nO1xuICAgIGVuZEVkZ2U6IHN0cmluZztcbiAgICBkaXJlY3Rpb246IG51bWJlcjtcbiAgICBzaXplOiBzdHJpbmc7XG59XG5cbkBJbmplY3RhYmxlKHsgcHJvdmlkZWRJbjogJ3Jvb3QnIH0pXG5leHBvcnQgY2xhc3MgUmR4U2xpZGVyT3JpZW50YXRpb25Db250ZXh0U2VydmljZSB7XG4gICAgcHJpdmF0ZSBjb250ZXh0U2lnbmFsID0gc2lnbmFsPE9yaWVudGF0aW9uQ29udGV4dD4oe1xuICAgICAgICBzdGFydEVkZ2U6ICdsZWZ0JyxcbiAgICAgICAgZW5kRWRnZTogJ3JpZ2h0JyxcbiAgICAgICAgZGlyZWN0aW9uOiAxLFxuICAgICAgICBzaXplOiAnd2lkdGgnXG4gICAgfSk7XG5cbiAgICBnZXQgY29udGV4dCgpIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuY29udGV4dFNpZ25hbCgpO1xuICAgIH1cblxuICAgIHVwZGF0ZUNvbnRleHQoY29udGV4dDogUGFydGlhbDxPcmllbnRhdGlvbkNvbnRleHQ+KSB7XG4gICAgICAgIHRoaXMuY29udGV4dFNpZ25hbC51cGRhdGUoKGN1cnJlbnQpID0+ICh7XG4gICAgICAgICAgICAuLi5jdXJyZW50LFxuICAgICAgICAgICAgLi4uY29udGV4dFxuICAgICAgICB9KSk7XG4gICAgfVxufVxuIl19
27
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2xpZGVyLW9yaWVudGF0aW9uLWNvbnRleHQuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3ByaW1pdGl2ZXMvc2xpZGVyL3NyYy9zbGlkZXItb3JpZW50YXRpb24tY29udGV4dC5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQVVuRCxNQUFNLE9BQU8sa0NBQWtDO0lBRC9DO1FBRVksa0JBQWEsR0FBRyxNQUFNLENBQXFCO1lBQy9DLFNBQVMsRUFBRSxNQUFNO1lBQ2pCLE9BQU8sRUFBRSxPQUFPO1lBQ2hCLFNBQVMsRUFBRSxDQUFDO1lBQ1osSUFBSSxFQUFFLE9BQU87U0FDaEIsQ0FBQyxDQUFDO0tBWU47SUFWRyxJQUFJLE9BQU87UUFDUCxPQUFPLElBQUksQ0FBQyxhQUFhLEVBQUUsQ0FBQztJQUNoQyxDQUFDO0lBRUQsYUFBYSxDQUFDLE9BQW9DO1FBQzlDLElBQUksQ0FBQyxhQUFhLENBQUMsTUFBTSxDQUFDLENBQUMsT0FBTyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1lBQ3BDLEdBQUcsT0FBTztZQUNWLEdBQUcsT0FBTztTQUNiLENBQUMsQ0FBQyxDQUFDO0lBQ1IsQ0FBQzsrR0FqQlEsa0NBQWtDO21IQUFsQyxrQ0FBa0M7OzRGQUFsQyxrQ0FBa0M7a0JBRDlDLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlLCBzaWduYWwgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuZXhwb3J0IGludGVyZmFjZSBPcmllbnRhdGlvbkNvbnRleHQge1xuICAgIHN0YXJ0RWRnZTogc3RyaW5nO1xuICAgIGVuZEVkZ2U6IHN0cmluZztcbiAgICBkaXJlY3Rpb246IG51bWJlcjtcbiAgICBzaXplOiBzdHJpbmc7XG59XG5cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBSZHhTbGlkZXJPcmllbnRhdGlvbkNvbnRleHRTZXJ2aWNlIHtcbiAgICBwcml2YXRlIGNvbnRleHRTaWduYWwgPSBzaWduYWw8T3JpZW50YXRpb25Db250ZXh0Pih7XG4gICAgICAgIHN0YXJ0RWRnZTogJ2xlZnQnLFxuICAgICAgICBlbmRFZGdlOiAncmlnaHQnLFxuICAgICAgICBkaXJlY3Rpb246IDEsXG4gICAgICAgIHNpemU6ICd3aWR0aCdcbiAgICB9KTtcblxuICAgIGdldCBjb250ZXh0KCkge1xuICAgICAgICByZXR1cm4gdGhpcy5jb250ZXh0U2lnbmFsKCk7XG4gICAgfVxuXG4gICAgdXBkYXRlQ29udGV4dChjb250ZXh0OiBQYXJ0aWFsPE9yaWVudGF0aW9uQ29udGV4dD4pIHtcbiAgICAgICAgdGhpcy5jb250ZXh0U2lnbmFsLnVwZGF0ZSgoY3VycmVudCkgPT4gKHtcbiAgICAgICAgICAgIC4uLmN1cnJlbnQsXG4gICAgICAgICAgICAuLi5jb250ZXh0XG4gICAgICAgIH0pKTtcbiAgICB9XG59XG4iXX0=
@@ -25,7 +25,9 @@ export class RdxSliderRootComponent {
25
25
  this.valueIndexToChange = model(0);
26
26
  /** @ignore */
27
27
  this.valuesBeforeSlideStart = model([]);
28
+ /** @ignore */
28
29
  this.isSlidingFromLeft = computed(() => (this.dir() === 'ltr' && !this.inverted()) || (this.dir() !== 'ltr' && this.inverted()));
30
+ /** @ignore */
29
31
  this.isSlidingFromBottom = computed(() => !this.inverted());
30
32
  /** @ignore */
31
33
  this.thumbElements = [];
@@ -99,7 +101,7 @@ export class RdxSliderRootComponent {
99
101
  }
100
102
  }
101
103
  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: `
104
+ 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" }, providers: [RdxSliderOrientationContextService], ngImport: i0, template: `
103
105
  <ng-template #transclude><ng-content /></ng-template>
104
106
 
105
107
  <ng-container *ngIf="orientation() === 'horizontal'">
@@ -151,6 +153,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImpo
151
153
  selector: 'rdx-slider',
152
154
  standalone: true,
153
155
  imports: [RdxSliderHorizontalComponent, RdxSliderVerticalComponent, NgIf, NgTemplateOutlet],
156
+ providers: [RdxSliderOrientationContextService],
154
157
  template: `
155
158
  <ng-template #transclude><ng-content /></ng-template>
156
159
 
@@ -204,4 +207,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImpo
204
207
  }], valueCommit: [{
205
208
  type: Output
206
209
  }] } });
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"]}
210
+ //# 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    providers: [RdxSliderOrientationContextService],\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    /** @ignore */\n    readonly isSlidingFromLeft = computed(\n        () => (this.dir() === 'ltr' && !this.inverted()) || (this.dir() !== 'ltr' && this.inverted())\n    );\n\n    /** @ignore */\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"]}
@@ -4,7 +4,7 @@ import * as i0 from "@angular/core";
4
4
  import * as i1 from "@radix-ng/primitives/visually-hidden";
5
5
  export class RdxToggleInputDirective {
6
6
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxToggleInputDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
7
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.11", type: RdxToggleInputDirective, isStandalone: true, selector: "[rdxToggleInput]", host: { attributes: { "type": "checkbox" } }, exportAs: ["rdxToggleInput"], hostDirectives: [{ directive: i1.RdxVisuallyHiddenInputDirective, inputs: ["name", "name", "required", "required"] }], ngImport: i0 }); }
7
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.11", type: RdxToggleInputDirective, isStandalone: true, selector: "[rdxToggleInput]", host: { attributes: { "type": "checkbox" } }, exportAs: ["rdxToggleInput"], hostDirectives: [{ directive: i1.RdxVisuallyHiddenInputDirective, inputs: ["name", "name", "required", "required", "value", "value"] }], ngImport: i0 }); }
8
8
  }
9
9
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxToggleInputDirective, decorators: [{
10
10
  type: Directive,
@@ -17,7 +17,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImpo
17
17
  directive: RdxVisuallyHiddenInputDirective,
18
18
  inputs: [
19
19
  'name',
20
- 'required'
20
+ 'required',
21
+ 'value'
21
22
  ]
22
23
  }
23
24
  ],
@@ -26,4 +27,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImpo
26
27
  }
27
28
  }]
28
29
  }] });
29
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9nZ2xlLWlucHV0LmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3ByaW1pdGl2ZXMvdG9nZ2xlL3NyYy90b2dnbGUtaW5wdXQuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDMUMsT0FBTyxFQUFFLCtCQUErQixFQUFFLE1BQU0sc0NBQXNDLENBQUM7OztBQW1CdkYsTUFBTSxPQUFPLHVCQUF1QjsrR0FBdkIsdUJBQXVCO21HQUF2Qix1QkFBdUI7OzRGQUF2Qix1QkFBdUI7a0JBakJuQyxTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSxrQkFBa0I7b0JBQzVCLFFBQVEsRUFBRSxnQkFBZ0I7b0JBQzFCLFVBQVUsRUFBRSxJQUFJO29CQUNoQixjQUFjLEVBQUU7d0JBQ1o7NEJBQ0ksU0FBUyxFQUFFLCtCQUErQjs0QkFDMUMsTUFBTSxFQUFFO2dDQUNKLE1BQU07Z0NBQ04sVUFBVTs2QkFDYjt5QkFDSjtxQkFDSjtvQkFDRCxJQUFJLEVBQUU7d0JBQ0YsSUFBSSxFQUFFLFVBQVU7cUJBQ25CO2lCQUNKIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBSZHhWaXN1YWxseUhpZGRlbklucHV0RGlyZWN0aXZlIH0gZnJvbSAnQHJhZGl4LW5nL3ByaW1pdGl2ZXMvdmlzdWFsbHktaGlkZGVuJztcblxuQERpcmVjdGl2ZSh7XG4gICAgc2VsZWN0b3I6ICdbcmR4VG9nZ2xlSW5wdXRdJyxcbiAgICBleHBvcnRBczogJ3JkeFRvZ2dsZUlucHV0JyxcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIGhvc3REaXJlY3RpdmVzOiBbXG4gICAgICAgIHtcbiAgICAgICAgICAgIGRpcmVjdGl2ZTogUmR4VmlzdWFsbHlIaWRkZW5JbnB1dERpcmVjdGl2ZSxcbiAgICAgICAgICAgIGlucHV0czogW1xuICAgICAgICAgICAgICAgICduYW1lJyxcbiAgICAgICAgICAgICAgICAncmVxdWlyZWQnXG4gICAgICAgICAgICBdXG4gICAgICAgIH1cbiAgICBdLFxuICAgIGhvc3Q6IHtcbiAgICAgICAgdHlwZTogJ2NoZWNrYm94J1xuICAgIH1cbn0pXG5leHBvcnQgY2xhc3MgUmR4VG9nZ2xlSW5wdXREaXJlY3RpdmUge31cbiJdfQ==
30
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9nZ2xlLWlucHV0LmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3ByaW1pdGl2ZXMvdG9nZ2xlL3NyYy90b2dnbGUtaW5wdXQuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDMUMsT0FBTyxFQUFFLCtCQUErQixFQUFFLE1BQU0sc0NBQXNDLENBQUM7OztBQW9CdkYsTUFBTSxPQUFPLHVCQUF1QjsrR0FBdkIsdUJBQXVCO21HQUF2Qix1QkFBdUI7OzRGQUF2Qix1QkFBdUI7a0JBbEJuQyxTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSxrQkFBa0I7b0JBQzVCLFFBQVEsRUFBRSxnQkFBZ0I7b0JBQzFCLFVBQVUsRUFBRSxJQUFJO29CQUNoQixjQUFjLEVBQUU7d0JBQ1o7NEJBQ0ksU0FBUyxFQUFFLCtCQUErQjs0QkFDMUMsTUFBTSxFQUFFO2dDQUNKLE1BQU07Z0NBQ04sVUFBVTtnQ0FDVixPQUFPOzZCQUNWO3lCQUNKO3FCQUNKO29CQUNELElBQUksRUFBRTt3QkFDRixJQUFJLEVBQUUsVUFBVTtxQkFDbkI7aUJBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFJkeFZpc3VhbGx5SGlkZGVuSW5wdXREaXJlY3RpdmUgfSBmcm9tICdAcmFkaXgtbmcvcHJpbWl0aXZlcy92aXN1YWxseS1oaWRkZW4nO1xuXG5ARGlyZWN0aXZlKHtcbiAgICBzZWxlY3RvcjogJ1tyZHhUb2dnbGVJbnB1dF0nLFxuICAgIGV4cG9ydEFzOiAncmR4VG9nZ2xlSW5wdXQnLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgaG9zdERpcmVjdGl2ZXM6IFtcbiAgICAgICAge1xuICAgICAgICAgICAgZGlyZWN0aXZlOiBSZHhWaXN1YWxseUhpZGRlbklucHV0RGlyZWN0aXZlLFxuICAgICAgICAgICAgaW5wdXRzOiBbXG4gICAgICAgICAgICAgICAgJ25hbWUnLFxuICAgICAgICAgICAgICAgICdyZXF1aXJlZCcsXG4gICAgICAgICAgICAgICAgJ3ZhbHVlJ1xuICAgICAgICAgICAgXVxuICAgICAgICB9XG4gICAgXSxcbiAgICBob3N0OiB7XG4gICAgICAgIHR5cGU6ICdjaGVja2JveCdcbiAgICB9XG59KVxuZXhwb3J0IGNsYXNzIFJkeFRvZ2dsZUlucHV0RGlyZWN0aXZlIHt9XG4iXX0=