Sha256: 4aad04323b0a8e45f26ec2cb130b2ea44c128963e160f4c303ac043ff0a12510

Contents?: true

Size: 1.25 KB

Versions: 17

Compression:

Stored size: 1.25 KB

Contents

# frozen_string_literal: true

module Primer
  # Use FlexItemComponent to specify the ability of a flex item to alter its
  # dimensions to fill available space
  class FlexItemComponent < Primer::Component
    FLEX_AUTO_DEFAULT = false
    FLEX_AUTO_ALLOWED_VALUES = [FLEX_AUTO_DEFAULT, true].freeze

    # @example Default
    #   <%= render(Primer::FlexComponent.new) do %>
    #     <%= render(Primer::FlexItemComponent.new) do %>
    #       Item 1
    #     <% end %>
    #
    #     <%= render(Primer::FlexItemComponent.new(flex_auto: true)) do %>
    #       Item 2
    #     <% end %>
    #   <% end %>
    #
    # @param flex_auto [Boolean] Fills available space and auto-sizes based on the content. Defaults to <%= Primer::FlexItemComponent::FLEX_AUTO_DEFAULT %>
    # @param system_arguments [Hash] <%= link_to_system_arguments_docs %>
    def initialize(flex_auto: FLEX_AUTO_DEFAULT, **system_arguments)
      @system_arguments = system_arguments
      @system_arguments[:classes] =
        class_names(
          @system_arguments[:classes],
          "flex-auto" => fetch_or_fallback(FLEX_AUTO_ALLOWED_VALUES, flex_auto, FLEX_AUTO_DEFAULT)
        )
    end

    def call
      render(Primer::BoxComponent.new(**@system_arguments)) { content }
    end
  end
end

Version data entries

17 entries across 17 versions & 1 rubygems

Version Path
primer_view_components-0.0.38 app/components/primer/flex_item_component.rb
primer_view_components-0.0.37 app/components/primer/flex_item_component.rb
primer_view_components-0.0.36 app/components/primer/flex_item_component.rb
primer_view_components-0.0.35 app/components/primer/flex_item_component.rb
primer_view_components-0.0.34 app/components/primer/flex_item_component.rb
primer_view_components-0.0.33 app/components/primer/flex_item_component.rb
primer_view_components-0.0.32 app/components/primer/flex_item_component.rb
primer_view_components-0.0.31 app/components/primer/flex_item_component.rb
primer_view_components-0.0.30 app/components/primer/flex_item_component.rb
primer_view_components-0.0.29 app/components/primer/flex_item_component.rb
primer_view_components-0.0.28 app/components/primer/flex_item_component.rb
primer_view_components-0.0.27 app/components/primer/flex_item_component.rb
primer_view_components-0.0.26 app/components/primer/flex_item_component.rb
primer_view_components-0.0.25 app/components/primer/flex_item_component.rb
primer_view_components-0.0.24 app/components/primer/flex_item_component.rb
primer_view_components-0.0.23 app/components/primer/flex_item_component.rb
primer_view_components-0.0.22 app/components/primer/flex_item_component.rb