@treenity/react 3.0.0 → 3.0.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 (369) hide show
  1. package/README.md +91 -0
  2. package/dist/AclEditor.d.ts +1 -1
  3. package/dist/AclEditor.d.ts.map +1 -1
  4. package/dist/AclEditor.js +5 -5
  5. package/dist/AclEditor.js.map +1 -1
  6. package/dist/ActionCards.d.ts +9 -0
  7. package/dist/ActionCards.d.ts.map +1 -0
  8. package/dist/ActionCards.js +96 -0
  9. package/dist/ActionCards.js.map +1 -0
  10. package/dist/App.d.ts.map +1 -1
  11. package/dist/App.js +71 -185
  12. package/dist/App.js.map +1 -1
  13. package/dist/ComponentSection.d.ts +15 -0
  14. package/dist/ComponentSection.d.ts.map +1 -0
  15. package/dist/ComponentSection.js +25 -0
  16. package/dist/ComponentSection.js.map +1 -0
  17. package/dist/ErrorBoundary.d.ts +18 -0
  18. package/dist/ErrorBoundary.d.ts.map +1 -0
  19. package/dist/ErrorBoundary.js +17 -0
  20. package/dist/ErrorBoundary.js.map +1 -0
  21. package/dist/Inspector.d.ts +1 -0
  22. package/dist/Inspector.d.ts.map +1 -1
  23. package/dist/Inspector.js +22 -347
  24. package/dist/Inspector.js.map +1 -1
  25. package/dist/Login.d.ts +8 -0
  26. package/dist/Login.d.ts.map +1 -0
  27. package/dist/Login.js +45 -0
  28. package/dist/Login.js.map +1 -0
  29. package/dist/NodeEditor.d.ts +11 -0
  30. package/dist/NodeEditor.d.ts.map +1 -0
  31. package/dist/NodeEditor.js +157 -0
  32. package/dist/NodeEditor.js.map +1 -0
  33. package/dist/Tree.d.ts +1 -0
  34. package/dist/Tree.d.ts.map +1 -1
  35. package/dist/Tree.js +8 -27
  36. package/dist/Tree.js.map +1 -1
  37. package/dist/bind/engine.js +1 -1
  38. package/dist/bind/engine.js.map +1 -1
  39. package/dist/bind/eval.d.ts +1 -1
  40. package/dist/bind/eval.d.ts.map +1 -1
  41. package/dist/bind/hook.d.ts +1 -1
  42. package/dist/bind/hook.d.ts.map +1 -1
  43. package/dist/bind/hook.js +1 -1
  44. package/dist/bind/hook.js.map +1 -1
  45. package/dist/cache.d.ts +1 -1
  46. package/dist/cache.d.ts.map +1 -1
  47. package/dist/cache.js +4 -0
  48. package/dist/cache.js.map +1 -1
  49. package/dist/client-tree.d.ts +1 -2
  50. package/dist/client-tree.d.ts.map +1 -1
  51. package/dist/client-tree.js +12 -5
  52. package/dist/client-tree.js.map +1 -1
  53. package/dist/client.d.ts +1 -1
  54. package/dist/client.d.ts.map +1 -1
  55. package/dist/client.js +2 -4
  56. package/dist/client.js.map +1 -1
  57. package/dist/components/ConfirmDialog.d.ts +9 -0
  58. package/dist/components/ConfirmDialog.d.ts.map +1 -0
  59. package/dist/components/ConfirmDialog.js +6 -0
  60. package/dist/components/ConfirmDialog.js.map +1 -0
  61. package/dist/components/ConfirmPopover.d.ts +8 -0
  62. package/dist/components/ConfirmPopover.d.ts.map +1 -0
  63. package/dist/components/ConfirmPopover.js +9 -0
  64. package/dist/components/ConfirmPopover.js.map +1 -0
  65. package/dist/components/PathBreadcrumb.d.ts +5 -0
  66. package/dist/components/PathBreadcrumb.d.ts.map +1 -0
  67. package/dist/components/PathBreadcrumb.js +16 -0
  68. package/dist/components/PathBreadcrumb.js.map +1 -0
  69. package/dist/components/lib/utils.d.ts +3 -0
  70. package/dist/components/lib/utils.d.ts.map +1 -0
  71. package/dist/components/lib/utils.js +6 -0
  72. package/dist/components/lib/utils.js.map +1 -0
  73. package/dist/components/ui/accordion.js +1 -1
  74. package/dist/components/ui/accordion.js.map +1 -1
  75. package/dist/components/ui/alert-dialog.d.ts +19 -0
  76. package/dist/components/ui/alert-dialog.d.ts.map +1 -0
  77. package/dist/components/ui/alert-dialog.js +42 -0
  78. package/dist/components/ui/alert-dialog.js.map +1 -0
  79. package/dist/components/ui/badge.js +1 -1
  80. package/dist/components/ui/badge.js.map +1 -1
  81. package/dist/components/ui/breadcrumb.d.ts +12 -0
  82. package/dist/components/ui/breadcrumb.d.ts.map +1 -0
  83. package/dist/components/ui/breadcrumb.js +28 -0
  84. package/dist/components/ui/breadcrumb.js.map +1 -0
  85. package/dist/components/ui/button.d.ts +9 -8
  86. package/dist/components/ui/button.d.ts.map +1 -1
  87. package/dist/components/ui/button.js +26 -21
  88. package/dist/components/ui/button.js.map +1 -1
  89. package/dist/components/ui/card.d.ts +10 -0
  90. package/dist/components/ui/card.d.ts.map +1 -0
  91. package/dist/components/ui/card.js +25 -0
  92. package/dist/components/ui/card.js.map +1 -0
  93. package/dist/components/ui/checkbox.js +1 -1
  94. package/dist/components/ui/checkbox.js.map +1 -1
  95. package/dist/components/ui/collapsible.d.ts +6 -0
  96. package/dist/components/ui/collapsible.d.ts.map +1 -0
  97. package/dist/components/ui/collapsible.js +13 -0
  98. package/dist/components/ui/collapsible.js.map +1 -0
  99. package/dist/components/ui/command.d.ts +19 -0
  100. package/dist/components/ui/command.d.ts.map +1 -0
  101. package/dist/components/ui/command.js +35 -0
  102. package/dist/components/ui/command.js.map +1 -0
  103. package/dist/components/ui/dialog.d.ts.map +1 -1
  104. package/dist/components/ui/dialog.js +1 -1
  105. package/dist/components/ui/dialog.js.map +1 -1
  106. package/dist/components/ui/drawer.js +1 -1
  107. package/dist/components/ui/drawer.js.map +1 -1
  108. package/dist/components/ui/dropdown-menu.d.ts +26 -0
  109. package/dist/components/ui/dropdown-menu.d.ts.map +1 -0
  110. package/dist/components/ui/dropdown-menu.js +52 -0
  111. package/dist/components/ui/dropdown-menu.js.map +1 -0
  112. package/dist/components/ui/form-field.d.ts +7 -0
  113. package/dist/components/ui/form-field.d.ts.map +1 -0
  114. package/dist/components/ui/form-field.js +17 -0
  115. package/dist/components/ui/form-field.js.map +1 -0
  116. package/dist/components/ui/input.js +1 -1
  117. package/dist/components/ui/input.js.map +1 -1
  118. package/dist/components/ui/label.js +1 -1
  119. package/dist/components/ui/label.js.map +1 -1
  120. package/dist/components/ui/pagination.d.ts +14 -0
  121. package/dist/components/ui/pagination.d.ts.map +1 -0
  122. package/dist/components/ui/pagination.js +30 -0
  123. package/dist/components/ui/pagination.js.map +1 -0
  124. package/dist/components/ui/popover.js +2 -2
  125. package/dist/components/ui/popover.js.map +1 -1
  126. package/dist/components/ui/progress.js +1 -1
  127. package/dist/components/ui/progress.js.map +1 -1
  128. package/dist/components/ui/resizable.d.ts +8 -0
  129. package/dist/components/ui/resizable.d.ts.map +1 -0
  130. package/dist/components/ui/resizable.js +14 -0
  131. package/dist/components/ui/resizable.js.map +1 -0
  132. package/dist/components/ui/scroll-area.d.ts +6 -0
  133. package/dist/components/ui/scroll-area.d.ts.map +1 -0
  134. package/dist/components/ui/scroll-area.js +13 -0
  135. package/dist/components/ui/scroll-area.js.map +1 -0
  136. package/dist/components/ui/select.js +1 -1
  137. package/dist/components/ui/select.js.map +1 -1
  138. package/dist/components/ui/separator.d.ts +5 -0
  139. package/dist/components/ui/separator.d.ts.map +1 -0
  140. package/dist/components/ui/separator.js +9 -0
  141. package/dist/components/ui/separator.js.map +1 -0
  142. package/dist/components/ui/sheet.d.ts +15 -0
  143. package/dist/components/ui/sheet.d.ts.map +1 -0
  144. package/dist/components/ui/sheet.js +40 -0
  145. package/dist/components/ui/sheet.js.map +1 -0
  146. package/dist/components/ui/skeleton.d.ts +3 -0
  147. package/dist/components/ui/skeleton.d.ts.map +1 -0
  148. package/dist/components/ui/skeleton.js +7 -0
  149. package/dist/components/ui/skeleton.js.map +1 -0
  150. package/dist/components/ui/slider.js +1 -1
  151. package/dist/components/ui/slider.js.map +1 -1
  152. package/dist/components/ui/switch.js +1 -1
  153. package/dist/components/ui/switch.js.map +1 -1
  154. package/dist/components/ui/table.d.ts +11 -0
  155. package/dist/components/ui/table.d.ts.map +1 -0
  156. package/dist/components/ui/table.js +29 -0
  157. package/dist/components/ui/table.js.map +1 -0
  158. package/dist/components/ui/tabs.d.ts +12 -0
  159. package/dist/components/ui/tabs.d.ts.map +1 -0
  160. package/dist/components/ui/tabs.js +29 -0
  161. package/dist/components/ui/tabs.js.map +1 -0
  162. package/dist/components/ui/textarea.js +1 -1
  163. package/dist/components/ui/textarea.js.map +1 -1
  164. package/dist/components/ui/toggle-group.d.ts +10 -0
  165. package/dist/components/ui/toggle-group.d.ts.map +1 -0
  166. package/dist/components/ui/toggle-group.js +23 -0
  167. package/dist/components/ui/toggle-group.js.map +1 -0
  168. package/dist/components/ui/toggle.d.ts +10 -0
  169. package/dist/components/ui/toggle.d.ts.map +1 -0
  170. package/dist/components/ui/toggle.js +27 -0
  171. package/dist/components/ui/toggle.js.map +1 -0
  172. package/dist/components/ui/tooltip.js +1 -1
  173. package/dist/components/ui/tooltip.js.map +1 -1
  174. package/dist/context/index.d.ts +27 -10
  175. package/dist/context/index.d.ts.map +1 -1
  176. package/dist/context/index.js +43 -36
  177. package/dist/context/index.js.map +1 -1
  178. package/dist/events.d.ts +10 -0
  179. package/dist/events.d.ts.map +1 -0
  180. package/dist/events.js +78 -0
  181. package/dist/events.js.map +1 -0
  182. package/dist/fiber-tree.d.ts +3 -0
  183. package/dist/fiber-tree.d.ts.map +1 -0
  184. package/dist/fiber-tree.js +93 -0
  185. package/dist/fiber-tree.js.map +1 -0
  186. package/dist/hooks.d.ts +5 -2
  187. package/dist/hooks.d.ts.map +1 -1
  188. package/dist/hooks.js +66 -6
  189. package/dist/hooks.js.map +1 -1
  190. package/dist/idb.d.ts +1 -1
  191. package/dist/idb.d.ts.map +1 -1
  192. package/dist/lib/to-plain.d.ts +2 -0
  193. package/dist/lib/to-plain.d.ts.map +1 -0
  194. package/dist/lib/to-plain.js +21 -0
  195. package/dist/lib/to-plain.js.map +1 -0
  196. package/dist/main.d.ts +1 -1
  197. package/dist/main.d.ts.map +1 -1
  198. package/dist/main.js +4 -3
  199. package/dist/main.js.map +1 -1
  200. package/dist/mods/clients.d.ts +3 -0
  201. package/dist/mods/clients.d.ts.map +1 -0
  202. package/dist/mods/clients.js +4 -0
  203. package/dist/mods/clients.js.map +1 -0
  204. package/dist/mods/editor-ui/FieldLabel.d.ts +15 -0
  205. package/dist/mods/editor-ui/FieldLabel.d.ts.map +1 -0
  206. package/dist/mods/editor-ui/FieldLabel.js +55 -0
  207. package/dist/mods/editor-ui/FieldLabel.js.map +1 -0
  208. package/dist/mods/editor-ui/client.d.ts +1 -1
  209. package/dist/mods/editor-ui/client.d.ts.map +1 -1
  210. package/dist/mods/editor-ui/client.js +1 -1
  211. package/dist/mods/editor-ui/client.js.map +1 -1
  212. package/dist/mods/editor-ui/default-edit.d.ts +2 -0
  213. package/dist/mods/editor-ui/default-edit.d.ts.map +1 -0
  214. package/dist/mods/editor-ui/default-edit.js +54 -0
  215. package/dist/mods/editor-ui/default-edit.js.map +1 -0
  216. package/dist/mods/editor-ui/default-view.d.ts +8 -1
  217. package/dist/mods/editor-ui/default-view.d.ts.map +1 -1
  218. package/dist/mods/editor-ui/default-view.js +8 -5
  219. package/dist/mods/editor-ui/default-view.js.map +1 -1
  220. package/dist/mods/editor-ui/dir-view.js +0 -2
  221. package/dist/mods/editor-ui/dir-view.js.map +1 -1
  222. package/dist/mods/editor-ui/empty-placeholder.d.ts +5 -0
  223. package/dist/mods/editor-ui/empty-placeholder.d.ts.map +1 -0
  224. package/dist/mods/editor-ui/empty-placeholder.js +14 -0
  225. package/dist/mods/editor-ui/empty-placeholder.js.map +1 -0
  226. package/dist/mods/editor-ui/form-field.d.ts +17 -0
  227. package/dist/mods/editor-ui/form-field.d.ts.map +1 -0
  228. package/dist/mods/editor-ui/form-field.js +68 -0
  229. package/dist/mods/editor-ui/form-field.js.map +1 -0
  230. package/dist/mods/editor-ui/form-fields.d.ts +1 -2
  231. package/dist/mods/editor-ui/form-fields.d.ts.map +1 -1
  232. package/dist/mods/editor-ui/form-fields.js +56 -60
  233. package/dist/mods/editor-ui/form-fields.js.map +1 -1
  234. package/dist/mods/editor-ui/layout-view.js +3 -2
  235. package/dist/mods/editor-ui/layout-view.js.map +1 -1
  236. package/dist/mods/editor-ui/list-items.js +1 -1
  237. package/dist/mods/editor-ui/list-items.js.map +1 -1
  238. package/dist/mods/editor-ui/node-utils.d.ts +2 -2
  239. package/dist/mods/editor-ui/node-utils.d.ts.map +1 -1
  240. package/dist/mods/editor-ui/node-utils.js +4 -5
  241. package/dist/mods/editor-ui/node-utils.js.map +1 -1
  242. package/dist/mods/editor-ui/type-picker.d.ts +15 -0
  243. package/dist/mods/editor-ui/type-picker.d.ts.map +1 -0
  244. package/dist/mods/editor-ui/type-picker.js +69 -0
  245. package/dist/mods/editor-ui/type-picker.js.map +1 -0
  246. package/dist/mods/editor-ui/user-view.js +1 -1
  247. package/dist/mods/editor-ui/user-view.js.map +1 -1
  248. package/dist/mods/servers.d.ts +1 -0
  249. package/dist/mods/servers.d.ts.map +1 -0
  250. package/dist/mods/servers.js +4 -0
  251. package/dist/mods/servers.js.map +1 -0
  252. package/dist/mods/treenity/groups/index.js +1 -1
  253. package/dist/mods/treenity/groups/index.js.map +1 -1
  254. package/dist/mods/treenity/preview.js +1 -1
  255. package/dist/mods/treenity/preview.js.map +1 -1
  256. package/dist/mods/treenity/ref-view.js +1 -1
  257. package/dist/mods/treenity/ref-view.js.map +1 -1
  258. package/dist/mods/treenity/schema-form.js +1 -1
  259. package/dist/mods/treenity/schema-form.js.map +1 -1
  260. package/dist/mods/treenity/seed.js +1 -1
  261. package/dist/mods/treenity/seed.js.map +1 -1
  262. package/dist/mods/treenity/type-view.js +1 -1
  263. package/dist/mods/treenity/type-view.js.map +1 -1
  264. package/dist/schema-loader.d.ts +1 -1
  265. package/dist/schema-loader.d.ts.map +1 -1
  266. package/dist/schema-loader.js +1 -1
  267. package/dist/schema-loader.js.map +1 -1
  268. package/dist/symbols.d.ts +5 -0
  269. package/dist/symbols.d.ts.map +1 -0
  270. package/dist/symbols.js +16 -0
  271. package/dist/symbols.js.map +1 -0
  272. package/dist/trpc.d.ts +10 -3
  273. package/dist/trpc.d.ts.map +1 -1
  274. package/package.json +74 -8
  275. package/src/AclEditor.tsx +11 -18
  276. package/src/ActionCards.tsx +224 -0
  277. package/src/App.tsx +204 -385
  278. package/src/ComponentSection.tsx +113 -0
  279. package/src/ErrorBoundary.tsx +37 -0
  280. package/src/Inspector.css +54 -0
  281. package/src/Inspector.tsx +73 -793
  282. package/src/Login.tsx +97 -0
  283. package/src/NodeEditor.tsx +300 -0
  284. package/src/Tree.css +91 -0
  285. package/src/Tree.tsx +40 -43
  286. package/src/bind/bind.test.ts +1 -1
  287. package/src/bind/engine.ts +1 -1
  288. package/src/bind/eval.ts +1 -1
  289. package/src/bind/hook.ts +1 -1
  290. package/src/bind/pipes.ts +1 -1
  291. package/src/cache.ts +5 -1
  292. package/src/client-tree.test.ts +1 -1
  293. package/src/client-tree.ts +22 -16
  294. package/src/client.ts +2 -4
  295. package/src/components/ConfirmDialog.tsx +34 -0
  296. package/src/components/ConfirmPopover.tsx +41 -0
  297. package/src/components/PathBreadcrumb.tsx +36 -0
  298. package/src/components/lib/utils.ts +6 -0
  299. package/src/components/lib/utils.ts.bak +6 -0
  300. package/src/components/ui/accordion.tsx +1 -1
  301. package/src/components/ui/alert-dialog.tsx +189 -0
  302. package/src/components/ui/badge.tsx +1 -1
  303. package/src/components/ui/breadcrumb.tsx +108 -0
  304. package/src/components/ui/button.tsx +53 -31
  305. package/src/components/ui/card.tsx +91 -0
  306. package/src/components/ui/checkbox.tsx +1 -1
  307. package/src/components/ui/collapsible.tsx +31 -0
  308. package/src/components/ui/command.tsx +177 -0
  309. package/src/components/ui/dialog.tsx +1 -2
  310. package/src/components/ui/drawer.tsx +1 -1
  311. package/src/components/ui/dropdown-menu.tsx +256 -0
  312. package/src/components/ui/form-field.tsx +37 -0
  313. package/src/components/ui/input.tsx +1 -1
  314. package/src/components/ui/label.tsx +1 -1
  315. package/src/components/ui/pagination.tsx +127 -0
  316. package/src/components/ui/popover.tsx +2 -2
  317. package/src/components/ui/progress.tsx +1 -1
  318. package/src/components/ui/resizable.tsx +47 -0
  319. package/src/components/ui/scroll-area.tsx +55 -0
  320. package/src/components/ui/select.tsx +1 -1
  321. package/src/components/ui/separator.tsx +27 -0
  322. package/src/components/ui/sheet.tsx +140 -0
  323. package/src/components/ui/skeleton.tsx +13 -0
  324. package/src/components/ui/slider.tsx +1 -1
  325. package/src/components/ui/switch.tsx +1 -1
  326. package/src/components/ui/table.tsx +115 -0
  327. package/src/components/ui/tabs.tsx +88 -0
  328. package/src/components/ui/textarea.tsx +1 -1
  329. package/src/components/ui/toggle-group.tsx +82 -0
  330. package/src/components/ui/toggle.tsx +46 -0
  331. package/src/components/ui/tooltip.tsx +1 -1
  332. package/src/context/index.tsx +75 -42
  333. package/src/events.ts +81 -0
  334. package/src/fiber-tree.ts +112 -0
  335. package/src/hooks.ts +88 -9
  336. package/src/idb.ts +1 -1
  337. package/src/lib/to-plain.ts +21 -0
  338. package/src/main.tsx +3 -1
  339. package/src/mods/clients.ts +3 -0
  340. package/src/mods/editor-ui/FieldLabel.tsx +124 -0
  341. package/src/mods/editor-ui/client.ts +1 -1
  342. package/src/mods/editor-ui/default-edit.tsx +99 -0
  343. package/src/mods/editor-ui/default-view.tsx +13 -8
  344. package/src/mods/editor-ui/dir-view.tsx +2 -2
  345. package/src/mods/editor-ui/editor-ui.css +174 -0
  346. package/src/mods/editor-ui/empty-placeholder.tsx +39 -0
  347. package/src/mods/editor-ui/form-field.tsx +144 -0
  348. package/src/mods/editor-ui/form-fields.tsx +132 -113
  349. package/src/mods/editor-ui/layout-view.tsx +4 -2
  350. package/src/mods/editor-ui/list-items.tsx +2 -2
  351. package/src/mods/editor-ui/node-utils.ts +4 -5
  352. package/src/mods/editor-ui/type-picker.tsx +147 -0
  353. package/src/mods/editor-ui/user-view.tsx +1 -1
  354. package/src/mods/servers.ts +2 -0
  355. package/src/mods/treenity/groups/index.tsx +1 -1
  356. package/src/mods/treenity/preview.tsx +1 -1
  357. package/src/mods/treenity/ref-view.tsx +1 -1
  358. package/src/mods/treenity/schema-form.tsx +1 -1
  359. package/src/mods/treenity/seed.ts +1 -1
  360. package/src/mods/treenity/type-view.tsx +1 -1
  361. package/src/optimistic.test.ts +111 -0
  362. package/src/remote-tree.test.ts +1 -1
  363. package/src/remote-tree.ts +1 -1
  364. package/src/root.css +117 -0
  365. package/src/schema-loader.ts +1 -1
  366. package/src/symbols.ts +18 -0
  367. package/src/index.html +0 -14
  368. package/src/style.css +0 -1269
  369. package/src/vite-env.d.ts +0 -3
@@ -1,9 +1,12 @@
1
1
  import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
2
+ import './editor-ui.css';
3
+ import { Button } from '#components/ui/button';
2
4
  import { Render, RenderContext } from '#context';
3
5
  import { useChildren } from '#hooks';
4
6
  import { trpc } from '#trpc';
5
- import { register } from '@treenity/core/core';
7
+ import { register } from '@treenity/core';
6
8
  import { useCallback, useState } from 'react';
9
+ import { EmptyNodePlaceholder } from './empty-placeholder';
7
10
  import { getComponents, getPlainFields, getSchema } from './node-utils';
8
11
  /** Fallback for components without their own react handler */
9
12
  function ComponentFieldsView({ value }) {
@@ -20,7 +23,7 @@ function ComponentFieldsView({ value }) {
20
23
  return null;
21
24
  return (_jsx(_Fragment, { children: entries.map(([k, v]) => (_jsxs("div", { className: "comp-view-row", children: [_jsx("span", { className: "comp-view-label", children: k }), _jsx("span", { className: "comp-view-value", children: typeof v === 'string' ? v || '—' : typeof v === 'object' ? JSON.stringify(v) : String(v) })] }, k))) }));
22
25
  }
23
- function GenerateViewButton({ type, sample }) {
26
+ export function GenerateViewButton({ type, sample, context, label }) {
24
27
  const [status, setStatus] = useState('idle');
25
28
  const [error, setError] = useState('');
26
29
  const generate = useCallback(async () => {
@@ -30,7 +33,7 @@ function GenerateViewButton({ type, sample }) {
30
33
  await trpc.execute.mutate({
31
34
  path: '/metatron',
32
35
  action: 'task',
33
- data: { prompt: `Generate a React view for type "${type}". Sample data:\n${JSON.stringify(clean, null, 2)}` },
36
+ data: { prompt: `Generate a React view for type "${type}"${context ? ` in context "${context}"` : ''}. Sample data:\n${JSON.stringify(clean, null, 2)}` },
34
37
  });
35
38
  setStatus('done');
36
39
  }
@@ -48,7 +51,7 @@ function GenerateViewButton({ type, sample }) {
48
51
  if (status === 'done') {
49
52
  return _jsx("div", { className: "text-sm text-green-400 py-2", children: "Task created in /metatron \u2014 waiting for AI" });
50
53
  }
51
- return (_jsx("button", { onClick: generate, className: "text-sm text-blue-400 hover:text-blue-300 border border-blue-400/30 rounded px-3 py-1.5 my-2", children: "Generate AI View" }));
54
+ return (_jsx(Button, { variant: "outline", size: "sm", onClick: generate, className: "text-blue-400 border-blue-400/30 hover:text-blue-300 my-2", children: label ?? 'Generate AI View' }));
52
55
  }
53
56
  function DefaultNodeView({ value }) {
54
57
  const children = useChildren(value.$path);
@@ -59,7 +62,7 @@ function DefaultNodeView({ value }) {
59
62
  return (_jsxs("div", { className: "node-default-view", children: [canGenerate && _jsx(GenerateViewButton, { type: value.$type, sample: value }), components.map(([name, comp]) => {
60
63
  const ctype = comp.$type;
61
64
  return (_jsxs("div", { className: "comp-view-card", children: [_jsxs("div", { className: "comp-view-header", children: [name, name !== ctype && _jsx("span", { className: "comp-type", children: ctype })] }), _jsx(Render, { value: comp })] }, name));
62
- }), Object.keys(plain).length > 0 && (_jsx("div", { className: "node-info-bar", children: Object.entries(plain).map(([k, v]) => (_jsxs("span", { className: "node-info-chip data", children: [_jsx("span", { className: "node-info-chip-label", children: k }), _jsx("span", { className: "node-info-chip-val", children: typeof v === 'string' ? v : JSON.stringify(v) })] }, k))) })), children.length > 0 && (_jsx(RenderContext, { name: "react:list", children: _jsx("div", { className: "children-grid", children: children.map((child) => (_jsx(Render, { value: child }, child.$path))) }) })), children.length === 0 && !hasInfo && _jsx("div", { className: "node-empty", children: "Empty node" })] }));
65
+ }), Object.keys(plain).length > 0 && (_jsx("div", { className: "node-info-bar", children: Object.entries(plain).map(([k, v]) => (_jsxs("span", { className: "node-info-chip data", children: [_jsx("span", { className: "node-info-chip-label", children: k }), _jsx("span", { className: "node-info-chip-val", children: typeof v === 'string' ? v : JSON.stringify(v) })] }, k))) })), children.length > 0 && (_jsx(RenderContext, { name: "react:list", children: _jsx("div", { className: "children-grid", children: children.map((child) => (_jsx(Render, { value: child }, child.$path))) }) })), children.length === 0 && !hasInfo && _jsx(EmptyNodePlaceholder, { value: value })] }));
63
66
  }
64
67
  /** Dispatch: node → DefaultNodeView, component → ComponentFieldsView */
65
68
  function DefaultView({ value }) {
@@ -1 +1 @@
1
- {"version":3,"file":"default-view.js","sourceRoot":"","sources":["../../../src/mods/editor-ui/default-view.tsx"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"default-view.js","sourceRoot":"","sources":["../../../src/mods/editor-ui/default-view.tsx"],"names":[],"mappings":"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"}
@@ -1,7 +1,6 @@
1
1
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
2
  import { Render, RenderContext } from '#context';
3
3
  import { useChildren } from '#hooks';
4
- import { register } from '@treenity/core/core';
5
4
  const STATUS_COLORS = {
6
5
  draft: ['var(--accent-subtle, #1a2a3a)', 'var(--accent)'],
7
6
  published: ['#1a2e1a', '#4c8'],
@@ -38,5 +37,4 @@ function FolderView({ value }) {
38
37
  color: 'var(--text-2)',
39
38
  }, children: ["count: ", counter.count ?? 0] }))] }))] })), children.length > 0 && (_jsx(RenderContext, { name: "react:list", children: _jsx("div", { className: "children-grid", children: children.map((child) => (_jsx(Render, { value: child }, child.$path))) }) })), children.length === 0 && !meta && !status && !counter && (_jsx("div", { className: "node-empty", children: "Empty folder" }))] }));
40
39
  }
41
- register('dir', 'react', FolderView);
42
40
  //# sourceMappingURL=dir-view.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"dir-view.js","sourceRoot":"","sources":["../../../src/mods/editor-ui/dir-view.tsx"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"dir-view.js","sourceRoot":"","sources":["../../../src/mods/editor-ui/dir-view.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ import type { NodeData } from '@treenity/core';
2
+ export declare function EmptyNodePlaceholder({ value }: {
3
+ value: NodeData;
4
+ }): import("react/jsx-runtime").JSX.Element;
5
+ //# sourceMappingURL=empty-placeholder.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"empty-placeholder.d.ts","sourceRoot":"","sources":["../../../src/mods/editor-ui/empty-placeholder.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAK/C,wBAAgB,oBAAoB,CAAC,EAAE,KAAK,EAAE,EAAE;IAAE,KAAK,EAAE,QAAQ,CAAA;CAAE,2CA+BlE"}
@@ -0,0 +1,14 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { Button } from '#components/ui/button';
3
+ import { set } from '#hooks';
4
+ import { Plus } from 'lucide-react';
5
+ import { useState } from 'react';
6
+ import { TypePicker } from './type-picker';
7
+ export function EmptyNodePlaceholder({ value }) {
8
+ const [picking, setPicking] = useState(false);
9
+ return (_jsxs("div", { className: "flex flex-col items-center justify-center gap-3 py-12 px-6", children: [_jsx("div", { className: "text-[13px] text-[--text-3]", children: "Empty node" }), _jsxs(Button, { variant: "outline", size: "sm", onClick: () => setPicking(true), className: "text-[12px] text-[--text-3] hover:text-[--accent] hover:bg-[--accent]/10", children: [_jsx(Plus, { className: "w-3.5 h-3.5" }), "Add Component"] }), picking && (_jsx(TypePicker, { title: "Add Component", nameLabel: "Component name", action: "Add", autoName: true, onCancel: () => setPicking(false), onSelect: async (name, type) => {
10
+ setPicking(false);
11
+ await set({ ...value, [name]: { $type: type } });
12
+ } }))] }));
13
+ }
14
+ //# sourceMappingURL=empty-placeholder.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"empty-placeholder.js","sourceRoot":"","sources":["../../../src/mods/editor-ui/empty-placeholder.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAC/C,OAAO,EAAE,GAAG,EAAE,MAAM,QAAQ,CAAC;AAE7B,OAAO,EAAE,IAAI,EAAE,MAAM,cAAc,CAAC;AACpC,OAAO,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AACjC,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAE3C,MAAM,UAAU,oBAAoB,CAAC,EAAE,KAAK,EAAuB;IACjE,MAAM,CAAC,OAAO,EAAE,UAAU,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;IAE9C,OAAO,CACL,eAAK,SAAS,EAAC,4DAA4D,aACzE,cAAK,SAAS,EAAC,6BAA6B,2BAAiB,EAC7D,MAAC,MAAM,IACL,OAAO,EAAC,SAAS,EACjB,IAAI,EAAC,IAAI,EACT,OAAO,EAAE,GAAG,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,EAC/B,SAAS,EAAC,0EAA0E,aAEpF,KAAC,IAAI,IAAC,SAAS,EAAC,aAAa,GAAG,qBAEzB,EAER,OAAO,IAAI,CACV,KAAC,UAAU,IACT,KAAK,EAAC,eAAe,EACrB,SAAS,EAAC,gBAAgB,EAC1B,MAAM,EAAC,KAAK,EACZ,QAAQ,QACR,QAAQ,EAAE,GAAG,EAAE,CAAC,UAAU,CAAC,KAAK,CAAC,EACjC,QAAQ,EAAE,KAAK,EAAE,IAAI,EAAE,IAAI,EAAE,EAAE;oBAC7B,UAAU,CAAC,KAAK,CAAC,CAAC;oBAClB,MAAM,GAAG,CAAC,EAAE,GAAG,KAAK,EAAE,CAAC,IAAI,CAAC,EAAE,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE,CAAC,CAAC;gBACnD,CAAC,GACD,CACH,IACG,CACP,CAAC;AACJ,CAAC"}
@@ -0,0 +1,17 @@
1
+ export declare function renderField(name: string, fieldSchema: {
2
+ type: string;
3
+ label: string;
4
+ placeholder?: string;
5
+ readOnly?: boolean;
6
+ enum?: string[];
7
+ items?: {
8
+ type?: string;
9
+ properties?: Record<string, unknown>;
10
+ };
11
+ refType?: string;
12
+ }, data: Record<string, unknown>, setData: (fn: (prev: Record<string, unknown>) => Record<string, unknown>) => void): import("react/jsx-runtime").JSX.Element | null;
13
+ export declare function StringArrayField({ value, onChange, }: {
14
+ value: unknown[];
15
+ onChange: (next: unknown[]) => void;
16
+ }): import("react/jsx-runtime").JSX.Element;
17
+ //# sourceMappingURL=form-field.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"form-field.d.ts","sourceRoot":"","sources":["../../../src/mods/editor-ui/form-field.tsx"],"names":[],"mappings":"AAMA,wBAAgB,WAAW,CACzB,IAAI,EAAE,MAAM,EACZ,WAAW,EAAE;IACX,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC;IAChB,KAAK,CAAC,EAAE;QAAE,IAAI,CAAC,EAAE,MAAM,CAAC;QAAC,UAAU,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;KAAE,CAAC;IAChE,OAAO,CAAC,EAAE,MAAM,CAAC;CAClB,EACD,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAC7B,OAAO,EAAE,CAAC,EAAE,EAAE,CAAC,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,KAAK,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,KAAK,IAAI,kDA6DlF;AAED,wBAAgB,gBAAgB,CAAC,EAC/B,KAAK,EACL,QAAQ,GACT,EAAE;IACD,KAAK,EAAE,OAAO,EAAE,CAAC;IACjB,QAAQ,EAAE,CAAC,IAAI,EAAE,OAAO,EAAE,KAAK,IAAI,CAAC;CACrC,2CAwDA"}
@@ -0,0 +1,68 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { Button } from '#components/ui/button';
3
+ import { Input } from '#components/ui/input';
4
+ import { isRef, resolveExact } from '@treenity/core';
5
+ import { createElement, useState } from 'react';
6
+ import { FieldLabel, RefEditor } from './FieldLabel';
7
+ export function renderField(name, fieldSchema, data, setData) {
8
+ if (!fieldSchema.type)
9
+ return null;
10
+ const rawValue = data[name];
11
+ const isRefValue = rawValue && typeof rawValue === 'object' && isRef(rawValue);
12
+ // If value is a $ref/$map, show ref editor instead of the normal field handler
13
+ if (isRefValue) {
14
+ const onFieldChange = fieldSchema.readOnly
15
+ ? undefined
16
+ : (next) => setData((prev) => ({ ...prev, [name]: next }));
17
+ return (_jsxs("div", { className: "field", children: [_jsx(FieldLabel, { label: fieldSchema.label, value: rawValue, onChange: onFieldChange }), onFieldChange && (_jsx(RefEditor, { value: rawValue, onChange: onFieldChange }))] }, name));
18
+ }
19
+ const ctx = fieldSchema.readOnly ? 'react' : 'react:form';
20
+ const handler = resolveExact(fieldSchema.type, ctx) ?? resolveExact('string', ctx);
21
+ if (!handler)
22
+ return (_jsxs("div", { className: "text-[--danger] text-xs", children: ["No form handler: ", fieldSchema.type] }, name));
23
+ const fieldData = {
24
+ $type: fieldSchema.type,
25
+ value: rawValue,
26
+ label: fieldSchema.label,
27
+ placeholder: fieldSchema.placeholder,
28
+ };
29
+ if (fieldSchema.items)
30
+ fieldData.items = fieldSchema.items;
31
+ if (fieldSchema.enum)
32
+ fieldData.enum = fieldSchema.enum;
33
+ if (fieldSchema.refType)
34
+ fieldData.refType = fieldSchema.refType;
35
+ const isComplex = fieldSchema.type === 'object' || fieldSchema.type === 'array';
36
+ const onFieldChange = fieldSchema.readOnly
37
+ ? undefined
38
+ : (next) => setData((prev) => ({ ...prev, [name]: next.value }));
39
+ return (_jsxs("div", { className: isComplex ? 'field stack' : 'field', children: [fieldSchema.type !== 'boolean' && (_jsx(FieldLabel, { label: fieldSchema.label, value: rawValue, onChange: fieldSchema.readOnly ? undefined : (next) => setData((prev) => ({ ...prev, [name]: next })) })), createElement(handler, {
40
+ value: fieldData,
41
+ onChange: onFieldChange,
42
+ })] }, name));
43
+ }
44
+ export function StringArrayField({ value, onChange, }) {
45
+ const [input, setInput] = useState('');
46
+ const isStrings = value.every((v) => typeof v === 'string');
47
+ if (!isStrings) {
48
+ return (_jsx("textarea", { value: JSON.stringify(value, null, 2), onChange: (e) => {
49
+ try {
50
+ onChange(JSON.parse(e.target.value));
51
+ }
52
+ catch {
53
+ /* typing */
54
+ }
55
+ } }));
56
+ }
57
+ const tags = value;
58
+ return (_jsxs("div", { className: "flex-1 space-y-1", children: [_jsx("div", { className: "flex flex-wrap gap-1", children: tags.map((tag, i) => (_jsxs("span", { className: "inline-flex items-center gap-0.5 text-[11px] font-mono bg-muted text-foreground/70 px-1.5 py-0.5 rounded", children: [tag, _jsx(Button, { variant: "ghost", size: "icon", type: "button", className: "h-5 w-5 p-0 ml-0.5 text-muted-foreground/40 hover:text-foreground leading-none", onClick: () => onChange(tags.filter((_, j) => j !== i)), children: "x" })] }, i))) }), _jsx(Input, { className: "h-7 text-xs w-full", placeholder: "Add item...", value: input, onChange: (e) => setInput(e.target.value), onKeyDown: (e) => {
59
+ if (e.key !== 'Enter')
60
+ return;
61
+ e.preventDefault();
62
+ const t = input.trim();
63
+ if (t && !tags.includes(t))
64
+ onChange([...tags, t]);
65
+ setInput('');
66
+ } })] }));
67
+ }
68
+ //# sourceMappingURL=form-field.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"form-field.js","sourceRoot":"","sources":["../../../src/mods/editor-ui/form-field.tsx"],"names":[],"mappings":"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"}
@@ -1,6 +1,5 @@
1
- export declare function MiniTree({ onSelect, onClose }: {
1
+ export declare function MiniTree({ onSelect }: {
2
2
  onSelect: (path: string) => void;
3
- onClose: () => void;
4
3
  }): import("react/jsx-runtime").JSX.Element;
5
4
  export declare function registerFormFields(): void;
6
5
  //# sourceMappingURL=form-fields.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"form-fields.d.ts","sourceRoot":"","sources":["../../../src/mods/editor-ui/form-fields.tsx"],"names":[],"mappings":"AAoeA,wBAAgB,QAAQ,CAAC,EAAE,QAAQ,EAAE,OAAO,EAAE,EAAE;IAAE,QAAQ,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,IAAI,CAAC;IAAC,OAAO,EAAE,MAAM,IAAI,CAAA;CAAE,2CAmIxG;AAgPD,wBAAgB,kBAAkB,SAKjC"}
1
+ {"version":3,"file":"form-fields.d.ts","sourceRoot":"","sources":["../../../src/mods/editor-ui/form-fields.tsx"],"names":[],"mappings":"AA6fA,wBAAgB,QAAQ,CAAC,EAAE,QAAQ,EAAE,EAAE;IAAE,QAAQ,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,IAAI,CAAA;CAAE,2CAsH1E;AAuPD,wBAAgB,kBAAkB,SAKjC"}
@@ -1,11 +1,17 @@
1
- import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
1
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
2
2
  // react:form handlers — editable fields for inspector panel
3
3
  import * as cache from '#cache';
4
4
  import { tree as clientStore } from '#client';
5
- import { useSchema } from '#schema-loader';
6
5
  // react view handlers — readOnly display for same types
7
6
  // Covers: string, text, textarea, number, integer, boolean, array, object, image, uri, url, select, timestamp, path
8
- import { register, resolve as resolveHandler } from '@treenity/core/core';
7
+ import { Button } from '#components/ui/button';
8
+ import { Input } from '#components/ui/input';
9
+ import { Popover, PopoverContent, PopoverTrigger } from '#components/ui/popover';
10
+ import { Select, SelectContent, SelectItem, SelectTrigger, SelectValue } from '#components/ui/select';
11
+ import { Switch } from '#components/ui/switch';
12
+ import { Textarea } from '#components/ui/textarea';
13
+ import { useSchema } from '#schema-loader';
14
+ import { register, resolve as resolveHandler } from '@treenity/core';
9
15
  import dayjs from 'dayjs';
10
16
  import { X } from 'lucide-react';
11
17
  import { createElement, useCallback, useEffect, useRef, useState, useSyncExternalStore } from 'react';
@@ -54,38 +60,38 @@ function ObjectView({ value }) {
54
60
  function StringForm({ value, onChange }) {
55
61
  // enum → select dropdown
56
62
  if (value.enum && value.enum.length > 0) {
57
- return (_jsxs("select", { value: String(value.value ?? ''), onChange: (e) => onChange?.({ ...value, value: e.target.value }), children: [_jsx("option", { value: "", children: "\u2014" }), value.enum.map((v) => (_jsx("option", { value: v, children: v }, v)))] }));
63
+ return (_jsxs(Select, { value: String(value.value ?? ''), onValueChange: (v) => onChange?.({ ...value, value: v }), children: [_jsx(SelectTrigger, { className: "h-7 text-xs font-mono", children: _jsx(SelectValue, { placeholder: "\u2014" }) }), _jsx(SelectContent, { children: value.enum.map((v) => (_jsx(SelectItem, { value: v, children: v }, v))) })] }));
58
64
  }
59
- return (_jsx("input", { value: String(value.value ?? ''), placeholder: value.placeholder, onChange: (e) => onChange?.({ ...value, value: e.target.value }) }));
65
+ return (_jsx(Input, { className: "h-7 text-xs", value: String(value.value ?? ''), placeholder: value.placeholder, onChange: (e) => onChange?.({ ...value, value: e.target.value }) }));
60
66
  }
61
67
  function TextForm({ value, onChange }) {
62
- return (_jsx("textarea", { value: String(value.value ?? ''), placeholder: value.placeholder, onChange: (e) => onChange?.({ ...value, value: e.target.value }) }));
68
+ return (_jsx(Textarea, { className: "text-xs", value: String(value.value ?? ''), placeholder: value.placeholder, onChange: (e) => onChange?.({ ...value, value: e.target.value }) }));
63
69
  }
64
70
  function NumberForm({ value, onChange }) {
65
- return (_jsx("input", { type: "number", value: String(value.value ?? 0), onChange: (e) => onChange?.({ ...value, value: Number(e.target.value) }) }));
71
+ return (_jsx(Input, { type: "number", className: "h-7 text-xs", value: String(value.value ?? 0), onChange: (e) => onChange?.({ ...value, value: Number(e.target.value) }) }));
66
72
  }
67
73
  function IntegerForm({ value, onChange }) {
68
- return (_jsx("input", { type: "number", step: "1", value: String(value.value ?? 0), onChange: (e) => onChange?.({ ...value, value: Math.round(Number(e.target.value)) }) }));
74
+ return (_jsx(Input, { type: "number", step: "1", className: "h-7 text-xs", value: String(value.value ?? 0), onChange: (e) => onChange?.({ ...value, value: Math.round(Number(e.target.value)) }) }));
69
75
  }
70
76
  function BooleanForm({ value, onChange }) {
71
- return (_jsxs("label", { className: "flex items-center gap-2 cursor-pointer", children: [_jsx("input", { type: "checkbox", className: "w-auto", checked: !!value.value, onChange: (e) => onChange?.({ ...value, value: e.target.checked }) }), _jsx("span", { className: "text-xs text-muted-foreground", children: value.label })] }));
77
+ return (_jsxs("label", { className: "flex items-center gap-2 cursor-pointer", children: [_jsx(Switch, { checked: !!value.value, onCheckedChange: (checked) => onChange?.({ ...value, value: checked }) }), _jsx("span", { className: "text-xs text-muted-foreground", children: value.label })] }));
72
78
  }
73
79
  function ImageForm({ value, onChange }) {
74
80
  const src = typeof value.value === 'string' ? value.value : '';
75
- return (_jsxs("div", { className: "space-y-2", children: [_jsx("input", { value: src, placeholder: "Image URL", onChange: (e) => onChange?.({ ...value, value: e.target.value }) }), src && _jsx("img", { src: src, className: "max-w-full max-h-[120px] rounded object-contain" })] }));
81
+ return (_jsxs("div", { className: "space-y-2", children: [_jsx(Input, { className: "h-7 text-xs", value: src, placeholder: "Image URL", onChange: (e) => onChange?.({ ...value, value: e.target.value }) }), src && _jsx("img", { src: src, className: "max-w-full max-h-[120px] rounded object-contain" })] }));
76
82
  }
77
83
  function UriForm({ value, onChange }) {
78
84
  const url = String(value.value ?? '');
79
- return (_jsxs("div", { className: "space-y-1", children: [_jsx("input", { value: url, placeholder: value.placeholder ?? 'https://...', onChange: (e) => onChange?.({ ...value, value: e.target.value }) }), url && (_jsx("a", { href: url, target: "_blank", rel: "noopener", className: "text-[10px] text-primary hover:underline truncate block", children: url }))] }));
85
+ return (_jsxs("div", { className: "space-y-1", children: [_jsx(Input, { className: "h-7 text-xs", value: url, placeholder: value.placeholder ?? 'https://...', onChange: (e) => onChange?.({ ...value, value: e.target.value }) }), url && (_jsx("a", { href: url, target: "_blank", rel: "noopener", className: "text-[10px] text-primary hover:underline truncate block", children: url }))] }));
80
86
  }
81
87
  function TimestampForm({ value, onChange }) {
82
88
  const ts = Number(value.value ?? 0);
83
89
  const formatted = ts ? dayjs(ts > 1e12 ? ts : ts * 1000).format('YYYY-MM-DD HH:mm:ss') : '—';
84
- return (_jsxs("div", { className: "flex items-center gap-2", children: [_jsx("input", { type: "number", className: "flex-1", value: String(ts), onChange: (e) => onChange?.({ ...value, value: Number(e.target.value) }) }), _jsx("span", { className: "text-[10px] text-muted-foreground whitespace-nowrap", children: formatted })] }));
90
+ return (_jsxs("div", { className: "flex items-center gap-2", children: [_jsx(Input, { type: "number", className: "h-7 text-xs flex-1", value: String(ts), onChange: (e) => onChange?.({ ...value, value: Number(e.target.value) }) }), _jsx("span", { className: "text-[10px] text-muted-foreground whitespace-nowrap", children: formatted })] }));
85
91
  }
86
92
  function SelectForm({ value, onChange }) {
87
93
  const opts = value.enum ?? [];
88
- return (_jsxs("select", { value: String(value.value ?? ''), onChange: (e) => onChange?.({ ...value, value: e.target.value }), children: [_jsx("option", { value: "", children: "\u2014" }), opts.map((v) => (_jsx("option", { value: v, children: v }, v)))] }));
94
+ return (_jsxs(Select, { value: String(value.value ?? ''), onValueChange: (v) => onChange?.({ ...value, value: v }), children: [_jsx(SelectTrigger, { className: "h-7 text-xs font-mono", children: _jsx(SelectValue, { placeholder: "\u2014" }) }), _jsx(SelectContent, { children: opts.map((v) => (_jsx(SelectItem, { value: v, children: v }, v))) })] }));
89
95
  }
90
96
  function ObjectForm({ value, onChange }) {
91
97
  const [mode, setMode] = useState('fields');
@@ -95,13 +101,13 @@ function ObjectForm({ value, onChange }) {
95
101
  const obj = (typeof value.value === 'object' && value.value !== null ? value.value : {});
96
102
  const emit = (next) => onChange?.({ ...value, value: next });
97
103
  const entries = Object.entries(obj);
98
- const modeToggle = (_jsxs("div", { className: "flex gap-1 mb-1", children: [_jsx("button", { type: "button", className: `border-0 px-2 py-0.5 text-[10px] rounded ${mode === 'fields' ? 'bg-muted text-foreground' : 'bg-transparent text-muted-foreground hover:text-foreground'}`, onClick: () => setMode('fields'), children: "Fields" }), _jsx("button", { type: "button", className: `border-0 px-2 py-0.5 text-[10px] rounded ${mode === 'json' ? 'bg-muted text-foreground' : 'bg-transparent text-muted-foreground hover:text-foreground'}`, onClick: () => {
104
+ const modeToggle = (_jsxs("div", { className: "flex gap-1 mb-1", children: [_jsx(Button, { variant: "ghost", size: "sm", type: "button", className: `h-6 px-2 text-[10px] ${mode === 'fields' ? 'bg-muted text-foreground' : 'text-muted-foreground hover:text-foreground'}`, onClick: () => setMode('fields'), children: "Fields" }), _jsx(Button, { variant: "ghost", size: "sm", type: "button", className: `h-6 px-2 text-[10px] ${mode === 'json' ? 'bg-muted text-foreground' : 'text-muted-foreground hover:text-foreground'}`, onClick: () => {
99
105
  setJsonDraft(JSON.stringify(obj, null, 2));
100
106
  setJsonError(false);
101
107
  setMode('json');
102
108
  }, children: "JSON" })] }));
103
109
  if (mode === 'json') {
104
- return (_jsxs("div", { className: "rounded border border-border/50 bg-muted/30 p-2", children: [modeToggle, _jsx("textarea", { className: `text-[11px] min-h-[60px] ${jsonError ? 'border-destructive' : ''}`, value: jsonDraft, onChange: (e) => {
110
+ return (_jsxs("div", { className: "rounded border border-border/50 bg-muted/30 p-2", children: [modeToggle, _jsx(Textarea, { className: `text-[11px] min-h-[60px] ${jsonError ? 'border-destructive' : ''}`, value: jsonDraft, onChange: (e) => {
105
111
  setJsonDraft(e.target.value);
106
112
  try {
107
113
  const parsed = JSON.parse(e.target.value);
@@ -118,18 +124,18 @@ function ObjectForm({ value, onChange }) {
118
124
  }
119
125
  } })] }));
120
126
  }
121
- return (_jsxs("div", { className: "rounded border border-border/50 bg-muted/30 p-2", children: [modeToggle, entries.length > 0 && (_jsx("div", { className: "space-y-1 mb-1.5", children: entries.map(([k, v]) => (_jsxs("div", { className: "flex gap-1.5 items-start group", children: [_jsx("span", { className: "text-[11px] font-mono text-muted-foreground pt-[5px] min-w-[50px] truncate shrink-0", children: k }), typeof v === 'boolean' ? (_jsx("input", { type: "checkbox", className: "w-auto mt-1.5", checked: v, onChange: (e) => emit({ ...obj, [k]: e.target.checked }) })) : typeof v === 'number' ? (_jsx("input", { type: "number", className: "flex-1 min-w-0 text-[11px]", value: String(v), onChange: (e) => emit({ ...obj, [k]: Number(e.target.value) }) })) : typeof v === 'string' ? (_jsx("input", { className: "flex-1 min-w-0 text-[11px]", value: v, onChange: (e) => emit({ ...obj, [k]: e.target.value }) })) : (_jsx("textarea", { className: "flex-1 min-w-0 text-[11px] font-mono min-h-[40px]", value: JSON.stringify(v, null, 2), onChange: (e) => {
127
+ return (_jsxs("div", { className: "rounded border border-border/50 bg-muted/30 p-2", children: [modeToggle, entries.length > 0 && (_jsx("div", { className: "space-y-1 mb-1.5", children: entries.map(([k, v]) => (_jsxs("div", { className: "flex gap-1.5 items-start group", children: [_jsx("span", { className: "text-[11px] font-mono text-muted-foreground pt-[5px] min-w-[50px] truncate shrink-0", children: k }), typeof v === 'boolean' ? (_jsx(Switch, { className: "mt-1", checked: v, onCheckedChange: (checked) => emit({ ...obj, [k]: checked }) })) : typeof v === 'number' ? (_jsx(Input, { type: "number", className: "h-7 text-[11px] flex-1 min-w-0", value: String(v), onChange: (e) => emit({ ...obj, [k]: Number(e.target.value) }) })) : typeof v === 'string' ? (_jsx(Input, { className: "h-7 text-[11px] flex-1 min-w-0", value: v, onChange: (e) => emit({ ...obj, [k]: e.target.value }) })) : (_jsx(Textarea, { className: "flex-1 min-w-0 text-[11px] font-mono min-h-[40px]", value: JSON.stringify(v, null, 2), onChange: (e) => {
122
128
  try {
123
129
  emit({ ...obj, [k]: JSON.parse(e.target.value) });
124
130
  }
125
131
  catch {
126
132
  /* typing */
127
133
  }
128
- } })), _jsx("button", { type: "button", className: "border-0 bg-transparent p-0 mt-1 text-muted-foreground/30 opacity-0 group-hover:opacity-100 hover:text-destructive shrink-0 cursor-pointer transition-opacity", onClick: () => {
134
+ } })), _jsx(Button, { variant: "ghost", size: "icon", type: "button", className: "h-5 w-5 p-0 mt-1 text-muted-foreground/30 opacity-0 group-hover:opacity-100 hover:text-destructive shrink-0 transition-opacity", onClick: () => {
129
135
  const next = { ...obj };
130
136
  delete next[k];
131
137
  emit(next);
132
- }, children: _jsx(X, { className: "h-3 w-3" }) })] }, k))) })), _jsxs("div", { className: "flex gap-1 items-center border-t border-border/30 pt-1.5", children: [_jsx("input", { className: "flex-1 min-w-0 text-[11px] bg-transparent border-dashed", placeholder: "new key...", value: newKey, onChange: (e) => setNewKey(e.target.value), onKeyDown: (e) => {
138
+ }, children: _jsx(X, { className: "h-3 w-3" }) })] }, k))) })), _jsxs("div", { className: "flex gap-1 items-center border-t border-border/30 pt-1.5", children: [_jsx(Input, { className: "h-7 text-[11px] flex-1 min-w-0 bg-transparent border-dashed", placeholder: "new key...", value: newKey, onChange: (e) => setNewKey(e.target.value), onKeyDown: (e) => {
133
139
  if (e.key !== 'Enter')
134
140
  return;
135
141
  e.preventDefault();
@@ -138,7 +144,7 @@ function ObjectForm({ value, onChange }) {
138
144
  emit({ ...obj, [k]: '' });
139
145
  setNewKey('');
140
146
  }
141
- } }), _jsx("button", { type: "button", className: "border-0 bg-transparent p-0 text-[11px] text-muted-foreground hover:text-foreground shrink-0 cursor-pointer", onClick: () => {
147
+ } }), _jsx(Button, { variant: "ghost", size: "sm", type: "button", className: "h-6 px-2 text-[10px] text-muted-foreground hover:text-foreground shrink-0", onClick: () => {
142
148
  const k = newKey.trim();
143
149
  if (k && !(k in obj)) {
144
150
  emit({ ...obj, [k]: '' });
@@ -152,7 +158,7 @@ function ArrayForm({ value, onChange }) {
152
158
  const itemType = value.items?.type ?? 'string';
153
159
  const emit = (next) => onChange?.({ ...value, value: next });
154
160
  if (itemType === 'string') {
155
- return (_jsxs("div", { className: "rounded border border-border/50 bg-muted/30 p-2 space-y-1.5", children: [arr.length > 0 && (_jsx("div", { className: "flex flex-wrap gap-1", children: arr.map((tag, i) => (_jsxs("span", { className: "inline-flex items-center gap-0.5 text-[11px] font-mono bg-muted text-foreground/70 px-1.5 py-0.5 rounded", children: [tag, _jsx("button", { type: "button", className: "ml-0.5 border-0 bg-transparent p-0 text-muted-foreground/40 hover:text-foreground leading-none cursor-pointer", onClick: () => emit(arr.filter((_, j) => j !== i)), children: "\u00D7" })] }, i))) })), _jsx("input", { className: "text-[11px] bg-transparent border-dashed", placeholder: "add item...", value: input, onChange: (e) => setInput(e.target.value), onKeyDown: (e) => {
161
+ return (_jsxs("div", { className: "rounded border border-border/50 bg-muted/30 p-2 space-y-1.5", children: [arr.length > 0 && (_jsx("div", { className: "flex flex-wrap gap-1", children: arr.map((tag, i) => (_jsxs("span", { className: "inline-flex items-center gap-0.5 text-[11px] font-mono bg-muted text-foreground/70 px-1.5 py-0.5 rounded", children: [tag, _jsx(Button, { variant: "ghost", size: "icon", type: "button", className: "h-5 w-5 p-0 ml-0.5 text-muted-foreground/40 hover:text-foreground leading-none", onClick: () => emit(arr.filter((_, j) => j !== i)), children: "\u00D7" })] }, i))) })), _jsx(Input, { className: "h-7 text-[11px] bg-transparent border-dashed", placeholder: "add item...", value: input, onChange: (e) => setInput(e.target.value), onKeyDown: (e) => {
156
162
  if (e.key !== 'Enter')
157
163
  return;
158
164
  e.preventDefault();
@@ -163,10 +169,10 @@ function ArrayForm({ value, onChange }) {
163
169
  } })] }));
164
170
  }
165
171
  if (itemType === 'number') {
166
- return (_jsxs("div", { className: "rounded border border-border/50 bg-muted/30 p-2 space-y-1", children: [arr.map((item, i) => (_jsxs("div", { className: "flex gap-1 items-center group", children: [_jsx("input", { type: "number", className: "flex-1 text-[11px]", value: String(item ?? 0), onChange: (e) => emit(arr.map((v, j) => (j === i ? Number(e.target.value) : v))) }), _jsx("button", { type: "button", className: "border-0 bg-transparent p-0 text-muted-foreground/30 opacity-0 group-hover:opacity-100 hover:text-destructive cursor-pointer transition-opacity", onClick: () => emit(arr.filter((_, j) => j !== i)), children: _jsx(X, { className: "h-3 w-3" }) })] }, i))), _jsx("button", { type: "button", className: "border-0 bg-transparent p-0 text-[11px] text-muted-foreground hover:text-foreground cursor-pointer", onClick: () => emit([...arr, 0]), children: "+ add" })] }));
172
+ return (_jsxs("div", { className: "rounded border border-border/50 bg-muted/30 p-2 space-y-1", children: [arr.map((item, i) => (_jsxs("div", { className: "flex gap-1 items-center group", children: [_jsx(Input, { type: "number", className: "h-7 text-[11px] flex-1", value: String(item ?? 0), onChange: (e) => emit(arr.map((v, j) => (j === i ? Number(e.target.value) : v))) }), _jsx(Button, { variant: "ghost", size: "icon", type: "button", className: "h-5 w-5 p-0 text-muted-foreground/30 opacity-0 group-hover:opacity-100 hover:text-destructive transition-opacity", onClick: () => emit(arr.filter((_, j) => j !== i)), children: _jsx(X, { className: "h-3 w-3" }) })] }, i))), _jsx(Button, { variant: "ghost", size: "sm", type: "button", className: "h-6 px-2 text-[10px] text-muted-foreground hover:text-foreground", onClick: () => emit([...arr, 0]), children: "+ add" })] }));
167
173
  }
168
174
  // object/other — textarea fallback
169
- return (_jsx("textarea", { value: JSON.stringify(arr, null, 2), onChange: (e) => {
175
+ return (_jsx(Textarea, { value: JSON.stringify(arr, null, 2), onChange: (e) => {
170
176
  try {
171
177
  emit(JSON.parse(e.target.value));
172
178
  }
@@ -184,8 +190,7 @@ function PathView({ value }) {
184
190
  }
185
191
  // Compact tree picker dropdown for selecting a node path
186
192
  // Lazy-loads children via trpc on expand, caches into front/cache
187
- export function MiniTree({ onSelect, onClose }) {
188
- const ref = useRef(null);
193
+ export function MiniTree({ onSelect }) {
189
194
  const [expanded, setExpanded] = useState(new Set(['/']));
190
195
  const [loaded, setLoaded] = useState(new Set());
191
196
  const [filter, setFilter] = useState('');
@@ -195,15 +200,6 @@ export function MiniTree({ onSelect, onClose }) {
195
200
  useEffect(() => {
196
201
  fetchChildren('/');
197
202
  }, []);
198
- // Close on outside click
199
- useEffect(() => {
200
- const handler = (e) => {
201
- if (ref.current && !ref.current.contains(e.target))
202
- onClose();
203
- };
204
- document.addEventListener('mousedown', handler);
205
- return () => document.removeEventListener('mousedown', handler);
206
- }, [onClose]);
207
203
  async function fetchChildren(path) {
208
204
  if (loaded.has(path))
209
205
  return;
@@ -264,7 +260,7 @@ export function MiniTree({ onSelect, onClose }) {
264
260
  }
265
261
  const rootKids = getKids('/');
266
262
  const rootNode = nodes.get('/');
267
- return (_jsxs("div", { ref: ref, className: "absolute z-50 mt-1 w-64 max-h-60 overflow-auto bg-popover border border-border rounded-lg shadow-lg", children: [_jsx("div", { className: "p-1.5 border-b border-border", children: _jsx("input", { className: "text-[11px] w-full", placeholder: "Filter...", value: filter, onChange: (e) => setFilter(e.target.value), autoFocus: true }) }), _jsxs("div", { className: "p-1", children: [rootNode && renderNode('/', 0), !rootNode && rootKids.map((r) => renderNode(r, 0))] })] }));
263
+ return (_jsxs(_Fragment, { children: [_jsx("div", { className: "p-1.5 border-b border-border", children: _jsx(Input, { className: "h-7 text-[11px] w-full", placeholder: "Filter...", value: filter, onChange: (e) => setFilter(e.target.value), autoFocus: true }) }), _jsxs("div", { className: "p-1", children: [rootNode && renderNode('/', 0), !rootNode && rootKids.map((r) => renderNode(r, 0))] })] }));
268
264
  }
269
265
  // Inline typed editor for embedded object values
270
266
  function EmbeddedFields({ data, type, setData }) {
@@ -300,7 +296,7 @@ function EmbeddedFields({ data, type, setData }) {
300
296
  const entries = Object.entries(data).filter(([k]) => !k.startsWith('$'));
301
297
  if (entries.length === 0)
302
298
  return null;
303
- return (_jsx("div", { className: "space-y-1", children: entries.map(([k, v]) => (_jsxs("div", { className: "field", children: [_jsx("label", { children: k }), _jsx("input", { className: "text-[11px]", value: typeof v === 'string' ? v : JSON.stringify(v), onChange: (e) => setData((prev) => ({ ...prev, [k]: e.target.value })) })] }, k))) }));
299
+ return (_jsx("div", { className: "space-y-1", children: entries.map(([k, v]) => (_jsxs("div", { className: "field", children: [_jsx("label", { children: k }), _jsx(Input, { className: "h-7 text-[11px]", value: typeof v === 'string' ? v : JSON.stringify(v), onChange: (e) => setData((prev) => ({ ...prev, [k]: e.target.value })) })] }, k))) }));
304
300
  }
305
301
  function PathForm({ value, onChange }) {
306
302
  const raw = value.value;
@@ -347,32 +343,32 @@ function PathForm({ value, onChange }) {
347
343
  onChange?.({ ...value, value: fn({ ...obj }) });
348
344
  }
349
345
  const hasValue = isValue || !!refPath;
350
- return (_jsxs("div", { ref: wrapRef, className: "relative", children: [_jsxs("div", { className: `rounded border transition-colors ${dragOver ? 'border-primary ring-2 ring-primary/30 bg-primary/5' : 'border-border'}`, onDragOver: (e) => {
351
- if (e.dataTransfer.types.includes('application/treenity-path')) {
352
- e.preventDefault();
353
- e.dataTransfer.dropEffect = 'link';
354
- setDragOver(true);
355
- }
356
- }, onDragLeave: () => setDragOver(false), onDrop: (e) => {
346
+ return (_jsx("div", { ref: wrapRef, className: "relative", children: _jsxs("div", { className: `rounded border transition-colors ${dragOver ? 'border-primary ring-2 ring-primary/30 bg-primary/5' : 'border-border'}`, onDragOver: (e) => {
347
+ if (e.dataTransfer.types.includes('application/treenity-path')) {
357
348
  e.preventDefault();
358
- setDragOver(false);
359
- const dropped = e.dataTransfer.getData('application/treenity-path');
360
- if (dropped)
361
- applyNode(dropped);
362
- }, children: [_jsxs("div", { className: "flex items-center gap-1", children: [_jsx("button", { type: "button", className: `border-0 bg-transparent p-0 px-1 cursor-pointer shrink-0 text-[10px] font-bold font-mono ${mode === 'val' ? 'text-amber-500' : 'text-primary'}`, onClick: () => {
363
- if (mode === 'ref') {
364
- setMode('val');
365
- if (refPath)
366
- setByValue(refPath);
367
- else if (!isValue)
368
- createEmpty();
369
- }
370
- else {
371
- setMode('ref');
372
- if (refPath)
373
- setRef(refPath);
374
- }
375
- }, title: mode === 'val' ? 'Value mode — embeds node data' : 'Ref mode — stores path', children: mode }), refType && (_jsx("span", { className: "text-[9px] text-muted-foreground font-mono shrink-0", children: refType.includes('.') ? refType.slice(refType.lastIndexOf('.') + 1) : refType })), isValue ? (_jsxs("span", { className: "flex-1 min-w-0 text-[11px] font-mono text-foreground/70 truncate py-1", children: [refPath && _jsx("span", { className: "text-muted-foreground", children: refPath }), embeddedType && (_jsx("span", { className: "ml-1 text-amber-500", children: embeddedType }))] })) : (_jsx("input", { className: "flex-1 min-w-0 text-[11px] font-mono border-0 bg-transparent", value: refPath, placeholder: "drop or pick a node", onChange: (e) => setRef(e.target.value) })), hasValue && (_jsx("button", { type: "button", className: "border-0 bg-transparent p-0 px-0.5 text-muted-foreground/40 hover:text-foreground cursor-pointer shrink-0", onClick: () => { onChange?.({ ...value, value: '' }); setMode('ref'); }, children: _jsx(X, { className: "h-3 w-3" }) })), _jsx("button", { type: "button", className: "border-0 bg-transparent p-0 px-1 text-muted-foreground hover:text-foreground cursor-pointer shrink-0 text-[11px]", onClick: () => setPickerOpen((v) => !v), title: "Browse tree", children: "\u2630" })] }), isValue && (_jsx("div", { className: "border-t border-border/50 p-2", children: _jsx(EmbeddedFields, { data: raw, type: effectiveType, setData: updateEmbedded }) }))] }), pickerOpen && (_jsx(MiniTree, { onSelect: (p) => { applyNode(p); setPickerOpen(false); }, onClose: () => setPickerOpen(false) }))] }));
349
+ e.dataTransfer.dropEffect = 'link';
350
+ setDragOver(true);
351
+ }
352
+ }, onDragLeave: () => setDragOver(false), onDrop: (e) => {
353
+ e.preventDefault();
354
+ setDragOver(false);
355
+ const dropped = e.dataTransfer.getData('application/treenity-path');
356
+ if (dropped)
357
+ applyNode(dropped);
358
+ }, children: [_jsxs("div", { className: "flex items-center gap-1", children: [_jsx(Button, { variant: "ghost", size: "sm", type: "button", className: `h-6 px-1 text-[10px] font-bold font-mono shrink-0 ${mode === 'val' ? 'text-amber-500' : 'text-primary'}`, onClick: () => {
359
+ if (mode === 'ref') {
360
+ setMode('val');
361
+ if (refPath)
362
+ setByValue(refPath);
363
+ else if (!isValue)
364
+ createEmpty();
365
+ }
366
+ else {
367
+ setMode('ref');
368
+ if (refPath)
369
+ setRef(refPath);
370
+ }
371
+ }, title: mode === 'val' ? 'Value mode — embeds node data' : 'Ref mode — stores path', children: mode }), refType && (_jsx("span", { className: "text-[9px] text-muted-foreground font-mono shrink-0", children: refType.includes('.') ? refType.slice(refType.lastIndexOf('.') + 1) : refType })), isValue ? (_jsxs("span", { className: "flex-1 min-w-0 text-[11px] font-mono text-foreground/70 truncate py-1", children: [refPath && _jsx("span", { className: "text-muted-foreground", children: refPath }), embeddedType && (_jsx("span", { className: "ml-1 text-amber-500", children: embeddedType }))] })) : (_jsx(Input, { className: "h-7 text-[11px] font-mono flex-1 min-w-0 border-0 bg-transparent", value: refPath, placeholder: "drop or pick a node", onChange: (e) => setRef(e.target.value) })), hasValue && (_jsx(Button, { variant: "ghost", size: "icon", type: "button", className: "h-5 w-5 p-0 text-muted-foreground/40 hover:text-foreground shrink-0", onClick: () => { onChange?.({ ...value, value: '' }); setMode('ref'); }, children: _jsx(X, { className: "h-3 w-3" }) })), _jsxs(Popover, { open: pickerOpen, onOpenChange: setPickerOpen, children: [_jsx(PopoverTrigger, { asChild: true, children: _jsx(Button, { variant: "ghost", size: "icon", type: "button", className: "h-5 w-5 p-0 text-muted-foreground hover:text-foreground shrink-0 text-[11px]", title: "Browse tree", children: "\u2630" }) }), _jsx(PopoverContent, { align: "end", className: "w-64 max-h-60 overflow-auto p-0", children: _jsx(MiniTree, { onSelect: (p) => { applyNode(p); setPickerOpen(false); } }) })] })] }), isValue && (_jsx("div", { className: "border-t border-border/50 p-2", children: _jsx(EmbeddedFields, { data: raw, type: effectiveType, setData: updateEmbedded }) }))] }) }));
376
372
  }
377
373
  // ── Registration ──
378
374
  // Each entry: [type, viewHandler, formHandler]