@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,158 +0,0 @@
1
- /**
2
- * ObjectUI
3
- * Copyright (c) 2024-present ObjectStack Inc.
4
- *
5
- * This source code is licensed under the MIT license found in the
6
- * LICENSE file in the root directory of this source tree.
7
- */
8
-
9
- /**
10
- * action:button — Smart action button driven by ActionSchema.
11
- *
12
- * Renders a Shadcn Button wired to the ActionRunner. Supports:
13
- * - All 5 spec action types (script, url, modal, flow, api)
14
- * - Conditional visibility & enabled state
15
- * - Loading indicator during async execution
16
- * - Icon rendering via Lucide
17
- * - Variant / size / className overrides from schema
18
- */
19
-
20
- import React, { forwardRef, useCallback, useState } from 'react';
21
- import { ComponentRegistry } from '@object-ui/core';
22
- import type { ActionSchema } from '@object-ui/types';
23
- import { useAction } from '@object-ui/react';
24
- import { useCondition } from '@object-ui/react';
25
- import { Button } from '../../ui';
26
- import { cn } from '../../lib/utils';
27
- import { Loader2 } from 'lucide-react';
28
- import { resolveIcon } from './resolve-icon';
29
-
30
- export interface ActionButtonProps {
31
- schema: ActionSchema & { type: string; className?: string; actionType?: string };
32
- className?: string;
33
- /** Override context for this specific action */
34
- context?: Record<string, any>;
35
- [key: string]: any;
36
- }
37
-
38
- const ActionButtonRenderer = forwardRef<HTMLButtonElement, ActionButtonProps>(
39
- ({ schema, className, context: localContext, ...props }, ref) => {
40
- const {
41
- 'data-obj-id': dataObjId,
42
- 'data-obj-type': dataObjType,
43
- style,
44
- data,
45
- ...rest
46
- } = props;
47
-
48
- const { execute } = useAction();
49
- const [loading, setLoading] = useState(false);
50
-
51
- // Record data may be passed from SchemaRenderer (e.g. DetailView passes record data)
52
- const recordData = data != null && typeof data === 'object' ? data as Record<string, any> : {};
53
-
54
- // Evaluate visibility and enabled conditions with record data context
55
- const isVisible = useCondition(schema.visible ? `\${${schema.visible}}` : undefined, recordData);
56
- const isEnabled = useCondition(schema.enabled ? `\${${schema.enabled}}` : undefined, recordData);
57
-
58
- // Resolve icon
59
- const Icon = resolveIcon(schema.icon);
60
-
61
- // Map schema variant to Shadcn button variant
62
- const variant = schema.variant === 'primary' ? 'default' : (schema.variant || 'default');
63
- const size = schema.size === 'md' ? 'default' : (schema.size || 'default');
64
-
65
- const handleClick = useCallback(async () => {
66
- if (loading) return;
67
- setLoading(true);
68
-
69
- try {
70
- // Route params correctly:
71
- // - Array of objects with name+type → ActionParamDef[] → pass as actionParams for collection
72
- // - Otherwise → pass as actual param values
73
- const paramsPayload = Array.isArray(schema.params)
74
- ? { actionParams: schema.params as any }
75
- : { params: schema.params as Record<string, any> | undefined };
76
-
77
- await execute({
78
- type: schema.actionType || schema.type,
79
- name: schema.name,
80
- target: schema.target,
81
- execute: schema.execute,
82
- endpoint: schema.endpoint,
83
- method: schema.method,
84
- ...paramsPayload,
85
- confirmText: schema.confirmText,
86
- successMessage: schema.successMessage,
87
- errorMessage: schema.errorMessage,
88
- refreshAfter: schema.refreshAfter,
89
- toast: schema.toast,
90
- ...localContext,
91
- });
92
- } finally {
93
- setLoading(false);
94
- }
95
- }, [schema, execute, loading, localContext]);
96
-
97
- if (schema.visible && !isVisible) return null;
98
-
99
- return (
100
- <Button
101
- ref={ref}
102
- type="button"
103
- variant={variant as any}
104
- size={size as any}
105
- className={cn(schema.className, className)}
106
- disabled={(schema.enabled ? !isEnabled : false) || loading}
107
- onClick={handleClick}
108
- {...rest}
109
- {...{ 'data-obj-id': dataObjId, 'data-obj-type': dataObjType, style }}
110
- >
111
- {loading && <Loader2 className="mr-2 h-4 w-4 animate-spin" />}
112
- {!loading && Icon && <Icon className={cn('h-4 w-4', schema.label && 'mr-2')} />}
113
- {schema.label}
114
- </Button>
115
- );
116
- },
117
- );
118
-
119
- ActionButtonRenderer.displayName = 'ActionButtonRenderer';
120
-
121
- ComponentRegistry.register('action:button', ActionButtonRenderer, {
122
- namespace: 'action',
123
- label: 'Action Button',
124
- inputs: [
125
- { name: 'name', type: 'string', label: 'Action Name' },
126
- { name: 'label', type: 'string', label: 'Label', defaultValue: 'Action' },
127
- { name: 'icon', type: 'string', label: 'Icon' },
128
- {
129
- name: 'type',
130
- type: 'enum',
131
- label: 'Action Type',
132
- enum: ['script', 'url', 'modal', 'flow', 'api'],
133
- defaultValue: 'script',
134
- },
135
- { name: 'target', type: 'string', label: 'Target' },
136
- {
137
- name: 'variant',
138
- type: 'enum',
139
- label: 'Variant',
140
- enum: ['default', 'primary', 'secondary', 'destructive', 'outline', 'ghost'],
141
- defaultValue: 'default',
142
- },
143
- {
144
- name: 'size',
145
- type: 'enum',
146
- label: 'Size',
147
- enum: ['sm', 'md', 'lg'],
148
- defaultValue: 'md',
149
- },
150
- { name: 'className', type: 'string', label: 'CSS Class', advanced: true },
151
- ],
152
- defaultProps: {
153
- label: 'Action',
154
- type: 'script',
155
- variant: 'default',
156
- size: 'md',
157
- },
158
- });
@@ -1,270 +0,0 @@
1
- /**
2
- * ObjectUI
3
- * Copyright (c) 2024-present ObjectStack Inc.
4
- *
5
- * This source code is licensed under the MIT license found in the
6
- * LICENSE file in the root directory of this source tree.
7
- */
8
-
9
- /**
10
- * action:group — Toolbar or button group for organizing related actions.
11
- *
12
- * Supports two display modes:
13
- * - 'inline': Renders all actions as a horizontal button row
14
- * - 'dropdown': Renders a primary button + dropdown for overflow
15
- *
16
- * Filters actions by location when `location` prop is provided.
17
- */
18
-
19
- import React, { forwardRef, useCallback, useState } from 'react';
20
- import { ComponentRegistry } from '@object-ui/core';
21
- import type { ActionSchema, ActionGroup, ActionLocation } from '@object-ui/types';
22
- import { useAction } from '@object-ui/react';
23
- import { useCondition } from '@object-ui/react';
24
- import { Button } from '../../ui';
25
- import {
26
- DropdownMenu,
27
- DropdownMenuContent,
28
- DropdownMenuItem,
29
- DropdownMenuSeparator,
30
- DropdownMenuTrigger,
31
- } from '../../ui';
32
- import { cn } from '../../lib/utils';
33
- import { Loader2, ChevronDown } from 'lucide-react';
34
- import { resolveIcon } from './resolve-icon';
35
-
36
- export interface ActionGroupSchema {
37
- type: 'action:group';
38
- /** Group name */
39
- name?: string;
40
- /** Group label */
41
- label?: string;
42
- /** Group icon */
43
- icon?: string;
44
- /** Actions in this group */
45
- actions?: ActionSchema[];
46
- /** Display mode: inline button row or dropdown */
47
- display?: 'dropdown' | 'inline';
48
- /** Filter actions by location */
49
- location?: ActionLocation;
50
- /** Group visibility condition */
51
- visible?: string;
52
- /** Button variant for inline actions */
53
- variant?: string;
54
- /** Button size for inline actions */
55
- size?: string;
56
- /** Custom CSS class */
57
- className?: string;
58
- [key: string]: any;
59
- }
60
-
61
- /**
62
- * Inline action button within a group.
63
- */
64
- const InlineActionButton: React.FC<{
65
- action: ActionSchema;
66
- variant?: string;
67
- size?: string;
68
- onExecute: (action: ActionSchema) => Promise<void>;
69
- }> = ({ action, variant, size, onExecute }) => {
70
- const [loading, setLoading] = useState(false);
71
- const isVisible = useCondition(action.visible ? `\${${action.visible}}` : undefined);
72
- const isEnabled = useCondition(action.enabled ? `\${${action.enabled}}` : undefined);
73
-
74
- const Icon = resolveIcon(action.icon);
75
- const btnVariant = (action.variant as string) === 'primary' ? 'default' : (action.variant || variant || 'outline');
76
- const btnSize = action.size === 'md' ? 'default' : (action.size || size || 'sm');
77
-
78
- const handleClick = useCallback(async () => {
79
- if (loading) return;
80
- setLoading(true);
81
- try {
82
- await onExecute(action);
83
- } finally {
84
- setLoading(false);
85
- }
86
- }, [action, onExecute, loading]);
87
-
88
- if (action.visible && !isVisible) return null;
89
-
90
- return (
91
- <Button
92
- type="button"
93
- variant={btnVariant as any}
94
- size={btnSize as any}
95
- className={action.className}
96
- disabled={(action.enabled ? !isEnabled : false) || loading}
97
- onClick={handleClick}
98
- >
99
- {loading && <Loader2 className="mr-2 h-4 w-4 animate-spin" />}
100
- {!loading && Icon && <Icon className={cn('h-4 w-4', action.label && 'mr-2')} />}
101
- {action.label}
102
- </Button>
103
- );
104
- };
105
-
106
- InlineActionButton.displayName = 'InlineActionButton';
107
-
108
- const ActionGroupRenderer = forwardRef<HTMLDivElement, { schema: ActionGroupSchema; [key: string]: any }>(
109
- ({ schema, className, ...props }, ref) => {
110
- const {
111
- 'data-obj-id': dataObjId,
112
- 'data-obj-type': dataObjType,
113
- style,
114
- ...rest
115
- } = props;
116
-
117
- const { execute } = useAction();
118
- const [dropdownLoading, setDropdownLoading] = useState(false);
119
-
120
- const isVisible = useCondition(schema.visible ? `\${${schema.visible}}` : undefined);
121
-
122
- // Filter actions by location if specified
123
- let actions = schema.actions || [];
124
- if (schema.location) {
125
- actions = actions.filter(
126
- a => !a.locations || a.locations.includes(schema.location!),
127
- );
128
- }
129
-
130
- const handleExecute = useCallback(
131
- async (action: ActionSchema) => {
132
- await execute({
133
- type: action.type,
134
- name: action.name,
135
- target: action.target,
136
- execute: action.execute,
137
- endpoint: action.endpoint,
138
- method: action.method,
139
- params: action.params as Record<string, any> | undefined,
140
- confirmText: action.confirmText,
141
- successMessage: action.successMessage,
142
- errorMessage: action.errorMessage,
143
- refreshAfter: action.refreshAfter,
144
- toast: action.toast,
145
- });
146
- },
147
- [execute],
148
- );
149
-
150
- if (schema.visible && !isVisible) return null;
151
- if (actions.length === 0) return null;
152
-
153
- const display = schema.display || 'inline';
154
-
155
- // --- DROPDOWN MODE ---
156
- if (display === 'dropdown') {
157
- const TriggerIcon = resolveIcon(schema.icon);
158
- return (
159
- <DropdownMenu>
160
- <DropdownMenuTrigger asChild>
161
- <Button
162
- type="button"
163
- variant={(schema.variant || 'outline') as any}
164
- size={(schema.size === 'md' ? 'default' : (schema.size || 'default')) as any}
165
- className={cn(schema.className, className)}
166
- disabled={dropdownLoading}
167
- {...{ 'data-obj-id': dataObjId, 'data-obj-type': dataObjType, style }}
168
- >
169
- {dropdownLoading && <Loader2 className="mr-2 h-4 w-4 animate-spin" />}
170
- {!dropdownLoading && TriggerIcon && <TriggerIcon className="mr-2 h-4 w-4" />}
171
- {schema.label || 'Actions'}
172
- <ChevronDown className="ml-2 h-3 w-3 opacity-50" />
173
- </Button>
174
- </DropdownMenuTrigger>
175
-
176
- <DropdownMenuContent align="end">
177
- {actions.map((action, index) => {
178
- const Icon = resolveIcon(action.icon);
179
- const showSeparator = action.tags?.includes('separator-before') && index > 0;
180
- return (
181
- <React.Fragment key={action.name || index}>
182
- {showSeparator && <DropdownMenuSeparator />}
183
- <DropdownMenuItem
184
- onSelect={async (e) => {
185
- e.preventDefault();
186
- setDropdownLoading(true);
187
- try {
188
- await handleExecute(action);
189
- } finally {
190
- setDropdownLoading(false);
191
- }
192
- }}
193
- className={cn(
194
- action.variant === 'destructive' && 'text-destructive focus:text-destructive',
195
- action.className,
196
- )}
197
- >
198
- {Icon && <Icon className="mr-2 h-4 w-4" />}
199
- <span>{action.label || action.name}</span>
200
- </DropdownMenuItem>
201
- </React.Fragment>
202
- );
203
- })}
204
- </DropdownMenuContent>
205
- </DropdownMenu>
206
- );
207
- }
208
-
209
- // --- INLINE MODE (default) ---
210
- return (
211
- <div
212
- ref={ref}
213
- className={cn('flex items-center gap-2', schema.className, className)}
214
- {...rest}
215
- {...{ 'data-obj-id': dataObjId, 'data-obj-type': dataObjType, style }}
216
- >
217
- {actions.map((action) => (
218
- <InlineActionButton
219
- key={action.name}
220
- action={action}
221
- variant={schema.variant}
222
- size={schema.size}
223
- onExecute={handleExecute}
224
- />
225
- ))}
226
- </div>
227
- );
228
- },
229
- );
230
-
231
- ActionGroupRenderer.displayName = 'ActionGroupRenderer';
232
-
233
- ComponentRegistry.register('action:group', ActionGroupRenderer, {
234
- namespace: 'action',
235
- label: 'Action Group',
236
- inputs: [
237
- { name: 'name', type: 'string', label: 'Group Name' },
238
- { name: 'label', type: 'string', label: 'Label' },
239
- { name: 'icon', type: 'string', label: 'Icon' },
240
- { name: 'actions', type: 'object', label: 'Actions' },
241
- {
242
- name: 'display',
243
- type: 'enum',
244
- label: 'Display Mode',
245
- enum: ['inline', 'dropdown'],
246
- defaultValue: 'inline',
247
- },
248
- {
249
- name: 'variant',
250
- type: 'enum',
251
- label: 'Variant',
252
- enum: ['default', 'secondary', 'outline', 'ghost'],
253
- defaultValue: 'outline',
254
- },
255
- {
256
- name: 'size',
257
- type: 'enum',
258
- label: 'Size',
259
- enum: ['sm', 'md', 'lg'],
260
- defaultValue: 'sm',
261
- },
262
- { name: 'className', type: 'string', label: 'CSS Class', advanced: true },
263
- ],
264
- defaultProps: {
265
- display: 'inline',
266
- variant: 'outline',
267
- size: 'sm',
268
- actions: [],
269
- },
270
- });
@@ -1,150 +0,0 @@
1
- /**
2
- * ObjectUI
3
- * Copyright (c) 2024-present ObjectStack Inc.
4
- *
5
- * This source code is licensed under the MIT license found in the
6
- * LICENSE file in the root directory of this source tree.
7
- */
8
-
9
- /**
10
- * action:icon — Icon-only action button for dense layouts.
11
- *
12
- * Renders a Shadcn Button (size="icon") with tooltip and ActionRunner integration.
13
- */
14
-
15
- import React, { forwardRef, useCallback, useState } from 'react';
16
- import { ComponentRegistry } from '@object-ui/core';
17
- import type { ActionSchema } from '@object-ui/types';
18
- import { useAction } from '@object-ui/react';
19
- import { useCondition } from '@object-ui/react';
20
- import { Button } from '../../ui';
21
- import { Tooltip, TooltipContent, TooltipProvider, TooltipTrigger } from '../../ui';
22
- import { cn } from '../../lib/utils';
23
- import { Loader2 } from 'lucide-react';
24
- import { resolveIcon } from './resolve-icon';
25
-
26
- export interface ActionIconProps {
27
- schema: ActionSchema & { type: string; className?: string };
28
- className?: string;
29
- context?: Record<string, any>;
30
- [key: string]: any;
31
- }
32
-
33
- const ActionIconRenderer = forwardRef<HTMLButtonElement, ActionIconProps>(
34
- ({ schema, className, context: localContext, ...props }, ref) => {
35
- const {
36
- 'data-obj-id': dataObjId,
37
- 'data-obj-type': dataObjType,
38
- style,
39
- ...rest
40
- } = props;
41
-
42
- const { execute } = useAction();
43
- const [loading, setLoading] = useState(false);
44
-
45
- const isVisible = useCondition(schema.visible ? `\${${schema.visible}}` : undefined);
46
- const isEnabled = useCondition(schema.enabled ? `\${${schema.enabled}}` : undefined);
47
-
48
- const Icon = resolveIcon(schema.icon);
49
- const variant = schema.variant === 'primary' ? 'default' : (schema.variant || 'ghost');
50
- const size = 'icon';
51
-
52
- const handleClick = useCallback(async () => {
53
- if (loading) return;
54
- setLoading(true);
55
- try {
56
- await execute({
57
- type: schema.type,
58
- name: schema.name,
59
- target: schema.target,
60
- execute: schema.execute,
61
- endpoint: schema.endpoint,
62
- method: schema.method,
63
- params: schema.params as Record<string, any> | undefined,
64
- confirmText: schema.confirmText,
65
- successMessage: schema.successMessage,
66
- errorMessage: schema.errorMessage,
67
- refreshAfter: schema.refreshAfter,
68
- toast: schema.toast,
69
- ...localContext,
70
- });
71
- } finally {
72
- setLoading(false);
73
- }
74
- }, [schema, execute, loading, localContext]);
75
-
76
- if (schema.visible && !isVisible) return null;
77
-
78
- const button = (
79
- <Button
80
- ref={ref}
81
- type="button"
82
- variant={variant as any}
83
- size={size}
84
- className={cn('h-8 w-8', schema.className, className)}
85
- disabled={(schema.enabled ? !isEnabled : false) || loading}
86
- onClick={handleClick}
87
- aria-label={schema.label || schema.name}
88
- {...rest}
89
- {...{ 'data-obj-id': dataObjId, 'data-obj-type': dataObjType, style }}
90
- >
91
- {loading ? (
92
- <Loader2 className="h-4 w-4 animate-spin" />
93
- ) : Icon ? (
94
- <Icon className="h-4 w-4" />
95
- ) : (
96
- <span className="text-xs">{schema.label?.charAt(0) || '?'}</span>
97
- )}
98
- </Button>
99
- );
100
-
101
- // Wrap with tooltip if label is provided
102
- if (schema.label || schema.description) {
103
- return (
104
- <TooltipProvider delayDuration={300}>
105
- <Tooltip>
106
- <TooltipTrigger asChild>{button}</TooltipTrigger>
107
- <TooltipContent>
108
- <p>{schema.label || schema.description}</p>
109
- </TooltipContent>
110
- </Tooltip>
111
- </TooltipProvider>
112
- );
113
- }
114
-
115
- return button;
116
- },
117
- );
118
-
119
- ActionIconRenderer.displayName = 'ActionIconRenderer';
120
-
121
- ComponentRegistry.register('action:icon', ActionIconRenderer, {
122
- namespace: 'action',
123
- label: 'Action Icon',
124
- inputs: [
125
- { name: 'name', type: 'string', label: 'Action Name' },
126
- { name: 'label', type: 'string', label: 'Tooltip Label' },
127
- { name: 'icon', type: 'string', label: 'Icon' },
128
- {
129
- name: 'type',
130
- type: 'enum',
131
- label: 'Action Type',
132
- enum: ['script', 'url', 'modal', 'flow', 'api'],
133
- defaultValue: 'script',
134
- },
135
- { name: 'target', type: 'string', label: 'Target' },
136
- {
137
- name: 'variant',
138
- type: 'enum',
139
- label: 'Variant',
140
- enum: ['default', 'secondary', 'destructive', 'outline', 'ghost'],
141
- defaultValue: 'ghost',
142
- },
143
- { name: 'className', type: 'string', label: 'CSS Class', advanced: true },
144
- ],
145
- defaultProps: {
146
- icon: 'play',
147
- type: 'script',
148
- variant: 'ghost',
149
- },
150
- });