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 🙏

© 2024 – Pkg Stats / Ryan Hefner

react-sidenav

v4.0.6

Published

A Simple SideBar Navigation written in React

Downloads

1,903

Readme

react-sidenav

Build Status coverage report npm version

Side Navigation Component for React

Alt Img

Requirements

react-sidenav are exported as an es module thus you would need a bundler to use it. It is also written in Typescript so it can be directly used with a typescript project as well.

Peer Dependencies

React 16.8

NavContext

As the current version of react-sidenav does not have any fixed rendering template, the user is free to render Nav items as they see fit. To render conditionally an item can get the context which contains the following attributes:

| property | type | description | |------------:|-------------:|------:| | selected | boolean | if this Nav item is selected | | id | string | the id of the Nav as per props.id | | pathId | string | The path id, will be parentId|props.id if rendered with a parent | | level | number | The level of the Nav, starts with 1 | | isLeaf | boolean | If true, then this Nav has no children |

Below is an example on how to use it.

    const Item = () => {
      const context = React.useContext(NavContext);
      return (
        <div style={{ color: context.selected: 'pink': 'inherit'}}>{ props.children }</div>
      )
    }
  
    <SideNav>
      <Nav id="1">
        <Item>Link 1</Item>
      </Nav>
      <Nav id="2">
        <Item>Link 2</Item>
      </Nav>
      <Nav id="3">
        <Item>Link 3</Item>
      </Nav>
    </SideNav>
  

SideNav Properties

| property | type | description | isRequired | |------------|-------------:|------:|-----------------------| | onSelection | function: ({id, path, payload}) => void | a function that gets called when a navigation has been clicked | false | | defaultSelectedPath | string | the default selection | false | | mode | compact, normal | changes rendering style of children | false, defaults to normal | | childrenToggleMode | hover, click | changes how children are expanded | false, defaults to hover | | childrenToggleIndicator | React Component | the toggle indicator to render. The collapse, expand state is passed or you can use the NavGroupContext to get the collapse/expand state | false |

Nav Properties

| property | type | description | isRequired | |------------|-------------:|------:|-----------------------| | id | | a function that gets called when a navigation has been clicked | true | | payload | any | passed to the listener when this nav is clicked | false |

Development

Please checkout example on CodeSandbox and the src/playground directory for now while all the documentation/testing is being completed.

Sponsors

JetBrains