@object-ui/components 0.3.0 → 0.5.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (423) hide show
  1. package/.turbo/turbo-build.log +47 -0
  2. package/CHANGELOG.md +10 -0
  3. package/README.md +32 -1
  4. package/README_SHADCN_SYNC.md +281 -0
  5. package/TESTING.md +335 -0
  6. package/dist/index.css +1 -1
  7. package/dist/index.js +45067 -34357
  8. package/dist/index.umd.cjs +54 -42
  9. package/dist/src/SchemaRenderer.d.ts +3 -0
  10. package/dist/src/{ui → custom}/button-group.d.ts +1 -1
  11. package/dist/src/custom/combobox.d.ts +22 -0
  12. package/dist/src/custom/date-picker.d.ts +15 -0
  13. package/dist/src/custom/field.d.ts +19 -0
  14. package/dist/src/{ui → custom}/filter-builder.d.ts +7 -0
  15. package/dist/src/custom/index.d.ts +12 -0
  16. package/dist/src/custom/input-group.d.ts +14 -0
  17. package/dist/src/{ui → custom}/item.d.ts +8 -1
  18. package/dist/src/{ui → custom}/kbd.d.ts +7 -0
  19. package/dist/src/custom/native-select.d.ts +12 -0
  20. package/dist/src/custom/sort-builder.d.ts +22 -0
  21. package/dist/src/custom/spinner.d.ts +10 -0
  22. package/dist/src/hooks/use-mobile.d.ts +7 -0
  23. package/dist/src/index.d.ts +5 -1
  24. package/dist/src/renderers/basic/button-group.d.ts +8 -0
  25. package/dist/src/renderers/basic/div.d.ts +7 -0
  26. package/dist/src/renderers/basic/html.d.ts +7 -0
  27. package/dist/src/renderers/basic/icon.d.ts +7 -0
  28. package/dist/src/renderers/basic/image.d.ts +7 -0
  29. package/dist/src/renderers/basic/navigation-menu.d.ts +8 -0
  30. package/dist/src/renderers/basic/pagination.d.ts +8 -0
  31. package/dist/src/renderers/basic/separator.d.ts +7 -0
  32. package/dist/src/renderers/basic/span.d.ts +7 -0
  33. package/dist/src/renderers/basic/text.d.ts +7 -0
  34. package/dist/src/renderers/complex/carousel.d.ts +7 -0
  35. package/dist/src/renderers/complex/data-table.d.ts +7 -0
  36. package/dist/src/renderers/complex/filter-builder.d.ts +7 -0
  37. package/dist/src/renderers/complex/resizable.d.ts +7 -0
  38. package/dist/src/renderers/complex/scroll-area.d.ts +7 -0
  39. package/dist/src/renderers/complex/table.d.ts +7 -0
  40. package/dist/src/renderers/data-display/alert.d.ts +7 -0
  41. package/dist/src/renderers/data-display/avatar.d.ts +7 -0
  42. package/dist/src/renderers/data-display/badge.d.ts +7 -0
  43. package/dist/src/renderers/data-display/breadcrumb.d.ts +8 -0
  44. package/dist/src/renderers/data-display/kbd.d.ts +8 -0
  45. package/dist/src/renderers/data-display/list.d.ts +7 -0
  46. package/dist/src/renderers/data-display/statistic.d.ts +7 -0
  47. package/dist/src/renderers/data-display/table.d.ts +8 -0
  48. package/dist/src/renderers/data-display/tree-view.d.ts +7 -0
  49. package/dist/src/renderers/disclosure/accordion.d.ts +7 -0
  50. package/dist/src/renderers/disclosure/collapsible.d.ts +7 -0
  51. package/dist/src/renderers/disclosure/toggle-group.d.ts +8 -0
  52. package/dist/src/renderers/feedback/empty.d.ts +8 -0
  53. package/dist/src/renderers/feedback/loading.d.ts +7 -0
  54. package/dist/src/renderers/feedback/progress.d.ts +7 -0
  55. package/dist/src/renderers/feedback/skeleton.d.ts +7 -0
  56. package/dist/src/renderers/feedback/sonner.d.ts +8 -0
  57. package/dist/src/renderers/feedback/spinner.d.ts +8 -0
  58. package/dist/src/renderers/feedback/toast.d.ts +8 -0
  59. package/dist/src/renderers/feedback/toaster.d.ts +7 -0
  60. package/dist/src/renderers/form/button.d.ts +7 -0
  61. package/dist/src/renderers/form/calendar.d.ts +7 -0
  62. package/dist/src/renderers/form/checkbox.d.ts +7 -0
  63. package/dist/src/renderers/form/combobox.d.ts +8 -0
  64. package/dist/src/renderers/form/command.d.ts +8 -0
  65. package/dist/src/renderers/form/date-picker.d.ts +7 -0
  66. package/dist/src/renderers/form/file-upload.d.ts +7 -0
  67. package/dist/src/renderers/form/form.d.ts +7 -0
  68. package/dist/src/renderers/form/input-otp.d.ts +7 -0
  69. package/dist/src/renderers/form/input.d.ts +7 -0
  70. package/dist/src/renderers/form/label.d.ts +7 -0
  71. package/dist/src/renderers/form/radio-group.d.ts +7 -0
  72. package/dist/src/renderers/form/select.d.ts +7 -0
  73. package/dist/src/renderers/form/slider.d.ts +7 -0
  74. package/dist/src/renderers/form/switch.d.ts +7 -0
  75. package/dist/src/renderers/form/textarea.d.ts +7 -0
  76. package/dist/src/renderers/form/toggle.d.ts +7 -0
  77. package/dist/src/renderers/layout/aspect-ratio.d.ts +8 -0
  78. package/dist/src/renderers/layout/card.d.ts +7 -0
  79. package/dist/src/renderers/layout/container.d.ts +7 -0
  80. package/dist/src/renderers/layout/flex.d.ts +7 -0
  81. package/dist/src/renderers/layout/grid.d.ts +7 -0
  82. package/dist/src/renderers/layout/page.d.ts +1 -1
  83. package/dist/src/renderers/layout/semantic.d.ts +7 -0
  84. package/dist/src/renderers/layout/stack.d.ts +7 -0
  85. package/dist/src/renderers/layout/tabs.d.ts +7 -0
  86. package/dist/src/renderers/navigation/header-bar.d.ts +7 -0
  87. package/dist/src/renderers/navigation/sidebar.d.ts +7 -0
  88. package/dist/src/renderers/overlay/alert-dialog.d.ts +7 -0
  89. package/dist/src/renderers/overlay/context-menu.d.ts +7 -0
  90. package/dist/src/renderers/overlay/dialog.d.ts +7 -0
  91. package/dist/src/renderers/overlay/drawer.d.ts +7 -0
  92. package/dist/src/renderers/overlay/dropdown-menu.d.ts +7 -0
  93. package/dist/src/renderers/overlay/hover-card.d.ts +7 -0
  94. package/dist/src/renderers/overlay/menubar.d.ts +8 -0
  95. package/dist/src/renderers/overlay/popover.d.ts +7 -0
  96. package/dist/src/renderers/overlay/sheet.d.ts +7 -0
  97. package/dist/src/renderers/overlay/tooltip.d.ts +7 -0
  98. package/dist/src/renderers/placeholders.d.ts +9 -0
  99. package/dist/src/ui/accordion.d.ts +11 -4
  100. package/dist/src/ui/alert-dialog.d.ts +24 -11
  101. package/dist/src/ui/alert.d.ts +11 -5
  102. package/dist/src/ui/aspect-ratio.d.ts +8 -1
  103. package/dist/src/ui/avatar.d.ts +10 -3
  104. package/dist/src/ui/badge.d.ts +10 -3
  105. package/dist/src/ui/breadcrumb.d.ts +23 -8
  106. package/dist/src/ui/button.d.ts +10 -5
  107. package/dist/src/ui/calendar.d.ts +8 -1
  108. package/dist/src/ui/card.d.ts +14 -8
  109. package/dist/src/ui/carousel.d.ts +12 -6
  110. package/dist/src/ui/chart.d.ts +62 -0
  111. package/dist/src/ui/checkbox.d.ts +8 -1
  112. package/dist/src/ui/collapsible.d.ts +10 -3
  113. package/dist/src/ui/command.d.ts +85 -16
  114. package/dist/src/ui/context-menu.d.ts +21 -12
  115. package/dist/src/ui/dialog.d.ts +24 -13
  116. package/dist/src/ui/drawer.d.ts +26 -10
  117. package/dist/src/ui/dropdown-menu.d.ts +27 -18
  118. package/dist/src/ui/form.d.ts +13 -7
  119. package/dist/src/ui/hover-card.d.ts +10 -3
  120. package/dist/src/ui/index.d.ts +10 -11
  121. package/dist/src/ui/input-otp.d.ts +37 -7
  122. package/dist/src/ui/input.d.ts +7 -0
  123. package/dist/src/ui/label.d.ts +9 -1
  124. package/dist/src/ui/menubar.d.ts +26 -17
  125. package/dist/src/ui/navigation-menu.d.ts +16 -11
  126. package/dist/src/ui/pagination.d.ts +32 -10
  127. package/dist/src/ui/popover.d.ts +11 -5
  128. package/dist/src/ui/progress.d.ts +8 -1
  129. package/dist/src/ui/radio-group.d.ts +9 -2
  130. package/dist/src/ui/resizable.d.ts +12 -8
  131. package/dist/src/ui/scroll-area.d.ts +9 -2
  132. package/dist/src/ui/select.d.ts +18 -13
  133. package/dist/src/ui/separator.d.ts +7 -0
  134. package/dist/src/ui/sheet.d.ts +30 -11
  135. package/dist/src/ui/sidebar.d.ts +41 -38
  136. package/dist/src/ui/skeleton.d.ts +8 -1
  137. package/dist/src/ui/slider.d.ts +8 -1
  138. package/dist/src/ui/sonner.d.ts +2 -1
  139. package/dist/src/ui/switch.d.ts +9 -2
  140. package/dist/src/ui/table.d.ts +15 -8
  141. package/dist/src/ui/tabs.d.ts +8 -1
  142. package/dist/src/ui/textarea.d.ts +8 -1
  143. package/dist/src/ui/toast.d.ts +22 -0
  144. package/dist/src/ui/toggle-group.d.ts +15 -5
  145. package/dist/src/ui/toggle.d.ts +11 -1
  146. package/dist/src/ui/tooltip.d.ts +11 -4
  147. package/dist/src/ui/typography.d.ts +21 -0
  148. package/metadata/ObjectGrid.component.yml +72 -0
  149. package/package.json +35 -13
  150. package/postcss.config.js +9 -1
  151. package/shadcn-components.json +315 -0
  152. package/src/SchemaRenderer.tsx +28 -0
  153. package/src/__tests__/PageRendererRegions.test.tsx +59 -0
  154. package/src/__tests__/README.md +124 -0
  155. package/src/__tests__/Registry.test.ts +21 -0
  156. package/src/__tests__/basic-renderers.test.tsx +255 -0
  157. package/src/__tests__/complex-disclosure-renderers.test.tsx +302 -0
  158. package/src/__tests__/feedback-overlay-renderers.test.tsx +349 -0
  159. package/src/__tests__/form-renderers.test.tsx +364 -0
  160. package/src/__tests__/layout-data-renderers.test.tsx +340 -0
  161. package/src/__tests__/test-utils.tsx +190 -0
  162. package/src/{ui → custom}/button-group.tsx +9 -1
  163. package/src/custom/combobox.tsx +104 -0
  164. package/src/custom/date-picker.tsx +61 -0
  165. package/src/{ui → custom}/empty.tsx +8 -0
  166. package/src/custom/field.tsx +81 -0
  167. package/src/{ui → custom}/filter-builder.tsx +11 -3
  168. package/src/custom/index.ts +12 -0
  169. package/src/custom/input-group.tsx +53 -0
  170. package/src/{ui → custom}/item.tsx +9 -1
  171. package/src/{ui → custom}/kbd.tsx +8 -0
  172. package/src/custom/native-select.tsx +33 -0
  173. package/src/custom/sort-builder.tsx +129 -0
  174. package/src/custom/spinner.tsx +26 -0
  175. package/src/hooks/use-mobile.tsx +8 -0
  176. package/src/index.css +105 -54
  177. package/src/index.test.ts +8 -0
  178. package/src/index.ts +22 -1
  179. package/src/lib/utils.tsx +8 -0
  180. package/src/new-components.test.ts +8 -9
  181. package/src/renderers/basic/button-group.tsx +79 -0
  182. package/src/renderers/basic/div.tsx +21 -2
  183. package/src/renderers/basic/html.tsx +9 -0
  184. package/src/renderers/basic/icon.tsx +67 -3
  185. package/src/renderers/basic/image.tsx +13 -1
  186. package/src/renderers/basic/index.ts +11 -0
  187. package/src/renderers/basic/navigation-menu.tsx +81 -0
  188. package/src/renderers/basic/pagination.tsx +109 -0
  189. package/src/renderers/basic/separator.tsx +10 -1
  190. package/src/renderers/basic/span.tsx +21 -2
  191. package/src/renderers/basic/text.tsx +12 -2
  192. package/src/renderers/complex/__tests__/data-table.test.ts +8 -0
  193. package/src/renderers/complex/carousel.tsx +12 -3
  194. package/src/renderers/complex/data-table.tsx +150 -96
  195. package/src/renderers/complex/filter-builder.tsx +10 -1
  196. package/src/renderers/complex/index.ts +9 -3
  197. package/src/renderers/complex/resizable.tsx +10 -1
  198. package/src/renderers/complex/scroll-area.tsx +33 -7
  199. package/src/renderers/complex/table.tsx +11 -2
  200. package/src/renderers/data-display/alert.tsx +9 -0
  201. package/src/renderers/data-display/avatar.tsx +9 -0
  202. package/src/renderers/data-display/badge.tsx +9 -0
  203. package/src/renderers/data-display/breadcrumb.tsx +60 -0
  204. package/src/renderers/data-display/index.ts +12 -0
  205. package/src/renderers/data-display/kbd.tsx +50 -0
  206. package/src/renderers/data-display/list.tsx +29 -49
  207. package/src/renderers/data-display/statistic.tsx +45 -48
  208. package/src/renderers/data-display/table.tsx +78 -0
  209. package/src/renderers/data-display/tree-view.tsx +32 -37
  210. package/src/renderers/disclosure/accordion.tsx +9 -0
  211. package/src/renderers/disclosure/collapsible.tsx +9 -0
  212. package/src/renderers/disclosure/index.ts +9 -0
  213. package/src/renderers/disclosure/toggle-group.tsx +79 -0
  214. package/src/renderers/feedback/empty.tsx +49 -0
  215. package/src/renderers/feedback/index.ts +12 -0
  216. package/src/renderers/feedback/loading.tsx +10 -1
  217. package/src/renderers/feedback/progress.tsx +9 -0
  218. package/src/renderers/feedback/skeleton.tsx +9 -0
  219. package/src/renderers/feedback/sonner.tsx +56 -0
  220. package/src/renderers/feedback/spinner.tsx +55 -0
  221. package/src/renderers/feedback/toast.tsx +59 -0
  222. package/src/renderers/feedback/toaster.tsx +14 -17
  223. package/src/renderers/form/button.tsx +43 -1
  224. package/src/renderers/form/calendar.tsx +9 -0
  225. package/src/renderers/form/checkbox.tsx +46 -16
  226. package/src/renderers/form/combobox.tsx +48 -0
  227. package/src/renderers/form/command.tsx +58 -0
  228. package/src/renderers/form/date-picker.tsx +11 -2
  229. package/src/renderers/form/file-upload.tsx +11 -2
  230. package/src/renderers/form/form.tsx +104 -18
  231. package/src/renderers/form/index.ts +10 -0
  232. package/src/renderers/form/input-otp.tsx +35 -15
  233. package/src/renderers/form/input.tsx +92 -50
  234. package/src/renderers/form/label.tsx +9 -0
  235. package/src/renderers/form/radio-group.tsx +9 -0
  236. package/src/renderers/form/select.tsx +43 -15
  237. package/src/renderers/form/slider.tsx +17 -1
  238. package/src/renderers/form/switch.tsx +9 -0
  239. package/src/renderers/form/textarea.tsx +58 -27
  240. package/src/renderers/form/toggle.tsx +11 -45
  241. package/src/renderers/index.ts +8 -0
  242. package/src/renderers/layout/aspect-ratio.tsx +51 -0
  243. package/src/renderers/layout/card.tsx +18 -2
  244. package/src/renderers/layout/container.tsx +21 -12
  245. package/src/renderers/layout/flex.tsx +17 -8
  246. package/src/renderers/layout/grid.tsx +31 -8
  247. package/src/renderers/layout/index.ts +9 -0
  248. package/src/renderers/layout/page.tsx +44 -24
  249. package/src/renderers/layout/semantic.tsx +9 -0
  250. package/src/renderers/layout/stack.tsx +18 -9
  251. package/src/renderers/layout/tabs.tsx +51 -17
  252. package/src/renderers/navigation/header-bar.tsx +10 -1
  253. package/src/renderers/navigation/index.ts +8 -0
  254. package/src/renderers/navigation/sidebar.tsx +13 -0
  255. package/src/renderers/overlay/alert-dialog.tsx +9 -0
  256. package/src/renderers/overlay/context-menu.tsx +10 -1
  257. package/src/renderers/overlay/dialog.tsx +9 -0
  258. package/src/renderers/overlay/drawer.tsx +9 -0
  259. package/src/renderers/overlay/dropdown-menu.tsx +9 -0
  260. package/src/renderers/overlay/hover-card.tsx +9 -0
  261. package/src/renderers/overlay/index.ts +9 -0
  262. package/src/renderers/overlay/menubar.tsx +76 -0
  263. package/src/renderers/overlay/popover.tsx +9 -0
  264. package/src/renderers/overlay/sheet.tsx +9 -0
  265. package/src/renderers/overlay/tooltip.tsx +9 -0
  266. package/src/renderers/placeholders.tsx +107 -0
  267. package/src/stories/CRMApp.stories.tsx +706 -0
  268. package/src/stories/Guide.mdx +55 -0
  269. package/src/stories/Introduction.mdx +34 -0
  270. package/src/stories/MockedData.stories.tsx +71 -0
  271. package/src/stories/assets/accessibility.png +0 -0
  272. package/src/stories/assets/accessibility.svg +1 -0
  273. package/src/stories/assets/addon-library.png +0 -0
  274. package/src/stories/assets/assets.png +0 -0
  275. package/src/stories/assets/avif-test-image.avif +0 -0
  276. package/src/stories/assets/context.png +0 -0
  277. package/src/stories/assets/discord.svg +1 -0
  278. package/src/stories/assets/docs.png +0 -0
  279. package/src/stories/assets/figma-plugin.png +0 -0
  280. package/src/stories/assets/github.svg +1 -0
  281. package/src/stories/assets/share.png +0 -0
  282. package/src/stories/assets/styling.png +0 -0
  283. package/src/stories/assets/testing.png +0 -0
  284. package/src/stories/assets/theming.png +0 -0
  285. package/src/stories/assets/tutorials.svg +1 -0
  286. package/src/stories/assets/youtube.svg +1 -0
  287. package/src/stories/button.css +30 -0
  288. package/src/stories/header.css +32 -0
  289. package/src/stories/page.css +68 -0
  290. package/src/stories-json/accordion.stories.tsx +43 -0
  291. package/src/stories-json/aggrid.stories.tsx +103 -0
  292. package/src/stories-json/alert.stories.tsx +39 -0
  293. package/src/stories-json/aspect-ratio.stories.tsx +34 -0
  294. package/src/stories-json/avatar.stories.tsx +38 -0
  295. package/src/stories-json/badge.stories.tsx +53 -0
  296. package/src/stories-json/breadcrumb.stories.tsx +30 -0
  297. package/src/stories-json/button-group.stories.tsx +43 -0
  298. package/src/stories-json/button.stories.tsx +73 -0
  299. package/src/stories-json/calendar.stories.tsx +85 -0
  300. package/src/stories-json/card.stories.tsx +48 -0
  301. package/src/stories-json/carousel.stories.tsx +33 -0
  302. package/src/stories-json/charts.stories.tsx +195 -0
  303. package/src/stories-json/chatbot.stories.tsx +248 -0
  304. package/src/stories-json/code-editor.stories.tsx +92 -0
  305. package/src/stories-json/collapsible.stories.tsx +40 -0
  306. package/src/stories-json/controls.stories.tsx +36 -0
  307. package/src/stories-json/dashboard.stories.tsx +318 -0
  308. package/src/stories-json/data-table.stories.tsx +60 -0
  309. package/src/stories-json/data_display_extras.stories.tsx +102 -0
  310. package/src/stories-json/date-picker.stories.tsx +28 -0
  311. package/src/stories-json/detail-view.stories.tsx +258 -0
  312. package/src/stories-json/dialog.stories.tsx +43 -0
  313. package/src/stories-json/feedback_extras.stories.tsx +40 -0
  314. package/src/stories-json/feedback_others.stories.tsx +46 -0
  315. package/src/stories-json/form_advanced.stories.tsx +117 -0
  316. package/src/stories-json/form_extras.stories.tsx +123 -0
  317. package/src/stories-json/grid.stories.tsx +56 -0
  318. package/src/stories-json/icon.stories.tsx +36 -0
  319. package/src/stories-json/input.stories.tsx +52 -0
  320. package/src/stories-json/kanban.stories.tsx +295 -0
  321. package/src/stories-json/layout_extended.stories.tsx +76 -0
  322. package/src/stories-json/layout_flex.stories.tsx +107 -0
  323. package/src/stories-json/list-view.stories.tsx +97 -0
  324. package/src/stories-json/markdown.stories.tsx +129 -0
  325. package/src/stories-json/menus.stories.tsx +63 -0
  326. package/src/stories-json/metric-card.stories.tsx +143 -0
  327. package/src/stories-json/navigation-menu.stories.tsx +37 -0
  328. package/src/stories-json/object-aggrid.stories.tsx +252 -0
  329. package/src/stories-json/object-form.stories.tsx +130 -0
  330. package/src/stories-json/object-gantt.stories.tsx +114 -0
  331. package/src/stories-json/object-grid.stories.tsx +157 -0
  332. package/src/stories-json/object-map.stories.tsx +116 -0
  333. package/src/stories-json/object-view.stories.tsx +118 -0
  334. package/src/stories-json/overlay_extras.stories.tsx +113 -0
  335. package/src/stories-json/overlay_others.stories.tsx +76 -0
  336. package/src/stories-json/page.stories.tsx +55 -0
  337. package/src/stories-json/reports.stories.tsx +163 -0
  338. package/src/stories-json/resizable.stories.tsx +44 -0
  339. package/src/stories-json/select.stories.tsx +34 -0
  340. package/src/stories-json/separator.stories.tsx +41 -0
  341. package/src/stories-json/sidebar.stories.tsx +147 -0
  342. package/src/stories-json/statistic.stories.tsx +44 -0
  343. package/src/stories-json/tabs.stories.tsx +51 -0
  344. package/src/stories-json/timeline.stories.tsx +188 -0
  345. package/src/stories-json/typography.stories.tsx +45 -0
  346. package/src/ui/accordion.tsx +55 -53
  347. package/src/ui/alert-dialog.tsx +111 -117
  348. package/src/ui/alert.tsx +46 -57
  349. package/src/ui/aspect-ratio.tsx +9 -5
  350. package/src/ui/avatar.tsx +49 -42
  351. package/src/ui/badge.tsx +18 -20
  352. package/src/ui/breadcrumb.tsx +89 -75
  353. package/src/ui/button.tsx +38 -37
  354. package/src/ui/calendar.tsx +37 -53
  355. package/src/ui/card.tsx +59 -110
  356. package/src/ui/carousel.tsx +144 -113
  357. package/src/ui/chart.tsx +367 -0
  358. package/src/ui/checkbox.tsx +28 -22
  359. package/src/ui/collapsible.tsx +13 -25
  360. package/src/ui/command.tsx +114 -135
  361. package/src/ui/context-menu.tsx +77 -116
  362. package/src/ui/dialog.tsx +102 -113
  363. package/src/ui/drawer.tsx +90 -99
  364. package/src/ui/dropdown-menu.tsx +142 -188
  365. package/src/ui/form.tsx +59 -40
  366. package/src/ui/hover-card.tsx +26 -33
  367. package/src/ui/index.ts +11 -11
  368. package/src/ui/input-otp.tsx +53 -55
  369. package/src/ui/input.tsx +21 -15
  370. package/src/ui/label.tsx +25 -15
  371. package/src/ui/menubar.tsx +196 -206
  372. package/src/ui/navigation-menu.tsx +104 -136
  373. package/src/ui/pagination.tsx +94 -96
  374. package/src/ui/popover.tsx +29 -38
  375. package/src/ui/progress.tsx +29 -34
  376. package/src/ui/radio-group.tsx +27 -20
  377. package/src/ui/resizable.tsx +40 -42
  378. package/src/ui/scroll-area.tsx +46 -48
  379. package/src/ui/select.tsx +140 -160
  380. package/src/ui/separator.tsx +10 -2
  381. package/src/ui/sheet.tsx +118 -107
  382. package/src/ui/sidebar.tsx +471 -418
  383. package/src/ui/skeleton.tsx +14 -11
  384. package/src/ui/slider.tsx +27 -54
  385. package/src/ui/sonner.tsx +29 -19
  386. package/src/ui/switch.tsx +27 -21
  387. package/src/ui/table.tsx +102 -97
  388. package/src/ui/tabs.tsx +14 -37
  389. package/src/ui/textarea.tsx +16 -4
  390. package/src/ui/toast.tsx +137 -0
  391. package/src/ui/toggle-group.tsx +37 -55
  392. package/src/ui/toggle.tsx +30 -27
  393. package/src/ui/tooltip.tsx +29 -52
  394. package/src/ui/typography.tsx +85 -0
  395. package/tsconfig.json +2 -1
  396. package/vite.config.ts +20 -2
  397. package/vitest.config.ts +5 -0
  398. package/dist/src/index.test.d.ts +0 -1
  399. package/dist/src/new-components.test.d.ts +0 -1
  400. package/dist/src/renderers/complex/__tests__/data-table.test.d.ts +0 -0
  401. package/dist/src/renderers/complex/calendar-view.d.ts +0 -1
  402. package/dist/src/renderers/complex/chatbot.d.ts +0 -1
  403. package/dist/src/renderers/complex/chatbot.test.d.ts +0 -1
  404. package/dist/src/renderers/complex/timeline.d.ts +0 -1
  405. package/dist/src/ui/calendar-view.d.ts +0 -21
  406. package/dist/src/ui/chatbot.d.ts +0 -36
  407. package/dist/src/ui/field.d.ts +0 -24
  408. package/dist/src/ui/input-group.d.ts +0 -16
  409. package/dist/src/ui/spinner.d.ts +0 -3
  410. package/dist/src/ui/timeline.d.ts +0 -25
  411. package/metadata/ObjectTable.component.yml +0 -41
  412. package/src/renderers/complex/calendar-view.tsx +0 -219
  413. package/src/renderers/complex/chatbot.test.ts +0 -44
  414. package/src/renderers/complex/chatbot.tsx +0 -185
  415. package/src/renderers/complex/timeline.tsx +0 -466
  416. package/src/ui/calendar-view.tsx +0 -503
  417. package/src/ui/chatbot.tsx +0 -240
  418. package/src/ui/field.tsx +0 -246
  419. package/src/ui/input-group.tsx +0 -170
  420. package/src/ui/spinner.tsx +0 -38
  421. package/src/ui/timeline.tsx +0 -266
  422. package/tailwind.config.js +0 -75
  423. /package/dist/src/{ui → custom}/empty.d.ts +0 -0
@@ -0,0 +1,129 @@
1
+ import type { Meta, StoryObj } from '@storybook/react';
2
+ import { SchemaRenderer } from '../SchemaRenderer';
3
+ import type { BaseSchema } from '@object-ui/types';
4
+
5
+ const meta = {
6
+ title: 'Views/Markdown',
7
+ component: SchemaRenderer,
8
+ parameters: {
9
+ layout: 'padded',
10
+ },
11
+ tags: ['autodocs'],
12
+ argTypes: {
13
+ schema: { table: { disable: true } },
14
+ },
15
+ } satisfies Meta<any>;
16
+
17
+ export default meta;
18
+ type Story = StoryObj<typeof meta>;
19
+
20
+ const renderStory = (args: any) => <SchemaRenderer schema={args as unknown as BaseSchema} />;
21
+
22
+ export const Default: Story = {
23
+ render: renderStory,
24
+ args: {
25
+ type: 'markdown',
26
+ content: '# Hello World\n\nThis is a **markdown** component with *formatting* support.\n\n- Item 1\n- Item 2\n- Item 3'
27
+ } as any,
28
+ };
29
+
30
+ export const CompleteExample: Story = {
31
+ render: renderStory,
32
+ args: {
33
+ type: 'markdown',
34
+ content: `# ObjectUI Documentation
35
+
36
+ ## Introduction
37
+
38
+ ObjectUI is a **Universal, Server-Driven UI (SDUI) Engine** built on React + Tailwind + Shadcn.
39
+
40
+ ### Key Features
41
+
42
+ - 🚀 JSON-based component definitions
43
+ - 🎨 Beautiful UI with Shadcn components
44
+ - ⚡ Fast and lightweight
45
+ - 🔧 Fully customizable
46
+
47
+ ### Installation
48
+
49
+ \`\`\`bash
50
+ npm install @object-ui/react
51
+ \`\`\`
52
+
53
+ ### Quick Start
54
+
55
+ \`\`\`javascript
56
+ import { SchemaRenderer } from '@object-ui/react';
57
+
58
+ const schema = {
59
+ type: 'button',
60
+ children: [{ type: 'text', content: 'Click Me' }]
61
+ };
62
+
63
+ <SchemaRenderer schema={schema} />
64
+ \`\`\`
65
+
66
+ > **Note:** This is just a sample documentation.
67
+
68
+ For more information, visit our [website](https://objectui.dev).
69
+ `
70
+ } as any,
71
+ };
72
+
73
+ export const CodeExample: Story = {
74
+ render: renderStory,
75
+ args: {
76
+ type: 'markdown',
77
+ content: `## Code Snippets
78
+
79
+ Here's how to create a button component:
80
+
81
+ \`\`\`json
82
+ {
83
+ "type": "button",
84
+ "props": {
85
+ "variant": "default"
86
+ },
87
+ "children": [
88
+ {
89
+ "type": "text",
90
+ "content": "Click Me"
91
+ }
92
+ ]
93
+ }
94
+ \`\`\`
95
+
96
+ And here's a TypeScript example:
97
+
98
+ \`\`\`typescript
99
+ interface ButtonSchema {
100
+ type: 'button';
101
+ props?: {
102
+ variant?: 'default' | 'outline' | 'ghost';
103
+ };
104
+ children?: BaseSchema[];
105
+ }
106
+ \`\`\`
107
+ `
108
+ } as any,
109
+ };
110
+
111
+ export const TableExample: Story = {
112
+ render: renderStory,
113
+ args: {
114
+ type: 'markdown',
115
+ content: `## Component Comparison
116
+
117
+ | Feature | ObjectUI | Traditional |
118
+ |---------|----------|-------------|
119
+ | Development Speed | ⚡ Fast | 🐌 Slow |
120
+ | Flexibility | 🔥 High | ⭐ Medium |
121
+ | Learning Curve | 📚 Easy | 🎓 Steep |
122
+ | Performance | 🚀 Excellent | ✅ Good |
123
+
124
+ ### Conclusion
125
+
126
+ ObjectUI provides a modern approach to building user interfaces with better development speed and flexibility.
127
+ `
128
+ } as any,
129
+ };
@@ -0,0 +1,63 @@
1
+ import type { Meta, StoryObj } from '@storybook/react';
2
+ import { SchemaRenderer } from '../SchemaRenderer';
3
+ import type { BaseSchema } from '@object-ui/types';
4
+
5
+ const meta = {
6
+ title: 'Components/Menus',
7
+ component: SchemaRenderer,
8
+ parameters: { layout: 'centered' },
9
+ tags: ['autodocs'],
10
+ argTypes: {
11
+ schema: { table: { disable: true } }
12
+ }
13
+ } satisfies Meta<typeof SchemaRenderer>;
14
+
15
+ export default meta;
16
+ type Story = StoryObj<typeof meta>;
17
+
18
+ const renderStory = (args: any) => <SchemaRenderer schema={args as unknown as BaseSchema} />;
19
+
20
+ export const DropdownMenu: Story = {
21
+ render: renderStory,
22
+ args: {
23
+ type: 'dropdown-menu',
24
+ trigger: [
25
+ { type: 'button', props: { variant: 'outline' }, children: [{type:'text', content: 'Open Menu'}] }
26
+ ],
27
+ label: 'My Account',
28
+ items: [
29
+ { label: 'Profile', shortcut: '⇧⌘P' },
30
+ { label: 'Billing', shortcut: '⌘B' },
31
+ { label: 'Settings', shortcut: '⌘S' },
32
+ { type: 'separator' },
33
+ { label: 'Team', children: [
34
+ { label: 'Invite users' },
35
+ { label: 'Create team' },
36
+ ]},
37
+ { type: 'separator' },
38
+ { label: 'Log out', shortcut: '⇧⌘Q' }
39
+ ]
40
+ } as any,
41
+ };
42
+
43
+ export const Sheet: Story = {
44
+ render: renderStory,
45
+ args: {
46
+ type: 'sheet',
47
+ trigger: [
48
+ { type: 'button', props: { variant: 'outline' }, children: [{type: 'text', content: 'Open Sheet'}] }
49
+ ],
50
+ title: 'Schema/Navigation/Edit profile',
51
+ description: 'Make changes to your profile here. Click save when you\'re done.',
52
+ side: 'right',
53
+ content: [
54
+ { type: 'div', className: 'grid gap-4 py-4', children: [
55
+ { type: 'input', label: 'Name', defaultValue: 'Pedro Duarte', wrapperClass: 'grid grid-cols-4 items-center gap-4' },
56
+ { type: 'input', label: 'Username', defaultValue: '@peduarte', wrapperClass: 'grid grid-cols-4 items-center gap-4' }
57
+ ]}
58
+ ],
59
+ footer: [
60
+ { type: 'button', children: [{type: 'text', content: 'Save changes'}] }
61
+ ]
62
+ } as any,
63
+ };
@@ -0,0 +1,143 @@
1
+ import type { Meta, StoryObj } from '@storybook/react';
2
+ import { SchemaRenderer } from '../SchemaRenderer';
3
+ import type { BaseSchema } from '@object-ui/types';
4
+
5
+ const meta = {
6
+ title: 'Components/Data Display/Metric Card',
7
+ component: SchemaRenderer,
8
+ parameters: {
9
+ layout: 'padded',
10
+ },
11
+ tags: ['autodocs'],
12
+ argTypes: {
13
+ schema: { table: { disable: true } },
14
+ },
15
+ } satisfies Meta<any>;
16
+
17
+ export default meta;
18
+ type Story = StoryObj<typeof meta>;
19
+
20
+ const renderStory = (args: any) => <SchemaRenderer schema={args as unknown as BaseSchema} />;
21
+
22
+ export const Default: Story = {
23
+ render: renderStory,
24
+ args: {
25
+ type: 'metric-card',
26
+ title: 'Total Revenue',
27
+ value: '$45,231.89',
28
+ } as any,
29
+ };
30
+
31
+ export const WithIcon: Story = {
32
+ render: renderStory,
33
+ args: {
34
+ type: 'metric-card',
35
+ title: 'Total Revenue',
36
+ value: '$45,231.89',
37
+ icon: 'DollarSign',
38
+ } as any,
39
+ };
40
+
41
+ export const WithTrendUp: Story = {
42
+ render: renderStory,
43
+ args: {
44
+ type: 'metric-card',
45
+ title: 'Total Revenue',
46
+ value: '$45,231.89',
47
+ icon: 'DollarSign',
48
+ trend: 'up',
49
+ trendValue: '+20.1%',
50
+ description: 'from last month'
51
+ } as any,
52
+ };
53
+
54
+ export const WithTrendDown: Story = {
55
+ render: renderStory,
56
+ args: {
57
+ type: 'metric-card',
58
+ title: 'Bounce Rate',
59
+ value: '2.4%',
60
+ icon: 'TrendingDown',
61
+ trend: 'down',
62
+ trendValue: '-5.2%',
63
+ description: 'from last month'
64
+ } as any,
65
+ };
66
+
67
+ export const WithTrendNeutral: Story = {
68
+ render: renderStory,
69
+ args: {
70
+ type: 'metric-card',
71
+ title: 'Active Users',
72
+ value: '1,234',
73
+ icon: 'Users',
74
+ trend: 'neutral',
75
+ trendValue: '0%',
76
+ description: 'no change'
77
+ } as any,
78
+ };
79
+
80
+ export const MultipleMetrics: Story = {
81
+ render: renderStory,
82
+ args: {
83
+ type: 'flex',
84
+ direction: 'row',
85
+ gap: 4,
86
+ children: [
87
+ {
88
+ type: 'metric-card',
89
+ title: 'Total Revenue',
90
+ value: '$45,231.89',
91
+ icon: 'DollarSign',
92
+ trend: 'up',
93
+ trendValue: '+20.1%',
94
+ description: 'from last month',
95
+ className: 'flex-1'
96
+ },
97
+ {
98
+ type: 'metric-card',
99
+ title: 'New Customers',
100
+ value: '+2,350',
101
+ icon: 'Users',
102
+ trend: 'up',
103
+ trendValue: '+180.1%',
104
+ description: 'from last month',
105
+ className: 'flex-1'
106
+ },
107
+ {
108
+ type: 'metric-card',
109
+ title: 'Active Sessions',
110
+ value: '+573',
111
+ icon: 'Activity',
112
+ trend: 'up',
113
+ trendValue: '+201',
114
+ description: 'since last hour',
115
+ className: 'flex-1'
116
+ }
117
+ ]
118
+ } as any,
119
+ };
120
+
121
+ export const LargeNumbers: Story = {
122
+ render: renderStory,
123
+ args: {
124
+ type: 'metric-card',
125
+ title: 'Total Views',
126
+ value: '1,234,567',
127
+ icon: 'Eye',
128
+ trend: 'up',
129
+ trendValue: '+45.2%',
130
+ description: 'from last quarter'
131
+ } as any,
132
+ };
133
+
134
+ export const WithDescription: Story = {
135
+ render: renderStory,
136
+ args: {
137
+ type: 'metric-card',
138
+ title: 'Conversion Rate',
139
+ value: '12.5%',
140
+ icon: 'Target',
141
+ description: 'above industry average'
142
+ } as any,
143
+ };
@@ -0,0 +1,37 @@
1
+ import type { Meta, StoryObj } from '@storybook/react';
2
+ import { SchemaRenderer } from '../SchemaRenderer';
3
+ import type { BaseSchema } from '@object-ui/types';
4
+
5
+ const meta = {
6
+ title: 'Components/Navigation Menu',
7
+ component: SchemaRenderer,
8
+ parameters: { layout: 'centered' },
9
+ tags: ['autodocs'],
10
+ argTypes: {
11
+ schema: { table: { disable: true } }
12
+ }
13
+ } satisfies Meta<typeof SchemaRenderer>;
14
+
15
+ export default meta;
16
+ type Story = StoryObj<typeof meta>;
17
+
18
+ const renderStory = (args: any) => <SchemaRenderer schema={args as unknown as BaseSchema} />;
19
+
20
+ export const Default: Story = {
21
+ render: renderStory,
22
+ args: {
23
+ type: 'navigation-menu',
24
+ items: [
25
+ { label: 'Home', href: '#' },
26
+ {
27
+ label: 'Products',
28
+ children: [
29
+ { label: 'Analytics', description: 'Get insights into who is clicking your links', href: '#' },
30
+ { label: 'Engagement', description: 'Measure active engagement with your brand', href: '#' },
31
+ { label: 'Security', description: 'Advanced security features', href: '#' }
32
+ ]
33
+ },
34
+ { label: 'Pricing', href: '#' }
35
+ ]
36
+ } as any,
37
+ };
@@ -0,0 +1,252 @@
1
+ import type { Meta, StoryObj } from '@storybook/react';
2
+ import { SchemaRenderer } from '../SchemaRenderer';
3
+ import type { BaseSchema } from '@object-ui/types';
4
+ import { ObjectStackAdapter } from '@object-ui/data-objectstack';
5
+
6
+ const meta = {
7
+ title: 'Views/Object Data Grid (ObjectAgGrid)',
8
+ component: SchemaRenderer,
9
+ parameters: {
10
+ layout: 'padded',
11
+ },
12
+ tags: ['autodocs'],
13
+ argTypes: {
14
+ schema: { table: { disable: true } },
15
+ },
16
+ } satisfies Meta<any>;
17
+
18
+ export default meta;
19
+ type Story = StoryObj<typeof meta>;
20
+
21
+ const renderStory = (args: any) => <SchemaRenderer schema={args as unknown as BaseSchema} />;
22
+
23
+ // Mock data source for demonstration
24
+ const createMockDataSource = (objectName: string, data: any[]) => {
25
+ const mockSchema = {
26
+ name: objectName,
27
+ label: objectName.charAt(0).toUpperCase() + objectName.slice(1),
28
+ fields: {} as any
29
+ };
30
+
31
+ // Infer fields from data
32
+ if (data.length > 0) {
33
+ const firstRow = data[0];
34
+ Object.keys(firstRow).forEach(key => {
35
+ let type = 'text';
36
+ const value = firstRow[key];
37
+
38
+ if (typeof value === 'number') type = 'number';
39
+ else if (typeof value === 'boolean') type = 'boolean';
40
+ else if (key.includes('email')) type = 'email';
41
+ else if (key.includes('phone')) type = 'phone';
42
+ else if (key.includes('url') || key.includes('website')) type = 'url';
43
+ else if (key.includes('date')) type = 'date';
44
+ else if (key.includes('price') || key.includes('cost') || key.includes('amount')) type = 'currency';
45
+ else if (key.includes('percent') || key.includes('rate')) type = 'percent';
46
+
47
+ mockSchema.fields[key] = {
48
+ name: key,
49
+ label: key.charAt(0).toUpperCase() + key.slice(1).replace(/_/g, ' '),
50
+ type,
51
+ sortable: true,
52
+ filterable: true
53
+ };
54
+ });
55
+ }
56
+
57
+ return {
58
+ find: async () => ({
59
+ data,
60
+ total: data.length,
61
+ page: 1,
62
+ pageSize: data.length,
63
+ hasMore: false
64
+ }),
65
+ getObjectSchema: async () => mockSchema
66
+ };
67
+ };
68
+
69
+ const contactsData = [
70
+ {
71
+ id: '1',
72
+ name: 'John Doe',
73
+ email: 'john.doe@example.com',
74
+ phone: '+1-555-0101',
75
+ company: 'Acme Corp',
76
+ status: 'Active',
77
+ created_date: '2024-01-15'
78
+ },
79
+ {
80
+ id: '2',
81
+ name: 'Jane Smith',
82
+ email: 'jane.smith@example.com',
83
+ phone: '+1-555-0102',
84
+ company: 'Tech Solutions',
85
+ status: 'Active',
86
+ created_date: '2024-01-20'
87
+ },
88
+ {
89
+ id: '3',
90
+ name: 'Bob Johnson',
91
+ email: 'bob.johnson@example.com',
92
+ phone: '+1-555-0103',
93
+ company: 'Innovate Inc',
94
+ status: 'Inactive',
95
+ created_date: '2024-02-01'
96
+ },
97
+ {
98
+ id: '4',
99
+ name: 'Alice Williams',
100
+ email: 'alice.w@example.com',
101
+ phone: '+1-555-0104',
102
+ company: 'Creative Studio',
103
+ status: 'Active',
104
+ created_date: '2024-02-10'
105
+ },
106
+ {
107
+ id: '5',
108
+ name: 'Charlie Brown',
109
+ email: 'charlie.b@example.com',
110
+ phone: '+1-555-0105',
111
+ company: 'Digital Agency',
112
+ status: 'Active',
113
+ created_date: '2024-02-15'
114
+ },
115
+ ];
116
+
117
+ const productsData = [
118
+ {
119
+ id: '1',
120
+ name: 'Laptop Pro',
121
+ category: 'Electronics',
122
+ price: 1299.99,
123
+ stock: 45,
124
+ rating: 4.5,
125
+ available: true
126
+ },
127
+ {
128
+ id: '2',
129
+ name: 'Wireless Mouse',
130
+ category: 'Electronics',
131
+ price: 29.99,
132
+ stock: 150,
133
+ rating: 4.2,
134
+ available: true
135
+ },
136
+ {
137
+ id: '3',
138
+ name: 'Desk Chair',
139
+ category: 'Furniture',
140
+ price: 299.99,
141
+ stock: 20,
142
+ rating: 4.8,
143
+ available: true
144
+ },
145
+ {
146
+ id: '4',
147
+ name: 'Monitor 27"',
148
+ category: 'Electronics',
149
+ price: 399.99,
150
+ stock: 35,
151
+ rating: 4.6,
152
+ available: true
153
+ },
154
+ {
155
+ id: '5',
156
+ name: 'Keyboard Mechanical',
157
+ category: 'Electronics',
158
+ price: 149.99,
159
+ stock: 60,
160
+ rating: 4.7,
161
+ available: false
162
+ },
163
+ ];
164
+
165
+ export const ContactsGrid: Story = {
166
+ render: renderStory,
167
+ args: {
168
+ type: 'object-aggrid',
169
+ objectName: 'contacts',
170
+ dataSource: createMockDataSource('contacts', contactsData),
171
+ pagination: true,
172
+ pageSize: 10,
173
+ theme: 'quartz',
174
+ height: 500,
175
+ animateRows: true,
176
+ columnConfig: {
177
+ resizable: true,
178
+ sortable: true,
179
+ filterable: true
180
+ }
181
+ } as any,
182
+ };
183
+
184
+ export const ProductsGrid: Story = {
185
+ render: renderStory,
186
+ args: {
187
+ type: 'object-aggrid',
188
+ objectName: 'products',
189
+ dataSource: createMockDataSource('products', productsData),
190
+ pagination: true,
191
+ pageSize: 10,
192
+ theme: 'quartz',
193
+ height: 500,
194
+ animateRows: true,
195
+ columnConfig: {
196
+ resizable: true,
197
+ sortable: true,
198
+ filterable: true
199
+ }
200
+ } as any,
201
+ };
202
+
203
+ export const WithFieldSelection: Story = {
204
+ render: renderStory,
205
+ args: {
206
+ type: 'object-aggrid',
207
+ objectName: 'contacts',
208
+ dataSource: createMockDataSource('contacts', contactsData),
209
+ fieldNames: ['name', 'email', 'company', 'status'],
210
+ pagination: true,
211
+ pageSize: 10,
212
+ theme: 'alpine',
213
+ height: 400
214
+ } as any,
215
+ };
216
+
217
+ export const EditableGrid: Story = {
218
+ render: renderStory,
219
+ args: {
220
+ type: 'object-aggrid',
221
+ objectName: 'products',
222
+ dataSource: createMockDataSource('products', productsData),
223
+ editable: true,
224
+ singleClickEdit: true,
225
+ pagination: true,
226
+ pageSize: 10,
227
+ theme: 'quartz',
228
+ height: 500,
229
+ columnConfig: {
230
+ resizable: true,
231
+ sortable: true,
232
+ filterable: true
233
+ }
234
+ } as any,
235
+ };
236
+
237
+ export const WithExport: Story = {
238
+ render: renderStory,
239
+ args: {
240
+ type: 'object-aggrid',
241
+ objectName: 'contacts',
242
+ dataSource: createMockDataSource('contacts', contactsData),
243
+ pagination: true,
244
+ pageSize: 10,
245
+ theme: 'quartz',
246
+ height: 500,
247
+ exportConfig: {
248
+ enabled: true,
249
+ fileName: 'contacts-export.csv'
250
+ }
251
+ } as any,
252
+ };