Which UI do you use?
Pre built UI
Custom UI
How to use
- ReactJS
- Angular
- Vue
caution
Not applicable to non-react apps. You can disable the specific pre built UI component, and then build your own UI instead.
- You will have to use the
PasswordlessComponentsOverrideProvider
or theAuthRecipeComponentsOverrideContextProvider
component as shown below. make sure that it render the SuperTokens components inside this component. - Pick a component that you'd like to override by its key.
- Supply a React component against the key you have picked. Your custom component will get the original component as a
prop
.
Do you use react-router-dom?
YesNo
data:image/s3,"s3://crabby-images/9047d/9047d8f502c7e6eb2971e98bff577d48190590bc" alt="Prebuilt sign in UI with custom image"
important
Please make sure that the file in which this config is specified is a .tsx
or .jsx
file type.
#
Finding which component will be overriddenTo do that, you should use React Developer Tools extension which provides a component tree inspector.
#
Exampledata:image/s3,"s3://crabby-images/d6e2e/d6e2e6a85d23067c27a96b6420d3e7041ca3d60a" alt="Checking which component from the prebuilt UI will be overridden using React Developer Tools extension"
- Look for the names defined in component override config and/or components ending in
_Override
in the component tree. - Ensure that's the component you want to override
- Overide the component as stated above.
#
How do I render the original componentBecause the override function receives the original component as a parameter, you can render it. To do this, simply use it in JSX. Don't forget to supply original props by spreading them.
import React from "react";
import { SuperTokensWrapper } from "supertokens-auth-react";
import { AuthRecipeComponentsOverrideContextProvider } from "supertokens-auth-react/ui";
import octocat from "./octocat.png";
function App() {
return (
<SuperTokensWrapper>
<AuthRecipeComponentsOverrideContextProvider
components={{
AuthPageHeader_Override: ({ DefaultComponent, ...props }) => {
return (
<>
<h1>I'm a header that you added above original component</h1>
<DefaultComponent {...props} />
</>
)
}
}}>
{/* Rest of the JSX */}
</AuthRecipeComponentsOverrideContextProvider>
</SuperTokensWrapper>
);
}
export default App;
caution
Not applicable to non-react apps. You can disable the specific pre built UI component, and then build your own UI instead.