Files
arcadia-admin/tsconfig.json
jules 9cbe921db7 ai: rich-output blocks via lazy-fetched typed-fence protocol
Assistant replies can now emit typed fenced blocks that render as
@crema/*-ui components inline at their position in the reply.

- message-body.tsx: segmented rendering — alternating prose chunks and
  block dispatch (was: all blocks appended at end). Renderers for kpi,
  table, chart-bar/-line/-donut/-spark, code, diff, flowchart, orgchart,
  steps, checklist, welcome, hint, plus the legacy card kinds.
- block-schemas.ts: single source of truth — BLOCK_INDEX (one-line
  purpose per kind, always in prompt) + SCHEMAS (full JSON shape +
  example, fetched on demand).
- admin-tools.ts: new get_block_schema(kind) tool the model calls once
  per kind per thread to fetch the exact schema. Keeps the always-on
  prompt small (~110 tokens vs ~400 inline).
- assistant.tsx: replaces the inline schema dump with the generated
  thin index.
- ai.tsx: empty-state preview button injects a synthetic assistant
  message exercising every block, for renderer/theme smoke-testing.
- console.css + ai.tsx: shrink ATLAS headline so it doesn't slip under
  the composer with the added preview button.
- tsconfig.json + app.css: wire lib-data-ui, lib-code-ui, lib-diagram-ui,
  lib-onboarding-ui as siblings.

Adding a new block kind = add the lib paths, add a renderer case, add
a schema entry. No prompt edits required.

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
2026-05-02 22:47:36 +10:00

86 lines
3.9 KiB
JSON

{
"include": [
"**/*",
"**/.server/**/*",
"**/.client/**/*",
".react-router/types/**/*"
],
"compilerOptions": {
"lib": ["DOM", "DOM.Iterable", "ES2022"],
"types": ["node", "vite/client"],
"target": "ES2022",
"module": "ES2022",
"moduleResolution": "bundler",
"jsx": "react-jsx",
"rootDirs": [".", "./.react-router/types"],
"baseUrl": ".",
"paths": {
"~/*": ["./app/*"],
"@crema/notification-ui": ["../lib-notification-ui/src/index.tsx"],
"@crema/notification-ui/*": ["../lib-notification-ui/src/*"],
"@crema/chat-ui": ["../lib-chat-ui/src/index.tsx"],
"@crema/chat-ui/*": ["../lib-chat-ui/src/*"],
"@crema/aifirst-ui": ["../lib-aifirst-ui/src/index.tsx"],
"@crema/aifirst-ui/*": ["../lib-aifirst-ui/src/*"],
"@crema/llm-ui": ["../lib-llm-ui/src/index.tsx"],
"@crema/llm-ui/*": ["../lib-llm-ui/src/*"],
"@crema/action-bus": ["../lib-action-bus/src/index.tsx"],
"@crema/action-bus/*": ["../lib-action-bus/src/*"],
"@crema/arcadia-client": ["../lib-arcadia-client/src/index.tsx"],
"@crema/arcadia-client/*": ["../lib-arcadia-client/src/*"],
"@crema/arcadia-auth-ui": ["../lib-arcadia-auth-ui/src/index.tsx"],
"@crema/arcadia-auth-ui/*": ["../lib-arcadia-auth-ui/src/*"],
"@crema/table-ui": ["../lib-table-ui/src/index.tsx"],
"@crema/table-ui/*": ["../lib-table-ui/src/*"],
"@crema/search-ui": ["../lib-search-ui/src/index.tsx"],
"@crema/search-ui/*": ["../lib-search-ui/src/*"],
"@crema/feedback-ui": ["../lib-feedback-ui/src/index.tsx"],
"@crema/feedback-ui/*": ["../lib-feedback-ui/src/*"],
"@crema/auth-ui": ["../lib-auth-ui/src/index.tsx"],
"@crema/auth-ui/*": ["../lib-auth-ui/src/*"],
"@crema/agent-ui": ["../lib-agent-ui/src/index.tsx"],
"@crema/agent-ui/*": ["../lib-agent-ui/src/*"],
"@crema/llm-providers-ui": ["../lib-llm-providers-ui/src/index.tsx"],
"@crema/llm-providers-ui/*": ["../lib-llm-providers-ui/src/*"],
"@crema/file-ui": ["../lib-file-ui/src/index.tsx"],
"@crema/file-ui/*": ["../lib-file-ui/src/*"],
"@crema/card-ui": ["../lib-card-ui/src/index.tsx"],
"@crema/card-ui/*": ["../lib-card-ui/src/*"],
"@crema/dashboard-ui": ["../lib-dashboard-ui/src/index.tsx"],
"@crema/dashboard-ui/*": ["../lib-dashboard-ui/src/*"],
"@crema/chart-ui": ["../lib-chart-ui/src/index.tsx"],
"@crema/chart-ui/*": ["../lib-chart-ui/src/*"],
"@crema/map-ui": ["../lib-map-ui/src/index.tsx"],
"@crema/map-ui/*": ["../lib-map-ui/src/*"],
"@crema/status-ui": ["../lib-status-ui/src/index.tsx"],
"@crema/status-ui/*": ["../lib-status-ui/src/*"],
"@crema/data-ui": ["../lib-data-ui/src/index.tsx"],
"@crema/data-ui/*": ["../lib-data-ui/src/*"],
"@crema/code-ui": ["../lib-code-ui/src/index.tsx"],
"@crema/code-ui/*": ["../lib-code-ui/src/*"],
"@crema/diagram-ui": ["../lib-diagram-ui/src/index.tsx"],
"@crema/diagram-ui/*": ["../lib-diagram-ui/src/*"],
"@crema/onboarding-ui": ["../lib-onboarding-ui/src/index.tsx"],
"@crema/onboarding-ui/*": ["../lib-onboarding-ui/src/*"],
"// CREMA:PATHS": [""],
"react": ["./node_modules/@types/react"],
"react/*": ["./node_modules/@types/react/*"],
"react-dom": ["./node_modules/@types/react-dom"],
"react-dom/*": ["./node_modules/@types/react-dom/*"],
"clsx": ["./node_modules/clsx"],
"tailwind-merge": ["./node_modules/tailwind-merge"],
"lucide-react": ["./node_modules/lucide-react"],
"openapi-fetch": ["./node_modules/openapi-fetch"],
"openapi-fetch/*": ["./node_modules/openapi-fetch/*"],
"phoenix": ["./node_modules/@types/phoenix"],
"phoenix/*": ["./node_modules/@types/phoenix/*"]
},
"esModuleInterop": true,
"verbatimModuleSyntax": true,
"noEmit": true,
"resolveJsonModule": true,
"skipLibCheck": true,
"strict": true
}
}