Documentation
Overlay Components
Consent Manager

Consent Manager

JavaScript library designed to simplify the management of user consents in web applications developed with React. This package is particularly useful for complying with data protection regulations such as the General Data Protection Regulation (GDPR) in the European Union and the California Consumer Privacy Act (CCPA) in the United States. It provides developers with a flexible and easy-to-integrate solution to handle user consents for cookies, tracking scripts, and other third-party services that require user approval before activation.

With this package, developers can create customizable consent banners or dialogs that inform users about the use of cookies and trackers, allowing users to accept, reject, or select specific preferences. The library ensures that consents are properly stored and retrieved, making sure that only approved services are executed. This not only helps in enhancing user trust by respecting their privacy choices but also aids in legal compliance by documenting consents accurately.

The package offers features such as consent grouping for different categories of services (e.g., analytics, marketing), This makes this package a comprehensive solution for consent management in modern web applications built with React.

CSS variables for theming are available for all components. Classnames are available for all components. Built-in dark mode support.

Features

  • CSS variables for theming all available components.
  • Classnames for all available components.
  • Built-in dark mode support.

Installation

bash copy npm install --save @start-base/react-consent-manager

Make sure to add css file to your app root file

import '@start-base/react-consent-manager/dist/lib/index.css';

Components

<ConsentBanner />

We ask for your permission for a better experience.

This Website uses cookies to ensure our website works, to understand how you use our services, and to personalise content.

<ConsentBanner /> Props

PropTypeDefaultDescription
childrenReact.ReactNodenullContent to display inside the banner
decline{ hidden: boolean, label: string }{ hidden: false, label: 'Decline' }Object to configure the decline button
approve{ hidden: boolean, label: string }{ hidden: false, label: 'Accept' }Object to configure the approve button
settings{ hidden: boolean, label: string, modal: ModalConfig }{}Object to configure the settings of the consent banner

ModalConfig

Configuration object for the consent banner modal.

interface ModalConfig {
  title: string;
  description?: string;
  decline?: {
    hidden?: boolean;
    label?: string;
  };
  approve?: {
    hidden?: boolean;
    label?: string;
  };
  approveAll?: {
    hidden?: boolean;
    label?: string;
  };
}