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

Sign up to get free protection for your applications and to get access to all the features.
Files changed (53) hide show
  1. package/dist/AudioLevel/AudioLevel.d.ts +5 -8
  2. package/dist/AudioLevel/index.d.ts +2 -1
  3. package/dist/AudioLevel/useBorderAudioLevel.d.ts +8 -0
  4. package/dist/{HLSView-3S74KF3A.js → HLSView-IQRPLYNH.js} +5 -4
  5. package/dist/{HLSView-3S74KF3A.js.map → HLSView-IQRPLYNH.js.map} +2 -2
  6. package/dist/Prebuilt/components/Chip.d.ts +12 -0
  7. package/dist/Prebuilt/components/PrebuiltDialogPortal.d.ts +4 -0
  8. package/dist/{VirtualBackground-3TI5NA4V.js → VirtualBackground-GP4ATXD3.js} +3 -3
  9. package/dist/{chunk-36X4ZCLC.js → chunk-2H5NIZB7.js} +2 -2
  10. package/dist/{chunk-Z7P5WITU.js → chunk-GLYGPYNS.js} +560 -1190
  11. package/dist/chunk-GLYGPYNS.js.map +7 -0
  12. package/dist/{chunk-5DQ3WTED.js → chunk-Z3O2WGWV.js} +2 -2
  13. package/dist/{chunk-5DQ3WTED.js.map → chunk-Z3O2WGWV.js.map} +1 -1
  14. package/dist/{conference-JNABIZBG.js → conference-JD35TNH4.js} +1351 -662
  15. package/dist/conference-JD35TNH4.js.map +7 -0
  16. package/dist/index.cjs.js +3387 -3297
  17. package/dist/index.cjs.js.map +4 -4
  18. package/dist/index.js +4 -2
  19. package/dist/meta.cjs.json +1001 -826
  20. package/dist/meta.esbuild.json +1053 -877
  21. package/package.json +6 -6
  22. package/src/AudioLevel/AudioLevel.tsx +79 -30
  23. package/src/AudioLevel/audio-level.png +0 -0
  24. package/src/AudioLevel/index.ts +2 -1
  25. package/src/AudioLevel/useBorderAudioLevel.tsx +34 -0
  26. package/src/Prebuilt/App.tsx +1 -0
  27. package/src/Prebuilt/common/utils.js +0 -7
  28. package/src/Prebuilt/components/{Chip.jsx → Chip.tsx} +13 -2
  29. package/src/Prebuilt/components/Footer/ParticipantList.jsx +23 -12
  30. package/src/Prebuilt/components/Footer/RoleAccordion.tsx +43 -3
  31. package/src/Prebuilt/components/Leave/DesktopLeaveRoom.tsx +7 -4
  32. package/src/Prebuilt/components/MoreSettings/ChangeNameModal.jsx +3 -2
  33. package/src/Prebuilt/components/MoreSettings/EmbedUrl.jsx +3 -2
  34. package/src/Prebuilt/components/MwebLandscapePrompt.jsx +58 -0
  35. package/src/Prebuilt/components/Notifications/HLSFailureModal.jsx +3 -2
  36. package/src/Prebuilt/components/Notifications/PermissionErrorModal.jsx +3 -2
  37. package/src/Prebuilt/components/PrebuiltDialogPortal.tsx +6 -0
  38. package/src/Prebuilt/components/Preview/PreviewJoin.tsx +4 -3
  39. package/src/Prebuilt/components/RoleChangeModal.jsx +3 -2
  40. package/src/Prebuilt/components/RoleChangeRequest/RequestPrompt.tsx +3 -2
  41. package/src/Prebuilt/components/Settings/SettingsModal.jsx +3 -2
  42. package/src/Prebuilt/components/Settings/StartRecording.jsx +3 -2
  43. package/src/Prebuilt/components/StatsForNerds.jsx +3 -2
  44. package/src/Prebuilt/components/VideoTile.jsx +22 -69
  45. package/src/Prebuilt/components/pdfAnnotator/pdfFileOptions.jsx +3 -2
  46. package/src/Prebuilt/components/pdfAnnotator/shareScreenOptions.jsx +4 -29
  47. package/src/Prebuilt/components/pdfAnnotator/uploadedFile.jsx +3 -2
  48. package/src/Prebuilt/layouts/HLSView.jsx +1 -0
  49. package/src/Prebuilt/primitives/DialogContent.jsx +5 -4
  50. package/dist/chunk-Z7P5WITU.js.map +0 -7
  51. package/dist/conference-JNABIZBG.js.map +0 -7
  52. /package/dist/{VirtualBackground-3TI5NA4V.js.map → VirtualBackground-GP4ATXD3.js.map} +0 -0
  53. /package/dist/{chunk-36X4ZCLC.js.map → chunk-2H5NIZB7.js.map} +0 -0
@@ -1,14 +1,16 @@
1
1
  import {
2
2
  ActionTile
3
- } from "./chunk-36X4ZCLC.js";
3
+ } from "./chunk-2H5NIZB7.js";
4
4
  import {
5
5
  APP_DATA,
6
6
  Accordion,
7
+ AudioLevel,
7
8
  AudioVideoToggle,
9
+ Avatar,
8
10
  Button,
9
11
  CHAT_SELECTOR,
10
- ChangeNameModal,
11
12
  Checkbox,
13
+ Chip_default,
12
14
  ConnectionIndicator,
13
15
  Dialog,
14
16
  DialogCol,
@@ -27,8 +29,10 @@ import {
27
29
  Label,
28
30
  PictureInPicture,
29
31
  Popover,
32
+ PrebuiltDialogPortal,
30
33
  PreviewControls,
31
34
  PreviewTile,
35
+ REMOTE_STOP_SCREENSHARE_TYPE,
32
36
  ROLE_CHANGE_DECLINED,
33
37
  RTMP_RECORD_DEFAULT_RESOLUTION,
34
38
  RTMP_RECORD_RESOLUTION_MAX,
@@ -38,22 +42,22 @@ import {
38
42
  SIDE_PANE_OPTIONS,
39
43
  SettingsModal_default,
40
44
  Sheet,
45
+ Slider,
41
46
  StopRecordingInSheet,
47
+ StyledMenuTile,
42
48
  StyledPagination,
43
49
  StyledVideoTile,
44
50
  Switch,
45
51
  Tabs,
46
52
  ThemeTypes,
47
- TileMenu_default,
53
+ TileConnection_default,
48
54
  ToastManager,
49
55
  UI_SETTINGS,
50
56
  UserPreferencesKeys,
51
57
  Video,
52
58
  VideoTileStats,
53
- VideoTile_default,
54
59
  getFormattedCount,
55
60
  getMetadata,
56
- getVideoTileLabel,
57
61
  isAndroid,
58
62
  isChrome,
59
63
  isIOS,
@@ -61,7 +65,6 @@ import {
61
65
  isMacOS,
62
66
  isScreenshareSupported,
63
67
  useAuthToken,
64
- useDropdownList,
65
68
  useDropdownSelection,
66
69
  useFilteredRoles,
67
70
  useHMSPrebuiltContext,
@@ -83,7 +86,7 @@ import {
83
86
  useUrlToEmbed,
84
87
  useUserPreferences,
85
88
  useWaitingViewerRole
86
- } from "./chunk-Z7P5WITU.js";
89
+ } from "./chunk-GLYGPYNS.js";
87
90
  import {
88
91
  Box,
89
92
  Flex,
@@ -102,10 +105,10 @@ import {
102
105
  slideLeftAndFade,
103
106
  styled,
104
107
  textEllipsis
105
- } from "./chunk-5DQ3WTED.js";
108
+ } from "./chunk-Z3O2WGWV.js";
106
109
 
107
110
  // src/Prebuilt/components/conference.jsx
108
- import React63, { useEffect as useEffect25, useRef as useRef14, useState as useState35 } from "react";
111
+ import React68, { useEffect as useEffect27, useRef as useRef16, useState as useState39 } from "react";
109
112
  import { useNavigate, useParams } from "react-router-dom";
110
113
  import { usePrevious } from "react-use";
111
114
  import {
@@ -113,13 +116,13 @@ import {
113
116
  selectAppData as selectAppData4,
114
117
  selectIsConnectedToRoom as selectIsConnectedToRoom7,
115
118
  selectRoomState,
116
- useHMSActions as useHMSActions22,
117
- useHMSStore as useHMSStore35
119
+ useHMSActions as useHMSActions25,
120
+ useHMSStore as useHMSStore39
118
121
  } from "@100mslive/react-sdk";
119
122
 
120
123
  // src/Prebuilt/components/Footer/Footer.tsx
121
- import React36, { Suspense, useEffect as useEffect6 } from "react";
122
- import { useMedia as useMedia5 } from "react-use";
124
+ import React38, { Suspense, useEffect as useEffect8 } from "react";
125
+ import { useMedia as useMedia6 } from "react-use";
123
126
  import { Chat_ChatState } from "@100mslive/types-prebuilt/elements/chat";
124
127
  import { useAVToggle as useAVToggle2 } from "@100mslive/react-sdk";
125
128
 
@@ -159,6 +162,26 @@ var EmojiContainer = styled("span", {
159
162
  }
160
163
  });
161
164
 
165
+ // src/Prebuilt/components/hooks/useDropdownList.jsx
166
+ import { useEffect } from "react";
167
+ var useDropdownList = ({ name, open }) => {
168
+ const [dropdownList = [], setDropdownList] = useSetAppDataByKey(APP_DATA.dropdownList);
169
+ useEffect(() => {
170
+ if (open) {
171
+ if (!dropdownList.includes(name)) {
172
+ setDropdownList([...dropdownList, name]);
173
+ }
174
+ } else {
175
+ const index = dropdownList.indexOf(name);
176
+ if (index >= 0) {
177
+ const newDropdownList = [...dropdownList];
178
+ newDropdownList.splice(index, 1);
179
+ setDropdownList(newDropdownList);
180
+ }
181
+ }
182
+ }, [open, name]);
183
+ };
184
+
162
185
  // src/Prebuilt/components/EmojiReaction.jsx
163
186
  init({ data });
164
187
  var EmojiReaction = () => {
@@ -431,7 +454,7 @@ var DesktopLeaveRoom = ({
431
454
  "data-testid": "leave_room_btn"
432
455
  },
433
456
  /* @__PURE__ */ React6.createElement(Tooltip, { title: "Leave Room" }, /* @__PURE__ */ React6.createElement(Box, null, /* @__PURE__ */ React6.createElement(ExitIcon, { style: { transform: "rotate(180deg)" } })))
434
- ), /* @__PURE__ */ React6.createElement(Dialog.Root, { open: showEndStreamAlert, 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(
457
+ ), /* @__PURE__ */ React6.createElement(Dialog.Root, { open: showEndStreamAlert, modal: false }, /* @__PURE__ */ React6.createElement(PrebuiltDialogPortal, 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(
435
458
  EndSessionContent,
436
459
  {
437
460
  setShowEndStreamAlert,
@@ -439,7 +462,7 @@ var DesktopLeaveRoom = ({
439
462
  isStreamingOn,
440
463
  isModal: true
441
464
  }
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 })))));
465
+ )))), /* @__PURE__ */ React6.createElement(Dialog.Root, { open: showLeaveRoomAlert, modal: false }, /* @__PURE__ */ React6.createElement(PrebuiltDialogPortal, 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 })))));
443
466
  };
444
467
 
445
468
  // src/Prebuilt/components/Leave/MwebLeaveRoom.tsx
@@ -553,8 +576,8 @@ var LeaveRoom = ({ screenType }) => {
553
576
  };
554
577
 
555
578
  // src/Prebuilt/components/MoreSettings/MoreSettings.tsx
556
- import React23 from "react";
557
- import { useMedia as useMedia3 } from "react-use";
579
+ import React25 from "react";
580
+ import { useMedia as useMedia4 } from "react-use";
558
581
 
559
582
  // src/Prebuilt/components/MoreSettings/SplitComponents/DesktopOptions.tsx
560
583
  import React21, { Fragment as Fragment4, useState as useState13 } from "react";
@@ -566,7 +589,7 @@ import { BrbIcon, CheckIcon as CheckIcon3, DragHandleIcon, InfoIcon as InfoIcon2
566
589
  import React10 from "react";
567
590
 
568
591
  // src/Prebuilt/components/PIP/PIPComponent.jsx
569
- import React9, { useCallback, useEffect, useState as useState4 } from "react";
592
+ import React9, { useCallback, useEffect as useEffect2, useState as useState4 } from "react";
570
593
  import { selectPeers, selectTracksMap, useHMSActions as useHMSActions2, useHMSStore as useHMSStore5, useHMSVanillaStore } from "@100mslive/react-sdk";
571
594
  import { PipIcon } from "@100mslive/react-icons";
572
595
 
@@ -646,7 +669,7 @@ var ActivatedPIP = () => {
646
669
  const tracksMap = useHMSStore5(selectTracksMap);
647
670
  const storePeers = useHMSStore5(selectPeers);
648
671
  const pinnedTrack = usePinnedTrack();
649
- useEffect(() => {
672
+ useEffect2(() => {
650
673
  function updatePIP() {
651
674
  if (!PictureInPicture.isOn()) {
652
675
  return;
@@ -707,7 +730,7 @@ var RoleChangeModal = ({ peerId, onOpenChange }) => {
707
730
  return null;
708
731
  }
709
732
  const peerNameMaxWidth = 200;
710
- return /* @__PURE__ */ React11.createElement(Dialog.Root, { defaultOpen: true, onOpenChange }, /* @__PURE__ */ React11.createElement(Dialog.Portal, null, /* @__PURE__ */ React11.createElement(Dialog.Overlay, null), /* @__PURE__ */ React11.createElement(Dialog.Content, { css: { width: "min(400px,80%)", p: "$10" } }, /* @__PURE__ */ React11.createElement(Dialog.Title, { css: { p: 0 }, asChild: true }, /* @__PURE__ */ React11.createElement(Text, { as: "h6", variant: "h6" }, "Change Role")), /* @__PURE__ */ React11.createElement(Dialog.Description, { asChild: true }, /* @__PURE__ */ React11.createElement(
733
+ return /* @__PURE__ */ React11.createElement(Dialog.Root, { defaultOpen: true, onOpenChange }, /* @__PURE__ */ React11.createElement(PrebuiltDialogPortal, null, /* @__PURE__ */ React11.createElement(Dialog.Overlay, null), /* @__PURE__ */ React11.createElement(Dialog.Content, { css: { width: "min(400px,80%)", p: "$10" } }, /* @__PURE__ */ React11.createElement(Dialog.Title, { css: { p: 0 }, asChild: true }, /* @__PURE__ */ React11.createElement(Text, { as: "h6", variant: "h6" }, "Change Role")), /* @__PURE__ */ React11.createElement(Dialog.Description, { asChild: true }, /* @__PURE__ */ React11.createElement(
711
734
  Text,
712
735
  {
713
736
  variant: "body2",
@@ -873,7 +896,7 @@ var ResolutionInput = ({ onResolutionChange, disabled, tooltipText, css, testId
873
896
  };
874
897
 
875
898
  // src/Prebuilt/components/Streaming/RTMPStreaming.jsx
876
- import React14, { useEffect as useEffect2, useRef as useRef2, useState as useState7 } from "react";
899
+ import React14, { useEffect as useEffect3, useRef as useRef2, useState as useState7 } from "react";
877
900
  import { useHMSActions as useHMSActions4, useRecordingStreaming as useRecordingStreaming3 } from "@100mslive/react-sdk";
878
901
  import { AddCircleIcon, EndStreamIcon, GoLiveIcon, PencilIcon, SettingsIcon, TrashIcon } from "@100mslive/react-icons";
879
902
 
@@ -1086,7 +1109,7 @@ var EndRTMP = () => {
1086
1109
  const [inProgress, setInProgress] = useState7(false);
1087
1110
  const [error, setError] = useState7("");
1088
1111
  const { isRTMPRunning } = useRecordingStreaming3();
1089
- useEffect2(() => {
1112
+ useEffect3(() => {
1090
1113
  if (inProgress && !isRTMPRunning) {
1091
1114
  setInProgress(false);
1092
1115
  }
@@ -1240,7 +1263,7 @@ var StartRecording = ({ open, onOpenChange }) => {
1240
1263
  return null;
1241
1264
  }
1242
1265
  if (isBrowserRecordingOn) {
1243
- return /* @__PURE__ */ React15.createElement(Dialog.Root, { open, onOpenChange }, /* @__PURE__ */ React15.createElement(Dialog.Portal, null, /* @__PURE__ */ React15.createElement(
1266
+ return /* @__PURE__ */ React15.createElement(Dialog.Root, { open, onOpenChange }, /* @__PURE__ */ React15.createElement(PrebuiltDialogPortal, null, /* @__PURE__ */ React15.createElement(
1244
1267
  Dialog.Content,
1245
1268
  {
1246
1269
  css: {
@@ -1319,7 +1342,7 @@ var StartRecording = ({ open, onOpenChange }) => {
1319
1342
  var StartRecording_default = StartRecording;
1320
1343
 
1321
1344
  // src/Prebuilt/components/StatsForNerds.jsx
1322
- import React16, { useEffect as useEffect3, useMemo, useRef as useRef3, useState as useState9 } from "react";
1345
+ import React16, { useEffect as useEffect4, useMemo, useRef as useRef3, useState as useState9 } from "react";
1323
1346
  import {
1324
1347
  selectHMSStats,
1325
1348
  selectLocalPeerID as selectLocalPeerID2,
@@ -1340,12 +1363,12 @@ var StatsForNerds = ({ onOpenChange }) => {
1340
1363
  const [open, setOpen] = useState9(false);
1341
1364
  const ref = useRef3();
1342
1365
  const selectionBg = useDropdownSelection();
1343
- useEffect3(() => {
1366
+ useEffect4(() => {
1344
1367
  if (selectedStat.id !== "local-peer" && !tracksWithLabels.find((track) => track.id === selectedStat.id)) {
1345
1368
  setSelectedStat("local-peer");
1346
1369
  }
1347
1370
  }, [tracksWithLabels, selectedStat]);
1348
- return /* @__PURE__ */ React16.createElement(Dialog.Root, { defaultOpen: true, onOpenChange }, /* @__PURE__ */ React16.createElement(Dialog.Portal, null, /* @__PURE__ */ React16.createElement(Dialog.Overlay, null), /* @__PURE__ */ React16.createElement(
1371
+ return /* @__PURE__ */ React16.createElement(Dialog.Root, { defaultOpen: true, onOpenChange }, /* @__PURE__ */ React16.createElement(PrebuiltDialogPortal, null, /* @__PURE__ */ React16.createElement(Dialog.Overlay, null), /* @__PURE__ */ React16.createElement(
1349
1372
  Dialog.Content,
1350
1373
  {
1351
1374
  css: {
@@ -1604,7 +1627,7 @@ import React18 from "react";
1604
1627
  import { ExpandIcon } from "@100mslive/react-icons";
1605
1628
 
1606
1629
  // src/Prebuilt/components/hooks/useFullscreen.js
1607
- import { useCallback as useCallback4, useEffect as useEffect4, useState as useState11 } from "react";
1630
+ import { useCallback as useCallback4, useEffect as useEffect5, useState as useState11 } from "react";
1608
1631
  import screenfull from "screenfull";
1609
1632
  var useFullscreen = () => {
1610
1633
  const [isFullScreenEnabled, setIsFullScreenEnabled] = useState11(screenfull.isFullscreen);
@@ -1623,7 +1646,7 @@ var useFullscreen = () => {
1623
1646
  ToastManager.addToast({ title: err.message });
1624
1647
  }
1625
1648
  }), [isFullScreenEnabled]);
1626
- useEffect4(() => {
1649
+ useEffect5(() => {
1627
1650
  const onChange = () => {
1628
1651
  setIsFullScreenEnabled(screenfull.isFullscreen);
1629
1652
  };
@@ -1857,20 +1880,20 @@ var DesktopOptions = ({
1857
1880
  };
1858
1881
 
1859
1882
  // src/Prebuilt/components/MoreSettings/SplitComponents/MwebOptions.tsx
1860
- import React22, { useRef as useRef5, useState as useState14 } from "react";
1883
+ import React24, { useRef as useRef5, useState as useState15 } from "react";
1861
1884
  import { useClickAway } from "react-use";
1862
1885
  import {
1863
1886
  selectIsConnectedToRoom as selectIsConnectedToRoom5,
1864
1887
  selectPeerCount,
1865
1888
  selectPermissions as selectPermissions6,
1866
1889
  useAVToggle,
1867
- useHMSActions as useHMSActions9,
1868
- useHMSStore as useHMSStore11,
1890
+ useHMSActions as useHMSActions10,
1891
+ useHMSStore as useHMSStore12,
1869
1892
  useRecordingStreaming as useRecordingStreaming5
1870
1893
  } from "@100mslive/react-sdk";
1871
1894
  import {
1872
1895
  BrbIcon as BrbIcon2,
1873
- CrossIcon as CrossIcon4,
1896
+ CrossIcon as CrossIcon5,
1874
1897
  DragHandleIcon as DragHandleIcon2,
1875
1898
  EmojiIcon as EmojiIcon2,
1876
1899
  HandIcon,
@@ -1879,6 +1902,161 @@ import {
1879
1902
  RecordIcon as RecordIcon2,
1880
1903
  SettingsIcon as SettingsIcon3
1881
1904
  } from "@100mslive/react-icons";
1905
+
1906
+ // src/Prebuilt/components/MoreSettings/ChangeNameModal.jsx
1907
+ import React23, { useState as useState14 } from "react";
1908
+ import { useMedia as useMedia3 } from "react-use";
1909
+ import { selectLocalPeerName, useHMSActions as useHMSActions9, useHMSStore as useHMSStore11 } from "@100mslive/react-sdk";
1910
+
1911
+ // src/Prebuilt/components/MoreSettings/ChangeNameContent.jsx
1912
+ import React22 from "react";
1913
+ import { ChevronLeftIcon as ChevronLeftIcon2, CrossIcon as CrossIcon4 } from "@100mslive/react-icons";
1914
+ var ChangeNameContent = ({
1915
+ changeName,
1916
+ setCurrentName,
1917
+ currentName,
1918
+ localPeerName,
1919
+ isMobile,
1920
+ onExit,
1921
+ onBackClick
1922
+ }) => {
1923
+ return /* @__PURE__ */ React22.createElement(
1924
+ "form",
1925
+ {
1926
+ onSubmit: (e) => __async(void 0, null, function* () {
1927
+ e.preventDefault();
1928
+ yield changeName();
1929
+ })
1930
+ },
1931
+ /* @__PURE__ */ React22.createElement(
1932
+ Text,
1933
+ {
1934
+ variant: isMobile ? "md" : "lg",
1935
+ css: {
1936
+ color: "$on_surface_high",
1937
+ fontWeight: "$semiBold",
1938
+ display: "flex",
1939
+ pb: "$4",
1940
+ "@md": { px: "$8", borderBottom: "1px solid $border_default" }
1941
+ }
1942
+ },
1943
+ isMobile ? /* @__PURE__ */ React22.createElement(ChevronLeftIcon2, { onClick: onBackClick, style: { marginRight: "0.5rem" } }) : null,
1944
+ "Change Name",
1945
+ /* @__PURE__ */ React22.createElement(
1946
+ Box,
1947
+ {
1948
+ css: { color: "inherit", ml: "auto", "&:hover": { color: "$on_surface_medium", cursor: "pointer" } },
1949
+ onClick: onExit
1950
+ },
1951
+ /* @__PURE__ */ React22.createElement(CrossIcon4, null)
1952
+ )
1953
+ ),
1954
+ /* @__PURE__ */ React22.createElement(Text, { variant: "sm", css: { color: "$on_surface_medium", pb: "$6", mb: "$8", "@md": { px: "$8", mt: "$4" } } }, "Your name will be visible to other participants in the session."),
1955
+ /* @__PURE__ */ React22.createElement(Flex, { justify: "center", align: "center", css: { my: "$8", w: "100%", "@md": { px: "$8" } } }, /* @__PURE__ */ React22.createElement(
1956
+ Input,
1957
+ {
1958
+ css: { width: "100%", bg: "$surface_default" },
1959
+ value: currentName,
1960
+ type: isMobile ? "search" : "text",
1961
+ onChange: (e) => {
1962
+ setCurrentName(e.target.value);
1963
+ },
1964
+ autoComplete: "name",
1965
+ required: true,
1966
+ "data-testid": "change_name_field",
1967
+ onKeyDown: (e) => __async(void 0, null, function* () {
1968
+ if (e.key === "Enter" && currentName.trim().length > 0 && currentName !== localPeerName) {
1969
+ e.preventDefault();
1970
+ if (isMobile) {
1971
+ return;
1972
+ }
1973
+ changeName();
1974
+ }
1975
+ })
1976
+ }
1977
+ )),
1978
+ /* @__PURE__ */ React22.createElement(
1979
+ Flex,
1980
+ {
1981
+ justify: "between",
1982
+ align: "center",
1983
+ css: {
1984
+ width: "100%",
1985
+ gap: "$md",
1986
+ mt: "$10",
1987
+ "@md": { px: "$4" }
1988
+ }
1989
+ },
1990
+ isMobile ? null : /* @__PURE__ */ React22.createElement(
1991
+ Button,
1992
+ {
1993
+ variant: "standard",
1994
+ css: { w: "100%" },
1995
+ outlined: true,
1996
+ type: "submit",
1997
+ disabled: !localPeerName,
1998
+ onClick: onExit
1999
+ },
2000
+ "Cancel"
2001
+ ),
2002
+ /* @__PURE__ */ React22.createElement(
2003
+ Button,
2004
+ {
2005
+ variant: "primary",
2006
+ css: { width: "100%" },
2007
+ type: "submit",
2008
+ disabled: !currentName.trim() || currentName.trim() === localPeerName,
2009
+ "data-testid": "popup_change_btn"
2010
+ },
2011
+ "Change"
2012
+ )
2013
+ )
2014
+ );
2015
+ };
2016
+
2017
+ // src/Prebuilt/components/MoreSettings/ChangeNameModal.jsx
2018
+ var ChangeNameModal = ({ onOpenChange, openParentSheet = null }) => {
2019
+ const [previewPreference, setPreviewPreference] = useUserPreferences(UserPreferencesKeys.PREVIEW);
2020
+ const hmsActions = useHMSActions9();
2021
+ const localPeerName = useHMSStore11(selectLocalPeerName);
2022
+ const [currentName, setCurrentName] = useState14(localPeerName);
2023
+ const isMobile = useMedia3(config.media.md);
2024
+ const changeName = () => __async(void 0, null, function* () {
2025
+ const name = currentName.trim();
2026
+ if (!name || name === localPeerName) {
2027
+ return;
2028
+ }
2029
+ try {
2030
+ yield hmsActions.changeName(name);
2031
+ setPreviewPreference(__spreadProps(__spreadValues({}, previewPreference || {}), {
2032
+ name
2033
+ }));
2034
+ } catch (error) {
2035
+ console.error("failed to update name", error);
2036
+ ToastManager.addToast({ title: error.message });
2037
+ } finally {
2038
+ onOpenChange(false);
2039
+ }
2040
+ });
2041
+ const props = {
2042
+ changeName,
2043
+ setCurrentName,
2044
+ currentName,
2045
+ localPeerName,
2046
+ isMobile,
2047
+ onExit: () => onOpenChange(false),
2048
+ onBackClick: () => {
2049
+ onOpenChange(false);
2050
+ openParentSheet();
2051
+ }
2052
+ };
2053
+ if (isMobile) {
2054
+ return /* @__PURE__ */ React23.createElement(Sheet.Root, { defaultOpen: true, onOpenChange }, /* @__PURE__ */ React23.createElement(Sheet.Content, { css: { bg: "$surface_dim", p: "$8 0" } }, /* @__PURE__ */ React23.createElement(ChangeNameContent, __spreadValues({}, props))));
2055
+ }
2056
+ return /* @__PURE__ */ React23.createElement(Dialog.Root, { defaultOpen: true, onOpenChange }, /* @__PURE__ */ React23.createElement(PrebuiltDialogPortal, null, /* @__PURE__ */ React23.createElement(Dialog.Overlay, null), /* @__PURE__ */ React23.createElement(Dialog.Content, { css: { bg: "$surface_dim", width: "min(400px,80%)", p: "$10" } }, /* @__PURE__ */ React23.createElement(ChangeNameContent, __spreadValues({}, props)))));
2057
+ };
2058
+
2059
+ // src/Prebuilt/components/MoreSettings/SplitComponents/MwebOptions.tsx
1882
2060
  var MODALS2 = {
1883
2061
  CHANGE_NAME: "changeName",
1884
2062
  SELF_ROLE_CHANGE: "selfRoleChange",
@@ -1894,18 +2072,18 @@ var MwebOptions = ({
1894
2072
  elements,
1895
2073
  screenType
1896
2074
  }) => {
1897
- const hmsActions = useHMSActions9();
1898
- const permissions = useHMSStore11(selectPermissions6);
1899
- const isConnected = useHMSStore11(selectIsConnectedToRoom5);
2075
+ const hmsActions = useHMSActions10();
2076
+ const permissions = useHMSStore12(selectPermissions6);
2077
+ const isConnected = useHMSStore12(selectIsConnectedToRoom5);
1900
2078
  const { isBrowserRecordingOn, isStreamingOn, isHLSRunning } = useRecordingStreaming5();
1901
- const [openModals, setOpenModals] = useState14(/* @__PURE__ */ new Set());
1902
- const [openOptionsSheet, setOpenOptionsSheet] = useState14(false);
1903
- const [openSettingsSheet, setOpenSettingsSheet] = useState14(false);
1904
- const [showEmojiCard, setShowEmojiCard] = useState14(false);
1905
- const [showRecordingOn, setShowRecordingOn] = useState14(false);
1906
- const [isRecordingLoading, setIsRecordingLoading] = useState14(false);
2079
+ const [openModals, setOpenModals] = useState15(/* @__PURE__ */ new Set());
2080
+ const [openOptionsSheet, setOpenOptionsSheet] = useState15(false);
2081
+ const [openSettingsSheet, setOpenSettingsSheet] = useState15(false);
2082
+ const [showEmojiCard, setShowEmojiCard] = useState15(false);
2083
+ const [showRecordingOn, setShowRecordingOn] = useState15(false);
2084
+ const [isRecordingLoading, setIsRecordingLoading] = useState15(false);
1907
2085
  const toggleParticipants = useSidepaneToggle(SIDE_PANE_OPTIONS.PARTICIPANTS);
1908
- const peerCount = useHMSStore11(selectPeerCount);
2086
+ const peerCount = useHMSStore12(selectPeerCount);
1909
2087
  const emojiCardRef = useRef5(null);
1910
2088
  const { isBRBOn, toggleBRB, isHandRaised, toggleHandRaise } = useMyMetadata();
1911
2089
  const { toggleAudio, toggleVideo } = useAVToggle();
@@ -1923,7 +2101,7 @@ var MwebOptions = ({
1923
2101
  });
1924
2102
  };
1925
2103
  useClickAway(emojiCardRef, () => setShowEmojiCard(false));
1926
- return /* @__PURE__ */ React22.createElement(React22.Fragment, null, /* @__PURE__ */ React22.createElement(Sheet.Root, { open: openOptionsSheet, onOpenChange: setOpenOptionsSheet }, /* @__PURE__ */ React22.createElement(Tooltip, { title: "More options" }, /* @__PURE__ */ React22.createElement(Sheet.Trigger, { asChild: true, "data-testid": "more_settings_btn" }, /* @__PURE__ */ React22.createElement(IconButton_default, null, /* @__PURE__ */ React22.createElement(DragHandleIcon2, null)))), /* @__PURE__ */ React22.createElement(Sheet.Content, { css: { bg: "$surface_dim", pb: "$14" } }, /* @__PURE__ */ React22.createElement(
2104
+ return /* @__PURE__ */ React24.createElement(React24.Fragment, null, /* @__PURE__ */ React24.createElement(Sheet.Root, { open: openOptionsSheet, onOpenChange: setOpenOptionsSheet }, /* @__PURE__ */ React24.createElement(Tooltip, { title: "More options" }, /* @__PURE__ */ React24.createElement(Sheet.Trigger, { asChild: true, "data-testid": "more_settings_btn" }, /* @__PURE__ */ React24.createElement(IconButton_default, null, /* @__PURE__ */ React24.createElement(DragHandleIcon2, null)))), /* @__PURE__ */ React24.createElement(Sheet.Content, { css: { bg: "$surface_dim", pb: "$14" } }, /* @__PURE__ */ React24.createElement(
1927
2105
  Sheet.Title,
1928
2106
  {
1929
2107
  css: {
@@ -1941,8 +2119,8 @@ var MwebOptions = ({
1941
2119
  }
1942
2120
  },
1943
2121
  "Options",
1944
- /* @__PURE__ */ React22.createElement(Sheet.Close, null, /* @__PURE__ */ React22.createElement(Box, { css: { color: "$on_surface_high" } }, /* @__PURE__ */ React22.createElement(CrossIcon4, null)))
1945
- ), /* @__PURE__ */ React22.createElement(
2122
+ /* @__PURE__ */ React24.createElement(Sheet.Close, null, /* @__PURE__ */ React24.createElement(Box, { css: { color: "$on_surface_high" } }, /* @__PURE__ */ React24.createElement(CrossIcon5, null)))
2123
+ ), /* @__PURE__ */ React24.createElement(
1946
2124
  Box,
1947
2125
  {
1948
2126
  css: {
@@ -1954,7 +2132,7 @@ var MwebOptions = ({
1954
2132
  px: "$9"
1955
2133
  }
1956
2134
  },
1957
- (elements == null ? void 0 : elements.participant_list) && /* @__PURE__ */ React22.createElement(
2135
+ (elements == null ? void 0 : elements.participant_list) && /* @__PURE__ */ React24.createElement(
1958
2136
  ActionTile.Root,
1959
2137
  {
1960
2138
  onClick: () => {
@@ -1962,11 +2140,11 @@ var MwebOptions = ({
1962
2140
  setOpenOptionsSheet(false);
1963
2141
  }
1964
2142
  },
1965
- /* @__PURE__ */ React22.createElement(ActionTile.Count, null, getFormattedCount(peerCount)),
1966
- /* @__PURE__ */ React22.createElement(PeopleIcon, null),
1967
- /* @__PURE__ */ React22.createElement(ActionTile.Title, null, "Participants")
2143
+ /* @__PURE__ */ React24.createElement(ActionTile.Count, null, getFormattedCount(peerCount)),
2144
+ /* @__PURE__ */ React24.createElement(PeopleIcon, null),
2145
+ /* @__PURE__ */ React24.createElement(ActionTile.Title, null, "Participants")
1968
2146
  ),
1969
- !noAVPermissions ? /* @__PURE__ */ React22.createElement(
2147
+ !noAVPermissions ? /* @__PURE__ */ React24.createElement(
1970
2148
  ActionTile.Root,
1971
2149
  {
1972
2150
  active: isHandRaised,
@@ -1975,10 +2153,10 @@ var MwebOptions = ({
1975
2153
  setOpenOptionsSheet(false);
1976
2154
  }
1977
2155
  },
1978
- isHandRaised ? /* @__PURE__ */ React22.createElement(HandRaiseSlashedIcon, null) : /* @__PURE__ */ React22.createElement(HandIcon, null),
1979
- /* @__PURE__ */ React22.createElement(ActionTile.Title, null, isHandRaised ? "Lower" : "Raise", " Hand")
2156
+ isHandRaised ? /* @__PURE__ */ React24.createElement(HandRaiseSlashedIcon, null) : /* @__PURE__ */ React24.createElement(HandIcon, null),
2157
+ /* @__PURE__ */ React24.createElement(ActionTile.Title, null, isHandRaised ? "Lower" : "Raise", " Hand")
1980
2158
  ) : null,
1981
- (elements == null ? void 0 : elements.emoji_reactions) && /* @__PURE__ */ React22.createElement(
2159
+ (elements == null ? void 0 : elements.emoji_reactions) && /* @__PURE__ */ React24.createElement(
1982
2160
  ActionTile.Root,
1983
2161
  {
1984
2162
  onClick: () => {
@@ -1986,10 +2164,10 @@ var MwebOptions = ({
1986
2164
  setOpenOptionsSheet(false);
1987
2165
  }
1988
2166
  },
1989
- /* @__PURE__ */ React22.createElement(EmojiIcon2, null),
1990
- /* @__PURE__ */ React22.createElement(ActionTile.Title, null, "Emoji Reactions")
2167
+ /* @__PURE__ */ React24.createElement(EmojiIcon2, null),
2168
+ /* @__PURE__ */ React24.createElement(ActionTile.Title, null, "Emoji Reactions")
1991
2169
  ),
1992
- (elements == null ? void 0 : elements.brb) && /* @__PURE__ */ React22.createElement(
2170
+ (elements == null ? void 0 : elements.brb) && /* @__PURE__ */ React24.createElement(
1993
2171
  ActionTile.Root,
1994
2172
  {
1995
2173
  active: isBRBOn,
@@ -1998,10 +2176,10 @@ var MwebOptions = ({
1998
2176
  setOpenOptionsSheet(false);
1999
2177
  }
2000
2178
  },
2001
- /* @__PURE__ */ React22.createElement(BrbIcon2, null),
2002
- /* @__PURE__ */ React22.createElement(ActionTile.Title, null, "Be Right Back")
2179
+ /* @__PURE__ */ React24.createElement(BrbIcon2, null),
2180
+ /* @__PURE__ */ React24.createElement(ActionTile.Title, null, "Be Right Back")
2003
2181
  ),
2004
- /* @__PURE__ */ React22.createElement(
2182
+ /* @__PURE__ */ React24.createElement(
2005
2183
  ActionTile.Root,
2006
2184
  {
2007
2185
  onClick: () => {
@@ -2009,10 +2187,10 @@ var MwebOptions = ({
2009
2187
  setOpenOptionsSheet(false);
2010
2188
  }
2011
2189
  },
2012
- /* @__PURE__ */ React22.createElement(SettingsIcon3, null),
2013
- /* @__PURE__ */ React22.createElement(ActionTile.Title, null, "Settings")
2190
+ /* @__PURE__ */ React24.createElement(SettingsIcon3, null),
2191
+ /* @__PURE__ */ React24.createElement(ActionTile.Title, null, "Settings")
2014
2192
  ),
2015
- isConnected && (permissions == null ? void 0 : permissions.browserRecording) ? /* @__PURE__ */ React22.createElement(
2193
+ isConnected && (permissions == null ? void 0 : permissions.browserRecording) ? /* @__PURE__ */ React24.createElement(
2016
2194
  ActionTile.Root,
2017
2195
  {
2018
2196
  disabled: isHLSRunning,
@@ -2052,16 +2230,16 @@ var MwebOptions = ({
2052
2230
  }
2053
2231
  })
2054
2232
  },
2055
- isRecordingLoading ? /* @__PURE__ */ React22.createElement(Loading, null) : /* @__PURE__ */ React22.createElement(RecordIcon2, null),
2056
- /* @__PURE__ */ React22.createElement(ActionTile.Title, null, isBrowserRecordingOn ? "Recording On" : isRecordingLoading ? "Starting Recording" : "Start Recording")
2233
+ isRecordingLoading ? /* @__PURE__ */ React24.createElement(Loading, null) : /* @__PURE__ */ React24.createElement(RecordIcon2, null),
2234
+ /* @__PURE__ */ React24.createElement(ActionTile.Title, null, isBrowserRecordingOn ? "Recording On" : isRecordingLoading ? "Starting Recording" : "Start Recording")
2057
2235
  ) : null
2058
- ))), /* @__PURE__ */ React22.createElement(SettingsModal_default, { open: openSettingsSheet, onOpenChange: setOpenSettingsSheet, screenType }), openModals.has(MODALS2.MUTE_ALL) && /* @__PURE__ */ React22.createElement(MuteAllModal, { onOpenChange: (value) => updateState(MODALS2.MUTE_ALL, value), isMobile: true }), openModals.has(MODALS2.CHANGE_NAME) && /* @__PURE__ */ React22.createElement(
2236
+ ))), /* @__PURE__ */ React24.createElement(SettingsModal_default, { open: openSettingsSheet, onOpenChange: setOpenSettingsSheet, screenType }), openModals.has(MODALS2.MUTE_ALL) && /* @__PURE__ */ React24.createElement(MuteAllModal, { onOpenChange: (value) => updateState(MODALS2.MUTE_ALL, value), isMobile: true }), openModals.has(MODALS2.CHANGE_NAME) && /* @__PURE__ */ React24.createElement(
2059
2237
  ChangeNameModal,
2060
2238
  {
2061
2239
  onOpenChange: (value) => updateState(MODALS2.CHANGE_NAME, value),
2062
2240
  openParentSheet: () => setOpenOptionsSheet(true)
2063
2241
  }
2064
- ), showEmojiCard && /* @__PURE__ */ React22.createElement(
2242
+ ), showEmojiCard && /* @__PURE__ */ React24.createElement(
2065
2243
  Box,
2066
2244
  {
2067
2245
  ref: emojiCardRef,
@@ -2080,8 +2258,8 @@ var MwebOptions = ({
2080
2258
  mx: "$4"
2081
2259
  }
2082
2260
  },
2083
- /* @__PURE__ */ React22.createElement(EmojiReaction, null)
2084
- ), showRecordingOn && /* @__PURE__ */ React22.createElement(
2261
+ /* @__PURE__ */ React24.createElement(EmojiReaction, null)
2262
+ ), showRecordingOn && /* @__PURE__ */ React24.createElement(
2085
2263
  StopRecordingInSheet,
2086
2264
  {
2087
2265
  onClose: () => setShowRecordingOn(false),
@@ -2106,27 +2284,27 @@ var MoreSettings = ({
2106
2284
  elements,
2107
2285
  screenType
2108
2286
  }) => {
2109
- const isMobile = useMedia3(config.media.md);
2110
- return isMobile ? /* @__PURE__ */ React23.createElement(MwebOptions, { elements, screenType }) : /* @__PURE__ */ React23.createElement(DesktopOptions, { elements, screenType });
2287
+ const isMobile = useMedia4(config.media.md);
2288
+ return isMobile ? /* @__PURE__ */ React25.createElement(MwebOptions, { elements, screenType }) : /* @__PURE__ */ React25.createElement(DesktopOptions, { elements, screenType });
2111
2289
  };
2112
2290
 
2113
2291
  // src/Prebuilt/components/RaiseHand.jsx
2114
- import React24 from "react";
2292
+ import React26 from "react";
2115
2293
  import { HandIcon as HandIcon2 } from "@100mslive/react-icons";
2116
2294
  var RaiseHand = () => {
2117
2295
  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* () {
2296
+ return /* @__PURE__ */ React26.createElement(Tooltip, { title: isHandRaised ? "Lower hand" : "Raise hand" }, /* @__PURE__ */ React26.createElement(IconButton_default, { active: !isHandRaised, onClick: () => __async(void 0, null, function* () {
2119
2297
  return yield toggleHandRaise();
2120
- }) }, /* @__PURE__ */ React24.createElement(HandIcon2, null)));
2298
+ }) }, /* @__PURE__ */ React26.createElement(HandIcon2, null)));
2121
2299
  };
2122
2300
 
2123
2301
  // src/Prebuilt/components/ScreenShareToggle.jsx
2124
- import React31, { Fragment as Fragment6 } from "react";
2125
- import { selectIsAllowedToPublish, useHMSStore as useHMSStore12, useScreenShare as useScreenShare2 } from "@100mslive/react-sdk";
2302
+ import React33, { Fragment as Fragment6 } from "react";
2303
+ import { selectIsAllowedToPublish, useHMSStore as useHMSStore13, useScreenShare as useScreenShare2 } from "@100mslive/react-sdk";
2126
2304
  import { ShareScreenIcon } from "@100mslive/react-icons";
2127
2305
 
2128
2306
  // src/Prebuilt/components/pdfAnnotator/shareScreenOptions.jsx
2129
- import React30, { Fragment as Fragment5, useState as useState16 } from "react";
2307
+ import React32, { Fragment as Fragment5, useState as useState17 } from "react";
2130
2308
  import { useScreenShare } from "@100mslive/react-sdk";
2131
2309
  import { StarIcon, VerticalMenuIcon as VerticalMenuIcon2 } from "@100mslive/react-icons";
2132
2310
 
@@ -2162,12 +2340,12 @@ var ShareMenuIcon = styled(ScreenShareButton, {
2162
2340
  });
2163
2341
 
2164
2342
  // src/Prebuilt/components/pdfAnnotator/pdfFileOptions.jsx
2165
- import React29, { useState as useState15 } from "react";
2343
+ import React31, { useState as useState16 } from "react";
2166
2344
 
2167
2345
  // src/Prebuilt/components/pdfAnnotator/pdfHeader.jsx
2168
- import React25 from "react";
2346
+ import React27 from "react";
2169
2347
  var PDFHeader = () => {
2170
- return /* @__PURE__ */ React25.createElement(
2348
+ return /* @__PURE__ */ React27.createElement(
2171
2349
  DialogCol,
2172
2350
  {
2173
2351
  align: "start",
@@ -2176,8 +2354,8 @@ var PDFHeader = () => {
2176
2354
  mb: "$6"
2177
2355
  }
2178
2356
  },
2179
- /* @__PURE__ */ React25.createElement(Dialog.Title, { asChild: true }, /* @__PURE__ */ React25.createElement(Text, { as: "h6", variant: "h6" }, "Share PDF")),
2180
- /* @__PURE__ */ React25.createElement(Dialog.Description, { asChild: true }, /* @__PURE__ */ React25.createElement(
2357
+ /* @__PURE__ */ React27.createElement(Dialog.Title, { asChild: true }, /* @__PURE__ */ React27.createElement(Text, { as: "h6", variant: "h6" }, "Share PDF")),
2358
+ /* @__PURE__ */ React27.createElement(Dialog.Description, { asChild: true }, /* @__PURE__ */ React27.createElement(
2181
2359
  Text,
2182
2360
  {
2183
2361
  variant: "sm",
@@ -2191,10 +2369,10 @@ var PDFHeader = () => {
2191
2369
  };
2192
2370
 
2193
2371
  // src/Prebuilt/components/pdfAnnotator/submitPdf.jsx
2194
- import React26 from "react";
2372
+ import React28 from "react";
2195
2373
  var SubmitPDF = ({ pdfFile, onOpenChange }) => {
2196
2374
  const [, setPDFConfig] = useSetAppDataByKey(APP_DATA.pdfConfig);
2197
- return /* @__PURE__ */ React26.createElement(
2375
+ return /* @__PURE__ */ React28.createElement(
2198
2376
  Flex,
2199
2377
  {
2200
2378
  direction: "row",
@@ -2204,7 +2382,7 @@ var SubmitPDF = ({ pdfFile, onOpenChange }) => {
2204
2382
  gap: "$8"
2205
2383
  }
2206
2384
  },
2207
- /* @__PURE__ */ React26.createElement(
2385
+ /* @__PURE__ */ React28.createElement(
2208
2386
  Button,
2209
2387
  {
2210
2388
  variant: "standard",
@@ -2217,7 +2395,7 @@ var SubmitPDF = ({ pdfFile, onOpenChange }) => {
2217
2395
  },
2218
2396
  "Cancel"
2219
2397
  ),
2220
- /* @__PURE__ */ React26.createElement(
2398
+ /* @__PURE__ */ React28.createElement(
2221
2399
  Button,
2222
2400
  {
2223
2401
  variant: "primary",
@@ -2240,14 +2418,14 @@ var SubmitPDF = ({ pdfFile, onOpenChange }) => {
2240
2418
  };
2241
2419
 
2242
2420
  // src/Prebuilt/components/pdfAnnotator/uploadedFile.jsx
2243
- import React28 from "react";
2421
+ import React30 from "react";
2244
2422
  import { TrashIcon as TrashIcon2 } from "@100mslive/react-icons";
2245
2423
 
2246
2424
  // src/Prebuilt/components/pdfAnnotator/pdfInfo.jsx
2247
- import React27 from "react";
2425
+ import React29 from "react";
2248
2426
  import { InfoIcon as InfoIcon3 } from "@100mslive/react-icons";
2249
2427
  var PDFInfo = () => {
2250
- return /* @__PURE__ */ React27.createElement(
2428
+ return /* @__PURE__ */ React29.createElement(
2251
2429
  DialogRow,
2252
2430
  {
2253
2431
  css: {
@@ -2260,7 +2438,7 @@ var PDFInfo = () => {
2260
2438
  minHeight: "$11"
2261
2439
  }
2262
2440
  },
2263
- /* @__PURE__ */ React27.createElement(
2441
+ /* @__PURE__ */ React29.createElement(
2264
2442
  InfoIcon3,
2265
2443
  {
2266
2444
  width: "64px",
@@ -2270,14 +2448,14 @@ var PDFInfo = () => {
2270
2448
  }
2271
2449
  }
2272
2450
  ),
2273
- /* @__PURE__ */ React27.createElement(Text, { variant: "caption" }, "On the next screen, ensure you select \u201CThis Tab\u201D and click on share. Only the PDF viewer will be seen by other participants")
2451
+ /* @__PURE__ */ React29.createElement(Text, { variant: "caption" }, "On the next screen, ensure you select \u201CThis Tab\u201D and click on share. Only the PDF viewer will be seen by other participants")
2274
2452
  );
2275
2453
  };
2276
2454
 
2277
2455
  // src/Prebuilt/components/pdfAnnotator/uploadedFile.jsx
2278
2456
  var UploadedFile = ({ pdfFile, setPDFFile, onOpenChange }) => {
2279
2457
  const [fileName, ext] = pdfFile.name.split(".");
2280
- return /* @__PURE__ */ React28.createElement(Dialog.Root, { defaultOpen: true, onOpenChange }, /* @__PURE__ */ React28.createElement(Dialog.Portal, null, /* @__PURE__ */ React28.createElement(Dialog.Overlay, null), /* @__PURE__ */ React28.createElement(
2458
+ return /* @__PURE__ */ React30.createElement(Dialog.Root, { defaultOpen: true, onOpenChange }, /* @__PURE__ */ React30.createElement(PrebuiltDialogPortal, null, /* @__PURE__ */ React30.createElement(Dialog.Overlay, null), /* @__PURE__ */ React30.createElement(
2281
2459
  Dialog.Content,
2282
2460
  {
2283
2461
  css: {
@@ -2287,7 +2465,7 @@ var UploadedFile = ({ pdfFile, setPDFFile, onOpenChange }) => {
2287
2465
  bg: "$surface_dim"
2288
2466
  }
2289
2467
  },
2290
- /* @__PURE__ */ React28.createElement(Flex, { direction: "column" }, /* @__PURE__ */ React28.createElement(PDFHeader, null), /* @__PURE__ */ React28.createElement(
2468
+ /* @__PURE__ */ React30.createElement(Flex, { direction: "column" }, /* @__PURE__ */ React30.createElement(PDFHeader, null), /* @__PURE__ */ React30.createElement(
2291
2469
  DialogRow,
2292
2470
  {
2293
2471
  css: {
@@ -2309,7 +2487,7 @@ var UploadedFile = ({ pdfFile, setPDFFile, onOpenChange }) => {
2309
2487
  mt: "$6"
2310
2488
  }
2311
2489
  },
2312
- /* @__PURE__ */ React28.createElement(Flex, { direction: "row", css: { flexGrow: "1", maxWidth: "88%" } }, /* @__PURE__ */ React28.createElement(
2490
+ /* @__PURE__ */ React30.createElement(Flex, { direction: "row", css: { flexGrow: "1", maxWidth: "88%" } }, /* @__PURE__ */ React30.createElement(
2313
2491
  Text,
2314
2492
  {
2315
2493
  css: {
@@ -2319,8 +2497,8 @@ var UploadedFile = ({ pdfFile, setPDFFile, onOpenChange }) => {
2319
2497
  }
2320
2498
  },
2321
2499
  fileName
2322
- ), /* @__PURE__ */ React28.createElement(Text, { css: { whiteSpace: "nowrap" } }, ".", ext)),
2323
- /* @__PURE__ */ React28.createElement(
2500
+ ), /* @__PURE__ */ React30.createElement(Text, { css: { whiteSpace: "nowrap" } }, ".", ext)),
2501
+ /* @__PURE__ */ React30.createElement(
2324
2502
  TrashIcon2,
2325
2503
  {
2326
2504
  onClick: () => setPDFFile(null),
@@ -2329,14 +2507,14 @@ var UploadedFile = ({ pdfFile, setPDFFile, onOpenChange }) => {
2329
2507
  }
2330
2508
  }
2331
2509
  )
2332
- ), /* @__PURE__ */ React28.createElement(PDFInfo, null), /* @__PURE__ */ React28.createElement(SubmitPDF, { pdfFile, onOpenChange }))
2510
+ ), /* @__PURE__ */ React30.createElement(PDFInfo, null), /* @__PURE__ */ React30.createElement(SubmitPDF, { pdfFile, onOpenChange }))
2333
2511
  )));
2334
2512
  };
2335
2513
 
2336
2514
  // src/Prebuilt/components/pdfAnnotator/pdfFileOptions.jsx
2337
2515
  function PDFFileOptions({ onOpenChange }) {
2338
- const [pdfFile, setPDFFile] = useState15(null);
2339
- return !pdfFile ? /* @__PURE__ */ React29.createElement(Dialog.Root, { defaultOpen: true, onOpenChange }, /* @__PURE__ */ React29.createElement(Dialog.Portal, null, /* @__PURE__ */ React29.createElement(Dialog.Overlay, null), /* @__PURE__ */ React29.createElement(
2516
+ const [pdfFile, setPDFFile] = useState16(null);
2517
+ return !pdfFile ? /* @__PURE__ */ React31.createElement(Dialog.Root, { defaultOpen: true, onOpenChange }, /* @__PURE__ */ React31.createElement(PrebuiltDialogPortal, null, /* @__PURE__ */ React31.createElement(Dialog.Overlay, null), /* @__PURE__ */ React31.createElement(
2340
2518
  Dialog.Content,
2341
2519
  {
2342
2520
  css: {
@@ -2346,7 +2524,7 @@ function PDFFileOptions({ onOpenChange }) {
2346
2524
  bg: "$surface_dim"
2347
2525
  }
2348
2526
  },
2349
- /* @__PURE__ */ React29.createElement(Flex, { direction: "column" }, /* @__PURE__ */ React29.createElement(PDFHeader, null), /* @__PURE__ */ React29.createElement(
2527
+ /* @__PURE__ */ React31.createElement(Flex, { direction: "column" }, /* @__PURE__ */ React31.createElement(PDFHeader, null), /* @__PURE__ */ React31.createElement(
2350
2528
  DialogInputFile,
2351
2529
  {
2352
2530
  onChange: (target) => {
@@ -2356,8 +2534,8 @@ function PDFFileOptions({ onOpenChange }) {
2356
2534
  type: "file",
2357
2535
  accept: ".pdf"
2358
2536
  }
2359
- ), /* @__PURE__ */ React29.createElement(SubmitPDF, { pdfFile, onOpenChange }))
2360
- ))) : /* @__PURE__ */ React29.createElement(UploadedFile, { pdfFile, setPDFFile, onOpenChange });
2537
+ ), /* @__PURE__ */ React31.createElement(SubmitPDF, { pdfFile, onOpenChange }))
2538
+ ))) : /* @__PURE__ */ React31.createElement(UploadedFile, { pdfFile, setPDFFile, onOpenChange });
2361
2539
  }
2362
2540
 
2363
2541
  // src/Prebuilt/components/pdfAnnotator/shareScreenOptions.jsx
@@ -2367,7 +2545,7 @@ var MODALS3 = {
2367
2545
  PDF_SHARE: "pdfShare"
2368
2546
  };
2369
2547
  function ShareScreenOptions() {
2370
- const [openModals, setOpenModals] = useState16(/* @__PURE__ */ new Set());
2548
+ const [openModals, setOpenModals] = useState17(/* @__PURE__ */ new Set());
2371
2549
  const { amIScreenSharing } = useScreenShare();
2372
2550
  const updateState = (modalName, value) => {
2373
2551
  setOpenModals((modals) => {
@@ -2381,15 +2559,15 @@ function ShareScreenOptions() {
2381
2559
  });
2382
2560
  };
2383
2561
  const { toggleScreenShare } = useScreenShare();
2384
- return /* @__PURE__ */ React30.createElement(Fragment5, null, /* @__PURE__ */ React30.createElement(
2562
+ return /* @__PURE__ */ React32.createElement(Fragment5, null, /* @__PURE__ */ React32.createElement(
2385
2563
  Dropdown.Root,
2386
2564
  {
2387
2565
  open: openModals.has(MODALS3.SHARE),
2388
2566
  onOpenChange: (value) => updateState(MODALS3.SHARE, value),
2389
2567
  modal: false
2390
2568
  },
2391
- /* @__PURE__ */ React30.createElement(Dropdown.Trigger, { asChild: true, "data-testid": "sharing_btn", disabled: amIScreenSharing }, /* @__PURE__ */ React30.createElement(ShareMenuIcon, { disabled: amIScreenSharing }, /* @__PURE__ */ React30.createElement(Tooltip, { title: "Share" }, /* @__PURE__ */ React30.createElement(Box, null, /* @__PURE__ */ React30.createElement(VerticalMenuIcon2, null))))),
2392
- /* @__PURE__ */ React30.createElement(
2569
+ /* @__PURE__ */ React32.createElement(Dropdown.Trigger, { asChild: true, "data-testid": "sharing_btn", disabled: amIScreenSharing }, /* @__PURE__ */ React32.createElement(ShareMenuIcon, { disabled: amIScreenSharing }, /* @__PURE__ */ React32.createElement(Tooltip, { title: "Share" }, /* @__PURE__ */ React32.createElement(Box, null, /* @__PURE__ */ React32.createElement(VerticalMenuIcon2, null))))),
2570
+ /* @__PURE__ */ React32.createElement(
2393
2571
  Dropdown.Content,
2394
2572
  {
2395
2573
  sideOffset: 5,
@@ -2400,7 +2578,7 @@ function ShareScreenOptions() {
2400
2578
  bg: "$surface_dim"
2401
2579
  }
2402
2580
  },
2403
- /* @__PURE__ */ React30.createElement(
2581
+ /* @__PURE__ */ React32.createElement(
2404
2582
  Dropdown.Item,
2405
2583
  {
2406
2584
  css: {
@@ -2415,10 +2593,10 @@ function ShareScreenOptions() {
2415
2593
  }
2416
2594
  }
2417
2595
  },
2418
- /* @__PURE__ */ React30.createElement(Text, { variant: "h6" }, "Start Sharing"),
2419
- /* @__PURE__ */ React30.createElement(Text, { variant: "sm" }, "Choose what you want to share")
2596
+ /* @__PURE__ */ React32.createElement(Text, { variant: "h6" }, "Start Sharing"),
2597
+ /* @__PURE__ */ React32.createElement(Text, { variant: "sm" }, "Choose what you want to share")
2420
2598
  ),
2421
- /* @__PURE__ */ React30.createElement(
2599
+ /* @__PURE__ */ React32.createElement(
2422
2600
  Dropdown.Item,
2423
2601
  {
2424
2602
  css: {
@@ -2426,14 +2604,15 @@ function ShareScreenOptions() {
2426
2604
  alignItems: "flex-start",
2427
2605
  gap: "$8",
2428
2606
  px: "$10",
2429
- py: "$6",
2607
+ pt: "$6",
2608
+ pb: "$10",
2430
2609
  "&:hover": {
2431
2610
  bg: "$transparent",
2432
2611
  cursor: "default"
2433
2612
  }
2434
2613
  }
2435
2614
  },
2436
- /* @__PURE__ */ React30.createElement(
2615
+ /* @__PURE__ */ React32.createElement(
2437
2616
  Flex,
2438
2617
  {
2439
2618
  direction: "column",
@@ -2442,7 +2621,7 @@ function ShareScreenOptions() {
2442
2621
  gap: "$6"
2443
2622
  }
2444
2623
  },
2445
- /* @__PURE__ */ React30.createElement(
2624
+ /* @__PURE__ */ React32.createElement(
2446
2625
  IconButton,
2447
2626
  {
2448
2627
  as: "div",
@@ -2457,7 +2636,7 @@ function ShareScreenOptions() {
2457
2636
  pb: "0"
2458
2637
  }
2459
2638
  },
2460
- /* @__PURE__ */ React30.createElement(
2639
+ /* @__PURE__ */ React32.createElement(
2461
2640
  "img",
2462
2641
  {
2463
2642
  src: screen_share_default,
@@ -2472,7 +2651,7 @@ function ShareScreenOptions() {
2472
2651
  }
2473
2652
  )
2474
2653
  ),
2475
- /* @__PURE__ */ React30.createElement(Flex, { direction: "column", align: "center" }, /* @__PURE__ */ React30.createElement(Text, { variant: "body2" }, "Share Screen"), /* @__PURE__ */ React30.createElement(
2654
+ /* @__PURE__ */ React32.createElement(Flex, { direction: "column", align: "center" }, /* @__PURE__ */ React32.createElement(Text, { variant: "body2" }, "Share Screen"), /* @__PURE__ */ React32.createElement(
2476
2655
  Text,
2477
2656
  {
2478
2657
  variant: "caption",
@@ -2484,7 +2663,7 @@ function ShareScreenOptions() {
2484
2663
  "Share your tab, window or your entire screen"
2485
2664
  ))
2486
2665
  ),
2487
- /* @__PURE__ */ React30.createElement(
2666
+ /* @__PURE__ */ React32.createElement(
2488
2667
  Flex,
2489
2668
  {
2490
2669
  direction: "column",
@@ -2493,7 +2672,7 @@ function ShareScreenOptions() {
2493
2672
  gap: "$6"
2494
2673
  }
2495
2674
  },
2496
- /* @__PURE__ */ React30.createElement(
2675
+ /* @__PURE__ */ React32.createElement(
2497
2676
  IconButton,
2498
2677
  {
2499
2678
  onClick: () => {
@@ -2510,7 +2689,7 @@ function ShareScreenOptions() {
2510
2689
  pb: "0"
2511
2690
  }
2512
2691
  },
2513
- /* @__PURE__ */ React30.createElement(
2692
+ /* @__PURE__ */ React32.createElement(
2514
2693
  "img",
2515
2694
  {
2516
2695
  src: pdf_share_default,
@@ -2524,14 +2703,14 @@ function ShareScreenOptions() {
2524
2703
  }
2525
2704
  }
2526
2705
  ),
2527
- /* @__PURE__ */ React30.createElement(
2706
+ /* @__PURE__ */ React32.createElement(
2528
2707
  Flex,
2529
2708
  {
2530
2709
  direction: "row",
2531
2710
  align: "center",
2532
2711
  css: {
2533
2712
  position: "absolute",
2534
- top: "29%",
2713
+ top: "35%",
2535
2714
  left: "54%",
2536
2715
  padding: "$2 $4",
2537
2716
  r: "$2",
@@ -2540,8 +2719,8 @@ function ShareScreenOptions() {
2540
2719
  gap: "$2"
2541
2720
  }
2542
2721
  },
2543
- /* @__PURE__ */ React30.createElement(StarIcon, { height: 14, width: 14 }),
2544
- /* @__PURE__ */ React30.createElement(
2722
+ /* @__PURE__ */ React32.createElement(StarIcon, { height: 14, width: 14 }),
2723
+ /* @__PURE__ */ React32.createElement(
2545
2724
  Text,
2546
2725
  {
2547
2726
  variant: "xs",
@@ -2555,7 +2734,7 @@ function ShareScreenOptions() {
2555
2734
  )
2556
2735
  )
2557
2736
  ),
2558
- /* @__PURE__ */ React30.createElement(Flex, { direction: "column", align: "center" }, /* @__PURE__ */ React30.createElement(Text, { variant: "body2" }, "Share PDF"), /* @__PURE__ */ React30.createElement(
2737
+ /* @__PURE__ */ React32.createElement(Flex, { direction: "column", align: "center" }, /* @__PURE__ */ React32.createElement(Text, { variant: "body2" }, "Share PDF"), /* @__PURE__ */ React32.createElement(
2559
2738
  Text,
2560
2739
  {
2561
2740
  variant: "caption",
@@ -2567,51 +2746,21 @@ function ShareScreenOptions() {
2567
2746
  "Annotate, draw shapes, and more over PDFs"
2568
2747
  ))
2569
2748
  )
2570
- ),
2571
- /* @__PURE__ */ React30.createElement(
2572
- Dropdown.Item,
2573
- {
2574
- css: {
2575
- px: "$10",
2576
- pb: "$10",
2577
- pt: "$6",
2578
- "&:hover": {
2579
- bg: "$transparent",
2580
- cursor: "default"
2581
- }
2582
- }
2583
- },
2584
- /* @__PURE__ */ React30.createElement(
2585
- Button,
2586
- {
2587
- variant: "standard",
2588
- outlined: true,
2589
- type: "submit",
2590
- onClick: () => {
2591
- updateState(MODALS3.SHARE, false);
2592
- },
2593
- "data-testid": "share_btn",
2594
- css: {
2595
- w: "100%"
2596
- }
2597
- },
2598
- "Cancel"
2599
- )
2600
2749
  )
2601
2750
  )
2602
- ), openModals.has(MODALS3.PDF_SHARE) && /* @__PURE__ */ React30.createElement(PDFFileOptions, { onOpenChange: (value) => updateState(MODALS3.PDF_SHARE, value) }));
2751
+ ), openModals.has(MODALS3.PDF_SHARE) && /* @__PURE__ */ React32.createElement(PDFFileOptions, { onOpenChange: (value) => updateState(MODALS3.PDF_SHARE, value) }));
2603
2752
  }
2604
2753
 
2605
2754
  // src/Prebuilt/components/ScreenShareToggle.jsx
2606
2755
  var ScreenshareToggle = ({ css = {} }) => {
2607
- const isAllowedToPublish = useHMSStore12(selectIsAllowedToPublish);
2756
+ const isAllowedToPublish = useHMSStore13(selectIsAllowedToPublish);
2608
2757
  const isAudioOnly = useUISettings(UI_SETTINGS.isAudioOnly);
2609
2758
  const { amIScreenSharing, screenShareVideoTrackId: video, toggleScreenShare } = useScreenShare2();
2610
2759
  const isVideoScreenshare = amIScreenSharing && !!video;
2611
2760
  if (!isAllowedToPublish.screen || !isScreenshareSupported()) {
2612
2761
  return null;
2613
2762
  }
2614
- return /* @__PURE__ */ React31.createElement(Fragment6, null, /* @__PURE__ */ React31.createElement(Flex, { direction: "row", css: { "@md": { display: "none" } } }, /* @__PURE__ */ React31.createElement(
2763
+ return /* @__PURE__ */ React33.createElement(Fragment6, null, /* @__PURE__ */ React33.createElement(Flex, { direction: "row", css: { "@md": { display: "none" } } }, /* @__PURE__ */ React33.createElement(
2615
2764
  ScreenShareButton,
2616
2765
  {
2617
2766
  variant: "standard",
@@ -2623,24 +2772,24 @@ var ScreenshareToggle = ({ css = {} }) => {
2623
2772
  toggleScreenShare();
2624
2773
  }
2625
2774
  },
2626
- /* @__PURE__ */ React31.createElement(Tooltip, { title: `${!isVideoScreenshare ? "Start" : "Stop"} screen sharing` }, /* @__PURE__ */ React31.createElement(Box, null, /* @__PURE__ */ React31.createElement(ShareScreenIcon, null)))
2627
- ), /* @__PURE__ */ React31.createElement(ShareScreenOptions, null)));
2775
+ /* @__PURE__ */ React33.createElement(Tooltip, { title: `${!isVideoScreenshare ? "Start" : "Stop"} screen sharing` }, /* @__PURE__ */ React33.createElement(Box, null, /* @__PURE__ */ React33.createElement(ShareScreenIcon, null)))
2776
+ ), /* @__PURE__ */ React33.createElement(ShareScreenOptions, null)));
2628
2777
  };
2629
2778
 
2630
2779
  // src/Prebuilt/components/Footer/ChatToggle.tsx
2631
- import React32 from "react";
2632
- import { selectUnreadHMSMessagesCount, useHMSStore as useHMSStore13 } from "@100mslive/react-sdk";
2780
+ import React34 from "react";
2781
+ import { selectUnreadHMSMessagesCount, useHMSStore as useHMSStore14 } from "@100mslive/react-sdk";
2633
2782
  import { ChatIcon, ChatUnreadIcon } from "@100mslive/react-icons";
2634
2783
  var ChatToggle = () => {
2635
- const countUnreadMessages = useHMSStore13(selectUnreadHMSMessagesCount);
2784
+ const countUnreadMessages = useHMSStore14(selectUnreadHMSMessagesCount);
2636
2785
  const isChatOpen = useIsSidepaneTypeOpen(SIDE_PANE_OPTIONS.CHAT);
2637
2786
  const toggleChat = useSidepaneToggle(SIDE_PANE_OPTIONS.CHAT);
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" })));
2787
+ return /* @__PURE__ */ React34.createElement(Tooltip, { key: "chat", title: `${isChatOpen ? "Close" : "Open"} chat` }, /* @__PURE__ */ React34.createElement(IconButton_default, { onClick: toggleChat, active: !isChatOpen, "data-testid": "chat_btn" }, countUnreadMessages === 0 ? /* @__PURE__ */ React34.createElement(ChatIcon, null) : /* @__PURE__ */ React34.createElement(ChatUnreadIcon, { "data-testid": "chat_unread_btn" })));
2639
2788
  };
2640
2789
 
2641
2790
  // src/Prebuilt/components/Footer/ParticipantList.jsx
2642
- import React35, { Fragment as Fragment7, useCallback as useCallback6, useEffect as useEffect5, useState as useState18 } from "react";
2643
- import { useDebounce, useMedia as useMedia4 } from "react-use";
2791
+ import React37, { Fragment as Fragment7, useCallback as useCallback7, useEffect as useEffect7, useState as useState20 } from "react";
2792
+ import { useDebounce, useMedia as useMedia5 } from "react-use";
2644
2793
  import {
2645
2794
  selectHandRaisedPeers,
2646
2795
  selectHasPeerHandRaised,
@@ -2649,8 +2798,8 @@ import {
2649
2798
  selectPeerCount as selectPeerCount2,
2650
2799
  selectPeerMetadata,
2651
2800
  selectPermissions as selectPermissions8,
2652
- useHMSActions as useHMSActions11,
2653
- useHMSStore as useHMSStore15
2801
+ useHMSActions as useHMSActions13,
2802
+ useHMSStore as useHMSStore16
2654
2803
  } from "@100mslive/react-sdk";
2655
2804
  import {
2656
2805
  ChangeRoleIcon as ChangeRoleIcon2,
@@ -2663,13 +2812,15 @@ import {
2663
2812
  } from "@100mslive/react-icons";
2664
2813
 
2665
2814
  // src/Prebuilt/components/Footer/RoleAccordion.tsx
2666
- import React34 from "react";
2815
+ import React36, { useCallback as useCallback6, useEffect as useEffect6, useRef as useRef6, useState as useState19 } from "react";
2667
2816
  import { useMeasure } from "react-use";
2668
2817
  import { FixedSizeList } from "react-window";
2818
+ import { useHMSActions as useHMSActions12 } from "@100mslive/react-sdk";
2819
+ import { AddCircleIcon as AddCircleIcon2 } from "@100mslive/react-icons";
2669
2820
 
2670
2821
  // src/Prebuilt/components/Footer/RoleOptions.tsx
2671
- import React33, { useState as useState17 } from "react";
2672
- import { selectPermissions as selectPermissions7, useHMSActions as useHMSActions10, useHMSStore as useHMSStore14, useHMSVanillaStore as useHMSVanillaStore2 } from "@100mslive/react-sdk";
2822
+ import React35, { useState as useState18 } from "react";
2823
+ import { selectPermissions as selectPermissions7, useHMSActions as useHMSActions11, useHMSStore as useHMSStore15, useHMSVanillaStore as useHMSVanillaStore2 } from "@100mslive/react-sdk";
2673
2824
  import {
2674
2825
  MicOffIcon as MicOffIcon2,
2675
2826
  MicOnIcon,
@@ -2682,9 +2833,9 @@ import {
2682
2833
  var dropdownItemCSS = { backgroundColor: "$surface_default", gap: "$4", p: "$8" };
2683
2834
  var optionTextCSS = { fontWeight: "$semiBold", color: "$on_surface_high", textTransform: "none" };
2684
2835
  var RoleOptions = ({ roleName, peerList }) => {
2685
- const [openOptions, setOpenOptions] = useState17(false);
2686
- const permissions = useHMSStore14(selectPermissions7);
2687
- const hmsActions = useHMSActions10();
2836
+ const [openOptions, setOpenOptions] = useState18(false);
2837
+ const permissions = useHMSStore15(selectPermissions7);
2838
+ const hmsActions = useHMSActions11();
2688
2839
  const { elements } = useRoomLayoutConferencingScreen();
2689
2840
  const { on_stage_role, off_stage_roles = [] } = (elements == null ? void 0 : elements.on_stage_exp) || {};
2690
2841
  const vanillaStore = useHMSVanillaStore2();
@@ -2728,7 +2879,7 @@ var RoleOptions = ({ roleName, peerList }) => {
2728
2879
  console.error(e);
2729
2880
  }
2730
2881
  });
2731
- return /* @__PURE__ */ React33.createElement(Dropdown.Root, { open: openOptions, onOpenChange: setOpenOptions }, /* @__PURE__ */ React33.createElement(
2882
+ return /* @__PURE__ */ React35.createElement(Dropdown.Root, { open: openOptions, onOpenChange: setOpenOptions }, /* @__PURE__ */ React35.createElement(
2732
2883
  Dropdown.Trigger,
2733
2884
  {
2734
2885
  onClick: (e) => e.stopPropagation(),
@@ -2747,40 +2898,40 @@ var RoleOptions = ({ roleName, peerList }) => {
2747
2898
  }
2748
2899
  }
2749
2900
  },
2750
- /* @__PURE__ */ React33.createElement(Flex, null, /* @__PURE__ */ React33.createElement(VerticalMenuIcon3, null))
2751
- ), /* @__PURE__ */ React33.createElement(
2901
+ /* @__PURE__ */ React35.createElement(Flex, null, /* @__PURE__ */ React35.createElement(VerticalMenuIcon3, null))
2902
+ ), /* @__PURE__ */ React35.createElement(
2752
2903
  Dropdown.Content,
2753
2904
  {
2754
2905
  onClick: (e) => e.stopPropagation(),
2755
2906
  css: { w: "max-content", maxWidth: "$64", bg: "$surface_default", py: 0 },
2756
2907
  align: "end"
2757
2908
  },
2758
- canRemoveRoleFromStage && /* @__PURE__ */ React33.createElement(
2909
+ canRemoveRoleFromStage && /* @__PURE__ */ React35.createElement(
2759
2910
  Dropdown.Item,
2760
2911
  {
2761
2912
  css: __spreadProps(__spreadValues({}, dropdownItemCSS), { borderBottom: "1px solid $border_bright" }),
2762
2913
  onClick: removeAllFromStage
2763
2914
  },
2764
- /* @__PURE__ */ React33.createElement(PersonRectangleIcon, null),
2765
- /* @__PURE__ */ React33.createElement(Text, { variant: "sm", css: optionTextCSS }, "Remove all from Stage")
2915
+ /* @__PURE__ */ React35.createElement(PersonRectangleIcon, null),
2916
+ /* @__PURE__ */ React35.createElement(Text, { variant: "sm", css: optionTextCSS }, "Remove all from Stage")
2766
2917
  ),
2767
- canMuteRole && /* @__PURE__ */ React33.createElement(React33.Fragment, null, /* @__PURE__ */ React33.createElement(Dropdown.Item, { css: dropdownItemCSS, onClick: () => setTrackEnabled("audio", !allPeersHaveAudioOn) }, allPeersHaveAudioOn ? /* @__PURE__ */ React33.createElement(MicOffIcon2, null) : /* @__PURE__ */ React33.createElement(MicOnIcon, null), /* @__PURE__ */ React33.createElement(Text, { variant: "sm", css: optionTextCSS }, allPeersHaveAudioOn ? "Mute" : "Unmute", " Audio")), /* @__PURE__ */ React33.createElement(
2918
+ canMuteRole && /* @__PURE__ */ React35.createElement(React35.Fragment, null, /* @__PURE__ */ React35.createElement(Dropdown.Item, { css: dropdownItemCSS, onClick: () => setTrackEnabled("audio", !allPeersHaveAudioOn) }, allPeersHaveAudioOn ? /* @__PURE__ */ React35.createElement(MicOffIcon2, null) : /* @__PURE__ */ React35.createElement(MicOnIcon, null), /* @__PURE__ */ React35.createElement(Text, { variant: "sm", css: optionTextCSS }, allPeersHaveAudioOn ? "Mute" : "Unmute", " Audio")), /* @__PURE__ */ React35.createElement(
2768
2919
  Dropdown.Item,
2769
2920
  {
2770
2921
  css: __spreadProps(__spreadValues({}, dropdownItemCSS), { borderTop: "1px solid $border_bright" }),
2771
2922
  onClick: () => setTrackEnabled("video", !allPeersHaveVideoOn)
2772
2923
  },
2773
- allPeersHaveVideoOn ? /* @__PURE__ */ React33.createElement(VideoOffIcon, null) : /* @__PURE__ */ React33.createElement(VideoOnIcon, null),
2774
- /* @__PURE__ */ React33.createElement(Text, { variant: "sm", css: optionTextCSS }, allPeersHaveVideoOn ? "Mute" : "Unmute", " Video")
2924
+ allPeersHaveVideoOn ? /* @__PURE__ */ React35.createElement(VideoOffIcon, null) : /* @__PURE__ */ React35.createElement(VideoOnIcon, null),
2925
+ /* @__PURE__ */ React35.createElement(Text, { variant: "sm", css: optionTextCSS }, allPeersHaveVideoOn ? "Mute" : "Unmute", " Video")
2775
2926
  )),
2776
- canRemoveRoleFromRoom && /* @__PURE__ */ React33.createElement(
2927
+ canRemoveRoleFromRoom && /* @__PURE__ */ React35.createElement(
2777
2928
  Dropdown.Item,
2778
2929
  {
2779
2930
  css: __spreadProps(__spreadValues({}, dropdownItemCSS), { borderTop: "1px solid $border_bright", color: "$alert_error_default" }),
2780
2931
  onClick: removePeersFromRoom
2781
2932
  },
2782
- /* @__PURE__ */ React33.createElement(RemoveUserIcon, null),
2783
- /* @__PURE__ */ React33.createElement(Text, { variant: "sm", css: __spreadProps(__spreadValues({}, optionTextCSS), { color: "inherit" }) }, "Remove all from Room")
2933
+ /* @__PURE__ */ React35.createElement(RemoveUserIcon, null),
2934
+ /* @__PURE__ */ React35.createElement(Text, { variant: "sm", css: __spreadProps(__spreadValues({}, optionTextCSS), { color: "inherit" }) }, "Remove all from Room")
2784
2935
  )
2785
2936
  ));
2786
2937
  };
@@ -2790,8 +2941,8 @@ var ROW_HEIGHT = 50;
2790
2941
  function itemKey(index, data3) {
2791
2942
  return data3.peerList[index].id;
2792
2943
  }
2793
- var VirtualizedParticipantItem = React34.memo(({ index, data: data3 }) => {
2794
- return /* @__PURE__ */ React34.createElement(Participant, { key: data3.peerList[index].id, peer: data3.peerList[index], isConnected: data3.isConnected });
2944
+ var VirtualizedParticipantItem = React36.memo(({ index, data: data3 }) => {
2945
+ return /* @__PURE__ */ React36.createElement(Participant, { key: data3.peerList[index].id, peer: data3.peerList[index], isConnected: data3.isConnected });
2795
2946
  });
2796
2947
  var RoleAccordion = ({
2797
2948
  peerList = [],
@@ -2801,12 +2952,29 @@ var RoleAccordion = ({
2801
2952
  isHandRaisedAccordion = false
2802
2953
  }) => {
2803
2954
  const [ref, { width }] = useMeasure();
2955
+ const actions = useHMSActions12();
2804
2956
  const showAcordion = (filter == null ? void 0 : filter.search) ? peerList.some((peer) => peer.name.toLowerCase().includes(filter.search)) : true;
2805
- if (!showAcordion || isHandRaisedAccordion && (filter == null ? void 0 : filter.search) || peerList.length === 0) {
2957
+ const [hasNext, setHasNext] = useState19(false);
2958
+ const iteratorRef = useRef6(null);
2959
+ const loadNext = useCallback6(() => {
2960
+ if (!roleName || roleName === "Hand Raised") {
2961
+ return;
2962
+ }
2963
+ if (!iteratorRef.current) {
2964
+ iteratorRef.current = actions.getPeerListIterator({ role: roleName });
2965
+ }
2966
+ iteratorRef.current.next().catch(console.error).finally(() => {
2967
+ setHasNext(iteratorRef.current ? iteratorRef.current.hasNext() : false);
2968
+ });
2969
+ }, [actions, roleName]);
2970
+ useEffect6(() => {
2971
+ loadNext();
2972
+ }, [loadNext]);
2973
+ if (!showAcordion || isHandRaisedAccordion && (filter == null ? void 0 : filter.search) || peerList.length === 0 && (filter == null ? void 0 : filter.search)) {
2806
2974
  return null;
2807
2975
  }
2808
2976
  const height = ROW_HEIGHT * peerList.length;
2809
- return /* @__PURE__ */ React34.createElement(Flex, { direction: "column", css: { "&:hover .role_actions": { visibility: "visible" } }, ref }, /* @__PURE__ */ React34.createElement(
2977
+ return /* @__PURE__ */ React36.createElement(Flex, { direction: "column", css: { "&:hover .role_actions": { visibility: "visible" } }, ref }, /* @__PURE__ */ React36.createElement(
2810
2978
  Accordion.Root,
2811
2979
  {
2812
2980
  type: "single",
@@ -2814,7 +2982,7 @@ var RoleAccordion = ({
2814
2982
  defaultValue: roleName,
2815
2983
  css: { borderRadius: "$1", border: "1px solid $border_bright" }
2816
2984
  },
2817
- /* @__PURE__ */ React34.createElement(Accordion.Item, { value: roleName }, /* @__PURE__ */ React34.createElement(
2985
+ /* @__PURE__ */ React36.createElement(Accordion.Item, { value: roleName }, /* @__PURE__ */ React36.createElement(
2818
2986
  Accordion.Header,
2819
2987
  {
2820
2988
  iconStyles: { c: "$on_surface_high" },
@@ -2826,7 +2994,7 @@ var RoleAccordion = ({
2826
2994
  c: "$on_surface_medium"
2827
2995
  }
2828
2996
  },
2829
- /* @__PURE__ */ React34.createElement(Flex, { justify: "between", css: { flexGrow: 1, pr: "$6" } }, /* @__PURE__ */ React34.createElement(
2997
+ /* @__PURE__ */ React36.createElement(Flex, { justify: "between", css: { flexGrow: 1, pr: "$6" } }, /* @__PURE__ */ React36.createElement(
2830
2998
  Text,
2831
2999
  {
2832
3000
  variant: "sm",
@@ -2835,8 +3003,8 @@ var RoleAccordion = ({
2835
3003
  roleName,
2836
3004
  " ",
2837
3005
  `(${getFormattedCount(peerList.length)})`
2838
- ), /* @__PURE__ */ React34.createElement(RoleOptions, { roleName, peerList }))
2839
- ), /* @__PURE__ */ React34.createElement(Accordion.Content, null, /* @__PURE__ */ React34.createElement(Box, { css: { borderTop: "1px solid $border_default" } }), /* @__PURE__ */ React34.createElement(
3006
+ ), /* @__PURE__ */ React36.createElement(RoleOptions, { roleName, peerList }))
3007
+ ), /* @__PURE__ */ React36.createElement(Accordion.Content, null, /* @__PURE__ */ React36.createElement(Box, { css: { borderTop: "1px solid $border_default" } }), /* @__PURE__ */ React36.createElement(
2840
3008
  FixedSizeList,
2841
3009
  {
2842
3010
  itemSize: ROW_HEIGHT,
@@ -2847,23 +3015,38 @@ var RoleAccordion = ({
2847
3015
  height
2848
3016
  },
2849
3017
  VirtualizedParticipantItem
2850
- )))
3018
+ ), hasNext ? /* @__PURE__ */ React36.createElement(
3019
+ Chip_default,
3020
+ {
3021
+ icon: /* @__PURE__ */ React36.createElement(AddCircleIcon2, null),
3022
+ content: "Load More",
3023
+ onClick: loadNext,
3024
+ backgroundColor: "$secondary_default",
3025
+ css: {
3026
+ w: "max-content",
3027
+ borderRadius: "$size$9",
3028
+ m: "$2 auto",
3029
+ p: "$4",
3030
+ cursor: "pointer"
3031
+ }
3032
+ }
3033
+ ) : null))
2851
3034
  ));
2852
3035
  };
2853
3036
 
2854
3037
  // src/Prebuilt/components/Footer/ParticipantList.jsx
2855
3038
  var ParticipantList = () => {
2856
- const [filter, setFilter] = useState18();
3039
+ const [filter, setFilter] = useState20();
2857
3040
  const { participants, isConnected, peerCount } = useParticipants(filter);
2858
3041
  const peersOrderedByRoles = {};
2859
- const handRaisedPeers = useHMSStore15(selectHandRaisedPeers);
3042
+ const handRaisedPeers = useHMSStore16(selectHandRaisedPeers);
2860
3043
  participants.forEach((participant) => {
2861
3044
  if (peersOrderedByRoles[participant.roleName] === void 0) {
2862
3045
  peersOrderedByRoles[participant.roleName] = [];
2863
3046
  }
2864
3047
  peersOrderedByRoles[participant.roleName].push(participant);
2865
3048
  });
2866
- const onSearch = useCallback6((value) => {
3049
+ const onSearch = useCallback7((value) => {
2867
3050
  setFilter((filterValue) => {
2868
3051
  if (!filterValue) {
2869
3052
  filterValue = {};
@@ -2875,7 +3058,7 @@ var ParticipantList = () => {
2875
3058
  if (peerCount === 0) {
2876
3059
  return null;
2877
3060
  }
2878
- return /* @__PURE__ */ React35.createElement(Fragment7, null, /* @__PURE__ */ React35.createElement(Flex, { direction: "column", css: { size: "100%", gap: "$4" } }, !(filter == null ? void 0 : filter.search) && participants.length === 0 ? null : /* @__PURE__ */ React35.createElement(ParticipantSearch, { onSearch, inSidePane: true }), participants.length === 0 ? /* @__PURE__ */ React35.createElement(Flex, { align: "center", justify: "center", css: { w: "100%", p: "$8 0" } }, /* @__PURE__ */ React35.createElement(Text, { variant: "sm" }, !filter ? "No participants" : "No matching participants")) : null, /* @__PURE__ */ React35.createElement(
3061
+ return /* @__PURE__ */ React37.createElement(Fragment7, null, /* @__PURE__ */ React37.createElement(Flex, { direction: "column", css: { size: "100%", gap: "$4" } }, !(filter == null ? void 0 : filter.search) && participants.length === 0 ? null : /* @__PURE__ */ React37.createElement(ParticipantSearch, { onSearch, inSidePane: true }), participants.length === 0 ? /* @__PURE__ */ React37.createElement(Flex, { align: "center", justify: "center", css: { w: "100%", p: "$8 0" } }, /* @__PURE__ */ React37.createElement(Text, { variant: "sm" }, !filter ? "No participants" : "No matching participants")) : null, /* @__PURE__ */ React37.createElement(
2879
3062
  VirtualizedParticipants,
2880
3063
  {
2881
3064
  peersOrderedByRoles,
@@ -2886,10 +3069,10 @@ var ParticipantList = () => {
2886
3069
  )));
2887
3070
  };
2888
3071
  var ParticipantCount = () => {
2889
- const peerCount = useHMSStore15(selectPeerCount2);
3072
+ const peerCount = useHMSStore16(selectPeerCount2);
2890
3073
  const toggleSidepane = useSidepaneToggle(SIDE_PANE_OPTIONS.PARTICIPANTS);
2891
3074
  const isParticipantsOpen = useIsSidepaneTypeOpen(SIDE_PANE_OPTIONS.PARTICIPANTS);
2892
- useEffect5(() => {
3075
+ useEffect7(() => {
2893
3076
  if (isParticipantsOpen && peerCount === 0) {
2894
3077
  toggleSidepane();
2895
3078
  }
@@ -2897,7 +3080,7 @@ var ParticipantCount = () => {
2897
3080
  if (peerCount === 0) {
2898
3081
  return null;
2899
3082
  }
2900
- return /* @__PURE__ */ React35.createElement(
3083
+ return /* @__PURE__ */ React37.createElement(
2901
3084
  IconButton_default,
2902
3085
  {
2903
3086
  css: {
@@ -2913,12 +3096,12 @@ var ParticipantCount = () => {
2913
3096
  active: !isParticipantsOpen,
2914
3097
  "data-testid": "participant_list"
2915
3098
  },
2916
- /* @__PURE__ */ React35.createElement(PeopleIcon2, null),
2917
- /* @__PURE__ */ React35.createElement(Text, { variant: "sm", css: { mx: "$4", c: "inherit" } }, getFormattedCount(peerCount))
3099
+ /* @__PURE__ */ React37.createElement(PeopleIcon2, null),
3100
+ /* @__PURE__ */ React37.createElement(Text, { variant: "sm", css: { mx: "$4", c: "inherit" } }, getFormattedCount(peerCount))
2918
3101
  );
2919
3102
  };
2920
3103
  var VirtualizedParticipants = ({ peersOrderedByRoles = {}, isConnected, filter, handRaisedList = [] }) => {
2921
- return /* @__PURE__ */ React35.createElement(
3104
+ return /* @__PURE__ */ React37.createElement(
2922
3105
  Flex,
2923
3106
  {
2924
3107
  direction: "column",
@@ -2931,7 +3114,7 @@ var VirtualizedParticipants = ({ peersOrderedByRoles = {}, isConnected, filter,
2931
3114
  flex: "1 1 0"
2932
3115
  }
2933
3116
  },
2934
- /* @__PURE__ */ React35.createElement(
3117
+ handRaisedList.length > 0 ? /* @__PURE__ */ React37.createElement(
2935
3118
  RoleAccordion,
2936
3119
  {
2937
3120
  peerList: handRaisedList,
@@ -2940,8 +3123,8 @@ var VirtualizedParticipants = ({ peersOrderedByRoles = {}, isConnected, filter,
2940
3123
  isConnected,
2941
3124
  isHandRaisedAccordion: true
2942
3125
  }
2943
- ),
2944
- Object.keys(peersOrderedByRoles).map((role) => /* @__PURE__ */ React35.createElement(
3126
+ ) : null,
3127
+ Object.keys(peersOrderedByRoles).map((role) => /* @__PURE__ */ React37.createElement(
2945
3128
  RoleAccordion,
2946
3129
  {
2947
3130
  key: role,
@@ -2954,8 +3137,8 @@ var VirtualizedParticipants = ({ peersOrderedByRoles = {}, isConnected, filter,
2954
3137
  );
2955
3138
  };
2956
3139
  var Participant = ({ peer, isConnected }) => {
2957
- const localPeerId = useHMSStore15(selectLocalPeerID4);
2958
- return /* @__PURE__ */ React35.createElement(
3140
+ const localPeerId = useHMSStore16(selectLocalPeerID4);
3141
+ return /* @__PURE__ */ React37.createElement(
2959
3142
  Flex,
2960
3143
  {
2961
3144
  key: peer.id,
@@ -2970,17 +3153,20 @@ var Participant = ({ peer, isConnected }) => {
2970
3153
  justify: "between",
2971
3154
  "data-testid": "participant_" + peer.name
2972
3155
  },
2973
- /* @__PURE__ */ React35.createElement(Text, { variant: "sm", css: __spreadProps(__spreadValues({}, textEllipsis(150)), { fontWeight: "$semiBold", color: "$on_surface_high" }) }, peer.name, " ", localPeerId === peer.id ? "(You)" : ""),
2974
- isConnected ? /* @__PURE__ */ React35.createElement(ParticipantActions, { peerId: peer.id, isLocal: peer.id === localPeerId, role: peer.roleName }) : null
3156
+ /* @__PURE__ */ React37.createElement(Text, { variant: "sm", css: __spreadProps(__spreadValues({}, textEllipsis(150)), { fontWeight: "$semiBold", color: "$on_surface_high" }) }, peer.name, " ", localPeerId === peer.id ? "(You)" : ""),
3157
+ isConnected ? /* @__PURE__ */ React37.createElement(ParticipantActions, { peerId: peer.id, isLocal: peer.id === localPeerId, role: peer.roleName }) : null
2975
3158
  );
2976
3159
  };
2977
- var ParticipantActions = React35.memo(({ peerId, role, isLocal }) => {
2978
- var _a;
2979
- const isHandRaised = useHMSStore15(selectHasPeerHandRaised(peerId));
2980
- const canChangeRole = (_a = useHMSStore15(selectPermissions8)) == null ? void 0 : _a.changeRole;
2981
- const shouldShowMoreActions = canChangeRole;
2982
- const isAudioMuted = !useHMSStore15(selectIsPeerAudioEnabled(peerId));
2983
- return /* @__PURE__ */ React35.createElement(
3160
+ var ParticipantActions = React37.memo(({ peerId, role, isLocal }) => {
3161
+ var _a, _b;
3162
+ const isHandRaised = useHMSStore16(selectHasPeerHandRaised(peerId));
3163
+ const canChangeRole = (_a = useHMSStore16(selectPermissions8)) == null ? void 0 : _a.changeRole;
3164
+ const canRemoveOthers = (_b = useHMSStore16(selectPermissions8)) == null ? void 0 : _b.removeOthers;
3165
+ const { elements } = useRoomLayoutConferencingScreen();
3166
+ const { on_stage_exp } = elements || {};
3167
+ const shouldShowMoreActions = on_stage_exp && canChangeRole || canRemoveOthers;
3168
+ const isAudioMuted = !useHMSStore16(selectIsPeerAudioEnabled(peerId));
3169
+ return /* @__PURE__ */ React37.createElement(
2984
3170
  Flex,
2985
3171
  {
2986
3172
  align: "center",
@@ -2989,33 +3175,40 @@ var ParticipantActions = React35.memo(({ peerId, role, isLocal }) => {
2989
3175
  gap: "$8"
2990
3176
  }
2991
3177
  },
2992
- /* @__PURE__ */ React35.createElement(ConnectionIndicator, { peerId }),
2993
- isHandRaised && /* @__PURE__ */ React35.createElement(
3178
+ /* @__PURE__ */ React37.createElement(ConnectionIndicator, { peerId }),
3179
+ isHandRaised && /* @__PURE__ */ React37.createElement(
2994
3180
  Flex,
2995
3181
  {
2996
3182
  align: "center",
2997
3183
  justify: "center",
2998
3184
  css: { p: "$1", c: "$on_surface_high", bg: "$surface_bright", borderRadius: "$round" }
2999
3185
  },
3000
- /* @__PURE__ */ React35.createElement(HandIcon3, { height: 19, width: 19 })
3186
+ /* @__PURE__ */ React37.createElement(HandIcon3, { height: 19, width: 19 })
3001
3187
  ),
3002
- isAudioMuted ? /* @__PURE__ */ React35.createElement(
3188
+ isAudioMuted ? /* @__PURE__ */ React37.createElement(
3003
3189
  Flex,
3004
3190
  {
3005
3191
  align: "center",
3006
3192
  justify: "center",
3007
3193
  css: { p: "$2", c: "$on_surface_high", bg: "$surface_bright", borderRadius: "$round" }
3008
3194
  },
3009
- /* @__PURE__ */ React35.createElement(MicOffIcon3, { height: 19, width: 19 })
3195
+ /* @__PURE__ */ React37.createElement(MicOffIcon3, { height: 19, width: 19 })
3010
3196
  ) : null,
3011
- shouldShowMoreActions && !isLocal ? /* @__PURE__ */ React35.createElement(ParticipantMoreActions, { peerId, role }) : null
3197
+ shouldShowMoreActions && !isLocal ? /* @__PURE__ */ React37.createElement(
3198
+ ParticipantMoreActions,
3199
+ {
3200
+ peerId,
3201
+ role,
3202
+ elements,
3203
+ canChangeRole,
3204
+ canRemoveOthers
3205
+ }
3206
+ ) : null
3012
3207
  );
3013
3208
  });
3014
- var ParticipantMoreActions = ({ peerId, role }) => {
3209
+ var ParticipantMoreActions = ({ peerId, role, elements, canChangeRole, canRemoveOthers }) => {
3015
3210
  var _a;
3016
- const hmsActions = useHMSActions11();
3017
- const { changeRole: canChangeRole, removeOthers: canRemoveOthers } = useHMSStore15(selectPermissions8);
3018
- const { elements } = useRoomLayoutConferencingScreen();
3211
+ const hmsActions = useHMSActions13();
3019
3212
  const {
3020
3213
  bring_to_stage_label,
3021
3214
  remove_from_stage_label,
@@ -3024,10 +3217,10 @@ var ParticipantMoreActions = ({ peerId, role }) => {
3024
3217
  } = elements.on_stage_exp || {};
3025
3218
  const isInStage = role === on_stage_role;
3026
3219
  const shouldShowStageRoleChange = canChangeRole && (isInStage && remove_from_stage_label || (off_stage_roles == null ? void 0 : off_stage_roles.includes(role)) && bring_to_stage_label);
3027
- const prevRole = (_a = useHMSStore15(selectPeerMetadata(peerId))) == null ? void 0 : _a.prevRole;
3028
- const localPeerId = useHMSStore15(selectLocalPeerID4);
3220
+ const prevRole = (_a = useHMSStore16(selectPeerMetadata(peerId))) == null ? void 0 : _a.prevRole;
3221
+ const localPeerId = useHMSStore16(selectLocalPeerID4);
3029
3222
  const isLocal = localPeerId === peerId;
3030
- const [open, setOpen] = useState18(false);
3223
+ const [open, setOpen] = useState20(false);
3031
3224
  const handleStageAction = () => __async(void 0, null, function* () {
3032
3225
  if (isInStage) {
3033
3226
  prevRole && hmsActions.changeRoleOfPeer(peerId, prevRole, true);
@@ -3036,7 +3229,7 @@ var ParticipantMoreActions = ({ peerId, role }) => {
3036
3229
  }
3037
3230
  setOpen(false);
3038
3231
  });
3039
- return /* @__PURE__ */ React35.createElement(Dropdown.Root, { open, onOpenChange: (value) => setOpen(value), modal: false }, /* @__PURE__ */ React35.createElement(
3232
+ return /* @__PURE__ */ React37.createElement(Dropdown.Root, { open, onOpenChange: (value) => setOpen(value), modal: false }, /* @__PURE__ */ React37.createElement(
3040
3233
  Dropdown.Trigger,
3041
3234
  {
3042
3235
  asChild: true,
@@ -3056,8 +3249,8 @@ var ParticipantMoreActions = ({ peerId, role }) => {
3056
3249
  },
3057
3250
  tabIndex: 0
3058
3251
  },
3059
- /* @__PURE__ */ React35.createElement(Box, { css: { my: "auto" } }, /* @__PURE__ */ React35.createElement(VerticalMenuIcon4, null))
3060
- ), /* @__PURE__ */ React35.createElement(Dropdown.Portal, null, /* @__PURE__ */ React35.createElement(Dropdown.Content, { align: "end", sideOffset: 8, css: { w: "$64", bg: "$surface_default" } }, shouldShowStageRoleChange ? /* @__PURE__ */ React35.createElement(Dropdown.Item, { css: { bg: "$surface_default" }, onClick: () => handleStageAction() }, /* @__PURE__ */ React35.createElement(ChangeRoleIcon2, null), /* @__PURE__ */ React35.createElement(Text, { variant: "sm", css: { ml: "$4", fontWeight: "$semiBold", c: "$on_surface_high" } }, isInStage ? remove_from_stage_label : bring_to_stage_label)) : null, !isLocal && canRemoveOthers && /* @__PURE__ */ React35.createElement(
3252
+ /* @__PURE__ */ React37.createElement(Box, { css: { my: "auto" } }, /* @__PURE__ */ React37.createElement(VerticalMenuIcon4, null))
3253
+ ), /* @__PURE__ */ React37.createElement(Dropdown.Portal, null, /* @__PURE__ */ React37.createElement(Dropdown.Content, { align: "end", sideOffset: 8, css: { w: "$64", bg: "$surface_default" } }, shouldShowStageRoleChange ? /* @__PURE__ */ React37.createElement(Dropdown.Item, { css: { bg: "$surface_default" }, onClick: () => handleStageAction() }, /* @__PURE__ */ React37.createElement(ChangeRoleIcon2, null), /* @__PURE__ */ React37.createElement(Text, { variant: "sm", css: { ml: "$4", fontWeight: "$semiBold", c: "$on_surface_high" } }, isInStage ? remove_from_stage_label : bring_to_stage_label)) : null, !isLocal && canRemoveOthers && /* @__PURE__ */ React37.createElement(
3061
3254
  Dropdown.Item,
3062
3255
  {
3063
3256
  css: { color: "$alert_error_default", bg: "$surface_default" },
@@ -3069,13 +3262,13 @@ var ParticipantMoreActions = ({ peerId, role }) => {
3069
3262
  }
3070
3263
  })
3071
3264
  },
3072
- /* @__PURE__ */ React35.createElement(PeopleRemoveIcon, null),
3073
- /* @__PURE__ */ React35.createElement(Text, { variant: "sm", css: { ml: "$4", color: "inherit", fontWeight: "$semiBold" } }, "Remove Participant")
3265
+ /* @__PURE__ */ React37.createElement(PeopleRemoveIcon, null),
3266
+ /* @__PURE__ */ React37.createElement(Text, { variant: "sm", css: { ml: "$4", color: "inherit", fontWeight: "$semiBold" } }, "Remove Participant")
3074
3267
  ))));
3075
3268
  };
3076
3269
  var ParticipantSearch = ({ onSearch, placeholder, inSidePane = false }) => {
3077
- const [value, setValue] = React35.useState("");
3078
- const isMobile = useMedia4(config.media.md);
3270
+ const [value, setValue] = React37.useState("");
3271
+ const isMobile = useMedia5(config.media.md);
3079
3272
  useDebounce(
3080
3273
  () => {
3081
3274
  onSearch(value);
@@ -3083,7 +3276,7 @@ var ParticipantSearch = ({ onSearch, placeholder, inSidePane = false }) => {
3083
3276
  300,
3084
3277
  [value, onSearch]
3085
3278
  );
3086
- return /* @__PURE__ */ React35.createElement(
3279
+ return /* @__PURE__ */ React37.createElement(
3087
3280
  Flex,
3088
3281
  {
3089
3282
  align: "center",
@@ -3095,8 +3288,8 @@ var ParticipantSearch = ({ onSearch, placeholder, inSidePane = false }) => {
3095
3288
  mt: inSidePane ? "$4" : ""
3096
3289
  }
3097
3290
  },
3098
- /* @__PURE__ */ React35.createElement(SearchIcon, { style: { position: "absolute", left: isMobile ? "1.25rem" : "0.5rem" } }),
3099
- /* @__PURE__ */ React35.createElement(
3291
+ /* @__PURE__ */ React37.createElement(SearchIcon, { style: { position: "absolute", left: isMobile ? "1.25rem" : "0.5rem" } }),
3292
+ /* @__PURE__ */ React37.createElement(
3100
3293
  Input,
3101
3294
  {
3102
3295
  type: "text",
@@ -3117,25 +3310,25 @@ var ParticipantSearch = ({ onSearch, placeholder, inSidePane = false }) => {
3117
3310
  };
3118
3311
 
3119
3312
  // src/Prebuilt/components/Footer/Footer.tsx
3120
- var VirtualBackground = React36.lazy(() => import("./VirtualBackground-3TI5NA4V.js"));
3313
+ var VirtualBackground = React38.lazy(() => import("./VirtualBackground-GP4ATXD3.js"));
3121
3314
  var Footer2 = ({
3122
3315
  screenType,
3123
3316
  elements
3124
3317
  }) => {
3125
3318
  var _a, _b;
3126
- const isMobile = useMedia5(config.media.md);
3319
+ const isMobile = useMedia6(config.media.md);
3127
3320
  const isOverlayChat = !!((_a = elements == null ? void 0 : elements.chat) == null ? void 0 : _a.is_overlay);
3128
3321
  const openByDefault = ((_b = elements == null ? void 0 : elements.chat) == null ? void 0 : _b.initial_state) === Chat_ChatState.CHAT_STATE_OPEN;
3129
3322
  const { toggleAudio, toggleVideo } = useAVToggle2();
3130
3323
  const noAVPermissions = !(toggleAudio || toggleVideo);
3131
3324
  const isChatOpen = useIsSidepaneTypeOpen(SIDE_PANE_OPTIONS.CHAT);
3132
3325
  const toggleChat = useSidepaneToggle(SIDE_PANE_OPTIONS.CHAT);
3133
- useEffect6(() => {
3326
+ useEffect8(() => {
3134
3327
  if (!isChatOpen && openByDefault) {
3135
3328
  toggleChat();
3136
3329
  }
3137
3330
  }, [toggleChat, openByDefault]);
3138
- return /* @__PURE__ */ React36.createElement(
3331
+ return /* @__PURE__ */ React38.createElement(
3139
3332
  Footer.Root,
3140
3333
  {
3141
3334
  css: {
@@ -3149,7 +3342,7 @@ var Footer2 = ({
3149
3342
  }
3150
3343
  }
3151
3344
  },
3152
- /* @__PURE__ */ React36.createElement(
3345
+ /* @__PURE__ */ React38.createElement(
3153
3346
  Footer.Left,
3154
3347
  {
3155
3348
  css: {
@@ -3160,11 +3353,11 @@ var Footer2 = ({
3160
3353
  }
3161
3354
  }
3162
3355
  },
3163
- isMobile ? /* @__PURE__ */ React36.createElement(LeaveRoom, { screenType }) : null,
3164
- /* @__PURE__ */ React36.createElement(AudioVideoToggle, null),
3165
- isMobile ? null : /* @__PURE__ */ React36.createElement(Suspense, { fallback: /* @__PURE__ */ React36.createElement(React36.Fragment, null) }, /* @__PURE__ */ React36.createElement(VirtualBackground, null))
3356
+ isMobile ? /* @__PURE__ */ React38.createElement(LeaveRoom, { screenType }) : null,
3357
+ /* @__PURE__ */ React38.createElement(AudioVideoToggle, null),
3358
+ isMobile ? null : /* @__PURE__ */ React38.createElement(Suspense, { fallback: /* @__PURE__ */ React38.createElement(React38.Fragment, null) }, /* @__PURE__ */ React38.createElement(VirtualBackground, null))
3166
3359
  ),
3167
- /* @__PURE__ */ React36.createElement(
3360
+ /* @__PURE__ */ React38.createElement(
3168
3361
  Footer.Center,
3169
3362
  {
3170
3363
  css: {
@@ -3174,21 +3367,21 @@ var Footer2 = ({
3174
3367
  }
3175
3368
  }
3176
3369
  },
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 }))
3370
+ isMobile ? /* @__PURE__ */ React38.createElement(React38.Fragment, null, noAVPermissions ? /* @__PURE__ */ React38.createElement(RaiseHand, null) : null, (elements == null ? void 0 : elements.chat) && /* @__PURE__ */ React38.createElement(ChatToggle, null), /* @__PURE__ */ React38.createElement(MoreSettings, { elements, screenType })) : /* @__PURE__ */ React38.createElement(React38.Fragment, null, /* @__PURE__ */ React38.createElement(ScreenshareToggle, null), /* @__PURE__ */ React38.createElement(RaiseHand, null), (elements == null ? void 0 : elements.emoji_reactions) && /* @__PURE__ */ React38.createElement(EmojiReaction, null), /* @__PURE__ */ React38.createElement(LeaveRoom, { screenType }))
3178
3371
  ),
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 }))
3372
+ /* @__PURE__ */ React38.createElement(Footer.Right, null, !isMobile && (elements == null ? void 0 : elements.chat) && /* @__PURE__ */ React38.createElement(ChatToggle, null), (elements == null ? void 0 : elements.participant_list) && /* @__PURE__ */ React38.createElement(ParticipantCount, null), /* @__PURE__ */ React38.createElement(MoreSettings, { elements, screenType }))
3180
3373
  );
3181
3374
  };
3182
3375
 
3183
3376
  // src/Prebuilt/components/Notifications/HLSFailureModal.jsx
3184
- import React37, { useCallback as useCallback7, useState as useState19 } from "react";
3185
- import { selectHLSState as selectHLSState2, useHMSActions as useHMSActions12, useHMSStore as useHMSStore16 } from "@100mslive/react-sdk";
3377
+ import React39, { useCallback as useCallback8, useState as useState21 } from "react";
3378
+ import { selectHLSState as selectHLSState2, useHMSActions as useHMSActions14, useHMSStore as useHMSStore17 } from "@100mslive/react-sdk";
3186
3379
  function HLSFailureModal() {
3187
- const { hlsError } = useHMSStore16(selectHLSState2).error || false;
3188
- const [openModal, setOpenModal] = useState19(!!hlsError);
3189
- const hmsActions = useHMSActions12();
3380
+ const { hlsError } = useHMSStore17(selectHLSState2).error || false;
3381
+ const [openModal, setOpenModal] = useState21(!!hlsError);
3382
+ const hmsActions = useHMSActions14();
3190
3383
  const [isHLSStarted, setHLSStarted] = useSetAppDataByKey(APP_DATA.hlsStarted);
3191
- const startHLS = useCallback7(() => __async(this, null, function* () {
3384
+ const startHLS = useCallback8(() => __async(this, null, function* () {
3192
3385
  try {
3193
3386
  if (isHLSStarted) {
3194
3387
  return;
@@ -3203,7 +3396,7 @@ function HLSFailureModal() {
3203
3396
  setHLSStarted(false);
3204
3397
  }
3205
3398
  }), [hmsActions, isHLSStarted, setHLSStarted]);
3206
- return hlsError ? /* @__PURE__ */ React37.createElement(
3399
+ return hlsError ? /* @__PURE__ */ React39.createElement(
3207
3400
  Dialog.Root,
3208
3401
  {
3209
3402
  open: openModal,
@@ -3213,7 +3406,7 @@ function HLSFailureModal() {
3213
3406
  }
3214
3407
  }
3215
3408
  },
3216
- /* @__PURE__ */ React37.createElement(Dialog.Portal, null, /* @__PURE__ */ React37.createElement(Dialog.Overlay, null), /* @__PURE__ */ React37.createElement(Dialog.Content, { css: { w: "min(360px, 90%)" } }, /* @__PURE__ */ React37.createElement(
3409
+ /* @__PURE__ */ React39.createElement(PrebuiltDialogPortal, null, /* @__PURE__ */ React39.createElement(Dialog.Overlay, null), /* @__PURE__ */ React39.createElement(Dialog.Content, { css: { w: "min(360px, 90%)" } }, /* @__PURE__ */ React39.createElement(
3217
3410
  Dialog.Title,
3218
3411
  {
3219
3412
  css: {
@@ -3224,25 +3417,25 @@ function HLSFailureModal() {
3224
3417
  mt: "$4"
3225
3418
  }
3226
3419
  },
3227
- /* @__PURE__ */ React37.createElement(Text, { variant: "h6", css: { fontWeight: "$semiBold" } }, "Failed to Go Live")
3228
- ), /* @__PURE__ */ React37.createElement(Text, { variant: "sm", css: { mb: "$10", color: "$on_surface_medium" } }, "Something went wrong and your live broadcast failed. Please try again."), /* @__PURE__ */ React37.createElement(Flex, { align: "center", justify: "between", css: { w: "100%", gap: "$8" } }, /* @__PURE__ */ React37.createElement(Button, { outlined: true, variant: "standard", css: { w: "100%" }, onClick: () => setOpenModal(false) }, "Dismiss"), /* @__PURE__ */ React37.createElement(Button, { css: { w: "100%" }, onClick: startHLS }, "Go Live"))))
3420
+ /* @__PURE__ */ React39.createElement(Text, { variant: "h6", css: { fontWeight: "$semiBold" } }, "Failed to Go Live")
3421
+ ), /* @__PURE__ */ React39.createElement(Text, { variant: "sm", css: { mb: "$10", color: "$on_surface_medium" } }, "Something went wrong and your live broadcast failed. Please try again."), /* @__PURE__ */ React39.createElement(Flex, { align: "center", justify: "between", css: { w: "100%", gap: "$8" } }, /* @__PURE__ */ React39.createElement(Button, { outlined: true, variant: "standard", css: { w: "100%" }, onClick: () => setOpenModal(false) }, "Dismiss"), /* @__PURE__ */ React39.createElement(Button, { css: { w: "100%" }, onClick: startHLS }, "Go Live"))))
3229
3422
  ) : null;
3230
3423
  }
3231
3424
 
3232
3425
  // src/Prebuilt/components/RoleChangeRequest/RoleChangeRequestModal.tsx
3233
- import React39, { useEffect as useEffect7 } from "react";
3426
+ import React41, { useEffect as useEffect9 } from "react";
3234
3427
  import {
3235
- selectLocalPeerName,
3428
+ selectLocalPeerName as selectLocalPeerName2,
3236
3429
  selectLocalPeerRoleName,
3237
3430
  selectRoleChangeRequest,
3238
3431
  useCustomEvent as useCustomEvent2,
3239
- useHMSActions as useHMSActions13,
3240
- useHMSStore as useHMSStore17
3432
+ useHMSActions as useHMSActions15,
3433
+ useHMSStore as useHMSStore18
3241
3434
  } from "@100mslive/react-sdk";
3242
3435
 
3243
3436
  // src/Prebuilt/components/RoleChangeRequest/RequestPrompt.tsx
3244
- import React38 from "react";
3245
- import { useMedia as useMedia6 } from "react-use";
3437
+ import React40 from "react";
3438
+ import { useMedia as useMedia7 } from "react-use";
3246
3439
  var RequestPrompt = ({
3247
3440
  open = true,
3248
3441
  onOpenChange,
@@ -3251,23 +3444,23 @@ var RequestPrompt = ({
3251
3444
  actionText = "Accept",
3252
3445
  onAction
3253
3446
  }) => {
3254
- const isMobile = useMedia6(config.media.md);
3447
+ const isMobile = useMedia7(config.media.md);
3255
3448
  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 })));
3449
+ return /* @__PURE__ */ React40.createElement(Sheet.Root, { open, onOpenChange }, /* @__PURE__ */ React40.createElement(Sheet.Content, { css: { py: "$8" } }, /* @__PURE__ */ React40.createElement(Text, { css: { fontWeight: "$semiBold", c: "$on_surface_high", "@md": { px: "$8" } } }, title), body, /* @__PURE__ */ React40.createElement(RequestActions, { actionText, onAction })));
3257
3450
  }
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 }))));
3451
+ return /* @__PURE__ */ React40.createElement(Dialog.Root, { open, onOpenChange }, /* @__PURE__ */ React40.createElement(PrebuiltDialogPortal, null, /* @__PURE__ */ React40.createElement(Dialog.Overlay, null), /* @__PURE__ */ React40.createElement(Dialog.Content, { css: { p: "$10" } }, /* @__PURE__ */ React40.createElement(Dialog.Title, { css: { p: 0, display: "flex", flexDirection: "row", gap: "$md", justifyContent: "center" } }, /* @__PURE__ */ React40.createElement(Text, { variant: "h6" }, title)), /* @__PURE__ */ React40.createElement(Box, { css: { mt: "$4", mb: "$10" } }, body), /* @__PURE__ */ React40.createElement(RequestActions, { actionText, onAction }))));
3259
3452
  };
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)));
3453
+ var RequestActions = ({ onAction, actionText }) => /* @__PURE__ */ React40.createElement(Flex, { justify: "center", align: "center", css: { width: "100%", gap: "$md", "@md": { mt: "$8", px: "$8" } } }, /* @__PURE__ */ React40.createElement(Box, { css: { width: "50%" } }, /* @__PURE__ */ React40.createElement(Dialog.Close, { css: { width: "100%" } }, /* @__PURE__ */ React40.createElement(Button, { variant: "standard", outlined: true, css: { width: "100%" } }, "Decline"))), /* @__PURE__ */ React40.createElement(Box, { css: { width: "50%" } }, /* @__PURE__ */ React40.createElement(Button, { variant: "primary", css: { width: "100%" }, onClick: onAction }, actionText)));
3261
3454
 
3262
3455
  // src/Prebuilt/components/RoleChangeRequest/RoleChangeRequestModal.tsx
3263
3456
  var RoleChangeRequestModal = () => {
3264
- const hmsActions = useHMSActions13();
3457
+ const hmsActions = useHMSActions15();
3265
3458
  const { updateMetaData } = useMyMetadata();
3266
- const currentRole = useHMSStore17(selectLocalPeerRoleName);
3267
- const roleChangeRequest = useHMSStore17(selectRoleChangeRequest);
3268
- const name = useHMSStore17(selectLocalPeerName);
3459
+ const currentRole = useHMSStore18(selectLocalPeerRoleName);
3460
+ const roleChangeRequest = useHMSStore18(selectRoleChangeRequest);
3461
+ const name = useHMSStore18(selectLocalPeerName2);
3269
3462
  const { sendEvent } = useCustomEvent2({ type: ROLE_CHANGE_DECLINED });
3270
- useEffect7(() => {
3463
+ useEffect9(() => {
3271
3464
  if (!(roleChangeRequest == null ? void 0 : roleChangeRequest.role)) {
3272
3465
  return;
3273
3466
  }
@@ -3278,7 +3471,7 @@ var RoleChangeRequestModal = () => {
3278
3471
  if (!(roleChangeRequest == null ? void 0 : roleChangeRequest.role)) {
3279
3472
  return null;
3280
3473
  }
3281
- const body = /* @__PURE__ */ React39.createElement(React39.Fragment, null, /* @__PURE__ */ React39.createElement(
3474
+ const body = /* @__PURE__ */ React41.createElement(React41.Fragment, null, /* @__PURE__ */ React41.createElement(
3282
3475
  Text,
3283
3476
  {
3284
3477
  variant: "xs",
@@ -3289,7 +3482,7 @@ var RoleChangeRequestModal = () => {
3289
3482
  }
3290
3483
  },
3291
3484
  "Setup your audio and video before joining"
3292
- ), /* @__PURE__ */ React39.createElement(
3485
+ ), /* @__PURE__ */ React41.createElement(
3293
3486
  Flex,
3294
3487
  {
3295
3488
  align: "center",
@@ -3301,10 +3494,10 @@ var RoleChangeRequestModal = () => {
3301
3494
  "@md": { px: "$8" }
3302
3495
  }
3303
3496
  },
3304
- /* @__PURE__ */ React39.createElement(PreviewTile, { name: name || "" }),
3305
- /* @__PURE__ */ React39.createElement(PreviewControls, { hideSettings: true })
3497
+ /* @__PURE__ */ React41.createElement(PreviewTile, { name: name || "" }),
3498
+ /* @__PURE__ */ React41.createElement(PreviewControls, { hideSettings: true })
3306
3499
  ));
3307
- return /* @__PURE__ */ React39.createElement(
3500
+ return /* @__PURE__ */ React41.createElement(
3308
3501
  RequestPrompt,
3309
3502
  {
3310
3503
  title: "You're invited to join the stage",
@@ -3329,28 +3522,524 @@ var RoleChangeRequestModal = () => {
3329
3522
  };
3330
3523
 
3331
3524
  // src/Prebuilt/layouts/VideoStreamingSection.tsx
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";
3525
+ import React67, { Suspense as Suspense2, useEffect as useEffect26 } from "react";
3526
+ import { selectIsConnectedToRoom as selectIsConnectedToRoom6, selectLocalPeerRoleName as selectLocalPeerRoleName3, useHMSActions as useHMSActions24, useHMSStore as useHMSStore38 } from "@100mslive/react-sdk";
3334
3527
 
3335
3528
  // src/Prebuilt/components/VideoLayouts/GridLayout.tsx
3336
- import React51, { useEffect as useEffect15, useMemo as useMemo6, useState as useState26 } from "react";
3337
- import { selectPeers as selectPeers2, selectPeerScreenSharing, useHMSStore as useHMSStore23, useHMSVanillaStore as useHMSVanillaStore4 } from "@100mslive/react-sdk";
3529
+ import React56, { useEffect as useEffect17, useMemo as useMemo7, useState as useState30 } from "react";
3530
+ import { selectPeers as selectPeers2, selectPeerScreenSharing, useHMSStore as useHMSStore27, useHMSVanillaStore as useHMSVanillaStore4 } from "@100mslive/react-sdk";
3338
3531
 
3339
3532
  // src/Prebuilt/components/VideoLayouts/EqualProminence.tsx
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";
3533
+ import React49, { useEffect as useEffect13, useMemo as useMemo4, useState as useState25 } from "react";
3534
+ import { useMedia as useMedia13 } from "react-use";
3535
+ import { selectLocalPeer as selectLocalPeer2, useHMSStore as useHMSStore23 } from "@100mslive/react-sdk";
3343
3536
 
3344
3537
  // src/Prebuilt/components/InsetTile.tsx
3345
- import React41, { useEffect as useEffect8, useRef as useRef6 } from "react";
3538
+ import React46, { useEffect as useEffect10, useRef as useRef8 } from "react";
3346
3539
  import Draggable from "react-draggable";
3347
- import { useMedia as useMedia7 } from "react-use";
3348
- import { selectIsAllowedToPublish as selectIsAllowedToPublish2, selectLocalPeer, selectVideoTrackByID, useHMSStore as useHMSStore18 } from "@100mslive/react-sdk";
3540
+ import { useMedia as useMedia11 } from "react-use";
3541
+ import { selectIsAllowedToPublish as selectIsAllowedToPublish2, selectLocalPeer, selectVideoTrackByID as selectVideoTrackByID2, useHMSStore as useHMSStore22 } from "@100mslive/react-sdk";
3349
3542
  import { ExpandIcon as ExpandIcon2 } from "@100mslive/react-icons";
3350
3543
 
3544
+ // src/Prebuilt/components/VideoTile.jsx
3545
+ import React44, { Fragment as Fragment9, useCallback as useCallback9, useMemo as useMemo2, useRef as useRef7, useState as useState23 } from "react";
3546
+ import { useMedia as useMedia10 } from "react-use";
3547
+ import {
3548
+ selectAudioTrackByPeerID,
3549
+ selectHasPeerHandRaised as selectHasPeerHandRaised2,
3550
+ selectIsPeerAudioEnabled as selectIsPeerAudioEnabled2,
3551
+ selectLocalPeerID as selectLocalPeerID6,
3552
+ selectPeerMetadata as selectPeerMetadata2,
3553
+ selectPeerNameByID,
3554
+ selectSessionStore as selectSessionStore2,
3555
+ selectVideoTrackByID,
3556
+ selectVideoTrackByPeerID as selectVideoTrackByPeerID2,
3557
+ useHMSStore as useHMSStore21
3558
+ } from "@100mslive/react-sdk";
3559
+ import { BrbTileIcon, HandIcon as HandIcon4, MicOffIcon as MicOffIcon5 } from "@100mslive/react-icons";
3560
+
3561
+ // src/Prebuilt/components/TileMenu/TileMenu.jsx
3562
+ import React43, { useState as useState22 } from "react";
3563
+ import { useMedia as useMedia9 } from "react-use";
3564
+ import {
3565
+ selectLocalPeerID as selectLocalPeerID5,
3566
+ selectPeerByID as selectPeerByID2,
3567
+ selectPermissions as selectPermissions10,
3568
+ selectTrackByID as selectTrackByID2,
3569
+ selectVideoTrackByPeerID,
3570
+ useHMSStore as useHMSStore20,
3571
+ useRemoteAVToggle as useRemoteAVToggle2
3572
+ } from "@100mslive/react-sdk";
3573
+ import { CrossIcon as CrossIcon6, VerticalMenuIcon as VerticalMenuIcon5 } from "@100mslive/react-icons";
3574
+
3575
+ // src/Prebuilt/components/TileMenu/TileMenuContent.jsx
3576
+ import React42, { Fragment as Fragment8 } from "react";
3577
+ import { useMedia as useMedia8 } from "react-use";
3578
+ import {
3579
+ selectPermissions as selectPermissions9,
3580
+ selectSessionStore,
3581
+ selectTrackByID,
3582
+ useCustomEvent as useCustomEvent3,
3583
+ useHMSActions as useHMSActions16,
3584
+ useHMSStore as useHMSStore19,
3585
+ useRemoteAVToggle
3586
+ } from "@100mslive/react-sdk";
3587
+ import {
3588
+ MicOffIcon as MicOffIcon4,
3589
+ MicOnIcon as MicOnIcon2,
3590
+ PencilIcon as PencilIcon2,
3591
+ PinIcon,
3592
+ RemoveUserIcon as RemoveUserIcon2,
3593
+ ShareScreenIcon as ShareScreenIcon2,
3594
+ ShrinkIcon,
3595
+ SpeakerIcon,
3596
+ StarIcon as StarIcon2,
3597
+ VideoOffIcon as VideoOffIcon2,
3598
+ VideoOnIcon as VideoOnIcon2
3599
+ } from "@100mslive/react-icons";
3600
+ var isSameTile = ({ trackId, videoTrackID, audioTrackID }) => trackId && (videoTrackID && videoTrackID === trackId || audioTrackID && audioTrackID === trackId);
3601
+ var spacingCSS = { "@md": { my: "$8", fontWeight: "$semiBold", fontSize: "sm" } };
3602
+ var SpotlightActions = ({
3603
+ peerId,
3604
+ onSpotLightClick = () => {
3605
+ return;
3606
+ }
3607
+ }) => {
3608
+ const hmsActions = useHMSActions16();
3609
+ const spotlightPeerId = useHMSStore19(selectSessionStore(SESSION_STORE_KEY.SPOTLIGHT));
3610
+ const isTileSpotlighted = spotlightPeerId === peerId;
3611
+ const setSpotlightPeerId = (peer) => hmsActions.sessionStore.set(SESSION_STORE_KEY.SPOTLIGHT, peer).catch((err) => ToastManager.addToast({ title: err.description }));
3612
+ return /* @__PURE__ */ React42.createElement(
3613
+ StyledMenuTile.ItemButton,
3614
+ {
3615
+ css: spacingCSS,
3616
+ onClick: () => {
3617
+ if (isTileSpotlighted) {
3618
+ setSpotlightPeerId();
3619
+ } else {
3620
+ setSpotlightPeerId(peerId);
3621
+ }
3622
+ onSpotLightClick();
3623
+ }
3624
+ },
3625
+ /* @__PURE__ */ React42.createElement(StarIcon2, { height: 20, width: 20 }),
3626
+ /* @__PURE__ */ React42.createElement("span", null, isTileSpotlighted ? "Remove from Spotlight" : "Spotlight Tile for everyone")
3627
+ );
3628
+ };
3629
+ var PinActions = ({ audioTrackID, videoTrackID }) => {
3630
+ const [pinnedTrackId, setPinnedTrackId] = useSetAppDataByKey(APP_DATA.pinnedTrackId);
3631
+ const isTilePinned = isSameTile({
3632
+ trackId: pinnedTrackId,
3633
+ videoTrackID,
3634
+ audioTrackID
3635
+ });
3636
+ return /* @__PURE__ */ React42.createElement(React42.Fragment, null, /* @__PURE__ */ React42.createElement(
3637
+ StyledMenuTile.ItemButton,
3638
+ {
3639
+ css: spacingCSS,
3640
+ onClick: () => isTilePinned ? setPinnedTrackId() : setPinnedTrackId(videoTrackID || audioTrackID)
3641
+ },
3642
+ /* @__PURE__ */ React42.createElement(PinIcon, { height: 20, width: 20 }),
3643
+ /* @__PURE__ */ React42.createElement("span", null, isTilePinned ? "Unpin" : "Pin", " Tile for myself")
3644
+ ));
3645
+ };
3646
+ var MinimiseInset = () => {
3647
+ const [minimised, setMinimised] = useSetAppDataByKey(APP_DATA.minimiseInset);
3648
+ return /* @__PURE__ */ React42.createElement(React42.Fragment, null, /* @__PURE__ */ React42.createElement(StyledMenuTile.ItemButton, { css: spacingCSS, onClick: () => setMinimised(!minimised) }, /* @__PURE__ */ React42.createElement(ShrinkIcon, { height: 20, width: 20 }), /* @__PURE__ */ React42.createElement("span", null, minimised ? "Show" : "Minimise", " your video")));
3649
+ };
3650
+ var SimulcastLayers = ({ trackId }) => {
3651
+ var _a;
3652
+ const track = useHMSStore19(selectTrackByID(trackId));
3653
+ const actions = useHMSActions16();
3654
+ const bg = useDropdownSelection();
3655
+ if (!((_a = track == null ? void 0 : track.layerDefinitions) == null ? void 0 : _a.length) || track.degraded || !track.enabled) {
3656
+ return null;
3657
+ }
3658
+ const currentLayer = track.layerDefinitions.find((layer) => layer.layer === track.layer);
3659
+ return /* @__PURE__ */ React42.createElement(Fragment8, null, /* @__PURE__ */ React42.createElement(StyledMenuTile.ItemButton, { css: { color: "$on_surface_medium", cursor: "default" } }, "Select maximum resolution"), track.layerDefinitions.map((layer) => {
3660
+ return /* @__PURE__ */ React42.createElement(
3661
+ StyledMenuTile.ItemButton,
3662
+ {
3663
+ key: layer.layer,
3664
+ onClick: () => __async(void 0, null, function* () {
3665
+ yield actions.setPreferredLayer(trackId, layer.layer);
3666
+ }),
3667
+ css: {
3668
+ justifyContent: "space-between",
3669
+ bg: track.preferredLayer === layer.layer ? bg : void 0,
3670
+ "&:hover": {
3671
+ bg: track.preferredLayer === layer.layer ? bg : void 0
3672
+ }
3673
+ }
3674
+ },
3675
+ /* @__PURE__ */ React42.createElement(
3676
+ Text,
3677
+ {
3678
+ as: "span",
3679
+ css: {
3680
+ textTransform: "capitalize",
3681
+ mr: "$2",
3682
+ fontWeight: track.preferredLayer === layer.layer ? "$semiBold" : "$regular",
3683
+ color: track.preferredLayer === layer.layer ? "$on_primary_high" : "$on_surface_high"
3684
+ }
3685
+ },
3686
+ layer.layer
3687
+ ),
3688
+ /* @__PURE__ */ React42.createElement(
3689
+ Text,
3690
+ {
3691
+ as: "span",
3692
+ variant: "xs",
3693
+ css: {
3694
+ color: track.preferredLayer === layer.layer ? "$on_primary_high" : "$on_surface_high"
3695
+ }
3696
+ },
3697
+ layer.resolution.width,
3698
+ "x",
3699
+ layer.resolution.height
3700
+ )
3701
+ );
3702
+ }), /* @__PURE__ */ React42.createElement(StyledMenuTile.ItemButton, null, /* @__PURE__ */ React42.createElement(Text, { as: "span", variant: "xs", css: { color: "$on_surface_medium" } }, "Currently streaming:", /* @__PURE__ */ React42.createElement(
3703
+ Text,
3704
+ {
3705
+ as: "span",
3706
+ variant: "xs",
3707
+ css: {
3708
+ fontWeight: "$semiBold",
3709
+ textTransform: "capitalize",
3710
+ color: "$on_surface_medium",
3711
+ ml: "$2"
3712
+ }
3713
+ },
3714
+ currentLayer ? /* @__PURE__ */ React42.createElement(React42.Fragment, null, track.layer, " (", currentLayer.resolution.width, "x", currentLayer.resolution.height, ")") : "-"
3715
+ ))));
3716
+ };
3717
+ var TileMenuContent = (props) => {
3718
+ const actions = useHMSActions16();
3719
+ const { removeOthers } = useHMSStore19(selectPermissions9);
3720
+ const {
3721
+ videoTrackID,
3722
+ audioTrackID,
3723
+ isLocal,
3724
+ isScreenshare,
3725
+ showSpotlight,
3726
+ showPinAction,
3727
+ peerID,
3728
+ canMinimise,
3729
+ closeSheetOnClick = () => {
3730
+ return;
3731
+ },
3732
+ openNameChangeModal = () => {
3733
+ return;
3734
+ }
3735
+ } = props;
3736
+ const { isAudioEnabled, isVideoEnabled, setVolume, toggleAudio, toggleVideo, volume } = useRemoteAVToggle(
3737
+ audioTrackID,
3738
+ videoTrackID
3739
+ );
3740
+ const { sendEvent } = useCustomEvent3({
3741
+ type: REMOTE_STOP_SCREENSHARE_TYPE
3742
+ });
3743
+ const isMobile = useMedia8(config.media.md);
3744
+ return isLocal ? (showPinAction || canMinimise) && /* @__PURE__ */ React42.createElement(React42.Fragment, null, showPinAction && /* @__PURE__ */ React42.createElement(PinActions, { audioTrackID, videoTrackID }), showSpotlight && /* @__PURE__ */ React42.createElement(SpotlightActions, { peerId: peerID, onSpotLightClick: () => closeSheetOnClick() }), canMinimise && /* @__PURE__ */ React42.createElement(MinimiseInset, null), /* @__PURE__ */ React42.createElement(
3745
+ StyledMenuTile.ItemButton,
3746
+ {
3747
+ onClick: () => {
3748
+ openNameChangeModal();
3749
+ closeSheetOnClick();
3750
+ }
3751
+ },
3752
+ /* @__PURE__ */ React42.createElement(PencilIcon2, { height: 20, width: 20 }),
3753
+ /* @__PURE__ */ React42.createElement(Text, { variant: "sm", css: { "@md": { fontWeight: "$semiBold" }, c: "$on_surface_high" } }, "Change Name")
3754
+ )) : /* @__PURE__ */ React42.createElement(React42.Fragment, null, toggleVideo ? /* @__PURE__ */ React42.createElement(
3755
+ StyledMenuTile.ItemButton,
3756
+ {
3757
+ css: spacingCSS,
3758
+ onClick: () => {
3759
+ toggleVideo();
3760
+ closeSheetOnClick();
3761
+ },
3762
+ "data-testid": isVideoEnabled ? "mute_video_participant_btn" : "unmute_video_participant_btn"
3763
+ },
3764
+ isVideoEnabled ? /* @__PURE__ */ React42.createElement(VideoOnIcon2, { height: 20, width: 20 }) : /* @__PURE__ */ React42.createElement(VideoOffIcon2, { height: 20, width: 20 }),
3765
+ /* @__PURE__ */ React42.createElement("span", null, isVideoEnabled ? "Mute" : "Request Unmute")
3766
+ ) : null, toggleAudio ? /* @__PURE__ */ React42.createElement(
3767
+ StyledMenuTile.ItemButton,
3768
+ {
3769
+ css: spacingCSS,
3770
+ onClick: () => {
3771
+ toggleAudio();
3772
+ closeSheetOnClick();
3773
+ },
3774
+ "data-testid": isVideoEnabled ? "mute_audio_participant_btn" : "unmute_audio_participant_btn"
3775
+ },
3776
+ isAudioEnabled ? /* @__PURE__ */ React42.createElement(MicOnIcon2, { height: 20, width: 20 }) : /* @__PURE__ */ React42.createElement(MicOffIcon4, { height: 20, width: 20 }),
3777
+ /* @__PURE__ */ React42.createElement("span", null, isAudioEnabled ? "Mute" : "Request Unmute")
3778
+ ) : null, audioTrackID ? /* @__PURE__ */ React42.createElement(StyledMenuTile.VolumeItem, { "data-testid": "participant_volume_slider", css: __spreadProps(__spreadValues({}, spacingCSS), { mb: "$0" }) }, /* @__PURE__ */ React42.createElement(Flex, { align: "center", gap: 1 }, /* @__PURE__ */ React42.createElement(SpeakerIcon, { height: 20, width: 20 }), /* @__PURE__ */ React42.createElement(Box, { as: "span", css: { ml: "$4" } }, "Volume (", volume, ")")), /* @__PURE__ */ React42.createElement(Slider, { css: { my: "0.5rem" }, step: 5, value: [volume], onValueChange: (e) => setVolume(e[0]) })) : null, showPinAction && /* @__PURE__ */ React42.createElement(React42.Fragment, null, /* @__PURE__ */ React42.createElement(PinActions, { audioTrackID, videoTrackID }), showSpotlight && /* @__PURE__ */ React42.createElement(SpotlightActions, { peerId: peerID, onSpotLightClick: () => closeSheetOnClick() })), isMobile ? null : /* @__PURE__ */ React42.createElement(SimulcastLayers, { trackId: videoTrackID }), removeOthers ? /* @__PURE__ */ React42.createElement(
3779
+ StyledMenuTile.RemoveItem,
3780
+ {
3781
+ css: __spreadProps(__spreadValues({}, spacingCSS), { borderTop: "none" }),
3782
+ onClick: () => __async(void 0, null, function* () {
3783
+ try {
3784
+ yield actions.removePeer(peerID, "");
3785
+ } catch (error) {
3786
+ }
3787
+ closeSheetOnClick();
3788
+ }),
3789
+ "data-testid": "remove_participant_btn"
3790
+ },
3791
+ /* @__PURE__ */ React42.createElement(RemoveUserIcon2, { height: 20, width: 20 }),
3792
+ /* @__PURE__ */ React42.createElement("span", null, "Remove Participant")
3793
+ ) : null, removeOthers && isScreenshare ? /* @__PURE__ */ React42.createElement(
3794
+ StyledMenuTile.RemoveItem,
3795
+ {
3796
+ onClick: () => {
3797
+ sendEvent({});
3798
+ closeSheetOnClick();
3799
+ },
3800
+ css: spacingCSS
3801
+ },
3802
+ /* @__PURE__ */ React42.createElement(ShareScreenIcon2, { height: 20, width: 20 }),
3803
+ /* @__PURE__ */ React42.createElement("span", null, "Stop Screenshare")
3804
+ ) : null);
3805
+ };
3806
+
3807
+ // src/Prebuilt/components/TileMenu/TileMenu.jsx
3808
+ var TileMenu = ({
3809
+ audioTrackID,
3810
+ videoTrackID,
3811
+ peerID,
3812
+ isScreenshare = false,
3813
+ canMinimise,
3814
+ enableSpotlightingPeer = true
3815
+ }) => {
3816
+ var _a, _b;
3817
+ const [open, setOpen] = useState22(false);
3818
+ const { theme } = useTheme();
3819
+ const localPeerID = useHMSStore20(selectLocalPeerID5);
3820
+ const isLocal = localPeerID === peerID;
3821
+ const { removeOthers } = useHMSStore20(selectPermissions10);
3822
+ const { setVolume, toggleAudio, toggleVideo } = useRemoteAVToggle2(audioTrackID, videoTrackID);
3823
+ const showSpotlight = enableSpotlightingPeer;
3824
+ const isPrimaryVideoTrack = ((_a = useHMSStore20(selectVideoTrackByPeerID(peerID))) == null ? void 0 : _a.id) === videoTrackID;
3825
+ const showPinAction = audioTrackID || videoTrackID && isPrimaryVideoTrack;
3826
+ const track = useHMSStore20(selectTrackByID2(videoTrackID));
3827
+ const hideSimulcastLayers = !((_b = track == null ? void 0 : track.layerDefinitions) == null ? void 0 : _b.length) || track.degraded || !track.enabled;
3828
+ const isMobile = useMedia9(config.media.md);
3829
+ const peer = useHMSStore20(selectPeerByID2(peerID));
3830
+ const [showNameChangeModal, setShowNameChangeModal] = useState22(false);
3831
+ useDropdownList({ open, name: "TileMenu" });
3832
+ if (!(removeOthers || toggleAudio || toggleVideo || setVolume || showPinAction) && hideSimulcastLayers) {
3833
+ return null;
3834
+ }
3835
+ const openNameChangeModal = () => setShowNameChangeModal(true);
3836
+ const props = {
3837
+ isLocal,
3838
+ isScreenshare,
3839
+ audioTrackID,
3840
+ videoTrackID,
3841
+ peerID,
3842
+ isPrimaryVideoTrack,
3843
+ showSpotlight,
3844
+ showPinAction,
3845
+ canMinimise,
3846
+ openNameChangeModal
3847
+ };
3848
+ return /* @__PURE__ */ React43.createElement(React43.Fragment, null, /* @__PURE__ */ React43.createElement(StyledMenuTile.Root, { open, onOpenChange: setOpen }, /* @__PURE__ */ React43.createElement(
3849
+ StyledMenuTile.Trigger,
3850
+ {
3851
+ "data-testid": "participant_menu_btn",
3852
+ css: { bg: `${theme.colors.background_dim.value}A3`, p: "$2", w: "unset", h: "unset" },
3853
+ onClick: (e) => e.stopPropagation(),
3854
+ className: isMobile ? "__cancel-drag-event" : ""
3855
+ },
3856
+ /* @__PURE__ */ React43.createElement(VerticalMenuIcon5, { width: 20, height: 20 })
3857
+ ), isMobile ? /* @__PURE__ */ React43.createElement(Sheet.Root, { open, onOpenChange: setOpen }, /* @__PURE__ */ React43.createElement(Sheet.Content, { css: { bg: "$surface_dim", pt: "$8" } }, /* @__PURE__ */ React43.createElement(
3858
+ Flex,
3859
+ {
3860
+ css: {
3861
+ color: "$on_surface_high",
3862
+ display: "flex",
3863
+ w: "100%",
3864
+ justifyContent: "space-between",
3865
+ alignItems: "center",
3866
+ px: "$10",
3867
+ pb: "$8",
3868
+ borderBottom: "1px solid $border_default"
3869
+ }
3870
+ },
3871
+ /* @__PURE__ */ React43.createElement(Box, null, /* @__PURE__ */ React43.createElement(Text, { css: { color: "$on_surface_high", fontWeight: "$semiBold" } }, peer.name, isLocal ? ` (You)` : null), (peer == null ? void 0 : peer.roleName) ? /* @__PURE__ */ React43.createElement(Text, { variant: "xs", css: { color: "$on_surface_low", mt: "$2" } }, peer.roleName) : null),
3872
+ /* @__PURE__ */ React43.createElement(Sheet.Close, { css: { color: "inherit" } }, /* @__PURE__ */ React43.createElement(CrossIcon6, null))
3873
+ ), /* @__PURE__ */ React43.createElement(Box, { css: { px: "$8", pb: "$8", maxHeight: "80vh", overflowY: "auto" } }, /* @__PURE__ */ React43.createElement(TileMenuContent, __spreadProps(__spreadValues({}, props), { closeSheetOnClick: () => setOpen(false) }))))) : /* @__PURE__ */ React43.createElement(StyledMenuTile.Content, { side: "top", align: "end", css: { maxHeight: "$80", overflowY: "auto" } }, /* @__PURE__ */ React43.createElement(TileMenuContent, __spreadValues({}, props)))), showNameChangeModal && /* @__PURE__ */ React43.createElement(ChangeNameModal, { onOpenChange: setShowNameChangeModal }));
3874
+ };
3875
+ var TileMenu_default = TileMenu;
3876
+
3877
+ // src/Prebuilt/components/peerTileUtils.jsx
3878
+ var PEER_NAME_PLACEHOLDER = "peerName";
3879
+ var labelMap = /* @__PURE__ */ new Map([
3880
+ [[true, "screen"].toString(), "Your Screen"],
3881
+ [[true, "regular"].toString(), `You (${PEER_NAME_PLACEHOLDER})`],
3882
+ [[false, "screen"].toString(), `${PEER_NAME_PLACEHOLDER}'s Screen`],
3883
+ [[false, "regular"].toString(), PEER_NAME_PLACEHOLDER],
3884
+ [[true, void 0].toString(), `You (${PEER_NAME_PLACEHOLDER})`],
3885
+ [[false, void 0].toString(), `${PEER_NAME_PLACEHOLDER}`]
3886
+ ]);
3887
+ var getVideoTileLabel = ({ peerName, isLocal, track }) => {
3888
+ const isPeerPresent = peerName !== void 0;
3889
+ if (!isPeerPresent || !track) {
3890
+ return isPeerPresent ? labelMap.get([isLocal, void 0].toString()).replace(PEER_NAME_PLACEHOLDER, peerName) : "";
3891
+ }
3892
+ const isLocallyMuted = track.volume === 0;
3893
+ let label = labelMap.get([isLocal, track.source].toString());
3894
+ if (label) {
3895
+ label = label.replace(PEER_NAME_PLACEHOLDER, peerName);
3896
+ } else {
3897
+ label = `${peerName} ${track.source}`;
3898
+ }
3899
+ return `${label}${isLocallyMuted ? " (Muted for you)" : ""}`;
3900
+ };
3901
+
3902
+ // src/Prebuilt/components/VideoTile.jsx
3903
+ var Tile = ({
3904
+ peerId,
3905
+ trackId,
3906
+ width,
3907
+ height,
3908
+ objectFit = "cover",
3909
+ canMinimise = false,
3910
+ isDragabble = false,
3911
+ rootCSS = {},
3912
+ containerCSS = {},
3913
+ enableSpotlightingPeer = true,
3914
+ hideParticipantNameOnTile = false,
3915
+ roundedVideoTile = true,
3916
+ hideAudioMuteOnTile = false,
3917
+ hideMetadataOnTile = false
3918
+ }) => {
3919
+ var _a, _b;
3920
+ const trackSelector = trackId ? selectVideoTrackByID(trackId) : selectVideoTrackByPeerID2(peerId);
3921
+ const track = useHMSStore21(trackSelector);
3922
+ const isMobile = useMedia10(config.media.md);
3923
+ const peerName = useHMSStore21(selectPeerNameByID(peerId));
3924
+ const audioTrack = useHMSStore21(selectAudioTrackByPeerID(peerId));
3925
+ const localPeerID = useHMSStore21(selectLocalPeerID6);
3926
+ const isAudioOnly = useUISettings(UI_SETTINGS.isAudioOnly);
3927
+ const mirrorLocalVideo = useUISettings(UI_SETTINGS.mirrorLocalVideo);
3928
+ const showStatsOnTiles = useUISettings(UI_SETTINGS.showStatsOnTiles);
3929
+ const isAudioMuted = !useHMSStore21(selectIsPeerAudioEnabled2(peerId));
3930
+ const isVideoMuted = !(track == null ? void 0 : track.enabled);
3931
+ const [isMouseHovered, setIsMouseHovered] = useState23(false);
3932
+ const isVideoDegraded = track == null ? void 0 : track.degraded;
3933
+ const isLocal = localPeerID === peerId;
3934
+ const [pinnedTrackId] = useSetAppDataByKey(APP_DATA.pinnedTrackId);
3935
+ const pinned = isSameTile({
3936
+ trackId: pinnedTrackId,
3937
+ videoTrackID: track == null ? void 0 : track.id,
3938
+ audioTrackID: audioTrack == null ? void 0 : audioTrack.id
3939
+ });
3940
+ const spotlighted = useHMSStore21(selectSessionStore2(SESSION_STORE_KEY.SPOTLIGHT)) === peerId;
3941
+ const label = getVideoTileLabel({
3942
+ peerName,
3943
+ track,
3944
+ isLocal
3945
+ });
3946
+ const onHoverHandler = useCallback9((event) => {
3947
+ setIsMouseHovered(event.type === "mouseenter");
3948
+ }, []);
3949
+ const ref = useRef7(null);
3950
+ const calculatedHeight = ((_a = ref.current) == null ? void 0 : _a.clientHeight) || "";
3951
+ const calculatedWidth = ((_b = ref.current) == null ? void 0 : _b.clientWidth) || "";
3952
+ const isTileBigEnoughToShowStats = calculatedHeight >= 180 && calculatedWidth >= 180;
3953
+ const [avatarSize, attribBoxSize] = useMemo2(() => {
3954
+ if (!calculatedWidth || !calculatedHeight) {
3955
+ return [void 0, void 0];
3956
+ }
3957
+ let avatarSize2 = "large";
3958
+ if (calculatedWidth <= 150 || calculatedHeight <= 150) {
3959
+ avatarSize2 = "small";
3960
+ } else if (calculatedWidth <= 300 || calculatedHeight <= 300) {
3961
+ avatarSize2 = "medium";
3962
+ }
3963
+ let attribBoxSize2 = "medium";
3964
+ if (calculatedWidth <= 180 || calculatedHeight <= 180) {
3965
+ attribBoxSize2 = "small";
3966
+ }
3967
+ return [avatarSize2, attribBoxSize2];
3968
+ }, [calculatedWidth, calculatedHeight]);
3969
+ return /* @__PURE__ */ React44.createElement(
3970
+ StyledVideoTile.Root,
3971
+ {
3972
+ ref,
3973
+ css: __spreadValues({
3974
+ width,
3975
+ height
3976
+ }, rootCSS),
3977
+ "data-testid": `participant_tile_${peerName}`
3978
+ },
3979
+ peerName !== void 0 ? /* @__PURE__ */ React44.createElement(
3980
+ StyledVideoTile.Container,
3981
+ {
3982
+ onMouseEnter: onHoverHandler,
3983
+ onMouseLeave: onHoverHandler,
3984
+ noRadius: !roundedVideoTile,
3985
+ css: containerCSS
3986
+ },
3987
+ showStatsOnTiles && isTileBigEnoughToShowStats ? /* @__PURE__ */ React44.createElement(VideoTileStats, { audioTrackID: audioTrack == null ? void 0 : audioTrack.id, videoTrackID: track == null ? void 0 : track.id, peerID: peerId, isLocal }) : null,
3988
+ /* @__PURE__ */ React44.createElement(
3989
+ Video,
3990
+ {
3991
+ trackId: track == null ? void 0 : track.id,
3992
+ attach: isLocal ? void 0 : !isAudioOnly,
3993
+ mirror: mirrorLocalVideo && peerId === localPeerID && (track == null ? void 0 : track.source) === "regular" && (track == null ? void 0 : track.facingMode) !== "environment",
3994
+ noRadius: !roundedVideoTile,
3995
+ "data-testid": "participant_video_tile",
3996
+ css: {
3997
+ objectFit,
3998
+ filter: isVideoDegraded ? "blur($space$2)" : void 0,
3999
+ bg: "transparent"
4000
+ }
4001
+ }
4002
+ ),
4003
+ isVideoMuted || !isLocal && isAudioOnly ? /* @__PURE__ */ React44.createElement(StyledVideoTile.AvatarContainer, null, /* @__PURE__ */ React44.createElement(Avatar, { name: peerName || "", "data-testid": "participant_avatar_icon", size: avatarSize })) : null,
4004
+ !hideAudioMuteOnTile ? isAudioMuted ? /* @__PURE__ */ React44.createElement(StyledVideoTile.AudioIndicator, { "data-testid": "participant_audio_mute_icon", size: attribBoxSize }, /* @__PURE__ */ React44.createElement(MicOffIcon5, null)) : /* @__PURE__ */ React44.createElement(StyledVideoTile.AudioIndicator, { size: attribBoxSize }, /* @__PURE__ */ React44.createElement(AudioLevel, { trackId: audioTrack == null ? void 0 : audioTrack.id, size: attribBoxSize })) : null,
4005
+ isMouseHovered || isDragabble && isMobile ? /* @__PURE__ */ React44.createElement(
4006
+ TileMenu_default,
4007
+ {
4008
+ peerID: peerId,
4009
+ audioTrackID: audioTrack == null ? void 0 : audioTrack.id,
4010
+ videoTrackID: track == null ? void 0 : track.id,
4011
+ canMinimise,
4012
+ enableSpotlightingPeer
4013
+ }
4014
+ ) : null,
4015
+ !hideMetadataOnTile && /* @__PURE__ */ React44.createElement(PeerMetadata, { peerId, size: attribBoxSize }),
4016
+ /* @__PURE__ */ React44.createElement(
4017
+ TileConnection_default,
4018
+ {
4019
+ hideLabel: hideParticipantNameOnTile,
4020
+ name: label,
4021
+ isTile: true,
4022
+ peerId,
4023
+ width,
4024
+ pinned,
4025
+ spotlighted
4026
+ }
4027
+ )
4028
+ ) : null
4029
+ );
4030
+ };
4031
+ var PeerMetadata = ({ peerId, size }) => {
4032
+ const metaData = useHMSStore21(selectPeerMetadata2(peerId));
4033
+ const isBRB = (metaData == null ? void 0 : metaData.isBRBOn) || false;
4034
+ const isHandRaised = useHMSStore21(selectHasPeerHandRaised2(peerId));
4035
+ return /* @__PURE__ */ React44.createElement(Fragment9, null, isHandRaised ? /* @__PURE__ */ React44.createElement(StyledVideoTile.AttributeBox, { size, "data-testid": "raiseHand_icon_onTile" }, /* @__PURE__ */ React44.createElement(HandIcon4, { width: 24, height: 24 })) : null, isBRB ? /* @__PURE__ */ React44.createElement(StyledVideoTile.AttributeBox, { size, "data-testid": "brb_icon_onTile" }, /* @__PURE__ */ React44.createElement(BrbTileIcon, { width: 22, height: 22 })) : null);
4036
+ };
4037
+ var VideoTile = React44.memo(Tile);
4038
+ var VideoTile_default = VideoTile;
4039
+
3351
4040
  // src/Prebuilt/components/hooks/useVideoTileLayout.ts
3352
- import React40, { useContext } from "react";
3353
- var VideoTileContext = React40.createContext({
4041
+ import React45, { useContext } from "react";
4042
+ var VideoTileContext = React45.createContext({
3354
4043
  enableSpotlightingPeer: true,
3355
4044
  hideParticipantNameOnTile: false,
3356
4045
  roundedVideoTile: true,
@@ -3366,14 +4055,14 @@ var useVideoTileContext = () => {
3366
4055
 
3367
4056
  // src/Prebuilt/components/InsetTile.tsx
3368
4057
  var MinimisedTile = ({ setMinimised }) => {
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(
4058
+ return /* @__PURE__ */ React46.createElement(Flex, { align: "center", css: { gap: "$6", r: "$1", bg: "$surface_default", p: "$4", color: "$on_surface_high" } }, /* @__PURE__ */ React46.createElement(AudioVideoToggle, { hideOptions: true }), /* @__PURE__ */ React46.createElement(Text, null, "You"), /* @__PURE__ */ React46.createElement(
3370
4059
  IconButton_default,
3371
4060
  {
3372
4061
  className: "__cancel-drag-event",
3373
4062
  onClick: () => setMinimised(false),
3374
4063
  css: { bg: "transparent", border: "transparent" }
3375
4064
  },
3376
- /* @__PURE__ */ React41.createElement(ExpandIcon2, null)
4065
+ /* @__PURE__ */ React46.createElement(ExpandIcon2, null)
3377
4066
  ));
3378
4067
  };
3379
4068
  var insetHeightPx = 180;
@@ -3381,12 +4070,12 @@ var insetMaxWidthPx = 240;
3381
4070
  var defaultMobileAspectRatio = 9 / 16;
3382
4071
  var desktopAspectRatio = 1 / defaultMobileAspectRatio;
3383
4072
  var InsetTile = () => {
3384
- const isMobile = useMedia7(config.media.md);
3385
- const isLandscape = useMedia7(config.media.ls);
3386
- const localPeer = useHMSStore18(selectLocalPeer);
4073
+ const isMobile = useMedia11(config.media.md);
4074
+ const isLandscape = useMedia11(config.media.ls);
4075
+ const localPeer = useHMSStore22(selectLocalPeer);
3387
4076
  const [minimised, setMinimised] = useSetAppDataByKey(APP_DATA.minimiseInset);
3388
- const videoTrack = useHMSStore18(selectVideoTrackByID(localPeer == null ? void 0 : localPeer.videoTrack));
3389
- const isAllowedToPublish = useHMSStore18(selectIsAllowedToPublish2);
4077
+ const videoTrack = useHMSStore22(selectVideoTrackByID2(localPeer == null ? void 0 : localPeer.videoTrack));
4078
+ const isAllowedToPublish = useHMSStore22(selectIsAllowedToPublish2);
3390
4079
  const videoTileProps = useVideoTileContext();
3391
4080
  let aspectRatio = isMobile ? defaultMobileAspectRatio : desktopAspectRatio;
3392
4081
  if ((videoTrack == null ? void 0 : videoTrack.width) && (videoTrack == null ? void 0 : videoTrack.height) && !isMobile) {
@@ -3398,8 +4087,8 @@ var InsetTile = () => {
3398
4087
  width = 240;
3399
4088
  height = width / aspectRatio;
3400
4089
  }
3401
- const nodeRef = useRef6(null);
3402
- useEffect8(() => {
4090
+ const nodeRef = useRef8(null);
4091
+ useEffect10(() => {
3403
4092
  const node = nodeRef.current;
3404
4093
  if (!node || !window.ResizeObserver) {
3405
4094
  return;
@@ -3420,7 +4109,7 @@ var InsetTile = () => {
3420
4109
  if (!isAllowedToPublish.video && !isAllowedToPublish.audio) {
3421
4110
  return null;
3422
4111
  }
3423
- return /* @__PURE__ */ React41.createElement(Draggable, { bounds: "parent", nodeRef, cancel: ".__cancel-drag-event" }, /* @__PURE__ */ React41.createElement(
4112
+ return /* @__PURE__ */ React46.createElement(Draggable, { bounds: "parent", nodeRef, cancel: ".__cancel-drag-event" }, /* @__PURE__ */ React46.createElement(
3424
4113
  Box,
3425
4114
  {
3426
4115
  ref: nodeRef,
@@ -3436,7 +4125,7 @@ var InsetTile = () => {
3436
4125
  h: height
3437
4126
  } : {})
3438
4127
  },
3439
- minimised ? /* @__PURE__ */ React41.createElement(MinimisedTile, { setMinimised }) : /* @__PURE__ */ React41.createElement(
4128
+ minimised ? /* @__PURE__ */ React46.createElement(MinimisedTile, { setMinimised }) : /* @__PURE__ */ React46.createElement(
3440
4129
  VideoTile_default,
3441
4130
  __spreadProps(__spreadValues({
3442
4131
  peerId: localPeer == null ? void 0 : localPeer.id,
@@ -3458,8 +4147,8 @@ var InsetTile = () => {
3458
4147
  };
3459
4148
 
3460
4149
  // src/Prebuilt/components/Pagination.tsx
3461
- import React42, { useEffect as useEffect9 } from "react";
3462
- import { ChevronLeftIcon as ChevronLeftIcon2, ChevronRightIcon as ChevronRightIcon2 } from "@100mslive/react-icons";
4150
+ import React47, { useEffect as useEffect11 } from "react";
4151
+ import { ChevronLeftIcon as ChevronLeftIcon3, ChevronRightIcon as ChevronRightIcon2 } from "@100mslive/react-icons";
3463
4152
  var Pagination = ({
3464
4153
  page,
3465
4154
  onPageChange,
@@ -3475,7 +4164,7 @@ var Pagination = ({
3475
4164
  e.stopPropagation();
3476
4165
  onPageChange(Math.max(page - 1, 0));
3477
4166
  };
3478
- useEffect9(() => {
4167
+ useEffect11(() => {
3479
4168
  if (page >= numPages) {
3480
4169
  onPageChange(Math.max(0, numPages - 1));
3481
4170
  }
@@ -3483,7 +4172,7 @@ var Pagination = ({
3483
4172
  if (numPages <= 1) {
3484
4173
  return null;
3485
4174
  }
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(
4175
+ return /* @__PURE__ */ React47.createElement(StyledPagination.Root, { css: { flexShrink: 0 } }, /* @__PURE__ */ React47.createElement(StyledPagination.Chevron, { disabled: disableLeft, onClick: prevPage }, /* @__PURE__ */ React47.createElement(ChevronLeftIcon3, { width: 16, height: 16, style: { cursor: disableLeft ? "not-allowed" : "pointer" } })), numPages <= 5 ? /* @__PURE__ */ React47.createElement(StyledPagination.Dots, null, [...Array(numPages)].map((_, i) => /* @__PURE__ */ React47.createElement(
3487
4176
  StyledPagination.Dot,
3488
4177
  {
3489
4178
  key: i,
@@ -3493,15 +4182,15 @@ var Pagination = ({
3493
4182
  onPageChange(i);
3494
4183
  }
3495
4184
  }
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" } })));
4185
+ ))) : null, /* @__PURE__ */ React47.createElement(StyledPagination.Chevron, { disabled: disableRight, onClick: nextPage }, /* @__PURE__ */ React47.createElement(ChevronRightIcon2, { width: 16, height: 16, style: { cursor: disableRight ? "not-allowed" : "pointer" } })));
3497
4186
  };
3498
4187
 
3499
4188
  // src/Prebuilt/components/VideoLayouts/Grid.tsx
3500
- import React43 from "react";
3501
- var Grid = React43.forwardRef(
4189
+ import React48 from "react";
4190
+ var Grid = React48.forwardRef(
3502
4191
  ({ tiles, edgeToEdge }, ref) => {
3503
4192
  const videoTileProps = useVideoTileContext();
3504
- return /* @__PURE__ */ React43.createElement(
4193
+ return /* @__PURE__ */ React48.createElement(
3505
4194
  Box,
3506
4195
  {
3507
4196
  ref,
@@ -3519,7 +4208,7 @@ var Grid = React43.forwardRef(
3519
4208
  },
3520
4209
  tiles == null ? void 0 : tiles.map((tile) => {
3521
4210
  var _a, _b, _c, _d;
3522
- return /* @__PURE__ */ React43.createElement(
4211
+ return /* @__PURE__ */ React48.createElement(
3523
4212
  VideoTile_default,
3524
4213
  __spreadValues({
3525
4214
  key: ((_a = tile.track) == null ? void 0 : _a.id) || ((_b = tile.peer) == null ? void 0 : _b.id),
@@ -3537,8 +4226,8 @@ var Grid = React43.forwardRef(
3537
4226
  );
3538
4227
 
3539
4228
  // src/Prebuilt/components/hooks/useTileLayout.tsx
3540
- import { useEffect as useEffect10, useMemo as useMemo2, useState as useState20 } from "react";
3541
- import { useMeasure as useMeasure2, useMedia as useMedia8 } from "react-use";
4229
+ import { useEffect as useEffect12, useMemo as useMemo3, useState as useState24 } from "react";
4230
+ import { useMeasure as useMeasure2, useMedia as useMedia12 } from "react-use";
3542
4231
  import {
3543
4232
  getPeersWithTiles,
3544
4233
  selectTracksMap as selectTracksMap3,
@@ -3548,12 +4237,12 @@ var aspectRatioConfig = { default: [1 / 1, 4 / 3, 16 / 9], mobile: [1 / 1, 3 / 4
3548
4237
  var usePagesWithTiles = ({ peers, maxTileCount }) => {
3549
4238
  const vanillaStore = useHMSVanillaStore3();
3550
4239
  const tracksMap = vanillaStore.getState(selectTracksMap3);
3551
- const peersWithTiles = useMemo2(
4240
+ const peersWithTiles = useMemo3(
3552
4241
  () => getPeersWithTiles(peers, tracksMap, () => false),
3553
4242
  [peers, tracksMap]
3554
4243
  );
3555
4244
  const noOfPages = Math.ceil(peersWithTiles.length / maxTileCount);
3556
- const pagesList = useMemo2(() => {
4245
+ const pagesList = useMemo3(() => {
3557
4246
  let sliceStart = 0;
3558
4247
  let remaining = peersWithTiles.length;
3559
4248
  const list = [];
@@ -3574,9 +4263,9 @@ var useTileLayout = ({
3574
4263
  }) => {
3575
4264
  const vanillaStore = useHMSVanillaStore3();
3576
4265
  const [ref, { width, height }] = useMeasure2();
3577
- const isMobile = useMedia8(config.media.lg);
3578
- const [pagesWithTiles, setPagesWithTiles] = useState20([]);
3579
- useEffect10(() => {
4266
+ const isMobile = useMedia12(config.media.lg);
4267
+ const [pagesWithTiles, setPagesWithTiles] = useState24([]);
4268
+ useEffect12(() => {
3580
4269
  if (width === 0 || height === 0) {
3581
4270
  return;
3582
4271
  }
@@ -3643,15 +4332,15 @@ var useTileLayout = ({
3643
4332
  // src/Prebuilt/components/VideoLayouts/EqualProminence.tsx
3644
4333
  function EqualProminence({ isInsetEnabled = false, peers, onPageChange, onPageSize, edgeToEdge }) {
3645
4334
  var _a;
3646
- const localPeer = useHMSStore19(selectLocalPeer2);
3647
- const isMobile = useMedia9(config.media.md);
4335
+ const localPeer = useHMSStore23(selectLocalPeer2);
4336
+ const isMobile = useMedia13(config.media.md);
3648
4337
  let maxTileCount = useUISettings(UI_SETTINGS.maxTileCount);
3649
4338
  maxTileCount = isMobile ? Math.min(maxTileCount, 6) : maxTileCount;
3650
4339
  let pageList = usePagesWithTiles({
3651
4340
  peers,
3652
4341
  maxTileCount
3653
4342
  });
3654
- const inputPeers = useMemo3(
4343
+ const inputPeers = useMemo4(
3655
4344
  () => pageList.length === 0 ? localPeer ? [localPeer] : [] : peers,
3656
4345
  [pageList.length, peers, localPeer]
3657
4346
  );
@@ -3664,14 +4353,14 @@ function EqualProminence({ isInsetEnabled = false, peers, onPageChange, onPageSi
3664
4353
  maxTileCount,
3665
4354
  edgeToEdge
3666
4355
  });
3667
- const [page, setPage] = useState21(0);
4356
+ const [page, setPage] = useState25(0);
3668
4357
  const pageSize = ((_a = pagesWithTiles[0]) == null ? void 0 : _a.length) || 0;
3669
- useEffect11(() => {
4358
+ useEffect13(() => {
3670
4359
  if (pageSize > 0) {
3671
4360
  onPageSize == null ? void 0 : onPageSize(pageSize);
3672
4361
  }
3673
4362
  }, [pageSize, onPageSize]);
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(
4363
+ return /* @__PURE__ */ React49.createElement(Flex, { direction: "column", css: { flex: "1 1 0", h: "100%", position: "relative", minWidth: 0 } }, /* @__PURE__ */ React49.createElement(Grid, { tiles: pagesWithTiles[page], ref, edgeToEdge }), !edgeToEdge && /* @__PURE__ */ React49.createElement(
3675
4364
  Pagination,
3676
4365
  {
3677
4366
  page,
@@ -3681,20 +4370,20 @@ function EqualProminence({ isInsetEnabled = false, peers, onPageChange, onPageSi
3681
4370
  },
3682
4371
  numPages: pagesWithTiles.length
3683
4372
  }
3684
- ), isInsetEnabled && pageList.length > 0 && pageList[0][0].peer.id !== (localPeer == null ? void 0 : localPeer.id) && /* @__PURE__ */ React44.createElement(InsetTile, null));
4373
+ ), isInsetEnabled && pageList.length > 0 && pageList[0][0].peer.id !== (localPeer == null ? void 0 : localPeer.id) && /* @__PURE__ */ React49.createElement(InsetTile, null));
3685
4374
  }
3686
4375
 
3687
4376
  // src/Prebuilt/components/VideoLayouts/RoleProminence.tsx
3688
- import React47, { useEffect as useEffect13, useState as useState23 } from "react";
3689
- import { selectLocalPeer as selectLocalPeer3, useHMSStore as useHMSStore20 } from "@100mslive/react-sdk";
4377
+ import React52, { useEffect as useEffect15, useState as useState27 } from "react";
4378
+ import { selectLocalPeer as selectLocalPeer3, useHMSStore as useHMSStore24 } from "@100mslive/react-sdk";
3690
4379
 
3691
4380
  // src/Prebuilt/components/SecondaryTiles.tsx
3692
- import React46, { useEffect as useEffect12, useState as useState22 } from "react";
3693
- import { useMedia as useMedia10 } from "react-use";
4381
+ import React51, { useEffect as useEffect14, useState as useState26 } from "react";
4382
+ import { useMedia as useMedia14 } from "react-use";
3694
4383
 
3695
4384
  // src/Prebuilt/components/VideoLayouts/ProminenceLayout.tsx
3696
- import React45 from "react";
3697
- var Root = ({ children, edgeToEdge }) => /* @__PURE__ */ React45.createElement(
4385
+ import React50 from "react";
4386
+ var Root = ({ children, edgeToEdge }) => /* @__PURE__ */ React50.createElement(
3698
4387
  Flex,
3699
4388
  {
3700
4389
  direction: "column",
@@ -3703,7 +4392,7 @@ var Root = ({ children, edgeToEdge }) => /* @__PURE__ */ React45.createElement(
3703
4392
  children
3704
4393
  );
3705
4394
  var ProminentSection = ({ children, css = {} }) => {
3706
- return /* @__PURE__ */ React45.createElement(Flex, { direction: "column", css: __spreadValues({ flex: "1 1 0", gap: "$2", minHeight: 0 }, css) }, children);
4395
+ return /* @__PURE__ */ React50.createElement(Flex, { direction: "column", css: __spreadValues({ flex: "1 1 0", gap: "$2", minHeight: 0 }, css) }, children);
3707
4396
  };
3708
4397
  var SecondarySection = ({
3709
4398
  tiles,
@@ -3714,12 +4403,12 @@ var SecondarySection = ({
3714
4403
  if (!(tiles == null ? void 0 : tiles.length)) {
3715
4404
  return null;
3716
4405
  }
3717
- return /* @__PURE__ */ React45.createElement(
4406
+ return /* @__PURE__ */ React50.createElement(
3718
4407
  Box,
3719
4408
  {
3720
4409
  css: {
3721
4410
  display: "grid",
3722
- gridTemplateRows: React45.Children.count(children) > 0 ? "136px auto" : "154px",
4411
+ gridTemplateRows: React50.Children.count(children) > 0 ? "136px auto" : "154px",
3723
4412
  gridTemplateColumns: `repeat(${tiles.length}, minmax(0, 1fr))`,
3724
4413
  margin: "0 auto",
3725
4414
  gap: "$2 $4",
@@ -3729,7 +4418,7 @@ var SecondarySection = ({
3729
4418
  },
3730
4419
  tiles.map((tile) => {
3731
4420
  var _a, _b, _c, _d;
3732
- return /* @__PURE__ */ React45.createElement(
4421
+ return /* @__PURE__ */ React50.createElement(
3733
4422
  VideoTile_default,
3734
4423
  __spreadValues({
3735
4424
  key: ((_a = tile.track) == null ? void 0 : _a.id) || ((_b = tile.peer) == null ? void 0 : _b.id),
@@ -3746,7 +4435,7 @@ var SecondarySection = ({
3746
4435
  }, tileLayoutProps)
3747
4436
  );
3748
4437
  }),
3749
- /* @__PURE__ */ React45.createElement(Box, { css: { gridColumn: `1/span ${tiles.length}` } }, children)
4438
+ /* @__PURE__ */ React50.createElement(Box, { css: { gridColumn: `1/span ${tiles.length}` } }, children)
3750
4439
  );
3751
4440
  };
3752
4441
  var ProminenceLayout = {
@@ -3758,17 +4447,17 @@ var ProminenceLayout = {
3758
4447
  // src/Prebuilt/components/SecondaryTiles.tsx
3759
4448
  var SecondaryTiles = ({ peers, onPageChange, onPageSize, edgeToEdge }) => {
3760
4449
  var _a;
3761
- const isMobile = useMedia10(config.media.md);
4450
+ const isMobile = useMedia14(config.media.md);
3762
4451
  const maxTileCount = isMobile ? 2 : 4;
3763
4452
  const pagesWithTiles = usePagesWithTiles({ peers, maxTileCount });
3764
- const [page, setPage] = useState22(0);
4453
+ const [page, setPage] = useState26(0);
3765
4454
  const pageSize = ((_a = pagesWithTiles[0]) == null ? void 0 : _a.length) || 0;
3766
- useEffect12(() => {
4455
+ useEffect14(() => {
3767
4456
  if (pageSize > 0) {
3768
4457
  onPageSize == null ? void 0 : onPageSize(pageSize);
3769
4458
  }
3770
4459
  }, [pageSize, onPageSize]);
3771
- return /* @__PURE__ */ React46.createElement(ProminenceLayout.SecondarySection, { tiles: pagesWithTiles[page], edgeToEdge }, !edgeToEdge && /* @__PURE__ */ React46.createElement(
4460
+ return /* @__PURE__ */ React51.createElement(ProminenceLayout.SecondarySection, { tiles: pagesWithTiles[page], edgeToEdge }, !edgeToEdge && /* @__PURE__ */ React51.createElement(
3772
4461
  Pagination,
3773
4462
  {
3774
4463
  page,
@@ -3782,10 +4471,10 @@ var SecondaryTiles = ({ peers, onPageChange, onPageSize, edgeToEdge }) => {
3782
4471
  };
3783
4472
 
3784
4473
  // src/Prebuilt/components/hooks/useRoleProminencePeers.tsx
3785
- import { useMemo as useMemo4 } from "react";
4474
+ import { useMemo as useMemo5 } from "react";
3786
4475
  var useRoleProminencePeers = (prominentRoles, peers, isInsetEnabled) => {
3787
4476
  const pinnedTrack = usePinnedTrack();
3788
- const [prominentPeers, secondaryPeers] = useMemo4(() => {
4477
+ const [prominentPeers, secondaryPeers] = useMemo5(() => {
3789
4478
  return peers.reduce(
3790
4479
  (acc, peer) => {
3791
4480
  if (pinnedTrack) {
@@ -3826,7 +4515,7 @@ function RoleProminence({
3826
4515
  }) {
3827
4516
  var _a;
3828
4517
  const { prominentPeers, secondaryPeers } = useRoleProminencePeers(prominentRoles, peers, isInsetEnabled);
3829
- const localPeer = useHMSStore20(selectLocalPeer3);
4518
+ const localPeer = useHMSStore24(selectLocalPeer3);
3830
4519
  const maxTileCount = 4;
3831
4520
  const pageList = usePagesWithTiles({
3832
4521
  peers: prominentPeers,
@@ -3836,14 +4525,14 @@ function RoleProminence({
3836
4525
  pageList,
3837
4526
  maxTileCount
3838
4527
  });
3839
- const [page, setPage] = useState23(0);
4528
+ const [page, setPage] = useState27(0);
3840
4529
  const pageSize = ((_a = pagesWithTiles[0]) == null ? void 0 : _a.length) || 0;
3841
- useEffect13(() => {
4530
+ useEffect15(() => {
3842
4531
  if (pageSize > 0) {
3843
4532
  onPageSize == null ? void 0 : onPageSize(pageSize);
3844
4533
  }
3845
4534
  }, [pageSize, onPageSize]);
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(
4535
+ return /* @__PURE__ */ React52.createElement(ProminenceLayout.Root, null, /* @__PURE__ */ React52.createElement(ProminenceLayout.ProminentSection, null, /* @__PURE__ */ React52.createElement(Grid, { ref, tiles: pagesWithTiles[page] })), !edgeToEdge && /* @__PURE__ */ React52.createElement(
3847
4536
  Pagination,
3848
4537
  {
3849
4538
  page,
@@ -3853,34 +4542,34 @@ function RoleProminence({
3853
4542
  },
3854
4543
  numPages: pagesWithTiles.length
3855
4544
  }
3856
- ), /* @__PURE__ */ React47.createElement(SecondaryTiles, { peers: secondaryPeers, isInsetEnabled, edgeToEdge }), isInsetEnabled && localPeer && !prominentPeers.includes(localPeer) && /* @__PURE__ */ React47.createElement(InsetTile, null));
4545
+ ), /* @__PURE__ */ React52.createElement(SecondaryTiles, { peers: secondaryPeers, isInsetEnabled, edgeToEdge }), isInsetEnabled && localPeer && !prominentPeers.includes(localPeer) && /* @__PURE__ */ React52.createElement(InsetTile, null));
3857
4546
  }
3858
4547
 
3859
4548
  // src/Prebuilt/components/VideoLayouts/ScreenshareLayout.tsx
3860
- import React50, { useEffect as useEffect14, useMemo as useMemo5, useState as useState25 } from "react";
3861
- import { useMedia as useMedia11 } from "react-use";
3862
- import { selectPeersScreenSharing, useHMSStore as useHMSStore22 } from "@100mslive/react-sdk";
4549
+ import React55, { useEffect as useEffect16, useMemo as useMemo6, useState as useState29 } from "react";
4550
+ import { useMedia as useMedia15 } from "react-use";
4551
+ import { selectPeersScreenSharing, useHMSStore as useHMSStore26 } from "@100mslive/react-sdk";
3863
4552
 
3864
4553
  // src/Prebuilt/components/ScreenshareTile.jsx
3865
- import React49, { useRef as useRef7, useState as useState24 } from "react";
4554
+ import React54, { useRef as useRef9, useState as useState28 } from "react";
3866
4555
  import { useFullscreen as useFullscreen2 } from "react-use";
3867
4556
  import screenfull2 from "screenfull";
3868
4557
  import {
3869
- selectLocalPeerID as selectLocalPeerID5,
3870
- selectPeerByID as selectPeerByID2,
4558
+ selectLocalPeerID as selectLocalPeerID7,
4559
+ selectPeerByID as selectPeerByID3,
3871
4560
  selectScreenShareAudioByPeerID,
3872
4561
  selectScreenShareByPeerID,
3873
- useHMSStore as useHMSStore21
4562
+ useHMSStore as useHMSStore25
3874
4563
  } from "@100mslive/react-sdk";
3875
- import { ExpandIcon as ExpandIcon3, ShrinkIcon } from "@100mslive/react-icons";
4564
+ import { ExpandIcon as ExpandIcon3, ShrinkIcon as ShrinkIcon2 } from "@100mslive/react-icons";
3876
4565
 
3877
4566
  // src/Prebuilt/components/ScreenshareDisplay.jsx
3878
- import React48 from "react";
3879
- import { useHMSActions as useHMSActions14 } from "@100mslive/react-sdk";
3880
- import { CrossIcon as CrossIcon5, ShareScreenIcon as ShareScreenIcon2 } from "@100mslive/react-icons";
4567
+ import React53 from "react";
4568
+ import { useHMSActions as useHMSActions17 } from "@100mslive/react-sdk";
4569
+ import { CrossIcon as CrossIcon7, ShareScreenIcon as ShareScreenIcon3 } from "@100mslive/react-icons";
3881
4570
  var ScreenshareDisplay = () => {
3882
- const hmsActions = useHMSActions14();
3883
- return /* @__PURE__ */ React48.createElement(
4571
+ const hmsActions = useHMSActions17();
4572
+ return /* @__PURE__ */ React53.createElement(
3884
4573
  Flex,
3885
4574
  {
3886
4575
  direction: "column",
@@ -3892,9 +4581,9 @@ var ScreenshareDisplay = () => {
3892
4581
  color: "$on_surface_high"
3893
4582
  }
3894
4583
  },
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(
4584
+ /* @__PURE__ */ React53.createElement(ShareScreenIcon3, { width: 48, height: 48 }),
4585
+ /* @__PURE__ */ React53.createElement(Text, { variant: "h5", css: { m: "$8 0" } }, "You are sharing your screen"),
4586
+ /* @__PURE__ */ React53.createElement(
3898
4587
  Button,
3899
4588
  {
3900
4589
  variant: "danger",
@@ -3904,7 +4593,7 @@ var ScreenshareDisplay = () => {
3904
4593
  }),
3905
4594
  "data-testid": "stop_screen_share_btn"
3906
4595
  },
3907
- /* @__PURE__ */ React48.createElement(CrossIcon5, { width: 18, height: 18 }),
4596
+ /* @__PURE__ */ React53.createElement(CrossIcon7, { width: 18, height: 18 }),
3908
4597
  "\xA0 Stop screen share"
3909
4598
  )
3910
4599
  );
@@ -3919,22 +4608,22 @@ var labelStyles = {
3919
4608
  transform: "none",
3920
4609
  flexShrink: 0
3921
4610
  };
3922
- var Tile = ({ peerId, width = "100%", height = "100%" }) => {
3923
- const isLocal = useHMSStore21(selectLocalPeerID5) === peerId;
3924
- const track = useHMSStore21(selectScreenShareByPeerID(peerId));
3925
- const peer = useHMSStore21(selectPeerByID2(peerId));
4611
+ var Tile2 = ({ peerId, width = "100%", height = "100%" }) => {
4612
+ const isLocal = useHMSStore25(selectLocalPeerID7) === peerId;
4613
+ const track = useHMSStore25(selectScreenShareByPeerID(peerId));
4614
+ const peer = useHMSStore25(selectPeerByID3(peerId));
3926
4615
  const isAudioOnly = useUISettings(UI_SETTINGS.isAudioOnly);
3927
- const [isMouseHovered, setIsMouseHovered] = useState24(false);
4616
+ const [isMouseHovered, setIsMouseHovered] = useState28(false);
3928
4617
  const showStatsOnTiles = useUISettings(UI_SETTINGS.showStatsOnTiles);
3929
- const fullscreenRef = useRef7(null);
3930
- const [fullscreen, setFullscreen] = useState24(false);
4618
+ const fullscreenRef = useRef9(null);
4619
+ const [fullscreen, setFullscreen] = useState28(false);
3931
4620
  const isFullscreen = useFullscreen2(fullscreenRef, fullscreen, {
3932
4621
  onClose: () => setFullscreen(false)
3933
4622
  });
3934
4623
  const isFullScreenSupported = screenfull2.isEnabled;
3935
- const audioTrack = useHMSStore21(selectScreenShareAudioByPeerID(peer == null ? void 0 : peer.id));
4624
+ const audioTrack = useHMSStore25(selectScreenShareAudioByPeerID(peer == null ? void 0 : peer.id));
3936
4625
  if (isLocal && !["browser", "window", "application"].includes(track == null ? void 0 : track.displaySurface)) {
3937
- return /* @__PURE__ */ React49.createElement(ScreenshareDisplay, null);
4626
+ return /* @__PURE__ */ React54.createElement(ScreenshareDisplay, null);
3938
4627
  }
3939
4628
  if (!peer) {
3940
4629
  return null;
@@ -3944,7 +4633,7 @@ var Tile = ({ peerId, width = "100%", height = "100%" }) => {
3944
4633
  isLocal: false,
3945
4634
  track
3946
4635
  });
3947
- return /* @__PURE__ */ React49.createElement(StyledVideoTile.Root, { css: { width, height, p: 0, minHeight: 0 }, "data-testid": "screenshare_tile" }, /* @__PURE__ */ React49.createElement(
4636
+ return /* @__PURE__ */ React54.createElement(StyledVideoTile.Root, { css: { width, height, p: 0, minHeight: 0 }, "data-testid": "screenshare_tile" }, /* @__PURE__ */ React54.createElement(
3948
4637
  StyledVideoTile.Container,
3949
4638
  {
3950
4639
  transparentBg: true,
@@ -3955,9 +4644,9 @@ var Tile = ({ peerId, width = "100%", height = "100%" }) => {
3955
4644
  setIsMouseHovered(false);
3956
4645
  }
3957
4646
  },
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(
4647
+ showStatsOnTiles ? /* @__PURE__ */ React54.createElement(VideoTileStats, { audioTrackID: audioTrack == null ? void 0 : audioTrack.id, videoTrackID: track == null ? void 0 : track.id, peerID: peerId, isLocal }) : null,
4648
+ isFullScreenSupported && isMouseHovered ? /* @__PURE__ */ React54.createElement(StyledVideoTile.FullScreenButton, { onClick: () => setFullscreen(!fullscreen) }, isFullscreen ? /* @__PURE__ */ React54.createElement(ShrinkIcon2, null) : /* @__PURE__ */ React54.createElement(ExpandIcon3, null)) : null,
4649
+ track ? /* @__PURE__ */ React54.createElement(
3961
4650
  Video,
3962
4651
  {
3963
4652
  screenShare: true,
@@ -3967,8 +4656,8 @@ var Tile = ({ peerId, width = "100%", height = "100%" }) => {
3967
4656
  css: { minHeight: 0 }
3968
4657
  }
3969
4658
  ) : null,
3970
- /* @__PURE__ */ React49.createElement(StyledVideoTile.Info, { css: labelStyles }, label),
3971
- isMouseHovered && !peer.isLocal ? /* @__PURE__ */ React49.createElement(
4659
+ /* @__PURE__ */ React54.createElement(StyledVideoTile.Info, { css: labelStyles }, label),
4660
+ isMouseHovered && !peer.isLocal ? /* @__PURE__ */ React54.createElement(
3972
4661
  TileMenu_default,
3973
4662
  {
3974
4663
  isScreenshare: true,
@@ -3980,28 +4669,28 @@ var Tile = ({ peerId, width = "100%", height = "100%" }) => {
3980
4669
  ) : null
3981
4670
  ));
3982
4671
  };
3983
- var ScreenshareTile = React49.memo(Tile);
4672
+ var ScreenshareTile = React54.memo(Tile2);
3984
4673
  var ScreenshareTile_default = ScreenshareTile;
3985
4674
 
3986
4675
  // src/Prebuilt/components/VideoLayouts/ScreenshareLayout.tsx
3987
4676
  var ScreenshareLayout = ({ peers, onPageChange, onPageSize, edgeToEdge }) => {
3988
4677
  var _a;
3989
- const peersSharing = useHMSStore22(selectPeersScreenSharing);
4678
+ const peersSharing = useHMSStore26(selectPeersScreenSharing);
3990
4679
  const [, setActiveScreenSharePeer] = useSetAppDataByKey(APP_DATA.activeScreensharePeerId);
3991
- const [page, setPage] = useState25(0);
4680
+ const [page, setPage] = useState29(0);
3992
4681
  const activeSharePeer = peersSharing[page];
3993
- const isMobile = useMedia11(config.media.md);
3994
- const secondaryPeers = useMemo5(
4682
+ const isMobile = useMedia15(config.media.md);
4683
+ const secondaryPeers = useMemo6(
3995
4684
  () => 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)),
3996
4685
  [activeSharePeer, peers, isMobile]
3997
4686
  );
3998
- useEffect14(() => {
4687
+ useEffect16(() => {
3999
4688
  setActiveScreenSharePeer(isMobile ? "" : activeSharePeer == null ? void 0 : activeSharePeer.id);
4000
4689
  return () => {
4001
4690
  setActiveScreenSharePeer("");
4002
4691
  };
4003
4692
  }, [activeSharePeer == null ? void 0 : activeSharePeer.id, isMobile, setActiveScreenSharePeer]);
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(
4693
+ return /* @__PURE__ */ React55.createElement(ProminenceLayout.Root, { edgeToEdge }, /* @__PURE__ */ React55.createElement(ProminenceLayout.ProminentSection, null, /* @__PURE__ */ React55.createElement(ScreenshareTile_default, { peerId: (_a = peersSharing[page]) == null ? void 0 : _a.id }), !edgeToEdge && /* @__PURE__ */ React55.createElement(Pagination, { page, onPageChange: setPage, numPages: peersSharing.length })), /* @__PURE__ */ React55.createElement(
4005
4694
  SecondaryTiles,
4006
4695
  {
4007
4696
  peers: secondaryPeers,
@@ -4106,23 +4795,23 @@ var GridLayout = ({
4106
4795
  edge_to_edge = false,
4107
4796
  hide_metadata_on_tile = false
4108
4797
  }) => {
4109
- const peerSharing = useHMSStore23(selectPeerScreenSharing);
4798
+ const peerSharing = useHMSStore27(selectPeerScreenSharing);
4110
4799
  const pinnedTrack = usePinnedTrack();
4111
- const peers = useHMSStore23(selectPeers2);
4800
+ const peers = useHMSStore27(selectPeers2);
4112
4801
  const isRoleProminence = prominentRoles.length && peers.some(
4113
4802
  (peer) => peer.roleName && prominentRoles.includes(peer.roleName) && (peer.videoTrack || peer.audioTrack)
4114
4803
  ) || pinnedTrack;
4115
- const updatedPeers = useMemo6(() => {
4804
+ const updatedPeers = useMemo7(() => {
4116
4805
  if (isInsetEnabled && !isRoleProminence && !peerSharing) {
4117
4806
  return peers.filter((peer) => !peer.isLocal);
4118
4807
  }
4119
4808
  return peers;
4120
4809
  }, [isInsetEnabled, isRoleProminence, peerSharing, peers]);
4121
4810
  const vanillaStore = useHMSVanillaStore4();
4122
- const [sortedPeers, setSortedPeers] = useState26(updatedPeers);
4123
- const peersSorter = useMemo6(() => new PeersSorter_default(vanillaStore), [vanillaStore]);
4124
- const [pageSize, setPageSize] = useState26(0);
4125
- const [mainPage, setMainPage] = useState26(0);
4811
+ const [sortedPeers, setSortedPeers] = useState30(updatedPeers);
4812
+ const peersSorter = useMemo7(() => new PeersSorter_default(vanillaStore), [vanillaStore]);
4813
+ const [pageSize, setPageSize] = useState30(0);
4814
+ const [mainPage, setMainPage] = useState30(0);
4126
4815
  const tileLayout = {
4127
4816
  enableSpotlightingPeer: enable_spotlighting_peer,
4128
4817
  hideParticipantNameOnTile: hide_participant_name_on_tile,
@@ -4131,7 +4820,7 @@ var GridLayout = ({
4131
4820
  hideMetadataOnTile: hide_metadata_on_tile,
4132
4821
  objectFit: video_object_fit
4133
4822
  };
4134
- useEffect15(() => {
4823
+ useEffect17(() => {
4135
4824
  if (mainPage !== 0) {
4136
4825
  return;
4137
4826
  }
@@ -4142,7 +4831,7 @@ var GridLayout = ({
4142
4831
  peersSorter.onUpdate(setSortedPeers);
4143
4832
  }, [mainPage, peersSorter, updatedPeers, pageSize]);
4144
4833
  if (peerSharing) {
4145
- return /* @__PURE__ */ React51.createElement(VideoTileContext.Provider, { value: tileLayout }, /* @__PURE__ */ React51.createElement(
4834
+ return /* @__PURE__ */ React56.createElement(VideoTileContext.Provider, { value: tileLayout }, /* @__PURE__ */ React56.createElement(
4146
4835
  ScreenshareLayout,
4147
4836
  {
4148
4837
  peers: sortedPeers,
@@ -4152,7 +4841,7 @@ var GridLayout = ({
4152
4841
  }
4153
4842
  ));
4154
4843
  } else if (isRoleProminence) {
4155
- return /* @__PURE__ */ React51.createElement(VideoTileContext.Provider, { value: tileLayout }, /* @__PURE__ */ React51.createElement(
4844
+ return /* @__PURE__ */ React56.createElement(VideoTileContext.Provider, { value: tileLayout }, /* @__PURE__ */ React56.createElement(
4156
4845
  RoleProminence,
4157
4846
  {
4158
4847
  peers: sortedPeers,
@@ -4164,7 +4853,7 @@ var GridLayout = ({
4164
4853
  }
4165
4854
  ));
4166
4855
  }
4167
- return /* @__PURE__ */ React51.createElement(VideoTileContext.Provider, { value: tileLayout }, /* @__PURE__ */ React51.createElement(
4856
+ return /* @__PURE__ */ React56.createElement(VideoTileContext.Provider, { value: tileLayout }, /* @__PURE__ */ React56.createElement(
4168
4857
  EqualProminence,
4169
4858
  {
4170
4859
  peers: sortedPeers,
@@ -4177,46 +4866,46 @@ var GridLayout = ({
4177
4866
  };
4178
4867
 
4179
4868
  // src/Prebuilt/layouts/EmbedView.jsx
4180
- import React52, { useCallback as useCallback8, useEffect as useEffect16, useMemo as useMemo7, useRef as useRef8, useState as useState27 } from "react";
4869
+ import React57, { useCallback as useCallback10, useEffect as useEffect18, useMemo as useMemo8, useRef as useRef10, useState as useState31 } from "react";
4181
4870
  import {
4182
4871
  selectPeers as selectPeers3,
4183
4872
  selectPeerScreenSharing as selectPeerScreenSharing2,
4184
4873
  throwErrorHandler,
4185
- useHMSStore as useHMSStore24,
4874
+ useHMSStore as useHMSStore28,
4186
4875
  useScreenShare as useScreenShare3
4187
4876
  } from "@100mslive/react-sdk";
4188
4877
  var EmbedView = () => {
4189
- return /* @__PURE__ */ React52.createElement(EmbebScreenShareView, null, /* @__PURE__ */ React52.createElement(EmbedComponent, null));
4878
+ return /* @__PURE__ */ React57.createElement(EmbebScreenShareView, null, /* @__PURE__ */ React57.createElement(EmbedComponent, null));
4190
4879
  };
4191
4880
  var EmbebScreenShareView = ({ children }) => {
4192
- const peers = useHMSStore24(selectPeers3);
4193
- const peerPresenting = useHMSStore24(selectPeerScreenSharing2);
4881
+ const peers = useHMSStore28(selectPeers3);
4882
+ const peerPresenting = useHMSStore28(selectPeerScreenSharing2);
4194
4883
  const [, setActiveScreenSharePeer] = useSetAppDataByKey(APP_DATA.activeScreensharePeerId);
4195
- const smallTilePeers = useMemo7(() => {
4884
+ const smallTilePeers = useMemo8(() => {
4196
4885
  const smallTilePeers2 = peers.filter((peer) => peer.id !== (peerPresenting == null ? void 0 : peerPresenting.id));
4197
4886
  return smallTilePeers2;
4198
4887
  }, [peers, peerPresenting]);
4199
- useEffect16(() => {
4888
+ useEffect18(() => {
4200
4889
  setActiveScreenSharePeer(peerPresenting == null ? void 0 : peerPresenting.id);
4201
4890
  return () => {
4202
4891
  setActiveScreenSharePeer("");
4203
4892
  };
4204
4893
  }, [peerPresenting == null ? void 0 : peerPresenting.id, setActiveScreenSharePeer]);
4205
- return /* @__PURE__ */ React52.createElement(ProminenceLayout.Root, null, /* @__PURE__ */ React52.createElement(ProminenceLayout.ProminentSection, null, children), /* @__PURE__ */ React52.createElement(SecondaryTiles, { peers: smallTilePeers }));
4894
+ return /* @__PURE__ */ React57.createElement(ProminenceLayout.Root, null, /* @__PURE__ */ React57.createElement(ProminenceLayout.ProminentSection, null, children), /* @__PURE__ */ React57.createElement(SecondaryTiles, { peers: smallTilePeers }));
4206
4895
  };
4207
4896
  var EmbedComponent = () => {
4208
4897
  const { amIScreenSharing, toggleScreenShare } = useScreenShare3(throwErrorHandler);
4209
4898
  const [embedConfig, setEmbedConfig] = useSetAppDataByKey(APP_DATA.embedConfig);
4210
- const [wasScreenShared, setWasScreenShared] = useState27(false);
4211
- const screenShareAttemptInProgress = useRef8(false);
4899
+ const [wasScreenShared, setWasScreenShared] = useState31(false);
4900
+ const screenShareAttemptInProgress = useRef10(false);
4212
4901
  const src = embedConfig.url;
4213
- const iframeRef = useRef8();
4214
- const resetEmbedConfig = useCallback8(() => {
4902
+ const iframeRef = useRef10();
4903
+ const resetEmbedConfig = useCallback10(() => {
4215
4904
  if (src) {
4216
4905
  setEmbedConfig({ url: "" });
4217
4906
  }
4218
4907
  }, [src, setEmbedConfig]);
4219
- useEffect16(() => {
4908
+ useEffect18(() => {
4220
4909
  if (embedConfig.shareScreen && !amIScreenSharing && !wasScreenShared && !screenShareAttemptInProgress.current) {
4221
4910
  screenShareAttemptInProgress.current = true;
4222
4911
  toggleScreenShare({
@@ -4229,7 +4918,7 @@ var EmbedComponent = () => {
4229
4918
  });
4230
4919
  }
4231
4920
  }, []);
4232
- useEffect16(() => {
4921
+ useEffect18(() => {
4233
4922
  if (wasScreenShared && !amIScreenSharing) {
4234
4923
  resetEmbedConfig();
4235
4924
  }
@@ -4240,7 +4929,7 @@ var EmbedComponent = () => {
4240
4929
  }
4241
4930
  };
4242
4931
  }, [wasScreenShared, amIScreenSharing, resetEmbedConfig, toggleScreenShare]);
4243
- return /* @__PURE__ */ React52.createElement(Box, { ref: iframeRef, css: { size: "100%" } }, /* @__PURE__ */ React52.createElement(
4932
+ return /* @__PURE__ */ React57.createElement(Box, { ref: iframeRef, css: { size: "100%" } }, /* @__PURE__ */ React57.createElement(
4244
4933
  "iframe",
4245
4934
  {
4246
4935
  src,
@@ -4253,28 +4942,28 @@ var EmbedComponent = () => {
4253
4942
  };
4254
4943
 
4255
4944
  // src/Prebuilt/layouts/PDFView.jsx
4256
- import React53, { useCallback as useCallback9, useEffect as useEffect17, useRef as useRef9, useState as useState28 } from "react";
4945
+ import React58, { useCallback as useCallback11, useEffect as useEffect19, useRef as useRef11, useState as useState32 } from "react";
4257
4946
  import { throwErrorHandler as throwErrorHandler2, useScreenShare as useScreenShare4 } from "@100mslive/react-sdk";
4258
4947
  var PDFView = () => {
4259
- return /* @__PURE__ */ React53.createElement(EmbebScreenShareView, null, /* @__PURE__ */ React53.createElement(PDFEmbedComponent, null));
4948
+ return /* @__PURE__ */ React58.createElement(EmbebScreenShareView, null, /* @__PURE__ */ React58.createElement(PDFEmbedComponent, null));
4260
4949
  };
4261
4950
  var PDFEmbedComponent = () => {
4262
- const ref = useRef9();
4951
+ const ref = useRef11();
4263
4952
  const themeType = useTheme().themeType;
4264
- const [isPDFLoaded, setIsPDFLoaded] = useState28(false);
4953
+ const [isPDFLoaded, setIsPDFLoaded] = useState32(false);
4265
4954
  let pdfJSURL = define_process_env_default.REACT_APP_PDFJS_IFRAME_URL;
4266
4955
  const { amIScreenSharing, toggleScreenShare } = useScreenShare4(throwErrorHandler2);
4267
4956
  const [pdfConfig, setPDFConfig] = useSetAppDataByKey(APP_DATA.pdfConfig);
4268
4957
  if (pdfConfig.url && !pdfConfig.file) {
4269
4958
  pdfJSURL = pdfJSURL + "?file=" + encodeURIComponent(pdfConfig.url);
4270
4959
  }
4271
- const [wasScreenShared, setWasScreenShared] = useState28(false);
4272
- const screenShareAttemptInProgress = useRef9(false);
4273
- const iframeRef = useRef9();
4274
- const resetEmbedConfig = useCallback9(() => {
4960
+ const [wasScreenShared, setWasScreenShared] = useState32(false);
4961
+ const screenShareAttemptInProgress = useRef11(false);
4962
+ const iframeRef = useRef11();
4963
+ const resetEmbedConfig = useCallback11(() => {
4275
4964
  setPDFConfig({ state: false });
4276
4965
  }, [setPDFConfig]);
4277
- useEffect17(() => {
4966
+ useEffect19(() => {
4278
4967
  if (isPDFLoaded && ref.current) {
4279
4968
  ref.current.contentWindow.postMessage(
4280
4969
  {
@@ -4284,7 +4973,7 @@ var PDFEmbedComponent = () => {
4284
4973
  );
4285
4974
  }
4286
4975
  }, [isPDFLoaded, themeType]);
4287
- useEffect17(() => {
4976
+ useEffect19(() => {
4288
4977
  if (!amIScreenSharing && !wasScreenShared && !screenShareAttemptInProgress.current) {
4289
4978
  screenShareAttemptInProgress.current = true;
4290
4979
  toggleScreenShare({
@@ -4298,7 +4987,7 @@ var PDFEmbedComponent = () => {
4298
4987
  });
4299
4988
  }
4300
4989
  }, []);
4301
- useEffect17(() => {
4990
+ useEffect19(() => {
4302
4991
  if (wasScreenShared && !amIScreenSharing) {
4303
4992
  resetEmbedConfig();
4304
4993
  }
@@ -4309,7 +4998,7 @@ var PDFEmbedComponent = () => {
4309
4998
  }
4310
4999
  };
4311
5000
  }, [wasScreenShared, amIScreenSharing, resetEmbedConfig, toggleScreenShare]);
4312
- return /* @__PURE__ */ React53.createElement(Box, { ref: iframeRef, css: { size: "100%" } }, /* @__PURE__ */ React53.createElement(
5001
+ return /* @__PURE__ */ React58.createElement(Box, { ref: iframeRef, css: { size: "100%" } }, /* @__PURE__ */ React58.createElement(
4313
5002
  "iframe",
4314
5003
  {
4315
5004
  src: pdfJSURL,
@@ -4342,72 +5031,72 @@ var PDFEmbedComponent = () => {
4342
5031
  };
4343
5032
 
4344
5033
  // src/Prebuilt/layouts/SidePane.tsx
4345
- import React60 from "react";
4346
- import { useMedia as useMedia16 } from "react-use";
4347
- import { selectAppData as selectAppData3, selectVideoTrackByPeerID, useHMSStore as useHMSStore33 } from "@100mslive/react-sdk";
5034
+ import React65 from "react";
5035
+ import { useMedia as useMedia20 } from "react-use";
5036
+ import { selectAppData as selectAppData3, selectVideoTrackByPeerID as selectVideoTrackByPeerID3, useHMSStore as useHMSStore37 } from "@100mslive/react-sdk";
4348
5037
 
4349
5038
  // src/Prebuilt/components/SidePaneTabs.tsx
4350
- import React57, { useEffect as useEffect22, useState as useState32 } from "react";
4351
- import { useMedia as useMedia15 } from "react-use";
4352
- import { selectPeerCount as selectPeerCount3, useHMSStore as useHMSStore30 } from "@100mslive/react-sdk";
4353
- import { CrossIcon as CrossIcon7 } from "@100mslive/react-icons";
5039
+ import React62, { useEffect as useEffect24, useState as useState36 } from "react";
5040
+ import { useMedia as useMedia19 } from "react-use";
5041
+ import { selectPeerCount as selectPeerCount3, useHMSStore as useHMSStore34 } from "@100mslive/react-sdk";
5042
+ import { CrossIcon as CrossIcon9 } from "@100mslive/react-icons";
4354
5043
 
4355
5044
  // src/Prebuilt/components/Chat/Chat.jsx
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";
5045
+ import React61, { useCallback as useCallback16, useEffect as useEffect23, useRef as useRef15, useState as useState35 } from "react";
5046
+ import { useMedia as useMedia18 } from "react-use";
4358
5047
  import {
4359
5048
  HMSNotificationTypes,
4360
5049
  selectHMSMessagesCount,
4361
- selectPeerNameByID as selectPeerNameByID3,
4362
- selectPermissions as selectPermissions10,
4363
- selectSessionStore,
4364
- useHMSActions as useHMSActions19,
5050
+ selectPeerNameByID as selectPeerNameByID4,
5051
+ selectPermissions as selectPermissions12,
5052
+ selectSessionStore as selectSessionStore3,
5053
+ useHMSActions as useHMSActions22,
4365
5054
  useHMSNotifications,
4366
- useHMSStore as useHMSStore29
5055
+ useHMSStore as useHMSStore33
4367
5056
  } from "@100mslive/react-sdk";
4368
- import { ChevronDownIcon as ChevronDownIcon2, CrossIcon as CrossIcon6, PinIcon as PinIcon2 } from "@100mslive/react-icons";
5057
+ import { ChevronDownIcon as ChevronDownIcon2, CrossIcon as CrossIcon8, PinIcon as PinIcon3 } from "@100mslive/react-icons";
4369
5058
 
4370
5059
  // src/Prebuilt/components/Chat/ChatBody.jsx
4371
- import React54, { Fragment as Fragment8, useCallback as useCallback11, useEffect as useEffect18, useLayoutEffect, useMemo as useMemo8, useRef as useRef10, useState as useState29 } from "react";
5060
+ import React59, { Fragment as Fragment10, useCallback as useCallback13, useEffect as useEffect20, useLayoutEffect, useMemo as useMemo9, useRef as useRef12, useState as useState33 } from "react";
4372
5061
  import { useInView } from "react-intersection-observer";
4373
- import { useMedia as useMedia12 } from "react-use";
5062
+ import { useMedia as useMedia16 } from "react-use";
4374
5063
  import AutoSizer from "react-virtualized-auto-sizer";
4375
5064
  import { VariableSizeList } from "react-window";
4376
5065
  import {
4377
5066
  selectHMSMessages,
4378
- selectLocalPeerID as selectLocalPeerID6,
5067
+ selectLocalPeerID as selectLocalPeerID8,
4379
5068
  selectLocalPeerRoleName as selectLocalPeerRoleName2,
4380
5069
  selectMessagesByPeerID,
4381
5070
  selectMessagesByRole,
4382
- selectPeerNameByID as selectPeerNameByID2,
4383
- selectPermissions as selectPermissions9,
4384
- useHMSActions as useHMSActions16,
4385
- useHMSStore as useHMSStore27
5071
+ selectPeerNameByID as selectPeerNameByID3,
5072
+ selectPermissions as selectPermissions11,
5073
+ useHMSActions as useHMSActions19,
5074
+ useHMSStore as useHMSStore31
4386
5075
  } from "@100mslive/react-sdk";
4387
- import { PinIcon, VerticalMenuIcon as VerticalMenuIcon5 } from "@100mslive/react-icons";
5076
+ import { PinIcon as PinIcon2, VerticalMenuIcon as VerticalMenuIcon6 } from "@100mslive/react-icons";
4388
5077
 
4389
5078
  // src/Prebuilt/images/empty-chat.svg
4390
5079
  var empty_chat_default = 'data:image/svg+xml,<svg width="184" height="133" viewBox="0 0 184 133" fill="none" xmlns="http://www.w3.org/2000/svg">%0A<path fill-rule="evenodd" clip-rule="evenodd" d="M144.885 91.3998C145.318 91.023 145.861 90.7947 146.433 90.7483L146.446 90.7473L169.355 89.1614C169.702 89.1376 170.049 89.2101 170.358 89.3712C170.662 89.5305 170.918 89.7702 171.096 90.0642C171.098 90.0672 171.1 90.0703 171.102 90.0734L171.104 90.0766C171.281 90.3744 171.373 90.7154 171.369 91.062C171.365 91.4097 171.265 91.7496 171.08 92.044L158.85 111.504C158.539 111.986 158.081 112.356 157.544 112.56C157.007 112.764 156.419 112.791 155.866 112.636C155.313 112.482 154.823 112.155 154.469 111.703C154.115 111.25 153.915 110.697 153.898 110.123C153.898 110.109 153.898 110.094 153.898 110.08L153.996 100.307L145.347 95.7858C145.334 95.779 145.321 95.7721 145.308 95.7649C144.811 95.4785 144.417 95.0404 144.186 94.5146C143.955 93.9888 143.898 93.4029 144.024 92.8425C144.15 92.2821 144.451 91.7765 144.885 91.3998ZM167.441 91.0088L146.603 92.8952C146.49 92.9053 146.383 92.9508 146.298 93.0251C146.211 93.1005 146.151 93.2016 146.125 93.3137C146.1 93.4257 146.112 93.5429 146.158 93.6481C146.202 93.7484 146.276 93.8327 146.369 93.89L155.26 98.296L167.441 91.0088ZM156.32 100.171L168.547 92.8564L157.039 110.339C156.976 110.434 156.886 110.506 156.78 110.547C156.673 110.587 156.555 110.593 156.444 110.562C156.334 110.531 156.236 110.466 156.165 110.375C156.097 110.289 156.058 110.184 156.052 110.075L156.32 100.171Z" fill="%23444954"/>%0A<path d="M83.3248 35.4156C71.7182 47.1017 51.2098 75.5175 62.0292 95.6918C75.5536 120.91 140.453 79.2983 115.364 67.6657C90.2756 56.0331 65.8818 122.018 101.568 120.391C116.398 118.62 131.221 114.699 145.703 105.512" stroke="%23293042" stroke-width="2.25" stroke-dasharray="6 6"/>%0A<rect x="0.00256348" y="0.5" width="173.524" height="58.3398" rx="29.1699" fill="%23272A31"/>%0A<g opacity="0.4">%0A<rect x="24.7526" y="20.9312" width="111" height="4.5" rx="2.25" fill="%23444954"/>%0A</g>%0A<g opacity="0.4">%0A<rect x="38.2526" y="34.4312" width="110.25" height="4.5" rx="2.25" fill="%23444954"/>%0A</g>%0A<path d="M40.3918 71.5547L28.4246 55.0999L52.3589 55.0999L40.3918 71.5547Z" fill="%23272A31"/>%0A</svg>%0A';
4391
5080
 
4392
5081
  // src/Prebuilt/components/hooks/useSetPinnedMessage.js
4393
- import { useCallback as useCallback10 } from "react";
5082
+ import { useCallback as useCallback12 } from "react";
4394
5083
  import {
4395
- selectPeerNameByID,
5084
+ selectPeerNameByID as selectPeerNameByID2,
4396
5085
  selectSessionMetadata,
4397
- useHMSActions as useHMSActions15,
4398
- useHMSStore as useHMSStore25,
5086
+ useHMSActions as useHMSActions18,
5087
+ useHMSStore as useHMSStore29,
4399
5088
  useHMSVanillaStore as useHMSVanillaStore5
4400
5089
  } from "@100mslive/react-sdk";
4401
5090
  var useSetPinnedMessage = () => {
4402
- const hmsActions = useHMSActions15();
5091
+ const hmsActions = useHMSActions18();
4403
5092
  const vanillaStore = useHMSVanillaStore5();
4404
- const pinnedMessage = useHMSStore25(selectSessionMetadata);
4405
- const setPinnedMessage = useCallback10(
5093
+ const pinnedMessage = useHMSStore29(selectSessionMetadata);
5094
+ const setPinnedMessage = useCallback12(
4406
5095
  /**
4407
5096
  * @param {import("@100mslive/react-sdk").HMSMessage | undefined} message
4408
5097
  */
4409
5098
  (message) => __async(void 0, null, function* () {
4410
- const peerName = vanillaStore.getState(selectPeerNameByID(message == null ? void 0 : message.sender)) || (message == null ? void 0 : message.senderName);
5099
+ const peerName = vanillaStore.getState(selectPeerNameByID2(message == null ? void 0 : message.sender)) || (message == null ? void 0 : message.senderName);
4411
5100
  const newPinnedMessage = message ? peerName ? `${peerName}: ${message.message}` : message.message : null;
4412
5101
  if (newPinnedMessage !== pinnedMessage) {
4413
5102
  yield hmsActions.sessionStore.set(SESSION_STORE_KEY.PINNED_MESSAGE, newPinnedMessage).catch((err) => ToastManager.addToast({ title: err.description }));
@@ -4423,11 +5112,11 @@ import {
4423
5112
  selectMessagesUnreadCountByPeerID,
4424
5113
  selectMessagesUnreadCountByRole,
4425
5114
  selectUnreadHMSMessagesCount as selectUnreadHMSMessagesCount2,
4426
- useHMSStore as useHMSStore26
5115
+ useHMSStore as useHMSStore30
4427
5116
  } from "@100mslive/react-sdk";
4428
5117
  var useUnreadCount = ({ role, peerId }) => {
4429
5118
  const unreadCountSelector = role ? selectMessagesUnreadCountByRole(role) : peerId ? selectMessagesUnreadCountByPeerID(peerId) : selectUnreadHMSMessagesCount2;
4430
- const unreadCount = useHMSStore26(unreadCountSelector);
5119
+ const unreadCount = useHMSStore30(unreadCountSelector);
4431
5120
  return unreadCount;
4432
5121
  };
4433
5122
 
@@ -4448,7 +5137,7 @@ var formatTime = (date) => {
4448
5137
  return `${hours}:${mins} ${suffix}`;
4449
5138
  };
4450
5139
  var MessageTypeContainer = ({ left, right }) => {
4451
- return /* @__PURE__ */ React54.createElement(
5140
+ return /* @__PURE__ */ React59.createElement(
4452
5141
  Flex,
4453
5142
  {
4454
5143
  align: "center",
@@ -4460,16 +5149,16 @@ var MessageTypeContainer = ({ left, right }) => {
4460
5149
  r: "$0"
4461
5150
  }
4462
5151
  },
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)
5152
+ left && /* @__PURE__ */ React59.createElement(SenderName, { variant: "tiny", as: "span", css: { color: "$on_surface_medium" } }, left),
5153
+ left && right && /* @__PURE__ */ React59.createElement(Box, { css: { borderLeft: "1px solid $border_bright", mx: "$4", h: "$8" } }),
5154
+ right && /* @__PURE__ */ React59.createElement(SenderName, { as: "span", variant: "tiny", css: { textTransform: "uppercase" } }, right)
4466
5155
  );
4467
5156
  };
4468
5157
  var MessageType = ({ roles, hasCurrentUserSent, receiver }) => {
4469
- const peerName = useHMSStore27(selectPeerNameByID2(receiver));
4470
- const localPeerRoleName = useHMSStore27(selectLocalPeerRoleName2);
5158
+ const peerName = useHMSStore31(selectPeerNameByID3(receiver));
5159
+ const localPeerRoleName = useHMSStore31(selectLocalPeerRoleName2);
4471
5160
  if (receiver) {
4472
- return /* @__PURE__ */ React54.createElement(
5161
+ return /* @__PURE__ */ React59.createElement(
4473
5162
  MessageTypeContainer,
4474
5163
  {
4475
5164
  left: hasCurrentUserSent ? `${peerName ? `TO ${peerName}` : ""}` : "TO YOU",
@@ -4478,7 +5167,7 @@ var MessageType = ({ roles, hasCurrentUserSent, receiver }) => {
4478
5167
  );
4479
5168
  }
4480
5169
  if (roles && roles.length) {
4481
- return /* @__PURE__ */ React54.createElement(MessageTypeContainer, { left: "TO", right: hasCurrentUserSent ? roles.join(",") : localPeerRoleName });
5170
+ return /* @__PURE__ */ React59.createElement(MessageTypeContainer, { left: "TO", right: hasCurrentUserSent ? roles.join(",") : localPeerRoleName });
4482
5171
  }
4483
5172
  return null;
4484
5173
  };
@@ -4492,10 +5181,10 @@ var Link = styled("a", {
4492
5181
  });
4493
5182
  var AnnotisedMessage = ({ message }) => {
4494
5183
  if (!message) {
4495
- return /* @__PURE__ */ React54.createElement(Fragment8, null);
5184
+ return /* @__PURE__ */ React59.createElement(Fragment10, null);
4496
5185
  }
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
5186
+ return /* @__PURE__ */ React59.createElement(Fragment10, null, message.trim().split(/(\s)/).map(
5187
+ (part) => URL_REGEX.test(part) ? /* @__PURE__ */ React59.createElement(Link, { href: part, key: part, target: "_blank", rel: "noopener noreferrer" }, part) : part
4499
5188
  ));
4500
5189
  };
4501
5190
  var getMessageType = ({ roles, receiver }) => {
@@ -4505,18 +5194,18 @@ var getMessageType = ({ roles, receiver }) => {
4505
5194
  return receiver ? "private" : "";
4506
5195
  };
4507
5196
  var ChatActions = ({ onPin, showPinAction }) => {
4508
- const [open, setOpen] = useState29(false);
5197
+ const [open, setOpen] = useState33(false);
4509
5198
  if (!showPinAction) {
4510
5199
  return null;
4511
5200
  }
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(
5201
+ return /* @__PURE__ */ React59.createElement(Dropdown.Root, { open, onOpenChange: setOpen }, /* @__PURE__ */ React59.createElement(Dropdown.Trigger, { className: "chat_actions", css: { opacity: open ? 1 : 0, "@md": { opacity: 1 } }, asChild: true }, /* @__PURE__ */ React59.createElement(IconButton, null, /* @__PURE__ */ React59.createElement(Tooltip, { title: "More options" }, /* @__PURE__ */ React59.createElement(VerticalMenuIcon6, null)))), /* @__PURE__ */ React59.createElement(Dropdown.Portal, null, /* @__PURE__ */ React59.createElement(
4513
5202
  Dropdown.Content,
4514
5203
  {
4515
5204
  sideOffset: 5,
4516
5205
  align: "end",
4517
5206
  css: { width: "$48", backgroundColor: "$surface_bright", py: "$0", border: "1px solid $border_bright" }
4518
5207
  },
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"))
5208
+ /* @__PURE__ */ React59.createElement(Dropdown.Item, { "data-testid": "pin_message_btn", onClick: onPin }, /* @__PURE__ */ React59.createElement(PinIcon2, null), /* @__PURE__ */ React59.createElement(Text, { variant: "sm", css: { ml: "$4" } }, "Pin Message"))
4520
5209
  )));
4521
5210
  };
4522
5211
  var SenderName = styled(Text, {
@@ -4528,38 +5217,38 @@ var SenderName = styled(Text, {
4528
5217
  color: "$on_surface_high",
4529
5218
  fontWeight: "$semiBold"
4530
5219
  });
4531
- var ChatMessage = React54.memo(
5220
+ var ChatMessage = React59.memo(
4532
5221
  ({ index, style = {}, message, setRowHeight, isLast = false, unreadCount = 0, scrollToBottom, onPin }) => {
4533
5222
  var _a, _b;
4534
5223
  const { ref, inView } = useInView({ threshold: 0.5, triggerOnce: true });
4535
- const rowRef = useRef10(null);
4536
- useEffect18(() => {
5224
+ const rowRef = useRef12(null);
5225
+ useEffect20(() => {
4537
5226
  if (rowRef.current) {
4538
5227
  setRowHeight(index, rowRef.current.clientHeight);
4539
5228
  }
4540
5229
  }, [index, setRowHeight]);
4541
- const isMobile = useMedia12(config.media.md);
5230
+ const isMobile = useMedia16(config.media.md);
4542
5231
  const { elements } = useRoomLayoutConferencingScreen();
4543
5232
  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);
5233
+ const hmsActions = useHMSActions19();
5234
+ const localPeerId = useHMSStore31(selectLocalPeerID8);
5235
+ const permissions = useHMSStore31(selectPermissions11);
4547
5236
  const messageType = getMessageType({
4548
5237
  roles: message.recipientRoles,
4549
5238
  receiver: message.recipientPeer
4550
5239
  });
4551
5240
  const showPinAction = permissions.removeOthers && !messageType && ((_b = elements == null ? void 0 : elements.chat) == null ? void 0 : _b.allow_pinning_messages);
4552
- useEffect18(() => {
5241
+ useEffect20(() => {
4553
5242
  if (message.id && !message.read && inView) {
4554
5243
  hmsActions.setMessageRead(true, message.id);
4555
5244
  }
4556
5245
  }, [message.read, hmsActions, inView, message.id]);
4557
- useEffect18(() => {
5246
+ useEffect20(() => {
4558
5247
  if (isLast && inView && unreadCount >= 1) {
4559
5248
  scrollToBottom(1);
4560
5249
  }
4561
5250
  }, [inView, isLast, scrollToBottom, unreadCount]);
4562
- return /* @__PURE__ */ React54.createElement(
5251
+ return /* @__PURE__ */ React59.createElement(
4563
5252
  Box,
4564
5253
  {
4565
5254
  ref,
@@ -4567,7 +5256,7 @@ var ChatMessage = React54.memo(
4567
5256
  css: { mb: "$10", pr: "$10", mt: "$8", "&:hover .chat_actions": { opacity: 1 } },
4568
5257
  style
4569
5258
  },
4570
- /* @__PURE__ */ React54.createElement(
5259
+ /* @__PURE__ */ React59.createElement(
4571
5260
  Flex,
4572
5261
  {
4573
5262
  ref: rowRef,
@@ -4584,7 +5273,7 @@ var ChatMessage = React54.memo(
4584
5273
  key: message.time,
4585
5274
  "data-testid": "chat_msg"
4586
5275
  },
4587
- /* @__PURE__ */ React54.createElement(
5276
+ /* @__PURE__ */ React59.createElement(
4588
5277
  Text,
4589
5278
  {
4590
5279
  css: {
@@ -4597,7 +5286,7 @@ var ChatMessage = React54.memo(
4597
5286
  },
4598
5287
  as: "div"
4599
5288
  },
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(
5289
+ /* @__PURE__ */ React59.createElement(Flex, { align: "baseline" }, message.senderName === "You" || !message.senderName ? /* @__PURE__ */ React59.createElement(SenderName, { as: "span", variant: "sm", css: { color: isOverlay ? "#FFF" : "$on_surface_high" } }, message.senderName || "Anonymous") : /* @__PURE__ */ React59.createElement(Tooltip, { title: message.senderName, side: "top", align: "start" }, /* @__PURE__ */ React59.createElement(SenderName, { as: "span", variant: "sm", css: { color: isOverlay ? "#FFF" : "$on_surface_high" } }, message.senderName)), !isOverlay ? /* @__PURE__ */ React59.createElement(
4601
5290
  Text,
4602
5291
  {
4603
5292
  as: "span",
@@ -4610,7 +5299,7 @@ var ChatMessage = React54.memo(
4610
5299
  },
4611
5300
  formatTime(message.time)
4612
5301
  ) : null),
4613
- /* @__PURE__ */ React54.createElement(
5302
+ /* @__PURE__ */ React59.createElement(
4614
5303
  MessageType,
4615
5304
  {
4616
5305
  hasCurrentUserSent: message.sender === localPeerId,
@@ -4618,9 +5307,9 @@ var ChatMessage = React54.memo(
4618
5307
  roles: message.recipientRoles
4619
5308
  }
4620
5309
  ),
4621
- !isOverlay ? /* @__PURE__ */ React54.createElement(ChatActions, { onPin, showPinAction }) : null
5310
+ !isOverlay ? /* @__PURE__ */ React59.createElement(ChatActions, { onPin, showPinAction }) : null
4622
5311
  ),
4623
- /* @__PURE__ */ React54.createElement(
5312
+ /* @__PURE__ */ React59.createElement(
4624
5313
  Text,
4625
5314
  {
4626
5315
  variant: "sm",
@@ -4634,13 +5323,13 @@ var ChatMessage = React54.memo(
4634
5323
  },
4635
5324
  onClick: (e) => e.stopPropagation()
4636
5325
  },
4637
- /* @__PURE__ */ React54.createElement(AnnotisedMessage, { message: message.message })
5326
+ /* @__PURE__ */ React59.createElement(AnnotisedMessage, { message: message.message })
4638
5327
  )
4639
5328
  )
4640
5329
  );
4641
5330
  }
4642
5331
  );
4643
- var ChatList = React54.forwardRef(
5332
+ var ChatList = React59.forwardRef(
4644
5333
  ({ width, height, setRowHeight, getRowHeight, messages, unreadCount = 0, scrollToBottom }, listRef) => {
4645
5334
  const { setPinnedMessage } = useSetPinnedMessage();
4646
5335
  useLayoutEffect(() => {
@@ -4648,7 +5337,7 @@ var ChatList = React54.forwardRef(
4648
5337
  scrollToBottom(1);
4649
5338
  }
4650
5339
  }, [listRef]);
4651
- return /* @__PURE__ */ React54.createElement(
5340
+ return /* @__PURE__ */ React59.createElement(
4652
5341
  VariableSizeList,
4653
5342
  {
4654
5343
  ref: listRef,
@@ -4660,7 +5349,7 @@ var ChatList = React54.forwardRef(
4660
5349
  overflowX: "hidden"
4661
5350
  }
4662
5351
  },
4663
- ({ index, style }) => /* @__PURE__ */ React54.createElement(
5352
+ ({ index, style }) => /* @__PURE__ */ React59.createElement(
4664
5353
  ChatMessage,
4665
5354
  {
4666
5355
  style,
@@ -4677,19 +5366,19 @@ var ChatList = React54.forwardRef(
4677
5366
  );
4678
5367
  }
4679
5368
  );
4680
- var VirtualizedChatMessages = React54.forwardRef(({ messages, unreadCount = 0, scrollToBottom }, listRef) => {
4681
- const rowHeights = useRef10({});
5369
+ var VirtualizedChatMessages = React59.forwardRef(({ messages, unreadCount = 0, scrollToBottom }, listRef) => {
5370
+ const rowHeights = useRef12({});
4682
5371
  function getRowHeight(index) {
4683
5372
  return rowHeights.current[index] + 16 || 72;
4684
5373
  }
4685
- const setRowHeight = useCallback11(
5374
+ const setRowHeight = useCallback13(
4686
5375
  (index, size) => {
4687
5376
  listRef.current.resetAfterIndex(0);
4688
5377
  rowHeights.current = __spreadProps(__spreadValues({}, rowHeights.current), { [index]: size });
4689
5378
  },
4690
5379
  [listRef]
4691
5380
  );
4692
- return /* @__PURE__ */ React54.createElement(
5381
+ return /* @__PURE__ */ React59.createElement(
4693
5382
  Box,
4694
5383
  {
4695
5384
  css: {
@@ -4698,14 +5387,14 @@ var VirtualizedChatMessages = React54.forwardRef(({ messages, unreadCount = 0, s
4698
5387
  },
4699
5388
  as: "div"
4700
5389
  },
4701
- /* @__PURE__ */ React54.createElement(
5390
+ /* @__PURE__ */ React59.createElement(
4702
5391
  AutoSizer,
4703
5392
  {
4704
5393
  style: {
4705
5394
  width: "90%"
4706
5395
  }
4707
5396
  },
4708
- ({ height, width }) => /* @__PURE__ */ React54.createElement(
5397
+ ({ height, width }) => /* @__PURE__ */ React59.createElement(
4709
5398
  ChatList,
4710
5399
  {
4711
5400
  width,
@@ -4721,16 +5410,16 @@ var VirtualizedChatMessages = React54.forwardRef(({ messages, unreadCount = 0, s
4721
5410
  )
4722
5411
  );
4723
5412
  });
4724
- var ChatBody = React54.forwardRef(({ role, peerId, scrollToBottom }, listRef) => {
5413
+ var ChatBody = React59.forwardRef(({ role, peerId, scrollToBottom }, listRef) => {
4725
5414
  var _a;
4726
5415
  const storeMessageSelector = role ? selectMessagesByRole(role) : peerId ? selectMessagesByPeerID(peerId) : selectHMSMessages;
4727
- let messages = useHMSStore27(storeMessageSelector);
4728
- messages = useMemo8(() => (messages == null ? void 0 : messages.filter((message) => message.type === "chat")) || [], [messages]);
4729
- const isMobile = useMedia12(config.media.md);
5416
+ let messages = useHMSStore31(storeMessageSelector);
5417
+ messages = useMemo9(() => (messages == null ? void 0 : messages.filter((message) => message.type === "chat")) || [], [messages]);
5418
+ const isMobile = useMedia16(config.media.md);
4730
5419
  const { elements } = useRoomLayoutConferencingScreen();
4731
5420
  const unreadCount = useUnreadCount({ role, peerId });
4732
5421
  if (messages.length === 0 && !(isMobile && ((_a = elements == null ? void 0 : elements.chat) == null ? void 0 : _a.is_overlay))) {
4733
- return /* @__PURE__ */ React54.createElement(
5422
+ return /* @__PURE__ */ React59.createElement(
4734
5423
  Flex,
4735
5424
  {
4736
5425
  css: {
@@ -4742,7 +5431,7 @@ var ChatBody = React54.forwardRef(({ role, peerId, scrollToBottom }, listRef) =>
4742
5431
  align: "center",
4743
5432
  justify: "center"
4744
5433
  },
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(
5434
+ /* @__PURE__ */ React59.createElement(Box, null, /* @__PURE__ */ React59.createElement("img", { src: empty_chat_default, alt: "Empty Chat", height: 132, width: 185, style: { margin: "0 auto" } }), /* @__PURE__ */ React59.createElement(Text, { variant: "h5", css: { mt: "$8", c: "$on_surface_high" } }, "Start a conversation"), /* @__PURE__ */ React59.createElement(
4746
5435
  Text,
4747
5436
  {
4748
5437
  variant: "sm",
@@ -4752,7 +5441,7 @@ var ChatBody = React54.forwardRef(({ role, peerId, scrollToBottom }, listRef) =>
4752
5441
  ))
4753
5442
  );
4754
5443
  }
4755
- return /* @__PURE__ */ React54.createElement(Fragment8, null, /* @__PURE__ */ React54.createElement(
5444
+ return /* @__PURE__ */ React59.createElement(Fragment10, null, /* @__PURE__ */ React59.createElement(
4756
5445
  VirtualizedChatMessages,
4757
5446
  {
4758
5447
  messages,
@@ -4764,23 +5453,23 @@ var ChatBody = React54.forwardRef(({ role, peerId, scrollToBottom }, listRef) =>
4764
5453
  });
4765
5454
 
4766
5455
  // src/Prebuilt/components/Chat/ChatFooter.tsx
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";
5456
+ import React60, { useCallback as useCallback15, useEffect as useEffect22, useRef as useRef14, useState as useState34 } from "react";
5457
+ import { useMedia as useMedia17 } from "react-use";
4769
5458
  import data2 from "@emoji-mart/data";
4770
5459
  import Picker from "@emoji-mart/react";
4771
- import { useHMSActions as useHMSActions18 } from "@100mslive/react-sdk";
5460
+ import { useHMSActions as useHMSActions21 } from "@100mslive/react-sdk";
4772
5461
  import { EmojiIcon as EmojiIcon3, SendIcon } from "@100mslive/react-icons";
4773
5462
 
4774
5463
  // src/Prebuilt/components/AppData/useChatState.js
4775
- import { useCallback as useCallback12 } from "react";
4776
- import { selectAppData as selectAppData2, useHMSActions as useHMSActions17, useHMSStore as useHMSStore28 } from "@100mslive/react-sdk";
5464
+ import { useCallback as useCallback14 } from "react";
5465
+ import { selectAppData as selectAppData2, useHMSActions as useHMSActions20, useHMSStore as useHMSStore32 } from "@100mslive/react-sdk";
4777
5466
  var useChatDraftMessage = () => {
4778
- const hmsActions = useHMSActions17();
4779
- let chatDraftMessage = useHMSStore28(selectAppData2(APP_DATA.chatDraft));
5467
+ const hmsActions = useHMSActions20();
5468
+ let chatDraftMessage = useHMSStore32(selectAppData2(APP_DATA.chatDraft));
4780
5469
  if (chatDraftMessage === void 0 || chatDraftMessage === null) {
4781
5470
  chatDraftMessage = "";
4782
5471
  }
4783
- const setDraftMessage = useCallback12(
5472
+ const setDraftMessage = useCallback14(
4784
5473
  (message) => {
4785
5474
  hmsActions.setAppData(APP_DATA.chatDraft, message, true);
4786
5475
  },
@@ -4790,10 +5479,10 @@ var useChatDraftMessage = () => {
4790
5479
  };
4791
5480
 
4792
5481
  // src/Prebuilt/components/Chat/useEmojiPickerStyles.js
4793
- import { useEffect as useEffect19, useRef as useRef11 } from "react";
5482
+ import { useEffect as useEffect21, useRef as useRef13 } from "react";
4794
5483
  var useEmojiPickerStyles = (showing) => {
4795
- const ref = useRef11(null);
4796
- useEffect19(() => {
5484
+ const ref = useRef13(null);
5485
+ useEffect21(() => {
4797
5486
  if (showing) {
4798
5487
  setTimeout(() => {
4799
5488
  var _a, _b;
@@ -4841,9 +5530,9 @@ var TextArea = styled("textarea", {
4841
5530
  }
4842
5531
  });
4843
5532
  function EmojiPicker({ onSelect }) {
4844
- const [showEmoji, setShowEmoji] = useState30(false);
5533
+ const [showEmoji, setShowEmoji] = useState34(false);
4845
5534
  const ref = useEmojiPickerStyles(showEmoji);
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(
5535
+ return /* @__PURE__ */ React60.createElement(Popover.Root, { open: showEmoji, onOpenChange: setShowEmoji }, /* @__PURE__ */ React60.createElement(Popover.Trigger, { asChild: true, css: { appearance: "none" } }, /* @__PURE__ */ React60.createElement(IconButton, { as: "div" }, /* @__PURE__ */ React60.createElement(EmojiIcon3, null))), /* @__PURE__ */ React60.createElement(Popover.Portal, null, /* @__PURE__ */ React60.createElement(
4847
5536
  Popover.Content,
4848
5537
  {
4849
5538
  alignOffset: -40,
@@ -4853,7 +5542,7 @@ function EmojiPicker({ onSelect }) {
4853
5542
  p: 0
4854
5543
  }
4855
5544
  },
4856
- /* @__PURE__ */ React55.createElement(
5545
+ /* @__PURE__ */ React60.createElement(
4857
5546
  Box,
4858
5547
  {
4859
5548
  css: {
@@ -4862,7 +5551,7 @@ function EmojiPicker({ onSelect }) {
4862
5551
  },
4863
5552
  ref
4864
5553
  },
4865
- /* @__PURE__ */ React55.createElement(Picker, { onEmojiSelect: onSelect, data: data2, previewPosition: "none", skinPosition: "search" })
5554
+ /* @__PURE__ */ React60.createElement(Picker, { onEmojiSelect: onSelect, data: data2, previewPosition: "none", skinPosition: "search" })
4866
5555
  )
4867
5556
  )));
4868
5557
  }
@@ -4873,13 +5562,13 @@ var ChatFooter = ({
4873
5562
  children
4874
5563
  }) => {
4875
5564
  var _a;
4876
- const hmsActions = useHMSActions18();
4877
- const inputRef = useRef12(null);
5565
+ const hmsActions = useHMSActions21();
5566
+ const inputRef = useRef14(null);
4878
5567
  const [draftMessage, setDraftMessage] = useChatDraftMessage();
4879
- const isMobile = useMedia13(config.media.md);
5568
+ const isMobile = useMedia17(config.media.md);
4880
5569
  const { elements } = useRoomLayoutConferencingScreen();
4881
5570
  const isOverlayChat = (_a = elements == null ? void 0 : elements.chat) == null ? void 0 : _a.is_overlay;
4882
- const sendMessage = useCallback13(() => __async(void 0, null, function* () {
5571
+ const sendMessage = useCallback15(() => __async(void 0, null, function* () {
4883
5572
  var _a2;
4884
5573
  const message = (_a2 = inputRef == null ? void 0 : inputRef.current) == null ? void 0 : _a2.value;
4885
5574
  if (!message || !message.trim().length) {
@@ -4902,19 +5591,19 @@ var ChatFooter = ({
4902
5591
  ToastManager.addToast({ title: err.message });
4903
5592
  }
4904
5593
  }), [role, peerId, hmsActions, onSend]);
4905
- useEffect20(() => {
5594
+ useEffect22(() => {
4906
5595
  const messageElement = inputRef.current;
4907
5596
  if (messageElement) {
4908
5597
  messageElement.value = draftMessage;
4909
5598
  }
4910
5599
  }, [draftMessage]);
4911
- useEffect20(() => {
5600
+ useEffect22(() => {
4912
5601
  const messageElement = inputRef.current;
4913
5602
  return () => {
4914
5603
  setDraftMessage((messageElement == null ? void 0 : messageElement.value) || "");
4915
5604
  };
4916
5605
  }, [setDraftMessage]);
4917
- return /* @__PURE__ */ React55.createElement(React55.Fragment, null, /* @__PURE__ */ React55.createElement(Flex, { align: "center", css: { gap: "$4", w: "100%" } }, /* @__PURE__ */ React55.createElement(
5606
+ return /* @__PURE__ */ React60.createElement(React60.Fragment, null, /* @__PURE__ */ React60.createElement(Flex, { align: "center", css: { gap: "$4", w: "100%" } }, /* @__PURE__ */ React60.createElement(
4918
5607
  Flex,
4919
5608
  {
4920
5609
  align: "center",
@@ -4935,7 +5624,7 @@ var ChatFooter = ({
4935
5624
  }
4936
5625
  },
4937
5626
  children,
4938
- /* @__PURE__ */ React55.createElement(
5627
+ /* @__PURE__ */ React60.createElement(
4939
5628
  TextArea,
4940
5629
  {
4941
5630
  css: {
@@ -4963,7 +5652,7 @@ var ChatFooter = ({
4963
5652
  onCopy: (e) => e.stopPropagation()
4964
5653
  }
4965
5654
  ),
4966
- !isMobile ? /* @__PURE__ */ React55.createElement(
5655
+ !isMobile ? /* @__PURE__ */ React60.createElement(
4967
5656
  EmojiPicker,
4968
5657
  {
4969
5658
  onSelect: (emoji) => {
@@ -4973,7 +5662,7 @@ var ChatFooter = ({
4973
5662
  }
4974
5663
  }
4975
5664
  ) : null,
4976
- /* @__PURE__ */ React55.createElement(
5665
+ /* @__PURE__ */ React60.createElement(
4977
5666
  IconButton,
4978
5667
  {
4979
5668
  className: "send-msg",
@@ -4986,7 +5675,7 @@ var ChatFooter = ({
4986
5675
  },
4987
5676
  "data-testid": "send_msg_btn"
4988
5677
  },
4989
- /* @__PURE__ */ React55.createElement(SendIcon, null)
5678
+ /* @__PURE__ */ React60.createElement(SendIcon, null)
4990
5679
  )
4991
5680
  )));
4992
5681
  };
@@ -4994,10 +5683,10 @@ var ChatFooter = ({
4994
5683
  // src/Prebuilt/components/Chat/Chat.jsx
4995
5684
  var PINNED_MESSAGE_LENGTH = 80;
4996
5685
  var PinnedMessage = ({ clearPinnedMessage }) => {
4997
- const permissions = useHMSStore29(selectPermissions10);
4998
- const pinnedMessage = useHMSStore29(selectSessionStore(SESSION_STORE_KEY.PINNED_MESSAGE));
5686
+ const permissions = useHMSStore33(selectPermissions12);
5687
+ const pinnedMessage = useHMSStore33(selectSessionStore3(SESSION_STORE_KEY.PINNED_MESSAGE));
4999
5688
  const formattedPinnedMessage = (pinnedMessage == null ? void 0 : pinnedMessage.length) && pinnedMessage.length > PINNED_MESSAGE_LENGTH ? `${pinnedMessage.slice(0, PINNED_MESSAGE_LENGTH)}...` : pinnedMessage;
5000
- return pinnedMessage ? /* @__PURE__ */ React56.createElement(
5689
+ return pinnedMessage ? /* @__PURE__ */ React61.createElement(
5001
5690
  Flex,
5002
5691
  {
5003
5692
  title: pinnedMessage,
@@ -5005,8 +5694,8 @@ var PinnedMessage = ({ clearPinnedMessage }) => {
5005
5694
  align: "center",
5006
5695
  justify: "between"
5007
5696
  },
5008
- /* @__PURE__ */ React56.createElement(PinIcon2, null),
5009
- /* @__PURE__ */ React56.createElement(
5697
+ /* @__PURE__ */ React61.createElement(PinIcon3, null),
5698
+ /* @__PURE__ */ React61.createElement(
5010
5699
  Box,
5011
5700
  {
5012
5701
  css: {
@@ -5016,15 +5705,15 @@ var PinnedMessage = ({ clearPinnedMessage }) => {
5016
5705
  overflowY: "auto"
5017
5706
  }
5018
5707
  },
5019
- /* @__PURE__ */ React56.createElement(Text, { variant: "sm" }, /* @__PURE__ */ React56.createElement(AnnotisedMessage, { message: formattedPinnedMessage }))
5708
+ /* @__PURE__ */ React61.createElement(Text, { variant: "sm" }, /* @__PURE__ */ React61.createElement(AnnotisedMessage, { message: formattedPinnedMessage }))
5020
5709
  ),
5021
- permissions.removeOthers && /* @__PURE__ */ React56.createElement(
5710
+ permissions.removeOthers && /* @__PURE__ */ React61.createElement(
5022
5711
  Flex,
5023
5712
  {
5024
5713
  onClick: () => clearPinnedMessage(),
5025
5714
  css: { cursor: "pointer", color: "$on_surface_medium", "&:hover": { color: "$on_surface_high" } }
5026
5715
  },
5027
- /* @__PURE__ */ React56.createElement(CrossIcon6, null)
5716
+ /* @__PURE__ */ React61.createElement(CrossIcon8, null)
5028
5717
  )
5029
5718
  ) : null;
5030
5719
  };
@@ -5033,17 +5722,17 @@ var Chat = ({ screenType }) => {
5033
5722
  const notification = useHMSNotifications(HMSNotificationTypes.PEER_LEFT);
5034
5723
  const [peerSelector, setPeerSelector] = useSetSubscribedChatSelector(CHAT_SELECTOR.PEER_ID);
5035
5724
  const [roleSelector, setRoleSelector] = useSetSubscribedChatSelector(CHAT_SELECTOR.ROLE);
5036
- const peerName = useHMSStore29(selectPeerNameByID3(peerSelector));
5037
- const [chatOptions, setChatOptions] = useState31({
5725
+ const peerName = useHMSStore33(selectPeerNameByID4(peerSelector));
5726
+ const [chatOptions, setChatOptions] = useState35({
5038
5727
  role: roleSelector || "",
5039
5728
  peerId: peerSelector && peerName ? peerSelector : "",
5040
5729
  selection: roleSelector ? roleSelector : peerSelector && peerName ? peerName : "Everyone"
5041
5730
  });
5042
- const [isSelectorOpen] = useState31(false);
5043
- const listRef = useRef13(null);
5044
- const hmsActions = useHMSActions19();
5731
+ const [isSelectorOpen] = useState35(false);
5732
+ const listRef = useRef15(null);
5733
+ const hmsActions = useHMSActions22();
5045
5734
  const { setPinnedMessage } = useSetPinnedMessage();
5046
- useEffect21(() => {
5735
+ useEffect23(() => {
5047
5736
  if (notification && notification.data && peerSelector === notification.data.id) {
5048
5737
  setPeerSelector("");
5049
5738
  setChatOptions({
@@ -5055,14 +5744,14 @@ var Chat = ({ screenType }) => {
5055
5744
  }, [notification, peerSelector, setPeerSelector]);
5056
5745
  const storeMessageSelector = selectHMSMessagesCount;
5057
5746
  const { elements } = useRoomLayoutConferencingScreen();
5058
- const isMobile = useMedia14(config.media.md);
5747
+ const isMobile = useMedia18(config.media.md);
5059
5748
  let isScrolledToBottom = false;
5060
5749
  if (listRef.current) {
5061
5750
  const currentRef = listRef.current._outerRef;
5062
5751
  isScrolledToBottom = currentRef.scrollHeight - currentRef.clientHeight - currentRef.scrollTop < 10;
5063
5752
  }
5064
- const messagesCount = useHMSStore29(storeMessageSelector) || 0;
5065
- const scrollToBottom = useCallback14(
5753
+ const messagesCount = useHMSStore33(storeMessageSelector) || 0;
5754
+ const scrollToBottom = useCallback16(
5066
5755
  (unreadCount = 0) => {
5067
5756
  var _a2;
5068
5757
  if (listRef.current && listRef.current.scrollToItem && unreadCount > 0) {
@@ -5076,7 +5765,7 @@ var Chat = ({ screenType }) => {
5076
5765
  },
5077
5766
  [hmsActions, messagesCount]
5078
5767
  );
5079
- return /* @__PURE__ */ React56.createElement(
5768
+ return /* @__PURE__ */ React61.createElement(
5080
5769
  Flex,
5081
5770
  {
5082
5771
  direction: "column",
@@ -5085,8 +5774,8 @@ var Chat = ({ screenType }) => {
5085
5774
  gap: "$4"
5086
5775
  }
5087
5776
  },
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(
5777
+ isMobile && ((_a = elements == null ? void 0 : elements.chat) == null ? void 0 : _a.is_overlay) ? null : /* @__PURE__ */ React61.createElement(React61.Fragment, null, ((_b = elements == null ? void 0 : elements.chat) == null ? void 0 : _b.allow_pinning_messages) ? /* @__PURE__ */ React61.createElement(PinnedMessage, { clearPinnedMessage: setPinnedMessage }) : null),
5778
+ /* @__PURE__ */ React61.createElement(
5090
5779
  ChatBody,
5091
5780
  {
5092
5781
  role: chatOptions.role,
@@ -5096,7 +5785,7 @@ var Chat = ({ screenType }) => {
5096
5785
  screenType
5097
5786
  }
5098
5787
  ),
5099
- /* @__PURE__ */ React56.createElement(
5788
+ /* @__PURE__ */ React61.createElement(
5100
5789
  ChatFooter,
5101
5790
  {
5102
5791
  role: chatOptions.role,
@@ -5114,7 +5803,7 @@ var Chat = ({ screenType }) => {
5114
5803
  },
5115
5804
  peerId: chatOptions.peerId
5116
5805
  },
5117
- !isSelectorOpen && !isScrolledToBottom && /* @__PURE__ */ React56.createElement(NewMessageIndicator, { role: chatOptions.role, peerId: chatOptions.peerId, scrollToBottom })
5806
+ !isSelectorOpen && !isScrolledToBottom && /* @__PURE__ */ React61.createElement(NewMessageIndicator, { role: chatOptions.role, peerId: chatOptions.peerId, scrollToBottom })
5118
5807
  )
5119
5808
  );
5120
5809
  };
@@ -5123,7 +5812,7 @@ var NewMessageIndicator = ({ role, peerId, scrollToBottom }) => {
5123
5812
  if (!unreadCount) {
5124
5813
  return null;
5125
5814
  }
5126
- return /* @__PURE__ */ React56.createElement(
5815
+ return /* @__PURE__ */ React61.createElement(
5127
5816
  Flex,
5128
5817
  {
5129
5818
  justify: "center",
@@ -5134,7 +5823,7 @@ var NewMessageIndicator = ({ role, peerId, scrollToBottom }) => {
5134
5823
  position: "absolute"
5135
5824
  }
5136
5825
  },
5137
- /* @__PURE__ */ React56.createElement(
5826
+ /* @__PURE__ */ React61.createElement(
5138
5827
  Button,
5139
5828
  {
5140
5829
  variant: "standard",
@@ -5157,7 +5846,7 @@ var NewMessageIndicator = ({ role, peerId, scrollToBottom }) => {
5157
5846
  },
5158
5847
  "New ",
5159
5848
  unreadCount === 1 ? "message" : "messages",
5160
- /* @__PURE__ */ React56.createElement(ChevronDownIcon2, null)
5849
+ /* @__PURE__ */ React61.createElement(ChevronDownIcon2, null)
5161
5850
  )
5162
5851
  );
5163
5852
  };
@@ -5172,23 +5861,23 @@ var tabTriggerCSS = {
5172
5861
  justifyContent: "center"
5173
5862
  };
5174
5863
  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), ")"));
5864
+ return count < 1e3 ? /* @__PURE__ */ React62.createElement("span", null, "(", count, ")") : /* @__PURE__ */ React62.createElement(Tooltip, { title: count }, /* @__PURE__ */ React62.createElement("span", null, "(", getFormattedCount(count), ")"));
5176
5865
  };
5177
- var SidePaneTabs = React57.memo(({ active = SIDE_PANE_OPTIONS.CHAT, screenType, hideControls }) => {
5866
+ var SidePaneTabs = React62.memo(({ active = SIDE_PANE_OPTIONS.CHAT, screenType, hideControls }) => {
5178
5867
  var _a;
5179
5868
  const toggleChat = useSidepaneToggle(SIDE_PANE_OPTIONS.CHAT);
5180
5869
  const toggleParticipants = useSidepaneToggle(SIDE_PANE_OPTIONS.PARTICIPANTS);
5181
5870
  const resetSidePane = useSidepaneReset();
5182
- const [activeTab, setActiveTab] = useState32(active);
5183
- const peerCount = useHMSStore30(selectPeerCount3);
5871
+ const [activeTab, setActiveTab] = useState36(active);
5872
+ const peerCount = useHMSStore34(selectPeerCount3);
5184
5873
  const { elements } = useRoomLayoutConferencingScreen();
5185
5874
  const showChat = !!(elements == null ? void 0 : elements.chat);
5186
5875
  const showParticipants = !!(elements == null ? void 0 : elements.participant_list);
5187
5876
  const hideTabs = !(showChat && showParticipants);
5188
- const isMobile = useMedia15(config.media.md);
5877
+ const isMobile = useMedia19(config.media.md);
5189
5878
  const isOverlayChat = !!((_a = elements == null ? void 0 : elements.chat) == null ? void 0 : _a.is_overlay) && isMobile;
5190
5879
  const isChatOpen = useIsSidepaneTypeOpen(SIDE_PANE_OPTIONS.CHAT);
5191
- useEffect22(() => {
5880
+ useEffect24(() => {
5192
5881
  if (activeTab === SIDE_PANE_OPTIONS.CHAT && !showChat && showParticipants) {
5193
5882
  setActiveTab(SIDE_PANE_OPTIONS.PARTICIPANTS);
5194
5883
  } else if (activeTab === SIDE_PANE_OPTIONS.PARTICIPANTS && showChat && !showParticipants) {
@@ -5197,10 +5886,10 @@ var SidePaneTabs = React57.memo(({ active = SIDE_PANE_OPTIONS.CHAT, screenType,
5197
5886
  resetSidePane();
5198
5887
  }
5199
5888
  }, [showChat, activeTab, showParticipants, resetSidePane]);
5200
- useEffect22(() => {
5889
+ useEffect24(() => {
5201
5890
  setActiveTab(active);
5202
5891
  }, [active]);
5203
- return /* @__PURE__ */ React57.createElement(
5892
+ return /* @__PURE__ */ React62.createElement(
5204
5893
  Flex,
5205
5894
  {
5206
5895
  direction: "column",
@@ -5211,7 +5900,7 @@ var SidePaneTabs = React57.memo(({ active = SIDE_PANE_OPTIONS.CHAT, screenType,
5211
5900
  transition: "margin 0.3s ease-in-out"
5212
5901
  }
5213
5902
  },
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(
5903
+ isOverlayChat && isChatOpen && showChat ? /* @__PURE__ */ React62.createElement(Chat, { screenType }) : /* @__PURE__ */ React62.createElement(React62.Fragment, null, hideTabs ? /* @__PURE__ */ React62.createElement(React62.Fragment, null, /* @__PURE__ */ React62.createElement(Text, { variant: "sm", css: { fontWeight: "$semiBold", p: "$4", c: "$on_surface_high", pr: "$12" } }, showChat ? "Chat" : /* @__PURE__ */ React62.createElement("span", null, "Participants ", /* @__PURE__ */ React62.createElement(ParticipantCount2, { count: peerCount }))), showChat ? /* @__PURE__ */ React62.createElement(Chat, { screenType }) : /* @__PURE__ */ React62.createElement(ParticipantList, null)) : /* @__PURE__ */ React62.createElement(
5215
5904
  Tabs.Root,
5216
5905
  {
5217
5906
  value: activeTab,
@@ -5221,7 +5910,7 @@ var SidePaneTabs = React57.memo(({ active = SIDE_PANE_OPTIONS.CHAT, screenType,
5221
5910
  size: "100%"
5222
5911
  }
5223
5912
  },
5224
- /* @__PURE__ */ React57.createElement(Tabs.List, { css: { w: "calc(100% - $12)", p: "$2", borderRadius: "$2", bg: "$surface_default" } }, /* @__PURE__ */ React57.createElement(
5913
+ /* @__PURE__ */ React62.createElement(Tabs.List, { css: { w: "calc(100% - $12)", p: "$2", borderRadius: "$2", bg: "$surface_default" } }, /* @__PURE__ */ React62.createElement(
5225
5914
  Tabs.Trigger,
5226
5915
  {
5227
5916
  value: SIDE_PANE_OPTIONS.CHAT,
@@ -5231,7 +5920,7 @@ var SidePaneTabs = React57.memo(({ active = SIDE_PANE_OPTIONS.CHAT, screenType,
5231
5920
  })
5232
5921
  },
5233
5922
  "Chat"
5234
- ), /* @__PURE__ */ React57.createElement(
5923
+ ), /* @__PURE__ */ React62.createElement(
5235
5924
  Tabs.Trigger,
5236
5925
  {
5237
5926
  value: SIDE_PANE_OPTIONS.PARTICIPANTS,
@@ -5241,12 +5930,12 @@ var SidePaneTabs = React57.memo(({ active = SIDE_PANE_OPTIONS.CHAT, screenType,
5241
5930
  })
5242
5931
  },
5243
5932
  "Participants ",
5244
- /* @__PURE__ */ React57.createElement(ParticipantCount2, { count: peerCount })
5933
+ /* @__PURE__ */ React62.createElement(ParticipantCount2, { count: peerCount })
5245
5934
  )),
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 }))
5935
+ /* @__PURE__ */ React62.createElement(Tabs.Content, { value: SIDE_PANE_OPTIONS.PARTICIPANTS, css: { p: 0 } }, /* @__PURE__ */ React62.createElement(ParticipantList, null)),
5936
+ /* @__PURE__ */ React62.createElement(Tabs.Content, { value: SIDE_PANE_OPTIONS.CHAT, css: { p: 0 } }, /* @__PURE__ */ React62.createElement(Chat, { screenType }))
5248
5937
  )),
5249
- isOverlayChat && isChatOpen ? null : /* @__PURE__ */ React57.createElement(
5938
+ isOverlayChat && isChatOpen ? null : /* @__PURE__ */ React62.createElement(
5250
5939
  IconButton,
5251
5940
  {
5252
5941
  css: { position: "absolute", right: "$10", top: "$11", "@md": { top: "$8", right: "$8" } },
@@ -5260,22 +5949,22 @@ var SidePaneTabs = React57.memo(({ active = SIDE_PANE_OPTIONS.CHAT, screenType,
5260
5949
  },
5261
5950
  "data-testid": "close_chat"
5262
5951
  },
5263
- /* @__PURE__ */ React57.createElement(CrossIcon7, null)
5952
+ /* @__PURE__ */ React62.createElement(CrossIcon9, null)
5264
5953
  )
5265
5954
  );
5266
5955
  });
5267
5956
 
5268
5957
  // src/Prebuilt/components/Streaming/StreamingLanding.jsx
5269
- import React59, { Fragment as Fragment10, useState as useState34 } from "react";
5270
- import { selectPermissions as selectPermissions11, useHMSStore as useHMSStore32, useRecordingStreaming as useRecordingStreaming7 } from "@100mslive/react-sdk";
5271
- import { ColoredHandIcon, CrossIcon as CrossIcon8, GoLiveIcon as GoLiveIcon3 } from "@100mslive/react-icons";
5958
+ import React64, { Fragment as Fragment12, useState as useState38 } from "react";
5959
+ import { selectPermissions as selectPermissions13, useHMSStore as useHMSStore36, useRecordingStreaming as useRecordingStreaming7 } from "@100mslive/react-sdk";
5960
+ import { ColoredHandIcon, CrossIcon as CrossIcon10, GoLiveIcon as GoLiveIcon3 } from "@100mslive/react-icons";
5272
5961
 
5273
5962
  // src/Prebuilt/images/rtmp.png
5274
5963
  var rtmp_default = "";
5275
5964
 
5276
5965
  // src/Prebuilt/components/Streaming/HLSStreaming.jsx
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";
5966
+ import React63, { Fragment as Fragment11, useCallback as useCallback17, useEffect as useEffect25, useState as useState37 } from "react";
5967
+ import { selectRoomID, useHMSActions as useHMSActions23, useHMSStore as useHMSStore35, useRecordingStreaming as useRecordingStreaming6 } from "@100mslive/react-sdk";
5279
5968
  import {
5280
5969
  EndStreamIcon as EndStreamIcon2,
5281
5970
  EyeOpenIcon,
@@ -5294,7 +5983,7 @@ var getCardData = (roleName, roomId) => {
5294
5983
  data3 = {
5295
5984
  title: formattedRoleName,
5296
5985
  content: "Broadcasters can livestream audio or video, manage stream appearance and control the room via HLS.",
5297
- icon: /* @__PURE__ */ React58.createElement(SupportIcon, null)
5986
+ icon: /* @__PURE__ */ React63.createElement(SupportIcon, null)
5298
5987
  };
5299
5988
  break;
5300
5989
  }
@@ -5302,7 +5991,7 @@ var getCardData = (roleName, roomId) => {
5302
5991
  data3 = {
5303
5992
  title: "HLS Viewer",
5304
5993
  content: "Viewers can view and send chat messages, but need to be made broadcasters to participate with audio or video.",
5305
- icon: /* @__PURE__ */ React58.createElement(EyeOpenIcon, null)
5994
+ icon: /* @__PURE__ */ React63.createElement(EyeOpenIcon, null)
5306
5995
  };
5307
5996
  break;
5308
5997
  }
@@ -5310,7 +5999,7 @@ var getCardData = (roleName, roomId) => {
5310
5999
  data3 = {
5311
6000
  title: formattedRoleName,
5312
6001
  content: `${formattedRoleName} is customised with specific permissions, which will determine how it interacts with this room.`,
5313
- icon: /* @__PURE__ */ React58.createElement(WrenchIcon, null),
6002
+ icon: /* @__PURE__ */ React63.createElement(WrenchIcon, null),
5314
6003
  order: 1
5315
6004
  };
5316
6005
  }
@@ -5318,8 +6007,8 @@ var getCardData = (roleName, roomId) => {
5318
6007
  return data3;
5319
6008
  };
5320
6009
  var Card = ({ title, icon, link, content, isHLSRunning, order = 0 }) => {
5321
- const [copied, setCopied] = useState33(false);
5322
- return isHLSRunning ? /* @__PURE__ */ React58.createElement(
6010
+ const [copied, setCopied] = useState37(false);
6011
+ return isHLSRunning ? /* @__PURE__ */ React63.createElement(
5323
6012
  Box,
5324
6013
  {
5325
6014
  key: title,
@@ -5330,9 +6019,9 @@ var Card = ({ title, icon, link, content, isHLSRunning, order = 0 }) => {
5330
6019
  borderRadius: "$2"
5331
6020
  }
5332
6021
  },
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(
6022
+ /* @__PURE__ */ React63.createElement(Flex, { align: "center", gap: "2", css: { color: "$primary_bright" } }, icon, /* @__PURE__ */ React63.createElement(Text, { variant: "h6", css: { fontWeight: "$semiBold" } }, title)),
6023
+ /* @__PURE__ */ React63.createElement(Text, { variant: "sm", css: { color: "$on_surface_medium", mt: "$6" } }, content),
6024
+ /* @__PURE__ */ React63.createElement(
5336
6025
  Button,
5337
6026
  {
5338
6027
  variant: "standard",
@@ -5344,24 +6033,24 @@ var Card = ({ title, icon, link, content, isHLSRunning, order = 0 }) => {
5344
6033
  css: { w: "100%", r: "$1", mt: "$10", fontWeight: "$semiBold" },
5345
6034
  icon: true
5346
6035
  },
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")
6036
+ copied ? /* @__PURE__ */ React63.createElement(React63.Fragment, null, "Link copied!") : /* @__PURE__ */ React63.createElement(React63.Fragment, null, /* @__PURE__ */ React63.createElement(LinkIcon, { style: { color: "inherit" } }), "Copy Invite Link")
5348
6037
  )
5349
6038
  ) : null;
5350
6039
  };
5351
6040
  var HLSStreaming = ({ onBack }) => {
5352
6041
  const roleNames = useFilteredRoles();
5353
- const roomId = useHMSStore31(selectRoomID);
6042
+ const roomId = useHMSStore35(selectRoomID);
5354
6043
  const cards = roleNames.map((roleName) => getCardData(roleName, roomId));
5355
6044
  const { isHLSRunning } = useRecordingStreaming6();
5356
- const [showLinks, setShowLinks] = useState33(false);
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 })))));
6045
+ const [showLinks, setShowLinks] = useState37(false);
6046
+ return !showLinks ? /* @__PURE__ */ React63.createElement(Container, { rounded: true }, /* @__PURE__ */ React63.createElement(ContentHeader, { title: "Start Streaming", content: "HLS", onBack }), /* @__PURE__ */ React63.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__ */ React63.createElement(EndHLS, { setShowLinks }) : /* @__PURE__ */ React63.createElement(StartHLS, null)) : /* @__PURE__ */ React63.createElement(Container, { rounded: true }, /* @__PURE__ */ React63.createElement(ContentHeader, { title: "Invite People", content: "Start the conversation", onBack: () => setShowLinks(false) }), /* @__PURE__ */ React63.createElement(Flex, { direction: "column", css: { gap: "$10", p: "$0 $10", overflowY: "auto", mb: "$10" } }, cards.map((card) => /* @__PURE__ */ React63.createElement(Card, __spreadProps(__spreadValues({ key: card.title }, card), { isHLSRunning })))));
5358
6047
  };
5359
6048
  var StartHLS = () => {
5360
- const [record, setRecord] = useState33(false);
5361
- const [error, setError] = useState33(false);
5362
- const hmsActions = useHMSActions20();
6049
+ const [record, setRecord] = useState37(false);
6050
+ const [error, setError] = useState37(false);
6051
+ const hmsActions = useHMSActions23();
5363
6052
  const [isHLSStarted, setHLSStarted] = useSetAppDataByKey(APP_DATA.hlsStarted);
5364
- const startHLS = useCallback15(
6053
+ const startHLS = useCallback17(
5365
6054
  (variants) => __async(void 0, null, function* () {
5366
6055
  try {
5367
6056
  if (isHLSStarted) {
@@ -5380,7 +6069,7 @@ var StartHLS = () => {
5380
6069
  }),
5381
6070
  [hmsActions, record, isHLSStarted, setHLSStarted]
5382
6071
  );
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(
6072
+ return /* @__PURE__ */ React63.createElement(Fragment11, null, /* @__PURE__ */ React63.createElement(RecordStream, { record, setRecord, testId: "hls-recording" }), /* @__PURE__ */ React63.createElement(Box, { css: { p: "$4 $10" } }, /* @__PURE__ */ React63.createElement(ErrorText, { error }), /* @__PURE__ */ React63.createElement(
5384
6073
  Button,
5385
6074
  {
5386
6075
  "data-testid": "start_hls",
@@ -5389,21 +6078,21 @@ var StartHLS = () => {
5389
6078
  onClick: () => startHLS(),
5390
6079
  disabled: isHLSStarted
5391
6080
  },
5392
- isHLSStarted ? /* @__PURE__ */ React58.createElement(Loading, { size: 24, color: "currentColor" }) : /* @__PURE__ */ React58.createElement(GoLiveIcon2, null),
6081
+ isHLSStarted ? /* @__PURE__ */ React63.createElement(Loading, { size: 24, color: "currentColor" }) : /* @__PURE__ */ React63.createElement(GoLiveIcon2, null),
5393
6082
  isHLSStarted ? "Starting stream..." : "Go Live"
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.")));
6083
+ )), /* @__PURE__ */ React63.createElement(Flex, { align: "center", css: { p: "$4 $10" } }, /* @__PURE__ */ React63.createElement(Text, null, /* @__PURE__ */ React63.createElement(InfoIcon4, { width: 16, height: 16 })), /* @__PURE__ */ React63.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.")));
5395
6084
  };
5396
6085
  var EndHLS = ({ setShowLinks }) => {
5397
- const hmsActions = useHMSActions20();
5398
- const [inProgress, setInProgress] = useState33(false);
5399
- const [error, setError] = useState33("");
6086
+ const hmsActions = useHMSActions23();
6087
+ const [inProgress, setInProgress] = useState37(false);
6088
+ const [error, setError] = useState37("");
5400
6089
  const { isHLSRunning } = useRecordingStreaming6();
5401
- useEffect23(() => {
6090
+ useEffect25(() => {
5402
6091
  if (inProgress && !isHLSRunning) {
5403
6092
  setInProgress(false);
5404
6093
  }
5405
6094
  }, [inProgress, isHLSRunning]);
5406
- return /* @__PURE__ */ React58.createElement(Box, { css: { p: "$4 $10" } }, /* @__PURE__ */ React58.createElement(ErrorText, { error }), /* @__PURE__ */ React58.createElement(
6095
+ return /* @__PURE__ */ React63.createElement(Box, { css: { p: "$4 $10" } }, /* @__PURE__ */ React63.createElement(ErrorText, { error }), /* @__PURE__ */ React63.createElement(
5407
6096
  Button,
5408
6097
  {
5409
6098
  "data-testid": "stop_hls",
@@ -5422,23 +6111,23 @@ var EndHLS = ({ setShowLinks }) => {
5422
6111
  }
5423
6112
  })
5424
6113
  },
5425
- /* @__PURE__ */ React58.createElement(EndStreamIcon2, null),
6114
+ /* @__PURE__ */ React63.createElement(EndStreamIcon2, null),
5426
6115
  "End Stream"
5427
- ), /* @__PURE__ */ React58.createElement(Button, { icon: true, css: { w: "100%", r: "$0", mt: "$8" }, onClick: () => setShowLinks(true) }, /* @__PURE__ */ React58.createElement(PeopleIcon3, null), " Invite People"));
6116
+ ), /* @__PURE__ */ React63.createElement(Button, { icon: true, css: { w: "100%", r: "$0", mt: "$8" }, onClick: () => setShowLinks(true) }, /* @__PURE__ */ React63.createElement(PeopleIcon3, null), " Invite People"));
5428
6117
  };
5429
6118
 
5430
6119
  // src/Prebuilt/components/Streaming/StreamingLanding.jsx
5431
6120
  var StreamingLanding = () => {
5432
6121
  const toggleStreaming = useSidepaneToggle(SIDE_PANE_OPTIONS.STREAMING);
5433
6122
  const { isHLSRunning, isRTMPRunning } = useRecordingStreaming7();
5434
- const permissions = useHMSStore32(selectPermissions11);
5435
- const [showHLS, setShowHLS] = useState34(isHLSRunning);
5436
- const [showRTMP, setShowRTMP] = useState34(isRTMPRunning);
6123
+ const permissions = useHMSStore36(selectPermissions13);
6124
+ const [showHLS, setShowHLS] = useState38(isHLSRunning);
6125
+ const [showRTMP, setShowRTMP] = useState38(isRTMPRunning);
5437
6126
  if (!(permissions == null ? void 0 : permissions.hlsStreaming) && !(permissions == null ? void 0 : permissions.rtmpStreaming)) {
5438
6127
  toggleStreaming();
5439
6128
  return null;
5440
6129
  }
5441
- return /* @__PURE__ */ React59.createElement(Fragment10, null, /* @__PURE__ */ React59.createElement(Flex, { css: { w: "100%", py: "$8" } }, /* @__PURE__ */ React59.createElement(
6130
+ return /* @__PURE__ */ React64.createElement(Fragment12, null, /* @__PURE__ */ React64.createElement(Flex, { css: { w: "100%", py: "$8" } }, /* @__PURE__ */ React64.createElement(
5442
6131
  Box,
5443
6132
  {
5444
6133
  css: {
@@ -5448,8 +6137,8 @@ var StreamingLanding = () => {
5448
6137
  r: "$round"
5449
6138
  }
5450
6139
  },
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(
6140
+ /* @__PURE__ */ React64.createElement(ColoredHandIcon, { width: 40, height: 40 })
6141
+ ), /* @__PURE__ */ React64.createElement(Box, { css: { flex: "1 1 0", mx: "$8" } }, /* @__PURE__ */ React64.createElement(Text, { variant: "sm" }, "Welcome !"), /* @__PURE__ */ React64.createElement(Text, { variant: "h6" }, "Let\u2019s get you started")), /* @__PURE__ */ React64.createElement(IconButton_default, { onClick: toggleStreaming, css: { alignSelf: "flex-start" }, "data-testid": "close_streaming" }, /* @__PURE__ */ React64.createElement(CrossIcon10, null))), /* @__PURE__ */ React64.createElement(Text, { variant: "tiny", color: "$on_surface_medium" }, "Start Streaming"), (permissions == null ? void 0 : permissions.hlsStreaming) && /* @__PURE__ */ React64.createElement(
5453
6142
  StreamCard,
5454
6143
  {
5455
6144
  testId: "hls_stream",
@@ -5459,7 +6148,7 @@ var StreamingLanding = () => {
5459
6148
  onClick: () => setShowHLS(true),
5460
6149
  Icon: GoLiveIcon3
5461
6150
  }
5462
- ), (permissions == null ? void 0 : permissions.rtmpStreaming) && /* @__PURE__ */ React59.createElement(
6151
+ ), (permissions == null ? void 0 : permissions.rtmpStreaming) && /* @__PURE__ */ React64.createElement(
5463
6152
  StreamCard,
5464
6153
  {
5465
6154
  testId: "rtmp_stream",
@@ -5471,7 +6160,7 @@ var StreamingLanding = () => {
5471
6160
  },
5472
6161
  imgSrc: rtmp_default
5473
6162
  }
5474
- ), showHLS && /* @__PURE__ */ React59.createElement(HLSStreaming, { onBack: () => setShowHLS(false) }), showRTMP && /* @__PURE__ */ React59.createElement(RTMPStreaming, { onBack: () => setShowRTMP(false) }));
6163
+ ), showHLS && /* @__PURE__ */ React64.createElement(HLSStreaming, { onBack: () => setShowHLS(false) }), showRTMP && /* @__PURE__ */ React64.createElement(RTMPStreaming, { onBack: () => setShowRTMP(false) }));
5475
6164
  };
5476
6165
 
5477
6166
  // src/Prebuilt/layouts/SidePane.tsx
@@ -5481,16 +6170,16 @@ var SidePane = ({
5481
6170
  hideControls = false
5482
6171
  }) => {
5483
6172
  var _a, _b;
5484
- const isMobile = useMedia16(config.media.md);
5485
- const sidepane = useHMSStore33(selectAppData3(APP_DATA.sidePane));
5486
- const activeScreensharePeerId = useHMSStore33(selectAppData3(APP_DATA.activeScreensharePeerId));
5487
- const trackId = (_a = useHMSStore33(selectVideoTrackByPeerID(activeScreensharePeerId))) == null ? void 0 : _a.id;
6173
+ const isMobile = useMedia20(config.media.md);
6174
+ const sidepane = useHMSStore37(selectAppData3(APP_DATA.sidePane));
6175
+ const activeScreensharePeerId = useHMSStore37(selectAppData3(APP_DATA.activeScreensharePeerId));
6176
+ const trackId = (_a = useHMSStore37(selectVideoTrackByPeerID3(activeScreensharePeerId))) == null ? void 0 : _a.id;
5488
6177
  const { elements } = useRoomLayoutConferencingScreen();
5489
6178
  let ViewComponent;
5490
6179
  if (sidepane === SIDE_PANE_OPTIONS.PARTICIPANTS || sidepane === SIDE_PANE_OPTIONS.CHAT) {
5491
- ViewComponent = /* @__PURE__ */ React60.createElement(SidePaneTabs, { screenType, hideControls, active: sidepane });
6180
+ ViewComponent = /* @__PURE__ */ React65.createElement(SidePaneTabs, { screenType, hideControls, active: sidepane });
5492
6181
  } else if (sidepane === SIDE_PANE_OPTIONS.STREAMING) {
5493
- ViewComponent = /* @__PURE__ */ React60.createElement(StreamingLanding, null);
6182
+ ViewComponent = /* @__PURE__ */ React65.createElement(StreamingLanding, null);
5494
6183
  }
5495
6184
  if (!ViewComponent && !trackId) {
5496
6185
  return null;
@@ -5503,7 +6192,7 @@ var SidePane = ({
5503
6192
  objectFit: tileProps == null ? void 0 : tileProps.video_object_fit
5504
6193
  };
5505
6194
  const mwebStreamingChat = isMobile && sidepane === SIDE_PANE_OPTIONS.CHAT && ((_b = elements == null ? void 0 : elements.chat) == null ? void 0 : _b.is_overlay);
5506
- return /* @__PURE__ */ React60.createElement(
6195
+ return /* @__PURE__ */ React65.createElement(
5507
6196
  Flex,
5508
6197
  {
5509
6198
  direction: "column",
@@ -5516,7 +6205,7 @@ var SidePane = ({
5516
6205
  "@md": { position: mwebStreamingChat ? "absolute" : "", zIndex: 12 }
5517
6206
  }
5518
6207
  },
5519
- trackId && /* @__PURE__ */ React60.createElement(
6208
+ trackId && /* @__PURE__ */ React65.createElement(
5520
6209
  VideoTile_default,
5521
6210
  __spreadValues({
5522
6211
  peerId: activeScreensharePeerId,
@@ -5525,7 +6214,7 @@ var SidePane = ({
5525
6214
  rootCSS: { p: 0, alignSelf: "start", flexShrink: 0 }
5526
6215
  }, tileLayout)
5527
6216
  ),
5528
- !!ViewComponent && /* @__PURE__ */ React60.createElement(
6217
+ !!ViewComponent && /* @__PURE__ */ React65.createElement(
5529
6218
  Box,
5530
6219
  {
5531
6220
  css: {
@@ -5561,10 +6250,10 @@ var SidePane = ({
5561
6250
  var SidePane_default = SidePane;
5562
6251
 
5563
6252
  // src/Prebuilt/layouts/WaitingView.jsx
5564
- import React61 from "react";
6253
+ import React66 from "react";
5565
6254
  import { ColoredTimeIcon } from "@100mslive/react-icons";
5566
- var WaitingView = React61.memo(() => {
5567
- return /* @__PURE__ */ React61.createElement(
6255
+ var WaitingView = React66.memo(() => {
6256
+ return /* @__PURE__ */ React66.createElement(
5568
6257
  Box,
5569
6258
  {
5570
6259
  css: {
@@ -5578,7 +6267,7 @@ var WaitingView = React61.memo(() => {
5578
6267
  },
5579
6268
  "data-testid": "waiting_view"
5580
6269
  },
5581
- /* @__PURE__ */ React61.createElement(
6270
+ /* @__PURE__ */ React66.createElement(
5582
6271
  Flex,
5583
6272
  {
5584
6273
  align: "center",
@@ -5592,8 +6281,8 @@ var WaitingView = React61.memo(() => {
5592
6281
  gap: "$8"
5593
6282
  }
5594
6283
  },
5595
- /* @__PURE__ */ React61.createElement(ColoredTimeIcon, { width: "80px", height: "80px" }),
5596
- /* @__PURE__ */ React61.createElement(
6284
+ /* @__PURE__ */ React66.createElement(ColoredTimeIcon, { width: "80px", height: "80px" }),
6285
+ /* @__PURE__ */ React66.createElement(
5597
6286
  Flex,
5598
6287
  {
5599
6288
  direction: "column",
@@ -5603,28 +6292,28 @@ var WaitingView = React61.memo(() => {
5603
6292
  gap: "$4"
5604
6293
  }
5605
6294
  },
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.")
6295
+ /* @__PURE__ */ React66.createElement(Text, { color: "white", variant: "h6", css: { "@md": { fontSize: "$md" } } }, "Please wait"),
6296
+ /* @__PURE__ */ React66.createElement(Text, { color: "$on_surface_medium", css: { mt: "$4", "@md": { fontSize: "$sm" } } }, "Sit back and relax till others let you join.")
5608
6297
  )
5609
6298
  )
5610
6299
  );
5611
6300
  });
5612
6301
 
5613
6302
  // src/Prebuilt/layouts/VideoStreamingSection.tsx
5614
- var HLSView = React62.lazy(() => import("./HLSView-3S74KF3A.js"));
6303
+ var HLSView = React67.lazy(() => import("./HLSView-IQRPLYNH.js"));
5615
6304
  var VideoStreamingSection = ({
5616
6305
  screenType,
5617
6306
  elements,
5618
6307
  hideControls = false
5619
6308
  }) => {
5620
6309
  var _a, _b;
5621
- const localPeerRole = useHMSStore34(selectLocalPeerRoleName3);
5622
- const isConnected = useHMSStore34(selectIsConnectedToRoom6);
5623
- const hmsActions = useHMSActions21();
6310
+ const localPeerRole = useHMSStore38(selectLocalPeerRoleName3);
6311
+ const isConnected = useHMSStore38(selectIsConnectedToRoom6);
6312
+ const hmsActions = useHMSActions24();
5624
6313
  const waitingViewerRole = useWaitingViewerRole();
5625
6314
  const urlToIframe = useUrlToEmbed();
5626
6315
  const pdfAnnotatorActive = usePDFAnnotator();
5627
- useEffect24(() => {
6316
+ useEffect26(() => {
5628
6317
  if (!isConnected) {
5629
6318
  return;
5630
6319
  }
@@ -5635,17 +6324,17 @@ var VideoStreamingSection = ({
5635
6324
  }
5636
6325
  let ViewComponent;
5637
6326
  if (screenType === "hls_live_streaming") {
5638
- ViewComponent = /* @__PURE__ */ React62.createElement(HLSView, null);
6327
+ ViewComponent = /* @__PURE__ */ React67.createElement(HLSView, null);
5639
6328
  } else if (localPeerRole === waitingViewerRole) {
5640
- ViewComponent = /* @__PURE__ */ React62.createElement(WaitingView, null);
6329
+ ViewComponent = /* @__PURE__ */ React67.createElement(WaitingView, null);
5641
6330
  } else if (pdfAnnotatorActive) {
5642
- ViewComponent = /* @__PURE__ */ React62.createElement(PDFView, null);
6331
+ ViewComponent = /* @__PURE__ */ React67.createElement(PDFView, null);
5643
6332
  } else if (urlToIframe) {
5644
- ViewComponent = /* @__PURE__ */ React62.createElement(EmbedView, null);
6333
+ ViewComponent = /* @__PURE__ */ React67.createElement(EmbedView, null);
5645
6334
  } else {
5646
- ViewComponent = /* @__PURE__ */ React62.createElement(GridLayout, __spreadValues({}, (_a = elements == null ? void 0 : elements.video_tile_layout) == null ? void 0 : _a.grid));
6335
+ ViewComponent = /* @__PURE__ */ React67.createElement(GridLayout, __spreadValues({}, (_a = elements == null ? void 0 : elements.video_tile_layout) == null ? void 0 : _a.grid));
5647
6336
  }
5648
- return /* @__PURE__ */ React62.createElement(Suspense2, { fallback: /* @__PURE__ */ React62.createElement(FullPageProgress_default, null) }, /* @__PURE__ */ React62.createElement(
6337
+ return /* @__PURE__ */ React67.createElement(Suspense2, { fallback: /* @__PURE__ */ React67.createElement(FullPageProgress_default, null) }, /* @__PURE__ */ React67.createElement(
5649
6338
  Flex,
5650
6339
  {
5651
6340
  css: {
@@ -5655,7 +6344,7 @@ var VideoStreamingSection = ({
5655
6344
  }
5656
6345
  },
5657
6346
  ViewComponent,
5658
- /* @__PURE__ */ React62.createElement(
6347
+ /* @__PURE__ */ React67.createElement(
5659
6348
  SidePane_default,
5660
6349
  {
5661
6350
  screenType,
@@ -5674,17 +6363,17 @@ var Conference = () => {
5674
6363
  const { userName, endpoints } = useHMSPrebuiltContext();
5675
6364
  const screenProps = useRoomLayoutConferencingScreen();
5676
6365
  const { isPreviewScreenEnabled } = useRoomLayoutPreviewScreen();
5677
- const roomState = useHMSStore35(selectRoomState);
6366
+ const roomState = useHMSStore39(selectRoomState);
5678
6367
  const prevState = usePrevious(roomState);
5679
- const isConnectedToRoom = useHMSStore35(selectIsConnectedToRoom7);
5680
- const hmsActions = useHMSActions22();
5681
- const [hideControls, setHideControls] = useState35(false);
5682
- const dropdownList = useHMSStore35(selectAppData4(APP_DATA.dropdownList));
6368
+ const isConnectedToRoom = useHMSStore39(selectIsConnectedToRoom7);
6369
+ const hmsActions = useHMSActions25();
6370
+ const [hideControls, setHideControls] = useState39(false);
6371
+ const dropdownList = useHMSStore39(selectAppData4(APP_DATA.dropdownList));
5683
6372
  const authTokenInAppData = useAuthToken();
5684
- const headerRef = useRef14();
5685
- const footerRef = useRef14();
6373
+ const headerRef = useRef16();
6374
+ const footerRef = useRef16();
5686
6375
  const isMobileDevice = isAndroid || isIOS || isIPadOS;
5687
- const dropdownListRef = useRef14();
6376
+ const dropdownListRef = useRef16();
5688
6377
  const [isHLSStarted] = useSetAppDataByKey(APP_DATA.hlsStarted);
5689
6378
  const toggleControls = () => {
5690
6379
  var _a2;
@@ -5692,8 +6381,8 @@ var Conference = () => {
5692
6381
  setHideControls((value) => !value);
5693
6382
  }
5694
6383
  };
5695
- const autoRoomJoined = useRef14(isPreviewScreenEnabled);
5696
- useEffect25(() => {
6384
+ const autoRoomJoined = useRef16(isPreviewScreenEnabled);
6385
+ useEffect27(() => {
5697
6386
  let timeout = null;
5698
6387
  dropdownListRef.current = dropdownList || [];
5699
6388
  if (dropdownListRef.current.length === 0) {
@@ -5708,7 +6397,7 @@ var Conference = () => {
5708
6397
  clearTimeout(timeout);
5709
6398
  };
5710
6399
  }, [dropdownList, hideControls, isMobileDevice]);
5711
- useEffect25(() => {
6400
+ useEffect27(() => {
5712
6401
  if (!roomId) {
5713
6402
  navigate(`/`);
5714
6403
  return;
@@ -5723,7 +6412,7 @@ var Conference = () => {
5723
6412
  navigate(`/preview/${roomId || ""}`);
5724
6413
  }
5725
6414
  }, [isConnectedToRoom, prevState, roomState, navigate, role, roomId, isPreviewScreenEnabled]);
5726
- useEffect25(() => {
6415
+ useEffect27(() => {
5727
6416
  if (authTokenInAppData && !isConnectedToRoom && !isPreviewScreenEnabled && roomState !== HMSRoomState.Connecting && !autoRoomJoined.current) {
5728
6417
  hmsActions.join({
5729
6418
  userName,
@@ -5738,15 +6427,15 @@ var Conference = () => {
5738
6427
  autoRoomJoined.current = true;
5739
6428
  }
5740
6429
  }, [authTokenInAppData, endpoints == null ? void 0 : endpoints.init, hmsActions, isConnectedToRoom, isPreviewScreenEnabled, roomState, userName]);
5741
- useEffect25(() => {
6430
+ useEffect27(() => {
5742
6431
  return () => {
5743
6432
  PictureInPicture.stop().catch((error) => console.error("stopping pip", error));
5744
6433
  };
5745
6434
  }, []);
5746
6435
  if (!isConnectedToRoom) {
5747
- return /* @__PURE__ */ React63.createElement(FullPageProgress_default, { text: "Joining..." });
6436
+ return /* @__PURE__ */ React68.createElement(FullPageProgress_default, { text: "Joining..." });
5748
6437
  }
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(
6438
+ return /* @__PURE__ */ React68.createElement(React68.Fragment, null, isHLSStarted ? /* @__PURE__ */ React68.createElement(Box, { css: { position: "fixed", zIndex: 100, w: "100%", h: "100%", left: 0, top: 0 } }, /* @__PURE__ */ React68.createElement(FullPageProgress_default, { text: "Starting live stream...", css: { opacity: 0.8, bg: "$background_dim" } })) : null, /* @__PURE__ */ React68.createElement(Flex, { css: { size: "100%", overflow: "hidden" }, direction: "column" }, !screenProps.hideSections.includes("header") && /* @__PURE__ */ React68.createElement(
5750
6439
  Box,
5751
6440
  {
5752
6441
  ref: headerRef,
@@ -5760,8 +6449,8 @@ var Conference = () => {
5760
6449
  },
5761
6450
  "data-testid": "header"
5762
6451
  },
5763
- /* @__PURE__ */ React63.createElement(Header, { elements: screenProps.elements, screenType: screenProps.screenType })
5764
- ), /* @__PURE__ */ React63.createElement(
6452
+ /* @__PURE__ */ React68.createElement(Header, { elements: screenProps.elements, screenType: screenProps.screenType })
6453
+ ), /* @__PURE__ */ React68.createElement(
5765
6454
  Box,
5766
6455
  {
5767
6456
  css: {
@@ -5779,7 +6468,7 @@ var Conference = () => {
5779
6468
  "data-testid": "conferencing",
5780
6469
  onClick: toggleControls
5781
6470
  },
5782
- /* @__PURE__ */ React63.createElement(
6471
+ /* @__PURE__ */ React68.createElement(
5783
6472
  VideoStreamingSection,
5784
6473
  {
5785
6474
  screenType: screenProps.screenType,
@@ -5787,7 +6476,7 @@ var Conference = () => {
5787
6476
  hideControls
5788
6477
  }
5789
6478
  )
5790
- ), !screenProps.hideSections.includes("footer") && /* @__PURE__ */ React63.createElement(
6479
+ ), !screenProps.hideSections.includes("footer") && /* @__PURE__ */ React68.createElement(
5791
6480
  Box,
5792
6481
  {
5793
6482
  ref: footerRef,
@@ -5804,11 +6493,11 @@ var Conference = () => {
5804
6493
  },
5805
6494
  "data-testid": "footer"
5806
6495
  },
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)));
6496
+ /* @__PURE__ */ React68.createElement(Footer2, { elements: screenProps.elements, screenType: screenProps.screenType })
6497
+ ), /* @__PURE__ */ React68.createElement(RoleChangeRequestModal, null), /* @__PURE__ */ React68.createElement(HLSFailureModal, null), /* @__PURE__ */ React68.createElement(ActivatedPIP, null)));
5809
6498
  };
5810
6499
  var conference_default = Conference;
5811
6500
  export {
5812
6501
  conference_default as default
5813
6502
  };
5814
- //# sourceMappingURL=conference-JNABIZBG.js.map
6503
+ //# sourceMappingURL=conference-JD35TNH4.js.map