Filter panel
Displays a result count and a toggleable panel with arbitrary content, a submit input, and an optional reset link.
How it looks (preview) (preview all)
123,456 results
I can contain arbitrary content, usually a set of filters and sort options.
How to call this component
<%= render "components/filter_panel", {
result_text: "123,456 results",
button_text: "Filter and sort"
} do %>
<p class="govuk-body">
I can contain arbitrary content, usually a set of filters and sort options.
</p>
<% end %>
Accessibility acceptance criteria
The component must:
- accept focus
- be focusable with a keyboard
- be usable with a keyboard
- be usable with touch
- indicate when it has focus
- toggle the visibility of the panel when interacted with
- indicate the expanded state when panel is visible
- indicate the collapsed state when panel is hidden
- be visible by default without Javascript enabled
Other examples
Standard options
This component uses the component wrapper helper. It accepts the following options and applies them to the parent element of the component. See the component wrapper helper documentation for more detail.
id
- accepts a string for the element ID attributedata_attributes
- accepts a hash of data attributesaria
- accepts a hash of aria attributesclasses
- accepts a space separated string of classes, these should not be used for styling and must be prefixed withjs-
margin_bottom
- accepts a number from0
to9
(0px
to60px
) using the GOV.UK Frontend spacing scale (defaults to no margin)role
- accepts a space separated string of roleslang
- accepts a language attribute valueopen
- accepts an open attribute value (true or false)hidden
- accepts an empty string, ‘hidden’, or ‘until-found’tabindex
- accepts an integer. The integer can also be passed as a stringdir
- accepts ‘rtl’, ‘ltr’, or ‘auto’type
- accepts any valid type attribute e.g. ‘button’, ‘submit’, ‘text’rel
- accepts any valid rel attribute e.g. ‘nofollow’target
- accepts a valid target attribute e.g. ‘_blank’title
- accepts any stringdraggable
- accepts a draggable attribute value (“true” or “false”)
Open (preview)
1,989 seeds
I am open by default!
<%= render "components/filter_panel", {
result_text: "1,989 seeds",
button_text: "Open sesame",
open: true
} do %>
<p class="govuk-body">
I am open by default!
</p>
<% end %>
With reset link (preview)
Shows a clear link when the filter panel is open, for example if any filters are selected that can be cleared.
42 widgets
Some filters
<%= render "components/filter_panel", {
result_text: "42 widgets",
button_text: "Clearable filters",
open: true,
show_reset_link: true,
reset_link_href: "http://example.org"
} do %>
<p class="govuk-body">
Some filters
</p>
<% end %>
With filter section (preview)
Pass filter section component as a block
42 universes
Filter by
Filter 1
1 Selected
<%= render "components/filter_panel", {
result_text: "42 universes",
button_text: "View filter section"
} do %>
<%= render "components/filter_section", {
status_text: "1 Selected",
heading_text: "Filter 1"
} do %>
<span>filter section content</span>
<% end %>
<% end %>
With radios and checkboxes (preview)
Overrides default styles of GOV.UK Frontend radios and checkboxes to ensure they have a white background despite being inside a grey panel.
<%= render "components/filter_panel", {
button_text: "Filter with radios and checkboxes",
open: true
} do %>
<div class="govuk-!-padding-4">
<%= render "govuk_publishing_components/components/radio", {
heading: "Radios",
name: "radio",
small: true,
items: [
{ value: "1", text: "Radio 1" },
{ value: "2", text: "Radio 2", checked: true }
]
} %>
<%= render "govuk_publishing_components/components/checkboxes", {
name: "checkbox",
heading: "Checkboxes",
small: true,
items: [
{
label: "Red",
value: "red"
},
{
label: "Green",
value: "green"
},
{
label: "Blue",
value: "blue"
}
]
} %>
</div>
<% end %>