Security News
Node.js EOL Versions CVE Dubbed the "Worst CVE of the Year" by Security Experts
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
treble-hook
Advanced tools
- IMPORTANT: Upgrading from v1 to v2 includes breaking changes; see API below for new interfaces.
yarn add treble-hook
or
npm install --save treble-hook
import trebleHook, { usePubSub } from 'treble-hook'
// Welcome.jsx
export default function Welcome() {
const [guestName] = usePubSub('guest')
return (
<h3>Welcome to treble-hook, {guestName || ''}!</h3>
)
}
// GuestEntry.jsx
export default function GuestEntry() {
const [, pubGuestName] = usePubSub('guest')
return (
<div>
<input
type="text"
onChange={(e) => { pubGuestName(e.target.value) }}
/>
</div>
)
}
// App.jsx
export default function App() {
trebleHook.addTopic('guest', '')
const GuestPublisher = trebleHook.getPublisher()
return (
<GuestPublisher>
<GuestEntry />
<br />
<Welcome />
</GuestPublisher>
)
}
Adds a new topic that can be published and subscribed to.
addTopic<T>(topicName: string, defaultValue: T, initWithSessionStorage = false): void
topicName
is the identifier for the topic and must be unique within the application.defaultValue
will be used as the initial state value for respective topic.initWithSessionStorage
determines whether to retrieve the topic's initial state from session storage. If true
, then all subsequent published state changes will also be stored in sessions state for the app. This is helpful to ensure consistent state between any routes that require hard reloads.Example:
import trebleHook from 'treble-hook'
trebleHook.addTopic('apples', 25)
trebleHook.addTopic('organges', 42)
trebleHook.addTopic('carrots', 100)
Returns a TrebleHookPublisher JSX element that manages publications for given topics. The Publisher JSX should be placed high in the component tree (ancestral to all components that interact with the respective publisher state).
getPublisher(topics?: string[]): TrebleHookPublisher (JSX.Element)
topics
is the array of topic names contextual to this publisher that have been added using the addTopic
method. If no topics are passed in then all topics will be included in the returned publisher.Example:
import React from 'react'
import trebleHook from 'treble-hook'
const FruitCountPublisher = trebleHook.getPublisher(['apples', 'oranges'])
return (
<FruitCountPublisher>
<FruitStand />
</FruitCountPublisher>
)
A React hook that subscribes a component to a topic. The hook returns a tuple that is similar to the tuple returned from useState
where the first element is the topic's current state value and the second element is the method to publish a new state value for the topic.
usePubSub<T>(topic: string): PubSubTuple<T>
topic
is the unique topic name to subscribe to.Example:
import React from 'react'
import { usePubSub } from 'treble-hook'
function FruitTable() {
const [apples] = usePubSub<number>('apples')
const [oranges] = usePubSub<number>('oranges')
return (
<div>
<h3>Apple count: {apples}</h3>
<h3>Orange count: {oranges}</h3>
</div>
)
}
function FruitVendor() {
const [apples, pubApples] = usePubSub<number>('apples')
const [oranges, pubOranges] = usePubSub<number>('oranges')
return (
<div>
<button
disabled={apples === 0}
onClick={() => {
pubApples(apples - 1)
}}
>
Sell an apple
</button>
<button
disabled={oranges === 0}
onClick={() => {
pubOranges(oranges - 1)
}}
>
Sell an orange
</button>
</div>
)
}
function FruitStand() {
<FruitTable />
<FruitVendor />
}
FAQs
Get hooked on simple subscribe-and-publish in ReactJS.
The npm package treble-hook receives a total of 4 weekly downloads. As such, treble-hook popularity was classified as not popular.
We found that treble-hook demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 2 open source maintainers collaborating on the project.
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
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
Security News
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.
Security News
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.