{"version":3,"file":"all.bundle.mjs","sources":["../../src/govuk/common/govuk-frontend-version.mjs","../../src/govuk/common/index.mjs","../../src/govuk/errors/index.mjs","../../src/govuk/component.mjs","../../src/govuk/common/configuration.mjs","../../src/govuk/i18n.mjs","../../src/govuk/components/accordion/accordion.mjs","../../src/govuk/components/button/button.mjs","../../src/govuk/common/closest-attribute-value.mjs","../../src/govuk/components/character-count/character-count.mjs","../../src/govuk/components/checkboxes/checkboxes.mjs","../../src/govuk/components/error-summary/error-summary.mjs","../../src/govuk/components/exit-this-page/exit-this-page.mjs","../../src/govuk/components/file-upload/file-upload.mjs","../../src/govuk/components/notification-banner/notification-banner.mjs","../../src/govuk/components/password-input/password-input.mjs","../../src/govuk/components/radios/radios.mjs","../../src/govuk/components/service-navigation/service-navigation.mjs","../../src/govuk/components/skip-link/skip-link.mjs","../../src/govuk/components/tabs/tabs.mjs","../../src/govuk/init.mjs"],"sourcesContent":["/*\n * This variable is automatically overwritten during builds and releases.\n * It doesn't need to be updated manually.\n */\n\n/**\n * GOV.UK Frontend release version\n *\n * {@link https://github.com/alphagov/govuk-frontend/releases}\n */\nexport const version = 'development'\n","/**\n * Common helpers which do not require polyfill.\n *\n * IMPORTANT: If a helper require a polyfill, please isolate it in its own module\n * so that the polyfill can be properly tree-shaken and does not burden\n * the components that do not need that helper\n */\n\n/**\n * Get GOV.UK Frontend breakpoint value from CSS custom property\n *\n * @private\n * @param {string} name - Breakpoint name\n * @returns {{ property: string, value?: string }} Breakpoint object\n */\nexport function getBreakpoint(name) {\n  const property = `--govuk-breakpoint-${name}`\n\n  // Get value from `<html>` with breakpoints on CSS :root\n  const value = window\n    .getComputedStyle(document.documentElement)\n    .getPropertyValue(property)\n\n  return {\n    property,\n    value: value || undefined\n  }\n}\n\n/**\n * Move focus to element\n *\n * Sets tabindex to -1 to make the element programmatically focusable,\n * but removes it on blur as the element doesn't need to be focused again.\n *\n * @private\n * @template {HTMLElement} FocusElement\n * @param {FocusElement} $element - HTML element\n * @param {object} [options] - Handler options\n * @param {function(this: FocusElement): void} [options.onBeforeFocus] - Callback before focus\n * @param {function(this: FocusElement): void} [options.onBlur] - Callback on blur\n */\nexport function setFocus($element, options = {}) {\n  const isFocusable = $element.getAttribute('tabindex')\n\n  if (!isFocusable) {\n    $element.setAttribute('tabindex', '-1')\n  }\n\n  /**\n   * Handle element focus\n   */\n  function onFocus() {\n    $element.addEventListener('blur', onBlur, { once: true })\n  }\n\n  /**\n   * Handle element blur\n   */\n  function onBlur() {\n    options.onBlur?.call($element)\n\n    if (!isFocusable) {\n      $element.removeAttribute('tabindex')\n    }\n  }\n\n  // Add listener to reset element on blur, after focus\n  $element.addEventListener('focus', onFocus, { once: true })\n\n  // Focus element\n  options.onBeforeFocus?.call($element)\n  $element.focus()\n}\n\n/**\n * Checks if component is already initialised\n *\n * @internal\n * @param {Element} $root - HTML element to be checked\n * @param {string} moduleName - name of component module\n * @returns {boolean} Whether component is already initialised\n */\nexport function isInitialised($root, moduleName) {\n  return (\n    $root instanceof HTMLElement &&\n    $root.hasAttribute(`data-${moduleName}-init`)\n  )\n}\n\n/**\n * Checks if GOV.UK Frontend is supported on this page\n *\n * Some browsers will load and run our JavaScript but GOV.UK Frontend\n * won't be supported.\n *\n * @param {HTMLElement | null} [$scope] - (internal) `<body>` HTML element checked for browser support\n * @returns {boolean} Whether GOV.UK Frontend is supported on this page\n */\nexport function isSupported($scope = document.body) {\n  if (!$scope) {\n    return false\n  }\n\n  return $scope.classList.contains('govuk-frontend-supported')\n}\n\n/**\n * Check for an array\n *\n * @internal\n * @param {unknown} option - Option to check\n * @returns {boolean} Whether the option is an array\n */\nfunction isArray(option) {\n  return Array.isArray(option)\n}\n\n/**\n * Check for an object\n *\n * @internal\n * @template {Partial<Record<keyof ObjectType, unknown>>} ObjectType\n * @param {unknown | ObjectType} option - Option to check\n * @returns {option is ObjectType} Whether the option is an object\n */\nexport function isObject(option) {\n  return !!option && typeof option === 'object' && !isArray(option)\n}\n\n/**\n * Check for valid scope\n *\n * @internal\n * @template {Element | Document} ScopeType\n * @param {unknown | ScopeType} $scope - Scope of the document to search within\n * @returns {$scope is ScopeType} Whether the scope can be queried\n */\nexport function isScope($scope) {\n  return !!$scope && ($scope instanceof Element || $scope instanceof Document)\n}\n\n/**\n * Format error message\n *\n * @internal\n * @param {ComponentWithModuleName} Component - Component that threw the error\n * @param {string} message - Error message\n * @returns {string} - Formatted error message\n */\nexport function formatErrorMessage(Component, message) {\n  return `${Component.moduleName}: ${message}`\n}\n\n/* eslint-disable jsdoc/valid-types --\n * `{new(...args: any[] ): object}` is not recognised as valid\n * https://github.com/gajus/eslint-plugin-jsdoc/issues/145#issuecomment-1308722878\n * https://github.com/jsdoc-type-pratt-parser/jsdoc-type-pratt-parser/issues/131\n **/\n\n/**\n * @typedef ComponentWithModuleName\n * @property {string} moduleName - Name of the component\n */\n\n/* eslint-enable jsdoc/valid-types */\n","import { formatErrorMessage, isObject } from '../common/index.mjs'\n\n/**\n * GOV.UK Frontend error\n *\n * A base class for `Error`s thrown by GOV.UK Frontend.\n *\n * It is meant to be extended into specific types of errors\n * to be thrown by our code.\n *\n * @example\n * ```js\n * class MissingRootError extends GOVUKFrontendError {\n *   // Setting an explicit name is important as extending the class will not\n *   // set a new `name` on the subclass. The `name` property is important\n *   // to ensure intelligible error names even if the class name gets\n *   // mangled by a minifier\n *   name = \"MissingRootError\"\n * }\n * ```\n * @virtual\n */\nexport class GOVUKFrontendError extends Error {\n  name = 'GOVUKFrontendError'\n}\n\n/**\n * Indicates that GOV.UK Frontend is not supported\n */\nexport class SupportError extends GOVUKFrontendError {\n  name = 'SupportError'\n\n  /**\n   * Checks if GOV.UK Frontend is supported on this page\n   *\n   * @param {HTMLElement | null} [$scope] - HTML element `<body>` checked for browser support\n   */\n  constructor($scope = document.body) {\n    const supportMessage =\n      'noModule' in HTMLScriptElement.prototype\n        ? 'GOV.UK Frontend initialised without `<body class=\"govuk-frontend-supported\">` from template `<script>` snippet'\n        : 'GOV.UK Frontend is not supported in this browser'\n\n    super(\n      $scope\n        ? supportMessage\n        : 'GOV.UK Frontend initialised without `<script type=\"module\">`'\n    )\n  }\n}\n\n/**\n * Indicates that a component has received an illegal configuration\n */\nexport class ConfigError extends GOVUKFrontendError {\n  name = 'ConfigError'\n}\n\n/**\n * Indicates an issue with an element (possibly `null` or `undefined`)\n */\nexport class ElementError extends GOVUKFrontendError {\n  name = 'ElementError'\n\n  /**\n   * @internal\n   * @overload\n   * @param {string} message - Element error message\n   */\n\n  /**\n   * @internal\n   * @overload\n   * @param {ElementErrorOptions} options - Element error options\n   */\n\n  /**\n   * @internal\n   * @param {string | ElementErrorOptions} messageOrOptions - Element error message or options\n   */\n  constructor(messageOrOptions) {\n    let message = typeof messageOrOptions === 'string' ? messageOrOptions : ''\n\n    // Build message from options\n    if (isObject(messageOrOptions)) {\n      const { component, identifier, element, expectedType } = messageOrOptions\n\n      message = identifier\n\n      // Append reason\n      message += element\n        ? ` is not of type ${expectedType ?? 'HTMLElement'}`\n        : ' not found'\n\n      // Prepend with module name (optional)\n      if (component) {\n        message = formatErrorMessage(component, message)\n      }\n    }\n\n    super(message)\n  }\n}\n\n/**\n * Indicates that a component is already initialised\n */\nexport class InitError extends GOVUKFrontendError {\n  name = 'InitError'\n\n  /**\n   * @internal\n   * @param {ComponentWithModuleName | string} componentOrMessage - name of the component module\n   */\n  constructor(componentOrMessage) {\n    const message =\n      typeof componentOrMessage === 'string'\n        ? componentOrMessage\n        : formatErrorMessage(\n            componentOrMessage,\n            `Root element (\\`$root\\`) already initialised`\n          )\n\n    super(message)\n  }\n}\n\n/**\n * Element error options\n *\n * @internal\n * @typedef {object} ElementErrorOptions\n * @property {Element | Document | null} [element] - The element in error (optional)\n * @property {ComponentWithModuleName} [component] - Component throwing the error (optional)\n * @property {string} identifier - An identifier that'll let the user understand which element has an error. This is whatever makes the most sense\n * @property {string} [expectedType] - The type that was expected for the identifier (optional)\n */\n\n/**\n * @import { ComponentWithModuleName } from '../common/index.mjs'\n */\n","import { isInitialised, isSupported } from './common/index.mjs'\nimport { ElementError, InitError, SupportError } from './errors/index.mjs'\n\n/**\n * Base Component class\n *\n * Centralises the behaviours shared by our components\n *\n * @virtual\n * @template {Element} [RootElementType=HTMLElement]\n */\nexport class Component {\n  /**\n   * @type {typeof Element}\n   */\n  static elementType = HTMLElement\n\n  // allows Typescript user to work around the lack of types\n  // in GOVUKFrontend package, Typescript is not aware of $root\n  // in components that extend GOVUKFrontendComponent\n  /**\n   * Returns the root element of the component\n   *\n   * @protected\n   * @returns {RootElementType} - the root element of component\n   */\n  get $root() {\n    return this._$root\n  }\n\n  /**\n   * @protected\n   * @type {RootElementType}\n   */\n  _$root\n\n  /**\n   * Constructs a new component, validating that GOV.UK Frontend is supported\n   *\n   * @internal\n   * @param {Element | null} [$root] - HTML element to use for component\n   */\n  constructor($root) {\n    const childConstructor = /** @type {ChildClassConstructor} */ (\n      this.constructor\n    )\n\n    // TypeScript does not enforce that inheriting classes will define a `moduleName`\n    // (even if we add a `@virtual` `static moduleName` property to this class).\n    // While we trust users to do this correctly, we do a little check to provide them\n    // a helpful error message.\n    //\n    // After this, we'll be sure that `childConstructor` has a `moduleName`\n    // as expected of the `ChildClassConstructor` we've cast `this.constructor` to.\n    if (typeof childConstructor.moduleName !== 'string') {\n      throw new InitError(`\\`moduleName\\` not defined in component`)\n    }\n\n    if (!($root instanceof childConstructor.elementType)) {\n      throw new ElementError({\n        element: $root,\n        component: childConstructor,\n        identifier: 'Root element (`$root`)',\n        expectedType: childConstructor.elementType.name\n      })\n    } else {\n      this._$root = /** @type {RootElementType} */ ($root)\n    }\n\n    childConstructor.checkSupport()\n\n    this.checkInitialised()\n\n    const moduleName = childConstructor.moduleName\n\n    this.$root.setAttribute(`data-${moduleName}-init`, '')\n  }\n\n  /**\n   * Validates whether component is already initialised\n   *\n   * @private\n   * @throws {InitError} when component is already initialised\n   */\n  checkInitialised() {\n    const constructor = /** @type {ChildClassConstructor} */ (this.constructor)\n    const moduleName = constructor.moduleName\n\n    if (moduleName && isInitialised(this.$root, moduleName)) {\n      throw new InitError(constructor)\n    }\n  }\n\n  /**\n   * Validates whether components are supported\n   *\n   * @throws {SupportError} when the components are not supported\n   */\n  static checkSupport() {\n    if (!isSupported()) {\n      throw new SupportError()\n    }\n  }\n}\n\n/**\n * @typedef ChildClass\n * @property {string} moduleName - The module name that'll be looked for in the DOM when initialising the component\n */\n\n/**\n * @typedef {typeof Component & ChildClass} ChildClassConstructor\n */\n","import { Component } from '../component.mjs'\nimport { ConfigError } from '../errors/index.mjs'\n\nimport { isObject, isScope, formatErrorMessage } from './index.mjs'\n\nexport const configOverride = Symbol.for('configOverride')\n\n/**\n * Base Component class\n *\n * Centralises the behaviours shared by our components\n *\n * @virtual\n * @template {Partial<Record<keyof ConfigurationType, unknown>>} [ConfigurationType=ObjectNested]\n * @template {Element & { dataset: DOMStringMap }} [RootElementType=HTMLElement]\n * @augments Component<RootElementType>\n */\nexport class ConfigurableComponent extends Component {\n  /**\n   * configOverride\n   *\n   * Function which defines configuration overrides to prioritize\n   * properties from the root element's dataset.\n   *\n   * It should take a subset of configuration as input and return\n   * a new configuration object with properties that should be\n   * overridden based on the root element's dataset. A Symbol\n   * is used for indexing to prevent conflicts.\n   *\n   * @internal\n   * @virtual\n   * @param {Partial<ConfigurationType>} [param] - Configuration object\n   * @returns {Partial<ConfigurationType>} return - Configuration object\n   */\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  [configOverride](param) {\n    return {}\n  }\n\n  /**\n   * Returns the root element of the component\n   *\n   * @protected\n   * @returns {ConfigurationType} - the root element of component\n   */\n  get config() {\n    return this._config\n  }\n\n  /**\n   *\n   * @type {ConfigurationType}\n   */\n  _config\n\n  /**\n   * Constructs a new component, validating that GOV.UK Frontend is supported\n   *\n   * @internal\n   * @param {Element | null} [$root] - HTML element to use for component\n   * @param {ConfigurationType} [config] - HTML element to use for component\n   */\n  constructor($root, config) {\n    super($root)\n\n    const childConstructor =\n      /** @type {ChildClassConstructor<ConfigurationType>} */ (this.constructor)\n\n    if (!isObject(childConstructor.defaults)) {\n      throw new ConfigError(\n        formatErrorMessage(\n          childConstructor,\n          'Config passed as parameter into constructor but no defaults defined'\n        )\n      )\n    }\n\n    const datasetConfig = /** @type {ConfigurationType} */ (\n      normaliseDataset(childConstructor, this._$root.dataset)\n    )\n\n    this._config = /** @type {ConfigurationType} */ (\n      mergeConfigs(\n        childConstructor.defaults,\n        config ?? {},\n        this[configOverride](datasetConfig),\n        datasetConfig\n      )\n    )\n  }\n}\n\n/**\n * Normalise string\n *\n * 'If it looks like a duck, and it quacks like a duck…' 🦆\n *\n * If the passed value looks like a boolean or a number, convert it to a boolean\n * or number.\n *\n * Designed to be used to convert config passed via data attributes (which are\n * always strings) into something sensible.\n *\n * @internal\n * @param {DOMStringMap[string]} value - The value to normalise\n * @param {SchemaProperty} [property] - Component schema property\n * @returns {string | boolean | number | undefined} Normalised data\n */\nexport function normaliseString(value, property) {\n  const trimmedValue = value ? value.trim() : ''\n\n  let output\n  let outputType = property?.type\n\n  // No schema type set? Determine automatically\n  if (!outputType) {\n    if (['true', 'false'].includes(trimmedValue)) {\n      outputType = 'boolean'\n    }\n\n    // Empty / whitespace-only strings are considered finite so we need to check\n    // the length of the trimmed string as well\n    if (trimmedValue.length > 0 && isFinite(Number(trimmedValue))) {\n      outputType = 'number'\n    }\n  }\n\n  switch (outputType) {\n    case 'boolean':\n      output = trimmedValue === 'true'\n      break\n\n    case 'number':\n      output = Number(trimmedValue)\n      break\n\n    default:\n      output = value\n  }\n\n  return output\n}\n\n/**\n * Normalise dataset\n *\n * Loop over an object and normalise each value using {@link normaliseString},\n * optionally expanding nested `i18n.field`\n *\n * @internal\n * @template {Partial<Record<keyof ConfigurationType, unknown>>} ConfigurationType\n * @template {[keyof ConfigurationType, SchemaProperty | undefined][]} SchemaEntryType\n * @param {{ schema?: Schema<ConfigurationType>, moduleName: string }} Component - Component class\n * @param {DOMStringMap} dataset - HTML element dataset\n * @returns {ObjectNested} Normalised dataset\n */\nexport function normaliseDataset(Component, dataset) {\n  if (!isObject(Component.schema)) {\n    throw new ConfigError(\n      formatErrorMessage(\n        Component,\n        'Config passed as parameter into constructor but no schema defined'\n      )\n    )\n  }\n\n  const out = /** @type {ObjectNested} */ ({})\n  const entries = /** @type {SchemaEntryType} */ (\n    Object.entries(Component.schema.properties)\n  )\n\n  // Normalise top-level dataset ('data-*') values using schema types\n  for (const entry of entries) {\n    const [namespace, property] = entry\n\n    // Cast the `namespace` to string so it can be used to access the dataset\n    const field = namespace.toString()\n\n    if (field in dataset) {\n      out[field] = normaliseString(dataset[field], property)\n    }\n\n    /**\n     * Extract and normalise nested object values automatically using\n     * {@link normaliseString} but only schema object types are allowed\n     */\n    if (property?.type === 'object') {\n      out[field] = extractConfigByNamespace(\n        Component.schema,\n        dataset,\n        namespace\n      )\n    }\n  }\n\n  return out\n}\n\n/**\n * Normalise options passed to `initAll` or `createAll`\n *\n * @internal\n * @template {CompatibleClass} ComponentClass\n * @param {Config | CreateAllOptions<ComponentClass> | OnErrorCallback<ComponentClass> | Element | Document | null} [scopeOrOptions] - Scope of the document to search within, initialisation options or error callback function\n * @returns {CreateAllOptions<ComponentClass>} Normalised options\n */\nexport function normaliseOptions(scopeOrOptions) {\n  let /** @type {Element | Document | null} */ $scope = document\n  let /** @type {OnErrorCallback<ComponentClass> | undefined} */ onError\n\n  // Handle options object\n  if (isObject(scopeOrOptions)) {\n    const options = scopeOrOptions\n\n    // Scope must be valid or null\n    if (isScope(options.scope) || options.scope === null) {\n      $scope = options.scope\n    }\n\n    // Error handler must be a function\n    if (typeof options.onError === 'function') {\n      onError = options.onError\n    }\n  }\n\n  if (isScope(scopeOrOptions)) {\n    $scope = scopeOrOptions\n  } else if (scopeOrOptions === null) {\n    $scope = null\n  } else if (typeof scopeOrOptions === 'function') {\n    onError = scopeOrOptions\n  }\n\n  return {\n    scope: $scope,\n    onError\n  }\n}\n\n/**\n * Config merging function\n *\n * Takes any number of objects and combines them together, with\n * greatest priority on the LAST item passed in.\n *\n * @internal\n * @param {...{ [key: string]: unknown }} configObjects - Config objects to merge\n * @returns {{ [key: string]: unknown }} A merged config object\n */\nexport function mergeConfigs(...configObjects) {\n  // Start with an empty object as our base\n  /** @type {{ [key: string]: unknown }} */\n  const formattedConfigObject = {}\n\n  // Loop through each of the passed objects\n  for (const configObject of configObjects) {\n    for (const key of Object.keys(configObject)) {\n      const option = formattedConfigObject[key]\n      const override = configObject[key]\n\n      // Push their keys one-by-one into formattedConfigObject. Any duplicate\n      // keys with object values will be merged, otherwise the new value will\n      // override the existing value.\n      if (isObject(option) && isObject(override)) {\n        formattedConfigObject[key] = mergeConfigs(option, override)\n      } else {\n        // Apply override\n        formattedConfigObject[key] = override\n      }\n    }\n  }\n\n  return formattedConfigObject\n}\n\n/**\n * Validate component config by schema\n *\n * Follows limited examples in JSON schema for wider support in future\n *\n * {@link https://ajv.js.org/json-schema.html#compound-keywords}\n * {@link https://ajv.js.org/packages/ajv-errors.html#single-message}\n *\n * @internal\n * @template {Partial<Record<keyof ConfigurationType, unknown>>} ConfigurationType\n * @param {Schema<ConfigurationType>} schema - The schema of a component\n * @param {ConfigurationType} config - Component config\n * @returns {string[]} List of validation errors\n */\nexport function validateConfig(schema, config) {\n  const validationErrors = []\n\n  // Check errors for each schema\n  for (const [name, conditions] of Object.entries(schema)) {\n    const errors = []\n\n    // Check errors for each schema condition\n    if (Array.isArray(conditions)) {\n      for (const { required, errorMessage } of conditions) {\n        if (!required.every((key) => !!config[key])) {\n          errors.push(errorMessage) // Missing config key value\n        }\n      }\n\n      // Check one condition passes or add errors\n      if (name === 'anyOf' && !(conditions.length - errors.length >= 1)) {\n        validationErrors.push(...errors)\n      }\n    }\n  }\n\n  return validationErrors\n}\n\n/**\n * Extracts keys starting with a particular namespace from dataset ('data-*')\n * object, removing the namespace in the process, normalising all values\n *\n * @internal\n * @template {Partial<Record<keyof ConfigurationType, unknown>>} ConfigurationType\n * @param {Schema<ConfigurationType>} schema - The schema of a component\n * @param {DOMStringMap} dataset - The object to extract key-value pairs from\n * @param {keyof ConfigurationType} namespace - The namespace to filter keys with\n * @returns {ObjectNested | undefined} Nested object with dot-separated key namespace removed\n */\nexport function extractConfigByNamespace(schema, dataset, namespace) {\n  const property = schema.properties[namespace]\n\n  // Only extract configs for object schema properties\n  if (property?.type !== 'object') {\n    return\n  }\n\n  // Add default empty config\n  const newObject = /** @type {Record<typeof namespace, ObjectNested>} */ ({\n    [namespace]: {}\n  })\n\n  for (const [key, value] of Object.entries(dataset)) {\n    /** @type {ObjectNested | ObjectNested[NestedKey]} */\n    let current = newObject\n\n    // Split the key into parts, using . as our namespace separator\n    const keyParts = key.split('.')\n\n    /**\n     * Create new level per part\n     *\n     * e.g. 'i18n.textareaDescription.other' becomes\n     * `{ i18n: { textareaDescription: { other } } }`\n     */\n    for (const [index, name] of keyParts.entries()) {\n      if (isObject(current)) {\n        // Drop down to nested object until the last part\n        if (index < keyParts.length - 1) {\n          // New nested object (optionally) replaces existing value\n          if (!isObject(current[name])) {\n            current[name] = {}\n          }\n\n          // Drop down into new or existing nested object\n          current = current[name]\n        } else if (key !== namespace) {\n          // Normalised value (optionally) replaces existing value\n          current[name] = normaliseString(value)\n        }\n      }\n    }\n  }\n\n  return newObject[namespace]\n}\n\n/**\n * @internal\n * @typedef {keyof ObjectNested} NestedKey\n * @typedef {{ [key: string]: string | boolean | number | ObjectNested | undefined }} ObjectNested\n */\n\n/**\n * Schema for component config\n *\n * @template {Partial<Record<keyof ConfigurationType, unknown>>} ConfigurationType\n * @typedef {object} Schema\n * @property {Record<keyof ConfigurationType, SchemaProperty | undefined>} properties - Schema properties\n * @property {SchemaCondition<ConfigurationType>[]} [anyOf] - List of schema conditions\n */\n\n/**\n * Schema property for component config\n *\n * @typedef {object} SchemaProperty\n * @property {'string' | 'boolean' | 'number' | 'object'} type - Property type\n */\n\n/**\n * Schema condition for component config\n *\n * @template {Partial<Record<keyof ConfigurationType, unknown>>} ConfigurationType\n * @typedef {object} SchemaCondition\n * @property {(keyof ConfigurationType)[]} required - List of required config fields\n * @property {string} errorMessage - Error message when required config fields not provided\n */\n\n/**\n * @template {Partial<Record<keyof ConfigurationType, unknown>>} [ConfigurationType=ObjectNested]\n * @typedef ChildClass\n * @property {string} moduleName - The module name that'll be looked for in the DOM when initialising the component\n * @property {Schema<ConfigurationType>} [schema] - The schema of the component configuration\n * @property {ConfigurationType} [defaults] - The default values of the configuration of the component\n */\n\n/**\n * @template {Partial<Record<keyof ConfigurationType, unknown>>} [ConfigurationType=ObjectNested]\n * @typedef {typeof Component & ChildClass<ConfigurationType>} ChildClassConstructor<ConfigurationType>\n */\n\n/**\n * @import { CompatibleClass, Config, CreateAllOptions, OnErrorCallback } from '../init.mjs'\n */\n","import { isObject } from './common/index.mjs'\n\n/**\n * Internal support for selecting messages to render, with placeholder\n * interpolation and locale-aware number formatting and pluralisation\n *\n * @internal\n */\nexport class I18n {\n  translations\n  locale\n\n  /**\n   * @internal\n   * @param {{ [key: string]: string | TranslationPluralForms }} translations - Key-value pairs of the translation strings to use.\n   * @param {object} [config] - Configuration options for the function.\n   * @param {string | null} [config.locale] - An overriding locale for the PluralRules functionality.\n   */\n  constructor(translations = {}, config = {}) {\n    // Make list of translations available throughout function\n    this.translations = translations\n\n    // The locale to use for PluralRules and NumberFormat\n    this.locale = config.locale ?? (document.documentElement.lang || 'en')\n  }\n\n  /**\n   * The most used function - takes the key for a given piece of UI text and\n   * returns the appropriate string.\n   *\n   * @internal\n   * @param {string} lookupKey - The lookup key of the string to use.\n   * @param {{ [key: string]: unknown }} [options] - Any options passed with the translation string, e.g: for string interpolation.\n   * @returns {string} The appropriate translation string.\n   * @throws {Error} Lookup key required\n   * @throws {Error} Options required for `${}` placeholders\n   */\n  t(lookupKey, options) {\n    if (!lookupKey) {\n      // Print a console error if no lookup key has been provided\n      throw new Error('i18n: lookup key missing')\n    }\n\n    // Fetch the translation for that lookup key\n    let translation = this.translations[lookupKey]\n\n    // If the `count` option is set, determine which plural suffix is needed and\n    // change the lookupKey to match. We check to see if it's numeric instead of\n    // falsy, as this could legitimately be 0.\n    if (typeof options?.count === 'number' && isObject(translation)) {\n      const translationPluralForm =\n        translation[this.getPluralSuffix(lookupKey, options.count)]\n\n      // Update translation with plural suffix\n      if (translationPluralForm) {\n        translation = translationPluralForm\n      }\n    }\n\n    if (typeof translation === 'string') {\n      // Check for ${} placeholders in the translation string\n      // eslint-disable-next-line @typescript-eslint/prefer-regexp-exec\n      if (translation.match(/%{(.\\S+)}/)) {\n        if (!options) {\n          throw new Error(\n            'i18n: cannot replace placeholders in string if no option data provided'\n          )\n        }\n\n        return this.replacePlaceholders(translation, options)\n      }\n\n      return translation\n    }\n\n    // If the key wasn't found in our translations object,\n    // return the lookup key itself as the fallback\n    return lookupKey\n  }\n\n  /**\n   * Takes a translation string with placeholders, and replaces the placeholders\n   * with the provided data\n   *\n   * @internal\n   * @param {string} translationString - The translation string\n   * @param {{ [key: string]: unknown }} options - Any options passed with the translation string, e.g: for string interpolation.\n   * @returns {string} The translation string to output, with $\\{\\} placeholders replaced\n   */\n  replacePlaceholders(translationString, options) {\n    const formatter = Intl.NumberFormat.supportedLocalesOf(this.locale).length\n      ? new Intl.NumberFormat(this.locale)\n      : undefined\n\n    return translationString.replace(\n      /%{(.\\S+)}/g,\n\n      /**\n       * Replace translation string placeholders\n       *\n       * @internal\n       * @param {string} placeholderWithBraces - Placeholder with braces\n       * @param {string} placeholderKey - Placeholder key\n       * @returns {string} Placeholder value\n       */\n      function (placeholderWithBraces, placeholderKey) {\n        if (Object.prototype.hasOwnProperty.call(options, placeholderKey)) {\n          const placeholderValue = options[placeholderKey]\n\n          // If a user has passed `false` as the value for the placeholder\n          // treat it as though the value should not be displayed\n          if (\n            placeholderValue === false ||\n            (typeof placeholderValue !== 'number' &&\n              typeof placeholderValue !== 'string')\n          ) {\n            return ''\n          }\n\n          // If the placeholder's value is a number, localise the number formatting\n          if (typeof placeholderValue === 'number') {\n            return formatter\n              ? formatter.format(placeholderValue)\n              : `${placeholderValue}`\n          }\n\n          return placeholderValue\n        }\n\n        throw new Error(\n          `i18n: no data found to replace ${placeholderWithBraces} placeholder in string`\n        )\n      }\n    )\n  }\n\n  /**\n   * Check to see if the browser supports Intl.PluralRules\n   *\n   * It requires all conditions to be met in order to be supported:\n   * - The implementation of Intl supports PluralRules (NOT true in Safari 10–12)\n   * - The browser/OS has plural rules for the current locale (browser dependent)\n   *\n   * {@link https://browsersl.ist/#q=supports+es6-module+and+not+supports+intl-pluralrules}\n   *\n   * @internal\n   * @returns {boolean} Returns true if all conditions are met. Returns false otherwise.\n   */\n  hasIntlPluralRulesSupport() {\n    return Boolean(\n      'PluralRules' in window.Intl &&\n      Intl.PluralRules.supportedLocalesOf(this.locale).length\n    )\n  }\n\n  /**\n   * Get the appropriate suffix for the plural form.\n   *\n   * Uses Intl.PluralRules (or our own fallback implementation) to get the\n   * 'preferred' form to use for the given count.\n   *\n   * Checks that a translation has been provided for that plural form – if it\n   * hasn't, it'll fall back to the 'other' plural form (unless that doesn't exist\n   * either, in which case an error will be thrown)\n   *\n   * @internal\n   * @param {string} lookupKey - The lookup key of the string to use.\n   * @param {number} count - Number used to determine which pluralisation to use.\n   * @returns {PluralRule} The suffix associated with the correct pluralisation for this locale.\n   * @throws {Error} Plural form `.other` required when preferred plural form is missing\n   */\n  getPluralSuffix(lookupKey, count) {\n    // Validate that the number is actually a number.\n    //\n    // Number(count) will turn anything that can't be converted to a Number type\n    // into 'NaN'. isFinite filters out NaN, as it isn't a finite number.\n    // eslint-disable-next-line @typescript-eslint/no-unnecessary-type-conversion\n    count = Number(count)\n    if (!isFinite(count)) {\n      return 'other'\n    }\n\n    // Fetch the translation for that lookup key\n    const translation = this.translations[lookupKey]\n\n    // Check to verify that all the requirements for Intl.PluralRules are met.\n    // If so, we can use that instead of our custom implementation. Otherwise,\n    // use the hardcoded fallback.\n    const preferredForm = this.hasIntlPluralRulesSupport()\n      ? new Intl.PluralRules(this.locale).select(count)\n      : 'other'\n\n    // Use the correct plural form if provided\n    if (isObject(translation)) {\n      if (preferredForm in translation) {\n        return preferredForm\n        // Fall back to `other` if the plural form is missing, but log a warning\n        // to the console\n      } else if ('other' in translation) {\n        console.warn(\n          `i18n: Missing plural form \".${preferredForm}\" for \"${this.locale}\" locale. Falling back to \".other\".`\n        )\n\n        return 'other'\n      }\n    }\n\n    // If the required `other` plural form is missing, all we can do is error\n    throw new Error(\n      `i18n: Plural form \".other\" is required for \"${this.locale}\" locale`\n    )\n  }\n}\n\n/**\n * Plural rule category mnemonic tags\n *\n * @internal\n * @typedef {'zero' | 'one' | 'two' | 'few' | 'many' | 'other'} PluralRule\n */\n\n/**\n * Translated message by plural rule they correspond to.\n *\n * Allows to group pluralised messages under a single key when passing\n * translations to a component's constructor\n *\n * @internal\n * @typedef {object} TranslationPluralForms\n * @property {string} [other] - General plural form\n * @property {string} [zero] - Plural form used with 0\n * @property {string} [one] - Plural form used with 1\n * @property {string} [two] - Plural form used with 2\n * @property {string} [few] - Plural form used for a few\n * @property {string} [many] - Plural form used for many\n */\n","import { ConfigurableComponent } from '../../common/configuration.mjs'\nimport { ElementError } from '../../errors/index.mjs'\nimport { I18n } from '../../i18n.mjs'\n\n/**\n * Accordion component\n *\n * This allows a collection of sections to be collapsed by default, showing only\n * their headers. Sections can be expanded or collapsed individually by clicking\n * their headers. A \"Show all sections\" button is also added to the top of the\n * accordion, which switches to \"Hide all sections\" when all the sections are\n * expanded.\n *\n * The state of each section is saved to the DOM via the `aria-expanded`\n * attribute, which also provides accessibility.\n *\n * @preserve\n * @augments ConfigurableComponent<AccordionConfig>\n */\nexport class Accordion extends ConfigurableComponent {\n  /** @private */\n  i18n\n\n  /** @private */\n  controlsClass = 'govuk-accordion__controls'\n\n  /** @private */\n  showAllClass = 'govuk-accordion__show-all'\n\n  /** @private */\n  showAllTextClass = 'govuk-accordion__show-all-text'\n\n  /** @private */\n  sectionClass = 'govuk-accordion__section'\n\n  /** @private */\n  sectionExpandedClass = 'govuk-accordion__section--expanded'\n\n  /** @private */\n  sectionButtonClass = 'govuk-accordion__section-button'\n\n  /** @private */\n  sectionHeaderClass = 'govuk-accordion__section-header'\n\n  /** @private */\n  sectionHeadingClass = 'govuk-accordion__section-heading'\n\n  /** @private */\n  sectionHeadingDividerClass = 'govuk-accordion__section-heading-divider'\n\n  /** @private */\n  sectionHeadingTextClass = 'govuk-accordion__section-heading-text'\n\n  /** @private */\n  sectionHeadingTextFocusClass = 'govuk-accordion__section-heading-text-focus'\n\n  /** @private */\n  sectionShowHideToggleClass = 'govuk-accordion__section-toggle'\n\n  /** @private */\n  sectionShowHideToggleFocusClass = 'govuk-accordion__section-toggle-focus'\n\n  /** @private */\n  sectionShowHideTextClass = 'govuk-accordion__section-toggle-text'\n\n  /** @private */\n  upChevronIconClass = 'govuk-accordion-nav__chevron'\n\n  /** @private */\n  downChevronIconClass = 'govuk-accordion-nav__chevron--down'\n\n  /** @private */\n  sectionSummaryClass = 'govuk-accordion__section-summary'\n\n  /** @private */\n  sectionSummaryFocusClass = 'govuk-accordion__section-summary-focus'\n\n  /** @private */\n  sectionContentClass = 'govuk-accordion__section-content'\n\n  /** @private */\n  $sections\n\n  /**\n   * @private\n   * @type {HTMLButtonElement | null}\n   */\n  $showAllButton = null\n\n  /**\n   * @private\n   * @type {HTMLElement | null}\n   */\n  $showAllIcon = null\n\n  /**\n   * @private\n   * @type {HTMLElement | null}\n   */\n  $showAllText = null\n\n  /**\n   * @param {Element | null} $root - HTML element to use for accordion\n   * @param {AccordionConfig} [config] - Accordion config\n   */\n  constructor($root, config = {}) {\n    super($root, config)\n\n    this.i18n = new I18n(this.config.i18n)\n\n    const $sections = this.$root.querySelectorAll(`.${this.sectionClass}`)\n    if (!$sections.length) {\n      throw new ElementError({\n        component: Accordion,\n        identifier: `Sections (\\`<div class=\"${this.sectionClass}\">\\`)`\n      })\n    }\n\n    this.$sections = $sections\n\n    this.initControls()\n    this.initSectionHeaders()\n\n    this.updateShowAllButton(this.areAllSectionsOpen())\n  }\n\n  /**\n   * Initialise controls and set attributes\n   *\n   * @private\n   */\n  initControls() {\n    // Create \"Show all\" button and set attributes\n    this.$showAllButton = document.createElement('button')\n    this.$showAllButton.setAttribute('type', 'button')\n    this.$showAllButton.setAttribute('class', this.showAllClass)\n    this.$showAllButton.setAttribute('aria-expanded', 'false')\n\n    // Create icon, add to element\n    this.$showAllIcon = document.createElement('span')\n    this.$showAllIcon.classList.add(this.upChevronIconClass)\n    this.$showAllButton.appendChild(this.$showAllIcon)\n\n    // Create control wrapper and add controls to it\n    const $accordionControls = document.createElement('div')\n    $accordionControls.setAttribute('class', this.controlsClass)\n    $accordionControls.appendChild(this.$showAllButton)\n    this.$root.insertBefore($accordionControls, this.$root.firstChild)\n\n    // Build additional wrapper for Show all toggle text and place after icon\n    this.$showAllText = document.createElement('span')\n    this.$showAllText.classList.add(this.showAllTextClass)\n    this.$showAllButton.appendChild(this.$showAllText)\n\n    // Handle click events on the show/hide all button\n    this.$showAllButton.addEventListener('click', () =>\n      this.onShowOrHideAllToggle()\n    )\n\n    // Handle 'beforematch' events, if the user agent supports them\n    if ('onbeforematch' in document) {\n      document.addEventListener('beforematch', (event) =>\n        this.onBeforeMatch(event)\n      )\n    }\n  }\n\n  /**\n   * Initialise section headers\n   *\n   * @private\n   */\n  initSectionHeaders() {\n    this.$sections.forEach(($section, i) => {\n      const $header = $section.querySelector(`.${this.sectionHeaderClass}`)\n      if (!$header) {\n        throw new ElementError({\n          component: Accordion,\n          identifier: `Section headers (\\`<div class=\"${this.sectionHeaderClass}\">\\`)`\n        })\n      }\n\n      // Set header attributes\n      this.constructHeaderMarkup($header, i)\n      this.setExpanded(this.isExpanded($section), $section)\n\n      // Handle events\n      $header.addEventListener('click', () => this.onSectionToggle($section))\n\n      // See if there is any state stored in sessionStorage and set the sections\n      // to open or closed.\n      this.setInitialState($section)\n    })\n  }\n\n  /**\n   * Construct section header\n   *\n   * @private\n   * @param {Element} $header - Section header\n   * @param {number} index - Section index\n   */\n  constructHeaderMarkup($header, index) {\n    const $span = $header.querySelector(`.${this.sectionButtonClass}`)\n    const $heading = $header.querySelector(`.${this.sectionHeadingClass}`)\n    const $summary = $header.querySelector(`.${this.sectionSummaryClass}`)\n\n    if (!$heading) {\n      throw new ElementError({\n        component: Accordion,\n        identifier: `Section heading (\\`.${this.sectionHeadingClass}\\`)`\n      })\n    }\n\n    if (!$span) {\n      throw new ElementError({\n        component: Accordion,\n        identifier: `Section button placeholder (\\`<span class=\"${this.sectionButtonClass}\">\\`)`\n      })\n    }\n\n    // Create a button element that will replace the\n    // '.govuk-accordion__section-button' span\n    const $button = document.createElement('button')\n    $button.setAttribute('type', 'button')\n    $button.setAttribute(\n      'aria-controls',\n      `${this.$root.id}-content-${index + 1}`\n    )\n\n    // Copy all attributes from $span to $button (except `id`, which gets added\n    // to the `$headingText` element)\n    for (const attr of Array.from($span.attributes)) {\n      if (attr.name !== 'id') {\n        $button.setAttribute(attr.name, attr.value)\n      }\n    }\n\n    // Create container for heading text so it can be styled\n    const $headingText = document.createElement('span')\n    $headingText.classList.add(this.sectionHeadingTextClass)\n    // Copy the span ID to the heading text to allow it to be referenced by\n    // `aria-labelledby` on the hidden content area without \"Show this section\"\n    $headingText.id = $span.id\n\n    // Create an inner heading text container to limit the width of the focus\n    // state\n    const $headingTextFocus = document.createElement('span')\n    $headingTextFocus.classList.add(this.sectionHeadingTextFocusClass)\n    $headingText.appendChild($headingTextFocus)\n    // span could contain HTML elements\n    // (see https://www.w3.org/TR/2011/WD-html5-20110525/content-models.html#phrasing-content)\n    Array.from($span.childNodes).forEach(($child) =>\n      $headingTextFocus.appendChild($child)\n    )\n\n    // Create container for show / hide icons and text.\n    const $showHideToggle = document.createElement('span')\n    $showHideToggle.classList.add(this.sectionShowHideToggleClass)\n    // Tell Google not to index the 'show' text as part of the heading. Must be\n    // set on the element before it's added to the DOM.\n    // See https://developers.google.com/search/docs/advanced/robots/robots_meta_tag#data-nosnippet-attr\n    $showHideToggle.setAttribute('data-nosnippet', '')\n    // Create an inner container to limit the width of the focus state\n    const $showHideToggleFocus = document.createElement('span')\n    $showHideToggleFocus.classList.add(this.sectionShowHideToggleFocusClass)\n    $showHideToggle.appendChild($showHideToggleFocus)\n    // Create wrapper for the show / hide text. Append text after the show/hide icon\n    const $showHideText = document.createElement('span')\n    const $showHideIcon = document.createElement('span')\n    $showHideIcon.classList.add(this.upChevronIconClass)\n    $showHideToggleFocus.appendChild($showHideIcon)\n    $showHideText.classList.add(this.sectionShowHideTextClass)\n    $showHideToggleFocus.appendChild($showHideText)\n\n    // Append elements to the button:\n    // 1. Heading text\n    // 2. Punctuation\n    // 3. (Optional: Summary line followed by punctuation)\n    // 4. Show / hide toggle\n    $button.appendChild($headingText)\n    $button.appendChild(this.getButtonPunctuationEl())\n\n    // If summary content exists add to DOM in correct order\n    if ($summary) {\n      // Create a new `span` element and copy the summary line content from the\n      // original `div` to the new `span`. This is because the summary line text\n      // is now inside a button element, which can only contain phrasing\n      // content.\n      const $summarySpan = document.createElement('span')\n      // Create an inner summary container to limit the width of the summary\n      // focus state\n      const $summarySpanFocus = document.createElement('span')\n      $summarySpanFocus.classList.add(this.sectionSummaryFocusClass)\n      $summarySpan.appendChild($summarySpanFocus)\n\n      // Get original attributes, and pass them to the replacement\n      for (const attr of Array.from($summary.attributes)) {\n        $summarySpan.setAttribute(attr.name, attr.value)\n      }\n\n      // Copy original contents of summary to the new summary span\n      Array.from($summary.childNodes).forEach(($child) =>\n        $summarySpanFocus.appendChild($child)\n      )\n\n      // Replace the original summary `div` with the new summary `span`\n      $summary.remove()\n\n      $button.appendChild($summarySpan)\n      $button.appendChild(this.getButtonPunctuationEl())\n    }\n\n    $button.appendChild($showHideToggle)\n\n    $heading.removeChild($span)\n    $heading.appendChild($button)\n  }\n\n  /**\n   * When a section is opened by the user agent via the 'beforematch' event\n   *\n   * @private\n   * @param {Event} event - Generic event\n   */\n  onBeforeMatch(event) {\n    const $fragment = event.target\n\n    // Handle elements with `.closest()` support only\n    if (!($fragment instanceof Element)) {\n      return\n    }\n\n    // Handle when fragment is inside section\n    const $section = $fragment.closest(`.${this.sectionClass}`)\n    if ($section) {\n      this.setExpanded(true, $section)\n    }\n  }\n\n  /**\n   * When section toggled, set and store state\n   *\n   * @private\n   * @param {Element} $section - Section element\n   */\n  onSectionToggle($section) {\n    const nowExpanded = !this.isExpanded($section)\n    this.setExpanded(nowExpanded, $section)\n\n    // Store the state in sessionStorage when a change is triggered\n    this.storeState($section, nowExpanded)\n  }\n\n  /**\n   * When Open/Close All toggled, set and store state\n   *\n   * @private\n   */\n  onShowOrHideAllToggle() {\n    const nowExpanded = !this.areAllSectionsOpen()\n\n    this.$sections.forEach(($section) => {\n      this.setExpanded(nowExpanded, $section)\n      this.storeState($section, nowExpanded)\n    })\n\n    this.updateShowAllButton(nowExpanded)\n  }\n\n  /**\n   * Set section attributes when opened/closed\n   *\n   * @private\n   * @param {boolean} expanded - Section expanded\n   * @param {Element} $section - Section element\n   */\n  setExpanded(expanded, $section) {\n    const $showHideIcon = $section.querySelector(`.${this.upChevronIconClass}`)\n    const $showHideText = $section.querySelector(\n      `.${this.sectionShowHideTextClass}`\n    )\n    const $button = $section.querySelector(`.${this.sectionButtonClass}`)\n    const $content = $section.querySelector(`.${this.sectionContentClass}`)\n\n    if (!$content) {\n      throw new ElementError({\n        component: Accordion,\n        identifier: `Section content (\\`<div class=\"${this.sectionContentClass}\">\\`)`\n      })\n    }\n\n    if (!$showHideIcon || !$showHideText || !$button) {\n      // Return early for elements we create\n      return\n    }\n\n    const newButtonText = expanded\n      ? this.i18n.t('hideSection')\n      : this.i18n.t('showSection')\n\n    $showHideText.textContent = newButtonText\n    $button.setAttribute('aria-expanded', `${expanded}`)\n\n    // Update aria-label combining\n    const ariaLabelParts = []\n\n    const $headingText = $section.querySelector(\n      `.${this.sectionHeadingTextClass}`\n    )\n    if ($headingText) {\n      ariaLabelParts.push($headingText.textContent.trim())\n    }\n\n    const $summary = $section.querySelector(`.${this.sectionSummaryClass}`)\n    if ($summary) {\n      ariaLabelParts.push($summary.textContent.trim())\n    }\n\n    const ariaLabelMessage = expanded\n      ? this.i18n.t('hideSectionAriaLabel')\n      : this.i18n.t('showSectionAriaLabel')\n    ariaLabelParts.push(ariaLabelMessage)\n\n    /*\n     * Join with a comma to add pause for assistive technology.\n     * Example: [heading]Section A ,[pause] Show this section.\n     * https://accessibility.blog.gov.uk/2017/12/18/what-working-on-gov-uk-navigation-taught-us-about-accessibility/\n     */\n    $button.setAttribute('aria-label', ariaLabelParts.join(' , '))\n\n    // Swap icon, change class\n    if (expanded) {\n      $content.removeAttribute('hidden')\n      $section.classList.add(this.sectionExpandedClass)\n      $showHideIcon.classList.remove(this.downChevronIconClass)\n    } else {\n      $content.setAttribute('hidden', 'until-found')\n      $section.classList.remove(this.sectionExpandedClass)\n      $showHideIcon.classList.add(this.downChevronIconClass)\n    }\n\n    // See if \"Show all sections\" button text should be updated\n    this.updateShowAllButton(this.areAllSectionsOpen())\n  }\n\n  /**\n   * Get state of section\n   *\n   * @private\n   * @param {Element} $section - Section element\n   * @returns {boolean} True if expanded\n   */\n  isExpanded($section) {\n    return $section.classList.contains(this.sectionExpandedClass)\n  }\n\n  /**\n   * Check if all sections are open\n   *\n   * @private\n   * @returns {boolean} True if all sections are open\n   */\n  areAllSectionsOpen() {\n    return Array.from(this.$sections).every(($section) =>\n      this.isExpanded($section)\n    )\n  }\n\n  /**\n   * Update \"Show all sections\" button\n   *\n   * @private\n   * @param {boolean} expanded - Section expanded\n   */\n  updateShowAllButton(expanded) {\n    if (!this.$showAllButton || !this.$showAllText || !this.$showAllIcon) {\n      return\n    }\n\n    this.$showAllButton.setAttribute('aria-expanded', expanded.toString())\n    this.$showAllText.textContent = expanded\n      ? this.i18n.t('hideAllSections')\n      : this.i18n.t('showAllSections')\n    this.$showAllIcon.classList.toggle(this.downChevronIconClass, !expanded)\n  }\n\n  /**\n   * Get the identifier for a section\n   *\n   * We need a unique way of identifying each content in the Accordion.\n   * Since an `#id` should be unique and an `id` is required for `aria-`\n   * attributes `id` can be safely used.\n   *\n   * @param {Element} $section - Section element\n   * @returns {string | undefined | null} Identifier for section\n   */\n  getIdentifier($section) {\n    const $button = $section.querySelector(`.${this.sectionButtonClass}`)\n\n    return $button?.getAttribute('aria-controls')\n  }\n\n  /**\n   * Set the state of the accordions in sessionStorage\n   *\n   * @private\n   * @param {Element} $section - Section element\n   * @param {boolean} isExpanded - Whether the section is expanded\n   */\n  storeState($section, isExpanded) {\n    if (!this.config.rememberExpanded) {\n      return\n    }\n\n    const id = this.getIdentifier($section)\n\n    if (id) {\n      try {\n        window.sessionStorage.setItem(id, isExpanded.toString())\n      } catch {}\n    }\n  }\n\n  /**\n   * Read the state of the accordions from sessionStorage\n   *\n   * @private\n   * @param {Element} $section - Section element\n   */\n  setInitialState($section) {\n    if (!this.config.rememberExpanded) {\n      return\n    }\n\n    const id = this.getIdentifier($section)\n\n    if (id) {\n      try {\n        const state = window.sessionStorage.getItem(id)\n\n        if (state !== null) {\n          this.setExpanded(state === 'true', $section)\n        }\n      } catch {}\n    }\n  }\n\n  /**\n   * Create an element to improve semantics of the section button with\n   * punctuation\n   *\n   * Adding punctuation to the button can also improve its general semantics by\n   * dividing its contents into thematic chunks. See\n   * https://github.com/alphagov/govuk-frontend/issues/2327#issuecomment-922957442\n   *\n   * @private\n   * @returns {Element} DOM element\n   */\n  getButtonPunctuationEl() {\n    const $punctuationEl = document.createElement('span')\n    $punctuationEl.classList.add(\n      'govuk-visually-hidden',\n      this.sectionHeadingDividerClass\n    )\n    $punctuationEl.textContent = ', '\n    return $punctuationEl\n  }\n\n  /**\n   * Name for the component used when initialising using data-module attributes.\n   */\n  static moduleName = 'govuk-accordion'\n\n  /**\n   * Accordion default config\n   *\n   * @see {@link AccordionConfig}\n   * @constant\n   * @type {AccordionConfig}\n   */\n  static defaults = Object.freeze({\n    i18n: {\n      hideAllSections: 'Hide all sections',\n      hideSection: 'Hide',\n      hideSectionAriaLabel: 'Hide this section',\n      showAllSections: 'Show all sections',\n      showSection: 'Show',\n      showSectionAriaLabel: 'Show this section'\n    },\n    rememberExpanded: true\n  })\n\n  /**\n   * Accordion config schema\n   *\n   * @constant\n   * @satisfies {Schema<AccordionConfig>}\n   */\n  static schema = Object.freeze({\n    properties: {\n      i18n: { type: 'object' },\n      rememberExpanded: { type: 'boolean' }\n    }\n  })\n}\n\n/**\n * Accordion config\n *\n * @see {@link Accordion.defaults}\n * @typedef {object} AccordionConfig\n * @property {AccordionTranslations} [i18n=Accordion.defaults.i18n] - Accordion translations\n * @property {boolean} [rememberExpanded] - Whether the expanded and collapsed\n *   state of each section is remembered and restored when navigating.\n */\n\n/**\n * Accordion translations\n *\n * @see {@link Accordion.defaults.i18n}\n * @typedef {object} AccordionTranslations\n *\n * Messages used by the component for the labels of its buttons. This includes\n * the visible text shown on screen, and text to help assistive technology users\n * for the buttons toggling each section.\n * @property {string} [hideAllSections] - The text content for the 'Hide all\n *   sections' button, used when at least one section is expanded.\n * @property {string} [hideSection] - The text content for the 'Hide'\n *   button, used when a section is expanded.\n * @property {string} [hideSectionAriaLabel] - The text content appended to the\n *   'Hide' button's accessible name when a section is expanded.\n * @property {string} [showAllSections] - The text content for the 'Show all\n *   sections' button, used when all sections are collapsed.\n * @property {string} [showSection] - The text content for the 'Show'\n *   button, used when a section is collapsed.\n * @property {string} [showSectionAriaLabel] - The text content appended to the\n *   'Show' button's accessible name when a section is expanded.\n */\n\n/**\n * @import { Schema } from '../../common/configuration.mjs'\n */\n","import { ConfigurableComponent } from '../../common/configuration.mjs'\n\nconst DEBOUNCE_TIMEOUT_IN_SECONDS = 1\n\n/**\n * JavaScript enhancements for the Button component\n *\n * @preserve\n * @augments ConfigurableComponent<ButtonConfig>\n */\nexport class Button extends ConfigurableComponent {\n  /**\n   * @private\n   * @type {number | null}\n   */\n  debounceFormSubmitTimer = null\n\n  /**\n   * @param {Element | null} $root - HTML element to use for button\n   * @param {ButtonConfig} [config] - Button config\n   */\n  constructor($root, config = {}) {\n    super($root, config)\n\n    this.$root.addEventListener('keydown', (event) => this.handleKeyDown(event))\n    this.$root.addEventListener('click', (event) => this.debounce(event))\n  }\n\n  /**\n   * Trigger a click event when the space key is pressed\n   *\n   * Some screen readers tell users they can use the space bar to activate\n   * things with the 'button' role, so we need to match the functionality of\n   * native HTML buttons.\n   *\n   * See https://github.com/alphagov/govuk_elements/pull/272#issuecomment-233028270\n   *\n   * @private\n   * @param {KeyboardEvent} event - Keydown event\n   */\n  handleKeyDown(event) {\n    const $target = event.target\n\n    // Handle space bar only\n    if (event.key !== ' ') {\n      return\n    }\n\n    // Handle elements with [role=\"button\"] only\n    if (\n      $target instanceof HTMLElement &&\n      $target.getAttribute('role') === 'button'\n    ) {\n      event.preventDefault() // prevent the page from scrolling\n      $target.click()\n    }\n  }\n\n  /**\n   * Debounce double-clicks\n   *\n   * If the click quickly succeeds a previous click then nothing will happen.\n   * This stops people accidentally causing multiple form submissions by double\n   * clicking buttons.\n   *\n   * @private\n   * @param {MouseEvent} event - Mouse click event\n   * @returns {undefined | false} Returns undefined, or false when debounced\n   */\n  debounce(event) {\n    // Check the button that was clicked has preventDoubleClick enabled\n    if (!this.config.preventDoubleClick) {\n      return\n    }\n\n    // If the timer is still running, prevent the click from submitting the form\n    if (this.debounceFormSubmitTimer) {\n      event.preventDefault()\n      return false\n    }\n\n    this.debounceFormSubmitTimer = window.setTimeout(() => {\n      this.debounceFormSubmitTimer = null\n    }, DEBOUNCE_TIMEOUT_IN_SECONDS * 1000)\n  }\n\n  /**\n   * Name for the component used when initialising using data-module attributes.\n   */\n  static moduleName = 'govuk-button'\n\n  /**\n   * Button default config\n   *\n   * @see {@link ButtonConfig}\n   * @constant\n   * @type {ButtonConfig}\n   */\n  static defaults = Object.freeze({\n    preventDoubleClick: false\n  })\n\n  /**\n   * Button config schema\n   *\n   * @constant\n   * @satisfies {Schema<ButtonConfig>}\n   */\n  static schema = Object.freeze({\n    properties: {\n      preventDoubleClick: { type: 'boolean' }\n    }\n  })\n}\n\n/**\n * Button config\n *\n * @typedef {object} ButtonConfig\n * @property {boolean} [preventDoubleClick=false] - Prevent accidental double\n *   clicks on submit buttons from submitting forms multiple times.\n */\n\n/**\n * @import { Schema } from '../../common/configuration.mjs'\n */\n","/**\n * Returns the value of the given attribute closest to the given element (including itself)\n *\n * @internal\n * @param {Element} $element - The element to start walking the DOM tree up\n * @param {string} attributeName - The name of the attribute\n * @returns {string | null} Attribute value\n */\nexport function closestAttributeValue($element, attributeName) {\n  const $closestElementWithAttribute = $element.closest(`[${attributeName}]`)\n  return $closestElementWithAttribute\n    ? $closestElementWithAttribute.getAttribute(attributeName)\n    : null\n}\n","import { closestAttributeValue } from '../../common/closest-attribute-value.mjs'\nimport {\n  validateConfig,\n  ConfigurableComponent,\n  configOverride\n} from '../../common/configuration.mjs'\nimport { formatErrorMessage } from '../../common/index.mjs'\nimport { ConfigError, ElementError } from '../../errors/index.mjs'\nimport { I18n } from '../../i18n.mjs'\n\n/**\n * Character count component\n *\n * Tracks the number of characters or words in the `.govuk-js-character-count`\n * `<textarea>` inside the element. Displays a message with the remaining number\n * of characters/words available, or the number of characters/words in excess.\n *\n * You can configure the message to only appear after a certain percentage\n * of the available characters/words has been entered.\n *\n * @preserve\n * @augments ConfigurableComponent<CharacterCountConfig>\n */\nexport class CharacterCount extends ConfigurableComponent {\n  /** @private */\n  $textarea\n\n  /** @private */\n  count = 0\n\n  /** @private */\n  $visibleCountMessage\n\n  /** @private */\n  $screenReaderCountMessage\n\n  /**\n   * @private\n   * @type {number | null}\n   */\n  lastInputTimestamp = null\n\n  /** @private */\n  lastInputValue = ''\n\n  /**\n   * @private\n   * @type {number | null}\n   */\n  valueChecker = null\n\n  /** @private */\n  i18n\n\n  /** @private */\n  maxLength;\n\n  /**\n   * Character count config override\n   *\n   * To ensure data-attributes take complete precedence, even if they change\n   * the type of count, we need to reset the `maxlength` and `maxwords` from\n   * the JavaScript config.\n   *\n   * @internal\n   * @param {CharacterCountConfig} datasetConfig - configuration specified by dataset\n   * @returns {CharacterCountConfig} - configuration to override by dataset\n   */\n  [configOverride](datasetConfig) {\n    let configOverrides = {}\n    if ('maxwords' in datasetConfig || 'maxlength' in datasetConfig) {\n      configOverrides = {\n        maxlength: undefined,\n        maxwords: undefined\n      }\n    }\n\n    return configOverrides\n  }\n\n  /**\n   * @param {Element | null} $root - HTML element to use for character count\n   * @param {CharacterCountConfig} [config] - Character count config\n   */\n  constructor($root, config = {}) {\n    super($root, config)\n\n    const $textarea = this.$root.querySelector('.govuk-js-character-count')\n    if (\n      !(\n        $textarea instanceof HTMLTextAreaElement ||\n        $textarea instanceof HTMLInputElement\n      )\n    ) {\n      throw new ElementError({\n        component: CharacterCount,\n        element: $textarea,\n        expectedType: 'HTMLTextareaElement or HTMLInputElement',\n        identifier: 'Form field (`.govuk-js-character-count`)'\n      })\n    }\n\n    // Check for valid config\n    const errors = validateConfig(CharacterCount.schema, this.config)\n    if (errors[0]) {\n      throw new ConfigError(formatErrorMessage(CharacterCount, errors[0]))\n    }\n\n    this.i18n = new I18n(this.config.i18n, {\n      // Read the fallback if necessary rather than have it set in the defaults\n      locale: closestAttributeValue(this.$root, 'lang')\n    })\n\n    // Determine the limit attribute (characters or words)\n    this.maxLength = this.config.maxwords ?? this.config.maxlength ?? Infinity\n\n    this.$textarea = $textarea\n\n    const textareaDescriptionId = `${this.$textarea.id}-info`\n    const $textareaDescription = document.getElementById(textareaDescriptionId)\n    if (!$textareaDescription) {\n      throw new ElementError({\n        component: CharacterCount,\n        element: $textareaDescription,\n        identifier: `Count message (\\`id=\"${textareaDescriptionId}\"\\`)`\n      })\n    }\n\n    // Pre-existing validation error rendered from server\n    this.$errorMessage = this.$root.querySelector('.govuk-error-message')\n\n    // Inject a description for the textarea if none is present already\n    // for when the component was rendered with no maxlength, maxwords\n    // nor custom textareaDescriptionText\n    // eslint-disable-next-line @typescript-eslint/prefer-regexp-exec\n    if ($textareaDescription.textContent.match(/^\\s*$/)) {\n      $textareaDescription.textContent = this.i18n.t('textareaDescription', {\n        count: this.maxLength\n      })\n    }\n\n    // Move the textarea description to be immediately after the textarea\n    // Kept for backwards compatibility\n    this.$textarea.insertAdjacentElement('afterend', $textareaDescription)\n\n    // Create the *screen reader* specific live-updating counter\n    // This doesn't need any styling classes, as it is never visible\n    const $screenReaderCountMessage = document.createElement('div')\n    $screenReaderCountMessage.className =\n      'govuk-character-count__sr-status govuk-visually-hidden'\n    $screenReaderCountMessage.setAttribute('aria-live', 'polite')\n    this.$screenReaderCountMessage = $screenReaderCountMessage\n    $textareaDescription.insertAdjacentElement(\n      'afterend',\n      $screenReaderCountMessage\n    )\n\n    // Create our live-updating counter element, copying the classes from the\n    // textarea description for backwards compatibility as these may have been\n    // configured\n    const $visibleCountMessage = document.createElement('div')\n    $visibleCountMessage.className = $textareaDescription.className\n    $visibleCountMessage.classList.add('govuk-character-count__status')\n    $visibleCountMessage.setAttribute('aria-hidden', 'true')\n    this.$visibleCountMessage = $visibleCountMessage\n    $textareaDescription.insertAdjacentElement('afterend', $visibleCountMessage)\n\n    // Hide the textarea description\n    $textareaDescription.classList.add('govuk-visually-hidden')\n\n    // Remove hard limit if set\n    this.$textarea.removeAttribute('maxlength')\n\n    this.bindChangeEvents()\n\n    // When the page is restored after navigating 'back' in some browsers the\n    // state of form controls is not restored until *after* the DOMContentLoaded\n    // event is fired, so we need to sync after the pageshow event.\n    window.addEventListener('pageshow', () => {\n      // If the current value of the textarea is the same as what's\n      // in the HTML, don't re-run when users have not edited the field yet\n      // (new page load or BF cache navigation without having edited).\n      if (this.$textarea.value !== this.$textarea.textContent) {\n        this.updateCount()\n        this.updateCountMessage()\n      }\n    })\n\n    // Although we've set up handlers to sync state on the pageshow event, init\n    // could be called after those events have fired, for example if they are\n    // added to the page dynamically, so update now too.\n    this.updateCount()\n    this.updateCountMessage()\n  }\n\n  /**\n   * Bind change events\n   *\n   * Set up event listeners on the $textarea so that the count messages update\n   * when the user types.\n   *\n   * @private\n   */\n  bindChangeEvents() {\n    this.$textarea.addEventListener('input', () => this.handleInput())\n\n    // Bind focus/blur events to start/stop polling\n    this.$textarea.addEventListener('focus', () => this.handleFocus())\n    this.$textarea.addEventListener('blur', () => this.handleBlur())\n  }\n\n  /**\n   * Handle input event\n   *\n   * Update the visible character counter and keep track of when the last update\n   * happened for each keypress\n   *\n   * @private\n   */\n  handleInput() {\n    this.updateCount()\n    this.updateVisibleCountMessage()\n    this.lastInputTimestamp = Date.now()\n  }\n\n  /**\n   * Handle focus event\n   *\n   * Speech recognition software such as Dragon NaturallySpeaking will modify\n   * the fields by directly changing its `value`. These changes don't trigger\n   * events in JavaScript, so we need to poll to handle when and if they occur.\n   *\n   * Once the keyup event hasn't been detected for at least 1000 ms (1s), check\n   * if the textarea value has changed and update the count message if it has.\n   *\n   * This is so that the update triggered by the manual comparison doesn't\n   * conflict with debounced KeyboardEvent updates.\n   *\n   * @private\n   */\n  handleFocus() {\n    this.valueChecker = window.setInterval(() => {\n      if (\n        !this.lastInputTimestamp ||\n        Date.now() - 500 >= this.lastInputTimestamp\n      ) {\n        this.updateIfValueChanged()\n      }\n    }, 1000)\n  }\n\n  /**\n   * Handle blur event\n   *\n   * Stop checking the textarea value once the textarea no longer has focus\n   *\n   * @private\n   */\n  handleBlur() {\n    // Cancel value checking on blur\n    if (this.valueChecker) {\n      window.clearInterval(this.valueChecker)\n    }\n  }\n\n  /**\n   * Update count message if textarea value has changed\n   *\n   * @private\n   */\n  updateIfValueChanged() {\n    if (this.$textarea.value !== this.lastInputValue) {\n      this.lastInputValue = this.$textarea.value\n      this.updateCountMessage()\n    }\n  }\n\n  /**\n   * Update count message\n   *\n   * Helper function to update both the visible and screen reader-specific\n   * counters simultaneously (e.g. on init)\n   *\n   * @private\n   */\n  updateCountMessage() {\n    this.updateVisibleCountMessage()\n    this.updateScreenReaderCountMessage()\n  }\n\n  /**\n   * Update visible count message\n   *\n   * @private\n   */\n  updateVisibleCountMessage() {\n    const remainingNumber = this.maxLength - this.count\n    const isError = remainingNumber < 0\n\n    // If input is over the threshold, remove the disabled class which renders\n    // the counter invisible.\n    this.$visibleCountMessage.classList.toggle(\n      'govuk-character-count__message--disabled',\n      !this.isOverThreshold()\n    )\n\n    // Update styles\n    if (!this.$errorMessage) {\n      // Only toggle the textarea error class if there isn't an error message\n      // already, as it may be unrelated to the limit (eg: allowed characters)\n      // and would set the border colour back to black.\n      this.$textarea.classList.toggle('govuk-textarea--error', isError)\n    }\n    this.$visibleCountMessage.classList.toggle('govuk-error-message', isError)\n    this.$visibleCountMessage.classList.toggle('govuk-hint', !isError)\n\n    // Update message\n    this.$visibleCountMessage.textContent = this.getCountMessage()\n  }\n\n  /**\n   * Update screen reader count message\n   *\n   * @private\n   */\n  updateScreenReaderCountMessage() {\n    // If over the threshold, remove the aria-hidden attribute, allowing screen\n    // readers to announce the content of the element.\n    if (this.isOverThreshold()) {\n      this.$screenReaderCountMessage.removeAttribute('aria-hidden')\n    } else {\n      this.$screenReaderCountMessage.setAttribute('aria-hidden', 'true')\n    }\n\n    // Update message\n    this.$screenReaderCountMessage.textContent = this.getCountMessage()\n  }\n\n  /**\n   * Count the number of characters (or words, if `config.maxwords` is set)\n   * in the given text, and update the component-wide count\n   *\n   * @private\n   */\n  updateCount() {\n    const text = this.$textarea.value\n\n    if (this.config.maxwords) {\n      const tokens = text.match(/\\S+/g) ?? [] // Matches consecutive non-whitespace chars\n      this.count = tokens.length\n      return\n    }\n\n    this.count = text.length\n  }\n\n  /**\n   * Get count message\n   *\n   * @private\n   * @returns {string} Status message\n   */\n  getCountMessage() {\n    const remainingNumber = this.maxLength - this.count\n    const countType = this.config.maxwords ? 'words' : 'characters'\n    return this.formatCountMessage(remainingNumber, countType)\n  }\n\n  /**\n   * Formats the message shown to users according to what's counted\n   * and how many remain\n   *\n   * @private\n   * @param {number} remainingNumber - The number of words/characaters remaining\n   * @param {string} countType - \"words\" or \"characters\"\n   * @returns {string} Status message\n   */\n  formatCountMessage(remainingNumber, countType) {\n    if (remainingNumber === 0) {\n      return this.i18n.t(`${countType}AtLimit`)\n    }\n\n    const translationKeySuffix =\n      remainingNumber < 0 ? 'OverLimit' : 'UnderLimit'\n\n    return this.i18n.t(`${countType}${translationKeySuffix}`, {\n      count: Math.abs(remainingNumber)\n    })\n  }\n\n  /**\n   * Check if count is over threshold\n   *\n   * Checks whether the value is over the configured threshold for the input.\n   * If there is no configured threshold, it is set to 0 and this function will\n   * always return true.\n   *\n   * @private\n   * @returns {boolean} true if the current count is over the config.threshold\n   *   (or no threshold is set)\n   */\n  isOverThreshold() {\n    // No threshold means we're always above threshold so save some computation\n    if (!this.config.threshold) {\n      return true\n    }\n\n    // Determine the remaining number of characters/words\n    const currentLength = this.count\n    const maxLength = this.maxLength\n\n    const thresholdValue = (maxLength * this.config.threshold) / 100\n\n    return thresholdValue <= currentLength\n  }\n\n  /**\n   * Name for the component used when initialising using data-module attributes.\n   */\n  static moduleName = 'govuk-character-count'\n\n  /**\n   * Character count default config\n   *\n   * @see {@link CharacterCountConfig}\n   * @constant\n   * @type {CharacterCountConfig}\n   */\n  static defaults = Object.freeze({\n    threshold: 0,\n    i18n: {\n      // Characters\n      charactersUnderLimit: {\n        one: 'You have %{count} character remaining',\n        other: 'You have %{count} characters remaining'\n      },\n      charactersAtLimit: 'You have 0 characters remaining',\n      charactersOverLimit: {\n        one: 'You have %{count} character too many',\n        other: 'You have %{count} characters too many'\n      },\n      // Words\n      wordsUnderLimit: {\n        one: 'You have %{count} word remaining',\n        other: 'You have %{count} words remaining'\n      },\n      wordsAtLimit: 'You have 0 words remaining',\n      wordsOverLimit: {\n        one: 'You have %{count} word too many',\n        other: 'You have %{count} words too many'\n      },\n      textareaDescription: {\n        other: ''\n      }\n    }\n  })\n\n  /**\n   * Character count config schema\n   *\n   * @constant\n   * @satisfies {Schema<CharacterCountConfig>}\n   */\n  static schema = Object.freeze({\n    properties: {\n      i18n: { type: 'object' },\n      maxwords: { type: 'number' },\n      maxlength: { type: 'number' },\n      threshold: { type: 'number' }\n    },\n    anyOf: [\n      {\n        required: ['maxwords'],\n        errorMessage: 'Either \"maxlength\" or \"maxwords\" must be provided'\n      },\n      {\n        required: ['maxlength'],\n        errorMessage: 'Either \"maxlength\" or \"maxwords\" must be provided'\n      }\n    ]\n  })\n}\n\n/**\n * Character count config\n *\n * @see {@link CharacterCount.defaults}\n * @typedef {object} CharacterCountConfig\n * @property {number} [maxlength] - The maximum number of characters.\n *   If maxwords is provided, the maxlength option will be ignored.\n * @property {number} [maxwords] - The maximum number of words. If maxwords is\n *   provided, the maxlength option will be ignored.\n * @property {number} [threshold=0] - The percentage value of the limit at\n *   which point the count message is displayed. If this attribute is set, the\n *   count message will be hidden by default.\n * @property {CharacterCountTranslations} [i18n=CharacterCount.defaults.i18n] - Character count translations\n */\n\n/**\n * Character count translations\n *\n * @see {@link CharacterCount.defaults.i18n}\n * @typedef {object} CharacterCountTranslations\n *\n * Messages shown to users as they type. It provides feedback on how many words\n * or characters they have remaining or if they are over the limit. This also\n * includes a message used as an accessible description for the textarea.\n * @property {TranslationPluralForms} [charactersUnderLimit] - Message displayed\n *   when the number of characters is under the configured maximum, `maxlength`.\n *   This message is displayed visually and through assistive technologies. The\n *   component will replace the `%{count}` placeholder with the number of\n *   remaining characters. This is a [pluralised list of\n *   messages](https://frontend.design-system.service.gov.uk/localise-govuk-frontend).\n * @property {string} [charactersAtLimit] - Message displayed when the number of\n *   characters reaches the configured maximum, `maxlength`. This message is\n *   displayed visually and through assistive technologies.\n * @property {TranslationPluralForms} [charactersOverLimit] - Message displayed\n *   when the number of characters is over the configured maximum, `maxlength`.\n *   This message is displayed visually and through assistive technologies. The\n *   component will replace the `%{count}` placeholder with the number of\n *   remaining characters. This is a [pluralised list of\n *   messages](https://frontend.design-system.service.gov.uk/localise-govuk-frontend).\n * @property {TranslationPluralForms} [wordsUnderLimit] - Message displayed when\n *   the number of words is under the configured maximum, `maxlength`. This\n *   message is displayed visually and through assistive technologies. The\n *   component will replace the `%{count}` placeholder with the number of\n *   remaining words. This is a [pluralised list of\n *   messages](https://frontend.design-system.service.gov.uk/localise-govuk-frontend).\n * @property {string} [wordsAtLimit] - Message displayed when the number of\n *   words reaches the configured maximum, `maxlength`. This message is\n *   displayed visually and through assistive technologies.\n * @property {TranslationPluralForms} [wordsOverLimit] - Message displayed when\n *   the number of words is over the configured maximum, `maxlength`. This\n *   message is displayed visually and through assistive technologies. The\n *   component will replace the `%{count}` placeholder with the number of\n *   remaining words. This is a [pluralised list of\n *   messages](https://frontend.design-system.service.gov.uk/localise-govuk-frontend).\n * @property {TranslationPluralForms} [textareaDescription] - Message made\n *   available to assistive technologies, if none is already present in the\n *   HTML, to describe that the component accepts only a limited amount of\n *   content. It is visible on the page when JavaScript is unavailable. The\n *   component will replace the `%{count}` placeholder with the value of the\n *   `maxlength` or `maxwords` parameter.\n */\n\n/**\n * @import { Schema } from '../../common/configuration.mjs'\n * @import { TranslationPluralForms } from '../../i18n.mjs'\n */\n","import { Component } from '../../component.mjs'\nimport { ElementError } from '../../errors/index.mjs'\n\n/**\n * Checkboxes component\n *\n * @preserve\n */\nexport class Checkboxes extends Component {\n  /** @private */\n  $inputs\n\n  /**\n   * Checkboxes can be associated with a 'conditionally revealed' content block\n   * – for example, a checkbox for 'Phone' could reveal an additional form field\n   * for the user to enter their phone number.\n   *\n   * These associations are made using a `data-aria-controls` attribute, which\n   * is promoted to an aria-controls attribute during initialisation.\n   *\n   * We also need to restore the state of any conditional reveals on the page\n   * (for example if the user has navigated back), and set up event handlers to\n   * keep the reveal in sync with the checkbox state.\n   *\n   * @param {Element | null} $root - HTML element to use for checkboxes\n   */\n  constructor($root) {\n    super($root)\n\n    const $inputs = this.$root.querySelectorAll('input[type=\"checkbox\"]')\n    if (!$inputs.length) {\n      throw new ElementError({\n        component: Checkboxes,\n        identifier: 'Form inputs (`<input type=\"checkbox\">`)'\n      })\n    }\n\n    this.$inputs = $inputs\n\n    this.$inputs.forEach(($input) => {\n      const targetId = $input.getAttribute('data-aria-controls')\n\n      // Skip radios without data-aria-controls attributes\n      if (!targetId) {\n        return\n      }\n\n      // Throw if target conditional element does not exist.\n      if (!document.getElementById(targetId)) {\n        throw new ElementError({\n          component: Checkboxes,\n          identifier: `Conditional reveal (\\`id=\"${targetId}\"\\`)`\n        })\n      }\n\n      // Promote the data-aria-controls attribute to a aria-controls attribute\n      // so that the relationship is exposed in the AOM\n      $input.setAttribute('aria-controls', targetId)\n      $input.removeAttribute('data-aria-controls')\n    })\n\n    // When the page is restored after navigating 'back' in some browsers the\n    // state of form controls is not restored until *after* the DOMContentLoaded\n    // event is fired, so we need to sync after the pageshow event.\n    window.addEventListener('pageshow', () => this.syncAllConditionalReveals())\n\n    // Although we've set up handlers to sync state on the pageshow event, init\n    // could be called after those events have fired, for example if they are\n    // added to the page dynamically, so sync now too.\n    this.syncAllConditionalReveals()\n\n    // Handle events\n    this.$root.addEventListener('click', (event) => this.handleClick(event))\n  }\n\n  /**\n   * Sync the conditional reveal states for all checkboxes in this component.\n   *\n   * @private\n   */\n  syncAllConditionalReveals() {\n    this.$inputs.forEach(($input) =>\n      this.syncConditionalRevealWithInputState($input)\n    )\n  }\n\n  /**\n   * Sync conditional reveal with the input state\n   *\n   * Synchronise the visibility of the conditional reveal, and its accessible\n   * state, with the input's checked state.\n   *\n   * @private\n   * @param {HTMLInputElement} $input - Checkbox input\n   */\n  syncConditionalRevealWithInputState($input) {\n    const targetId = $input.getAttribute('aria-controls')\n    if (!targetId) {\n      return\n    }\n\n    const $target = document.getElementById(targetId)\n    if ($target?.classList.contains('govuk-checkboxes__conditional')) {\n      const inputIsChecked = $input.checked\n\n      $input.setAttribute('aria-expanded', inputIsChecked.toString())\n      $target.classList.toggle(\n        'govuk-checkboxes__conditional--hidden',\n        !inputIsChecked\n      )\n    }\n  }\n\n  /**\n   * Uncheck other checkboxes\n   *\n   * Find any other checkbox inputs with the same name value, and uncheck them.\n   * This is useful for when a “None of these\" checkbox is checked.\n   *\n   * @private\n   * @param {HTMLInputElement} $input - Checkbox input\n   */\n  unCheckAllInputsExcept($input) {\n    const allInputsWithSameName = document.querySelectorAll(\n      `input[type=\"checkbox\"][name=\"${$input.name}\"]`\n    )\n\n    allInputsWithSameName.forEach(($inputWithSameName) => {\n      const hasSameFormOwner = $input.form === $inputWithSameName.form\n      if (hasSameFormOwner && $inputWithSameName !== $input) {\n        $inputWithSameName.checked = false\n        this.syncConditionalRevealWithInputState($inputWithSameName)\n      }\n    })\n  }\n\n  /**\n   * Uncheck exclusive checkboxes\n   *\n   * Find any checkbox inputs with the same name value and the 'exclusive'\n   * behaviour, and uncheck them. This helps prevent someone checking both a\n   * regular checkbox and a \"None of these\" checkbox in the same fieldset.\n   *\n   * @private\n   * @param {HTMLInputElement} $input - Checkbox input\n   */\n  unCheckExclusiveInputs($input) {\n    const allInputsWithSameNameAndExclusiveBehaviour =\n      document.querySelectorAll(\n        `input[data-behaviour=\"exclusive\"][type=\"checkbox\"][name=\"${$input.name}\"]`\n      )\n\n    allInputsWithSameNameAndExclusiveBehaviour.forEach(($exclusiveInput) => {\n      const hasSameFormOwner = $input.form === $exclusiveInput.form\n      if (hasSameFormOwner) {\n        $exclusiveInput.checked = false\n        this.syncConditionalRevealWithInputState($exclusiveInput)\n      }\n    })\n  }\n\n  /**\n   * Click event handler\n   *\n   * Handle a click within the component root – if the click occurred on a checkbox,\n   * sync the state of any associated conditional reveal with the checkbox\n   * state.\n   *\n   * @private\n   * @param {MouseEvent} event - Click event\n   */\n  handleClick(event) {\n    const $clickedInput = event.target\n\n    // Ignore clicks on things that aren't checkbox inputs\n    if (\n      !($clickedInput instanceof HTMLInputElement) ||\n      $clickedInput.type !== 'checkbox'\n    ) {\n      return\n    }\n\n    // If the checkbox conditionally-reveals some content, sync the state\n    const hasAriaControls = $clickedInput.getAttribute('aria-controls')\n    if (hasAriaControls) {\n      this.syncConditionalRevealWithInputState($clickedInput)\n    }\n\n    // No further behaviour needed for unchecking\n    if (!$clickedInput.checked) {\n      return\n    }\n\n    // Handle 'exclusive' checkbox behaviour (ie \"None of these\")\n    const hasBehaviourExclusive =\n      $clickedInput.getAttribute('data-behaviour') === 'exclusive'\n    if (hasBehaviourExclusive) {\n      this.unCheckAllInputsExcept($clickedInput)\n    } else {\n      this.unCheckExclusiveInputs($clickedInput)\n    }\n  }\n\n  /**\n   * Name for the component used when initialising using data-module attributes.\n   */\n  static moduleName = 'govuk-checkboxes'\n}\n","import { ConfigurableComponent } from '../../common/configuration.mjs'\nimport { setFocus } from '../../common/index.mjs'\n\n/**\n * Error summary component\n *\n * Takes focus on initialisation for accessible announcement, unless disabled in\n * configuration.\n *\n * @preserve\n * @augments ConfigurableComponent<ErrorSummaryConfig>\n */\nexport class ErrorSummary extends ConfigurableComponent {\n  /**\n   * @param {Element | null} $root - HTML element to use for error summary\n   * @param {ErrorSummaryConfig} [config] - Error summary config\n   */\n  constructor($root, config = {}) {\n    super($root, config)\n\n    /**\n     * Focus the error summary\n     */\n    if (!this.config.disableAutoFocus) {\n      setFocus(this.$root)\n    }\n\n    this.$root.addEventListener('click', (event) => this.handleClick(event))\n  }\n\n  /**\n   * Click event handler\n   *\n   * @private\n   * @param {MouseEvent} event - Click event\n   */\n  handleClick(event) {\n    const $target = event.target\n    if ($target && this.focusTarget($target)) {\n      event.preventDefault()\n    }\n  }\n\n  /**\n   * Focus the target element\n   *\n   * By default, the browser will scroll the target into view. Because our\n   * labels or legends appear above the input, this means the user will be\n   * presented with an input without any context, as the label or legend will be\n   * off the top of the screen.\n   *\n   * Manually handling the click event, scrolling the question into view and\n   * then focussing the element solves this.\n   *\n   * This also results in the label and/or legend being announced correctly in\n   * NVDA (as tested in 2018.3.2) - without this only the field type is\n   * announced (e.g. \"Edit, has autocomplete\").\n   *\n   * @private\n   * @param {EventTarget} $target - Event target\n   * @returns {boolean} True if the target was able to be focussed\n   */\n  focusTarget($target) {\n    // If the element that was clicked was not a link, return early\n    if (!($target instanceof HTMLAnchorElement)) {\n      return false\n    }\n\n    const inputId = $target.hash.replace('#', '')\n    if (!inputId) {\n      return false\n    }\n\n    const $input = document.getElementById(inputId)\n    if (!$input) {\n      return false\n    }\n\n    const $legendOrLabel = this.getAssociatedLegendOrLabel($input)\n    if (!$legendOrLabel) {\n      return false\n    }\n\n    // Scroll the legend or label into view *before* calling focus on the input\n    // to avoid extra scrolling in browsers that don't support `preventScroll`\n    // (which at time of writing is most of them...)\n    $legendOrLabel.scrollIntoView()\n    $input.focus({ preventScroll: true })\n\n    return true\n  }\n\n  /**\n   * Get associated legend or label\n   *\n   * Returns the first element that exists from this list:\n   *\n   * - The `<legend>` associated with the closest `<fieldset>` ancestor, as long\n   *   as the top of it is no more than half a viewport height away from the\n   *   bottom of the input\n   * - The first `<label>` that is associated with the input using for=\"inputId\"\n   * - The closest parent `<label>`\n   *\n   * @private\n   * @param {Element} $input - The input\n   * @returns {Element | null} Associated legend or label, or null if no\n   *   associated legend or label can be found\n   */\n  getAssociatedLegendOrLabel($input) {\n    const $fieldset = $input.closest('fieldset')\n\n    if ($fieldset) {\n      const $legends = $fieldset.getElementsByTagName('legend')\n\n      if ($legends.length) {\n        const $candidateLegend = $legends[0]\n\n        // If the input type is radio or checkbox, always use the legend if\n        // there is one.\n        if (\n          $input instanceof HTMLInputElement &&\n          ($input.type === 'checkbox' || $input.type === 'radio')\n        ) {\n          return $candidateLegend\n        }\n\n        // For other input types, only scroll to the fieldset’s legend (instead\n        // of the label associated with the input) if the input would end up in\n        // the top half of the screen.\n        //\n        // This should avoid situations where the input either ends up off the\n        // screen, or obscured by a software keyboard.\n        const legendTop = $candidateLegend.getBoundingClientRect().top\n        const inputRect = $input.getBoundingClientRect()\n\n        // If the browser doesn't support Element.getBoundingClientRect().height\n        // or window.innerHeight (like IE8), bail and just link to the label.\n        if (inputRect.height && window.innerHeight) {\n          const inputBottom = inputRect.top + inputRect.height\n\n          if (inputBottom - legendTop < window.innerHeight / 2) {\n            return $candidateLegend\n          }\n        }\n      }\n    }\n\n    return (\n      document.querySelector(`label[for='${$input.getAttribute('id')}']`) ??\n      $input.closest('label')\n    )\n  }\n\n  /**\n   * Name for the component used when initialising using data-module attributes.\n   */\n  static moduleName = 'govuk-error-summary'\n\n  /**\n   * Error summary default config\n   *\n   * @see {@link ErrorSummaryConfig}\n   * @constant\n   * @type {ErrorSummaryConfig}\n   */\n  static defaults = Object.freeze({\n    disableAutoFocus: false\n  })\n\n  /**\n   * Error summary config schema\n   *\n   * @constant\n   * @satisfies {Schema<ErrorSummaryConfig>}\n   */\n  static schema = Object.freeze({\n    properties: {\n      disableAutoFocus: { type: 'boolean' }\n    }\n  })\n}\n\n/**\n * Error summary config\n *\n * @typedef {object} ErrorSummaryConfig\n * @property {boolean} [disableAutoFocus=false] - If set to `true` the error\n *   summary will not be focussed when the page loads.\n */\n\n/**\n * @import { Schema } from '../../common/configuration.mjs'\n */\n","import { ConfigurableComponent } from '../../common/configuration.mjs'\nimport { ElementError } from '../../errors/index.mjs'\nimport { I18n } from '../../i18n.mjs'\n\n/**\n * Exit this page component\n *\n * @preserve\n * @augments ConfigurableComponent<ExitThisPageConfig>\n */\nexport class ExitThisPage extends ConfigurableComponent {\n  /** @private */\n  i18n\n\n  /** @private */\n  $button\n\n  /**\n   * @private\n   * @type {HTMLAnchorElement | null}\n   */\n  $skiplinkButton = null\n\n  /**\n   * @private\n   * @type {HTMLElement | null}\n   */\n  $updateSpan = null\n\n  /**\n   * @private\n   * @type {HTMLElement | null}\n   */\n  $indicatorContainer = null\n\n  /**\n   * @private\n   * @type {HTMLElement | null}\n   */\n  $overlay = null\n\n  /** @private */\n  keypressCounter = 0\n\n  /** @private */\n  lastKeyWasModified = false\n\n  /** @private */\n  timeoutTime = 5000 // milliseconds\n\n  // Store the timeout events so that we can clear them to avoid user keypresses overlapping\n  // setTimeout returns an id that we can use to clear it with clearTimeout,\n  // hence the 'Id' suffix\n\n  /**\n   * @private\n   * @type {number | null}\n   */\n  keypressTimeoutId = null\n\n  /**\n   * @private\n   * @type {number | null}\n   */\n  timeoutMessageId = null\n\n  /**\n   * @param {Element | null} $root - HTML element that wraps the Exit This Page button\n   * @param {ExitThisPageConfig} [config] - Exit This Page config\n   */\n  constructor($root, config = {}) {\n    super($root, config)\n\n    const $button = this.$root.querySelector('.govuk-exit-this-page__button')\n    if (!($button instanceof HTMLAnchorElement)) {\n      throw new ElementError({\n        component: ExitThisPage,\n        element: $button,\n        expectedType: 'HTMLAnchorElement',\n        identifier: 'Button (`.govuk-exit-this-page__button`)'\n      })\n    }\n\n    this.i18n = new I18n(this.config.i18n)\n    this.$button = $button\n\n    const $skiplinkButton = document.querySelector(\n      '.govuk-js-exit-this-page-skiplink'\n    )\n    if ($skiplinkButton instanceof HTMLAnchorElement) {\n      this.$skiplinkButton = $skiplinkButton\n    }\n\n    this.buildIndicator()\n    this.initUpdateSpan()\n    this.initButtonClickHandler()\n\n    // Check to see if this has already been done by a previous initialisation of ExitThisPage\n    if (!('govukFrontendExitThisPageKeypress' in document.body.dataset)) {\n      document.addEventListener('keyup', this.handleKeypress.bind(this), true)\n      document.body.dataset.govukFrontendExitThisPageKeypress = 'true'\n    }\n\n    // When the page is restored after navigating 'back' in some browsers the\n    // blank overlay remains present, rendering the page unusable. Here, we check\n    // to see if it's present on page (re)load, and remove it if so.\n    window.addEventListener('pageshow', this.resetPage.bind(this))\n  }\n\n  /**\n   * Create the <span> we use for screen reader announcements.\n   *\n   * @private\n   */\n  initUpdateSpan() {\n    this.$updateSpan = document.createElement('span')\n    this.$updateSpan.setAttribute('role', 'status')\n    this.$updateSpan.className = 'govuk-visually-hidden'\n\n    this.$root.appendChild(this.$updateSpan)\n  }\n\n  /**\n   * Create button click handlers.\n   *\n   * @private\n   */\n  initButtonClickHandler() {\n    // Main EtP button\n    this.$button.addEventListener('click', this.handleClick.bind(this))\n\n    // EtP secondary link\n    if (this.$skiplinkButton) {\n      this.$skiplinkButton.addEventListener(\n        'click',\n        this.handleClick.bind(this)\n      )\n    }\n  }\n\n  /**\n   * Create the HTML for the 'three lights' indicator on the button.\n   *\n   * @private\n   */\n  buildIndicator() {\n    // Build container\n    // Putting `aria-hidden` on it as it won't contain any readable information\n    this.$indicatorContainer = document.createElement('div')\n    this.$indicatorContainer.className = 'govuk-exit-this-page__indicator'\n    this.$indicatorContainer.setAttribute('aria-hidden', 'true')\n\n    // Create three 'lights' and place them within the container\n    for (let i = 0; i < 3; i++) {\n      const $indicator = document.createElement('div')\n      $indicator.className = 'govuk-exit-this-page__indicator-light'\n      this.$indicatorContainer.appendChild($indicator)\n    }\n\n    // Append it all to the module\n    this.$button.appendChild(this.$indicatorContainer)\n  }\n\n  /**\n   * Update whether the lights are visible and which ones are lit up depending on\n   * the value of `keypressCounter`.\n   *\n   * @private\n   */\n  updateIndicator() {\n    if (!this.$indicatorContainer) {\n      return\n    }\n\n    // Show or hide the indicator container depending on keypressCounter value\n    this.$indicatorContainer.classList.toggle(\n      'govuk-exit-this-page__indicator--visible',\n      this.keypressCounter > 0\n    )\n\n    // Turn on only the indicators we want on\n    const $indicators = this.$indicatorContainer.querySelectorAll(\n      '.govuk-exit-this-page__indicator-light'\n    )\n    $indicators.forEach(($indicator, index) => {\n      $indicator.classList.toggle(\n        'govuk-exit-this-page__indicator-light--on',\n        index < this.keypressCounter\n      )\n    })\n  }\n\n  /**\n   * Initiates the redirection away from the current page.\n   * Includes the loading overlay functionality, which covers the current page with a\n   * white overlay so that the contents are not visible during the loading\n   * process. This is particularly important on slow network connections.\n   *\n   * @private\n   */\n  exitPage() {\n    if (!this.$updateSpan) {\n      return\n    }\n\n    this.$updateSpan.textContent = ''\n\n    // Blank the page\n    // As well as creating an overlay with text, we also set the body to hidden\n    // to prevent screen reader and sequential navigation users potentially\n    // navigating through the page behind the overlay during loading\n    document.body.classList.add('govuk-exit-this-page-hide-content')\n    this.$overlay = document.createElement('div')\n    this.$overlay.className = 'govuk-exit-this-page-overlay'\n    this.$overlay.setAttribute('role', 'alert')\n\n    // we do these this way round, thus incurring a second paint, because changing\n    // the element text after adding it means that screen readers pick up the\n    // announcement more reliably.\n    document.body.appendChild(this.$overlay)\n    this.$overlay.textContent = this.i18n.t('activated')\n\n    window.location.href = this.$button.href\n  }\n\n  /**\n   * Pre-activation logic for when the button is clicked/activated via mouse or\n   * pointer.\n   *\n   * We do this to differentiate it from the keyboard activation event because we\n   * need to run `e.preventDefault` as the button or skiplink are both links and we\n   * want to apply some additional logic in `exitPage` before navigating.\n   *\n   * @private\n   * @param {MouseEvent} event - mouse click event\n   */\n  handleClick(event) {\n    event.preventDefault()\n    this.exitPage()\n  }\n\n  /**\n   * Logic for the 'quick escape' keyboard sequence functionality (pressing the\n   * Shift key three times without interruption, within a time limit).\n   *\n   * @private\n   * @param {KeyboardEvent} event - keyup event\n   */\n  handleKeypress(event) {\n    if (!this.$updateSpan) {\n      return\n    }\n\n    // Detect if the 'Shift' key has been pressed. We want to only do things if it\n    // was pressed by itself and not in a combination with another key—so we keep\n    // track of whether the preceding keyup had shiftKey: true on it, and if it\n    // did, we ignore the next Shift keyup event.\n    //\n    // This works because using Shift as a modifier key (e.g. pressing Shift + A)\n    // will fire TWO keyup events, one for A (with e.shiftKey: true) and the other\n    // for Shift (with e.shiftKey: false).\n    if (event.key === 'Shift' && !this.lastKeyWasModified) {\n      this.keypressCounter += 1\n\n      // Update the indicator before the below if statement can reset it back to 0\n      this.updateIndicator()\n\n      // Clear the timeout for the keypress timeout message clearing itself\n      if (this.timeoutMessageId) {\n        window.clearTimeout(this.timeoutMessageId)\n        this.timeoutMessageId = null\n      }\n\n      if (this.keypressCounter >= 3) {\n        this.keypressCounter = 0\n\n        if (this.keypressTimeoutId) {\n          window.clearTimeout(this.keypressTimeoutId)\n          this.keypressTimeoutId = null\n        }\n\n        this.exitPage()\n      } else {\n        if (this.keypressCounter === 1) {\n          this.$updateSpan.textContent = this.i18n.t('pressTwoMoreTimes')\n        } else {\n          this.$updateSpan.textContent = this.i18n.t('pressOneMoreTime')\n        }\n      }\n\n      this.setKeypressTimer()\n    } else if (this.keypressTimeoutId) {\n      // If the user pressed any key other than 'Shift', after having pressed\n      // 'Shift' and activating the timer, stop and reset the timer.\n      this.resetKeypressTimer()\n    }\n\n    // Keep track of whether the Shift modifier key was held during this keypress\n    this.lastKeyWasModified = event.shiftKey\n  }\n\n  /**\n   * Starts the 'quick escape' keyboard sequence timer.\n   *\n   * This can be invoked several times. We want this to be possible so that the\n   * timer is restarted each time the shortcut key is pressed (e.g. the user has\n   * up to n seconds between each keypress, rather than n seconds to invoke the\n   * entire sequence.)\n   *\n   * @private\n   */\n  setKeypressTimer() {\n    // Clear any existing timeout. This is so only one timer is running even if\n    // there are multiple keypresses in quick succession.\n    if (this.keypressTimeoutId) {\n      window.clearTimeout(this.keypressTimeoutId)\n    }\n\n    // Set a fresh timeout\n    this.keypressTimeoutId = window.setTimeout(\n      this.resetKeypressTimer.bind(this),\n      this.timeoutTime\n    )\n  }\n\n  /**\n   * Stops and resets the 'quick escape' keyboard sequence timer.\n   *\n   * @private\n   */\n  resetKeypressTimer() {\n    if (!this.$updateSpan) {\n      return\n    }\n\n    if (this.keypressTimeoutId) {\n      window.clearTimeout(this.keypressTimeoutId)\n      this.keypressTimeoutId = null\n    }\n\n    const $updateSpan = this.$updateSpan\n\n    this.keypressCounter = 0\n    $updateSpan.textContent = this.i18n.t('timedOut')\n\n    this.timeoutMessageId = window.setTimeout(() => {\n      $updateSpan.textContent = ''\n    }, this.timeoutTime)\n\n    this.updateIndicator()\n  }\n\n  /**\n   * Reset the page using the EtP button\n   *\n   * We use this in situations where a user may re-enter a page using the browser\n   * back button. In these cases, the browser can choose to restore the state of\n   * the page as it was previously, including restoring the 'ghost page' overlay,\n   * the announcement span having it's role set to \"alert\" and the keypress\n   * indicator still active, leaving the page in an unusable state.\n   *\n   * By running this check when the page is shown, we can programatically restore\n   * the page and the component to a \"default\" state\n   *\n   * @private\n   */\n  resetPage() {\n    // If an overlay is set, remove it and reset the value\n    document.body.classList.remove('govuk-exit-this-page-hide-content')\n\n    if (this.$overlay) {\n      this.$overlay.remove()\n      this.$overlay = null\n    }\n\n    // Ensure the announcement span's role is status, not alert and clear any text\n    if (this.$updateSpan) {\n      this.$updateSpan.setAttribute('role', 'status')\n      this.$updateSpan.textContent = ''\n    }\n\n    // Sync the keypress indicator lights\n    this.updateIndicator()\n\n    // If the timeouts are active, clear them\n    if (this.keypressTimeoutId) {\n      window.clearTimeout(this.keypressTimeoutId)\n    }\n\n    if (this.timeoutMessageId) {\n      window.clearTimeout(this.timeoutMessageId)\n    }\n  }\n\n  /**\n   * Name for the component used when initialising using data-module attributes.\n   */\n  static moduleName = 'govuk-exit-this-page'\n\n  /**\n   * Exit this page default config\n   *\n   * @see {@link ExitThisPageConfig}\n   * @constant\n   * @type {ExitThisPageConfig}\n   */\n  static defaults = Object.freeze({\n    i18n: {\n      activated: 'Loading.',\n      timedOut: 'Exit this page expired.',\n      pressTwoMoreTimes: 'Shift, press 2 more times to exit.',\n      pressOneMoreTime: 'Shift, press 1 more time to exit.'\n    }\n  })\n\n  /**\n   * Exit this page config schema\n   *\n   * @constant\n   * @satisfies {Schema<ExitThisPageConfig>}\n   */\n  static schema = Object.freeze({\n    properties: {\n      i18n: { type: 'object' }\n    }\n  })\n}\n\n/**\n * Exit this Page config\n *\n * @see {@link ExitThisPage.defaults}\n * @typedef {object} ExitThisPageConfig\n * @property {ExitThisPageTranslations} [i18n=ExitThisPage.defaults.i18n] - Exit this page translations\n */\n\n/**\n * Exit this Page translations\n *\n * @see {@link ExitThisPage.defaults.i18n}\n * @typedef {object} ExitThisPageTranslations\n *\n * Messages used by the component programatically inserted text, including\n * overlay text and screen reader announcements.\n * @property {string} [activated] - Screen reader announcement for when EtP\n *   keypress functionality has been successfully activated.\n * @property {string} [timedOut] - Screen reader announcement for when the EtP\n *   keypress functionality has timed out.\n * @property {string} [pressTwoMoreTimes] - Screen reader announcement informing\n *   the user they must press the activation key two more times.\n * @property {string} [pressOneMoreTime] - Screen reader announcement informing\n *   the user they must press the activation key one more time.\n */\n\n/**\n * @import { Schema } from '../../common/configuration.mjs'\n */\n","import { closestAttributeValue } from '../../common/closest-attribute-value.mjs'\nimport { ConfigurableComponent } from '../../common/configuration.mjs'\nimport { formatErrorMessage } from '../../common/index.mjs'\nimport { ElementError } from '../../errors/index.mjs'\nimport { I18n } from '../../i18n.mjs'\n\n/**\n * File upload component\n *\n * @preserve\n * @augments ConfigurableComponent<FileUploadConfig>\n */\nexport class FileUpload extends ConfigurableComponent {\n  /**\n   * @private\n   * @type {HTMLFileInputElement}\n   */\n  $input\n\n  /**\n   * @private\n   */\n  $button\n\n  /**\n   * @private\n   */\n  $status\n\n  /** @private */\n  i18n\n\n  /** @private */\n  id\n\n  /** @private */\n  $announcements\n\n  /**\n   * @private\n   * @type {boolean | undefined}\n   */\n  enteredAnotherElement\n\n  /**\n   * @param {Element | null} $root - File input element\n   * @param {FileUploadConfig} [config] - File Upload config\n   */\n  constructor($root, config = {}) {\n    super($root, config)\n\n    const $input = this.$root.querySelector('input')\n\n    if ($input === null) {\n      throw new ElementError({\n        component: FileUpload,\n        identifier: 'File inputs (`<input type=\"file\">`)'\n      })\n    }\n\n    if ($input.type !== 'file') {\n      throw new ElementError(\n        formatErrorMessage(\n          FileUpload,\n          'File input (`<input type=\"file\">`) attribute (`type`) is not `file`'\n        )\n      )\n    }\n\n    this.$input = /** @type {HTMLFileInputElement} */ ($input)\n\n    if (!this.$input.id) {\n      throw new ElementError({\n        component: FileUpload,\n        identifier: 'File input (`<input type=\"file\">`) attribute (`id`)'\n      })\n    }\n\n    this.id = this.$input.id\n\n    this.i18n = new I18n(this.config.i18n, {\n      // Read the fallback if necessary rather than have it set in the defaults\n      locale: closestAttributeValue(this.$root, 'lang')\n    })\n\n    const $label = this.findLabel()\n    // Add an ID to the label if it doesn't have one already\n    // so it can be referenced by `aria-labelledby`\n    if (!$label.id) {\n      $label.id = `${this.id}-label`\n    }\n\n    // we need to copy the 'id' of the root element\n    // to the new button replacement element\n    // so that focus will work in the error summary\n    this.$input.id = `${this.id}-input`\n\n    // Hide the native input\n    this.$input.setAttribute('hidden', 'true')\n\n    // Create the file selection button\n    const $button = document.createElement('button')\n    $button.classList.add('govuk-file-upload-button')\n    $button.type = 'button'\n    $button.id = this.id\n    $button.classList.add('govuk-file-upload-button--empty')\n\n    // Copy `aria-describedby` if present so hints and errors\n    // are associated to the `<button>`\n    const ariaDescribedBy = this.$input.getAttribute('aria-describedby')\n    if (ariaDescribedBy) {\n      $button.setAttribute('aria-describedby', ariaDescribedBy)\n    }\n\n    // Create status element that shows what/how many files are selected\n    const $status = document.createElement('span')\n    $status.className = 'govuk-body govuk-file-upload-button__status'\n    $status.setAttribute('aria-live', 'polite')\n    $status.innerText = this.i18n.t('noFileChosen')\n\n    $button.appendChild($status)\n\n    const commaSpan = document.createElement('span')\n    commaSpan.className = 'govuk-visually-hidden'\n    commaSpan.innerText = ', '\n    commaSpan.id = `${this.id}-comma`\n\n    $button.appendChild(commaSpan)\n\n    const containerSpan = document.createElement('span')\n    containerSpan.className =\n      'govuk-file-upload-button__pseudo-button-container'\n\n    const buttonSpan = document.createElement('span')\n    buttonSpan.className =\n      'govuk-button govuk-button--secondary govuk-file-upload-button__pseudo-button'\n    buttonSpan.innerText = this.i18n.t('chooseFilesButton')\n\n    containerSpan.appendChild(buttonSpan)\n\n    // Add a space so the button and instruction read correctly\n    // when CSS is disabled\n    containerSpan.insertAdjacentText('beforeend', ' ')\n\n    const instructionSpan = document.createElement('span')\n    instructionSpan.className =\n      'govuk-body govuk-file-upload-button__instruction'\n    instructionSpan.innerText = this.i18n.t('dropInstruction')\n\n    containerSpan.appendChild(instructionSpan)\n\n    $button.appendChild(containerSpan)\n    $button.setAttribute(\n      'aria-labelledby',\n      `${$label.id} ${commaSpan.id} ${$button.id}`\n    )\n    $button.addEventListener('click', this.onClick.bind(this))\n    $button.addEventListener('dragover', (event) => {\n      // prevent default to allow drop\n      event.preventDefault()\n    })\n\n    // Assemble these all together\n    this.$root.insertAdjacentElement('afterbegin', $button)\n\n    this.$input.setAttribute('tabindex', '-1')\n    this.$input.setAttribute('aria-hidden', 'true')\n\n    // Make all these new variables available to the module\n    this.$button = $button\n    this.$status = $status\n\n    // Bind change event to the underlying input\n    this.$input.addEventListener('change', this.onChange.bind(this))\n\n    // Synchronise the `disabled` state between the button and underlying input\n    this.updateDisabledState()\n    this.observeDisabledState()\n\n    // Handle drop zone visibility\n    // A live region to announce when users enter or leave the drop zone\n    this.$announcements = document.createElement('span')\n    this.$announcements.classList.add('govuk-file-upload-announcements')\n    this.$announcements.classList.add('govuk-visually-hidden')\n    this.$announcements.setAttribute('aria-live', 'assertive')\n    this.$root.insertAdjacentElement('afterend', this.$announcements)\n\n    // if there is no CSS and input is hidden\n    // button will need to handle drop event\n    this.$button.addEventListener('drop', this.onDrop.bind(this))\n\n    // While user is dragging, it gets a little more complex because of Safari.\n    // Safari doesn't fill `relatedTarget` on `dragleave` (nor `dragenter`).\n    // This means we can't use `relatedTarget` to:\n    // - check if the user is still within the wrapper\n    //   (`relatedTarget` being a descendant of the wrapper)\n    // - check if the user is still over the viewport\n    //   (`relatedTarget` being null if outside)\n\n    // Thanks to `dragenter` bubbling, we can listen on the `document` with a\n    // single function and update the visibility based on whether we entered a\n    // node inside or outside the wrapper.\n    document.addEventListener(\n      'dragenter',\n      this.updateDropzoneVisibility.bind(this)\n    )\n\n    // To detect if we're outside the document, we can track if there was a\n    // `dragenter` event preceding a `dragleave`. If there wasn't, this means\n    // we're outside the document.\n    //\n    // The order of events is guaranteed by the HTML specs:\n    // https://html.spec.whatwg.org/multipage/dnd.html#drag-and-drop-processing-model\n    document.addEventListener('dragenter', () => {\n      this.enteredAnotherElement = true\n    })\n\n    document.addEventListener('dragleave', () => {\n      if (!this.enteredAnotherElement && !this.$button.disabled) {\n        this.hideDraggingState()\n        this.$announcements.innerText = this.i18n.t('leftDropZone')\n      }\n\n      this.enteredAnotherElement = false\n    })\n  }\n\n  /**\n   * Updates the visibility of the dropzone as users enters the various elements on the page\n   *\n   * @private\n   * @param {DragEvent} event - The `dragenter` event\n   */\n  updateDropzoneVisibility(event) {\n    if (this.$button.disabled) return\n\n    // DOM interfaces only type `event.target` as `EventTarget`\n    // so we first need to make sure it's a `Node`\n    if (event.target instanceof Node) {\n      if (this.$root.contains(event.target)) {\n        if (event.dataTransfer && this.canDrop(event.dataTransfer)) {\n          // Only update the class and make the announcement if not already visible\n          // to avoid repeated announcements on NVDA (2024.4) + Firefox (133)\n          if (\n            !this.$button.classList.contains(\n              'govuk-file-upload-button--dragging'\n            )\n          ) {\n            this.showDraggingState()\n            this.$announcements.innerText = this.i18n.t('enteredDropZone')\n          }\n        }\n      } else {\n        // Only hide the dropzone if it is visible to prevent announcing user\n        // left the drop zone when they enter the page but haven't reached yet\n        // the file upload component\n        if (\n          this.$button.classList.contains('govuk-file-upload-button--dragging')\n        ) {\n          this.hideDraggingState()\n          this.$announcements.innerText = this.i18n.t('leftDropZone')\n        }\n      }\n    }\n  }\n\n  /**\n   * Show the drop zone visually\n   *\n   * @private\n   */\n  showDraggingState() {\n    this.$button.classList.add('govuk-file-upload-button--dragging')\n  }\n\n  /**\n   * Hides the drop zone visually\n   *\n   * @private\n   */\n  hideDraggingState() {\n    this.$button.classList.remove('govuk-file-upload-button--dragging')\n  }\n\n  /**\n   * Handles user dropping on the component\n   *\n   * @private\n   * @param {DragEvent} event - The `dragenter` event\n   */\n  onDrop(event) {\n    event.preventDefault()\n\n    if (event.dataTransfer && this.canFillInput(event.dataTransfer)) {\n      this.$input.files = event.dataTransfer.files\n\n      // Dispatch a `change` event so external code that would rely on the `<input>`\n      // dispatching an event when files are dropped still work.\n      // Use a `CustomEvent` so our events are distinguishable from browser's native events\n      this.$input.dispatchEvent(new CustomEvent('change'))\n\n      this.hideDraggingState()\n    }\n  }\n\n  /**\n   * Confirms if enhanced `<input>` can be filled with files from the given `DataTransfer`\n   *\n   * @param {DataTransfer} dataTransfer - The `DataTransfer` being dropped\n   * @returns {boolean} - true if the `DataTransfer` contains files, in number matching the `multiple` attribute of the original `<input>`\n   * @private\n   */\n  canFillInput(dataTransfer) {\n    return this.matchesInputCapacity(dataTransfer.files.length)\n  }\n\n  /**\n   * Confirms if the content of a `DataTransfer` dragged over component can be dropped\n   *\n   * Unfortunately, there's a certain level of uncertainty in Safari which does not\n   * even provide a list of `items` while dragging (and seems to even miss the `types` sometimes)\n   *\n   * @param {DataTransfer} dataTransfer - The `DataTransfer` being dragged\n   * @returns {boolean} - true if the `DataTransfer` looks OK for filling the input, false otherwise\n   * @private\n   */\n  canDrop(dataTransfer) {\n    // If the browser is kind enough to give a list of items, we'll use that as source of truth\n    if (dataTransfer.items.length) {\n      return this.matchesInputCapacity(countFileItems(dataTransfer.items))\n    }\n\n    // If we have some type information, we'll use that\n    if (dataTransfer.types.length) {\n      return dataTransfer.types.includes('Files')\n    }\n\n    // If we have nothing to go by, we'll assume things are OK\n    // until we have a more accurate picture inside the `drop` event\n    return true\n  }\n\n  /**\n   * Confirms the given number of files matches that allowed by the enhanced `<input>`\n   *\n   * @param {number} numberOfFiles - The number of files\n   * @returns {boolean} - `true` if the enhanced `<input>` can accept that number of files\n   * @private\n   */\n  matchesInputCapacity(numberOfFiles) {\n    if (this.$input.multiple) {\n      return numberOfFiles > 0\n    }\n\n    return numberOfFiles === 1\n  }\n\n  /**\n   * Check if the value of the underlying input has changed\n   *\n   * @private\n   */\n  onChange() {\n    const fileCount = this.$input.files.length\n\n    if (fileCount === 0) {\n      // If there are no files, show the default selection text\n      this.$status.innerText = this.i18n.t('noFileChosen')\n      this.$button.classList.add('govuk-file-upload-button--empty')\n    } else {\n      if (\n        // If there is 1 file, just show the file name\n        fileCount === 1\n      ) {\n        this.$status.innerText = this.$input.files[0].name\n      } else {\n        // Otherwise, tell the user how many files are selected\n        this.$status.innerText = this.i18n.t('multipleFilesChosen', {\n          count: fileCount\n        })\n      }\n\n      this.$button.classList.remove('govuk-file-upload-button--empty')\n    }\n  }\n\n  /**\n   * Looks up the `<label>` element associated to the field\n   *\n   * @private\n   * @returns {HTMLElement} The `<label>` element associated to the field\n   * @throws {ElementError} If the `<label>` cannot be found\n   */\n  findLabel() {\n    // Use `label` in the selector so TypeScript knows the type fo `HTMLElement`\n    const $label = document.querySelector(`label[for=\"${this.$input.id}\"]`)\n\n    if (!$label) {\n      throw new ElementError({\n        component: FileUpload,\n        identifier: `Field label (\\`<label for=${this.$input.id}>\\`)`\n      })\n    }\n\n    return $label\n  }\n\n  /**\n   * When the button is clicked, emulate clicking the actual, hidden file input\n   *\n   * @private\n   */\n  onClick() {\n    this.$input.click()\n  }\n\n  /**\n   * Create a mutation observer to check if the input's attributes altered.\n   *\n   * @private\n   */\n  observeDisabledState() {\n    const observer = new MutationObserver((mutationList) => {\n      for (const mutation of mutationList) {\n        if (\n          mutation.type === 'attributes' &&\n          mutation.attributeName === 'disabled'\n        ) {\n          this.updateDisabledState()\n        }\n      }\n    })\n\n    observer.observe(this.$input, {\n      attributes: true\n    })\n  }\n\n  /**\n   * Synchronise the `disabled` state between the input and replacement button.\n   *\n   * @private\n   */\n  updateDisabledState() {\n    this.$button.disabled = this.$input.disabled\n\n    this.$root.classList.toggle(\n      'govuk-drop-zone--disabled',\n      this.$button.disabled\n    )\n  }\n\n  /**\n   * Name for the component used when initialising using data-module attributes.\n   */\n  static moduleName = 'govuk-file-upload'\n\n  /**\n   * File upload default config\n   *\n   * @see {@link FileUploadConfig}\n   * @constant\n   * @type {FileUploadConfig}\n   */\n  static defaults = Object.freeze({\n    i18n: {\n      chooseFilesButton: 'Choose file',\n      dropInstruction: 'or drop file',\n      noFileChosen: 'No file chosen',\n      multipleFilesChosen: {\n        // the 'one' string isn't used as the component displays the filename\n        // instead, however it's here for coverage's sake\n        one: '%{count} file chosen',\n        other: '%{count} files chosen'\n      },\n      enteredDropZone: 'Entered drop zone',\n      leftDropZone: 'Left drop zone'\n    }\n  })\n\n  /**\n   * File upload config schema\n   *\n   * @constant\n   * @satisfies {Schema<FileUploadConfig>}\n   */\n  static schema = Object.freeze({\n    properties: {\n      i18n: { type: 'object' }\n    }\n  })\n}\n\n/**\n * Counts the number of `DataTransferItem` whose kind is `file`\n *\n * @param {DataTransferItemList} list - The list\n * @returns {number} - The number of items whose kind is `file` in the list\n */\nfunction countFileItems(list) {\n  let result = 0\n\n  // `DataTransferItemList` is not iterable\n  // eslint-disable-next-line @typescript-eslint/prefer-for-of\n  for (let i = 0; i < list.length; i++) {\n    if (list[i].kind === 'file') {\n      result++\n    }\n  }\n  return result\n}\n\n/**\n * @typedef {HTMLInputElement & {files: FileList}} HTMLFileInputElement\n */\n\n/**\n * File upload config\n *\n * @see {@link FileUpload.defaults}\n * @typedef {object} FileUploadConfig\n * @property {FileUploadTranslations} [i18n=FileUpload.defaults.i18n] - File upload translations\n */\n\n/**\n * File upload translations\n *\n * @see {@link FileUpload.defaults.i18n}\n * @typedef {object} FileUploadTranslations\n *\n * Messages used by the component\n * @property {string} [chooseFile] - The text of the button that opens the file picker\n * @property {string} [dropInstruction] - The text informing users they can drop files\n * @property {TranslationPluralForms} [multipleFilesChosen] - The text displayed when multiple files\n *   have been chosen by the user\n * @property {string} [noFileChosen] - The text to displayed when no file has been chosen by the user\n * @property {string} [enteredDropZone] - The text announced by assistive technology\n *   when user drags files and enters the drop zone\n * @property {string} [leftDropZone] - The text announced by assistive technology\n *   when user drags files and leaves the drop zone without dropping\n */\n\n/**\n * @import { Schema } from '../../common/configuration.mjs'\n * @import { TranslationPluralForms } from '../../i18n.mjs'\n */\n","import { ConfigurableComponent } from '../../common/configuration.mjs'\nimport { setFocus } from '../../common/index.mjs'\n\n/**\n * Notification Banner component\n *\n * @preserve\n * @augments ConfigurableComponent<NotificationBannerConfig>\n */\nexport class NotificationBanner extends ConfigurableComponent {\n  /**\n   * @param {Element | null} $root - HTML element to use for notification banner\n   * @param {NotificationBannerConfig} [config] - Notification banner config\n   */\n  constructor($root, config = {}) {\n    super($root, config)\n\n    /**\n     * Focus the notification banner\n     *\n     * If `role=\"alert\"` is set, focus the element to help some assistive\n     * technologies prioritise announcing it.\n     *\n     * You can turn off the auto-focus functionality by setting\n     * `data-disable-auto-focus=\"true\"` in the component HTML. You might wish to\n     * do this based on user research findings, or to avoid a clash with another\n     * element which should be focused when the page loads.\n     */\n    if (\n      this.$root.getAttribute('role') === 'alert' &&\n      !this.config.disableAutoFocus\n    ) {\n      setFocus(this.$root)\n    }\n  }\n\n  /**\n   * Name for the component used when initialising using data-module attributes.\n   */\n  static moduleName = 'govuk-notification-banner'\n\n  /**\n   * Notification banner default config\n   *\n   * @see {@link NotificationBannerConfig}\n   * @constant\n   * @type {NotificationBannerConfig}\n   */\n  static defaults = Object.freeze({\n    disableAutoFocus: false\n  })\n\n  /**\n   * Notification banner config schema\n   *\n   * @constant\n   * @satisfies {Schema<NotificationBannerConfig>}\n   */\n  static schema = Object.freeze({\n    properties: {\n      disableAutoFocus: { type: 'boolean' }\n    }\n  })\n}\n\n/**\n * Notification banner config\n *\n * @typedef {object} NotificationBannerConfig\n * @property {boolean} [disableAutoFocus=false] - If set to `true` the\n *   notification banner will not be focussed when the page loads. This only\n *   applies if the component has a `role` of `alert` – in other cases the\n *   component will not be focused on page load, regardless of this option.\n */\n\n/**\n * @import { Schema } from '../../common/configuration.mjs'\n */\n","import { closestAttributeValue } from '../../common/closest-attribute-value.mjs'\nimport { ConfigurableComponent } from '../../common/configuration.mjs'\nimport { ElementError } from '../../errors/index.mjs'\nimport { I18n } from '../../i18n.mjs'\n\n/**\n * Password input component\n *\n * @preserve\n * @augments ConfigurableComponent<PasswordInputConfig>\n */\nexport class PasswordInput extends ConfigurableComponent {\n  /** @private */\n  i18n\n\n  /**\n   * @private\n   * @type {HTMLInputElement}\n   */\n  $input\n\n  /**\n   * @private\n   * @type {HTMLButtonElement}\n   */\n  $showHideButton\n\n  /** @private */\n  $screenReaderStatusMessage\n\n  /**\n   * @param {Element | null} $root - HTML element to use for password input\n   * @param {PasswordInputConfig} [config] - Password input config\n   */\n  constructor($root, config = {}) {\n    super($root, config)\n\n    const $input = this.$root.querySelector('.govuk-js-password-input-input')\n    if (!($input instanceof HTMLInputElement)) {\n      throw new ElementError({\n        component: PasswordInput,\n        element: $input,\n        expectedType: 'HTMLInputElement',\n        identifier: 'Form field (`.govuk-js-password-input-input`)'\n      })\n    }\n\n    if ($input.type !== 'password') {\n      throw new ElementError(\n        'Password input: Form field (`.govuk-js-password-input-input`) must be of type `password`.'\n      )\n    }\n\n    const $showHideButton = this.$root.querySelector(\n      '.govuk-js-password-input-toggle'\n    )\n    if (!($showHideButton instanceof HTMLButtonElement)) {\n      throw new ElementError({\n        component: PasswordInput,\n        element: $showHideButton,\n        expectedType: 'HTMLButtonElement',\n        identifier: 'Button (`.govuk-js-password-input-toggle`)'\n      })\n    }\n\n    if ($showHideButton.type !== 'button') {\n      throw new ElementError(\n        'Password input: Button (`.govuk-js-password-input-toggle`) must be of type `button`.'\n      )\n    }\n\n    this.$input = $input\n    this.$showHideButton = $showHideButton\n\n    this.i18n = new I18n(this.config.i18n, {\n      // Read the fallback if necessary rather than have it set in the defaults\n      locale: closestAttributeValue(this.$root, 'lang')\n    })\n\n    // Show the toggle button element\n    this.$showHideButton.removeAttribute('hidden')\n\n    // Create and append the status text for screen readers.\n    // This is injected between the input and button so that users get a sensible reading order if\n    // moving through the page content linearly:\n    // [password input] -> [your password is visible/hidden] -> [show/hide password]\n    const $screenReaderStatusMessage = document.createElement('div')\n    $screenReaderStatusMessage.className =\n      'govuk-password-input__sr-status govuk-visually-hidden'\n    $screenReaderStatusMessage.setAttribute('aria-live', 'polite')\n    this.$screenReaderStatusMessage = $screenReaderStatusMessage\n    this.$input.insertAdjacentElement('afterend', $screenReaderStatusMessage)\n\n    // Bind toggle button\n    this.$showHideButton.addEventListener('click', this.toggle.bind(this))\n\n    // Bind event to revert the password visibility to hidden\n    if (this.$input.form) {\n      this.$input.form.addEventListener('submit', () => this.hide())\n    }\n\n    // If the page is restored from bfcache and the password is visible, hide it again\n    window.addEventListener('pageshow', (event) => {\n      if (event.persisted && this.$input.type !== 'password') {\n        this.hide()\n      }\n    })\n\n    // Default the component to having the password hidden.\n    this.hide()\n  }\n\n  /**\n   * Toggle the visibility of the password input\n   *\n   * @private\n   * @param {MouseEvent} event - Click event\n   */\n  toggle(event) {\n    event.preventDefault()\n\n    // If on this click, the field is type=\"password\", show the value\n    if (this.$input.type === 'password') {\n      this.show()\n      return\n    }\n\n    // Otherwise, hide it\n    // Being defensive - hiding should always be the default\n    this.hide()\n  }\n\n  /**\n   * Show the password input value in plain text.\n   *\n   * @private\n   */\n  show() {\n    this.setType('text')\n  }\n\n  /**\n   * Hide the password input value.\n   *\n   * @private\n   */\n  hide() {\n    this.setType('password')\n  }\n\n  /**\n   * Set the password input type\n   *\n   * @param {'text' | 'password'} type - Input type\n   * @private\n   */\n  setType(type) {\n    if (type === this.$input.type) {\n      return\n    }\n\n    // Update input type\n    this.$input.setAttribute('type', type)\n\n    const isHidden = type === 'password'\n    const prefixButton = isHidden ? 'show' : 'hide'\n    const prefixStatus = isHidden ? 'passwordHidden' : 'passwordShown'\n\n    // Update button text\n    this.$showHideButton.innerText = this.i18n.t(`${prefixButton}Password`)\n\n    // Update button aria-label\n    this.$showHideButton.setAttribute(\n      'aria-label',\n      this.i18n.t(`${prefixButton}PasswordAriaLabel`)\n    )\n\n    // Update status change text\n    this.$screenReaderStatusMessage.innerText = this.i18n.t(\n      `${prefixStatus}Announcement`\n    )\n  }\n\n  /**\n   * Name for the component used when initialising using data-module attributes.\n   */\n  static moduleName = 'govuk-password-input'\n\n  /**\n   * Password input default config\n   *\n   * @see {@link PasswordInputConfig}\n   * @constant\n   * @default\n   * @type {PasswordInputConfig}\n   */\n  static defaults = Object.freeze({\n    i18n: {\n      showPassword: 'Show',\n      hidePassword: 'Hide',\n      showPasswordAriaLabel: 'Show password',\n      hidePasswordAriaLabel: 'Hide password',\n      passwordShownAnnouncement: 'Your password is visible',\n      passwordHiddenAnnouncement: 'Your password is hidden'\n    }\n  })\n\n  /**\n   * Password input config schema\n   *\n   * @constant\n   * @satisfies {Schema<PasswordInputConfig>}\n   */\n  static schema = Object.freeze({\n    properties: {\n      i18n: { type: 'object' }\n    }\n  })\n}\n\n/**\n * Password input config\n *\n * @typedef {object} PasswordInputConfig\n * @property {PasswordInputTranslations} [i18n=PasswordInput.defaults.i18n] - Password input translations\n */\n\n/**\n * Password input translations\n *\n * @see {@link PasswordInput.defaults.i18n}\n * @typedef {object} PasswordInputTranslations\n *\n * Messages displayed to the user indicating the state of the show/hide toggle.\n * @property {string} [showPassword] - Visible text of the button when the\n *   password is currently hidden. Plain text only.\n * @property {string} [hidePassword] - Visible text of the button when the\n *   password is currently visible. Plain text only.\n * @property {string} [showPasswordAriaLabel] - aria-label of the button when\n *   the password is currently hidden. Plain text only.\n * @property {string} [hidePasswordAriaLabel] - aria-label of the button when\n *   the password is currently visible. Plain text only.\n * @property {string} [passwordShownAnnouncement] - Screen reader\n *   announcement to make when the password has just become visible.\n *   Plain text only.\n * @property {string} [passwordHiddenAnnouncement] - Screen reader\n *   announcement to make when the password has just been hidden.\n *   Plain text only.\n */\n\n/**\n * @import { Schema } from '../../common/configuration.mjs'\n */\n","import { Component } from '../../component.mjs'\nimport { ElementError } from '../../errors/index.mjs'\n\n/**\n * Radios component\n *\n * @preserve\n */\nexport class Radios extends Component {\n  /** @private */\n  $inputs\n\n  /**\n   * Radios can be associated with a 'conditionally revealed' content block –\n   * for example, a radio for 'Phone' could reveal an additional form field for\n   * the user to enter their phone number.\n   *\n   * These associations are made using a `data-aria-controls` attribute, which\n   * is promoted to an aria-controls attribute during initialisation.\n   *\n   * We also need to restore the state of any conditional reveals on the page\n   * (for example if the user has navigated back), and set up event handlers to\n   * keep the reveal in sync with the radio state.\n   *\n   * @param {Element | null} $root - HTML element to use for radios\n   */\n  constructor($root) {\n    super($root)\n\n    const $inputs = this.$root.querySelectorAll('input[type=\"radio\"]')\n    if (!$inputs.length) {\n      throw new ElementError({\n        component: Radios,\n        identifier: 'Form inputs (`<input type=\"radio\">`)'\n      })\n    }\n\n    this.$inputs = $inputs\n\n    this.$inputs.forEach(($input) => {\n      const targetId = $input.getAttribute('data-aria-controls')\n\n      // Skip radios without data-aria-controls attributes\n      if (!targetId) {\n        return\n      }\n\n      // Throw if target conditional element does not exist.\n      if (!document.getElementById(targetId)) {\n        throw new ElementError({\n          component: Radios,\n          identifier: `Conditional reveal (\\`id=\"${targetId}\"\\`)`\n        })\n      }\n\n      // Promote the data-aria-controls attribute to a aria-controls attribute\n      // so that the relationship is exposed in the AOM\n      $input.setAttribute('aria-controls', targetId)\n      $input.removeAttribute('data-aria-controls')\n    })\n\n    // When the page is restored after navigating 'back' in some browsers the\n    // state of form controls is not restored until *after* the DOMContentLoaded\n    // event is fired, so we need to sync after the pageshow event.\n    window.addEventListener('pageshow', () => this.syncAllConditionalReveals())\n\n    // Although we've set up handlers to sync state on the pageshow event, init\n    // could be called after those events have fired, for example if they are\n    // added to the page dynamically, so sync now too.\n    this.syncAllConditionalReveals()\n\n    // Handle events\n    this.$root.addEventListener('click', (event) => this.handleClick(event))\n  }\n\n  /**\n   * Sync the conditional reveal states for all radio buttons in this component.\n   *\n   * @private\n   */\n  syncAllConditionalReveals() {\n    this.$inputs.forEach(($input) =>\n      this.syncConditionalRevealWithInputState($input)\n    )\n  }\n\n  /**\n   * Sync conditional reveal with the input state\n   *\n   * Synchronise the visibility of the conditional reveal, and its accessible\n   * state, with the input's checked state.\n   *\n   * @private\n   * @param {HTMLInputElement} $input - Radio input\n   */\n  syncConditionalRevealWithInputState($input) {\n    const targetId = $input.getAttribute('aria-controls')\n    if (!targetId) {\n      return\n    }\n\n    const $target = document.getElementById(targetId)\n    if ($target?.classList.contains('govuk-radios__conditional')) {\n      const inputIsChecked = $input.checked\n\n      $input.setAttribute('aria-expanded', inputIsChecked.toString())\n      $target.classList.toggle(\n        'govuk-radios__conditional--hidden',\n        !inputIsChecked\n      )\n    }\n  }\n\n  /**\n   * Click event handler\n   *\n   * Handle a click within the component root – if the click occurred on a radio, sync\n   * the state of the conditional reveal for all radio buttons in the same form\n   * with the same name (because checking one radio could have un-checked a\n   * radio under the root of another Radio component)\n   *\n   * @private\n   * @param {MouseEvent} event - Click event\n   */\n  handleClick(event) {\n    const $clickedInput = event.target\n\n    // Ignore clicks on things that aren't radio buttons\n    if (\n      !($clickedInput instanceof HTMLInputElement) ||\n      $clickedInput.type !== 'radio'\n    ) {\n      return\n    }\n\n    // We only need to consider radios with conditional reveals, which will have\n    // aria-controls attributes.\n    const $allInputs = document.querySelectorAll(\n      'input[type=\"radio\"][aria-controls]'\n    )\n\n    const $clickedInputForm = $clickedInput.form\n    const $clickedInputName = $clickedInput.name\n\n    $allInputs.forEach(($input) => {\n      const hasSameFormOwner = $input.form === $clickedInputForm\n      const hasSameName = $input.name === $clickedInputName\n\n      if (hasSameName && hasSameFormOwner) {\n        this.syncConditionalRevealWithInputState($input)\n      }\n    })\n  }\n\n  /**\n   * Name for the component used when initialising using data-module attributes.\n   */\n  static moduleName = 'govuk-radios'\n}\n","import { getBreakpoint } from '../../common/index.mjs'\nimport { Component } from '../../component.mjs'\nimport { ElementError } from '../../errors/index.mjs'\n\n/**\n * Service Navigation component\n *\n * @preserve\n */\nexport class ServiceNavigation extends Component {\n  /** @private */\n  $menuButton\n\n  /** @private */\n  $menu\n\n  /**\n   * Remember the open/closed state of the nav so we can maintain it when the\n   * screen is resized.\n   *\n   * @private\n   */\n  menuIsOpen = false\n\n  /**\n   * A global const for storing a matchMedia instance which we'll use to detect\n   * when a screen size change happens. We rely on it being null if the feature\n   * isn't available to initially apply hidden attributes\n   *\n   * @private\n   * @type {MediaQueryList | null}\n   */\n  mql = null\n\n  /**\n   * @param {Element | null} $root - HTML element to use for header\n   */\n  constructor($root) {\n    super($root)\n\n    const $menuButton = this.$root.querySelector(\n      '.govuk-js-service-navigation-toggle'\n    )\n\n    // Headers don't necessarily have a navigation. When they don't, the menu\n    // toggle won't be rendered by our macro (or may be omitted when writing\n    // plain HTML)\n    if (!$menuButton) {\n      return this\n    }\n\n    const menuId = $menuButton.getAttribute('aria-controls')\n    if (!menuId) {\n      throw new ElementError({\n        component: ServiceNavigation,\n        identifier:\n          'Navigation button (`<button class=\"govuk-js-service-navigation-toggle\">`) attribute (`aria-controls`)'\n      })\n    }\n\n    const $menu = document.getElementById(menuId)\n    if (!$menu) {\n      throw new ElementError({\n        component: ServiceNavigation,\n        element: $menu,\n        identifier: `Navigation (\\`<ul id=\"${menuId}\">\\`)`\n      })\n    }\n\n    this.$menu = $menu\n    this.$menuButton = $menuButton\n\n    this.setupResponsiveChecks()\n\n    this.$menuButton.addEventListener('click', () =>\n      this.handleMenuButtonClick()\n    )\n  }\n\n  /**\n   * Setup viewport resize check\n   *\n   * @private\n   */\n  setupResponsiveChecks() {\n    const breakpoint = getBreakpoint('tablet')\n\n    if (!breakpoint.value) {\n      throw new ElementError({\n        component: ServiceNavigation,\n        identifier: `CSS custom property (\\`${breakpoint.property}\\`) on pseudo-class \\`:root\\``\n      })\n    }\n\n    // Media query list for GOV.UK Frontend desktop breakpoint\n    this.mql = window.matchMedia(`(min-width: ${breakpoint.value})`)\n\n    // MediaQueryList.addEventListener isn't supported by Safari < 14 so we need\n    // to be able to fall back to the deprecated MediaQueryList.addListener\n    if ('addEventListener' in this.mql) {\n      this.mql.addEventListener('change', () => this.checkMode())\n    } else {\n      // @ts-expect-error Property 'addListener' does not exist\n      // eslint-disable-next-line @typescript-eslint/no-unsafe-call\n      this.mql.addListener(() => this.checkMode())\n    }\n\n    this.checkMode()\n  }\n\n  /**\n   * Sync menu state\n   *\n   * Uses the global variable menuIsOpen to correctly set the accessible and\n   * visual states of the menu and the menu button.\n   * Additionally will force the menu to be visible and the menu button to be\n   * hidden if the matchMedia is triggered to desktop.\n   *\n   * @private\n   */\n  checkMode() {\n    if (!this.mql || !this.$menu || !this.$menuButton) {\n      return\n    }\n\n    if (this.mql.matches) {\n      this.$menu.removeAttribute('hidden')\n      setAttributes(this.$menuButton, attributesForHidingButton)\n    } else {\n      removeAttributes(this.$menuButton, Object.keys(attributesForHidingButton))\n      this.$menuButton.setAttribute('aria-expanded', this.menuIsOpen.toString())\n\n      if (this.menuIsOpen) {\n        this.$menu.removeAttribute('hidden')\n      } else {\n        this.$menu.setAttribute('hidden', '')\n      }\n    }\n  }\n\n  /**\n   * Handle menu button click\n   *\n   * When the menu button is clicked, change the visibility of the menu and then\n   * sync the accessibility state and menu button state\n   *\n   * @private\n   */\n  handleMenuButtonClick() {\n    this.menuIsOpen = !this.menuIsOpen\n    this.checkMode()\n  }\n\n  /**\n   * Name for the component used when initialising using data-module attributes.\n   */\n  static moduleName = 'govuk-service-navigation'\n}\n\n/**\n * Collection of attributes that needs setting on a `<button>`\n * to fully hide it, both visually and from screen-readers,\n * and prevent its activation while hidden\n */\nconst attributesForHidingButton = {\n  hidden: '',\n  // Fix button still appearing in VoiceOver's form control's menu despite being hidden\n  // https://bugs.webkit.org/show_bug.cgi?id=300899\n  'aria-hidden': 'true'\n}\n\n/**\n * Sets a group of attributes on the given element\n *\n * @param {Element} $element - The element to set the attribute on\n * @param {{[attributeName: string]: string}} attributes - The attributes to set\n */\nfunction setAttributes($element, attributes) {\n  for (const attributeName in attributes) {\n    $element.setAttribute(attributeName, attributes[attributeName])\n  }\n}\n\n/**\n * Removes a list of attributes from the given element\n *\n * @param {Element} $element - The element to remove the attributes from\n * @param {string[]} attributeNames - The names of the attributes to remove\n */\nfunction removeAttributes($element, attributeNames) {\n  for (const attributeName of attributeNames) {\n    $element.removeAttribute(attributeName)\n  }\n}\n","import { setFocus } from '../../common/index.mjs'\nimport { Component } from '../../component.mjs'\nimport { ElementError } from '../../errors/index.mjs'\n\n/**\n * Skip link component\n *\n * @preserve\n * @augments Component<HTMLAnchorElement>\n */\nexport class SkipLink extends Component {\n  static elementType = HTMLAnchorElement\n\n  /**\n   * @param {Element | null} $root - HTML element to use for skip link\n   * @throws {ElementError} when $root is not set or the wrong type\n   * @throws {ElementError} when $root.hash does not contain a hash\n   * @throws {ElementError} when the linked element is missing or the wrong type\n   */\n  constructor($root) {\n    super($root)\n\n    const hash = this.$root.hash\n    const href = this.$root.getAttribute('href') ?? ''\n\n    // Return early for external URLs or links to other pages\n    if (\n      this.$root.origin !== window.location.origin ||\n      this.$root.pathname !== window.location.pathname\n    ) {\n      return\n    }\n\n    const linkedElementId = hash.replace('#', '')\n\n    // Check link path matching current page\n    if (!linkedElementId) {\n      throw new ElementError(\n        `Skip link: Target link (\\`href=\"${href}\"\\`) has no hash fragment`\n      )\n    }\n\n    const $linkedElement = document.getElementById(linkedElementId)\n\n    // Check for link target element\n    if (!$linkedElement) {\n      throw new ElementError({\n        component: SkipLink,\n        element: $linkedElement,\n        identifier: `Target content (\\`id=\"${linkedElementId}\"\\`)`\n      })\n    }\n\n    /**\n     * Focus the linked element on click\n     *\n     * Adds a helper CSS class to hide native focus styles,\n     * but removes it on blur to restore native focus styles\n     */\n    this.$root.addEventListener('click', () =>\n      setFocus($linkedElement, {\n        onBeforeFocus() {\n          $linkedElement.classList.add('govuk-skip-link-focused-element')\n        },\n        onBlur() {\n          $linkedElement.classList.remove('govuk-skip-link-focused-element')\n        }\n      })\n    )\n  }\n\n  /**\n   * Name for the component used when initialising using data-module attributes.\n   */\n  static moduleName = 'govuk-skip-link'\n}\n","import { getBreakpoint } from '../../common/index.mjs'\nimport { Component } from '../../component.mjs'\nimport { ElementError } from '../../errors/index.mjs'\n\n/**\n * Tabs component\n *\n * @preserve\n */\nexport class Tabs extends Component {\n  /** @private */\n  $tabs\n\n  /** @private */\n  $tabList\n\n  /** @private */\n  $tabListItems\n\n  /** @private */\n  jsHiddenClass = 'govuk-tabs__panel--hidden'\n\n  /** @private */\n  changingHash = false\n\n  /** @private */\n  boundTabClick\n\n  /** @private */\n  boundTabKeydown\n\n  /** @private */\n  boundOnHashChange\n\n  /**\n   * @private\n   * @type {MediaQueryList | null}\n   */\n  mql = null\n\n  /**\n   * @param {Element | null} $root - HTML element to use for tabs\n   */\n  constructor($root) {\n    super($root)\n\n    const $tabs = this.$root.querySelectorAll('a.govuk-tabs__tab')\n    if (!$tabs.length) {\n      throw new ElementError({\n        component: Tabs,\n        identifier: 'Links (`<a class=\"govuk-tabs__tab\">`)'\n      })\n    }\n\n    this.$tabs = $tabs\n\n    // Save bound functions so we can remove event listeners during teardown\n    this.boundTabClick = this.onTabClick.bind(this)\n    this.boundTabKeydown = this.onTabKeydown.bind(this)\n    this.boundOnHashChange = this.onHashChange.bind(this)\n\n    const $tabList = this.$root.querySelector('.govuk-tabs__list')\n    const $tabListItems = this.$root.querySelectorAll(\n      'li.govuk-tabs__list-item'\n    )\n\n    if (!$tabList) {\n      throw new ElementError({\n        component: Tabs,\n        identifier: 'List (`<ul class=\"govuk-tabs__list\">`)'\n      })\n    }\n\n    if (!$tabListItems.length) {\n      throw new ElementError({\n        component: Tabs,\n        identifier: 'List items (`<li class=\"govuk-tabs__list-item\">`)'\n      })\n    }\n\n    this.$tabList = $tabList\n    this.$tabListItems = $tabListItems\n\n    this.setupResponsiveChecks()\n  }\n\n  /**\n   * Setup viewport resize check\n   *\n   * @private\n   */\n  setupResponsiveChecks() {\n    const breakpoint = getBreakpoint('tablet')\n\n    if (!breakpoint.value) {\n      throw new ElementError({\n        component: Tabs,\n        identifier: `CSS custom property (\\`${breakpoint.property}\\`) on pseudo-class \\`:root\\``\n      })\n    }\n\n    // Media query list for GOV.UK Frontend tablet breakpoint\n    this.mql = window.matchMedia(`(min-width: ${breakpoint.value})`)\n\n    // MediaQueryList.addEventListener isn't supported by Safari < 14 so we need\n    // to be able to fall back to the deprecated MediaQueryList.addListener\n    if ('addEventListener' in this.mql) {\n      this.mql.addEventListener('change', () => this.checkMode())\n    } else {\n      // @ts-expect-error Property 'addListener' does not exist\n      // eslint-disable-next-line @typescript-eslint/no-unsafe-call\n      this.mql.addListener(() => this.checkMode())\n    }\n\n    this.checkMode()\n  }\n\n  /**\n   * Setup or teardown handler for viewport resize check\n   *\n   * @private\n   */\n  checkMode() {\n    if (this.mql?.matches) {\n      this.setup()\n    } else {\n      this.teardown()\n    }\n  }\n\n  /**\n   * Setup tab component\n   *\n   * @private\n   */\n  setup() {\n    this.$tabList.setAttribute('role', 'tablist')\n\n    this.$tabListItems.forEach(($item) => {\n      $item.setAttribute('role', 'presentation')\n    })\n\n    this.$tabs.forEach(($tab) => {\n      // Set HTML attributes\n      this.setAttributes($tab)\n\n      // Handle events\n      $tab.addEventListener('click', this.boundTabClick, true)\n      $tab.addEventListener('keydown', this.boundTabKeydown, true)\n\n      // Remove old active panels\n      this.hideTab($tab)\n    })\n\n    // Show either the active tab according to the URL's hash or the first tab\n    const $activeTab = this.getTab(window.location.hash) ?? this.$tabs[0]\n\n    this.showTab($activeTab)\n\n    // Handle hashchange events\n    window.addEventListener('hashchange', this.boundOnHashChange, true)\n  }\n\n  /**\n   * Teardown tab component\n   *\n   * @private\n   */\n  teardown() {\n    this.$tabList.removeAttribute('role')\n\n    this.$tabListItems.forEach(($item) => {\n      $item.removeAttribute('role')\n    })\n\n    this.$tabs.forEach(($tab) => {\n      // Remove events\n      $tab.removeEventListener('click', this.boundTabClick, true)\n      $tab.removeEventListener('keydown', this.boundTabKeydown, true)\n\n      // Unset HTML attributes\n      this.unsetAttributes($tab)\n    })\n\n    // Remove hashchange event handler\n    window.removeEventListener('hashchange', this.boundOnHashChange, true)\n  }\n\n  /**\n   * Handle hashchange event\n   *\n   * @private\n   * @returns {void | undefined} Returns void, or undefined when prevented\n   */\n  onHashChange() {\n    const hash = window.location.hash\n    const $tabWithHash = this.getTab(hash)\n    if (!$tabWithHash) {\n      return\n    }\n\n    // Prevent changing the hash\n    if (this.changingHash) {\n      this.changingHash = false\n      return\n    }\n\n    // Show either the active tab according to the URL's hash or the first tab\n    const $previousTab = this.getCurrentTab()\n    if (!$previousTab) {\n      return\n    }\n\n    this.hideTab($previousTab)\n    this.showTab($tabWithHash)\n    $tabWithHash.focus()\n  }\n\n  /**\n   * Hide panel for tab link\n   *\n   * @private\n   * @param {HTMLAnchorElement} $tab - Tab link\n   */\n  hideTab($tab) {\n    this.unhighlightTab($tab)\n    this.hidePanel($tab)\n  }\n\n  /**\n   * Show panel for tab link\n   *\n   * @private\n   * @param {HTMLAnchorElement} $tab - Tab link\n   */\n  showTab($tab) {\n    this.highlightTab($tab)\n    this.showPanel($tab)\n  }\n\n  /**\n   * Get tab link by hash\n   *\n   * @private\n   * @param {string} hash - Hash fragment including #\n   * @returns {HTMLAnchorElement | null} Tab link\n   */\n  getTab(hash) {\n    return this.$root.querySelector(`a.govuk-tabs__tab[href=\"${hash}\"]`)\n  }\n\n  /**\n   * Set tab link and panel attributes\n   *\n   * @private\n   * @param {HTMLAnchorElement} $tab - Tab link\n   */\n  setAttributes($tab) {\n    const panelId = $tab.hash.replace('#', '')\n    if (!panelId) {\n      return\n    }\n\n    // Set tab attributes\n    $tab.setAttribute('id', `tab_${panelId}`)\n    $tab.setAttribute('role', 'tab')\n    $tab.setAttribute('aria-controls', panelId)\n    $tab.setAttribute('aria-selected', 'false')\n    $tab.setAttribute('tabindex', '-1')\n\n    // Set panel attributes\n    const $panel = this.getPanel($tab)\n    if (!$panel) {\n      return\n    }\n\n    $panel.setAttribute('role', 'tabpanel')\n    $panel.setAttribute('aria-labelledby', $tab.id)\n    $panel.classList.add(this.jsHiddenClass)\n  }\n\n  /**\n   * Unset tab link and panel attributes\n   *\n   * @private\n   * @param {HTMLAnchorElement} $tab - Tab link\n   */\n  unsetAttributes($tab) {\n    // unset tab attributes\n    $tab.removeAttribute('id')\n    $tab.removeAttribute('role')\n    $tab.removeAttribute('aria-controls')\n    $tab.removeAttribute('aria-selected')\n    $tab.removeAttribute('tabindex')\n\n    // unset panel attributes\n    const $panel = this.getPanel($tab)\n    if (!$panel) {\n      return\n    }\n\n    $panel.removeAttribute('role')\n    $panel.removeAttribute('aria-labelledby')\n    $panel.classList.remove(this.jsHiddenClass)\n  }\n\n  /**\n   * Handle tab link clicks\n   *\n   * @private\n   * @param {MouseEvent} event - Mouse click event\n   * @returns {void} Returns void\n   */\n  onTabClick(event) {\n    const $currentTab = this.getCurrentTab()\n    const $nextTab = event.currentTarget\n\n    if (!$currentTab || !($nextTab instanceof HTMLAnchorElement)) {\n      return\n    }\n\n    event.preventDefault()\n\n    this.hideTab($currentTab)\n    this.showTab($nextTab)\n    this.createHistoryEntry($nextTab)\n  }\n\n  /**\n   * Update browser URL hash fragment for tab\n   *\n   * - Allows back/forward to navigate tabs\n   * - Avoids page jump when hash changes\n   *\n   * @private\n   * @param {HTMLAnchorElement} $tab - Tab link\n   */\n  createHistoryEntry($tab) {\n    const $panel = this.getPanel($tab)\n    if (!$panel) {\n      return\n    }\n\n    // Save and restore the id so the page doesn't jump when a user clicks a tab\n    // (which changes the hash)\n    const panelId = $panel.id\n    $panel.id = ''\n    this.changingHash = true\n    window.location.hash = panelId\n    $panel.id = panelId\n  }\n\n  /**\n   * Handle tab keydown event\n   *\n   * - Press right arrow for next tab\n   * - Press left arrow for previous tab\n   *\n   * @private\n   * @param {KeyboardEvent} event - Keydown event\n   */\n  onTabKeydown(event) {\n    switch (event.key) {\n      // 'Left' and 'Right' required for Edge 16 support.\n      case 'ArrowLeft':\n      case 'Left':\n        this.activatePreviousTab()\n        event.preventDefault()\n        break\n      case 'ArrowRight':\n      case 'Right':\n        this.activateNextTab()\n        event.preventDefault()\n        break\n    }\n  }\n\n  /**\n   * Activate next tab\n   *\n   * @private\n   */\n  activateNextTab() {\n    const $currentTab = this.getCurrentTab()\n    if (!$currentTab?.parentElement) {\n      return\n    }\n\n    const $nextTabListItem = $currentTab.parentElement.nextElementSibling\n    if (!$nextTabListItem) {\n      return\n    }\n\n    const $nextTab = $nextTabListItem.querySelector('a.govuk-tabs__tab')\n    if (!$nextTab) {\n      return\n    }\n\n    this.hideTab($currentTab)\n    this.showTab($nextTab)\n    $nextTab.focus()\n    this.createHistoryEntry($nextTab)\n  }\n\n  /**\n   * Activate previous tab\n   *\n   * @private\n   */\n  activatePreviousTab() {\n    const $currentTab = this.getCurrentTab()\n    if (!$currentTab?.parentElement) {\n      return\n    }\n\n    const $previousTabListItem =\n      $currentTab.parentElement.previousElementSibling\n    if (!$previousTabListItem) {\n      return\n    }\n\n    const $previousTab = $previousTabListItem.querySelector('a.govuk-tabs__tab')\n    if (!$previousTab) {\n      return\n    }\n\n    this.hideTab($currentTab)\n    this.showTab($previousTab)\n    $previousTab.focus()\n    this.createHistoryEntry($previousTab)\n  }\n\n  /**\n   * Get tab panel for tab link\n   *\n   * @private\n   * @param {HTMLAnchorElement} $tab - Tab link\n   * @returns {Element | null} Tab panel\n   */\n  getPanel($tab) {\n    const panelId = $tab.hash.replace('#', '')\n    if (!panelId) {\n      return null\n    }\n\n    return this.$root.querySelector(`#${panelId}`)\n  }\n\n  /**\n   * Show tab panel for tab link\n   *\n   * @private\n   * @param {HTMLAnchorElement} $tab - Tab link\n   */\n  showPanel($tab) {\n    const $panel = this.getPanel($tab)\n    if (!$panel) {\n      return\n    }\n\n    $panel.classList.remove(this.jsHiddenClass)\n  }\n\n  /**\n   * Hide tab panel for tab link\n   *\n   * @private\n   * @param {HTMLAnchorElement} $tab - Tab link\n   */\n  hidePanel($tab) {\n    const $panel = this.getPanel($tab)\n    if (!$panel) {\n      return\n    }\n\n    $panel.classList.add(this.jsHiddenClass)\n  }\n\n  /**\n   * Unset 'selected' state for tab link\n   *\n   * @private\n   * @param {HTMLAnchorElement} $tab - Tab link\n   */\n  unhighlightTab($tab) {\n    if (!$tab.parentElement) {\n      return\n    }\n\n    $tab.setAttribute('aria-selected', 'false')\n    $tab.parentElement.classList.remove('govuk-tabs__list-item--selected')\n    $tab.setAttribute('tabindex', '-1')\n  }\n\n  /**\n   * Set 'selected' state for tab link\n   *\n   * @private\n   * @param {HTMLAnchorElement} $tab - Tab link\n   */\n  highlightTab($tab) {\n    if (!$tab.parentElement) {\n      return\n    }\n\n    $tab.setAttribute('aria-selected', 'true')\n    $tab.parentElement.classList.add('govuk-tabs__list-item--selected')\n    $tab.setAttribute('tabindex', '0')\n  }\n\n  /**\n   * Get current tab link\n   *\n   * @private\n   * @returns {HTMLAnchorElement | null} Tab link\n   */\n  getCurrentTab() {\n    return this.$root.querySelector(\n      '.govuk-tabs__list-item--selected a.govuk-tabs__tab'\n    )\n  }\n\n  /**\n   * Name for the component used when initialising using data-module attributes.\n   */\n  static moduleName = 'govuk-tabs'\n}\n","import { normaliseOptions } from './common/configuration.mjs'\nimport { isObject, isSupported } from './common/index.mjs'\nimport { Accordion } from './components/accordion/accordion.mjs'\nimport { Button } from './components/button/button.mjs'\nimport { CharacterCount } from './components/character-count/character-count.mjs'\nimport { Checkboxes } from './components/checkboxes/checkboxes.mjs'\nimport { ErrorSummary } from './components/error-summary/error-summary.mjs'\nimport { ExitThisPage } from './components/exit-this-page/exit-this-page.mjs'\nimport { FileUpload } from './components/file-upload/file-upload.mjs'\nimport { NotificationBanner } from './components/notification-banner/notification-banner.mjs'\nimport { PasswordInput } from './components/password-input/password-input.mjs'\nimport { Radios } from './components/radios/radios.mjs'\nimport { ServiceNavigation } from './components/service-navigation/service-navigation.mjs'\nimport { SkipLink } from './components/skip-link/skip-link.mjs'\nimport { Tabs } from './components/tabs/tabs.mjs'\nimport { ElementError, SupportError } from './errors/index.mjs'\n\n/**\n * Initialise all components\n *\n * Use the `data-module` attributes to find, instantiate and init all of the\n * components provided as part of GOV.UK Frontend.\n *\n * @param {Config | Element | Document | null} [scopeOrConfig] - Scope of the document to search within or config for all components (with optional scope)\n */\nfunction initAll(scopeOrConfig = {}) {\n  const config = isObject(scopeOrConfig) ? scopeOrConfig : {}\n\n  // Extract initialisation options\n  const options = normaliseOptions(scopeOrConfig)\n\n  try {\n    // Skip initialisation when GOV.UK Frontend is not supported\n    if (!isSupported()) {\n      throw new SupportError()\n    }\n\n    // Users can initialise GOV.UK Frontend in certain sections of the page\n    // unless the scope is null (for example, query selector not found)\n    if (options.scope === null) {\n      throw new ElementError({\n        element: options.scope,\n        identifier: 'GOV.UK Frontend scope element (`$scope`)'\n      })\n    }\n  } catch (error) {\n    if (options.onError) {\n      options.onError(error, {\n        config\n      })\n    } else {\n      console.log(error)\n    }\n\n    return\n  }\n\n  const components = /** @type {const} */ ([\n    [Accordion, config.accordion],\n    [Button, config.button],\n    [CharacterCount, config.characterCount],\n    [Checkboxes],\n    [ErrorSummary, config.errorSummary],\n    [ExitThisPage, config.exitThisPage],\n    [FileUpload, config.fileUpload],\n    [NotificationBanner, config.notificationBanner],\n    [PasswordInput, config.passwordInput],\n    [Radios],\n    [ServiceNavigation],\n    [SkipLink],\n    [Tabs]\n  ])\n\n  components.forEach(([Component, componentConfig]) => {\n    createAll(Component, componentConfig, options)\n  })\n}\n\n/**\n * Create all instances of a specific component on the page\n *\n * Uses the `data-module` attribute to find all elements matching the specified\n * component on the page, creating instances of the component object for each\n * of them.\n *\n * Any component errors will be caught and logged to the console.\n *\n * @template {CompatibleClass} ComponentClass\n * @param {ComponentClass} Component - class of the component to create\n * @param {ComponentConfig<ComponentClass>} [config] - Config supplied to component\n * @param {OnErrorCallback<ComponentClass> | Element | Document | null | CreateAllOptions<ComponentClass>} [scopeOrOptions] - options for createAll including scope of the document to search within and callback function if error throw by component on init\n * @returns {Array<InstanceType<ComponentClass>>} - array of instantiated components\n */\nfunction createAll(Component, config, scopeOrOptions) {\n  let /** @type {NodeListOf<Element> | undefined} */ $elements\n\n  // Extract initialisation options\n  const options = normaliseOptions(scopeOrOptions)\n\n  try {\n    // Skip initialisation when GOV.UK Frontend is not supported\n    if (!isSupported()) {\n      throw new SupportError()\n    }\n\n    // Users can initialise GOV.UK Frontend in certain sections of the page\n    // unless the scope is null (for example, query selector not found)\n    if (options.scope === null) {\n      throw new ElementError({\n        element: options.scope,\n        component: Component,\n        identifier: 'Scope element (`$scope`)'\n      })\n    }\n\n    $elements = options.scope?.querySelectorAll(\n      `[data-module=\"${Component.moduleName}\"]`\n    )\n  } catch (error) {\n    if (options.onError) {\n      options.onError(error, {\n        component: Component,\n        config\n      })\n    } else {\n      console.log(error)\n    }\n\n    return []\n  }\n\n  /* eslint-disable-next-line @typescript-eslint/no-unsafe-return --\n   * We can't define CompatibleClass as `{new(): CompatibleClass, moduleName: string}`,\n   * as when doing `typeof Accordion` (or any component), TypeScript doesn't seem\n   * to acknowledge the static `moduleName` that's set in our component classes.\n   * This means we have to set the constructor of `CompatibleClass` as `{new(): any}`,\n   * leading to ESLint frowning that we're returning `any[]`.\n   */\n  return Array.from($elements ?? [])\n    .map(($element) => {\n      try {\n        // Only pass config to components that accept it\n        // eslint-disable-next-line @typescript-eslint/no-unsafe-return\n        return typeof config !== 'undefined'\n          ? new Component($element, config)\n          : new Component($element)\n      } catch (error) {\n        if (options.onError) {\n          options.onError(error, {\n            element: $element,\n            component: Component,\n            config\n          })\n        } else {\n          console.log(error)\n        }\n\n        return null\n      }\n    })\n    .filter(Boolean) // Exclude components that errored\n}\n\nexport { initAll, createAll }\n\n/* eslint-disable jsdoc/valid-types --\n * `{new(...args: any[] ): object}` is not recognised as valid\n * https://github.com/gajus/eslint-plugin-jsdoc/issues/145#issuecomment-1308722878\n * https://github.com/jsdoc-type-pratt-parser/jsdoc-type-pratt-parser/issues/131\n **/\n\n/**\n * @typedef {{new (...args: any[]): any, moduleName: string}} CompatibleClass\n */\n\n/* eslint-enable jsdoc/valid-types */\n\n/**\n * Config for all components via `initAll()`\n *\n * @typedef {object} Config\n * @property {Element | Document | null} [scope] - Scope of the document to search within\n * @property {OnErrorCallback<CompatibleClass>} [onError] - Initialisation error callback\n * @property {AccordionConfig} [accordion] - Accordion config\n * @property {ButtonConfig} [button] - Button config\n * @property {CharacterCountConfig} [characterCount] - Character Count config\n * @property {ErrorSummaryConfig} [errorSummary] - Error Summary config\n * @property {ExitThisPageConfig} [exitThisPage] - Exit This Page config\n * @property {FileUploadConfig} [fileUpload] - File Upload config\n * @property {NotificationBannerConfig} [notificationBanner] - Notification Banner config\n * @property {PasswordInputConfig} [passwordInput] - Password input config\n */\n\n/**\n * Config for individual components\n *\n * @import { AccordionConfig } from './components/accordion/accordion.mjs'\n * @import { ButtonConfig } from './components/button/button.mjs'\n * @import { CharacterCountConfig } from './components/character-count/character-count.mjs'\n * @import { ErrorSummaryConfig } from './components/error-summary/error-summary.mjs'\n * @import { ExitThisPageConfig } from './components/exit-this-page/exit-this-page.mjs'\n * @import { NotificationBannerConfig } from './components/notification-banner/notification-banner.mjs'\n * @import { PasswordInputConfig } from './components/password-input/password-input.mjs'\n * @import { FileUploadConfig } from './components/file-upload/file-upload.mjs'\n */\n\n/**\n * Component config keys, e.g. `accordion` and `characterCount`\n *\n * @typedef {keyof Omit<Config, 'scope' | 'onError'>} ConfigKey\n */\n\n/**\n * @template {CompatibleClass} ComponentClass\n * @typedef {ConstructorParameters<ComponentClass>[1]} ComponentConfig\n */\n\n/**\n * @template {CompatibleClass} ComponentClass\n * @typedef {object} ErrorContext\n * @property {Element} [element] - Element used for component module initialisation\n * @property {ComponentClass} [component] - Class of component\n * @property {Config | ComponentConfig<ComponentClass>} [config] - Config supplied to components\n */\n\n/**\n * @template {CompatibleClass} ComponentClass\n * @callback OnErrorCallback\n * @param {unknown} error - Thrown error\n * @param {ErrorContext<ComponentClass>} context - Object containing the element, component class and configuration\n */\n\n/**\n * @template {CompatibleClass} ComponentClass\n * @typedef {object} CreateAllOptions\n * @property {Element | Document | null} [scope] - scope of the document to search within\n * @property {OnErrorCallback<ComponentClass>} [onError] - callback function if error throw by component on init\n */\n"],"names":["version","getBreakpoint","name","property","value","window","getComputedStyle","document","documentElement","getPropertyValue","undefined","setFocus","$element","options","_options$onBeforeFocu","isFocusable","getAttribute","setAttribute","onFocus","addEventListener","onBlur","once","_options$onBlur","call","removeAttribute","onBeforeFocus","focus","isInitialised","$root","moduleName","HTMLElement","hasAttribute","isSupported","$scope","body","classList","contains","isArray","option","Array","isObject","isScope","Element","Document","formatErrorMessage","Component","message","GOVUKFrontendError","Error","constructor","args","SupportError","supportMessage","HTMLScriptElement","prototype","ConfigError","ElementError","messageOrOptions","component","identifier","element","expectedType","InitError","componentOrMessage","_$root","childConstructor","elementType","checkSupport","checkInitialised","configOverride","Symbol","for","ConfigurableComponent","param","config","_config","defaults","datasetConfig","normaliseDataset","dataset","mergeConfigs","normaliseString","trimmedValue","trim","output","outputType","type","includes","length","isFinite","Number","schema","out","entries","Object","properties","entry","namespace","field","toString","extractConfigByNamespace","normaliseOptions","scopeOrOptions","onError","scope","configObjects","formattedConfigObject","configObject","key","keys","override","validateConfig","validationErrors","conditions","errors","required","errorMessage","every","push","newObject","current","keyParts","split","index","I18n","translations","_config$locale","locale","lang","t","lookupKey","translation","count","translationPluralForm","getPluralSuffix","match","replacePlaceholders","translationString","formatter","Intl","NumberFormat","supportedLocalesOf","replace","placeholderWithBraces","placeholderKey","hasOwnProperty","placeholderValue","format","hasIntlPluralRulesSupport","Boolean","PluralRules","preferredForm","select","console","warn","Accordion","i18n","controlsClass","showAllClass","showAllTextClass","sectionClass","sectionExpandedClass","sectionButtonClass","sectionHeaderClass","sectionHeadingClass","sectionHeadingDividerClass","sectionHeadingTextClass","sectionHeadingTextFocusClass","sectionShowHideToggleClass","sectionShowHideToggleFocusClass","sectionShowHideTextClass","upChevronIconClass","downChevronIconClass","sectionSummaryClass","sectionSummaryFocusClass","sectionContentClass","$sections","$showAllButton","$showAllIcon","$showAllText","querySelectorAll","initControls","initSectionHeaders","updateShowAllButton","areAllSectionsOpen","createElement","add","appendChild","$accordionControls","insertBefore","firstChild","onShowOrHideAllToggle","event","onBeforeMatch","forEach","$section","i","$header","querySelector","constructHeaderMarkup","setExpanded","isExpanded","onSectionToggle","setInitialState","$span","$heading","$summary","$button","id","attr","from","attributes","$headingText","$headingTextFocus","childNodes","$child","$showHideToggle","$showHideToggleFocus","$showHideText","$showHideIcon","getButtonPunctuationEl","$summarySpan","$summarySpanFocus","remove","removeChild","$fragment","target","closest","nowExpanded","storeState","expanded","$content","newButtonText","textContent","ariaLabelParts","ariaLabelMessage","join","toggle","getIdentifier","rememberExpanded","sessionStorage","setItem","_unused","state","getItem","_unused2","$punctuationEl","freeze","hideAllSections","hideSection","hideSectionAriaLabel","showAllSections","showSection","showSectionAriaLabel","DEBOUNCE_TIMEOUT_IN_SECONDS","Button","debounceFormSubmitTimer","handleKeyDown","debounce","$target","preventDefault","click","preventDoubleClick","setTimeout","closestAttributeValue","attributeName","$closestElementWithAttribute","CharacterCount","configOverrides","maxlength","maxwords","_ref","_this$config$maxwords","$textarea","$visibleCountMessage","$screenReaderCountMessage","lastInputTimestamp","lastInputValue","valueChecker","maxLength","HTMLTextAreaElement","HTMLInputElement","Infinity","textareaDescriptionId","$textareaDescription","getElementById","$errorMessage","insertAdjacentElement","className","bindChangeEvents","updateCount","updateCountMessage","handleInput","handleFocus","handleBlur","updateVisibleCountMessage","Date","now","setInterval","updateIfValueChanged","clearInterval","updateScreenReaderCountMessage","remainingNumber","isError","isOverThreshold","getCountMessage","text","_text$match","tokens","countType","formatCountMessage","translationKeySuffix","Math","abs","threshold","currentLength","thresholdValue","charactersUnderLimit","one","other","charactersAtLimit","charactersOverLimit","wordsUnderLimit","wordsAtLimit","wordsOverLimit","textareaDescription","anyOf","Checkboxes","$inputs","$input","targetId","syncAllConditionalReveals","handleClick","syncConditionalRevealWithInputState","inputIsChecked","checked","unCheckAllInputsExcept","allInputsWithSameName","$inputWithSameName","hasSameFormOwner","form","unCheckExclusiveInputs","allInputsWithSameNameAndExclusiveBehaviour","$exclusiveInput","$clickedInput","hasAriaControls","hasBehaviourExclusive","ErrorSummary","disableAutoFocus","focusTarget","HTMLAnchorElement","inputId","hash","$legendOrLabel","getAssociatedLegendOrLabel","scrollIntoView","preventScroll","_document$querySelect","$fieldset","$legends","getElementsByTagName","$candidateLegend","legendTop","getBoundingClientRect","top","inputRect","height","innerHeight","inputBottom","ExitThisPage","$skiplinkButton","$updateSpan","$indicatorContainer","$overlay","keypressCounter","lastKeyWasModified","timeoutTime","keypressTimeoutId","timeoutMessageId","buildIndicator","initUpdateSpan","initButtonClickHandler","handleKeypress","bind","govukFrontendExitThisPageKeypress","resetPage","$indicator","updateIndicator","$indicators","exitPage","location","href","clearTimeout","setKeypressTimer","resetKeypressTimer","shiftKey","activated","timedOut","pressTwoMoreTimes","pressOneMoreTime","FileUpload","$status","$announcements","enteredAnotherElement","$label","findLabel","ariaDescribedBy","innerText","commaSpan","containerSpan","buttonSpan","insertAdjacentText","instructionSpan","onClick","onChange","updateDisabledState","observeDisabledState","onDrop","updateDropzoneVisibility","disabled","hideDraggingState","Node","dataTransfer","canDrop","showDraggingState","canFillInput","files","dispatchEvent","CustomEvent","matchesInputCapacity","items","countFileItems","types","numberOfFiles","multiple","fileCount","observer","MutationObserver","mutationList","mutation","observe","chooseFilesButton","dropInstruction","noFileChosen","multipleFilesChosen","enteredDropZone","leftDropZone","list","result","kind","NotificationBanner","PasswordInput","$showHideButton","$screenReaderStatusMessage","HTMLButtonElement","hide","persisted","show","setType","isHidden","prefixButton","prefixStatus","showPassword","hidePassword","showPasswordAriaLabel","hidePasswordAriaLabel","passwordShownAnnouncement","passwordHiddenAnnouncement","Radios","$allInputs","$clickedInputForm","$clickedInputName","hasSameName","ServiceNavigation","$menuButton","$menu","menuIsOpen","mql","menuId","setupResponsiveChecks","handleMenuButtonClick","breakpoint","matchMedia","checkMode","addListener","matches","setAttributes","attributesForHidingButton","removeAttributes","hidden","attributeNames","SkipLink","_this$$root$getAttrib","origin","pathname","linkedElementId","$linkedElement","Tabs","$tabs","$tabList","$tabListItems","jsHiddenClass","changingHash","boundTabClick","boundTabKeydown","boundOnHashChange","onTabClick","onTabKeydown","onHashChange","_this$mql","setup","teardown","_this$getTab","$item","$tab","hideTab","$activeTab","getTab","showTab","removeEventListener","unsetAttributes","$tabWithHash","$previousTab","getCurrentTab","unhighlightTab","hidePanel","highlightTab","showPanel","panelId","$panel","getPanel","$currentTab","$nextTab","currentTarget","createHistoryEntry","activatePreviousTab","activateNextTab","parentElement","$nextTabListItem","nextElementSibling","$previousTabListItem","previousElementSibling","initAll","scopeOrConfig","error","log","components","accordion","button","characterCount","errorSummary","exitThisPage","fileUpload","notificationBanner","passwordInput","componentConfig","createAll","$elements","_options$scope","map","filter"],"mappings":"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"}