To ensure cookie consent settings are consistent across all subdomains, we extended our CookieConsentProvider to set and remove cookies with the domain attribute. This also ensures that Google Analytics (gtag) settings are updated accordingly.
First up, let's set the cookie with the domain attribute:
const COOKIE_DOMAIN = '.bulletninja.com'; // Ensure this is the correct domain const setConsentCookie = (value: string) => { document.cookie = `${COOKIE_NAME}=${value}; domain=${COOKIE_DOMAIN}; path=/;`; };
Next, here's how you can remove the cookie from the specified domain:
const removeConsentCookie = () => { document.cookie = `${COOKIE_NAME}=; domain=${COOKIE_DOMAIN}; path=/; expires=${new Date(0).toUTCString()};`; };
To retrieve the cookie, use this function:
const getConsentCookie = () => { const match = document.cookie.match(new RegExp('(^| )' + COOKIE_NAME + '=([^;]+)')); return match ? JSON.parse(match[2]) : null; };
When denying all cookie consents, update the state and remove the cookie like this:
const denyAllCookieConsent = useCallback(() => { const deniedConsent = { ad_storage: 'denied', ad_user_data: 'denied', ad_personalization: 'denied', analytics_storage: 'denied', }; updateConsent(deniedConsent); if (typeof window !== 'undefined' && window.gtag) { window.gtag('consent', 'update', deniedConsent); } removeConsentCookie(); }, [updateConsent]);
CookieConsentProviderIn your CookieConsentProvider, manage the cookie consent effortlessly with these functions:
useEffect(() => { const consent = getConsentCookie(); if (consent) updateConsent(consent); setIsClient(true); }, [updateConsent]); const setCookieConsent = useCallback((updates: Partial<CookieConsent>) => { const newConsent = { ...cookieConsent, ...updates }; updateConsent(newConsent); if (typeof window !== 'undefined' && window.gtag) window.gtag('consent', 'update', newConsent); setConsentCookie(JSON.stringify(newConsent)); }, [cookieConsent, updateConsent]);
Wrap your application with the CookieConsentContext.Provider like this:
return ( <CookieConsentContext.Provider value={value}> {children} </CookieConsentContext.Provider> );
The CookieConsentBanner component displays a banner to manage user consent. Here's how it looks:
const { cookieConsent, setCookieConsent, denyAllCookieConsent } = useCookieConsent(); const allDenied = Object.values(cookieConsent).every(value => value === 'denied'); if (!allDenied) return null; // Skip rendering if consents are not all denied return ( <> <div style={{ ...overlayStyles }}></div> <div style={{ ...bannerStyles }}> <p>We use cookies to improve your experience and analyze our traffic. By using our site, you consent to our use of cookies. You can manage your preferences below:</p> <div style={{ ...buttonContainerStyles }}> <button style={{ ...acceptButtonStyles }} onClick={() => setCookieConsent({ ...grantedConsent })}>Accept All</button> <button style={{ ...declineButtonStyles }} onClick={denyAllCookieConsent}>Decline All</button> </div> </div> </> );
Now, integrate CookieConsentProvider and CookieConsentBanner in your layout:
<CookieConsentProvider> <CookieConsentBanner /> </CookieConsentProvider>
Ensure you have the context and its type defined:
type CookieConsentContextType = { cookieConsent: CookieConsent; setCookieConsent: (updates: Partial<CookieConsent>) => void; denyAllCookieConsent: () => void; }; const CookieConsentContext = createContext<CookieConsentContextType | undefined>(undefined);
By ensuring that cookies are set and removed with the domain attribute, your cookie consent preferences will be consistent across all subdomains, resulting in a smoother, more unified user experience. Happy coding!
Learn how to enhance your code snippets with a COPY button in your syntax highlighter. This guide provides a step-by-step solution to implement a user-friendly copy feature, improving code sharing and readability.
Discover the magic behind automated article generation using OpenAI's GPT-4o and how it’s revolutionizing content creation.
Learn how to implement a pre-commit hook in TypeScript that validates and grades content quality using AI, specifically GPT-4o, applies changes, and manages state with markdown metadata.
We use cookies to improve your experience and analyze our traffic. By using our site, you consent to our use of cookies. You can manage your preferences below: