bigbluebutton-Github/bigbluebutton-html5/imports/ui/components/connection-status/button/container.jsx
2024-07-04 17:26:09 -03:00

35 lines
1.4 KiB
JavaScript

import React from 'react';
import ConnectionStatusButtonComponent from './component';
import useSettings from '/imports/ui/services/settings/hooks/useSettings';
import { SETTINGS } from '/imports/ui/services/settings/enums';
import { useStorageKey } from '/imports/ui/services/storage/hooks';
import { useReactiveVar } from '@apollo/client';
import connectionStatus from '/imports/ui/core/graphql/singletons/connectionStatus';
import { getWorstStatus } from '../service';
const ConnectionStatusButtonContainer = (props) => {
const connected = useReactiveVar(connectionStatus.getConnectedStatusVar());
const rttStatus = useReactiveVar(connectionStatus.getRttStatusVar());
const jitterStatus = useReactiveVar(connectionStatus.getJitterStatusVar());
const packetLossStatus = useReactiveVar(connectionStatus.getPacketLossStatusVar());
const myCurrentStatus = getWorstStatus([rttStatus, jitterStatus, packetLossStatus]);
const { paginationEnabled } = useSettings(SETTINGS.APPLICATION);
const { viewParticipantsWebcams } = useSettings(SETTINGS.DATA_SAVING);
const isGridLayout = useStorageKey('isGridEnabled');
return (
<ConnectionStatusButtonComponent
myCurrentStatus={myCurrentStatus}
paginationEnabled={paginationEnabled}
viewParticipantsWebcams={viewParticipantsWebcams}
isGridLayout={isGridLayout}
connected={connected}
{...props}
/>
);
};
export default ConnectionStatusButtonContainer;