bigbluebutton-Github/bigbluebutton-html5/imports/ui/components/actions-bar/reactions-button/container.jsx

52 lines
1.7 KiB
React
Raw Normal View History

2023-04-28 05:31:11 +08:00
import React from 'react';
import { layoutSelectInput, layoutDispatch } from '/imports/ui/components/layout/context';
import { injectIntl } from 'react-intl';
2023-07-18 19:54:36 +08:00
import ReactionsButton from './component';
2023-06-27 22:08:49 +08:00
import { SMALL_VIEWPORT_BREAKPOINT } from '/imports/ui/components/layout/enums';
import Auth from '/imports/ui/services/auth';
import useCurrentUser from '/imports/ui/core/hooks/useCurrentUser';
import useSettings from '/imports/ui/services/settings/hooks/useSettings';
import { SETTINGS } from '/imports/ui/services/settings/enums';
2023-07-18 19:54:36 +08:00
const ReactionsButtonContainer = ({ ...props }) => {
2023-04-28 05:31:11 +08:00
const layoutContextDispatch = layoutDispatch();
const sidebarContent = layoutSelectInput((i) => i.sidebarContent);
const { sidebarContentPanel } = sidebarContent;
2023-06-27 22:08:49 +08:00
const { width: browserWidth } = layoutSelectInput((i) => i.browser);
const isMobile = browserWidth <= SMALL_VIEWPORT_BREAKPOINT;
const { data: currentUserData } = useCurrentUser((user) => ({
emoji: user.emoji,
raiseHand: user.raiseHand,
2024-04-24 01:56:23 +08:00
away: user.away,
voice: user.voice,
reactionEmoji: user.reactionEmoji,
}));
2024-04-25 02:45:28 +08:00
const currentUser = {
userId: Auth.userID,
emoji: currentUserData?.emoji,
raiseHand: currentUserData?.raiseHand,
2024-04-24 01:56:23 +08:00
away: currentUserData?.away,
muted: currentUserData?.voice?.muted || false,
};
const { autoCloseReactionsBar } = useSettings(SETTINGS.APPLICATION);
return (
2023-07-18 19:54:36 +08:00
<ReactionsButton {...{
currentUserReaction: currentUserData?.reactionEmoji ?? 'none',
2024-04-25 02:45:28 +08:00
layoutContextDispatch,
sidebarContentPanel,
isMobile,
autoCloseReactionsBar,
2024-04-25 02:45:28 +08:00
...currentUser,
...props,
}}
/>
);
};
export default injectIntl(ReactionsButtonContainer);