mirror of
https://gitee.com/nocobase/nocobase.git
synced 2025-07-02 03:02:19 +08:00
* feat: add pie schema template * chore: refactor * chore: update * chore: init server * feat: add pie schema template * chore: add chart utils * chore: update * chore: update * chore: update * chore: update * feat: mvp * chore: update * chore: test * feat: example * fix: templates map error * chore: update * feat: add ChartBlockEngineDesigner.tsx * chore: clean code * chore: update templates * chore: init bat template * chore: update chart block engine * feat: add chart block engine designer * chore: update chart block initializer * chore: update pie template * chore: update * feat: split sql * chore: update * chore: clean * feat: support bar * chore: add bar template * chore: clean code * chore: clean code * fix: chart block initializer title * chore: update * fix: use title * chore: update * fix: bugs * chore: clean code * chore: update pie template * chore: update ChartBlockInitializer.tsx * chore: update * feat: support chart config * chore: add local plugin * feat: add column template * feat: add column chart action * feat: add line chart template * feat: add line action * feat: add area template * feat: add area action * chore: update pie template * chore: update * chore: update dep * fix: export missing utils * chore: update dep * chore: update dep * chore: update pie template * fix(charts): sql table capitalization * fix(charts): improve sql compatibility * fix: support choices type * chore: update * chore: clean code * chore: get collection fields in chart engine * feat(demo): chart block initializer * fix: hello block * chore: init data analyse plugin * chore: add data-analyse plugin * chore: init plugin * chore: update * chore: export schema initializers * feat: add data analyse block * chore: update data analyse block initializer * chore: rename plugin name * chore: update * chore: update enum * chore: update add block * feat: add pie schema template * chore: refactor * chore: update * chore: init server * feat: add pie schema template * chore: add chart utils * chore: update * chore: update * chore: update * chore: update * feat: mvp * chore: update * chore: test * feat: example * fix: templates map error * chore: update * feat: add ChartBlockEngineDesigner.tsx * chore: clean code * chore: update templates * chore: init bat template * chore: update chart block engine * feat: add chart block engine designer * chore: update chart block initializer * chore: update pie template * chore: update * feat: split sql * chore: update * chore: clean * feat: support bar * chore: add bar template * chore: clean code * chore: clean code * fix: chart block initializer title * chore: update * fix: use title * chore: update * fix: bugs * chore: clean code * chore: update pie template * chore: update ChartBlockInitializer.tsx * chore: update * feat: support chart config * chore: add local plugin * feat: add column template * feat: add column chart action * feat: add line chart template * feat: add line action * feat: add area template * feat: add area action * chore: update pie template * chore: update * chore: update dep * fix: export missing utils * chore: update dep * chore: update dep * chore: update pie template * fix(charts): sql table capitalization * fix(charts): improve sql compatibility * fix: support choices type * chore: update * chore: clean code * chore: get collection fields in chart engine * chore: init dataset plugin * chore: init dataset designer * chore: init dataset block initializer * chore: update * chore: update * chore: update deps * chore: add tests * chore: update utils * chore: init plugin * feat: add datasets client * chore: update tests * chore: update datastructures * chore: update * feat: add DataSetBlockInitializer * chore: use dataset initializer * chore: update deps * chore: update * chore: update pie template * chore: update ChartBlockInitializer * chore: update ChartBlockEngine * chore: remove mdg file * chore: update ChartBlockEngine * chore: update * chore: update g2plot * chore: update template * chore: update pie handler * chore: update DataSetPreviewTable * chore: update ChartBlockEngine * chore: update ChartBlockEngineDesigner * chore: remove useless files * chore: update ChartBlockInitializer * chore: update template * chore: feat area template * chore: update tests * chore: update local plugins * chore: update deps * chore: update templates * chore: update template * feat: add CustomSelect * chore: update select component * fix: seriesField color error * chore: update template * chore: update * fix: bar * chore: update templates & clean code * chore: update templates * feat: add FunnelTemplate * feat: charts queries * fix: data shift * feat: add ChartQueryMetadataProvider * chore: update * chore: remove dataset * chore: update * chore: update * chore: clean code * fix: delete query query list wrong behavior * fix: delete all queries query list behavior * chore: add empty occupancy * chore: update description * chore: update chart icon * chore: update funnel template * chore: update template title * chore: add references * chore: update dialog height * fix: scatter template * chore: update popup description * refactor: schema level * refactor: charts schema * chore: remove console * chore: remove console * fix: error message * chore: remove console * chore: update DataSetPreviewTable * feat: chart icons * feat: update i18n * feat: update i18n * chore: update i18n * chore: update i18n * chore: update i18n * feat: add tittle * chore: update icons * chore: update i18n * chore: update i18n * chore: update i18n * chore: update i18n * chore: update i18n * fix: improve code * chore: update i18n * chore: update i18n * fix: chart icon * feat: quick add query (#1527) * feat: quick add query * feat: query * chore: remove useless files * fix: json5 validator error * chore: update * chore: update style * chore: lint * feat: improve code * feat: sql validation * refactor: clean code * Update utils.ts * chore: format code * chore: remove useless file * chore: update --------- Co-authored-by: chenos <chenlinxh@gmail.com>
217 lines
8.0 KiB
TypeScript
217 lines
8.0 KiB
TypeScript
import { css } from '@emotion/css';
|
|
import { FormDialog, FormLayout } from '@formily/antd';
|
|
import { Field } from '@formily/core';
|
|
import { observer, RecursionField, Schema, SchemaOptionsContext, useField, useForm } from '@formily/react';
|
|
import {
|
|
APIClientProvider,
|
|
FormProvider,
|
|
SchemaComponent,
|
|
SchemaComponentOptions,
|
|
useAPIClient,
|
|
useCompile,
|
|
} from '@nocobase/client';
|
|
import { Card } from 'antd';
|
|
import JSON5 from 'json5';
|
|
import React, { useContext, useEffect, useState } from 'react';
|
|
import { ChartBlockEngineMetaData } from './ChartBlockEngine';
|
|
import { jsonConfigDesc } from './ChartBlockEngineDesigner';
|
|
import { ChartQueryBlockInitializer, ChartQueryMetadata } from './ChartQueryBlockInitializer';
|
|
import DataSetPreviewTable from './DataSetPreviewTable';
|
|
import { lang, useChartsTranslation } from './locale';
|
|
import { templates } from './templates';
|
|
|
|
export const Options = observer((props) => {
|
|
const form = useForm<ChartFormInterface>();
|
|
const field = useField<Field>();
|
|
const [s, setSchema] = useState(new Schema({}));
|
|
const [chartType, setChartType] = useState(form.values.type);
|
|
useEffect(() => {
|
|
// form.clearFormGraph('options.*');
|
|
setChartType(form?.values?.type);
|
|
if (chartType !== form?.values?.type) {
|
|
form.clearFormGraph('options.*');
|
|
}
|
|
if (form.values.type) {
|
|
const template = templates.get(form.values.type);
|
|
setSchema(new Schema(template.configurableProperties || {}));
|
|
}
|
|
}, [form.values.type]);
|
|
return <RecursionField schema={s} />;
|
|
});
|
|
|
|
interface ChartFormInterface {
|
|
type: string;
|
|
template: string;
|
|
metric: string;
|
|
dimension: string;
|
|
category?: string;
|
|
|
|
[key: string]: string;
|
|
}
|
|
|
|
export const ChartBlockInitializer = (props) => {
|
|
const { insert } = props;
|
|
const options = useContext(SchemaOptionsContext);
|
|
const api = useAPIClient();
|
|
const compile = useCompile();
|
|
const { t } = useChartsTranslation();
|
|
return (
|
|
<ChartQueryBlockInitializer
|
|
{...props}
|
|
componentType={'Charts'}
|
|
onCreateBlockSchema={async ({ item: chartQueryMetadata }: { item: ChartQueryMetadata }) => {
|
|
const dataSource = chartQueryMetadata?.fields.map((field) => {
|
|
return {
|
|
label: field.name,
|
|
value: field.name,
|
|
};
|
|
});
|
|
let values = await FormDialog(
|
|
{
|
|
okText: compile('{{t("Submit")}}'),
|
|
title: lang('Create chart block'),
|
|
width: 1200,
|
|
bodyStyle: { background: '#f0f2f5', maxHeight: '65vh', overflow: 'auto' },
|
|
},
|
|
() => {
|
|
const form = useForm<ChartFormInterface>();
|
|
const [chartBlockEngineMetaData, setChartBlockEngineMetaData] = useState<ChartBlockEngineMetaData>(null);
|
|
useEffect(() => {
|
|
const chartBlockEngineMetaData = {
|
|
query: {
|
|
id: chartQueryMetadata?.id,
|
|
},
|
|
chart: form.values, //TODO
|
|
};
|
|
setChartBlockEngineMetaData(chartBlockEngineMetaData);
|
|
}, [form.values.type]);
|
|
return (
|
|
<APIClientProvider apiClient={api}>
|
|
<SchemaComponentOptions scope={options.scope} components={{ ...options.components }}>
|
|
<section
|
|
className={css`
|
|
display: flex;
|
|
gap: 24px;
|
|
`}
|
|
>
|
|
{/* left*/}
|
|
<Card
|
|
title={lang('Chart config')}
|
|
size={'default'}
|
|
className={css`
|
|
flex: 1;
|
|
`}
|
|
>
|
|
<FormProvider form={form}>
|
|
<FormLayout layout={'vertical'}>
|
|
<SchemaComponent
|
|
scope={{ dataSource, JSON5, jsonConfigDesc }}
|
|
components={{ Options }}
|
|
schema={{
|
|
properties: {
|
|
// title: {
|
|
// title: lang('Chart title'),
|
|
// 'x-component': 'Input',
|
|
// 'x-decorator': 'FormItem',
|
|
// },
|
|
type: {
|
|
title: lang('Chart type'),
|
|
required: true,
|
|
'x-component': 'CustomSelect',
|
|
'x-decorator': 'FormItem',
|
|
enum: [...templates.values()].map((template) => {
|
|
return {
|
|
title: template.title,
|
|
key: template.type,
|
|
description: template.description,
|
|
group: template.group,
|
|
iconId: template.iconId,
|
|
};
|
|
}),
|
|
},
|
|
options: {
|
|
type: 'void',
|
|
'x-component': 'Options',
|
|
},
|
|
},
|
|
}}
|
|
/>
|
|
</FormLayout>
|
|
</FormProvider>
|
|
</Card>
|
|
{/* right*/}
|
|
<div
|
|
className={css`
|
|
flex: 1;
|
|
min-width: 600px;
|
|
`}
|
|
>
|
|
<Card size={'default'} title={lang('Chart preview')}>
|
|
{/* Chart Preview*/}
|
|
{chartBlockEngineMetaData && (
|
|
<>
|
|
<SchemaComponent
|
|
schema={{
|
|
properties: {
|
|
chartPreview: {
|
|
type: 'void',
|
|
'x-decorator': 'CardItem',
|
|
'x-component': 'ChartBlockEngine',
|
|
'x-component-props': {
|
|
chartBlockEngineMetaData,
|
|
},
|
|
},
|
|
},
|
|
}}
|
|
/>
|
|
</>
|
|
)}
|
|
</Card>
|
|
<Card
|
|
size={'default'}
|
|
title={lang('Data preview')}
|
|
className={css`
|
|
margin-top: 24px;
|
|
overflow: scroll;
|
|
`}
|
|
>
|
|
{/*Data preview*/}
|
|
{chartBlockEngineMetaData?.query?.id && (
|
|
<DataSetPreviewTable
|
|
queryId={chartBlockEngineMetaData?.query?.id}
|
|
fields={chartQueryMetadata?.fields}
|
|
/>
|
|
)}
|
|
</Card>
|
|
</div>
|
|
</section>
|
|
</SchemaComponentOptions>
|
|
</APIClientProvider>
|
|
);
|
|
},
|
|
).open({
|
|
initialValues: {},
|
|
});
|
|
if (values) {
|
|
const chartBlockEngineMetaData: ChartBlockEngineMetaData = {
|
|
query: {
|
|
id: chartQueryMetadata.id,
|
|
},
|
|
chart: values,
|
|
};
|
|
insert({
|
|
type: 'void',
|
|
title: values?.title,
|
|
'x-designer': 'ChartBlockEngine.Designer',
|
|
'x-decorator': 'CardItem',
|
|
'x-component': 'ChartBlockEngine',
|
|
'x-component-props': {
|
|
chartBlockEngineMetaData,
|
|
},
|
|
});
|
|
}
|
|
}}
|
|
/>
|
|
);
|
|
};
|