use-sync-event
v0.0.3
Published
A custom hook that lets you subscribe to a DOM event. You can get the event object or subscribe to the change of a property only. Support smart code-completion to select event name and property easily.
Downloads
2
Maintainers
Readme
About
A custom hook that lets you subscribe to a DOM event. It uses useSyncExternalStore under the hood, but allows you to do the following that useSyncExternalStore doesn't support.
- Get the event object.
- Provide a selector function to subscribe to the change of an event's property only.
- Specify a ref to an HTMLElement that the listener of this hook will be attached to.
- Select the event name with code-completion support.
- The event type in the selector function is inferred from the event name you typed in the first parameter, so that you can easily select a property of the event with code-completion aid.
Installation
npm install use-sync-event
or
pnpm add use-sync-event
Import
import { useSyncEvent } from "use-sync-event";
Usage
- The first parameter is the event name that you want to subscribe. If you provide this parameter only, the event object will be returned when it is triggered.
const resizeEvent = useSyncEvent("resize");
- The second parameter is an optional object. It has 2 optional fields. In the first field, you can provide a selector function to subscribe to the change of a property only. In the second field, you can provide a ref to an HTMLElement that the listener of this hook will be attached to.
const myRef = useRef<HTMLElement>(null);
const pointerX = useSyncEvent("pointerdown", {
selector: (e) => e.clientX,
ref: myRef,
});
<div ref={myRef}>Click or touch me...</div>
- Note that the type of e in the optional selector function is inferred by the event name you typed in the first parameter. This allows you to easily find a property of a specific event type. For example, e in the following is inferred as WheelEvent because "wheel" is typed in the first parameter.
const wheelDeltaY = useSyncEvent("wheel", {
selector: (e) => e.deltaY,
});
License
Copyright
Copyright (c) 2023 Ho Chung Law