2024-01-29 19:28:39 +08:00
|
|
|
import authorizationUtil from '@/utils/authorizationUtil';
|
2024-03-07 14:39:34 +08:00
|
|
|
import { message } from 'antd';
|
|
|
|
import { useEffect, useMemo, useState } from 'react';
|
2024-03-07 14:23:42 +08:00
|
|
|
import { useNavigate, useSearchParams } from 'umi';
|
2024-01-29 19:28:39 +08:00
|
|
|
|
2024-03-07 14:23:42 +08:00
|
|
|
export const useLoginWithGithub = () => {
|
|
|
|
const [currentQueryParameters, setSearchParams] = useSearchParams();
|
|
|
|
const error = currentQueryParameters.get('error');
|
|
|
|
const newQueryParameters: URLSearchParams = useMemo(
|
|
|
|
() => new URLSearchParams(currentQueryParameters.toString()),
|
|
|
|
[currentQueryParameters],
|
|
|
|
);
|
|
|
|
const navigate = useNavigate();
|
|
|
|
|
|
|
|
if (error) {
|
2024-03-07 14:39:34 +08:00
|
|
|
message.error(error);
|
2024-03-07 14:23:42 +08:00
|
|
|
navigate('/login');
|
|
|
|
newQueryParameters.delete('error');
|
|
|
|
setSearchParams(newQueryParameters);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
const auth = currentQueryParameters.get('auth');
|
|
|
|
|
|
|
|
if (auth) {
|
|
|
|
authorizationUtil.setAuthorization(auth);
|
|
|
|
newQueryParameters.delete('auth');
|
|
|
|
setSearchParams(newQueryParameters);
|
|
|
|
}
|
2024-03-07 14:39:34 +08:00
|
|
|
return auth;
|
|
|
|
};
|
|
|
|
|
|
|
|
export const useAuth = () => {
|
|
|
|
const auth = useLoginWithGithub();
|
2024-03-07 15:32:12 +08:00
|
|
|
const [isLogin, setIsLogin] = useState<Nullable<boolean>>(null);
|
2024-03-07 14:39:34 +08:00
|
|
|
|
|
|
|
useEffect(() => {
|
2024-03-07 15:32:12 +08:00
|
|
|
setIsLogin(!!authorizationUtil.getAuthorization() || !!auth);
|
2024-03-07 14:39:34 +08:00
|
|
|
}, [auth]);
|
|
|
|
|
|
|
|
return { isLogin };
|
2024-03-07 14:23:42 +08:00
|
|
|
};
|