mirror of
https://github.com/nocobase/nocobase
synced 2024-11-17 01:50:36 +00:00
d76e8fb87f
* refactor: update umi version 3.x to version 4.x
* refactor: update react-router-dom version to 6.x
* refactor(react-router-dom): change Layout Component `props.children` to `<Outlet />`
* refactor(react-router-dom): change <Route /> props and <RouteSwitch /> correct
* refactor(react-router-dom): replace `<Redirect />` to `<Navigate replace />`
* refactor(react-router-dom): replace `useHistory` to `useNavigate`
* refactor(react-router-dom): replace `useRouteMatch` to `useParams`
* refactor(react-router-dom & dumi): fix <RouteSwitch /> & umi document bug
* refactor(react-router-dom): `useRoutes` Optimize `<RouteSwitch />` code
* refactor(react-router-dom): update `Route` types and docs
* refactor(react-router-dom): optimize RouteSwitch code
* refactor(react-router-dom): `useLocation` no generics type
* refactor(react-router-dom): add `less v3.9.0` to `resolutions` to solve the error of `gulp-less`
* refactor(react-router-dom): fix `<RouteSwitch />` `props.routes` as an array is not handled
* chore: upgrade `dumi` and refactor docs
* fix: completed code review, add `targets` to solve browser compatibility & removed `chainWebpack`
* refactor(dumi): upgraded dumi under `packages/core/client`
* refactor(dumi): delete `packages/core/dumi-theme-nocobase`
* refactor(dumi): degrade `react` & replace `dumi-theme-antd` to `dumi-theme-nocobase`
* refactor(dumi): solve conflicts between multiple dumi applications
* fix: login page error in react 17
* refactor(dumi): remove less resolutions
* refactor(dumi): umi add `msfu: true` config
* fix: merge bug
* fix: self code review
* fix: code reivew and test bug
* refactor: upgrade react to 18
* refactor: degrade react types to 17
* chore: fix ci error
* fix: support routerBase & fix workflow page params
* fix(doc): menu externel link
* fix: build error
* fix: delete
* fix: vitest error
* fix: react-router new code replace
* fix: vitest markdown error
* fix: title is none when refresh
* fix: merge error
* fix: sidebar width is wrong
* fix: useProps error
* fix: side-menu-width
* fix: menu selectId is wrong & useProps is string
* fix: menu selected first default & side menu hide when change
* fix: test error & v0.10 change log
* fix: new compnent doc modify
* fix: set umi `fastRefresh=false`
* refactor: application v2
* fix: improve code
* fix: bug
* fix: page = 0 error
* fix: workflow navigate error
* feat: plugin manager
* fix: afterAdd
* feat: update docs
* feat: update docs
* fix: page tab change not work
* fix: login redirect query param doesn't work
* fix: bug and doc
* feat: update docs
* fix: ci error
* fix: merge main
* feat: update docs
* feat: update docs
* feat: update docs
* chore(versions): 😊 publish v0.10.0-alpha.1
* fix: translations
* chore: backend node test max old space size
* docs: add useSearchParams
---------
Co-authored-by: chenos <chenlinxh@gmail.com>
Co-authored-by: ChengLei Shao <chareice@live.com>
105 lines
2.8 KiB
TypeScript
105 lines
2.8 KiB
TypeScript
import { registerValidateRules } from '@formily/core';
|
|
import {
|
|
SchemaComponentOptions,
|
|
SchemaInitializerContext,
|
|
SettingsCenterProvider,
|
|
useAPIClient,
|
|
} from '@nocobase/client';
|
|
import JSON5 from 'json5';
|
|
import React, { useContext } from 'react';
|
|
import { ChartBlockEngine } from './ChartBlockEngine';
|
|
import { ChartBlockInitializer } from './ChartBlockInitializer';
|
|
import { ChartQueryMetadataProvider } from './ChartQueryMetadataProvider';
|
|
import './Icons';
|
|
import { lang } from './locale';
|
|
import { CustomSelect } from './select';
|
|
import { QueriesTable } from './settings/QueriesTable';
|
|
|
|
registerValidateRules({
|
|
json5: (value, rule) => {
|
|
if (!value) {
|
|
return '';
|
|
}
|
|
try {
|
|
const val = JSON5.parse(value);
|
|
if (!isNaN(val)) {
|
|
return {
|
|
type: 'error',
|
|
message: lang('Invalid JSON format'),
|
|
};
|
|
}
|
|
return '';
|
|
} catch (error) {
|
|
console.error(error);
|
|
return {
|
|
type: 'error',
|
|
message: lang('Invalid JSON format'),
|
|
};
|
|
}
|
|
},
|
|
});
|
|
|
|
const Charts = React.memo((props) => {
|
|
const api = useAPIClient();
|
|
const items = useContext<any>(SchemaInitializerContext);
|
|
const children = items.BlockInitializers.items[0].children;
|
|
if (children) {
|
|
const hasChartItem = children.some((child) => child?.component === 'ChartBlockInitializer');
|
|
if (!hasChartItem) {
|
|
children.push({
|
|
key: 'chart',
|
|
type: 'item',
|
|
icon: 'PieChartOutlined',
|
|
title: '{{t("Chart",{ns:"charts"})}}',
|
|
component: 'ChartBlockInitializer',
|
|
});
|
|
}
|
|
}
|
|
const validateSQL = (sql) => {
|
|
return new Promise((resolve) => {
|
|
api
|
|
.request({
|
|
url: 'chartsQueries:validate',
|
|
method: 'post',
|
|
data: {
|
|
sql,
|
|
},
|
|
})
|
|
.then(({ data }) => {
|
|
resolve(data?.data?.errorMessage);
|
|
})
|
|
.catch(() => {
|
|
resolve('Invalid SQL');
|
|
});
|
|
});
|
|
};
|
|
return (
|
|
<ChartQueryMetadataProvider>
|
|
<SettingsCenterProvider
|
|
settings={{
|
|
charts: {
|
|
title: '{{t("Charts", {ns:"charts"})}}',
|
|
icon: 'PieChartOutlined',
|
|
tabs: {
|
|
queries: {
|
|
title: '{{t("Queries", {ns:"charts"})}}',
|
|
component: QueriesTable,
|
|
},
|
|
},
|
|
},
|
|
}}
|
|
>
|
|
<SchemaComponentOptions
|
|
scope={{ validateSQL }}
|
|
components={{ CustomSelect, ChartBlockInitializer, ChartBlockEngine }}
|
|
>
|
|
<SchemaInitializerContext.Provider value={items}>{props.children}</SchemaInitializerContext.Provider>
|
|
</SchemaComponentOptions>
|
|
</SettingsCenterProvider>
|
|
</ChartQueryMetadataProvider>
|
|
);
|
|
});
|
|
Charts.displayName = 'Charts';
|
|
|
|
export default Charts;
|