Files
cinny/src/app/hooks/useStateEvent.ts
T

33 lines
965 B
TypeScript
Raw Normal View History

2023-06-12 21:15:23 +10:00
import { Room } from 'matrix-js-sdk';
import { useCallback, useMemo } from 'react';
import { useStateEventCallback } from './useStateEventCallback';
import { useForceUpdate } from './useForceUpdate';
import { getStateEvent } from '../utils/room';
import { StateEvent } from '../../types/matrix/room';
export const useStateEvent = (room: Room, eventType: StateEvent, stateKey = '') => {
const [updateCount, forceUpdate] = useForceUpdate();
useStateEventCallback(
room.client,
useCallback(
(event) => {
if (
event.getRoomId() === room.roomId &&
event.getType() === eventType &&
event.getStateKey() === stateKey
) {
forceUpdate();
}
},
[room, eventType, stateKey, forceUpdate]
)
);
return useMemo(
() => getStateEvent(room, eventType, stateKey),
// eslint-disable-next-line react-hooks/exhaustive-deps
[room, eventType, stateKey, updateCount]
);
};