From c8553fe15454d57447d40f60e252353459dab20c Mon Sep 17 00:00:00 2001 From: Andrew Hosgood Date: Thu, 9 Nov 2023 20:25:12 +0000 Subject: [PATCH] Rework Cookie class --- CHANGELOG.md | 1 + .../cookie-banner/cookie-banner.stories.js | 8 +++---- src/nationalarchives/lib/cookies.mjs | 23 ++++++++++--------- 3 files changed, 17 insertions(+), 15 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index ad3d7395..868450a5 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -19,6 +19,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 - Change many instances of Font Awesome icons to a fixed width - Adjusted the width of the hero caption - Removed margin and padding from all elements by default +- The standard cookie policies are always `essential`, `usage` and `settings` - other custom policies can be added ### Deprecated ### Removed diff --git a/src/nationalarchives/components/cookie-banner/cookie-banner.stories.js b/src/nationalarchives/components/cookie-banner/cookie-banner.stories.js index e0904fa8..c846b168 100644 --- a/src/nationalarchives/components/cookie-banner/cookie-banner.stories.js +++ b/src/nationalarchives/components/cookie-banner/cookie-banner.stories.js @@ -142,8 +142,8 @@ CustomPolicies.play = async ({ args, canvasElement }) => { const cookies = new Cookies(args.policies.split(",")); await expect(cookies.isPolicyAccepted("essential")).toEqual(true); - await expect(cookies.isPolicyAccepted("usage")).toEqual(null); - await expect(cookies.isPolicyAccepted("settings")).toEqual(null); + await expect(cookies.isPolicyAccepted("usage")).toEqual(false); + await expect(cookies.isPolicyAccepted("settings")).toEqual(false); await expect(cookies.isPolicyAccepted("custom")).toEqual(false); const canvas = within(canvasElement); @@ -151,8 +151,8 @@ CustomPolicies.play = async ({ args, canvasElement }) => { await userEvent.click(acceptButton); await expect(cookies.isPolicyAccepted("essential")).toEqual(true); - await expect(cookies.isPolicyAccepted("usage")).toEqual(null); - await expect(cookies.isPolicyAccepted("settings")).toEqual(null); + await expect(cookies.isPolicyAccepted("usage")).toEqual(true); + await expect(cookies.isPolicyAccepted("settings")).toEqual(true); await expect(cookies.isPolicyAccepted("custom")).toEqual(true); deleteAllCookies(); diff --git a/src/nationalarchives/lib/cookies.mjs b/src/nationalarchives/lib/cookies.mjs index da07d9e0..1d2b9c9d 100644 --- a/src/nationalarchives/lib/cookies.mjs +++ b/src/nationalarchives/lib/cookies.mjs @@ -11,24 +11,25 @@ export default class Cookies { /** * Create a cookie handler. - * @param {string[]} [policies=usage,settings] - The cookie policies to manage. + * @param {string[]} [extraPolicies=[]] - The extra cookie policies to manage. * @param {string} [cookiesPolicyKey=cookies_policy] - The name of the cookie. */ constructor( - policies = ["usage", "settings"], + extraPolicies = [], cookiesPolicyKey = "cookies_policy", ) { - this.cookiesPolicyKey = cookiesPolicyKey; - let allPolicies = {}; - policies.forEach((policy) => { - allPolicies[policy.toLowerCase()] = false; - }); - allPolicies = { - ...allPolicies, + this.savePolicies({ + ...Object.fromEntries(extraPolicies.map(k => [k.toLowerCase(), false])), + usage: false, + settings: false, ...this.policies, essential: true, - }; - this.savePolicies(allPolicies); + }); + if (Cookies._instance && Cookies._instance.cookiesPolicyKey === cookiesPolicyKey) { + return Cookies._instance + } + Cookies._instance = this; + this.cookiesPolicyKey = cookiesPolicyKey; this.events = {}; }