nocobase/packages/core/client/src/schema-initializer/SchemaInitializerProvider.tsx
jack zhang d76e8fb87f
refactor: upgrade umi, react and react-router-dom (#1921)
* 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>
2023-06-20 11:48:02 +08:00

79 lines
2.8 KiB
TypeScript

import { useFieldSchema } from '@formily/react';
import { isPlainObj } from '@formily/shared';
import get from 'lodash/get';
import React, { ReactNode, createContext, useContext, useEffect, useMemo, useRef } from 'react';
import { SchemaComponentOptions } from '../schema-component';
import { SchemaInitializer } from './SchemaInitializer';
import * as globals from './buttons';
import * as initializerComponents from './components';
import * as items from './items';
export const SchemaInitializerContext = createContext({});
export interface SchemaInitializerProviderProps {
components?: any;
initializers?: Record<string, any>;
}
export const useSchemaInitializer = (name: string, props = {}) => {
const fieldSchema = useFieldSchema();
const initializers = useContext(SchemaInitializerContext);
const render = (component?: any, props?: any): any => {
return component && React.createElement(component, props);
};
const initializerPropsRef = useRef({});
const initializer = name ? get(initializers, name || fieldSchema?.['x-initializer']) : null;
const initializerProps = { ...props, ...fieldSchema?.['x-initializer-props'] };
initializerPropsRef.current = initializerProps;
const InitializerComponent = useMemo(() => {
let C = React.Fragment;
if (!initializer) {
return C;
} else if (isPlainObj(initializer)) {
C = (initializer as any).component || SchemaInitializer.Button;
return (p) => <C {...initializer} {...initializerPropsRef.current} {...p} />;
} else {
C = initializer;
return (p) => <C {...initializerPropsRef.current} {...p} />;
}
}, [initializer]);
if (!initializer) {
return { exists: false, InitializerComponent, render: (props?: any) => render(null) };
}
if (isPlainObj(initializer)) {
return {
exists: true,
InitializerComponent,
render: (props?: any) => {
const component = (initializer as any).component || SchemaInitializer.Button;
return render(component, { ...initializer, ...initializerProps, ...props });
},
};
}
return {
exists: true,
InitializerComponent,
render: (props?: any) => render(initializer, { ...initializerProps, ...props }),
};
};
export const SchemaInitializerPluginContext = createContext(null);
export const SchemaInitializerProvider: React.FC<SchemaInitializerProviderProps> = (props) => {
const { initializers, components, children } = props;
const parentInitializers = useContext(SchemaInitializerContext);
return (
<SchemaInitializerContext.Provider value={{ ...globals, ...parentInitializers, ...initializers }}>
<SchemaComponentOptions components={{ ...items, ...components, ...initializerComponents }}>
{children}
</SchemaComponentOptions>
</SchemaInitializerContext.Provider>
);
};