@100mslive/roomkit-react 0.1.6-alpha.1 → 0.1.6-alpha.3

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