mirror of
https://github.com/csunny/DB-GPT.git
synced 2025-10-04 08:35:40 +00:00
39 lines
1.3 KiB
TypeScript
39 lines
1.3 KiB
TypeScript
import { Datum } from '@antv/ava';
|
|
import { Table, Tabs, TabsProps } from 'antd';
|
|
import React from 'react';
|
|
import { format } from 'sql-formatter';
|
|
import { AutoChart, BackEndChartType, getChartType } from '@/components/chart/autoChart';
|
|
import { CodePreview } from './code-preview';
|
|
|
|
function ChartView({ data, type, sql }: { data: Datum[]; type: BackEndChartType; sql: string }) {
|
|
const columns = data?.[0]
|
|
? Object.keys(data?.[0])?.map((item) => {
|
|
return {
|
|
title: item,
|
|
dataIndex: item,
|
|
key: item,
|
|
};
|
|
})
|
|
: [];
|
|
const ChartItem = {
|
|
key: 'chart',
|
|
label: 'Chart',
|
|
children: <AutoChart data={data} chartType={getChartType(type)} />,
|
|
};
|
|
const SqlItem = {
|
|
key: 'sql',
|
|
label: 'SQL',
|
|
children: <CodePreview language="sql" code={format(sql ?? '', { language: 'mysql' }) as string} />,
|
|
};
|
|
const DataItem = {
|
|
key: 'data',
|
|
label: 'Data',
|
|
children: <Table dataSource={data} columns={columns} scroll={{ x: 'auto' }} />,
|
|
};
|
|
const TabItems: TabsProps['items'] = type === 'response_table' ? [DataItem, SqlItem] : [ChartItem, SqlItem, DataItem];
|
|
|
|
return <Tabs defaultActiveKey={type === 'response_table' ? 'data' : 'chart'} items={TabItems} size="small" />;
|
|
}
|
|
|
|
export default ChartView;
|