Attachment link
A link to a file with metadata of the file contents
This component provides a means to show a link to an attachment with some relevant file data.
It is expected to be embedded inside an element that provides text styles
(such as .govuk-body) so does not provide its own text styling.
How it looks (preview) (preview all)
How to call this component
<%= render "govuk_publishing_components/components/attachment_link", {
  attachment: {
    title: "Temporary snow ploughs: guidance note",
    url: "https://assets.publishing.service.gov.uk/government/uploads/system/uploads/attachment_data/file/259634/temporary-snow-ploughs.pdf",
    filename: "temporary-snow-ploughs.pdf",
    content_type: "application/pdf",
    file_size: 20000,
    number_of_pages: 1
  }
} %>Accessibility acceptance criteria
All touch targets (e.g the attachment link) must be 24px large, or leave sufficient space (target-size). See Understanding Success Criterion 2.5.8: Target Size (Minimum)).
To achieve this, you can embed the attachment link within another element that maintains sufficient space above and below the target. For instance, you can place individual links inside a paragraph element styled with a .govuk-body class, or as list items in the list component.
Attachment links within paragraphs of text do not need to meet the 24 by 24 CSS pixels requirements.
Links in the component must:
- accept focus
- be focusable with a keyboard
- be usable with a keyboard
- indicate when they have focus
- change in appearance when touched (in the touch-down state)
- change in appearance when hovered
- be usable with touch
- be usable with voice commands
- have visible text
- have meaningful text
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 attribute
- data_attributes- accepts a hash of data attributes
- aria- accepts a hash of aria attributes
- classes- accepts a space separated string of classes, these should not be used for styling and must be prefixed with- js-
- margin_bottom- accepts a number from- 0to- 9(- 0pxto- 60px) using the GOV.UK Frontend spacing scale
- role- accepts a space separated string of roles
- lang- accepts a language attribute value
- open- 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 string
- dir- 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 string
- draggable- accepts a draggable attribute value (“true” or “false”)
Embedded in govuk body (preview)
<p class="govuk-body">
  <%= render "govuk_publishing_components/components/attachment_link", {
  attachment: {
    title: "Temporary snow ploughs: guidance note",
    url: "https://assets.publishing.service.gov.uk/government/uploads/system/uploads/attachment_data/file/259634/temporary-snow-ploughs.pdf",
    filename: "temporary-snow-ploughs.pdf",
    content_type: "application/pdf",
    file_size: 20000,
    number_of_pages: 1
  }
} %>
</p>
Embedded in govspeak (preview)
This component can be embedded in Govspeak with the [AttachmentLink:] code.
Some introductory information about .
<%= render "govuk_publishing_components/components/govspeak" do %>
  <p>Some introductory information about <%= render "govuk_publishing_components/components/attachment_link", {
  attachment: {
    title: "Temporary snow ploughs: guidance note",
    url: "https://assets.publishing.service.gov.uk/government/uploads/system/uploads/attachment_data/file/259634/temporary-snow-ploughs.pdf",
    filename: "temporary-snow-ploughs.pdf",
    content_type: "application/pdf",
    file_size: 20000,
    number_of_pages: 1
  }
} %>.</p>
<% end %>
With target blank (preview)
<%= render "govuk_publishing_components/components/attachment_link", {
  attachment: {
    title: "Temporary snow ploughs: guidance note",
    url: "https://assets.publishing.service.gov.uk/government/uploads/system/uploads/attachment_data/file/259634/temporary-snow-ploughs.pdf"
  },
  target: "_blank"
} %>With data attributes on url (preview)
<%= render "govuk_publishing_components/components/attachment_link", {
  attachment: {
    title: "Temporary snow ploughs: guidance note",
    url: "https://assets.publishing.service.gov.uk/government/uploads/system/uploads/attachment_data/file/259634/temporary-snow-ploughs.pdf"
  },
  url_data_attributes: {
    gtm: "attachment-preview"
  }
} %>