Complexity Score
Low
Open Issues
20
Dependent Projects
28
Weekly Downloadsglobal
4,634
Keywords
License
- MIT
- Yesattribution
- Permissivelinking
- Permissivedistribution
- Permissivemodification
- Nopatent grant
- Yesprivate use
- Permissivesublicensing
- Notrademark grant
Downloads
Readme
Reactions Component
This has moved to Reach UI, but this repo is here for the sake of history I guess.
What?
Declarative version of React.Component.
Why?
Because sometimes you want a lifecycle or some state but don’t want to create a new component. Also, this stuff is composable as heck.
Installation
npm install @reactions/component
# or
yarn add @reactions/component
And then import it:
// using es modules
import Component from "@reactions/component";
// common.js
const Component = require("@reactions/component");
// AMD
// I've forgotten but it should work.
Or use script tags and globals.
<script src="https://unpkg.com/@reactions/component"></script>
And then grab it off the global like so:
const Component = ReactionsComponent;
How?
Let’s say you want some async data but don’t want to make a whole new component just for the lifecycles to get it:
// import Component from '@reactions/component'
const Component = ReactComponentComponent;
ReactDOM.render(
<div>
<h2>Let's get some gists!</h2>
<Component
initialState={{ gists: null }}
didMount={({ setState }) => {
fetch("https://api.github.com/gists")
.then(res => res.json())
.then(gists => setState({ gists }));
}}
>
{({ state }) =>
state.gists ? (
<ul>
{state.gists.map(gist => (
<li key={gist.id}>{gist.description}</li>
))}
</ul>
) : (
<div>Loading...</div>
)
}
</Component>
</div>,
DOM_NODE
);
Or maybe you need a little bit of state but an entire component seems a bit heavy:
// import Component from '@reactions/component'
const Component = ReactComponentComponent;
ReactDOM.render(
<Component initialState={{ count: 0 }}>
{({ setState, state }) => (
<div>
<h2>Every app needs a counter!</h2>
<button
onClick={() =>
setState(state => ({ count: state.count - 1 }))
}
>
-
</button>
<span> {state.count} </span>
<button
onClick={() =>
setState(state => ({ count: state.count + 1 }))
}
>
+
</button>
</div>
)}
</Component>,
DOM_NODE
);
Props
You know all of these already:
didMount({ state, setState, props, forceUpdate })
shouldUpdate({ state, props, nextProps, nextState })
didUpdate({ state, setState, props, forceUpdate, prevProps, prevState })
willUnmount({ state, props })
children({ state, setState, props, forceUpdate })
render({ state, setState, props, forceUpdate })
Legal
Released under MIT license.
Copyright © 2017-present Ryan Florence
Dependencies
No runtime dependency information found for this package.
CVE IssuesActive
0
Scorecards Score
1.70
Test Coverage
No Data
Follows Semver
Yes
Github Stars
1,065
Dependenciestotal
0
DependenciesOutdated
0
DependenciesDeprecated
0
Threat Modelling
No
Repo Audits
No
Learn how to distribute @reactions/component in your own private NPM registry
$npm config set registry
https://npm.cloudsmith.com/owner/repo
/Processing...
✓Done
$npm install @reactions/component
/Processing...
✓Done
3 Releases
NPM on Cloudsmith