HTML element to use for accordion
Optional
config: AccordionConfig = {}Accordion config
Protected
_$rootPrivate
$sectionsPrivate
$showPrivate
$showPrivate
$showPrivate
i18nStatic
Constant
defaultsAccordion default config
Static
elementStatic
moduleName for the component used when initialising using data-module attributes.
Static
Constant
schemaAccordion config schema
Protected
$rootProtected
Returns the root element of the component
Protected
configProtected
Returns the root element of the component
Internal
Virtual
configOverride
Function which defines configuration overrides to prioritize properties from the root element's dataset.
It should take a subset of configuration as input and return a new configuration object with properties that should be overridden based on the root element's dataset. A Symbol is used for indexing to prevent conflicts.
Optional
param: ObjectNestedConfiguration object
return - Configuration object
Private
arePrivate
constructCreates the <span>
element with the summary for the section
This is necessary because the summary line text is now inside
a button element, which can only contain phrasing content, and
not a <div>
element
The original <div>
containing the summary
<span>
element containing the summaryPrivate
getPrivate
Create an element to improve semantics of the section button with punctuation
Adding punctuation to the button can also improve its general semantics by dividing its contents into thematic chunks. See https://github.com/alphagov/govuk-frontend/issues/2327#issuecomment-922957442
DOM element
Get the identifier for a section
We need a unique way of identifying each content in the Accordion.
Since an #id
should be unique and an id
is required for aria-
attributes id
can be safely used.
Section element
Identifier for section
Private
initPrivate
initPrivate
isPrivate
onPrivate
onPrivate
onPrivate
setPrivate
setPrivate
storePrivate
updateStatic
check
Accordion component
This allows a collection of sections to be collapsed by default, showing only their headers. Sections can be expanded or collapsed individually by clicking their headers. A "Show all sections" button is also added to the top of the accordion, which switches to "Hide all sections" when all the sections are expanded.
The state of each section is saved to the DOM via the
aria-expanded
attribute, which also provides accessibility.