saleor-dashboard/src/auth/index.tsx

48 lines
1.3 KiB
TypeScript
Raw Normal View History

2019-08-09 10:26:22 +00:00
import React from "react";
2019-09-02 19:23:37 +00:00
import { Route, Switch } from "react-router-dom";
2019-06-19 14:40:52 +00:00
2019-09-03 13:42:15 +00:00
import Layout from "./components/Layout";
2019-06-19 14:40:52 +00:00
import { User } from "./types/User";
2019-09-02 19:23:37 +00:00
import {
newPasswordPath,
passwordResetPath,
passwordResetSuccessPath
} from "./urls";
import LoginView from "./views/Login";
import NewPassword from "./views/NewPassword";
import ResetPassword from "./views/ResetPassword";
import ResetPasswordSuccess from "./views/ResetPasswordSuccess";
2019-06-19 14:40:52 +00:00
interface UserContext {
login: (username: string, password: string, persist: boolean) => void;
2019-09-03 13:42:15 +00:00
loginByToken: (token: string, user: User) => void;
2019-06-19 14:40:52 +00:00
logout: () => void;
2019-09-02 19:23:37 +00:00
tokenAuthLoading: boolean;
tokenVerifyLoading: boolean;
2019-06-19 14:40:52 +00:00
user?: User;
}
export const UserContext = React.createContext<UserContext>({
login: undefined,
2019-09-03 13:42:15 +00:00
loginByToken: undefined,
2019-09-02 19:23:37 +00:00
logout: undefined,
tokenAuthLoading: false,
tokenVerifyLoading: false
2019-06-19 14:40:52 +00:00
});
2019-09-02 19:23:37 +00:00
const AuthRouter: React.FC = () => (
2019-09-03 13:42:15 +00:00
<Layout>
<Switch>
<Route path={passwordResetSuccessPath} component={ResetPasswordSuccess} />
<Route path={passwordResetPath} component={ResetPassword} />
<Route path={newPasswordPath} component={NewPassword} />
<Route component={LoginView} />
</Switch>
</Layout>
2019-09-02 19:23:37 +00:00
);
AuthRouter.displayName = "AuthRouter";
export default AuthRouter;
2019-09-03 13:42:15 +00:00
export * from "./utils";