35 lines
1.4 KiB
JavaScript
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;
|