Sha256: 5f05a7dbbbb86aa1946e5ff78f40299ca0be9ca9d0d778c7119b74d2155c3fe1

Contents?: true

Size: 1.36 KB

Versions: 120

Compression:

Stored size: 1.36 KB

Contents

# frozen_string_literal: true

module Primer
  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. `Primer::Alpha::HellipButton.new("aria-label": "Expand next part")`
    class HellipButton < Primer::Component
      # @param inline [Boolean] Whether or not the button is inline.
      # @param disabled [Boolean] Whether or not the button is disabled.
      # @param system_arguments [Hash] <%= link_to_system_arguments_docs %>
      def initialize(inline: false, disabled: 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
        )
        @system_arguments[:disabled] = disabled
      end

      def call
        render(Primer::Beta::BaseButton.new(**@system_arguments)) { "&hellip;".html_safe }
      end
    end
  end
end

Version data entries

120 entries across 120 versions & 2 rubygems

Version Path
openproject-primer_view_components-0.33.0 app/components/primer/alpha/hellip_button.rb
primer_view_components-0.25.1 app/components/primer/alpha/hellip_button.rb
openproject-primer_view_components-0.32.1 app/components/primer/alpha/hellip_button.rb
openproject-primer_view_components-0.32.0 app/components/primer/alpha/hellip_button.rb
openproject-primer_view_components-0.29.1 app/components/primer/alpha/hellip_button.rb
openproject-primer_view_components-0.29.0 app/components/primer/alpha/hellip_button.rb
primer_view_components-0.23.0 app/components/primer/alpha/hellip_button.rb
openproject-primer_view_components-0.28.1 app/components/primer/alpha/hellip_button.rb
openproject-primer_view_components-0.28.0 app/components/primer/alpha/hellip_button.rb
openproject-primer_view_components-0.27.0 app/components/primer/alpha/hellip_button.rb
openproject-primer_view_components-0.26.0 app/components/primer/alpha/hellip_button.rb
openproject-primer_view_components-0.25.1 app/components/primer/alpha/hellip_button.rb
primer_view_components-0.22.0 app/components/primer/alpha/hellip_button.rb
primer_view_components-0.21.1 app/components/primer/alpha/hellip_button.rb
openproject-primer_view_components-0.25.0 app/components/primer/alpha/hellip_button.rb
openproject-primer_view_components-0.24.0 app/components/primer/alpha/hellip_button.rb
primer_view_components-0.21.0 app/components/primer/alpha/hellip_button.rb
primer_view_components-0.20.1 app/components/primer/alpha/hellip_button.rb
primer_view_components-0.20.0 app/components/primer/alpha/hellip_button.rb
openproject-primer_view_components-0.23.0 app/components/primer/alpha/hellip_button.rb