@100mslive/roomkit-react 0.1.7-alpha.0 → 0.1.7
Sign up to get free protection for your applications and to get access to all the features.
- package/dist/{HLSView-F5BDZVT2.js → HLSView-3S74KF3A.js} +6 -5
- package/dist/{HLSView-F5BDZVT2.js.map → HLSView-3S74KF3A.js.map} +2 -2
- package/dist/Prebuilt/components/RoleChangeRequest/RequestPrompt.d.ts +9 -0
- package/dist/VideoTile/StyledVideoTile.d.ts +445 -3
- package/dist/{VirtualBackground-THDRYDRA.js → VirtualBackground-3TI5NA4V.js} +3 -3
- package/dist/{chunk-JSH7SKEH.js → chunk-36X4ZCLC.js} +2 -2
- package/dist/{chunk-U3G743OY.js → chunk-5DQ3WTED.js} +2 -2
- package/dist/{chunk-U3G743OY.js.map → chunk-5DQ3WTED.js.map} +1 -1
- package/dist/{chunk-CDYRVICT.js → chunk-Z7P5WITU.js} +40 -32
- package/dist/chunk-Z7P5WITU.js.map +7 -0
- package/dist/{conference-6IVZHILI.js → conference-JNABIZBG.js} +506 -490
- package/dist/conference-JNABIZBG.js.map +7 -0
- package/dist/index.cjs.js +826 -790
- package/dist/index.cjs.js.map +4 -4
- package/dist/index.js +2 -2
- package/dist/meta.cjs.json +185 -126
- package/dist/meta.esbuild.json +221 -162
- package/package.json +6 -6
- package/src/Input/Input.tsx +1 -1
- package/src/Prebuilt/common/utils.js +7 -0
- package/src/Prebuilt/components/Chat/ChatBody.jsx +125 -106
- package/src/Prebuilt/components/Footer/ParticipantList.jsx +1 -1
- package/src/Prebuilt/components/Leave/DesktopLeaveRoom.tsx +36 -44
- package/src/Prebuilt/components/Leave/MwebLeaveRoom.tsx +23 -35
- package/src/Prebuilt/components/Preview/PreviewJoin.tsx +5 -3
- package/src/Prebuilt/components/RaiseHand.jsx +4 -11
- package/src/Prebuilt/components/RoleChangeRequest/RequestPrompt.tsx +66 -0
- package/src/Prebuilt/components/{RoleChangeRequestModal.tsx → RoleChangeRequest/RoleChangeRequestModal.tsx} +18 -50
- package/src/Prebuilt/components/VideoTile.jsx +18 -12
- package/src/Prebuilt/components/conference.jsx +1 -1
- package/src/Prebuilt/components/hooks/useMetadata.jsx +2 -1
- package/src/Prebuilt/layouts/HLSView.jsx +3 -2
- package/src/Prebuilt/layouts/SidePane.tsx +0 -1
- package/src/VideoTile/StyledVideoTile.tsx +10 -14
- package/dist/chunk-CDYRVICT.js.map +0 -7
- package/dist/conference-6IVZHILI.js.map +0 -7
- /package/dist/Prebuilt/components/{RoleChangeRequestModal.d.ts → RoleChangeRequest/RoleChangeRequestModal.d.ts} +0 -0
- /package/dist/{VirtualBackground-THDRYDRA.js.map → VirtualBackground-3TI5NA4V.js.map} +0 -0
- /package/dist/{chunk-JSH7SKEH.js.map → chunk-36X4ZCLC.js.map} +0 -0
@@ -1,6 +1,6 @@
|
|
1
1
|
import {
|
2
2
|
ActionTile
|
3
|
-
} from "./chunk-
|
3
|
+
} from "./chunk-36X4ZCLC.js";
|
4
4
|
import {
|
5
5
|
APP_DATA,
|
6
6
|
Accordion,
|
@@ -83,7 +83,7 @@ import {
|
|
83
83
|
useUrlToEmbed,
|
84
84
|
useUserPreferences,
|
85
85
|
useWaitingViewerRole
|
86
|
-
} from "./chunk-
|
86
|
+
} from "./chunk-Z7P5WITU.js";
|
87
87
|
import {
|
88
88
|
Box,
|
89
89
|
Flex,
|
@@ -102,10 +102,10 @@ import {
|
|
102
102
|
slideLeftAndFade,
|
103
103
|
styled,
|
104
104
|
textEllipsis
|
105
|
-
} from "./chunk-
|
105
|
+
} from "./chunk-5DQ3WTED.js";
|
106
106
|
|
107
107
|
// src/Prebuilt/components/conference.jsx
|
108
|
-
import
|
108
|
+
import React63, { useEffect as useEffect25, useRef as useRef14, useState as useState35 } from "react";
|
109
109
|
import { useNavigate, useParams } from "react-router-dom";
|
110
110
|
import { usePrevious } from "react-use";
|
111
111
|
import {
|
@@ -113,8 +113,8 @@ import {
|
|
113
113
|
selectAppData as selectAppData4,
|
114
114
|
selectIsConnectedToRoom as selectIsConnectedToRoom7,
|
115
115
|
selectRoomState,
|
116
|
-
useHMSActions as
|
117
|
-
useHMSStore as
|
116
|
+
useHMSActions as useHMSActions22,
|
117
|
+
useHMSStore as useHMSStore35
|
118
118
|
} from "@100mslive/react-sdk";
|
119
119
|
|
120
120
|
// src/Prebuilt/components/Footer/Footer.tsx
|
@@ -345,11 +345,12 @@ var DesktopLeaveRoom = ({
|
|
345
345
|
const permissions = useHMSStore2(selectPermissions);
|
346
346
|
const { isStreamingOn } = useRecordingStreaming();
|
347
347
|
const showStream = screenType !== "hls_live_streaming" && isStreamingOn;
|
348
|
+
const showLeaveOptions = (permissions == null ? void 0 : permissions.hlsStreaming) && isStreamingOn || (permissions == null ? void 0 : permissions.endRoom);
|
348
349
|
useDropdownList({ open: open || showEndStreamAlert || showLeaveRoomAlert, name: "LeaveRoom" });
|
349
350
|
if (!permissions || !isConnected) {
|
350
351
|
return null;
|
351
352
|
}
|
352
|
-
return /* @__PURE__ */ React6.createElement(Fragment2, null,
|
353
|
+
return /* @__PURE__ */ React6.createElement(Fragment2, null, showLeaveOptions ? /* @__PURE__ */ React6.createElement(Flex, null, /* @__PURE__ */ React6.createElement(
|
353
354
|
LeaveIconButton,
|
354
355
|
{
|
355
356
|
key: "LeaveRoom",
|
@@ -358,9 +359,7 @@ var DesktopLeaveRoom = ({
|
|
358
359
|
borderTopRightRadius: 0,
|
359
360
|
borderBottomRightRadius: 0
|
360
361
|
},
|
361
|
-
onClick: () =>
|
362
|
-
leaveRoom({ endstream: false });
|
363
|
-
}
|
362
|
+
onClick: () => setShowLeaveRoomAlert(true)
|
364
363
|
},
|
365
364
|
/* @__PURE__ */ React6.createElement(Tooltip, { title: "Leave Room" }, /* @__PURE__ */ React6.createElement(Box, null, /* @__PURE__ */ React6.createElement(ExitIcon, { style: { transform: "rotate(180deg)" } })))
|
366
365
|
), /* @__PURE__ */ React6.createElement(Dropdown.Root, { open, onOpenChange: setOpen, modal: false }, /* @__PURE__ */ React6.createElement(
|
@@ -379,7 +378,7 @@ var DesktopLeaveRoom = ({
|
|
379
378
|
{
|
380
379
|
css: {
|
381
380
|
bg: "$surface_dim",
|
382
|
-
color: "$
|
381
|
+
color: "$on_surface_medium",
|
383
382
|
"&:hover": { bg: "$surface_default", color: "$on_surface_high" }
|
384
383
|
},
|
385
384
|
onClick: () => leaveRoom({ endstream: false }),
|
@@ -397,7 +396,7 @@ var DesktopLeaveRoom = ({
|
|
397
396
|
css: { p: 0 }
|
398
397
|
}
|
399
398
|
)
|
400
|
-
),
|
399
|
+
), /* @__PURE__ */ React6.createElement(
|
401
400
|
Dropdown.Item,
|
402
401
|
{
|
403
402
|
css: {
|
@@ -422,15 +421,11 @@ var DesktopLeaveRoom = ({
|
|
422
421
|
css: { p: 0 }
|
423
422
|
}
|
424
423
|
)
|
425
|
-
)
|
424
|
+
)))) : /* @__PURE__ */ React6.createElement(
|
426
425
|
LeaveIconButton,
|
427
426
|
{
|
428
427
|
onClick: () => {
|
429
|
-
|
430
|
-
setShowLeaveRoomAlert(true);
|
431
|
-
} else {
|
432
|
-
leaveRoom({ endstream: false });
|
433
|
-
}
|
428
|
+
setShowLeaveRoomAlert(true);
|
434
429
|
},
|
435
430
|
key: "LeaveRoom",
|
436
431
|
"data-testid": "leave_room_btn"
|
@@ -444,7 +439,7 @@ var DesktopLeaveRoom = ({
|
|
444
439
|
isStreamingOn,
|
445
440
|
isModal: true
|
446
441
|
}
|
447
|
-
)))),
|
442
|
+
)))), /* @__PURE__ */ React6.createElement(Dialog.Root, { open: showLeaveRoomAlert, modal: false }, /* @__PURE__ */ React6.createElement(Dialog.Portal, null, /* @__PURE__ */ React6.createElement(Dialog.Overlay, null), /* @__PURE__ */ React6.createElement(Dialog.Content, { css: { w: "min(420px, 90%)", p: "$8", bg: "$surface_dim" } }, /* @__PURE__ */ React6.createElement(LeaveSessionContent, { setShowLeaveRoomAlert, leaveRoom, isModal: true })))));
|
448
443
|
};
|
449
444
|
|
450
445
|
// src/Prebuilt/components/Leave/MwebLeaveRoom.tsx
|
@@ -463,11 +458,12 @@ var MwebLeaveRoom = ({
|
|
463
458
|
const permissions = useHMSStore3(selectPermissions2);
|
464
459
|
const { isStreamingOn } = useRecordingStreaming2();
|
465
460
|
const showStream = screenType !== "hls_live_streaming" && isStreamingOn;
|
461
|
+
const showLeaveOptions = (permissions == null ? void 0 : permissions.hlsStreaming) && isStreamingOn || (permissions == null ? void 0 : permissions.endRoom);
|
466
462
|
useDropdownList({ open, name: "LeaveRoom" });
|
467
463
|
if (!permissions || !isConnected) {
|
468
464
|
return null;
|
469
465
|
}
|
470
|
-
return /* @__PURE__ */ React7.createElement(Fragment3, null,
|
466
|
+
return /* @__PURE__ */ React7.createElement(Fragment3, null, showLeaveOptions ? /* @__PURE__ */ React7.createElement(Sheet.Root, { open, onOpenChange: setOpen }, /* @__PURE__ */ React7.createElement(Sheet.Trigger, { asChild: true }, /* @__PURE__ */ React7.createElement(
|
471
467
|
LeaveIconButton,
|
472
468
|
{
|
473
469
|
key: "LeaveRoom",
|
@@ -489,7 +485,7 @@ var MwebLeaveRoom = ({
|
|
489
485
|
onClick: () => leaveRoom({ endstream: false }),
|
490
486
|
css: { pt: 0, mt: "$10", color: "$on_surface_low", "&:hover": { color: "$on_surface_high" } }
|
491
487
|
}
|
492
|
-
),
|
488
|
+
), /* @__PURE__ */ React7.createElement(
|
493
489
|
LeaveCard,
|
494
490
|
{
|
495
491
|
title: showStream ? "End Stream" : "End Session",
|
@@ -503,28 +499,14 @@ var MwebLeaveRoom = ({
|
|
503
499
|
setShowEndStreamAlert(true);
|
504
500
|
}
|
505
501
|
}
|
506
|
-
) : null)) : /* @__PURE__ */ React7.createElement(
|
507
|
-
LeaveIconButton,
|
508
|
-
{
|
509
|
-
key: "LeaveRoom",
|
510
|
-
"data-testid": "leave_room_btn",
|
511
|
-
onClick: () => {
|
512
|
-
if (screenType === "hls_live_streaming") {
|
513
|
-
setShowLeaveRoomAlert(true);
|
514
|
-
} else {
|
515
|
-
leaveRoom({ endstream: false });
|
516
|
-
}
|
517
|
-
}
|
518
|
-
},
|
519
|
-
/* @__PURE__ */ React7.createElement(Tooltip, { title: "Leave Room" }, /* @__PURE__ */ React7.createElement(Box, null, /* @__PURE__ */ React7.createElement(ExitIcon2, { style: { transform: "rotate(180deg)" } })))
|
520
|
-
), /* @__PURE__ */ React7.createElement(Sheet.Root, { open: showEndStreamAlert, onOpenChange: setShowEndStreamAlert }, /* @__PURE__ */ React7.createElement(Sheet.Content, { css: { bg: "$surface_dim", p: "$10", pb: "$12" } }, /* @__PURE__ */ React7.createElement(
|
502
|
+
))) : /* @__PURE__ */ React7.createElement(LeaveIconButton, { key: "LeaveRoom", "data-testid": "leave_room_btn", onClick: () => setShowLeaveRoomAlert(true) }, /* @__PURE__ */ React7.createElement(Tooltip, { title: "Leave Room" }, /* @__PURE__ */ React7.createElement(Box, null, /* @__PURE__ */ React7.createElement(ExitIcon2, { style: { transform: "rotate(180deg)" } })))), /* @__PURE__ */ React7.createElement(Sheet.Root, { open: showEndStreamAlert, onOpenChange: setShowEndStreamAlert }, /* @__PURE__ */ React7.createElement(Sheet.Content, { css: { bg: "$surface_dim", p: "$10", pb: "$12" } }, /* @__PURE__ */ React7.createElement(
|
521
503
|
EndSessionContent,
|
522
504
|
{
|
523
505
|
setShowEndStreamAlert,
|
524
506
|
leaveRoom: isStreamingOn ? leaveRoom : endRoom,
|
525
507
|
isStreamingOn
|
526
508
|
}
|
527
|
-
))),
|
509
|
+
))), /* @__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 }))));
|
528
510
|
};
|
529
511
|
|
530
512
|
// src/Prebuilt/components/Leave/LeaveRoom.tsx
|
@@ -2130,27 +2112,17 @@ var MoreSettings = ({
|
|
2130
2112
|
|
2131
2113
|
// src/Prebuilt/components/RaiseHand.jsx
|
2132
2114
|
import React24 from "react";
|
2133
|
-
import { selectHasPeerHandRaised, selectLocalPeerID as selectLocalPeerID4, useHMSActions as useHMSActions10, useHMSStore as useHMSStore12 } from "@100mslive/react-sdk";
|
2134
2115
|
import { HandIcon as HandIcon2 } from "@100mslive/react-icons";
|
2135
2116
|
var RaiseHand = () => {
|
2136
|
-
const
|
2137
|
-
|
2138
|
-
|
2139
|
-
|
2140
|
-
IconButton_default,
|
2141
|
-
{
|
2142
|
-
active: !isHandRaised,
|
2143
|
-
onClick: () => {
|
2144
|
-
isHandRaised ? actions.lowerLocalPeerHand() : actions.raiseLocalPeerHand();
|
2145
|
-
}
|
2146
|
-
},
|
2147
|
-
/* @__PURE__ */ React24.createElement(HandIcon2, null)
|
2148
|
-
));
|
2117
|
+
const { isHandRaised, toggleHandRaise } = useMyMetadata();
|
2118
|
+
return /* @__PURE__ */ React24.createElement(Tooltip, { title: isHandRaised ? "Lower hand" : "Raise hand" }, /* @__PURE__ */ React24.createElement(IconButton_default, { active: !isHandRaised, onClick: () => __async(void 0, null, function* () {
|
2119
|
+
return yield toggleHandRaise();
|
2120
|
+
}) }, /* @__PURE__ */ React24.createElement(HandIcon2, null)));
|
2149
2121
|
};
|
2150
2122
|
|
2151
2123
|
// src/Prebuilt/components/ScreenShareToggle.jsx
|
2152
2124
|
import React31, { Fragment as Fragment6 } from "react";
|
2153
|
-
import { selectIsAllowedToPublish, useHMSStore as
|
2125
|
+
import { selectIsAllowedToPublish, useHMSStore as useHMSStore12, useScreenShare as useScreenShare2 } from "@100mslive/react-sdk";
|
2154
2126
|
import { ShareScreenIcon } from "@100mslive/react-icons";
|
2155
2127
|
|
2156
2128
|
// src/Prebuilt/components/pdfAnnotator/shareScreenOptions.jsx
|
@@ -2632,7 +2604,7 @@ function ShareScreenOptions() {
|
|
2632
2604
|
|
2633
2605
|
// src/Prebuilt/components/ScreenShareToggle.jsx
|
2634
2606
|
var ScreenshareToggle = ({ css = {} }) => {
|
2635
|
-
const isAllowedToPublish =
|
2607
|
+
const isAllowedToPublish = useHMSStore12(selectIsAllowedToPublish);
|
2636
2608
|
const isAudioOnly = useUISettings(UI_SETTINGS.isAudioOnly);
|
2637
2609
|
const { amIScreenSharing, screenShareVideoTrackId: video, toggleScreenShare } = useScreenShare2();
|
2638
2610
|
const isVideoScreenshare = amIScreenSharing && !!video;
|
@@ -2657,10 +2629,10 @@ var ScreenshareToggle = ({ css = {} }) => {
|
|
2657
2629
|
|
2658
2630
|
// src/Prebuilt/components/Footer/ChatToggle.tsx
|
2659
2631
|
import React32 from "react";
|
2660
|
-
import { selectUnreadHMSMessagesCount, useHMSStore as
|
2632
|
+
import { selectUnreadHMSMessagesCount, useHMSStore as useHMSStore13 } from "@100mslive/react-sdk";
|
2661
2633
|
import { ChatIcon, ChatUnreadIcon } from "@100mslive/react-icons";
|
2662
2634
|
var ChatToggle = () => {
|
2663
|
-
const countUnreadMessages =
|
2635
|
+
const countUnreadMessages = useHMSStore13(selectUnreadHMSMessagesCount);
|
2664
2636
|
const isChatOpen = useIsSidepaneTypeOpen(SIDE_PANE_OPTIONS.CHAT);
|
2665
2637
|
const toggleChat = useSidepaneToggle(SIDE_PANE_OPTIONS.CHAT);
|
2666
2638
|
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" })));
|
@@ -2671,14 +2643,14 @@ import React35, { Fragment as Fragment7, useCallback as useCallback6, useEffect
|
|
2671
2643
|
import { useDebounce, useMedia as useMedia4 } from "react-use";
|
2672
2644
|
import {
|
2673
2645
|
selectHandRaisedPeers,
|
2674
|
-
selectHasPeerHandRaised
|
2646
|
+
selectHasPeerHandRaised,
|
2675
2647
|
selectIsPeerAudioEnabled,
|
2676
|
-
selectLocalPeerID as
|
2648
|
+
selectLocalPeerID as selectLocalPeerID4,
|
2677
2649
|
selectPeerCount as selectPeerCount2,
|
2678
2650
|
selectPeerMetadata,
|
2679
2651
|
selectPermissions as selectPermissions8,
|
2680
|
-
useHMSActions as
|
2681
|
-
useHMSStore as
|
2652
|
+
useHMSActions as useHMSActions11,
|
2653
|
+
useHMSStore as useHMSStore15
|
2682
2654
|
} from "@100mslive/react-sdk";
|
2683
2655
|
import {
|
2684
2656
|
ChangeRoleIcon as ChangeRoleIcon2,
|
@@ -2697,7 +2669,7 @@ import { FixedSizeList } from "react-window";
|
|
2697
2669
|
|
2698
2670
|
// src/Prebuilt/components/Footer/RoleOptions.tsx
|
2699
2671
|
import React33, { useState as useState17 } from "react";
|
2700
|
-
import { selectPermissions as selectPermissions7, useHMSActions as
|
2672
|
+
import { selectPermissions as selectPermissions7, useHMSActions as useHMSActions10, useHMSStore as useHMSStore14, useHMSVanillaStore as useHMSVanillaStore2 } from "@100mslive/react-sdk";
|
2701
2673
|
import {
|
2702
2674
|
MicOffIcon as MicOffIcon2,
|
2703
2675
|
MicOnIcon,
|
@@ -2711,8 +2683,8 @@ var dropdownItemCSS = { backgroundColor: "$surface_default", gap: "$4", p: "$8"
|
|
2711
2683
|
var optionTextCSS = { fontWeight: "$semiBold", color: "$on_surface_high", textTransform: "none" };
|
2712
2684
|
var RoleOptions = ({ roleName, peerList }) => {
|
2713
2685
|
const [openOptions, setOpenOptions] = useState17(false);
|
2714
|
-
const permissions =
|
2715
|
-
const hmsActions =
|
2686
|
+
const permissions = useHMSStore14(selectPermissions7);
|
2687
|
+
const hmsActions = useHMSActions10();
|
2716
2688
|
const { elements } = useRoomLayoutConferencingScreen();
|
2717
2689
|
const { on_stage_role, off_stage_roles = [] } = (elements == null ? void 0 : elements.on_stage_exp) || {};
|
2718
2690
|
const vanillaStore = useHMSVanillaStore2();
|
@@ -2884,7 +2856,7 @@ var ParticipantList = () => {
|
|
2884
2856
|
const [filter, setFilter] = useState18();
|
2885
2857
|
const { participants, isConnected, peerCount } = useParticipants(filter);
|
2886
2858
|
const peersOrderedByRoles = {};
|
2887
|
-
const handRaisedPeers =
|
2859
|
+
const handRaisedPeers = useHMSStore15(selectHandRaisedPeers);
|
2888
2860
|
participants.forEach((participant) => {
|
2889
2861
|
if (peersOrderedByRoles[participant.roleName] === void 0) {
|
2890
2862
|
peersOrderedByRoles[participant.roleName] = [];
|
@@ -2914,7 +2886,7 @@ var ParticipantList = () => {
|
|
2914
2886
|
)));
|
2915
2887
|
};
|
2916
2888
|
var ParticipantCount = () => {
|
2917
|
-
const peerCount =
|
2889
|
+
const peerCount = useHMSStore15(selectPeerCount2);
|
2918
2890
|
const toggleSidepane = useSidepaneToggle(SIDE_PANE_OPTIONS.PARTICIPANTS);
|
2919
2891
|
const isParticipantsOpen = useIsSidepaneTypeOpen(SIDE_PANE_OPTIONS.PARTICIPANTS);
|
2920
2892
|
useEffect5(() => {
|
@@ -2982,7 +2954,7 @@ var VirtualizedParticipants = ({ peersOrderedByRoles = {}, isConnected, filter,
|
|
2982
2954
|
);
|
2983
2955
|
};
|
2984
2956
|
var Participant = ({ peer, isConnected }) => {
|
2985
|
-
const localPeerId =
|
2957
|
+
const localPeerId = useHMSStore15(selectLocalPeerID4);
|
2986
2958
|
return /* @__PURE__ */ React35.createElement(
|
2987
2959
|
Flex,
|
2988
2960
|
{
|
@@ -3004,10 +2976,10 @@ var Participant = ({ peer, isConnected }) => {
|
|
3004
2976
|
};
|
3005
2977
|
var ParticipantActions = React35.memo(({ peerId, role, isLocal }) => {
|
3006
2978
|
var _a;
|
3007
|
-
const isHandRaised =
|
3008
|
-
const canChangeRole = (_a =
|
2979
|
+
const isHandRaised = useHMSStore15(selectHasPeerHandRaised(peerId));
|
2980
|
+
const canChangeRole = (_a = useHMSStore15(selectPermissions8)) == null ? void 0 : _a.changeRole;
|
3009
2981
|
const shouldShowMoreActions = canChangeRole;
|
3010
|
-
const isAudioMuted = !
|
2982
|
+
const isAudioMuted = !useHMSStore15(selectIsPeerAudioEnabled(peerId));
|
3011
2983
|
return /* @__PURE__ */ React35.createElement(
|
3012
2984
|
Flex,
|
3013
2985
|
{
|
@@ -3041,8 +3013,8 @@ var ParticipantActions = React35.memo(({ peerId, role, isLocal }) => {
|
|
3041
3013
|
});
|
3042
3014
|
var ParticipantMoreActions = ({ peerId, role }) => {
|
3043
3015
|
var _a;
|
3044
|
-
const hmsActions =
|
3045
|
-
const { changeRole: canChangeRole, removeOthers: canRemoveOthers } =
|
3016
|
+
const hmsActions = useHMSActions11();
|
3017
|
+
const { changeRole: canChangeRole, removeOthers: canRemoveOthers } = useHMSStore15(selectPermissions8);
|
3046
3018
|
const { elements } = useRoomLayoutConferencingScreen();
|
3047
3019
|
const {
|
3048
3020
|
bring_to_stage_label,
|
@@ -3052,8 +3024,8 @@ var ParticipantMoreActions = ({ peerId, role }) => {
|
|
3052
3024
|
} = elements.on_stage_exp || {};
|
3053
3025
|
const isInStage = role === on_stage_role;
|
3054
3026
|
const shouldShowStageRoleChange = canChangeRole && (isInStage && remove_from_stage_label || (off_stage_roles == null ? void 0 : off_stage_roles.includes(role)) && bring_to_stage_label);
|
3055
|
-
const prevRole = (_a =
|
3056
|
-
const localPeerId =
|
3027
|
+
const prevRole = (_a = useHMSStore15(selectPeerMetadata(peerId))) == null ? void 0 : _a.prevRole;
|
3028
|
+
const localPeerId = useHMSStore15(selectLocalPeerID4);
|
3057
3029
|
const isLocal = localPeerId === peerId;
|
3058
3030
|
const [open, setOpen] = useState18(false);
|
3059
3031
|
const handleStageAction = () => __async(void 0, null, function* () {
|
@@ -3129,7 +3101,7 @@ var ParticipantSearch = ({ onSearch, placeholder, inSidePane = false }) => {
|
|
3129
3101
|
{
|
3130
3102
|
type: "text",
|
3131
3103
|
placeholder: placeholder || "Search for participants",
|
3132
|
-
css: { w: "100%", p: "$6", pl: "$
|
3104
|
+
css: { w: "100%", p: "$6", pl: "$16", mr: "$4", bg: inSidePane ? "$surface_default" : "$surface_dim" },
|
3133
3105
|
value,
|
3134
3106
|
onKeyDown: (event) => {
|
3135
3107
|
event.stopPropagation();
|
@@ -3145,7 +3117,7 @@ var ParticipantSearch = ({ onSearch, placeholder, inSidePane = false }) => {
|
|
3145
3117
|
};
|
3146
3118
|
|
3147
3119
|
// src/Prebuilt/components/Footer/Footer.tsx
|
3148
|
-
var VirtualBackground = React36.lazy(() => import("./VirtualBackground-
|
3120
|
+
var VirtualBackground = React36.lazy(() => import("./VirtualBackground-3TI5NA4V.js"));
|
3149
3121
|
var Footer2 = ({
|
3150
3122
|
screenType,
|
3151
3123
|
elements
|
@@ -3210,11 +3182,11 @@ var Footer2 = ({
|
|
3210
3182
|
|
3211
3183
|
// src/Prebuilt/components/Notifications/HLSFailureModal.jsx
|
3212
3184
|
import React37, { useCallback as useCallback7, useState as useState19 } from "react";
|
3213
|
-
import { selectHLSState as selectHLSState2, useHMSActions as
|
3185
|
+
import { selectHLSState as selectHLSState2, useHMSActions as useHMSActions12, useHMSStore as useHMSStore16 } from "@100mslive/react-sdk";
|
3214
3186
|
function HLSFailureModal() {
|
3215
|
-
const { hlsError } =
|
3187
|
+
const { hlsError } = useHMSStore16(selectHLSState2).error || false;
|
3216
3188
|
const [openModal, setOpenModal] = useState19(!!hlsError);
|
3217
|
-
const hmsActions =
|
3189
|
+
const hmsActions = useHMSActions12();
|
3218
3190
|
const [isHLSStarted, setHLSStarted] = useSetAppDataByKey(APP_DATA.hlsStarted);
|
3219
3191
|
const startHLS = useCallback7(() => __async(this, null, function* () {
|
3220
3192
|
try {
|
@@ -3257,29 +3229,128 @@ function HLSFailureModal() {
|
|
3257
3229
|
) : null;
|
3258
3230
|
}
|
3259
3231
|
|
3232
|
+
// src/Prebuilt/components/RoleChangeRequest/RoleChangeRequestModal.tsx
|
3233
|
+
import React39, { useEffect as useEffect7 } from "react";
|
3234
|
+
import {
|
3235
|
+
selectLocalPeerName,
|
3236
|
+
selectLocalPeerRoleName,
|
3237
|
+
selectRoleChangeRequest,
|
3238
|
+
useCustomEvent as useCustomEvent2,
|
3239
|
+
useHMSActions as useHMSActions13,
|
3240
|
+
useHMSStore as useHMSStore17
|
3241
|
+
} from "@100mslive/react-sdk";
|
3242
|
+
|
3243
|
+
// src/Prebuilt/components/RoleChangeRequest/RequestPrompt.tsx
|
3244
|
+
import React38 from "react";
|
3245
|
+
import { useMedia as useMedia6 } from "react-use";
|
3246
|
+
var RequestPrompt = ({
|
3247
|
+
open = true,
|
3248
|
+
onOpenChange,
|
3249
|
+
title,
|
3250
|
+
body,
|
3251
|
+
actionText = "Accept",
|
3252
|
+
onAction
|
3253
|
+
}) => {
|
3254
|
+
const isMobile = useMedia6(config.media.md);
|
3255
|
+
if (isMobile) {
|
3256
|
+
return /* @__PURE__ */ React38.createElement(Sheet.Root, { open, onOpenChange }, /* @__PURE__ */ React38.createElement(Sheet.Content, { css: { py: "$8" } }, /* @__PURE__ */ React38.createElement(Text, { css: { fontWeight: "$semiBold", c: "$on_surface_high", "@md": { px: "$8" } } }, title), body, /* @__PURE__ */ React38.createElement(RequestActions, { actionText, onAction })));
|
3257
|
+
}
|
3258
|
+
return /* @__PURE__ */ React38.createElement(Dialog.Root, { open, onOpenChange }, /* @__PURE__ */ React38.createElement(Dialog.Portal, null, /* @__PURE__ */ React38.createElement(Dialog.Overlay, null), /* @__PURE__ */ React38.createElement(Dialog.Content, { css: { p: "$10" } }, /* @__PURE__ */ React38.createElement(Dialog.Title, { css: { p: 0, display: "flex", flexDirection: "row", gap: "$md", justifyContent: "center" } }, /* @__PURE__ */ React38.createElement(Text, { variant: "h6" }, title)), /* @__PURE__ */ React38.createElement(Box, { css: { mt: "$4", mb: "$10" } }, body), /* @__PURE__ */ React38.createElement(RequestActions, { actionText, onAction }))));
|
3259
|
+
};
|
3260
|
+
var RequestActions = ({ onAction, actionText }) => /* @__PURE__ */ React38.createElement(Flex, { justify: "center", align: "center", css: { width: "100%", gap: "$md", "@md": { mt: "$8", px: "$8" } } }, /* @__PURE__ */ React38.createElement(Box, { css: { width: "50%" } }, /* @__PURE__ */ React38.createElement(Dialog.Close, { css: { width: "100%" } }, /* @__PURE__ */ React38.createElement(Button, { variant: "standard", outlined: true, css: { width: "100%" } }, "Decline"))), /* @__PURE__ */ React38.createElement(Box, { css: { width: "50%" } }, /* @__PURE__ */ React38.createElement(Button, { variant: "primary", css: { width: "100%" }, onClick: onAction }, actionText)));
|
3261
|
+
|
3262
|
+
// src/Prebuilt/components/RoleChangeRequest/RoleChangeRequestModal.tsx
|
3263
|
+
var RoleChangeRequestModal = () => {
|
3264
|
+
const hmsActions = useHMSActions13();
|
3265
|
+
const { updateMetaData } = useMyMetadata();
|
3266
|
+
const currentRole = useHMSStore17(selectLocalPeerRoleName);
|
3267
|
+
const roleChangeRequest = useHMSStore17(selectRoleChangeRequest);
|
3268
|
+
const name = useHMSStore17(selectLocalPeerName);
|
3269
|
+
const { sendEvent } = useCustomEvent2({ type: ROLE_CHANGE_DECLINED });
|
3270
|
+
useEffect7(() => {
|
3271
|
+
if (!(roleChangeRequest == null ? void 0 : roleChangeRequest.role)) {
|
3272
|
+
return;
|
3273
|
+
}
|
3274
|
+
(() => __async(void 0, null, function* () {
|
3275
|
+
yield hmsActions.preview({ asRole: roleChangeRequest.role.name });
|
3276
|
+
}))();
|
3277
|
+
}, [hmsActions, roleChangeRequest, currentRole, updateMetaData]);
|
3278
|
+
if (!(roleChangeRequest == null ? void 0 : roleChangeRequest.role)) {
|
3279
|
+
return null;
|
3280
|
+
}
|
3281
|
+
const body = /* @__PURE__ */ React39.createElement(React39.Fragment, null, /* @__PURE__ */ React39.createElement(
|
3282
|
+
Text,
|
3283
|
+
{
|
3284
|
+
variant: "xs",
|
3285
|
+
css: {
|
3286
|
+
c: "$on_surface_medium",
|
3287
|
+
textAlign: "center",
|
3288
|
+
"@md": { textAlign: "left", borderBottom: "1px solid $border_bright", pb: "$4", px: "$8" }
|
3289
|
+
}
|
3290
|
+
},
|
3291
|
+
"Setup your audio and video before joining"
|
3292
|
+
), /* @__PURE__ */ React39.createElement(
|
3293
|
+
Flex,
|
3294
|
+
{
|
3295
|
+
align: "center",
|
3296
|
+
justify: "center",
|
3297
|
+
css: {
|
3298
|
+
"@sm": { width: "100%" },
|
3299
|
+
flexDirection: "column",
|
3300
|
+
mt: "$6",
|
3301
|
+
"@md": { px: "$8" }
|
3302
|
+
}
|
3303
|
+
},
|
3304
|
+
/* @__PURE__ */ React39.createElement(PreviewTile, { name: name || "" }),
|
3305
|
+
/* @__PURE__ */ React39.createElement(PreviewControls, { hideSettings: true })
|
3306
|
+
));
|
3307
|
+
return /* @__PURE__ */ React39.createElement(
|
3308
|
+
RequestPrompt,
|
3309
|
+
{
|
3310
|
+
title: "You're invited to join the stage",
|
3311
|
+
onOpenChange: (value) => __async(void 0, null, function* () {
|
3312
|
+
var _a;
|
3313
|
+
if (!value) {
|
3314
|
+
hmsActions.rejectChangeRole(roleChangeRequest);
|
3315
|
+
sendEvent(__spreadProps(__spreadValues({}, roleChangeRequest), { peerName: name }), { peerId: (_a = roleChangeRequest.requestedBy) == null ? void 0 : _a.id });
|
3316
|
+
yield hmsActions.cancelMidCallPreview();
|
3317
|
+
yield hmsActions.lowerLocalPeerHand();
|
3318
|
+
}
|
3319
|
+
}),
|
3320
|
+
body,
|
3321
|
+
onAction: () => __async(void 0, null, function* () {
|
3322
|
+
yield hmsActions.acceptChangeRole(roleChangeRequest);
|
3323
|
+
yield updateMetaData({ prevRole: currentRole });
|
3324
|
+
yield hmsActions.lowerLocalPeerHand();
|
3325
|
+
}),
|
3326
|
+
actionText: "Accept"
|
3327
|
+
}
|
3328
|
+
);
|
3329
|
+
};
|
3330
|
+
|
3260
3331
|
// src/Prebuilt/layouts/VideoStreamingSection.tsx
|
3261
|
-
import
|
3262
|
-
import { selectIsConnectedToRoom as selectIsConnectedToRoom6, selectLocalPeerRoleName as
|
3332
|
+
import React62, { Suspense as Suspense2, useEffect as useEffect24 } from "react";
|
3333
|
+
import { selectIsConnectedToRoom as selectIsConnectedToRoom6, selectLocalPeerRoleName as selectLocalPeerRoleName3, useHMSActions as useHMSActions21, useHMSStore as useHMSStore34 } from "@100mslive/react-sdk";
|
3263
3334
|
|
3264
3335
|
// src/Prebuilt/components/VideoLayouts/GridLayout.tsx
|
3265
|
-
import
|
3336
|
+
import React51, { useEffect as useEffect15, useMemo as useMemo6, useState as useState26 } from "react";
|
3266
3337
|
import { selectPeers as selectPeers2, selectPeerScreenSharing, useHMSStore as useHMSStore23, useHMSVanillaStore as useHMSVanillaStore4 } from "@100mslive/react-sdk";
|
3267
3338
|
|
3268
3339
|
// src/Prebuilt/components/VideoLayouts/EqualProminence.tsx
|
3269
|
-
import
|
3270
|
-
import { useMedia as
|
3340
|
+
import React44, { useEffect as useEffect11, useMemo as useMemo3, useState as useState21 } from "react";
|
3341
|
+
import { useMedia as useMedia9 } from "react-use";
|
3271
3342
|
import { selectLocalPeer as selectLocalPeer2, useHMSStore as useHMSStore19 } from "@100mslive/react-sdk";
|
3272
3343
|
|
3273
3344
|
// src/Prebuilt/components/InsetTile.tsx
|
3274
|
-
import
|
3345
|
+
import React41, { useEffect as useEffect8, useRef as useRef6 } from "react";
|
3275
3346
|
import Draggable from "react-draggable";
|
3276
|
-
import { useMedia as
|
3347
|
+
import { useMedia as useMedia7 } from "react-use";
|
3277
3348
|
import { selectIsAllowedToPublish as selectIsAllowedToPublish2, selectLocalPeer, selectVideoTrackByID, useHMSStore as useHMSStore18 } from "@100mslive/react-sdk";
|
3278
3349
|
import { ExpandIcon as ExpandIcon2 } from "@100mslive/react-icons";
|
3279
3350
|
|
3280
3351
|
// src/Prebuilt/components/hooks/useVideoTileLayout.ts
|
3281
|
-
import
|
3282
|
-
var VideoTileContext =
|
3352
|
+
import React40, { useContext } from "react";
|
3353
|
+
var VideoTileContext = React40.createContext({
|
3283
3354
|
enableSpotlightingPeer: true,
|
3284
3355
|
hideParticipantNameOnTile: false,
|
3285
3356
|
roundedVideoTile: true,
|
@@ -3295,14 +3366,14 @@ var useVideoTileContext = () => {
|
|
3295
3366
|
|
3296
3367
|
// src/Prebuilt/components/InsetTile.tsx
|
3297
3368
|
var MinimisedTile = ({ setMinimised }) => {
|
3298
|
-
return /* @__PURE__ */
|
3369
|
+
return /* @__PURE__ */ React41.createElement(Flex, { align: "center", css: { gap: "$6", r: "$1", bg: "$surface_default", p: "$4", color: "$on_surface_high" } }, /* @__PURE__ */ React41.createElement(AudioVideoToggle, { hideOptions: true }), /* @__PURE__ */ React41.createElement(Text, null, "You"), /* @__PURE__ */ React41.createElement(
|
3299
3370
|
IconButton_default,
|
3300
3371
|
{
|
3301
3372
|
className: "__cancel-drag-event",
|
3302
3373
|
onClick: () => setMinimised(false),
|
3303
3374
|
css: { bg: "transparent", border: "transparent" }
|
3304
3375
|
},
|
3305
|
-
/* @__PURE__ */
|
3376
|
+
/* @__PURE__ */ React41.createElement(ExpandIcon2, null)
|
3306
3377
|
));
|
3307
3378
|
};
|
3308
3379
|
var insetHeightPx = 180;
|
@@ -3310,8 +3381,8 @@ var insetMaxWidthPx = 240;
|
|
3310
3381
|
var defaultMobileAspectRatio = 9 / 16;
|
3311
3382
|
var desktopAspectRatio = 1 / defaultMobileAspectRatio;
|
3312
3383
|
var InsetTile = () => {
|
3313
|
-
const isMobile =
|
3314
|
-
const isLandscape =
|
3384
|
+
const isMobile = useMedia7(config.media.md);
|
3385
|
+
const isLandscape = useMedia7(config.media.ls);
|
3315
3386
|
const localPeer = useHMSStore18(selectLocalPeer);
|
3316
3387
|
const [minimised, setMinimised] = useSetAppDataByKey(APP_DATA.minimiseInset);
|
3317
3388
|
const videoTrack = useHMSStore18(selectVideoTrackByID(localPeer == null ? void 0 : localPeer.videoTrack));
|
@@ -3328,7 +3399,7 @@ var InsetTile = () => {
|
|
3328
3399
|
height = width / aspectRatio;
|
3329
3400
|
}
|
3330
3401
|
const nodeRef = useRef6(null);
|
3331
|
-
|
3402
|
+
useEffect8(() => {
|
3332
3403
|
const node = nodeRef.current;
|
3333
3404
|
if (!node || !window.ResizeObserver) {
|
3334
3405
|
return;
|
@@ -3349,7 +3420,7 @@ var InsetTile = () => {
|
|
3349
3420
|
if (!isAllowedToPublish.video && !isAllowedToPublish.audio) {
|
3350
3421
|
return null;
|
3351
3422
|
}
|
3352
|
-
return /* @__PURE__ */
|
3423
|
+
return /* @__PURE__ */ React41.createElement(Draggable, { bounds: "parent", nodeRef, cancel: ".__cancel-drag-event" }, /* @__PURE__ */ React41.createElement(
|
3353
3424
|
Box,
|
3354
3425
|
{
|
3355
3426
|
ref: nodeRef,
|
@@ -3365,7 +3436,7 @@ var InsetTile = () => {
|
|
3365
3436
|
h: height
|
3366
3437
|
} : {})
|
3367
3438
|
},
|
3368
|
-
minimised ? /* @__PURE__ */
|
3439
|
+
minimised ? /* @__PURE__ */ React41.createElement(MinimisedTile, { setMinimised }) : /* @__PURE__ */ React41.createElement(
|
3369
3440
|
VideoTile_default,
|
3370
3441
|
__spreadProps(__spreadValues({
|
3371
3442
|
peerId: localPeer == null ? void 0 : localPeer.id,
|
@@ -3387,7 +3458,7 @@ var InsetTile = () => {
|
|
3387
3458
|
};
|
3388
3459
|
|
3389
3460
|
// src/Prebuilt/components/Pagination.tsx
|
3390
|
-
import
|
3461
|
+
import React42, { useEffect as useEffect9 } from "react";
|
3391
3462
|
import { ChevronLeftIcon as ChevronLeftIcon2, ChevronRightIcon as ChevronRightIcon2 } from "@100mslive/react-icons";
|
3392
3463
|
var Pagination = ({
|
3393
3464
|
page,
|
@@ -3404,7 +3475,7 @@ var Pagination = ({
|
|
3404
3475
|
e.stopPropagation();
|
3405
3476
|
onPageChange(Math.max(page - 1, 0));
|
3406
3477
|
};
|
3407
|
-
|
3478
|
+
useEffect9(() => {
|
3408
3479
|
if (page >= numPages) {
|
3409
3480
|
onPageChange(Math.max(0, numPages - 1));
|
3410
3481
|
}
|
@@ -3412,7 +3483,7 @@ var Pagination = ({
|
|
3412
3483
|
if (numPages <= 1) {
|
3413
3484
|
return null;
|
3414
3485
|
}
|
3415
|
-
return /* @__PURE__ */
|
3486
|
+
return /* @__PURE__ */ React42.createElement(StyledPagination.Root, { css: { flexShrink: 0 } }, /* @__PURE__ */ React42.createElement(StyledPagination.Chevron, { disabled: disableLeft, onClick: prevPage }, /* @__PURE__ */ React42.createElement(ChevronLeftIcon2, { width: 16, height: 16, style: { cursor: disableLeft ? "not-allowed" : "pointer" } })), numPages <= 5 ? /* @__PURE__ */ React42.createElement(StyledPagination.Dots, null, [...Array(numPages)].map((_, i) => /* @__PURE__ */ React42.createElement(
|
3416
3487
|
StyledPagination.Dot,
|
3417
3488
|
{
|
3418
3489
|
key: i,
|
@@ -3422,15 +3493,15 @@ var Pagination = ({
|
|
3422
3493
|
onPageChange(i);
|
3423
3494
|
}
|
3424
3495
|
}
|
3425
|
-
))) : null, /* @__PURE__ */
|
3496
|
+
))) : null, /* @__PURE__ */ React42.createElement(StyledPagination.Chevron, { disabled: disableRight, onClick: nextPage }, /* @__PURE__ */ React42.createElement(ChevronRightIcon2, { width: 16, height: 16, style: { cursor: disableRight ? "not-allowed" : "pointer" } })));
|
3426
3497
|
};
|
3427
3498
|
|
3428
3499
|
// src/Prebuilt/components/VideoLayouts/Grid.tsx
|
3429
|
-
import
|
3430
|
-
var Grid =
|
3500
|
+
import React43 from "react";
|
3501
|
+
var Grid = React43.forwardRef(
|
3431
3502
|
({ tiles, edgeToEdge }, ref) => {
|
3432
3503
|
const videoTileProps = useVideoTileContext();
|
3433
|
-
return /* @__PURE__ */
|
3504
|
+
return /* @__PURE__ */ React43.createElement(
|
3434
3505
|
Box,
|
3435
3506
|
{
|
3436
3507
|
ref,
|
@@ -3448,7 +3519,7 @@ var Grid = React41.forwardRef(
|
|
3448
3519
|
},
|
3449
3520
|
tiles == null ? void 0 : tiles.map((tile) => {
|
3450
3521
|
var _a, _b, _c, _d;
|
3451
|
-
return /* @__PURE__ */
|
3522
|
+
return /* @__PURE__ */ React43.createElement(
|
3452
3523
|
VideoTile_default,
|
3453
3524
|
__spreadValues({
|
3454
3525
|
key: ((_a = tile.track) == null ? void 0 : _a.id) || ((_b = tile.peer) == null ? void 0 : _b.id),
|
@@ -3466,8 +3537,8 @@ var Grid = React41.forwardRef(
|
|
3466
3537
|
);
|
3467
3538
|
|
3468
3539
|
// src/Prebuilt/components/hooks/useTileLayout.tsx
|
3469
|
-
import { useEffect as
|
3470
|
-
import { useMeasure as useMeasure2, useMedia as
|
3540
|
+
import { useEffect as useEffect10, useMemo as useMemo2, useState as useState20 } from "react";
|
3541
|
+
import { useMeasure as useMeasure2, useMedia as useMedia8 } from "react-use";
|
3471
3542
|
import {
|
3472
3543
|
getPeersWithTiles,
|
3473
3544
|
selectTracksMap as selectTracksMap3,
|
@@ -3503,9 +3574,9 @@ var useTileLayout = ({
|
|
3503
3574
|
}) => {
|
3504
3575
|
const vanillaStore = useHMSVanillaStore3();
|
3505
3576
|
const [ref, { width, height }] = useMeasure2();
|
3506
|
-
const isMobile =
|
3577
|
+
const isMobile = useMedia8(config.media.lg);
|
3507
3578
|
const [pagesWithTiles, setPagesWithTiles] = useState20([]);
|
3508
|
-
|
3579
|
+
useEffect10(() => {
|
3509
3580
|
if (width === 0 || height === 0) {
|
3510
3581
|
return;
|
3511
3582
|
}
|
@@ -3573,7 +3644,7 @@ var useTileLayout = ({
|
|
3573
3644
|
function EqualProminence({ isInsetEnabled = false, peers, onPageChange, onPageSize, edgeToEdge }) {
|
3574
3645
|
var _a;
|
3575
3646
|
const localPeer = useHMSStore19(selectLocalPeer2);
|
3576
|
-
const isMobile =
|
3647
|
+
const isMobile = useMedia9(config.media.md);
|
3577
3648
|
let maxTileCount = useUISettings(UI_SETTINGS.maxTileCount);
|
3578
3649
|
maxTileCount = isMobile ? Math.min(maxTileCount, 6) : maxTileCount;
|
3579
3650
|
let pageList = usePagesWithTiles({
|
@@ -3595,12 +3666,12 @@ function EqualProminence({ isInsetEnabled = false, peers, onPageChange, onPageSi
|
|
3595
3666
|
});
|
3596
3667
|
const [page, setPage] = useState21(0);
|
3597
3668
|
const pageSize = ((_a = pagesWithTiles[0]) == null ? void 0 : _a.length) || 0;
|
3598
|
-
|
3669
|
+
useEffect11(() => {
|
3599
3670
|
if (pageSize > 0) {
|
3600
3671
|
onPageSize == null ? void 0 : onPageSize(pageSize);
|
3601
3672
|
}
|
3602
3673
|
}, [pageSize, onPageSize]);
|
3603
|
-
return /* @__PURE__ */
|
3674
|
+
return /* @__PURE__ */ React44.createElement(Flex, { direction: "column", css: { flex: "1 1 0", h: "100%", position: "relative", minWidth: 0 } }, /* @__PURE__ */ React44.createElement(Grid, { tiles: pagesWithTiles[page], ref, edgeToEdge }), !edgeToEdge && /* @__PURE__ */ React44.createElement(
|
3604
3675
|
Pagination,
|
3605
3676
|
{
|
3606
3677
|
page,
|
@@ -3610,20 +3681,20 @@ function EqualProminence({ isInsetEnabled = false, peers, onPageChange, onPageSi
|
|
3610
3681
|
},
|
3611
3682
|
numPages: pagesWithTiles.length
|
3612
3683
|
}
|
3613
|
-
), isInsetEnabled && pageList.length > 0 && pageList[0][0].peer.id !== (localPeer == null ? void 0 : localPeer.id) && /* @__PURE__ */
|
3684
|
+
), isInsetEnabled && pageList.length > 0 && pageList[0][0].peer.id !== (localPeer == null ? void 0 : localPeer.id) && /* @__PURE__ */ React44.createElement(InsetTile, null));
|
3614
3685
|
}
|
3615
3686
|
|
3616
3687
|
// src/Prebuilt/components/VideoLayouts/RoleProminence.tsx
|
3617
|
-
import
|
3688
|
+
import React47, { useEffect as useEffect13, useState as useState23 } from "react";
|
3618
3689
|
import { selectLocalPeer as selectLocalPeer3, useHMSStore as useHMSStore20 } from "@100mslive/react-sdk";
|
3619
3690
|
|
3620
3691
|
// src/Prebuilt/components/SecondaryTiles.tsx
|
3621
|
-
import
|
3622
|
-
import { useMedia as
|
3692
|
+
import React46, { useEffect as useEffect12, useState as useState22 } from "react";
|
3693
|
+
import { useMedia as useMedia10 } from "react-use";
|
3623
3694
|
|
3624
3695
|
// src/Prebuilt/components/VideoLayouts/ProminenceLayout.tsx
|
3625
|
-
import
|
3626
|
-
var Root = ({ children, edgeToEdge }) => /* @__PURE__ */
|
3696
|
+
import React45 from "react";
|
3697
|
+
var Root = ({ children, edgeToEdge }) => /* @__PURE__ */ React45.createElement(
|
3627
3698
|
Flex,
|
3628
3699
|
{
|
3629
3700
|
direction: "column",
|
@@ -3632,7 +3703,7 @@ var Root = ({ children, edgeToEdge }) => /* @__PURE__ */ React43.createElement(
|
|
3632
3703
|
children
|
3633
3704
|
);
|
3634
3705
|
var ProminentSection = ({ children, css = {} }) => {
|
3635
|
-
return /* @__PURE__ */
|
3706
|
+
return /* @__PURE__ */ React45.createElement(Flex, { direction: "column", css: __spreadValues({ flex: "1 1 0", gap: "$2", minHeight: 0 }, css) }, children);
|
3636
3707
|
};
|
3637
3708
|
var SecondarySection = ({
|
3638
3709
|
tiles,
|
@@ -3643,12 +3714,12 @@ var SecondarySection = ({
|
|
3643
3714
|
if (!(tiles == null ? void 0 : tiles.length)) {
|
3644
3715
|
return null;
|
3645
3716
|
}
|
3646
|
-
return /* @__PURE__ */
|
3717
|
+
return /* @__PURE__ */ React45.createElement(
|
3647
3718
|
Box,
|
3648
3719
|
{
|
3649
3720
|
css: {
|
3650
3721
|
display: "grid",
|
3651
|
-
gridTemplateRows:
|
3722
|
+
gridTemplateRows: React45.Children.count(children) > 0 ? "136px auto" : "154px",
|
3652
3723
|
gridTemplateColumns: `repeat(${tiles.length}, minmax(0, 1fr))`,
|
3653
3724
|
margin: "0 auto",
|
3654
3725
|
gap: "$2 $4",
|
@@ -3658,7 +3729,7 @@ var SecondarySection = ({
|
|
3658
3729
|
},
|
3659
3730
|
tiles.map((tile) => {
|
3660
3731
|
var _a, _b, _c, _d;
|
3661
|
-
return /* @__PURE__ */
|
3732
|
+
return /* @__PURE__ */ React45.createElement(
|
3662
3733
|
VideoTile_default,
|
3663
3734
|
__spreadValues({
|
3664
3735
|
key: ((_a = tile.track) == null ? void 0 : _a.id) || ((_b = tile.peer) == null ? void 0 : _b.id),
|
@@ -3675,7 +3746,7 @@ var SecondarySection = ({
|
|
3675
3746
|
}, tileLayoutProps)
|
3676
3747
|
);
|
3677
3748
|
}),
|
3678
|
-
/* @__PURE__ */
|
3749
|
+
/* @__PURE__ */ React45.createElement(Box, { css: { gridColumn: `1/span ${tiles.length}` } }, children)
|
3679
3750
|
);
|
3680
3751
|
};
|
3681
3752
|
var ProminenceLayout = {
|
@@ -3687,17 +3758,17 @@ var ProminenceLayout = {
|
|
3687
3758
|
// src/Prebuilt/components/SecondaryTiles.tsx
|
3688
3759
|
var SecondaryTiles = ({ peers, onPageChange, onPageSize, edgeToEdge }) => {
|
3689
3760
|
var _a;
|
3690
|
-
const isMobile =
|
3761
|
+
const isMobile = useMedia10(config.media.md);
|
3691
3762
|
const maxTileCount = isMobile ? 2 : 4;
|
3692
3763
|
const pagesWithTiles = usePagesWithTiles({ peers, maxTileCount });
|
3693
3764
|
const [page, setPage] = useState22(0);
|
3694
3765
|
const pageSize = ((_a = pagesWithTiles[0]) == null ? void 0 : _a.length) || 0;
|
3695
|
-
|
3766
|
+
useEffect12(() => {
|
3696
3767
|
if (pageSize > 0) {
|
3697
3768
|
onPageSize == null ? void 0 : onPageSize(pageSize);
|
3698
3769
|
}
|
3699
3770
|
}, [pageSize, onPageSize]);
|
3700
|
-
return /* @__PURE__ */
|
3771
|
+
return /* @__PURE__ */ React46.createElement(ProminenceLayout.SecondarySection, { tiles: pagesWithTiles[page], edgeToEdge }, !edgeToEdge && /* @__PURE__ */ React46.createElement(
|
3701
3772
|
Pagination,
|
3702
3773
|
{
|
3703
3774
|
page,
|
@@ -3767,12 +3838,12 @@ function RoleProminence({
|
|
3767
3838
|
});
|
3768
3839
|
const [page, setPage] = useState23(0);
|
3769
3840
|
const pageSize = ((_a = pagesWithTiles[0]) == null ? void 0 : _a.length) || 0;
|
3770
|
-
|
3841
|
+
useEffect13(() => {
|
3771
3842
|
if (pageSize > 0) {
|
3772
3843
|
onPageSize == null ? void 0 : onPageSize(pageSize);
|
3773
3844
|
}
|
3774
3845
|
}, [pageSize, onPageSize]);
|
3775
|
-
return /* @__PURE__ */
|
3846
|
+
return /* @__PURE__ */ React47.createElement(ProminenceLayout.Root, null, /* @__PURE__ */ React47.createElement(ProminenceLayout.ProminentSection, null, /* @__PURE__ */ React47.createElement(Grid, { ref, tiles: pagesWithTiles[page] })), !edgeToEdge && /* @__PURE__ */ React47.createElement(
|
3776
3847
|
Pagination,
|
3777
3848
|
{
|
3778
3849
|
page,
|
@@ -3782,20 +3853,20 @@ function RoleProminence({
|
|
3782
3853
|
},
|
3783
3854
|
numPages: pagesWithTiles.length
|
3784
3855
|
}
|
3785
|
-
), /* @__PURE__ */
|
3856
|
+
), /* @__PURE__ */ React47.createElement(SecondaryTiles, { peers: secondaryPeers, isInsetEnabled, edgeToEdge }), isInsetEnabled && localPeer && !prominentPeers.includes(localPeer) && /* @__PURE__ */ React47.createElement(InsetTile, null));
|
3786
3857
|
}
|
3787
3858
|
|
3788
3859
|
// src/Prebuilt/components/VideoLayouts/ScreenshareLayout.tsx
|
3789
|
-
import
|
3790
|
-
import { useMedia as
|
3860
|
+
import React50, { useEffect as useEffect14, useMemo as useMemo5, useState as useState25 } from "react";
|
3861
|
+
import { useMedia as useMedia11 } from "react-use";
|
3791
3862
|
import { selectPeersScreenSharing, useHMSStore as useHMSStore22 } from "@100mslive/react-sdk";
|
3792
3863
|
|
3793
3864
|
// src/Prebuilt/components/ScreenshareTile.jsx
|
3794
|
-
import
|
3865
|
+
import React49, { useRef as useRef7, useState as useState24 } from "react";
|
3795
3866
|
import { useFullscreen as useFullscreen2 } from "react-use";
|
3796
3867
|
import screenfull2 from "screenfull";
|
3797
3868
|
import {
|
3798
|
-
selectLocalPeerID as
|
3869
|
+
selectLocalPeerID as selectLocalPeerID5,
|
3799
3870
|
selectPeerByID as selectPeerByID2,
|
3800
3871
|
selectScreenShareAudioByPeerID,
|
3801
3872
|
selectScreenShareByPeerID,
|
@@ -3804,12 +3875,12 @@ import {
|
|
3804
3875
|
import { ExpandIcon as ExpandIcon3, ShrinkIcon } from "@100mslive/react-icons";
|
3805
3876
|
|
3806
3877
|
// src/Prebuilt/components/ScreenshareDisplay.jsx
|
3807
|
-
import
|
3878
|
+
import React48 from "react";
|
3808
3879
|
import { useHMSActions as useHMSActions14 } from "@100mslive/react-sdk";
|
3809
3880
|
import { CrossIcon as CrossIcon5, ShareScreenIcon as ShareScreenIcon2 } from "@100mslive/react-icons";
|
3810
3881
|
var ScreenshareDisplay = () => {
|
3811
3882
|
const hmsActions = useHMSActions14();
|
3812
|
-
return /* @__PURE__ */
|
3883
|
+
return /* @__PURE__ */ React48.createElement(
|
3813
3884
|
Flex,
|
3814
3885
|
{
|
3815
3886
|
direction: "column",
|
@@ -3821,9 +3892,9 @@ var ScreenshareDisplay = () => {
|
|
3821
3892
|
color: "$on_surface_high"
|
3822
3893
|
}
|
3823
3894
|
},
|
3824
|
-
/* @__PURE__ */
|
3825
|
-
/* @__PURE__ */
|
3826
|
-
/* @__PURE__ */
|
3895
|
+
/* @__PURE__ */ React48.createElement(ShareScreenIcon2, { width: 48, height: 48 }),
|
3896
|
+
/* @__PURE__ */ React48.createElement(Text, { variant: "h5", css: { m: "$8 0" } }, "You are sharing your screen"),
|
3897
|
+
/* @__PURE__ */ React48.createElement(
|
3827
3898
|
Button,
|
3828
3899
|
{
|
3829
3900
|
variant: "danger",
|
@@ -3833,7 +3904,7 @@ var ScreenshareDisplay = () => {
|
|
3833
3904
|
}),
|
3834
3905
|
"data-testid": "stop_screen_share_btn"
|
3835
3906
|
},
|
3836
|
-
/* @__PURE__ */
|
3907
|
+
/* @__PURE__ */ React48.createElement(CrossIcon5, { width: 18, height: 18 }),
|
3837
3908
|
"\xA0 Stop screen share"
|
3838
3909
|
)
|
3839
3910
|
);
|
@@ -3849,7 +3920,7 @@ var labelStyles = {
|
|
3849
3920
|
flexShrink: 0
|
3850
3921
|
};
|
3851
3922
|
var Tile = ({ peerId, width = "100%", height = "100%" }) => {
|
3852
|
-
const isLocal = useHMSStore21(
|
3923
|
+
const isLocal = useHMSStore21(selectLocalPeerID5) === peerId;
|
3853
3924
|
const track = useHMSStore21(selectScreenShareByPeerID(peerId));
|
3854
3925
|
const peer = useHMSStore21(selectPeerByID2(peerId));
|
3855
3926
|
const isAudioOnly = useUISettings(UI_SETTINGS.isAudioOnly);
|
@@ -3863,7 +3934,7 @@ var Tile = ({ peerId, width = "100%", height = "100%" }) => {
|
|
3863
3934
|
const isFullScreenSupported = screenfull2.isEnabled;
|
3864
3935
|
const audioTrack = useHMSStore21(selectScreenShareAudioByPeerID(peer == null ? void 0 : peer.id));
|
3865
3936
|
if (isLocal && !["browser", "window", "application"].includes(track == null ? void 0 : track.displaySurface)) {
|
3866
|
-
return /* @__PURE__ */
|
3937
|
+
return /* @__PURE__ */ React49.createElement(ScreenshareDisplay, null);
|
3867
3938
|
}
|
3868
3939
|
if (!peer) {
|
3869
3940
|
return null;
|
@@ -3873,7 +3944,7 @@ var Tile = ({ peerId, width = "100%", height = "100%" }) => {
|
|
3873
3944
|
isLocal: false,
|
3874
3945
|
track
|
3875
3946
|
});
|
3876
|
-
return /* @__PURE__ */
|
3947
|
+
return /* @__PURE__ */ React49.createElement(StyledVideoTile.Root, { css: { width, height, p: 0, minHeight: 0 }, "data-testid": "screenshare_tile" }, /* @__PURE__ */ React49.createElement(
|
3877
3948
|
StyledVideoTile.Container,
|
3878
3949
|
{
|
3879
3950
|
transparentBg: true,
|
@@ -3884,9 +3955,9 @@ var Tile = ({ peerId, width = "100%", height = "100%" }) => {
|
|
3884
3955
|
setIsMouseHovered(false);
|
3885
3956
|
}
|
3886
3957
|
},
|
3887
|
-
showStatsOnTiles ? /* @__PURE__ */
|
3888
|
-
isFullScreenSupported && isMouseHovered ? /* @__PURE__ */
|
3889
|
-
track ? /* @__PURE__ */
|
3958
|
+
showStatsOnTiles ? /* @__PURE__ */ React49.createElement(VideoTileStats, { audioTrackID: audioTrack == null ? void 0 : audioTrack.id, videoTrackID: track == null ? void 0 : track.id, peerID: peerId, isLocal }) : null,
|
3959
|
+
isFullScreenSupported && isMouseHovered ? /* @__PURE__ */ React49.createElement(StyledVideoTile.FullScreenButton, { onClick: () => setFullscreen(!fullscreen) }, isFullscreen ? /* @__PURE__ */ React49.createElement(ShrinkIcon, null) : /* @__PURE__ */ React49.createElement(ExpandIcon3, null)) : null,
|
3960
|
+
track ? /* @__PURE__ */ React49.createElement(
|
3890
3961
|
Video,
|
3891
3962
|
{
|
3892
3963
|
screenShare: true,
|
@@ -3896,8 +3967,8 @@ var Tile = ({ peerId, width = "100%", height = "100%" }) => {
|
|
3896
3967
|
css: { minHeight: 0 }
|
3897
3968
|
}
|
3898
3969
|
) : null,
|
3899
|
-
/* @__PURE__ */
|
3900
|
-
isMouseHovered && !peer.isLocal ? /* @__PURE__ */
|
3970
|
+
/* @__PURE__ */ React49.createElement(StyledVideoTile.Info, { css: labelStyles }, label),
|
3971
|
+
isMouseHovered && !peer.isLocal ? /* @__PURE__ */ React49.createElement(
|
3901
3972
|
TileMenu_default,
|
3902
3973
|
{
|
3903
3974
|
isScreenshare: true,
|
@@ -3909,7 +3980,7 @@ var Tile = ({ peerId, width = "100%", height = "100%" }) => {
|
|
3909
3980
|
) : null
|
3910
3981
|
));
|
3911
3982
|
};
|
3912
|
-
var ScreenshareTile =
|
3983
|
+
var ScreenshareTile = React49.memo(Tile);
|
3913
3984
|
var ScreenshareTile_default = ScreenshareTile;
|
3914
3985
|
|
3915
3986
|
// src/Prebuilt/components/VideoLayouts/ScreenshareLayout.tsx
|
@@ -3919,18 +3990,18 @@ var ScreenshareLayout = ({ peers, onPageChange, onPageSize, edgeToEdge }) => {
|
|
3919
3990
|
const [, setActiveScreenSharePeer] = useSetAppDataByKey(APP_DATA.activeScreensharePeerId);
|
3920
3991
|
const [page, setPage] = useState25(0);
|
3921
3992
|
const activeSharePeer = peersSharing[page];
|
3922
|
-
const isMobile =
|
3993
|
+
const isMobile = useMedia11(config.media.md);
|
3923
3994
|
const secondaryPeers = useMemo5(
|
3924
3995
|
() => isMobile ? activeSharePeer ? [activeSharePeer, ...peers.filter((p) => p.id !== (activeSharePeer == null ? void 0 : activeSharePeer.id))] : peers : peers.filter((p) => p.id !== (activeSharePeer == null ? void 0 : activeSharePeer.id)),
|
3925
3996
|
[activeSharePeer, peers, isMobile]
|
3926
3997
|
);
|
3927
|
-
|
3998
|
+
useEffect14(() => {
|
3928
3999
|
setActiveScreenSharePeer(isMobile ? "" : activeSharePeer == null ? void 0 : activeSharePeer.id);
|
3929
4000
|
return () => {
|
3930
4001
|
setActiveScreenSharePeer("");
|
3931
4002
|
};
|
3932
4003
|
}, [activeSharePeer == null ? void 0 : activeSharePeer.id, isMobile, setActiveScreenSharePeer]);
|
3933
|
-
return /* @__PURE__ */
|
4004
|
+
return /* @__PURE__ */ React50.createElement(ProminenceLayout.Root, { edgeToEdge }, /* @__PURE__ */ React50.createElement(ProminenceLayout.ProminentSection, null, /* @__PURE__ */ React50.createElement(ScreenshareTile_default, { peerId: (_a = peersSharing[page]) == null ? void 0 : _a.id }), !edgeToEdge && /* @__PURE__ */ React50.createElement(Pagination, { page, onPageChange: setPage, numPages: peersSharing.length })), /* @__PURE__ */ React50.createElement(
|
3934
4005
|
SecondaryTiles,
|
3935
4006
|
{
|
3936
4007
|
peers: secondaryPeers,
|
@@ -4060,7 +4131,7 @@ var GridLayout = ({
|
|
4060
4131
|
hideMetadataOnTile: hide_metadata_on_tile,
|
4061
4132
|
objectFit: video_object_fit
|
4062
4133
|
};
|
4063
|
-
|
4134
|
+
useEffect15(() => {
|
4064
4135
|
if (mainPage !== 0) {
|
4065
4136
|
return;
|
4066
4137
|
}
|
@@ -4071,7 +4142,7 @@ var GridLayout = ({
|
|
4071
4142
|
peersSorter.onUpdate(setSortedPeers);
|
4072
4143
|
}, [mainPage, peersSorter, updatedPeers, pageSize]);
|
4073
4144
|
if (peerSharing) {
|
4074
|
-
return /* @__PURE__ */
|
4145
|
+
return /* @__PURE__ */ React51.createElement(VideoTileContext.Provider, { value: tileLayout }, /* @__PURE__ */ React51.createElement(
|
4075
4146
|
ScreenshareLayout,
|
4076
4147
|
{
|
4077
4148
|
peers: sortedPeers,
|
@@ -4081,7 +4152,7 @@ var GridLayout = ({
|
|
4081
4152
|
}
|
4082
4153
|
));
|
4083
4154
|
} else if (isRoleProminence) {
|
4084
|
-
return /* @__PURE__ */
|
4155
|
+
return /* @__PURE__ */ React51.createElement(VideoTileContext.Provider, { value: tileLayout }, /* @__PURE__ */ React51.createElement(
|
4085
4156
|
RoleProminence,
|
4086
4157
|
{
|
4087
4158
|
peers: sortedPeers,
|
@@ -4093,7 +4164,7 @@ var GridLayout = ({
|
|
4093
4164
|
}
|
4094
4165
|
));
|
4095
4166
|
}
|
4096
|
-
return /* @__PURE__ */
|
4167
|
+
return /* @__PURE__ */ React51.createElement(VideoTileContext.Provider, { value: tileLayout }, /* @__PURE__ */ React51.createElement(
|
4097
4168
|
EqualProminence,
|
4098
4169
|
{
|
4099
4170
|
peers: sortedPeers,
|
@@ -4106,7 +4177,7 @@ var GridLayout = ({
|
|
4106
4177
|
};
|
4107
4178
|
|
4108
4179
|
// src/Prebuilt/layouts/EmbedView.jsx
|
4109
|
-
import
|
4180
|
+
import React52, { useCallback as useCallback8, useEffect as useEffect16, useMemo as useMemo7, useRef as useRef8, useState as useState27 } from "react";
|
4110
4181
|
import {
|
4111
4182
|
selectPeers as selectPeers3,
|
4112
4183
|
selectPeerScreenSharing as selectPeerScreenSharing2,
|
@@ -4115,7 +4186,7 @@ import {
|
|
4115
4186
|
useScreenShare as useScreenShare3
|
4116
4187
|
} from "@100mslive/react-sdk";
|
4117
4188
|
var EmbedView = () => {
|
4118
|
-
return /* @__PURE__ */
|
4189
|
+
return /* @__PURE__ */ React52.createElement(EmbebScreenShareView, null, /* @__PURE__ */ React52.createElement(EmbedComponent, null));
|
4119
4190
|
};
|
4120
4191
|
var EmbebScreenShareView = ({ children }) => {
|
4121
4192
|
const peers = useHMSStore24(selectPeers3);
|
@@ -4125,13 +4196,13 @@ var EmbebScreenShareView = ({ children }) => {
|
|
4125
4196
|
const smallTilePeers2 = peers.filter((peer) => peer.id !== (peerPresenting == null ? void 0 : peerPresenting.id));
|
4126
4197
|
return smallTilePeers2;
|
4127
4198
|
}, [peers, peerPresenting]);
|
4128
|
-
|
4199
|
+
useEffect16(() => {
|
4129
4200
|
setActiveScreenSharePeer(peerPresenting == null ? void 0 : peerPresenting.id);
|
4130
4201
|
return () => {
|
4131
4202
|
setActiveScreenSharePeer("");
|
4132
4203
|
};
|
4133
4204
|
}, [peerPresenting == null ? void 0 : peerPresenting.id, setActiveScreenSharePeer]);
|
4134
|
-
return /* @__PURE__ */
|
4205
|
+
return /* @__PURE__ */ React52.createElement(ProminenceLayout.Root, null, /* @__PURE__ */ React52.createElement(ProminenceLayout.ProminentSection, null, children), /* @__PURE__ */ React52.createElement(SecondaryTiles, { peers: smallTilePeers }));
|
4135
4206
|
};
|
4136
4207
|
var EmbedComponent = () => {
|
4137
4208
|
const { amIScreenSharing, toggleScreenShare } = useScreenShare3(throwErrorHandler);
|
@@ -4145,7 +4216,7 @@ var EmbedComponent = () => {
|
|
4145
4216
|
setEmbedConfig({ url: "" });
|
4146
4217
|
}
|
4147
4218
|
}, [src, setEmbedConfig]);
|
4148
|
-
|
4219
|
+
useEffect16(() => {
|
4149
4220
|
if (embedConfig.shareScreen && !amIScreenSharing && !wasScreenShared && !screenShareAttemptInProgress.current) {
|
4150
4221
|
screenShareAttemptInProgress.current = true;
|
4151
4222
|
toggleScreenShare({
|
@@ -4158,7 +4229,7 @@ var EmbedComponent = () => {
|
|
4158
4229
|
});
|
4159
4230
|
}
|
4160
4231
|
}, []);
|
4161
|
-
|
4232
|
+
useEffect16(() => {
|
4162
4233
|
if (wasScreenShared && !amIScreenSharing) {
|
4163
4234
|
resetEmbedConfig();
|
4164
4235
|
}
|
@@ -4169,7 +4240,7 @@ var EmbedComponent = () => {
|
|
4169
4240
|
}
|
4170
4241
|
};
|
4171
4242
|
}, [wasScreenShared, amIScreenSharing, resetEmbedConfig, toggleScreenShare]);
|
4172
|
-
return /* @__PURE__ */
|
4243
|
+
return /* @__PURE__ */ React52.createElement(Box, { ref: iframeRef, css: { size: "100%" } }, /* @__PURE__ */ React52.createElement(
|
4173
4244
|
"iframe",
|
4174
4245
|
{
|
4175
4246
|
src,
|
@@ -4182,10 +4253,10 @@ var EmbedComponent = () => {
|
|
4182
4253
|
};
|
4183
4254
|
|
4184
4255
|
// src/Prebuilt/layouts/PDFView.jsx
|
4185
|
-
import
|
4256
|
+
import React53, { useCallback as useCallback9, useEffect as useEffect17, useRef as useRef9, useState as useState28 } from "react";
|
4186
4257
|
import { throwErrorHandler as throwErrorHandler2, useScreenShare as useScreenShare4 } from "@100mslive/react-sdk";
|
4187
4258
|
var PDFView = () => {
|
4188
|
-
return /* @__PURE__ */
|
4259
|
+
return /* @__PURE__ */ React53.createElement(EmbebScreenShareView, null, /* @__PURE__ */ React53.createElement(PDFEmbedComponent, null));
|
4189
4260
|
};
|
4190
4261
|
var PDFEmbedComponent = () => {
|
4191
4262
|
const ref = useRef9();
|
@@ -4203,7 +4274,7 @@ var PDFEmbedComponent = () => {
|
|
4203
4274
|
const resetEmbedConfig = useCallback9(() => {
|
4204
4275
|
setPDFConfig({ state: false });
|
4205
4276
|
}, [setPDFConfig]);
|
4206
|
-
|
4277
|
+
useEffect17(() => {
|
4207
4278
|
if (isPDFLoaded && ref.current) {
|
4208
4279
|
ref.current.contentWindow.postMessage(
|
4209
4280
|
{
|
@@ -4213,7 +4284,7 @@ var PDFEmbedComponent = () => {
|
|
4213
4284
|
);
|
4214
4285
|
}
|
4215
4286
|
}, [isPDFLoaded, themeType]);
|
4216
|
-
|
4287
|
+
useEffect17(() => {
|
4217
4288
|
if (!amIScreenSharing && !wasScreenShared && !screenShareAttemptInProgress.current) {
|
4218
4289
|
screenShareAttemptInProgress.current = true;
|
4219
4290
|
toggleScreenShare({
|
@@ -4227,7 +4298,7 @@ var PDFEmbedComponent = () => {
|
|
4227
4298
|
});
|
4228
4299
|
}
|
4229
4300
|
}, []);
|
4230
|
-
|
4301
|
+
useEffect17(() => {
|
4231
4302
|
if (wasScreenShared && !amIScreenSharing) {
|
4232
4303
|
resetEmbedConfig();
|
4233
4304
|
}
|
@@ -4238,7 +4309,7 @@ var PDFEmbedComponent = () => {
|
|
4238
4309
|
}
|
4239
4310
|
};
|
4240
4311
|
}, [wasScreenShared, amIScreenSharing, resetEmbedConfig, toggleScreenShare]);
|
4241
|
-
return /* @__PURE__ */
|
4312
|
+
return /* @__PURE__ */ React53.createElement(Box, { ref: iframeRef, css: { size: "100%" } }, /* @__PURE__ */ React53.createElement(
|
4242
4313
|
"iframe",
|
4243
4314
|
{
|
4244
4315
|
src: pdfJSURL,
|
@@ -4271,19 +4342,19 @@ var PDFEmbedComponent = () => {
|
|
4271
4342
|
};
|
4272
4343
|
|
4273
4344
|
// src/Prebuilt/layouts/SidePane.tsx
|
4274
|
-
import
|
4275
|
-
import { useMedia as
|
4345
|
+
import React60 from "react";
|
4346
|
+
import { useMedia as useMedia16 } from "react-use";
|
4276
4347
|
import { selectAppData as selectAppData3, selectVideoTrackByPeerID, useHMSStore as useHMSStore33 } from "@100mslive/react-sdk";
|
4277
4348
|
|
4278
4349
|
// src/Prebuilt/components/SidePaneTabs.tsx
|
4279
|
-
import
|
4280
|
-
import { useMedia as
|
4350
|
+
import React57, { useEffect as useEffect22, useState as useState32 } from "react";
|
4351
|
+
import { useMedia as useMedia15 } from "react-use";
|
4281
4352
|
import { selectPeerCount as selectPeerCount3, useHMSStore as useHMSStore30 } from "@100mslive/react-sdk";
|
4282
4353
|
import { CrossIcon as CrossIcon7 } from "@100mslive/react-icons";
|
4283
4354
|
|
4284
4355
|
// src/Prebuilt/components/Chat/Chat.jsx
|
4285
|
-
import
|
4286
|
-
import { useMedia as
|
4356
|
+
import React56, { useCallback as useCallback14, useEffect as useEffect21, useRef as useRef13, useState as useState31 } from "react";
|
4357
|
+
import { useMedia as useMedia14 } from "react-use";
|
4287
4358
|
import {
|
4288
4359
|
HMSNotificationTypes,
|
4289
4360
|
selectHMSMessagesCount,
|
@@ -4297,21 +4368,21 @@ import {
|
|
4297
4368
|
import { ChevronDownIcon as ChevronDownIcon2, CrossIcon as CrossIcon6, PinIcon as PinIcon2 } from "@100mslive/react-icons";
|
4298
4369
|
|
4299
4370
|
// src/Prebuilt/components/Chat/ChatBody.jsx
|
4300
|
-
import
|
4371
|
+
import React54, { Fragment as Fragment8, useCallback as useCallback11, useEffect as useEffect18, useLayoutEffect, useMemo as useMemo8, useRef as useRef10, useState as useState29 } from "react";
|
4301
4372
|
import { useInView } from "react-intersection-observer";
|
4302
|
-
import { useMedia as
|
4373
|
+
import { useMedia as useMedia12 } from "react-use";
|
4303
4374
|
import AutoSizer from "react-virtualized-auto-sizer";
|
4304
4375
|
import { VariableSizeList } from "react-window";
|
4305
4376
|
import {
|
4306
4377
|
selectHMSMessages,
|
4307
|
-
selectLocalPeerID as
|
4308
|
-
selectLocalPeerRoleName,
|
4378
|
+
selectLocalPeerID as selectLocalPeerID6,
|
4379
|
+
selectLocalPeerRoleName as selectLocalPeerRoleName2,
|
4309
4380
|
selectMessagesByPeerID,
|
4310
4381
|
selectMessagesByRole,
|
4311
4382
|
selectPeerNameByID as selectPeerNameByID2,
|
4312
4383
|
selectPermissions as selectPermissions9,
|
4313
4384
|
useHMSActions as useHMSActions16,
|
4314
|
-
useHMSStore as
|
4385
|
+
useHMSStore as useHMSStore27
|
4315
4386
|
} from "@100mslive/react-sdk";
|
4316
4387
|
import { PinIcon, VerticalMenuIcon as VerticalMenuIcon5 } from "@100mslive/react-icons";
|
4317
4388
|
|
@@ -4347,6 +4418,19 @@ var useSetPinnedMessage = () => {
|
|
4347
4418
|
return { setPinnedMessage };
|
4348
4419
|
};
|
4349
4420
|
|
4421
|
+
// src/Prebuilt/components/Chat/useUnreadCount.js
|
4422
|
+
import {
|
4423
|
+
selectMessagesUnreadCountByPeerID,
|
4424
|
+
selectMessagesUnreadCountByRole,
|
4425
|
+
selectUnreadHMSMessagesCount as selectUnreadHMSMessagesCount2,
|
4426
|
+
useHMSStore as useHMSStore26
|
4427
|
+
} from "@100mslive/react-sdk";
|
4428
|
+
var useUnreadCount = ({ role, peerId }) => {
|
4429
|
+
const unreadCountSelector = role ? selectMessagesUnreadCountByRole(role) : peerId ? selectMessagesUnreadCountByPeerID(peerId) : selectUnreadHMSMessagesCount2;
|
4430
|
+
const unreadCount = useHMSStore26(unreadCountSelector);
|
4431
|
+
return unreadCount;
|
4432
|
+
};
|
4433
|
+
|
4350
4434
|
// src/Prebuilt/components/Chat/ChatBody.jsx
|
4351
4435
|
var formatTime = (date) => {
|
4352
4436
|
if (!(date instanceof Date)) {
|
@@ -4364,7 +4448,7 @@ var formatTime = (date) => {
|
|
4364
4448
|
return `${hours}:${mins} ${suffix}`;
|
4365
4449
|
};
|
4366
4450
|
var MessageTypeContainer = ({ left, right }) => {
|
4367
|
-
return /* @__PURE__ */
|
4451
|
+
return /* @__PURE__ */ React54.createElement(
|
4368
4452
|
Flex,
|
4369
4453
|
{
|
4370
4454
|
align: "center",
|
@@ -4376,16 +4460,16 @@ var MessageTypeContainer = ({ left, right }) => {
|
|
4376
4460
|
r: "$0"
|
4377
4461
|
}
|
4378
4462
|
},
|
4379
|
-
left && /* @__PURE__ */
|
4380
|
-
left && right && /* @__PURE__ */
|
4381
|
-
right && /* @__PURE__ */
|
4463
|
+
left && /* @__PURE__ */ React54.createElement(SenderName, { variant: "tiny", as: "span", css: { color: "$on_surface_medium" } }, left),
|
4464
|
+
left && right && /* @__PURE__ */ React54.createElement(Box, { css: { borderLeft: "1px solid $border_bright", mx: "$4", h: "$8" } }),
|
4465
|
+
right && /* @__PURE__ */ React54.createElement(SenderName, { as: "span", variant: "tiny", css: { textTransform: "uppercase" } }, right)
|
4382
4466
|
);
|
4383
4467
|
};
|
4384
4468
|
var MessageType = ({ roles, hasCurrentUserSent, receiver }) => {
|
4385
|
-
const peerName =
|
4386
|
-
const localPeerRoleName =
|
4469
|
+
const peerName = useHMSStore27(selectPeerNameByID2(receiver));
|
4470
|
+
const localPeerRoleName = useHMSStore27(selectLocalPeerRoleName2);
|
4387
4471
|
if (receiver) {
|
4388
|
-
return /* @__PURE__ */
|
4472
|
+
return /* @__PURE__ */ React54.createElement(
|
4389
4473
|
MessageTypeContainer,
|
4390
4474
|
{
|
4391
4475
|
left: hasCurrentUserSent ? `${peerName ? `TO ${peerName}` : ""}` : "TO YOU",
|
@@ -4394,7 +4478,7 @@ var MessageType = ({ roles, hasCurrentUserSent, receiver }) => {
|
|
4394
4478
|
);
|
4395
4479
|
}
|
4396
4480
|
if (roles && roles.length) {
|
4397
|
-
return /* @__PURE__ */
|
4481
|
+
return /* @__PURE__ */ React54.createElement(MessageTypeContainer, { left: "TO", right: hasCurrentUserSent ? roles.join(",") : localPeerRoleName });
|
4398
4482
|
}
|
4399
4483
|
return null;
|
4400
4484
|
};
|
@@ -4408,10 +4492,10 @@ var Link = styled("a", {
|
|
4408
4492
|
});
|
4409
4493
|
var AnnotisedMessage = ({ message }) => {
|
4410
4494
|
if (!message) {
|
4411
|
-
return /* @__PURE__ */
|
4495
|
+
return /* @__PURE__ */ React54.createElement(Fragment8, null);
|
4412
4496
|
}
|
4413
|
-
return /* @__PURE__ */
|
4414
|
-
(part) => URL_REGEX.test(part) ? /* @__PURE__ */
|
4497
|
+
return /* @__PURE__ */ React54.createElement(Fragment8, null, message.trim().split(/(\s)/).map(
|
4498
|
+
(part) => URL_REGEX.test(part) ? /* @__PURE__ */ React54.createElement(Link, { href: part, key: part, target: "_blank", rel: "noopener noreferrer" }, part) : part
|
4415
4499
|
));
|
4416
4500
|
};
|
4417
4501
|
var getMessageType = ({ roles, receiver }) => {
|
@@ -4425,14 +4509,14 @@ var ChatActions = ({ onPin, showPinAction }) => {
|
|
4425
4509
|
if (!showPinAction) {
|
4426
4510
|
return null;
|
4427
4511
|
}
|
4428
|
-
return /* @__PURE__ */
|
4512
|
+
return /* @__PURE__ */ React54.createElement(Dropdown.Root, { open, onOpenChange: setOpen }, /* @__PURE__ */ React54.createElement(Dropdown.Trigger, { className: "chat_actions", css: { opacity: open ? 1 : 0, "@md": { opacity: 1 } }, asChild: true }, /* @__PURE__ */ React54.createElement(IconButton, null, /* @__PURE__ */ React54.createElement(Tooltip, { title: "More options" }, /* @__PURE__ */ React54.createElement(VerticalMenuIcon5, null)))), /* @__PURE__ */ React54.createElement(Dropdown.Portal, null, /* @__PURE__ */ React54.createElement(
|
4429
4513
|
Dropdown.Content,
|
4430
4514
|
{
|
4431
4515
|
sideOffset: 5,
|
4432
4516
|
align: "end",
|
4433
4517
|
css: { width: "$48", backgroundColor: "$surface_bright", py: "$0", border: "1px solid $border_bright" }
|
4434
4518
|
},
|
4435
|
-
/* @__PURE__ */
|
4519
|
+
/* @__PURE__ */ React54.createElement(Dropdown.Item, { "data-testid": "pin_message_btn", onClick: onPin }, /* @__PURE__ */ React54.createElement(PinIcon, null), /* @__PURE__ */ React54.createElement(Text, { variant: "sm", css: { ml: "$4" } }, "Pin Message"))
|
4436
4520
|
)));
|
4437
4521
|
};
|
4438
4522
|
var SenderName = styled(Text, {
|
@@ -4444,120 +4528,127 @@ var SenderName = styled(Text, {
|
|
4444
4528
|
color: "$on_surface_high",
|
4445
4529
|
fontWeight: "$semiBold"
|
4446
4530
|
});
|
4447
|
-
var ChatMessage =
|
4448
|
-
|
4449
|
-
|
4450
|
-
|
4451
|
-
|
4452
|
-
|
4453
|
-
|
4454
|
-
|
4455
|
-
|
4456
|
-
|
4457
|
-
|
4458
|
-
|
4459
|
-
|
4460
|
-
|
4461
|
-
|
4462
|
-
|
4463
|
-
|
4464
|
-
|
4465
|
-
|
4466
|
-
|
4467
|
-
|
4468
|
-
|
4469
|
-
|
4470
|
-
|
4471
|
-
|
4472
|
-
|
4473
|
-
|
4474
|
-
|
4475
|
-
|
4476
|
-
|
4477
|
-
|
4478
|
-
|
4479
|
-
|
4480
|
-
/* @__PURE__ */ React52.createElement(
|
4481
|
-
Flex,
|
4531
|
+
var ChatMessage = React54.memo(
|
4532
|
+
({ index, style = {}, message, setRowHeight, isLast = false, unreadCount = 0, scrollToBottom, onPin }) => {
|
4533
|
+
var _a, _b;
|
4534
|
+
const { ref, inView } = useInView({ threshold: 0.5, triggerOnce: true });
|
4535
|
+
const rowRef = useRef10(null);
|
4536
|
+
useEffect18(() => {
|
4537
|
+
if (rowRef.current) {
|
4538
|
+
setRowHeight(index, rowRef.current.clientHeight);
|
4539
|
+
}
|
4540
|
+
}, [index, setRowHeight]);
|
4541
|
+
const isMobile = useMedia12(config.media.md);
|
4542
|
+
const { elements } = useRoomLayoutConferencingScreen();
|
4543
|
+
const isOverlay = ((_a = elements == null ? void 0 : elements.chat) == null ? void 0 : _a.is_overlay) && isMobile;
|
4544
|
+
const hmsActions = useHMSActions16();
|
4545
|
+
const localPeerId = useHMSStore27(selectLocalPeerID6);
|
4546
|
+
const permissions = useHMSStore27(selectPermissions9);
|
4547
|
+
const messageType = getMessageType({
|
4548
|
+
roles: message.recipientRoles,
|
4549
|
+
receiver: message.recipientPeer
|
4550
|
+
});
|
4551
|
+
const showPinAction = permissions.removeOthers && !messageType && ((_b = elements == null ? void 0 : elements.chat) == null ? void 0 : _b.allow_pinning_messages);
|
4552
|
+
useEffect18(() => {
|
4553
|
+
if (message.id && !message.read && inView) {
|
4554
|
+
hmsActions.setMessageRead(true, message.id);
|
4555
|
+
}
|
4556
|
+
}, [message.read, hmsActions, inView, message.id]);
|
4557
|
+
useEffect18(() => {
|
4558
|
+
if (isLast && inView && unreadCount >= 1) {
|
4559
|
+
scrollToBottom(1);
|
4560
|
+
}
|
4561
|
+
}, [inView, isLast, scrollToBottom, unreadCount]);
|
4562
|
+
return /* @__PURE__ */ React54.createElement(
|
4563
|
+
Box,
|
4482
4564
|
{
|
4483
|
-
ref
|
4484
|
-
|
4485
|
-
css: {
|
4486
|
-
|
4487
|
-
// Theme independent color, token should not be used for transparent chat
|
4488
|
-
bg: messageType ? isOverlay ? "rgba(0, 0, 0, 0.64)" : "$surface_default" : void 0,
|
4489
|
-
r: messageType ? "$1" : void 0,
|
4490
|
-
px: messageType ? "$4" : "$2",
|
4491
|
-
py: messageType ? "$4" : 0,
|
4492
|
-
userSelect: "none"
|
4493
|
-
},
|
4494
|
-
key: message.time,
|
4495
|
-
"data-testid": "chat_msg"
|
4565
|
+
ref,
|
4566
|
+
as: "div",
|
4567
|
+
css: { mb: "$10", pr: "$10", mt: "$8", "&:hover .chat_actions": { opacity: 1 } },
|
4568
|
+
style
|
4496
4569
|
},
|
4497
|
-
/* @__PURE__ */
|
4498
|
-
|
4570
|
+
/* @__PURE__ */ React54.createElement(
|
4571
|
+
Flex,
|
4499
4572
|
{
|
4573
|
+
ref: rowRef,
|
4574
|
+
align: "center",
|
4500
4575
|
css: {
|
4501
|
-
|
4502
|
-
|
4503
|
-
|
4504
|
-
|
4505
|
-
|
4506
|
-
|
4576
|
+
flexWrap: "wrap",
|
4577
|
+
// Theme independent color, token should not be used for transparent chat
|
4578
|
+
bg: messageType ? isOverlay ? "rgba(0, 0, 0, 0.64)" : "$surface_default" : void 0,
|
4579
|
+
r: messageType ? "$1" : void 0,
|
4580
|
+
px: messageType ? "$4" : "$2",
|
4581
|
+
py: messageType ? "$4" : 0,
|
4582
|
+
userSelect: "none"
|
4507
4583
|
},
|
4508
|
-
|
4584
|
+
key: message.time,
|
4585
|
+
"data-testid": "chat_msg"
|
4509
4586
|
},
|
4510
|
-
/* @__PURE__ */
|
4587
|
+
/* @__PURE__ */ React54.createElement(
|
4511
4588
|
Text,
|
4512
4589
|
{
|
4513
|
-
as: "span",
|
4514
|
-
variant: "xs",
|
4515
4590
|
css: {
|
4516
|
-
|
4517
|
-
|
4518
|
-
|
4519
|
-
|
4591
|
+
color: isOverlay ? "#FFF" : "$on_surface_high",
|
4592
|
+
fontWeight: "$semiBold",
|
4593
|
+
display: "inline-flex",
|
4594
|
+
alignItems: "center",
|
4595
|
+
justifyContent: "space-between",
|
4596
|
+
width: "100%"
|
4597
|
+
},
|
4598
|
+
as: "div"
|
4520
4599
|
},
|
4521
|
-
|
4522
|
-
|
4523
|
-
|
4524
|
-
|
4525
|
-
|
4526
|
-
|
4527
|
-
|
4528
|
-
|
4529
|
-
|
4600
|
+
/* @__PURE__ */ React54.createElement(Flex, { align: "baseline" }, message.senderName === "You" || !message.senderName ? /* @__PURE__ */ React54.createElement(SenderName, { as: "span", variant: "sm", css: { color: isOverlay ? "#FFF" : "$on_surface_high" } }, message.senderName || "Anonymous") : /* @__PURE__ */ React54.createElement(Tooltip, { title: message.senderName, side: "top", align: "start" }, /* @__PURE__ */ React54.createElement(SenderName, { as: "span", variant: "sm", css: { color: isOverlay ? "#FFF" : "$on_surface_high" } }, message.senderName)), !isOverlay ? /* @__PURE__ */ React54.createElement(
|
4601
|
+
Text,
|
4602
|
+
{
|
4603
|
+
as: "span",
|
4604
|
+
variant: "xs",
|
4605
|
+
css: {
|
4606
|
+
ml: "$4",
|
4607
|
+
color: "$on_surface_medium",
|
4608
|
+
flexShrink: 0
|
4609
|
+
}
|
4610
|
+
},
|
4611
|
+
formatTime(message.time)
|
4612
|
+
) : null),
|
4613
|
+
/* @__PURE__ */ React54.createElement(
|
4614
|
+
MessageType,
|
4615
|
+
{
|
4616
|
+
hasCurrentUserSent: message.sender === localPeerId,
|
4617
|
+
receiver: message.recipientPeer,
|
4618
|
+
roles: message.recipientRoles
|
4619
|
+
}
|
4620
|
+
),
|
4621
|
+
!isOverlay ? /* @__PURE__ */ React54.createElement(ChatActions, { onPin, showPinAction }) : null
|
4530
4622
|
),
|
4531
|
-
|
4532
|
-
|
4533
|
-
|
4534
|
-
|
4535
|
-
|
4536
|
-
|
4537
|
-
|
4538
|
-
|
4539
|
-
|
4540
|
-
|
4541
|
-
|
4542
|
-
|
4543
|
-
|
4623
|
+
/* @__PURE__ */ React54.createElement(
|
4624
|
+
Text,
|
4625
|
+
{
|
4626
|
+
variant: "sm",
|
4627
|
+
css: {
|
4628
|
+
w: "100%",
|
4629
|
+
mt: "$2",
|
4630
|
+
wordBreak: "break-word",
|
4631
|
+
whiteSpace: "pre-wrap",
|
4632
|
+
userSelect: "all",
|
4633
|
+
color: isOverlay ? "#FFF" : "$on_surface_high"
|
4634
|
+
},
|
4635
|
+
onClick: (e) => e.stopPropagation()
|
4544
4636
|
},
|
4545
|
-
|
4546
|
-
|
4547
|
-
/* @__PURE__ */ React52.createElement(AnnotisedMessage, { message: message.message })
|
4637
|
+
/* @__PURE__ */ React54.createElement(AnnotisedMessage, { message: message.message })
|
4638
|
+
)
|
4548
4639
|
)
|
4549
|
-
)
|
4550
|
-
|
4551
|
-
|
4552
|
-
var ChatList =
|
4553
|
-
({ width, height, setRowHeight, getRowHeight, messages, scrollToBottom }, listRef) => {
|
4640
|
+
);
|
4641
|
+
}
|
4642
|
+
);
|
4643
|
+
var ChatList = React54.forwardRef(
|
4644
|
+
({ width, height, setRowHeight, getRowHeight, messages, unreadCount = 0, scrollToBottom }, listRef) => {
|
4554
4645
|
const { setPinnedMessage } = useSetPinnedMessage();
|
4555
4646
|
useLayoutEffect(() => {
|
4556
4647
|
if (listRef.current && listRef.current.scrollToItem) {
|
4557
4648
|
scrollToBottom(1);
|
4558
4649
|
}
|
4559
4650
|
}, [listRef]);
|
4560
|
-
return /* @__PURE__ */
|
4651
|
+
return /* @__PURE__ */ React54.createElement(
|
4561
4652
|
VariableSizeList,
|
4562
4653
|
{
|
4563
4654
|
ref: listRef,
|
@@ -4569,7 +4660,7 @@ var ChatList = React52.forwardRef(
|
|
4569
4660
|
overflowX: "hidden"
|
4570
4661
|
}
|
4571
4662
|
},
|
4572
|
-
({ index, style }) => /* @__PURE__ */
|
4663
|
+
({ index, style }) => /* @__PURE__ */ React54.createElement(
|
4573
4664
|
ChatMessage,
|
4574
4665
|
{
|
4575
4666
|
style,
|
@@ -4577,13 +4668,16 @@ var ChatList = React52.forwardRef(
|
|
4577
4668
|
key: messages[index].id,
|
4578
4669
|
message: messages[index],
|
4579
4670
|
setRowHeight,
|
4671
|
+
unreadCount,
|
4672
|
+
isLast: index >= messages.length - 2,
|
4673
|
+
scrollToBottom,
|
4580
4674
|
onPin: () => setPinnedMessage(messages[index])
|
4581
4675
|
}
|
4582
4676
|
)
|
4583
4677
|
);
|
4584
4678
|
}
|
4585
4679
|
);
|
4586
|
-
var VirtualizedChatMessages =
|
4680
|
+
var VirtualizedChatMessages = React54.forwardRef(({ messages, unreadCount = 0, scrollToBottom }, listRef) => {
|
4587
4681
|
const rowHeights = useRef10({});
|
4588
4682
|
function getRowHeight(index) {
|
4589
4683
|
return rowHeights.current[index] + 16 || 72;
|
@@ -4595,7 +4689,7 @@ var VirtualizedChatMessages = React52.forwardRef(({ messages, scrollToBottom },
|
|
4595
4689
|
},
|
4596
4690
|
[listRef]
|
4597
4691
|
);
|
4598
|
-
return /* @__PURE__ */
|
4692
|
+
return /* @__PURE__ */ React54.createElement(
|
4599
4693
|
Box,
|
4600
4694
|
{
|
4601
4695
|
css: {
|
@@ -4604,14 +4698,14 @@ var VirtualizedChatMessages = React52.forwardRef(({ messages, scrollToBottom },
|
|
4604
4698
|
},
|
4605
4699
|
as: "div"
|
4606
4700
|
},
|
4607
|
-
/* @__PURE__ */
|
4701
|
+
/* @__PURE__ */ React54.createElement(
|
4608
4702
|
AutoSizer,
|
4609
4703
|
{
|
4610
4704
|
style: {
|
4611
4705
|
width: "90%"
|
4612
4706
|
}
|
4613
4707
|
},
|
4614
|
-
({ height, width }) => /* @__PURE__ */
|
4708
|
+
({ height, width }) => /* @__PURE__ */ React54.createElement(
|
4615
4709
|
ChatList,
|
4616
4710
|
{
|
4617
4711
|
width,
|
@@ -4620,21 +4714,23 @@ var VirtualizedChatMessages = React52.forwardRef(({ messages, scrollToBottom },
|
|
4620
4714
|
setRowHeight,
|
4621
4715
|
getRowHeight,
|
4622
4716
|
scrollToBottom,
|
4623
|
-
ref: listRef
|
4717
|
+
ref: listRef,
|
4718
|
+
unreadCount
|
4624
4719
|
}
|
4625
4720
|
)
|
4626
4721
|
)
|
4627
4722
|
);
|
4628
4723
|
});
|
4629
|
-
var ChatBody =
|
4724
|
+
var ChatBody = React54.forwardRef(({ role, peerId, scrollToBottom }, listRef) => {
|
4630
4725
|
var _a;
|
4631
4726
|
const storeMessageSelector = role ? selectMessagesByRole(role) : peerId ? selectMessagesByPeerID(peerId) : selectHMSMessages;
|
4632
|
-
let messages =
|
4727
|
+
let messages = useHMSStore27(storeMessageSelector);
|
4633
4728
|
messages = useMemo8(() => (messages == null ? void 0 : messages.filter((message) => message.type === "chat")) || [], [messages]);
|
4634
|
-
const isMobile =
|
4729
|
+
const isMobile = useMedia12(config.media.md);
|
4635
4730
|
const { elements } = useRoomLayoutConferencingScreen();
|
4731
|
+
const unreadCount = useUnreadCount({ role, peerId });
|
4636
4732
|
if (messages.length === 0 && !(isMobile && ((_a = elements == null ? void 0 : elements.chat) == null ? void 0 : _a.is_overlay))) {
|
4637
|
-
return /* @__PURE__ */
|
4733
|
+
return /* @__PURE__ */ React54.createElement(
|
4638
4734
|
Flex,
|
4639
4735
|
{
|
4640
4736
|
css: {
|
@@ -4646,7 +4742,7 @@ var ChatBody = React52.forwardRef(({ role, peerId, scrollToBottom }, listRef) =>
|
|
4646
4742
|
align: "center",
|
4647
4743
|
justify: "center"
|
4648
4744
|
},
|
4649
|
-
/* @__PURE__ */
|
4745
|
+
/* @__PURE__ */ React54.createElement(Box, null, /* @__PURE__ */ React54.createElement("img", { src: empty_chat_default, alt: "Empty Chat", height: 132, width: 185, style: { margin: "0 auto" } }), /* @__PURE__ */ React54.createElement(Text, { variant: "h5", css: { mt: "$8", c: "$on_surface_high" } }, "Start a conversation"), /* @__PURE__ */ React54.createElement(
|
4650
4746
|
Text,
|
4651
4747
|
{
|
4652
4748
|
variant: "sm",
|
@@ -4656,12 +4752,20 @@ var ChatBody = React52.forwardRef(({ role, peerId, scrollToBottom }, listRef) =>
|
|
4656
4752
|
))
|
4657
4753
|
);
|
4658
4754
|
}
|
4659
|
-
return /* @__PURE__ */
|
4755
|
+
return /* @__PURE__ */ React54.createElement(Fragment8, null, /* @__PURE__ */ React54.createElement(
|
4756
|
+
VirtualizedChatMessages,
|
4757
|
+
{
|
4758
|
+
messages,
|
4759
|
+
scrollToBottom,
|
4760
|
+
unreadCount,
|
4761
|
+
ref: listRef
|
4762
|
+
}
|
4763
|
+
));
|
4660
4764
|
});
|
4661
4765
|
|
4662
4766
|
// src/Prebuilt/components/Chat/ChatFooter.tsx
|
4663
|
-
import
|
4664
|
-
import { useMedia as
|
4767
|
+
import React55, { useCallback as useCallback13, useEffect as useEffect20, useRef as useRef12, useState as useState30 } from "react";
|
4768
|
+
import { useMedia as useMedia13 } from "react-use";
|
4665
4769
|
import data2 from "@emoji-mart/data";
|
4666
4770
|
import Picker from "@emoji-mart/react";
|
4667
4771
|
import { useHMSActions as useHMSActions18 } from "@100mslive/react-sdk";
|
@@ -4669,10 +4773,10 @@ import { EmojiIcon as EmojiIcon3, SendIcon } from "@100mslive/react-icons";
|
|
4669
4773
|
|
4670
4774
|
// src/Prebuilt/components/AppData/useChatState.js
|
4671
4775
|
import { useCallback as useCallback12 } from "react";
|
4672
|
-
import { selectAppData as selectAppData2, useHMSActions as useHMSActions17, useHMSStore as
|
4776
|
+
import { selectAppData as selectAppData2, useHMSActions as useHMSActions17, useHMSStore as useHMSStore28 } from "@100mslive/react-sdk";
|
4673
4777
|
var useChatDraftMessage = () => {
|
4674
4778
|
const hmsActions = useHMSActions17();
|
4675
|
-
let chatDraftMessage =
|
4779
|
+
let chatDraftMessage = useHMSStore28(selectAppData2(APP_DATA.chatDraft));
|
4676
4780
|
if (chatDraftMessage === void 0 || chatDraftMessage === null) {
|
4677
4781
|
chatDraftMessage = "";
|
4678
4782
|
}
|
@@ -4686,10 +4790,10 @@ var useChatDraftMessage = () => {
|
|
4686
4790
|
};
|
4687
4791
|
|
4688
4792
|
// src/Prebuilt/components/Chat/useEmojiPickerStyles.js
|
4689
|
-
import { useEffect as
|
4793
|
+
import { useEffect as useEffect19, useRef as useRef11 } from "react";
|
4690
4794
|
var useEmojiPickerStyles = (showing) => {
|
4691
4795
|
const ref = useRef11(null);
|
4692
|
-
|
4796
|
+
useEffect19(() => {
|
4693
4797
|
if (showing) {
|
4694
4798
|
setTimeout(() => {
|
4695
4799
|
var _a, _b;
|
@@ -4739,7 +4843,7 @@ var TextArea = styled("textarea", {
|
|
4739
4843
|
function EmojiPicker({ onSelect }) {
|
4740
4844
|
const [showEmoji, setShowEmoji] = useState30(false);
|
4741
4845
|
const ref = useEmojiPickerStyles(showEmoji);
|
4742
|
-
return /* @__PURE__ */
|
4846
|
+
return /* @__PURE__ */ React55.createElement(Popover.Root, { open: showEmoji, onOpenChange: setShowEmoji }, /* @__PURE__ */ React55.createElement(Popover.Trigger, { asChild: true, css: { appearance: "none" } }, /* @__PURE__ */ React55.createElement(IconButton, { as: "div" }, /* @__PURE__ */ React55.createElement(EmojiIcon3, null))), /* @__PURE__ */ React55.createElement(Popover.Portal, null, /* @__PURE__ */ React55.createElement(
|
4743
4847
|
Popover.Content,
|
4744
4848
|
{
|
4745
4849
|
alignOffset: -40,
|
@@ -4749,7 +4853,7 @@ function EmojiPicker({ onSelect }) {
|
|
4749
4853
|
p: 0
|
4750
4854
|
}
|
4751
4855
|
},
|
4752
|
-
/* @__PURE__ */
|
4856
|
+
/* @__PURE__ */ React55.createElement(
|
4753
4857
|
Box,
|
4754
4858
|
{
|
4755
4859
|
css: {
|
@@ -4758,7 +4862,7 @@ function EmojiPicker({ onSelect }) {
|
|
4758
4862
|
},
|
4759
4863
|
ref
|
4760
4864
|
},
|
4761
|
-
/* @__PURE__ */
|
4865
|
+
/* @__PURE__ */ React55.createElement(Picker, { onEmojiSelect: onSelect, data: data2, previewPosition: "none", skinPosition: "search" })
|
4762
4866
|
)
|
4763
4867
|
)));
|
4764
4868
|
}
|
@@ -4772,7 +4876,7 @@ var ChatFooter = ({
|
|
4772
4876
|
const hmsActions = useHMSActions18();
|
4773
4877
|
const inputRef = useRef12(null);
|
4774
4878
|
const [draftMessage, setDraftMessage] = useChatDraftMessage();
|
4775
|
-
const isMobile =
|
4879
|
+
const isMobile = useMedia13(config.media.md);
|
4776
4880
|
const { elements } = useRoomLayoutConferencingScreen();
|
4777
4881
|
const isOverlayChat = (_a = elements == null ? void 0 : elements.chat) == null ? void 0 : _a.is_overlay;
|
4778
4882
|
const sendMessage = useCallback13(() => __async(void 0, null, function* () {
|
@@ -4798,19 +4902,19 @@ var ChatFooter = ({
|
|
4798
4902
|
ToastManager.addToast({ title: err.message });
|
4799
4903
|
}
|
4800
4904
|
}), [role, peerId, hmsActions, onSend]);
|
4801
|
-
|
4905
|
+
useEffect20(() => {
|
4802
4906
|
const messageElement = inputRef.current;
|
4803
4907
|
if (messageElement) {
|
4804
4908
|
messageElement.value = draftMessage;
|
4805
4909
|
}
|
4806
4910
|
}, [draftMessage]);
|
4807
|
-
|
4911
|
+
useEffect20(() => {
|
4808
4912
|
const messageElement = inputRef.current;
|
4809
4913
|
return () => {
|
4810
4914
|
setDraftMessage((messageElement == null ? void 0 : messageElement.value) || "");
|
4811
4915
|
};
|
4812
4916
|
}, [setDraftMessage]);
|
4813
|
-
return /* @__PURE__ */
|
4917
|
+
return /* @__PURE__ */ React55.createElement(React55.Fragment, null, /* @__PURE__ */ React55.createElement(Flex, { align: "center", css: { gap: "$4", w: "100%" } }, /* @__PURE__ */ React55.createElement(
|
4814
4918
|
Flex,
|
4815
4919
|
{
|
4816
4920
|
align: "center",
|
@@ -4831,7 +4935,7 @@ var ChatFooter = ({
|
|
4831
4935
|
}
|
4832
4936
|
},
|
4833
4937
|
children,
|
4834
|
-
/* @__PURE__ */
|
4938
|
+
/* @__PURE__ */ React55.createElement(
|
4835
4939
|
TextArea,
|
4836
4940
|
{
|
4837
4941
|
css: {
|
@@ -4859,7 +4963,7 @@ var ChatFooter = ({
|
|
4859
4963
|
onCopy: (e) => e.stopPropagation()
|
4860
4964
|
}
|
4861
4965
|
),
|
4862
|
-
!isMobile ? /* @__PURE__ */
|
4966
|
+
!isMobile ? /* @__PURE__ */ React55.createElement(
|
4863
4967
|
EmojiPicker,
|
4864
4968
|
{
|
4865
4969
|
onSelect: (emoji) => {
|
@@ -4869,7 +4973,7 @@ var ChatFooter = ({
|
|
4869
4973
|
}
|
4870
4974
|
}
|
4871
4975
|
) : null,
|
4872
|
-
/* @__PURE__ */
|
4976
|
+
/* @__PURE__ */ React55.createElement(
|
4873
4977
|
IconButton,
|
4874
4978
|
{
|
4875
4979
|
className: "send-msg",
|
@@ -4882,31 +4986,18 @@ var ChatFooter = ({
|
|
4882
4986
|
},
|
4883
4987
|
"data-testid": "send_msg_btn"
|
4884
4988
|
},
|
4885
|
-
/* @__PURE__ */
|
4989
|
+
/* @__PURE__ */ React55.createElement(SendIcon, null)
|
4886
4990
|
)
|
4887
4991
|
)));
|
4888
4992
|
};
|
4889
4993
|
|
4890
|
-
// src/Prebuilt/components/Chat/useUnreadCount.js
|
4891
|
-
import {
|
4892
|
-
selectMessagesUnreadCountByPeerID,
|
4893
|
-
selectMessagesUnreadCountByRole,
|
4894
|
-
selectUnreadHMSMessagesCount as selectUnreadHMSMessagesCount2,
|
4895
|
-
useHMSStore as useHMSStore28
|
4896
|
-
} from "@100mslive/react-sdk";
|
4897
|
-
var useUnreadCount = ({ role, peerId }) => {
|
4898
|
-
const unreadCountSelector = role ? selectMessagesUnreadCountByRole(role) : peerId ? selectMessagesUnreadCountByPeerID(peerId) : selectUnreadHMSMessagesCount2;
|
4899
|
-
const unreadCount = useHMSStore28(unreadCountSelector);
|
4900
|
-
return unreadCount;
|
4901
|
-
};
|
4902
|
-
|
4903
4994
|
// src/Prebuilt/components/Chat/Chat.jsx
|
4904
4995
|
var PINNED_MESSAGE_LENGTH = 80;
|
4905
4996
|
var PinnedMessage = ({ clearPinnedMessage }) => {
|
4906
4997
|
const permissions = useHMSStore29(selectPermissions10);
|
4907
4998
|
const pinnedMessage = useHMSStore29(selectSessionStore(SESSION_STORE_KEY.PINNED_MESSAGE));
|
4908
4999
|
const formattedPinnedMessage = (pinnedMessage == null ? void 0 : pinnedMessage.length) && pinnedMessage.length > PINNED_MESSAGE_LENGTH ? `${pinnedMessage.slice(0, PINNED_MESSAGE_LENGTH)}...` : pinnedMessage;
|
4909
|
-
return pinnedMessage ? /* @__PURE__ */
|
5000
|
+
return pinnedMessage ? /* @__PURE__ */ React56.createElement(
|
4910
5001
|
Flex,
|
4911
5002
|
{
|
4912
5003
|
title: pinnedMessage,
|
@@ -4914,8 +5005,8 @@ var PinnedMessage = ({ clearPinnedMessage }) => {
|
|
4914
5005
|
align: "center",
|
4915
5006
|
justify: "between"
|
4916
5007
|
},
|
4917
|
-
/* @__PURE__ */
|
4918
|
-
/* @__PURE__ */
|
5008
|
+
/* @__PURE__ */ React56.createElement(PinIcon2, null),
|
5009
|
+
/* @__PURE__ */ React56.createElement(
|
4919
5010
|
Box,
|
4920
5011
|
{
|
4921
5012
|
css: {
|
@@ -4925,15 +5016,15 @@ var PinnedMessage = ({ clearPinnedMessage }) => {
|
|
4925
5016
|
overflowY: "auto"
|
4926
5017
|
}
|
4927
5018
|
},
|
4928
|
-
/* @__PURE__ */
|
5019
|
+
/* @__PURE__ */ React56.createElement(Text, { variant: "sm" }, /* @__PURE__ */ React56.createElement(AnnotisedMessage, { message: formattedPinnedMessage }))
|
4929
5020
|
),
|
4930
|
-
permissions.removeOthers && /* @__PURE__ */
|
5021
|
+
permissions.removeOthers && /* @__PURE__ */ React56.createElement(
|
4931
5022
|
Flex,
|
4932
5023
|
{
|
4933
5024
|
onClick: () => clearPinnedMessage(),
|
4934
5025
|
css: { cursor: "pointer", color: "$on_surface_medium", "&:hover": { color: "$on_surface_high" } }
|
4935
5026
|
},
|
4936
|
-
/* @__PURE__ */
|
5027
|
+
/* @__PURE__ */ React56.createElement(CrossIcon6, null)
|
4937
5028
|
)
|
4938
5029
|
) : null;
|
4939
5030
|
};
|
@@ -4952,7 +5043,7 @@ var Chat = ({ screenType }) => {
|
|
4952
5043
|
const listRef = useRef13(null);
|
4953
5044
|
const hmsActions = useHMSActions19();
|
4954
5045
|
const { setPinnedMessage } = useSetPinnedMessage();
|
4955
|
-
|
5046
|
+
useEffect21(() => {
|
4956
5047
|
if (notification && notification.data && peerSelector === notification.data.id) {
|
4957
5048
|
setPeerSelector("");
|
4958
5049
|
setChatOptions({
|
@@ -4964,7 +5055,7 @@ var Chat = ({ screenType }) => {
|
|
4964
5055
|
}, [notification, peerSelector, setPeerSelector]);
|
4965
5056
|
const storeMessageSelector = selectHMSMessagesCount;
|
4966
5057
|
const { elements } = useRoomLayoutConferencingScreen();
|
4967
|
-
const isMobile =
|
5058
|
+
const isMobile = useMedia14(config.media.md);
|
4968
5059
|
let isScrolledToBottom = false;
|
4969
5060
|
if (listRef.current) {
|
4970
5061
|
const currentRef = listRef.current._outerRef;
|
@@ -4985,7 +5076,7 @@ var Chat = ({ screenType }) => {
|
|
4985
5076
|
},
|
4986
5077
|
[hmsActions, messagesCount]
|
4987
5078
|
);
|
4988
|
-
return /* @__PURE__ */
|
5079
|
+
return /* @__PURE__ */ React56.createElement(
|
4989
5080
|
Flex,
|
4990
5081
|
{
|
4991
5082
|
direction: "column",
|
@@ -4994,8 +5085,8 @@ var Chat = ({ screenType }) => {
|
|
4994
5085
|
gap: "$4"
|
4995
5086
|
}
|
4996
5087
|
},
|
4997
|
-
isMobile && ((_a = elements == null ? void 0 : elements.chat) == null ? void 0 : _a.is_overlay) ? null : /* @__PURE__ */
|
4998
|
-
/* @__PURE__ */
|
5088
|
+
isMobile && ((_a = elements == null ? void 0 : elements.chat) == null ? void 0 : _a.is_overlay) ? null : /* @__PURE__ */ React56.createElement(React56.Fragment, null, ((_b = elements == null ? void 0 : elements.chat) == null ? void 0 : _b.allow_pinning_messages) ? /* @__PURE__ */ React56.createElement(PinnedMessage, { clearPinnedMessage: setPinnedMessage }) : null),
|
5089
|
+
/* @__PURE__ */ React56.createElement(
|
4999
5090
|
ChatBody,
|
5000
5091
|
{
|
5001
5092
|
role: chatOptions.role,
|
@@ -5005,7 +5096,7 @@ var Chat = ({ screenType }) => {
|
|
5005
5096
|
screenType
|
5006
5097
|
}
|
5007
5098
|
),
|
5008
|
-
/* @__PURE__ */
|
5099
|
+
/* @__PURE__ */ React56.createElement(
|
5009
5100
|
ChatFooter,
|
5010
5101
|
{
|
5011
5102
|
role: chatOptions.role,
|
@@ -5023,7 +5114,7 @@ var Chat = ({ screenType }) => {
|
|
5023
5114
|
},
|
5024
5115
|
peerId: chatOptions.peerId
|
5025
5116
|
},
|
5026
|
-
!isSelectorOpen && !isScrolledToBottom && /* @__PURE__ */
|
5117
|
+
!isSelectorOpen && !isScrolledToBottom && /* @__PURE__ */ React56.createElement(NewMessageIndicator, { role: chatOptions.role, peerId: chatOptions.peerId, scrollToBottom })
|
5027
5118
|
)
|
5028
5119
|
);
|
5029
5120
|
};
|
@@ -5032,7 +5123,7 @@ var NewMessageIndicator = ({ role, peerId, scrollToBottom }) => {
|
|
5032
5123
|
if (!unreadCount) {
|
5033
5124
|
return null;
|
5034
5125
|
}
|
5035
|
-
return /* @__PURE__ */
|
5126
|
+
return /* @__PURE__ */ React56.createElement(
|
5036
5127
|
Flex,
|
5037
5128
|
{
|
5038
5129
|
justify: "center",
|
@@ -5043,7 +5134,7 @@ var NewMessageIndicator = ({ role, peerId, scrollToBottom }) => {
|
|
5043
5134
|
position: "absolute"
|
5044
5135
|
}
|
5045
5136
|
},
|
5046
|
-
/* @__PURE__ */
|
5137
|
+
/* @__PURE__ */ React56.createElement(
|
5047
5138
|
Button,
|
5048
5139
|
{
|
5049
5140
|
variant: "standard",
|
@@ -5066,7 +5157,7 @@ var NewMessageIndicator = ({ role, peerId, scrollToBottom }) => {
|
|
5066
5157
|
},
|
5067
5158
|
"New ",
|
5068
5159
|
unreadCount === 1 ? "message" : "messages",
|
5069
|
-
/* @__PURE__ */
|
5160
|
+
/* @__PURE__ */ React56.createElement(ChevronDownIcon2, null)
|
5070
5161
|
)
|
5071
5162
|
);
|
5072
5163
|
};
|
@@ -5081,9 +5172,9 @@ var tabTriggerCSS = {
|
|
5081
5172
|
justifyContent: "center"
|
5082
5173
|
};
|
5083
5174
|
var ParticipantCount2 = ({ count }) => {
|
5084
|
-
return count < 1e3 ? /* @__PURE__ */
|
5175
|
+
return count < 1e3 ? /* @__PURE__ */ React57.createElement("span", null, "(", count, ")") : /* @__PURE__ */ React57.createElement(Tooltip, { title: count }, /* @__PURE__ */ React57.createElement("span", null, "(", getFormattedCount(count), ")"));
|
5085
5176
|
};
|
5086
|
-
var SidePaneTabs =
|
5177
|
+
var SidePaneTabs = React57.memo(({ active = SIDE_PANE_OPTIONS.CHAT, screenType, hideControls }) => {
|
5087
5178
|
var _a;
|
5088
5179
|
const toggleChat = useSidepaneToggle(SIDE_PANE_OPTIONS.CHAT);
|
5089
5180
|
const toggleParticipants = useSidepaneToggle(SIDE_PANE_OPTIONS.PARTICIPANTS);
|
@@ -5094,10 +5185,10 @@ var SidePaneTabs = React55.memo(({ active = SIDE_PANE_OPTIONS.CHAT, screenType,
|
|
5094
5185
|
const showChat = !!(elements == null ? void 0 : elements.chat);
|
5095
5186
|
const showParticipants = !!(elements == null ? void 0 : elements.participant_list);
|
5096
5187
|
const hideTabs = !(showChat && showParticipants);
|
5097
|
-
const isMobile =
|
5188
|
+
const isMobile = useMedia15(config.media.md);
|
5098
5189
|
const isOverlayChat = !!((_a = elements == null ? void 0 : elements.chat) == null ? void 0 : _a.is_overlay) && isMobile;
|
5099
5190
|
const isChatOpen = useIsSidepaneTypeOpen(SIDE_PANE_OPTIONS.CHAT);
|
5100
|
-
|
5191
|
+
useEffect22(() => {
|
5101
5192
|
if (activeTab === SIDE_PANE_OPTIONS.CHAT && !showChat && showParticipants) {
|
5102
5193
|
setActiveTab(SIDE_PANE_OPTIONS.PARTICIPANTS);
|
5103
5194
|
} else if (activeTab === SIDE_PANE_OPTIONS.PARTICIPANTS && showChat && !showParticipants) {
|
@@ -5106,10 +5197,10 @@ var SidePaneTabs = React55.memo(({ active = SIDE_PANE_OPTIONS.CHAT, screenType,
|
|
5106
5197
|
resetSidePane();
|
5107
5198
|
}
|
5108
5199
|
}, [showChat, activeTab, showParticipants, resetSidePane]);
|
5109
|
-
|
5200
|
+
useEffect22(() => {
|
5110
5201
|
setActiveTab(active);
|
5111
5202
|
}, [active]);
|
5112
|
-
return /* @__PURE__ */
|
5203
|
+
return /* @__PURE__ */ React57.createElement(
|
5113
5204
|
Flex,
|
5114
5205
|
{
|
5115
5206
|
direction: "column",
|
@@ -5120,7 +5211,7 @@ var SidePaneTabs = React55.memo(({ active = SIDE_PANE_OPTIONS.CHAT, screenType,
|
|
5120
5211
|
transition: "margin 0.3s ease-in-out"
|
5121
5212
|
}
|
5122
5213
|
},
|
5123
|
-
isOverlayChat && isChatOpen && showChat ? /* @__PURE__ */
|
5214
|
+
isOverlayChat && isChatOpen && showChat ? /* @__PURE__ */ React57.createElement(Chat, { screenType }) : /* @__PURE__ */ React57.createElement(React57.Fragment, null, hideTabs ? /* @__PURE__ */ React57.createElement(React57.Fragment, null, /* @__PURE__ */ React57.createElement(Text, { variant: "sm", css: { fontWeight: "$semiBold", p: "$4", c: "$on_surface_high", pr: "$12" } }, showChat ? "Chat" : /* @__PURE__ */ React57.createElement("span", null, "Participants ", /* @__PURE__ */ React57.createElement(ParticipantCount2, { count: peerCount }))), showChat ? /* @__PURE__ */ React57.createElement(Chat, { screenType }) : /* @__PURE__ */ React57.createElement(ParticipantList, null)) : /* @__PURE__ */ React57.createElement(
|
5124
5215
|
Tabs.Root,
|
5125
5216
|
{
|
5126
5217
|
value: activeTab,
|
@@ -5130,7 +5221,7 @@ var SidePaneTabs = React55.memo(({ active = SIDE_PANE_OPTIONS.CHAT, screenType,
|
|
5130
5221
|
size: "100%"
|
5131
5222
|
}
|
5132
5223
|
},
|
5133
|
-
/* @__PURE__ */
|
5224
|
+
/* @__PURE__ */ React57.createElement(Tabs.List, { css: { w: "calc(100% - $12)", p: "$2", borderRadius: "$2", bg: "$surface_default" } }, /* @__PURE__ */ React57.createElement(
|
5134
5225
|
Tabs.Trigger,
|
5135
5226
|
{
|
5136
5227
|
value: SIDE_PANE_OPTIONS.CHAT,
|
@@ -5140,7 +5231,7 @@ var SidePaneTabs = React55.memo(({ active = SIDE_PANE_OPTIONS.CHAT, screenType,
|
|
5140
5231
|
})
|
5141
5232
|
},
|
5142
5233
|
"Chat"
|
5143
|
-
), /* @__PURE__ */
|
5234
|
+
), /* @__PURE__ */ React57.createElement(
|
5144
5235
|
Tabs.Trigger,
|
5145
5236
|
{
|
5146
5237
|
value: SIDE_PANE_OPTIONS.PARTICIPANTS,
|
@@ -5150,12 +5241,12 @@ var SidePaneTabs = React55.memo(({ active = SIDE_PANE_OPTIONS.CHAT, screenType,
|
|
5150
5241
|
})
|
5151
5242
|
},
|
5152
5243
|
"Participants ",
|
5153
|
-
/* @__PURE__ */
|
5244
|
+
/* @__PURE__ */ React57.createElement(ParticipantCount2, { count: peerCount })
|
5154
5245
|
)),
|
5155
|
-
/* @__PURE__ */
|
5156
|
-
/* @__PURE__ */
|
5246
|
+
/* @__PURE__ */ React57.createElement(Tabs.Content, { value: SIDE_PANE_OPTIONS.PARTICIPANTS, css: { p: 0 } }, /* @__PURE__ */ React57.createElement(ParticipantList, null)),
|
5247
|
+
/* @__PURE__ */ React57.createElement(Tabs.Content, { value: SIDE_PANE_OPTIONS.CHAT, css: { p: 0 } }, /* @__PURE__ */ React57.createElement(Chat, { screenType }))
|
5157
5248
|
)),
|
5158
|
-
isOverlayChat && isChatOpen ? null : /* @__PURE__ */
|
5249
|
+
isOverlayChat && isChatOpen ? null : /* @__PURE__ */ React57.createElement(
|
5159
5250
|
IconButton,
|
5160
5251
|
{
|
5161
5252
|
css: { position: "absolute", right: "$10", top: "$11", "@md": { top: "$8", right: "$8" } },
|
@@ -5169,13 +5260,13 @@ var SidePaneTabs = React55.memo(({ active = SIDE_PANE_OPTIONS.CHAT, screenType,
|
|
5169
5260
|
},
|
5170
5261
|
"data-testid": "close_chat"
|
5171
5262
|
},
|
5172
|
-
/* @__PURE__ */
|
5263
|
+
/* @__PURE__ */ React57.createElement(CrossIcon7, null)
|
5173
5264
|
)
|
5174
5265
|
);
|
5175
5266
|
});
|
5176
5267
|
|
5177
5268
|
// src/Prebuilt/components/Streaming/StreamingLanding.jsx
|
5178
|
-
import
|
5269
|
+
import React59, { Fragment as Fragment10, useState as useState34 } from "react";
|
5179
5270
|
import { selectPermissions as selectPermissions11, useHMSStore as useHMSStore32, useRecordingStreaming as useRecordingStreaming7 } from "@100mslive/react-sdk";
|
5180
5271
|
import { ColoredHandIcon, CrossIcon as CrossIcon8, GoLiveIcon as GoLiveIcon3 } from "@100mslive/react-icons";
|
5181
5272
|
|
@@ -5183,7 +5274,7 @@ import { ColoredHandIcon, CrossIcon as CrossIcon8, GoLiveIcon as GoLiveIcon3 } f
|
|
5183
5274
|
var rtmp_default = "";
|
5184
5275
|
|
5185
5276
|
// src/Prebuilt/components/Streaming/HLSStreaming.jsx
|
5186
|
-
import
|
5277
|
+
import React58, { Fragment as Fragment9, useCallback as useCallback15, useEffect as useEffect23, useState as useState33 } from "react";
|
5187
5278
|
import { selectRoomID, useHMSActions as useHMSActions20, useHMSStore as useHMSStore31, useRecordingStreaming as useRecordingStreaming6 } from "@100mslive/react-sdk";
|
5188
5279
|
import {
|
5189
5280
|
EndStreamIcon as EndStreamIcon2,
|
@@ -5203,7 +5294,7 @@ var getCardData = (roleName, roomId) => {
|
|
5203
5294
|
data3 = {
|
5204
5295
|
title: formattedRoleName,
|
5205
5296
|
content: "Broadcasters can livestream audio or video, manage stream appearance and control the room via HLS.",
|
5206
|
-
icon: /* @__PURE__ */
|
5297
|
+
icon: /* @__PURE__ */ React58.createElement(SupportIcon, null)
|
5207
5298
|
};
|
5208
5299
|
break;
|
5209
5300
|
}
|
@@ -5211,7 +5302,7 @@ var getCardData = (roleName, roomId) => {
|
|
5211
5302
|
data3 = {
|
5212
5303
|
title: "HLS Viewer",
|
5213
5304
|
content: "Viewers can view and send chat messages, but need to be made broadcasters to participate with audio or video.",
|
5214
|
-
icon: /* @__PURE__ */
|
5305
|
+
icon: /* @__PURE__ */ React58.createElement(EyeOpenIcon, null)
|
5215
5306
|
};
|
5216
5307
|
break;
|
5217
5308
|
}
|
@@ -5219,7 +5310,7 @@ var getCardData = (roleName, roomId) => {
|
|
5219
5310
|
data3 = {
|
5220
5311
|
title: formattedRoleName,
|
5221
5312
|
content: `${formattedRoleName} is customised with specific permissions, which will determine how it interacts with this room.`,
|
5222
|
-
icon: /* @__PURE__ */
|
5313
|
+
icon: /* @__PURE__ */ React58.createElement(WrenchIcon, null),
|
5223
5314
|
order: 1
|
5224
5315
|
};
|
5225
5316
|
}
|
@@ -5228,7 +5319,7 @@ var getCardData = (roleName, roomId) => {
|
|
5228
5319
|
};
|
5229
5320
|
var Card = ({ title, icon, link, content, isHLSRunning, order = 0 }) => {
|
5230
5321
|
const [copied, setCopied] = useState33(false);
|
5231
|
-
return isHLSRunning ? /* @__PURE__ */
|
5322
|
+
return isHLSRunning ? /* @__PURE__ */ React58.createElement(
|
5232
5323
|
Box,
|
5233
5324
|
{
|
5234
5325
|
key: title,
|
@@ -5239,9 +5330,9 @@ var Card = ({ title, icon, link, content, isHLSRunning, order = 0 }) => {
|
|
5239
5330
|
borderRadius: "$2"
|
5240
5331
|
}
|
5241
5332
|
},
|
5242
|
-
/* @__PURE__ */
|
5243
|
-
/* @__PURE__ */
|
5244
|
-
/* @__PURE__ */
|
5333
|
+
/* @__PURE__ */ React58.createElement(Flex, { align: "center", gap: "2", css: { color: "$primary_bright" } }, icon, /* @__PURE__ */ React58.createElement(Text, { variant: "h6", css: { fontWeight: "$semiBold" } }, title)),
|
5334
|
+
/* @__PURE__ */ React58.createElement(Text, { variant: "sm", css: { color: "$on_surface_medium", mt: "$6" } }, content),
|
5335
|
+
/* @__PURE__ */ React58.createElement(
|
5245
5336
|
Button,
|
5246
5337
|
{
|
5247
5338
|
variant: "standard",
|
@@ -5253,7 +5344,7 @@ var Card = ({ title, icon, link, content, isHLSRunning, order = 0 }) => {
|
|
5253
5344
|
css: { w: "100%", r: "$1", mt: "$10", fontWeight: "$semiBold" },
|
5254
5345
|
icon: true
|
5255
5346
|
},
|
5256
|
-
copied ? /* @__PURE__ */
|
5347
|
+
copied ? /* @__PURE__ */ React58.createElement(React58.Fragment, null, "Link copied!") : /* @__PURE__ */ React58.createElement(React58.Fragment, null, /* @__PURE__ */ React58.createElement(LinkIcon, { style: { color: "inherit" } }), "Copy Invite Link")
|
5257
5348
|
)
|
5258
5349
|
) : null;
|
5259
5350
|
};
|
@@ -5263,7 +5354,7 @@ var HLSStreaming = ({ onBack }) => {
|
|
5263
5354
|
const cards = roleNames.map((roleName) => getCardData(roleName, roomId));
|
5264
5355
|
const { isHLSRunning } = useRecordingStreaming6();
|
5265
5356
|
const [showLinks, setShowLinks] = useState33(false);
|
5266
|
-
return !showLinks ? /* @__PURE__ */
|
5357
|
+
return !showLinks ? /* @__PURE__ */ React58.createElement(Container, { rounded: true }, /* @__PURE__ */ React58.createElement(ContentHeader, { title: "Start Streaming", content: "HLS", onBack }), /* @__PURE__ */ React58.createElement(ContentBody, { title: "HLS Streaming", Icon: GoLiveIcon2, removeVerticalPadding: true }, "Stream directly from the browser using any device with multiple hosts and real-time messaging, all within this platform."), isHLSRunning ? /* @__PURE__ */ React58.createElement(EndHLS, { setShowLinks }) : /* @__PURE__ */ React58.createElement(StartHLS, null)) : /* @__PURE__ */ React58.createElement(Container, { rounded: true }, /* @__PURE__ */ React58.createElement(ContentHeader, { title: "Invite People", content: "Start the conversation", onBack: () => setShowLinks(false) }), /* @__PURE__ */ React58.createElement(Flex, { direction: "column", css: { gap: "$10", p: "$0 $10", overflowY: "auto", mb: "$10" } }, cards.map((card) => /* @__PURE__ */ React58.createElement(Card, __spreadProps(__spreadValues({ key: card.title }, card), { isHLSRunning })))));
|
5267
5358
|
};
|
5268
5359
|
var StartHLS = () => {
|
5269
5360
|
const [record, setRecord] = useState33(false);
|
@@ -5289,7 +5380,7 @@ var StartHLS = () => {
|
|
5289
5380
|
}),
|
5290
5381
|
[hmsActions, record, isHLSStarted, setHLSStarted]
|
5291
5382
|
);
|
5292
|
-
return /* @__PURE__ */
|
5383
|
+
return /* @__PURE__ */ React58.createElement(Fragment9, null, /* @__PURE__ */ React58.createElement(RecordStream, { record, setRecord, testId: "hls-recording" }), /* @__PURE__ */ React58.createElement(Box, { css: { p: "$4 $10" } }, /* @__PURE__ */ React58.createElement(ErrorText, { error }), /* @__PURE__ */ React58.createElement(
|
5293
5384
|
Button,
|
5294
5385
|
{
|
5295
5386
|
"data-testid": "start_hls",
|
@@ -5298,21 +5389,21 @@ var StartHLS = () => {
|
|
5298
5389
|
onClick: () => startHLS(),
|
5299
5390
|
disabled: isHLSStarted
|
5300
5391
|
},
|
5301
|
-
isHLSStarted ? /* @__PURE__ */
|
5392
|
+
isHLSStarted ? /* @__PURE__ */ React58.createElement(Loading, { size: 24, color: "currentColor" }) : /* @__PURE__ */ React58.createElement(GoLiveIcon2, null),
|
5302
5393
|
isHLSStarted ? "Starting stream..." : "Go Live"
|
5303
|
-
)), /* @__PURE__ */
|
5394
|
+
)), /* @__PURE__ */ React58.createElement(Flex, { align: "center", css: { p: "$4 $10" } }, /* @__PURE__ */ React58.createElement(Text, null, /* @__PURE__ */ React58.createElement(InfoIcon4, { width: 16, height: 16 })), /* @__PURE__ */ React58.createElement(Text, { variant: "tiny", color: "$on_surface_medium", css: { mx: "$8" } }, "You cannot start recording once the stream starts, you will have to stop the stream to enable recording.")));
|
5304
5395
|
};
|
5305
5396
|
var EndHLS = ({ setShowLinks }) => {
|
5306
5397
|
const hmsActions = useHMSActions20();
|
5307
5398
|
const [inProgress, setInProgress] = useState33(false);
|
5308
5399
|
const [error, setError] = useState33("");
|
5309
5400
|
const { isHLSRunning } = useRecordingStreaming6();
|
5310
|
-
|
5401
|
+
useEffect23(() => {
|
5311
5402
|
if (inProgress && !isHLSRunning) {
|
5312
5403
|
setInProgress(false);
|
5313
5404
|
}
|
5314
5405
|
}, [inProgress, isHLSRunning]);
|
5315
|
-
return /* @__PURE__ */
|
5406
|
+
return /* @__PURE__ */ React58.createElement(Box, { css: { p: "$4 $10" } }, /* @__PURE__ */ React58.createElement(ErrorText, { error }), /* @__PURE__ */ React58.createElement(
|
5316
5407
|
Button,
|
5317
5408
|
{
|
5318
5409
|
"data-testid": "stop_hls",
|
@@ -5331,9 +5422,9 @@ var EndHLS = ({ setShowLinks }) => {
|
|
5331
5422
|
}
|
5332
5423
|
})
|
5333
5424
|
},
|
5334
|
-
/* @__PURE__ */
|
5425
|
+
/* @__PURE__ */ React58.createElement(EndStreamIcon2, null),
|
5335
5426
|
"End Stream"
|
5336
|
-
), /* @__PURE__ */
|
5427
|
+
), /* @__PURE__ */ React58.createElement(Button, { icon: true, css: { w: "100%", r: "$0", mt: "$8" }, onClick: () => setShowLinks(true) }, /* @__PURE__ */ React58.createElement(PeopleIcon3, null), " Invite People"));
|
5337
5428
|
};
|
5338
5429
|
|
5339
5430
|
// src/Prebuilt/components/Streaming/StreamingLanding.jsx
|
@@ -5347,7 +5438,7 @@ var StreamingLanding = () => {
|
|
5347
5438
|
toggleStreaming();
|
5348
5439
|
return null;
|
5349
5440
|
}
|
5350
|
-
return /* @__PURE__ */
|
5441
|
+
return /* @__PURE__ */ React59.createElement(Fragment10, null, /* @__PURE__ */ React59.createElement(Flex, { css: { w: "100%", py: "$8" } }, /* @__PURE__ */ React59.createElement(
|
5351
5442
|
Box,
|
5352
5443
|
{
|
5353
5444
|
css: {
|
@@ -5357,8 +5448,8 @@ var StreamingLanding = () => {
|
|
5357
5448
|
r: "$round"
|
5358
5449
|
}
|
5359
5450
|
},
|
5360
|
-
/* @__PURE__ */
|
5361
|
-
), /* @__PURE__ */
|
5451
|
+
/* @__PURE__ */ React59.createElement(ColoredHandIcon, { width: 40, height: 40 })
|
5452
|
+
), /* @__PURE__ */ React59.createElement(Box, { css: { flex: "1 1 0", mx: "$8" } }, /* @__PURE__ */ React59.createElement(Text, { variant: "sm" }, "Welcome !"), /* @__PURE__ */ React59.createElement(Text, { variant: "h6" }, "Let\u2019s get you started")), /* @__PURE__ */ React59.createElement(IconButton_default, { onClick: toggleStreaming, css: { alignSelf: "flex-start" }, "data-testid": "close_streaming" }, /* @__PURE__ */ React59.createElement(CrossIcon8, null))), /* @__PURE__ */ React59.createElement(Text, { variant: "tiny", color: "$on_surface_medium" }, "Start Streaming"), (permissions == null ? void 0 : permissions.hlsStreaming) && /* @__PURE__ */ React59.createElement(
|
5362
5453
|
StreamCard,
|
5363
5454
|
{
|
5364
5455
|
testId: "hls_stream",
|
@@ -5368,7 +5459,7 @@ var StreamingLanding = () => {
|
|
5368
5459
|
onClick: () => setShowHLS(true),
|
5369
5460
|
Icon: GoLiveIcon3
|
5370
5461
|
}
|
5371
|
-
), (permissions == null ? void 0 : permissions.rtmpStreaming) && /* @__PURE__ */
|
5462
|
+
), (permissions == null ? void 0 : permissions.rtmpStreaming) && /* @__PURE__ */ React59.createElement(
|
5372
5463
|
StreamCard,
|
5373
5464
|
{
|
5374
5465
|
testId: "rtmp_stream",
|
@@ -5380,7 +5471,7 @@ var StreamingLanding = () => {
|
|
5380
5471
|
},
|
5381
5472
|
imgSrc: rtmp_default
|
5382
5473
|
}
|
5383
|
-
), showHLS && /* @__PURE__ */
|
5474
|
+
), showHLS && /* @__PURE__ */ React59.createElement(HLSStreaming, { onBack: () => setShowHLS(false) }), showRTMP && /* @__PURE__ */ React59.createElement(RTMPStreaming, { onBack: () => setShowRTMP(false) }));
|
5384
5475
|
};
|
5385
5476
|
|
5386
5477
|
// src/Prebuilt/layouts/SidePane.tsx
|
@@ -5390,16 +5481,16 @@ var SidePane = ({
|
|
5390
5481
|
hideControls = false
|
5391
5482
|
}) => {
|
5392
5483
|
var _a, _b;
|
5393
|
-
const isMobile =
|
5484
|
+
const isMobile = useMedia16(config.media.md);
|
5394
5485
|
const sidepane = useHMSStore33(selectAppData3(APP_DATA.sidePane));
|
5395
5486
|
const activeScreensharePeerId = useHMSStore33(selectAppData3(APP_DATA.activeScreensharePeerId));
|
5396
5487
|
const trackId = (_a = useHMSStore33(selectVideoTrackByPeerID(activeScreensharePeerId))) == null ? void 0 : _a.id;
|
5397
5488
|
const { elements } = useRoomLayoutConferencingScreen();
|
5398
5489
|
let ViewComponent;
|
5399
5490
|
if (sidepane === SIDE_PANE_OPTIONS.PARTICIPANTS || sidepane === SIDE_PANE_OPTIONS.CHAT) {
|
5400
|
-
ViewComponent = /* @__PURE__ */
|
5491
|
+
ViewComponent = /* @__PURE__ */ React60.createElement(SidePaneTabs, { screenType, hideControls, active: sidepane });
|
5401
5492
|
} else if (sidepane === SIDE_PANE_OPTIONS.STREAMING) {
|
5402
|
-
ViewComponent = /* @__PURE__ */
|
5493
|
+
ViewComponent = /* @__PURE__ */ React60.createElement(StreamingLanding, null);
|
5403
5494
|
}
|
5404
5495
|
if (!ViewComponent && !trackId) {
|
5405
5496
|
return null;
|
@@ -5412,7 +5503,7 @@ var SidePane = ({
|
|
5412
5503
|
objectFit: tileProps == null ? void 0 : tileProps.video_object_fit
|
5413
5504
|
};
|
5414
5505
|
const mwebStreamingChat = isMobile && sidepane === SIDE_PANE_OPTIONS.CHAT && ((_b = elements == null ? void 0 : elements.chat) == null ? void 0 : _b.is_overlay);
|
5415
|
-
return /* @__PURE__ */
|
5506
|
+
return /* @__PURE__ */ React60.createElement(
|
5416
5507
|
Flex,
|
5417
5508
|
{
|
5418
5509
|
direction: "column",
|
@@ -5425,17 +5516,16 @@ var SidePane = ({
|
|
5425
5516
|
"@md": { position: mwebStreamingChat ? "absolute" : "", zIndex: 12 }
|
5426
5517
|
}
|
5427
5518
|
},
|
5428
|
-
trackId && /* @__PURE__ */
|
5519
|
+
trackId && /* @__PURE__ */ React60.createElement(
|
5429
5520
|
VideoTile_default,
|
5430
5521
|
__spreadValues({
|
5431
5522
|
peerId: activeScreensharePeerId,
|
5432
5523
|
trackId,
|
5433
|
-
width: "100%",
|
5434
5524
|
height: 225,
|
5435
5525
|
rootCSS: { p: 0, alignSelf: "start", flexShrink: 0 }
|
5436
5526
|
}, tileLayout)
|
5437
5527
|
),
|
5438
|
-
!!ViewComponent && /* @__PURE__ */
|
5528
|
+
!!ViewComponent && /* @__PURE__ */ React60.createElement(
|
5439
5529
|
Box,
|
5440
5530
|
{
|
5441
5531
|
css: {
|
@@ -5471,10 +5561,10 @@ var SidePane = ({
|
|
5471
5561
|
var SidePane_default = SidePane;
|
5472
5562
|
|
5473
5563
|
// src/Prebuilt/layouts/WaitingView.jsx
|
5474
|
-
import
|
5564
|
+
import React61 from "react";
|
5475
5565
|
import { ColoredTimeIcon } from "@100mslive/react-icons";
|
5476
|
-
var WaitingView =
|
5477
|
-
return /* @__PURE__ */
|
5566
|
+
var WaitingView = React61.memo(() => {
|
5567
|
+
return /* @__PURE__ */ React61.createElement(
|
5478
5568
|
Box,
|
5479
5569
|
{
|
5480
5570
|
css: {
|
@@ -5488,7 +5578,7 @@ var WaitingView = React59.memo(() => {
|
|
5488
5578
|
},
|
5489
5579
|
"data-testid": "waiting_view"
|
5490
5580
|
},
|
5491
|
-
/* @__PURE__ */
|
5581
|
+
/* @__PURE__ */ React61.createElement(
|
5492
5582
|
Flex,
|
5493
5583
|
{
|
5494
5584
|
align: "center",
|
@@ -5502,8 +5592,8 @@ var WaitingView = React59.memo(() => {
|
|
5502
5592
|
gap: "$8"
|
5503
5593
|
}
|
5504
5594
|
},
|
5505
|
-
/* @__PURE__ */
|
5506
|
-
/* @__PURE__ */
|
5595
|
+
/* @__PURE__ */ React61.createElement(ColoredTimeIcon, { width: "80px", height: "80px" }),
|
5596
|
+
/* @__PURE__ */ React61.createElement(
|
5507
5597
|
Flex,
|
5508
5598
|
{
|
5509
5599
|
direction: "column",
|
@@ -5513,28 +5603,28 @@ var WaitingView = React59.memo(() => {
|
|
5513
5603
|
gap: "$4"
|
5514
5604
|
}
|
5515
5605
|
},
|
5516
|
-
/* @__PURE__ */
|
5517
|
-
/* @__PURE__ */
|
5606
|
+
/* @__PURE__ */ React61.createElement(Text, { color: "white", variant: "h6", css: { "@md": { fontSize: "$md" } } }, "Please wait"),
|
5607
|
+
/* @__PURE__ */ React61.createElement(Text, { color: "$on_surface_medium", css: { mt: "$4", "@md": { fontSize: "$sm" } } }, "Sit back and relax till others let you join.")
|
5518
5608
|
)
|
5519
5609
|
)
|
5520
5610
|
);
|
5521
5611
|
});
|
5522
5612
|
|
5523
5613
|
// src/Prebuilt/layouts/VideoStreamingSection.tsx
|
5524
|
-
var HLSView =
|
5614
|
+
var HLSView = React62.lazy(() => import("./HLSView-3S74KF3A.js"));
|
5525
5615
|
var VideoStreamingSection = ({
|
5526
5616
|
screenType,
|
5527
5617
|
elements,
|
5528
5618
|
hideControls = false
|
5529
5619
|
}) => {
|
5530
5620
|
var _a, _b;
|
5531
|
-
const localPeerRole = useHMSStore34(
|
5621
|
+
const localPeerRole = useHMSStore34(selectLocalPeerRoleName3);
|
5532
5622
|
const isConnected = useHMSStore34(selectIsConnectedToRoom6);
|
5533
5623
|
const hmsActions = useHMSActions21();
|
5534
5624
|
const waitingViewerRole = useWaitingViewerRole();
|
5535
5625
|
const urlToIframe = useUrlToEmbed();
|
5536
5626
|
const pdfAnnotatorActive = usePDFAnnotator();
|
5537
|
-
|
5627
|
+
useEffect24(() => {
|
5538
5628
|
if (!isConnected) {
|
5539
5629
|
return;
|
5540
5630
|
}
|
@@ -5545,17 +5635,17 @@ var VideoStreamingSection = ({
|
|
5545
5635
|
}
|
5546
5636
|
let ViewComponent;
|
5547
5637
|
if (screenType === "hls_live_streaming") {
|
5548
|
-
ViewComponent = /* @__PURE__ */
|
5638
|
+
ViewComponent = /* @__PURE__ */ React62.createElement(HLSView, null);
|
5549
5639
|
} else if (localPeerRole === waitingViewerRole) {
|
5550
|
-
ViewComponent = /* @__PURE__ */
|
5640
|
+
ViewComponent = /* @__PURE__ */ React62.createElement(WaitingView, null);
|
5551
5641
|
} else if (pdfAnnotatorActive) {
|
5552
|
-
ViewComponent = /* @__PURE__ */
|
5642
|
+
ViewComponent = /* @__PURE__ */ React62.createElement(PDFView, null);
|
5553
5643
|
} else if (urlToIframe) {
|
5554
|
-
ViewComponent = /* @__PURE__ */
|
5644
|
+
ViewComponent = /* @__PURE__ */ React62.createElement(EmbedView, null);
|
5555
5645
|
} else {
|
5556
|
-
ViewComponent = /* @__PURE__ */
|
5646
|
+
ViewComponent = /* @__PURE__ */ React62.createElement(GridLayout, __spreadValues({}, (_a = elements == null ? void 0 : elements.video_tile_layout) == null ? void 0 : _a.grid));
|
5557
5647
|
}
|
5558
|
-
return /* @__PURE__ */
|
5648
|
+
return /* @__PURE__ */ React62.createElement(Suspense2, { fallback: /* @__PURE__ */ React62.createElement(FullPageProgress_default, null) }, /* @__PURE__ */ React62.createElement(
|
5559
5649
|
Flex,
|
5560
5650
|
{
|
5561
5651
|
css: {
|
@@ -5565,7 +5655,7 @@ var VideoStreamingSection = ({
|
|
5565
5655
|
}
|
5566
5656
|
},
|
5567
5657
|
ViewComponent,
|
5568
|
-
/* @__PURE__ */
|
5658
|
+
/* @__PURE__ */ React62.createElement(
|
5569
5659
|
SidePane_default,
|
5570
5660
|
{
|
5571
5661
|
screenType,
|
@@ -5576,80 +5666,6 @@ var VideoStreamingSection = ({
|
|
5576
5666
|
));
|
5577
5667
|
};
|
5578
5668
|
|
5579
|
-
// src/Prebuilt/components/RoleChangeRequestModal.tsx
|
5580
|
-
import React61, { useEffect as useEffect24 } from "react";
|
5581
|
-
import {
|
5582
|
-
selectLocalPeerName,
|
5583
|
-
selectLocalPeerRoleName as selectLocalPeerRoleName3,
|
5584
|
-
selectRoleChangeRequest,
|
5585
|
-
useCustomEvent as useCustomEvent2,
|
5586
|
-
useHMSActions as useHMSActions22,
|
5587
|
-
useHMSStore as useHMSStore35
|
5588
|
-
} from "@100mslive/react-sdk";
|
5589
|
-
var RoleChangeRequestModal = () => {
|
5590
|
-
const hmsActions = useHMSActions22();
|
5591
|
-
const { updateMetaData } = useMyMetadata();
|
5592
|
-
const currentRole = useHMSStore35(selectLocalPeerRoleName3);
|
5593
|
-
const roleChangeRequest = useHMSStore35(selectRoleChangeRequest);
|
5594
|
-
const name = useHMSStore35(selectLocalPeerName);
|
5595
|
-
const { sendEvent } = useCustomEvent2({ type: ROLE_CHANGE_DECLINED });
|
5596
|
-
useEffect24(() => {
|
5597
|
-
if (!(roleChangeRequest == null ? void 0 : roleChangeRequest.role)) {
|
5598
|
-
return;
|
5599
|
-
}
|
5600
|
-
(() => __async(void 0, null, function* () {
|
5601
|
-
yield hmsActions.preview({ asRole: roleChangeRequest.role.name });
|
5602
|
-
}))();
|
5603
|
-
}, [hmsActions, roleChangeRequest, currentRole, updateMetaData]);
|
5604
|
-
if (!(roleChangeRequest == null ? void 0 : roleChangeRequest.role)) {
|
5605
|
-
return null;
|
5606
|
-
}
|
5607
|
-
const body = /* @__PURE__ */ React61.createElement(React61.Fragment, null, /* @__PURE__ */ React61.createElement(Text, { css: { fontWeight: 400, c: "$on_surface_medium", textAlign: "center" } }, "Setup your audio and video before joining"), /* @__PURE__ */ React61.createElement(
|
5608
|
-
Flex,
|
5609
|
-
{
|
5610
|
-
align: "center",
|
5611
|
-
justify: "center",
|
5612
|
-
css: {
|
5613
|
-
"@sm": { width: "100%" },
|
5614
|
-
flexDirection: "column",
|
5615
|
-
mt: "$6"
|
5616
|
-
}
|
5617
|
-
},
|
5618
|
-
/* @__PURE__ */ React61.createElement(PreviewTile, { name: name || "" }),
|
5619
|
-
/* @__PURE__ */ React61.createElement(PreviewControls, { hideSettings: true })
|
5620
|
-
));
|
5621
|
-
return /* @__PURE__ */ React61.createElement(
|
5622
|
-
RequestDialog,
|
5623
|
-
{
|
5624
|
-
title: `You're invited to join the ${roleChangeRequest.role.name} role`,
|
5625
|
-
onOpenChange: (value) => __async(void 0, null, function* () {
|
5626
|
-
var _a;
|
5627
|
-
if (!value) {
|
5628
|
-
yield hmsActions.rejectChangeRole(roleChangeRequest);
|
5629
|
-
sendEvent(__spreadProps(__spreadValues({}, roleChangeRequest), { peerName: name }), { peerId: (_a = roleChangeRequest.requestedBy) == null ? void 0 : _a.id });
|
5630
|
-
yield hmsActions.cancelMidCallPreview();
|
5631
|
-
yield hmsActions.lowerLocalPeerHand();
|
5632
|
-
}
|
5633
|
-
}),
|
5634
|
-
body,
|
5635
|
-
onAction: () => __async(void 0, null, function* () {
|
5636
|
-
yield hmsActions.acceptChangeRole(roleChangeRequest);
|
5637
|
-
yield updateMetaData({ prevRole: currentRole });
|
5638
|
-
yield hmsActions.lowerLocalPeerHand();
|
5639
|
-
}),
|
5640
|
-
actionText: "Accept"
|
5641
|
-
}
|
5642
|
-
);
|
5643
|
-
};
|
5644
|
-
var RequestDialog = ({
|
5645
|
-
open = true,
|
5646
|
-
onOpenChange,
|
5647
|
-
title,
|
5648
|
-
body,
|
5649
|
-
actionText = "Accept",
|
5650
|
-
onAction
|
5651
|
-
}) => /* @__PURE__ */ React61.createElement(Dialog.Root, { open, onOpenChange }, /* @__PURE__ */ React61.createElement(Dialog.Portal, null, /* @__PURE__ */ React61.createElement(Dialog.Overlay, null), /* @__PURE__ */ React61.createElement(Dialog.Content, { css: { p: "$10" } }, /* @__PURE__ */ React61.createElement(Dialog.Title, { css: { p: 0, display: "flex", flexDirection: "row", gap: "$md", justifyContent: "center" } }, /* @__PURE__ */ React61.createElement(Text, { variant: "h6" }, title)), /* @__PURE__ */ React61.createElement(Box, { css: { mt: "$4", mb: "$10" } }, body), /* @__PURE__ */ React61.createElement(Flex, { justify: "center", align: "center", css: { width: "100%", gap: "$md" } }, /* @__PURE__ */ React61.createElement(Box, { css: { width: "50%" } }, /* @__PURE__ */ React61.createElement(Dialog.Close, { css: { width: "100%" } }, /* @__PURE__ */ React61.createElement(Button, { variant: "standard", outlined: true, css: { width: "100%" } }, "Cancel"))), /* @__PURE__ */ React61.createElement(Box, { css: { width: "50%" } }, /* @__PURE__ */ React61.createElement(Button, { variant: "primary", css: { width: "100%" }, onClick: onAction }, actionText))))));
|
5652
|
-
|
5653
5669
|
// src/Prebuilt/components/conference.jsx
|
5654
5670
|
var Conference = () => {
|
5655
5671
|
var _a, _b, _c, _d, _e;
|
@@ -5658,12 +5674,12 @@ var Conference = () => {
|
|
5658
5674
|
const { userName, endpoints } = useHMSPrebuiltContext();
|
5659
5675
|
const screenProps = useRoomLayoutConferencingScreen();
|
5660
5676
|
const { isPreviewScreenEnabled } = useRoomLayoutPreviewScreen();
|
5661
|
-
const roomState =
|
5677
|
+
const roomState = useHMSStore35(selectRoomState);
|
5662
5678
|
const prevState = usePrevious(roomState);
|
5663
|
-
const isConnectedToRoom =
|
5664
|
-
const hmsActions =
|
5679
|
+
const isConnectedToRoom = useHMSStore35(selectIsConnectedToRoom7);
|
5680
|
+
const hmsActions = useHMSActions22();
|
5665
5681
|
const [hideControls, setHideControls] = useState35(false);
|
5666
|
-
const dropdownList =
|
5682
|
+
const dropdownList = useHMSStore35(selectAppData4(APP_DATA.dropdownList));
|
5667
5683
|
const authTokenInAppData = useAuthToken();
|
5668
5684
|
const headerRef = useRef14();
|
5669
5685
|
const footerRef = useRef14();
|
@@ -5728,9 +5744,9 @@ var Conference = () => {
|
|
5728
5744
|
};
|
5729
5745
|
}, []);
|
5730
5746
|
if (!isConnectedToRoom) {
|
5731
|
-
return /* @__PURE__ */
|
5747
|
+
return /* @__PURE__ */ React63.createElement(FullPageProgress_default, { text: "Joining..." });
|
5732
5748
|
}
|
5733
|
-
return /* @__PURE__ */
|
5749
|
+
return /* @__PURE__ */ React63.createElement(React63.Fragment, null, isHLSStarted ? /* @__PURE__ */ React63.createElement(Box, { css: { position: "fixed", zIndex: 100, w: "100%", h: "100%", left: 0, top: 0 } }, /* @__PURE__ */ React63.createElement(FullPageProgress_default, { text: "Starting live stream...", css: { opacity: 0.8, bg: "$background_dim" } })) : null, /* @__PURE__ */ React63.createElement(Flex, { css: { size: "100%", overflow: "hidden" }, direction: "column" }, !screenProps.hideSections.includes("header") && /* @__PURE__ */ React63.createElement(
|
5734
5750
|
Box,
|
5735
5751
|
{
|
5736
5752
|
ref: headerRef,
|
@@ -5744,8 +5760,8 @@ var Conference = () => {
|
|
5744
5760
|
},
|
5745
5761
|
"data-testid": "header"
|
5746
5762
|
},
|
5747
|
-
/* @__PURE__ */
|
5748
|
-
), /* @__PURE__ */
|
5763
|
+
/* @__PURE__ */ React63.createElement(Header, { elements: screenProps.elements, screenType: screenProps.screenType })
|
5764
|
+
), /* @__PURE__ */ React63.createElement(
|
5749
5765
|
Box,
|
5750
5766
|
{
|
5751
5767
|
css: {
|
@@ -5763,7 +5779,7 @@ var Conference = () => {
|
|
5763
5779
|
"data-testid": "conferencing",
|
5764
5780
|
onClick: toggleControls
|
5765
5781
|
},
|
5766
|
-
/* @__PURE__ */
|
5782
|
+
/* @__PURE__ */ React63.createElement(
|
5767
5783
|
VideoStreamingSection,
|
5768
5784
|
{
|
5769
5785
|
screenType: screenProps.screenType,
|
@@ -5771,7 +5787,7 @@ var Conference = () => {
|
|
5771
5787
|
hideControls
|
5772
5788
|
}
|
5773
5789
|
)
|
5774
|
-
), !screenProps.hideSections.includes("footer") && /* @__PURE__ */
|
5790
|
+
), !screenProps.hideSections.includes("footer") && /* @__PURE__ */ React63.createElement(
|
5775
5791
|
Box,
|
5776
5792
|
{
|
5777
5793
|
ref: footerRef,
|
@@ -5788,11 +5804,11 @@ var Conference = () => {
|
|
5788
5804
|
},
|
5789
5805
|
"data-testid": "footer"
|
5790
5806
|
},
|
5791
|
-
/* @__PURE__ */
|
5792
|
-
), /* @__PURE__ */
|
5807
|
+
/* @__PURE__ */ React63.createElement(Footer2, { elements: screenProps.elements, screenType: screenProps.screenType })
|
5808
|
+
), /* @__PURE__ */ React63.createElement(RoleChangeRequestModal, null), /* @__PURE__ */ React63.createElement(HLSFailureModal, null), /* @__PURE__ */ React63.createElement(ActivatedPIP, null)));
|
5793
5809
|
};
|
5794
5810
|
var conference_default = Conference;
|
5795
5811
|
export {
|
5796
5812
|
conference_default as default
|
5797
5813
|
};
|
5798
|
-
//# sourceMappingURL=conference-
|
5814
|
+
//# sourceMappingURL=conference-JNABIZBG.js.map
|