Building cookie banners should be easy. We've written @enzsft/react-cookie-consents to ensure you can get up and running as quickly as possible. It provides a convenient API to write and read cookie consents.
@enzsft/react-cookie-consents uses React Hooks so requires at least [email protected]
The React ecosystem was lacking a hooks based cookie consents API when this library was first required.
yarn add @enzsft/react-cookie-consents
# or
npm install @enzsft/react-cookie-consents
The following example renders a cookie banner but only if consent has not already been given.
import { React } from "react";
import ReactDOM from "react-dom";
import {
CookieConsentsProvider,
useCookieConsents,
} from "@enzsft/react-cookie-consents";
const CookieBanner = () => {
const cookieConsents = useCookieConsents();
if (cookieConsents.get().length > 0) {
return null;
}
return (
<>
<span>
We use cookies to help give you the best experience on our site. By
continuing you agree to our use of cookies.
</span>
<button type="button" onClick={() => cookieConsents.add("analytics")}>
Accept and close
</button>
</>
);
};
const App = () => {
return (
<CookieConsentsProvider cookieName="cookieConsents" expiryInDays={365}>
<CookieBanner />
</CookieConsentsProvider>
);
};
ReactDOM.render(<App />, document.getElementById("root"));
Configure the cookie name and when it will expire.
<CookieConsentsProvider cookieName="cookieConsents" expiryInDays={365}>
{children}
</CookieConsentsProvider>
React Hook that returns a cookie consent object to read/write cookie consents. Components that use this must be nested within a CookieConsentsProvider
as it uses React Context.
Cookie consents are stores in a cookie. When you add, remove or clear consents the cookie is updated.
const Comp = () => {
const cookieConsents = useCookieConsents();
// Get all cookie consents
const allConsents = cookieConsents.get();
// Add a new consent, silently ignores duplicates
cookieConsents.add("consent name");
// Remove a consent
cookieConsents.remove("consent name");
// Remove all consents
cookieConsents.clear();
};
TypeScript type definitions are bundled in with the module. No need to install an additional module for type definitions.