Skip to content

Getting Started

This section will help you install CookieConsent in your app/website.

Installation

You can download/import the plugin using one of the following methods:

  1. Install via NPM.

    npm i vanilla-cookieconsent
    yarn add vanilla-cookieconsent
    

    Special thanks to Till Sanders for bringing the plugin on npm!

  2. Use the CDN hosted version.

    https://cdn.jsdelivr.net/gh/orestbida/cookieconsent@v3.0.0-rc.2/dist/cookieconsent.umd.js
    https://cdn.jsdelivr.net/gh/orestbida/cookieconsent@v3.0.0-rc.2/dist/cookieconsent.css
    
  3. Download the latest release from github and use the optimized files located in the dist folder.

Usage

Here are some of the most common setups to help you get up and running.


HTML

Import cookieconsent.css and cookieconsent.js files respectively in the head and body section. Create a new file — cookieconsent-init.js — and import it in the body section.









 



 
 



<html>
    <head>
        <!-- head content -->

        <!-- Typical CSS loading -->
        <!-- <link rel="stylesheet" href="path-to-cookieconsent.css"> -->

        <!-- Deferred CSS loading (recommended) -->
        <link rel="stylesheet" href="path-to-cookieconsent.css" media="print" onload="this.media='all'">
    </head>
    <body>
        <!-- body content -->
        <script defer src="path-to-cookieconsent.js"></script>
        <script defer src="path-to-cookieconsent-init.js"></script>
    </body>
</html>

Note

Replace path-to-cookieconsent.js, path-to-cookieconsent.css and path-to-cookieconsent-init.js with valid paths.

Configure the plugin inside cookieconsent-init.js:

const cc = CookieConsent.init();

cc.run({
    // your config. goes here (required)
});

React

Import the plugin in your root/APP component, and configure it inside the useEffect hook:



 
 














import { useEffect } from "react";

import "vanilla-cookieconsent/dist/cookieconsent.css";
import CookieConsent from "vanilla-cookieconsent";

export default function App() {

    useEffect(() => {
        const cc = CookieConsent.init();

        cc.run({
            // your config. goes here (required)
        });
    }, []);

    // ...
}

Vue

Create a new VUE Plugin, CookieConsentVue.js:

import "vanilla-cookieconsent/dist/cookieconsent.css";
import CookieConsent from "vanilla-cookieconsent"

export default {
    install: (app, pluginConfig) => {
        app.config.globalProperties.$cc = CookieConsent.init();
        app.config.globalProperties.$cc.run(pluginConfig);
    }
}

INFO

The newly created VUE Plugin will allow you to access CookieConsent from any component, using either this.$cc or $cc.

"Register" the plugin in your root/APP component, inside main.js:





 



 
 
 


import { createApp } from 'vue'
import App from './App.vue'
import router from './router'

import CookieConsentVue from 'path-to-CookieConsentVue.js'

createApp(App)
    .use(router),
    .use(CookieConsentVue, {
        // your config. goes here (required)
    })
    .mount('#app');

Angular

Add compilerOptions.allowSyntheticDefaultImports in the tsconfig.json file:

{
  "compilerOptions": {
    "allowSyntheticDefaultImports": true
  }
}

Declare the cookieconsent.css style in the angular.json file:

{
    ...
        "build": {
            "options": {
                "styles": [
                    "node_modules/vanilla-cookieconsent/dist/cookieconsent.css"
                ]
            }
        }
    ...
}

Import the module in your angular component (generally app.component.ts):


 











 
 
 
 



import { Component, AfterViewInit } from '@angular/core';
import CookieConsent from 'vanilla-cookieconsent';

@Component({
    selector: 'app-root',
    templateUrl: './app.component.html',
    styleUrls: ['./app.component.css']
})

export class AppComponent implements AfterViewInit{
    title = 'angular-javascript-demo';

    ngAfterViewInit(): void{
        const cc = CookieConsent.init();
        cc.run({
            // your config. goes here (required)
        });
    }
}

Finally, Configure the plugin.


Configuration

The most basic configuration requires the definition of the following 2 fields:

  • categories
  • language
  • Basic example config.

    {
    
        onConsent: function () {
            // consent was given
        },
    
        onChange: function () {
            // user changed his/her preferences
        },
    
        categories: {
            necessary: {
                enabled: true,  // this category is enabled by default
                readOnly: true  // this category cannot be disabled
            },
            analytics: {
                enabled: false,
                readOnly: false,
    
                // Delete specific cookies when the user opts-out of this category
                autoClear: {
                    cookies: [
                        {
                            name: /^_ga/,   // regex: match all cookies starting with '_ga'
                        },
                        {
                            name: '_gid',   // string: exact cookie name
                        }
                    ]
                }
            }
        },
    
        language: {
            default: 'en',
    
            translations: {
                en: {
                    consentModal: {
                        title: 'We use cookies',
                        description: 'Cookie modal description',
                        acceptAllBtn: 'Accept all',
                        acceptNecessaryBtn: 'Reject all',
                        showPreferencesBtn: 'Manage Individual preferences'
                    },
                    preferencesModal: {
                        title: 'Manage cookie preferences',
                        acceptAllBtn: 'Accept all',
                        acceptNecessaryBtn: 'Reject all',
                        savePreferencesBtn: 'Accept current selection',
                        closeIconLabel: 'Close modal',
                        sections: [
                            {
                                title: 'Somebody said ... cookies?',
                                description: 'I want one!'
                            },
                            {
                                title: 'Strictly Necessary cookies',
                                description: 'These cookies are essential for the proper functioning of the website and cannot be disabled.',
    
                                //this field will generate a toggle linked to the 'necessary' category
                                linkedCategory: 'necessary'
                            },
                            {
                                title: 'Performance and Analytics',
                                description: 'These cookies collect information about how you use our website. All of the data is anonymized and cannot be used to identify you.',
                                linkedCategory: 'analytics'
                            },
                            {
                                title: 'More information',
                                description: 'For any queries in relation to my policy on cookies and your choices, please <a href="#contact-page">contact us</a>'
                            }
                        ]
                    }
                }
            }
        }
    }
    

You should now see the consent modal pop up!

TIP

You can also define external translation files.

If you're having trouble setting up the plugin, you can check out a few demo examples on github.


Manage scripts/cookies

You can block any script tag by simply adding the following 2 attributes:

  • type="text/plain" disables the script
  • data-category="category-name" enables the script if the specified category is accepted

Before:

<script src="external.js"></script>

<script>
    console.log("Hi i'm an inline script!");
</script>

After:

<script src="external.js" type="text/plain" data-category="analytics"></script>

<script type="text/plain" data-category="analytics">
    console.log("Hi, I'm an inline script!");
</script>

You can also use callbacks or custom events for more flexibility.


Open preferences modal

The simplest way to open the preferences modal is by creating a button (or a link) with the following attribute:

  • data-cc="show-preferencesModal"
<button type="button" data-cc="show-preferencesModal">Manage cookie preferences</button>

Check out all the possible data-cc values.

Released under the MIT License.