import { useField, useFieldSchema } from '@formily/react';
import {
GeneralSchemaDesigner,
SchemaSettingsBlockTitleItem,
SchemaSettingsDivider,
SchemaSettingsItem,
SchemaSettingsRemove,
gridRowColWrap,
useAPIClient,
useCollection_deprecated,
useDataSource,
useDesignable,
} from '@nocobase/client';
import { Empty, Result, Spin, Typography } from 'antd';
import React, { useContext } from 'react';
import { ErrorBoundary } from 'react-error-boundary';
import { ChartConfigContext } from '../configure';
import { useData, useFieldTransformer, useFieldsWithAssociation } from '../hooks';
import { useChartsTranslation } from '../locale';
import { createRendererSchema, getField } from '../utils';
import { ChartRendererContext } from './ChartRendererProvider';
import { useChart } from '../chart/group';
import { ChartDataContext } from '../block/ChartDataProvider';
const { Paragraph, Text } = Typography;
export const ChartRenderer: React.FC & {
Designer: React.FC;
} = (props) => {
const { t } = useChartsTranslation();
const ctx = useContext(ChartRendererContext);
const { config, transform, dataSource, collection, service, data: _data } = ctx;
const fields = useFieldsWithAssociation(dataSource, collection);
const data = useData(_data, dataSource, collection);
const general = config?.general || {};
const advanced = config?.advanced || {};
const api = useAPIClient();
const chart = useChart(config?.chartType);
const locale = api.auth.getLocale();
const transformers = useFieldTransformer(transform, locale);
const Component = chart?.render({
data,
general,
advanced,
fieldProps: Object.keys(data[0] || {}).reduce((props, name) => {
if (!props[name]) {
const field = getField(fields, name.split('.'));
const transformer = transformers[name];
props[name] = { label: field?.label || name, transformer, interface: field?.interface };
}
return props;
}, {}),
});
const C = () =>
chart ? (