mirror of
https://github.com/logto-io/logto.git
synced 2024-12-30 20:33:54 -05:00
refactor(console): redirect to current tenant when needed
This commit is contained in:
parent
51fb943986
commit
c1fa47f280
3 changed files with 21 additions and 3 deletions
|
@ -9,6 +9,7 @@ import { withTranslation } from 'react-i18next';
|
|||
|
||||
import AppError from '@/components/AppError';
|
||||
import SessionExpired from '@/components/SessionExpired';
|
||||
import { isInCallback } from '@/utils/url';
|
||||
|
||||
type Props = {
|
||||
children: ReactNode;
|
||||
|
@ -59,8 +60,7 @@ class ErrorBoundary extends Component<Props, State> {
|
|||
if (error) {
|
||||
// Different strategies for handling errors in callback pages since the callback errors
|
||||
// are likely unexpected and unrecoverable.
|
||||
const { pathname } = window.location;
|
||||
if (['/callback', '-callback'].some((path) => pathname.endsWith(path))) {
|
||||
if (isInCallback()) {
|
||||
if (error instanceof LogtoError && error.data instanceof OidcError) {
|
||||
return (
|
||||
<AppError
|
||||
|
|
|
@ -2,11 +2,21 @@ import { useHandleSignInCallback } from '@logto/react';
|
|||
import { useNavigate } from 'react-router-dom';
|
||||
|
||||
import AppLoading from '@/components/AppLoading';
|
||||
import { getUserTenantId } from '@/consts';
|
||||
import { isInFirstLevelCallback } from '@/utils/url';
|
||||
|
||||
function Callback() {
|
||||
const navigate = useNavigate();
|
||||
|
||||
useHandleSignInCallback(() => {
|
||||
navigate('/', { replace: true });
|
||||
/**
|
||||
* The first level callback check is due to the usage of `basename`
|
||||
* for tenant-specific routes, e.g., `/:tenantId/applications`.
|
||||
* Once we merge all the routes into one router, we can remove this check.
|
||||
*/
|
||||
navigate(isInFirstLevelCallback() ? `/${getUserTenantId()}` : '/', {
|
||||
replace: true,
|
||||
});
|
||||
});
|
||||
|
||||
return <AppLoading />;
|
||||
|
|
|
@ -2,3 +2,11 @@ export const buildUrl = (path: string, searchParameters: Record<string, string>)
|
|||
`${path}?${new URLSearchParams(searchParameters).toString()}`;
|
||||
|
||||
export const formatSearchKeyword = (keyword: string) => `%${keyword}%`;
|
||||
|
||||
/** If the current pathname is `/callback` or ends with `-callback`, we consider it as a callback page. */
|
||||
export const isInCallback = () =>
|
||||
['/callback', '-callback'].some((path) => window.location.pathname.endsWith(path));
|
||||
|
||||
/** If the current pathname is a callback page and the pathname only has one level. */
|
||||
export const isInFirstLevelCallback = () =>
|
||||
window.location.pathname.split('/').length === 1 && isInCallback();
|
||||
|
|
Loading…
Reference in a new issue