Sha256: 2e53b67d741d99e1b93288746cee9d41ccc93871760b7db9f5d4b45d3ec538af
Contents?: true
Size: 1.62 KB
Versions: 2
Compression:
Stored size: 1.62 KB
Contents
# frozen_string_literal: true module Yattho module Alpha # Use `HellipButton` to render a button with a hellip. Often used for hidden text expanders. # @accessibility # Always set an accessible label to help the user interact with the component. # # * This button is displaying a hellip as its content (The three dots character). Therefore a label is needed for screen readers. # * Set the attribute `aria-label` on the system arguments. E.g. `Yattho::Alpha::HellipButton.new("aria-label": "Expand next part")` class HellipButton < Yattho::Component # @example Default # <%= render(Yattho::Alpha::HellipButton.new("aria-label": "No effect")) %> # # @example Inline # <%= render(Yattho::Alpha::HellipButton.new(inline: true, "aria-label": "No effect")) %> # # @example Styling the button # <%= render(Yattho::Alpha::HellipButton.new(p: 1, classes: "custom-class", "aria-label": "No effect")) %> # # @param inline [Boolean] Whether or not the button is inline. # @param system_arguments [Hash] <%= link_to_system_arguments_docs %> def initialize(inline: false, **system_arguments) @system_arguments = deny_tag_argument(**system_arguments) validate_aria_label @system_arguments[:tag] = :button @system_arguments[:'aria-expanded'] = false @system_arguments[:classes] = class_names( @system_arguments[:classes], "inline" => inline ) end def call render(Yattho::Beta::BaseButton.new(**@system_arguments)) { "…".html_safe } end end end end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
yattho_view_components-0.1.1 | app/components/yattho/alpha/hellip_button.rb |
yattho_view_components-0.0.1 | app/components/yattho/alpha/hellip_button.rb |