@refraktor/core 0.0.1 → 0.0.2

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 (81) hide show
  1. package/.turbo/turbo-build.log +1 -1
  2. package/build/components/menu/menu-dropdown/menu-dropdown.d.ts.map +1 -1
  3. package/build/components/menu/menu-dropdown/menu-dropdown.js +3 -2
  4. package/build/components/menu/menu-sub-dropdown/menu-sub-dropdown.d.ts.map +1 -1
  5. package/build/components/menu/menu-sub-dropdown/menu-sub-dropdown.js +2 -1
  6. package/build/components/menu/use-menu.d.ts.map +1 -1
  7. package/build/components/menu/use-menu.js +2 -1
  8. package/build/components/modal/modal-close/modal-close.d.ts.map +1 -1
  9. package/build/components/modal/modal-close/modal-close.js +1 -1
  10. package/build/components/modal/modal-content/modal-content.d.ts.map +1 -1
  11. package/build/components/modal/modal-content/modal-content.js +1 -1
  12. package/build/components/modal/modal-header/modal-header.d.ts.map +1 -1
  13. package/build/components/modal/modal-header/modal-header.js +1 -1
  14. package/build/components/number-input/number-input.d.ts.map +1 -1
  15. package/build/components/number-input/number-input.js +22 -15
  16. package/build/components/number-input/number-input.test.d.ts +2 -0
  17. package/build/components/number-input/number-input.test.d.ts.map +1 -0
  18. package/build/components/number-input/number-input.test.js +14 -0
  19. package/build/components/number-input/number-input.types.d.ts +2 -2
  20. package/build/components/number-input/number-input.types.d.ts.map +1 -1
  21. package/build/components/popover/popover-dropdown/popover-dropdown.d.ts.map +1 -1
  22. package/build/components/popover/popover-dropdown/popover-dropdown.js +2 -1
  23. package/build/components/popover/use-popover.d.ts.map +1 -1
  24. package/build/components/popover/use-popover.js +2 -1
  25. package/build/components/portal/portal.js +1 -1
  26. package/build/components/select/select-dropdown/select-dropdown.d.ts.map +1 -1
  27. package/build/components/select/select-dropdown/select-dropdown.js +3 -2
  28. package/build/components/select/select-item/select-item.d.ts.map +1 -1
  29. package/build/components/select/select-item/select-item.js +1 -1
  30. package/build/components/select/select-root/select-root.d.ts.map +1 -1
  31. package/build/components/select/select-root/select-root.js +36 -6
  32. package/build/components/select/select-trigger/select-trigger.d.ts.map +1 -1
  33. package/build/components/select/select-trigger/select-trigger.js +1 -1
  34. package/build/components/select/select.context.d.ts +2 -0
  35. package/build/components/select/select.context.d.ts.map +1 -1
  36. package/build/components/select/select.test.js +17 -0
  37. package/build/components/select/select.types.d.ts +10 -0
  38. package/build/components/select/select.types.d.ts.map +1 -1
  39. package/build/components/select/use-select.d.ts.map +1 -1
  40. package/build/components/select/use-select.js +2 -1
  41. package/build/components/switch/switch.js +1 -1
  42. package/build/components/tabs/tabs-tab/tabs-tab.d.ts.map +1 -1
  43. package/build/components/tabs/tabs-tab/tabs-tab.js +0 -6
  44. package/build/components/tooltip/tooltip.d.ts.map +1 -1
  45. package/build/components/tooltip/tooltip.js +7 -3
  46. package/build/components/tooltip/use-tooltip.d.ts.map +1 -1
  47. package/build/components/tooltip/use-tooltip.js +2 -1
  48. package/build/components/transition/transition.d.ts.map +1 -1
  49. package/build/components/transition/transition.js +16 -12
  50. package/build/style.css +1 -1
  51. package/package.json +2 -2
  52. package/src/components/menu/menu-dropdown/menu-dropdown.tsx +4 -3
  53. package/src/components/menu/menu-sub-dropdown/menu-sub-dropdown.tsx +2 -0
  54. package/src/components/menu/use-menu.ts +2 -1
  55. package/src/components/modal/modal-close/modal-close.tsx +1 -5
  56. package/src/components/modal/modal-content/modal-content.tsx +3 -4
  57. package/src/components/modal/modal-header/modal-header.tsx +4 -2
  58. package/src/components/modal/modal-overlay/modal-overlay.tsx +64 -64
  59. package/src/components/modal/modal.test.tsx +110 -110
  60. package/src/components/modal/use-modal.ts +101 -101
  61. package/src/components/number-input/number-input.test.tsx +22 -0
  62. package/src/components/number-input/number-input.tsx +79 -51
  63. package/src/components/number-input/number-input.types.ts +8 -8
  64. package/src/components/popover/popover-dropdown/popover-dropdown.tsx +2 -0
  65. package/src/components/popover/use-popover.ts +2 -1
  66. package/src/components/portal/portal.tsx +1 -1
  67. package/src/components/select/select-dropdown/select-dropdown.tsx +4 -3
  68. package/src/components/select/select-item/select-item.tsx +0 -1
  69. package/src/components/select/select-root/select-root.tsx +87 -11
  70. package/src/components/select/select-trigger/select-trigger.tsx +2 -0
  71. package/src/components/select/select.context.ts +2 -0
  72. package/src/components/select/select.test.tsx +35 -0
  73. package/src/components/select/select.types.ts +15 -0
  74. package/src/components/select/use-select.ts +2 -1
  75. package/src/components/switch/switch.tsx +1 -1
  76. package/src/components/tabs/tabs-tab/tabs-tab.tsx +0 -8
  77. package/src/components/tooltip/tooltip.tsx +7 -1
  78. package/src/components/tooltip/use-tooltip.ts +2 -1
  79. package/src/components/transition/transition.tsx +18 -14
  80. package/src/style.css +0 -1
  81. package/tsconfig.tsbuildinfo +1 -1
@@ -201,6 +201,7 @@ const SelectDropdown = factory<SelectDropdownFactoryPayload>(
201
201
  transition="fade"
202
202
  duration={150}
203
203
  mounted={select.select.opened}
204
+ style={{ position: "relative", zIndex: 1000 }}
204
205
  {...select.transitionProps}
205
206
  >
206
207
  <div
@@ -211,6 +212,7 @@ const SelectDropdown = factory<SelectDropdownFactoryPayload>(
211
212
  tabIndex={-1}
212
213
  style={{
213
214
  ...select.select.floatingStyles,
215
+ zIndex: 1000,
214
216
  width: referenceWidth,
215
217
  ...style
216
218
  }}
@@ -273,16 +275,15 @@ const SelectDropdown = factory<SelectDropdownFactoryPayload>(
273
275
  </Transition>
274
276
  );
275
277
 
276
- const wrappedContent = select.select.opened ? (
278
+ const wrappedContent = (
277
279
  <FloatingFocusManager
278
280
  context={select.select.context}
279
281
  modal={false}
280
282
  initialFocus={-1}
283
+ disabled={!select.select.opened}
281
284
  >
282
285
  {dropdownContent}
283
286
  </FloatingFocusManager>
284
- ) : (
285
- dropdownContent
286
287
  );
287
288
 
288
289
  return select.withinPortal ? (
@@ -95,7 +95,6 @@ const SelectItem = factory<SelectItemFactoryPayload>(
95
95
  "w-full text-left p-1.5 text-sm rounded-none appearance-none border-none bg-transparent",
96
96
  "inline-flex items-center gap-2 outline-none transition-colors",
97
97
  "hover:bg-[var(--refraktor-bg-hover)] focus-visible:bg-[var(--refraktor-bg-hover)]",
98
- "data-[selected=true]:bg-[var(--refraktor-bg-hover)]",
99
98
  "data-[disabled=true]:opacity-50 data-[disabled=true]:pointer-events-none data-[disabled=true]:cursor-not-allowed",
100
99
  getRadius(select.radius),
101
100
  select.getStyles("item"),
@@ -1,9 +1,18 @@
1
1
  import { useId, useUncontrolled } from "@refraktor/utils";
2
- import { useCallback, useEffect, useRef } from "react";
2
+ import {
3
+ Children,
4
+ isValidElement,
5
+ useCallback,
6
+ useEffect,
7
+ useMemo,
8
+ useRef
9
+ } from "react";
10
+ import type { ReactNode } from "react";
3
11
  import { useTheme } from "../../../theme";
4
12
  import { factory, useClassNames, useProps } from "../../../utils";
5
13
  import {
6
14
  focusSelectItem,
15
+ getNodeTextValue,
7
16
  getNavigableSelectItems,
8
17
  SelectProvider,
9
18
  useSelectItemsRegistry
@@ -18,6 +27,7 @@ import type {
18
27
  SelectRootProps
19
28
  } from "../select.types";
20
29
  import { useSelect } from "../use-select";
30
+ import { InputWrapper } from "../../input/input-wrapper";
21
31
 
22
32
  const defaultProps = {
23
33
  positioning: {
@@ -37,11 +47,52 @@ const defaultProps = {
37
47
  closeOnEscape: true
38
48
  } satisfies Partial<SelectRootProps>;
39
49
 
50
+ function collectSelectItemLabels(node: ReactNode, labels: Map<string, string>) {
51
+ Children.forEach(node, (child) => {
52
+ if (!isValidElement(child)) {
53
+ return;
54
+ }
55
+
56
+ const typeDisplayName = (child.type as { displayName?: string })
57
+ .displayName;
58
+ const props = child.props as {
59
+ value?: string;
60
+ textValue?: string;
61
+ children?: ReactNode;
62
+ };
63
+
64
+ if (
65
+ typeDisplayName === "@refraktor/core/Select.Item" &&
66
+ typeof props.value === "string"
67
+ ) {
68
+ labels.set(
69
+ props.value,
70
+ getNodeTextValue(props.children, props.textValue) || props.value
71
+ );
72
+ }
73
+
74
+ if (props.children !== undefined && props.children !== null) {
75
+ collectSelectItemLabels(props.children, labels);
76
+ }
77
+ });
78
+ }
79
+
80
+ function getSelectItemLabels(node: ReactNode) {
81
+ const labels = new Map<string, string>();
82
+ collectSelectItemLabels(node, labels);
83
+ return labels;
84
+ }
85
+
40
86
  const SelectRoot = factory<SelectRootFactoryPayload>((_props, ref) => {
41
87
  const { cx } = useTheme();
42
88
  const {
43
89
  id,
44
90
  children,
91
+ label,
92
+ description,
93
+ error,
94
+ required,
95
+ withAsterisk,
45
96
  value,
46
97
  defaultValue,
47
98
  onChange,
@@ -74,6 +125,8 @@ const SelectRoot = factory<SelectRootFactoryPayload>((_props, ref) => {
74
125
  const _id = useId(id);
75
126
  const listId = `${_id}-listbox`;
76
127
  const triggerId = `${_id}-trigger`;
128
+ const hasWrapper = label || description || error;
129
+ const inferredLabels = useMemo(() => getSelectItemLabels(children), [children]);
77
130
 
78
131
  const [selectedValue, setSelectedValue] = useUncontrolled<string | null>({
79
132
  value,
@@ -153,8 +206,12 @@ const SelectRoot = factory<SelectRootFactoryPayload>((_props, ref) => {
153
206
  return "";
154
207
  }
155
208
 
156
- return labelsRef.current.get(selectedValue) ?? selectedValue;
157
- }, [selectedValue]);
209
+ return (
210
+ labelsRef.current.get(selectedValue) ??
211
+ inferredLabels.get(selectedValue) ??
212
+ selectedValue
213
+ );
214
+ }, [selectedValue, inferredLabels]);
158
215
 
159
216
  const focusFirstItem = useCallback(() => {
160
217
  const items = getNavigableSelectItems(getVisibleItems());
@@ -216,6 +273,8 @@ const SelectRoot = factory<SelectRootFactoryPayload>((_props, ref) => {
216
273
  searchPlaceholder,
217
274
  nothingFound,
218
275
  disabled: !!disabled,
276
+ error: !!error,
277
+ required: !!required,
219
278
  size,
220
279
  radius,
221
280
  variant,
@@ -238,16 +297,33 @@ const SelectRoot = factory<SelectRootFactoryPayload>((_props, ref) => {
238
297
  getStyles
239
298
  };
240
299
 
300
+ const content = (
301
+ <div
302
+ ref={ref}
303
+ id={_id}
304
+ className={cx("relative w-full", classes.root, className)}
305
+ {...props}
306
+ >
307
+ {children}
308
+ </div>
309
+ );
310
+
241
311
  return (
242
312
  <SelectProvider value={context}>
243
- <div
244
- ref={ref}
245
- id={_id}
246
- className={cx("relative w-full", classes.root, className)}
247
- {...props}
248
- >
249
- {children}
250
- </div>
313
+ {hasWrapper ? (
314
+ <InputWrapper
315
+ label={label}
316
+ description={description}
317
+ error={error}
318
+ required={required}
319
+ withAsterisk={withAsterisk}
320
+ inputId={triggerId}
321
+ >
322
+ {content}
323
+ </InputWrapper>
324
+ ) : (
325
+ content
326
+ )}
251
327
  </SelectProvider>
252
328
  );
253
329
  });
@@ -81,6 +81,8 @@ const SelectTrigger = factory<SelectTriggerFactoryPayload>(
81
81
  select.triggerInputRef.current = node;
82
82
  }}
83
83
  readOnly
84
+ required={select.required}
85
+ error={select.error}
84
86
  disabled={select.disabled}
85
87
  value={hasValue ? selectedLabel : ""}
86
88
  placeholder={hasValue ? undefined : placeholder ?? select.placeholder}
@@ -29,6 +29,8 @@ export interface SelectContextValue {
29
29
  searchPlaceholder: string;
30
30
  nothingFound: ReactNode;
31
31
  disabled: boolean;
32
+ error: boolean;
33
+ required: boolean;
32
34
  size: RefraktorSize;
33
35
  radius: RefraktorRadius;
34
36
  variant: InputVariant;
@@ -36,6 +36,20 @@ describe("@refraktor/core/Select", () => {
36
36
  });
37
37
  });
38
38
 
39
+ it("renders defaultValue label in trigger before opening", async () => {
40
+ await render(
41
+ <Select
42
+ defaultValue="apple"
43
+ data={[
44
+ { value: "apple", label: "Apple" },
45
+ { value: "orange", label: "Orange" }
46
+ ]}
47
+ />
48
+ );
49
+
50
+ expect(screen.getByRole("combobox")).toHaveValue("Apple");
51
+ });
52
+
39
53
  it("renders searchable input inside dropdown", async () => {
40
54
  const user = userEvent.setup();
41
55
 
@@ -152,4 +166,25 @@ describe("@refraktor/core/Select", () => {
152
166
  expect(onChange).toHaveBeenCalledWith("vue");
153
167
  expect(screen.getByRole("combobox")).toHaveValue("Vue");
154
168
  });
169
+
170
+ it("supports input wrapper props", async () => {
171
+ await render(
172
+ <Select
173
+ label="Framework"
174
+ description="Pick one option"
175
+ error="Selection is required"
176
+ transitionProps={transitionProps}
177
+ data={[
178
+ { value: "react", label: "React" },
179
+ { value: "vue", label: "Vue" }
180
+ ]}
181
+ />
182
+ );
183
+
184
+ const trigger = screen.getByLabelText("Framework");
185
+
186
+ expect(trigger).toHaveAttribute("aria-invalid", "true");
187
+ expect(screen.getByText("Pick one option")).toBeInTheDocument();
188
+ expect(screen.getByText("Selection is required")).toBeInTheDocument();
189
+ });
155
190
  });
@@ -82,6 +82,21 @@ export interface SelectRootProps
82
82
  /** Children containing select subcomponents */
83
83
  children: ReactNode;
84
84
 
85
+ /** Label text */
86
+ label?: ReactNode;
87
+
88
+ /** Description text */
89
+ description?: ReactNode;
90
+
91
+ /** Error message */
92
+ error?: ReactNode;
93
+
94
+ /** Whether the field is required */
95
+ required?: boolean;
96
+
97
+ /** Display an asterisk next to the label */
98
+ withAsterisk?: boolean;
99
+
85
100
  /** Selected value (controlled) */
86
101
  value?: string | null;
87
102
 
@@ -114,7 +114,8 @@ export function useSelect(options: UseSelectProps = {}): UseSelectReturn {
114
114
  open: isOpen,
115
115
  onOpenChange: setIsOpen,
116
116
  middleware,
117
- whileElementsMounted: autoUpdate
117
+ whileElementsMounted: autoUpdate,
118
+ strategy: "fixed"
118
119
  });
119
120
 
120
121
  const click = useClick(floating.context, {
@@ -100,7 +100,7 @@ const Switch = factory<SwitchFactoryPayload>((_props, ref) => {
100
100
  <span
101
101
  className={cx(
102
102
  "text-[var(--refraktor-text)]",
103
- labelPosition === "left" ? "mr-3" : "ml-3",
103
+ labelPosition === "left" ? "mr-2" : "ml-2",
104
104
  sizeClass.label,
105
105
  classes.label
106
106
  )}
@@ -91,10 +91,6 @@ const TabsTab = factory<TabsTabFactoryPayload>(
91
91
 
92
92
  const nextTab = tabs[nextIndex];
93
93
  nextTab.ref.current?.focus();
94
-
95
- if (activationMode === "automatic") {
96
- onValueChange(nextTab.value);
97
- }
98
94
  };
99
95
 
100
96
  const handleBoundary = (type: "first" | "last") => {
@@ -107,10 +103,6 @@ const TabsTab = factory<TabsTabFactoryPayload>(
107
103
  const target = type === "first" ? tabs[0] : tabs[tabs.length - 1];
108
104
 
109
105
  target.ref.current?.focus();
110
-
111
- if (activationMode === "automatic") {
112
- onValueChange(target.value);
113
- }
114
106
  };
115
107
 
116
108
  return (
@@ -50,6 +50,7 @@ const Tooltip = factory<TooltipFactoryPayload>((_props, ref) => {
50
50
  transitionProps,
51
51
  radius,
52
52
  withinPortal,
53
+ style,
53
54
  className,
54
55
  classNames,
55
56
  ...props
@@ -94,6 +95,7 @@ const Tooltip = factory<TooltipFactoryPayload>((_props, ref) => {
94
95
  transition="fade"
95
96
  duration={200}
96
97
  mounted={isOpened}
98
+ style={{ position: "relative", zIndex: 1000 }}
97
99
  {...transitionProps}
98
100
  >
99
101
  <div
@@ -108,7 +110,11 @@ const Tooltip = factory<TooltipFactoryPayload>((_props, ref) => {
108
110
  }}
109
111
  id={_id}
110
112
  role="tooltip"
111
- style={floatingStyles}
113
+ style={{
114
+ ...floatingStyles,
115
+ zIndex: 1000,
116
+ ...style
117
+ }}
112
118
  className={cx(
113
119
  "z-50 px-1.5 py-0.5 text-sm bg-[var(--refraktor-bg)] text-[var(--refraktor-text)] shadow-md",
114
120
  getRadius(radius),
@@ -136,7 +136,8 @@ export function useTooltip(options: UseTooltipProps = {}): UseTooltipReturn {
136
136
  open: isOpen,
137
137
  onOpenChange: setIsOpen,
138
138
  middleware: middleware,
139
- whileElementsMounted: autoUpdate
139
+ whileElementsMounted: autoUpdate,
140
+ strategy: "fixed"
140
141
  });
141
142
 
142
143
  const hover = useHover(floating.context, {
@@ -239,26 +239,30 @@ const Transition = polymorphicFactory<TransitionFactoryPayload>(
239
239
  setTransitionState("entering");
240
240
 
241
241
  rafRef.current = window.requestAnimationFrame(() => {
242
- if (runIdRef.current !== runId) {
243
- return;
244
- }
245
-
246
- setTransitionState("entered");
242
+ // Second rAF ensures the browser has painted the enterFrom
243
+ // styles before we move to entered, so the CSS transition fires.
244
+ rafRef.current = window.requestAnimationFrame(() => {
245
+ if (runIdRef.current !== runId) {
246
+ return;
247
+ }
247
248
 
248
- const waitTime = enterDuration + enterDelay;
249
+ setTransitionState("entered");
249
250
 
250
- if (waitTime <= 0) {
251
- onEnterEnd?.();
252
- return;
253
- }
251
+ const waitTime = enterDuration + enterDelay;
254
252
 
255
- timeoutRef.current = window.setTimeout(() => {
256
- if (runIdRef.current !== runId) {
253
+ if (waitTime <= 0) {
254
+ onEnterEnd?.();
257
255
  return;
258
256
  }
259
257
 
260
- onEnterEnd?.();
261
- }, waitTime);
258
+ timeoutRef.current = window.setTimeout(() => {
259
+ if (runIdRef.current !== runId) {
260
+ return;
261
+ }
262
+
263
+ onEnterEnd?.();
264
+ }, waitTime);
265
+ });
262
266
  });
263
267
 
264
268
  return;
package/src/style.css CHANGED
@@ -253,7 +253,6 @@
253
253
  .refraktor-scrollbar {
254
254
  scrollbar-width: thin;
255
255
  scrollbar-color: var(--refraktor-scroll-thumb) transparent;
256
- scrollbar-gutter: stable both-edges;
257
256
  }
258
257
 
259
258
  .refraktor-scrollbar::-webkit-scrollbar {
@@ -1 +1 @@
1
- {"root":["./src/index.ts","./src/components/index.ts","./src/components/accordion/accordion.context.ts","./src/components/accordion/accordion.styles.ts","./src/components/accordion/accordion.test.tsx","./src/components/accordion/accordion.tsx","./src/components/accordion/accordion.types.ts","./src/components/accordion/index.ts","./src/components/accordion/accordion-control/accordion-control.tsx","./src/components/accordion/accordion-control/index.ts","./src/components/accordion/accordion-item/accordion-item.tsx","./src/components/accordion/accordion-item/index.ts","./src/components/accordion/accordion-panel/accordion-panel.tsx","./src/components/accordion/accordion-panel/index.ts","./src/components/avatar/avatar.styles.ts","./src/components/avatar/avatar.tsx","./src/components/avatar/avatar.types.ts","./src/components/avatar/index.ts","./src/components/avatar/avatar-group/avatar-group.tsx","./src/components/avatar/avatar-group/index.ts","./src/components/badge/badge.styles.ts","./src/components/badge/badge.tsx","./src/components/badge/badge.types.ts","./src/components/badge/index.ts","./src/components/button/button.styles.ts","./src/components/button/button.test.tsx","./src/components/button/button.tsx","./src/components/button/button.types.ts","./src/components/button/index.ts","./src/components/checkbox/checkbox.context.ts","./src/components/checkbox/checkbox.styles.ts","./src/components/checkbox/checkbox.test.tsx","./src/components/checkbox/checkbox.tsx","./src/components/checkbox/checkbox.types.ts","./src/components/checkbox/index.ts","./src/components/checkbox/checkbox-group/checkbox-group.tsx","./src/components/checkbox/checkbox-group/index.ts","./src/components/color-swatch/color-swatch.styles.ts","./src/components/color-swatch/color-swatch.test.tsx","./src/components/color-swatch/color-swatch.tsx","./src/components/color-swatch/color-swatch.types.ts","./src/components/color-swatch/index.ts","./src/components/input/index.ts","./src/components/input/input.tsx","./src/components/input/input.types.ts","./src/components/input/input-description/index.ts","./src/components/input/input-description/input-description.tsx","./src/components/input/input-error/index.ts","./src/components/input/input-error/input-error.tsx","./src/components/input/input-field/index.ts","./src/components/input/input-field/input-field.styles.ts","./src/components/input/input-field/input-field.tsx","./src/components/input/input-label/index.ts","./src/components/input/input-label/input-label.tsx","./src/components/input/input-wrapper/index.ts","./src/components/input/input-wrapper/input-wrapper.tsx","./src/components/loader/index.ts","./src/components/loader/loader.tsx","./src/components/loader/loader.types.ts","./src/components/menu/index.ts","./src/components/menu/menu.context.ts","./src/components/menu/menu.test.tsx","./src/components/menu/menu.tsx","./src/components/menu/menu.types.ts","./src/components/menu/use-menu.ts","./src/components/menu/menu-dropdown/index.ts","./src/components/menu/menu-dropdown/menu-dropdown.tsx","./src/components/menu/menu-item/index.ts","./src/components/menu/menu-item/menu-item.tsx","./src/components/menu/menu-label/index.ts","./src/components/menu/menu-label/menu-label.tsx","./src/components/menu/menu-separator/index.ts","./src/components/menu/menu-separator/menu-separator.tsx","./src/components/menu/menu-sub/index.ts","./src/components/menu/menu-sub/menu-sub.tsx","./src/components/menu/menu-sub-dropdown/index.ts","./src/components/menu/menu-sub-dropdown/menu-sub-dropdown.tsx","./src/components/menu/menu-sub-trigger/index.ts","./src/components/menu/menu-sub-trigger/menu-sub-trigger.tsx","./src/components/menu/menu-trigger/index.ts","./src/components/menu/menu-trigger/menu-trigger.tsx","./src/components/modal/index.ts","./src/components/modal/modal.context.ts","./src/components/modal/modal.test.tsx","./src/components/modal/modal.tsx","./src/components/modal/modal.types.ts","./src/components/modal/use-modal.ts","./src/components/modal/modal-close/index.ts","./src/components/modal/modal-close/modal-close.tsx","./src/components/modal/modal-content/index.ts","./src/components/modal/modal-content/modal-content.tsx","./src/components/modal/modal-header/index.ts","./src/components/modal/modal-header/modal-header.tsx","./src/components/modal/modal-overlay/index.ts","./src/components/modal/modal-overlay/modal-overlay.tsx","./src/components/modal/modal-root/index.ts","./src/components/modal/modal-root/modal-root.tsx","./src/components/number-input/index.ts","./src/components/number-input/number-input.styles.ts","./src/components/number-input/number-input.tsx","./src/components/number-input/number-input.types.ts","./src/components/pagination/index.ts","./src/components/pagination/pagination.styles.ts","./src/components/pagination/pagination.test.tsx","./src/components/pagination/pagination.tsx","./src/components/pagination/pagination.types.ts","./src/components/pagination/pagination.utils.ts","./src/components/popover/index.ts","./src/components/popover/popover.context.ts","./src/components/popover/popover.tsx","./src/components/popover/popover.types.ts","./src/components/popover/use-popover.ts","./src/components/popover/popover-dropdown/index.ts","./src/components/popover/popover-dropdown/popover-dropdown.tsx","./src/components/popover/popover-trigger/index.ts","./src/components/popover/popover-trigger/popover-trigger.tsx","./src/components/portal/index.ts","./src/components/portal/portal.test.tsx","./src/components/portal/portal.tsx","./src/components/portal/portal.types.ts","./src/components/progress/index.ts","./src/components/progress/progress.styles.ts","./src/components/progress/progress.test.tsx","./src/components/progress/progress.tsx","./src/components/progress/progress.types.ts","./src/components/progress-circle/index.ts","./src/components/progress-circle/progress-circle.styles.ts","./src/components/progress-circle/progress-circle.test.tsx","./src/components/progress-circle/progress-circle.tsx","./src/components/progress-circle/progress-circle.types.ts","./src/components/radio/index.ts","./src/components/radio/radio.context.ts","./src/components/radio/radio.styles.ts","./src/components/radio/radio.test.tsx","./src/components/radio/radio.tsx","./src/components/radio/radio.types.ts","./src/components/radio/radio-group/index.ts","./src/components/radio/radio-group/radio-group.tsx","./src/components/select/index.ts","./src/components/select/select.context.ts","./src/components/select/select.test.tsx","./src/components/select/select.tsx","./src/components/select/select.types.ts","./src/components/select/use-select.ts","./src/components/select/select-dropdown/index.ts","./src/components/select/select-dropdown/select-dropdown.tsx","./src/components/select/select-group/index.ts","./src/components/select/select-group/select-group.tsx","./src/components/select/select-item/index.ts","./src/components/select/select-item/select-item.tsx","./src/components/select/select-root/index.ts","./src/components/select/select-root/select-root.tsx","./src/components/select/select-trigger/index.ts","./src/components/select/select-trigger/select-trigger.tsx","./src/components/slider/index.ts","./src/components/slider/slider.styles.ts","./src/components/slider/slider.tsx","./src/components/slider/slider.types.ts","./src/components/switch/index.ts","./src/components/switch/switch.styles.ts","./src/components/switch/switch.tsx","./src/components/switch/switch.types.ts","./src/components/tabs/index.ts","./src/components/tabs/tabs.context.ts","./src/components/tabs/tabs.styles.ts","./src/components/tabs/tabs.test.tsx","./src/components/tabs/tabs.tsx","./src/components/tabs/tabs.types.ts","./src/components/tabs/tabs-list/index.ts","./src/components/tabs/tabs-list/tabs-list.tsx","./src/components/tabs/tabs-panel/index.ts","./src/components/tabs/tabs-panel/tabs-panel.tsx","./src/components/tabs/tabs-tab/index.ts","./src/components/tabs/tabs-tab/tabs-tab.tsx","./src/components/textarea/index.ts","./src/components/textarea/textarea.tsx","./src/components/textarea/textarea.types.ts","./src/components/textarea/textarea-field/index.ts","./src/components/textarea/textarea-field/textarea-field.styles.ts","./src/components/textarea/textarea-field/textarea-field.tsx","./src/components/timeline/index.ts","./src/components/timeline/timeline.context.ts","./src/components/timeline/timeline.styles.ts","./src/components/timeline/timeline.test.tsx","./src/components/timeline/timeline.tsx","./src/components/timeline/timeline.types.ts","./src/components/timeline/timeline-item/index.ts","./src/components/timeline/timeline-item/timeline-item.tsx","./src/components/tooltip/index.ts","./src/components/tooltip/tooltip.tsx","./src/components/tooltip/tooltip.types.ts","./src/components/tooltip/use-tooltip.ts","./src/components/transition/index.ts","./src/components/transition/transition.test.tsx","./src/components/transition/transition.tsx","./src/components/transition/transition.types.ts","./src/components/transition/transitions.ts","./src/icons/check.tsx","./src/icons/chevron.tsx","./src/icons/index.ts","./src/icons/minus.tsx","./src/icons/types.ts","./src/icons/user.tsx","./src/icons/x.tsx","./src/theme/index.ts","./src/theme/types.ts","./src/theme/themeprovider/themeprovider.tsx","./src/theme/themeprovider/context.ts","./src/theme/themeprovider/generatevariables.test.ts","./src/theme/themeprovider/generatevariables.ts","./src/theme/themeprovider/index.ts","./src/theme/themeprovider/types.ts","./src/theme/createtheme/createtheme.ts","./src/theme/createtheme/index.ts","./src/theme/createtheme/types.ts","./src/theme/defaults/colors.ts","./src/theme/defaults/settings.ts","./src/theme/utils/get-radius.ts","./src/theme/utils/get-shade.ts","./src/theme/utils/index.ts","./src/theme/utils/use-theme.ts","./src/utils/index.ts","./src/utils/configs/create-config.ts","./src/utils/configs/index.ts","./src/utils/configs/use-class-names.ts","./src/utils/configs/use-props.ts","./src/utils/cx/index.ts","./src/utils/factory/factory.ts","./src/utils/factory/index.ts","./src/utils/factory/types.ts","./src/vitest/index.ts","./src/vitest/setup.tsx","./src/vitest/utils.tsx"],"version":"5.9.3"}
1
+ {"root":["./src/index.ts","./src/components/index.ts","./src/components/accordion/accordion.context.ts","./src/components/accordion/accordion.styles.ts","./src/components/accordion/accordion.test.tsx","./src/components/accordion/accordion.tsx","./src/components/accordion/accordion.types.ts","./src/components/accordion/index.ts","./src/components/accordion/accordion-control/accordion-control.tsx","./src/components/accordion/accordion-control/index.ts","./src/components/accordion/accordion-item/accordion-item.tsx","./src/components/accordion/accordion-item/index.ts","./src/components/accordion/accordion-panel/accordion-panel.tsx","./src/components/accordion/accordion-panel/index.ts","./src/components/avatar/avatar.styles.ts","./src/components/avatar/avatar.tsx","./src/components/avatar/avatar.types.ts","./src/components/avatar/index.ts","./src/components/avatar/avatar-group/avatar-group.tsx","./src/components/avatar/avatar-group/index.ts","./src/components/badge/badge.styles.ts","./src/components/badge/badge.tsx","./src/components/badge/badge.types.ts","./src/components/badge/index.ts","./src/components/button/button.styles.ts","./src/components/button/button.test.tsx","./src/components/button/button.tsx","./src/components/button/button.types.ts","./src/components/button/index.ts","./src/components/checkbox/checkbox.context.ts","./src/components/checkbox/checkbox.styles.ts","./src/components/checkbox/checkbox.test.tsx","./src/components/checkbox/checkbox.tsx","./src/components/checkbox/checkbox.types.ts","./src/components/checkbox/index.ts","./src/components/checkbox/checkbox-group/checkbox-group.tsx","./src/components/checkbox/checkbox-group/index.ts","./src/components/color-swatch/color-swatch.styles.ts","./src/components/color-swatch/color-swatch.test.tsx","./src/components/color-swatch/color-swatch.tsx","./src/components/color-swatch/color-swatch.types.ts","./src/components/color-swatch/index.ts","./src/components/input/index.ts","./src/components/input/input.tsx","./src/components/input/input.types.ts","./src/components/input/input-description/index.ts","./src/components/input/input-description/input-description.tsx","./src/components/input/input-error/index.ts","./src/components/input/input-error/input-error.tsx","./src/components/input/input-field/index.ts","./src/components/input/input-field/input-field.styles.ts","./src/components/input/input-field/input-field.tsx","./src/components/input/input-label/index.ts","./src/components/input/input-label/input-label.tsx","./src/components/input/input-wrapper/index.ts","./src/components/input/input-wrapper/input-wrapper.tsx","./src/components/loader/index.ts","./src/components/loader/loader.tsx","./src/components/loader/loader.types.ts","./src/components/menu/index.ts","./src/components/menu/menu.context.ts","./src/components/menu/menu.test.tsx","./src/components/menu/menu.tsx","./src/components/menu/menu.types.ts","./src/components/menu/use-menu.ts","./src/components/menu/menu-dropdown/index.ts","./src/components/menu/menu-dropdown/menu-dropdown.tsx","./src/components/menu/menu-item/index.ts","./src/components/menu/menu-item/menu-item.tsx","./src/components/menu/menu-label/index.ts","./src/components/menu/menu-label/menu-label.tsx","./src/components/menu/menu-separator/index.ts","./src/components/menu/menu-separator/menu-separator.tsx","./src/components/menu/menu-sub/index.ts","./src/components/menu/menu-sub/menu-sub.tsx","./src/components/menu/menu-sub-dropdown/index.ts","./src/components/menu/menu-sub-dropdown/menu-sub-dropdown.tsx","./src/components/menu/menu-sub-trigger/index.ts","./src/components/menu/menu-sub-trigger/menu-sub-trigger.tsx","./src/components/menu/menu-trigger/index.ts","./src/components/menu/menu-trigger/menu-trigger.tsx","./src/components/modal/index.ts","./src/components/modal/modal.context.ts","./src/components/modal/modal.test.tsx","./src/components/modal/modal.tsx","./src/components/modal/modal.types.ts","./src/components/modal/use-modal.ts","./src/components/modal/modal-close/index.ts","./src/components/modal/modal-close/modal-close.tsx","./src/components/modal/modal-content/index.ts","./src/components/modal/modal-content/modal-content.tsx","./src/components/modal/modal-header/index.ts","./src/components/modal/modal-header/modal-header.tsx","./src/components/modal/modal-overlay/index.ts","./src/components/modal/modal-overlay/modal-overlay.tsx","./src/components/modal/modal-root/index.ts","./src/components/modal/modal-root/modal-root.tsx","./src/components/number-input/index.ts","./src/components/number-input/number-input.styles.ts","./src/components/number-input/number-input.test.tsx","./src/components/number-input/number-input.tsx","./src/components/number-input/number-input.types.ts","./src/components/pagination/index.ts","./src/components/pagination/pagination.styles.ts","./src/components/pagination/pagination.test.tsx","./src/components/pagination/pagination.tsx","./src/components/pagination/pagination.types.ts","./src/components/pagination/pagination.utils.ts","./src/components/popover/index.ts","./src/components/popover/popover.context.ts","./src/components/popover/popover.tsx","./src/components/popover/popover.types.ts","./src/components/popover/use-popover.ts","./src/components/popover/popover-dropdown/index.ts","./src/components/popover/popover-dropdown/popover-dropdown.tsx","./src/components/popover/popover-trigger/index.ts","./src/components/popover/popover-trigger/popover-trigger.tsx","./src/components/portal/index.ts","./src/components/portal/portal.test.tsx","./src/components/portal/portal.tsx","./src/components/portal/portal.types.ts","./src/components/progress/index.ts","./src/components/progress/progress.styles.ts","./src/components/progress/progress.test.tsx","./src/components/progress/progress.tsx","./src/components/progress/progress.types.ts","./src/components/progress-circle/index.ts","./src/components/progress-circle/progress-circle.styles.ts","./src/components/progress-circle/progress-circle.test.tsx","./src/components/progress-circle/progress-circle.tsx","./src/components/progress-circle/progress-circle.types.ts","./src/components/radio/index.ts","./src/components/radio/radio.context.ts","./src/components/radio/radio.styles.ts","./src/components/radio/radio.test.tsx","./src/components/radio/radio.tsx","./src/components/radio/radio.types.ts","./src/components/radio/radio-group/index.ts","./src/components/radio/radio-group/radio-group.tsx","./src/components/select/index.ts","./src/components/select/select.context.ts","./src/components/select/select.test.tsx","./src/components/select/select.tsx","./src/components/select/select.types.ts","./src/components/select/use-select.ts","./src/components/select/select-dropdown/index.ts","./src/components/select/select-dropdown/select-dropdown.tsx","./src/components/select/select-group/index.ts","./src/components/select/select-group/select-group.tsx","./src/components/select/select-item/index.ts","./src/components/select/select-item/select-item.tsx","./src/components/select/select-root/index.ts","./src/components/select/select-root/select-root.tsx","./src/components/select/select-trigger/index.ts","./src/components/select/select-trigger/select-trigger.tsx","./src/components/slider/index.ts","./src/components/slider/slider.styles.ts","./src/components/slider/slider.tsx","./src/components/slider/slider.types.ts","./src/components/switch/index.ts","./src/components/switch/switch.styles.ts","./src/components/switch/switch.tsx","./src/components/switch/switch.types.ts","./src/components/tabs/index.ts","./src/components/tabs/tabs.context.ts","./src/components/tabs/tabs.styles.ts","./src/components/tabs/tabs.test.tsx","./src/components/tabs/tabs.tsx","./src/components/tabs/tabs.types.ts","./src/components/tabs/tabs-list/index.ts","./src/components/tabs/tabs-list/tabs-list.tsx","./src/components/tabs/tabs-panel/index.ts","./src/components/tabs/tabs-panel/tabs-panel.tsx","./src/components/tabs/tabs-tab/index.ts","./src/components/tabs/tabs-tab/tabs-tab.tsx","./src/components/textarea/index.ts","./src/components/textarea/textarea.tsx","./src/components/textarea/textarea.types.ts","./src/components/textarea/textarea-field/index.ts","./src/components/textarea/textarea-field/textarea-field.styles.ts","./src/components/textarea/textarea-field/textarea-field.tsx","./src/components/timeline/index.ts","./src/components/timeline/timeline.context.ts","./src/components/timeline/timeline.styles.ts","./src/components/timeline/timeline.test.tsx","./src/components/timeline/timeline.tsx","./src/components/timeline/timeline.types.ts","./src/components/timeline/timeline-item/index.ts","./src/components/timeline/timeline-item/timeline-item.tsx","./src/components/tooltip/index.ts","./src/components/tooltip/tooltip.tsx","./src/components/tooltip/tooltip.types.ts","./src/components/tooltip/use-tooltip.ts","./src/components/transition/index.ts","./src/components/transition/transition.test.tsx","./src/components/transition/transition.tsx","./src/components/transition/transition.types.ts","./src/components/transition/transitions.ts","./src/icons/check.tsx","./src/icons/chevron.tsx","./src/icons/index.ts","./src/icons/minus.tsx","./src/icons/types.ts","./src/icons/user.tsx","./src/icons/x.tsx","./src/theme/index.ts","./src/theme/types.ts","./src/theme/themeprovider/themeprovider.tsx","./src/theme/themeprovider/context.ts","./src/theme/themeprovider/generatevariables.test.ts","./src/theme/themeprovider/generatevariables.ts","./src/theme/themeprovider/index.ts","./src/theme/themeprovider/types.ts","./src/theme/createtheme/createtheme.ts","./src/theme/createtheme/index.ts","./src/theme/createtheme/types.ts","./src/theme/defaults/colors.ts","./src/theme/defaults/settings.ts","./src/theme/utils/get-radius.ts","./src/theme/utils/get-shade.ts","./src/theme/utils/index.ts","./src/theme/utils/use-theme.ts","./src/utils/index.ts","./src/utils/configs/create-config.ts","./src/utils/configs/index.ts","./src/utils/configs/use-class-names.ts","./src/utils/configs/use-props.ts","./src/utils/cx/index.ts","./src/utils/factory/factory.ts","./src/utils/factory/index.ts","./src/utils/factory/types.ts","./src/vitest/index.ts","./src/vitest/setup.tsx","./src/vitest/utils.tsx"],"version":"5.9.3"}