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>
86 lines
3.9 KiB
JSON
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
|
|
}
|
|
}
|