x
1
2
3
4
5
6
7
8
9
10
11
12
<a href="#" data-controller="better-ui--button" data-action="click->better-ui--button#handleClick" class="inline-flex items-center justify-center font-medium rounded-lg transition-all duration-200 focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-primary-500 bg-primary-600 hover:bg-primary-700 active:bg-primary-800 text-grayscale-50 px-4 py-2 text-base gap-2 cursor-pointer"> <span data-better-ui--button-target="spinner" class="hidden"> <svg class="animate-spin w-5 h-5" xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24" aria-hidden="true"> <circle class="opacity-25" cx="12" cy="12" r="10" stroke="currentColor" stroke-width="4"></circle> <path class="opacity-75" fill="currentColor" d="M4 12a8 8 0 018-8V0C5.373 0 0 5.373 0 12h4zm2 5.291A7.962 7.962 0 014 12H0c0 3.042 1.135 5.824 3 7.938l3-2.647z"></path> </svg> <span class="sr-only">Loading...</span> </span> <span data-better-ui--button-target="content" class=" inline-flex items-center gap-2"> Link Button </span></a>1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
target_val = case targetwhen :blank then "_blank"when :self then "_self"else nilend# Convert to boolean - handles both true/false and "true"/"false"disabled_bool = ActiveModel::Type::Boolean.new.cast(disabled)show_loader_bool = ActiveModel::Type::Boolean.new.cast(show_loader)show_loader_on_click_bool = ActiveModel::Type::Boolean.new.cast(show_loader_on_click)render BetterUi::ButtonComponent.new( href: "#", variant: variant, style: style, size: size, target: target_val, disabled: disabled_bool, show_loader: show_loader_bool, show_loader_on_click: show_loader_on_click_bool) do "Link Button"endNo notes provided.
| Param | Description | Input |
|---|---|---|
|
— |
|
|
|
— |
|
|
|
— |
|
|
|
— |
|
|
|
— |
|
|
|
— |
|
|
|
— |
|