Router Wrapper around the Authenticator from aws-amplify-react
Having to rely on local authState
is a pain the butt when you want to use a router as well as overriding the default components. This component makes that even easier now.
yarn add amplify-react-router aws-amplify-react aws-amplify react-router-dom
import React from 'react';
import AmplifyRouter from 'amplify-react-router';
import { Router, navigate } from '@reach/router';
import MySignIn from './SignIn';
import Page from './Page';
import awsExports from './aws-exports';
export default () => (
<AmplifyRouter
amplifyConfig={awsExports}
homeRoute="/home"
navigate={navigate}
componentOverrides={[MySignIn]}
>
<Router>
<Page path="/home" />
</Router>
</AmplifyRouter>
);
You no longer have to pass in the hide
property for components you want to override. Only pass in the components to the hide
prop that you want to actually hide.
All overriden components should be placed in the componentOverrides
and will auto hide their super class
s component.
All the base Authenticator Props plus the below.
Prop Name | Types | Default | Description |
---|---|---|---|
componentOverrides |
Array(Component) | Optional | The auth components you want to override |
homeRoute |
String | / | The home route to navigate to when once signed in |
navigate |
(route: string) => void | Function that takes new route to optionally push to history api for router. |