
Security News
Attackers Are Hunting High-Impact Node.js Maintainers in a Coordinated Social Engineering Campaign
Multiple high-impact npm maintainers confirm they have been targeted in the same social engineering campaign that compromised Axios.
shared-state-hook
Advanced tools
This is a module for React that implements a hook named useSharedState for managing application state.
It is similar to the provided hook useState, but rather than associating the state with the component that uses the hook,
it stores the state outside of the component so it can be shared by many components.
$ npm install shared-state-hook
<script src="//unpkg.com/shared-state-hook"></script>
https://unpkg.com/shared-state-hook
import {useSharedState} from 'shared-state-hook'
const Counter = props => {
const [count, setCount] = useSharedState("counter", props.count)
return (
<div>
<p>You clicked {count} times</p>
<button onClick={() => setCount(count + 1)}>
Click me
</button>
</div>
)
}
const CounterApp1 = props => <Counter count={1}/>
//Order matters, initial value has already been set
const CounterApp2 = props => <Counter count={2}/>
import {useSharedState} from "shared-state-hook"
const Component = props => {
const [userInfo, setUserInfo] = useSharedState("userInfo", optionalInitialValue, optionalOnUpdatesCallback)
return ""
}
//=> "!"
Allows you to use React Hooks outside of the function body
Invariant React Error 307

import {useHooksOutside} from "shared-state-hook"
const ReactElement = useHooksOutside(()=>{
//Call any restricted React Hook outside of a component function body!
useState()
useEffect()
useContext()
useSharedState("userInfo", initialValues)
});
//=> "!"
You can initialize useSharedState from useHooksOutside as a external Provider that will both update the shared state by others as well as get notified if anyone else updates the same name share
let notifier
const rel = useHooksOutside(() => {
const onUpdate = updates => {
$scope.user = {
...$scope.user, ...updates
}
$scope.$apply()
}
const [, setUser] = useSharedState("user", $scope.user, onUpdate)
notifier=setUser
})
Forked from top-state-hook
FAQs
Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Security News
Multiple high-impact npm maintainers confirm they have been targeted in the same social engineering campaign that compromised Axios.

Security News
Axios compromise traced to social engineering, showing how attacks on maintainers can bypass controls and expose the broader software supply chain.

Security News
Node.js has paused its bug bounty program after funding ended, removing payouts for vulnerability reports but keeping its security process unchanged.