mirror of
https://gitee.com/nocobase/nocobase.git
synced 2025-05-05 21:49:25 +08:00
* 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>
132 lines
4.0 KiB
TypeScript
132 lines
4.0 KiB
TypeScript
import { useField, useFieldSchema } from '@formily/react';
|
|
import {
|
|
GeneralSchemaDesigner,
|
|
SchemaSettingsBlockTitleItem,
|
|
SchemaSettingsDivider,
|
|
SchemaSettingsItem,
|
|
SchemaSettingsRemove,
|
|
gridRowColWrap,
|
|
useAPIClient,
|
|
useCollection,
|
|
useDesignable,
|
|
} from '@nocobase/client';
|
|
import { Empty, Result, Spin, Typography } from 'antd';
|
|
import React, { useContext } from 'react';
|
|
import { ErrorBoundary } from 'react-error-boundary';
|
|
import { useChart } from '../chart/group';
|
|
import { ChartConfigContext } from '../configure/ChartConfigure';
|
|
import { useData, useFieldTransformer, useFieldsWithAssociation } from '../hooks';
|
|
import { useChartsTranslation } from '../locale';
|
|
import { createRendererSchema, getField } from '../utils';
|
|
import { ChartRendererContext } from './ChartRendererProvider';
|
|
const { Paragraph, Text } = Typography;
|
|
|
|
export const ChartRenderer: React.FC & {
|
|
Designer: React.FC;
|
|
} = (props) => {
|
|
const { t } = useChartsTranslation();
|
|
const ctx = useContext(ChartRendererContext);
|
|
const { config, transform, collection, service, data: _data } = ctx;
|
|
const fields = useFieldsWithAssociation(collection);
|
|
const data = useData(_data, 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 };
|
|
}
|
|
return props;
|
|
}, {}),
|
|
});
|
|
|
|
const C = () =>
|
|
chart ? (
|
|
<ErrorBoundary
|
|
onError={(error) => {
|
|
console.error(error);
|
|
}}
|
|
FallbackComponent={ErrorFallback}
|
|
>
|
|
<Component />
|
|
</ErrorBoundary>
|
|
) : (
|
|
<Empty image={Empty.PRESENTED_IMAGE_SIMPLE} description={t('Please configure chart')} />
|
|
);
|
|
|
|
if (service.loading) {
|
|
return <Spin />;
|
|
}
|
|
|
|
if (!(data && data.length)) {
|
|
return <Empty image={Empty.PRESENTED_IMAGE_SIMPLE} description={t('Please configure and run query')} />;
|
|
}
|
|
|
|
return <C />;
|
|
};
|
|
|
|
ChartRenderer.Designer = function Designer() {
|
|
const { t } = useChartsTranslation();
|
|
const { setVisible, setCurrent } = useContext(ChartConfigContext);
|
|
const { service } = useContext(ChartRendererContext);
|
|
const field = useField();
|
|
const schema = useFieldSchema();
|
|
const { insertAdjacent } = useDesignable();
|
|
const { name, title } = useCollection();
|
|
return (
|
|
<GeneralSchemaDesigner disableInitializer title={title || name}>
|
|
<SchemaSettingsItem
|
|
title="Configure"
|
|
key="configure"
|
|
onClick={() => {
|
|
setCurrent({ schema, field, collection: name, service, data: service?.data });
|
|
setVisible(true);
|
|
}}
|
|
>
|
|
{t('Configure')}
|
|
</SchemaSettingsItem>
|
|
<SchemaSettingsItem
|
|
title="Duplicate"
|
|
key="duplicate"
|
|
onClick={() => insertAdjacent('afterEnd', gridRowColWrap(createRendererSchema(schema?.['x-decorator-props'])))}
|
|
>
|
|
{t('Duplicate')}
|
|
</SchemaSettingsItem>
|
|
<SchemaSettingsBlockTitleItem />
|
|
<SchemaSettingsDivider />
|
|
<SchemaSettingsRemove
|
|
// removeParentsIfNoChildren
|
|
breakRemoveOn={{
|
|
'x-component': 'ChartV2Block',
|
|
}}
|
|
/>
|
|
</GeneralSchemaDesigner>
|
|
);
|
|
};
|
|
|
|
const ErrorFallback = ({ error }) => {
|
|
const { t } = useChartsTranslation();
|
|
|
|
return (
|
|
<div style={{ backgroundColor: 'white' }}>
|
|
<Result status="error" title={t('Render Failed')} subTitle={t('Please check the configuration.')}>
|
|
<Paragraph copyable>
|
|
<Text type="danger" style={{ whiteSpace: 'pre-line', textAlign: 'center' }}>
|
|
{error.message}
|
|
</Text>
|
|
</Paragraph>
|
|
</Result>
|
|
</div>
|
|
);
|
|
};
|