# frozen_string_literal: true
module Primer
module Beta
# Use `Subhead` as the start of a section. The `:heading` slot will render an `
` font-sized text.
#
# - Optionally set the `:description` slot to render a short description and the `:actions` slot for a related action.
# - Use a succinct, one-line description for the `:description` slot. For longer descriptions, omit the description slot and render a paragraph below the `Subhead`.
# - Use the actions slot to render a related action to the right of the heading. Use <%= link_to_component(Primer::ButtonComponent) %> or <%= link_to_component(Primer::Beta::Link) %>.
#
# @accessibility
# The `:heading` slot defaults to rendering a `
`. Update the tag to a heading element with the appropriate level to improve page navigation for assistive technologies.
# <%= link_to_heading_practices %>
class Subhead < Primer::Component
status :beta
DEFAULT_HEADING_TAG = :div
HEADING_TAG_OPTIONS = [DEFAULT_HEADING_TAG, :h1, :h2, :h3, :h4, :h5, :h6].freeze
DEFAULT_HEADING_SIZE = :large
HEADING_SIZE_MAP = {
DEFAULT_HEADING_SIZE => "Subhead-heading--large",
:medium => "Subhead-heading--medium"
}.freeze
HEADING_SIZE_OPTIONS = HEADING_SIZE_MAP.keys.freeze
# The heading
#
# @param tag [Symbol] <%= one_of(Primer::Beta::Subhead::HEADING_TAG_OPTIONS)%>
# @param danger [Boolean] Whether to style the heading as dangerous.
# @param system_arguments [Hash] <%= link_to_system_arguments_docs %>
renders_one :heading, lambda { |tag: DEFAULT_HEADING_TAG, danger: false, size: DEFAULT_HEADING_SIZE, **system_arguments|
system_arguments[:tag] = fetch_or_fallback(HEADING_TAG_OPTIONS, tag, DEFAULT_HEADING_TAG)
system_arguments[:classes] = class_names(
system_arguments[:classes],
"Subhead-heading",
HEADING_SIZE_MAP[fetch_or_fallback(HEADING_SIZE_OPTIONS, size, DEFAULT_HEADING_SIZE)],
"Subhead-heading--danger": danger
)
Primer::BaseComponent.new(**system_arguments)
}
# Actions
#
# @param system_arguments [Hash] <%= link_to_system_arguments_docs %>
renders_one :actions, lambda { |**system_arguments|
deny_tag_argument(**system_arguments)
system_arguments[:tag] = :div
system_arguments[:classes] = class_names(system_arguments[:classes], "Subhead-actions")
Primer::BaseComponent.new(**system_arguments)
}
# The description
#
# @param system_arguments [Hash] <%= link_to_system_arguments_docs %>
renders_one :description, lambda { |**system_arguments|
deny_tag_argument(**system_arguments)
system_arguments[:tag] = :div
system_arguments[:classes] = class_names(system_arguments[:classes], "Subhead-description")
Primer::BaseComponent.new(**system_arguments)
}
# @param spacious [Boolean] Whether to add spacing to the Subhead.
# @param hide_border [Boolean] Whether to hide the border under the heading.
# @param system_arguments [Hash] <%= link_to_system_arguments_docs %>
def initialize(spacious: false, hide_border: false, **system_arguments)
@system_arguments = deny_tag_argument(**system_arguments)
@system_arguments[:tag] = :div
@system_arguments[:classes] =
class_names(
@system_arguments[:classes],
"Subhead",
"Subhead--spacious": spacious,
"border-bottom-0": hide_border
)
@system_arguments[:mb] ||= hide_border ? 0 : nil
end
def render?
heading.present?
end
end
end
end