Class: UI::TooltipTrigger
- Inherits:
-
Phlex::HTML
- Object
- Phlex::HTML
- UI::TooltipTrigger
- Includes:
- TooltipTriggerBehavior
- Defined in:
- app/components/ui/tooltip_trigger.rb
Overview
Trigger - Phlex implementation
The interactive element that shows/hides the tooltip on hover/focus. Supports asChild pattern for composition with other components.
Instance Method Summary collapse
-
#initialize(as_child: false, **attributes) ⇒ TooltipTrigger
constructor
A new instance of TooltipTrigger.
- #view_template(&block) ⇒ Object
Methods included from TooltipTriggerBehavior
#tooltip_trigger_classes, #tooltip_trigger_data_attributes, #tooltip_trigger_html_attributes
Constructor Details
#initialize(as_child: false, **attributes) ⇒ TooltipTrigger
Returns a new instance of TooltipTrigger.
25 26 27 28 |
# File 'app/components/ui/tooltip_trigger.rb', line 25 def initialize(as_child: false, **attributes) @as_child = as_child @attributes = attributes end |
Instance Method Details
#view_template(&block) ⇒ Object
30 31 32 33 34 35 36 37 38 39 40 41 |
# File 'app/components/ui/tooltip_trigger.rb', line 30 def view_template(&block) trigger_attrs = tooltip_trigger_html_attributes.deep_merge(@attributes) if @as_child # asChild mode: yield attributes to block # The caller is responsible for rendering an element with these attributes yield(trigger_attrs) if block_given? else # Default mode: render as button (**trigger_attrs, &block) end end |