class Primer::Beta::ClipboardCopy
Always set an accessible label to help the user interact with the component.
@accessibility
instead.
If you’re looking for a button, consider using <%= link_to_component(Primer::Beta::ClipboardCopyButton) %>
This component by itself is not styled as a button, and can therefore only be used in limited circumstances.
Use ‘ClipboardCopy` to copy element text content or input values to the clipboard.
def before_render
def before_render validate_aria_label if content.blank? end
def initialize(value: nil, **system_arguments)
-
system_arguments
(Hash
) -- <%= link_to_system_arguments_docs %> -
for
(String
) -- Element id from where to get the copied value. -
value
(String
) -- Text to copy into the users clipboard when they click the component. -
aria-label
(String
) -- String that will be read to screenreaders when the component is focused
def initialize(value: nil, **system_arguments) @system_arguments = deny_tag_argument(**system_arguments) @value = value validate! @system_arguments[:tag] = "clipboard-copy" @system_arguments[:value] = value if value.present? end
def validate!
def validate! raise ArgumentError, "Must provide either `value` or `for`" if @value.nil? && @system_arguments[:for].nil? end