# frozen_string_literal: true module Primer # `Tooltip` is a wrapper component that will apply a tooltip to the provided content. class Tooltip < Primer::Component status :beta DIRECTION_DEFAULT = :n ALIGN_DEFAULT = :default MULTILINE_DEFAULT = false DELAY_DEFAULT = false ALIGN_MAPPING = { ALIGN_DEFAULT => "", :left_1 => "tooltipped-align-left-1", :right_1 => "tooltipped-align-right-1", :left_2 => "tooltipped-align-left-2", :right_2 => "tooltipped-align-right-2" }.freeze DIRECTION_OPTIONS = [DIRECTION_DEFAULT] + %i[ nw ne w e sw s se ] # @example Default #
# <%= render(Primer::Tooltip.new(label: "Even bolder")) { "Default Bold Text" } %> #
# # @example Wrapping another component #
# <%= render(Primer::Tooltip.new(label: "Even bolder")) do %> # <%= render(Primer::ButtonComponent.new) { "Bold Button" } %> # <% end %> #
# # @example With a direction #
# <%= render(Primer::Tooltip.new(label: "Even bolder", direction: :s)) { "Bold Text With a Direction" } %> #
# # @example With an alignment #
# <%= render(Primer::Tooltip.new(label: "Even bolder", direction: :s, alignment: :right_1)) { "Bold Text With an Alignment" } %> #
# # @example Without a delay #
# <%= render(Primer::Tooltip.new(label: "Even bolder", direction: :s, no_delay: true)) { "Bold Text without a delay" } %> #
# # @param label [String] the text to appear in the tooltip # @param direction [String] Direction of the tooltip. <%= one_of(Primer::Tooltip::DIRECTION_OPTIONS) %> # @param align [String] Align tooltips to the left or right of an element, combined with a `direction` to specify north or south. <%= one_of(Primer::Tooltip::ALIGN_MAPPING.keys) %> # @param multiline [Boolean] Use this when you have long content # @param no_delay [Boolean] By default the tooltips have a slight delay before appearing. Set true to override this # @param system_arguments [Hash] <%= link_to_system_arguments_docs %> def initialize( label:, direction: DIRECTION_DEFAULT, align: ALIGN_DEFAULT, multiline: MULTILINE_DEFAULT, no_delay: DELAY_DEFAULT, **system_arguments ) @system_arguments = system_arguments @system_arguments[:tag] ||= :span @system_arguments[:aria] = { label: label } @system_arguments[:classes] = class_names( @system_arguments[:classes], "tooltipped", "tooltipped-#{fetch_or_fallback(DIRECTION_OPTIONS, direction, DIRECTION_DEFAULT)}", ALIGN_MAPPING[fetch_or_fallback(ALIGN_MAPPING.keys, align, ALIGN_DEFAULT)], "tooltipped-no-delay" => fetch_or_fallback_boolean(no_delay, DELAY_DEFAULT), "tooltipped-multiline" => fetch_or_fallback_boolean(multiline, MULTILINE_DEFAULT) ) end def call render(Primer::BaseComponent.new(**@system_arguments)) { content } end end end