@object-ui/components 3.1.5 → 3.3.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 (495) hide show
  1. package/CHANGELOG.md +38 -0
  2. package/README.md +21 -1
  3. package/dist/index.css +6339 -2
  4. package/dist/index.d.ts +1 -1
  5. package/dist/index.js +31896 -31523
  6. package/dist/index.umd.cjs +40 -40
  7. package/dist/{src → packages/components/src}/custom/empty.d.ts +12 -1
  8. package/dist/{src → packages/components/src}/custom/mobile-dialog-content.d.ts +1 -1
  9. package/dist/{src → packages/components/src}/renderers/action/action-bar.d.ts +12 -1
  10. package/dist/{src → packages/components/src}/ui/accordion.d.ts +1 -1
  11. package/dist/{src → packages/components/src}/ui/alert-dialog.d.ts +1 -1
  12. package/dist/packages/components/src/ui/aspect-ratio.d.ts +10 -0
  13. package/dist/{src → packages/components/src}/ui/avatar.d.ts +1 -1
  14. package/dist/{src → packages/components/src}/ui/button.d.ts +1 -1
  15. package/dist/packages/components/src/ui/chart.d.ts +56 -0
  16. package/dist/{src → packages/components/src}/ui/checkbox.d.ts +1 -1
  17. package/dist/{src → packages/components/src}/ui/collapsible.d.ts +8 -1
  18. package/dist/{src → packages/components/src}/ui/command.d.ts +2 -2
  19. package/dist/{src → packages/components/src}/ui/context-menu.d.ts +1 -1
  20. package/dist/{src → packages/components/src}/ui/dialog.d.ts +1 -1
  21. package/dist/{src → packages/components/src}/ui/drawer.d.ts +6 -10
  22. package/dist/{src → packages/components/src}/ui/dropdown-menu.d.ts +1 -1
  23. package/dist/{src → packages/components/src}/ui/form.d.ts +2 -2
  24. package/dist/{src → packages/components/src}/ui/hover-card.d.ts +1 -1
  25. package/dist/{src → packages/components/src}/ui/label.d.ts +1 -1
  26. package/dist/{src → packages/components/src}/ui/menubar.d.ts +1 -1
  27. package/dist/{src → packages/components/src}/ui/navigation-menu.d.ts +1 -1
  28. package/dist/{src → packages/components/src}/ui/popover.d.ts +1 -1
  29. package/dist/{src → packages/components/src}/ui/progress.d.ts +1 -1
  30. package/dist/{src → packages/components/src}/ui/radio-group.d.ts +1 -1
  31. package/dist/packages/components/src/ui/resizable.d.ts +7 -0
  32. package/dist/{src → packages/components/src}/ui/scroll-area.d.ts +1 -1
  33. package/dist/{src → packages/components/src}/ui/select.d.ts +1 -1
  34. package/dist/{src → packages/components/src}/ui/separator.d.ts +1 -1
  35. package/dist/{src → packages/components/src}/ui/sheet.d.ts +1 -2
  36. package/dist/{src → packages/components/src}/ui/sidebar.d.ts +1 -8
  37. package/dist/{src → packages/components/src}/ui/slider.d.ts +1 -1
  38. package/dist/{src → packages/components/src}/ui/switch.d.ts +1 -1
  39. package/dist/{src → packages/components/src}/ui/tabs.d.ts +1 -1
  40. package/dist/{src → packages/components/src}/ui/toast.d.ts +1 -1
  41. package/dist/{src → packages/components/src}/ui/toggle-group.d.ts +1 -1
  42. package/dist/{src → packages/components/src}/ui/toggle.d.ts +1 -1
  43. package/dist/{src → packages/components/src}/ui/tooltip.d.ts +1 -1
  44. package/package.json +68 -20
  45. package/.turbo/turbo-build.log +0 -64
  46. package/README_SHADCN_SYNC.md +0 -281
  47. package/TESTING.md +0 -335
  48. package/dist/src/ui/aspect-ratio.d.ts +0 -3
  49. package/dist/src/ui/chart.d.ts +0 -68
  50. package/dist/src/ui/resizable.d.ts +0 -14
  51. package/docs/FilterBuilder.md +0 -268
  52. package/metadata/Chart.component.yml +0 -30
  53. package/metadata/FilterBuilder.component.yml +0 -39
  54. package/metadata/GridLayout.component.yml +0 -27
  55. package/metadata/Menu.component.yml +0 -31
  56. package/metadata/ObjectForm.component.yml +0 -34
  57. package/metadata/ObjectGrid.component.yml +0 -72
  58. package/metadata/Page.component.yml +0 -24
  59. package/postcss.config.js +0 -14
  60. package/shadcn-components.json +0 -440
  61. package/src/SchemaRenderer.tsx +0 -28
  62. package/src/__tests__/PageRendererRegions.test.tsx +0 -668
  63. package/src/__tests__/README.md +0 -124
  64. package/src/__tests__/__snapshots__/snapshot-critical.test.tsx.snap +0 -811
  65. package/src/__tests__/__snapshots__/snapshot.test.tsx.snap +0 -327
  66. package/src/__tests__/accessibility.test.tsx +0 -137
  67. package/src/__tests__/action-bar.test.tsx +0 -206
  68. package/src/__tests__/api-consistency.test.tsx +0 -596
  69. package/src/__tests__/basic-renderers.test.tsx +0 -255
  70. package/src/__tests__/color-contrast.test.tsx +0 -212
  71. package/src/__tests__/complex-disclosure-renderers.test.tsx +0 -302
  72. package/src/__tests__/compliance.test.tsx +0 -72
  73. package/src/__tests__/config-field-renderer.test.tsx +0 -307
  74. package/src/__tests__/config-panel-renderer.test.tsx +0 -580
  75. package/src/__tests__/config-primitives.test.tsx +0 -106
  76. package/src/__tests__/edge-cases.test.tsx +0 -285
  77. package/src/__tests__/feedback-overlay-renderers.test.tsx +0 -349
  78. package/src/__tests__/filter-builder.test.tsx +0 -409
  79. package/src/__tests__/form-renderers.test.tsx +0 -364
  80. package/src/__tests__/layout-data-renderers.test.tsx +0 -340
  81. package/src/__tests__/mobile-accessibility.test.tsx +0 -120
  82. package/src/__tests__/navigation-overlay.test.tsx +0 -370
  83. package/src/__tests__/snapshot-critical.test.tsx +0 -317
  84. package/src/__tests__/snapshot.test.tsx +0 -205
  85. package/src/__tests__/test-utils.tsx +0 -190
  86. package/src/__tests__/use-config-draft.test.tsx +0 -295
  87. package/src/__tests__/view-compliance.test.tsx +0 -153
  88. package/src/__tests__/wcag-audit.test.tsx +0 -493
  89. package/src/custom/action-param-dialog.tsx +0 -264
  90. package/src/custom/button-group.tsx +0 -91
  91. package/src/custom/combobox.tsx +0 -104
  92. package/src/custom/config-field-renderer.tsx +0 -276
  93. package/src/custom/config-panel-renderer.tsx +0 -306
  94. package/src/custom/config-row.tsx +0 -50
  95. package/src/custom/date-picker.tsx +0 -61
  96. package/src/custom/empty.tsx +0 -112
  97. package/src/custom/field.tsx +0 -81
  98. package/src/custom/filter-builder.tsx +0 -418
  99. package/src/custom/index.ts +0 -21
  100. package/src/custom/input-group.tsx +0 -53
  101. package/src/custom/item.tsx +0 -201
  102. package/src/custom/kbd.tsx +0 -36
  103. package/src/custom/mobile-dialog-content.tsx +0 -67
  104. package/src/custom/native-select.tsx +0 -33
  105. package/src/custom/navigation-overlay.tsx +0 -334
  106. package/src/custom/section-header.tsx +0 -68
  107. package/src/custom/sort-builder.tsx +0 -129
  108. package/src/custom/spinner.tsx +0 -26
  109. package/src/custom/view-skeleton.tsx +0 -243
  110. package/src/custom/view-states.tsx +0 -153
  111. package/src/debug/DebugPanel.tsx +0 -313
  112. package/src/debug/__tests__/DebugPanel.test.tsx +0 -134
  113. package/src/debug/index.ts +0 -10
  114. package/src/hooks/use-config-draft.ts +0 -127
  115. package/src/hooks/use-mobile.tsx +0 -27
  116. package/src/index.css +0 -131
  117. package/src/index.ts +0 -47
  118. package/src/lib/use-sync-external-store-shim.ts +0 -10
  119. package/src/lib/use-sync-external-store-with-selector-shim.ts +0 -90
  120. package/src/lib/utils.tsx +0 -35
  121. package/src/new-components.test.ts +0 -73
  122. package/src/renderers/action/action-bar.tsx +0 -221
  123. package/src/renderers/action/action-button.tsx +0 -158
  124. package/src/renderers/action/action-group.tsx +0 -270
  125. package/src/renderers/action/action-icon.tsx +0 -150
  126. package/src/renderers/action/action-menu.tsx +0 -203
  127. package/src/renderers/action/index.ts +0 -19
  128. package/src/renderers/action/resolve-icon.ts +0 -35
  129. package/src/renderers/basic/button-group.tsx +0 -79
  130. package/src/renderers/basic/div.tsx +0 -60
  131. package/src/renderers/basic/html.tsx +0 -43
  132. package/src/renderers/basic/icon.tsx +0 -89
  133. package/src/renderers/basic/image.tsx +0 -49
  134. package/src/renderers/basic/index.ts +0 -18
  135. package/src/renderers/basic/navigation-menu.tsx +0 -81
  136. package/src/renderers/basic/pagination.tsx +0 -109
  137. package/src/renderers/basic/separator.tsx +0 -57
  138. package/src/renderers/basic/span.tsx +0 -63
  139. package/src/renderers/basic/text.tsx +0 -52
  140. package/src/renderers/complex/README-KANBAN.md +0 -208
  141. package/src/renderers/complex/TIMELINE.md +0 -353
  142. package/src/renderers/complex/__tests__/data-table-airtable-ux.test.tsx +0 -239
  143. package/src/renderers/complex/__tests__/data-table-batch-editing.test.tsx +0 -275
  144. package/src/renderers/complex/__tests__/data-table-cell-renderer.test.tsx +0 -120
  145. package/src/renderers/complex/__tests__/data-table-editing.test.tsx +0 -221
  146. package/src/renderers/complex/__tests__/data-table.test.ts +0 -76
  147. package/src/renderers/complex/carousel.tsx +0 -69
  148. package/src/renderers/complex/data-table.tsx +0 -1243
  149. package/src/renderers/complex/filter-builder.tsx +0 -77
  150. package/src/renderers/complex/index.ts +0 -16
  151. package/src/renderers/complex/resizable.tsx +0 -66
  152. package/src/renderers/complex/scroll-area.tsx +0 -58
  153. package/src/renderers/complex/table.tsx +0 -95
  154. package/src/renderers/data-display/alert.tsx +0 -46
  155. package/src/renderers/data-display/avatar.tsx +0 -38
  156. package/src/renderers/data-display/badge.tsx +0 -55
  157. package/src/renderers/data-display/breadcrumb.tsx +0 -61
  158. package/src/renderers/data-display/index.ts +0 -18
  159. package/src/renderers/data-display/kbd.tsx +0 -50
  160. package/src/renderers/data-display/list.tsx +0 -75
  161. package/src/renderers/data-display/statistic.tsx +0 -95
  162. package/src/renderers/data-display/table.tsx +0 -78
  163. package/src/renderers/data-display/tree-view.tsx +0 -176
  164. package/src/renderers/disclosure/accordion.tsx +0 -69
  165. package/src/renderers/disclosure/collapsible.tsx +0 -53
  166. package/src/renderers/disclosure/index.ts +0 -11
  167. package/src/renderers/disclosure/toggle-group.tsx +0 -79
  168. package/src/renderers/feedback/empty.tsx +0 -49
  169. package/src/renderers/feedback/index.ts +0 -16
  170. package/src/renderers/feedback/loading.tsx +0 -78
  171. package/src/renderers/feedback/progress.tsx +0 -29
  172. package/src/renderers/feedback/skeleton.tsx +0 -31
  173. package/src/renderers/feedback/sonner.tsx +0 -56
  174. package/src/renderers/feedback/spinner.tsx +0 -55
  175. package/src/renderers/feedback/toast.tsx +0 -59
  176. package/src/renderers/feedback/toaster.tsx +0 -23
  177. package/src/renderers/form/button.tsx +0 -103
  178. package/src/renderers/form/calendar.tsx +0 -34
  179. package/src/renderers/form/checkbox.tsx +0 -71
  180. package/src/renderers/form/combobox.tsx +0 -48
  181. package/src/renderers/form/command.tsx +0 -58
  182. package/src/renderers/form/date-picker.tsx +0 -84
  183. package/src/renderers/form/file-upload.tsx +0 -184
  184. package/src/renderers/form/form.tsx +0 -533
  185. package/src/renderers/form/index.ts +0 -26
  186. package/src/renderers/form/input-otp.tsx +0 -51
  187. package/src/renderers/form/input.tsx +0 -121
  188. package/src/renderers/form/label.tsx +0 -45
  189. package/src/renderers/form/radio-group.tsx +0 -63
  190. package/src/renderers/form/select.tsx +0 -94
  191. package/src/renderers/form/slider.tsx +0 -61
  192. package/src/renderers/form/switch.tsx +0 -48
  193. package/src/renderers/form/textarea.tsx +0 -76
  194. package/src/renderers/form/toggle.tsx +0 -42
  195. package/src/renderers/index.ts +0 -18
  196. package/src/renderers/layout/aspect-ratio.tsx +0 -51
  197. package/src/renderers/layout/card.tsx +0 -85
  198. package/src/renderers/layout/container.tsx +0 -122
  199. package/src/renderers/layout/flex.tsx +0 -132
  200. package/src/renderers/layout/grid.tsx +0 -178
  201. package/src/renderers/layout/index.ts +0 -19
  202. package/src/renderers/layout/page.tsx +0 -466
  203. package/src/renderers/layout/semantic.tsx +0 -48
  204. package/src/renderers/layout/stack.tsx +0 -132
  205. package/src/renderers/layout/tabs.tsx +0 -97
  206. package/src/renderers/navigation/header-bar.tsx +0 -118
  207. package/src/renderers/navigation/index.ts +0 -10
  208. package/src/renderers/navigation/sidebar.tsx +0 -208
  209. package/src/renderers/overlay/alert-dialog.tsx +0 -72
  210. package/src/renderers/overlay/context-menu.tsx +0 -100
  211. package/src/renderers/overlay/dialog.tsx +0 -77
  212. package/src/renderers/overlay/drawer.tsx +0 -77
  213. package/src/renderers/overlay/dropdown-menu.tsx +0 -99
  214. package/src/renderers/overlay/hover-card.tsx +0 -55
  215. package/src/renderers/overlay/index.ts +0 -18
  216. package/src/renderers/overlay/menubar.tsx +0 -76
  217. package/src/renderers/overlay/popover.tsx +0 -56
  218. package/src/renderers/overlay/sheet.tsx +0 -77
  219. package/src/renderers/overlay/tooltip.tsx +0 -67
  220. package/src/renderers/placeholders.tsx +0 -107
  221. package/src/stories/CRMApp.stories.tsx +0 -706
  222. package/src/stories/ConfigPanel.stories.tsx +0 -232
  223. package/src/stories/Guide.mdx +0 -55
  224. package/src/stories/MockedData.stories.tsx +0 -121
  225. package/src/stories/assets/accessibility.png +0 -0
  226. package/src/stories/assets/accessibility.svg +0 -1
  227. package/src/stories/assets/addon-library.png +0 -0
  228. package/src/stories/assets/assets.png +0 -0
  229. package/src/stories/assets/avif-test-image.avif +0 -0
  230. package/src/stories/assets/context.png +0 -0
  231. package/src/stories/assets/discord.svg +0 -1
  232. package/src/stories/assets/docs.png +0 -0
  233. package/src/stories/assets/figma-plugin.png +0 -0
  234. package/src/stories/assets/github.svg +0 -1
  235. package/src/stories/assets/share.png +0 -0
  236. package/src/stories/assets/styling.png +0 -0
  237. package/src/stories/assets/testing.png +0 -0
  238. package/src/stories/assets/theming.png +0 -0
  239. package/src/stories/assets/tutorials.svg +0 -1
  240. package/src/stories/assets/youtube.svg +0 -1
  241. package/src/stories/button.css +0 -30
  242. package/src/stories/header.css +0 -32
  243. package/src/stories/page.css +0 -68
  244. package/src/stories-json/Accessibility.mdx +0 -297
  245. package/src/stories-json/EdgeCases.stories.tsx +0 -160
  246. package/src/stories-json/GettingStarted.mdx +0 -89
  247. package/src/stories-json/Introduction.mdx +0 -127
  248. package/src/stories-json/accordion.stories.tsx +0 -43
  249. package/src/stories-json/aggrid.stories.tsx +0 -103
  250. package/src/stories-json/alert.stories.tsx +0 -39
  251. package/src/stories-json/aspect-ratio.stories.tsx +0 -34
  252. package/src/stories-json/avatar.stories.tsx +0 -38
  253. package/src/stories-json/badge.stories.tsx +0 -53
  254. package/src/stories-json/breadcrumb.stories.tsx +0 -30
  255. package/src/stories-json/button-group.stories.tsx +0 -43
  256. package/src/stories-json/button.stories.tsx +0 -73
  257. package/src/stories-json/calendar.stories.tsx +0 -85
  258. package/src/stories-json/card.stories.tsx +0 -48
  259. package/src/stories-json/carousel.stories.tsx +0 -33
  260. package/src/stories-json/charts.stories.tsx +0 -195
  261. package/src/stories-json/chatbot.stories.tsx +0 -248
  262. package/src/stories-json/code-editor.stories.tsx +0 -92
  263. package/src/stories-json/collapsible.stories.tsx +0 -40
  264. package/src/stories-json/controls.stories.tsx +0 -36
  265. package/src/stories-json/crm-live-data.stories.tsx +0 -154
  266. package/src/stories-json/dashboard.stories.tsx +0 -318
  267. package/src/stories-json/data-table.stories.tsx +0 -136
  268. package/src/stories-json/data_display_extras.stories.tsx +0 -102
  269. package/src/stories-json/date-picker.stories.tsx +0 -28
  270. package/src/stories-json/detail-view.stories.tsx +0 -258
  271. package/src/stories-json/dialog.stories.tsx +0 -43
  272. package/src/stories-json/feedback_extras.stories.tsx +0 -40
  273. package/src/stories-json/feedback_others.stories.tsx +0 -46
  274. package/src/stories-json/form-variants.stories.tsx +0 -210
  275. package/src/stories-json/form_advanced.stories.tsx +0 -117
  276. package/src/stories-json/form_extras.stories.tsx +0 -123
  277. package/src/stories-json/grid.stories.tsx +0 -56
  278. package/src/stories-json/icon.stories.tsx +0 -36
  279. package/src/stories-json/input.stories.tsx +0 -52
  280. package/src/stories-json/kanban.stories.tsx +0 -295
  281. package/src/stories-json/layout_extended.stories.tsx +0 -76
  282. package/src/stories-json/layout_flex.stories.tsx +0 -107
  283. package/src/stories-json/list-view.stories.tsx +0 -97
  284. package/src/stories-json/markdown.stories.tsx +0 -129
  285. package/src/stories-json/menus.stories.tsx +0 -63
  286. package/src/stories-json/metric-card.stories.tsx +0 -143
  287. package/src/stories-json/navigation-menu.stories.tsx +0 -37
  288. package/src/stories-json/object-aggrid-advanced.stories.tsx +0 -389
  289. package/src/stories-json/object-aggrid.stories.tsx +0 -252
  290. package/src/stories-json/object-form.stories.tsx +0 -130
  291. package/src/stories-json/object-gantt.stories.tsx +0 -114
  292. package/src/stories-json/object-grid.stories.tsx +0 -315
  293. package/src/stories-json/object-map.stories.tsx +0 -116
  294. package/src/stories-json/object-view.stories.tsx +0 -118
  295. package/src/stories-json/overlay_extras.stories.tsx +0 -113
  296. package/src/stories-json/overlay_others.stories.tsx +0 -76
  297. package/src/stories-json/page.stories.tsx +0 -55
  298. package/src/stories-json/reports.stories.tsx +0 -163
  299. package/src/stories-json/resizable.stories.tsx +0 -44
  300. package/src/stories-json/select.stories.tsx +0 -34
  301. package/src/stories-json/separator.stories.tsx +0 -41
  302. package/src/stories-json/sidebar.stories.tsx +0 -147
  303. package/src/stories-json/statistic.stories.tsx +0 -44
  304. package/src/stories-json/tabs.stories.tsx +0 -51
  305. package/src/stories-json/timeline.stories.tsx +0 -188
  306. package/src/stories-json/typography.stories.tsx +0 -45
  307. package/src/types/config-panel.ts +0 -101
  308. package/src/ui/accordion.tsx +0 -66
  309. package/src/ui/alert-dialog.tsx +0 -149
  310. package/src/ui/alert.tsx +0 -67
  311. package/src/ui/aspect-ratio.tsx +0 -15
  312. package/src/ui/avatar.tsx +0 -58
  313. package/src/ui/badge.tsx +0 -44
  314. package/src/ui/breadcrumb.tsx +0 -123
  315. package/src/ui/button.tsx +0 -66
  316. package/src/ui/calendar.tsx +0 -221
  317. package/src/ui/card.tsx +0 -87
  318. package/src/ui/carousel.tsx +0 -270
  319. package/src/ui/chart.tsx +0 -367
  320. package/src/ui/checkbox.tsx +0 -38
  321. package/src/ui/collapsible.tsx +0 -19
  322. package/src/ui/command.tsx +0 -161
  323. package/src/ui/context-menu.tsx +0 -208
  324. package/src/ui/dialog.tsx +0 -147
  325. package/src/ui/drawer.tsx +0 -126
  326. package/src/ui/dropdown-menu.tsx +0 -208
  327. package/src/ui/form.tsx +0 -186
  328. package/src/ui/hover-card.tsx +0 -37
  329. package/src/ui/index.ts +0 -56
  330. package/src/ui/input-otp.tsx +0 -79
  331. package/src/ui/input.tsx +0 -30
  332. package/src/ui/label.tsx +0 -34
  333. package/src/ui/menubar.tsx +0 -264
  334. package/src/ui/navigation-menu.tsx +0 -136
  335. package/src/ui/pagination.tsx +0 -125
  336. package/src/ui/popover.tsx +0 -39
  337. package/src/ui/progress.tsx +0 -36
  338. package/src/ui/radio-group.tsx +0 -52
  339. package/src/ui/resizable.tsx +0 -53
  340. package/src/ui/scroll-area.tsx +0 -56
  341. package/src/ui/select.tsx +0 -168
  342. package/src/ui/separator.tsx +0 -39
  343. package/src/ui/sheet.tsx +0 -151
  344. package/src/ui/sidebar.tsx +0 -866
  345. package/src/ui/skeleton.tsx +0 -23
  346. package/src/ui/slider.tsx +0 -40
  347. package/src/ui/sonner.tsx +0 -53
  348. package/src/ui/switch.tsx +0 -37
  349. package/src/ui/table.tsx +0 -125
  350. package/src/ui/tabs.tsx +0 -63
  351. package/src/ui/textarea.tsx +0 -30
  352. package/src/ui/toast.tsx +0 -137
  353. package/src/ui/toggle-group.tsx +0 -69
  354. package/src/ui/toggle.tsx +0 -53
  355. package/src/ui/tooltip.tsx +0 -38
  356. package/src/ui/typography.tsx +0 -85
  357. package/tsconfig.json +0 -19
  358. package/vite.config.ts +0 -70
  359. package/vitest.config.ts +0 -5
  360. /package/dist/{src → packages/components/src}/SchemaRenderer.d.ts +0 -0
  361. /package/dist/{src → packages/components/src}/custom/action-param-dialog.d.ts +0 -0
  362. /package/dist/{src → packages/components/src}/custom/button-group.d.ts +0 -0
  363. /package/dist/{src → packages/components/src}/custom/combobox.d.ts +0 -0
  364. /package/dist/{src → packages/components/src}/custom/config-field-renderer.d.ts +0 -0
  365. /package/dist/{src → packages/components/src}/custom/config-panel-renderer.d.ts +0 -0
  366. /package/dist/{src → packages/components/src}/custom/config-row.d.ts +0 -0
  367. /package/dist/{src → packages/components/src}/custom/date-picker.d.ts +0 -0
  368. /package/dist/{src → packages/components/src}/custom/field.d.ts +0 -0
  369. /package/dist/{src → packages/components/src}/custom/filter-builder.d.ts +0 -0
  370. /package/dist/{src → packages/components/src}/custom/index.d.ts +0 -0
  371. /package/dist/{src → packages/components/src}/custom/input-group.d.ts +0 -0
  372. /package/dist/{src → packages/components/src}/custom/item.d.ts +0 -0
  373. /package/dist/{src → packages/components/src}/custom/kbd.d.ts +0 -0
  374. /package/dist/{src → packages/components/src}/custom/native-select.d.ts +0 -0
  375. /package/dist/{src → packages/components/src}/custom/navigation-overlay.d.ts +0 -0
  376. /package/dist/{src → packages/components/src}/custom/section-header.d.ts +0 -0
  377. /package/dist/{src → packages/components/src}/custom/sort-builder.d.ts +0 -0
  378. /package/dist/{src → packages/components/src}/custom/spinner.d.ts +0 -0
  379. /package/dist/{src → packages/components/src}/custom/view-skeleton.d.ts +0 -0
  380. /package/dist/{src → packages/components/src}/custom/view-states.d.ts +0 -0
  381. /package/dist/{src → packages/components/src}/debug/DebugPanel.d.ts +0 -0
  382. /package/dist/{src → packages/components/src}/debug/index.d.ts +0 -0
  383. /package/dist/{src → packages/components/src}/hooks/use-config-draft.d.ts +0 -0
  384. /package/dist/{src → packages/components/src}/hooks/use-mobile.d.ts +0 -0
  385. /package/dist/{src → packages/components/src}/index.d.ts +0 -0
  386. /package/dist/{src → packages/components/src}/lib/use-sync-external-store-shim.d.ts +0 -0
  387. /package/dist/{src → packages/components/src}/lib/use-sync-external-store-with-selector-shim.d.ts +0 -0
  388. /package/dist/{src → packages/components/src}/lib/utils.d.ts +0 -0
  389. /package/dist/{src → packages/components/src}/renderers/action/action-button.d.ts +0 -0
  390. /package/dist/{src → packages/components/src}/renderers/action/action-group.d.ts +0 -0
  391. /package/dist/{src → packages/components/src}/renderers/action/action-icon.d.ts +0 -0
  392. /package/dist/{src → packages/components/src}/renderers/action/action-menu.d.ts +0 -0
  393. /package/dist/{src → packages/components/src}/renderers/action/index.d.ts +0 -0
  394. /package/dist/{src → packages/components/src}/renderers/action/resolve-icon.d.ts +0 -0
  395. /package/dist/{src → packages/components/src}/renderers/basic/button-group.d.ts +0 -0
  396. /package/dist/{src → packages/components/src}/renderers/basic/div.d.ts +0 -0
  397. /package/dist/{src → packages/components/src}/renderers/basic/html.d.ts +0 -0
  398. /package/dist/{src → packages/components/src}/renderers/basic/icon.d.ts +0 -0
  399. /package/dist/{src → packages/components/src}/renderers/basic/image.d.ts +0 -0
  400. /package/dist/{src → packages/components/src}/renderers/basic/index.d.ts +0 -0
  401. /package/dist/{src → packages/components/src}/renderers/basic/navigation-menu.d.ts +0 -0
  402. /package/dist/{src → packages/components/src}/renderers/basic/pagination.d.ts +0 -0
  403. /package/dist/{src → packages/components/src}/renderers/basic/separator.d.ts +0 -0
  404. /package/dist/{src → packages/components/src}/renderers/basic/span.d.ts +0 -0
  405. /package/dist/{src → packages/components/src}/renderers/basic/text.d.ts +0 -0
  406. /package/dist/{src → packages/components/src}/renderers/complex/carousel.d.ts +0 -0
  407. /package/dist/{src → packages/components/src}/renderers/complex/data-table.d.ts +0 -0
  408. /package/dist/{src → packages/components/src}/renderers/complex/filter-builder.d.ts +0 -0
  409. /package/dist/{src → packages/components/src}/renderers/complex/index.d.ts +0 -0
  410. /package/dist/{src → packages/components/src}/renderers/complex/resizable.d.ts +0 -0
  411. /package/dist/{src → packages/components/src}/renderers/complex/scroll-area.d.ts +0 -0
  412. /package/dist/{src → packages/components/src}/renderers/complex/table.d.ts +0 -0
  413. /package/dist/{src → packages/components/src}/renderers/data-display/alert.d.ts +0 -0
  414. /package/dist/{src → packages/components/src}/renderers/data-display/avatar.d.ts +0 -0
  415. /package/dist/{src → packages/components/src}/renderers/data-display/badge.d.ts +0 -0
  416. /package/dist/{src → packages/components/src}/renderers/data-display/breadcrumb.d.ts +0 -0
  417. /package/dist/{src → packages/components/src}/renderers/data-display/index.d.ts +0 -0
  418. /package/dist/{src → packages/components/src}/renderers/data-display/kbd.d.ts +0 -0
  419. /package/dist/{src → packages/components/src}/renderers/data-display/list.d.ts +0 -0
  420. /package/dist/{src → packages/components/src}/renderers/data-display/statistic.d.ts +0 -0
  421. /package/dist/{src → packages/components/src}/renderers/data-display/table.d.ts +0 -0
  422. /package/dist/{src → packages/components/src}/renderers/data-display/tree-view.d.ts +0 -0
  423. /package/dist/{src → packages/components/src}/renderers/disclosure/accordion.d.ts +0 -0
  424. /package/dist/{src → packages/components/src}/renderers/disclosure/collapsible.d.ts +0 -0
  425. /package/dist/{src → packages/components/src}/renderers/disclosure/index.d.ts +0 -0
  426. /package/dist/{src → packages/components/src}/renderers/disclosure/toggle-group.d.ts +0 -0
  427. /package/dist/{src → packages/components/src}/renderers/feedback/empty.d.ts +0 -0
  428. /package/dist/{src → packages/components/src}/renderers/feedback/index.d.ts +0 -0
  429. /package/dist/{src → packages/components/src}/renderers/feedback/loading.d.ts +0 -0
  430. /package/dist/{src → packages/components/src}/renderers/feedback/progress.d.ts +0 -0
  431. /package/dist/{src → packages/components/src}/renderers/feedback/skeleton.d.ts +0 -0
  432. /package/dist/{src → packages/components/src}/renderers/feedback/sonner.d.ts +0 -0
  433. /package/dist/{src → packages/components/src}/renderers/feedback/spinner.d.ts +0 -0
  434. /package/dist/{src → packages/components/src}/renderers/feedback/toast.d.ts +0 -0
  435. /package/dist/{src → packages/components/src}/renderers/feedback/toaster.d.ts +0 -0
  436. /package/dist/{src → packages/components/src}/renderers/form/button.d.ts +0 -0
  437. /package/dist/{src → packages/components/src}/renderers/form/calendar.d.ts +0 -0
  438. /package/dist/{src → packages/components/src}/renderers/form/checkbox.d.ts +0 -0
  439. /package/dist/{src → packages/components/src}/renderers/form/combobox.d.ts +0 -0
  440. /package/dist/{src → packages/components/src}/renderers/form/command.d.ts +0 -0
  441. /package/dist/{src → packages/components/src}/renderers/form/date-picker.d.ts +0 -0
  442. /package/dist/{src → packages/components/src}/renderers/form/file-upload.d.ts +0 -0
  443. /package/dist/{src → packages/components/src}/renderers/form/form.d.ts +0 -0
  444. /package/dist/{src → packages/components/src}/renderers/form/index.d.ts +0 -0
  445. /package/dist/{src → packages/components/src}/renderers/form/input-otp.d.ts +0 -0
  446. /package/dist/{src → packages/components/src}/renderers/form/input.d.ts +0 -0
  447. /package/dist/{src → packages/components/src}/renderers/form/label.d.ts +0 -0
  448. /package/dist/{src → packages/components/src}/renderers/form/radio-group.d.ts +0 -0
  449. /package/dist/{src → packages/components/src}/renderers/form/select.d.ts +0 -0
  450. /package/dist/{src → packages/components/src}/renderers/form/slider.d.ts +0 -0
  451. /package/dist/{src → packages/components/src}/renderers/form/switch.d.ts +0 -0
  452. /package/dist/{src → packages/components/src}/renderers/form/textarea.d.ts +0 -0
  453. /package/dist/{src → packages/components/src}/renderers/form/toggle.d.ts +0 -0
  454. /package/dist/{src → packages/components/src}/renderers/index.d.ts +0 -0
  455. /package/dist/{src → packages/components/src}/renderers/layout/aspect-ratio.d.ts +0 -0
  456. /package/dist/{src → packages/components/src}/renderers/layout/card.d.ts +0 -0
  457. /package/dist/{src → packages/components/src}/renderers/layout/container.d.ts +0 -0
  458. /package/dist/{src → packages/components/src}/renderers/layout/flex.d.ts +0 -0
  459. /package/dist/{src → packages/components/src}/renderers/layout/grid.d.ts +0 -0
  460. /package/dist/{src → packages/components/src}/renderers/layout/index.d.ts +0 -0
  461. /package/dist/{src → packages/components/src}/renderers/layout/page.d.ts +0 -0
  462. /package/dist/{src → packages/components/src}/renderers/layout/semantic.d.ts +0 -0
  463. /package/dist/{src → packages/components/src}/renderers/layout/stack.d.ts +0 -0
  464. /package/dist/{src → packages/components/src}/renderers/layout/tabs.d.ts +0 -0
  465. /package/dist/{src → packages/components/src}/renderers/navigation/header-bar.d.ts +0 -0
  466. /package/dist/{src → packages/components/src}/renderers/navigation/index.d.ts +0 -0
  467. /package/dist/{src → packages/components/src}/renderers/navigation/sidebar.d.ts +0 -0
  468. /package/dist/{src → packages/components/src}/renderers/overlay/alert-dialog.d.ts +0 -0
  469. /package/dist/{src → packages/components/src}/renderers/overlay/context-menu.d.ts +0 -0
  470. /package/dist/{src → packages/components/src}/renderers/overlay/dialog.d.ts +0 -0
  471. /package/dist/{src → packages/components/src}/renderers/overlay/drawer.d.ts +0 -0
  472. /package/dist/{src → packages/components/src}/renderers/overlay/dropdown-menu.d.ts +0 -0
  473. /package/dist/{src → packages/components/src}/renderers/overlay/hover-card.d.ts +0 -0
  474. /package/dist/{src → packages/components/src}/renderers/overlay/index.d.ts +0 -0
  475. /package/dist/{src → packages/components/src}/renderers/overlay/menubar.d.ts +0 -0
  476. /package/dist/{src → packages/components/src}/renderers/overlay/popover.d.ts +0 -0
  477. /package/dist/{src → packages/components/src}/renderers/overlay/sheet.d.ts +0 -0
  478. /package/dist/{src → packages/components/src}/renderers/overlay/tooltip.d.ts +0 -0
  479. /package/dist/{src → packages/components/src}/renderers/placeholders.d.ts +0 -0
  480. /package/dist/{src → packages/components/src}/types/config-panel.d.ts +0 -0
  481. /package/dist/{src → packages/components/src}/ui/alert.d.ts +0 -0
  482. /package/dist/{src → packages/components/src}/ui/badge.d.ts +0 -0
  483. /package/dist/{src → packages/components/src}/ui/breadcrumb.d.ts +0 -0
  484. /package/dist/{src → packages/components/src}/ui/calendar.d.ts +0 -0
  485. /package/dist/{src → packages/components/src}/ui/card.d.ts +0 -0
  486. /package/dist/{src → packages/components/src}/ui/carousel.d.ts +0 -0
  487. /package/dist/{src → packages/components/src}/ui/index.d.ts +0 -0
  488. /package/dist/{src → packages/components/src}/ui/input-otp.d.ts +0 -0
  489. /package/dist/{src → packages/components/src}/ui/input.d.ts +0 -0
  490. /package/dist/{src → packages/components/src}/ui/pagination.d.ts +0 -0
  491. /package/dist/{src → packages/components/src}/ui/skeleton.d.ts +0 -0
  492. /package/dist/{src → packages/components/src}/ui/sonner.d.ts +0 -0
  493. /package/dist/{src → packages/components/src}/ui/table.d.ts +0 -0
  494. /package/dist/{src → packages/components/src}/ui/textarea.d.ts +0 -0
  495. /package/dist/{src → packages/components/src}/ui/typography.d.ts +0 -0
@@ -1,154 +0,0 @@
1
- import type { Meta, StoryObj } from '@storybook/react';
2
- import React, { useEffect, useState, useCallback } from 'react';
3
- import { SchemaRenderer, SchemaRendererProvider } from '@object-ui/react';
4
- import type { BaseSchema } from '@object-ui/types';
5
- import { createStorybookDataSource } from '@storybook-config/datasource';
6
-
7
- const meta: Meta = {
8
- title: 'Plugins/Data Views/CRM Live Data',
9
- parameters: {
10
- layout: 'padded',
11
- },
12
- };
13
-
14
- export default meta;
15
-
16
- const dataSource = createStorybookDataSource();
17
-
18
- // ==========================================
19
- // Helper: Fetches data from MSW and renders a schema
20
- // ==========================================
21
- const LiveDataView = ({
22
- objectName,
23
- schema,
24
- title
25
- }: {
26
- objectName: string;
27
- schema: (data: any[]) => BaseSchema;
28
- title: string;
29
- }) => {
30
- const [data, setData] = useState<any[]>([]);
31
- const [loading, setLoading] = useState(true);
32
- const [error, setError] = useState<string | null>(null);
33
-
34
- const fetchData = useCallback(async () => {
35
- setLoading(true);
36
- setError(null);
37
- try {
38
- const result = await dataSource.find(objectName, { $top: 50 });
39
- setData(result.data as any[]);
40
- } catch (err: any) {
41
- console.error(`[CRM Live] Failed to fetch ${objectName}:`, err);
42
- setError(err?.message || `Failed to fetch ${objectName}`);
43
- } finally {
44
- setLoading(false);
45
- }
46
- }, [objectName]);
47
-
48
- useEffect(() => {
49
- fetchData();
50
- }, [fetchData]);
51
-
52
- if (loading) return <div className="p-8 text-muted-foreground">Loading {title} from MSW API...</div>;
53
- if (error) return (
54
- <div className="p-8 space-y-2">
55
- <div className="text-destructive font-medium">API Error: {error}</div>
56
- <div className="text-sm text-muted-foreground">
57
- Ensure the ObjectStack MSW runtime is running. Check browser console for logs.
58
- </div>
59
- </div>
60
- );
61
-
62
- return (
63
- <SchemaRendererProvider dataSource={dataSource}>
64
- <div className="space-y-4">
65
- <h2 className="text-lg font-semibold">{title} ({data.length} records)</h2>
66
- <SchemaRenderer schema={schema(data)} />
67
- </div>
68
- </SchemaRendererProvider>
69
- );
70
- };
71
-
72
- // ==========================================
73
- // Contact Grid from MSW
74
- // ==========================================
75
- export const ContactGrid: StoryObj = {
76
- name: 'Contact Grid (Live)',
77
- render: () => (
78
- <LiveDataView
79
- objectName="contact"
80
- title="Contacts"
81
- schema={(data) => ({
82
- type: 'object-grid',
83
- objectName: 'contact',
84
- columns: [
85
- { field: 'name', header: 'Name', sortable: true, filterable: true },
86
- { field: 'email', header: 'Email', sortable: true },
87
- { field: 'title', header: 'Title' },
88
- { field: 'department', header: 'Department' },
89
- { field: 'status', header: 'Status', sortable: true },
90
- ],
91
- data,
92
- pagination: true,
93
- pageSize: 10,
94
- className: 'w-full',
95
- } as any)}
96
- />
97
- ),
98
- };
99
-
100
- // ==========================================
101
- // Account Grid from MSW
102
- // ==========================================
103
- export const AccountGrid: StoryObj = {
104
- name: 'Account Grid (Live)',
105
- render: () => (
106
- <LiveDataView
107
- objectName="account"
108
- title="Accounts"
109
- schema={(data) => ({
110
- type: 'object-grid',
111
- objectName: 'account',
112
- columns: [
113
- { field: 'name', header: 'Company', sortable: true, filterable: true },
114
- { field: 'industry', header: 'Industry', sortable: true },
115
- { field: 'type', header: 'Type' },
116
- { field: 'employees', header: 'Employees', type: 'number' },
117
- { field: 'phone', header: 'Phone' },
118
- ],
119
- data,
120
- pagination: true,
121
- pageSize: 10,
122
- className: 'w-full',
123
- } as any)}
124
- />
125
- ),
126
- };
127
-
128
- // ==========================================
129
- // Opportunity Grid from MSW
130
- // ==========================================
131
- export const OpportunityGrid: StoryObj = {
132
- name: 'Opportunity Grid (Live)',
133
- render: () => (
134
- <LiveDataView
135
- objectName="opportunity"
136
- title="Opportunities"
137
- schema={(data) => ({
138
- type: 'object-grid',
139
- objectName: 'opportunity',
140
- columns: [
141
- { field: 'name', header: 'Opportunity', sortable: true },
142
- { field: 'amount', header: 'Amount', type: 'currency', sortable: true },
143
- { field: 'stage', header: 'Stage', sortable: true },
144
- { field: 'probability', header: 'Probability' },
145
- { field: 'close_date', header: 'Close Date', type: 'date' },
146
- ],
147
- data,
148
- pagination: true,
149
- pageSize: 10,
150
- className: 'w-full',
151
- } as any)}
152
- />
153
- ),
154
- };
@@ -1,318 +0,0 @@
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: 'Templates/Dashboard',
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: 'dashboard',
26
- columns: 3,
27
- gap: 4,
28
- widgets: [
29
- {
30
- id: 'metric-1',
31
- component: {
32
- type: 'metric',
33
- label: 'Total Revenue',
34
- value: '$45,231.89',
35
- }
36
- },
37
- {
38
- id: 'metric-2',
39
- component: {
40
- type: 'metric',
41
- label: 'Active Users',
42
- value: '2,350',
43
- }
44
- },
45
- {
46
- id: 'metric-3',
47
- component: {
48
- type: 'metric',
49
- label: 'Conversion Rate',
50
- value: '12.5%',
51
- }
52
- }
53
- ]
54
- } as any,
55
- };
56
-
57
- export const WithCards: Story = {
58
- render: renderStory,
59
- args: {
60
- type: 'dashboard',
61
- columns: 2,
62
- gap: 6,
63
- widgets: [
64
- {
65
- id: 'card-1',
66
- title: 'Sales Overview',
67
- component: {
68
- type: 'card',
69
- children: [
70
- { type: 'metric', label: 'Today', value: '$1,234' },
71
- { type: 'metric', label: 'This Week', value: '$8,456' },
72
- ],
73
- }
74
- },
75
- {
76
- id: 'card-2',
77
- title: 'User Metrics',
78
- component: {
79
- type: 'card',
80
- children: [
81
- { type: 'metric', label: 'Online', value: '456' },
82
- { type: 'metric', label: 'New Today', value: '89' },
83
- ],
84
- }
85
- }
86
- ]
87
- } as any,
88
- };
89
-
90
- export const WithMetricCards: Story = {
91
- render: renderStory,
92
- args: {
93
- type: 'dashboard',
94
- columns: 3,
95
- gap: 4,
96
- widgets: [
97
- {
98
- id: 'metric-card-1',
99
- component: {
100
- type: 'metric-card',
101
- title: 'Total Revenue',
102
- value: '$45,231.89',
103
- icon: 'DollarSign',
104
- trend: 'up',
105
- trendValue: '+20.1%',
106
- description: 'from last month'
107
- },
108
- layout: { x: 0, y: 0, w: 1, h: 1 }
109
- },
110
- {
111
- id: 'metric-card-2',
112
- component: {
113
- type: 'metric-card',
114
- title: 'New Customers',
115
- value: '+2,350',
116
- icon: 'Users',
117
- trend: 'up',
118
- trendValue: '+180.1%',
119
- description: 'from last month'
120
- },
121
- layout: { x: 1, y: 0, w: 1, h: 1 }
122
- },
123
- {
124
- id: 'metric-card-3',
125
- component: {
126
- type: 'metric-card',
127
- title: 'Active Sessions',
128
- value: '+573',
129
- icon: 'Activity',
130
- trend: 'up',
131
- trendValue: '+201',
132
- description: 'since last hour'
133
- },
134
- layout: { x: 2, y: 0, w: 1, h: 1 }
135
- }
136
- ]
137
- } as any,
138
- };
139
-
140
- export const WithChartsAndMetrics: Story = {
141
- render: renderStory,
142
- args: {
143
- type: 'dashboard',
144
- columns: 3,
145
- gap: 4,
146
- widgets: [
147
- {
148
- id: 'metric-1',
149
- component: {
150
- type: 'metric-card',
151
- title: 'Total Revenue',
152
- value: '$45,231',
153
- icon: 'DollarSign',
154
- trend: 'up',
155
- trendValue: '+12%'
156
- },
157
- layout: { x: 0, y: 0, w: 1, h: 1 }
158
- },
159
- {
160
- id: 'metric-2',
161
- component: {
162
- type: 'metric-card',
163
- title: 'Orders',
164
- value: '856',
165
- icon: 'ShoppingCart',
166
- trend: 'up',
167
- trendValue: '+8%'
168
- },
169
- layout: { x: 1, y: 0, w: 1, h: 1 }
170
- },
171
- {
172
- id: 'metric-3',
173
- component: {
174
- type: 'metric-card',
175
- title: 'Bounce Rate',
176
- value: '2.4%',
177
- icon: 'TrendingDown',
178
- trend: 'down',
179
- trendValue: '-5%'
180
- },
181
- layout: { x: 2, y: 0, w: 1, h: 1 }
182
- },
183
- {
184
- id: 'chart-1',
185
- title: 'Revenue Overview',
186
- component: {
187
- type: 'chart',
188
- chartType: 'line',
189
- data: [
190
- { month: 'Jan', revenue: 4000 },
191
- { month: 'Feb', revenue: 3000 },
192
- { month: 'Mar', revenue: 6000 },
193
- { month: 'Apr', revenue: 8000 },
194
- { month: 'May', revenue: 5000 },
195
- { month: 'Jun', revenue: 7000 },
196
- ],
197
- xAxisKey: 'month',
198
- series: [{ dataKey: 'revenue' }],
199
- config: {
200
- revenue: { label: 'Revenue', color: '#10b981' }
201
- }
202
- },
203
- layout: { x: 0, y: 1, w: 3, h: 2 }
204
- }
205
- ]
206
- } as any,
207
- };
208
-
209
- export const WithGridLayout: Story = {
210
- render: renderStory,
211
- args: {
212
- type: 'dashboard',
213
- name: 'sales_dashboard',
214
- title: 'Sales Analytics Dashboard',
215
- enableGridLayout: true,
216
- persistLayout: true,
217
- widgets: [
218
- {
219
- id: 'total-revenue',
220
- type: 'metric-card',
221
- title: 'Total Revenue',
222
- value: '$142,892',
223
- change: '+12.5%',
224
- trend: 'up',
225
- layout: { x: 0, y: 0, w: 3, h: 2 },
226
- },
227
- {
228
- id: 'new-customers',
229
- type: 'metric-card',
230
- title: 'New Customers',
231
- value: '847',
232
- change: '+8.2%',
233
- trend: 'up',
234
- layout: { x: 3, y: 0, w: 3, h: 2 },
235
- },
236
- {
237
- id: 'conversion-rate',
238
- type: 'metric-card',
239
- title: 'Conversion Rate',
240
- value: '3.24%',
241
- change: '-0.5%',
242
- trend: 'down',
243
- layout: { x: 6, y: 0, w: 3, h: 2 },
244
- },
245
- {
246
- id: 'revenue-chart',
247
- type: 'bar',
248
- title: 'Monthly Revenue',
249
- data: [
250
- { month: 'Jan', revenue: 12000 },
251
- { month: 'Feb', revenue: 15000 },
252
- { month: 'Mar', revenue: 18000 },
253
- { month: 'Apr', revenue: 14000 },
254
- { month: 'May', revenue: 20000 },
255
- { month: 'Jun', revenue: 22000 },
256
- ],
257
- xAxisKey: 'month',
258
- series: [{ dataKey: 'revenue' }],
259
- layout: { x: 0, y: 2, w: 6, h: 4 },
260
- },
261
- {
262
- id: 'top-products',
263
- type: 'table',
264
- title: 'Top Products',
265
- columns: ['Product', 'Sales', 'Revenue'],
266
- data: [
267
- { Product: 'Product A', Sales: 245, Revenue: '$12,450' },
268
- { Product: 'Product B', Sales: 189, Revenue: '$9,450' },
269
- { Product: 'Product C', Sales: 156, Revenue: '$7,800' },
270
- ],
271
- layout: { x: 6, y: 2, w: 3, h: 4 },
272
- },
273
- ],
274
- } as any,
275
- };
276
-
277
- export const EditableLayout: Story = {
278
- render: renderStory,
279
- args: {
280
- type: 'dashboard',
281
- name: 'custom_dashboard',
282
- title: 'Customizable Dashboard',
283
- enableGridLayout: true,
284
- enableEditMode: true,
285
- persistLayout: true,
286
- widgets: [
287
- {
288
- id: 'widget-1',
289
- type: 'metric-card',
290
- title: 'Metric 1',
291
- value: '1,234',
292
- layout: { x: 0, y: 0, w: 3, h: 2 },
293
- },
294
- {
295
- id: 'widget-2',
296
- type: 'metric-card',
297
- title: 'Metric 2',
298
- value: '5,678',
299
- layout: { x: 3, y: 0, w: 3, h: 2 },
300
- },
301
- {
302
- id: 'widget-3',
303
- type: 'line',
304
- title: 'Trend Chart',
305
- data: [
306
- { date: 'Mon', value: 100 },
307
- { date: 'Tue', value: 150 },
308
- { date: 'Wed', value: 130 },
309
- { date: 'Thu', value: 180 },
310
- { date: 'Fri', value: 200 },
311
- ],
312
- xAxisKey: 'date',
313
- series: [{ dataKey: 'value' }],
314
- layout: { x: 0, y: 2, w: 6, h: 3 },
315
- },
316
- ],
317
- } as any,
318
- };
@@ -1,136 +0,0 @@
1
- import type { Meta, StoryObj } from '@storybook/react';
2
- import { SchemaRenderer, SchemaRendererProvider } from '@object-ui/react';
3
- import type { BaseSchema } from '@object-ui/types';
4
- import { createStorybookDataSource } from '@storybook-config/datasource';
5
-
6
- const meta: Meta = {
7
- title: 'Primitives/Data Display/Table',
8
- component: SchemaRenderer,
9
- tags: ['autodocs'],
10
- argTypes: {
11
- // Schema properties
12
- }
13
- };
14
-
15
- export default meta;
16
- type Story = StoryObj<typeof meta>;
17
-
18
- // Create a DataSource instance that connects to MSW
19
- const dataSource = createStorybookDataSource();
20
-
21
- const renderStory = (args: any) => (
22
- <SchemaRendererProvider dataSource={dataSource}>
23
- <SchemaRenderer schema={args as unknown as BaseSchema} />
24
- </SchemaRendererProvider>
25
- );
26
-
27
- export const DataTable: Story = {
28
- args: {
29
- type: 'data-table',
30
- caption: 'Employees',
31
- columns: [
32
- { header: 'ID', accessorKey: 'id', width: '80px' },
33
- { header: 'Name', accessorKey: 'name' },
34
- { header: 'Email', accessorKey: 'email' },
35
- { header: 'Role', accessorKey: 'role' },
36
- ],
37
- data: [
38
- { id: 1, name: 'John Doe', email: 'john@example.com', role: 'Admin' },
39
- { id: 2, name: 'Jane Smith', email: 'jane@example.com', role: 'User' },
40
- { id: 3, name: 'Bob Johnson', email: 'bob@example.com', role: 'User' }
41
- ]
42
- },
43
- render: renderStory
44
- };
45
-
46
- export const FullFeatures: Story = {
47
- args: {
48
- type: 'data-table',
49
- caption: 'Full Feature Table',
50
- searchable: true,
51
- pagination: true,
52
- selectable: true,
53
- sortable: true,
54
- exportable: true,
55
- rowActions: true,
56
- pageSize: 5,
57
- columns: [
58
- { header: 'Invoice', accessorKey: 'invoice' },
59
- { header: 'Status', accessorKey: 'status' },
60
- { header: 'Amount', accessorKey: 'amount', enableSorting: true },
61
- { header: 'Method', accessorKey: 'method' }
62
- ],
63
- data: Array.from({ length: 20 }).map((_, i) => ({
64
- invoice: `INV-${1000 + i}`,
65
- status: i % 3 === 0 ? 'Paid' : 'Pending',
66
- amount: `$${(Math.random() * 500).toFixed(2)}`,
67
- method: i % 2 === 0 ? 'Credit Card' : 'PayPal'
68
- }))
69
- },
70
- render: renderStory
71
- };
72
-
73
- export const EditableTable: Story = {
74
- args: {
75
- type: 'data-table',
76
- caption: 'Editable Product Inventory - Simple Cell Editing',
77
- searchable: false,
78
- pagination: false,
79
- editable: true,
80
- columns: [
81
- { header: 'SKU', accessorKey: 'sku', width: '100px', editable: false },
82
- { header: 'Product Name', accessorKey: 'name' },
83
- { header: 'Price', accessorKey: 'price' },
84
- { header: 'Stock', accessorKey: 'stock' }
85
- ],
86
- data: [
87
- { sku: 'PROD-001', name: 'Laptop', price: '$1299.99', stock: 15 },
88
- { sku: 'PROD-002', name: 'Mouse', price: '$29.99', stock: 120 },
89
- { sku: 'PROD-003', name: 'Keyboard', price: '$79.99', stock: 45 },
90
- { sku: 'PROD-004', name: 'Monitor', price: '$399.99', stock: 22 }
91
- ],
92
- onCellChange: (rowIndex: number, columnKey: string, newValue: any, row: any) => {
93
- console.log('Cell edited:', { rowIndex, columnKey, newValue, row });
94
- alert(`Updated ${columnKey} to "${newValue}" for ${row.name}`);
95
- }
96
- },
97
- render: renderStory
98
- };
99
-
100
- export const BatchEditTable: Story = {
101
- args: {
102
- type: 'data-table',
103
- caption: 'Batch Edit Mode - Edit Multiple Rows & Save Together (💡 Double-click cells to edit, then see save buttons appear)',
104
- searchable: false,
105
- pagination: false,
106
- editable: true,
107
- rowActions: true,
108
- columns: [
109
- { header: 'ID', accessorKey: 'id', width: '60px', editable: false },
110
- { header: 'Product Name', accessorKey: 'name' },
111
- { header: 'Category', accessorKey: 'category' },
112
- { header: 'Price', accessorKey: 'price' },
113
- { header: 'Stock', accessorKey: 'stock' }
114
- ],
115
- data: [
116
- { id: 1, name: 'Wireless Mouse', category: 'Electronics', price: '$29.99', stock: 50 },
117
- { id: 2, name: 'USB-C Cable', category: 'Accessories', price: '$12.99', stock: 100 },
118
- { id: 3, name: 'Laptop Stand', category: 'Accessories', price: '$45.99', stock: 25 },
119
- { id: 4, name: 'Webcam HD', category: 'Electronics', price: '$79.99', stock: 15 },
120
- { id: 5, name: 'Desk Lamp', category: 'Furniture', price: '$34.99', stock: 30 }
121
- ],
122
- onRowSave: async (rowIndex: number, changes: Record<string, any>, row: any) => {
123
- console.log('Saving single row:', { rowIndex, changes, row });
124
- await new Promise(resolve => setTimeout(resolve, 500));
125
- alert(`✓ Saved changes for "${row.name}":\n${JSON.stringify(changes, null, 2)}`);
126
- },
127
- onBatchSave: async (allChanges: Array<{ rowIndex: number; changes: Record<string, any>; row: any }>) => {
128
- console.log('Batch saving all rows:', allChanges);
129
- await new Promise(resolve => setTimeout(resolve, 800));
130
- const summary = allChanges.map(c => `${c.row.name}: ${Object.keys(c.changes).length} field(s)`).join('\n');
131
- alert(`✓ Batch saved ${allChanges.length} rows:\n\n${summary}`);
132
- }
133
- },
134
- render: renderStory
135
- };
136
-
@@ -1,102 +0,0 @@
1
- import type { Meta, StoryObj } from '@storybook/react';
2
- import { SchemaRenderer } from '../SchemaRenderer';
3
-
4
- const meta: Meta = {
5
- title: 'Primitives/Data Display/Extras',
6
- component: SchemaRenderer,
7
- tags: ['autodocs'],
8
- argTypes: {
9
- // Schema properties
10
- }
11
- };
12
-
13
- export default meta;
14
- type Story = StoryObj<typeof meta>;
15
-
16
- export const KeyboardKey: Story = {
17
- args: {
18
- type: 'kbd',
19
- keys: ['⌘', 'K'],
20
- className: 'text-xs'
21
- },
22
- render: (args) => <SchemaRenderer schema={args} />
23
- };
24
-
25
- export const ListUnordered: Story = {
26
- args: {
27
- type: 'list',
28
- title: 'Schema/Data Display/Technology Stack',
29
- ordered: false,
30
- items: [
31
- 'React',
32
- 'TypeScript',
33
- 'Tailwind CSS',
34
- { content: 'Storybook', className: 'font-bold' }
35
- ]
36
- },
37
- render: (args) => <SchemaRenderer schema={args} />
38
- };
39
-
40
- export const ListOrdered: Story = {
41
- args: {
42
- type: 'list',
43
- title: 'Schema/Data Display/Installation Steps',
44
- ordered: true,
45
- items: [
46
- 'Run npm install',
47
- 'Configure provider',
48
- 'Start application'
49
- ]
50
- },
51
- render: (args) => <SchemaRenderer schema={args} />
52
- };
53
-
54
- export const SimpleTable: Story = {
55
- args: {
56
- type: 'table',
57
- bind: 'users',
58
- columns: [
59
- { key: 'id', label: 'ID' },
60
- { key: 'name', label: 'Name' },
61
- { key: 'role', label: 'Role' }
62
- ]
63
- },
64
- decorators: [
65
- (Story) => (
66
- <div className="p-4">
67
- {/* Mock data context would be needed here, but since stories don't have easy data injection without a provider,
68
- we rely on the renderer handling undefined/empty data gracefully, or we wrap it in a provider if available using decorators.
69
- However, SchemaRenderer doesn't accept a provider prop directly.
70
- The users will see "Table data must be an array" or Empty state.
71
- Hack: We can't easily inject data into the unified SchemaRenderer story pattern without a wrapping provider in the story.
72
- */}
73
- <Story />
74
- </div>
75
- )
76
- ],
77
- render: (args) => <SchemaRenderer schema={args} />
78
- };
79
-
80
- export const TreeView: Story = {
81
- args: {
82
- type: 'tree-view',
83
- title: 'Schema/Data Display/Project Files',
84
- nodes: [
85
- {
86
- id: 'src',
87
- label: 'src',
88
- icon: 'folder',
89
- children: [
90
- { id: 'components', label: 'components', icon: 'folder', children: [{id: 'Button.tsx', label: 'Button.tsx', icon: 'file'}] },
91
- { id: 'App.tsx', label: 'App.tsx', icon: 'file' }
92
- ]
93
- },
94
- {
95
- id: 'package.json',
96
- label: 'package.json',
97
- icon: 'file'
98
- }
99
- ]
100
- },
101
- render: (args) => <SchemaRenderer schema={args} />
102
- };