@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.
- package/README.md +91 -0
- package/dist/AclEditor.d.ts +1 -1
- package/dist/AclEditor.d.ts.map +1 -1
- package/dist/AclEditor.js +5 -5
- package/dist/AclEditor.js.map +1 -1
- package/dist/ActionCards.d.ts +9 -0
- package/dist/ActionCards.d.ts.map +1 -0
- package/dist/ActionCards.js +96 -0
- package/dist/ActionCards.js.map +1 -0
- package/dist/App.d.ts.map +1 -1
- package/dist/App.js +71 -185
- package/dist/App.js.map +1 -1
- package/dist/ComponentSection.d.ts +15 -0
- package/dist/ComponentSection.d.ts.map +1 -0
- package/dist/ComponentSection.js +25 -0
- package/dist/ComponentSection.js.map +1 -0
- package/dist/ErrorBoundary.d.ts +18 -0
- package/dist/ErrorBoundary.d.ts.map +1 -0
- package/dist/ErrorBoundary.js +17 -0
- package/dist/ErrorBoundary.js.map +1 -0
- package/dist/Inspector.d.ts +1 -0
- package/dist/Inspector.d.ts.map +1 -1
- package/dist/Inspector.js +22 -347
- package/dist/Inspector.js.map +1 -1
- package/dist/Login.d.ts +8 -0
- package/dist/Login.d.ts.map +1 -0
- package/dist/Login.js +45 -0
- package/dist/Login.js.map +1 -0
- package/dist/NodeEditor.d.ts +11 -0
- package/dist/NodeEditor.d.ts.map +1 -0
- package/dist/NodeEditor.js +157 -0
- package/dist/NodeEditor.js.map +1 -0
- package/dist/Tree.d.ts +1 -0
- package/dist/Tree.d.ts.map +1 -1
- package/dist/Tree.js +8 -27
- package/dist/Tree.js.map +1 -1
- package/dist/bind/engine.js +1 -1
- package/dist/bind/engine.js.map +1 -1
- package/dist/bind/eval.d.ts +1 -1
- package/dist/bind/eval.d.ts.map +1 -1
- package/dist/bind/hook.d.ts +1 -1
- package/dist/bind/hook.d.ts.map +1 -1
- package/dist/bind/hook.js +1 -1
- package/dist/bind/hook.js.map +1 -1
- package/dist/cache.d.ts +1 -1
- package/dist/cache.d.ts.map +1 -1
- package/dist/cache.js +4 -0
- package/dist/cache.js.map +1 -1
- package/dist/client-tree.d.ts +1 -2
- package/dist/client-tree.d.ts.map +1 -1
- package/dist/client-tree.js +12 -5
- package/dist/client-tree.js.map +1 -1
- package/dist/client.d.ts +1 -1
- package/dist/client.d.ts.map +1 -1
- package/dist/client.js +2 -4
- package/dist/client.js.map +1 -1
- package/dist/components/ConfirmDialog.d.ts +9 -0
- package/dist/components/ConfirmDialog.d.ts.map +1 -0
- package/dist/components/ConfirmDialog.js +6 -0
- package/dist/components/ConfirmDialog.js.map +1 -0
- package/dist/components/ConfirmPopover.d.ts +8 -0
- package/dist/components/ConfirmPopover.d.ts.map +1 -0
- package/dist/components/ConfirmPopover.js +9 -0
- package/dist/components/ConfirmPopover.js.map +1 -0
- package/dist/components/PathBreadcrumb.d.ts +5 -0
- package/dist/components/PathBreadcrumb.d.ts.map +1 -0
- package/dist/components/PathBreadcrumb.js +16 -0
- package/dist/components/PathBreadcrumb.js.map +1 -0
- package/dist/components/lib/utils.d.ts +3 -0
- package/dist/components/lib/utils.d.ts.map +1 -0
- package/dist/components/lib/utils.js +6 -0
- package/dist/components/lib/utils.js.map +1 -0
- package/dist/components/ui/accordion.js +1 -1
- package/dist/components/ui/accordion.js.map +1 -1
- package/dist/components/ui/alert-dialog.d.ts +19 -0
- package/dist/components/ui/alert-dialog.d.ts.map +1 -0
- package/dist/components/ui/alert-dialog.js +42 -0
- package/dist/components/ui/alert-dialog.js.map +1 -0
- package/dist/components/ui/badge.js +1 -1
- package/dist/components/ui/badge.js.map +1 -1
- package/dist/components/ui/breadcrumb.d.ts +12 -0
- package/dist/components/ui/breadcrumb.d.ts.map +1 -0
- package/dist/components/ui/breadcrumb.js +28 -0
- package/dist/components/ui/breadcrumb.js.map +1 -0
- package/dist/components/ui/button.d.ts +9 -8
- package/dist/components/ui/button.d.ts.map +1 -1
- package/dist/components/ui/button.js +26 -21
- package/dist/components/ui/button.js.map +1 -1
- package/dist/components/ui/card.d.ts +10 -0
- package/dist/components/ui/card.d.ts.map +1 -0
- package/dist/components/ui/card.js +25 -0
- package/dist/components/ui/card.js.map +1 -0
- package/dist/components/ui/checkbox.js +1 -1
- package/dist/components/ui/checkbox.js.map +1 -1
- package/dist/components/ui/collapsible.d.ts +6 -0
- package/dist/components/ui/collapsible.d.ts.map +1 -0
- package/dist/components/ui/collapsible.js +13 -0
- package/dist/components/ui/collapsible.js.map +1 -0
- package/dist/components/ui/command.d.ts +19 -0
- package/dist/components/ui/command.d.ts.map +1 -0
- package/dist/components/ui/command.js +35 -0
- package/dist/components/ui/command.js.map +1 -0
- package/dist/components/ui/dialog.d.ts.map +1 -1
- package/dist/components/ui/dialog.js +1 -1
- package/dist/components/ui/dialog.js.map +1 -1
- package/dist/components/ui/drawer.js +1 -1
- package/dist/components/ui/drawer.js.map +1 -1
- package/dist/components/ui/dropdown-menu.d.ts +26 -0
- package/dist/components/ui/dropdown-menu.d.ts.map +1 -0
- package/dist/components/ui/dropdown-menu.js +52 -0
- package/dist/components/ui/dropdown-menu.js.map +1 -0
- package/dist/components/ui/form-field.d.ts +7 -0
- package/dist/components/ui/form-field.d.ts.map +1 -0
- package/dist/components/ui/form-field.js +17 -0
- package/dist/components/ui/form-field.js.map +1 -0
- package/dist/components/ui/input.js +1 -1
- package/dist/components/ui/input.js.map +1 -1
- package/dist/components/ui/label.js +1 -1
- package/dist/components/ui/label.js.map +1 -1
- package/dist/components/ui/pagination.d.ts +14 -0
- package/dist/components/ui/pagination.d.ts.map +1 -0
- package/dist/components/ui/pagination.js +30 -0
- package/dist/components/ui/pagination.js.map +1 -0
- package/dist/components/ui/popover.js +2 -2
- package/dist/components/ui/popover.js.map +1 -1
- package/dist/components/ui/progress.js +1 -1
- package/dist/components/ui/progress.js.map +1 -1
- package/dist/components/ui/resizable.d.ts +8 -0
- package/dist/components/ui/resizable.d.ts.map +1 -0
- package/dist/components/ui/resizable.js +14 -0
- package/dist/components/ui/resizable.js.map +1 -0
- package/dist/components/ui/scroll-area.d.ts +6 -0
- package/dist/components/ui/scroll-area.d.ts.map +1 -0
- package/dist/components/ui/scroll-area.js +13 -0
- package/dist/components/ui/scroll-area.js.map +1 -0
- package/dist/components/ui/select.js +1 -1
- package/dist/components/ui/select.js.map +1 -1
- package/dist/components/ui/separator.d.ts +5 -0
- package/dist/components/ui/separator.d.ts.map +1 -0
- package/dist/components/ui/separator.js +9 -0
- package/dist/components/ui/separator.js.map +1 -0
- package/dist/components/ui/sheet.d.ts +15 -0
- package/dist/components/ui/sheet.d.ts.map +1 -0
- package/dist/components/ui/sheet.js +40 -0
- package/dist/components/ui/sheet.js.map +1 -0
- package/dist/components/ui/skeleton.d.ts +3 -0
- package/dist/components/ui/skeleton.d.ts.map +1 -0
- package/dist/components/ui/skeleton.js +7 -0
- package/dist/components/ui/skeleton.js.map +1 -0
- package/dist/components/ui/slider.js +1 -1
- package/dist/components/ui/slider.js.map +1 -1
- package/dist/components/ui/switch.js +1 -1
- package/dist/components/ui/switch.js.map +1 -1
- package/dist/components/ui/table.d.ts +11 -0
- package/dist/components/ui/table.d.ts.map +1 -0
- package/dist/components/ui/table.js +29 -0
- package/dist/components/ui/table.js.map +1 -0
- package/dist/components/ui/tabs.d.ts +12 -0
- package/dist/components/ui/tabs.d.ts.map +1 -0
- package/dist/components/ui/tabs.js +29 -0
- package/dist/components/ui/tabs.js.map +1 -0
- package/dist/components/ui/textarea.js +1 -1
- package/dist/components/ui/textarea.js.map +1 -1
- package/dist/components/ui/toggle-group.d.ts +10 -0
- package/dist/components/ui/toggle-group.d.ts.map +1 -0
- package/dist/components/ui/toggle-group.js +23 -0
- package/dist/components/ui/toggle-group.js.map +1 -0
- package/dist/components/ui/toggle.d.ts +10 -0
- package/dist/components/ui/toggle.d.ts.map +1 -0
- package/dist/components/ui/toggle.js +27 -0
- package/dist/components/ui/toggle.js.map +1 -0
- package/dist/components/ui/tooltip.js +1 -1
- package/dist/components/ui/tooltip.js.map +1 -1
- package/dist/context/index.d.ts +27 -10
- package/dist/context/index.d.ts.map +1 -1
- package/dist/context/index.js +43 -36
- package/dist/context/index.js.map +1 -1
- package/dist/events.d.ts +10 -0
- package/dist/events.d.ts.map +1 -0
- package/dist/events.js +78 -0
- package/dist/events.js.map +1 -0
- package/dist/fiber-tree.d.ts +3 -0
- package/dist/fiber-tree.d.ts.map +1 -0
- package/dist/fiber-tree.js +93 -0
- package/dist/fiber-tree.js.map +1 -0
- package/dist/hooks.d.ts +5 -2
- package/dist/hooks.d.ts.map +1 -1
- package/dist/hooks.js +66 -6
- package/dist/hooks.js.map +1 -1
- package/dist/idb.d.ts +1 -1
- package/dist/idb.d.ts.map +1 -1
- package/dist/lib/to-plain.d.ts +2 -0
- package/dist/lib/to-plain.d.ts.map +1 -0
- package/dist/lib/to-plain.js +21 -0
- package/dist/lib/to-plain.js.map +1 -0
- package/dist/main.d.ts +1 -1
- package/dist/main.d.ts.map +1 -1
- package/dist/main.js +4 -3
- package/dist/main.js.map +1 -1
- package/dist/mods/clients.d.ts +3 -0
- package/dist/mods/clients.d.ts.map +1 -0
- package/dist/mods/clients.js +4 -0
- package/dist/mods/clients.js.map +1 -0
- package/dist/mods/editor-ui/FieldLabel.d.ts +15 -0
- package/dist/mods/editor-ui/FieldLabel.d.ts.map +1 -0
- package/dist/mods/editor-ui/FieldLabel.js +55 -0
- package/dist/mods/editor-ui/FieldLabel.js.map +1 -0
- package/dist/mods/editor-ui/client.d.ts +1 -1
- package/dist/mods/editor-ui/client.d.ts.map +1 -1
- package/dist/mods/editor-ui/client.js +1 -1
- package/dist/mods/editor-ui/client.js.map +1 -1
- package/dist/mods/editor-ui/default-edit.d.ts +2 -0
- package/dist/mods/editor-ui/default-edit.d.ts.map +1 -0
- package/dist/mods/editor-ui/default-edit.js +54 -0
- package/dist/mods/editor-ui/default-edit.js.map +1 -0
- package/dist/mods/editor-ui/default-view.d.ts +8 -1
- package/dist/mods/editor-ui/default-view.d.ts.map +1 -1
- package/dist/mods/editor-ui/default-view.js +8 -5
- package/dist/mods/editor-ui/default-view.js.map +1 -1
- package/dist/mods/editor-ui/dir-view.js +0 -2
- package/dist/mods/editor-ui/dir-view.js.map +1 -1
- package/dist/mods/editor-ui/empty-placeholder.d.ts +5 -0
- package/dist/mods/editor-ui/empty-placeholder.d.ts.map +1 -0
- package/dist/mods/editor-ui/empty-placeholder.js +14 -0
- package/dist/mods/editor-ui/empty-placeholder.js.map +1 -0
- package/dist/mods/editor-ui/form-field.d.ts +17 -0
- package/dist/mods/editor-ui/form-field.d.ts.map +1 -0
- package/dist/mods/editor-ui/form-field.js +68 -0
- package/dist/mods/editor-ui/form-field.js.map +1 -0
- package/dist/mods/editor-ui/form-fields.d.ts +1 -2
- package/dist/mods/editor-ui/form-fields.d.ts.map +1 -1
- package/dist/mods/editor-ui/form-fields.js +56 -60
- package/dist/mods/editor-ui/form-fields.js.map +1 -1
- package/dist/mods/editor-ui/layout-view.js +3 -2
- package/dist/mods/editor-ui/layout-view.js.map +1 -1
- package/dist/mods/editor-ui/list-items.js +1 -1
- package/dist/mods/editor-ui/list-items.js.map +1 -1
- package/dist/mods/editor-ui/node-utils.d.ts +2 -2
- package/dist/mods/editor-ui/node-utils.d.ts.map +1 -1
- package/dist/mods/editor-ui/node-utils.js +4 -5
- package/dist/mods/editor-ui/node-utils.js.map +1 -1
- package/dist/mods/editor-ui/type-picker.d.ts +15 -0
- package/dist/mods/editor-ui/type-picker.d.ts.map +1 -0
- package/dist/mods/editor-ui/type-picker.js +69 -0
- package/dist/mods/editor-ui/type-picker.js.map +1 -0
- package/dist/mods/editor-ui/user-view.js +1 -1
- package/dist/mods/editor-ui/user-view.js.map +1 -1
- package/dist/mods/servers.d.ts +1 -0
- package/dist/mods/servers.d.ts.map +1 -0
- package/dist/mods/servers.js +4 -0
- package/dist/mods/servers.js.map +1 -0
- package/dist/mods/treenity/groups/index.js +1 -1
- package/dist/mods/treenity/groups/index.js.map +1 -1
- package/dist/mods/treenity/preview.js +1 -1
- package/dist/mods/treenity/preview.js.map +1 -1
- package/dist/mods/treenity/ref-view.js +1 -1
- package/dist/mods/treenity/ref-view.js.map +1 -1
- package/dist/mods/treenity/schema-form.js +1 -1
- package/dist/mods/treenity/schema-form.js.map +1 -1
- package/dist/mods/treenity/seed.js +1 -1
- package/dist/mods/treenity/seed.js.map +1 -1
- package/dist/mods/treenity/type-view.js +1 -1
- package/dist/mods/treenity/type-view.js.map +1 -1
- package/dist/schema-loader.d.ts +1 -1
- package/dist/schema-loader.d.ts.map +1 -1
- package/dist/schema-loader.js +1 -1
- package/dist/schema-loader.js.map +1 -1
- package/dist/symbols.d.ts +5 -0
- package/dist/symbols.d.ts.map +1 -0
- package/dist/symbols.js +16 -0
- package/dist/symbols.js.map +1 -0
- package/dist/trpc.d.ts +10 -3
- package/dist/trpc.d.ts.map +1 -1
- package/package.json +74 -8
- package/src/AclEditor.tsx +11 -18
- package/src/ActionCards.tsx +224 -0
- package/src/App.tsx +204 -385
- package/src/ComponentSection.tsx +113 -0
- package/src/ErrorBoundary.tsx +37 -0
- package/src/Inspector.css +54 -0
- package/src/Inspector.tsx +73 -793
- package/src/Login.tsx +97 -0
- package/src/NodeEditor.tsx +300 -0
- package/src/Tree.css +91 -0
- package/src/Tree.tsx +40 -43
- package/src/bind/bind.test.ts +1 -1
- package/src/bind/engine.ts +1 -1
- package/src/bind/eval.ts +1 -1
- package/src/bind/hook.ts +1 -1
- package/src/bind/pipes.ts +1 -1
- package/src/cache.ts +5 -1
- package/src/client-tree.test.ts +1 -1
- package/src/client-tree.ts +22 -16
- package/src/client.ts +2 -4
- package/src/components/ConfirmDialog.tsx +34 -0
- package/src/components/ConfirmPopover.tsx +41 -0
- package/src/components/PathBreadcrumb.tsx +36 -0
- package/src/components/lib/utils.ts +6 -0
- package/src/components/lib/utils.ts.bak +6 -0
- package/src/components/ui/accordion.tsx +1 -1
- package/src/components/ui/alert-dialog.tsx +189 -0
- package/src/components/ui/badge.tsx +1 -1
- package/src/components/ui/breadcrumb.tsx +108 -0
- package/src/components/ui/button.tsx +53 -31
- package/src/components/ui/card.tsx +91 -0
- package/src/components/ui/checkbox.tsx +1 -1
- package/src/components/ui/collapsible.tsx +31 -0
- package/src/components/ui/command.tsx +177 -0
- package/src/components/ui/dialog.tsx +1 -2
- package/src/components/ui/drawer.tsx +1 -1
- package/src/components/ui/dropdown-menu.tsx +256 -0
- package/src/components/ui/form-field.tsx +37 -0
- package/src/components/ui/input.tsx +1 -1
- package/src/components/ui/label.tsx +1 -1
- package/src/components/ui/pagination.tsx +127 -0
- package/src/components/ui/popover.tsx +2 -2
- package/src/components/ui/progress.tsx +1 -1
- package/src/components/ui/resizable.tsx +47 -0
- package/src/components/ui/scroll-area.tsx +55 -0
- package/src/components/ui/select.tsx +1 -1
- package/src/components/ui/separator.tsx +27 -0
- package/src/components/ui/sheet.tsx +140 -0
- package/src/components/ui/skeleton.tsx +13 -0
- package/src/components/ui/slider.tsx +1 -1
- package/src/components/ui/switch.tsx +1 -1
- package/src/components/ui/table.tsx +115 -0
- package/src/components/ui/tabs.tsx +88 -0
- package/src/components/ui/textarea.tsx +1 -1
- package/src/components/ui/toggle-group.tsx +82 -0
- package/src/components/ui/toggle.tsx +46 -0
- package/src/components/ui/tooltip.tsx +1 -1
- package/src/context/index.tsx +75 -42
- package/src/events.ts +81 -0
- package/src/fiber-tree.ts +112 -0
- package/src/hooks.ts +88 -9
- package/src/idb.ts +1 -1
- package/src/lib/to-plain.ts +21 -0
- package/src/main.tsx +3 -1
- package/src/mods/clients.ts +3 -0
- package/src/mods/editor-ui/FieldLabel.tsx +124 -0
- package/src/mods/editor-ui/client.ts +1 -1
- package/src/mods/editor-ui/default-edit.tsx +99 -0
- package/src/mods/editor-ui/default-view.tsx +13 -8
- package/src/mods/editor-ui/dir-view.tsx +2 -2
- package/src/mods/editor-ui/editor-ui.css +174 -0
- package/src/mods/editor-ui/empty-placeholder.tsx +39 -0
- package/src/mods/editor-ui/form-field.tsx +144 -0
- package/src/mods/editor-ui/form-fields.tsx +132 -113
- package/src/mods/editor-ui/layout-view.tsx +4 -2
- package/src/mods/editor-ui/list-items.tsx +2 -2
- package/src/mods/editor-ui/node-utils.ts +4 -5
- package/src/mods/editor-ui/type-picker.tsx +147 -0
- package/src/mods/editor-ui/user-view.tsx +1 -1
- package/src/mods/servers.ts +2 -0
- package/src/mods/treenity/groups/index.tsx +1 -1
- package/src/mods/treenity/preview.tsx +1 -1
- package/src/mods/treenity/ref-view.tsx +1 -1
- package/src/mods/treenity/schema-form.tsx +1 -1
- package/src/mods/treenity/seed.ts +1 -1
- package/src/mods/treenity/type-view.tsx +1 -1
- package/src/optimistic.test.ts +111 -0
- package/src/remote-tree.test.ts +1 -1
- package/src/remote-tree.ts +1 -1
- package/src/root.css +117 -0
- package/src/schema-loader.ts +1 -1
- package/src/symbols.ts +18 -0
- package/src/index.html +0 -14
- package/src/style.css +0 -1269
- 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
|
|
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("
|
|
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(
|
|
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":";AAAA,OAAO,EAAE,MAAM,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AACjD,OAAO,EAAE,WAAW,EAAE,MAAM,QAAQ,CAAC;AACrC,OAAO,EAAE,IAAI,EAAE,MAAM,OAAO,CAAC;AAC7B,OAAO,EAAqC,QAAQ,EAAE,MAAM,
|
|
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":";AAAA,OAAO,EAAE,MAAM,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AACjD,OAAO,EAAE,WAAW,EAAE,MAAM,QAAQ,CAAC;
|
|
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 @@
|
|
|
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
|
|
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":"
|
|
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 {
|
|
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(
|
|
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("
|
|
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("
|
|
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(
|
|
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(
|
|
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(
|
|
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("
|
|
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("
|
|
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(
|
|
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(
|
|
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("
|
|
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(
|
|
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(
|
|
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("
|
|
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(
|
|
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("
|
|
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("
|
|
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(
|
|
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(
|
|
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
|
|
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(
|
|
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(
|
|
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 (
|
|
351
|
-
|
|
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
|
-
|
|
359
|
-
|
|
360
|
-
|
|
361
|
-
|
|
362
|
-
|
|
363
|
-
|
|
364
|
-
|
|
365
|
-
|
|
366
|
-
|
|
367
|
-
|
|
368
|
-
|
|
369
|
-
|
|
370
|
-
|
|
371
|
-
|
|
372
|
-
|
|
373
|
-
|
|
374
|
-
|
|
375
|
-
|
|
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]
|