mirror of
https://gitee.com/nocobase/nocobase.git
synced 2025-05-08 23:19:26 +08:00
* 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>
79 lines
2.8 KiB
TypeScript
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>
|
|
);
|
|
};
|