use-custom-event
v2.0.1
Published
data:image/s3,"s3://crabby-images/a31fe/a31fe65142997b1d23df7d93f4a8eeba9fba6a48" alt="Bundle Size" data:image/s3,"s3://crabby-images/4fe27/4fe27e25478c5fd2f9f6a569604c013385784913" alt="npm version" data:image/s3,"s3://crabby-images/cbe58/cbe580d3d14a4e94fac9068f38604c191dab3198" alt="types" data:image/s3,"s3://crabby-images/9edbb/9edbb6399184484c7dde2c306ee390382a6dfeb2" alt="visitor badge" and React hook for listening. Make the event payload strictly typed using zod
Installation
npm install use-custom-event
Usage
Basic Custom Event Emitter
import { z } from 'zod';
import { createEventEmitter } from 'use-custom-event';
const { emit, subscribe, useEventListener } = createEventEmitter(
'my-event',
z.object({
name: z.string(),
})
);
// subscribing to the event - payload is strictly typed
// can be done from anywhere in the app (not react specific)
const unsubscribe = subscribe((data) => {
console.log(data.name);
});
// call unsubscribe to stop listening to the event
unsubscribe();
function App() {
// using the useEventListener hook
useEventListener(
// callback to handle the event - payload is strictly typed
useCallback((data) => {
console.log(data.name);
}, [])
);
return (
<button
onClick={() => {
// emitting the event (with payload) - payload is strictly typed
// can be done from anywhere in the app (not react specific)
emit({
name: 'drenther',
});
}}
>
Trigger Event
</button>
);
}
Broadcast Channel Event Emitter
Broadcast Channel is a simple API for communication between browsing contexts in the same origin. It is useful for sending messages between different tabs or windows of the same origin.
import { z } from 'zod';
import { createBroadcastChannelEventEmitter } from 'use-custom-event';
const channel = new BroadcastChannel('my-channel');
const { emit, subscribe, useEventListener } =
createBroadcastChannelEventEmitter(
channel,
z.object({
name: z.string(),
})
);
// subscribing to the event - payload is strictly typed
// can be done from anywhere in the app (not react specific)
const unsubscribe = subscribe((data) => {
console.log(data.name);
});
// call unsubscribe to stop listening to the event
unsubscribe();
function App() {
// using the useEventListener hook
useEventListener(
// callback to handle the event - payload is strictly typed
useCallback((data) => {
console.log(data.name);
}, [])
);
return (
<button
onClick={() => {
// emitting the event (with payload) - payload is strictly typed
// can be done from anywhere in the app (not react specific)
emit({
name: 'drenther',
});
}}
>
Trigger Event
</button>
);
}
Use it for whatever you like and drop us a star!