JSPM

@vaadin/context-menu

24.1.0-beta3
  • ESM via JSPM
  • ES Module Entrypoint
  • Export Map
  • Keywords
  • License
  • Repository URL
  • TypeScript Types
  • README
  • Created
  • Published
  • Downloads 34386
  • Score
    100M100P100Q151960F
  • License Apache-2.0

Web Component for showing context dependent items for any element on the page

Package Exports

  • @vaadin/context-menu
  • @vaadin/context-menu/src/vaadin-context-menu.js
  • @vaadin/context-menu/src/vaadin-menu-overlay-mixin.js
  • @vaadin/context-menu/src/vaadin-menu-overlay-styles.js
  • @vaadin/context-menu/theme/lumo/vaadin-context-menu-item-styles.js
  • @vaadin/context-menu/theme/lumo/vaadin-context-menu-list-box-styles.js
  • @vaadin/context-menu/theme/lumo/vaadin-context-menu-overlay-styles.js
  • @vaadin/context-menu/theme/lumo/vaadin-context-menu.js
  • @vaadin/context-menu/theme/material/vaadin-context-menu-item-styles.js
  • @vaadin/context-menu/theme/material/vaadin-context-menu-list-box-styles.js
  • @vaadin/context-menu/theme/material/vaadin-context-menu-overlay-styles.js
  • @vaadin/context-menu/theme/material/vaadin-context-menu.js
  • @vaadin/context-menu/vaadin-context-menu
  • @vaadin/context-menu/vaadin-context-menu.js

This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (@vaadin/context-menu) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.

Readme

@vaadin/context-menu

A web component that can be attached to any component to display a context menu.

Documentation + Live Demo ↗

npm version Discord

<vaadin-context-menu>
  <span>Open a context menu with <b>right click</b> or with <b>long touch.</b></span>
</vaadin-context-menu>

<script>
  const contextMenu = document.querySelector('vaadin-context-menu');
  contextMenu.renderer = function (root) {
    let listBox = root.firstElementChild;
    // Check if there is a list-box generated with the previous renderer call to update its content instead of recreation
    if (listBox) {
      listBox.innerHTML = '';
    } else {
      listBox = document.createElement('vaadin-list-box');
      root.appendChild(listBox);
    }

    ['First', 'Second', 'Third'].forEach(function (name) {
      const item = document.createElement('vaadin-item');
      item.textContent = name + ' menu item';
      listBox.appendChild(item);
    });
  };
</script>

Screenshot of vaadin-context-menu

Note: <vaadin-list-box> component used in the above example should be installed and imported separately.

Installation

Install the component:

npm i @vaadin/context-menu

Once installed, import the component in your application:

import '@vaadin/context-menu';

Themes

Vaadin components come with two built-in themes, Lumo and Material. The main entrypoint of the package uses the Lumo theme.

To use the Material theme, import the component from the theme/material folder:

import '@vaadin/context-menu/theme/material/vaadin-context-menu.js';

You can also import the Lumo version of the component explicitly:

import '@vaadin/context-menu/theme/lumo/vaadin-context-menu.js';

Finally, you can import the un-themed component from the src folder to get a minimal starting point:

import '@vaadin/context-menu/src/vaadin-context-menu.js';

License

Apache License 2.0

Vaadin collects usage statistics at development time to improve this product. For details and to opt-out, see https://github.com/vaadin/vaadin-usage-statistics.