Component
Copy to clipboard
Content that a user is intended to copy, like a URL
How it looks (preview) (preview all)
How to call this component
<%= render "govuk_publishing_components/components/copy_to_clipboard", {
label: "Copy and send this link to someone and they’ll be able to preview your draft on GOV.UK.",
copyable_content: "http://www.example.org",
button_text: "Copy link"
} %>
Accessibility acceptance criteria
- should be usable with keyboard
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 scalerole
- 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”)
With data attributes (preview)
<%= render "govuk_publishing_components/components/copy_to_clipboard", {
label: "Copy and send this link to someone and they’ll be able to preview your draft on GOV.UK.",
copyable_content: "http://www.example.org",
input_data_attributes: {
an_attribute: "for the input"
},
button_text: "Copy link",
button_data_attributes: {
another_attribute: "for the button"
}
} %>