# frozen_string_literal: true module Ariadne # `List` is used to show a list of items in a vertical format. class ListComponent < Ariadne::Component DEFAULT_TAG = :ul DEFAULT_UL_CLASSES = "ariadne-divide-y ariadne-divide-gray-300" renders_many :items, "ListItem" # @example Basic # <% numbers = [1, 2, 3] %> # <%= render(Ariadne::ListComponent.new) do |list| %> # <% numbers.each do |number| %> # <%= list.with_item do |item| %> # <%= number %> # <% end %> # <% end %> # <% end %> # # # @param classes [String] <%= link_to_classes_docs %> # @param attributes [Hash] <%= link_to_attributes_docs %> def initialize(classes: "", attributes: {}) @tag = DEFAULT_TAG @classes = merge_class_names(DEFAULT_UL_CLASSES, classes) @attributes = attributes end def render? items? end # This component is part of `ListComponent` and should not be # used as a standalone component. class ListItem < Ariadne::Component DEFAULT_ITEM_CLASSES = "ariadne-relative ariadne-p-1.5 focus:ariadne-ring-2 focus:ariadne-ring-offset-2 focus:ariadne-ring-purple-500 hover:ariadne-bg-button-hover-color" attr_reader :link, :classes, :attributes def initialize(link: {}, classes: "", attributes: {}) @link = link @classes = merge_class_names(DEFAULT_ITEM_CLASSES, classes) @attributes = attributes end def selected? @selected end private def linked? @link.present? end def call render(Ariadne::BaseComponent.new(tag: :li, classes: @classes, attributes: @attributes)) do if linked? classes = @link[:classes] || "" attributes = @link[:attributes] || {} render(Ariadne::LinkComponent.new(href: @link[:href], classes: classes, attributes: attributes)) do content end else content end end end end end end