@spaceymonk/react-radial-menu
v2.0.6
Published
React radial menu with sub menu support, animations and themes.
Downloads
2,074
Maintainers
Readme
React Radial Menu
Radial menu with animations and nested sub menu support for React. You can use it for context menu or as a menu for your mobile app.
Features
- Nested sub menu support with back button
- Fully customizable with CSS variables (even background drawings!)
- Built-in animations (fade, scale, rotate) with any combination
- Disk or bubble display (see the GIF below)
- Further customization with CSS classes
- Dark mode support (thanks to CSS variables)
- Written in TypeScript
Demo
Click here.
Installation
npm install @spaceymonk/react-radial-menu
Quick start
Just wrap your menu items with <Menu>
component.
import React from "react";
import { Menu, MenuItem, SubMenu } from "@spaceymonk/react-radial-menu";
function App() {
const [show, setShow] = React.useState(false);
const [position, setPosition] = React.useState({ x: 0, y: 0 });
// You can also use separate handler for each item
const handleItemClick = (event, index, data) => {
console.log(`[MenuItem] ${data} clicked`);
setShow(false); // you should handle your menu visibility yourself
};
const handleSubMenuClick = (event, index, data) => {
console.log(`[SubMenu] ${data} clicked`);
};
const handleDisplayClick = (event, position) => {
console.log(`[Display] ${position} clicked`);
};
return (
<div
// right click event
onContextMenu={(e) => {
e.preventDefault();
setShow(true);
// if your div is not full screen, you should remove the offset
// via getBoundingClientRect().left and getBoundingClientRect().top
// check `src/stories/BasicControls.stories.tsx` for an example
setPosition({ x: e.clientX, y: e.clientY });
}}
onClick={() => setShow(false)}
style={{ width: "100vw", height: "100vh" }}
>
<Menu
centerX={position.x}
centerY={position.y}
innerRadius={75}
outerRadius={150}
show={show}
animation={["fade", "scale"]}
animationTimeout={150}
drawBackground
>
{/* Populate your menu here */}
<MenuItem onItemClick={handleItemClick} data="1. Item">
1. Item
</MenuItem>
<SubMenu
onDisplayClick={handleDisplayClick}
onItemClick={handleSubMenuClick}
itemView="2. Sub Menu"
data="2. Sub Menu"
displayPosition="bottom"
>
<MenuItem onItemClick={handleItemClick} data="2.1. Item">
2.1. Item
</MenuItem>
<MenuItem onItemClick={handleItemClick} data="2.2. Item">
2.2. Item
</MenuItem>
<MenuItem onItemClick={handleItemClick} data="2.3. Item">
2.3. Item
</MenuItem>
<SubMenu
onDisplayClick={handleDisplayClick}
onItemClick={handleSubMenuClick}
itemView="2.4. Sub Menu"
data="2.4. Sub Menu"
displayPosition="bottom"
>
<MenuItem onItemClick={handleItemClick} data="2.4.1. Item">
2.4.1. Item
</MenuItem>
<MenuItem onItemClick={handleItemClick} data="2.4.2. Item">
2.4.2. Item
</MenuItem>
</SubMenu>
</SubMenu>
</Menu>
</div>
);
}
export default App;
Contribute
Any idea and suggestions are welcome. Please have a look at the contributing guide.
License
React Radial Menu is licensed under MIT.