mirror of
https://gitee.com/nocobase/nocobase.git
synced 2025-05-05 21:49:25 +08:00
* fix: context add displayName * fix: observer add displayName * fix: memo component add displayName * fix: forwordRef component add displayName
54 lines
1.7 KiB
TypeScript
54 lines
1.7 KiB
TypeScript
import React, { createContext, useContext, useMemo } from 'react';
|
|
import { Navigate, useLocation } from 'react-router-dom';
|
|
import { useACLRoleContext } from '../acl';
|
|
import { ReturnTypeOfUseRequest, useRequest } from '../api-client';
|
|
import { useAppSpin } from '../application/hooks/useAppSpin';
|
|
import { useCompile } from '../schema-component';
|
|
|
|
export const CurrentUserContext = createContext<ReturnTypeOfUseRequest>(null);
|
|
CurrentUserContext.displayName = 'CurrentUserContext';
|
|
|
|
export const useCurrentUserContext = () => {
|
|
return useContext(CurrentUserContext);
|
|
};
|
|
|
|
export const useCurrentRoles = () => {
|
|
const { allowAnonymous } = useACLRoleContext();
|
|
const { data } = useCurrentUserContext();
|
|
const compile = useCompile();
|
|
const options = useMemo(() => {
|
|
const roles = (data?.data?.roles || []).map(({ name, title }) => ({ name, title: compile(title) }));
|
|
if (allowAnonymous) {
|
|
roles.push({
|
|
title: 'Anonymous',
|
|
name: 'anonymous',
|
|
});
|
|
}
|
|
return roles;
|
|
}, [allowAnonymous, data?.data?.roles]);
|
|
return options;
|
|
};
|
|
|
|
export const CurrentUserProvider = (props) => {
|
|
const { render } = useAppSpin();
|
|
const result = useRequest<any>({
|
|
url: 'auth:check',
|
|
});
|
|
|
|
if (result.loading) {
|
|
return render();
|
|
}
|
|
|
|
return <CurrentUserContext.Provider value={result}>{props.children}</CurrentUserContext.Provider>;
|
|
};
|
|
|
|
export const NavigateIfNotSignIn = ({ children }) => {
|
|
const result = useCurrentUserContext();
|
|
const { pathname, search } = useLocation();
|
|
const redirect = `?redirect=${pathname}${search}`;
|
|
if (!result?.data?.data?.id) {
|
|
return <Navigate replace to={`/signin${redirect}`} />;
|
|
}
|
|
return <>{children}</>;
|
|
};
|