You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 

85 lines
3.1 KiB

  1. import * as React from "react";
  2. import * as HttpUtils from "utils/HttpUtils";
  3. import * as UrlUtils from "utils/ApiPathConst";
  4. import { useNavigate } from "react-router-dom";
  5. import { useDispatch } from "react-redux";
  6. import { handleLogoutFunction, handleLogin } from 'auth/index';
  7. import Loadable from 'components/Loadable';
  8. const LoadingComponent = Loadable(React.lazy(() => import('pages/extra-pages/LoadingComponent')));
  9. import {
  10. Grid,
  11. } from '@mui/material';
  12. // ==============================|| DASHBOARD - DEFAULT ||============================== //
  13. const Index = () => {
  14. const dispatch = useDispatch()
  15. const navigate = useNavigate()
  16. React.useEffect(() => {
  17. goLogin();
  18. }, []);
  19. function goLogin(){
  20. dispatch(handleLogoutFunction());
  21. let params = new URLSearchParams(window.location.search)
  22. if(params.get("code")){
  23. HttpUtils.post({
  24. url: UrlUtils.GET_SMART_DIRECT_LOGIN,
  25. params:{
  26. code: params.get("code")
  27. },
  28. onSuccess: (responseData) => {
  29. // console.log("responseData");
  30. // console.log(responseData);
  31. const userData = {
  32. id: responseData.id,
  33. fullenName: responseData.name,
  34. fullchName: responseData.chName,
  35. email: responseData.email,
  36. type: responseData.type,
  37. role: responseData.role,
  38. abilities: responseData.abilities,
  39. creditor: responseData.creditor,
  40. passwordExpiryDate: responseData.passwordExpiryDate,
  41. orgPaymentRecord: responseData.orgPaymentRecord,
  42. //avatar: require('src/assets/images/users/avatar-3.png').default,
  43. }
  44. const data = { ...userData, accessToken: responseData.accessToken, refreshToken: responseData.refreshToken }
  45. dispatch(handleLogin(data))
  46. navigate('/dashboard');
  47. },
  48. onFail: (response)=>{
  49. console.log("Fail");
  50. console.log(response);
  51. window.location.assign("/iamsmart/loginFail");
  52. },
  53. onError:(error)=>{
  54. console.log("onError");
  55. console.log(error);
  56. if(error?.response?.data?.exception == "msg: please verify email."){
  57. window.location.assign("/iamsmart/notverify");
  58. }else{
  59. window.location.assign("/iamsmart/loginFail");
  60. }
  61. }
  62. });
  63. }else{
  64. window.location.assign("/iamsmart/loginFail");
  65. }
  66. }
  67. return (
  68. <Grid container sx={{ minHeight: '87vh', mb: 3 }} direction="column" justifyContent="center" alignItems="center">
  69. <Grid item>
  70. <LoadingComponent />
  71. </Grid>
  72. </Grid>
  73. );
  74. };
  75. export default Index;