Components Dropdowns
A dropdown is a compact UI element that allows a user to select from different options.
Basic dropdown
heex
          <.dropdown label="Dropdown">
  <.dropdown_menu_item>
    <.icon name="hero-home" class="w-5 h-5 text-gray-500" />
    Button item with icon
  </.dropdown_menu_item>
  <.dropdown_menu_item link_type="button" label="button item" />
  <.dropdown_menu_item link_type="a" to="/" label="Link" />
  <.dropdown_menu_item link_type="a" to="/" label="Link with method" method={:put} />
  <.dropdown_menu_item link_type="live_patch" to="/" label="Live Patch" />
  <.dropdown_menu_item link_type="live_redirect" to="/" label="Live Redirect" />
  <.dropdown_menu_item phx-click="some_phoenix_click_event" label="Phoenix click event" />
</.dropdown>

        
Unlabelled dropdown
heex
          <.dropdown>
  <.dropdown_menu_item label="Item 1" />
  <.dropdown_menu_item label="Item 2" />
</.dropdown>

        
Custom dropdown trigger
heex
          <.dropdown>
  <:trigger_element>
    <div class="inline-flex items-center justify-center w-full align-middle focus:outline-none">
      <.avatar
        size="sm"
        src="https://res.cloudinary.com/wickedsites/image/upload/v1604268092/unnamed_sagz0l.jpg"
      />
      <.icon
        name="hero-chevron-down"
        class="w-4 h-4 ml-1 -mr-1 text-gray-400 dark:text-gray-100"
      />
    </div>
  </:trigger_element>
  <.dropdown_menu_item label="Item 1" />
  <.dropdown_menu_item label="Item 2" />
</.dropdown>

        
Properties
elixir
          # <.dropdown>
attr(:options_container_id, :string)
attr(:label, :string, default: nil, doc: "labels your dropdown option")
attr(:class, :string, default: "", doc: "any extra CSS class for the parent container")

attr(:menu_items_wrapper_class, :string,
  default: "",
  doc: "any extra CSS class for menu item wrapper container"
)

attr(:js_lib, :string,
  default: "alpine_js",
  values: ["alpine_js", "live_view_js"],
  doc: "javascript library used for toggling"
)

attr(:placement, :string, default: "left", values: ["left", "right"])
attr(:rest, :global)
slot(:trigger_element)
slot(:inner_block, required: false)

# <.dropdown_menu_item>
attr(:to, :string, default: nil, doc: "link path")
attr(:label, :string, doc: "link label")
attr(:class, :string, default: "", doc: "any additional CSS classes")

attr(:link_type, :string,
  default: "button",
  values: ["a", "live_patch", "live_redirect", "button"]
)

attr(:rest, :global, include: ~w(method download hreflang ping referrerpolicy rel target type))
slot(:inner_block, required: false)