@reach/component-component
TypeScript icon, indicating that this package has built-in type declarations

0.17.0 • Public • Published

@reach/component-component

Stable release MIT license

Docs | Source

NOTE: This component was developed in the days before React Hooks. In most cases, you should probably build your function components using hooks and use a class component in the rare cases you need them. We may deprecate this component in the future.

A dynamic, functional version of React.Component, a component component if you will. Useful for inline lifecycles and state.

<Component initialState={{ hue: 0 }}>
  {({ setState, state }) => (
    <div style={{ textAlign: "center" }}>
      <button onClick={() => setState({ hue: Math.random() * 360 })}>
        Generate Triad Colorscheme
      </button>
      <br />
      {[1, 2, 3].map((n) => (
        <div
          key={n}
          style={{
            display: "inline-block",
            margin: 10,
            width: "2em",
            height: "2em",
            borderRadius: "50%",
            background: `hsl(${state.hue + n * 120}, 50%, 50%)`,
            transition: "background-color 200ms ease",
          }}
        />
      ))}
    </div>
  )}
</Component>

Readme

Keywords

none

Package Sidebar

Install

npm i @reach/component-component

Weekly Downloads

47,911

Version

0.17.0

License

MIT

Unpacked Size

20.1 kB

Total Files

9

Last publish

Collaborators

  • ryanflorence
  • mjackson
  • chancestrickland
  • blainekasten