bigbluebutton-Github/bigbluebutton-html5/imports/ui/components/nav-bar/leave-meeting-button/container.jsx
João Victor Nunes 06500be757
refactor(storage): replace Tracker.Dependency with observer hook (#20322)
* refactor(storage): replace Tracker.Dependency with observer hook

* fix(storage): set initial value

* refactor(storage): stop using Meteor's Session singleton
2024-06-06 10:50:03 -03:00

35 lines
1.3 KiB
JavaScript

import React from 'react';
import { withTracker } from 'meteor/react-meteor-data';
import deviceInfo from '/imports/utils/deviceInfo';
import { useMutation } from '@apollo/client';
import LeaveMeetingButton from './component';
import { meetingIsBreakout } from '/imports/ui/components/app/service';
import { layoutSelectInput, layoutSelect } from '../../layout/context';
import { SMALL_VIEWPORT_BREAKPOINT } from '../../layout/enums';
import { USER_LEAVE_MEETING } from '/imports/ui/core/graphql/mutations/userMutations';
import { useStorageKey } from '/imports/ui/services/storage/hooks';
const LeaveMeetingButtonContainer = (props) => {
const { width: browserWidth } = layoutSelectInput((i) => i.browser);
const isMobile = browserWidth <= SMALL_VIEWPORT_BREAKPOINT;
const isRTL = layoutSelect((i) => i.isRTL);
const [userLeaveMeeting] = useMutation(USER_LEAVE_MEETING);
const isDropdownOpen = useStorageKey('dropdownOpen');
return (
<LeaveMeetingButton {...
{
isMobile, isRTL, userLeaveMeeting, isDropdownOpen, ...props,
}
}
/>
);
};
export default withTracker((props) => ({
amIModerator: props.amIModerator,
isMobile: deviceInfo.isMobile,
isMeteorConnected: Meteor.status().connected,
isBreakoutRoom: meetingIsBreakout(),
}))(LeaveMeetingButtonContainer);