Socket
Socket
Sign inDemoInstall

dropdown-menu-element

Package Overview
Dependencies
1
Maintainers
1
Versions
3
Alerts
File Explorer

Advanced tools

Install Socket

Detect and block malicious and high-risk dependencies

Install

    dropdown-menu-element

Easy to use context menus and button dropdown menus. Lightweight using no UI frameworks.


Version published
Weekly downloads
56
increased by330.77%
Maintainers
1
Created
Weekly downloads
 

Readme

Source

dropdown-list-element

Because defining fancy right-click menus should be easy

Features

  • Easy to use
  • Framework independent
  • Can be configured to open on click or contextmenu events
  • Menu items can contain <input> elements with first class support for type="checkbox" and type="radio"
  • Full keyboard navigation support
  • Animatable

Installation

You can add the dropdown-list-element package as a dependency of your npm project. Just be sure to import it somewhere so that the custom elements will be registered.

If you run npm install && npm run build-standalone after cloning this repository, you will have a self-contained version of this library bundled with the one (1) external function depended upon that you can use in a normal <script> tag. (Woah, old school!)

Defining your menus

Quickstart example:

<div>This div has a context menu</div>
<dropdown-menu linked-elements="div:has(+ #this)">
	<dropdown-menu-item value="1">Option 1</dropdown-menu-item>
	<dropdown-menu-item value="2">Option 2</dropdown-menu-item>
	<dropdown-menu-item value="3">Option 3</dropdown-menu-item>
	<dropdown-menu-item>
		Nested options
		<dropdown-menu-inner>
			<dropdown-menu-item value="4">Option 4</dropdown-menu-item>
			<dropdown-menu-item disabled value="5">Disabled option 5</dropdown-menu-item>
			<dropdown-menu-item value="6">Option 6</dropdown-menu-item>
		</dropdown-menu-inner>
	</dropdown-menu-item>
</dropdown-menu>
divWithContextMenu.addEventListener("dropdownSelect", (ev) => {
	const {
		selectedElement, // The <active-dropdown-menu-item> selected.
		selectedElementOriginal, // The `<dropdown-menu-item>` used to create the `selectedElement`.
		selectedValue, // The value of the `value` attribute of the `selectedElementOriginal`, `undefined` if not set.
		dropdownMenu, // The <dropdown-menu> used to make the menu selection.
		triggeringElement // The linked element which triggered the opening of the menu.
	} = ev.detail;
	alert("Option " + selectedValue + " was selected!");
});

A more detailed example can be found in the tests/test.html file. If you wish to try it out yourself, you must run npm run build-standalone after cloning this repository.

Documentation

Hosted docs soon™. Though this project is full of tsdoc comments for your viewing pleasure. They can be generated into pretty .html files by running npm run docs. To get started, take a look at the {@link DropdownMenuElement | DropdownMenuElement} class documentation and explore from there.

Compatibility notes

Because Apple "thinks different", dropdown menus containing <form> elements will not work properly on Safari at the time of writing. However, <dropdown-menu> elements which are optionally children of <form> elements while also being grandparents of <input> elements will still work as intended. As a side-note, An earlier version of this library extended upon <ul> and <li> elements to define the menus.

Keywords

FAQs

Last updated on 03 May 2024

Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc