2026-03-07 18:03:32 +11:00
|
|
|
import {
|
|
|
|
|
ClientWidgetApi,
|
|
|
|
|
IWidgetApiAcknowledgeResponseData,
|
|
|
|
|
IWidgetApiRequestData,
|
|
|
|
|
} from 'matrix-widget-api';
|
|
|
|
|
import { useCallback, useEffect, useState } from 'react';
|
|
|
|
|
import { CallControl, CallControlEvent } from './CallControl';
|
|
|
|
|
import { CallControlState } from './CallControlState';
|
|
|
|
|
|
|
|
|
|
export const useClientWidgetApiEvent = <T>(
|
|
|
|
|
api: ClientWidgetApi | undefined,
|
|
|
|
|
type: string,
|
2026-05-21 23:30:50 -04:00
|
|
|
callback: (event: CustomEvent<T>) => void,
|
2026-03-07 18:03:32 +11:00
|
|
|
) => {
|
|
|
|
|
useEffect(() => {
|
|
|
|
|
api?.on(`action:${type}`, callback);
|
|
|
|
|
return () => {
|
|
|
|
|
api?.off(`action:${type}`, callback);
|
|
|
|
|
};
|
|
|
|
|
}, [api, type, callback]);
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
export const useSendClientWidgetApiAction = (api: ClientWidgetApi) => {
|
|
|
|
|
const sendWidgetAction = useCallback(
|
|
|
|
|
async <T extends IWidgetApiRequestData = IWidgetApiRequestData>(
|
|
|
|
|
action: string,
|
2026-05-21 23:30:50 -04:00
|
|
|
data: T,
|
2026-03-07 18:03:32 +11:00
|
|
|
): Promise<IWidgetApiAcknowledgeResponseData> => api.transport.send(action, data),
|
2026-05-21 23:30:50 -04:00
|
|
|
[api],
|
2026-03-07 18:03:32 +11:00
|
|
|
);
|
|
|
|
|
|
|
|
|
|
return sendWidgetAction;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
export const useCallControlState = (control: CallControl): CallControlState => {
|
|
|
|
|
const [state, setState] = useState(control.getState());
|
|
|
|
|
|
|
|
|
|
useEffect(() => {
|
|
|
|
|
const handleUpdate = () => {
|
|
|
|
|
setState(control.getState());
|
|
|
|
|
};
|
|
|
|
|
control.on(CallControlEvent.StateUpdate, handleUpdate);
|
|
|
|
|
return () => {
|
|
|
|
|
control.off(CallControlEvent.StateUpdate, handleUpdate);
|
|
|
|
|
};
|
|
|
|
|
}, [control]);
|
|
|
|
|
|
|
|
|
|
return state;
|
|
|
|
|
};
|