When creating a chart, automatically assign first text column to X axis
and first number column to Y axis (varies by chart type).
Charts now show data immediately instead of blank.
Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
- All 4 API clients now consistently use /api/v1/ prefix on all routes
- ChartRenderer fills missing style fields with defaults to prevent
undefined property crashes when backend returns minimal style
- KPICard uses safe defaults for background/border/title
Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
react-grid-layout v2 removed WidthProvider. Use ResizeObserver to
track container width and pass it directly to Responsive component.
Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
- useImportData: use dataset_id instead of id from backend response,
fetch rows after import, fix column type mapping
- useCreateChart: fix bindings mapper to use axis instead of fieldRole,
graceful error handling instead of throwing
Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
Clicking a chart type card now calls useCreateChart to create
a chart instance on the backend and add it to the canvas.
Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
WidthProvider is not available during SSR. Use dynamic import
inside useEffect to load it only on the client side.
Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
Previously excluded due to nested .git from create-next-app.
Includes all Clean Architecture layers, API client integration,
and full UI component suite.
Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>