@100mslive/roomkit-react 0.1.6 → 0.1.7

Sign up to get free protection for your applications and to get access to all the features.
Files changed (51) hide show
  1. package/dist/{HLSView-4NSE37G7.js → HLSView-3S74KF3A.js} +23 -4
  2. package/dist/HLSView-3S74KF3A.js.map +7 -0
  3. package/dist/Prebuilt/components/RoleChangeRequest/RequestPrompt.d.ts +9 -0
  4. package/dist/VideoTile/StyledVideoTile.d.ts +445 -3
  5. package/dist/{VirtualBackground-A5UM363O.js → VirtualBackground-3TI5NA4V.js} +3 -3
  6. package/dist/{chunk-BUWIMYLW.js → chunk-36X4ZCLC.js} +2 -2
  7. package/dist/{chunk-NMOZ33TX.js → chunk-5DQ3WTED.js} +3 -2
  8. package/dist/{chunk-NMOZ33TX.js.map → chunk-5DQ3WTED.js.map} +2 -2
  9. package/dist/{chunk-Q6U22HIE.js → chunk-Z7P5WITU.js} +223 -200
  10. package/dist/chunk-Z7P5WITU.js.map +7 -0
  11. package/dist/{conference-S7R3O4OC.js → conference-JNABIZBG.js} +534 -504
  12. package/dist/conference-JNABIZBG.js.map +7 -0
  13. package/dist/index.cjs.js +1011 -924
  14. package/dist/index.cjs.js.map +4 -4
  15. package/dist/index.js +2 -2
  16. package/dist/meta.cjs.json +241 -167
  17. package/dist/meta.esbuild.json +276 -203
  18. package/package.json +6 -6
  19. package/src/Input/Input.tsx +1 -1
  20. package/src/Prebuilt/common/hooks.js +1 -2
  21. package/src/Prebuilt/common/utils.js +7 -2
  22. package/src/Prebuilt/components/Chat/ChatBody.jsx +125 -106
  23. package/src/Prebuilt/components/Chat/ChatFooter.tsx +1 -0
  24. package/src/Prebuilt/components/Footer/Footer.tsx +4 -1
  25. package/src/Prebuilt/components/Footer/ParticipantList.jsx +8 -9
  26. package/src/Prebuilt/components/Header/ParticipantFilter.jsx +9 -12
  27. package/src/Prebuilt/components/Leave/DesktopLeaveRoom.tsx +36 -44
  28. package/src/Prebuilt/components/Leave/MwebLeaveRoom.tsx +23 -35
  29. package/src/Prebuilt/components/MoreSettings/SplitComponents/MwebOptions.tsx +4 -2
  30. package/src/Prebuilt/components/Notifications/Notifications.jsx +14 -1
  31. package/src/Prebuilt/components/Notifications/PeerNotifications.jsx +4 -15
  32. package/src/Prebuilt/components/Preview/PreviewJoin.tsx +12 -5
  33. package/src/Prebuilt/components/RaiseHand.jsx +3 -6
  34. package/src/Prebuilt/components/RoleChangeRequest/RequestPrompt.tsx +66 -0
  35. package/src/Prebuilt/components/RoleChangeRequest/RoleChangeRequestModal.tsx +89 -0
  36. package/src/Prebuilt/components/SidePaneTabs.tsx +21 -2
  37. package/src/Prebuilt/components/VideoTile.jsx +24 -15
  38. package/src/Prebuilt/components/conference.jsx +1 -1
  39. package/src/Prebuilt/components/hooks/useMetadata.jsx +15 -4
  40. package/src/Prebuilt/layouts/HLSView.jsx +20 -1
  41. package/src/Prebuilt/layouts/SidePane.tsx +0 -1
  42. package/src/Tooltip/Tooltip.tsx +1 -1
  43. package/src/VideoTile/StyledVideoTile.tsx +10 -14
  44. package/src/fixtures/peers.ts +5 -3
  45. package/dist/HLSView-4NSE37G7.js.map +0 -7
  46. package/dist/chunk-Q6U22HIE.js.map +0 -7
  47. package/dist/conference-S7R3O4OC.js.map +0 -7
  48. package/src/Prebuilt/components/RoleChangeRequestModal.tsx +0 -120
  49. /package/dist/Prebuilt/components/{RoleChangeRequestModal.d.ts → RoleChangeRequest/RoleChangeRequestModal.d.ts} +0 -0
  50. /package/dist/{VirtualBackground-A5UM363O.js.map → VirtualBackground-3TI5NA4V.js.map} +0 -0
  51. /package/dist/{chunk-BUWIMYLW.js.map → chunk-36X4ZCLC.js.map} +0 -0
@@ -1,6 +1,6 @@
1
1
  import {
2
2
  ActionTile
3
- } from "./chunk-BUWIMYLW.js";
3
+ } from "./chunk-36X4ZCLC.js";
4
4
  import {
5
5
  APP_DATA,
6
6
  Accordion,
@@ -58,7 +58,6 @@ import {
58
58
  isChrome,
59
59
  isIOS,
60
60
  isIPadOS,
61
- isInternalRole,
62
61
  isMacOS,
63
62
  isScreenshareSupported,
64
63
  useAuthToken,
@@ -84,7 +83,7 @@ import {
84
83
  useUrlToEmbed,
85
84
  useUserPreferences,
86
85
  useWaitingViewerRole
87
- } from "./chunk-Q6U22HIE.js";
86
+ } from "./chunk-Z7P5WITU.js";
88
87
  import {
89
88
  Box,
90
89
  Flex,
@@ -103,10 +102,10 @@ import {
103
102
  slideLeftAndFade,
104
103
  styled,
105
104
  textEllipsis
106
- } from "./chunk-NMOZ33TX.js";
105
+ } from "./chunk-5DQ3WTED.js";
107
106
 
108
107
  // src/Prebuilt/components/conference.jsx
109
- 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";
110
109
  import { useNavigate, useParams } from "react-router-dom";
111
110
  import { usePrevious } from "react-use";
112
111
  import {
@@ -115,13 +114,14 @@ import {
115
114
  selectIsConnectedToRoom as selectIsConnectedToRoom7,
116
115
  selectRoomState,
117
116
  useHMSActions as useHMSActions22,
118
- useHMSStore as useHMSStore36
117
+ useHMSStore as useHMSStore35
119
118
  } from "@100mslive/react-sdk";
120
119
 
121
120
  // src/Prebuilt/components/Footer/Footer.tsx
122
121
  import React36, { Suspense, useEffect as useEffect6 } from "react";
123
122
  import { useMedia as useMedia5 } from "react-use";
124
123
  import { Chat_ChatState } from "@100mslive/types-prebuilt/elements/chat";
124
+ import { useAVToggle as useAVToggle2 } from "@100mslive/react-sdk";
125
125
 
126
126
  // src/Prebuilt/components/EmojiReaction.jsx
127
127
  import React2, { Fragment, useState } from "react";
@@ -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
@@ -1881,6 +1863,7 @@ import {
1881
1863
  selectIsConnectedToRoom as selectIsConnectedToRoom5,
1882
1864
  selectPeerCount,
1883
1865
  selectPermissions as selectPermissions6,
1866
+ useAVToggle,
1884
1867
  useHMSActions as useHMSActions9,
1885
1868
  useHMSStore as useHMSStore11,
1886
1869
  useRecordingStreaming as useRecordingStreaming5
@@ -1925,6 +1908,8 @@ var MwebOptions = ({
1925
1908
  const peerCount = useHMSStore11(selectPeerCount);
1926
1909
  const emojiCardRef = useRef5(null);
1927
1910
  const { isBRBOn, toggleBRB, isHandRaised, toggleHandRaise } = useMyMetadata();
1911
+ const { toggleAudio, toggleVideo } = useAVToggle();
1912
+ const noAVPermissions = !(toggleAudio || toggleVideo);
1928
1913
  useDropdownList({ open: openModals.size > 0 || openOptionsSheet || openSettingsSheet, name: "MoreSettings" });
1929
1914
  const updateState = (modalName, value) => {
1930
1915
  setOpenModals((modals) => {
@@ -1981,7 +1966,7 @@ var MwebOptions = ({
1981
1966
  /* @__PURE__ */ React22.createElement(PeopleIcon, null),
1982
1967
  /* @__PURE__ */ React22.createElement(ActionTile.Title, null, "Participants")
1983
1968
  ),
1984
- screenType !== "hls_live_streaming" ? /* @__PURE__ */ React22.createElement(
1969
+ !noAVPermissions ? /* @__PURE__ */ React22.createElement(
1985
1970
  ActionTile.Root,
1986
1971
  {
1987
1972
  active: isHandRaised,
@@ -2079,7 +2064,6 @@ var MwebOptions = ({
2079
2064
  ), showEmojiCard && /* @__PURE__ */ React22.createElement(
2080
2065
  Box,
2081
2066
  {
2082
- onClick: () => setShowEmojiCard(false),
2083
2067
  ref: emojiCardRef,
2084
2068
  css: {
2085
2069
  maxWidth: "100%",
@@ -2128,19 +2112,17 @@ var MoreSettings = ({
2128
2112
 
2129
2113
  // src/Prebuilt/components/RaiseHand.jsx
2130
2114
  import React24 from "react";
2131
- import { selectLocalPeer, selectPeerMetadata, useHMSStore as useHMSStore12 } from "@100mslive/react-sdk";
2132
2115
  import { HandIcon as HandIcon2 } from "@100mslive/react-icons";
2133
2116
  var RaiseHand = () => {
2134
- var _a;
2135
- const { toggleHandRaise } = useMyMetadata();
2136
- const localPeer = useHMSStore12(selectLocalPeer);
2137
- const isHandRaised = ((_a = useHMSStore12(selectPeerMetadata(localPeer.id))) == null ? void 0 : _a.isHandRaised) || false;
2138
- return /* @__PURE__ */ React24.createElement(Tooltip, { title: isHandRaised ? "Lower hand" : "Raise hand" }, /* @__PURE__ */ React24.createElement(IconButton_default, { active: !isHandRaised, onClick: toggleHandRaise }, /* @__PURE__ */ React24.createElement(HandIcon2, null)));
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)));
2139
2121
  };
2140
2122
 
2141
2123
  // src/Prebuilt/components/ScreenShareToggle.jsx
2142
2124
  import React31, { Fragment as Fragment6 } from "react";
2143
- 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";
2144
2126
  import { ShareScreenIcon } from "@100mslive/react-icons";
2145
2127
 
2146
2128
  // src/Prebuilt/components/pdfAnnotator/shareScreenOptions.jsx
@@ -2622,7 +2604,7 @@ function ShareScreenOptions() {
2622
2604
 
2623
2605
  // src/Prebuilt/components/ScreenShareToggle.jsx
2624
2606
  var ScreenshareToggle = ({ css = {} }) => {
2625
- const isAllowedToPublish = useHMSStore13(selectIsAllowedToPublish);
2607
+ const isAllowedToPublish = useHMSStore12(selectIsAllowedToPublish);
2626
2608
  const isAudioOnly = useUISettings(UI_SETTINGS.isAudioOnly);
2627
2609
  const { amIScreenSharing, screenShareVideoTrackId: video, toggleScreenShare } = useScreenShare2();
2628
2610
  const isVideoScreenshare = amIScreenSharing && !!video;
@@ -2647,10 +2629,10 @@ var ScreenshareToggle = ({ css = {} }) => {
2647
2629
 
2648
2630
  // src/Prebuilt/components/Footer/ChatToggle.tsx
2649
2631
  import React32 from "react";
2650
- import { selectUnreadHMSMessagesCount, useHMSStore as useHMSStore14 } from "@100mslive/react-sdk";
2632
+ import { selectUnreadHMSMessagesCount, useHMSStore as useHMSStore13 } from "@100mslive/react-sdk";
2651
2633
  import { ChatIcon, ChatUnreadIcon } from "@100mslive/react-icons";
2652
2634
  var ChatToggle = () => {
2653
- const countUnreadMessages = useHMSStore14(selectUnreadHMSMessagesCount);
2635
+ const countUnreadMessages = useHMSStore13(selectUnreadHMSMessagesCount);
2654
2636
  const isChatOpen = useIsSidepaneTypeOpen(SIDE_PANE_OPTIONS.CHAT);
2655
2637
  const toggleChat = useSidepaneToggle(SIDE_PANE_OPTIONS.CHAT);
2656
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" })));
@@ -2660,14 +2642,15 @@ var ChatToggle = () => {
2660
2642
  import React35, { Fragment as Fragment7, useCallback as useCallback6, useEffect as useEffect5, useState as useState18 } from "react";
2661
2643
  import { useDebounce, useMedia as useMedia4 } from "react-use";
2662
2644
  import {
2645
+ selectHandRaisedPeers,
2646
+ selectHasPeerHandRaised,
2663
2647
  selectIsPeerAudioEnabled,
2664
2648
  selectLocalPeerID as selectLocalPeerID4,
2665
2649
  selectPeerCount as selectPeerCount2,
2666
- selectPeerMetadata as selectPeerMetadata2,
2667
- selectPeersByCondition as selectPeersByCondition2,
2650
+ selectPeerMetadata,
2668
2651
  selectPermissions as selectPermissions8,
2669
2652
  useHMSActions as useHMSActions11,
2670
- useHMSStore as useHMSStore16
2653
+ useHMSStore as useHMSStore15
2671
2654
  } from "@100mslive/react-sdk";
2672
2655
  import {
2673
2656
  ChangeRoleIcon as ChangeRoleIcon2,
@@ -2686,7 +2669,7 @@ import { FixedSizeList } from "react-window";
2686
2669
 
2687
2670
  // src/Prebuilt/components/Footer/RoleOptions.tsx
2688
2671
  import React33, { useState as useState17 } from "react";
2689
- import { selectPermissions as selectPermissions7, useHMSActions as useHMSActions10, useHMSStore as useHMSStore15, useHMSVanillaStore as useHMSVanillaStore2 } from "@100mslive/react-sdk";
2672
+ import { selectPermissions as selectPermissions7, useHMSActions as useHMSActions10, useHMSStore as useHMSStore14, useHMSVanillaStore as useHMSVanillaStore2 } from "@100mslive/react-sdk";
2690
2673
  import {
2691
2674
  MicOffIcon as MicOffIcon2,
2692
2675
  MicOnIcon,
@@ -2700,7 +2683,7 @@ var dropdownItemCSS = { backgroundColor: "$surface_default", gap: "$4", p: "$8"
2700
2683
  var optionTextCSS = { fontWeight: "$semiBold", color: "$on_surface_high", textTransform: "none" };
2701
2684
  var RoleOptions = ({ roleName, peerList }) => {
2702
2685
  const [openOptions, setOpenOptions] = useState17(false);
2703
- const permissions = useHMSStore15(selectPermissions7);
2686
+ const permissions = useHMSStore14(selectPermissions7);
2704
2687
  const hmsActions = useHMSActions10();
2705
2688
  const { elements } = useRoomLayoutConferencingScreen();
2706
2689
  const { on_stage_role, off_stage_roles = [] } = (elements == null ? void 0 : elements.on_stage_exp) || {};
@@ -2873,10 +2856,7 @@ var ParticipantList = () => {
2873
2856
  const [filter, setFilter] = useState18();
2874
2857
  const { participants, isConnected, peerCount } = useParticipants(filter);
2875
2858
  const peersOrderedByRoles = {};
2876
- const handRaisedPeers = useHMSStore16(selectPeersByCondition2((peer) => {
2877
- var _a;
2878
- return (_a = JSON.parse(peer.metadata || "{}")) == null ? void 0 : _a.isHandRaised;
2879
- }));
2859
+ const handRaisedPeers = useHMSStore15(selectHandRaisedPeers);
2880
2860
  participants.forEach((participant) => {
2881
2861
  if (peersOrderedByRoles[participant.roleName] === void 0) {
2882
2862
  peersOrderedByRoles[participant.roleName] = [];
@@ -2906,7 +2886,7 @@ var ParticipantList = () => {
2906
2886
  )));
2907
2887
  };
2908
2888
  var ParticipantCount = () => {
2909
- const peerCount = useHMSStore16(selectPeerCount2);
2889
+ const peerCount = useHMSStore15(selectPeerCount2);
2910
2890
  const toggleSidepane = useSidepaneToggle(SIDE_PANE_OPTIONS.PARTICIPANTS);
2911
2891
  const isParticipantsOpen = useIsSidepaneTypeOpen(SIDE_PANE_OPTIONS.PARTICIPANTS);
2912
2892
  useEffect5(() => {
@@ -2934,7 +2914,7 @@ var ParticipantCount = () => {
2934
2914
  "data-testid": "participant_list"
2935
2915
  },
2936
2916
  /* @__PURE__ */ React35.createElement(PeopleIcon2, null),
2937
- /* @__PURE__ */ React35.createElement(Text, { variant: "sm", css: { mx: "$4", c: "inherit" } }, peerCount)
2917
+ /* @__PURE__ */ React35.createElement(Text, { variant: "sm", css: { mx: "$4", c: "inherit" } }, getFormattedCount(peerCount))
2938
2918
  );
2939
2919
  };
2940
2920
  var VirtualizedParticipants = ({ peersOrderedByRoles = {}, isConnected, filter, handRaisedList = [] }) => {
@@ -2974,7 +2954,7 @@ var VirtualizedParticipants = ({ peersOrderedByRoles = {}, isConnected, filter,
2974
2954
  );
2975
2955
  };
2976
2956
  var Participant = ({ peer, isConnected }) => {
2977
- const localPeerId = useHMSStore16(selectLocalPeerID4);
2957
+ const localPeerId = useHMSStore15(selectLocalPeerID4);
2978
2958
  return /* @__PURE__ */ React35.createElement(
2979
2959
  Flex,
2980
2960
  {
@@ -2995,11 +2975,11 @@ var Participant = ({ peer, isConnected }) => {
2995
2975
  );
2996
2976
  };
2997
2977
  var ParticipantActions = React35.memo(({ peerId, role, isLocal }) => {
2998
- var _a, _b;
2999
- const isHandRaised = (_a = useHMSStore16(selectPeerMetadata2(peerId))) == null ? void 0 : _a.isHandRaised;
3000
- const canChangeRole = (_b = useHMSStore16(selectPermissions8)) == null ? void 0 : _b.changeRole;
2978
+ var _a;
2979
+ const isHandRaised = useHMSStore15(selectHasPeerHandRaised(peerId));
2980
+ const canChangeRole = (_a = useHMSStore15(selectPermissions8)) == null ? void 0 : _a.changeRole;
3001
2981
  const shouldShowMoreActions = canChangeRole;
3002
- const isAudioMuted = !useHMSStore16(selectIsPeerAudioEnabled(peerId));
2982
+ const isAudioMuted = !useHMSStore15(selectIsPeerAudioEnabled(peerId));
3003
2983
  return /* @__PURE__ */ React35.createElement(
3004
2984
  Flex,
3005
2985
  {
@@ -3028,13 +3008,13 @@ var ParticipantActions = React35.memo(({ peerId, role, isLocal }) => {
3028
3008
  },
3029
3009
  /* @__PURE__ */ React35.createElement(MicOffIcon3, { height: 19, width: 19 })
3030
3010
  ) : null,
3031
- shouldShowMoreActions && !isInternalRole(role) && !isLocal ? /* @__PURE__ */ React35.createElement(ParticipantMoreActions, { peerId, role }) : null
3011
+ shouldShowMoreActions && !isLocal ? /* @__PURE__ */ React35.createElement(ParticipantMoreActions, { peerId, role }) : null
3032
3012
  );
3033
3013
  });
3034
3014
  var ParticipantMoreActions = ({ peerId, role }) => {
3035
3015
  var _a;
3036
3016
  const hmsActions = useHMSActions11();
3037
- const { changeRole: canChangeRole, removeOthers: canRemoveOthers } = useHMSStore16(selectPermissions8);
3017
+ const { changeRole: canChangeRole, removeOthers: canRemoveOthers } = useHMSStore15(selectPermissions8);
3038
3018
  const { elements } = useRoomLayoutConferencingScreen();
3039
3019
  const {
3040
3020
  bring_to_stage_label,
@@ -3044,8 +3024,8 @@ var ParticipantMoreActions = ({ peerId, role }) => {
3044
3024
  } = elements.on_stage_exp || {};
3045
3025
  const isInStage = role === on_stage_role;
3046
3026
  const shouldShowStageRoleChange = canChangeRole && (isInStage && remove_from_stage_label || (off_stage_roles == null ? void 0 : off_stage_roles.includes(role)) && bring_to_stage_label);
3047
- const prevRole = (_a = useHMSStore16(selectPeerMetadata2(peerId))) == null ? void 0 : _a.prevRole;
3048
- const localPeerId = useHMSStore16(selectLocalPeerID4);
3027
+ const prevRole = (_a = useHMSStore15(selectPeerMetadata(peerId))) == null ? void 0 : _a.prevRole;
3028
+ const localPeerId = useHMSStore15(selectLocalPeerID4);
3049
3029
  const isLocal = localPeerId === peerId;
3050
3030
  const [open, setOpen] = useState18(false);
3051
3031
  const handleStageAction = () => __async(void 0, null, function* () {
@@ -3121,7 +3101,7 @@ var ParticipantSearch = ({ onSearch, placeholder, inSidePane = false }) => {
3121
3101
  {
3122
3102
  type: "text",
3123
3103
  placeholder: placeholder || "Search for participants",
3124
- 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" },
3125
3105
  value,
3126
3106
  onKeyDown: (event) => {
3127
3107
  event.stopPropagation();
@@ -3137,7 +3117,7 @@ var ParticipantSearch = ({ onSearch, placeholder, inSidePane = false }) => {
3137
3117
  };
3138
3118
 
3139
3119
  // src/Prebuilt/components/Footer/Footer.tsx
3140
- var VirtualBackground = React36.lazy(() => import("./VirtualBackground-A5UM363O.js"));
3120
+ var VirtualBackground = React36.lazy(() => import("./VirtualBackground-3TI5NA4V.js"));
3141
3121
  var Footer2 = ({
3142
3122
  screenType,
3143
3123
  elements
@@ -3146,6 +3126,8 @@ var Footer2 = ({
3146
3126
  const isMobile = useMedia5(config.media.md);
3147
3127
  const isOverlayChat = !!((_a = elements == null ? void 0 : elements.chat) == null ? void 0 : _a.is_overlay);
3148
3128
  const openByDefault = ((_b = elements == null ? void 0 : elements.chat) == null ? void 0 : _b.initial_state) === Chat_ChatState.CHAT_STATE_OPEN;
3129
+ const { toggleAudio, toggleVideo } = useAVToggle2();
3130
+ const noAVPermissions = !(toggleAudio || toggleVideo);
3149
3131
  const isChatOpen = useIsSidepaneTypeOpen(SIDE_PANE_OPTIONS.CHAT);
3150
3132
  const toggleChat = useSidepaneToggle(SIDE_PANE_OPTIONS.CHAT);
3151
3133
  useEffect6(() => {
@@ -3192,7 +3174,7 @@ var Footer2 = ({
3192
3174
  }
3193
3175
  }
3194
3176
  },
3195
- isMobile ? /* @__PURE__ */ React36.createElement(React36.Fragment, null, screenType === "hls_live_streaming" ? /* @__PURE__ */ React36.createElement(RaiseHand, null) : null, (elements == null ? void 0 : elements.chat) && /* @__PURE__ */ React36.createElement(ChatToggle, null), /* @__PURE__ */ React36.createElement(MoreSettings, { elements, screenType })) : /* @__PURE__ */ React36.createElement(React36.Fragment, null, /* @__PURE__ */ React36.createElement(ScreenshareToggle, null), /* @__PURE__ */ React36.createElement(RaiseHand, null), (elements == null ? void 0 : elements.emoji_reactions) && /* @__PURE__ */ React36.createElement(EmojiReaction, null), /* @__PURE__ */ React36.createElement(LeaveRoom, { screenType }))
3177
+ isMobile ? /* @__PURE__ */ React36.createElement(React36.Fragment, null, noAVPermissions ? /* @__PURE__ */ React36.createElement(RaiseHand, null) : null, (elements == null ? void 0 : elements.chat) && /* @__PURE__ */ React36.createElement(ChatToggle, null), /* @__PURE__ */ React36.createElement(MoreSettings, { elements, screenType })) : /* @__PURE__ */ React36.createElement(React36.Fragment, null, /* @__PURE__ */ React36.createElement(ScreenshareToggle, null), /* @__PURE__ */ React36.createElement(RaiseHand, null), (elements == null ? void 0 : elements.emoji_reactions) && /* @__PURE__ */ React36.createElement(EmojiReaction, null), /* @__PURE__ */ React36.createElement(LeaveRoom, { screenType }))
3196
3178
  ),
3197
3179
  /* @__PURE__ */ React36.createElement(Footer.Right, null, !isMobile && (elements == null ? void 0 : elements.chat) && /* @__PURE__ */ React36.createElement(ChatToggle, null), (elements == null ? void 0 : elements.participant_list) && /* @__PURE__ */ React36.createElement(ParticipantCount, null), /* @__PURE__ */ React36.createElement(MoreSettings, { elements, screenType }))
3198
3180
  );
@@ -3200,9 +3182,9 @@ var Footer2 = ({
3200
3182
 
3201
3183
  // src/Prebuilt/components/Notifications/HLSFailureModal.jsx
3202
3184
  import React37, { useCallback as useCallback7, useState as useState19 } from "react";
3203
- import { selectHLSState as selectHLSState2, useHMSActions as useHMSActions12, useHMSStore as useHMSStore17 } from "@100mslive/react-sdk";
3185
+ import { selectHLSState as selectHLSState2, useHMSActions as useHMSActions12, useHMSStore as useHMSStore16 } from "@100mslive/react-sdk";
3204
3186
  function HLSFailureModal() {
3205
- const { hlsError } = useHMSStore17(selectHLSState2).error || false;
3187
+ const { hlsError } = useHMSStore16(selectHLSState2).error || false;
3206
3188
  const [openModal, setOpenModal] = useState19(!!hlsError);
3207
3189
  const hmsActions = useHMSActions12();
3208
3190
  const [isHLSStarted, setHLSStarted] = useSetAppDataByKey(APP_DATA.hlsStarted);
@@ -3247,29 +3229,128 @@ function HLSFailureModal() {
3247
3229
  ) : null;
3248
3230
  }
3249
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
+
3250
3331
  // src/Prebuilt/layouts/VideoStreamingSection.tsx
3251
- import React60, { Suspense as Suspense2, useEffect as useEffect23 } from "react";
3252
- import { selectIsConnectedToRoom as selectIsConnectedToRoom6, selectLocalPeerRoleName as selectLocalPeerRoleName2, useHMSActions as useHMSActions20, useHMSStore as useHMSStore34 } from "@100mslive/react-sdk";
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";
3253
3334
 
3254
3335
  // src/Prebuilt/components/VideoLayouts/GridLayout.tsx
3255
- 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";
3256
3337
  import { selectPeers as selectPeers2, selectPeerScreenSharing, useHMSStore as useHMSStore23, useHMSVanillaStore as useHMSVanillaStore4 } from "@100mslive/react-sdk";
3257
3338
 
3258
3339
  // src/Prebuilt/components/VideoLayouts/EqualProminence.tsx
3259
- import React42, { useEffect as useEffect10, useMemo as useMemo3, useState as useState21 } from "react";
3260
- import { useMedia as useMedia8 } from "react-use";
3261
- import { selectLocalPeer as selectLocalPeer3, useHMSStore as useHMSStore19 } from "@100mslive/react-sdk";
3340
+ import React44, { useEffect as useEffect11, useMemo as useMemo3, useState as useState21 } from "react";
3341
+ import { useMedia as useMedia9 } from "react-use";
3342
+ import { selectLocalPeer as selectLocalPeer2, useHMSStore as useHMSStore19 } from "@100mslive/react-sdk";
3262
3343
 
3263
3344
  // src/Prebuilt/components/InsetTile.tsx
3264
- import React39, { useEffect as useEffect7, useRef as useRef6 } from "react";
3345
+ import React41, { useEffect as useEffect8, useRef as useRef6 } from "react";
3265
3346
  import Draggable from "react-draggable";
3266
- import { useMedia as useMedia6 } from "react-use";
3267
- import { selectIsAllowedToPublish as selectIsAllowedToPublish2, selectLocalPeer as selectLocalPeer2, selectVideoTrackByID, useHMSStore as useHMSStore18 } from "@100mslive/react-sdk";
3347
+ import { useMedia as useMedia7 } from "react-use";
3348
+ import { selectIsAllowedToPublish as selectIsAllowedToPublish2, selectLocalPeer, selectVideoTrackByID, useHMSStore as useHMSStore18 } from "@100mslive/react-sdk";
3268
3349
  import { ExpandIcon as ExpandIcon2 } from "@100mslive/react-icons";
3269
3350
 
3270
3351
  // src/Prebuilt/components/hooks/useVideoTileLayout.ts
3271
- import React38, { useContext } from "react";
3272
- var VideoTileContext = React38.createContext({
3352
+ import React40, { useContext } from "react";
3353
+ var VideoTileContext = React40.createContext({
3273
3354
  enableSpotlightingPeer: true,
3274
3355
  hideParticipantNameOnTile: false,
3275
3356
  roundedVideoTile: true,
@@ -3285,14 +3366,14 @@ var useVideoTileContext = () => {
3285
3366
 
3286
3367
  // src/Prebuilt/components/InsetTile.tsx
3287
3368
  var MinimisedTile = ({ setMinimised }) => {
3288
- return /* @__PURE__ */ React39.createElement(Flex, { align: "center", css: { gap: "$6", r: "$1", bg: "$surface_default", p: "$4", color: "$on_surface_high" } }, /* @__PURE__ */ React39.createElement(AudioVideoToggle, { hideOptions: true }), /* @__PURE__ */ React39.createElement(Text, null, "You"), /* @__PURE__ */ React39.createElement(
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(
3289
3370
  IconButton_default,
3290
3371
  {
3291
3372
  className: "__cancel-drag-event",
3292
3373
  onClick: () => setMinimised(false),
3293
3374
  css: { bg: "transparent", border: "transparent" }
3294
3375
  },
3295
- /* @__PURE__ */ React39.createElement(ExpandIcon2, null)
3376
+ /* @__PURE__ */ React41.createElement(ExpandIcon2, null)
3296
3377
  ));
3297
3378
  };
3298
3379
  var insetHeightPx = 180;
@@ -3300,9 +3381,9 @@ var insetMaxWidthPx = 240;
3300
3381
  var defaultMobileAspectRatio = 9 / 16;
3301
3382
  var desktopAspectRatio = 1 / defaultMobileAspectRatio;
3302
3383
  var InsetTile = () => {
3303
- const isMobile = useMedia6(config.media.md);
3304
- const isLandscape = useMedia6(config.media.ls);
3305
- const localPeer = useHMSStore18(selectLocalPeer2);
3384
+ const isMobile = useMedia7(config.media.md);
3385
+ const isLandscape = useMedia7(config.media.ls);
3386
+ const localPeer = useHMSStore18(selectLocalPeer);
3306
3387
  const [minimised, setMinimised] = useSetAppDataByKey(APP_DATA.minimiseInset);
3307
3388
  const videoTrack = useHMSStore18(selectVideoTrackByID(localPeer == null ? void 0 : localPeer.videoTrack));
3308
3389
  const isAllowedToPublish = useHMSStore18(selectIsAllowedToPublish2);
@@ -3318,7 +3399,7 @@ var InsetTile = () => {
3318
3399
  height = width / aspectRatio;
3319
3400
  }
3320
3401
  const nodeRef = useRef6(null);
3321
- useEffect7(() => {
3402
+ useEffect8(() => {
3322
3403
  const node = nodeRef.current;
3323
3404
  if (!node || !window.ResizeObserver) {
3324
3405
  return;
@@ -3339,7 +3420,7 @@ var InsetTile = () => {
3339
3420
  if (!isAllowedToPublish.video && !isAllowedToPublish.audio) {
3340
3421
  return null;
3341
3422
  }
3342
- 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(
3343
3424
  Box,
3344
3425
  {
3345
3426
  ref: nodeRef,
@@ -3355,7 +3436,7 @@ var InsetTile = () => {
3355
3436
  h: height
3356
3437
  } : {})
3357
3438
  },
3358
- minimised ? /* @__PURE__ */ React39.createElement(MinimisedTile, { setMinimised }) : /* @__PURE__ */ React39.createElement(
3439
+ minimised ? /* @__PURE__ */ React41.createElement(MinimisedTile, { setMinimised }) : /* @__PURE__ */ React41.createElement(
3359
3440
  VideoTile_default,
3360
3441
  __spreadProps(__spreadValues({
3361
3442
  peerId: localPeer == null ? void 0 : localPeer.id,
@@ -3377,7 +3458,7 @@ var InsetTile = () => {
3377
3458
  };
3378
3459
 
3379
3460
  // src/Prebuilt/components/Pagination.tsx
3380
- import React40, { useEffect as useEffect8 } from "react";
3461
+ import React42, { useEffect as useEffect9 } from "react";
3381
3462
  import { ChevronLeftIcon as ChevronLeftIcon2, ChevronRightIcon as ChevronRightIcon2 } from "@100mslive/react-icons";
3382
3463
  var Pagination = ({
3383
3464
  page,
@@ -3394,7 +3475,7 @@ var Pagination = ({
3394
3475
  e.stopPropagation();
3395
3476
  onPageChange(Math.max(page - 1, 0));
3396
3477
  };
3397
- useEffect8(() => {
3478
+ useEffect9(() => {
3398
3479
  if (page >= numPages) {
3399
3480
  onPageChange(Math.max(0, numPages - 1));
3400
3481
  }
@@ -3402,7 +3483,7 @@ var Pagination = ({
3402
3483
  if (numPages <= 1) {
3403
3484
  return null;
3404
3485
  }
3405
- return /* @__PURE__ */ React40.createElement(StyledPagination.Root, { css: { flexShrink: 0 } }, /* @__PURE__ */ React40.createElement(StyledPagination.Chevron, { disabled: disableLeft, onClick: prevPage }, /* @__PURE__ */ React40.createElement(ChevronLeftIcon2, { width: 16, height: 16, style: { cursor: disableLeft ? "not-allowed" : "pointer" } })), numPages <= 5 ? /* @__PURE__ */ React40.createElement(StyledPagination.Dots, null, [...Array(numPages)].map((_, i) => /* @__PURE__ */ React40.createElement(
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(
3406
3487
  StyledPagination.Dot,
3407
3488
  {
3408
3489
  key: i,
@@ -3412,15 +3493,15 @@ var Pagination = ({
3412
3493
  onPageChange(i);
3413
3494
  }
3414
3495
  }
3415
- ))) : null, /* @__PURE__ */ React40.createElement(StyledPagination.Chevron, { disabled: disableRight, onClick: nextPage }, /* @__PURE__ */ React40.createElement(ChevronRightIcon2, { width: 16, height: 16, style: { cursor: disableRight ? "not-allowed" : "pointer" } })));
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" } })));
3416
3497
  };
3417
3498
 
3418
3499
  // src/Prebuilt/components/VideoLayouts/Grid.tsx
3419
- import React41 from "react";
3420
- var Grid = React41.forwardRef(
3500
+ import React43 from "react";
3501
+ var Grid = React43.forwardRef(
3421
3502
  ({ tiles, edgeToEdge }, ref) => {
3422
3503
  const videoTileProps = useVideoTileContext();
3423
- return /* @__PURE__ */ React41.createElement(
3504
+ return /* @__PURE__ */ React43.createElement(
3424
3505
  Box,
3425
3506
  {
3426
3507
  ref,
@@ -3438,7 +3519,7 @@ var Grid = React41.forwardRef(
3438
3519
  },
3439
3520
  tiles == null ? void 0 : tiles.map((tile) => {
3440
3521
  var _a, _b, _c, _d;
3441
- return /* @__PURE__ */ React41.createElement(
3522
+ return /* @__PURE__ */ React43.createElement(
3442
3523
  VideoTile_default,
3443
3524
  __spreadValues({
3444
3525
  key: ((_a = tile.track) == null ? void 0 : _a.id) || ((_b = tile.peer) == null ? void 0 : _b.id),
@@ -3456,8 +3537,8 @@ var Grid = React41.forwardRef(
3456
3537
  );
3457
3538
 
3458
3539
  // src/Prebuilt/components/hooks/useTileLayout.tsx
3459
- import { useEffect as useEffect9, useMemo as useMemo2, useState as useState20 } from "react";
3460
- 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";
3461
3542
  import {
3462
3543
  getPeersWithTiles,
3463
3544
  selectTracksMap as selectTracksMap3,
@@ -3493,9 +3574,9 @@ var useTileLayout = ({
3493
3574
  }) => {
3494
3575
  const vanillaStore = useHMSVanillaStore3();
3495
3576
  const [ref, { width, height }] = useMeasure2();
3496
- const isMobile = useMedia7(config.media.lg);
3577
+ const isMobile = useMedia8(config.media.lg);
3497
3578
  const [pagesWithTiles, setPagesWithTiles] = useState20([]);
3498
- useEffect9(() => {
3579
+ useEffect10(() => {
3499
3580
  if (width === 0 || height === 0) {
3500
3581
  return;
3501
3582
  }
@@ -3562,8 +3643,8 @@ var useTileLayout = ({
3562
3643
  // src/Prebuilt/components/VideoLayouts/EqualProminence.tsx
3563
3644
  function EqualProminence({ isInsetEnabled = false, peers, onPageChange, onPageSize, edgeToEdge }) {
3564
3645
  var _a;
3565
- const localPeer = useHMSStore19(selectLocalPeer3);
3566
- const isMobile = useMedia8(config.media.md);
3646
+ const localPeer = useHMSStore19(selectLocalPeer2);
3647
+ const isMobile = useMedia9(config.media.md);
3567
3648
  let maxTileCount = useUISettings(UI_SETTINGS.maxTileCount);
3568
3649
  maxTileCount = isMobile ? Math.min(maxTileCount, 6) : maxTileCount;
3569
3650
  let pageList = usePagesWithTiles({
@@ -3585,12 +3666,12 @@ function EqualProminence({ isInsetEnabled = false, peers, onPageChange, onPageSi
3585
3666
  });
3586
3667
  const [page, setPage] = useState21(0);
3587
3668
  const pageSize = ((_a = pagesWithTiles[0]) == null ? void 0 : _a.length) || 0;
3588
- useEffect10(() => {
3669
+ useEffect11(() => {
3589
3670
  if (pageSize > 0) {
3590
3671
  onPageSize == null ? void 0 : onPageSize(pageSize);
3591
3672
  }
3592
3673
  }, [pageSize, onPageSize]);
3593
- return /* @__PURE__ */ React42.createElement(Flex, { direction: "column", css: { flex: "1 1 0", h: "100%", position: "relative", minWidth: 0 } }, /* @__PURE__ */ React42.createElement(Grid, { tiles: pagesWithTiles[page], ref, edgeToEdge }), !edgeToEdge && /* @__PURE__ */ React42.createElement(
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(
3594
3675
  Pagination,
3595
3676
  {
3596
3677
  page,
@@ -3600,20 +3681,20 @@ function EqualProminence({ isInsetEnabled = false, peers, onPageChange, onPageSi
3600
3681
  },
3601
3682
  numPages: pagesWithTiles.length
3602
3683
  }
3603
- ), 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));
3604
3685
  }
3605
3686
 
3606
3687
  // src/Prebuilt/components/VideoLayouts/RoleProminence.tsx
3607
- import React45, { useEffect as useEffect12, useState as useState23 } from "react";
3608
- import { selectLocalPeer as selectLocalPeer4, useHMSStore as useHMSStore20 } from "@100mslive/react-sdk";
3688
+ import React47, { useEffect as useEffect13, useState as useState23 } from "react";
3689
+ import { selectLocalPeer as selectLocalPeer3, useHMSStore as useHMSStore20 } from "@100mslive/react-sdk";
3609
3690
 
3610
3691
  // src/Prebuilt/components/SecondaryTiles.tsx
3611
- import React44, { useEffect as useEffect11, useState as useState22 } from "react";
3612
- 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";
3613
3694
 
3614
3695
  // src/Prebuilt/components/VideoLayouts/ProminenceLayout.tsx
3615
- import React43 from "react";
3616
- var Root = ({ children, edgeToEdge }) => /* @__PURE__ */ React43.createElement(
3696
+ import React45 from "react";
3697
+ var Root = ({ children, edgeToEdge }) => /* @__PURE__ */ React45.createElement(
3617
3698
  Flex,
3618
3699
  {
3619
3700
  direction: "column",
@@ -3622,7 +3703,7 @@ var Root = ({ children, edgeToEdge }) => /* @__PURE__ */ React43.createElement(
3622
3703
  children
3623
3704
  );
3624
3705
  var ProminentSection = ({ children, css = {} }) => {
3625
- 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);
3626
3707
  };
3627
3708
  var SecondarySection = ({
3628
3709
  tiles,
@@ -3633,12 +3714,12 @@ var SecondarySection = ({
3633
3714
  if (!(tiles == null ? void 0 : tiles.length)) {
3634
3715
  return null;
3635
3716
  }
3636
- return /* @__PURE__ */ React43.createElement(
3717
+ return /* @__PURE__ */ React45.createElement(
3637
3718
  Box,
3638
3719
  {
3639
3720
  css: {
3640
3721
  display: "grid",
3641
- gridTemplateRows: React43.Children.count(children) > 0 ? "136px auto" : "154px",
3722
+ gridTemplateRows: React45.Children.count(children) > 0 ? "136px auto" : "154px",
3642
3723
  gridTemplateColumns: `repeat(${tiles.length}, minmax(0, 1fr))`,
3643
3724
  margin: "0 auto",
3644
3725
  gap: "$2 $4",
@@ -3648,7 +3729,7 @@ var SecondarySection = ({
3648
3729
  },
3649
3730
  tiles.map((tile) => {
3650
3731
  var _a, _b, _c, _d;
3651
- return /* @__PURE__ */ React43.createElement(
3732
+ return /* @__PURE__ */ React45.createElement(
3652
3733
  VideoTile_default,
3653
3734
  __spreadValues({
3654
3735
  key: ((_a = tile.track) == null ? void 0 : _a.id) || ((_b = tile.peer) == null ? void 0 : _b.id),
@@ -3665,7 +3746,7 @@ var SecondarySection = ({
3665
3746
  }, tileLayoutProps)
3666
3747
  );
3667
3748
  }),
3668
- /* @__PURE__ */ React43.createElement(Box, { css: { gridColumn: `1/span ${tiles.length}` } }, children)
3749
+ /* @__PURE__ */ React45.createElement(Box, { css: { gridColumn: `1/span ${tiles.length}` } }, children)
3669
3750
  );
3670
3751
  };
3671
3752
  var ProminenceLayout = {
@@ -3677,17 +3758,17 @@ var ProminenceLayout = {
3677
3758
  // src/Prebuilt/components/SecondaryTiles.tsx
3678
3759
  var SecondaryTiles = ({ peers, onPageChange, onPageSize, edgeToEdge }) => {
3679
3760
  var _a;
3680
- const isMobile = useMedia9(config.media.md);
3761
+ const isMobile = useMedia10(config.media.md);
3681
3762
  const maxTileCount = isMobile ? 2 : 4;
3682
3763
  const pagesWithTiles = usePagesWithTiles({ peers, maxTileCount });
3683
3764
  const [page, setPage] = useState22(0);
3684
3765
  const pageSize = ((_a = pagesWithTiles[0]) == null ? void 0 : _a.length) || 0;
3685
- useEffect11(() => {
3766
+ useEffect12(() => {
3686
3767
  if (pageSize > 0) {
3687
3768
  onPageSize == null ? void 0 : onPageSize(pageSize);
3688
3769
  }
3689
3770
  }, [pageSize, onPageSize]);
3690
- 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(
3691
3772
  Pagination,
3692
3773
  {
3693
3774
  page,
@@ -3745,7 +3826,7 @@ function RoleProminence({
3745
3826
  }) {
3746
3827
  var _a;
3747
3828
  const { prominentPeers, secondaryPeers } = useRoleProminencePeers(prominentRoles, peers, isInsetEnabled);
3748
- const localPeer = useHMSStore20(selectLocalPeer4);
3829
+ const localPeer = useHMSStore20(selectLocalPeer3);
3749
3830
  const maxTileCount = 4;
3750
3831
  const pageList = usePagesWithTiles({
3751
3832
  peers: prominentPeers,
@@ -3757,12 +3838,12 @@ function RoleProminence({
3757
3838
  });
3758
3839
  const [page, setPage] = useState23(0);
3759
3840
  const pageSize = ((_a = pagesWithTiles[0]) == null ? void 0 : _a.length) || 0;
3760
- useEffect12(() => {
3841
+ useEffect13(() => {
3761
3842
  if (pageSize > 0) {
3762
3843
  onPageSize == null ? void 0 : onPageSize(pageSize);
3763
3844
  }
3764
3845
  }, [pageSize, onPageSize]);
3765
- return /* @__PURE__ */ React45.createElement(ProminenceLayout.Root, null, /* @__PURE__ */ React45.createElement(ProminenceLayout.ProminentSection, null, /* @__PURE__ */ React45.createElement(Grid, { ref, tiles: pagesWithTiles[page] })), !edgeToEdge && /* @__PURE__ */ React45.createElement(
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(
3766
3847
  Pagination,
3767
3848
  {
3768
3849
  page,
@@ -3772,16 +3853,16 @@ function RoleProminence({
3772
3853
  },
3773
3854
  numPages: pagesWithTiles.length
3774
3855
  }
3775
- ), /* @__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));
3776
3857
  }
3777
3858
 
3778
3859
  // src/Prebuilt/components/VideoLayouts/ScreenshareLayout.tsx
3779
- import React48, { useEffect as useEffect13, useMemo as useMemo5, useState as useState25 } from "react";
3780
- 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";
3781
3862
  import { selectPeersScreenSharing, useHMSStore as useHMSStore22 } from "@100mslive/react-sdk";
3782
3863
 
3783
3864
  // src/Prebuilt/components/ScreenshareTile.jsx
3784
- import React47, { useRef as useRef7, useState as useState24 } from "react";
3865
+ import React49, { useRef as useRef7, useState as useState24 } from "react";
3785
3866
  import { useFullscreen as useFullscreen2 } from "react-use";
3786
3867
  import screenfull2 from "screenfull";
3787
3868
  import {
@@ -3794,12 +3875,12 @@ import {
3794
3875
  import { ExpandIcon as ExpandIcon3, ShrinkIcon } from "@100mslive/react-icons";
3795
3876
 
3796
3877
  // src/Prebuilt/components/ScreenshareDisplay.jsx
3797
- import React46 from "react";
3798
- import { useHMSActions as useHMSActions13 } from "@100mslive/react-sdk";
3878
+ import React48 from "react";
3879
+ import { useHMSActions as useHMSActions14 } from "@100mslive/react-sdk";
3799
3880
  import { CrossIcon as CrossIcon5, ShareScreenIcon as ShareScreenIcon2 } from "@100mslive/react-icons";
3800
3881
  var ScreenshareDisplay = () => {
3801
- const hmsActions = useHMSActions13();
3802
- return /* @__PURE__ */ React46.createElement(
3882
+ const hmsActions = useHMSActions14();
3883
+ return /* @__PURE__ */ React48.createElement(
3803
3884
  Flex,
3804
3885
  {
3805
3886
  direction: "column",
@@ -3811,9 +3892,9 @@ var ScreenshareDisplay = () => {
3811
3892
  color: "$on_surface_high"
3812
3893
  }
3813
3894
  },
3814
- /* @__PURE__ */ React46.createElement(ShareScreenIcon2, { width: 48, height: 48 }),
3815
- /* @__PURE__ */ React46.createElement(Text, { variant: "h5", css: { m: "$8 0" } }, "You are sharing your screen"),
3816
- /* @__PURE__ */ React46.createElement(
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(
3817
3898
  Button,
3818
3899
  {
3819
3900
  variant: "danger",
@@ -3823,7 +3904,7 @@ var ScreenshareDisplay = () => {
3823
3904
  }),
3824
3905
  "data-testid": "stop_screen_share_btn"
3825
3906
  },
3826
- /* @__PURE__ */ React46.createElement(CrossIcon5, { width: 18, height: 18 }),
3907
+ /* @__PURE__ */ React48.createElement(CrossIcon5, { width: 18, height: 18 }),
3827
3908
  "\xA0 Stop screen share"
3828
3909
  )
3829
3910
  );
@@ -3853,7 +3934,7 @@ var Tile = ({ peerId, width = "100%", height = "100%" }) => {
3853
3934
  const isFullScreenSupported = screenfull2.isEnabled;
3854
3935
  const audioTrack = useHMSStore21(selectScreenShareAudioByPeerID(peer == null ? void 0 : peer.id));
3855
3936
  if (isLocal && !["browser", "window", "application"].includes(track == null ? void 0 : track.displaySurface)) {
3856
- return /* @__PURE__ */ React47.createElement(ScreenshareDisplay, null);
3937
+ return /* @__PURE__ */ React49.createElement(ScreenshareDisplay, null);
3857
3938
  }
3858
3939
  if (!peer) {
3859
3940
  return null;
@@ -3863,7 +3944,7 @@ var Tile = ({ peerId, width = "100%", height = "100%" }) => {
3863
3944
  isLocal: false,
3864
3945
  track
3865
3946
  });
3866
- 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(
3867
3948
  StyledVideoTile.Container,
3868
3949
  {
3869
3950
  transparentBg: true,
@@ -3874,9 +3955,9 @@ var Tile = ({ peerId, width = "100%", height = "100%" }) => {
3874
3955
  setIsMouseHovered(false);
3875
3956
  }
3876
3957
  },
3877
- showStatsOnTiles ? /* @__PURE__ */ React47.createElement(VideoTileStats, { audioTrackID: audioTrack == null ? void 0 : audioTrack.id, videoTrackID: track == null ? void 0 : track.id, peerID: peerId, isLocal }) : null,
3878
- isFullScreenSupported && isMouseHovered ? /* @__PURE__ */ React47.createElement(StyledVideoTile.FullScreenButton, { onClick: () => setFullscreen(!fullscreen) }, isFullscreen ? /* @__PURE__ */ React47.createElement(ShrinkIcon, null) : /* @__PURE__ */ React47.createElement(ExpandIcon3, null)) : null,
3879
- track ? /* @__PURE__ */ React47.createElement(
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(
3880
3961
  Video,
3881
3962
  {
3882
3963
  screenShare: true,
@@ -3886,8 +3967,8 @@ var Tile = ({ peerId, width = "100%", height = "100%" }) => {
3886
3967
  css: { minHeight: 0 }
3887
3968
  }
3888
3969
  ) : null,
3889
- /* @__PURE__ */ React47.createElement(StyledVideoTile.Info, { css: labelStyles }, label),
3890
- isMouseHovered && !peer.isLocal ? /* @__PURE__ */ React47.createElement(
3970
+ /* @__PURE__ */ React49.createElement(StyledVideoTile.Info, { css: labelStyles }, label),
3971
+ isMouseHovered && !peer.isLocal ? /* @__PURE__ */ React49.createElement(
3891
3972
  TileMenu_default,
3892
3973
  {
3893
3974
  isScreenshare: true,
@@ -3899,7 +3980,7 @@ var Tile = ({ peerId, width = "100%", height = "100%" }) => {
3899
3980
  ) : null
3900
3981
  ));
3901
3982
  };
3902
- var ScreenshareTile = React47.memo(Tile);
3983
+ var ScreenshareTile = React49.memo(Tile);
3903
3984
  var ScreenshareTile_default = ScreenshareTile;
3904
3985
 
3905
3986
  // src/Prebuilt/components/VideoLayouts/ScreenshareLayout.tsx
@@ -3909,18 +3990,18 @@ var ScreenshareLayout = ({ peers, onPageChange, onPageSize, edgeToEdge }) => {
3909
3990
  const [, setActiveScreenSharePeer] = useSetAppDataByKey(APP_DATA.activeScreensharePeerId);
3910
3991
  const [page, setPage] = useState25(0);
3911
3992
  const activeSharePeer = peersSharing[page];
3912
- const isMobile = useMedia10(config.media.md);
3993
+ const isMobile = useMedia11(config.media.md);
3913
3994
  const secondaryPeers = useMemo5(
3914
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)),
3915
3996
  [activeSharePeer, peers, isMobile]
3916
3997
  );
3917
- useEffect13(() => {
3998
+ useEffect14(() => {
3918
3999
  setActiveScreenSharePeer(isMobile ? "" : activeSharePeer == null ? void 0 : activeSharePeer.id);
3919
4000
  return () => {
3920
4001
  setActiveScreenSharePeer("");
3921
4002
  };
3922
4003
  }, [activeSharePeer == null ? void 0 : activeSharePeer.id, isMobile, setActiveScreenSharePeer]);
3923
- return /* @__PURE__ */ React48.createElement(ProminenceLayout.Root, { edgeToEdge }, /* @__PURE__ */ React48.createElement(ProminenceLayout.ProminentSection, null, /* @__PURE__ */ React48.createElement(ScreenshareTile_default, { peerId: (_a = peersSharing[page]) == null ? void 0 : _a.id }), !edgeToEdge && /* @__PURE__ */ React48.createElement(Pagination, { page, onPageChange: setPage, numPages: peersSharing.length })), /* @__PURE__ */ React48.createElement(
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(
3924
4005
  SecondaryTiles,
3925
4006
  {
3926
4007
  peers: secondaryPeers,
@@ -4050,7 +4131,7 @@ var GridLayout = ({
4050
4131
  hideMetadataOnTile: hide_metadata_on_tile,
4051
4132
  objectFit: video_object_fit
4052
4133
  };
4053
- useEffect14(() => {
4134
+ useEffect15(() => {
4054
4135
  if (mainPage !== 0) {
4055
4136
  return;
4056
4137
  }
@@ -4061,7 +4142,7 @@ var GridLayout = ({
4061
4142
  peersSorter.onUpdate(setSortedPeers);
4062
4143
  }, [mainPage, peersSorter, updatedPeers, pageSize]);
4063
4144
  if (peerSharing) {
4064
- return /* @__PURE__ */ React49.createElement(VideoTileContext.Provider, { value: tileLayout }, /* @__PURE__ */ React49.createElement(
4145
+ return /* @__PURE__ */ React51.createElement(VideoTileContext.Provider, { value: tileLayout }, /* @__PURE__ */ React51.createElement(
4065
4146
  ScreenshareLayout,
4066
4147
  {
4067
4148
  peers: sortedPeers,
@@ -4071,7 +4152,7 @@ var GridLayout = ({
4071
4152
  }
4072
4153
  ));
4073
4154
  } else if (isRoleProminence) {
4074
- return /* @__PURE__ */ React49.createElement(VideoTileContext.Provider, { value: tileLayout }, /* @__PURE__ */ React49.createElement(
4155
+ return /* @__PURE__ */ React51.createElement(VideoTileContext.Provider, { value: tileLayout }, /* @__PURE__ */ React51.createElement(
4075
4156
  RoleProminence,
4076
4157
  {
4077
4158
  peers: sortedPeers,
@@ -4083,7 +4164,7 @@ var GridLayout = ({
4083
4164
  }
4084
4165
  ));
4085
4166
  }
4086
- return /* @__PURE__ */ React49.createElement(VideoTileContext.Provider, { value: tileLayout }, /* @__PURE__ */ React49.createElement(
4167
+ return /* @__PURE__ */ React51.createElement(VideoTileContext.Provider, { value: tileLayout }, /* @__PURE__ */ React51.createElement(
4087
4168
  EqualProminence,
4088
4169
  {
4089
4170
  peers: sortedPeers,
@@ -4096,7 +4177,7 @@ var GridLayout = ({
4096
4177
  };
4097
4178
 
4098
4179
  // src/Prebuilt/layouts/EmbedView.jsx
4099
- 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";
4100
4181
  import {
4101
4182
  selectPeers as selectPeers3,
4102
4183
  selectPeerScreenSharing as selectPeerScreenSharing2,
@@ -4105,7 +4186,7 @@ import {
4105
4186
  useScreenShare as useScreenShare3
4106
4187
  } from "@100mslive/react-sdk";
4107
4188
  var EmbedView = () => {
4108
- return /* @__PURE__ */ React50.createElement(EmbebScreenShareView, null, /* @__PURE__ */ React50.createElement(EmbedComponent, null));
4189
+ return /* @__PURE__ */ React52.createElement(EmbebScreenShareView, null, /* @__PURE__ */ React52.createElement(EmbedComponent, null));
4109
4190
  };
4110
4191
  var EmbebScreenShareView = ({ children }) => {
4111
4192
  const peers = useHMSStore24(selectPeers3);
@@ -4115,13 +4196,13 @@ var EmbebScreenShareView = ({ children }) => {
4115
4196
  const smallTilePeers2 = peers.filter((peer) => peer.id !== (peerPresenting == null ? void 0 : peerPresenting.id));
4116
4197
  return smallTilePeers2;
4117
4198
  }, [peers, peerPresenting]);
4118
- useEffect15(() => {
4199
+ useEffect16(() => {
4119
4200
  setActiveScreenSharePeer(peerPresenting == null ? void 0 : peerPresenting.id);
4120
4201
  return () => {
4121
4202
  setActiveScreenSharePeer("");
4122
4203
  };
4123
4204
  }, [peerPresenting == null ? void 0 : peerPresenting.id, setActiveScreenSharePeer]);
4124
- 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 }));
4125
4206
  };
4126
4207
  var EmbedComponent = () => {
4127
4208
  const { amIScreenSharing, toggleScreenShare } = useScreenShare3(throwErrorHandler);
@@ -4135,7 +4216,7 @@ var EmbedComponent = () => {
4135
4216
  setEmbedConfig({ url: "" });
4136
4217
  }
4137
4218
  }, [src, setEmbedConfig]);
4138
- useEffect15(() => {
4219
+ useEffect16(() => {
4139
4220
  if (embedConfig.shareScreen && !amIScreenSharing && !wasScreenShared && !screenShareAttemptInProgress.current) {
4140
4221
  screenShareAttemptInProgress.current = true;
4141
4222
  toggleScreenShare({
@@ -4148,7 +4229,7 @@ var EmbedComponent = () => {
4148
4229
  });
4149
4230
  }
4150
4231
  }, []);
4151
- useEffect15(() => {
4232
+ useEffect16(() => {
4152
4233
  if (wasScreenShared && !amIScreenSharing) {
4153
4234
  resetEmbedConfig();
4154
4235
  }
@@ -4159,7 +4240,7 @@ var EmbedComponent = () => {
4159
4240
  }
4160
4241
  };
4161
4242
  }, [wasScreenShared, amIScreenSharing, resetEmbedConfig, toggleScreenShare]);
4162
- 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(
4163
4244
  "iframe",
4164
4245
  {
4165
4246
  src,
@@ -4172,10 +4253,10 @@ var EmbedComponent = () => {
4172
4253
  };
4173
4254
 
4174
4255
  // src/Prebuilt/layouts/PDFView.jsx
4175
- 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";
4176
4257
  import { throwErrorHandler as throwErrorHandler2, useScreenShare as useScreenShare4 } from "@100mslive/react-sdk";
4177
4258
  var PDFView = () => {
4178
- return /* @__PURE__ */ React51.createElement(EmbebScreenShareView, null, /* @__PURE__ */ React51.createElement(PDFEmbedComponent, null));
4259
+ return /* @__PURE__ */ React53.createElement(EmbebScreenShareView, null, /* @__PURE__ */ React53.createElement(PDFEmbedComponent, null));
4179
4260
  };
4180
4261
  var PDFEmbedComponent = () => {
4181
4262
  const ref = useRef9();
@@ -4193,7 +4274,7 @@ var PDFEmbedComponent = () => {
4193
4274
  const resetEmbedConfig = useCallback9(() => {
4194
4275
  setPDFConfig({ state: false });
4195
4276
  }, [setPDFConfig]);
4196
- useEffect16(() => {
4277
+ useEffect17(() => {
4197
4278
  if (isPDFLoaded && ref.current) {
4198
4279
  ref.current.contentWindow.postMessage(
4199
4280
  {
@@ -4203,7 +4284,7 @@ var PDFEmbedComponent = () => {
4203
4284
  );
4204
4285
  }
4205
4286
  }, [isPDFLoaded, themeType]);
4206
- useEffect16(() => {
4287
+ useEffect17(() => {
4207
4288
  if (!amIScreenSharing && !wasScreenShared && !screenShareAttemptInProgress.current) {
4208
4289
  screenShareAttemptInProgress.current = true;
4209
4290
  toggleScreenShare({
@@ -4217,7 +4298,7 @@ var PDFEmbedComponent = () => {
4217
4298
  });
4218
4299
  }
4219
4300
  }, []);
4220
- useEffect16(() => {
4301
+ useEffect17(() => {
4221
4302
  if (wasScreenShared && !amIScreenSharing) {
4222
4303
  resetEmbedConfig();
4223
4304
  }
@@ -4228,7 +4309,7 @@ var PDFEmbedComponent = () => {
4228
4309
  }
4229
4310
  };
4230
4311
  }, [wasScreenShared, amIScreenSharing, resetEmbedConfig, toggleScreenShare]);
4231
- 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(
4232
4313
  "iframe",
4233
4314
  {
4234
4315
  src: pdfJSURL,
@@ -4261,47 +4342,47 @@ var PDFEmbedComponent = () => {
4261
4342
  };
4262
4343
 
4263
4344
  // src/Prebuilt/layouts/SidePane.tsx
4264
- import React58 from "react";
4265
- import { useMedia as useMedia15 } from "react-use";
4345
+ import React60 from "react";
4346
+ import { useMedia as useMedia16 } from "react-use";
4266
4347
  import { selectAppData as selectAppData3, selectVideoTrackByPeerID, useHMSStore as useHMSStore33 } from "@100mslive/react-sdk";
4267
4348
 
4268
4349
  // src/Prebuilt/components/SidePaneTabs.tsx
4269
- import React55, { useEffect as useEffect21, useState as useState32 } from "react";
4270
- 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";
4271
4352
  import { selectPeerCount as selectPeerCount3, useHMSStore as useHMSStore30 } from "@100mslive/react-sdk";
4272
4353
  import { CrossIcon as CrossIcon7 } from "@100mslive/react-icons";
4273
4354
 
4274
4355
  // src/Prebuilt/components/Chat/Chat.jsx
4275
- import React54, { useCallback as useCallback14, useEffect as useEffect20, useRef as useRef13, useState as useState31 } from "react";
4276
- 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";
4277
4358
  import {
4278
4359
  HMSNotificationTypes,
4279
4360
  selectHMSMessagesCount,
4280
4361
  selectPeerNameByID as selectPeerNameByID3,
4281
4362
  selectPermissions as selectPermissions10,
4282
4363
  selectSessionStore,
4283
- useHMSActions as useHMSActions18,
4364
+ useHMSActions as useHMSActions19,
4284
4365
  useHMSNotifications,
4285
4366
  useHMSStore as useHMSStore29
4286
4367
  } from "@100mslive/react-sdk";
4287
4368
  import { ChevronDownIcon as ChevronDownIcon2, CrossIcon as CrossIcon6, PinIcon as PinIcon2 } from "@100mslive/react-icons";
4288
4369
 
4289
4370
  // src/Prebuilt/components/Chat/ChatBody.jsx
4290
- 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";
4291
4372
  import { useInView } from "react-intersection-observer";
4292
- import { useMedia as useMedia11 } from "react-use";
4373
+ import { useMedia as useMedia12 } from "react-use";
4293
4374
  import AutoSizer from "react-virtualized-auto-sizer";
4294
4375
  import { VariableSizeList } from "react-window";
4295
4376
  import {
4296
4377
  selectHMSMessages,
4297
4378
  selectLocalPeerID as selectLocalPeerID6,
4298
- selectLocalPeerRoleName,
4379
+ selectLocalPeerRoleName as selectLocalPeerRoleName2,
4299
4380
  selectMessagesByPeerID,
4300
4381
  selectMessagesByRole,
4301
4382
  selectPeerNameByID as selectPeerNameByID2,
4302
4383
  selectPermissions as selectPermissions9,
4303
- useHMSActions as useHMSActions15,
4304
- useHMSStore as useHMSStore26
4384
+ useHMSActions as useHMSActions16,
4385
+ useHMSStore as useHMSStore27
4305
4386
  } from "@100mslive/react-sdk";
4306
4387
  import { PinIcon, VerticalMenuIcon as VerticalMenuIcon5 } from "@100mslive/react-icons";
4307
4388
 
@@ -4313,12 +4394,12 @@ import { useCallback as useCallback10 } from "react";
4313
4394
  import {
4314
4395
  selectPeerNameByID,
4315
4396
  selectSessionMetadata,
4316
- useHMSActions as useHMSActions14,
4397
+ useHMSActions as useHMSActions15,
4317
4398
  useHMSStore as useHMSStore25,
4318
4399
  useHMSVanillaStore as useHMSVanillaStore5
4319
4400
  } from "@100mslive/react-sdk";
4320
4401
  var useSetPinnedMessage = () => {
4321
- const hmsActions = useHMSActions14();
4402
+ const hmsActions = useHMSActions15();
4322
4403
  const vanillaStore = useHMSVanillaStore5();
4323
4404
  const pinnedMessage = useHMSStore25(selectSessionMetadata);
4324
4405
  const setPinnedMessage = useCallback10(
@@ -4337,6 +4418,19 @@ var useSetPinnedMessage = () => {
4337
4418
  return { setPinnedMessage };
4338
4419
  };
4339
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
+
4340
4434
  // src/Prebuilt/components/Chat/ChatBody.jsx
4341
4435
  var formatTime = (date) => {
4342
4436
  if (!(date instanceof Date)) {
@@ -4354,7 +4448,7 @@ var formatTime = (date) => {
4354
4448
  return `${hours}:${mins} ${suffix}`;
4355
4449
  };
4356
4450
  var MessageTypeContainer = ({ left, right }) => {
4357
- return /* @__PURE__ */ React52.createElement(
4451
+ return /* @__PURE__ */ React54.createElement(
4358
4452
  Flex,
4359
4453
  {
4360
4454
  align: "center",
@@ -4366,16 +4460,16 @@ var MessageTypeContainer = ({ left, right }) => {
4366
4460
  r: "$0"
4367
4461
  }
4368
4462
  },
4369
- left && /* @__PURE__ */ React52.createElement(SenderName, { variant: "tiny", as: "span", css: { color: "$on_surface_medium" } }, left),
4370
- left && right && /* @__PURE__ */ React52.createElement(Box, { css: { borderLeft: "1px solid $border_bright", mx: "$4", h: "$8" } }),
4371
- right && /* @__PURE__ */ React52.createElement(SenderName, { as: "span", variant: "tiny", css: { textTransform: "uppercase" } }, right)
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)
4372
4466
  );
4373
4467
  };
4374
4468
  var MessageType = ({ roles, hasCurrentUserSent, receiver }) => {
4375
- const peerName = useHMSStore26(selectPeerNameByID2(receiver));
4376
- const localPeerRoleName = useHMSStore26(selectLocalPeerRoleName);
4469
+ const peerName = useHMSStore27(selectPeerNameByID2(receiver));
4470
+ const localPeerRoleName = useHMSStore27(selectLocalPeerRoleName2);
4377
4471
  if (receiver) {
4378
- return /* @__PURE__ */ React52.createElement(
4472
+ return /* @__PURE__ */ React54.createElement(
4379
4473
  MessageTypeContainer,
4380
4474
  {
4381
4475
  left: hasCurrentUserSent ? `${peerName ? `TO ${peerName}` : ""}` : "TO YOU",
@@ -4384,7 +4478,7 @@ var MessageType = ({ roles, hasCurrentUserSent, receiver }) => {
4384
4478
  );
4385
4479
  }
4386
4480
  if (roles && roles.length) {
4387
- 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 });
4388
4482
  }
4389
4483
  return null;
4390
4484
  };
@@ -4398,10 +4492,10 @@ var Link = styled("a", {
4398
4492
  });
4399
4493
  var AnnotisedMessage = ({ message }) => {
4400
4494
  if (!message) {
4401
- return /* @__PURE__ */ React52.createElement(Fragment8, null);
4495
+ return /* @__PURE__ */ React54.createElement(Fragment8, null);
4402
4496
  }
4403
- return /* @__PURE__ */ React52.createElement(Fragment8, null, message.trim().split(/(\s)/).map(
4404
- (part) => URL_REGEX.test(part) ? /* @__PURE__ */ React52.createElement(Link, { href: part, key: part, target: "_blank", rel: "noopener noreferrer" }, part) : part
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
4405
4499
  ));
4406
4500
  };
4407
4501
  var getMessageType = ({ roles, receiver }) => {
@@ -4415,14 +4509,14 @@ var ChatActions = ({ onPin, showPinAction }) => {
4415
4509
  if (!showPinAction) {
4416
4510
  return null;
4417
4511
  }
4418
- return /* @__PURE__ */ React52.createElement(Dropdown.Root, { open, onOpenChange: setOpen }, /* @__PURE__ */ React52.createElement(Dropdown.Trigger, { className: "chat_actions", css: { opacity: open ? 1 : 0, "@md": { opacity: 1 } }, asChild: true }, /* @__PURE__ */ React52.createElement(IconButton, null, /* @__PURE__ */ React52.createElement(Tooltip, { title: "More options" }, /* @__PURE__ */ React52.createElement(VerticalMenuIcon5, null)))), /* @__PURE__ */ React52.createElement(Dropdown.Portal, null, /* @__PURE__ */ React52.createElement(
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(
4419
4513
  Dropdown.Content,
4420
4514
  {
4421
4515
  sideOffset: 5,
4422
4516
  align: "end",
4423
4517
  css: { width: "$48", backgroundColor: "$surface_bright", py: "$0", border: "1px solid $border_bright" }
4424
4518
  },
4425
- /* @__PURE__ */ React52.createElement(Dropdown.Item, { "data-testid": "pin_message_btn", onClick: onPin }, /* @__PURE__ */ React52.createElement(PinIcon, null), /* @__PURE__ */ React52.createElement(Text, { variant: "sm", css: { ml: "$4" } }, "Pin Message"))
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"))
4426
4520
  )));
4427
4521
  };
4428
4522
  var SenderName = styled(Text, {
@@ -4434,120 +4528,127 @@ var SenderName = styled(Text, {
4434
4528
  color: "$on_surface_high",
4435
4529
  fontWeight: "$semiBold"
4436
4530
  });
4437
- var ChatMessage = React52.memo(({ index, style = {}, message, setRowHeight, onPin }) => {
4438
- var _a, _b;
4439
- const { ref, inView } = useInView({ threshold: 0.5, triggerOnce: true });
4440
- const rowRef = useRef10(null);
4441
- useEffect17(() => {
4442
- if (rowRef.current) {
4443
- setRowHeight(index, rowRef.current.clientHeight);
4444
- }
4445
- }, [index, setRowHeight]);
4446
- const isMobile = useMedia11(config.media.md);
4447
- const { elements } = useRoomLayoutConferencingScreen();
4448
- const isOverlay = ((_a = elements == null ? void 0 : elements.chat) == null ? void 0 : _a.is_overlay) && isMobile;
4449
- const hmsActions = useHMSActions15();
4450
- const localPeerId = useHMSStore26(selectLocalPeerID6);
4451
- const permissions = useHMSStore26(selectPermissions9);
4452
- const messageType = getMessageType({
4453
- roles: message.recipientRoles,
4454
- receiver: message.recipientPeer
4455
- });
4456
- const showPinAction = permissions.removeOthers && !messageType && ((_b = elements == null ? void 0 : elements.chat) == null ? void 0 : _b.allow_pinning_messages);
4457
- useEffect17(() => {
4458
- if (message.id && !message.read && inView) {
4459
- hmsActions.setMessageRead(true, message.id);
4460
- }
4461
- }, [message.read, hmsActions, inView, message.id]);
4462
- return /* @__PURE__ */ React52.createElement(
4463
- Box,
4464
- {
4465
- ref,
4466
- as: "div",
4467
- css: { mb: "$10", pr: "$10", mt: "$8", "&:hover .chat_actions": { opacity: 1 } },
4468
- style
4469
- },
4470
- /* @__PURE__ */ React52.createElement(
4471
- 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,
4472
4564
  {
4473
- ref: rowRef,
4474
- align: "center",
4475
- css: {
4476
- flexWrap: "wrap",
4477
- // Theme independent color, token should not be used for transparent chat
4478
- bg: messageType ? isOverlay ? "rgba(0, 0, 0, 0.64)" : "$surface_default" : void 0,
4479
- r: messageType ? "$1" : void 0,
4480
- px: messageType ? "$4" : "$2",
4481
- py: messageType ? "$4" : 0,
4482
- userSelect: "none"
4483
- },
4484
- key: message.time,
4485
- "data-testid": "chat_msg"
4565
+ ref,
4566
+ as: "div",
4567
+ css: { mb: "$10", pr: "$10", mt: "$8", "&:hover .chat_actions": { opacity: 1 } },
4568
+ style
4486
4569
  },
4487
- /* @__PURE__ */ React52.createElement(
4488
- Text,
4570
+ /* @__PURE__ */ React54.createElement(
4571
+ Flex,
4489
4572
  {
4573
+ ref: rowRef,
4574
+ align: "center",
4490
4575
  css: {
4491
- color: isOverlay ? "#FFF" : "$on_surface_high",
4492
- fontWeight: "$semiBold",
4493
- display: "inline-flex",
4494
- alignItems: "center",
4495
- justifyContent: "space-between",
4496
- 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"
4497
4583
  },
4498
- as: "div"
4584
+ key: message.time,
4585
+ "data-testid": "chat_msg"
4499
4586
  },
4500
- /* @__PURE__ */ React52.createElement(Flex, { align: "baseline" }, message.senderName === "You" || !message.senderName ? /* @__PURE__ */ React52.createElement(SenderName, { as: "span", variant: "sm", css: { color: isOverlay ? "#FFF" : "$on_surface_high" } }, message.senderName || "Anonymous") : /* @__PURE__ */ React52.createElement(Tooltip, { title: message.senderName, side: "top", align: "start" }, /* @__PURE__ */ React52.createElement(SenderName, { as: "span", variant: "sm", css: { color: isOverlay ? "#FFF" : "$on_surface_high" } }, message.senderName)), !isOverlay ? /* @__PURE__ */ React52.createElement(
4587
+ /* @__PURE__ */ React54.createElement(
4501
4588
  Text,
4502
4589
  {
4503
- as: "span",
4504
- variant: "xs",
4505
4590
  css: {
4506
- ml: "$4",
4507
- color: "$on_surface_medium",
4508
- flexShrink: 0
4509
- }
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"
4510
4599
  },
4511
- formatTime(message.time)
4512
- ) : null),
4513
- /* @__PURE__ */ React52.createElement(
4514
- MessageType,
4515
- {
4516
- hasCurrentUserSent: message.sender === localPeerId,
4517
- receiver: message.recipientPeer,
4518
- roles: message.recipientRoles
4519
- }
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
4520
4622
  ),
4521
- !isOverlay ? /* @__PURE__ */ React52.createElement(ChatActions, { onPin, showPinAction }) : null
4522
- ),
4523
- /* @__PURE__ */ React52.createElement(
4524
- Text,
4525
- {
4526
- variant: "sm",
4527
- css: {
4528
- w: "100%",
4529
- mt: "$2",
4530
- wordBreak: "break-word",
4531
- whiteSpace: "pre-wrap",
4532
- userSelect: "all",
4533
- 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()
4534
4636
  },
4535
- onClick: (e) => e.stopPropagation()
4536
- },
4537
- /* @__PURE__ */ React52.createElement(AnnotisedMessage, { message: message.message })
4637
+ /* @__PURE__ */ React54.createElement(AnnotisedMessage, { message: message.message })
4638
+ )
4538
4639
  )
4539
- )
4540
- );
4541
- });
4542
- var ChatList = React52.forwardRef(
4543
- ({ 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) => {
4544
4645
  const { setPinnedMessage } = useSetPinnedMessage();
4545
4646
  useLayoutEffect(() => {
4546
4647
  if (listRef.current && listRef.current.scrollToItem) {
4547
4648
  scrollToBottom(1);
4548
4649
  }
4549
4650
  }, [listRef]);
4550
- return /* @__PURE__ */ React52.createElement(
4651
+ return /* @__PURE__ */ React54.createElement(
4551
4652
  VariableSizeList,
4552
4653
  {
4553
4654
  ref: listRef,
@@ -4559,7 +4660,7 @@ var ChatList = React52.forwardRef(
4559
4660
  overflowX: "hidden"
4560
4661
  }
4561
4662
  },
4562
- ({ index, style }) => /* @__PURE__ */ React52.createElement(
4663
+ ({ index, style }) => /* @__PURE__ */ React54.createElement(
4563
4664
  ChatMessage,
4564
4665
  {
4565
4666
  style,
@@ -4567,13 +4668,16 @@ var ChatList = React52.forwardRef(
4567
4668
  key: messages[index].id,
4568
4669
  message: messages[index],
4569
4670
  setRowHeight,
4671
+ unreadCount,
4672
+ isLast: index >= messages.length - 2,
4673
+ scrollToBottom,
4570
4674
  onPin: () => setPinnedMessage(messages[index])
4571
4675
  }
4572
4676
  )
4573
4677
  );
4574
4678
  }
4575
4679
  );
4576
- var VirtualizedChatMessages = React52.forwardRef(({ messages, scrollToBottom }, listRef) => {
4680
+ var VirtualizedChatMessages = React54.forwardRef(({ messages, unreadCount = 0, scrollToBottom }, listRef) => {
4577
4681
  const rowHeights = useRef10({});
4578
4682
  function getRowHeight(index) {
4579
4683
  return rowHeights.current[index] + 16 || 72;
@@ -4585,7 +4689,7 @@ var VirtualizedChatMessages = React52.forwardRef(({ messages, scrollToBottom },
4585
4689
  },
4586
4690
  [listRef]
4587
4691
  );
4588
- return /* @__PURE__ */ React52.createElement(
4692
+ return /* @__PURE__ */ React54.createElement(
4589
4693
  Box,
4590
4694
  {
4591
4695
  css: {
@@ -4594,14 +4698,14 @@ var VirtualizedChatMessages = React52.forwardRef(({ messages, scrollToBottom },
4594
4698
  },
4595
4699
  as: "div"
4596
4700
  },
4597
- /* @__PURE__ */ React52.createElement(
4701
+ /* @__PURE__ */ React54.createElement(
4598
4702
  AutoSizer,
4599
4703
  {
4600
4704
  style: {
4601
4705
  width: "90%"
4602
4706
  }
4603
4707
  },
4604
- ({ height, width }) => /* @__PURE__ */ React52.createElement(
4708
+ ({ height, width }) => /* @__PURE__ */ React54.createElement(
4605
4709
  ChatList,
4606
4710
  {
4607
4711
  width,
@@ -4610,21 +4714,23 @@ var VirtualizedChatMessages = React52.forwardRef(({ messages, scrollToBottom },
4610
4714
  setRowHeight,
4611
4715
  getRowHeight,
4612
4716
  scrollToBottom,
4613
- ref: listRef
4717
+ ref: listRef,
4718
+ unreadCount
4614
4719
  }
4615
4720
  )
4616
4721
  )
4617
4722
  );
4618
4723
  });
4619
- var ChatBody = React52.forwardRef(({ role, peerId, scrollToBottom }, listRef) => {
4724
+ var ChatBody = React54.forwardRef(({ role, peerId, scrollToBottom }, listRef) => {
4620
4725
  var _a;
4621
4726
  const storeMessageSelector = role ? selectMessagesByRole(role) : peerId ? selectMessagesByPeerID(peerId) : selectHMSMessages;
4622
- let messages = useHMSStore26(storeMessageSelector);
4727
+ let messages = useHMSStore27(storeMessageSelector);
4623
4728
  messages = useMemo8(() => (messages == null ? void 0 : messages.filter((message) => message.type === "chat")) || [], [messages]);
4624
- const isMobile = useMedia11(config.media.md);
4729
+ const isMobile = useMedia12(config.media.md);
4625
4730
  const { elements } = useRoomLayoutConferencingScreen();
4731
+ const unreadCount = useUnreadCount({ role, peerId });
4626
4732
  if (messages.length === 0 && !(isMobile && ((_a = elements == null ? void 0 : elements.chat) == null ? void 0 : _a.is_overlay))) {
4627
- return /* @__PURE__ */ React52.createElement(
4733
+ return /* @__PURE__ */ React54.createElement(
4628
4734
  Flex,
4629
4735
  {
4630
4736
  css: {
@@ -4636,7 +4742,7 @@ var ChatBody = React52.forwardRef(({ role, peerId, scrollToBottom }, listRef) =>
4636
4742
  align: "center",
4637
4743
  justify: "center"
4638
4744
  },
4639
- /* @__PURE__ */ React52.createElement(Box, null, /* @__PURE__ */ React52.createElement("img", { src: empty_chat_default, alt: "Empty Chat", height: 132, width: 185, style: { margin: "0 auto" } }), /* @__PURE__ */ React52.createElement(Text, { variant: "h5", css: { mt: "$8", c: "$on_surface_high" } }, "Start a conversation"), /* @__PURE__ */ React52.createElement(
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(
4640
4746
  Text,
4641
4747
  {
4642
4748
  variant: "sm",
@@ -4646,23 +4752,31 @@ var ChatBody = React52.forwardRef(({ role, peerId, scrollToBottom }, listRef) =>
4646
4752
  ))
4647
4753
  );
4648
4754
  }
4649
- 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
+ ));
4650
4764
  });
4651
4765
 
4652
4766
  // src/Prebuilt/components/Chat/ChatFooter.tsx
4653
- import React53, { useCallback as useCallback13, useEffect as useEffect19, useRef as useRef12, useState as useState30 } from "react";
4654
- 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";
4655
4769
  import data2 from "@emoji-mart/data";
4656
4770
  import Picker from "@emoji-mart/react";
4657
- import { useHMSActions as useHMSActions17 } from "@100mslive/react-sdk";
4771
+ import { useHMSActions as useHMSActions18 } from "@100mslive/react-sdk";
4658
4772
  import { EmojiIcon as EmojiIcon3, SendIcon } from "@100mslive/react-icons";
4659
4773
 
4660
4774
  // src/Prebuilt/components/AppData/useChatState.js
4661
4775
  import { useCallback as useCallback12 } from "react";
4662
- import { selectAppData as selectAppData2, useHMSActions as useHMSActions16, useHMSStore as useHMSStore27 } from "@100mslive/react-sdk";
4776
+ import { selectAppData as selectAppData2, useHMSActions as useHMSActions17, useHMSStore as useHMSStore28 } from "@100mslive/react-sdk";
4663
4777
  var useChatDraftMessage = () => {
4664
- const hmsActions = useHMSActions16();
4665
- let chatDraftMessage = useHMSStore27(selectAppData2(APP_DATA.chatDraft));
4778
+ const hmsActions = useHMSActions17();
4779
+ let chatDraftMessage = useHMSStore28(selectAppData2(APP_DATA.chatDraft));
4666
4780
  if (chatDraftMessage === void 0 || chatDraftMessage === null) {
4667
4781
  chatDraftMessage = "";
4668
4782
  }
@@ -4676,10 +4790,10 @@ var useChatDraftMessage = () => {
4676
4790
  };
4677
4791
 
4678
4792
  // src/Prebuilt/components/Chat/useEmojiPickerStyles.js
4679
- import { useEffect as useEffect18, useRef as useRef11 } from "react";
4793
+ import { useEffect as useEffect19, useRef as useRef11 } from "react";
4680
4794
  var useEmojiPickerStyles = (showing) => {
4681
4795
  const ref = useRef11(null);
4682
- useEffect18(() => {
4796
+ useEffect19(() => {
4683
4797
  if (showing) {
4684
4798
  setTimeout(() => {
4685
4799
  var _a, _b;
@@ -4729,7 +4843,7 @@ var TextArea = styled("textarea", {
4729
4843
  function EmojiPicker({ onSelect }) {
4730
4844
  const [showEmoji, setShowEmoji] = useState30(false);
4731
4845
  const ref = useEmojiPickerStyles(showEmoji);
4732
- return /* @__PURE__ */ React53.createElement(Popover.Root, { open: showEmoji, onOpenChange: setShowEmoji }, /* @__PURE__ */ React53.createElement(Popover.Trigger, { asChild: true, css: { appearance: "none" } }, /* @__PURE__ */ React53.createElement(IconButton, { as: "div" }, /* @__PURE__ */ React53.createElement(EmojiIcon3, null))), /* @__PURE__ */ React53.createElement(Popover.Portal, null, /* @__PURE__ */ React53.createElement(
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(
4733
4847
  Popover.Content,
4734
4848
  {
4735
4849
  alignOffset: -40,
@@ -4739,7 +4853,7 @@ function EmojiPicker({ onSelect }) {
4739
4853
  p: 0
4740
4854
  }
4741
4855
  },
4742
- /* @__PURE__ */ React53.createElement(
4856
+ /* @__PURE__ */ React55.createElement(
4743
4857
  Box,
4744
4858
  {
4745
4859
  css: {
@@ -4748,7 +4862,7 @@ function EmojiPicker({ onSelect }) {
4748
4862
  },
4749
4863
  ref
4750
4864
  },
4751
- /* @__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" })
4752
4866
  )
4753
4867
  )));
4754
4868
  }
@@ -4759,10 +4873,10 @@ var ChatFooter = ({
4759
4873
  children
4760
4874
  }) => {
4761
4875
  var _a;
4762
- const hmsActions = useHMSActions17();
4876
+ const hmsActions = useHMSActions18();
4763
4877
  const inputRef = useRef12(null);
4764
4878
  const [draftMessage, setDraftMessage] = useChatDraftMessage();
4765
- const isMobile = useMedia12(config.media.md);
4879
+ const isMobile = useMedia13(config.media.md);
4766
4880
  const { elements } = useRoomLayoutConferencingScreen();
4767
4881
  const isOverlayChat = (_a = elements == null ? void 0 : elements.chat) == null ? void 0 : _a.is_overlay;
4768
4882
  const sendMessage = useCallback13(() => __async(void 0, null, function* () {
@@ -4788,19 +4902,19 @@ var ChatFooter = ({
4788
4902
  ToastManager.addToast({ title: err.message });
4789
4903
  }
4790
4904
  }), [role, peerId, hmsActions, onSend]);
4791
- useEffect19(() => {
4905
+ useEffect20(() => {
4792
4906
  const messageElement = inputRef.current;
4793
4907
  if (messageElement) {
4794
4908
  messageElement.value = draftMessage;
4795
4909
  }
4796
4910
  }, [draftMessage]);
4797
- useEffect19(() => {
4911
+ useEffect20(() => {
4798
4912
  const messageElement = inputRef.current;
4799
4913
  return () => {
4800
4914
  setDraftMessage((messageElement == null ? void 0 : messageElement.value) || "");
4801
4915
  };
4802
4916
  }, [setDraftMessage]);
4803
- 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(
4804
4918
  Flex,
4805
4919
  {
4806
4920
  align: "center",
@@ -4821,13 +4935,14 @@ var ChatFooter = ({
4821
4935
  }
4822
4936
  },
4823
4937
  children,
4824
- /* @__PURE__ */ React53.createElement(
4938
+ /* @__PURE__ */ React55.createElement(
4825
4939
  TextArea,
4826
4940
  {
4827
4941
  css: {
4828
4942
  c: "$on_surface_high",
4829
4943
  "&:valid ~ .send-msg": { color: "$on_surface_high" },
4830
- "& ~ .send-msg": { color: "$on_surface_low" }
4944
+ "& ~ .send-msg": { color: "$on_surface_low" },
4945
+ "&::placeholder": { color: "$on_surface_medium" }
4831
4946
  },
4832
4947
  placeholder: "Send a message....",
4833
4948
  ref: inputRef,
@@ -4848,7 +4963,7 @@ var ChatFooter = ({
4848
4963
  onCopy: (e) => e.stopPropagation()
4849
4964
  }
4850
4965
  ),
4851
- !isMobile ? /* @__PURE__ */ React53.createElement(
4966
+ !isMobile ? /* @__PURE__ */ React55.createElement(
4852
4967
  EmojiPicker,
4853
4968
  {
4854
4969
  onSelect: (emoji) => {
@@ -4858,7 +4973,7 @@ var ChatFooter = ({
4858
4973
  }
4859
4974
  }
4860
4975
  ) : null,
4861
- /* @__PURE__ */ React53.createElement(
4976
+ /* @__PURE__ */ React55.createElement(
4862
4977
  IconButton,
4863
4978
  {
4864
4979
  className: "send-msg",
@@ -4871,31 +4986,18 @@ var ChatFooter = ({
4871
4986
  },
4872
4987
  "data-testid": "send_msg_btn"
4873
4988
  },
4874
- /* @__PURE__ */ React53.createElement(SendIcon, null)
4989
+ /* @__PURE__ */ React55.createElement(SendIcon, null)
4875
4990
  )
4876
4991
  )));
4877
4992
  };
4878
4993
 
4879
- // src/Prebuilt/components/Chat/useUnreadCount.js
4880
- import {
4881
- selectMessagesUnreadCountByPeerID,
4882
- selectMessagesUnreadCountByRole,
4883
- selectUnreadHMSMessagesCount as selectUnreadHMSMessagesCount2,
4884
- useHMSStore as useHMSStore28
4885
- } from "@100mslive/react-sdk";
4886
- var useUnreadCount = ({ role, peerId }) => {
4887
- const unreadCountSelector = role ? selectMessagesUnreadCountByRole(role) : peerId ? selectMessagesUnreadCountByPeerID(peerId) : selectUnreadHMSMessagesCount2;
4888
- const unreadCount = useHMSStore28(unreadCountSelector);
4889
- return unreadCount;
4890
- };
4891
-
4892
4994
  // src/Prebuilt/components/Chat/Chat.jsx
4893
4995
  var PINNED_MESSAGE_LENGTH = 80;
4894
4996
  var PinnedMessage = ({ clearPinnedMessage }) => {
4895
4997
  const permissions = useHMSStore29(selectPermissions10);
4896
4998
  const pinnedMessage = useHMSStore29(selectSessionStore(SESSION_STORE_KEY.PINNED_MESSAGE));
4897
4999
  const formattedPinnedMessage = (pinnedMessage == null ? void 0 : pinnedMessage.length) && pinnedMessage.length > PINNED_MESSAGE_LENGTH ? `${pinnedMessage.slice(0, PINNED_MESSAGE_LENGTH)}...` : pinnedMessage;
4898
- return pinnedMessage ? /* @__PURE__ */ React54.createElement(
5000
+ return pinnedMessage ? /* @__PURE__ */ React56.createElement(
4899
5001
  Flex,
4900
5002
  {
4901
5003
  title: pinnedMessage,
@@ -4903,8 +5005,8 @@ var PinnedMessage = ({ clearPinnedMessage }) => {
4903
5005
  align: "center",
4904
5006
  justify: "between"
4905
5007
  },
4906
- /* @__PURE__ */ React54.createElement(PinIcon2, null),
4907
- /* @__PURE__ */ React54.createElement(
5008
+ /* @__PURE__ */ React56.createElement(PinIcon2, null),
5009
+ /* @__PURE__ */ React56.createElement(
4908
5010
  Box,
4909
5011
  {
4910
5012
  css: {
@@ -4914,15 +5016,15 @@ var PinnedMessage = ({ clearPinnedMessage }) => {
4914
5016
  overflowY: "auto"
4915
5017
  }
4916
5018
  },
4917
- /* @__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 }))
4918
5020
  ),
4919
- permissions.removeOthers && /* @__PURE__ */ React54.createElement(
5021
+ permissions.removeOthers && /* @__PURE__ */ React56.createElement(
4920
5022
  Flex,
4921
5023
  {
4922
5024
  onClick: () => clearPinnedMessage(),
4923
5025
  css: { cursor: "pointer", color: "$on_surface_medium", "&:hover": { color: "$on_surface_high" } }
4924
5026
  },
4925
- /* @__PURE__ */ React54.createElement(CrossIcon6, null)
5027
+ /* @__PURE__ */ React56.createElement(CrossIcon6, null)
4926
5028
  )
4927
5029
  ) : null;
4928
5030
  };
@@ -4939,9 +5041,9 @@ var Chat = ({ screenType }) => {
4939
5041
  });
4940
5042
  const [isSelectorOpen] = useState31(false);
4941
5043
  const listRef = useRef13(null);
4942
- const hmsActions = useHMSActions18();
5044
+ const hmsActions = useHMSActions19();
4943
5045
  const { setPinnedMessage } = useSetPinnedMessage();
4944
- useEffect20(() => {
5046
+ useEffect21(() => {
4945
5047
  if (notification && notification.data && peerSelector === notification.data.id) {
4946
5048
  setPeerSelector("");
4947
5049
  setChatOptions({
@@ -4953,7 +5055,7 @@ var Chat = ({ screenType }) => {
4953
5055
  }, [notification, peerSelector, setPeerSelector]);
4954
5056
  const storeMessageSelector = selectHMSMessagesCount;
4955
5057
  const { elements } = useRoomLayoutConferencingScreen();
4956
- const isMobile = useMedia13(config.media.md);
5058
+ const isMobile = useMedia14(config.media.md);
4957
5059
  let isScrolledToBottom = false;
4958
5060
  if (listRef.current) {
4959
5061
  const currentRef = listRef.current._outerRef;
@@ -4974,7 +5076,7 @@ var Chat = ({ screenType }) => {
4974
5076
  },
4975
5077
  [hmsActions, messagesCount]
4976
5078
  );
4977
- return /* @__PURE__ */ React54.createElement(
5079
+ return /* @__PURE__ */ React56.createElement(
4978
5080
  Flex,
4979
5081
  {
4980
5082
  direction: "column",
@@ -4983,8 +5085,8 @@ var Chat = ({ screenType }) => {
4983
5085
  gap: "$4"
4984
5086
  }
4985
5087
  },
4986
- isMobile && ((_a = elements == null ? void 0 : elements.chat) == null ? void 0 : _a.is_overlay) ? null : /* @__PURE__ */ React54.createElement(React54.Fragment, null, ((_b = elements == null ? void 0 : elements.chat) == null ? void 0 : _b.allow_pinning_messages) ? /* @__PURE__ */ React54.createElement(PinnedMessage, { clearPinnedMessage: setPinnedMessage }) : null),
4987
- /* @__PURE__ */ React54.createElement(
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(
4988
5090
  ChatBody,
4989
5091
  {
4990
5092
  role: chatOptions.role,
@@ -4994,7 +5096,7 @@ var Chat = ({ screenType }) => {
4994
5096
  screenType
4995
5097
  }
4996
5098
  ),
4997
- /* @__PURE__ */ React54.createElement(
5099
+ /* @__PURE__ */ React56.createElement(
4998
5100
  ChatFooter,
4999
5101
  {
5000
5102
  role: chatOptions.role,
@@ -5012,7 +5114,7 @@ var Chat = ({ screenType }) => {
5012
5114
  },
5013
5115
  peerId: chatOptions.peerId
5014
5116
  },
5015
- !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 })
5016
5118
  )
5017
5119
  );
5018
5120
  };
@@ -5021,7 +5123,7 @@ var NewMessageIndicator = ({ role, peerId, scrollToBottom }) => {
5021
5123
  if (!unreadCount) {
5022
5124
  return null;
5023
5125
  }
5024
- return /* @__PURE__ */ React54.createElement(
5126
+ return /* @__PURE__ */ React56.createElement(
5025
5127
  Flex,
5026
5128
  {
5027
5129
  justify: "center",
@@ -5032,7 +5134,7 @@ var NewMessageIndicator = ({ role, peerId, scrollToBottom }) => {
5032
5134
  position: "absolute"
5033
5135
  }
5034
5136
  },
5035
- /* @__PURE__ */ React54.createElement(
5137
+ /* @__PURE__ */ React56.createElement(
5036
5138
  Button,
5037
5139
  {
5038
5140
  variant: "standard",
@@ -5055,7 +5157,7 @@ var NewMessageIndicator = ({ role, peerId, scrollToBottom }) => {
5055
5157
  },
5056
5158
  "New ",
5057
5159
  unreadCount === 1 ? "message" : "messages",
5058
- /* @__PURE__ */ React54.createElement(ChevronDownIcon2, null)
5160
+ /* @__PURE__ */ React56.createElement(ChevronDownIcon2, null)
5059
5161
  )
5060
5162
  );
5061
5163
  };
@@ -5069,7 +5171,10 @@ var tabTriggerCSS = {
5069
5171
  w: "100%",
5070
5172
  justifyContent: "center"
5071
5173
  };
5072
- var SidePaneTabs = React55.memo(({ active = SIDE_PANE_OPTIONS.CHAT, screenType, hideControls }) => {
5174
+ var ParticipantCount2 = ({ count }) => {
5175
+ return count < 1e3 ? /* @__PURE__ */ React57.createElement("span", null, "(", count, ")") : /* @__PURE__ */ React57.createElement(Tooltip, { title: count }, /* @__PURE__ */ React57.createElement("span", null, "(", getFormattedCount(count), ")"));
5176
+ };
5177
+ var SidePaneTabs = React57.memo(({ active = SIDE_PANE_OPTIONS.CHAT, screenType, hideControls }) => {
5073
5178
  var _a;
5074
5179
  const toggleChat = useSidepaneToggle(SIDE_PANE_OPTIONS.CHAT);
5075
5180
  const toggleParticipants = useSidepaneToggle(SIDE_PANE_OPTIONS.PARTICIPANTS);
@@ -5080,10 +5185,10 @@ var SidePaneTabs = React55.memo(({ active = SIDE_PANE_OPTIONS.CHAT, screenType,
5080
5185
  const showChat = !!(elements == null ? void 0 : elements.chat);
5081
5186
  const showParticipants = !!(elements == null ? void 0 : elements.participant_list);
5082
5187
  const hideTabs = !(showChat && showParticipants);
5083
- const isMobile = useMedia14(config.media.md);
5188
+ const isMobile = useMedia15(config.media.md);
5084
5189
  const isOverlayChat = !!((_a = elements == null ? void 0 : elements.chat) == null ? void 0 : _a.is_overlay) && isMobile;
5085
5190
  const isChatOpen = useIsSidepaneTypeOpen(SIDE_PANE_OPTIONS.CHAT);
5086
- useEffect21(() => {
5191
+ useEffect22(() => {
5087
5192
  if (activeTab === SIDE_PANE_OPTIONS.CHAT && !showChat && showParticipants) {
5088
5193
  setActiveTab(SIDE_PANE_OPTIONS.PARTICIPANTS);
5089
5194
  } else if (activeTab === SIDE_PANE_OPTIONS.PARTICIPANTS && showChat && !showParticipants) {
@@ -5092,10 +5197,10 @@ var SidePaneTabs = React55.memo(({ active = SIDE_PANE_OPTIONS.CHAT, screenType,
5092
5197
  resetSidePane();
5093
5198
  }
5094
5199
  }, [showChat, activeTab, showParticipants, resetSidePane]);
5095
- useEffect21(() => {
5200
+ useEffect22(() => {
5096
5201
  setActiveTab(active);
5097
5202
  }, [active]);
5098
- return /* @__PURE__ */ React55.createElement(
5203
+ return /* @__PURE__ */ React57.createElement(
5099
5204
  Flex,
5100
5205
  {
5101
5206
  direction: "column",
@@ -5106,7 +5211,7 @@ var SidePaneTabs = React55.memo(({ active = SIDE_PANE_OPTIONS.CHAT, screenType,
5106
5211
  transition: "margin 0.3s ease-in-out"
5107
5212
  }
5108
5213
  },
5109
- isOverlayChat && isChatOpen && showChat ? /* @__PURE__ */ React55.createElement(Chat, { screenType }) : /* @__PURE__ */ React55.createElement(React55.Fragment, null, hideTabs ? /* @__PURE__ */ React55.createElement(React55.Fragment, null, /* @__PURE__ */ React55.createElement(Text, { variant: "sm", css: { fontWeight: "$semiBold", p: "$4", c: "$on_surface_high", pr: "$12" } }, showChat ? "Chat" : `Participants (${peerCount})`), showChat ? /* @__PURE__ */ React55.createElement(Chat, { screenType }) : /* @__PURE__ */ React55.createElement(ParticipantList, null)) : /* @__PURE__ */ React55.createElement(
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(
5110
5215
  Tabs.Root,
5111
5216
  {
5112
5217
  value: activeTab,
@@ -5116,7 +5221,7 @@ var SidePaneTabs = React55.memo(({ active = SIDE_PANE_OPTIONS.CHAT, screenType,
5116
5221
  size: "100%"
5117
5222
  }
5118
5223
  },
5119
- /* @__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(
5120
5225
  Tabs.Trigger,
5121
5226
  {
5122
5227
  value: SIDE_PANE_OPTIONS.CHAT,
@@ -5126,7 +5231,7 @@ var SidePaneTabs = React55.memo(({ active = SIDE_PANE_OPTIONS.CHAT, screenType,
5126
5231
  })
5127
5232
  },
5128
5233
  "Chat"
5129
- ), /* @__PURE__ */ React55.createElement(
5234
+ ), /* @__PURE__ */ React57.createElement(
5130
5235
  Tabs.Trigger,
5131
5236
  {
5132
5237
  value: SIDE_PANE_OPTIONS.PARTICIPANTS,
@@ -5135,14 +5240,13 @@ var SidePaneTabs = React55.memo(({ active = SIDE_PANE_OPTIONS.CHAT, screenType,
5135
5240
  color: activeTab !== SIDE_PANE_OPTIONS.PARTICIPANTS ? "$on_surface_low" : "$on_surface_high"
5136
5241
  })
5137
5242
  },
5138
- "Participants (",
5139
- peerCount,
5140
- ")"
5243
+ "Participants ",
5244
+ /* @__PURE__ */ React57.createElement(ParticipantCount2, { count: peerCount })
5141
5245
  )),
5142
- /* @__PURE__ */ React55.createElement(Tabs.Content, { value: SIDE_PANE_OPTIONS.PARTICIPANTS, css: { p: 0 } }, /* @__PURE__ */ React55.createElement(ParticipantList, null)),
5143
- /* @__PURE__ */ React55.createElement(Tabs.Content, { value: SIDE_PANE_OPTIONS.CHAT, css: { p: 0 } }, /* @__PURE__ */ React55.createElement(Chat, { screenType }))
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 }))
5144
5248
  )),
5145
- isOverlayChat && isChatOpen ? null : /* @__PURE__ */ React55.createElement(
5249
+ isOverlayChat && isChatOpen ? null : /* @__PURE__ */ React57.createElement(
5146
5250
  IconButton,
5147
5251
  {
5148
5252
  css: { position: "absolute", right: "$10", top: "$11", "@md": { top: "$8", right: "$8" } },
@@ -5156,13 +5260,13 @@ var SidePaneTabs = React55.memo(({ active = SIDE_PANE_OPTIONS.CHAT, screenType,
5156
5260
  },
5157
5261
  "data-testid": "close_chat"
5158
5262
  },
5159
- /* @__PURE__ */ React55.createElement(CrossIcon7, null)
5263
+ /* @__PURE__ */ React57.createElement(CrossIcon7, null)
5160
5264
  )
5161
5265
  );
5162
5266
  });
5163
5267
 
5164
5268
  // src/Prebuilt/components/Streaming/StreamingLanding.jsx
5165
- import React57, { Fragment as Fragment10, useState as useState34 } from "react";
5269
+ import React59, { Fragment as Fragment10, useState as useState34 } from "react";
5166
5270
  import { selectPermissions as selectPermissions11, useHMSStore as useHMSStore32, useRecordingStreaming as useRecordingStreaming7 } from "@100mslive/react-sdk";
5167
5271
  import { ColoredHandIcon, CrossIcon as CrossIcon8, GoLiveIcon as GoLiveIcon3 } from "@100mslive/react-icons";
5168
5272
 
@@ -5170,8 +5274,8 @@ import { ColoredHandIcon, CrossIcon as CrossIcon8, GoLiveIcon as GoLiveIcon3 } f
5170
5274
  var rtmp_default = "";
5171
5275
 
5172
5276
  // src/Prebuilt/components/Streaming/HLSStreaming.jsx
5173
- import React56, { Fragment as Fragment9, useCallback as useCallback15, useEffect as useEffect22, useState as useState33 } from "react";
5174
- import { selectRoomID, useHMSActions as useHMSActions19, useHMSStore as useHMSStore31, useRecordingStreaming as useRecordingStreaming6 } from "@100mslive/react-sdk";
5277
+ import React58, { Fragment as Fragment9, useCallback as useCallback15, useEffect as useEffect23, useState as useState33 } from "react";
5278
+ import { selectRoomID, useHMSActions as useHMSActions20, useHMSStore as useHMSStore31, useRecordingStreaming as useRecordingStreaming6 } from "@100mslive/react-sdk";
5175
5279
  import {
5176
5280
  EndStreamIcon as EndStreamIcon2,
5177
5281
  EyeOpenIcon,
@@ -5190,7 +5294,7 @@ var getCardData = (roleName, roomId) => {
5190
5294
  data3 = {
5191
5295
  title: formattedRoleName,
5192
5296
  content: "Broadcasters can livestream audio or video, manage stream appearance and control the room via HLS.",
5193
- icon: /* @__PURE__ */ React56.createElement(SupportIcon, null)
5297
+ icon: /* @__PURE__ */ React58.createElement(SupportIcon, null)
5194
5298
  };
5195
5299
  break;
5196
5300
  }
@@ -5198,7 +5302,7 @@ var getCardData = (roleName, roomId) => {
5198
5302
  data3 = {
5199
5303
  title: "HLS Viewer",
5200
5304
  content: "Viewers can view and send chat messages, but need to be made broadcasters to participate with audio or video.",
5201
- icon: /* @__PURE__ */ React56.createElement(EyeOpenIcon, null)
5305
+ icon: /* @__PURE__ */ React58.createElement(EyeOpenIcon, null)
5202
5306
  };
5203
5307
  break;
5204
5308
  }
@@ -5206,7 +5310,7 @@ var getCardData = (roleName, roomId) => {
5206
5310
  data3 = {
5207
5311
  title: formattedRoleName,
5208
5312
  content: `${formattedRoleName} is customised with specific permissions, which will determine how it interacts with this room.`,
5209
- icon: /* @__PURE__ */ React56.createElement(WrenchIcon, null),
5313
+ icon: /* @__PURE__ */ React58.createElement(WrenchIcon, null),
5210
5314
  order: 1
5211
5315
  };
5212
5316
  }
@@ -5215,7 +5319,7 @@ var getCardData = (roleName, roomId) => {
5215
5319
  };
5216
5320
  var Card = ({ title, icon, link, content, isHLSRunning, order = 0 }) => {
5217
5321
  const [copied, setCopied] = useState33(false);
5218
- return isHLSRunning ? /* @__PURE__ */ React56.createElement(
5322
+ return isHLSRunning ? /* @__PURE__ */ React58.createElement(
5219
5323
  Box,
5220
5324
  {
5221
5325
  key: title,
@@ -5226,9 +5330,9 @@ var Card = ({ title, icon, link, content, isHLSRunning, order = 0 }) => {
5226
5330
  borderRadius: "$2"
5227
5331
  }
5228
5332
  },
5229
- /* @__PURE__ */ React56.createElement(Flex, { align: "center", gap: "2", css: { color: "$primary_bright" } }, icon, /* @__PURE__ */ React56.createElement(Text, { variant: "h6", css: { fontWeight: "$semiBold" } }, title)),
5230
- /* @__PURE__ */ React56.createElement(Text, { variant: "sm", css: { color: "$on_surface_medium", mt: "$6" } }, content),
5231
- /* @__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(
5232
5336
  Button,
5233
5337
  {
5234
5338
  variant: "standard",
@@ -5240,7 +5344,7 @@ var Card = ({ title, icon, link, content, isHLSRunning, order = 0 }) => {
5240
5344
  css: { w: "100%", r: "$1", mt: "$10", fontWeight: "$semiBold" },
5241
5345
  icon: true
5242
5346
  },
5243
- 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")
5244
5348
  )
5245
5349
  ) : null;
5246
5350
  };
@@ -5250,12 +5354,12 @@ var HLSStreaming = ({ onBack }) => {
5250
5354
  const cards = roleNames.map((roleName) => getCardData(roleName, roomId));
5251
5355
  const { isHLSRunning } = useRecordingStreaming6();
5252
5356
  const [showLinks, setShowLinks] = useState33(false);
5253
- 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 })))));
5254
5358
  };
5255
5359
  var StartHLS = () => {
5256
5360
  const [record, setRecord] = useState33(false);
5257
5361
  const [error, setError] = useState33(false);
5258
- const hmsActions = useHMSActions19();
5362
+ const hmsActions = useHMSActions20();
5259
5363
  const [isHLSStarted, setHLSStarted] = useSetAppDataByKey(APP_DATA.hlsStarted);
5260
5364
  const startHLS = useCallback15(
5261
5365
  (variants) => __async(void 0, null, function* () {
@@ -5276,7 +5380,7 @@ var StartHLS = () => {
5276
5380
  }),
5277
5381
  [hmsActions, record, isHLSStarted, setHLSStarted]
5278
5382
  );
5279
- 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(
5280
5384
  Button,
5281
5385
  {
5282
5386
  "data-testid": "start_hls",
@@ -5285,21 +5389,21 @@ var StartHLS = () => {
5285
5389
  onClick: () => startHLS(),
5286
5390
  disabled: isHLSStarted
5287
5391
  },
5288
- 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),
5289
5393
  isHLSStarted ? "Starting stream..." : "Go Live"
5290
- )), /* @__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.")));
5291
5395
  };
5292
5396
  var EndHLS = ({ setShowLinks }) => {
5293
- const hmsActions = useHMSActions19();
5397
+ const hmsActions = useHMSActions20();
5294
5398
  const [inProgress, setInProgress] = useState33(false);
5295
5399
  const [error, setError] = useState33("");
5296
5400
  const { isHLSRunning } = useRecordingStreaming6();
5297
- useEffect22(() => {
5401
+ useEffect23(() => {
5298
5402
  if (inProgress && !isHLSRunning) {
5299
5403
  setInProgress(false);
5300
5404
  }
5301
5405
  }, [inProgress, isHLSRunning]);
5302
- 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(
5303
5407
  Button,
5304
5408
  {
5305
5409
  "data-testid": "stop_hls",
@@ -5318,9 +5422,9 @@ var EndHLS = ({ setShowLinks }) => {
5318
5422
  }
5319
5423
  })
5320
5424
  },
5321
- /* @__PURE__ */ React56.createElement(EndStreamIcon2, null),
5425
+ /* @__PURE__ */ React58.createElement(EndStreamIcon2, null),
5322
5426
  "End Stream"
5323
- ), /* @__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"));
5324
5428
  };
5325
5429
 
5326
5430
  // src/Prebuilt/components/Streaming/StreamingLanding.jsx
@@ -5334,7 +5438,7 @@ var StreamingLanding = () => {
5334
5438
  toggleStreaming();
5335
5439
  return null;
5336
5440
  }
5337
- 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(
5338
5442
  Box,
5339
5443
  {
5340
5444
  css: {
@@ -5344,8 +5448,8 @@ var StreamingLanding = () => {
5344
5448
  r: "$round"
5345
5449
  }
5346
5450
  },
5347
- /* @__PURE__ */ React57.createElement(ColoredHandIcon, { width: 40, height: 40 })
5348
- ), /* @__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(
5349
5453
  StreamCard,
5350
5454
  {
5351
5455
  testId: "hls_stream",
@@ -5355,7 +5459,7 @@ var StreamingLanding = () => {
5355
5459
  onClick: () => setShowHLS(true),
5356
5460
  Icon: GoLiveIcon3
5357
5461
  }
5358
- ), (permissions == null ? void 0 : permissions.rtmpStreaming) && /* @__PURE__ */ React57.createElement(
5462
+ ), (permissions == null ? void 0 : permissions.rtmpStreaming) && /* @__PURE__ */ React59.createElement(
5359
5463
  StreamCard,
5360
5464
  {
5361
5465
  testId: "rtmp_stream",
@@ -5367,7 +5471,7 @@ var StreamingLanding = () => {
5367
5471
  },
5368
5472
  imgSrc: rtmp_default
5369
5473
  }
5370
- ), 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) }));
5371
5475
  };
5372
5476
 
5373
5477
  // src/Prebuilt/layouts/SidePane.tsx
@@ -5377,16 +5481,16 @@ var SidePane = ({
5377
5481
  hideControls = false
5378
5482
  }) => {
5379
5483
  var _a, _b;
5380
- const isMobile = useMedia15(config.media.md);
5484
+ const isMobile = useMedia16(config.media.md);
5381
5485
  const sidepane = useHMSStore33(selectAppData3(APP_DATA.sidePane));
5382
5486
  const activeScreensharePeerId = useHMSStore33(selectAppData3(APP_DATA.activeScreensharePeerId));
5383
5487
  const trackId = (_a = useHMSStore33(selectVideoTrackByPeerID(activeScreensharePeerId))) == null ? void 0 : _a.id;
5384
5488
  const { elements } = useRoomLayoutConferencingScreen();
5385
5489
  let ViewComponent;
5386
5490
  if (sidepane === SIDE_PANE_OPTIONS.PARTICIPANTS || sidepane === SIDE_PANE_OPTIONS.CHAT) {
5387
- ViewComponent = /* @__PURE__ */ React58.createElement(SidePaneTabs, { screenType, hideControls, active: sidepane });
5491
+ ViewComponent = /* @__PURE__ */ React60.createElement(SidePaneTabs, { screenType, hideControls, active: sidepane });
5388
5492
  } else if (sidepane === SIDE_PANE_OPTIONS.STREAMING) {
5389
- ViewComponent = /* @__PURE__ */ React58.createElement(StreamingLanding, null);
5493
+ ViewComponent = /* @__PURE__ */ React60.createElement(StreamingLanding, null);
5390
5494
  }
5391
5495
  if (!ViewComponent && !trackId) {
5392
5496
  return null;
@@ -5399,7 +5503,7 @@ var SidePane = ({
5399
5503
  objectFit: tileProps == null ? void 0 : tileProps.video_object_fit
5400
5504
  };
5401
5505
  const mwebStreamingChat = isMobile && sidepane === SIDE_PANE_OPTIONS.CHAT && ((_b = elements == null ? void 0 : elements.chat) == null ? void 0 : _b.is_overlay);
5402
- return /* @__PURE__ */ React58.createElement(
5506
+ return /* @__PURE__ */ React60.createElement(
5403
5507
  Flex,
5404
5508
  {
5405
5509
  direction: "column",
@@ -5412,17 +5516,16 @@ var SidePane = ({
5412
5516
  "@md": { position: mwebStreamingChat ? "absolute" : "", zIndex: 12 }
5413
5517
  }
5414
5518
  },
5415
- trackId && /* @__PURE__ */ React58.createElement(
5519
+ trackId && /* @__PURE__ */ React60.createElement(
5416
5520
  VideoTile_default,
5417
5521
  __spreadValues({
5418
5522
  peerId: activeScreensharePeerId,
5419
5523
  trackId,
5420
- width: "100%",
5421
5524
  height: 225,
5422
5525
  rootCSS: { p: 0, alignSelf: "start", flexShrink: 0 }
5423
5526
  }, tileLayout)
5424
5527
  ),
5425
- !!ViewComponent && /* @__PURE__ */ React58.createElement(
5528
+ !!ViewComponent && /* @__PURE__ */ React60.createElement(
5426
5529
  Box,
5427
5530
  {
5428
5531
  css: {
@@ -5458,10 +5561,10 @@ var SidePane = ({
5458
5561
  var SidePane_default = SidePane;
5459
5562
 
5460
5563
  // src/Prebuilt/layouts/WaitingView.jsx
5461
- import React59 from "react";
5564
+ import React61 from "react";
5462
5565
  import { ColoredTimeIcon } from "@100mslive/react-icons";
5463
- var WaitingView = React59.memo(() => {
5464
- return /* @__PURE__ */ React59.createElement(
5566
+ var WaitingView = React61.memo(() => {
5567
+ return /* @__PURE__ */ React61.createElement(
5465
5568
  Box,
5466
5569
  {
5467
5570
  css: {
@@ -5475,7 +5578,7 @@ var WaitingView = React59.memo(() => {
5475
5578
  },
5476
5579
  "data-testid": "waiting_view"
5477
5580
  },
5478
- /* @__PURE__ */ React59.createElement(
5581
+ /* @__PURE__ */ React61.createElement(
5479
5582
  Flex,
5480
5583
  {
5481
5584
  align: "center",
@@ -5489,8 +5592,8 @@ var WaitingView = React59.memo(() => {
5489
5592
  gap: "$8"
5490
5593
  }
5491
5594
  },
5492
- /* @__PURE__ */ React59.createElement(ColoredTimeIcon, { width: "80px", height: "80px" }),
5493
- /* @__PURE__ */ React59.createElement(
5595
+ /* @__PURE__ */ React61.createElement(ColoredTimeIcon, { width: "80px", height: "80px" }),
5596
+ /* @__PURE__ */ React61.createElement(
5494
5597
  Flex,
5495
5598
  {
5496
5599
  direction: "column",
@@ -5500,28 +5603,28 @@ var WaitingView = React59.memo(() => {
5500
5603
  gap: "$4"
5501
5604
  }
5502
5605
  },
5503
- /* @__PURE__ */ React59.createElement(Text, { color: "white", variant: "h6", css: { "@md": { fontSize: "$md" } } }, "Please wait"),
5504
- /* @__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.")
5505
5608
  )
5506
5609
  )
5507
5610
  );
5508
5611
  });
5509
5612
 
5510
5613
  // src/Prebuilt/layouts/VideoStreamingSection.tsx
5511
- var HLSView = React60.lazy(() => import("./HLSView-4NSE37G7.js"));
5614
+ var HLSView = React62.lazy(() => import("./HLSView-3S74KF3A.js"));
5512
5615
  var VideoStreamingSection = ({
5513
5616
  screenType,
5514
5617
  elements,
5515
5618
  hideControls = false
5516
5619
  }) => {
5517
5620
  var _a, _b;
5518
- const localPeerRole = useHMSStore34(selectLocalPeerRoleName2);
5621
+ const localPeerRole = useHMSStore34(selectLocalPeerRoleName3);
5519
5622
  const isConnected = useHMSStore34(selectIsConnectedToRoom6);
5520
- const hmsActions = useHMSActions20();
5623
+ const hmsActions = useHMSActions21();
5521
5624
  const waitingViewerRole = useWaitingViewerRole();
5522
5625
  const urlToIframe = useUrlToEmbed();
5523
5626
  const pdfAnnotatorActive = usePDFAnnotator();
5524
- useEffect23(() => {
5627
+ useEffect24(() => {
5525
5628
  if (!isConnected) {
5526
5629
  return;
5527
5630
  }
@@ -5532,17 +5635,17 @@ var VideoStreamingSection = ({
5532
5635
  }
5533
5636
  let ViewComponent;
5534
5637
  if (screenType === "hls_live_streaming") {
5535
- ViewComponent = /* @__PURE__ */ React60.createElement(HLSView, null);
5638
+ ViewComponent = /* @__PURE__ */ React62.createElement(HLSView, null);
5536
5639
  } else if (localPeerRole === waitingViewerRole) {
5537
- ViewComponent = /* @__PURE__ */ React60.createElement(WaitingView, null);
5640
+ ViewComponent = /* @__PURE__ */ React62.createElement(WaitingView, null);
5538
5641
  } else if (pdfAnnotatorActive) {
5539
- ViewComponent = /* @__PURE__ */ React60.createElement(PDFView, null);
5642
+ ViewComponent = /* @__PURE__ */ React62.createElement(PDFView, null);
5540
5643
  } else if (urlToIframe) {
5541
- ViewComponent = /* @__PURE__ */ React60.createElement(EmbedView, null);
5644
+ ViewComponent = /* @__PURE__ */ React62.createElement(EmbedView, null);
5542
5645
  } else {
5543
- 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));
5544
5647
  }
5545
- 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(
5546
5649
  Flex,
5547
5650
  {
5548
5651
  css: {
@@ -5552,7 +5655,7 @@ var VideoStreamingSection = ({
5552
5655
  }
5553
5656
  },
5554
5657
  ViewComponent,
5555
- /* @__PURE__ */ React60.createElement(
5658
+ /* @__PURE__ */ React62.createElement(
5556
5659
  SidePane_default,
5557
5660
  {
5558
5661
  screenType,
@@ -5563,79 +5666,6 @@ var VideoStreamingSection = ({
5563
5666
  ));
5564
5667
  };
5565
5668
 
5566
- // src/Prebuilt/components/RoleChangeRequestModal.tsx
5567
- import React61, { useEffect as useEffect24 } from "react";
5568
- import {
5569
- selectLocalPeerName,
5570
- selectLocalPeerRoleName as selectLocalPeerRoleName3,
5571
- selectRoleChangeRequest,
5572
- useCustomEvent as useCustomEvent2,
5573
- useHMSActions as useHMSActions21,
5574
- useHMSStore as useHMSStore35
5575
- } from "@100mslive/react-sdk";
5576
- var RoleChangeRequestModal = () => {
5577
- const hmsActions = useHMSActions21();
5578
- const { updateMetaData } = useMyMetadata();
5579
- const currentRole = useHMSStore35(selectLocalPeerRoleName3);
5580
- const roleChangeRequest = useHMSStore35(selectRoleChangeRequest);
5581
- const name = useHMSStore35(selectLocalPeerName);
5582
- const { sendEvent } = useCustomEvent2({ type: ROLE_CHANGE_DECLINED });
5583
- useEffect24(() => {
5584
- if (!(roleChangeRequest == null ? void 0 : roleChangeRequest.role)) {
5585
- return;
5586
- }
5587
- (() => __async(void 0, null, function* () {
5588
- yield hmsActions.preview({ asRole: roleChangeRequest.role.name });
5589
- }))();
5590
- }, [hmsActions, roleChangeRequest, currentRole, updateMetaData]);
5591
- if (!(roleChangeRequest == null ? void 0 : roleChangeRequest.role)) {
5592
- return null;
5593
- }
5594
- 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(
5595
- Flex,
5596
- {
5597
- align: "center",
5598
- justify: "center",
5599
- css: {
5600
- "@sm": { width: "100%" },
5601
- flexDirection: "column",
5602
- mt: "$6"
5603
- }
5604
- },
5605
- /* @__PURE__ */ React61.createElement(PreviewTile, { name: name || "" }),
5606
- /* @__PURE__ */ React61.createElement(PreviewControls, { hideSettings: true })
5607
- ));
5608
- return /* @__PURE__ */ React61.createElement(
5609
- RequestDialog,
5610
- {
5611
- title: `You're invited to join the ${roleChangeRequest.role.name} role`,
5612
- onOpenChange: (value) => __async(void 0, null, function* () {
5613
- var _a;
5614
- if (!value) {
5615
- yield hmsActions.rejectChangeRole(roleChangeRequest);
5616
- sendEvent(__spreadProps(__spreadValues({}, roleChangeRequest), { peerName: name }), { peerId: (_a = roleChangeRequest.requestedBy) == null ? void 0 : _a.id });
5617
- yield hmsActions.cancelMidCallPreview();
5618
- yield updateMetaData({ isHandRaised: false });
5619
- }
5620
- }),
5621
- body,
5622
- onAction: () => __async(void 0, null, function* () {
5623
- yield hmsActions.acceptChangeRole(roleChangeRequest);
5624
- yield updateMetaData({ isHandRaised: false, prevRole: currentRole });
5625
- }),
5626
- actionText: "Accept"
5627
- }
5628
- );
5629
- };
5630
- var RequestDialog = ({
5631
- open = true,
5632
- onOpenChange,
5633
- title,
5634
- body,
5635
- actionText = "Accept",
5636
- onAction
5637
- }) => /* @__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))))));
5638
-
5639
5669
  // src/Prebuilt/components/conference.jsx
5640
5670
  var Conference = () => {
5641
5671
  var _a, _b, _c, _d, _e;
@@ -5644,12 +5674,12 @@ var Conference = () => {
5644
5674
  const { userName, endpoints } = useHMSPrebuiltContext();
5645
5675
  const screenProps = useRoomLayoutConferencingScreen();
5646
5676
  const { isPreviewScreenEnabled } = useRoomLayoutPreviewScreen();
5647
- const roomState = useHMSStore36(selectRoomState);
5677
+ const roomState = useHMSStore35(selectRoomState);
5648
5678
  const prevState = usePrevious(roomState);
5649
- const isConnectedToRoom = useHMSStore36(selectIsConnectedToRoom7);
5679
+ const isConnectedToRoom = useHMSStore35(selectIsConnectedToRoom7);
5650
5680
  const hmsActions = useHMSActions22();
5651
5681
  const [hideControls, setHideControls] = useState35(false);
5652
- const dropdownList = useHMSStore36(selectAppData4(APP_DATA.dropdownList));
5682
+ const dropdownList = useHMSStore35(selectAppData4(APP_DATA.dropdownList));
5653
5683
  const authTokenInAppData = useAuthToken();
5654
5684
  const headerRef = useRef14();
5655
5685
  const footerRef = useRef14();
@@ -5714,9 +5744,9 @@ var Conference = () => {
5714
5744
  };
5715
5745
  }, []);
5716
5746
  if (!isConnectedToRoom) {
5717
- return /* @__PURE__ */ React62.createElement(FullPageProgress_default, { text: "Joining..." });
5747
+ return /* @__PURE__ */ React63.createElement(FullPageProgress_default, { text: "Joining..." });
5718
5748
  }
5719
- 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(
5720
5750
  Box,
5721
5751
  {
5722
5752
  ref: headerRef,
@@ -5730,8 +5760,8 @@ var Conference = () => {
5730
5760
  },
5731
5761
  "data-testid": "header"
5732
5762
  },
5733
- /* @__PURE__ */ React62.createElement(Header, { elements: screenProps.elements, screenType: screenProps.screenType })
5734
- ), /* @__PURE__ */ React62.createElement(
5763
+ /* @__PURE__ */ React63.createElement(Header, { elements: screenProps.elements, screenType: screenProps.screenType })
5764
+ ), /* @__PURE__ */ React63.createElement(
5735
5765
  Box,
5736
5766
  {
5737
5767
  css: {
@@ -5749,7 +5779,7 @@ var Conference = () => {
5749
5779
  "data-testid": "conferencing",
5750
5780
  onClick: toggleControls
5751
5781
  },
5752
- /* @__PURE__ */ React62.createElement(
5782
+ /* @__PURE__ */ React63.createElement(
5753
5783
  VideoStreamingSection,
5754
5784
  {
5755
5785
  screenType: screenProps.screenType,
@@ -5757,7 +5787,7 @@ var Conference = () => {
5757
5787
  hideControls
5758
5788
  }
5759
5789
  )
5760
- ), !screenProps.hideSections.includes("footer") && /* @__PURE__ */ React62.createElement(
5790
+ ), !screenProps.hideSections.includes("footer") && /* @__PURE__ */ React63.createElement(
5761
5791
  Box,
5762
5792
  {
5763
5793
  ref: footerRef,
@@ -5774,11 +5804,11 @@ var Conference = () => {
5774
5804
  },
5775
5805
  "data-testid": "footer"
5776
5806
  },
5777
- /* @__PURE__ */ React62.createElement(Footer2, { elements: screenProps.elements, screenType: screenProps.screenType })
5778
- ), /* @__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)));
5779
5809
  };
5780
5810
  var conference_default = Conference;
5781
5811
  export {
5782
5812
  conference_default as default
5783
5813
  };
5784
- //# sourceMappingURL=conference-S7R3O4OC.js.map
5814
+ //# sourceMappingURL=conference-JNABIZBG.js.map