@100mslive/roomkit-react 0.1.6-alpha.1 → 0.1.6-alpha.3
Sign up to get free protection for your applications and to get access to all the features.
- package/dist/{HLSView-HNVYG5VE.js → HLSView-HL455FYH.js} +3 -3
- package/dist/Prebuilt/components/Footer/ChatToggle.d.ts +1 -3
- package/dist/Prebuilt/components/Leave/DesktopLeaveRoom.d.ts +2 -1
- package/dist/Prebuilt/components/Leave/MwebLeaveRoom.d.ts +2 -1
- package/dist/Prebuilt/components/SidePaneTabs.d.ts +7 -0
- package/dist/{VirtualBackground-UM2FOUHQ.js → VirtualBackground-6EP3X7MO.js} +6 -6
- package/dist/VirtualBackground-6EP3X7MO.js.map +7 -0
- package/dist/{chunk-LYSAET4G.js → chunk-6JF3GAOH.js} +109 -127
- package/dist/chunk-6JF3GAOH.js.map +7 -0
- package/dist/{chunk-POE7H4IE.js → chunk-KAJJ56J4.js} +2 -2
- package/dist/{chunk-POE7H4IE.js.map → chunk-KAJJ56J4.js.map} +1 -1
- package/dist/{chunk-364HP22I.js → chunk-UXBTLGWY.js} +2 -2
- package/dist/{conference-UWLJHMB2.js → conference-MPZNWHV5.js} +472 -415
- package/dist/conference-MPZNWHV5.js.map +7 -0
- package/dist/index.cjs.js +714 -678
- package/dist/index.cjs.js.map +4 -4
- package/dist/index.js +2 -2
- package/dist/meta.cjs.json +153 -153
- package/dist/meta.esbuild.json +185 -184
- package/package.json +6 -6
- package/src/Button/Button.tsx +6 -6
- package/src/Prebuilt/components/Chat/Chat.jsx +3 -9
- package/src/Prebuilt/components/Chat/useEmojiPickerStyles.js +1 -0
- package/src/Prebuilt/components/Footer/ChatToggle.tsx +2 -9
- package/src/Prebuilt/components/Footer/Footer.tsx +23 -7
- package/src/Prebuilt/components/Footer/ParticipantList.jsx +4 -5
- package/src/Prebuilt/components/Footer/RoleAccordion.tsx +1 -1
- package/src/Prebuilt/components/Header/HeaderComponents.jsx +10 -9
- package/src/Prebuilt/components/InsetTile.tsx +1 -0
- package/src/Prebuilt/components/Leave/DesktopLeaveRoom.tsx +7 -9
- package/src/Prebuilt/components/Leave/LeaveRoom.tsx +6 -2
- package/src/Prebuilt/components/Leave/MwebLeaveRoom.tsx +7 -4
- package/src/Prebuilt/components/MoreSettings/SplitComponents/MwebOptions.tsx +1 -1
- package/src/Prebuilt/components/Notifications/Notifications.jsx +4 -3
- package/src/Prebuilt/components/Preview/PreviewJoin.tsx +2 -3
- package/src/Prebuilt/components/RoleChangeRequestModal.tsx +4 -3
- package/src/Prebuilt/components/ScreenshareTile.jsx +15 -7
- package/src/Prebuilt/components/SidePaneTabs.tsx +141 -0
- package/src/Prebuilt/components/conference.jsx +9 -1
- package/src/Prebuilt/components/hooks/useMetadata.jsx +7 -25
- package/src/Prebuilt/layouts/SidePane.tsx +12 -10
- package/src/Prebuilt/plugins/VirtualBackground/VirtualBackground.jsx +3 -3
- package/src/Prebuilt/provider/roomLayoutProvider/hooks/useFetchRoomLayout.ts +2 -2
- package/dist/VirtualBackground-UM2FOUHQ.js.map +0 -7
- package/dist/chunk-LYSAET4G.js.map +0 -7
- package/dist/conference-UWLJHMB2.js.map +0 -7
- package/src/Prebuilt/components/Chat/ChatParticipantHeader.jsx +0 -84
- /package/dist/{HLSView-HNVYG5VE.js.map → HLSView-HL455FYH.js.map} +0 -0
- /package/dist/{chunk-364HP22I.js.map → chunk-UXBTLGWY.js.map} +0 -0
@@ -1,6 +1,6 @@
|
|
1
1
|
import {
|
2
2
|
ActionTile
|
3
|
-
} from "./chunk-
|
3
|
+
} from "./chunk-UXBTLGWY.js";
|
4
4
|
import {
|
5
5
|
APP_DATA,
|
6
6
|
Accordion,
|
@@ -77,13 +77,14 @@ import {
|
|
77
77
|
useSetAppDataByKey,
|
78
78
|
useSetSubscribedChatSelector,
|
79
79
|
useSetUiSettings,
|
80
|
+
useSidepaneReset,
|
80
81
|
useSidepaneToggle,
|
81
82
|
useTheme,
|
82
83
|
useUISettings,
|
83
84
|
useUrlToEmbed,
|
84
85
|
useUserPreferences,
|
85
86
|
useWaitingViewerRole
|
86
|
-
} from "./chunk-
|
87
|
+
} from "./chunk-6JF3GAOH.js";
|
87
88
|
import {
|
88
89
|
Box,
|
89
90
|
Flex,
|
@@ -102,10 +103,10 @@ import {
|
|
102
103
|
slideLeftAndFade,
|
103
104
|
styled,
|
104
105
|
textEllipsis
|
105
|
-
} from "./chunk-
|
106
|
+
} from "./chunk-KAJJ56J4.js";
|
106
107
|
|
107
108
|
// src/Prebuilt/components/conference.jsx
|
108
|
-
import React62, { useEffect as
|
109
|
+
import React62, { useEffect as useEffect25, useRef as useRef14, useState as useState35 } from "react";
|
109
110
|
import { useNavigate, useParams } from "react-router-dom";
|
110
111
|
import { usePrevious } from "react-use";
|
111
112
|
import {
|
@@ -114,14 +115,13 @@ import {
|
|
114
115
|
selectIsConnectedToRoom as selectIsConnectedToRoom7,
|
115
116
|
selectRoomState,
|
116
117
|
useHMSActions as useHMSActions22,
|
117
|
-
useHMSStore as
|
118
|
+
useHMSStore as useHMSStore36
|
118
119
|
} from "@100mslive/react-sdk";
|
119
120
|
|
120
121
|
// src/Prebuilt/components/Footer/Footer.tsx
|
121
|
-
import
|
122
|
+
import React36, { Suspense, useEffect as useEffect6 } from "react";
|
122
123
|
import { useMedia as useMedia5 } from "react-use";
|
123
124
|
import { Chat_ChatState } from "@100mslive/types-prebuilt/elements/chat";
|
124
|
-
import { selectIsLocalVideoEnabled as selectIsLocalVideoEnabled2, useHMSStore as useHMSStore18 } from "@100mslive/react-sdk";
|
125
125
|
|
126
126
|
// src/Prebuilt/components/EmojiReaction.jsx
|
127
127
|
import React2, { Fragment, useState } from "react";
|
@@ -335,7 +335,8 @@ var LeaveSessionContent = ({
|
|
335
335
|
// src/Prebuilt/components/Leave/DesktopLeaveRoom.tsx
|
336
336
|
var DesktopLeaveRoom = ({
|
337
337
|
leaveRoom,
|
338
|
-
screenType
|
338
|
+
screenType,
|
339
|
+
endRoom
|
339
340
|
}) => {
|
340
341
|
const [open, setOpen] = useState2(false);
|
341
342
|
const [showLeaveRoomAlert, setShowLeaveRoomAlert] = useState2(false);
|
@@ -343,12 +344,12 @@ var DesktopLeaveRoom = ({
|
|
343
344
|
const isConnected = useHMSStore2(selectIsConnectedToRoom2);
|
344
345
|
const permissions = useHMSStore2(selectPermissions);
|
345
346
|
const { isStreamingOn } = useRecordingStreaming();
|
346
|
-
const showStream =
|
347
|
+
const showStream = screenType !== "hls_live_streaming" && isStreamingOn;
|
347
348
|
useDropdownList({ open: open || showEndStreamAlert || showLeaveRoomAlert, name: "LeaveRoom" });
|
348
349
|
if (!permissions || !isConnected) {
|
349
350
|
return null;
|
350
351
|
}
|
351
|
-
return /* @__PURE__ */ React6.createElement(Fragment2, null, permissions.hlsStreaming ? /* @__PURE__ */ React6.createElement(Flex, null, /* @__PURE__ */ React6.createElement(
|
352
|
+
return /* @__PURE__ */ React6.createElement(Fragment2, null, screenType !== "hls_live_streaming" && ((permissions == null ? void 0 : permissions.hlsStreaming) || (permissions == null ? void 0 : permissions.endRoom)) ? /* @__PURE__ */ React6.createElement(Flex, null, /* @__PURE__ */ React6.createElement(
|
352
353
|
LeaveIconButton,
|
353
354
|
{
|
354
355
|
key: "LeaveRoom",
|
@@ -358,11 +359,7 @@ var DesktopLeaveRoom = ({
|
|
358
359
|
borderBottomRightRadius: 0
|
359
360
|
},
|
360
361
|
onClick: () => {
|
361
|
-
|
362
|
-
setShowLeaveRoomAlert(true);
|
363
|
-
} else {
|
364
|
-
leaveRoom({ endstream: false });
|
365
|
-
}
|
362
|
+
leaveRoom({ endstream: false });
|
366
363
|
}
|
367
364
|
},
|
368
365
|
/* @__PURE__ */ React6.createElement(Tooltip, { title: "Leave Room" }, /* @__PURE__ */ React6.createElement(Box, null, /* @__PURE__ */ React6.createElement(ExitIcon, { style: { transform: "rotate(180deg)" } })))
|
@@ -400,7 +397,7 @@ var DesktopLeaveRoom = ({
|
|
400
397
|
css: { p: 0 }
|
401
398
|
}
|
402
399
|
)
|
403
|
-
),
|
400
|
+
), (permissions == null ? void 0 : permissions.endRoom) || (permissions == null ? void 0 : permissions.hlsStreaming) ? /* @__PURE__ */ React6.createElement(
|
404
401
|
Dropdown.Item,
|
405
402
|
{
|
406
403
|
css: {
|
@@ -443,7 +440,7 @@ var DesktopLeaveRoom = ({
|
|
443
440
|
EndSessionContent,
|
444
441
|
{
|
445
442
|
setShowEndStreamAlert,
|
446
|
-
leaveRoom,
|
443
|
+
leaveRoom: isStreamingOn ? leaveRoom : endRoom,
|
447
444
|
isStreamingOn,
|
448
445
|
isModal: true
|
449
446
|
}
|
@@ -456,7 +453,8 @@ import { selectIsConnectedToRoom as selectIsConnectedToRoom3, selectPermissions
|
|
456
453
|
import { ExitIcon as ExitIcon2, StopIcon as StopIcon2 } from "@100mslive/react-icons";
|
457
454
|
var MwebLeaveRoom = ({
|
458
455
|
leaveRoom,
|
459
|
-
screenType
|
456
|
+
screenType,
|
457
|
+
endRoom
|
460
458
|
}) => {
|
461
459
|
const [open, setOpen] = useState3(false);
|
462
460
|
const [showLeaveRoomAlert, setShowLeaveRoomAlert] = useState3(false);
|
@@ -464,12 +462,12 @@ var MwebLeaveRoom = ({
|
|
464
462
|
const isConnected = useHMSStore3(selectIsConnectedToRoom3);
|
465
463
|
const permissions = useHMSStore3(selectPermissions2);
|
466
464
|
const { isStreamingOn } = useRecordingStreaming2();
|
467
|
-
const showStream =
|
465
|
+
const showStream = screenType !== "hls_live_streaming" && isStreamingOn;
|
468
466
|
useDropdownList({ open, name: "LeaveRoom" });
|
469
467
|
if (!permissions || !isConnected) {
|
470
468
|
return null;
|
471
469
|
}
|
472
|
-
return /* @__PURE__ */ React7.createElement(Fragment3, null,
|
470
|
+
return /* @__PURE__ */ React7.createElement(Fragment3, null, screenType !== "hls_live_streaming" ? /* @__PURE__ */ React7.createElement(Sheet.Root, { open, onOpenChange: setOpen }, /* @__PURE__ */ React7.createElement(Sheet.Trigger, { asChild: true }, /* @__PURE__ */ React7.createElement(
|
473
471
|
LeaveIconButton,
|
474
472
|
{
|
475
473
|
key: "LeaveRoom",
|
@@ -491,7 +489,7 @@ var MwebLeaveRoom = ({
|
|
491
489
|
onClick: () => leaveRoom({ endstream: false }),
|
492
490
|
css: { pt: 0, mt: "$10", color: "$on_surface_low", "&:hover": { color: "$on_surface_high" } }
|
493
491
|
}
|
494
|
-
),
|
492
|
+
), (permissions == null ? void 0 : permissions.endRoom) || (permissions == null ? void 0 : permissions.hlsStreaming) ? /* @__PURE__ */ React7.createElement(
|
495
493
|
LeaveCard,
|
496
494
|
{
|
497
495
|
title: showStream ? "End Stream" : "End Session",
|
@@ -523,7 +521,7 @@ var MwebLeaveRoom = ({
|
|
523
521
|
EndSessionContent,
|
524
522
|
{
|
525
523
|
setShowEndStreamAlert,
|
526
|
-
leaveRoom,
|
524
|
+
leaveRoom: isStreamingOn ? leaveRoom : endRoom,
|
527
525
|
isStreamingOn
|
528
526
|
}
|
529
527
|
))), screenType === "hls_live_streaming" ? /* @__PURE__ */ React7.createElement(Sheet.Root, { open: showLeaveRoomAlert, onOpenChange: setShowLeaveRoomAlert }, /* @__PURE__ */ React7.createElement(Sheet.Content, { css: { bg: "$surface_dim", p: "$10", pb: "$12" } }, /* @__PURE__ */ React7.createElement(LeaveSessionContent, { setShowLeaveRoomAlert, leaveRoom }))) : null);
|
@@ -555,6 +553,10 @@ var LeaveRoom = ({ screenType }) => {
|
|
555
553
|
ToastManager.addToast({ title: "Error in stopping the stream", type: "error" });
|
556
554
|
}
|
557
555
|
});
|
556
|
+
const endRoom = () => {
|
557
|
+
hmsActions.endRoom(false, "End Room");
|
558
|
+
redirectToLeave();
|
559
|
+
};
|
558
560
|
const leaveRoom = (_0) => __async(void 0, [_0], function* ({ endstream = false }) {
|
559
561
|
if (endstream || hlsState.running && peersWithStreamingRights.length === 1) {
|
560
562
|
yield stopStream();
|
@@ -565,7 +567,7 @@ var LeaveRoom = ({ screenType }) => {
|
|
565
567
|
if (!permissions || !isConnected) {
|
566
568
|
return null;
|
567
569
|
}
|
568
|
-
return isMobile ? /* @__PURE__ */ React8.createElement(MwebLeaveRoom, { leaveRoom, screenType }) : /* @__PURE__ */ React8.createElement(DesktopLeaveRoom, { leaveRoom, screenType });
|
570
|
+
return isMobile ? /* @__PURE__ */ React8.createElement(MwebLeaveRoom, { leaveRoom, screenType, endRoom }) : /* @__PURE__ */ React8.createElement(DesktopLeaveRoom, { leaveRoom, screenType, endRoom });
|
569
571
|
};
|
570
572
|
|
571
573
|
// src/Prebuilt/components/MoreSettings/MoreSettings.tsx
|
@@ -2068,7 +2070,7 @@ var MwebOptions = ({
|
|
2068
2070
|
isRecordingLoading ? /* @__PURE__ */ React22.createElement(Loading, null) : /* @__PURE__ */ React22.createElement(RecordIcon2, null),
|
2069
2071
|
/* @__PURE__ */ React22.createElement(ActionTile.Title, null, isBrowserRecordingOn ? "Recording On" : isRecordingLoading ? "Starting Recording" : "Start Recording")
|
2070
2072
|
) : null
|
2071
|
-
))), /* @__PURE__ */ React22.createElement(SettingsModal_default, { open: openSettingsSheet, onOpenChange: setOpenSettingsSheet }), openModals.has(MODALS2.MUTE_ALL) && /* @__PURE__ */ React22.createElement(MuteAllModal, { onOpenChange: (value) => updateState(MODALS2.MUTE_ALL, value), isMobile: true }), openModals.has(MODALS2.CHANGE_NAME) && /* @__PURE__ */ React22.createElement(
|
2073
|
+
))), /* @__PURE__ */ React22.createElement(SettingsModal_default, { open: openSettingsSheet, onOpenChange: setOpenSettingsSheet, screenType }), openModals.has(MODALS2.MUTE_ALL) && /* @__PURE__ */ React22.createElement(MuteAllModal, { onOpenChange: (value) => updateState(MODALS2.MUTE_ALL, value), isMobile: true }), openModals.has(MODALS2.CHANGE_NAME) && /* @__PURE__ */ React22.createElement(
|
2072
2074
|
ChangeNameModal,
|
2073
2075
|
{
|
2074
2076
|
onOpenChange: (value) => updateState(MODALS2.CHANGE_NAME, value),
|
@@ -2644,33 +2646,28 @@ var ScreenshareToggle = ({ css = {} }) => {
|
|
2644
2646
|
};
|
2645
2647
|
|
2646
2648
|
// src/Prebuilt/components/Footer/ChatToggle.tsx
|
2647
|
-
import React32
|
2649
|
+
import React32 from "react";
|
2648
2650
|
import { selectUnreadHMSMessagesCount, useHMSStore as useHMSStore14 } from "@100mslive/react-sdk";
|
2649
2651
|
import { ChatIcon, ChatUnreadIcon } from "@100mslive/react-icons";
|
2650
|
-
var ChatToggle = (
|
2652
|
+
var ChatToggle = () => {
|
2651
2653
|
const countUnreadMessages = useHMSStore14(selectUnreadHMSMessagesCount);
|
2652
2654
|
const isChatOpen = useIsSidepaneTypeOpen(SIDE_PANE_OPTIONS.CHAT);
|
2653
2655
|
const toggleChat = useSidepaneToggle(SIDE_PANE_OPTIONS.CHAT);
|
2654
|
-
useEffect5(() => {
|
2655
|
-
if (!isChatOpen && openByDefault) {
|
2656
|
-
toggleChat();
|
2657
|
-
}
|
2658
|
-
}, [toggleChat, openByDefault]);
|
2659
2656
|
return /* @__PURE__ */ React32.createElement(Tooltip, { key: "chat", title: `${isChatOpen ? "Close" : "Open"} chat` }, /* @__PURE__ */ React32.createElement(IconButton_default, { onClick: toggleChat, active: !isChatOpen, "data-testid": "chat_btn" }, countUnreadMessages === 0 ? /* @__PURE__ */ React32.createElement(ChatIcon, null) : /* @__PURE__ */ React32.createElement(ChatUnreadIcon, { "data-testid": "chat_unread_btn" })));
|
2660
2657
|
};
|
2661
2658
|
|
2662
2659
|
// src/Prebuilt/components/Footer/ParticipantList.jsx
|
2663
|
-
import
|
2660
|
+
import React35, { Fragment as Fragment7, useCallback as useCallback6, useEffect as useEffect5, useState as useState18 } from "react";
|
2664
2661
|
import { useDebounce, useMedia as useMedia4 } from "react-use";
|
2665
2662
|
import {
|
2666
2663
|
selectIsPeerAudioEnabled,
|
2667
2664
|
selectLocalPeerID as selectLocalPeerID4,
|
2668
|
-
selectPeerCount as
|
2665
|
+
selectPeerCount as selectPeerCount2,
|
2669
2666
|
selectPeerMetadata as selectPeerMetadata2,
|
2670
2667
|
selectPeersByCondition as selectPeersByCondition2,
|
2671
2668
|
selectPermissions as selectPermissions8,
|
2672
2669
|
useHMSActions as useHMSActions11,
|
2673
|
-
useHMSStore as
|
2670
|
+
useHMSStore as useHMSStore16
|
2674
2671
|
} from "@100mslive/react-sdk";
|
2675
2672
|
import {
|
2676
2673
|
ChangeRoleIcon as ChangeRoleIcon2,
|
@@ -2682,86 +2679,14 @@ import {
|
|
2682
2679
|
VerticalMenuIcon as VerticalMenuIcon4
|
2683
2680
|
} from "@100mslive/react-icons";
|
2684
2681
|
|
2685
|
-
// src/Prebuilt/components/Chat/ChatParticipantHeader.jsx
|
2686
|
-
import React33, { useState as useState17 } from "react";
|
2687
|
-
import { selectPeerCount as selectPeerCount2, useHMSStore as useHMSStore15 } from "@100mslive/react-sdk";
|
2688
|
-
import { CrossIcon as CrossIcon5 } from "@100mslive/react-icons";
|
2689
|
-
var tabTriggerCSS = {
|
2690
|
-
color: "$on_surface_high",
|
2691
|
-
p: "$4",
|
2692
|
-
fontWeight: "$semiBold",
|
2693
|
-
fontSize: "$sm",
|
2694
|
-
w: "100%",
|
2695
|
-
justifyContent: "center"
|
2696
|
-
};
|
2697
|
-
var ChatParticipantHeader = React33.memo(({ activeTabValue = SIDE_PANE_OPTIONS.CHAT }) => {
|
2698
|
-
const toggleChat = useSidepaneToggle(SIDE_PANE_OPTIONS.CHAT);
|
2699
|
-
const toggleParticipants = useSidepaneToggle(SIDE_PANE_OPTIONS.PARTICIPANTS);
|
2700
|
-
const [activeTab, setActiveTab] = useState17(activeTabValue);
|
2701
|
-
const peerCount = useHMSStore15(selectPeerCount2);
|
2702
|
-
const { elements } = useRoomLayoutConferencingScreen();
|
2703
|
-
const showChat = !!(elements == null ? void 0 : elements.chat);
|
2704
|
-
const showParticipants = !!(elements == null ? void 0 : elements.participant_list);
|
2705
|
-
const hideTabs = !(showChat && showParticipants);
|
2706
|
-
return /* @__PURE__ */ React33.createElement(
|
2707
|
-
Flex,
|
2708
|
-
{
|
2709
|
-
align: "center",
|
2710
|
-
css: {
|
2711
|
-
color: "$on_primary_high",
|
2712
|
-
h: "$16"
|
2713
|
-
}
|
2714
|
-
},
|
2715
|
-
hideTabs ? /* @__PURE__ */ React33.createElement(Text, { variant: "sm", css: { fontWeight: "$semiBold", c: "$on_surface_high" } }, showChat ? "Chat" : `Participants (${peerCount})`) : /* @__PURE__ */ React33.createElement(Flex, { css: { w: "100%", bg: "$surface_default", borderRadius: "$2" } }, /* @__PURE__ */ React33.createElement(Tabs.Root, { value: activeTab, onValueChange: setActiveTab, css: { w: "100%" } }, /* @__PURE__ */ React33.createElement(Tabs.List, { css: { w: "100%", p: "$2" } }, /* @__PURE__ */ React33.createElement(
|
2716
|
-
Tabs.Trigger,
|
2717
|
-
{
|
2718
|
-
value: SIDE_PANE_OPTIONS.CHAT,
|
2719
|
-
onClick: toggleChat,
|
2720
|
-
css: __spreadProps(__spreadValues({}, tabTriggerCSS), {
|
2721
|
-
color: activeTab !== SIDE_PANE_OPTIONS.CHAT ? "$on_surface_low" : "$on_surface_high"
|
2722
|
-
})
|
2723
|
-
},
|
2724
|
-
"Chat"
|
2725
|
-
), /* @__PURE__ */ React33.createElement(
|
2726
|
-
Tabs.Trigger,
|
2727
|
-
{
|
2728
|
-
value: SIDE_PANE_OPTIONS.PARTICIPANTS,
|
2729
|
-
onClick: toggleParticipants,
|
2730
|
-
css: __spreadProps(__spreadValues({}, tabTriggerCSS), {
|
2731
|
-
color: activeTab !== SIDE_PANE_OPTIONS.PARTICIPANTS ? "$on_surface_low" : "$on_surface_high"
|
2732
|
-
})
|
2733
|
-
},
|
2734
|
-
"Participants (",
|
2735
|
-
peerCount,
|
2736
|
-
")"
|
2737
|
-
)))),
|
2738
|
-
/* @__PURE__ */ React33.createElement(
|
2739
|
-
IconButton,
|
2740
|
-
{
|
2741
|
-
css: { ml: "auto" },
|
2742
|
-
onClick: (e) => {
|
2743
|
-
e.stopPropagation();
|
2744
|
-
if (activeTab === SIDE_PANE_OPTIONS.CHAT) {
|
2745
|
-
toggleChat();
|
2746
|
-
} else {
|
2747
|
-
toggleParticipants();
|
2748
|
-
}
|
2749
|
-
},
|
2750
|
-
"data-testid": "close_chat"
|
2751
|
-
},
|
2752
|
-
/* @__PURE__ */ React33.createElement(CrossIcon5, null)
|
2753
|
-
)
|
2754
|
-
);
|
2755
|
-
});
|
2756
|
-
|
2757
2682
|
// src/Prebuilt/components/Footer/RoleAccordion.tsx
|
2758
|
-
import
|
2683
|
+
import React34 from "react";
|
2759
2684
|
import { useMeasure } from "react-use";
|
2760
2685
|
import { FixedSizeList } from "react-window";
|
2761
2686
|
|
2762
2687
|
// src/Prebuilt/components/Footer/RoleOptions.tsx
|
2763
|
-
import
|
2764
|
-
import { selectPermissions as selectPermissions7, useHMSActions as useHMSActions10, useHMSStore as
|
2688
|
+
import React33, { useState as useState17 } from "react";
|
2689
|
+
import { selectPermissions as selectPermissions7, useHMSActions as useHMSActions10, useHMSStore as useHMSStore15, useHMSVanillaStore as useHMSVanillaStore2 } from "@100mslive/react-sdk";
|
2765
2690
|
import {
|
2766
2691
|
MicOffIcon as MicOffIcon2,
|
2767
2692
|
MicOnIcon,
|
@@ -2774,8 +2699,8 @@ import {
|
|
2774
2699
|
var dropdownItemCSS = { backgroundColor: "$surface_default", gap: "$4", p: "$8" };
|
2775
2700
|
var optionTextCSS = { fontWeight: "$semiBold", color: "$on_surface_high", textTransform: "none" };
|
2776
2701
|
var RoleOptions = ({ roleName, peerList }) => {
|
2777
|
-
const [openOptions, setOpenOptions] =
|
2778
|
-
const permissions =
|
2702
|
+
const [openOptions, setOpenOptions] = useState17(false);
|
2703
|
+
const permissions = useHMSStore15(selectPermissions7);
|
2779
2704
|
const hmsActions = useHMSActions10();
|
2780
2705
|
const { elements } = useRoomLayoutConferencingScreen();
|
2781
2706
|
const { on_stage_role, off_stage_roles = [] } = (elements == null ? void 0 : elements.on_stage_exp) || {};
|
@@ -2820,7 +2745,7 @@ var RoleOptions = ({ roleName, peerList }) => {
|
|
2820
2745
|
console.error(e);
|
2821
2746
|
}
|
2822
2747
|
});
|
2823
|
-
return /* @__PURE__ */
|
2748
|
+
return /* @__PURE__ */ React33.createElement(Dropdown.Root, { open: openOptions, onOpenChange: setOpenOptions }, /* @__PURE__ */ React33.createElement(
|
2824
2749
|
Dropdown.Trigger,
|
2825
2750
|
{
|
2826
2751
|
onClick: (e) => e.stopPropagation(),
|
@@ -2839,40 +2764,40 @@ var RoleOptions = ({ roleName, peerList }) => {
|
|
2839
2764
|
}
|
2840
2765
|
}
|
2841
2766
|
},
|
2842
|
-
/* @__PURE__ */
|
2843
|
-
), /* @__PURE__ */
|
2767
|
+
/* @__PURE__ */ React33.createElement(Flex, null, /* @__PURE__ */ React33.createElement(VerticalMenuIcon3, null))
|
2768
|
+
), /* @__PURE__ */ React33.createElement(
|
2844
2769
|
Dropdown.Content,
|
2845
2770
|
{
|
2846
2771
|
onClick: (e) => e.stopPropagation(),
|
2847
2772
|
css: { w: "max-content", maxWidth: "$64", bg: "$surface_default", py: 0 },
|
2848
2773
|
align: "end"
|
2849
2774
|
},
|
2850
|
-
canRemoveRoleFromStage && /* @__PURE__ */
|
2775
|
+
canRemoveRoleFromStage && /* @__PURE__ */ React33.createElement(
|
2851
2776
|
Dropdown.Item,
|
2852
2777
|
{
|
2853
2778
|
css: __spreadProps(__spreadValues({}, dropdownItemCSS), { borderBottom: "1px solid $border_bright" }),
|
2854
2779
|
onClick: removeAllFromStage
|
2855
2780
|
},
|
2856
|
-
/* @__PURE__ */
|
2857
|
-
/* @__PURE__ */
|
2781
|
+
/* @__PURE__ */ React33.createElement(PersonRectangleIcon, null),
|
2782
|
+
/* @__PURE__ */ React33.createElement(Text, { variant: "sm", css: optionTextCSS }, "Remove all from Stage")
|
2858
2783
|
),
|
2859
|
-
canMuteRole && /* @__PURE__ */
|
2784
|
+
canMuteRole && /* @__PURE__ */ React33.createElement(React33.Fragment, null, /* @__PURE__ */ React33.createElement(Dropdown.Item, { css: dropdownItemCSS, onClick: () => setTrackEnabled("audio", !allPeersHaveAudioOn) }, allPeersHaveAudioOn ? /* @__PURE__ */ React33.createElement(MicOffIcon2, null) : /* @__PURE__ */ React33.createElement(MicOnIcon, null), /* @__PURE__ */ React33.createElement(Text, { variant: "sm", css: optionTextCSS }, allPeersHaveAudioOn ? "Mute" : "Unmute", " Audio")), /* @__PURE__ */ React33.createElement(
|
2860
2785
|
Dropdown.Item,
|
2861
2786
|
{
|
2862
2787
|
css: __spreadProps(__spreadValues({}, dropdownItemCSS), { borderTop: "1px solid $border_bright" }),
|
2863
2788
|
onClick: () => setTrackEnabled("video", !allPeersHaveVideoOn)
|
2864
2789
|
},
|
2865
|
-
allPeersHaveVideoOn ? /* @__PURE__ */
|
2866
|
-
/* @__PURE__ */
|
2790
|
+
allPeersHaveVideoOn ? /* @__PURE__ */ React33.createElement(VideoOffIcon, null) : /* @__PURE__ */ React33.createElement(VideoOnIcon, null),
|
2791
|
+
/* @__PURE__ */ React33.createElement(Text, { variant: "sm", css: optionTextCSS }, allPeersHaveVideoOn ? "Mute" : "Unmute", " Video")
|
2867
2792
|
)),
|
2868
|
-
canRemoveRoleFromRoom && /* @__PURE__ */
|
2793
|
+
canRemoveRoleFromRoom && /* @__PURE__ */ React33.createElement(
|
2869
2794
|
Dropdown.Item,
|
2870
2795
|
{
|
2871
2796
|
css: __spreadProps(__spreadValues({}, dropdownItemCSS), { borderTop: "1px solid $border_bright", color: "$alert_error_default" }),
|
2872
2797
|
onClick: removePeersFromRoom
|
2873
2798
|
},
|
2874
|
-
/* @__PURE__ */
|
2875
|
-
/* @__PURE__ */
|
2799
|
+
/* @__PURE__ */ React33.createElement(RemoveUserIcon, null),
|
2800
|
+
/* @__PURE__ */ React33.createElement(Text, { variant: "sm", css: __spreadProps(__spreadValues({}, optionTextCSS), { color: "inherit" }) }, "Remove all from Room")
|
2876
2801
|
)
|
2877
2802
|
));
|
2878
2803
|
};
|
@@ -2882,8 +2807,8 @@ var ROW_HEIGHT = 50;
|
|
2882
2807
|
function itemKey(index, data3) {
|
2883
2808
|
return data3.peerList[index].id;
|
2884
2809
|
}
|
2885
|
-
var VirtualizedParticipantItem =
|
2886
|
-
return /* @__PURE__ */
|
2810
|
+
var VirtualizedParticipantItem = React34.memo(({ index, data: data3 }) => {
|
2811
|
+
return /* @__PURE__ */ React34.createElement(Participant, { key: data3.peerList[index].id, peer: data3.peerList[index], isConnected: data3.isConnected });
|
2887
2812
|
});
|
2888
2813
|
var RoleAccordion = ({
|
2889
2814
|
peerList = [],
|
@@ -2898,7 +2823,7 @@ var RoleAccordion = ({
|
|
2898
2823
|
return null;
|
2899
2824
|
}
|
2900
2825
|
const height = ROW_HEIGHT * peerList.length;
|
2901
|
-
return /* @__PURE__ */
|
2826
|
+
return /* @__PURE__ */ React34.createElement(Flex, { direction: "column", css: { "&:hover .role_actions": { visibility: "visible" } }, ref }, /* @__PURE__ */ React34.createElement(
|
2902
2827
|
Accordion.Root,
|
2903
2828
|
{
|
2904
2829
|
type: "single",
|
@@ -2906,7 +2831,7 @@ var RoleAccordion = ({
|
|
2906
2831
|
defaultValue: roleName,
|
2907
2832
|
css: { borderRadius: "$1", border: "1px solid $border_bright" }
|
2908
2833
|
},
|
2909
|
-
/* @__PURE__ */
|
2834
|
+
/* @__PURE__ */ React34.createElement(Accordion.Item, { value: roleName }, /* @__PURE__ */ React34.createElement(
|
2910
2835
|
Accordion.Header,
|
2911
2836
|
{
|
2912
2837
|
iconStyles: { c: "$on_surface_high" },
|
@@ -2918,7 +2843,7 @@ var RoleAccordion = ({
|
|
2918
2843
|
c: "$on_surface_medium"
|
2919
2844
|
}
|
2920
2845
|
},
|
2921
|
-
/* @__PURE__ */
|
2846
|
+
/* @__PURE__ */ React34.createElement(Flex, { justify: "between", css: { flexGrow: 1, pr: "$6" } }, /* @__PURE__ */ React34.createElement(
|
2922
2847
|
Text,
|
2923
2848
|
{
|
2924
2849
|
variant: "sm",
|
@@ -2927,8 +2852,8 @@ var RoleAccordion = ({
|
|
2927
2852
|
roleName,
|
2928
2853
|
" ",
|
2929
2854
|
`(${getFormattedCount(peerList.length)})`
|
2930
|
-
), /* @__PURE__ */
|
2931
|
-
), /* @__PURE__ */
|
2855
|
+
), /* @__PURE__ */ React34.createElement(RoleOptions, { roleName, peerList }))
|
2856
|
+
), /* @__PURE__ */ React34.createElement(Accordion.Content, null, /* @__PURE__ */ React34.createElement(Box, { css: { borderTop: "1px solid $border_default" } }), /* @__PURE__ */ React34.createElement(
|
2932
2857
|
FixedSizeList,
|
2933
2858
|
{
|
2934
2859
|
itemSize: ROW_HEIGHT,
|
@@ -2945,10 +2870,10 @@ var RoleAccordion = ({
|
|
2945
2870
|
|
2946
2871
|
// src/Prebuilt/components/Footer/ParticipantList.jsx
|
2947
2872
|
var ParticipantList = () => {
|
2948
|
-
const [filter, setFilter] =
|
2873
|
+
const [filter, setFilter] = useState18();
|
2949
2874
|
const { participants, isConnected, peerCount } = useParticipants(filter);
|
2950
2875
|
const peersOrderedByRoles = {};
|
2951
|
-
const handRaisedPeers =
|
2876
|
+
const handRaisedPeers = useHMSStore16(selectPeersByCondition2((peer) => {
|
2952
2877
|
var _a;
|
2953
2878
|
return (_a = JSON.parse(peer.metadata || "{}")) == null ? void 0 : _a.isHandRaised;
|
2954
2879
|
}));
|
@@ -2970,7 +2895,7 @@ var ParticipantList = () => {
|
|
2970
2895
|
if (peerCount === 0) {
|
2971
2896
|
return null;
|
2972
2897
|
}
|
2973
|
-
return /* @__PURE__ */
|
2898
|
+
return /* @__PURE__ */ React35.createElement(Fragment7, null, /* @__PURE__ */ React35.createElement(Flex, { direction: "column", css: { size: "100%", gap: "$4" } }, !(filter == null ? void 0 : filter.search) && participants.length === 0 ? null : /* @__PURE__ */ React35.createElement(ParticipantSearch, { onSearch, inSidePane: true }), participants.length === 0 ? /* @__PURE__ */ React35.createElement(Flex, { align: "center", justify: "center", css: { w: "100%", p: "$8 0" } }, /* @__PURE__ */ React35.createElement(Text, { variant: "sm" }, !filter ? "No participants" : "No matching participants")) : null, /* @__PURE__ */ React35.createElement(
|
2974
2899
|
VirtualizedParticipants,
|
2975
2900
|
{
|
2976
2901
|
peersOrderedByRoles,
|
@@ -2981,10 +2906,10 @@ var ParticipantList = () => {
|
|
2981
2906
|
)));
|
2982
2907
|
};
|
2983
2908
|
var ParticipantCount = () => {
|
2984
|
-
const peerCount =
|
2909
|
+
const peerCount = useHMSStore16(selectPeerCount2);
|
2985
2910
|
const toggleSidepane = useSidepaneToggle(SIDE_PANE_OPTIONS.PARTICIPANTS);
|
2986
2911
|
const isParticipantsOpen = useIsSidepaneTypeOpen(SIDE_PANE_OPTIONS.PARTICIPANTS);
|
2987
|
-
|
2912
|
+
useEffect5(() => {
|
2988
2913
|
if (isParticipantsOpen && peerCount === 0) {
|
2989
2914
|
toggleSidepane();
|
2990
2915
|
}
|
@@ -2992,7 +2917,7 @@ var ParticipantCount = () => {
|
|
2992
2917
|
if (peerCount === 0) {
|
2993
2918
|
return null;
|
2994
2919
|
}
|
2995
|
-
return /* @__PURE__ */
|
2920
|
+
return /* @__PURE__ */ React35.createElement(
|
2996
2921
|
IconButton_default,
|
2997
2922
|
{
|
2998
2923
|
css: {
|
@@ -3008,24 +2933,25 @@ var ParticipantCount = () => {
|
|
3008
2933
|
active: !isParticipantsOpen,
|
3009
2934
|
"data-testid": "participant_list"
|
3010
2935
|
},
|
3011
|
-
/* @__PURE__ */
|
3012
|
-
/* @__PURE__ */
|
2936
|
+
/* @__PURE__ */ React35.createElement(PeopleIcon2, null),
|
2937
|
+
/* @__PURE__ */ React35.createElement(Text, { variant: "sm", css: { mx: "$4", c: "inherit" } }, peerCount)
|
3013
2938
|
);
|
3014
2939
|
};
|
3015
2940
|
var VirtualizedParticipants = ({ peersOrderedByRoles = {}, isConnected, filter, handRaisedList = [] }) => {
|
3016
|
-
return /* @__PURE__ */
|
2941
|
+
return /* @__PURE__ */ React35.createElement(
|
3017
2942
|
Flex,
|
3018
2943
|
{
|
3019
2944
|
direction: "column",
|
3020
2945
|
css: {
|
3021
2946
|
gap: "$8",
|
3022
|
-
maxHeight: "100%",
|
3023
2947
|
overflowY: "auto",
|
3024
2948
|
overflowX: "hidden",
|
3025
|
-
pr: "$
|
2949
|
+
pr: "$10",
|
2950
|
+
mr: "-$10",
|
2951
|
+
flex: "1 1 0"
|
3026
2952
|
}
|
3027
2953
|
},
|
3028
|
-
/* @__PURE__ */
|
2954
|
+
/* @__PURE__ */ React35.createElement(
|
3029
2955
|
RoleAccordion,
|
3030
2956
|
{
|
3031
2957
|
peerList: handRaisedList,
|
@@ -3035,7 +2961,7 @@ var VirtualizedParticipants = ({ peersOrderedByRoles = {}, isConnected, filter,
|
|
3035
2961
|
isHandRaisedAccordion: true
|
3036
2962
|
}
|
3037
2963
|
),
|
3038
|
-
Object.keys(peersOrderedByRoles).map((role) => /* @__PURE__ */
|
2964
|
+
Object.keys(peersOrderedByRoles).map((role) => /* @__PURE__ */ React35.createElement(
|
3039
2965
|
RoleAccordion,
|
3040
2966
|
{
|
3041
2967
|
key: role,
|
@@ -3048,8 +2974,8 @@ var VirtualizedParticipants = ({ peersOrderedByRoles = {}, isConnected, filter,
|
|
3048
2974
|
);
|
3049
2975
|
};
|
3050
2976
|
var Participant = ({ peer, isConnected }) => {
|
3051
|
-
const localPeerId =
|
3052
|
-
return /* @__PURE__ */
|
2977
|
+
const localPeerId = useHMSStore16(selectLocalPeerID4);
|
2978
|
+
return /* @__PURE__ */ React35.createElement(
|
3053
2979
|
Flex,
|
3054
2980
|
{
|
3055
2981
|
key: peer.id,
|
@@ -3064,17 +2990,17 @@ var Participant = ({ peer, isConnected }) => {
|
|
3064
2990
|
justify: "between",
|
3065
2991
|
"data-testid": "participant_" + peer.name
|
3066
2992
|
},
|
3067
|
-
/* @__PURE__ */
|
3068
|
-
isConnected ? /* @__PURE__ */
|
2993
|
+
/* @__PURE__ */ React35.createElement(Text, { variant: "sm", css: __spreadProps(__spreadValues({}, textEllipsis(150)), { fontWeight: "$semiBold", color: "$on_surface_high" }) }, peer.name, " ", localPeerId === peer.id ? "(You)" : ""),
|
2994
|
+
isConnected ? /* @__PURE__ */ React35.createElement(ParticipantActions, { peerId: peer.id, isLocal: peer.id === localPeerId, role: peer.roleName }) : null
|
3069
2995
|
);
|
3070
2996
|
};
|
3071
|
-
var ParticipantActions =
|
2997
|
+
var ParticipantActions = React35.memo(({ peerId, role, isLocal }) => {
|
3072
2998
|
var _a, _b;
|
3073
|
-
const isHandRaised = (_a =
|
3074
|
-
const canChangeRole = (_b =
|
2999
|
+
const isHandRaised = (_a = useHMSStore16(selectPeerMetadata2(peerId))) == null ? void 0 : _a.isHandRaised;
|
3000
|
+
const canChangeRole = (_b = useHMSStore16(selectPermissions8)) == null ? void 0 : _b.changeRole;
|
3075
3001
|
const shouldShowMoreActions = canChangeRole;
|
3076
|
-
const isAudioMuted = !
|
3077
|
-
return /* @__PURE__ */
|
3002
|
+
const isAudioMuted = !useHMSStore16(selectIsPeerAudioEnabled(peerId));
|
3003
|
+
return /* @__PURE__ */ React35.createElement(
|
3078
3004
|
Flex,
|
3079
3005
|
{
|
3080
3006
|
align: "center",
|
@@ -3083,32 +3009,32 @@ var ParticipantActions = React36.memo(({ peerId, role, isLocal }) => {
|
|
3083
3009
|
gap: "$8"
|
3084
3010
|
}
|
3085
3011
|
},
|
3086
|
-
/* @__PURE__ */
|
3087
|
-
isHandRaised && /* @__PURE__ */
|
3012
|
+
/* @__PURE__ */ React35.createElement(ConnectionIndicator, { peerId }),
|
3013
|
+
isHandRaised && /* @__PURE__ */ React35.createElement(
|
3088
3014
|
Flex,
|
3089
3015
|
{
|
3090
3016
|
align: "center",
|
3091
3017
|
justify: "center",
|
3092
3018
|
css: { p: "$1", c: "$on_surface_high", bg: "$surface_bright", borderRadius: "$round" }
|
3093
3019
|
},
|
3094
|
-
/* @__PURE__ */
|
3020
|
+
/* @__PURE__ */ React35.createElement(HandIcon3, { height: 19, width: 19 })
|
3095
3021
|
),
|
3096
|
-
isAudioMuted ? /* @__PURE__ */
|
3022
|
+
isAudioMuted ? /* @__PURE__ */ React35.createElement(
|
3097
3023
|
Flex,
|
3098
3024
|
{
|
3099
3025
|
align: "center",
|
3100
3026
|
justify: "center",
|
3101
3027
|
css: { p: "$2", c: "$on_surface_high", bg: "$surface_bright", borderRadius: "$round" }
|
3102
3028
|
},
|
3103
|
-
/* @__PURE__ */
|
3029
|
+
/* @__PURE__ */ React35.createElement(MicOffIcon3, { height: 19, width: 19 })
|
3104
3030
|
) : null,
|
3105
|
-
shouldShowMoreActions && !isInternalRole(role) && !isLocal ? /* @__PURE__ */
|
3031
|
+
shouldShowMoreActions && !isInternalRole(role) && !isLocal ? /* @__PURE__ */ React35.createElement(ParticipantMoreActions, { peerId, role }) : null
|
3106
3032
|
);
|
3107
3033
|
});
|
3108
3034
|
var ParticipantMoreActions = ({ peerId, role }) => {
|
3109
3035
|
var _a;
|
3110
3036
|
const hmsActions = useHMSActions11();
|
3111
|
-
const { changeRole: canChangeRole, removeOthers: canRemoveOthers } =
|
3037
|
+
const { changeRole: canChangeRole, removeOthers: canRemoveOthers } = useHMSStore16(selectPermissions8);
|
3112
3038
|
const { elements } = useRoomLayoutConferencingScreen();
|
3113
3039
|
const {
|
3114
3040
|
bring_to_stage_label,
|
@@ -3118,10 +3044,10 @@ var ParticipantMoreActions = ({ peerId, role }) => {
|
|
3118
3044
|
} = elements.on_stage_exp || {};
|
3119
3045
|
const isInStage = role === on_stage_role;
|
3120
3046
|
const shouldShowStageRoleChange = canChangeRole && (isInStage && remove_from_stage_label || (off_stage_roles == null ? void 0 : off_stage_roles.includes(role)) && bring_to_stage_label);
|
3121
|
-
const prevRole = (_a =
|
3122
|
-
const localPeerId =
|
3047
|
+
const prevRole = (_a = useHMSStore16(selectPeerMetadata2(peerId))) == null ? void 0 : _a.prevRole;
|
3048
|
+
const localPeerId = useHMSStore16(selectLocalPeerID4);
|
3123
3049
|
const isLocal = localPeerId === peerId;
|
3124
|
-
const [open, setOpen] =
|
3050
|
+
const [open, setOpen] = useState18(false);
|
3125
3051
|
const handleStageAction = () => __async(void 0, null, function* () {
|
3126
3052
|
if (isInStage) {
|
3127
3053
|
prevRole && hmsActions.changeRoleOfPeer(peerId, prevRole, true);
|
@@ -3130,7 +3056,7 @@ var ParticipantMoreActions = ({ peerId, role }) => {
|
|
3130
3056
|
}
|
3131
3057
|
setOpen(false);
|
3132
3058
|
});
|
3133
|
-
return /* @__PURE__ */
|
3059
|
+
return /* @__PURE__ */ React35.createElement(Dropdown.Root, { open, onOpenChange: (value) => setOpen(value), modal: false }, /* @__PURE__ */ React35.createElement(
|
3134
3060
|
Dropdown.Trigger,
|
3135
3061
|
{
|
3136
3062
|
asChild: true,
|
@@ -3150,8 +3076,8 @@ var ParticipantMoreActions = ({ peerId, role }) => {
|
|
3150
3076
|
},
|
3151
3077
|
tabIndex: 0
|
3152
3078
|
},
|
3153
|
-
/* @__PURE__ */
|
3154
|
-
), /* @__PURE__ */
|
3079
|
+
/* @__PURE__ */ React35.createElement(Box, { css: { my: "auto" } }, /* @__PURE__ */ React35.createElement(VerticalMenuIcon4, null))
|
3080
|
+
), /* @__PURE__ */ React35.createElement(Dropdown.Portal, null, /* @__PURE__ */ React35.createElement(Dropdown.Content, { align: "end", sideOffset: 8, css: { w: "$64", bg: "$surface_default" } }, shouldShowStageRoleChange ? /* @__PURE__ */ React35.createElement(Dropdown.Item, { css: { bg: "$surface_default" }, onClick: () => handleStageAction() }, /* @__PURE__ */ React35.createElement(ChangeRoleIcon2, null), /* @__PURE__ */ React35.createElement(Text, { variant: "sm", css: { ml: "$4", fontWeight: "$semiBold", c: "$on_surface_high" } }, isInStage ? remove_from_stage_label : bring_to_stage_label)) : null, !isLocal && canRemoveOthers && /* @__PURE__ */ React35.createElement(
|
3155
3081
|
Dropdown.Item,
|
3156
3082
|
{
|
3157
3083
|
css: { color: "$alert_error_default", bg: "$surface_default" },
|
@@ -3163,12 +3089,12 @@ var ParticipantMoreActions = ({ peerId, role }) => {
|
|
3163
3089
|
}
|
3164
3090
|
})
|
3165
3091
|
},
|
3166
|
-
/* @__PURE__ */
|
3167
|
-
/* @__PURE__ */
|
3092
|
+
/* @__PURE__ */ React35.createElement(PeopleRemoveIcon, null),
|
3093
|
+
/* @__PURE__ */ React35.createElement(Text, { variant: "sm", css: { ml: "$4", color: "inherit", fontWeight: "$semiBold" } }, "Remove Participant")
|
3168
3094
|
))));
|
3169
3095
|
};
|
3170
3096
|
var ParticipantSearch = ({ onSearch, placeholder, inSidePane = false }) => {
|
3171
|
-
const [value, setValue] =
|
3097
|
+
const [value, setValue] = React35.useState("");
|
3172
3098
|
const isMobile = useMedia4(config.media.md);
|
3173
3099
|
useDebounce(
|
3174
3100
|
() => {
|
@@ -3177,20 +3103,20 @@ var ParticipantSearch = ({ onSearch, placeholder, inSidePane = false }) => {
|
|
3177
3103
|
300,
|
3178
3104
|
[value, onSearch]
|
3179
3105
|
);
|
3180
|
-
return /* @__PURE__ */
|
3106
|
+
return /* @__PURE__ */ React35.createElement(
|
3181
3107
|
Flex,
|
3182
3108
|
{
|
3183
3109
|
align: "center",
|
3184
3110
|
css: {
|
3185
|
-
p: isMobile ? "
|
3111
|
+
p: isMobile ? "0" : "$2 0",
|
3186
3112
|
mb: "$2",
|
3187
3113
|
position: "relative",
|
3188
3114
|
color: "$on_surface_medium",
|
3189
3115
|
mt: inSidePane ? "$4" : ""
|
3190
3116
|
}
|
3191
3117
|
},
|
3192
|
-
/* @__PURE__ */
|
3193
|
-
/* @__PURE__ */
|
3118
|
+
/* @__PURE__ */ React35.createElement(SearchIcon, { style: { position: "absolute", left: isMobile ? "1.25rem" : "0.5rem" } }),
|
3119
|
+
/* @__PURE__ */ React35.createElement(
|
3194
3120
|
Input,
|
3195
3121
|
{
|
3196
3122
|
type: "text",
|
@@ -3211,7 +3137,7 @@ var ParticipantSearch = ({ onSearch, placeholder, inSidePane = false }) => {
|
|
3211
3137
|
};
|
3212
3138
|
|
3213
3139
|
// src/Prebuilt/components/Footer/Footer.tsx
|
3214
|
-
var VirtualBackground =
|
3140
|
+
var VirtualBackground = React36.lazy(() => import("./VirtualBackground-6EP3X7MO.js"));
|
3215
3141
|
var Footer2 = ({
|
3216
3142
|
screenType,
|
3217
3143
|
elements
|
@@ -3220,8 +3146,14 @@ var Footer2 = ({
|
|
3220
3146
|
const isMobile = useMedia5(config.media.md);
|
3221
3147
|
const isOverlayChat = !!((_a = elements == null ? void 0 : elements.chat) == null ? void 0 : _a.is_overlay);
|
3222
3148
|
const openByDefault = ((_b = elements == null ? void 0 : elements.chat) == null ? void 0 : _b.initial_state) === Chat_ChatState.CHAT_STATE_OPEN;
|
3223
|
-
const
|
3224
|
-
|
3149
|
+
const isChatOpen = useIsSidepaneTypeOpen(SIDE_PANE_OPTIONS.CHAT);
|
3150
|
+
const toggleChat = useSidepaneToggle(SIDE_PANE_OPTIONS.CHAT);
|
3151
|
+
useEffect6(() => {
|
3152
|
+
if (!isChatOpen && openByDefault) {
|
3153
|
+
toggleChat();
|
3154
|
+
}
|
3155
|
+
}, [toggleChat, openByDefault]);
|
3156
|
+
return /* @__PURE__ */ React36.createElement(
|
3225
3157
|
Footer.Root,
|
3226
3158
|
{
|
3227
3159
|
css: {
|
@@ -3231,11 +3163,11 @@ var Footer2 = ({
|
|
3231
3163
|
gap: "$10",
|
3232
3164
|
position: "relative",
|
3233
3165
|
// To prevent it from showing over the sidepane if chat type is not overlay
|
3234
|
-
zIndex: isOverlayChat ? 20 : 1
|
3166
|
+
zIndex: isOverlayChat && isChatOpen ? 20 : 1
|
3235
3167
|
}
|
3236
3168
|
}
|
3237
3169
|
},
|
3238
|
-
/* @__PURE__ */
|
3170
|
+
/* @__PURE__ */ React36.createElement(
|
3239
3171
|
Footer.Left,
|
3240
3172
|
{
|
3241
3173
|
css: {
|
@@ -3246,11 +3178,11 @@ var Footer2 = ({
|
|
3246
3178
|
}
|
3247
3179
|
}
|
3248
3180
|
},
|
3249
|
-
isMobile ? /* @__PURE__ */
|
3250
|
-
/* @__PURE__ */
|
3251
|
-
isMobile ? null : /* @__PURE__ */
|
3181
|
+
isMobile ? /* @__PURE__ */ React36.createElement(LeaveRoom, { screenType }) : null,
|
3182
|
+
/* @__PURE__ */ React36.createElement(AudioVideoToggle, null),
|
3183
|
+
isMobile ? null : /* @__PURE__ */ React36.createElement(Suspense, { fallback: /* @__PURE__ */ React36.createElement(React36.Fragment, null) }, /* @__PURE__ */ React36.createElement(VirtualBackground, null))
|
3252
3184
|
),
|
3253
|
-
/* @__PURE__ */
|
3185
|
+
/* @__PURE__ */ React36.createElement(
|
3254
3186
|
Footer.Center,
|
3255
3187
|
{
|
3256
3188
|
css: {
|
@@ -3260,18 +3192,18 @@ var Footer2 = ({
|
|
3260
3192
|
}
|
3261
3193
|
}
|
3262
3194
|
},
|
3263
|
-
isMobile ? /* @__PURE__ */
|
3195
|
+
isMobile ? /* @__PURE__ */ React36.createElement(React36.Fragment, null, screenType === "hls_live_streaming" ? /* @__PURE__ */ React36.createElement(RaiseHand, null) : null, (elements == null ? void 0 : elements.chat) && /* @__PURE__ */ React36.createElement(ChatToggle, null), /* @__PURE__ */ React36.createElement(MoreSettings, { elements, screenType })) : /* @__PURE__ */ React36.createElement(React36.Fragment, null, /* @__PURE__ */ React36.createElement(ScreenshareToggle, null), /* @__PURE__ */ React36.createElement(RaiseHand, null), (elements == null ? void 0 : elements.emoji_reactions) && /* @__PURE__ */ React36.createElement(EmojiReaction, null), /* @__PURE__ */ React36.createElement(LeaveRoom, { screenType }))
|
3264
3196
|
),
|
3265
|
-
/* @__PURE__ */
|
3197
|
+
/* @__PURE__ */ React36.createElement(Footer.Right, null, !isMobile && (elements == null ? void 0 : elements.chat) && /* @__PURE__ */ React36.createElement(ChatToggle, null), (elements == null ? void 0 : elements.participant_list) && /* @__PURE__ */ React36.createElement(ParticipantCount, null), /* @__PURE__ */ React36.createElement(MoreSettings, { elements, screenType }))
|
3266
3198
|
);
|
3267
3199
|
};
|
3268
3200
|
|
3269
3201
|
// src/Prebuilt/components/Notifications/HLSFailureModal.jsx
|
3270
|
-
import
|
3271
|
-
import { selectHLSState as selectHLSState2, useHMSActions as useHMSActions12, useHMSStore as
|
3202
|
+
import React37, { useCallback as useCallback7, useState as useState19 } from "react";
|
3203
|
+
import { selectHLSState as selectHLSState2, useHMSActions as useHMSActions12, useHMSStore as useHMSStore17 } from "@100mslive/react-sdk";
|
3272
3204
|
function HLSFailureModal() {
|
3273
|
-
const { hlsError } =
|
3274
|
-
const [openModal, setOpenModal] =
|
3205
|
+
const { hlsError } = useHMSStore17(selectHLSState2).error || false;
|
3206
|
+
const [openModal, setOpenModal] = useState19(!!hlsError);
|
3275
3207
|
const hmsActions = useHMSActions12();
|
3276
3208
|
const [isHLSStarted, setHLSStarted] = useSetAppDataByKey(APP_DATA.hlsStarted);
|
3277
3209
|
const startHLS = useCallback7(() => __async(this, null, function* () {
|
@@ -3289,7 +3221,7 @@ function HLSFailureModal() {
|
|
3289
3221
|
setHLSStarted(false);
|
3290
3222
|
}
|
3291
3223
|
}), [hmsActions, isHLSStarted, setHLSStarted]);
|
3292
|
-
return hlsError ? /* @__PURE__ */
|
3224
|
+
return hlsError ? /* @__PURE__ */ React37.createElement(
|
3293
3225
|
Dialog.Root,
|
3294
3226
|
{
|
3295
3227
|
open: openModal,
|
@@ -3299,7 +3231,7 @@ function HLSFailureModal() {
|
|
3299
3231
|
}
|
3300
3232
|
}
|
3301
3233
|
},
|
3302
|
-
/* @__PURE__ */
|
3234
|
+
/* @__PURE__ */ React37.createElement(Dialog.Portal, null, /* @__PURE__ */ React37.createElement(Dialog.Overlay, null), /* @__PURE__ */ React37.createElement(Dialog.Content, { css: { w: "min(360px, 90%)" } }, /* @__PURE__ */ React37.createElement(
|
3303
3235
|
Dialog.Title,
|
3304
3236
|
{
|
3305
3237
|
css: {
|
@@ -3310,34 +3242,34 @@ function HLSFailureModal() {
|
|
3310
3242
|
mt: "$4"
|
3311
3243
|
}
|
3312
3244
|
},
|
3313
|
-
/* @__PURE__ */
|
3314
|
-
), /* @__PURE__ */
|
3245
|
+
/* @__PURE__ */ React37.createElement(Text, { variant: "h6", css: { fontWeight: "$semiBold" } }, "Failed to Go Live")
|
3246
|
+
), /* @__PURE__ */ React37.createElement(Text, { variant: "sm", css: { mb: "$10", color: "$on_surface_medium" } }, "Something went wrong and your live broadcast failed. Please try again."), /* @__PURE__ */ React37.createElement(Flex, { align: "center", justify: "between", css: { w: "100%", gap: "$8" } }, /* @__PURE__ */ React37.createElement(Button, { outlined: true, variant: "standard", css: { w: "100%" }, onClick: () => setOpenModal(false) }, "Dismiss"), /* @__PURE__ */ React37.createElement(Button, { css: { w: "100%" }, onClick: startHLS }, "Go Live"))))
|
3315
3247
|
) : null;
|
3316
3248
|
}
|
3317
3249
|
|
3318
3250
|
// src/Prebuilt/layouts/VideoStreamingSection.tsx
|
3319
|
-
import React60, { Suspense as Suspense2, useEffect as
|
3320
|
-
import { selectIsConnectedToRoom as selectIsConnectedToRoom6, selectLocalPeerRoleName as selectLocalPeerRoleName2, useHMSActions as useHMSActions20, useHMSStore as
|
3251
|
+
import React60, { Suspense as Suspense2, useEffect as useEffect23 } from "react";
|
3252
|
+
import { selectIsConnectedToRoom as selectIsConnectedToRoom6, selectLocalPeerRoleName as selectLocalPeerRoleName2, useHMSActions as useHMSActions20, useHMSStore as useHMSStore34 } from "@100mslive/react-sdk";
|
3321
3253
|
|
3322
3254
|
// src/Prebuilt/components/VideoLayouts/GridLayout.tsx
|
3323
|
-
import
|
3324
|
-
import { selectPeers as selectPeers2, selectPeerScreenSharing, useHMSStore as
|
3255
|
+
import React49, { useEffect as useEffect14, useMemo as useMemo6, useState as useState26 } from "react";
|
3256
|
+
import { selectPeers as selectPeers2, selectPeerScreenSharing, useHMSStore as useHMSStore23, useHMSVanillaStore as useHMSVanillaStore4 } from "@100mslive/react-sdk";
|
3325
3257
|
|
3326
3258
|
// src/Prebuilt/components/VideoLayouts/EqualProminence.tsx
|
3327
|
-
import
|
3259
|
+
import React42, { useEffect as useEffect10, useMemo as useMemo3, useState as useState21 } from "react";
|
3328
3260
|
import { useMedia as useMedia8 } from "react-use";
|
3329
|
-
import { selectLocalPeer as selectLocalPeer3, useHMSStore as
|
3261
|
+
import { selectLocalPeer as selectLocalPeer3, useHMSStore as useHMSStore19 } from "@100mslive/react-sdk";
|
3330
3262
|
|
3331
3263
|
// src/Prebuilt/components/InsetTile.tsx
|
3332
|
-
import
|
3264
|
+
import React39, { useEffect as useEffect7, useRef as useRef6 } from "react";
|
3333
3265
|
import Draggable from "react-draggable";
|
3334
3266
|
import { useMedia as useMedia6 } from "react-use";
|
3335
|
-
import { selectIsAllowedToPublish as selectIsAllowedToPublish2, selectLocalPeer as selectLocalPeer2, selectVideoTrackByID, useHMSStore as
|
3267
|
+
import { selectIsAllowedToPublish as selectIsAllowedToPublish2, selectLocalPeer as selectLocalPeer2, selectVideoTrackByID, useHMSStore as useHMSStore18 } from "@100mslive/react-sdk";
|
3336
3268
|
import { ExpandIcon as ExpandIcon2 } from "@100mslive/react-icons";
|
3337
3269
|
|
3338
3270
|
// src/Prebuilt/components/hooks/useVideoTileLayout.ts
|
3339
|
-
import
|
3340
|
-
var VideoTileContext =
|
3271
|
+
import React38, { useContext } from "react";
|
3272
|
+
var VideoTileContext = React38.createContext({
|
3341
3273
|
enableSpotlightingPeer: true,
|
3342
3274
|
hideParticipantNameOnTile: false,
|
3343
3275
|
roundedVideoTile: true,
|
@@ -3353,14 +3285,14 @@ var useVideoTileContext = () => {
|
|
3353
3285
|
|
3354
3286
|
// src/Prebuilt/components/InsetTile.tsx
|
3355
3287
|
var MinimisedTile = ({ setMinimised }) => {
|
3356
|
-
return /* @__PURE__ */
|
3288
|
+
return /* @__PURE__ */ React39.createElement(Flex, { align: "center", css: { gap: "$6", r: "$1", bg: "$surface_default", p: "$4", color: "$on_surface_high" } }, /* @__PURE__ */ React39.createElement(AudioVideoToggle, { hideOptions: true }), /* @__PURE__ */ React39.createElement(Text, null, "You"), /* @__PURE__ */ React39.createElement(
|
3357
3289
|
IconButton_default,
|
3358
3290
|
{
|
3359
3291
|
className: "__cancel-drag-event",
|
3360
3292
|
onClick: () => setMinimised(false),
|
3361
3293
|
css: { bg: "transparent", border: "transparent" }
|
3362
3294
|
},
|
3363
|
-
/* @__PURE__ */
|
3295
|
+
/* @__PURE__ */ React39.createElement(ExpandIcon2, null)
|
3364
3296
|
));
|
3365
3297
|
};
|
3366
3298
|
var insetHeightPx = 180;
|
@@ -3370,10 +3302,10 @@ var desktopAspectRatio = 1 / defaultMobileAspectRatio;
|
|
3370
3302
|
var InsetTile = () => {
|
3371
3303
|
const isMobile = useMedia6(config.media.md);
|
3372
3304
|
const isLandscape = useMedia6(config.media.ls);
|
3373
|
-
const localPeer =
|
3305
|
+
const localPeer = useHMSStore18(selectLocalPeer2);
|
3374
3306
|
const [minimised, setMinimised] = useSetAppDataByKey(APP_DATA.minimiseInset);
|
3375
|
-
const videoTrack =
|
3376
|
-
const isAllowedToPublish =
|
3307
|
+
const videoTrack = useHMSStore18(selectVideoTrackByID(localPeer == null ? void 0 : localPeer.videoTrack));
|
3308
|
+
const isAllowedToPublish = useHMSStore18(selectIsAllowedToPublish2);
|
3377
3309
|
const videoTileProps = useVideoTileContext();
|
3378
3310
|
let aspectRatio = isMobile ? defaultMobileAspectRatio : desktopAspectRatio;
|
3379
3311
|
if ((videoTrack == null ? void 0 : videoTrack.width) && (videoTrack == null ? void 0 : videoTrack.height) && !isMobile) {
|
@@ -3407,7 +3339,7 @@ var InsetTile = () => {
|
|
3407
3339
|
if (!isAllowedToPublish.video && !isAllowedToPublish.audio) {
|
3408
3340
|
return null;
|
3409
3341
|
}
|
3410
|
-
return /* @__PURE__ */
|
3342
|
+
return /* @__PURE__ */ React39.createElement(Draggable, { bounds: "parent", nodeRef, cancel: ".__cancel-drag-event" }, /* @__PURE__ */ React39.createElement(
|
3411
3343
|
Box,
|
3412
3344
|
{
|
3413
3345
|
ref: nodeRef,
|
@@ -3423,9 +3355,9 @@ var InsetTile = () => {
|
|
3423
3355
|
h: height
|
3424
3356
|
} : {})
|
3425
3357
|
},
|
3426
|
-
minimised ? /* @__PURE__ */
|
3358
|
+
minimised ? /* @__PURE__ */ React39.createElement(MinimisedTile, { setMinimised }) : /* @__PURE__ */ React39.createElement(
|
3427
3359
|
VideoTile_default,
|
3428
|
-
__spreadValues({
|
3360
|
+
__spreadProps(__spreadValues({
|
3429
3361
|
peerId: localPeer == null ? void 0 : localPeer.id,
|
3430
3362
|
trackid: localPeer == null ? void 0 : localPeer.videoTrack,
|
3431
3363
|
rootCSS: {
|
@@ -3437,13 +3369,15 @@ var InsetTile = () => {
|
|
3437
3369
|
containerCSS: { background: "$surface_default" },
|
3438
3370
|
canMinimise: true,
|
3439
3371
|
isDragabble: true
|
3440
|
-
}, videoTileProps)
|
3372
|
+
}, videoTileProps), {
|
3373
|
+
hideParticipantNameOnTile: true
|
3374
|
+
})
|
3441
3375
|
)
|
3442
3376
|
));
|
3443
3377
|
};
|
3444
3378
|
|
3445
3379
|
// src/Prebuilt/components/Pagination.tsx
|
3446
|
-
import
|
3380
|
+
import React40, { useEffect as useEffect8 } from "react";
|
3447
3381
|
import { ChevronLeftIcon as ChevronLeftIcon2, ChevronRightIcon as ChevronRightIcon2 } from "@100mslive/react-icons";
|
3448
3382
|
var Pagination = ({
|
3449
3383
|
page,
|
@@ -3468,7 +3402,7 @@ var Pagination = ({
|
|
3468
3402
|
if (numPages <= 1) {
|
3469
3403
|
return null;
|
3470
3404
|
}
|
3471
|
-
return /* @__PURE__ */
|
3405
|
+
return /* @__PURE__ */ React40.createElement(StyledPagination.Root, { css: { flexShrink: 0 } }, /* @__PURE__ */ React40.createElement(StyledPagination.Chevron, { disabled: disableLeft, onClick: prevPage }, /* @__PURE__ */ React40.createElement(ChevronLeftIcon2, { width: 16, height: 16, style: { cursor: disableLeft ? "not-allowed" : "pointer" } })), numPages <= 5 ? /* @__PURE__ */ React40.createElement(StyledPagination.Dots, null, [...Array(numPages)].map((_, i) => /* @__PURE__ */ React40.createElement(
|
3472
3406
|
StyledPagination.Dot,
|
3473
3407
|
{
|
3474
3408
|
key: i,
|
@@ -3478,15 +3412,15 @@ var Pagination = ({
|
|
3478
3412
|
onPageChange(i);
|
3479
3413
|
}
|
3480
3414
|
}
|
3481
|
-
))) : null, /* @__PURE__ */
|
3415
|
+
))) : null, /* @__PURE__ */ React40.createElement(StyledPagination.Chevron, { disabled: disableRight, onClick: nextPage }, /* @__PURE__ */ React40.createElement(ChevronRightIcon2, { width: 16, height: 16, style: { cursor: disableRight ? "not-allowed" : "pointer" } })));
|
3482
3416
|
};
|
3483
3417
|
|
3484
3418
|
// src/Prebuilt/components/VideoLayouts/Grid.tsx
|
3485
|
-
import
|
3486
|
-
var Grid =
|
3419
|
+
import React41 from "react";
|
3420
|
+
var Grid = React41.forwardRef(
|
3487
3421
|
({ tiles, edgeToEdge }, ref) => {
|
3488
3422
|
const videoTileProps = useVideoTileContext();
|
3489
|
-
return /* @__PURE__ */
|
3423
|
+
return /* @__PURE__ */ React41.createElement(
|
3490
3424
|
Box,
|
3491
3425
|
{
|
3492
3426
|
ref,
|
@@ -3504,7 +3438,7 @@ var Grid = React42.forwardRef(
|
|
3504
3438
|
},
|
3505
3439
|
tiles == null ? void 0 : tiles.map((tile) => {
|
3506
3440
|
var _a, _b, _c, _d;
|
3507
|
-
return /* @__PURE__ */
|
3441
|
+
return /* @__PURE__ */ React41.createElement(
|
3508
3442
|
VideoTile_default,
|
3509
3443
|
__spreadValues({
|
3510
3444
|
key: ((_a = tile.track) == null ? void 0 : _a.id) || ((_b = tile.peer) == null ? void 0 : _b.id),
|
@@ -3522,7 +3456,7 @@ var Grid = React42.forwardRef(
|
|
3522
3456
|
);
|
3523
3457
|
|
3524
3458
|
// src/Prebuilt/components/hooks/useTileLayout.tsx
|
3525
|
-
import { useEffect as useEffect9, useMemo as useMemo2, useState as
|
3459
|
+
import { useEffect as useEffect9, useMemo as useMemo2, useState as useState20 } from "react";
|
3526
3460
|
import { useMeasure as useMeasure2, useMedia as useMedia7 } from "react-use";
|
3527
3461
|
import {
|
3528
3462
|
getPeersWithTiles,
|
@@ -3560,7 +3494,7 @@ var useTileLayout = ({
|
|
3560
3494
|
const vanillaStore = useHMSVanillaStore3();
|
3561
3495
|
const [ref, { width, height }] = useMeasure2();
|
3562
3496
|
const isMobile = useMedia7(config.media.lg);
|
3563
|
-
const [pagesWithTiles, setPagesWithTiles] =
|
3497
|
+
const [pagesWithTiles, setPagesWithTiles] = useState20([]);
|
3564
3498
|
useEffect9(() => {
|
3565
3499
|
if (width === 0 || height === 0) {
|
3566
3500
|
return;
|
@@ -3628,7 +3562,7 @@ var useTileLayout = ({
|
|
3628
3562
|
// src/Prebuilt/components/VideoLayouts/EqualProminence.tsx
|
3629
3563
|
function EqualProminence({ isInsetEnabled = false, peers, onPageChange, onPageSize, edgeToEdge }) {
|
3630
3564
|
var _a;
|
3631
|
-
const localPeer =
|
3565
|
+
const localPeer = useHMSStore19(selectLocalPeer3);
|
3632
3566
|
const isMobile = useMedia8(config.media.md);
|
3633
3567
|
let maxTileCount = useUISettings(UI_SETTINGS.maxTileCount);
|
3634
3568
|
maxTileCount = isMobile ? Math.min(maxTileCount, 6) : maxTileCount;
|
@@ -3649,14 +3583,14 @@ function EqualProminence({ isInsetEnabled = false, peers, onPageChange, onPageSi
|
|
3649
3583
|
maxTileCount,
|
3650
3584
|
edgeToEdge
|
3651
3585
|
});
|
3652
|
-
const [page, setPage] =
|
3586
|
+
const [page, setPage] = useState21(0);
|
3653
3587
|
const pageSize = ((_a = pagesWithTiles[0]) == null ? void 0 : _a.length) || 0;
|
3654
3588
|
useEffect10(() => {
|
3655
3589
|
if (pageSize > 0) {
|
3656
3590
|
onPageSize == null ? void 0 : onPageSize(pageSize);
|
3657
3591
|
}
|
3658
3592
|
}, [pageSize, onPageSize]);
|
3659
|
-
return /* @__PURE__ */
|
3593
|
+
return /* @__PURE__ */ React42.createElement(Flex, { direction: "column", css: { flex: "1 1 0", h: "100%", position: "relative", minWidth: 0 } }, /* @__PURE__ */ React42.createElement(Grid, { tiles: pagesWithTiles[page], ref, edgeToEdge }), !edgeToEdge && /* @__PURE__ */ React42.createElement(
|
3660
3594
|
Pagination,
|
3661
3595
|
{
|
3662
3596
|
page,
|
@@ -3666,20 +3600,20 @@ function EqualProminence({ isInsetEnabled = false, peers, onPageChange, onPageSi
|
|
3666
3600
|
},
|
3667
3601
|
numPages: pagesWithTiles.length
|
3668
3602
|
}
|
3669
|
-
), isInsetEnabled && pageList.length > 0 && pageList[0][0].peer.id !== (localPeer == null ? void 0 : localPeer.id) && /* @__PURE__ */
|
3603
|
+
), isInsetEnabled && pageList.length > 0 && pageList[0][0].peer.id !== (localPeer == null ? void 0 : localPeer.id) && /* @__PURE__ */ React42.createElement(InsetTile, null));
|
3670
3604
|
}
|
3671
3605
|
|
3672
3606
|
// src/Prebuilt/components/VideoLayouts/RoleProminence.tsx
|
3673
|
-
import
|
3674
|
-
import { selectLocalPeer as selectLocalPeer4, useHMSStore as
|
3607
|
+
import React45, { useEffect as useEffect12, useState as useState23 } from "react";
|
3608
|
+
import { selectLocalPeer as selectLocalPeer4, useHMSStore as useHMSStore20 } from "@100mslive/react-sdk";
|
3675
3609
|
|
3676
3610
|
// src/Prebuilt/components/SecondaryTiles.tsx
|
3677
|
-
import
|
3611
|
+
import React44, { useEffect as useEffect11, useState as useState22 } from "react";
|
3678
3612
|
import { useMedia as useMedia9 } from "react-use";
|
3679
3613
|
|
3680
3614
|
// src/Prebuilt/components/VideoLayouts/ProminenceLayout.tsx
|
3681
|
-
import
|
3682
|
-
var Root = ({ children, edgeToEdge }) => /* @__PURE__ */
|
3615
|
+
import React43 from "react";
|
3616
|
+
var Root = ({ children, edgeToEdge }) => /* @__PURE__ */ React43.createElement(
|
3683
3617
|
Flex,
|
3684
3618
|
{
|
3685
3619
|
direction: "column",
|
@@ -3688,7 +3622,7 @@ var Root = ({ children, edgeToEdge }) => /* @__PURE__ */ React44.createElement(
|
|
3688
3622
|
children
|
3689
3623
|
);
|
3690
3624
|
var ProminentSection = ({ children, css = {} }) => {
|
3691
|
-
return /* @__PURE__ */
|
3625
|
+
return /* @__PURE__ */ React43.createElement(Flex, { direction: "column", css: __spreadValues({ flex: "1 1 0", gap: "$2", minHeight: 0 }, css) }, children);
|
3692
3626
|
};
|
3693
3627
|
var SecondarySection = ({
|
3694
3628
|
tiles,
|
@@ -3699,12 +3633,12 @@ var SecondarySection = ({
|
|
3699
3633
|
if (!(tiles == null ? void 0 : tiles.length)) {
|
3700
3634
|
return null;
|
3701
3635
|
}
|
3702
|
-
return /* @__PURE__ */
|
3636
|
+
return /* @__PURE__ */ React43.createElement(
|
3703
3637
|
Box,
|
3704
3638
|
{
|
3705
3639
|
css: {
|
3706
3640
|
display: "grid",
|
3707
|
-
gridTemplateRows:
|
3641
|
+
gridTemplateRows: React43.Children.count(children) > 0 ? "136px auto" : "154px",
|
3708
3642
|
gridTemplateColumns: `repeat(${tiles.length}, minmax(0, 1fr))`,
|
3709
3643
|
margin: "0 auto",
|
3710
3644
|
gap: "$2 $4",
|
@@ -3714,7 +3648,7 @@ var SecondarySection = ({
|
|
3714
3648
|
},
|
3715
3649
|
tiles.map((tile) => {
|
3716
3650
|
var _a, _b, _c, _d;
|
3717
|
-
return /* @__PURE__ */
|
3651
|
+
return /* @__PURE__ */ React43.createElement(
|
3718
3652
|
VideoTile_default,
|
3719
3653
|
__spreadValues({
|
3720
3654
|
key: ((_a = tile.track) == null ? void 0 : _a.id) || ((_b = tile.peer) == null ? void 0 : _b.id),
|
@@ -3731,7 +3665,7 @@ var SecondarySection = ({
|
|
3731
3665
|
}, tileLayoutProps)
|
3732
3666
|
);
|
3733
3667
|
}),
|
3734
|
-
/* @__PURE__ */
|
3668
|
+
/* @__PURE__ */ React43.createElement(Box, { css: { gridColumn: `1/span ${tiles.length}` } }, children)
|
3735
3669
|
);
|
3736
3670
|
};
|
3737
3671
|
var ProminenceLayout = {
|
@@ -3746,14 +3680,14 @@ var SecondaryTiles = ({ peers, onPageChange, onPageSize, edgeToEdge }) => {
|
|
3746
3680
|
const isMobile = useMedia9(config.media.md);
|
3747
3681
|
const maxTileCount = isMobile ? 2 : 4;
|
3748
3682
|
const pagesWithTiles = usePagesWithTiles({ peers, maxTileCount });
|
3749
|
-
const [page, setPage] =
|
3683
|
+
const [page, setPage] = useState22(0);
|
3750
3684
|
const pageSize = ((_a = pagesWithTiles[0]) == null ? void 0 : _a.length) || 0;
|
3751
3685
|
useEffect11(() => {
|
3752
3686
|
if (pageSize > 0) {
|
3753
3687
|
onPageSize == null ? void 0 : onPageSize(pageSize);
|
3754
3688
|
}
|
3755
3689
|
}, [pageSize, onPageSize]);
|
3756
|
-
return /* @__PURE__ */
|
3690
|
+
return /* @__PURE__ */ React44.createElement(ProminenceLayout.SecondarySection, { tiles: pagesWithTiles[page], edgeToEdge }, !edgeToEdge && /* @__PURE__ */ React44.createElement(
|
3757
3691
|
Pagination,
|
3758
3692
|
{
|
3759
3693
|
page,
|
@@ -3811,7 +3745,7 @@ function RoleProminence({
|
|
3811
3745
|
}) {
|
3812
3746
|
var _a;
|
3813
3747
|
const { prominentPeers, secondaryPeers } = useRoleProminencePeers(prominentRoles, peers, isInsetEnabled);
|
3814
|
-
const localPeer =
|
3748
|
+
const localPeer = useHMSStore20(selectLocalPeer4);
|
3815
3749
|
const maxTileCount = 4;
|
3816
3750
|
const pageList = usePagesWithTiles({
|
3817
3751
|
peers: prominentPeers,
|
@@ -3821,14 +3755,14 @@ function RoleProminence({
|
|
3821
3755
|
pageList,
|
3822
3756
|
maxTileCount
|
3823
3757
|
});
|
3824
|
-
const [page, setPage] =
|
3758
|
+
const [page, setPage] = useState23(0);
|
3825
3759
|
const pageSize = ((_a = pagesWithTiles[0]) == null ? void 0 : _a.length) || 0;
|
3826
3760
|
useEffect12(() => {
|
3827
3761
|
if (pageSize > 0) {
|
3828
3762
|
onPageSize == null ? void 0 : onPageSize(pageSize);
|
3829
3763
|
}
|
3830
3764
|
}, [pageSize, onPageSize]);
|
3831
|
-
return /* @__PURE__ */
|
3765
|
+
return /* @__PURE__ */ React45.createElement(ProminenceLayout.Root, null, /* @__PURE__ */ React45.createElement(ProminenceLayout.ProminentSection, null, /* @__PURE__ */ React45.createElement(Grid, { ref, tiles: pagesWithTiles[page] })), !edgeToEdge && /* @__PURE__ */ React45.createElement(
|
3832
3766
|
Pagination,
|
3833
3767
|
{
|
3834
3768
|
page,
|
@@ -3838,16 +3772,16 @@ function RoleProminence({
|
|
3838
3772
|
},
|
3839
3773
|
numPages: pagesWithTiles.length
|
3840
3774
|
}
|
3841
|
-
), /* @__PURE__ */
|
3775
|
+
), /* @__PURE__ */ React45.createElement(SecondaryTiles, { peers: secondaryPeers, isInsetEnabled, edgeToEdge }), isInsetEnabled && localPeer && !prominentPeers.includes(localPeer) && /* @__PURE__ */ React45.createElement(InsetTile, null));
|
3842
3776
|
}
|
3843
3777
|
|
3844
3778
|
// src/Prebuilt/components/VideoLayouts/ScreenshareLayout.tsx
|
3845
|
-
import
|
3779
|
+
import React48, { useEffect as useEffect13, useMemo as useMemo5, useState as useState25 } from "react";
|
3846
3780
|
import { useMedia as useMedia10 } from "react-use";
|
3847
|
-
import { selectPeersScreenSharing, useHMSStore as
|
3781
|
+
import { selectPeersScreenSharing, useHMSStore as useHMSStore22 } from "@100mslive/react-sdk";
|
3848
3782
|
|
3849
3783
|
// src/Prebuilt/components/ScreenshareTile.jsx
|
3850
|
-
import
|
3784
|
+
import React47, { useRef as useRef7, useState as useState24 } from "react";
|
3851
3785
|
import { useFullscreen as useFullscreen2 } from "react-use";
|
3852
3786
|
import screenfull2 from "screenfull";
|
3853
3787
|
import {
|
@@ -3855,17 +3789,17 @@ import {
|
|
3855
3789
|
selectPeerByID as selectPeerByID2,
|
3856
3790
|
selectScreenShareAudioByPeerID,
|
3857
3791
|
selectScreenShareByPeerID,
|
3858
|
-
useHMSStore as
|
3792
|
+
useHMSStore as useHMSStore21
|
3859
3793
|
} from "@100mslive/react-sdk";
|
3860
3794
|
import { ExpandIcon as ExpandIcon3, ShrinkIcon } from "@100mslive/react-icons";
|
3861
3795
|
|
3862
3796
|
// src/Prebuilt/components/ScreenshareDisplay.jsx
|
3863
|
-
import
|
3797
|
+
import React46 from "react";
|
3864
3798
|
import { useHMSActions as useHMSActions13 } from "@100mslive/react-sdk";
|
3865
|
-
import { CrossIcon as
|
3799
|
+
import { CrossIcon as CrossIcon5, ShareScreenIcon as ShareScreenIcon2 } from "@100mslive/react-icons";
|
3866
3800
|
var ScreenshareDisplay = () => {
|
3867
3801
|
const hmsActions = useHMSActions13();
|
3868
|
-
return /* @__PURE__ */
|
3802
|
+
return /* @__PURE__ */ React46.createElement(
|
3869
3803
|
Flex,
|
3870
3804
|
{
|
3871
3805
|
direction: "column",
|
@@ -3877,9 +3811,9 @@ var ScreenshareDisplay = () => {
|
|
3877
3811
|
color: "$on_surface_high"
|
3878
3812
|
}
|
3879
3813
|
},
|
3880
|
-
/* @__PURE__ */
|
3881
|
-
/* @__PURE__ */
|
3882
|
-
/* @__PURE__ */
|
3814
|
+
/* @__PURE__ */ React46.createElement(ShareScreenIcon2, { width: 48, height: 48 }),
|
3815
|
+
/* @__PURE__ */ React46.createElement(Text, { variant: "h5", css: { m: "$8 0" } }, "You are sharing your screen"),
|
3816
|
+
/* @__PURE__ */ React46.createElement(
|
3883
3817
|
Button,
|
3884
3818
|
{
|
3885
3819
|
variant: "danger",
|
@@ -3889,7 +3823,7 @@ var ScreenshareDisplay = () => {
|
|
3889
3823
|
}),
|
3890
3824
|
"data-testid": "stop_screen_share_btn"
|
3891
3825
|
},
|
3892
|
-
/* @__PURE__ */
|
3826
|
+
/* @__PURE__ */ React46.createElement(CrossIcon5, { width: 18, height: 18 }),
|
3893
3827
|
"\xA0 Stop screen share"
|
3894
3828
|
)
|
3895
3829
|
);
|
@@ -3905,31 +3839,31 @@ var labelStyles = {
|
|
3905
3839
|
flexShrink: 0
|
3906
3840
|
};
|
3907
3841
|
var Tile = ({ peerId, width = "100%", height = "100%" }) => {
|
3908
|
-
const isLocal =
|
3909
|
-
const track =
|
3910
|
-
const peer =
|
3842
|
+
const isLocal = useHMSStore21(selectLocalPeerID5) === peerId;
|
3843
|
+
const track = useHMSStore21(selectScreenShareByPeerID(peerId));
|
3844
|
+
const peer = useHMSStore21(selectPeerByID2(peerId));
|
3911
3845
|
const isAudioOnly = useUISettings(UI_SETTINGS.isAudioOnly);
|
3912
|
-
const [isMouseHovered, setIsMouseHovered] =
|
3846
|
+
const [isMouseHovered, setIsMouseHovered] = useState24(false);
|
3913
3847
|
const showStatsOnTiles = useUISettings(UI_SETTINGS.showStatsOnTiles);
|
3914
|
-
const label = getVideoTileLabel({
|
3915
|
-
peerName: peer.name,
|
3916
|
-
isLocal: false,
|
3917
|
-
track
|
3918
|
-
});
|
3919
3848
|
const fullscreenRef = useRef7(null);
|
3920
|
-
const [fullscreen, setFullscreen] =
|
3849
|
+
const [fullscreen, setFullscreen] = useState24(false);
|
3921
3850
|
const isFullscreen = useFullscreen2(fullscreenRef, fullscreen, {
|
3922
3851
|
onClose: () => setFullscreen(false)
|
3923
3852
|
});
|
3924
3853
|
const isFullScreenSupported = screenfull2.isEnabled;
|
3925
|
-
const audioTrack =
|
3854
|
+
const audioTrack = useHMSStore21(selectScreenShareAudioByPeerID(peer == null ? void 0 : peer.id));
|
3926
3855
|
if (isLocal && !["browser", "window", "application"].includes(track == null ? void 0 : track.displaySurface)) {
|
3927
|
-
return /* @__PURE__ */
|
3856
|
+
return /* @__PURE__ */ React47.createElement(ScreenshareDisplay, null);
|
3928
3857
|
}
|
3929
3858
|
if (!peer) {
|
3930
3859
|
return null;
|
3931
3860
|
}
|
3932
|
-
|
3861
|
+
const label = getVideoTileLabel({
|
3862
|
+
peerName: peer == null ? void 0 : peer.name,
|
3863
|
+
isLocal: false,
|
3864
|
+
track
|
3865
|
+
});
|
3866
|
+
return /* @__PURE__ */ React47.createElement(StyledVideoTile.Root, { css: { width, height, p: 0, minHeight: 0 }, "data-testid": "screenshare_tile" }, /* @__PURE__ */ React47.createElement(
|
3933
3867
|
StyledVideoTile.Container,
|
3934
3868
|
{
|
3935
3869
|
transparentBg: true,
|
@@ -3940,9 +3874,9 @@ var Tile = ({ peerId, width = "100%", height = "100%" }) => {
|
|
3940
3874
|
setIsMouseHovered(false);
|
3941
3875
|
}
|
3942
3876
|
},
|
3943
|
-
showStatsOnTiles ? /* @__PURE__ */
|
3944
|
-
isFullScreenSupported && isMouseHovered ? /* @__PURE__ */
|
3945
|
-
track ? /* @__PURE__ */
|
3877
|
+
showStatsOnTiles ? /* @__PURE__ */ React47.createElement(VideoTileStats, { audioTrackID: audioTrack == null ? void 0 : audioTrack.id, videoTrackID: track == null ? void 0 : track.id, peerID: peerId, isLocal }) : null,
|
3878
|
+
isFullScreenSupported && isMouseHovered ? /* @__PURE__ */ React47.createElement(StyledVideoTile.FullScreenButton, { onClick: () => setFullscreen(!fullscreen) }, isFullscreen ? /* @__PURE__ */ React47.createElement(ShrinkIcon, null) : /* @__PURE__ */ React47.createElement(ExpandIcon3, null)) : null,
|
3879
|
+
track ? /* @__PURE__ */ React47.createElement(
|
3946
3880
|
Video,
|
3947
3881
|
{
|
3948
3882
|
screenShare: true,
|
@@ -3952,19 +3886,28 @@ var Tile = ({ peerId, width = "100%", height = "100%" }) => {
|
|
3952
3886
|
css: { minHeight: 0 }
|
3953
3887
|
}
|
3954
3888
|
) : null,
|
3955
|
-
/* @__PURE__ */
|
3956
|
-
isMouseHovered && !
|
3889
|
+
/* @__PURE__ */ React47.createElement(StyledVideoTile.Info, { css: labelStyles }, label),
|
3890
|
+
isMouseHovered && !peer.isLocal ? /* @__PURE__ */ React47.createElement(
|
3891
|
+
TileMenu_default,
|
3892
|
+
{
|
3893
|
+
isScreenshare: true,
|
3894
|
+
peerID: peer.id,
|
3895
|
+
audioTrackID: audioTrack == null ? void 0 : audioTrack.id,
|
3896
|
+
videoTrackID: track == null ? void 0 : track.id,
|
3897
|
+
enableSpotlightingPeer: false
|
3898
|
+
}
|
3899
|
+
) : null
|
3957
3900
|
));
|
3958
3901
|
};
|
3959
|
-
var ScreenshareTile =
|
3902
|
+
var ScreenshareTile = React47.memo(Tile);
|
3960
3903
|
var ScreenshareTile_default = ScreenshareTile;
|
3961
3904
|
|
3962
3905
|
// src/Prebuilt/components/VideoLayouts/ScreenshareLayout.tsx
|
3963
3906
|
var ScreenshareLayout = ({ peers, onPageChange, onPageSize, edgeToEdge }) => {
|
3964
3907
|
var _a;
|
3965
|
-
const peersSharing =
|
3908
|
+
const peersSharing = useHMSStore22(selectPeersScreenSharing);
|
3966
3909
|
const [, setActiveScreenSharePeer] = useSetAppDataByKey(APP_DATA.activeScreensharePeerId);
|
3967
|
-
const [page, setPage] =
|
3910
|
+
const [page, setPage] = useState25(0);
|
3968
3911
|
const activeSharePeer = peersSharing[page];
|
3969
3912
|
const isMobile = useMedia10(config.media.md);
|
3970
3913
|
const secondaryPeers = useMemo5(
|
@@ -3977,7 +3920,7 @@ var ScreenshareLayout = ({ peers, onPageChange, onPageSize, edgeToEdge }) => {
|
|
3977
3920
|
setActiveScreenSharePeer("");
|
3978
3921
|
};
|
3979
3922
|
}, [activeSharePeer == null ? void 0 : activeSharePeer.id, isMobile, setActiveScreenSharePeer]);
|
3980
|
-
return /* @__PURE__ */
|
3923
|
+
return /* @__PURE__ */ React48.createElement(ProminenceLayout.Root, { edgeToEdge }, /* @__PURE__ */ React48.createElement(ProminenceLayout.ProminentSection, null, /* @__PURE__ */ React48.createElement(ScreenshareTile_default, { peerId: (_a = peersSharing[page]) == null ? void 0 : _a.id }), !edgeToEdge && /* @__PURE__ */ React48.createElement(Pagination, { page, onPageChange: setPage, numPages: peersSharing.length })), /* @__PURE__ */ React48.createElement(
|
3981
3924
|
SecondaryTiles,
|
3982
3925
|
{
|
3983
3926
|
peers: secondaryPeers,
|
@@ -4082,9 +4025,9 @@ var GridLayout = ({
|
|
4082
4025
|
edge_to_edge = false,
|
4083
4026
|
hide_metadata_on_tile = false
|
4084
4027
|
}) => {
|
4085
|
-
const peerSharing =
|
4028
|
+
const peerSharing = useHMSStore23(selectPeerScreenSharing);
|
4086
4029
|
const pinnedTrack = usePinnedTrack();
|
4087
|
-
const peers =
|
4030
|
+
const peers = useHMSStore23(selectPeers2);
|
4088
4031
|
const isRoleProminence = prominentRoles.length && peers.some(
|
4089
4032
|
(peer) => peer.roleName && prominentRoles.includes(peer.roleName) && (peer.videoTrack || peer.audioTrack)
|
4090
4033
|
) || pinnedTrack;
|
@@ -4095,10 +4038,10 @@ var GridLayout = ({
|
|
4095
4038
|
return peers;
|
4096
4039
|
}, [isInsetEnabled, isRoleProminence, peerSharing, peers]);
|
4097
4040
|
const vanillaStore = useHMSVanillaStore4();
|
4098
|
-
const [sortedPeers, setSortedPeers] =
|
4041
|
+
const [sortedPeers, setSortedPeers] = useState26(updatedPeers);
|
4099
4042
|
const peersSorter = useMemo6(() => new PeersSorter_default(vanillaStore), [vanillaStore]);
|
4100
|
-
const [pageSize, setPageSize] =
|
4101
|
-
const [mainPage, setMainPage] =
|
4043
|
+
const [pageSize, setPageSize] = useState26(0);
|
4044
|
+
const [mainPage, setMainPage] = useState26(0);
|
4102
4045
|
const tileLayout = {
|
4103
4046
|
enableSpotlightingPeer: enable_spotlighting_peer,
|
4104
4047
|
hideParticipantNameOnTile: hide_participant_name_on_tile,
|
@@ -4118,7 +4061,7 @@ var GridLayout = ({
|
|
4118
4061
|
peersSorter.onUpdate(setSortedPeers);
|
4119
4062
|
}, [mainPage, peersSorter, updatedPeers, pageSize]);
|
4120
4063
|
if (peerSharing) {
|
4121
|
-
return /* @__PURE__ */
|
4064
|
+
return /* @__PURE__ */ React49.createElement(VideoTileContext.Provider, { value: tileLayout }, /* @__PURE__ */ React49.createElement(
|
4122
4065
|
ScreenshareLayout,
|
4123
4066
|
{
|
4124
4067
|
peers: sortedPeers,
|
@@ -4128,7 +4071,7 @@ var GridLayout = ({
|
|
4128
4071
|
}
|
4129
4072
|
));
|
4130
4073
|
} else if (isRoleProminence) {
|
4131
|
-
return /* @__PURE__ */
|
4074
|
+
return /* @__PURE__ */ React49.createElement(VideoTileContext.Provider, { value: tileLayout }, /* @__PURE__ */ React49.createElement(
|
4132
4075
|
RoleProminence,
|
4133
4076
|
{
|
4134
4077
|
peers: sortedPeers,
|
@@ -4140,7 +4083,7 @@ var GridLayout = ({
|
|
4140
4083
|
}
|
4141
4084
|
));
|
4142
4085
|
}
|
4143
|
-
return /* @__PURE__ */
|
4086
|
+
return /* @__PURE__ */ React49.createElement(VideoTileContext.Provider, { value: tileLayout }, /* @__PURE__ */ React49.createElement(
|
4144
4087
|
EqualProminence,
|
4145
4088
|
{
|
4146
4089
|
peers: sortedPeers,
|
@@ -4153,20 +4096,20 @@ var GridLayout = ({
|
|
4153
4096
|
};
|
4154
4097
|
|
4155
4098
|
// src/Prebuilt/layouts/EmbedView.jsx
|
4156
|
-
import
|
4099
|
+
import React50, { useCallback as useCallback8, useEffect as useEffect15, useMemo as useMemo7, useRef as useRef8, useState as useState27 } from "react";
|
4157
4100
|
import {
|
4158
4101
|
selectPeers as selectPeers3,
|
4159
4102
|
selectPeerScreenSharing as selectPeerScreenSharing2,
|
4160
4103
|
throwErrorHandler,
|
4161
|
-
useHMSStore as
|
4104
|
+
useHMSStore as useHMSStore24,
|
4162
4105
|
useScreenShare as useScreenShare3
|
4163
4106
|
} from "@100mslive/react-sdk";
|
4164
4107
|
var EmbedView = () => {
|
4165
|
-
return /* @__PURE__ */
|
4108
|
+
return /* @__PURE__ */ React50.createElement(EmbebScreenShareView, null, /* @__PURE__ */ React50.createElement(EmbedComponent, null));
|
4166
4109
|
};
|
4167
4110
|
var EmbebScreenShareView = ({ children }) => {
|
4168
|
-
const peers =
|
4169
|
-
const peerPresenting =
|
4111
|
+
const peers = useHMSStore24(selectPeers3);
|
4112
|
+
const peerPresenting = useHMSStore24(selectPeerScreenSharing2);
|
4170
4113
|
const [, setActiveScreenSharePeer] = useSetAppDataByKey(APP_DATA.activeScreensharePeerId);
|
4171
4114
|
const smallTilePeers = useMemo7(() => {
|
4172
4115
|
const smallTilePeers2 = peers.filter((peer) => peer.id !== (peerPresenting == null ? void 0 : peerPresenting.id));
|
@@ -4178,12 +4121,12 @@ var EmbebScreenShareView = ({ children }) => {
|
|
4178
4121
|
setActiveScreenSharePeer("");
|
4179
4122
|
};
|
4180
4123
|
}, [peerPresenting == null ? void 0 : peerPresenting.id, setActiveScreenSharePeer]);
|
4181
|
-
return /* @__PURE__ */
|
4124
|
+
return /* @__PURE__ */ React50.createElement(ProminenceLayout.Root, null, /* @__PURE__ */ React50.createElement(ProminenceLayout.ProminentSection, null, children), /* @__PURE__ */ React50.createElement(SecondaryTiles, { peers: smallTilePeers }));
|
4182
4125
|
};
|
4183
4126
|
var EmbedComponent = () => {
|
4184
4127
|
const { amIScreenSharing, toggleScreenShare } = useScreenShare3(throwErrorHandler);
|
4185
4128
|
const [embedConfig, setEmbedConfig] = useSetAppDataByKey(APP_DATA.embedConfig);
|
4186
|
-
const [wasScreenShared, setWasScreenShared] =
|
4129
|
+
const [wasScreenShared, setWasScreenShared] = useState27(false);
|
4187
4130
|
const screenShareAttemptInProgress = useRef8(false);
|
4188
4131
|
const src = embedConfig.url;
|
4189
4132
|
const iframeRef = useRef8();
|
@@ -4216,7 +4159,7 @@ var EmbedComponent = () => {
|
|
4216
4159
|
}
|
4217
4160
|
};
|
4218
4161
|
}, [wasScreenShared, amIScreenSharing, resetEmbedConfig, toggleScreenShare]);
|
4219
|
-
return /* @__PURE__ */
|
4162
|
+
return /* @__PURE__ */ React50.createElement(Box, { ref: iframeRef, css: { size: "100%" } }, /* @__PURE__ */ React50.createElement(
|
4220
4163
|
"iframe",
|
4221
4164
|
{
|
4222
4165
|
src,
|
@@ -4229,22 +4172,22 @@ var EmbedComponent = () => {
|
|
4229
4172
|
};
|
4230
4173
|
|
4231
4174
|
// src/Prebuilt/layouts/PDFView.jsx
|
4232
|
-
import
|
4175
|
+
import React51, { useCallback as useCallback9, useEffect as useEffect16, useRef as useRef9, useState as useState28 } from "react";
|
4233
4176
|
import { throwErrorHandler as throwErrorHandler2, useScreenShare as useScreenShare4 } from "@100mslive/react-sdk";
|
4234
4177
|
var PDFView = () => {
|
4235
|
-
return /* @__PURE__ */
|
4178
|
+
return /* @__PURE__ */ React51.createElement(EmbebScreenShareView, null, /* @__PURE__ */ React51.createElement(PDFEmbedComponent, null));
|
4236
4179
|
};
|
4237
4180
|
var PDFEmbedComponent = () => {
|
4238
4181
|
const ref = useRef9();
|
4239
4182
|
const themeType = useTheme().themeType;
|
4240
|
-
const [isPDFLoaded, setIsPDFLoaded] =
|
4183
|
+
const [isPDFLoaded, setIsPDFLoaded] = useState28(false);
|
4241
4184
|
let pdfJSURL = define_process_env_default.REACT_APP_PDFJS_IFRAME_URL;
|
4242
4185
|
const { amIScreenSharing, toggleScreenShare } = useScreenShare4(throwErrorHandler2);
|
4243
4186
|
const [pdfConfig, setPDFConfig] = useSetAppDataByKey(APP_DATA.pdfConfig);
|
4244
4187
|
if (pdfConfig.url && !pdfConfig.file) {
|
4245
4188
|
pdfJSURL = pdfJSURL + "?file=" + encodeURIComponent(pdfConfig.url);
|
4246
4189
|
}
|
4247
|
-
const [wasScreenShared, setWasScreenShared] =
|
4190
|
+
const [wasScreenShared, setWasScreenShared] = useState28(false);
|
4248
4191
|
const screenShareAttemptInProgress = useRef9(false);
|
4249
4192
|
const iframeRef = useRef9();
|
4250
4193
|
const resetEmbedConfig = useCallback9(() => {
|
@@ -4285,7 +4228,7 @@ var PDFEmbedComponent = () => {
|
|
4285
4228
|
}
|
4286
4229
|
};
|
4287
4230
|
}, [wasScreenShared, amIScreenSharing, resetEmbedConfig, toggleScreenShare]);
|
4288
|
-
return /* @__PURE__ */
|
4231
|
+
return /* @__PURE__ */ React51.createElement(Box, { ref: iframeRef, css: { size: "100%" } }, /* @__PURE__ */ React51.createElement(
|
4289
4232
|
"iframe",
|
4290
4233
|
{
|
4291
4234
|
src: pdfJSURL,
|
@@ -4319,11 +4262,17 @@ var PDFEmbedComponent = () => {
|
|
4319
4262
|
|
4320
4263
|
// src/Prebuilt/layouts/SidePane.tsx
|
4321
4264
|
import React58 from "react";
|
4265
|
+
import { useMedia as useMedia15 } from "react-use";
|
4266
|
+
import { selectAppData as selectAppData3, selectVideoTrackByPeerID, useHMSStore as useHMSStore33 } from "@100mslive/react-sdk";
|
4267
|
+
|
4268
|
+
// src/Prebuilt/components/SidePaneTabs.tsx
|
4269
|
+
import React55, { useEffect as useEffect21, useState as useState32 } from "react";
|
4322
4270
|
import { useMedia as useMedia14 } from "react-use";
|
4323
|
-
import {
|
4271
|
+
import { selectPeerCount as selectPeerCount3, useHMSStore as useHMSStore30 } from "@100mslive/react-sdk";
|
4272
|
+
import { CrossIcon as CrossIcon7 } from "@100mslive/react-icons";
|
4324
4273
|
|
4325
4274
|
// src/Prebuilt/components/Chat/Chat.jsx
|
4326
|
-
import
|
4275
|
+
import React54, { useCallback as useCallback14, useEffect as useEffect20, useRef as useRef13, useState as useState31 } from "react";
|
4327
4276
|
import { useMedia as useMedia13 } from "react-use";
|
4328
4277
|
import {
|
4329
4278
|
HMSNotificationTypes,
|
@@ -4333,12 +4282,12 @@ import {
|
|
4333
4282
|
selectSessionStore,
|
4334
4283
|
useHMSActions as useHMSActions18,
|
4335
4284
|
useHMSNotifications,
|
4336
|
-
useHMSStore as
|
4285
|
+
useHMSStore as useHMSStore29
|
4337
4286
|
} from "@100mslive/react-sdk";
|
4338
|
-
import { ChevronDownIcon as ChevronDownIcon2, CrossIcon as
|
4287
|
+
import { ChevronDownIcon as ChevronDownIcon2, CrossIcon as CrossIcon6, PinIcon as PinIcon2 } from "@100mslive/react-icons";
|
4339
4288
|
|
4340
4289
|
// src/Prebuilt/components/Chat/ChatBody.jsx
|
4341
|
-
import
|
4290
|
+
import React52, { Fragment as Fragment8, useCallback as useCallback11, useEffect as useEffect17, useLayoutEffect, useMemo as useMemo8, useRef as useRef10, useState as useState29 } from "react";
|
4342
4291
|
import { useInView } from "react-intersection-observer";
|
4343
4292
|
import { useMedia as useMedia11 } from "react-use";
|
4344
4293
|
import AutoSizer from "react-virtualized-auto-sizer";
|
@@ -4352,7 +4301,7 @@ import {
|
|
4352
4301
|
selectPeerNameByID as selectPeerNameByID2,
|
4353
4302
|
selectPermissions as selectPermissions9,
|
4354
4303
|
useHMSActions as useHMSActions15,
|
4355
|
-
useHMSStore as
|
4304
|
+
useHMSStore as useHMSStore26
|
4356
4305
|
} from "@100mslive/react-sdk";
|
4357
4306
|
import { PinIcon, VerticalMenuIcon as VerticalMenuIcon5 } from "@100mslive/react-icons";
|
4358
4307
|
|
@@ -4365,13 +4314,13 @@ import {
|
|
4365
4314
|
selectPeerNameByID,
|
4366
4315
|
selectSessionMetadata,
|
4367
4316
|
useHMSActions as useHMSActions14,
|
4368
|
-
useHMSStore as
|
4317
|
+
useHMSStore as useHMSStore25,
|
4369
4318
|
useHMSVanillaStore as useHMSVanillaStore5
|
4370
4319
|
} from "@100mslive/react-sdk";
|
4371
4320
|
var useSetPinnedMessage = () => {
|
4372
4321
|
const hmsActions = useHMSActions14();
|
4373
4322
|
const vanillaStore = useHMSVanillaStore5();
|
4374
|
-
const pinnedMessage =
|
4323
|
+
const pinnedMessage = useHMSStore25(selectSessionMetadata);
|
4375
4324
|
const setPinnedMessage = useCallback10(
|
4376
4325
|
/**
|
4377
4326
|
* @param {import("@100mslive/react-sdk").HMSMessage | undefined} message
|
@@ -4405,7 +4354,7 @@ var formatTime = (date) => {
|
|
4405
4354
|
return `${hours}:${mins} ${suffix}`;
|
4406
4355
|
};
|
4407
4356
|
var MessageTypeContainer = ({ left, right }) => {
|
4408
|
-
return /* @__PURE__ */
|
4357
|
+
return /* @__PURE__ */ React52.createElement(
|
4409
4358
|
Flex,
|
4410
4359
|
{
|
4411
4360
|
align: "center",
|
@@ -4417,16 +4366,16 @@ var MessageTypeContainer = ({ left, right }) => {
|
|
4417
4366
|
r: "$0"
|
4418
4367
|
}
|
4419
4368
|
},
|
4420
|
-
left && /* @__PURE__ */
|
4421
|
-
left && right && /* @__PURE__ */
|
4422
|
-
right && /* @__PURE__ */
|
4369
|
+
left && /* @__PURE__ */ React52.createElement(SenderName, { variant: "tiny", as: "span", css: { color: "$on_surface_medium" } }, left),
|
4370
|
+
left && right && /* @__PURE__ */ React52.createElement(Box, { css: { borderLeft: "1px solid $border_bright", mx: "$4", h: "$8" } }),
|
4371
|
+
right && /* @__PURE__ */ React52.createElement(SenderName, { as: "span", variant: "tiny", css: { textTransform: "uppercase" } }, right)
|
4423
4372
|
);
|
4424
4373
|
};
|
4425
4374
|
var MessageType = ({ roles, hasCurrentUserSent, receiver }) => {
|
4426
|
-
const peerName =
|
4427
|
-
const localPeerRoleName =
|
4375
|
+
const peerName = useHMSStore26(selectPeerNameByID2(receiver));
|
4376
|
+
const localPeerRoleName = useHMSStore26(selectLocalPeerRoleName);
|
4428
4377
|
if (receiver) {
|
4429
|
-
return /* @__PURE__ */
|
4378
|
+
return /* @__PURE__ */ React52.createElement(
|
4430
4379
|
MessageTypeContainer,
|
4431
4380
|
{
|
4432
4381
|
left: hasCurrentUserSent ? `${peerName ? `TO ${peerName}` : ""}` : "TO YOU",
|
@@ -4435,7 +4384,7 @@ var MessageType = ({ roles, hasCurrentUserSent, receiver }) => {
|
|
4435
4384
|
);
|
4436
4385
|
}
|
4437
4386
|
if (roles && roles.length) {
|
4438
|
-
return /* @__PURE__ */
|
4387
|
+
return /* @__PURE__ */ React52.createElement(MessageTypeContainer, { left: "TO", right: hasCurrentUserSent ? roles.join(",") : localPeerRoleName });
|
4439
4388
|
}
|
4440
4389
|
return null;
|
4441
4390
|
};
|
@@ -4449,10 +4398,10 @@ var Link = styled("a", {
|
|
4449
4398
|
});
|
4450
4399
|
var AnnotisedMessage = ({ message }) => {
|
4451
4400
|
if (!message) {
|
4452
|
-
return /* @__PURE__ */
|
4401
|
+
return /* @__PURE__ */ React52.createElement(Fragment8, null);
|
4453
4402
|
}
|
4454
|
-
return /* @__PURE__ */
|
4455
|
-
(part) => URL_REGEX.test(part) ? /* @__PURE__ */
|
4403
|
+
return /* @__PURE__ */ React52.createElement(Fragment8, null, message.trim().split(/(\s)/).map(
|
4404
|
+
(part) => URL_REGEX.test(part) ? /* @__PURE__ */ React52.createElement(Link, { href: part, key: part, target: "_blank", rel: "noopener noreferrer" }, part) : part
|
4456
4405
|
));
|
4457
4406
|
};
|
4458
4407
|
var getMessageType = ({ roles, receiver }) => {
|
@@ -4462,18 +4411,18 @@ var getMessageType = ({ roles, receiver }) => {
|
|
4462
4411
|
return receiver ? "private" : "";
|
4463
4412
|
};
|
4464
4413
|
var ChatActions = ({ onPin, showPinAction }) => {
|
4465
|
-
const [open, setOpen] =
|
4414
|
+
const [open, setOpen] = useState29(false);
|
4466
4415
|
if (!showPinAction) {
|
4467
4416
|
return null;
|
4468
4417
|
}
|
4469
|
-
return /* @__PURE__ */
|
4418
|
+
return /* @__PURE__ */ React52.createElement(Dropdown.Root, { open, onOpenChange: setOpen }, /* @__PURE__ */ React52.createElement(Dropdown.Trigger, { className: "chat_actions", css: { opacity: open ? 1 : 0, "@md": { opacity: 1 } }, asChild: true }, /* @__PURE__ */ React52.createElement(IconButton, null, /* @__PURE__ */ React52.createElement(Tooltip, { title: "More options" }, /* @__PURE__ */ React52.createElement(VerticalMenuIcon5, null)))), /* @__PURE__ */ React52.createElement(Dropdown.Portal, null, /* @__PURE__ */ React52.createElement(
|
4470
4419
|
Dropdown.Content,
|
4471
4420
|
{
|
4472
4421
|
sideOffset: 5,
|
4473
4422
|
align: "end",
|
4474
4423
|
css: { width: "$48", backgroundColor: "$surface_bright", py: "$0", border: "1px solid $border_bright" }
|
4475
4424
|
},
|
4476
|
-
/* @__PURE__ */
|
4425
|
+
/* @__PURE__ */ React52.createElement(Dropdown.Item, { "data-testid": "pin_message_btn", onClick: onPin }, /* @__PURE__ */ React52.createElement(PinIcon, null), /* @__PURE__ */ React52.createElement(Text, { variant: "sm", css: { ml: "$4" } }, "Pin Message"))
|
4477
4426
|
)));
|
4478
4427
|
};
|
4479
4428
|
var SenderName = styled(Text, {
|
@@ -4485,7 +4434,7 @@ var SenderName = styled(Text, {
|
|
4485
4434
|
color: "$on_surface_high",
|
4486
4435
|
fontWeight: "$semiBold"
|
4487
4436
|
});
|
4488
|
-
var ChatMessage =
|
4437
|
+
var ChatMessage = React52.memo(({ index, style = {}, message, setRowHeight, onPin }) => {
|
4489
4438
|
var _a, _b;
|
4490
4439
|
const { ref, inView } = useInView({ threshold: 0.5, triggerOnce: true });
|
4491
4440
|
const rowRef = useRef10(null);
|
@@ -4498,8 +4447,8 @@ var ChatMessage = React53.memo(({ index, style = {}, message, setRowHeight, onPi
|
|
4498
4447
|
const { elements } = useRoomLayoutConferencingScreen();
|
4499
4448
|
const isOverlay = ((_a = elements == null ? void 0 : elements.chat) == null ? void 0 : _a.is_overlay) && isMobile;
|
4500
4449
|
const hmsActions = useHMSActions15();
|
4501
|
-
const localPeerId =
|
4502
|
-
const permissions =
|
4450
|
+
const localPeerId = useHMSStore26(selectLocalPeerID6);
|
4451
|
+
const permissions = useHMSStore26(selectPermissions9);
|
4503
4452
|
const messageType = getMessageType({
|
4504
4453
|
roles: message.recipientRoles,
|
4505
4454
|
receiver: message.recipientPeer
|
@@ -4510,7 +4459,7 @@ var ChatMessage = React53.memo(({ index, style = {}, message, setRowHeight, onPi
|
|
4510
4459
|
hmsActions.setMessageRead(true, message.id);
|
4511
4460
|
}
|
4512
4461
|
}, [message.read, hmsActions, inView, message.id]);
|
4513
|
-
return /* @__PURE__ */
|
4462
|
+
return /* @__PURE__ */ React52.createElement(
|
4514
4463
|
Box,
|
4515
4464
|
{
|
4516
4465
|
ref,
|
@@ -4518,7 +4467,7 @@ var ChatMessage = React53.memo(({ index, style = {}, message, setRowHeight, onPi
|
|
4518
4467
|
css: { mb: "$10", pr: "$10", mt: "$8", "&:hover .chat_actions": { opacity: 1 } },
|
4519
4468
|
style
|
4520
4469
|
},
|
4521
|
-
/* @__PURE__ */
|
4470
|
+
/* @__PURE__ */ React52.createElement(
|
4522
4471
|
Flex,
|
4523
4472
|
{
|
4524
4473
|
ref: rowRef,
|
@@ -4535,7 +4484,7 @@ var ChatMessage = React53.memo(({ index, style = {}, message, setRowHeight, onPi
|
|
4535
4484
|
key: message.time,
|
4536
4485
|
"data-testid": "chat_msg"
|
4537
4486
|
},
|
4538
|
-
/* @__PURE__ */
|
4487
|
+
/* @__PURE__ */ React52.createElement(
|
4539
4488
|
Text,
|
4540
4489
|
{
|
4541
4490
|
css: {
|
@@ -4548,7 +4497,7 @@ var ChatMessage = React53.memo(({ index, style = {}, message, setRowHeight, onPi
|
|
4548
4497
|
},
|
4549
4498
|
as: "div"
|
4550
4499
|
},
|
4551
|
-
/* @__PURE__ */
|
4500
|
+
/* @__PURE__ */ React52.createElement(Flex, { align: "baseline" }, message.senderName === "You" || !message.senderName ? /* @__PURE__ */ React52.createElement(SenderName, { as: "span", variant: "sm", css: { color: isOverlay ? "#FFF" : "$on_surface_high" } }, message.senderName || "Anonymous") : /* @__PURE__ */ React52.createElement(Tooltip, { title: message.senderName, side: "top", align: "start" }, /* @__PURE__ */ React52.createElement(SenderName, { as: "span", variant: "sm", css: { color: isOverlay ? "#FFF" : "$on_surface_high" } }, message.senderName)), !isOverlay ? /* @__PURE__ */ React52.createElement(
|
4552
4501
|
Text,
|
4553
4502
|
{
|
4554
4503
|
as: "span",
|
@@ -4561,7 +4510,7 @@ var ChatMessage = React53.memo(({ index, style = {}, message, setRowHeight, onPi
|
|
4561
4510
|
},
|
4562
4511
|
formatTime(message.time)
|
4563
4512
|
) : null),
|
4564
|
-
/* @__PURE__ */
|
4513
|
+
/* @__PURE__ */ React52.createElement(
|
4565
4514
|
MessageType,
|
4566
4515
|
{
|
4567
4516
|
hasCurrentUserSent: message.sender === localPeerId,
|
@@ -4569,9 +4518,9 @@ var ChatMessage = React53.memo(({ index, style = {}, message, setRowHeight, onPi
|
|
4569
4518
|
roles: message.recipientRoles
|
4570
4519
|
}
|
4571
4520
|
),
|
4572
|
-
!isOverlay ? /* @__PURE__ */
|
4521
|
+
!isOverlay ? /* @__PURE__ */ React52.createElement(ChatActions, { onPin, showPinAction }) : null
|
4573
4522
|
),
|
4574
|
-
/* @__PURE__ */
|
4523
|
+
/* @__PURE__ */ React52.createElement(
|
4575
4524
|
Text,
|
4576
4525
|
{
|
4577
4526
|
variant: "sm",
|
@@ -4585,12 +4534,12 @@ var ChatMessage = React53.memo(({ index, style = {}, message, setRowHeight, onPi
|
|
4585
4534
|
},
|
4586
4535
|
onClick: (e) => e.stopPropagation()
|
4587
4536
|
},
|
4588
|
-
/* @__PURE__ */
|
4537
|
+
/* @__PURE__ */ React52.createElement(AnnotisedMessage, { message: message.message })
|
4589
4538
|
)
|
4590
4539
|
)
|
4591
4540
|
);
|
4592
4541
|
});
|
4593
|
-
var ChatList =
|
4542
|
+
var ChatList = React52.forwardRef(
|
4594
4543
|
({ width, height, setRowHeight, getRowHeight, messages, scrollToBottom }, listRef) => {
|
4595
4544
|
const { setPinnedMessage } = useSetPinnedMessage();
|
4596
4545
|
useLayoutEffect(() => {
|
@@ -4598,7 +4547,7 @@ var ChatList = React53.forwardRef(
|
|
4598
4547
|
scrollToBottom(1);
|
4599
4548
|
}
|
4600
4549
|
}, [listRef]);
|
4601
|
-
return /* @__PURE__ */
|
4550
|
+
return /* @__PURE__ */ React52.createElement(
|
4602
4551
|
VariableSizeList,
|
4603
4552
|
{
|
4604
4553
|
ref: listRef,
|
@@ -4610,7 +4559,7 @@ var ChatList = React53.forwardRef(
|
|
4610
4559
|
overflowX: "hidden"
|
4611
4560
|
}
|
4612
4561
|
},
|
4613
|
-
({ index, style }) => /* @__PURE__ */
|
4562
|
+
({ index, style }) => /* @__PURE__ */ React52.createElement(
|
4614
4563
|
ChatMessage,
|
4615
4564
|
{
|
4616
4565
|
style,
|
@@ -4624,7 +4573,7 @@ var ChatList = React53.forwardRef(
|
|
4624
4573
|
);
|
4625
4574
|
}
|
4626
4575
|
);
|
4627
|
-
var VirtualizedChatMessages =
|
4576
|
+
var VirtualizedChatMessages = React52.forwardRef(({ messages, scrollToBottom }, listRef) => {
|
4628
4577
|
const rowHeights = useRef10({});
|
4629
4578
|
function getRowHeight(index) {
|
4630
4579
|
return rowHeights.current[index] + 16 || 72;
|
@@ -4636,7 +4585,7 @@ var VirtualizedChatMessages = React53.forwardRef(({ messages, scrollToBottom },
|
|
4636
4585
|
},
|
4637
4586
|
[listRef]
|
4638
4587
|
);
|
4639
|
-
return /* @__PURE__ */
|
4588
|
+
return /* @__PURE__ */ React52.createElement(
|
4640
4589
|
Box,
|
4641
4590
|
{
|
4642
4591
|
css: {
|
@@ -4645,14 +4594,14 @@ var VirtualizedChatMessages = React53.forwardRef(({ messages, scrollToBottom },
|
|
4645
4594
|
},
|
4646
4595
|
as: "div"
|
4647
4596
|
},
|
4648
|
-
/* @__PURE__ */
|
4597
|
+
/* @__PURE__ */ React52.createElement(
|
4649
4598
|
AutoSizer,
|
4650
4599
|
{
|
4651
4600
|
style: {
|
4652
4601
|
width: "90%"
|
4653
4602
|
}
|
4654
4603
|
},
|
4655
|
-
({ height, width }) => /* @__PURE__ */
|
4604
|
+
({ height, width }) => /* @__PURE__ */ React52.createElement(
|
4656
4605
|
ChatList,
|
4657
4606
|
{
|
4658
4607
|
width,
|
@@ -4667,15 +4616,15 @@ var VirtualizedChatMessages = React53.forwardRef(({ messages, scrollToBottom },
|
|
4667
4616
|
)
|
4668
4617
|
);
|
4669
4618
|
});
|
4670
|
-
var ChatBody =
|
4619
|
+
var ChatBody = React52.forwardRef(({ role, peerId, scrollToBottom }, listRef) => {
|
4671
4620
|
var _a;
|
4672
4621
|
const storeMessageSelector = role ? selectMessagesByRole(role) : peerId ? selectMessagesByPeerID(peerId) : selectHMSMessages;
|
4673
|
-
let messages =
|
4622
|
+
let messages = useHMSStore26(storeMessageSelector);
|
4674
4623
|
messages = useMemo8(() => (messages == null ? void 0 : messages.filter((message) => message.type === "chat")) || [], [messages]);
|
4675
4624
|
const isMobile = useMedia11(config.media.md);
|
4676
4625
|
const { elements } = useRoomLayoutConferencingScreen();
|
4677
4626
|
if (messages.length === 0 && !(isMobile && ((_a = elements == null ? void 0 : elements.chat) == null ? void 0 : _a.is_overlay))) {
|
4678
|
-
return /* @__PURE__ */
|
4627
|
+
return /* @__PURE__ */ React52.createElement(
|
4679
4628
|
Flex,
|
4680
4629
|
{
|
4681
4630
|
css: {
|
@@ -4687,7 +4636,7 @@ var ChatBody = React53.forwardRef(({ role, peerId, scrollToBottom }, listRef) =>
|
|
4687
4636
|
align: "center",
|
4688
4637
|
justify: "center"
|
4689
4638
|
},
|
4690
|
-
/* @__PURE__ */
|
4639
|
+
/* @__PURE__ */ React52.createElement(Box, null, /* @__PURE__ */ React52.createElement("img", { src: empty_chat_default, alt: "Empty Chat", height: 132, width: 185, style: { margin: "0 auto" } }), /* @__PURE__ */ React52.createElement(Text, { variant: "h5", css: { mt: "$8", c: "$on_surface_high" } }, "Start a conversation"), /* @__PURE__ */ React52.createElement(
|
4691
4640
|
Text,
|
4692
4641
|
{
|
4693
4642
|
variant: "sm",
|
@@ -4697,11 +4646,11 @@ var ChatBody = React53.forwardRef(({ role, peerId, scrollToBottom }, listRef) =>
|
|
4697
4646
|
))
|
4698
4647
|
);
|
4699
4648
|
}
|
4700
|
-
return /* @__PURE__ */
|
4649
|
+
return /* @__PURE__ */ React52.createElement(Fragment8, null, /* @__PURE__ */ React52.createElement(VirtualizedChatMessages, { messages, scrollToBottom, ref: listRef }));
|
4701
4650
|
});
|
4702
4651
|
|
4703
4652
|
// src/Prebuilt/components/Chat/ChatFooter.tsx
|
4704
|
-
import
|
4653
|
+
import React53, { useCallback as useCallback13, useEffect as useEffect19, useRef as useRef12, useState as useState30 } from "react";
|
4705
4654
|
import { useMedia as useMedia12 } from "react-use";
|
4706
4655
|
import data2 from "@emoji-mart/data";
|
4707
4656
|
import Picker from "@emoji-mart/react";
|
@@ -4710,10 +4659,10 @@ import { EmojiIcon as EmojiIcon3, SendIcon } from "@100mslive/react-icons";
|
|
4710
4659
|
|
4711
4660
|
// src/Prebuilt/components/AppData/useChatState.js
|
4712
4661
|
import { useCallback as useCallback12 } from "react";
|
4713
|
-
import { selectAppData as selectAppData2, useHMSActions as useHMSActions16, useHMSStore as
|
4662
|
+
import { selectAppData as selectAppData2, useHMSActions as useHMSActions16, useHMSStore as useHMSStore27 } from "@100mslive/react-sdk";
|
4714
4663
|
var useChatDraftMessage = () => {
|
4715
4664
|
const hmsActions = useHMSActions16();
|
4716
|
-
let chatDraftMessage =
|
4665
|
+
let chatDraftMessage = useHMSStore27(selectAppData2(APP_DATA.chatDraft));
|
4717
4666
|
if (chatDraftMessage === void 0 || chatDraftMessage === null) {
|
4718
4667
|
chatDraftMessage = "";
|
4719
4668
|
}
|
@@ -4747,6 +4696,7 @@ var useEmojiPickerStyles = (showing) => {
|
|
4747
4696
|
font-family: var(--hms-ui-fonts-sans);
|
4748
4697
|
}
|
4749
4698
|
.sticky {
|
4699
|
+
top: 0.25rem;
|
4750
4700
|
background-color: var(--hms-ui-colors-surface_bright);
|
4751
4701
|
margin-top: 0.5rem;
|
4752
4702
|
}
|
@@ -4777,9 +4727,9 @@ var TextArea = styled("textarea", {
|
|
4777
4727
|
}
|
4778
4728
|
});
|
4779
4729
|
function EmojiPicker({ onSelect }) {
|
4780
|
-
const [showEmoji, setShowEmoji] =
|
4730
|
+
const [showEmoji, setShowEmoji] = useState30(false);
|
4781
4731
|
const ref = useEmojiPickerStyles(showEmoji);
|
4782
|
-
return /* @__PURE__ */
|
4732
|
+
return /* @__PURE__ */ React53.createElement(Popover.Root, { open: showEmoji, onOpenChange: setShowEmoji }, /* @__PURE__ */ React53.createElement(Popover.Trigger, { asChild: true, css: { appearance: "none" } }, /* @__PURE__ */ React53.createElement(IconButton, { as: "div" }, /* @__PURE__ */ React53.createElement(EmojiIcon3, null))), /* @__PURE__ */ React53.createElement(Popover.Portal, null, /* @__PURE__ */ React53.createElement(
|
4783
4733
|
Popover.Content,
|
4784
4734
|
{
|
4785
4735
|
alignOffset: -40,
|
@@ -4789,7 +4739,7 @@ function EmojiPicker({ onSelect }) {
|
|
4789
4739
|
p: 0
|
4790
4740
|
}
|
4791
4741
|
},
|
4792
|
-
/* @__PURE__ */
|
4742
|
+
/* @__PURE__ */ React53.createElement(
|
4793
4743
|
Box,
|
4794
4744
|
{
|
4795
4745
|
css: {
|
@@ -4798,7 +4748,7 @@ function EmojiPicker({ onSelect }) {
|
|
4798
4748
|
},
|
4799
4749
|
ref
|
4800
4750
|
},
|
4801
|
-
/* @__PURE__ */
|
4751
|
+
/* @__PURE__ */ React53.createElement(Picker, { onEmojiSelect: onSelect, data: data2, previewPosition: "none", skinPosition: "search" })
|
4802
4752
|
)
|
4803
4753
|
)));
|
4804
4754
|
}
|
@@ -4850,7 +4800,7 @@ var ChatFooter = ({
|
|
4850
4800
|
setDraftMessage((messageElement == null ? void 0 : messageElement.value) || "");
|
4851
4801
|
};
|
4852
4802
|
}, [setDraftMessage]);
|
4853
|
-
return /* @__PURE__ */
|
4803
|
+
return /* @__PURE__ */ React53.createElement(React53.Fragment, null, /* @__PURE__ */ React53.createElement(Flex, { align: "center", css: { gap: "$4", w: "100%" } }, /* @__PURE__ */ React53.createElement(
|
4854
4804
|
Flex,
|
4855
4805
|
{
|
4856
4806
|
align: "center",
|
@@ -4871,7 +4821,7 @@ var ChatFooter = ({
|
|
4871
4821
|
}
|
4872
4822
|
},
|
4873
4823
|
children,
|
4874
|
-
/* @__PURE__ */
|
4824
|
+
/* @__PURE__ */ React53.createElement(
|
4875
4825
|
TextArea,
|
4876
4826
|
{
|
4877
4827
|
css: {
|
@@ -4898,7 +4848,7 @@ var ChatFooter = ({
|
|
4898
4848
|
onCopy: (e) => e.stopPropagation()
|
4899
4849
|
}
|
4900
4850
|
),
|
4901
|
-
!isMobile ? /* @__PURE__ */
|
4851
|
+
!isMobile ? /* @__PURE__ */ React53.createElement(
|
4902
4852
|
EmojiPicker,
|
4903
4853
|
{
|
4904
4854
|
onSelect: (emoji) => {
|
@@ -4908,7 +4858,7 @@ var ChatFooter = ({
|
|
4908
4858
|
}
|
4909
4859
|
}
|
4910
4860
|
) : null,
|
4911
|
-
/* @__PURE__ */
|
4861
|
+
/* @__PURE__ */ React53.createElement(
|
4912
4862
|
IconButton,
|
4913
4863
|
{
|
4914
4864
|
className: "send-msg",
|
@@ -4921,7 +4871,7 @@ var ChatFooter = ({
|
|
4921
4871
|
},
|
4922
4872
|
"data-testid": "send_msg_btn"
|
4923
4873
|
},
|
4924
|
-
/* @__PURE__ */
|
4874
|
+
/* @__PURE__ */ React53.createElement(SendIcon, null)
|
4925
4875
|
)
|
4926
4876
|
)));
|
4927
4877
|
};
|
@@ -4931,21 +4881,21 @@ import {
|
|
4931
4881
|
selectMessagesUnreadCountByPeerID,
|
4932
4882
|
selectMessagesUnreadCountByRole,
|
4933
4883
|
selectUnreadHMSMessagesCount as selectUnreadHMSMessagesCount2,
|
4934
|
-
useHMSStore as
|
4884
|
+
useHMSStore as useHMSStore28
|
4935
4885
|
} from "@100mslive/react-sdk";
|
4936
4886
|
var useUnreadCount = ({ role, peerId }) => {
|
4937
4887
|
const unreadCountSelector = role ? selectMessagesUnreadCountByRole(role) : peerId ? selectMessagesUnreadCountByPeerID(peerId) : selectUnreadHMSMessagesCount2;
|
4938
|
-
const unreadCount =
|
4888
|
+
const unreadCount = useHMSStore28(unreadCountSelector);
|
4939
4889
|
return unreadCount;
|
4940
4890
|
};
|
4941
4891
|
|
4942
4892
|
// src/Prebuilt/components/Chat/Chat.jsx
|
4943
4893
|
var PINNED_MESSAGE_LENGTH = 80;
|
4944
4894
|
var PinnedMessage = ({ clearPinnedMessage }) => {
|
4945
|
-
const permissions =
|
4946
|
-
const pinnedMessage =
|
4895
|
+
const permissions = useHMSStore29(selectPermissions10);
|
4896
|
+
const pinnedMessage = useHMSStore29(selectSessionStore(SESSION_STORE_KEY.PINNED_MESSAGE));
|
4947
4897
|
const formattedPinnedMessage = (pinnedMessage == null ? void 0 : pinnedMessage.length) && pinnedMessage.length > PINNED_MESSAGE_LENGTH ? `${pinnedMessage.slice(0, PINNED_MESSAGE_LENGTH)}...` : pinnedMessage;
|
4948
|
-
return pinnedMessage ? /* @__PURE__ */
|
4898
|
+
return pinnedMessage ? /* @__PURE__ */ React54.createElement(
|
4949
4899
|
Flex,
|
4950
4900
|
{
|
4951
4901
|
title: pinnedMessage,
|
@@ -4953,8 +4903,8 @@ var PinnedMessage = ({ clearPinnedMessage }) => {
|
|
4953
4903
|
align: "center",
|
4954
4904
|
justify: "between"
|
4955
4905
|
},
|
4956
|
-
/* @__PURE__ */
|
4957
|
-
/* @__PURE__ */
|
4906
|
+
/* @__PURE__ */ React54.createElement(PinIcon2, null),
|
4907
|
+
/* @__PURE__ */ React54.createElement(
|
4958
4908
|
Box,
|
4959
4909
|
{
|
4960
4910
|
css: {
|
@@ -4964,30 +4914,30 @@ var PinnedMessage = ({ clearPinnedMessage }) => {
|
|
4964
4914
|
overflowY: "auto"
|
4965
4915
|
}
|
4966
4916
|
},
|
4967
|
-
/* @__PURE__ */
|
4917
|
+
/* @__PURE__ */ React54.createElement(Text, { variant: "sm" }, /* @__PURE__ */ React54.createElement(AnnotisedMessage, { message: formattedPinnedMessage }))
|
4968
4918
|
),
|
4969
|
-
permissions.removeOthers && /* @__PURE__ */
|
4919
|
+
permissions.removeOthers && /* @__PURE__ */ React54.createElement(
|
4970
4920
|
Flex,
|
4971
4921
|
{
|
4972
4922
|
onClick: () => clearPinnedMessage(),
|
4973
4923
|
css: { cursor: "pointer", color: "$on_surface_medium", "&:hover": { color: "$on_surface_high" } }
|
4974
4924
|
},
|
4975
|
-
/* @__PURE__ */
|
4925
|
+
/* @__PURE__ */ React54.createElement(CrossIcon6, null)
|
4976
4926
|
)
|
4977
4927
|
) : null;
|
4978
4928
|
};
|
4979
|
-
var Chat = ({ screenType
|
4980
|
-
var _a, _b
|
4929
|
+
var Chat = ({ screenType }) => {
|
4930
|
+
var _a, _b;
|
4981
4931
|
const notification = useHMSNotifications(HMSNotificationTypes.PEER_LEFT);
|
4982
4932
|
const [peerSelector, setPeerSelector] = useSetSubscribedChatSelector(CHAT_SELECTOR.PEER_ID);
|
4983
4933
|
const [roleSelector, setRoleSelector] = useSetSubscribedChatSelector(CHAT_SELECTOR.ROLE);
|
4984
|
-
const peerName =
|
4985
|
-
const [chatOptions, setChatOptions] =
|
4934
|
+
const peerName = useHMSStore29(selectPeerNameByID3(peerSelector));
|
4935
|
+
const [chatOptions, setChatOptions] = useState31({
|
4986
4936
|
role: roleSelector || "",
|
4987
4937
|
peerId: peerSelector && peerName ? peerSelector : "",
|
4988
4938
|
selection: roleSelector ? roleSelector : peerSelector && peerName ? peerName : "Everyone"
|
4989
4939
|
});
|
4990
|
-
const [isSelectorOpen
|
4940
|
+
const [isSelectorOpen] = useState31(false);
|
4991
4941
|
const listRef = useRef13(null);
|
4992
4942
|
const hmsActions = useHMSActions18();
|
4993
4943
|
const { setPinnedMessage } = useSetPinnedMessage();
|
@@ -5009,7 +4959,7 @@ var Chat = ({ screenType, hideControls = false }) => {
|
|
5009
4959
|
const currentRef = listRef.current._outerRef;
|
5010
4960
|
isScrolledToBottom = currentRef.scrollHeight - currentRef.clientHeight - currentRef.scrollTop < 10;
|
5011
4961
|
}
|
5012
|
-
const messagesCount =
|
4962
|
+
const messagesCount = useHMSStore29(storeMessageSelector) || 0;
|
5013
4963
|
const scrollToBottom = useCallback14(
|
5014
4964
|
(unreadCount = 0) => {
|
5015
4965
|
var _a2;
|
@@ -5024,19 +4974,17 @@ var Chat = ({ screenType, hideControls = false }) => {
|
|
5024
4974
|
},
|
5025
4975
|
[hmsActions, messagesCount]
|
5026
4976
|
);
|
5027
|
-
return /* @__PURE__ */
|
4977
|
+
return /* @__PURE__ */ React54.createElement(
|
5028
4978
|
Flex,
|
5029
4979
|
{
|
5030
4980
|
direction: "column",
|
5031
4981
|
css: {
|
5032
4982
|
size: "100%",
|
5033
|
-
gap: "$4"
|
5034
|
-
marginTop: hideControls && ((_a = elements == null ? void 0 : elements.chat) == null ? void 0 : _a.is_overlay) ? "$17" : "0",
|
5035
|
-
transition: "margin 0.3s ease-in-out"
|
4983
|
+
gap: "$4"
|
5036
4984
|
}
|
5037
4985
|
},
|
5038
|
-
isMobile && ((
|
5039
|
-
/* @__PURE__ */
|
4986
|
+
isMobile && ((_a = elements == null ? void 0 : elements.chat) == null ? void 0 : _a.is_overlay) ? null : /* @__PURE__ */ React54.createElement(React54.Fragment, null, ((_b = elements == null ? void 0 : elements.chat) == null ? void 0 : _b.allow_pinning_messages) ? /* @__PURE__ */ React54.createElement(PinnedMessage, { clearPinnedMessage: setPinnedMessage }) : null),
|
4987
|
+
/* @__PURE__ */ React54.createElement(
|
5040
4988
|
ChatBody,
|
5041
4989
|
{
|
5042
4990
|
role: chatOptions.role,
|
@@ -5046,7 +4994,7 @@ var Chat = ({ screenType, hideControls = false }) => {
|
|
5046
4994
|
screenType
|
5047
4995
|
}
|
5048
4996
|
),
|
5049
|
-
/* @__PURE__ */
|
4997
|
+
/* @__PURE__ */ React54.createElement(
|
5050
4998
|
ChatFooter,
|
5051
4999
|
{
|
5052
5000
|
role: chatOptions.role,
|
@@ -5064,7 +5012,7 @@ var Chat = ({ screenType, hideControls = false }) => {
|
|
5064
5012
|
},
|
5065
5013
|
peerId: chatOptions.peerId
|
5066
5014
|
},
|
5067
|
-
!isSelectorOpen && !isScrolledToBottom && /* @__PURE__ */
|
5015
|
+
!isSelectorOpen && !isScrolledToBottom && /* @__PURE__ */ React54.createElement(NewMessageIndicator, { role: chatOptions.role, peerId: chatOptions.peerId, scrollToBottom })
|
5068
5016
|
)
|
5069
5017
|
);
|
5070
5018
|
};
|
@@ -5073,7 +5021,7 @@ var NewMessageIndicator = ({ role, peerId, scrollToBottom }) => {
|
|
5073
5021
|
if (!unreadCount) {
|
5074
5022
|
return null;
|
5075
5023
|
}
|
5076
|
-
return /* @__PURE__ */
|
5024
|
+
return /* @__PURE__ */ React54.createElement(
|
5077
5025
|
Flex,
|
5078
5026
|
{
|
5079
5027
|
justify: "center",
|
@@ -5084,7 +5032,7 @@ var NewMessageIndicator = ({ role, peerId, scrollToBottom }) => {
|
|
5084
5032
|
position: "absolute"
|
5085
5033
|
}
|
5086
5034
|
},
|
5087
|
-
/* @__PURE__ */
|
5035
|
+
/* @__PURE__ */ React54.createElement(
|
5088
5036
|
Button,
|
5089
5037
|
{
|
5090
5038
|
variant: "standard",
|
@@ -5107,22 +5055,123 @@ var NewMessageIndicator = ({ role, peerId, scrollToBottom }) => {
|
|
5107
5055
|
},
|
5108
5056
|
"New ",
|
5109
5057
|
unreadCount === 1 ? "message" : "messages",
|
5110
|
-
/* @__PURE__ */
|
5058
|
+
/* @__PURE__ */ React54.createElement(ChevronDownIcon2, null)
|
5111
5059
|
)
|
5112
5060
|
);
|
5113
5061
|
};
|
5114
5062
|
|
5063
|
+
// src/Prebuilt/components/SidePaneTabs.tsx
|
5064
|
+
var tabTriggerCSS = {
|
5065
|
+
color: "$on_surface_high",
|
5066
|
+
p: "$4",
|
5067
|
+
fontWeight: "$semiBold",
|
5068
|
+
fontSize: "$sm",
|
5069
|
+
w: "100%",
|
5070
|
+
justifyContent: "center"
|
5071
|
+
};
|
5072
|
+
var SidePaneTabs = React55.memo(({ active = SIDE_PANE_OPTIONS.CHAT, screenType, hideControls }) => {
|
5073
|
+
var _a;
|
5074
|
+
const toggleChat = useSidepaneToggle(SIDE_PANE_OPTIONS.CHAT);
|
5075
|
+
const toggleParticipants = useSidepaneToggle(SIDE_PANE_OPTIONS.PARTICIPANTS);
|
5076
|
+
const resetSidePane = useSidepaneReset();
|
5077
|
+
const [activeTab, setActiveTab] = useState32(active);
|
5078
|
+
const peerCount = useHMSStore30(selectPeerCount3);
|
5079
|
+
const { elements } = useRoomLayoutConferencingScreen();
|
5080
|
+
const showChat = !!(elements == null ? void 0 : elements.chat);
|
5081
|
+
const showParticipants = !!(elements == null ? void 0 : elements.participant_list);
|
5082
|
+
const hideTabs = !(showChat && showParticipants);
|
5083
|
+
const isMobile = useMedia14(config.media.md);
|
5084
|
+
const isOverlayChat = !!((_a = elements == null ? void 0 : elements.chat) == null ? void 0 : _a.is_overlay) && isMobile;
|
5085
|
+
const isChatOpen = useIsSidepaneTypeOpen(SIDE_PANE_OPTIONS.CHAT);
|
5086
|
+
useEffect21(() => {
|
5087
|
+
if (activeTab === SIDE_PANE_OPTIONS.CHAT && !showChat && showParticipants) {
|
5088
|
+
setActiveTab(SIDE_PANE_OPTIONS.PARTICIPANTS);
|
5089
|
+
} else if (activeTab === SIDE_PANE_OPTIONS.PARTICIPANTS && showChat && !showParticipants) {
|
5090
|
+
setActiveTab(SIDE_PANE_OPTIONS.CHAT);
|
5091
|
+
} else if (!showChat && !showParticipants) {
|
5092
|
+
resetSidePane();
|
5093
|
+
}
|
5094
|
+
}, [showChat, activeTab, showParticipants, resetSidePane]);
|
5095
|
+
useEffect21(() => {
|
5096
|
+
setActiveTab(active);
|
5097
|
+
}, [active]);
|
5098
|
+
return /* @__PURE__ */ React55.createElement(
|
5099
|
+
Flex,
|
5100
|
+
{
|
5101
|
+
direction: "column",
|
5102
|
+
css: {
|
5103
|
+
color: "$on_primary_high",
|
5104
|
+
h: "100%",
|
5105
|
+
marginTop: hideControls && isOverlayChat ? "$17" : "0",
|
5106
|
+
transition: "margin 0.3s ease-in-out"
|
5107
|
+
}
|
5108
|
+
},
|
5109
|
+
isOverlayChat && isChatOpen && showChat ? /* @__PURE__ */ React55.createElement(Chat, { screenType }) : /* @__PURE__ */ React55.createElement(React55.Fragment, null, hideTabs ? /* @__PURE__ */ React55.createElement(React55.Fragment, null, /* @__PURE__ */ React55.createElement(Text, { variant: "sm", css: { fontWeight: "$semiBold", p: "$4", c: "$on_surface_high", pr: "$12" } }, showChat ? "Chat" : `Participants (${peerCount})`), showChat ? /* @__PURE__ */ React55.createElement(Chat, { screenType }) : /* @__PURE__ */ React55.createElement(ParticipantList, null)) : /* @__PURE__ */ React55.createElement(
|
5110
|
+
Tabs.Root,
|
5111
|
+
{
|
5112
|
+
value: activeTab,
|
5113
|
+
onValueChange: setActiveTab,
|
5114
|
+
css: {
|
5115
|
+
flexDirection: "column",
|
5116
|
+
size: "100%"
|
5117
|
+
}
|
5118
|
+
},
|
5119
|
+
/* @__PURE__ */ React55.createElement(Tabs.List, { css: { w: "calc(100% - $12)", p: "$2", borderRadius: "$2", bg: "$surface_default" } }, /* @__PURE__ */ React55.createElement(
|
5120
|
+
Tabs.Trigger,
|
5121
|
+
{
|
5122
|
+
value: SIDE_PANE_OPTIONS.CHAT,
|
5123
|
+
onClick: toggleChat,
|
5124
|
+
css: __spreadProps(__spreadValues({}, tabTriggerCSS), {
|
5125
|
+
color: activeTab !== SIDE_PANE_OPTIONS.CHAT ? "$on_surface_low" : "$on_surface_high"
|
5126
|
+
})
|
5127
|
+
},
|
5128
|
+
"Chat"
|
5129
|
+
), /* @__PURE__ */ React55.createElement(
|
5130
|
+
Tabs.Trigger,
|
5131
|
+
{
|
5132
|
+
value: SIDE_PANE_OPTIONS.PARTICIPANTS,
|
5133
|
+
onClick: toggleParticipants,
|
5134
|
+
css: __spreadProps(__spreadValues({}, tabTriggerCSS), {
|
5135
|
+
color: activeTab !== SIDE_PANE_OPTIONS.PARTICIPANTS ? "$on_surface_low" : "$on_surface_high"
|
5136
|
+
})
|
5137
|
+
},
|
5138
|
+
"Participants (",
|
5139
|
+
peerCount,
|
5140
|
+
")"
|
5141
|
+
)),
|
5142
|
+
/* @__PURE__ */ React55.createElement(Tabs.Content, { value: SIDE_PANE_OPTIONS.PARTICIPANTS, css: { p: 0 } }, /* @__PURE__ */ React55.createElement(ParticipantList, null)),
|
5143
|
+
/* @__PURE__ */ React55.createElement(Tabs.Content, { value: SIDE_PANE_OPTIONS.CHAT, css: { p: 0 } }, /* @__PURE__ */ React55.createElement(Chat, { screenType }))
|
5144
|
+
)),
|
5145
|
+
isOverlayChat && isChatOpen ? null : /* @__PURE__ */ React55.createElement(
|
5146
|
+
IconButton,
|
5147
|
+
{
|
5148
|
+
css: { position: "absolute", right: "$10", top: "$11", "@md": { top: "$8", right: "$8" } },
|
5149
|
+
onClick: (e) => {
|
5150
|
+
e.stopPropagation();
|
5151
|
+
if (activeTab === SIDE_PANE_OPTIONS.CHAT) {
|
5152
|
+
toggleChat();
|
5153
|
+
} else {
|
5154
|
+
toggleParticipants();
|
5155
|
+
}
|
5156
|
+
},
|
5157
|
+
"data-testid": "close_chat"
|
5158
|
+
},
|
5159
|
+
/* @__PURE__ */ React55.createElement(CrossIcon7, null)
|
5160
|
+
)
|
5161
|
+
);
|
5162
|
+
});
|
5163
|
+
|
5115
5164
|
// src/Prebuilt/components/Streaming/StreamingLanding.jsx
|
5116
5165
|
import React57, { Fragment as Fragment10, useState as useState34 } from "react";
|
5117
|
-
import { selectPermissions as selectPermissions11, useHMSStore as
|
5166
|
+
import { selectPermissions as selectPermissions11, useHMSStore as useHMSStore32, useRecordingStreaming as useRecordingStreaming7 } from "@100mslive/react-sdk";
|
5118
5167
|
import { ColoredHandIcon, CrossIcon as CrossIcon8, GoLiveIcon as GoLiveIcon3 } from "@100mslive/react-icons";
|
5119
5168
|
|
5120
5169
|
// src/Prebuilt/images/rtmp.png
|
5121
5170
|
var rtmp_default = "";
|
5122
5171
|
|
5123
5172
|
// src/Prebuilt/components/Streaming/HLSStreaming.jsx
|
5124
|
-
import React56, { Fragment as Fragment9, useCallback as useCallback15, useEffect as
|
5125
|
-
import { selectRoomID, useHMSActions as useHMSActions19, useHMSStore as
|
5173
|
+
import React56, { Fragment as Fragment9, useCallback as useCallback15, useEffect as useEffect22, useState as useState33 } from "react";
|
5174
|
+
import { selectRoomID, useHMSActions as useHMSActions19, useHMSStore as useHMSStore31, useRecordingStreaming as useRecordingStreaming6 } from "@100mslive/react-sdk";
|
5126
5175
|
import {
|
5127
5176
|
EndStreamIcon as EndStreamIcon2,
|
5128
5177
|
EyeOpenIcon,
|
@@ -5197,7 +5246,7 @@ var Card = ({ title, icon, link, content, isHLSRunning, order = 0 }) => {
|
|
5197
5246
|
};
|
5198
5247
|
var HLSStreaming = ({ onBack }) => {
|
5199
5248
|
const roleNames = useFilteredRoles();
|
5200
|
-
const roomId =
|
5249
|
+
const roomId = useHMSStore31(selectRoomID);
|
5201
5250
|
const cards = roleNames.map((roleName) => getCardData(roleName, roomId));
|
5202
5251
|
const { isHLSRunning } = useRecordingStreaming6();
|
5203
5252
|
const [showLinks, setShowLinks] = useState33(false);
|
@@ -5245,7 +5294,7 @@ var EndHLS = ({ setShowLinks }) => {
|
|
5245
5294
|
const [inProgress, setInProgress] = useState33(false);
|
5246
5295
|
const [error, setError] = useState33("");
|
5247
5296
|
const { isHLSRunning } = useRecordingStreaming6();
|
5248
|
-
|
5297
|
+
useEffect22(() => {
|
5249
5298
|
if (inProgress && !isHLSRunning) {
|
5250
5299
|
setInProgress(false);
|
5251
5300
|
}
|
@@ -5278,7 +5327,7 @@ var EndHLS = ({ setShowLinks }) => {
|
|
5278
5327
|
var StreamingLanding = () => {
|
5279
5328
|
const toggleStreaming = useSidepaneToggle(SIDE_PANE_OPTIONS.STREAMING);
|
5280
5329
|
const { isHLSRunning, isRTMPRunning } = useRecordingStreaming7();
|
5281
|
-
const permissions =
|
5330
|
+
const permissions = useHMSStore32(selectPermissions11);
|
5282
5331
|
const [showHLS, setShowHLS] = useState34(isHLSRunning);
|
5283
5332
|
const [showRTMP, setShowRTMP] = useState34(isRTMPRunning);
|
5284
5333
|
if (!(permissions == null ? void 0 : permissions.hlsStreaming) && !(permissions == null ? void 0 : permissions.rtmpStreaming)) {
|
@@ -5328,22 +5377,27 @@ var SidePane = ({
|
|
5328
5377
|
hideControls = false
|
5329
5378
|
}) => {
|
5330
5379
|
var _a, _b;
|
5331
|
-
const isMobile =
|
5332
|
-
const sidepane =
|
5333
|
-
const activeScreensharePeerId =
|
5334
|
-
const trackId = (_a =
|
5380
|
+
const isMobile = useMedia15(config.media.md);
|
5381
|
+
const sidepane = useHMSStore33(selectAppData3(APP_DATA.sidePane));
|
5382
|
+
const activeScreensharePeerId = useHMSStore33(selectAppData3(APP_DATA.activeScreensharePeerId));
|
5383
|
+
const trackId = (_a = useHMSStore33(selectVideoTrackByPeerID(activeScreensharePeerId))) == null ? void 0 : _a.id;
|
5335
5384
|
const { elements } = useRoomLayoutConferencingScreen();
|
5336
5385
|
let ViewComponent;
|
5337
|
-
if (sidepane === SIDE_PANE_OPTIONS.PARTICIPANTS) {
|
5338
|
-
ViewComponent = /* @__PURE__ */ React58.createElement(
|
5339
|
-
} else if (sidepane === SIDE_PANE_OPTIONS.CHAT) {
|
5340
|
-
ViewComponent = /* @__PURE__ */ React58.createElement(Chat, { screenType, hideControls });
|
5386
|
+
if (sidepane === SIDE_PANE_OPTIONS.PARTICIPANTS || sidepane === SIDE_PANE_OPTIONS.CHAT) {
|
5387
|
+
ViewComponent = /* @__PURE__ */ React58.createElement(SidePaneTabs, { screenType, hideControls, active: sidepane });
|
5341
5388
|
} else if (sidepane === SIDE_PANE_OPTIONS.STREAMING) {
|
5342
5389
|
ViewComponent = /* @__PURE__ */ React58.createElement(StreamingLanding, null);
|
5343
5390
|
}
|
5344
5391
|
if (!ViewComponent && !trackId) {
|
5345
5392
|
return null;
|
5346
5393
|
}
|
5394
|
+
const tileLayout = {
|
5395
|
+
hideParticipantNameOnTile: tileProps == null ? void 0 : tileProps.hide_participant_name_on_tile,
|
5396
|
+
roundedVideoTile: tileProps == null ? void 0 : tileProps.rounded_video_tile,
|
5397
|
+
hideAudioMuteOnTile: tileProps == null ? void 0 : tileProps.hide_audio_mute_on_tile,
|
5398
|
+
hideMetadataOnTile: tileProps == null ? void 0 : tileProps.hide_metadata_on_tile,
|
5399
|
+
objectFit: tileProps == null ? void 0 : tileProps.video_object_fit
|
5400
|
+
};
|
5347
5401
|
const mwebStreamingChat = isMobile && sidepane === SIDE_PANE_OPTIONS.CHAT && ((_b = elements == null ? void 0 : elements.chat) == null ? void 0 : _b.is_overlay);
|
5348
5402
|
return /* @__PURE__ */ React58.createElement(
|
5349
5403
|
Flex,
|
@@ -5365,9 +5419,8 @@ var SidePane = ({
|
|
5365
5419
|
trackId,
|
5366
5420
|
width: "100%",
|
5367
5421
|
height: 225,
|
5368
|
-
rootCSS: { p: 0, alignSelf: "start", flexShrink: 0 }
|
5369
|
-
|
5370
|
-
}, tileProps)
|
5422
|
+
rootCSS: { p: 0, alignSelf: "start", flexShrink: 0 }
|
5423
|
+
}, tileLayout)
|
5371
5424
|
),
|
5372
5425
|
!!ViewComponent && /* @__PURE__ */ React58.createElement(
|
5373
5426
|
Box,
|
@@ -5455,20 +5508,20 @@ var WaitingView = React59.memo(() => {
|
|
5455
5508
|
});
|
5456
5509
|
|
5457
5510
|
// src/Prebuilt/layouts/VideoStreamingSection.tsx
|
5458
|
-
var HLSView = React60.lazy(() => import("./HLSView-
|
5511
|
+
var HLSView = React60.lazy(() => import("./HLSView-HL455FYH.js"));
|
5459
5512
|
var VideoStreamingSection = ({
|
5460
5513
|
screenType,
|
5461
5514
|
elements,
|
5462
5515
|
hideControls = false
|
5463
5516
|
}) => {
|
5464
5517
|
var _a, _b;
|
5465
|
-
const localPeerRole =
|
5466
|
-
const isConnected =
|
5518
|
+
const localPeerRole = useHMSStore34(selectLocalPeerRoleName2);
|
5519
|
+
const isConnected = useHMSStore34(selectIsConnectedToRoom6);
|
5467
5520
|
const hmsActions = useHMSActions20();
|
5468
5521
|
const waitingViewerRole = useWaitingViewerRole();
|
5469
5522
|
const urlToIframe = useUrlToEmbed();
|
5470
5523
|
const pdfAnnotatorActive = usePDFAnnotator();
|
5471
|
-
|
5524
|
+
useEffect23(() => {
|
5472
5525
|
if (!isConnected) {
|
5473
5526
|
return;
|
5474
5527
|
}
|
@@ -5511,28 +5564,30 @@ var VideoStreamingSection = ({
|
|
5511
5564
|
};
|
5512
5565
|
|
5513
5566
|
// src/Prebuilt/components/RoleChangeRequestModal.tsx
|
5514
|
-
import React61, { useEffect as
|
5567
|
+
import React61, { useEffect as useEffect24 } from "react";
|
5515
5568
|
import {
|
5516
5569
|
selectLocalPeerName,
|
5517
5570
|
selectLocalPeerRoleName as selectLocalPeerRoleName3,
|
5518
5571
|
selectRoleChangeRequest,
|
5519
5572
|
useCustomEvent as useCustomEvent2,
|
5520
5573
|
useHMSActions as useHMSActions21,
|
5521
|
-
useHMSStore as
|
5574
|
+
useHMSStore as useHMSStore35
|
5522
5575
|
} from "@100mslive/react-sdk";
|
5523
5576
|
var RoleChangeRequestModal = () => {
|
5524
5577
|
const hmsActions = useHMSActions21();
|
5525
5578
|
const { updateMetaData } = useMyMetadata();
|
5526
|
-
const currentRole =
|
5527
|
-
const roleChangeRequest =
|
5528
|
-
const name =
|
5579
|
+
const currentRole = useHMSStore35(selectLocalPeerRoleName3);
|
5580
|
+
const roleChangeRequest = useHMSStore35(selectRoleChangeRequest);
|
5581
|
+
const name = useHMSStore35(selectLocalPeerName);
|
5529
5582
|
const { sendEvent } = useCustomEvent2({ type: ROLE_CHANGE_DECLINED });
|
5530
|
-
|
5583
|
+
useEffect24(() => {
|
5531
5584
|
if (!(roleChangeRequest == null ? void 0 : roleChangeRequest.role)) {
|
5532
5585
|
return;
|
5533
5586
|
}
|
5534
|
-
|
5535
|
-
|
5587
|
+
(() => __async(void 0, null, function* () {
|
5588
|
+
yield hmsActions.preview({ asRole: roleChangeRequest.role.name });
|
5589
|
+
}))();
|
5590
|
+
}, [hmsActions, roleChangeRequest, currentRole, updateMetaData]);
|
5536
5591
|
if (!(roleChangeRequest == null ? void 0 : roleChangeRequest.role)) {
|
5537
5592
|
return null;
|
5538
5593
|
}
|
@@ -5589,12 +5644,12 @@ var Conference = () => {
|
|
5589
5644
|
const { userName, endpoints } = useHMSPrebuiltContext();
|
5590
5645
|
const screenProps = useRoomLayoutConferencingScreen();
|
5591
5646
|
const { isPreviewScreenEnabled } = useRoomLayoutPreviewScreen();
|
5592
|
-
const roomState =
|
5647
|
+
const roomState = useHMSStore36(selectRoomState);
|
5593
5648
|
const prevState = usePrevious(roomState);
|
5594
|
-
const isConnectedToRoom =
|
5649
|
+
const isConnectedToRoom = useHMSStore36(selectIsConnectedToRoom7);
|
5595
5650
|
const hmsActions = useHMSActions22();
|
5596
5651
|
const [hideControls, setHideControls] = useState35(false);
|
5597
|
-
const dropdownList =
|
5652
|
+
const dropdownList = useHMSStore36(selectAppData4(APP_DATA.dropdownList));
|
5598
5653
|
const authTokenInAppData = useAuthToken();
|
5599
5654
|
const headerRef = useRef14();
|
5600
5655
|
const footerRef = useRef14();
|
@@ -5607,7 +5662,8 @@ var Conference = () => {
|
|
5607
5662
|
setHideControls((value) => !value);
|
5608
5663
|
}
|
5609
5664
|
};
|
5610
|
-
|
5665
|
+
const autoRoomJoined = useRef14(isPreviewScreenEnabled);
|
5666
|
+
useEffect25(() => {
|
5611
5667
|
let timeout = null;
|
5612
5668
|
dropdownListRef.current = dropdownList || [];
|
5613
5669
|
if (dropdownListRef.current.length === 0) {
|
@@ -5622,7 +5678,7 @@ var Conference = () => {
|
|
5622
5678
|
clearTimeout(timeout);
|
5623
5679
|
};
|
5624
5680
|
}, [dropdownList, hideControls, isMobileDevice]);
|
5625
|
-
|
5681
|
+
useEffect25(() => {
|
5626
5682
|
if (!roomId) {
|
5627
5683
|
navigate(`/`);
|
5628
5684
|
return;
|
@@ -5637,8 +5693,8 @@ var Conference = () => {
|
|
5637
5693
|
navigate(`/preview/${roomId || ""}`);
|
5638
5694
|
}
|
5639
5695
|
}, [isConnectedToRoom, prevState, roomState, navigate, role, roomId, isPreviewScreenEnabled]);
|
5640
|
-
|
5641
|
-
if (authTokenInAppData && !isConnectedToRoom && !isPreviewScreenEnabled && roomState !== HMSRoomState.Connecting) {
|
5696
|
+
useEffect25(() => {
|
5697
|
+
if (authTokenInAppData && !isConnectedToRoom && !isPreviewScreenEnabled && roomState !== HMSRoomState.Connecting && !autoRoomJoined.current) {
|
5642
5698
|
hmsActions.join({
|
5643
5699
|
userName,
|
5644
5700
|
authToken: authTokenInAppData,
|
@@ -5649,9 +5705,10 @@ var Conference = () => {
|
|
5649
5705
|
speakerAutoSelectionBlacklist: ["Yeti Stereo Microphone"]
|
5650
5706
|
}
|
5651
5707
|
}).catch(console.error);
|
5708
|
+
autoRoomJoined.current = true;
|
5652
5709
|
}
|
5653
5710
|
}, [authTokenInAppData, endpoints == null ? void 0 : endpoints.init, hmsActions, isConnectedToRoom, isPreviewScreenEnabled, roomState, userName]);
|
5654
|
-
|
5711
|
+
useEffect25(() => {
|
5655
5712
|
return () => {
|
5656
5713
|
PictureInPicture.stop().catch((error) => console.error("stopping pip", error));
|
5657
5714
|
};
|
@@ -5724,4 +5781,4 @@ var conference_default = Conference;
|
|
5724
5781
|
export {
|
5725
5782
|
conference_default as default
|
5726
5783
|
};
|
5727
|
-
//# sourceMappingURL=conference-
|
5784
|
+
//# sourceMappingURL=conference-MPZNWHV5.js.map
|