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

with-lifecycles

v1.0.1

Published

An easy way to turn stateless functional components into class components with state and lifecycles.

Downloads

20

Readme

with-lifecycles

Travis npm package Coveralls

Everyone loves React's stateless functional components (SFC). The ease and simplicity of writing just a function for a React component is so delicious that you wish you could write your entire app with only functions!

Inevitably, you'll run across a need to use state in your component. Or even scarier, having to use some of the lifecycle methods of a React Class Component.

Then you're met with a horrible quandry: do you keep the beautiful simplicity of your SFC (🤗) or do you rewrite it to be a React Class Component (😢).

And everyone hates that most horrible of all chores of converting a SFC to a Class component.

...well fear not...

For this is the library for you! It'll let you have your 🎂 and 👄 it too!

Example

We have a simple Counter component that can increment a counter.

const Counter = ({ count, incrementCount }) => (
  <div>
    <div>Current count: {count}</div>
    <button onClick={incrementCount}>Increment</button>
  </div>
);

This is a nice and simple SFC. However, it doesn't do anything without any state. So let's add that.

const CounterWithLifecycles = withLifecycles({
  getInitialState: () => ({ count: 0 }),
  mapStateToProps: state => ({ count: state.count }),
  incrementCount: ({ props, state, setState }) =>
    setState({ count: state.count + 1 }),
})(Counter);

Voila! 🎉 Your SFC now has all the super powers of a React Class component.

Play with a live example on Codesandbox.

Edit withLifecycles

Documentation

withLifecycles is a Higher-Order Component which takes in an object which supports every known React Class method, including any additional methods you want to be included in the returned class (such as event handlers), and returns a function which takes in the component you want to wrap.

There's two additional special properties:

getInitialState(props): This is similar to the old React.createClass method and is a way for you to set the initial state of the wrapped component. It is called with props.

mapStateToProps(state, props): Similar to react-redux's mapStateToProps, it's called with state and props.

non-React method: Any non-React method is called with an object that looks like:

{
    event: event, // Event Handler Event if it exists.
    state: this.state, // State
    props: this.props, // Props
    setState: this.setState, // A copy of setState for updating.
}