You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
27 lines
824 B
27 lines
824 B
/**
|
|
* Copyright (c) Meta Platforms, Inc. and affiliates.
|
|
*
|
|
* This source code is licensed under the MIT license found in the
|
|
* LICENSE file in the root directory of this source tree.
|
|
*
|
|
* @flow
|
|
*/
|
|
import createEventHandle from '../createEventHandle';
|
|
import useLayoutEffect from '../useLayoutEffect';
|
|
import useStable from '../useStable';
|
|
type Callback = null | ((any) => void);
|
|
type AddListener = (target: EventTarget, listener: null | ((any) => void)) => () => void;
|
|
/**
|
|
* This can be used with any event type include custom events.
|
|
*
|
|
* const click = useEvent('click', options);
|
|
* useEffect(() => {
|
|
* click.setListener(target, onClick);
|
|
* return () => click.clear();
|
|
* }).
|
|
*/
|
|
|
|
declare export default function useEvent(event: string, options?: ?{
|
|
capture?: boolean,
|
|
passive?: boolean,
|
|
}): AddListener; |