Class: Avo::ButtonComponent

Inherits:
BaseComponent show all
Defined in:
app/components/avo/button_component.rb

Constant Summary collapse

SIZE =
_Union(:xs, :sm, :md, :lg, :xl)
STYLE =
_Union(:primary, :outline, :text, :icon)

Constants included from Concerns::FindAssociationField

Concerns::FindAssociationField::ASSOCIATIONS

Instance Method Summary collapse

Methods inherited from BaseComponent

#has_with_trial

Methods included from Concerns::FindAssociationField

#find_association_field

Instance Method Details

#argsObject



22
23
24
25
26
27
28
29
30
31
32
# File 'app/components/avo/button_component.rb', line 22

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

  @args[:class] = button_classes
  @args[:aria] = @aria

  @args
end

#button_classesObject



34
35
36
37
38
39
40
41
42
43
44
45
46
47
# File 'app/components/avo/button_component.rb', line 34

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



79
80
81
82
83
84
85
# File 'app/components/avo/button_component.rb', line 79

def call
  if is_link?
    output_link
  else
    output_button
  end
end

#full_contentObject



61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
# File 'app/components/avo/button_component.rb', line 61

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)


53
54
55
# File 'app/components/avo/button_component.rb', line 53

def is_icon?
  @style == :icon
end

#is_link?Boolean

Returns:

  • (Boolean)


49
50
51
# File 'app/components/avo/button_component.rb', line 49

def is_link?
  @is_link
end

#is_not_icon?Boolean

Returns:

  • (Boolean)


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

def is_not_icon?
  !is_icon?
end

#output_buttonObject



93
94
95
96
97
98
99
100
101
102
103
# File 'app/components/avo/button_component.rb', line 93

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


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

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