UNPKG

@siamf/context-menu

Version:

React hook for displaying configure able context menu

63 lines (49 loc) 2.86 kB
<picture> <source media="(prefers-color-scheme: dark)" srcset="https://raw.githubusercontent.com/siamahnaf/assets-kit/main/logo/logo-white.png"> <source media="(prefers-color-scheme: light)" srcset="https://raw.githubusercontent.com/siamahnaf/assets-kit/main/logo/logo-black.png"> <img alt="Siam Ahnaf" src="https://raw.githubusercontent.com/siamahnaf/assets-kit/main/logo/logo-black.png" height="auto" width="240"> </picture> # @siamf/context-menu React hook and components for displaying fully UI controlled context menu. This project is fork of [use-context-menu](https://github.com/bvaughn/use-context-menu) with react 19 support. # Installation ```bash $ npm i @siamf/context-menu ``` # Usage ### `ImageUpload` ```javascript "use client" import { ContextMenuItem, useContextMenu } from "@siamf/context-menu"; import "@siamf/context-menu/styles.css"; const Page = ({ className }: { className: string }) => { const { contextMenu, onContextMenu, onKeyDown } = useContextMenu( <> <ContextMenuItem onSelect={selectOne}>One</ContextMenuItem> <ContextMenuItem onSelect={selectTwo}>Two</ContextMenuItem> <ContextMenuItem onSelect={selectThree}>Three</ContextMenuItem> </> ); return ( <> <button onContextMenu={onContextMenu} onKeyDown={onKeyDown} tabIndex={0}> right-click me </button> {contextMenu} </> ); } export default Page; ``` ## Connect with me <div style="display: flex; align-items: center; gap: 3px;"> <a href="https://wa.me/8801611994403"><img src="https://raw.githubusercontent.com/siamahnaf/assets-kit/main/icons/whatsapp.png" width="40" height="40"></a> <a href="https://siamahnaf.com/" style="margin-right: 8px"><img src="https://raw.githubusercontent.com/siamahnaf/assets-kit/main/icons/web.png" width="40" height="40"></a> <a href="https://www.linkedin.com/in/siamahnaf/" style="margin-right: 8px"><img src="https://raw.githubusercontent.com/siamahnaf/assets-kit/main/icons/linkedin.png" width="40" height="40"></a> <a href="https://x.com/siamahnaf198" style="margin-right: 8px"><img src="https://raw.githubusercontent.com/siamahnaf/assets-kit/main/icons/x.png" width="40" height="40"></a> <a href="https://www.facebook.com/siamahnaf198/" style="margin-right: 8px"><img src="https://raw.githubusercontent.com/siamahnaf/assets-kit/main/icons/facebook.png" width="40" height="40"></a> <a href="https://t.me/siamahnaf198" style="margin-right: 8px"><img src="https://raw.githubusercontent.com/siamahnaf/assets-kit/main/icons/telegram.png" width="40" height="40"></a> <a href="https://www.npmjs.com/~siamahnaf" style="margin-right: 8px"><img src="https://raw.githubusercontent.com/siamahnaf/assets-kit/main/icons/npm.png" width="40" height="40"></a> </div> ------------ <p align="center" color="red"><a href="https://www.siamahnaf.com/">www.siamahnaf.com</a></p>