You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
npm install --save gatsby-plugin-netlify-identity
## you may also need RNIW's peer dependencies
npm install --save react-netlify-identity-widget @reach/dialog @reach/tabs @reach/visually-hidden
How to use
// In your gatsby-config.jsmodule.exports={plugins: [// You can should only have one instance of this plugin{resolve: `gatsby-plugin-netlify-identity`,options: {url: `https://your-identity-instance-here.netlify.com/`// required!}}]}
Options
To use this, you must have a Netlify site instance with Netlify Identity enabled (Deploy this demo to get started with one click). Then take the URL of that Netlify site and pass it in as the url for this plugin's options.
Usage
Once installed, you are free to use react-netlify-identity-widget's handy useIdentityContext hook anywhere in your Gatsby app. If you also want the authentication modal, you can import it as well. A good place to put this is in a Layout component, but really you could also put it in a Navbar component, it really doesn't matter since you're inside the context anyway.
Some sample code for your convenience:
// src/components/Layout.jsimportReactfrom"react"importIdentityModal,{useIdentityContext}from"react-netlify-identity-widget"import"react-netlify-identity-widget/styles.css"// delete if you want to bring your own CSSconstLayout=({ children })=>{constidentity=useIdentityContext()// see https://github.com/sw-yx/react-netlify-identity for api of this identity objectconst[dialog,setDialog]=React.useState(false)constname=(identity&&identity.user&&identity.user.user_metadata&&identity.user.user_metadata.name)||"NoName"console.log(JSON.stringify(identity))constisLoggedIn=identity&&identity.isLoggedInreturn(<><navstyle={{background: "green"}}>{" "}
Login Status:
<buttonclassName="btn"onClick={()=>setDialog(true)}>{isLoggedIn ? `Hello ${name}, Log out here!` : "LOG IN"}</button></nav><main>{children}</main><IdentityModalshowDialog={dialog}onCloseDialog={()=>setDialog(false)}/></>)}exportdefaultLayout