mirror of
https://github.com/vector-im/element-web.git
synced 2026-03-05 21:42:13 +01:00
* Update all non-major dependencies * Delint Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Iterate Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Prettier Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> --------- Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com> Co-authored-by: Michael Telatynski <7t3chguy@gmail.com>
33 lines
1.1 KiB
TypeScript
33 lines
1.1 KiB
TypeScript
/*
|
|
Copyright 2024 New Vector Ltd.
|
|
Copyright 2020 The Matrix.org Foundation C.I.C.
|
|
|
|
SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only OR LicenseRef-Element-Commercial
|
|
Please see LICENSE files in the repository root for full details.
|
|
*/
|
|
|
|
import { useEffect, useRef } from "react";
|
|
|
|
import { type ActionPayload } from "../dispatcher/payloads";
|
|
import { type MatrixDispatcher } from "../dispatcher/dispatcher";
|
|
|
|
// Hook to simplify listening to event dispatches
|
|
export const useDispatcher = (dispatcher: MatrixDispatcher, handler: (payload: ActionPayload) => void): void => {
|
|
// Create a ref that stores handler
|
|
const savedHandler = useRef((payload: ActionPayload) => {});
|
|
|
|
// Update ref.current value if handler changes.
|
|
useEffect(() => {
|
|
savedHandler.current = handler;
|
|
}, [handler]);
|
|
|
|
useEffect(() => {
|
|
// Create event listener that calls handler function stored in ref
|
|
const ref = dispatcher.register((payload) => savedHandler.current(payload));
|
|
// Remove event listener on cleanup
|
|
return () => {
|
|
dispatcher.unregister(ref);
|
|
};
|
|
}, [dispatcher]);
|
|
};
|