Class: Avo::ButtonComponent

Inherits:
ViewComponent::Base
  • Object
show all
Defined in:
app/components/avo/button_component.rb

Overview

A button/link can have the following settings: style: primary/outline/text size: :xs :sm, :md, :lg

Instance Method Summary collapse

Constructor Details

#initialize(path = nil, size: :md, style: :outline, color: :gray, icon: nil, icon_class: "", is_link: false, rounded: true, compact: false, **args) ⇒ ButtonComponent

Returns a new instance of ButtonComponent.



7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
# File 'app/components/avo/button_component.rb', line 7

def initialize(path = nil, size: :md, style: :outline, color: :gray, icon: nil, icon_class: "", is_link: false, rounded: true, compact: false, **args)
  # Main settings
  @size = size
  @style = style
  @color = color

  # Other things that appear in the button
  @path = path
  @icon = icon
  @icon_class = icon_class
  @rounded = rounded
  @compact = compact

  # Other settings
  @class = args[:class]
  @is_link = is_link
  @args = args || {}
end

Instance Method Details

#argsObject



26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
# File 'app/components/avo/button_component.rb', line 26

def args
  if @args[:loading]
    @args[:"data-controller"] = "loading-button"
    @args[:"data-loading-button-confirmed-value"] = false
    @args[:"data-action"] = "click->loading-button#attemptSubmit"

    if @args[:confirm]
      @args[:"data-loading-button-confirmation-message-value"] = @args.delete(:confirm)
    end
  end

  @args[:class] = button_classes

  @args
end

#button_classesObject



42
43
44
45
46
47
48
49
50
51
52
53
54
55
# File 'app/components/avo/button_component.rb', line 42

def button_classes
  classes = "button-component inline-flex flex-grow-0 items-center font-semibold leading-6 fill-current whitespace-nowrap transition duration-100 transform transition duration-100 cursor-pointer disabled:cursor-not-allowed disabled:opacity-70 justify-center #{@class}"

  # For non-icon-styled buttons we should not add borders.
  classes += " border active:outline active:outline-1" unless is_icon?

  classes += " rounded" if @rounded.present?
  classes += style_classes
  classes += horizontal_padding_classes
  classes += vertical_padding_classes
  classes += text_size_classes

  classes
end

#callObject



87
88
89
90
91
92
93
# File 'app/components/avo/button_component.rb', line 87

def call
  if is_link?
    output_link
  else
    output_button
  end
end

#full_contentObject



69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
# File 'app/components/avo/button_component.rb', line 69

def full_content
  result = ""
  icon_classes = @icon_class
  # space out the icon from the text if text is present
  icon_classes += " mr-1" if content.present? && is_not_icon?
  # add the icon height
  icon_classes += icon_size_classes

  # Add the icon
  result += helpers.svg(@icon, class: icon_classes) if @icon.present?

  if is_not_icon? && content.present?
    result += content
  end

  result.html_safe
end

#is_icon?Boolean

Returns:

  • (Boolean)


61
62
63
# File 'app/components/avo/button_component.rb', line 61

def is_icon?
  @style == :icon
end

#is_link?Boolean

Returns:

  • (Boolean)


57
58
59
# File 'app/components/avo/button_component.rb', line 57

def is_link?
  @is_link
end

#is_not_icon?Boolean

Returns:

  • (Boolean)


65
66
67
# File 'app/components/avo/button_component.rb', line 65

def is_not_icon?
  !is_icon?
end

#output_buttonObject



101
102
103
104
105
106
107
108
109
110
111
# File 'app/components/avo/button_component.rb', line 101

def output_button
  if args.dig(:method).present? || args.dig(:data, :turbo_method).present?
    button_to args[:url], **args do
      full_content
    end
  else
    button_tag(**args) do
      full_content
    end
  end
end


95
96
97
98
99
# File 'app/components/avo/button_component.rb', line 95

def output_link
  link_to @path, **args do
    full_content
  end
end