Class: Yattho::Beta::TimelineItem

Inherits:
Component
  • Object
show all
Defined in:
app/components/yattho/beta/timeline_item.rb

Overview

Use ‘TimelineItem` to display items on a vertical timeline, connected by badge elements.

Direct Known Subclasses

TimelineItemComponent

Defined Under Namespace

Classes: Badge

Constant Summary

Constants inherited from Component

Component::INVALID_ARIA_LABEL_TAGS

Constants included from Status::Dsl

Status::Dsl::STATUSES

Constants included from ViewHelper

ViewHelper::HELPERS

Constants included from TestSelectorHelper

TestSelectorHelper::TEST_SELECTOR_TAG

Constants included from FetchOrFallbackHelper

FetchOrFallbackHelper::InvalidValueError

Instance Method Summary collapse

Methods inherited from Component

deprecated?, generate_id

Methods included from JoinStyleArgumentsHelper

#join_style_arguments

Methods included from TestSelectorHelper

#add_test_selector

Methods included from FetchOrFallbackHelper

#fetch_or_fallback, #fetch_or_fallback_boolean, #silence_deprecations?

Methods included from ClassNameHelper

#class_names

Constructor Details

#initialize(condensed: false, **system_arguments) ⇒ TimelineItem

Returns a new instance of TimelineItem.

Examples:

Default

<div style="padding-left: 60px">
  <%= render(Yattho::Beta::TimelineItem.new) do |component| %>
    <% component.with_avatar(src: Yattho::ExampleImage::BASE64_SRC, alt: "github") %>
    <% component.with_badge(bg: :success_emphasis, color: :on_emphasis, icon: :check) %>
    <% component.with_body { "Success!" } %>
  <% end %>
</div>

Parameters:

  • condensed (Boolean) (defaults to: false)

    Reduce the vertical padding and remove the background from the badge item. Most commonly used in commits.

  • system_arguments (Hash)

    <%= link_to_system_arguments_docs %>



52
53
54
55
56
57
58
59
60
# File 'app/components/yattho/beta/timeline_item.rb', line 52

def initialize(condensed: false, **system_arguments)
  @system_arguments = deny_tag_argument(**system_arguments)
  @system_arguments[:tag] = :div
  @system_arguments[:classes] = class_names(
    "TimelineItem",
    condensed ? "TimelineItem--condensed" : "",
    system_arguments[:classes]
  )
end

Instance Method Details

#render?Boolean

Returns:

  • (Boolean)


62
63
64
# File 'app/components/yattho/beta/timeline_item.rb', line 62

def render?
  avatar? || badge? || body?
end