npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

react-float-menu

v0.4.7

Published

Smart draggable floating menu component for React

Downloads

143

Readme

  • ⚡ Configurable and smart floating menu for react
  • ⚙️ Comes with a lot of options to customize the behavior of the menu
  • 💡 Auto detects edges of the screen and places the menu accordingly
  • 🎨 Customize colors with ease
  • 📱 Seamless support for mobile and desktop
  • 💪 Built with Typescript

📦 Installation

Install the package with npm or yarn.

  npm install react-float-menu

or

  yarn add react-float-menu

🚀 Getting started

Let's get started by creating a new floating menu with drag super power.

  <Menu
    dimension={40}
    items={[
      { name: "File" },
      {
        children: [
          { children: [{ name: "Cut 1" }, { name: "Cut 2" }], name: "Cut" },
          { name: "Select All" },
        ],
        name: "Edit",
      },
      { name: "Add" },
      {
        children: [
          { name: "Copy from clipboard" },
          { name: "Copy selection" },
        ],
        name: "Copy",
      },
      { name: "Save" },
      { name: "Logout" },
    ]}
    shape="square"
    startPosition="top left"
    width={250}
    onSelect={(val) => console.log(val)}
  >
    <PlusIcon />
  </Menu>

⚙️ Properties

| name | description | default | | :------------------ | :------------------------------------------------------------------------------------------------------------------------ | :--------- | | autoFlipMenu | Flips the menu when the button is at the bottom of the screen and there is no space to display the menu | true | | bringMenuToFocus | Automatically moves the menu and brings it to focus when the menu is activated from the left or right edge of the screen. | true | | closeOnClickOutside | Closes the menu if you touch or click outside the menu. | true | | dimension | Sets the height and width of the button | 30 | | disableHeader | Disables the header section of the menu. | false | | iconSize | Size of the menu item icons | "1rem" | | items | Collection of menu items. Please refer Menu item model | [] | | pin | Disables dragging and pins the menu. The button's initial placement will be determined by startPosition | 30 | | shape | Shape of the button. can be square or circle | circle | | RTL | Renders the menu items right to left. The submenu's will open to the left side. | False | | startPosition | Starting position of the button. can be top left,top right,bottom left,bottom right | top left | | theme | With the theme object, you can change the colors of different elements. | | | width | Width of the menu | 30 |

items

items is an array of menu item objects. A menu item represents the individual menu item and its properties.

| name | description | | :------- | :----------------------------------------------------------------------------------------------------- | | name | Label of the menu item | | id | Unique id of the menu item. This is optional as the ids are automatically generated by the library | | children | The prop takes an array of Menu item objects and it will be rendered as the submenu for this menu item | | icon | Use this prop to display a icon for the menu item | | selected | This is an internal prop that is set to true when the menu item is selected |

submenus are activated by clicking on the menu item or by hovering over the menu item.

🎨 Theme

Use the theme object to customize the colors of the different elements of the menu.

| name | description | default | | :--------------------- | :------------------------------------------------- | :------ | | menuBackgroundColor | background color of the menu | #FFFFFF | | menuItemHoverColor | background color of the menu item when its hovered | #318CE7 | | menuItemHoverTextColor | Text color of the menu item when its hovered | #fff | | primary | Primary color or the predominant color of the menu | #318CE7 | | secondary | Secondary color of the menu | #FFFFFF |


import {Menu} from 'react-float-menu';

<Menu
  startPosition="top right"
  theme={{
    menuBackgroundColor: "#FFFFFF",
    menuItemHoverColor: "#318CE7",
    menuItemHoverTextColor: "#fff",
    primary: "#318CE7",
    secondary: "#FFFFFF",
  }}
/>

🧪 Tests

We use cypress to test the library.

To run the tests, run the following command in the root directory of the project.

  pnpm install
  pnpm run cypress:open

🍫 CodeSandbox Examples

  1. Basic
  2. Pinned Menu
  3. Custom Colors
  4. RTL

🤝 Contributing

  1. Fork it
  2. Create your feature branch (git checkout -b new-feature)
  3. Commit your changes (git commit -am 'Add feature')
  4. Push to the branch (git push origin new-feature)
  5. Create a new Pull Request

Check out the contributing guide for more details.

📃 Meta

Distributed under the MIT license. See LICENSE for more information.

Prabhu Murthy – @prabhumurthy2[email protected] https://github.com/prabhuignoto