@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,389 +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: 'Plugins/Data Views/Object AgGrid Advanced',
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
- // Mock data source for demonstration
23
- const createMockDataSource = (objectName: string, data: any[]) => {
24
- const mockSchema = {
25
- name: objectName,
26
- label: objectName.charAt(0).toUpperCase() + objectName.slice(1),
27
- fields: {} as any
28
- };
29
-
30
- // Infer fields from data
31
- if (data.length > 0) {
32
- const firstRow = data[0];
33
- Object.keys(firstRow).forEach(key => {
34
- let type = 'text';
35
- const value = firstRow[key];
36
-
37
- if (typeof value === 'number') type = 'number';
38
- else if (typeof value === 'boolean') type = 'boolean';
39
- else if (key.includes('email')) type = 'email';
40
- else if (key.includes('phone')) type = 'phone';
41
- else if (key.includes('url') || key.includes('website')) type = 'url';
42
- else if (key.includes('date')) type = 'date';
43
- else if (key.includes('price') || key.includes('cost') || key.includes('amount') || key.includes('salary')) type = 'currency';
44
- else if (key.includes('percent') || key.includes('rate')) type = 'percent';
45
-
46
- mockSchema.fields[key] = {
47
- name: key,
48
- label: key.charAt(0).toUpperCase() + key.slice(1).replace(/_/g, ' '),
49
- type,
50
- sortable: true,
51
- filterable: true,
52
- editable: key !== 'id' // All fields except ID are editable
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
- // Sample data for advanced examples
70
- const employeesData = [
71
- {
72
- id: '1',
73
- name: 'Alice Johnson',
74
- email: 'alice.j@company.com',
75
- department: 'Engineering',
76
- position: 'Senior Developer',
77
- salary: 95000,
78
- start_date: '2020-01-15',
79
- status: 'Active'
80
- },
81
- {
82
- id: '2',
83
- name: 'Bob Smith',
84
- email: 'bob.s@company.com',
85
- department: 'Marketing',
86
- position: 'Marketing Manager',
87
- salary: 72000,
88
- start_date: '2021-03-20',
89
- status: 'Active'
90
- },
91
- {
92
- id: '3',
93
- name: 'Carol Davis',
94
- email: 'carol.d@company.com',
95
- department: 'Sales',
96
- position: 'Sales Representative',
97
- salary: 68000,
98
- start_date: '2021-06-10',
99
- status: 'Active'
100
- },
101
- {
102
- id: '4',
103
- name: 'David Wilson',
104
- email: 'david.w@company.com',
105
- department: 'Engineering',
106
- position: 'Lead Engineer',
107
- salary: 102000,
108
- start_date: '2019-08-01',
109
- status: 'Active'
110
- },
111
- {
112
- id: '5',
113
- name: 'Eve Brown',
114
- email: 'eve.b@company.com',
115
- department: 'HR',
116
- position: 'HR Specialist',
117
- salary: 65000,
118
- start_date: '2022-02-14',
119
- status: 'On Leave'
120
- },
121
- {
122
- id: '6',
123
- name: 'Frank Miller',
124
- email: 'frank.m@company.com',
125
- department: 'Engineering',
126
- position: 'Software Engineer',
127
- salary: 88000,
128
- start_date: '2021-11-03',
129
- status: 'Active'
130
- },
131
- {
132
- id: '7',
133
- name: 'Grace Lee',
134
- email: 'grace.l@company.com',
135
- department: 'Marketing',
136
- position: 'Content Writer',
137
- salary: 58000,
138
- start_date: '2022-05-22',
139
- status: 'Active'
140
- },
141
- {
142
- id: '8',
143
- name: 'Henry Clark',
144
- email: 'henry.c@company.com',
145
- department: 'Sales',
146
- position: 'Sales Manager',
147
- salary: 85000,
148
- start_date: '2020-09-15',
149
- status: 'Active'
150
- },
151
- ];
152
-
153
- const ordersData = [
154
- {
155
- id: 'ORD-001',
156
- customer: 'Acme Corp',
157
- product: 'Enterprise License',
158
- quantity: 10,
159
- amount: 15750,
160
- date: '2024-01-15',
161
- status: 'Delivered'
162
- },
163
- {
164
- id: 'ORD-002',
165
- customer: 'TechStart Inc',
166
- product: 'Professional Plan',
167
- quantity: 5,
168
- amount: 8500,
169
- date: '2024-01-18',
170
- status: 'Shipped'
171
- },
172
- {
173
- id: 'ORD-003',
174
- customer: 'Global Solutions',
175
- product: 'Enterprise License',
176
- quantity: 15,
177
- amount: 22300,
178
- date: '2024-01-20',
179
- status: 'Processing'
180
- },
181
- {
182
- id: 'ORD-004',
183
- customer: 'Innovation Labs',
184
- product: 'Professional Plan',
185
- quantity: 8,
186
- amount: 12100,
187
- date: '2024-01-22',
188
- status: 'Delivered'
189
- },
190
- {
191
- id: 'ORD-005',
192
- customer: 'Future Systems',
193
- product: 'Starter Plan',
194
- quantity: 20,
195
- amount: 9800,
196
- date: '2024-01-25',
197
- status: 'Shipped'
198
- },
199
- ];
200
-
201
- // Advanced Stories
202
-
203
- export const WithStatusBarAndAggregations: Story = {
204
- render: renderStory,
205
- name: 'Status Bar & Aggregations',
206
- args: {
207
- type: 'object-aggrid',
208
- objectName: 'employees',
209
- dataSource: createMockDataSource('employees', employeesData),
210
- pagination: true,
211
- pageSize: 10,
212
- theme: 'quartz',
213
- height: 550,
214
- rowSelection: 'multiple',
215
- statusBar: {
216
- enabled: true,
217
- aggregations: ['count', 'sum', 'avg', 'min', 'max']
218
- },
219
- columnConfig: {
220
- resizable: true,
221
- sortable: true,
222
- filterable: true
223
- }
224
- } as any,
225
- };
226
-
227
- export const WithContextMenu: Story = {
228
- render: renderStory,
229
- name: 'Context Menu',
230
- args: {
231
- type: 'object-aggrid',
232
- objectName: 'employees',
233
- dataSource: createMockDataSource('employees', employeesData),
234
- pagination: true,
235
- pageSize: 10,
236
- theme: 'quartz',
237
- height: 500,
238
- contextMenu: {
239
- enabled: true,
240
- items: ['copy', 'copyWithHeaders', 'separator', 'export', 'autoSizeAll']
241
- },
242
- columnConfig: {
243
- resizable: true,
244
- sortable: true,
245
- filterable: true
246
- }
247
- } as any,
248
- };
249
-
250
- export const InlineEditingWithSelection: Story = {
251
- render: renderStory,
252
- name: 'Inline Editing + Row Selection',
253
- args: {
254
- type: 'object-aggrid',
255
- objectName: 'orders',
256
- dataSource: createMockDataSource('orders', ordersData),
257
- editable: true,
258
- singleClickEdit: true,
259
- pagination: true,
260
- pageSize: 10,
261
- theme: 'alpine',
262
- height: 500,
263
- rowSelection: 'multiple',
264
- columnConfig: {
265
- resizable: true,
266
- sortable: true,
267
- filterable: true
268
- }
269
- } as any,
270
- };
271
-
272
- export const FullFeatured: Story = {
273
- render: renderStory,
274
- name: 'Full Featured (All Options)',
275
- args: {
276
- type: 'object-aggrid',
277
- objectName: 'employees',
278
- dataSource: createMockDataSource('employees', employeesData),
279
- editable: true,
280
- singleClickEdit: false,
281
- pagination: true,
282
- pageSize: 5,
283
- theme: 'quartz',
284
- height: 600,
285
- rowSelection: 'multiple',
286
- animateRows: true,
287
- enableRangeSelection: true,
288
- exportConfig: {
289
- enabled: true,
290
- fileName: 'employees.csv'
291
- },
292
- statusBar: {
293
- enabled: true,
294
- aggregations: ['count', 'sum', 'avg']
295
- },
296
- contextMenu: {
297
- enabled: true,
298
- items: ['copy', 'copyWithHeaders', 'separator', 'export', 'autoSizeAll']
299
- },
300
- columnConfig: {
301
- resizable: true,
302
- sortable: true,
303
- filterable: true
304
- }
305
- } as any,
306
- };
307
-
308
- export const AlpineThemeFullFeatured: Story = {
309
- render: renderStory,
310
- name: 'Alpine Theme (Full Featured)',
311
- args: {
312
- type: 'object-aggrid',
313
- objectName: 'orders',
314
- dataSource: createMockDataSource('orders', ordersData),
315
- editable: true,
316
- singleClickEdit: true,
317
- pagination: true,
318
- pageSize: 5,
319
- theme: 'alpine',
320
- height: 550,
321
- rowSelection: 'multiple',
322
- exportConfig: {
323
- enabled: true,
324
- fileName: 'orders.csv'
325
- },
326
- statusBar: {
327
- enabled: true,
328
- aggregations: ['count', 'sum']
329
- },
330
- contextMenu: {
331
- enabled: true,
332
- items: ['copy', 'export', 'autoSizeAll']
333
- },
334
- columnConfig: {
335
- resizable: true,
336
- sortable: true,
337
- filterable: true
338
- }
339
- } as any,
340
- };
341
-
342
- export const BalhamThemeWithExport: Story = {
343
- render: renderStory,
344
- name: 'Balham Theme + Export',
345
- args: {
346
- type: 'object-aggrid',
347
- objectName: 'employees',
348
- dataSource: createMockDataSource('employees', employeesData),
349
- pagination: true,
350
- pageSize: 10,
351
- theme: 'balham',
352
- height: 500,
353
- rowSelection: 'multiple',
354
- exportConfig: {
355
- enabled: true,
356
- fileName: 'employees-balham.csv',
357
- onlySelected: true
358
- },
359
- columnConfig: {
360
- resizable: true,
361
- sortable: true,
362
- filterable: true
363
- }
364
- } as any,
365
- };
366
-
367
- export const MaterialThemeWithStatusBar: Story = {
368
- render: renderStory,
369
- name: 'Material Theme + Status Bar',
370
- args: {
371
- type: 'object-aggrid',
372
- objectName: 'orders',
373
- dataSource: createMockDataSource('orders', ordersData),
374
- pagination: true,
375
- pageSize: 10,
376
- theme: 'material',
377
- height: 550,
378
- rowSelection: 'multiple',
379
- statusBar: {
380
- enabled: true,
381
- aggregations: ['count', 'sum', 'avg']
382
- },
383
- columnConfig: {
384
- resizable: true,
385
- sortable: true,
386
- filterable: true
387
- }
388
- } as any,
389
- };
@@ -1,252 +0,0 @@
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: 'Plugins/Data Views/Object AgGrid',
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
- };