From 798fe78f1adaf165298cc32f8cbc43940fcd0bfc Mon Sep 17 00:00:00 2001 From: Patrick Cartlidge Date: Thu, 14 Nov 2024 15:21:28 +0000 Subject: [PATCH] Cookie banner extends `ConfigurableComponent` Make the cookie banner extends `ConfigurableComponent` which is now exported from the latest version of `govuk-frontend`. Remove redundant code and update references to the config. Use the `defaults` functionality of `ConfigurableComponent` and provide a `schema`. --- src/javascripts/components/cookie-banner.mjs | 36 ++++++++++++++------ 1 file changed, 26 insertions(+), 10 deletions(-) diff --git a/src/javascripts/components/cookie-banner.mjs b/src/javascripts/components/cookie-banner.mjs index 0d8887a9ef..eeb8f62b15 100644 --- a/src/javascripts/components/cookie-banner.mjs +++ b/src/javascripts/components/cookie-banner.mjs @@ -1,4 +1,4 @@ -import { Component } from 'govuk-frontend' +import { ConfigurableComponent } from 'govuk-frontend' import * as CookieFunctions from './cookie-functions.mjs' @@ -12,12 +12,12 @@ const cookieConfirmationRejectSelector = '.js-cookie-banner-confirmation-reject' /** * Website cookie banner */ -class CookieBanner extends Component { +class CookieBanner extends ConfigurableComponent { /** * Check support of CookieBanner */ static checkSupport() { - Component.checkSupport() + super.checkSupport() if (CookieBanner.onCookiesPage()) { throw Error('Cancelled initialisation as on cookie page') @@ -34,14 +34,13 @@ class CookieBanner extends Component { } static moduleName = 'govuk-cookie-banner' + /** * @param {Element} $module - HTML element + * @param {CookieBannerConfig} config - cookie banner config */ - constructor($module) { - super($module) - - this.cookieCategory = - (this.$root.dataset && this.$root.dataset.cookieCategory) || 'analytics' + constructor($module, config) { + super($module, config) const $acceptButton = $module.querySelector(cookieBannerAcceptSelector) const $rejectButton = $module.querySelector(cookieBannerRejectSelector) @@ -109,7 +108,7 @@ class CookieBanner extends Component { */ acceptCookies() { // Do actual cookie consent bit - CookieFunctions.setConsentCookie({ [this.cookieCategory]: true }) + CookieFunctions.setConsentCookie({ [this.config.cookieCategory]: true }) // Hide banner and show confirmation message this.$cookieMessage.setAttribute('hidden', 'true') @@ -121,7 +120,7 @@ class CookieBanner extends Component { */ rejectCookies() { // Do actual cookie consent bit - CookieFunctions.setConsentCookie({ [this.cookieCategory]: false }) + CookieFunctions.setConsentCookie({ [this.config.cookieCategory]: false }) // Hide banner and show confirmation message this.$cookieMessage.setAttribute('hidden', 'true') @@ -147,6 +146,23 @@ class CookieBanner extends Component { confirmationMessage.focus() } + + static defaults = { + cookieCategory: 'analytics' + } + + static schema = { + properties: { + cookieCategory: { type: 'string' } + } + } } +/** + * Cookie banner config + * + * @typedef {object} CookieBannerConfig + * @property {string} [cookieCategory] - category of cookie that the user is accepting/declining + */ + export default CookieBanner