@100mslive/roomkit-react 0.1.7-alpha.0 → 0.1.7

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