Class: UI::ContextMenuItem

Inherits:
Phlex::HTML
  • Object
show all
Includes:
ContextMenuItemBehavior
Defined in:
app/components/ui/context_menu_item.rb

Overview

Item - Phlex implementation

Individual menu item that can be rendered as a link or div. Uses ContextMenuItemBehavior concern for shared styling logic.

Examples:

Basic menu item

render UI::Item.new { "Profile" }

Menu item with link

render UI::Item.new(href: "/profile") { "Profile" }

Instance Method Summary collapse

Methods included from ContextMenuItemBehavior

#context_menu_item_classes, #context_menu_item_data_attributes, #context_menu_item_html_attributes

Constructor Details

#initialize(href: nil, inset: false, variant: "default", classes: "", **attributes) ⇒ ContextMenuItem

Returns a new instance of ContextMenuItem.

Parameters:

  • href (String) (defaults to: nil)

    Optional URL to make item a link

  • inset (Boolean) (defaults to: false)

    Whether to add left padding for alignment

  • variant (String) (defaults to: "default")

    Variant style (default, destructive)

  • classes (String) (defaults to: "")

    Additional CSS classes to merge

  • attributes (Hash)

    Additional HTML attributes



21
22
23
24
25
26
27
# File 'app/components/ui/context_menu_item.rb', line 21

def initialize(href: nil, inset: false, variant: "default", classes: "", **attributes)
  @href = href
  @inset = inset
  @variant = variant
  @classes = classes
  @attributes = attributes
end

Instance Method Details

#view_template(&block) ⇒ Object



29
30
31
32
33
34
35
36
37
38
39
# File 'app/components/ui/context_menu_item.rb', line 29

def view_template(&block)
  if @href
    a(**context_menu_item_html_attributes.deep_merge(@attributes)) do
      yield if block_given?
    end
  else
    div(**context_menu_item_html_attributes.deep_merge(@attributes)) do
      yield if block_given?
    end
  end
end