React JS – RCTX Contexmenu


Note: rctx-contextmenu Supports React 16.8 and above versions because this plugin solely uses React Hooks.

The problem

There are lot of times when you want to customize the right click menu or Context Menu. May be you want to add more customized options or even sub options with same look and feel how a native context menu gives.

The solution

rctx-contextmenu gives that flexibility to customize Context Menu. You can add options, sub-options with exactly the look and feel how you get when you use the native Context Menu.

Key features

  • Append to anywhere you want
  • Customize styling like however you want
  • In-built animation
  • Extensive list of APIs
  • Dynamically add/remove menus

Browser Support

  • IE 11 and Edge >= 12
  • FireFox >= 38
  • Chrome >= 47

Installation

Plain text
Copy to clipboard
Open code in new window
EnlighterJS 3 Syntax Highlighter
npm install --save rctx-contextmenu
npm install --save rctx-contextmenu
npm install --save rctx-contextmenu

Sample Usage

Plain text
Copy to clipboard
Open code in new window
EnlighterJS 3 Syntax Highlighter
import React from 'react';
import { ContextMenuTrigger, ContextMenu, ContextMenuItem } from 'rctx-contextmenu';
function App() {
return (
<div className="app">
<ContextMenuTrigger
id="my-context-menu-1"
>
<div className="box">
Right Click On Me
</div>
</ContextMenuTrigger>
<ContextMenu id="my-context-menu-1">
<ContextMenuItem>Menu Item 1</ContextMenuItem>
<ContextMenuItem>Menu Item 2</ContextMenuItem>
<ContextMenuItem>Menu Item 3</ContextMenuItem>
<ContextMenuItem>Menu Item 4</ContextMenuItem>
</ContextMenu>
</div>
);
}
export default App;
import React from 'react'; import { ContextMenuTrigger, ContextMenu, ContextMenuItem } from 'rctx-contextmenu'; function App() { return ( <div className="app"> <ContextMenuTrigger id="my-context-menu-1" > <div className="box"> Right Click On Me </div> </ContextMenuTrigger> <ContextMenu id="my-context-menu-1"> <ContextMenuItem>Menu Item 1</ContextMenuItem> <ContextMenuItem>Menu Item 2</ContextMenuItem> <ContextMenuItem>Menu Item 3</ContextMenuItem> <ContextMenuItem>Menu Item 4</ContextMenuItem> </ContextMenu> </div> ); } export default App;
import React from 'react';
import { ContextMenuTrigger, ContextMenu, ContextMenuItem } from 'rctx-contextmenu';

function App() {
  return (
    <div className="app">
      <ContextMenuTrigger
        id="my-context-menu-1"
      >
        <div className="box">
          Right Click On Me
        </div>
      </ContextMenuTrigger>

      <ContextMenu id="my-context-menu-1">
        <ContextMenuItem>Menu Item 1</ContextMenuItem>
        <ContextMenuItem>Menu Item 2</ContextMenuItem>
        <ContextMenuItem>Menu Item 3</ContextMenuItem>
        <ContextMenuItem>Menu Item 4</ContextMenuItem>
      </ContextMenu>
    </div>
  );
}

export default App;

Full example usage

Plain text
Copy to clipboard
Open code in new window
EnlighterJS 3 Syntax Highlighter
<ContextMenu
id="my-contextmenu"
appendTo="body"
animation="zoom"
hideOnLeave={false}
preventHideOnScroll={true}
preventHideOnResize={true}
attributes={{
'aria-label': 'Some text',
'aria-labelledby': 'Some text'
}}
className="my-context-menu"
onMouseLeave={() => console.log('Mouse left')}
onShow={() => console.log('I am visible!')}
onHide={() => console.log('I am hidden!')}
/>
<ContextMenuItem
disabled={true}
preventClose={false}
attributes={{
'aria-label': 'Some text',
'aria-labelledby': 'Some text'
}}
className="my-context-menu-item"
onClick={() => console.log("I'm clicked!")}
/>
<ContextMenuTrigger
id="my-contextmenu"
disable={false}
disableWhileShiftPressed={true}
attributes={{
'aria-label': 'Some text',
'aria-labelledby': 'Some text'
}}
className="my-context-menu-trigger"
/>
<Submenu
title="My submenu"
attributes={{
'aria-label': 'Some text',
'aria-labelledby': 'Some text'
}}
className="my-context-menu-submenu"
/>
<ContextMenu id="my-contextmenu" appendTo="body" animation="zoom" hideOnLeave={false} preventHideOnScroll={true} preventHideOnResize={true} attributes={{ 'aria-label': 'Some text', 'aria-labelledby': 'Some text' }} className="my-context-menu" onMouseLeave={() => console.log('Mouse left')} onShow={() => console.log('I am visible!')} onHide={() => console.log('I am hidden!')} /> <ContextMenuItem disabled={true} preventClose={false} attributes={{ 'aria-label': 'Some text', 'aria-labelledby': 'Some text' }} className="my-context-menu-item" onClick={() => console.log("I'm clicked!")} /> <ContextMenuTrigger id="my-contextmenu" disable={false} disableWhileShiftPressed={true} attributes={{ 'aria-label': 'Some text', 'aria-labelledby': 'Some text' }} className="my-context-menu-trigger" /> <Submenu title="My submenu" attributes={{ 'aria-label': 'Some text', 'aria-labelledby': 'Some text' }} className="my-context-menu-submenu" />
<ContextMenu
  id="my-contextmenu"
  appendTo="body"
  animation="zoom"
  hideOnLeave={false}
  preventHideOnScroll={true}
  preventHideOnResize={true}
  attributes={{
    'aria-label': 'Some text',
    'aria-labelledby': 'Some text'
  }}
  className="my-context-menu"
  onMouseLeave={() => console.log('Mouse left')}
  onShow={() => console.log('I am visible!')}
  onHide={() => console.log('I am hidden!')}
/>

<ContextMenuItem
  disabled={true}
  preventClose={false}
  attributes={{
    'aria-label': 'Some text',
    'aria-labelledby': 'Some text'
  }}
  className="my-context-menu-item"
  onClick={() => console.log("I'm clicked!")}
/>

<ContextMenuTrigger
  id="my-contextmenu"
  disable={false}
  disableWhileShiftPressed={true}
  attributes={{
    'aria-label': 'Some text',
    'aria-labelledby': 'Some text'
  }}
  className="my-context-menu-trigger"
/>

<Submenu
  title="My submenu"
  attributes={{
    'aria-label': 'Some text',
    'aria-labelledby': 'Some text'
  }}
  className="my-context-menu-submenu"
/>
Nandemo Webtools

Leave a Reply