@zentauri-ui/zentauri-components 1.7.6 → 1.7.8

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 (69) hide show
  1. package/README.md +9 -5
  2. package/cli/registry.json +2 -0
  3. package/dist/chunk-GRJFGIZC.mjs +417 -0
  4. package/dist/chunk-GRJFGIZC.mjs.map +1 -0
  5. package/dist/chunk-QHEHBC6M.js +421 -0
  6. package/dist/chunk-QHEHBC6M.js.map +1 -0
  7. package/dist/design-system/index.d.ts +2 -0
  8. package/dist/design-system/index.d.ts.map +1 -1
  9. package/dist/design-system/rating.d.ts +43 -0
  10. package/dist/design-system/rating.d.ts.map +1 -0
  11. package/dist/design-system/tree-view.d.ts +66 -0
  12. package/dist/design-system/tree-view.d.ts.map +1 -0
  13. package/dist/ui/rating/index.d.ts +4 -0
  14. package/dist/ui/rating/index.d.ts.map +1 -0
  15. package/dist/ui/rating/rating.d.ts +6 -0
  16. package/dist/ui/rating/rating.d.ts.map +1 -0
  17. package/dist/ui/rating/types.d.ts +25 -0
  18. package/dist/ui/rating/types.d.ts.map +1 -0
  19. package/dist/ui/rating/variants.d.ts +7 -0
  20. package/dist/ui/rating/variants.d.ts.map +1 -0
  21. package/dist/ui/rating.js +319 -0
  22. package/dist/ui/rating.js.map +1 -0
  23. package/dist/ui/rating.mjs +315 -0
  24. package/dist/ui/rating.mjs.map +1 -0
  25. package/dist/ui/tree-view/animated/animations.d.ts +6 -0
  26. package/dist/ui/tree-view/animated/animations.d.ts.map +1 -0
  27. package/dist/ui/tree-view/animated/index.d.ts +5 -0
  28. package/dist/ui/tree-view/animated/index.d.ts.map +1 -0
  29. package/dist/ui/tree-view/animated/tree-view-animated.d.ts +6 -0
  30. package/dist/ui/tree-view/animated/tree-view-animated.d.ts.map +1 -0
  31. package/dist/ui/tree-view/animated/types.d.ts +6 -0
  32. package/dist/ui/tree-view/animated/types.d.ts.map +1 -0
  33. package/dist/ui/tree-view/animated.js +53 -0
  34. package/dist/ui/tree-view/animated.js.map +1 -0
  35. package/dist/ui/tree-view/animated.mjs +50 -0
  36. package/dist/ui/tree-view/animated.mjs.map +1 -0
  37. package/dist/ui/tree-view/index.d.ts +5 -0
  38. package/dist/ui/tree-view/index.d.ts.map +1 -0
  39. package/dist/ui/tree-view/tree-view-base.d.ts +15 -0
  40. package/dist/ui/tree-view/tree-view-base.d.ts.map +1 -0
  41. package/dist/ui/tree-view/tree-view.d.ts +6 -0
  42. package/dist/ui/tree-view/tree-view.d.ts.map +1 -0
  43. package/dist/ui/tree-view/types.d.ts +61 -0
  44. package/dist/ui/tree-view/types.d.ts.map +1 -0
  45. package/dist/ui/tree-view/variants.d.ts +9 -0
  46. package/dist/ui/tree-view/variants.d.ts.map +1 -0
  47. package/dist/ui/tree-view.js +27 -0
  48. package/dist/ui/tree-view.js.map +1 -0
  49. package/dist/ui/tree-view.mjs +14 -0
  50. package/dist/ui/tree-view.mjs.map +1 -0
  51. package/package.json +1 -1
  52. package/src/design-system/index.ts +2 -0
  53. package/src/design-system/rating.ts +81 -0
  54. package/src/design-system/tree-view.ts +113 -0
  55. package/src/ui/rating/index.ts +10 -0
  56. package/src/ui/rating/rating.test.tsx +139 -0
  57. package/src/ui/rating/rating.tsx +305 -0
  58. package/src/ui/rating/types.ts +33 -0
  59. package/src/ui/rating/variants.ts +26 -0
  60. package/src/ui/tree-view/animated/animations.ts +13 -0
  61. package/src/ui/tree-view/animated/index.ts +6 -0
  62. package/src/ui/tree-view/animated/tree-view-animated.tsx +52 -0
  63. package/src/ui/tree-view/animated/types.ts +6 -0
  64. package/src/ui/tree-view/index.ts +13 -0
  65. package/src/ui/tree-view/tree-view-base.tsx +496 -0
  66. package/src/ui/tree-view/tree-view.test.tsx +136 -0
  67. package/src/ui/tree-view/tree-view.tsx +9 -0
  68. package/src/ui/tree-view/types.ts +68 -0
  69. package/src/ui/tree-view/variants.ts +32 -0
@@ -0,0 +1,61 @@
1
+ import type { VariantProps } from "class-variance-authority";
2
+ import type { ComponentType, ReactNode } from "react";
3
+ import type { treeViewVariants } from "./variants";
4
+ export type TreeViewVariantProps = VariantProps<typeof treeViewVariants>;
5
+ export type TreeNode = {
6
+ /** Stable, unique identifier used for expansion and selection state. */
7
+ id: string;
8
+ label: ReactNode;
9
+ /** Optional leading icon rendered before the label. */
10
+ icon?: ReactNode;
11
+ children?: TreeNode[];
12
+ disabled?: boolean;
13
+ };
14
+ export type TreeViewRenderArgs = {
15
+ node: TreeNode;
16
+ depth: number;
17
+ isExpanded: boolean;
18
+ isSelected: boolean;
19
+ };
20
+ export type TreeViewBaseProps = TreeViewVariantProps & {
21
+ data: TreeNode[];
22
+ /** Uncontrolled set of expanded node ids. */
23
+ defaultExpanded?: string[];
24
+ /** Controlled set of expanded node ids. */
25
+ expanded?: string[];
26
+ onExpandedChange?: (ids: string[]) => void;
27
+ /** Uncontrolled selected node id. */
28
+ defaultSelected?: string;
29
+ /** Controlled selected node id. */
30
+ selected?: string;
31
+ onSelect?: (node: TreeNode) => void;
32
+ /** Replace the default label rendering for each node. */
33
+ renderNode?: (args: TreeViewRenderArgs) => ReactNode;
34
+ /** Draw vertical indentation guide lines for nested levels. */
35
+ showGuides?: boolean;
36
+ className?: string;
37
+ "aria-label"?: string;
38
+ "aria-labelledby"?: string;
39
+ };
40
+ export type TreeViewProps = TreeViewBaseProps;
41
+ export type TreeGroupProps = {
42
+ open: boolean;
43
+ level: number;
44
+ children: ReactNode;
45
+ };
46
+ export type TreeViewCtx = {
47
+ appearance: NonNullable<TreeViewBaseProps["appearance"]>;
48
+ size: NonNullable<TreeViewBaseProps["size"]>;
49
+ showGuides: boolean;
50
+ GroupComponent: ComponentType<TreeGroupProps>;
51
+ isExpanded: (id: string) => boolean;
52
+ toggleExpanded: (id: string) => void;
53
+ setExpanded: (id: string, open: boolean) => void;
54
+ selectedId: string | undefined;
55
+ activeId: string | undefined;
56
+ selectNode: (node: TreeNode) => void;
57
+ registerItem: (id: string, el: HTMLDivElement | null) => void;
58
+ onItemKeyDown: (event: React.KeyboardEvent<HTMLDivElement>) => void;
59
+ renderNode?: (args: TreeViewRenderArgs) => ReactNode;
60
+ };
61
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/ui/tree-view/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAC;AAC7D,OAAO,KAAK,EAAE,aAAa,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAEtD,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAC;AAEnD,MAAM,MAAM,oBAAoB,GAAG,YAAY,CAAC,OAAO,gBAAgB,CAAC,CAAC;AAEzE,MAAM,MAAM,QAAQ,GAAG;IACrB,wEAAwE;IACxE,EAAE,EAAE,MAAM,CAAC;IACX,KAAK,EAAE,SAAS,CAAC;IACjB,uDAAuD;IACvD,IAAI,CAAC,EAAE,SAAS,CAAC;IACjB,QAAQ,CAAC,EAAE,QAAQ,EAAE,CAAC;IACtB,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB,CAAC;AAEF,MAAM,MAAM,kBAAkB,GAAG;IAC/B,IAAI,EAAE,QAAQ,CAAC;IACf,KAAK,EAAE,MAAM,CAAC;IACd,UAAU,EAAE,OAAO,CAAC;IACpB,UAAU,EAAE,OAAO,CAAC;CACrB,CAAC;AAEF,MAAM,MAAM,iBAAiB,GAAG,oBAAoB,GAAG;IACrD,IAAI,EAAE,QAAQ,EAAE,CAAC;IACjB,6CAA6C;IAC7C,eAAe,CAAC,EAAE,MAAM,EAAE,CAAC;IAC3B,2CAA2C;IAC3C,QAAQ,CAAC,EAAE,MAAM,EAAE,CAAC;IACpB,gBAAgB,CAAC,EAAE,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,IAAI,CAAC;IAC3C,qCAAqC;IACrC,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,mCAAmC;IACnC,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,QAAQ,CAAC,EAAE,CAAC,IAAI,EAAE,QAAQ,KAAK,IAAI,CAAC;IACpC,yDAAyD;IACzD,UAAU,CAAC,EAAE,CAAC,IAAI,EAAE,kBAAkB,KAAK,SAAS,CAAC;IACrD,+DAA+D;IAC/D,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,iBAAiB,CAAC,EAAE,MAAM,CAAC;CAC5B,CAAC;AAEF,MAAM,MAAM,aAAa,GAAG,iBAAiB,CAAC;AAE9C,MAAM,MAAM,cAAc,GAAG;IAC3B,IAAI,EAAE,OAAO,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,EAAE,SAAS,CAAC;CACrB,CAAC;AAEF,MAAM,MAAM,WAAW,GAAG;IACxB,UAAU,EAAE,WAAW,CAAC,iBAAiB,CAAC,YAAY,CAAC,CAAC,CAAC;IACzD,IAAI,EAAE,WAAW,CAAC,iBAAiB,CAAC,MAAM,CAAC,CAAC,CAAC;IAC7C,UAAU,EAAE,OAAO,CAAC;IACpB,cAAc,EAAE,aAAa,CAAC,cAAc,CAAC,CAAC;IAC9C,UAAU,EAAE,CAAC,EAAE,EAAE,MAAM,KAAK,OAAO,CAAC;IACpC,cAAc,EAAE,CAAC,EAAE,EAAE,MAAM,KAAK,IAAI,CAAC;IACrC,WAAW,EAAE,CAAC,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,OAAO,KAAK,IAAI,CAAC;IACjD,UAAU,EAAE,MAAM,GAAG,SAAS,CAAC;IAC/B,QAAQ,EAAE,MAAM,GAAG,SAAS,CAAC;IAC7B,UAAU,EAAE,CAAC,IAAI,EAAE,QAAQ,KAAK,IAAI,CAAC;IACrC,YAAY,EAAE,CAAC,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,cAAc,GAAG,IAAI,KAAK,IAAI,CAAC;IAC9D,aAAa,EAAE,CAAC,KAAK,EAAE,KAAK,CAAC,aAAa,CAAC,cAAc,CAAC,KAAK,IAAI,CAAC;IACpE,UAAU,CAAC,EAAE,CAAC,IAAI,EAAE,kBAAkB,KAAK,SAAS,CAAC;CACtD,CAAC"}
@@ -0,0 +1,9 @@
1
+ export declare const treeViewVariants: (props?: ({
2
+ appearance?: "default" | "outline" | "sky" | "emerald" | "rose" | "indigo" | "orange" | "pink" | "purple" | "teal" | "yellow" | "gradient-blue" | "gradient-green" | "gradient-red" | "gradient-yellow" | "gradient-purple" | "gradient-teal" | "gradient-indigo" | "gradient-pink" | "gradient-orange" | "ghost" | "card" | "separated" | null | undefined;
3
+ size?: "md" | "sm" | "lg" | null | undefined;
4
+ } & import("class-variance-authority/types").ClassProp) | undefined) => string;
5
+ export declare const treeViewItemVariants: (props?: ({
6
+ appearance?: "default" | "outline" | "sky" | "emerald" | "rose" | "indigo" | "orange" | "pink" | "purple" | "teal" | "yellow" | "gradient-blue" | "gradient-green" | "gradient-red" | "gradient-yellow" | "gradient-purple" | "gradient-teal" | "gradient-indigo" | "gradient-pink" | "gradient-orange" | "ghost" | "card" | "separated" | null | undefined;
7
+ size?: "md" | "sm" | "lg" | null | undefined;
8
+ } & import("class-variance-authority/types").ClassProp) | undefined) => string;
9
+ //# sourceMappingURL=variants.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"variants.d.ts","sourceRoot":"","sources":["../../../src/ui/tree-view/variants.ts"],"names":[],"mappings":"AAWA,eAAO,MAAM,gBAAgB;;;8EAS3B,CAAC;AAEH,eAAO,MAAM,oBAAoB;;;8EAS/B,CAAC"}
@@ -0,0 +1,27 @@
1
+ "use client";
2
+ 'use strict';
3
+
4
+ var chunkQHEHBC6M_js = require('../chunk-QHEHBC6M.js');
5
+ require('../chunk-ZS5756ZC.js');
6
+ var jsxRuntime = require('react/jsx-runtime');
7
+
8
+ function TreeView(props) {
9
+ return /* @__PURE__ */ jsxRuntime.jsx(chunkQHEHBC6M_js.TreeViewBase, { ...props });
10
+ }
11
+ TreeView.displayName = "TreeView";
12
+
13
+ Object.defineProperty(exports, "TreeViewBase", {
14
+ enumerable: true,
15
+ get: function () { return chunkQHEHBC6M_js.TreeViewBase; }
16
+ });
17
+ Object.defineProperty(exports, "treeViewItemVariants", {
18
+ enumerable: true,
19
+ get: function () { return chunkQHEHBC6M_js.treeViewItemVariants; }
20
+ });
21
+ Object.defineProperty(exports, "treeViewVariants", {
22
+ enumerable: true,
23
+ get: function () { return chunkQHEHBC6M_js.treeViewVariants; }
24
+ });
25
+ exports.TreeView = TreeView;
26
+ //# sourceMappingURL=tree-view.js.map
27
+ //# sourceMappingURL=tree-view.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/ui/tree-view/tree-view.tsx"],"names":["jsx","TreeViewBase"],"mappings":";;;;;;AAIO,SAAS,SAAS,KAAA,EAAsB;AAC7C,EAAA,uBAAOA,cAAA,CAACC,6BAAA,EAAA,EAAc,GAAG,KAAA,EAAO,CAAA;AAClC;AAEA,QAAA,CAAS,WAAA,GAAc,UAAA","file":"tree-view.js","sourcesContent":["// tree-view.tsx — default static entry (no framer-motion on expand/collapse)\nimport { TreeViewBase } from \"./tree-view-base\";\nimport type { TreeViewProps } from \"./types\";\n\nexport function TreeView(props: TreeViewProps) {\n return <TreeViewBase {...props} />;\n}\n\nTreeView.displayName = \"TreeView\";\n"]}
@@ -0,0 +1,14 @@
1
+ "use client";
2
+ import { TreeViewBase } from '../chunk-GRJFGIZC.mjs';
3
+ export { TreeViewBase, treeViewItemVariants, treeViewVariants } from '../chunk-GRJFGIZC.mjs';
4
+ import '../chunk-4D54YOL6.mjs';
5
+ import { jsx } from 'react/jsx-runtime';
6
+
7
+ function TreeView(props) {
8
+ return /* @__PURE__ */ jsx(TreeViewBase, { ...props });
9
+ }
10
+ TreeView.displayName = "TreeView";
11
+
12
+ export { TreeView };
13
+ //# sourceMappingURL=tree-view.mjs.map
14
+ //# sourceMappingURL=tree-view.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/ui/tree-view/tree-view.tsx"],"names":[],"mappings":";;;;;AAIO,SAAS,SAAS,KAAA,EAAsB;AAC7C,EAAA,uBAAO,GAAA,CAAC,YAAA,EAAA,EAAc,GAAG,KAAA,EAAO,CAAA;AAClC;AAEA,QAAA,CAAS,WAAA,GAAc,UAAA","file":"tree-view.mjs","sourcesContent":["// tree-view.tsx — default static entry (no framer-motion on expand/collapse)\nimport { TreeViewBase } from \"./tree-view-base\";\nimport type { TreeViewProps } from \"./types\";\n\nexport function TreeView(props: TreeViewProps) {\n return <TreeViewBase {...props} />;\n}\n\nTreeView.displayName = \"TreeView\";\n"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@zentauri-ui/zentauri-components",
3
- "version": "1.7.6",
3
+ "version": "1.7.8",
4
4
  "description": "React + Tailwind UI kit with charts, ESM/CJS builds, per-entry exports, and a zentauri-components / zentauri-ui CLI to vendor UI or hook source into your app",
5
5
  "license": "MIT",
6
6
  "files": [
@@ -20,6 +20,7 @@ export * from "./otp-input";
20
20
  export * from "./pagination";
21
21
  export * from "./popover";
22
22
  export * from "./progress";
23
+ export * from "./rating";
23
24
  export * from "./radio-group";
24
25
  export * from "./scroll-area";
25
26
  export * from "./select";
@@ -34,4 +35,5 @@ export * from "./toast";
34
35
  export * from "./tokens";
35
36
  export * from "./toggle";
36
37
  export * from "./tooltip";
38
+ export * from "./tree-view";
37
39
  export * from "./typography";
@@ -0,0 +1,81 @@
1
+ export const zuiRatingRootBase =
2
+ "grid w-fit gap-2 text-[color:var(--zui-rating-label-fg,oklch(20.8%_0.042_265.755))] dark:text-[color:var(--zui-rating-label-fg-dark,oklch(98.4%_0.003_247.858))] data-[disabled=true]:cursor-not-allowed data-[disabled=true]:opacity-50";
3
+
4
+ export const zuiRatingLabelBase =
5
+ "text-sm font-medium leading-6 text-[color:var(--zui-rating-label-fg,oklch(20.8%_0.042_265.755))] dark:text-[color:var(--zui-rating-label-fg-dark,oklch(98.4%_0.003_247.858))]";
6
+
7
+ export const zuiRatingHintBase =
8
+ "max-w-sm text-xs leading-5 text-[color:var(--zui-rating-hint-fg,oklch(55.4%_0.046_257.417))] dark:text-[color:var(--zui-rating-hint-fg-dark,oklch(70.4%_0.04_256.788))]";
9
+
10
+ export const zuiRatingGroupBase =
11
+ "flex w-fit flex-wrap items-center gap-[var(--zui-rating-gap,0.25rem)]";
12
+
13
+ export const zuiRatingItemBase =
14
+ "relative inline-grid shrink-0 place-items-center text-[color:var(--zui-rating-empty,oklch(86.9%_0.022_252.894))] transition-transform duration-200 data-[interactive=true]:hover:-translate-y-0.5 dark:text-[color:var(--zui-rating-empty-dark,oklch(37.2%_0.044_257.287))]";
15
+
16
+ export const zuiRatingIconBase =
17
+ "pointer-events-none col-start-1 row-start-1 transition-[clip-path,color,transform] duration-200 ease-out";
18
+
19
+ export const zuiRatingControlBase =
20
+ "absolute inset-y-0 z-[1] cursor-pointer rounded-md bg-transparent outline-none transition-shadow focus-visible:ring-2 focus-visible:ring-[var(--zui-rating-ring-focus,oklch(54.6%_0.245_262.881_/_0.32))] focus-visible:ring-offset-2 focus-visible:ring-offset-[var(--zui-rating-ring-offset-focus,#ffffff)] disabled:cursor-not-allowed dark:focus-visible:ring-offset-[var(--zui-rating-ring-offset-focus-dark,oklch(12.9%_0.042_264.695))]";
21
+
22
+ export const zuiRatingErrorBase =
23
+ "text-sm leading-6 text-[color:var(--zui-rating-error-fg,oklch(58.6%_0.253_17.585))] dark:text-[color:var(--zui-rating-error-fg-dark,oklch(71.2%_0.194_13.428))]";
24
+
25
+ export const zuiRatingSizes = {
26
+ sm: "size-5 text-lg",
27
+ md: "size-7 text-2xl",
28
+ lg: "size-9 text-3xl",
29
+ } as const;
30
+
31
+ export const zuiRatingAppearances = {
32
+ default:
33
+ "text-[color:var(--zui-rating-default-active,oklch(20.8%_0.042_265.755))] dark:text-[color:var(--zui-rating-default-active-dark,oklch(98.4%_0.003_247.858))]",
34
+ secondary:
35
+ "text-[color:var(--zui-rating-secondary-active,oklch(44.6%_0.043_257.281))] dark:text-[color:var(--zui-rating-secondary-active-dark,oklch(86.9%_0.022_252.894))]",
36
+ destructive:
37
+ "text-[color:var(--zui-rating-destructive-active,oklch(58.6%_0.253_17.585))] dark:text-[color:var(--zui-rating-destructive-active-dark,oklch(71.2%_0.194_13.428))]",
38
+ outline:
39
+ "text-[color:var(--zui-rating-outline-active,oklch(44.6%_0.043_257.281))] dark:text-[color:var(--zui-rating-outline-active-dark,oklch(86.9%_0.022_252.894))]",
40
+ ghost:
41
+ "text-[color:var(--zui-rating-ghost-active,oklch(37.2%_0.044_257.287))] dark:text-[color:var(--zui-rating-ghost-active-dark,oklch(92.9%_0.013_255.508))]",
42
+ glass:
43
+ "text-[color:var(--zui-rating-glass-active,oklch(54.6%_0.245_262.881))] drop-shadow-[0_2px_12px_rgba(59,130,246,0.25)] dark:text-[color:var(--zui-rating-glass-active-dark,oklch(78.9%_0.154_211.53))]",
44
+ emerald:
45
+ "text-[color:var(--zui-rating-emerald-active,oklch(59.6%_0.145_163.225))] dark:text-[color:var(--zui-rating-emerald-active-dark,oklch(77.7%_0.152_181.912))]",
46
+ indigo:
47
+ "text-[color:var(--zui-rating-indigo-active,oklch(51.1%_0.262_276.966))] dark:text-[color:var(--zui-rating-indigo-active-dark,oklch(67.3%_0.182_276.935))]",
48
+ purple:
49
+ "text-[color:var(--zui-rating-purple-active,oklch(55.8%_0.288_302.321))] dark:text-[color:var(--zui-rating-purple-active-dark,oklch(71.4%_0.203_305.504))]",
50
+ pink: "text-[color:var(--zui-rating-pink-active,oklch(59.2%_0.249_0.584))] dark:text-[color:var(--zui-rating-pink-active-dark,oklch(71.8%_0.202_349.761))]",
51
+ rose: "text-[color:var(--zui-rating-rose-active,oklch(58.6%_0.253_17.585))] dark:text-[color:var(--zui-rating-rose-active-dark,oklch(71.2%_0.194_13.428))]",
52
+ sky: "text-[color:var(--zui-rating-sky-active,oklch(62.3%_0.214_259.815))] dark:text-[color:var(--zui-rating-sky-active-dark,oklch(74.6%_0.16_232.661))]",
53
+ teal: "text-[color:var(--zui-rating-teal-active,oklch(60%_0.118_184.704))] dark:text-[color:var(--zui-rating-teal-active-dark,oklch(77.7%_0.152_181.912))]",
54
+ yellow:
55
+ "text-[color:var(--zui-rating-yellow-active,oklch(79.5%_0.184_86.047))] dark:text-[color:var(--zui-rating-yellow-active-dark,oklch(85.2%_0.199_91.936))]",
56
+ orange:
57
+ "text-[color:var(--zui-rating-orange-active,oklch(64.6%_0.222_41.116))] dark:text-[color:var(--zui-rating-orange-active-dark,oklch(75%_0.183_55.934))]",
58
+ gray: "text-[color:var(--zui-rating-gray-active,oklch(55.1%_0.027_264.364))] dark:text-[color:var(--zui-rating-gray-active-dark,oklch(70.7%_0.022_261.325))]",
59
+ amber:
60
+ "text-[color:var(--zui-rating-amber-active,oklch(76.9%_0.188_70.08))] dark:text-[color:var(--zui-rating-amber-active-dark,oklch(82.8%_0.189_84.429))]",
61
+ violet:
62
+ "text-[color:var(--zui-rating-violet-active,oklch(54.1%_0.281_293.009))] dark:text-[color:var(--zui-rating-violet-active-dark,oklch(70.2%_0.183_293.541))]",
63
+ "gradient-blue":
64
+ "text-[color:var(--zui-rating-gradient-blue-active,oklch(54.6%_0.245_262.881))] drop-shadow-[0_2px_12px_rgba(37,99,235,0.28)] dark:text-[color:var(--zui-rating-gradient-blue-active-dark,oklch(70.7%_0.165_254.624))]",
65
+ "gradient-green":
66
+ "text-[color:var(--zui-rating-gradient-green-active,oklch(62.7%_0.194_149.214))] drop-shadow-[0_2px_12px_rgba(22,163,74,0.24)] dark:text-[color:var(--zui-rating-gradient-green-active-dark,oklch(79.2%_0.209_151.711))]",
67
+ "gradient-red":
68
+ "text-[color:var(--zui-rating-gradient-red-active,oklch(57.7%_0.245_27.325))] drop-shadow-[0_2px_12px_rgba(220,38,38,0.24)] dark:text-[color:var(--zui-rating-gradient-red-active-dark,oklch(70.4%_0.191_22.216))]",
69
+ "gradient-yellow":
70
+ "text-[color:var(--zui-rating-gradient-yellow-active,oklch(79.5%_0.184_86.047))] drop-shadow-[0_2px_12px_rgba(234,179,8,0.24)] dark:text-[color:var(--zui-rating-gradient-yellow-active-dark,oklch(85.2%_0.199_91.936))]",
71
+ "gradient-purple":
72
+ "text-[color:var(--zui-rating-gradient-purple-active,oklch(62.7%_0.265_303.9))] drop-shadow-[0_2px_12px_rgba(147,51,234,0.24)] dark:text-[color:var(--zui-rating-gradient-purple-active-dark,oklch(71.4%_0.203_305.504))]",
73
+ "gradient-teal":
74
+ "text-[color:var(--zui-rating-gradient-teal-active,oklch(60%_0.118_184.704))] drop-shadow-[0_2px_12px_rgba(13,148,136,0.24)] dark:text-[color:var(--zui-rating-gradient-teal-active-dark,oklch(77.7%_0.152_181.912))]",
75
+ "gradient-indigo":
76
+ "text-[color:var(--zui-rating-gradient-indigo-active,oklch(51.1%_0.262_276.966))] drop-shadow-[0_2px_12px_rgba(79,70,229,0.24)] dark:text-[color:var(--zui-rating-gradient-indigo-active-dark,oklch(67.3%_0.182_276.935))]",
77
+ "gradient-pink":
78
+ "text-[color:var(--zui-rating-gradient-pink-active,oklch(59.2%_0.249_0.584))] drop-shadow-[0_2px_12px_rgba(219,39,119,0.24)] dark:text-[color:var(--zui-rating-gradient-pink-active-dark,oklch(71.8%_0.202_349.761))]",
79
+ "gradient-orange":
80
+ "text-[color:var(--zui-rating-gradient-orange-active,oklch(64.6%_0.222_41.116))] drop-shadow-[0_2px_12px_rgba(234,88,12,0.24)] dark:text-[color:var(--zui-rating-gradient-orange-active-dark,oklch(75%_0.183_55.934))]",
81
+ } as const;
@@ -0,0 +1,113 @@
1
+ export const zuiTreeViewBase =
2
+ "w-full text-[color:var(--zui-tree-view-fg,oklch(20.8%_0.042_265.755))] dark:text-[color:var(--zui-tree-view-fg-dark,oklch(92.9%_0.013_255.508))]";
3
+
4
+ export const zuiTreeViewAppearances = {
5
+ default:
6
+ "rounded-xl border border-[color:var(--zui-tree-view-default-border,#0000001a)] dark:border-[color:var(--zui-tree-view-default-border-dark,#ffffff1a)] p-2",
7
+ outline:
8
+ "rounded-xl border border-[color:var(--zui-tree-view-outline-border,#00000026)] dark:border-[color:var(--zui-tree-view-outline-border-dark,#ffffff26)] p-2",
9
+ ghost: "p-1",
10
+ card: "rounded-xl border border-[color:var(--zui-tree-view-card-border,#0000001a)] dark:border-[color:var(--zui-tree-view-card-border-dark,#ffffff1a)] bg-[var(--zui-tree-view-card-bg,#0000000d)] dark:bg-[var(--zui-tree-view-card-bg-dark,#00000099)] p-3",
11
+ separated:
12
+ "rounded-xl border border-[color:var(--zui-tree-view-separated-border,#0000001a)] dark:border-[color:var(--zui-tree-view-separated-border-dark,#ffffff1a)] bg-[var(--zui-tree-view-separated-bg,oklch(98.4%_0.003_247.858_/_0.4))] dark:bg-[var(--zui-tree-view-separated-bg-dark,oklch(12.9%_0.042_264.695_/_0.4))] p-3",
13
+ sky: "rounded-xl border border-[color:var(--zui-tree-view-sky-border,oklch(44.3%_0.11_240.79))] dark:border-[color:var(--zui-tree-view-sky-border-dark,oklch(58.8%_0.158_241.966))] p-2",
14
+ rose: "rounded-xl border border-[color:var(--zui-tree-view-rose-border,oklch(45.5%_0.188_13.697))] dark:border-[color:var(--zui-tree-view-rose-border-dark,oklch(58.6%_0.253_17.585))] p-2",
15
+ purple:
16
+ "rounded-xl border border-[color:var(--zui-tree-view-purple-border,oklch(43.8%_0.218_303.724))] dark:border-[color:var(--zui-tree-view-purple-border-dark,oklch(55.8%_0.288_302.321))] p-2",
17
+ pink: "rounded-xl border border-[color:var(--zui-tree-view-pink-border,oklch(45.9%_0.187_3.815))] dark:border-[color:var(--zui-tree-view-pink-border-dark,oklch(59.2%_0.249_0.584))] p-2",
18
+ orange:
19
+ "rounded-xl border border-[color:var(--zui-tree-view-orange-border,oklch(47%_0.157_37.304))] dark:border-[color:var(--zui-tree-view-orange-border-dark,oklch(64.6%_0.222_41.116))] p-2",
20
+ yellow:
21
+ "rounded-xl border border-[color:var(--zui-tree-view-yellow-border,oklch(47.6%_0.114_61.907))] dark:border-[color:var(--zui-tree-view-yellow-border-dark,oklch(68.1%_0.162_75.834))] p-2",
22
+ teal: "rounded-xl border border-[color:var(--zui-tree-view-teal-border,oklch(43.7%_0.078_188.216))] dark:border-[color:var(--zui-tree-view-teal-border-dark,oklch(60%_0.118_184.704))] p-2",
23
+ indigo:
24
+ "rounded-xl border border-[color:var(--zui-tree-view-indigo-border,oklch(39.8%_0.195_277.366))] dark:border-[color:var(--zui-tree-view-indigo-border-dark,oklch(51.1%_0.262_276.966))] p-2",
25
+ emerald:
26
+ "rounded-xl border border-[color:var(--zui-tree-view-emerald-border,oklch(43.2%_0.095_166.913))] dark:border-[color:var(--zui-tree-view-emerald-border-dark,oklch(59.6%_0.145_163.225))] p-2",
27
+ "gradient-blue":
28
+ "rounded-xl border border-[color:var(--zui-tree-view-gradient-blue-border,oklch(42.4%_0.199_265.638))] dark:border-[color:var(--zui-tree-view-gradient-blue-border-dark,oklch(54.6%_0.245_262.881))] p-2",
29
+ "gradient-green":
30
+ "rounded-xl border border-[color:var(--zui-tree-view-gradient-green-border,oklch(44.8%_0.119_151.328))] dark:border-[color:var(--zui-tree-view-gradient-green-border-dark,oklch(62.7%_0.194_149.214))] p-2",
31
+ "gradient-red":
32
+ "rounded-xl border border-[color:var(--zui-tree-view-gradient-red-border,oklch(44.4%_0.177_26.899))] dark:border-[color:var(--zui-tree-view-gradient-red-border-dark,oklch(57.7%_0.245_27.325))] p-2",
33
+ "gradient-yellow":
34
+ "rounded-xl border border-[color:var(--zui-tree-view-gradient-yellow-border,oklch(47.6%_0.114_61.907))] dark:border-[color:var(--zui-tree-view-gradient-yellow-border-dark,oklch(68.1%_0.162_75.834))] p-2",
35
+ "gradient-purple":
36
+ "rounded-xl border border-[color:var(--zui-tree-view-gradient-purple-border,oklch(43.8%_0.218_303.724))] dark:border-[color:var(--zui-tree-view-gradient-purple-border-dark,oklch(55.8%_0.288_302.321))] p-2",
37
+ "gradient-teal":
38
+ "rounded-xl border border-[color:var(--zui-tree-view-gradient-teal-border,oklch(43.7%_0.078_188.216))] dark:border-[color:var(--zui-tree-view-gradient-teal-border-dark,oklch(60%_0.118_184.704))] p-2",
39
+ "gradient-indigo":
40
+ "rounded-xl border border-[color:var(--zui-tree-view-gradient-indigo-border,oklch(39.8%_0.195_277.366))] dark:border-[color:var(--zui-tree-view-gradient-indigo-border-dark,oklch(51.1%_0.262_276.966))] p-2",
41
+ "gradient-pink":
42
+ "rounded-xl border border-[color:var(--zui-tree-view-gradient-pink-border,oklch(45.9%_0.187_3.815))] dark:border-[color:var(--zui-tree-view-gradient-pink-border-dark,oklch(59.2%_0.249_0.584))] p-2",
43
+ "gradient-orange":
44
+ "rounded-xl border border-[color:var(--zui-tree-view-gradient-orange-border,oklch(47%_0.157_37.304))] dark:border-[color:var(--zui-tree-view-gradient-orange-border-dark,oklch(64.6%_0.222_41.116))] p-2",
45
+ } as const;
46
+
47
+ export const zuiTreeViewSizes = {
48
+ sm: "text-xs",
49
+ md: "text-sm",
50
+ lg: "text-base",
51
+ } as const;
52
+
53
+ export const zuiTreeViewItemBase =
54
+ "relative flex w-full items-center gap-2 rounded-lg pr-2 text-left font-medium outline-none transition select-none cursor-pointer hover:bg-[var(--zui-tree-view-item-hover,#0000000d)] dark:hover:bg-[var(--zui-tree-view-item-hover-dark,#ffffff0d)] focus-visible:ring-2 focus-visible:ring-[var(--zui-tree-view-ring-focus,#0000004d)] dark:focus-visible:ring-[var(--zui-tree-view-ring-focus-dark,#ffffff4d)] data-[disabled=true]:cursor-not-allowed data-[disabled=true]:opacity-50";
55
+
56
+ export const zuiTreeViewItemSizes = {
57
+ sm: "py-1 text-xs",
58
+ md: "py-1.5 text-sm",
59
+ lg: "py-2 text-base",
60
+ } as const;
61
+
62
+ export const zuiTreeViewItemAppearances = {
63
+ default:
64
+ "data-[selected=true]:bg-[var(--zui-tree-view-selected,#0000000f)] dark:data-[selected=true]:bg-[var(--zui-tree-view-selected-dark,#ffffff14)] data-[selected=true]:text-[color:var(--zui-tree-view-selected-fg,oklch(20.8%_0.042_265.755))] dark:data-[selected=true]:text-[color:var(--zui-tree-view-selected-fg-dark,#ffffff)]",
65
+ outline:
66
+ "data-[selected=true]:bg-[var(--zui-tree-view-selected,#0000000f)] dark:data-[selected=true]:bg-[var(--zui-tree-view-selected-dark,#ffffff14)] data-[selected=true]:text-[color:var(--zui-tree-view-selected-fg,oklch(20.8%_0.042_265.755))] dark:data-[selected=true]:text-[color:var(--zui-tree-view-selected-fg-dark,#ffffff)]",
67
+ ghost:
68
+ "data-[selected=true]:bg-[var(--zui-tree-view-selected,#0000000f)] dark:data-[selected=true]:bg-[var(--zui-tree-view-selected-dark,#ffffff14)] data-[selected=true]:text-[color:var(--zui-tree-view-selected-fg,oklch(20.8%_0.042_265.755))] dark:data-[selected=true]:text-[color:var(--zui-tree-view-selected-fg-dark,#ffffff)]",
69
+ card: "data-[selected=true]:bg-[var(--zui-tree-view-selected,#00000014)] dark:data-[selected=true]:bg-[var(--zui-tree-view-selected-dark,#ffffff1f)] data-[selected=true]:text-[color:var(--zui-tree-view-selected-fg,oklch(20.8%_0.042_265.755))] dark:data-[selected=true]:text-[color:var(--zui-tree-view-selected-fg-dark,#ffffff)]",
70
+ separated:
71
+ "data-[selected=true]:bg-[var(--zui-tree-view-selected,#00000014)] dark:data-[selected=true]:bg-[var(--zui-tree-view-selected-dark,#ffffff1f)] data-[selected=true]:text-[color:var(--zui-tree-view-selected-fg,oklch(20.8%_0.042_265.755))] dark:data-[selected=true]:text-[color:var(--zui-tree-view-selected-fg-dark,#ffffff)]",
72
+ sky: "data-[selected=true]:bg-[var(--zui-tree-view-sky-selected,oklch(95.1%_0.026_236.824))] dark:data-[selected=true]:bg-[var(--zui-tree-view-sky-selected-dark,oklch(58.8%_0.158_241.966_/_0.16))] data-[selected=true]:text-[color:var(--zui-tree-view-sky-selected-fg,oklch(44.3%_0.11_240.79))] dark:data-[selected=true]:text-[color:var(--zui-tree-view-sky-selected-fg-dark,oklch(82.8%_0.111_230.318))]",
73
+ rose: "data-[selected=true]:bg-[var(--zui-tree-view-rose-selected,oklch(94.1%_0.03_12.58))] dark:data-[selected=true]:bg-[var(--zui-tree-view-rose-selected-dark,oklch(58.6%_0.253_17.585_/_0.16))] data-[selected=true]:text-[color:var(--zui-tree-view-rose-selected-fg,oklch(45.5%_0.188_13.697))] dark:data-[selected=true]:text-[color:var(--zui-tree-view-rose-selected-fg-dark,oklch(81%_0.117_11.638))]",
74
+ purple:
75
+ "data-[selected=true]:bg-[var(--zui-tree-view-purple-selected,oklch(94.6%_0.033_307.174))] dark:data-[selected=true]:bg-[var(--zui-tree-view-purple-selected-dark,oklch(55.8%_0.288_302.321_/_0.16))] data-[selected=true]:text-[color:var(--zui-tree-view-purple-selected-fg,oklch(43.8%_0.218_303.724))] dark:data-[selected=true]:text-[color:var(--zui-tree-view-purple-selected-fg-dark,oklch(82.7%_0.119_306.383))]",
76
+ pink: "data-[selected=true]:bg-[var(--zui-tree-view-pink-selected,oklch(94.8%_0.028_342.258))] dark:data-[selected=true]:bg-[var(--zui-tree-view-pink-selected-dark,oklch(59.2%_0.249_0.584_/_0.16))] data-[selected=true]:text-[color:var(--zui-tree-view-pink-selected-fg,oklch(45.9%_0.187_3.815))] dark:data-[selected=true]:text-[color:var(--zui-tree-view-pink-selected-fg-dark,oklch(82.3%_0.12_346.018))]",
77
+ orange:
78
+ "data-[selected=true]:bg-[var(--zui-tree-view-orange-selected,oklch(95.4%_0.038_75.164))] dark:data-[selected=true]:bg-[var(--zui-tree-view-orange-selected-dark,oklch(64.6%_0.222_41.116_/_0.16))] data-[selected=true]:text-[color:var(--zui-tree-view-orange-selected-fg,oklch(47%_0.157_37.304))] dark:data-[selected=true]:text-[color:var(--zui-tree-view-orange-selected-fg-dark,oklch(83.7%_0.128_66.29))]",
79
+ yellow:
80
+ "data-[selected=true]:bg-[var(--zui-tree-view-yellow-selected,oklch(97.3%_0.071_103.193))] dark:data-[selected=true]:bg-[var(--zui-tree-view-yellow-selected-dark,oklch(68.1%_0.162_75.834_/_0.16))] data-[selected=true]:text-[color:var(--zui-tree-view-yellow-selected-fg,oklch(47.6%_0.114_61.907))] dark:data-[selected=true]:text-[color:var(--zui-tree-view-yellow-selected-fg-dark,oklch(90.5%_0.182_98.111))]",
81
+ teal: "data-[selected=true]:bg-[var(--zui-tree-view-teal-selected,oklch(95.3%_0.051_180.801))] dark:data-[selected=true]:bg-[var(--zui-tree-view-teal-selected-dark,oklch(60%_0.118_184.704_/_0.16))] data-[selected=true]:text-[color:var(--zui-tree-view-teal-selected-fg,oklch(43.7%_0.078_188.216))] dark:data-[selected=true]:text-[color:var(--zui-tree-view-teal-selected-fg-dark,oklch(85.5%_0.138_181.071))]",
82
+ indigo:
83
+ "data-[selected=true]:bg-[var(--zui-tree-view-indigo-selected,oklch(93%_0.034_272.788))] dark:data-[selected=true]:bg-[var(--zui-tree-view-indigo-selected-dark,oklch(51.1%_0.262_276.966_/_0.16))] data-[selected=true]:text-[color:var(--zui-tree-view-indigo-selected-fg,oklch(39.8%_0.195_277.366))] dark:data-[selected=true]:text-[color:var(--zui-tree-view-indigo-selected-fg-dark,oklch(78.5%_0.115_274.713))]",
84
+ emerald:
85
+ "data-[selected=true]:bg-[var(--zui-tree-view-emerald-selected,oklch(95%_0.052_163.051))] dark:data-[selected=true]:bg-[var(--zui-tree-view-emerald-selected-dark,oklch(59.6%_0.145_163.225_/_0.16))] data-[selected=true]:text-[color:var(--zui-tree-view-emerald-selected-fg,oklch(43.2%_0.095_166.913))] dark:data-[selected=true]:text-[color:var(--zui-tree-view-emerald-selected-fg-dark,oklch(84.5%_0.143_164.978))]",
86
+ "gradient-blue":
87
+ "data-[selected=true]:bg-linear-to-r data-[selected=true]:from-[var(--zui-tree-view-gradient-blue-from,oklch(80.9%_0.105_251.813))] data-[selected=true]:to-[var(--zui-tree-view-gradient-blue-to,oklch(82.7%_0.119_306.383))] dark:data-[selected=true]:from-[var(--zui-tree-view-gradient-blue-from-dark,oklch(54.6%_0.245_262.881))] dark:data-[selected=true]:to-[var(--zui-tree-view-gradient-blue-to-dark,oklch(55.8%_0.288_302.321))] data-[selected=true]:text-[color:var(--zui-tree-view-gradient-fg,#ffffff)]",
88
+ "gradient-green":
89
+ "data-[selected=true]:bg-linear-to-r data-[selected=true]:from-[var(--zui-tree-view-gradient-green-from,oklch(87.1%_0.15_154.449))] data-[selected=true]:to-[var(--zui-tree-view-gradient-green-to,oklch(89.7%_0.196_126.665))] dark:data-[selected=true]:from-[var(--zui-tree-view-gradient-green-from-dark,oklch(62.7%_0.194_149.214))] dark:data-[selected=true]:to-[var(--zui-tree-view-gradient-green-to-dark,oklch(64.8%_0.2_131.684))] data-[selected=true]:text-[color:var(--zui-tree-view-gradient-fg,#ffffff)]",
90
+ "gradient-red":
91
+ "data-[selected=true]:bg-linear-to-r data-[selected=true]:from-[var(--zui-tree-view-gradient-red-from,oklch(80.8%_0.114_19.571))] data-[selected=true]:to-[var(--zui-tree-view-gradient-red-to,oklch(82.3%_0.12_346.018))] dark:data-[selected=true]:from-[var(--zui-tree-view-gradient-red-from-dark,oklch(57.7%_0.245_27.325))] dark:data-[selected=true]:to-[var(--zui-tree-view-gradient-red-to-dark,oklch(59.2%_0.249_0.584))] data-[selected=true]:text-[color:var(--zui-tree-view-gradient-fg,#ffffff)]",
92
+ "gradient-yellow":
93
+ "data-[selected=true]:bg-linear-to-r data-[selected=true]:from-[var(--zui-tree-view-gradient-yellow-from,oklch(90.5%_0.182_98.111))] data-[selected=true]:to-[var(--zui-tree-view-gradient-yellow-to,oklch(83.7%_0.128_66.29))] dark:data-[selected=true]:from-[var(--zui-tree-view-gradient-yellow-from-dark,oklch(68.1%_0.162_75.834))] dark:data-[selected=true]:to-[var(--zui-tree-view-gradient-yellow-to-dark,oklch(64.6%_0.222_41.116))] data-[selected=true]:text-[color:var(--zui-tree-view-gradient-fg,#ffffff)]",
94
+ "gradient-purple":
95
+ "data-[selected=true]:bg-linear-to-r data-[selected=true]:from-[var(--zui-tree-view-gradient-purple-from,oklch(82.7%_0.119_306.383))] data-[selected=true]:to-[var(--zui-tree-view-gradient-purple-to,oklch(82.3%_0.12_346.018))] dark:data-[selected=true]:from-[var(--zui-tree-view-gradient-purple-from-dark,oklch(55.8%_0.288_302.321))] dark:data-[selected=true]:to-[var(--zui-tree-view-gradient-purple-to-dark,oklch(59.2%_0.249_0.584))] data-[selected=true]:text-[color:var(--zui-tree-view-gradient-fg,#ffffff)]",
96
+ "gradient-teal":
97
+ "data-[selected=true]:bg-linear-to-r data-[selected=true]:from-[var(--zui-tree-view-gradient-teal-from,oklch(85.5%_0.138_181.071))] data-[selected=true]:to-[var(--zui-tree-view-gradient-teal-to,oklch(86.5%_0.127_207.078))] dark:data-[selected=true]:from-[var(--zui-tree-view-gradient-teal-from-dark,oklch(60%_0.118_184.704))] dark:data-[selected=true]:to-[var(--zui-tree-view-gradient-teal-to-dark,oklch(60.9%_0.126_221.723))] data-[selected=true]:text-[color:var(--zui-tree-view-gradient-fg,#ffffff)]",
98
+ "gradient-indigo":
99
+ "data-[selected=true]:bg-linear-to-r data-[selected=true]:from-[var(--zui-tree-view-gradient-indigo-from,oklch(78.5%_0.115_274.713))] data-[selected=true]:to-[var(--zui-tree-view-gradient-indigo-to,oklch(82.7%_0.119_306.383))] dark:data-[selected=true]:from-[var(--zui-tree-view-gradient-indigo-from-dark,oklch(51.1%_0.262_276.966))] dark:data-[selected=true]:to-[var(--zui-tree-view-gradient-indigo-to-dark,oklch(55.8%_0.288_302.321))] data-[selected=true]:text-[color:var(--zui-tree-view-gradient-fg,#ffffff)]",
100
+ "gradient-pink":
101
+ "data-[selected=true]:bg-linear-to-r data-[selected=true]:from-[var(--zui-tree-view-gradient-pink-from,oklch(82.3%_0.12_346.018))] data-[selected=true]:to-[var(--zui-tree-view-gradient-pink-to,oklch(81%_0.117_11.638))] dark:data-[selected=true]:from-[var(--zui-tree-view-gradient-pink-from-dark,oklch(59.2%_0.249_0.584))] dark:data-[selected=true]:to-[var(--zui-tree-view-gradient-pink-to-dark,oklch(58.6%_0.253_17.585))] data-[selected=true]:text-[color:var(--zui-tree-view-gradient-fg,#ffffff)]",
102
+ "gradient-orange":
103
+ "data-[selected=true]:bg-linear-to-r data-[selected=true]:from-[var(--zui-tree-view-gradient-orange-from,oklch(83.7%_0.128_66.29))] data-[selected=true]:to-[var(--zui-tree-view-gradient-orange-to,oklch(80.8%_0.114_19.571))] dark:data-[selected=true]:from-[var(--zui-tree-view-gradient-orange-from-dark,oklch(64.6%_0.222_41.116))] dark:data-[selected=true]:to-[var(--zui-tree-view-gradient-orange-to-dark,oklch(57.7%_0.245_27.325))] data-[selected=true]:text-[color:var(--zui-tree-view-gradient-fg,#ffffff)]",
104
+ } as const;
105
+
106
+ export const zuiTreeViewChevron =
107
+ "inline-flex h-5 w-5 shrink-0 items-center justify-center rounded text-[color:var(--zui-tree-view-chevron,oklch(55.5%_0.041_257.417))] dark:text-[color:var(--zui-tree-view-chevron-dark,oklch(70.4%_0.04_256.788))] transition-transform duration-200 data-[expanded=true]:rotate-90";
108
+
109
+ export const zuiTreeViewIcon =
110
+ "inline-flex shrink-0 items-center justify-center text-[color:var(--zui-tree-view-icon,oklch(55.5%_0.041_257.417))] dark:text-[color:var(--zui-tree-view-icon-dark,oklch(70.4%_0.04_256.788))]";
111
+
112
+ export const zuiTreeViewGuide =
113
+ "border-l border-[color:var(--zui-tree-view-guide,#0000001a)] dark:border-[color:var(--zui-tree-view-guide-dark,#ffffff1a)]";
@@ -0,0 +1,10 @@
1
+ "use client";
2
+
3
+ export { Rating } from "./rating";
4
+ export type {
5
+ RatingIconVariantProps,
6
+ RatingItemVariantProps,
7
+ RatingPresetIcon,
8
+ RatingProps,
9
+ } from "./types";
10
+ export { ratingIconVariants, ratingItemVariants } from "./variants";
@@ -0,0 +1,139 @@
1
+ import { createRef } from "react";
2
+ import { render, screen } from "@testing-library/react";
3
+ import userEvent from "@testing-library/user-event";
4
+ import { describe, expect, it, vi } from "vitest";
5
+
6
+ import { Rating } from "./rating";
7
+
8
+ describe("Rating", () => {
9
+ it("should expose displayName", () => {
10
+ expect(Rating.displayName).toBe("Rating");
11
+ });
12
+
13
+ it("should stamp data slots and render the requested number of controls", () => {
14
+ render(<Rating label="Product score" max={4} />);
15
+
16
+ expect(document.querySelector('[data-slot="rating"]')).toBeTruthy();
17
+ expect(screen.getByRole("radiogroup")).toBeInTheDocument();
18
+ expect(screen.getAllByRole("radio")).toHaveLength(4);
19
+ });
20
+
21
+ it("should render half-step radio options when allowHalf is enabled", () => {
22
+ render(<Rating allowHalf label="Product score" max={3} />);
23
+
24
+ expect(screen.getAllByRole("radio")).toHaveLength(6);
25
+ expect(screen.getByLabelText("2.5 of 3")).toBeInTheDocument();
26
+ });
27
+
28
+ it("should support uncontrolled value changes", async () => {
29
+ const user = userEvent.setup();
30
+ const onValueChange = vi.fn();
31
+ render(<Rating label="Product score" onValueChange={onValueChange} />);
32
+
33
+ await user.click(screen.getByLabelText("4 of 5"));
34
+
35
+ expect(screen.getByLabelText("4 of 5")).toHaveAttribute(
36
+ "aria-checked",
37
+ "true",
38
+ );
39
+ expect(onValueChange).toHaveBeenLastCalledWith(4);
40
+ });
41
+
42
+ it("should support controlled state", async () => {
43
+ const user = userEvent.setup();
44
+ const onValueChange = vi.fn();
45
+ render(
46
+ <Rating label="Product score" value={2} onValueChange={onValueChange} />,
47
+ );
48
+
49
+ await user.click(screen.getByLabelText("5 of 5"));
50
+
51
+ expect(screen.getByLabelText("2 of 5")).toHaveAttribute(
52
+ "aria-checked",
53
+ "true",
54
+ );
55
+ expect(onValueChange).toHaveBeenLastCalledWith(5);
56
+ });
57
+
58
+ it("should clear the current value when allowClear is enabled", async () => {
59
+ const user = userEvent.setup();
60
+ render(<Rating allowClear defaultValue={3} label="Product score" />);
61
+
62
+ await user.click(screen.getByLabelText("3 of 5"));
63
+
64
+ expect(screen.getByLabelText("1 of 5")).toHaveAttribute("tabindex", "0");
65
+ expect(screen.getByLabelText("3 of 5")).toHaveAttribute(
66
+ "aria-checked",
67
+ "false",
68
+ );
69
+ });
70
+
71
+ it("should step with arrow keys", async () => {
72
+ const user = userEvent.setup();
73
+ const onValueChange = vi.fn();
74
+ render(
75
+ <Rating
76
+ allowHalf
77
+ defaultValue={2}
78
+ label="Product score"
79
+ onValueChange={onValueChange}
80
+ />,
81
+ );
82
+
83
+ screen.getByLabelText("2 of 5").focus();
84
+ await user.keyboard("{ArrowRight}");
85
+
86
+ expect(onValueChange).toHaveBeenLastCalledWith(2.5);
87
+ expect(screen.getByLabelText("2.5 of 5")).toHaveAttribute(
88
+ "aria-checked",
89
+ "true",
90
+ );
91
+ expect(screen.getByLabelText("2.5 of 5")).toHaveFocus();
92
+ });
93
+
94
+ it("should fall back to the star icon for unknown icon preset strings", () => {
95
+ render(
96
+ <Rating
97
+ icon={"unknown" as never}
98
+ defaultValue={3}
99
+ label="Product score"
100
+ />,
101
+ );
102
+
103
+ expect(screen.getByRole("radiogroup")).toBeInTheDocument();
104
+ });
105
+
106
+ it("should not change when disabled", async () => {
107
+ const user = userEvent.setup();
108
+ const onValueChange = vi.fn();
109
+ render(
110
+ <Rating
111
+ disabled
112
+ defaultValue={2}
113
+ label="Product score"
114
+ onValueChange={onValueChange}
115
+ />,
116
+ );
117
+
118
+ await user.click(screen.getByLabelText("4 of 5"));
119
+
120
+ expect(onValueChange).not.toHaveBeenCalled();
121
+ expect(screen.getByLabelText("2 of 5")).toHaveAttribute(
122
+ "aria-checked",
123
+ "true",
124
+ );
125
+ });
126
+
127
+ it("should render a hidden input when name is provided", () => {
128
+ render(<Rating defaultValue={3.5} allowHalf label="Score" name="score" />);
129
+
130
+ expect(document.querySelector('input[name="score"]')).toHaveValue("3.5");
131
+ });
132
+
133
+ it("should forward ref to the root", () => {
134
+ const ref = createRef<HTMLDivElement>();
135
+ render(<Rating ref={ref} label="Product score" />);
136
+
137
+ expect(ref.current?.getAttribute("data-slot")).toBe("rating");
138
+ });
139
+ });