@moldable-ai/ui 0.1.1 → 0.2.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (169) hide show
  1. package/dist/components/chat/chat-input.d.ts.map +1 -1
  2. package/dist/components/chat/chat-input.js +8 -6
  3. package/dist/components/chat/chat-panel.d.ts +5 -1
  4. package/dist/components/chat/chat-panel.d.ts.map +1 -1
  5. package/dist/components/chat/chat-panel.js +6 -2
  6. package/dist/components/chat/markdown.d.ts +9 -0
  7. package/dist/components/chat/markdown.d.ts.map +1 -0
  8. package/dist/components/chat/markdown.js +47 -0
  9. package/dist/components/chat/tool-handlers.d.ts.map +1 -1
  10. package/dist/components/chat/tool-handlers.js +21 -51
  11. package/dist/components/ui/accordion.d.ts +8 -0
  12. package/dist/components/ui/accordion.d.ts.map +1 -0
  13. package/dist/components/ui/accordion.js +18 -0
  14. package/dist/components/ui/alert-dialog.d.ts.map +1 -1
  15. package/dist/components/ui/alert-dialog.js +1 -0
  16. package/dist/components/ui/alert.d.ts +10 -0
  17. package/dist/components/ui/alert.d.ts.map +1 -0
  18. package/dist/components/ui/alert.js +25 -0
  19. package/dist/components/ui/aspect-ratio.d.ts +4 -0
  20. package/dist/components/ui/aspect-ratio.d.ts.map +1 -0
  21. package/dist/components/ui/aspect-ratio.js +7 -0
  22. package/dist/components/ui/avatar.d.ts +7 -0
  23. package/dist/components/ui/avatar.d.ts.map +1 -0
  24. package/dist/components/ui/avatar.js +14 -0
  25. package/dist/components/ui/badge.d.ts.map +1 -1
  26. package/dist/components/ui/badge.js +1 -0
  27. package/dist/components/ui/breadcrumb.d.ts +12 -0
  28. package/dist/components/ui/breadcrumb.d.ts.map +1 -0
  29. package/dist/components/ui/breadcrumb.js +28 -0
  30. package/dist/components/ui/button-group.d.ts +12 -0
  31. package/dist/components/ui/button-group.d.ts.map +1 -0
  32. package/dist/components/ui/button-group.js +28 -0
  33. package/dist/components/ui/button.d.ts +2 -3
  34. package/dist/components/ui/button.d.ts.map +1 -1
  35. package/dist/components/ui/button.js +5 -6
  36. package/dist/components/ui/calendar.d.ts +9 -0
  37. package/dist/components/ui/calendar.d.ts.map +1 -0
  38. package/dist/components/ui/calendar.js +76 -0
  39. package/dist/components/ui/card.d.ts +8 -7
  40. package/dist/components/ui/card.d.ts.map +1 -1
  41. package/dist/components/ui/card.js +23 -14
  42. package/dist/components/ui/carousel.d.ts +20 -0
  43. package/dist/components/ui/carousel.d.ts.map +1 -0
  44. package/dist/components/ui/carousel.js +91 -0
  45. package/dist/components/ui/chart.d.ts +41 -0
  46. package/dist/components/ui/chart.d.ts.map +1 -0
  47. package/dist/components/ui/chart.js +132 -0
  48. package/dist/components/ui/checkbox.js +1 -1
  49. package/dist/components/ui/collapsible.d.ts +3 -3
  50. package/dist/components/ui/collapsible.d.ts.map +1 -1
  51. package/dist/components/ui/collapsible.js +11 -3
  52. package/dist/components/ui/command.d.ts +15 -15
  53. package/dist/components/ui/command.d.ts.map +1 -1
  54. package/dist/components/ui/command.js +29 -24
  55. package/dist/components/ui/context-menu.d.ts +26 -0
  56. package/dist/components/ui/context-menu.d.ts.map +1 -0
  57. package/dist/components/ui/context-menu.js +51 -0
  58. package/dist/components/ui/dialog.d.ts +13 -17
  59. package/dist/components/ui/dialog.d.ts.map +1 -1
  60. package/dist/components/ui/dialog.js +32 -19
  61. package/dist/components/ui/drawer.d.ts +14 -0
  62. package/dist/components/ui/drawer.d.ts.map +1 -0
  63. package/dist/components/ui/drawer.js +35 -0
  64. package/dist/components/ui/dropdown-menu.js +6 -6
  65. package/dist/components/ui/empty.d.ts +12 -0
  66. package/dist/components/ui/empty.d.ts.map +1 -0
  67. package/dist/components/ui/empty.js +34 -0
  68. package/dist/components/ui/field.d.ts +25 -0
  69. package/dist/components/ui/field.d.ts.map +1 -0
  70. package/dist/components/ui/field.js +76 -0
  71. package/dist/components/ui/form.d.ts +25 -0
  72. package/dist/components/ui/form.d.ts.map +1 -0
  73. package/dist/components/ui/form.js +59 -0
  74. package/dist/components/ui/hover-card.d.ts +7 -0
  75. package/dist/components/ui/hover-card.d.ts.map +1 -0
  76. package/dist/components/ui/hover-card.js +14 -0
  77. package/dist/components/ui/index.d.ts +35 -0
  78. package/dist/components/ui/index.d.ts.map +1 -1
  79. package/dist/components/ui/index.js +35 -0
  80. package/dist/components/ui/input-group.d.ts +17 -0
  81. package/dist/components/ui/input-group.d.ts.map +1 -0
  82. package/dist/components/ui/input-group.js +63 -0
  83. package/dist/components/ui/input-otp.d.ts +12 -0
  84. package/dist/components/ui/input-otp.d.ts.map +1 -0
  85. package/dist/components/ui/input-otp.js +21 -0
  86. package/dist/components/ui/input.d.ts +1 -2
  87. package/dist/components/ui/input.d.ts.map +1 -1
  88. package/dist/components/ui/input.js +4 -5
  89. package/dist/components/ui/item.d.ts +24 -0
  90. package/dist/components/ui/item.d.ts.map +1 -0
  91. package/dist/components/ui/item.js +67 -0
  92. package/dist/components/ui/kbd.d.ts +4 -0
  93. package/dist/components/ui/kbd.d.ts.map +1 -0
  94. package/dist/components/ui/kbd.js +10 -0
  95. package/dist/components/ui/label.d.ts +1 -1
  96. package/dist/components/ui/label.d.ts.map +1 -1
  97. package/dist/components/ui/label.js +3 -3
  98. package/dist/components/ui/menubar.d.ts +27 -0
  99. package/dist/components/ui/menubar.d.ts.map +1 -0
  100. package/dist/components/ui/menubar.js +54 -0
  101. package/dist/components/ui/navigation-menu.d.ts +15 -0
  102. package/dist/components/ui/navigation-menu.d.ts.map +1 -0
  103. package/dist/components/ui/navigation-menu.js +32 -0
  104. package/dist/components/ui/pagination.d.ts +14 -0
  105. package/dist/components/ui/pagination.d.ts.map +1 -0
  106. package/dist/components/ui/pagination.js +30 -0
  107. package/dist/components/ui/popover.d.ts.map +1 -1
  108. package/dist/components/ui/popover.js +1 -0
  109. package/dist/components/ui/progress.d.ts +5 -0
  110. package/dist/components/ui/progress.d.ts.map +1 -0
  111. package/dist/components/ui/progress.js +8 -0
  112. package/dist/components/ui/radio-group.d.ts +6 -0
  113. package/dist/components/ui/radio-group.d.ts.map +1 -0
  114. package/dist/components/ui/radio-group.js +12 -0
  115. package/dist/components/ui/resizable.d.ts +8 -0
  116. package/dist/components/ui/resizable.d.ts.map +1 -0
  117. package/dist/components/ui/resizable.js +15 -0
  118. package/dist/components/ui/scroll-area.d.ts +2 -2
  119. package/dist/components/ui/scroll-area.d.ts.map +1 -1
  120. package/dist/components/ui/scroll-area.js +9 -7
  121. package/dist/components/ui/select.d.ts +13 -11
  122. package/dist/components/ui/select.d.ts.map +1 -1
  123. package/dist/components/ui/select.js +35 -23
  124. package/dist/components/ui/separator.d.ts +5 -0
  125. package/dist/components/ui/separator.d.ts.map +1 -0
  126. package/dist/components/ui/separator.js +8 -0
  127. package/dist/components/ui/sheet.d.ts +14 -0
  128. package/dist/components/ui/sheet.d.ts.map +1 -0
  129. package/dist/components/ui/sheet.js +40 -0
  130. package/dist/components/ui/sidebar.d.ts +70 -0
  131. package/dist/components/ui/sidebar.d.ts.map +1 -0
  132. package/dist/components/ui/sidebar.js +212 -0
  133. package/dist/components/ui/skeleton.d.ts +3 -0
  134. package/dist/components/ui/skeleton.d.ts.map +1 -0
  135. package/dist/components/ui/skeleton.js +7 -0
  136. package/dist/components/ui/slider.d.ts +5 -0
  137. package/dist/components/ui/slider.d.ts.map +1 -0
  138. package/dist/components/ui/slider.js +14 -0
  139. package/dist/components/ui/sonner.d.ts +4 -0
  140. package/dist/components/ui/sonner.d.ts.map +1 -0
  141. package/dist/components/ui/sonner.js +21 -0
  142. package/dist/components/ui/spinner.d.ts +3 -0
  143. package/dist/components/ui/spinner.d.ts.map +1 -0
  144. package/dist/components/ui/spinner.js +8 -0
  145. package/dist/components/ui/switch.d.ts +2 -2
  146. package/dist/components/ui/switch.d.ts.map +1 -1
  147. package/dist/components/ui/switch.js +4 -4
  148. package/dist/components/ui/table.d.ts +11 -0
  149. package/dist/components/ui/table.d.ts.map +1 -0
  150. package/dist/components/ui/table.js +28 -0
  151. package/dist/components/ui/tabs.d.ts.map +1 -1
  152. package/dist/components/ui/tabs.js +1 -0
  153. package/dist/components/ui/textarea.d.ts +1 -2
  154. package/dist/components/ui/textarea.d.ts.map +1 -1
  155. package/dist/components/ui/textarea.js +4 -5
  156. package/dist/components/ui/toggle-group.d.ts +10 -0
  157. package/dist/components/ui/toggle-group.d.ts.map +1 -0
  158. package/dist/components/ui/toggle-group.js +22 -0
  159. package/dist/components/ui/toggle.d.ts +10 -0
  160. package/dist/components/ui/toggle.d.ts.map +1 -0
  161. package/dist/components/ui/toggle.js +26 -0
  162. package/dist/components/ui/tooltip.js +1 -1
  163. package/dist/hooks/use-mobile.d.ts +2 -0
  164. package/dist/hooks/use-mobile.d.ts.map +1 -0
  165. package/dist/hooks/use-mobile.js +15 -0
  166. package/dist/index.d.ts +1 -0
  167. package/dist/index.d.ts.map +1 -1
  168. package/dist/index.js +2 -0
  169. package/package.json +48 -24
@@ -0,0 +1,26 @@
1
+ 'use client';
2
+ import { jsx as _jsx } from "react/jsx-runtime";
3
+ import * as TogglePrimitive from '@radix-ui/react-toggle';
4
+ import { cn } from '../../lib/utils';
5
+ import { cva } from 'class-variance-authority';
6
+ const toggleVariants = cva("inline-flex items-center justify-center gap-2 rounded-md text-sm font-medium hover:bg-muted hover:text-muted-foreground disabled:pointer-events-none disabled:opacity-50 data-[state=on]:bg-accent data-[state=on]:text-accent-foreground [&_svg]:pointer-events-none [&_svg:not([class*='size-'])]:size-4 [&_svg]:shrink-0 focus-visible:border-ring focus-visible:ring-ring/50 focus-visible:ring-[3px] outline-none transition-[color,box-shadow] aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive whitespace-nowrap", {
7
+ variants: {
8
+ variant: {
9
+ default: 'bg-transparent',
10
+ outline: 'border border-input bg-transparent shadow-xs hover:bg-accent hover:text-accent-foreground',
11
+ },
12
+ size: {
13
+ default: 'h-9 px-2 min-w-9',
14
+ sm: 'h-8 px-1.5 min-w-8',
15
+ lg: 'h-10 px-2.5 min-w-10',
16
+ },
17
+ },
18
+ defaultVariants: {
19
+ variant: 'default',
20
+ size: 'default',
21
+ },
22
+ });
23
+ function Toggle({ className, variant, size, ...props }) {
24
+ return (_jsx(TogglePrimitive.Root, { "data-slot": "toggle", className: cn(toggleVariants({ variant, size, className })), ...props }));
25
+ }
26
+ export { Toggle, toggleVariants };
@@ -12,6 +12,6 @@ function TooltipTrigger({ ...props }) {
12
12
  return _jsx(TooltipPrimitive.Trigger, { "data-slot": "tooltip-trigger", ...props });
13
13
  }
14
14
  function TooltipContent({ className, sideOffset = 0, children, ...props }) {
15
- return (_jsx(TooltipPrimitive.Portal, { children: _jsxs(TooltipPrimitive.Content, { "data-slot": "tooltip-content", sideOffset: sideOffset, className: cn('origin-(--radix-tooltip-content-transform-origin) animate-in bg-foreground text-background fade-in-0 zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=closed]:zoom-out-95 z-50 w-fit text-balance rounded-md px-3 py-1.5 text-xs', className), ...props, children: [children, _jsx(TooltipPrimitive.Arrow, { className: "bg-foreground fill-foreground z-50 size-2.5 translate-y-[calc(-50%-2px)] rotate-45 rounded-[2px]" })] }) }));
15
+ return (_jsx(TooltipPrimitive.Portal, { children: _jsxs(TooltipPrimitive.Content, { "data-slot": "tooltip-content", sideOffset: sideOffset, className: cn('bg-foreground text-background animate-in fade-in-0 zoom-in-95 data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=closed]:zoom-out-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 origin-(--radix-tooltip-content-transform-origin) z-50 w-fit text-balance rounded-md px-3 py-1.5 text-xs', className), ...props, children: [children, _jsx(TooltipPrimitive.Arrow, { className: "bg-foreground fill-foreground z-50 size-2.5 translate-y-[calc(-50%_-_2px)] rotate-45 rounded-[2px]" })] }) }));
16
16
  }
17
17
  export { Tooltip, TooltipTrigger, TooltipContent, TooltipProvider };
@@ -0,0 +1,2 @@
1
+ export declare function useIsMobile(): boolean;
2
+ //# sourceMappingURL=use-mobile.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use-mobile.d.ts","sourceRoot":"","sources":["../../src/hooks/use-mobile.ts"],"names":[],"mappings":"AAIA,wBAAgB,WAAW,YAc1B"}
@@ -0,0 +1,15 @@
1
+ import * as React from 'react';
2
+ const MOBILE_BREAKPOINT = 768;
3
+ export function useIsMobile() {
4
+ const [isMobile, setIsMobile] = React.useState(undefined);
5
+ React.useEffect(() => {
6
+ const mql = window.matchMedia(`(max-width: ${MOBILE_BREAKPOINT - 1}px)`);
7
+ const onChange = () => {
8
+ setIsMobile(window.innerWidth < MOBILE_BREAKPOINT);
9
+ };
10
+ mql.addEventListener('change', onChange);
11
+ setIsMobile(window.innerWidth < MOBILE_BREAKPOINT);
12
+ return () => mql.removeEventListener('change', onChange);
13
+ }, []);
14
+ return !!isMobile;
15
+ }
package/dist/index.d.ts CHANGED
@@ -3,6 +3,7 @@ export { ThemeProvider, useTheme, themeScript, type Theme } from './lib/theme';
3
3
  export { WorkspaceProvider, useWorkspace, WORKSPACE_HEADER, } from './lib/workspace';
4
4
  export { useMoldableCommands, useMoldableCommand, isInMoldable, sendToMoldable, type AppCommand, type CommandAction, type CommandsResponse, type CommandMessage, } from './lib/commands';
5
5
  export * from './components/ui';
6
+ export { useIsMobile } from './hooks/use-mobile';
6
7
  export { Markdown } from './components/markdown';
7
8
  export { CodeBlock } from './components/code-block';
8
9
  export { WidgetLayout } from './components/widget-layout';
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,EAAE,EAAE,MAAM,aAAa,CAAA;AAGhC,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,WAAW,EAAE,KAAK,KAAK,EAAE,MAAM,aAAa,CAAA;AAG9E,OAAO,EACL,iBAAiB,EACjB,YAAY,EACZ,gBAAgB,GACjB,MAAM,iBAAiB,CAAA;AAGxB,OAAO,EACL,mBAAmB,EACnB,kBAAkB,EAClB,YAAY,EACZ,cAAc,EACd,KAAK,UAAU,EACf,KAAK,aAAa,EAClB,KAAK,gBAAgB,EACrB,KAAK,cAAc,GACpB,MAAM,gBAAgB,CAAA;AAGvB,cAAc,iBAAiB,CAAA;AAG/B,OAAO,EAAE,QAAQ,EAAE,MAAM,uBAAuB,CAAA;AAGhD,OAAO,EAAE,SAAS,EAAE,MAAM,yBAAyB,CAAA;AAGnD,OAAO,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAA;AAGzD,cAAc,mBAAmB,CAAA"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,EAAE,EAAE,MAAM,aAAa,CAAA;AAGhC,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,WAAW,EAAE,KAAK,KAAK,EAAE,MAAM,aAAa,CAAA;AAG9E,OAAO,EACL,iBAAiB,EACjB,YAAY,EACZ,gBAAgB,GACjB,MAAM,iBAAiB,CAAA;AAGxB,OAAO,EACL,mBAAmB,EACnB,kBAAkB,EAClB,YAAY,EACZ,cAAc,EACd,KAAK,UAAU,EACf,KAAK,aAAa,EAClB,KAAK,gBAAgB,EACrB,KAAK,cAAc,GACpB,MAAM,gBAAgB,CAAA;AAGvB,cAAc,iBAAiB,CAAA;AAG/B,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAA;AAGhD,OAAO,EAAE,QAAQ,EAAE,MAAM,uBAAuB,CAAA;AAGhD,OAAO,EAAE,SAAS,EAAE,MAAM,yBAAyB,CAAA;AAGnD,OAAO,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAA;AAGzD,cAAc,mBAAmB,CAAA"}
package/dist/index.js CHANGED
@@ -8,6 +8,8 @@ export { WorkspaceProvider, useWorkspace, WORKSPACE_HEADER, } from './lib/worksp
8
8
  export { useMoldableCommands, useMoldableCommand, isInMoldable, sendToMoldable, } from './lib/commands';
9
9
  // Export UI components
10
10
  export * from './components/ui';
11
+ // Export hooks
12
+ export { useIsMobile } from './hooks/use-mobile';
11
13
  // Export Markdown
12
14
  export { Markdown } from './components/markdown';
13
15
  // Export CodeBlock
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@moldable-ai/ui",
3
- "version": "0.1.1",
3
+ "version": "0.2.1",
4
4
  "description": "Shared UI components for Moldable applications",
5
5
  "author": "Desiderata LLC",
6
6
  "license": "Elastic-2.0",
@@ -32,56 +32,80 @@
32
32
  "src/styles",
33
33
  "LICENSE"
34
34
  ],
35
+ "scripts": {
36
+ "build": "tsc",
37
+ "dev": "tsc --watch",
38
+ "lint": "eslint . --ext .ts,.tsx --max-warnings 0",
39
+ "format": "prettier --write . --ignore-path ../../.prettierignore",
40
+ "check-types": "tsc --noEmit",
41
+ "test": "vitest run"
42
+ },
35
43
  "dependencies": {
44
+ "@hookform/resolvers": "^5.2.2",
45
+ "@radix-ui/react-accordion": "^1.2.12",
36
46
  "@radix-ui/react-alert-dialog": "^1.1.15",
37
- "@radix-ui/react-checkbox": "^1.3.2",
38
- "@radix-ui/react-collapsible": "^1.1.11",
47
+ "@radix-ui/react-aspect-ratio": "^1.1.8",
48
+ "@radix-ui/react-avatar": "^1.1.11",
49
+ "@radix-ui/react-checkbox": "^1.3.3",
50
+ "@radix-ui/react-collapsible": "^1.1.12",
51
+ "@radix-ui/react-context-menu": "^2.2.16",
39
52
  "@radix-ui/react-dialog": "^1.1.15",
40
- "@radix-ui/react-dropdown-menu": "^2.1.15",
41
- "@radix-ui/react-label": "^2.1.7",
53
+ "@radix-ui/react-dropdown-menu": "^2.1.16",
54
+ "@radix-ui/react-hover-card": "^1.1.15",
55
+ "@radix-ui/react-label": "^2.1.8",
56
+ "@radix-ui/react-menubar": "^1.1.16",
57
+ "@radix-ui/react-navigation-menu": "^1.2.14",
42
58
  "@radix-ui/react-popover": "^1.1.15",
43
- "@radix-ui/react-scroll-area": "^1.2.2",
44
- "@radix-ui/react-select": "^2.2.5",
45
- "@radix-ui/react-separator": "^1.1.7",
59
+ "@radix-ui/react-progress": "^1.1.8",
60
+ "@radix-ui/react-radio-group": "^1.3.8",
61
+ "@radix-ui/react-scroll-area": "^1.2.10",
62
+ "@radix-ui/react-select": "^2.2.6",
63
+ "@radix-ui/react-separator": "^1.1.8",
64
+ "@radix-ui/react-slider": "^1.3.6",
46
65
  "@radix-ui/react-slot": "^1.2.4",
47
- "@radix-ui/react-switch": "^1.2.5",
66
+ "@radix-ui/react-switch": "^1.2.6",
48
67
  "@radix-ui/react-tabs": "^1.1.13",
49
- "@radix-ui/react-tooltip": "^1.2.7",
68
+ "@radix-ui/react-toggle": "^1.1.10",
69
+ "@radix-ui/react-toggle-group": "^1.1.11",
70
+ "@radix-ui/react-tooltip": "^1.2.8",
50
71
  "@tailwindcss/typography": "^0.5.16",
51
72
  "class-variance-authority": "^0.7.1",
52
73
  "clsx": "^2.1.1",
53
74
  "cmdk": "1.1.0",
75
+ "date-fns": "^4.1.0",
76
+ "embla-carousel-react": "^8.6.0",
54
77
  "framer-motion": "^12.15.0",
78
+ "input-otp": "^1.4.2",
55
79
  "lucide-react": "^0.473.0",
80
+ "next-themes": "^0.4.6",
81
+ "react-day-picker": "^9.13.0",
82
+ "react-hook-form": "^7.71.1",
56
83
  "react-markdown": "^10.1.0",
84
+ "react-resizable-panels": "^4.4.1",
85
+ "recharts": "2.15.4",
57
86
  "rehype-raw": "^7.0.0",
58
87
  "remark-gfm": "^4.0.1",
59
88
  "shiki": "^3.21.0",
89
+ "sonner": "^2.0.7",
60
90
  "tailwind-merge": "^2.6.0",
61
91
  "tailwindcss": "^4.1.10",
62
- "tw-animate-css": "^1.3.4"
92
+ "tw-animate-css": "^1.3.4",
93
+ "vaul": "^1.1.2",
94
+ "zod": "^4.3.5"
63
95
  },
64
96
  "devDependencies": {
97
+ "@moldable-ai/eslint-config": "workspace:*",
98
+ "@moldable-ai/prettier-config": "workspace:*",
99
+ "@moldable-ai/typescript-config": "workspace:*",
65
100
  "@types/node": "^24.0.3",
66
101
  "@types/react": "^19.1.6",
67
102
  "@types/react-dom": "^19.1.6",
68
103
  "jsdom": "^26.1.0",
69
104
  "typescript": "^5.8.3",
70
- "vitest": "^3.2.4",
71
- "@moldable-ai/eslint-config": "0.0.1",
72
- "@moldable-ai/prettier-config": "0.0.1",
73
- "@moldable-ai/typescript-config": "0.0.1"
105
+ "vitest": "^3.2.4"
74
106
  },
75
107
  "peerDependencies": {
76
108
  "react": "^19.0.0",
77
109
  "react-dom": "^19.0.0"
78
- },
79
- "scripts": {
80
- "build": "tsc",
81
- "dev": "tsc --watch",
82
- "lint": "eslint . --ext .ts,.tsx --max-warnings 0",
83
- "format": "prettier --write . --ignore-path ../../.prettierignore",
84
- "check-types": "tsc --noEmit",
85
- "test": "vitest run"
86
110
  }
87
- }
111
+ }