# frozen_string_literal: true
module Ariadne
# `Heading` should be used to communicate page organization and hierarchy.
#
# - Set tag to one of `:h1`, `:h2`, `:h3`, `:h4`, `:h5`, `:h6` based on what is appropriate for the page context.
# - Use `Heading` as the title of a section or sub section.
# - Do not use `Heading` for styling alone. For simply styling text, consider using <%= link_to_component(Ariadne::Text) %> with relevant <%= link_to_typography_docs %>
# such as `font_size` and `font_weight`.
# - Do not jump heading levels. For instance, do not follow a `
` with an ``. Heading levels should increase by one in ascending order.
#
# @accessibility
# While sighted users rely on visual cues such as font size changes to determine what the heading is, assistive technology users rely on programatic cues that can be read out.
# When text on a page is visually implied to be a heading, ensure that it is coded as a heading. Additionally, visually implied heading level and coded heading level should be
# consistent. [See WCAG success criteria: 1.3.1: Info and Relationships](https://www.w3.org/WAI/WCAG21/Understanding/info-and-relationships.html)
#
# Headings allow assistive technology users to quickly navigate around a page. Navigation to text that is not meant to be a heading can be a confusing experience.
# <%= link_to_heading_practices %>
class HeadingComponent < Ariadne::Component
TAG_OPTIONS = [:h1, :h2, :h3, :h4, :h5, :h6].freeze
TAG_TO_CLASSES = {
h1: "font-bold leading-7 sm:text-3xl",
h2: "text-3xl font-extrabold",
h3: "text-2xl font-extrabold",
}
# @example Default
# <%= render(Ariadne::HeadingComponent.new(tag: :h1)) { "H1 Text" } %>
# <%= render(Ariadne::HeadingComponent.new(tag: :h2)) { "H2 Text" } %>
# <%= render(Ariadne::HeadingComponent.new(tag: :h3)) { "H3 Text" } %>
# <%= render(Ariadne::HeadingComponent.new(tag: :h4)) { "H4 Text" } %>
# <%= render(Ariadne::HeadingComponent.new(tag: :h5)) { "H5 Text" } %>
# <%= render(Ariadne::HeadingComponent.new(tag: :h6)) { "H6 Text" } %>
#
# @param tag [String] <%= one_of(Ariadne::HeadingComponent::TAG_OPTIONS) %>
# @param classes [String] <%= link_to_classes_docs %>
# @param attributes [Hash] <%= link_to_attributes_docs %>
def initialize(tag: nil, classes: "", attributes: {})
@tag = fetch_or_raise(TAG_OPTIONS, tag)
@attributes = attributes
@classes = class_names(*TAG_TO_CLASSES[tag], classes)
end
def call
render(Ariadne::BaseComponent.new(tag: @tag, classes: @classes, attributes: @attributes)) { content }
end
end
end