Appearance
Configuration Reference
Overview of all the available configuration options.
About the examples
All the examples in this section are partial code snippets. They do not represent full/valid configurations.
root
Root (parent) element where the modal will be appended as a last child.
- Type:
HTMLElement
- Default:
document.body
- Example:
cc.run({ // set a different root element root: document.getElementById('app') })
mode
Changes the scripts' activation logic when consent is not valid.
Type:
string
Values:
'opt-in'
,'opt-out'
Default:
'opt-in'
Details:
opt-in
: scripts — configured under a specific category — will run only if the user accepts that category (GDPR compliant).opt-out
: scripts — configured under a specific category which hasenabled: true
— will run automatically (it is generally not GDPR compliant). Once the user has provided consent, this option is ignored.Example:
Setting the mode on a per-country basis (concept):
const euCountries = ['DE', 'FR', 'IT', ...]; const userCountry = "IT"; const dynamicMode = euCountries.contains(userCountry) ? 'opt-in' : 'opt-out'; cc.run({ mode: dynamicMode })
autoShow
Automatically show the consent modal if consent is not valid.
Type:
boolean
Default:
true
Example:
Disable
autoShow
and show modal after 3 seconds:cc.run({ autoShow: false }) setTimeout(cc.show, 3000)
revision
Manages consent revisions; useful if you'd like to ask your users again for consent after a change in your cookie/privacy policy.
Type:
number
Default:
0
Details:
The default value
0
means that revision management is disabled. You can set any number different from 0 in order to enable it. Check out the dedicated revision management section.
manageScriptTags
Intercepts all <script>
tags with a data-category
attribute, and enables them based on the accepted categories. Check out the scripts management section for details and examples.
- Type:
boolean
- Default:
true
autoClearCookies
Clears cookies when user rejects a specific category. It requires a valid autoClear
array.
Type:
boolean
Default:
true
Details:
This function is executed on the following 2 events:
- when consent is not valid and the
onFirstConsent
callback is executed - when consent is valid and the state of the categories is changed
- when consent is not valid and the
hideFromBots
Stops the plugin's execution when a bot/crawler is detected, to prevent them from indexing the modal's content.
- Type:
boolean
- Default:
true
disablePageInteraction
Creates a dark overlay and blocks the page scroll until consent is expressed.
- Type:
boolean
- Default:
false
cookie
Customize the plugin's cookie.
- Type:
{ name: string, domain: string, path: string, expiresAfterDays: number | (acceptType: string) => number, sameSite: string }
- Default:
{ name: 'cc_cookie', domain: window.location.hostname, path: '/', expiresAfterDays: 182, sameSite: 'Lax' }
INFO
The cookie is automatically set with the secure
flag if https
is detected.
cookie.name
- Type:
string
- Default:
'cc_cookie'
cookie.domain
Current domain/subdomain's name, retrieved automatically.
- Type:
string
- Default:
window.location.hostname
cookie.path
- Type:
string
- Default:
'/'
cookie.expiresAfterDays
Number of days before the cookie expires.
Type:
number | (acceptType: string) => number
Default:
182
Details:
This field also accepts a
function
that must return a number. TheacceptType
parameter is equal togetUserPreferences().acceptType
.Example:
If the user accepted all categories, set
expiresAfterDays=365.25
, otherwise setexpiresAfterDays=182
.cc.run({ cookie: { expiresAfterDays: (acceptType) => { if(acceptType === 'all') return 365.25; return 182; } } })
cookie.sameSite
- Type:
string
- Values:
'Lax'
,'Strict'
,'None'
- Default:
'Lax'
onFirstConsent
Callback function executed once, on the user's first consent action.
- Type:
function({ cookie: {} // same as cc.getCookie() }): void
- Example:
cc.run({ onFirstConsent: ({cookie}) => { // do something } })
INFO
This callback function is also executed on revision change.
onConsent
Callback function executed on the user's first consent action and after each page load.
- Type:
function({ cookie: {} // same value as cc.getCookie() }): void
- Example:
cc.run({ onConsent: ({cookie}) => { // do something } })
INFO
This callback function is also executed on revision change.
onChange
Callback function executed when the user's preferences — such as accepted categories and services — change.
- Type:
function({ cookie: {}, // same as cc.getCookie() changedCategories: string[], changedPreferences: {[category: string]: string[]} }): void
- Example:
cc.run({ onChange: ({cookie, changedCategories, changedPreferences}) => { if(changedCategories.includes('analytics')){ if(cc.acceptedCategory('analytics')){ // the analytics category was just enabled }else{ // the analytics category was just disabled } if(changedServices['analytics'].includes('Google Analytics')){ if(cc.acceptedService('Google Analytics', 'analytics')){ // Google Analytics was just enabled }else{ // Google Analytics was just disabled } } } } })
onModalShow
Callback function executed when one of the modals is visible.
- Type:
function({ modalName: string }): void
- Example:
cc.run({ onModalShow: ({modalName}) => { // do something } })
Details:
modalName
equals to one of the following values:'consentModal'
'preferencesModal'
onModalHide
Callback function executed when one of the modals is hidden.
- Type:
function({ modalName: string }): void
- Example:
cc.run({ onModalHide: ({modalName}) => { // do something } })
Details:
modalName
equals to one of the following values:'consentModal'
'preferencesModal'
guiOptions
Tweak main UI settings.
- Type:
{ consentModal?: ConsentModalOptions preferencesModal?: PreferencesModalOptions }
guiOptions.consentModal
Type:
{ layout?: string position?: string flipButtons?: boolean equalWeightButtons?: boolean }
Default:
{ layout: 'box', position: 'bottom right', flipButtons: false, equalWeightButtons: true }
Details:
All available
layout
andposition
options.Layout Variant(s) Position-Y Position-X box
wide
,inline
top
,middle
,bottom
left
,center
,right
cloud
inline
top
,middle
,bottom
left
,center
,right
bar
inline
bottom
- Note
Valid
layout
syntax:<layoutName> <layoutVariant>
.
Validposition
syntax:<positionY> <positionX>
.Example:
guiOptions: { consentModal: { layout: 'cloud inline', position: 'bottom center' } }
guiOptions.preferencesModal
Type:
{ layout?: string position?: string flipButtons?: boolean equalWeightButtons?: boolean }
Default:
{ layout: 'box', position: 'right', flipButtons: false, equalWeightButtons: true }
Details:
All available
layout
andposition
options.Layout Variant(s) Position-Y Position-X box
- - - bar
wide
- left
,right
Note
Valid
layout
syntax:<layoutName> <layoutVariant>
.
Validposition
syntax:<positionX>
(if any available).Example:
guiOptions: { preferencesModal: { layout: 'bar wide', position: 'left', equalWeightButtons: false, flipButtons: true } }
categories required
Use to define your cookie categories.
Type:
{[category: string]: { enabled?: boolean, readOnly?: boolean, autoClear?: AutoClear }}
Example:
How to define the
analytics
category:cc.run({ categories: { analytics: {} } })
[category].enabled
Mark the category as enabled by default.
- Type:
boolean
- Default:
false
- Example:
cc.run({ categories: { necessary: { enabled: true }, analytics: { enabled: false } } })
[category].readOnly
Treat the category as read-only/necessary (always enabled).
- Type:
boolean
- Default:
false
- Example:
cc.run({ categories: { necessary: { readOnly: true }, analytics: { readOnly: false } } })
[category].autoClear
Clear cookies when the user rejects the cookie category.
Type:
{ cookies: Cookie[] reloadPage: boolean }
Details:
autoClear.cookies
:Cookie[]
array ofCookie
objectsautoClear.reloadPage
:boolean
reload page on clear
Cookie
type:{ name: string | RegExp path?: string domain?: string }
Example:
Clear the
'_gid'
cookie and all the other cookies starting with'_ga'
when the user opts-out of the "analytics" category.cc.run({ categories: { analytics: { readOnly: false, autoClear: [ { name: /^(_ga)/ //regex }, { name: '_gid' //string } ] } } })
WARNING
If you've installed CookieConsent in a subdomain, and the cookie you're trying to erase is in the main domain, you'll have to specify your main domain in the domain
field of the Cookie
object.
[category].services
Define individually togglable services.
Type:
{ [service: string]: { label?: string, onAccept?: () => void, onReject?: () => void } }
Details:
label
: overwrites the visible name in the preferencesModal (can be html)onAccept
: callback function executed when the service is acceptedonReject
: callback function executed when the service is rejected (assuming that it was previously accepted)
Example:
Defining 2 services:
ga
andnew_service
:cc.run({ categories: { analytics: { services: { ga: { label: 'Google Analytics', onAccept: () => { // enable ga }, onReject: () => { // disable ga } }, new_service: { label: 'Another Service', onAccept: () => { // enable new_service }, onReject: () => { // disable new_service } } } } } })
INFO
If one or more services are enabled, then the entire category will be treated as enabled/accepted.
language required
Define your language settings and the translation(s) content.
- Type:
{ default: string autoDetect?: string translations: Translations }
language.default required
The desired default language.
- Type:
string
- Example:
cc.run({ language: { default: 'en' } })
language.autoDetect
Set the current language dynamically.
Type:
string
Values:
'document'
,'browser'
Details:
'document'
: retrieve language from thelang
attribute (e.g.<html lang="en-US">
)'browser'
: retrieve the user's browser language vianavigator.language
INFO
The detected language will be used only if a valid translation is defined, otherwise the plugin will fallback to the
default
language.
language.translations required
Define the translation(s) content.
Type:
{ [language: string]: string | { consentModal: ConsentModal, preferencesModal: PreferencesModal } }
Details:
You can define an
inline
translation object, or specify the path to anexternal .json
translation file.Examples:
External translation file:
cc.run({ language: { default: 'en', translations: { en: '/assets/translations/en.json' } } })
Inline translation object:
cc.run({ language: { default: 'en', translations: { en: { consentModal: { // ... }, preferencesModal: { // ... } } } } })
[translation].consentModalrequired
Type:
{ title?: string description?: string acceptAllBtn?: string acceptNecessaryBtn?: string showPreferencesBtn?: string closeIconLabel?: string revisionMessage?: string footer?: string }
Details:
closeIconLabel
: if specified, a bigX
button will be generated (visible only in thebox
layout). It acts the same asacceptNecessaryBtn
.revisionMessage
: check out the dedicated revision section.footer
: a small area where you can place your links (impressum, privacy policy ...)
INFO
All the options/fields also allow html markup.
Example:
translations: { 'en': { consentModal: { title: 'We use cookies!', description: 'Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua', acceptAllBtn: 'Accept all', acceptNecessaryBtn: 'Accept necessary', showPreferencesBtn: 'Manage individual preferences', footer: ` <a href="#path-to-impressum.html" target="_blank">Impressum</a> <a href="#path-to-privacy-policy.html" target="_blank">Privacy Policy</a> ` } } }
[translation].preferencesModalrequired
Type:
{ title?: string acceptAllBtn?: string acceptNecessaryBtn?: string savePreferencesBtn?: string closeIconLabel?: string serviceCounterLabel?: string sections: Section[] }
Details:
serviceCounterLabel
: if you're using services, you can specify a label such as'Service(s)'
to clarify what the counter means.
Example:
translations: { 'en': { preferencesModal: { title: 'Cookie Preferences Center', acceptAllBtn: 'Accept all', acceptNecessaryBtn: 'Accept necessary only', savePreferencesBtn: 'Accept current selection', closeIconLabel: 'Close modal', sections: [] } } }
[translation].preferencesModal.sectionsrequired
Type:
{ title?: string description?: string linkedCategory?: string cookieTable?: CookieTable }
Details:
linkedCategory
: by specifying the name of a defined category (e.g. 'analytics'), a toggle will be generatedcookieTable
: html table where you can list and clarify the cookies under this category
CookieTable
type:{ headers: {[key: string]: string} body: {[key: string]: string}[] }
Example:
sections: [ { title: 'Section name', description: 'Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua' }, { title: 'Section name', description: 'Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua', linkedCategory: 'necessary' }, { title: 'Analytics Cookies', description: 'Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua', linkedCategory: 'analytics', cookieTable: { headers: { name: 'Name', description: 'Description', duration: 'Duration' }, body: [ { name: 'cookie-name', description: 'cookie-description', duration: 'cookie-duration' }, { name: 'cookie-name-2', description: 'cookie-description-2', duration: 'cookie-duration-2' } ] } } ]
TIP
You can define any table, with the headers you deem more fit.