mirror of
https://github.com/nocobase/nocobase
synced 2024-11-18 13:36:53 +00:00
bf1a19426a
* fix: form * refactor: schema-initializer * fix: bug * refactor: schema initializer * refactor: rename * fix: delete SchemaInitializerProvider * refactor: props `insert` to hooks `useSchemaInitializerV2` * fix: bug * refactor: delete `SchemaInitializer.Button` * refactor: delete old SchemaInitializer * fix: bug * fix: workflow * fix: docs * fix: bug * fix: bug * feat: style * fix: remove v2 * fix: visible * fix: bug * fix: item hook * feat: item hook * fix: add search DataBlockInitializer * fix: build bug * fix: style bug * fix: style bug * fix: test bug * fix: test bug * fix: rerender bug * fix: remove menu select * fix: bug * chore: add aria-label for SchemaInitializerButton * refactor: rename name to camel case * fix: menu height bug * fix: build errors * fix: build errors * fix: bug * fix: bug * fix: performance * test: add test for header * fix: sidebar is not refresh (T-2422) * feat(e2e): support to add group page and link page * chore: make sure the page is configurable when using page.goto * test: add tests for menu initializer * fix: imporve code * chore: fix build error * chore: optimize locator of menu item * refactor: rename testid for select * test: make tests passing * fix: make tests passing * chore: upgrade vitest to v0.34.6 * chore: increase timeout of e2e * feat: core * fix: revert schema initializer demos * test: menu, page tabs, page grid, table column * fix: schema button interface * feat: refactor: page tab settings * feat: page settings * fix: dumirc * fix: export CSSVariableProvider * feat: lazy render * fix: form-item * fix: general schema desinger * feat: filter form item settings * refactor: form-v2 schema settings * refactor: form-v1 schema settings * refactor: action schema settings * fix: action bug * fix: form-item bug * fix: types error * docs: schema settings doc * docs: schema settings * feat: schema setting item add name * fix: visible lazy render bug * fix: revert form item filter * fix: test bug * fix: test JSON.parse bug * fix: test bug * fix: improve styling * fix: styling * fix: cleanup * fix: token.borderRadiusSM * fix: bug * test: add tests * fix: style bug * fix: add chart performance * feat: add SchemaDesignerContext * fix: bug * fix: test bug * style: create record action style improve * fix: make test passing * chore: mack tests passing * chore: make tests passing * test: fix tests * style: style revert * fix: bug * fix: data selector * fix: fix tests * fix: fix tests * fix: delete PluginManagerContext * refactor: improve router and add SchemaComponentProvider & CSSVariableProvider to MainComponent * fix: add dn and field builtin to SchemaSettingWrapper * feat: update docs * refactor: application providers * fix: test bug * fix: fix tests * chore: make test passing * feat: update docs * chore: rename collection name * feat: update docs * chore: skip weird test * fix: blockInitializers media to otherBlocks * fix: cancel to skip test * fix: bug * test: add test * refactor: migrate to small files * test: add tests for form block settings * chore: format * fix: add chart scroll bug * refactor: action designer improve * refactor: formitem designer schemaSetting * feat: schemaSettingsManager and schemaInitializerManager addItem and removeItem * test: add tests for color field in creating block * test: add tests for email field in creating block * test: make tests passing * perf: reduce fields number * fix: sub menu bug * test: add tests basic in editing form * test: add tests basic in details form * fix: improve code * test: make tests passing * test(plugin-mock-collections): add color for enum options * refactor: improve code * fix: bug * fix: bug * refactor: convert parameters to destructured object * test: add tests choices * test: add tests media * test: add tests for datetime in creating form * feat(plugin-mock-collection): generate faker time * test: add tests for datetime in editing form * test: add tests for datetime in details form * fix: bug * feat: improve code * test: add tests for relation fields * fix: rename SchemaSettings * fix: type bug * refactor: useDesinger() * fix: bug * fix: bug * fix: build tip * fix: designableState * fix: bug * fix: designable * fix: designable * test: add tests for relation fields * test: add tests for relation fields * test: add tests for relation fields * feat: client api doc * test: add tests for relation fields * test: avoid errors * test: make tests passing * fix: bug * test: make tests passing * test: add tests for advanced fields * test: increase e2e timeout-minutes to 60 * fix: bug * fix: improve code * feat: add schema initailizer component demos * test: make tests passing * fix: schema settings demos * feat: shallowMerge & deepMerge * test: reduce number of tests * test: make tests passing * feat: updates * fix: add Initializer Internal * demos: useSchemaSettingsRender * test: make tests passing * test: make tests passing * fix: improve docs * fix: bug * chore: upgrade dumi theme * test: make tests passing * test: add tests for linkage rules * test: add test for form data templates * test: add tests for default value * test: reduce number of tests * fix: dn.deepMerge * fix: bug * fix: bug * fix: toolbar * fix: docs ssr * test: add tests for system fields * test: add tests for actions * fix: bug * test: add tests for lazy loading of variables * test: make testing more stable * fix: update docs * fix: bug --------- Co-authored-by: Rain <958414905@qq.com> Co-authored-by: chenos <chenlinxh@gmail.com> Co-authored-by: katherinehhh <katherine_15995@163.com>
157 lines
4.3 KiB
TypeScript
157 lines
4.3 KiB
TypeScript
import { TableOutlined } from '@ant-design/icons';
|
|
import { FormLayout } from '@formily/antd-v5';
|
|
import { SchemaOptionsContext } from '@formily/react';
|
|
import {
|
|
FormDialog,
|
|
SchemaInitializerItem,
|
|
SchemaComponent,
|
|
SchemaComponentOptions,
|
|
useAPIClient,
|
|
useGlobalTheme,
|
|
useSchemaInitializer,
|
|
} from '@nocobase/client';
|
|
import { error } from '@nocobase/utils/client';
|
|
import React, { useCallback, useContext, useMemo } from 'react';
|
|
import { useChartQueryMetadataContext } from './ChartQueryMetadataProvider';
|
|
import { lang } from './locale';
|
|
import { getQueryTypeSchema } from './settings/queryTypes';
|
|
|
|
export interface ChartQueryMetadata {
|
|
id: number;
|
|
title: string;
|
|
type: string;
|
|
fields: { name: string }[];
|
|
}
|
|
|
|
export const ChartQueryBlockInitializer = (props) => {
|
|
const { templateWrap, onCreateBlockSchema, componentType, createBlockSchema, ...others } = props;
|
|
const { setVisible } = useSchemaInitializer();
|
|
const apiClient = useAPIClient();
|
|
const ctx = useChartQueryMetadataContext();
|
|
const options = useContext(SchemaOptionsContext);
|
|
const { theme } = useGlobalTheme();
|
|
|
|
const onAddQuery = useCallback(
|
|
(info) => {
|
|
FormDialog(
|
|
{
|
|
sql: lang('Add SQL query'),
|
|
json: lang('Add JSON query'),
|
|
}[info.key],
|
|
() => {
|
|
return (
|
|
<div>
|
|
<SchemaComponentOptions scope={options.scope} components={{ ...options.components }}>
|
|
<FormLayout layout={'vertical'}>
|
|
<SchemaComponent
|
|
schema={{
|
|
type: 'object',
|
|
properties: {
|
|
title: {
|
|
title: lang('Title'),
|
|
required: true,
|
|
'x-component': 'Input',
|
|
'x-decorator': 'FormItem',
|
|
},
|
|
options: getQueryTypeSchema(info.key),
|
|
},
|
|
}}
|
|
/>
|
|
</FormLayout>
|
|
</SchemaComponentOptions>
|
|
</div>
|
|
);
|
|
},
|
|
theme,
|
|
)
|
|
.open({
|
|
initialValues: {
|
|
type: info.key,
|
|
},
|
|
})
|
|
.then(async (values) => {
|
|
try {
|
|
if (apiClient.resource('chartsQueries')?.create) {
|
|
const { data } = await apiClient.resource('chartsQueries').create({ values });
|
|
const items = (await ctx.refresh()) as any;
|
|
const item = items.find((item) => item.id === data?.data?.id);
|
|
onCreateBlockSchema({ item });
|
|
}
|
|
setVisible(false);
|
|
} catch (err) {
|
|
error(err);
|
|
}
|
|
})
|
|
.catch((err) => {
|
|
error(err);
|
|
});
|
|
},
|
|
[apiClient, ctx, onCreateBlockSchema, options.components, options.scope, setVisible],
|
|
);
|
|
|
|
const items = useMemo(() => {
|
|
const defaultItems: any = [
|
|
{
|
|
type: 'itemGroup',
|
|
title: lang('Select query data'),
|
|
children: [],
|
|
},
|
|
];
|
|
const chartQueryMetadata = ctx.data;
|
|
if (chartQueryMetadata && Array.isArray(chartQueryMetadata)) {
|
|
const item1 =
|
|
chartQueryMetadata.length > 0
|
|
? {
|
|
type: 'itemGroup',
|
|
title: '{{t("Select chart query", {ns: "charts"})}}',
|
|
children: chartQueryMetadata,
|
|
}
|
|
: null;
|
|
const item2 =
|
|
chartQueryMetadata.length > 0
|
|
? {
|
|
type: 'divider',
|
|
}
|
|
: null;
|
|
|
|
return [
|
|
item1,
|
|
item2,
|
|
{
|
|
type: 'subMenu',
|
|
title: lang('Add chart query'),
|
|
// component: AddChartQuery,
|
|
children: [
|
|
{
|
|
key: 'sql',
|
|
type: 'item',
|
|
title: 'SQL',
|
|
onClick: onAddQuery,
|
|
},
|
|
{
|
|
key: 'json',
|
|
type: 'item',
|
|
title: 'JSON',
|
|
onClick: onAddQuery,
|
|
},
|
|
],
|
|
},
|
|
].filter(Boolean);
|
|
}
|
|
|
|
return defaultItems;
|
|
}, [ctx.data, onAddQuery]);
|
|
|
|
return (
|
|
<SchemaInitializerItem
|
|
icon={<TableOutlined />}
|
|
{...others}
|
|
onClick={async ({ item }) => {
|
|
onCreateBlockSchema({ item });
|
|
setVisible(false);
|
|
}}
|
|
items={items}
|
|
/>
|
|
);
|
|
};
|